将设备列表,变量表列表,变量列表从ObservableCollection更换为字典类型的ObservableDictionary
This commit is contained in:
@@ -70,8 +70,8 @@ public class DataEventService : IDataEventService
|
||||
App.Current.Dispatcher.BeginInvoke(new Action(() =>
|
||||
{
|
||||
// 查找并更新对应的变量
|
||||
var variableToUpdate = _dataStorageService.Variables.FirstOrDefault(v => v.Id == e.VariableId);
|
||||
if (variableToUpdate != null)
|
||||
|
||||
if (_dataStorageService.Variables.TryGetValue(e.VariableId,out var variableToUpdate))
|
||||
{
|
||||
variableToUpdate.DataValue = e.NewValue;
|
||||
variableToUpdate.DisplayValue = e.NewValue;
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
using System.Collections.ObjectModel;
|
||||
using DMS.WPF.Interfaces;
|
||||
using DMS.WPF.ViewModels.Items;
|
||||
using ObservableCollections;
|
||||
|
||||
namespace DMS.WPF.Services;
|
||||
|
||||
@@ -11,17 +12,17 @@ public class DataStorageService : IDataStorageService
|
||||
/// <summary>
|
||||
/// 设备列表。
|
||||
/// </summary>
|
||||
public ObservableCollection<DeviceItemViewModel> Devices { get; set; }
|
||||
public ObservableDictionary<int,DeviceItemViewModel> Devices { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// 设备列表。
|
||||
/// </summary>
|
||||
public ObservableCollection<VariableTableItemViewModel> VariableTables { get; set; }
|
||||
public new ObservableDictionary<int,VariableTableItemViewModel> VariableTables { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// 变量数据列表。
|
||||
/// </summary>
|
||||
public ObservableCollection<VariableItemViewModel> Variables { get; set; }
|
||||
public ObservableDictionary<int,VariableItemViewModel> Variables { get; set; }
|
||||
|
||||
|
||||
/// <summary>
|
||||
@@ -46,9 +47,9 @@ public class DataStorageService : IDataStorageService
|
||||
|
||||
public DataStorageService()
|
||||
{
|
||||
Devices=new ObservableCollection<DeviceItemViewModel>();
|
||||
VariableTables = new ObservableCollection<VariableTableItemViewModel>();
|
||||
Variables=new ObservableCollection<VariableItemViewModel>();
|
||||
Devices=new ObservableDictionary<int,DeviceItemViewModel>();
|
||||
VariableTables = new ObservableDictionary<int,VariableTableItemViewModel>();
|
||||
Variables=new ObservableDictionary<int,VariableItemViewModel>();
|
||||
MqttServers=new ObservableCollection<MqttServerItemViewModel>();
|
||||
Menus=new ObservableCollection<MenuItemViewModel>();
|
||||
MenuTrees=new ObservableCollection<MenuItemViewModel>();
|
||||
|
||||
@@ -52,8 +52,8 @@ public class DeviceDataService : IDeviceDataService
|
||||
{
|
||||
_uiDispatcher.Invoke(() =>
|
||||
{
|
||||
var device = _dataStorageService.Devices.FirstOrDefault(d => d.Id == e.DeviceId);
|
||||
if (device != null)
|
||||
|
||||
if (_dataStorageService.Devices.TryGetValue(e.DeviceId,out DeviceItemViewModel device))
|
||||
{
|
||||
|
||||
device.IsRunning = e.NewStatus;
|
||||
@@ -76,7 +76,7 @@ public class DeviceDataService : IDeviceDataService
|
||||
{
|
||||
foreach (var deviceDto in _appDataStorageService.Devices.Values)
|
||||
{
|
||||
_dataStorageService.Devices.Add(_mapper.Map<DeviceItemViewModel>(deviceDto));
|
||||
_dataStorageService.Devices.Add(deviceDto.Id,_mapper.Map<DeviceItemViewModel>(deviceDto));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -95,7 +95,7 @@ public class DeviceDataService : IDeviceDataService
|
||||
if (_dataStorageService != null && addDto != null && addDto.Device != null)
|
||||
{
|
||||
//更新当前界面
|
||||
_dataStorageService.Devices.Add(_mapper.Map<DeviceItemViewModel>(addDto.Device));
|
||||
_dataStorageService.Devices.Add(addDto.Device.Id,_mapper.Map<DeviceItemViewModel>(addDto.Device));
|
||||
}
|
||||
|
||||
// 添加null检查
|
||||
@@ -163,9 +163,8 @@ public class DeviceDataService : IDeviceDataService
|
||||
_appDataCenterService.DeviceManagementService.RemoveDeviceFromMemory(device.Id);
|
||||
|
||||
// 删除设备
|
||||
_dataStorageService.Devices.Remove(device);
|
||||
|
||||
return true;
|
||||
|
||||
return _dataStorageService.Devices.Remove(device.Id);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
||||
@@ -38,9 +38,9 @@ public class VariableDataService : IVariableDataService
|
||||
{
|
||||
foreach (var variableTable in _dataStorageService.VariableTables)
|
||||
{
|
||||
foreach (var variable in variableTable.Variables)
|
||||
foreach (var variable in variableTable.Value.Variables)
|
||||
{
|
||||
_dataStorageService.Variables.Add(variable);
|
||||
_dataStorageService.Variables.Add(variable.Id,variable);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -130,13 +130,13 @@ public class VariableDataService : IVariableDataService
|
||||
// 删除与当前变量表关联的所有变量
|
||||
foreach (var variable in variableTable.Variables)
|
||||
{
|
||||
_dataStorageService.Variables.Remove(variable);
|
||||
_dataStorageService.Variables.Remove(variable.Id);
|
||||
}
|
||||
|
||||
_appDataCenterService.VariableTableManagementService.RemoveVariableTableFromMemory(variableTable.Id);
|
||||
|
||||
// 删除变量表
|
||||
_dataStorageService.VariableTables.Remove(variableTable);
|
||||
_dataStorageService.VariableTables.Remove(variableTable.Id);
|
||||
variableTable.Device.VariableTables.Remove(variableTable);
|
||||
return true;
|
||||
}
|
||||
@@ -151,7 +151,7 @@ public class VariableDataService : IVariableDataService
|
||||
return;
|
||||
}
|
||||
|
||||
_dataStorageService.Variables.Add(variableItem);
|
||||
_dataStorageService.Variables.Add(variableItem.Id,variableItem);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -159,16 +159,16 @@ public class VariableDataService : IVariableDataService
|
||||
/// </summary>
|
||||
public void DeleteVariable(int id)
|
||||
{
|
||||
var variableItem = _dataStorageService.Variables.FirstOrDefault(v => v.Id == id);
|
||||
if (variableItem == null)
|
||||
if (!_dataStorageService.Variables.TryGetValue(id,out var variableItem))
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
var variableTable = _dataStorageService.VariableTables.FirstOrDefault(vt => vt.Id == variableItem.VariableTableId);
|
||||
if (_dataStorageService.VariableTables.TryGetValue(variableItem.VariableTableId, out var variableTable))
|
||||
{
|
||||
variableTable.Variables.Remove(variableItem);
|
||||
}
|
||||
|
||||
variableTable.Variables.Remove(variableItem);
|
||||
|
||||
_dataStorageService.Variables.Remove(variableItem);
|
||||
_dataStorageService.Variables.Remove(variableItem.Id);
|
||||
}
|
||||
}
|
||||
@@ -34,9 +34,9 @@ public class VariableTableDataService : IVariableTableDataService
|
||||
{
|
||||
foreach (var device in _dataStorageService.Devices)
|
||||
{
|
||||
foreach (var variableTable in device.VariableTables)
|
||||
foreach (var variableTable in device.Value.VariableTables)
|
||||
{
|
||||
_dataStorageService.VariableTables.Add(variableTable);
|
||||
_dataStorageService.VariableTables.Add(variableTable.Id,variableTable);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -117,7 +117,7 @@ public class VariableTableDataService : IVariableTableDataService
|
||||
// 删除与当前变量表关联的所有变量
|
||||
foreach (var variable in variableTable.Variables)
|
||||
{
|
||||
_dataStorageService.Variables.Remove(variable);
|
||||
_dataStorageService.Variables.Remove(variable.Id);
|
||||
}
|
||||
|
||||
_appDataCenterService.VariableTableManagementService.RemoveVariableTableFromMemory(variableTable.Id);
|
||||
@@ -126,7 +126,7 @@ public class VariableTableDataService : IVariableTableDataService
|
||||
=_dataStorageService.Menus.FirstOrDefault(m => m.MenuType == MenuType.VariableTableMenu && m.TargetId == variableTable.Id);
|
||||
_menuDataService.DeleteMenuItem(variableTableMenu);
|
||||
// 删除变量表
|
||||
_dataStorageService.VariableTables.Remove(variableTable);
|
||||
_dataStorageService.VariableTables.Remove(variableTable.Id);
|
||||
variableTable.Device.VariableTables.Remove(variableTable);
|
||||
return true;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user