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;
|
||||||
|
|
||||||
|
[ObservableProperty]
|
||||||
|
private bool _isBusy;
|
||||||
|
|
||||||
private readonly INotificationService _notificationService;
|
private readonly INotificationService _notificationService;
|
||||||
|
|
||||||
|
|
||||||
|
public DeviceDetailViewModel(IMapper mapper, IDialogService dialogService, IDataStorageService dataStorageService,
|
||||||
public DeviceDetailViewModel(IMapper mapper, IDialogService dialogService,IDataStorageService dataStorageService ,INavigationService navigationService,
|
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()
|
||||||
@@ -67,27 +72,41 @@ public partial class DeviceDetailViewModel : ViewModelBase, INavigatable
|
|||||||
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;
|
||||||
|
if (_dataStorageService.Devices.TryGetValue(variableTableItemViewModel.DeviceId, out var device))
|
||||||
|
{
|
||||||
|
variableTableItemViewModel.Device = device;
|
||||||
|
}
|
||||||
|
|
||||||
_notificationService.ShowSuccess($"添加变量表成功:{variableTableItemViewModel.Name}");
|
_notificationService.ShowSuccess($"添加变量表成功:{variableTableItemViewModel.Name}");
|
||||||
|
CurrentDevice.VariableTables.Add(variableTableItemViewModel);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_notificationService.ShowError($"添加变量表失败:{variableTableItemViewModel.Name}!!");
|
_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,11 +142,17 @@ 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)
|
||||||
@@ -153,8 +180,11 @@ 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)
|
||||||
|
|||||||
Reference in New Issue
Block a user