修复删除变量表和更改变量表,菜单不同步的问题

This commit is contained in:
2025-07-16 20:15:39 +08:00
parent 9fb9e53331
commit b596887f6e
2 changed files with 85 additions and 17 deletions

View File

@@ -96,4 +96,30 @@ public class DataServicesHelper
return navgateVM; return navgateVM;
} }
public static MenuBean FindVarTableMenu(int varTableId, List<MenuBean> menus)
{
if (menus == null)
{
return null;
}
foreach (var menu in menus)
{
// 检查当前菜单项是否匹配
if (menu.Type==MenuType.VariableTableMenu && menu.DataId ==varTableId)
{
return menu;
}
// 递归搜索子菜单
var foundInSubMenu = FindVarTableMenu(varTableId, menu.Items);
if (foundInSubMenu != null)
{
return foundInSubMenu;
}
}
return null;
}
} }

View File

@@ -24,7 +24,8 @@ public partial class DeviceDetailViewModel : ViewModelBase
[ObservableProperty] [ObservableProperty]
private VariableTable _selectedVariableTable; private VariableTable _selectedVariableTable;
public DeviceDetailViewModel(IDialogService dialogService, VarTableRepository varTableRepository, MenuRepository menuRepository, DataServices dataServices) public DeviceDetailViewModel(IDialogService dialogService, VarTableRepository varTableRepository,
MenuRepository menuRepository, DataServices dataServices)
{ {
_dialogService = dialogService; _dialogService = dialogService;
_varTableRepository = varTableRepository; _varTableRepository = varTableRepository;
@@ -49,7 +50,6 @@ public partial class DeviceDetailViewModel : ViewModelBase
[RelayCommand] [RelayCommand]
private async Task AddVariableTable() private async Task AddVariableTable()
{ {
using var db = DbContext.GetInstance(); using var db = DbContext.GetInstance();
try try
{ {
@@ -91,7 +91,7 @@ public partial class DeviceDetailViewModel : ViewModelBase
await db.CommitTranAsync(); await db.CommitTranAsync();
// 8. Update UI // 8. Update UI
CurrentDevice.VariableTables.Add(addedVarTable); CurrentDevice?.VariableTables?.Add(addedVarTable);
MessageHelper.SendLoadMessage(Enums.LoadTypes.Menu); // Refresh the main navigation menu MessageHelper.SendLoadMessage(Enums.LoadTypes.Menu); // Refresh the main navigation menu
NotificationHelper.ShowSuccess($"变量表 {addedVarTable.Name} 添加成功。"); NotificationHelper.ShowSuccess($"变量表 {addedVarTable.Name} 添加成功。");
} }
@@ -111,25 +111,44 @@ public partial class DeviceDetailViewModel : ViewModelBase
return; return;
} }
using var db = DbContext.GetInstance();
try try
{ {
var originalName = SelectedVariableTable.Name; // Store original name for comparison
var editedVarTable = await _dialogService.ShowEditVarTableDialog(SelectedVariableTable); var editedVarTable = await _dialogService.ShowEditVarTableDialog(SelectedVariableTable);
if (editedVarTable == null) return; if (editedVarTable == null) return;
// The dialog already updated the SelectedVariableTable if it returned a non-null value await db.BeginTranAsync();
// So we just need to save it to the database
var result = await _varTableRepository.UpdateAsync(SelectedVariableTable); // Update variable table in DB
var result = await _varTableRepository.UpdateAsync(SelectedVariableTable, db);
if (result > 0) if (result > 0)
{ {
// Update corresponding menu item if name changed
if (originalName != SelectedVariableTable.Name)
{
var menu = DataServicesHelper.FindVarTableMenu(SelectedVariableTable.Id, _dataServices.MenuTrees);
if (menu != null)
{
menu.Name = SelectedVariableTable.Name;
await _menuRepository.UpdateAsync(menu, db);
}
}
await db.CommitTranAsync();
NotificationHelper.ShowSuccess($"变量表 {SelectedVariableTable.Name} 编辑成功。"); NotificationHelper.ShowSuccess($"变量表 {SelectedVariableTable.Name} 编辑成功。");
MessageHelper.SendLoadMessage(Enums.LoadTypes.Menu); // Refresh the main navigation menu
} }
else else
{ {
await db.RollbackTranAsync();
NotificationHelper.ShowError($"变量表 {SelectedVariableTable.Name} 编辑失败。"); NotificationHelper.ShowError($"变量表 {SelectedVariableTable.Name} 编辑失败。");
} }
} }
catch (Exception ex) catch (Exception ex)
{ {
await db.RollbackTranAsync();
NotificationHelper.ShowError($"编辑变量表时发生错误: {ex.Message}", ex); NotificationHelper.ShowError($"编辑变量表时发生错误: {ex.Message}", ex);
} }
} }
@@ -150,21 +169,44 @@ public partial class DeviceDetailViewModel : ViewModelBase
if (!confirm) return; if (!confirm) return;
using var db = DbContext.GetInstance();
try try
{ {
var result = await _varTableRepository.DeleteAsync(SelectedVariableTable); await db.BeginTranAsync();
// Find the corresponding menu item
MenuBean menuToDelete = null;
if (_dataServices.MenuTrees != null)
{
menuToDelete = DataServicesHelper.FindVarTableMenu( SelectedVariableTable.Id,_dataServices.MenuTrees);
}
// Delete variable table from DB
var result = await _varTableRepository.DeleteAsync(SelectedVariableTable, db);
if (result > 0) if (result > 0)
{ {
CurrentDevice.VariableTables.Remove(SelectedVariableTable); // Delete corresponding menu item
NotificationHelper.ShowSuccess($"变量表 {SelectedVariableTable.Name} 删除成功。"); if (menuToDelete != null)
{
await _menuRepository.DeleteAsync(menuToDelete, db);
}
await db.CommitTranAsync();
var delVarTableName = SelectedVariableTable.Name;
CurrentDevice?.VariableTables?.Remove(SelectedVariableTable);
NotificationHelper.ShowSuccess($"变量表 {delVarTableName} 删除成功。");
MessageHelper.SendLoadMessage(Enums.LoadTypes.Menu); // Refresh the main navigation menu
} }
else else
{ {
await db.RollbackTranAsync();
NotificationHelper.ShowError($"变量表 {SelectedVariableTable.Name} 删除失败。"); NotificationHelper.ShowError($"变量表 {SelectedVariableTable.Name} 删除失败。");
} }
} }
catch (Exception ex) catch (Exception ex)
{ {
await db.RollbackTranAsync();
NotificationHelper.ShowError($"删除变量表时发生错误: {ex.Message}", ex); NotificationHelper.ShowError($"删除变量表时发生错误: {ex.Message}", ex);
} }
} }