给应用添加图标,完成给设备添加变量表的功能

This commit is contained in:
2025-07-02 12:01:20 +08:00
parent 663e4fda0c
commit dbf7b81d4b
20 changed files with 326 additions and 151 deletions

View File

@@ -21,6 +21,7 @@ public partial class DataServices : ObservableRecipient, IRecipient<LoadMessage>
private readonly DeviceRepository _deviceRepository;
private readonly MenuRepository _menuRepository;
public event Action<List<Device>> OnDeviceListChanged;
public event Action<List<MenuBean>> OnMenuTreeListChanged;
@@ -28,19 +29,11 @@ public partial class DataServices : ObservableRecipient, IRecipient<LoadMessage>
partial void OnDevicesChanged(List<Device> devices)
{
OnDeviceListChanged?.Invoke(devices);
if (menuTrees != null && Devices != null)
{
FillMenuData(MenuTrees, Devices);
}
}
partial void OnMenuTreesChanged(List<MenuBean> MenuTrees)
{
OnMenuTreeListChanged?.Invoke(MenuTrees);
if (MenuTrees != null && Devices != null)
{
FillMenuData(MenuTrees, Devices);
}
}
@@ -53,77 +46,6 @@ public partial class DataServices : ObservableRecipient, IRecipient<LoadMessage>
}
/// <summary>
/// 给Menu菜单的Data填充数据
/// </summary>
/// <param name="MenuTrees"></param>
private void FillMenuData(List<MenuBean> MenuTrees, List<Device> devices)
{
if (MenuTrees == null || MenuTrees.Count == 0)
return;
foreach (MenuBean menuBean in MenuTrees)
{
switch (menuBean.Type)
{
case MenuType.MainMenu:
menuBean.ViewModel =DataServicesHelper.GetMainViewModel(menuBean.Name);
break;
case MenuType.DeviceMenu:
menuBean.ViewModel = App.Current.Services.GetRequiredService<DeviceDetailViewModel>();
menuBean.Data = devices.FirstOrDefault(d => d.Id == menuBean.DataId);
break;
case MenuType.VariableTableMenu:
var varTableVM = App.Current.Services.GetRequiredService<VariableTableViewModel>();
varTableVM.VariableTable = FindVarTableForDevice(menuBean.DataId);
menuBean.ViewModel = varTableVM;
menuBean.Data = varTableVM.VariableTable;
break;
case MenuType.AddVariableTableMenu:
break;
}
if (menuBean.Items != null && menuBean.Items.Count > 0)
{
FillMenuData(menuBean.Items, devices);
}
}
}
/// <summary>
/// 查找设备所对应的菜单对象
/// </summary>
/// <param name="device"></param>
/// <returns></returns>
public async Task<int> UpdateMenuForDevice(Device device)
{
var menu= DataServicesHelper.FindMenusForDevice(device, MenuTrees);
if (menu != null)
return await _menuRepository.Edit(menu);
return 0;
}
/// <summary>
/// 从设备列表中找到变量表VarTable对象
/// </summary>
/// <param name="vtableId">VarTable的ID</param>
/// <returns>如果找到择返回对象否则返回null</returns>
private VariableTable FindVarTableForDevice(int vtableId)
{
VariableTable varTable = null;
foreach (var device in _devices)
{
varTable = device.VariableTables.FirstOrDefault(v => v.Id == vtableId);
if (varTable != null)
return varTable;
}
return varTable;
}
/// <summary>
/// 接受加载消息,收到消息后从数据库加载对应的数据
/// </summary>
@@ -131,18 +53,16 @@ public partial class DataServices : ObservableRecipient, IRecipient<LoadMessage>
/// <exception cref="ArgumentException"></exception>
public async void Receive(LoadMessage message)
{
if (!(message.Value is LoadTypes))
throw new ArgumentException($"接受到的加载类型错误:{message.Value}");
try
{
switch ((LoadTypes)message.Value)
switch (message.LoadType)
{
case LoadTypes.All:
Devices = await _deviceRepository.GetAll();
await LoadDevices();
await LoadMenus();
break;
case LoadTypes.Devices:
Devices = await _deviceRepository.GetAll();
await LoadDevices();
break;
case LoadTypes.Menu:
await LoadMenus();
@@ -156,24 +76,18 @@ public partial class DataServices : ObservableRecipient, IRecipient<LoadMessage>
}
}
private async Task LoadDevices()
{
Devices = await _deviceRepository.GetAll();
}
private async Task LoadMenus()
{
MenuTrees = await _menuRepository.GetMenuTrees();
foreach (MenuBean menu in MenuTrees)
{
MenuHelper.MenuAddParent(menu);
DataServicesHelper.SortMenus(menu);
}
}
public async Task<int> DeleteMenuForDevice(Device device)
{
var menu= DataServicesHelper.FindMenusForDevice(device, MenuTrees);
if (menu != null)
{
return await _menuRepository.DeleteMenu(menu);
}
return 0;
}
}