Refactor:
- 重构了 VariableTableDataService 中的 AddVariableTable 方法,使其返回值从 bool 变为新表的 ID (int)。这使得服务层更加健壮,并能向调用方提供新创建实体的确切ID。 Fix: - 修复了 DeviceDetailViewModel 在创建变量表后UI不自动更新的Bug。现在视图模型会正确地将新表添加到UI集合中,确保了界面的即时刷新。 Feat: - 为 DeviceDetailViewModel 添加了 IsBusy 状态。现在“添加”、“编辑”和“删除”等异步操作会更新此状态,防止了用户重复点击,并允许UI在处理期间显示加载指示,提升了用户体验。
This commit is contained in:
@@ -9,7 +9,7 @@ public interface IVariableTableDataService
|
|||||||
|
|
||||||
void LoadAllVariableTables();
|
void LoadAllVariableTables();
|
||||||
|
|
||||||
Task<bool> AddVariableTable(VariableTableDto variableTableDto,
|
Task<int> AddVariableTable(VariableTableDto variableTableDto,
|
||||||
MenuBeanDto menuDto = null, bool isAddDb = false);
|
MenuBeanDto menuDto = null, bool isAddDb = false);
|
||||||
|
|
||||||
Task<bool> UpdateVariableTable(VariableTableItemViewModel variableTable);
|
Task<bool> UpdateVariableTable(VariableTableItemViewModel variableTable);
|
||||||
|
|||||||
@@ -14,8 +14,6 @@ public class VariableTableDataService : IVariableTableDataService
|
|||||||
private readonly IDataStorageService _dataStorageService;
|
private readonly IDataStorageService _dataStorageService;
|
||||||
private readonly IAppDataCenterService _appDataCenterService;
|
private readonly IAppDataCenterService _appDataCenterService;
|
||||||
private readonly IMenuDataService _menuDataService;
|
private readonly IMenuDataService _menuDataService;
|
||||||
// Removed circular dependency by not injecting IDeviceDataService
|
|
||||||
// private readonly IDeviceDataService _deviceDataService;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -40,11 +38,11 @@ public class VariableTableDataService : IVariableTableDataService
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<bool> AddVariableTable(VariableTableDto variableTableDto,
|
public async Task<int> AddVariableTable(VariableTableDto variableTableDto,
|
||||||
MenuBeanDto menuDto = null, bool isAddDb = false)
|
MenuBeanDto menuDto = null, bool isAddDb = false)
|
||||||
{
|
{
|
||||||
if (variableTableDto == null)
|
if (variableTableDto == null)
|
||||||
return false;
|
return 0;
|
||||||
|
|
||||||
if (isAddDb && menuDto != null)
|
if (isAddDb && menuDto != null)
|
||||||
{
|
{
|
||||||
@@ -53,22 +51,14 @@ public class VariableTableDataService : IVariableTableDataService
|
|||||||
createDto.DeviceId = variableTableDto.DeviceId;
|
createDto.DeviceId = variableTableDto.DeviceId;
|
||||||
createDto.Menu = menuDto;
|
createDto.Menu = menuDto;
|
||||||
var resDto = await _appDataCenterService.VariableTableManagementService.CreateVariableTableAsync(createDto);
|
var resDto = await _appDataCenterService.VariableTableManagementService.CreateVariableTableAsync(createDto);
|
||||||
_mapper.Map(resDto.VariableTable, variableTableDto);
|
|
||||||
_menuDataService.AddMenuItem(_mapper.Map<MenuItemViewModel>(resDto.Menu));
|
_menuDataService.AddMenuItem(_mapper.Map<MenuItemViewModel>(resDto.Menu));
|
||||||
|
return resDto.VariableTable.Id;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 添加变量表到内存的操作现在在服务内部完成,无需额外调用
|
|
||||||
|
|
||||||
// var device = _deviceDataService.Devices.FirstOrDefault(d => d.Id == variableTableDto.DeviceId);
|
|
||||||
// if (device != null)
|
|
||||||
// {
|
|
||||||
// var variableTableItemViewModel = _mapper.Map<VariableTableItemViewModel>(variableTableDto);
|
|
||||||
// variableTableItemViewModel.Device = device;
|
|
||||||
// device.VariableTables.Add(variableTableItemViewModel);
|
|
||||||
// VariableTables.Add(variableTableItemViewModel);
|
|
||||||
// }
|
|
||||||
|
|
||||||
return true;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -28,11 +28,14 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
[ObservableProperty]
|
[ObservableProperty]
|
||||||
private VariableTableItemViewModel _selectedVariableTable;
|
private VariableTableItemViewModel _selectedVariableTable;
|
||||||
|
|
||||||
private readonly INotificationService _notificationService;
|
[ObservableProperty]
|
||||||
|
private bool _isBusy;
|
||||||
|
|
||||||
|
|
||||||
public DeviceDetailViewModel(IMapper mapper, IDialogService dialogService,IDataStorageService dataStorageService ,INavigationService navigationService,
|
private readonly INotificationService _notificationService;
|
||||||
|
|
||||||
|
|
||||||
|
public DeviceDetailViewModel(IMapper mapper, IDialogService dialogService, IDataStorageService dataStorageService,
|
||||||
|
INavigationService navigationService,
|
||||||
IWPFDataService wpfDataService, INotificationService notificationService)
|
IWPFDataService wpfDataService, INotificationService notificationService)
|
||||||
{
|
{
|
||||||
_mapper = mapper;
|
_mapper = mapper;
|
||||||
@@ -46,6 +49,8 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private async Task AddVariableTable()
|
private async Task AddVariableTable()
|
||||||
{
|
{
|
||||||
|
if (IsBusy) return;
|
||||||
|
IsBusy = true;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
VariableTableDialogViewModel variableTableDialogViewModel = new VariableTableDialogViewModel()
|
VariableTableDialogViewModel variableTableDialogViewModel = new VariableTableDialogViewModel()
|
||||||
@@ -61,33 +66,47 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
variableTableItemViewModel.DeviceId = CurrentDevice.Id;
|
variableTableItemViewModel.DeviceId = CurrentDevice.Id;
|
||||||
var tableMenu = new MenuBeanDto()
|
var tableMenu = new MenuBeanDto()
|
||||||
{
|
{
|
||||||
Header = variableTableItemViewModel.Name,
|
Header = variableTableItemViewModel.Name,
|
||||||
Icon = SegoeFluentIcons.DataSense.Glyph,
|
Icon = SegoeFluentIcons.DataSense.Glyph,
|
||||||
TargetViewKey = "VariableTableView"
|
TargetViewKey = "VariableTableView"
|
||||||
};
|
};
|
||||||
|
int addVarTableId = await _wpfDataService.VariableTableDataService.AddVariableTable(
|
||||||
|
_mapper.Map<VariableTableDto>(variableTableItemViewModel),
|
||||||
|
tableMenu, true);
|
||||||
|
|
||||||
if (await _wpfDataService.VariableTableDataService.AddVariableTable(_mapper.Map<VariableTableDto>(variableTableItemViewModel),
|
if (addVarTableId > 0)
|
||||||
tableMenu, true))
|
{
|
||||||
{
|
variableTableItemViewModel.Id = addVarTableId;
|
||||||
_notificationService.ShowSuccess($"添加变量表成功:{variableTableItemViewModel.Name}");
|
if (_dataStorageService.Devices.TryGetValue(variableTableItemViewModel.DeviceId, out var device))
|
||||||
}
|
{
|
||||||
else
|
variableTableItemViewModel.Device = device;
|
||||||
{
|
}
|
||||||
_notificationService.ShowError($"添加变量表失败:{variableTableItemViewModel.Name}!!");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
_notificationService.ShowSuccess($"添加变量表成功:{variableTableItemViewModel.Name}");
|
||||||
|
CurrentDevice.VariableTables.Add(variableTableItemViewModel);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_notificationService.ShowError($"添加变量表失败:{variableTableItemViewModel.Name}!!");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
_notificationService.ShowError($"添加变量表时发生错误: {ex.Message}", ex);
|
_notificationService.ShowError($"添加变量表时发生错误: {ex.Message}", ex);
|
||||||
}
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
IsBusy = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private async Task EditVariableTable()
|
private async Task EditVariableTable()
|
||||||
{
|
{
|
||||||
|
if (IsBusy) return;
|
||||||
|
IsBusy = true;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (SelectedVariableTable == null)
|
if (SelectedVariableTable == null)
|
||||||
@@ -96,12 +115,14 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
VariableTableDialogViewModel variableTableDialogViewModel = new VariableTableDialogViewModel(SelectedVariableTable)
|
VariableTableDialogViewModel variableTableDialogViewModel
|
||||||
{
|
= new VariableTableDialogViewModel(SelectedVariableTable)
|
||||||
PrimaryButText = "编辑变量表"
|
{
|
||||||
};
|
PrimaryButText = "编辑变量表"
|
||||||
|
};
|
||||||
// 1. 显示变量表对话框
|
// 1. 显示变量表对话框
|
||||||
VariableTableItemViewModel variableTable = await _dialogService.ShowDialogAsync(variableTableDialogViewModel);
|
VariableTableItemViewModel variableTable
|
||||||
|
= await _dialogService.ShowDialogAsync(variableTableDialogViewModel);
|
||||||
// 如果用户取消或对话框未返回变量表,则直接返回
|
// 如果用户取消或对话框未返回变量表,则直接返回
|
||||||
if (variableTable == null)
|
if (variableTable == null)
|
||||||
{
|
{
|
||||||
@@ -121,13 +142,19 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
{
|
{
|
||||||
_notificationService.ShowError($"编辑变量表的过程中发生错误:{e.Message}", e);
|
_notificationService.ShowError($"编辑变量表的过程中发生错误:{e.Message}", e);
|
||||||
}
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
IsBusy = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private async Task DeleteVariableTable()
|
private async Task DeleteVariableTable()
|
||||||
{
|
{
|
||||||
|
if (IsBusy) return;
|
||||||
|
IsBusy = true;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (SelectedVariableTable == null)
|
if (SelectedVariableTable == null)
|
||||||
{
|
{
|
||||||
_notificationService.ShowError("你没有选择任何变量表,请选择变量表后再点击删除变量表");
|
_notificationService.ShowError("你没有选择任何变量表,请选择变量表后再点击删除变量表");
|
||||||
@@ -135,11 +162,11 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
string message = $"确认要删除变量表名为:{SelectedVariableTable.Name} \n\n此操作将同时删除该变量表下的所有变量数据,且无法恢复!";
|
string message = $"确认要删除变量表名为:{SelectedVariableTable.Name} \n\n此操作将同时删除该变量表下的所有变量数据,且无法恢复!";
|
||||||
ConfirmDialogViewModel viewModel = new ConfirmDialogViewModel("删除变量表",message,"删除");
|
ConfirmDialogViewModel viewModel = new ConfirmDialogViewModel("删除变量表", message, "删除");
|
||||||
if (await _dialogService.ShowDialogAsync(viewModel))
|
if (await _dialogService.ShowDialogAsync(viewModel))
|
||||||
{
|
{
|
||||||
var tableName = SelectedVariableTable.Name;
|
var tableName = SelectedVariableTable.Name;
|
||||||
if (await _wpfDataService.VariableDataService.DeleteVariableTable(SelectedVariableTable,true))
|
if (await _wpfDataService.VariableDataService.DeleteVariableTable(SelectedVariableTable, true))
|
||||||
{
|
{
|
||||||
_notificationService.ShowSuccess($"变量表:{tableName},删除成功。");
|
_notificationService.ShowSuccess($"变量表:{tableName},删除成功。");
|
||||||
}
|
}
|
||||||
@@ -153,13 +180,16 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
{
|
{
|
||||||
_notificationService.ShowError($"删除变量表的过程中发生错误:{e.Message}", e);
|
_notificationService.ShowError($"删除变量表的过程中发生错误:{e.Message}", e);
|
||||||
}
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
IsBusy = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public async Task OnNavigatedToAsync(MenuItemViewModel menu)
|
public async Task OnNavigatedToAsync(MenuItemViewModel menu)
|
||||||
{
|
{
|
||||||
if (_dataStorageService.Devices.TryGetValue(menu.TargetId,out var device))
|
if (_dataStorageService.Devices.TryGetValue(menu.TargetId, out var device))
|
||||||
{
|
{
|
||||||
CurrentDevice = device;
|
CurrentDevice = device;
|
||||||
}
|
}
|
||||||
@@ -174,4 +204,4 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
if (menu == null) return;
|
if (menu == null) return;
|
||||||
_navigationService.NavigateToAsync(menu);
|
_navigationService.NavigateToAsync(menu);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user