Files
DMS/Services/DataServices.cs

206 lines
6.9 KiB
C#
Raw Normal View History

using AutoMapper;
using CommunityToolkit.Mvvm.ComponentModel;
using CommunityToolkit.Mvvm.Messaging;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using PMSWPF.Data.Repositories;
using PMSWPF.Enums;
using PMSWPF.Helper;
using PMSWPF.Message;
using PMSWPF.Models;
using PMSWPF.ViewModels;
2025-07-01 21:34:20 +08:00
using SqlSugar;
namespace PMSWPF.Services;
/// <summary>
/// 数据服务类,负责从数据库加载和管理各种数据,并提供数据变更通知。
/// 继承自ObservableRecipient可以接收消息实现IRecipient<LoadMessage>,处理加载消息。
/// </summary>
2025-06-30 13:06:51 +08:00
public partial class DataServices : ObservableRecipient, IRecipient<LoadMessage>
{
private readonly IMapper _mapper;
// 设备列表使用ObservableProperty特性当值改变时会自动触发属性变更通知。
2025-07-06 19:51:53 +08:00
[ObservableProperty]
private List<Device> _devices;
// 变量表列表。
2025-07-06 19:51:53 +08:00
[ObservableProperty]
private List<VariableTable> _variableTables;
// 变量数据列表。
2025-07-06 19:51:53 +08:00
[ObservableProperty]
private List<VariableData> _variableDatas;
// 菜单树列表。
2025-07-06 19:51:53 +08:00
[ObservableProperty]
private List<MenuBean> menuTrees;
// MQTT配置列表。
2025-07-06 19:51:53 +08:00
[ObservableProperty]
private List<Mqtt> _mqtts;
// 设备数据仓库用于设备数据的CRUD操作。
private readonly DeviceRepository _deviceRepository;
2025-07-06 19:51:53 +08:00
// 菜单数据仓库用于菜单数据的CRUD操作。
private readonly MenuRepository _menuRepository;
2025-07-06 19:51:53 +08:00
// MQTT数据仓库用于MQTT配置数据的CRUD操作。
private readonly MqttRepository _mqttRepository;
2025-07-06 19:51:53 +08:00
// 变量数据仓库用于变量数据的CRUD操作。
private readonly VarDataRepository _varDataRepository;
// 设备列表变更事件,当设备列表数据更新时触发。
public event Action<List<Device>> OnDeviceListChanged;
2025-07-06 19:51:53 +08:00
// 菜单树列表变更事件,当菜单树数据更新时触发。
public event Action<List<MenuBean>> OnMenuTreeListChanged;
2025-07-06 19:51:53 +08:00
// MQTT列表变更事件当MQTT配置数据更新时触发。
public event Action<List<Mqtt>> OnMqttListChanged;
2025-07-06 19:51:53 +08:00
/// <summary>
/// 当_mqtts属性值改变时触发的局部方法用于调用OnMqttListChanged事件。
/// </summary>
/// <param name="mqtts">新的MQTT配置列表。</param>
partial void OnMqttsChanged(List<Mqtt> mqtts)
{
OnMqttListChanged?.Invoke(mqtts);
}
// 注释掉的代码块,可能用于变量数据变更事件的触发,但目前未启用。
// {
// OnVariableDataChanged?.Invoke(this, value);
// }
2025-06-30 13:06:51 +08:00
/// <summary>
/// DataServices类的构造函数。
/// 注入ILogger<DataServices>,并初始化各个数据仓库。
/// </summary>
/// <param name="mapper">AutoMapper 实例。</param>
/// <param name="varDataRepository"></param>
public DataServices(IMapper mapper,DeviceRepository deviceRepository,MenuRepository menuRepository,MqttRepository mqttRepository,VarDataRepository varDataRepository)
{
_mapper = mapper;
IsActive = true; // 激活消息接收器
_deviceRepository = deviceRepository;
_menuRepository = menuRepository;
_mqttRepository = mqttRepository;
_varDataRepository = varDataRepository;
_variableDatas = new List<VariableData>();
}
/// <summary>
/// 接收加载消息,根据消息类型从数据库加载对应的数据。
/// </summary>
/// <param name="message">加载消息,包含要加载的数据类型。</param>
/// <exception cref="ArgumentException">如果加载类型未知,可能会抛出此异常(尽管当前实现中未显式抛出)。</exception>
2025-06-30 13:06:51 +08:00
public async void Receive(LoadMessage message)
{
try
{
switch (message.LoadType)
{
case LoadTypes.All: // 加载所有数据
await LoadDevices();
await LoadMenus();
await LoadMqtts();
break;
case LoadTypes.Devices: // 仅加载设备数据
await LoadDevices();
break;
case LoadTypes.Menu: // 仅加载菜单数据
await LoadMenus();
break;
case LoadTypes.Mqtts: // 仅加载MQTT配置数据
await LoadMqtts();
break;
}
}
catch (Exception e)
{
// 捕获加载数据时发生的异常,并通过通知和日志记录错误信息。
NotificationHelper.ShowError($"加载数据出现了错误:{e.Message}", e);
}
}
2025-06-30 13:06:51 +08:00
/// <summary>
/// 异步加载设备数据。
/// </summary>
/// <returns>表示异步操作的任务。</returns>
private async Task LoadDevices()
{
Devices = await _deviceRepository.GetAll();
OnDeviceListChanged?.Invoke(Devices);
}
/// <summary>
/// 异步加载菜单数据,并进行父级关联和排序。
/// </summary>
/// <returns>表示异步操作的任务。</returns>
private async Task LoadMenus()
{
2025-07-01 21:34:20 +08:00
MenuTrees = await _menuRepository.GetMenuTrees();
foreach (MenuBean menu in MenuTrees)
{
MenuHelper.MenuAddParent(menu); // 为菜单添加父级引用
DataServicesHelper.SortMenus(menu); // 排序菜单
}
OnMenuTreeListChanged?.Invoke(MenuTrees);
}
/// <summary>
/// 异步获取所有MQTT配置。
/// </summary>
/// <returns>包含所有MQTT配置的列表。</returns>
public async Task<List<Mqtt>> GetMqttsAsync()
{
var mqtts = await _mqttRepository.GetAll();
OnMqttListChanged?.Invoke(mqtts);
return mqtts;
}
/// <summary>
/// 异步加载MQTT配置数据。
/// </summary>
/// <returns>表示异步操作的任务。</returns>
private async Task LoadMqtts()
{
Mqtts = await _mqttRepository.GetAll();
}
/// <summary>
/// 异步根据ID获取设备数据。
/// </summary>
/// <param name="id">设备ID。</param>
/// <returns>设备对象如果不存在则为null。</returns>
public async Task<Device> GetDeviceByIdAsync(int id)
{
return await _deviceRepository.GetById(id);
}
/// <summary>
/// 异步加载变量数据。
/// </summary>
/// <returns>表示异步操作的任务。</returns>
private async Task LoadVariableDatas()
{
VariableDatas = await _varDataRepository.GetAllAsync();
}
/// <summary>
/// 异步更新变量数据。
/// </summary>
/// <param name="variableData">要更新的变量数据。</param>
/// <returns>表示异步操作的任务。</returns>
public async Task UpdateVariableDataAsync(VariableData variableData)
{
await _varDataRepository.UpdateAsync(variableData);
}
}