refactor:完成变量表的重构添加,删除,更新
This commit is contained in:
@@ -50,36 +50,49 @@ public class VariableTableManagementService : IVariableTableManagementService
|
||||
/// <summary>
|
||||
/// 异步创建一个新变量表及其关联菜单(事务性操作)。
|
||||
/// </summary>
|
||||
public async Task<CreateVariableTableWithMenuDto> CreateVariableTableAsync(CreateVariableTableWithMenuDto dto)
|
||||
public async Task<CreateVariableTableWithMenuDto> AddAsync(CreateVariableTableWithMenuDto dto)
|
||||
{
|
||||
var result = await _variableTableAppService.CreateVariableTableAsync(dto);
|
||||
|
||||
// 创建成功后,将变量表添加到内存中
|
||||
if (result?.VariableTable != null)
|
||||
|
||||
var result = await _variableTableAppService.AddAsync(dto);
|
||||
|
||||
// 检查结果是否为空
|
||||
if (result?.VariableTable is null)
|
||||
{
|
||||
// 添加null检查
|
||||
if (_appDataService.Devices != null &&
|
||||
_appDataService.Devices.TryGetValue(result.VariableTable.DeviceId, out var device))
|
||||
{
|
||||
// 确保VariableTables不为null
|
||||
if (device.VariableTables == null)
|
||||
device.VariableTables = new List<VariableTable>();
|
||||
return null;
|
||||
}
|
||||
|
||||
device.VariableTables.Add(result.VariableTable);
|
||||
// 获取设备对象
|
||||
if (!_appDataService.Devices.TryGetValue(result.VariableTable.DeviceId, out var device))
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
// 确保Device属性不为null
|
||||
if (result.VariableTable != null)
|
||||
result.VariableTable.Device = device;
|
||||
}
|
||||
// 将变量表添加到设备列表并设置设备引用
|
||||
device.VariableTables.Add(result.VariableTable);
|
||||
result.VariableTable.Device = device;
|
||||
|
||||
// 确保_variableTables和result.VariableTable不为null
|
||||
if (_appDataService.VariableTables.TryAdd(result.VariableTable.Id, result.VariableTable))
|
||||
{
|
||||
_eventService.RaiseVariableTableChanged(this, new VariableTableChangedEventArgs(
|
||||
// 尝试将变量表添加到内存中
|
||||
if (!_appDataService.VariableTables.TryAdd(result.VariableTable.Id, result.VariableTable))
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
// 如果有菜单对象,则处理菜单相关逻辑
|
||||
if (result.Menu is null) return null;
|
||||
|
||||
var deviceMenu = _appDataService.Menus.Values.FirstOrDefault(m => m.MenuType == MenuType.DeviceMenu && m.TargetId == device.Id);
|
||||
if (deviceMenu is not null)
|
||||
{
|
||||
_appDataService.Menus.TryAdd(result.Menu.Id, result.Menu);
|
||||
//将设备菜单添加到根菜单中
|
||||
deviceMenu.Children.Add(result.Menu);
|
||||
}
|
||||
|
||||
// 触发变量表变化事件
|
||||
_eventService.RaiseVariableTableChanged(this, new VariableTableChangedEventArgs(
|
||||
DataChangeType.Added,
|
||||
result.VariableTable));
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
@@ -87,9 +100,9 @@ public class VariableTableManagementService : IVariableTableManagementService
|
||||
/// <summary>
|
||||
/// 异步更新一个已存在的变量表。
|
||||
/// </summary>
|
||||
public async Task<int> UpdateVariableTableAsync(VariableTable variableTable)
|
||||
public async Task<int> UpdateAsync(VariableTable variableTable)
|
||||
{
|
||||
var result = await _variableTableAppService.UpdateVariableTableAsync(variableTable);
|
||||
var result = await _variableTableAppService.UpdateAsync(variableTable);
|
||||
|
||||
// 更新成功后,更新内存中的变量表
|
||||
if (result > 0 && variableTable != null)
|
||||
@@ -106,25 +119,37 @@ public class VariableTableManagementService : IVariableTableManagementService
|
||||
/// <summary>
|
||||
/// 异步删除一个变量表。
|
||||
/// </summary>
|
||||
public async Task<bool> DeleteVariableTableAsync(int id)
|
||||
public async Task<bool> DeleteAsync(VariableTable variableTable)
|
||||
{
|
||||
var result = await _variableTableAppService.DeleteVariableTableAsync(id);
|
||||
var result = await _variableTableAppService.DeleteAsync(variableTable);
|
||||
|
||||
// 删除成功后,从内存中移除变量表
|
||||
if (result )
|
||||
if (result)
|
||||
{
|
||||
if (_appDataService.VariableTables.TryRemove(id, out var variableTable))
|
||||
if (_appDataService.Devices.TryGetValue(variableTable.DeviceId, out var device))
|
||||
{
|
||||
if (variableTable != null && _appDataService.Devices.TryGetValue(variableTable.DeviceId, out var device))
|
||||
device.VariableTables.Remove(variableTable);
|
||||
|
||||
_appDataService.VariableTables.TryRemove(variableTable.Id, out _);
|
||||
|
||||
//删除菜单
|
||||
var variableTableMenu = _appDataService.Menus.Values.FirstOrDefault(m => m.MenuType == MenuType.VariableTableMenu && m.TargetId == variableTable.Id);
|
||||
if (variableTableMenu is not null)
|
||||
{
|
||||
if (device.VariableTables != null)
|
||||
device.VariableTables.Remove(variableTable);
|
||||
if (_appDataService.Menus.TryGetValue(variableTableMenu.ParentId, out var deviceMenu))
|
||||
{
|
||||
deviceMenu.Children.Remove(variableTableMenu);
|
||||
}
|
||||
|
||||
|
||||
_appDataService.Menus.TryRemove(variableTableMenu.Id, out _);
|
||||
}
|
||||
|
||||
_eventService.RaiseVariableTableChanged(this, new VariableTableChangedEventArgs(
|
||||
DataChangeType.Deleted,
|
||||
variableTable));
|
||||
}
|
||||
|
||||
_eventService.RaiseVariableTableChanged(this, new VariableTableChangedEventArgs(
|
||||
DataChangeType.Deleted,
|
||||
variableTable));
|
||||
}
|
||||
|
||||
return result;
|
||||
|
||||
Reference in New Issue
Block a user