修复删除变量表和更改变量表,菜单不同步的问题
This commit is contained in:
@@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user