1 feat: 触发器功能增强及菜单集成
2
3 - 添加 CreateTriggerWithMenuDto 数据传输对象,用于同时创建触发器及关联菜单
4 - 在 TriggerDataService 中新增 AddTriggerWithMenu 方法,实现触发器与菜单的同时创建
5 - 更新 TriggersViewModel 以使用新的触发器和菜单创建流程
6 - 在 MenuType 枚举中添加 TriggerMenu 类型
7 - 调整 InitializeRepository 中触发器菜单的图标
8 - 更新相关服务中的注释,将 Trigger 替换为 TriggerMenu 以保持一致
9 - 修改时间记录方式,使用 DateTime.Now 替代 DateTime.UtcNow
10 - 优化 TriggerManagementService 中的触发器创建与存储流程
11 - 更新触发器评估和管理服务中的日志文本,统一使用 TriggerMenu 术语
This commit is contained in:
21
DMS.Application/DTOs/CreateTriggerWithMenuDto.cs
Normal file
21
DMS.Application/DTOs/CreateTriggerWithMenuDto.cs
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
using DMS.Core.Models;
|
||||||
|
using DMS.Core.Models.Triggers;
|
||||||
|
|
||||||
|
namespace DMS.Application.DTOs
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 创建触发器及其关联菜单的数据传输对象
|
||||||
|
/// </summary>
|
||||||
|
public class CreateTriggerWithMenuDto
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 触发器信息
|
||||||
|
/// </summary>
|
||||||
|
public Trigger Trigger { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 菜单项信息
|
||||||
|
/// </summary>
|
||||||
|
public MenuBean TriggerMenu { get; set; }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -177,7 +177,7 @@ namespace DMS.Application.Services.Database
|
|||||||
// // 获取关联的触发器ID列表
|
// // 获取关联的触发器ID列表
|
||||||
// var triggerIds = await _repositoryManager.GetTriggerIdsByVariableIdAsync(variableId);
|
// var triggerIds = await _repositoryManager.GetTriggerIdsByVariableIdAsync(variableId);
|
||||||
|
|
||||||
// var triggers = new List<Trigger>();
|
// var triggers = new List<TriggerMenu>();
|
||||||
// if (triggerIds.Any())
|
// if (triggerIds.Any())
|
||||||
// {
|
// {
|
||||||
// // 获取所有关联的触发器
|
// // 获取所有关联的触发器
|
||||||
|
|||||||
@@ -59,13 +59,10 @@ namespace DMS.Application.Services.Management
|
|||||||
// 3. 调用仓储保存实体
|
// 3. 调用仓储保存实体
|
||||||
var createdTrigger = await _repositoryManager.Triggers.AddAsync(triggerEntity);
|
var createdTrigger = await _repositoryManager.Triggers.AddAsync(triggerEntity);
|
||||||
|
|
||||||
// 4. 转换回 DTO 并返回
|
|
||||||
var result = _mapper.Map<Trigger>(createdTrigger);
|
|
||||||
|
|
||||||
// 5. 同步更新AppDataStorageService中的Triggers字典
|
// 5. 同步更新AppDataStorageService中的Triggers字典
|
||||||
_appStorageService.Triggers[result.Id] = result;
|
_appStorageService.Triggers[createdTrigger.Id] = createdTrigger;
|
||||||
|
|
||||||
return result;
|
return createdTrigger;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -122,7 +119,7 @@ namespace DMS.Application.Services.Management
|
|||||||
public async Task<List<Trigger>> GetTriggersForVariableAsync(int variableId)
|
public async Task<List<Trigger>> GetTriggersForVariableAsync(int variableId)
|
||||||
{
|
{
|
||||||
// var triggers = await _repositoryManager.Triggers.GetByVariableIdAsync(variableId);
|
// var triggers = await _repositoryManager.Triggers.GetByVariableIdAsync(variableId);
|
||||||
// return _mapper.Map<List<Trigger>>(triggers);
|
// return _mapper.Map<List<TriggerMenu>>(triggers);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -141,7 +138,7 @@ namespace DMS.Application.Services.Management
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 内部方法:验证 Trigger 的有效性
|
/// 内部方法:验证 TriggerMenu 的有效性
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private void ValidateTriggerDto(Trigger dto)
|
private void ValidateTriggerDto(Trigger dto)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -110,7 +110,7 @@ namespace DMS.Application.Services.Triggers.Impl
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 由于移除了条件,所有激活的触发器都会被触发
|
// 由于移除了条件,所有激活的触发器都会被触发
|
||||||
_logger.LogInformation("Trigger activated for trigger ID: {TriggerId}", trigger.Id);
|
_logger.LogInformation("TriggerMenu activated for trigger ID: {TriggerId}", trigger.Id);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -128,7 +128,7 @@ namespace DMS.Application.Services.Triggers.Impl
|
|||||||
|
|
||||||
if(isSuppressed)
|
if(isSuppressed)
|
||||||
{
|
{
|
||||||
_logger.LogTrace("Trigger is suppressed (until {SuppressionEnd}) for trigger ID: {TriggerId}", suppressionEndTime, trigger.Id);
|
_logger.LogTrace("TriggerMenu is suppressed (until {SuppressionEnd}) for trigger ID: {TriggerId}", suppressionEndTime, trigger.Id);
|
||||||
}
|
}
|
||||||
|
|
||||||
return isSuppressed;
|
return isSuppressed;
|
||||||
|
|||||||
@@ -7,5 +7,6 @@ public enum MenuType
|
|||||||
VariableTableMenu,
|
VariableTableMenu,
|
||||||
VariableMenu,
|
VariableMenu,
|
||||||
MqttMenu,
|
MqttMenu,
|
||||||
MqttServerMenu
|
MqttServerMenu,
|
||||||
|
TriggerMenu
|
||||||
}
|
}
|
||||||
@@ -7,7 +7,7 @@ using DMS.Core.Interfaces.Repositories;
|
|||||||
namespace DMS.Core.Interfaces.Repositories.Triggers
|
namespace DMS.Core.Interfaces.Repositories.Triggers
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 触发器仓储接口 (定义对 Trigger 实体的数据访问方法)
|
/// 触发器仓储接口 (定义对 TriggerMenu 实体的数据访问方法)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public interface ITriggerRepository : IBaseRepository<Trigger>
|
public interface ITriggerRepository : IBaseRepository<Trigger>
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -140,7 +140,7 @@ public class InitializeRepository : IInitializeRepository
|
|||||||
},
|
},
|
||||||
new DbMenu
|
new DbMenu
|
||||||
{
|
{
|
||||||
Id = 5, Header = "触发器", Icon = "\uE7BA", ParentId = 0,
|
Id = 5, Header = "触发器", Icon = "\uE945", ParentId = 0,
|
||||||
MenuType = MenuType.MainMenu, TargetViewKey = "TriggersViewModel",
|
MenuType = MenuType.MainMenu, TargetViewKey = "TriggersViewModel",
|
||||||
DisplayOrder = 5
|
DisplayOrder = 5
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -19,6 +19,11 @@ public interface ITriggerDataService
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
Task<TriggerItem> AddTrigger(TriggerItem triggerItem);
|
Task<TriggerItem> AddTrigger(TriggerItem triggerItem);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 添加触发器及其关联菜单。
|
||||||
|
/// </summary>
|
||||||
|
Task<CreateTriggerWithMenuDto> AddTriggerWithMenu(CreateTriggerWithMenuDto dto);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 删除触发器。
|
/// 删除触发器。
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -1,12 +1,14 @@
|
|||||||
using System.Windows.Threading;
|
|
||||||
using AutoMapper;
|
using AutoMapper;
|
||||||
using DMS.Application.DTOs;
|
using DMS.Application.DTOs;
|
||||||
using DMS.Application.Interfaces;
|
using DMS.Application.Interfaces;
|
||||||
|
using DMS.Application.Services;
|
||||||
|
using DMS.Core.Enums;
|
||||||
using DMS.Core.Events;
|
using DMS.Core.Events;
|
||||||
using DMS.Core.Models.Triggers;
|
using DMS.Core.Models.Triggers;
|
||||||
using DMS.WPF.Interfaces;
|
using DMS.WPF.Interfaces;
|
||||||
using DMS.WPF.ItemViewModel;
|
using DMS.WPF.ItemViewModel;
|
||||||
using Opc.Ua;
|
using Opc.Ua;
|
||||||
|
using System.Windows.Threading;
|
||||||
|
|
||||||
namespace DMS.WPF.Services;
|
namespace DMS.WPF.Services;
|
||||||
|
|
||||||
@@ -100,6 +102,48 @@ public class TriggerDataService : ITriggerDataService
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 添加触发器及其关联菜单。
|
||||||
|
/// </summary>
|
||||||
|
public async Task<CreateTriggerWithMenuDto> AddTriggerWithMenu(CreateTriggerWithMenuDto dto)
|
||||||
|
{
|
||||||
|
// 添加null检查
|
||||||
|
if (dto == null || dto.Trigger == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// 首先添加触发器
|
||||||
|
var createdTrigger = await _appCenterService.TriggerManagementService.CreateTriggerAsync(dto.Trigger);
|
||||||
|
if (createdTrigger == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
|
||||||
|
var parentMenu=_appStorageService.Menus.Values.OrderBy(m=>m.Id).FirstOrDefault(m=>m.MenuType==MenuType.TriggerMenu);
|
||||||
|
if (parentMenu is not null)
|
||||||
|
{
|
||||||
|
// 将菜单关联到触发器
|
||||||
|
dto.TriggerMenu.TargetId = createdTrigger.Id;
|
||||||
|
dto.TriggerMenu.MenuType = MenuType.TriggerMenu;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// 添加到UI数据存储
|
||||||
|
var addItem = _mapper.Map<TriggerItem>(createdTrigger);
|
||||||
|
_dataStorageService.Triggers.Add(createdTrigger.Id, addItem);
|
||||||
|
|
||||||
|
return dto;
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_notificationService?.ShowError($"添加触发器及菜单时发生错误:{ex.Message}", ex);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 更新触发器。
|
/// 更新触发器。
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -71,8 +71,8 @@ namespace DMS.WPF.ViewModels
|
|||||||
IsActive = true,
|
IsActive = true,
|
||||||
Action = Core.Models.Triggers.ActionType.SendEmail,
|
Action = Core.Models.Triggers.ActionType.SendEmail,
|
||||||
Description = "新建触发器",
|
Description = "新建触发器",
|
||||||
CreatedAt = DateTime.UtcNow,
|
CreatedAt = DateTime.Now,
|
||||||
UpdatedAt = DateTime.UtcNow
|
UpdatedAt = DateTime.Now
|
||||||
};
|
};
|
||||||
|
|
||||||
TriggerDialogViewModel viewModel = App.Current.Services.GetRequiredService<TriggerDialogViewModel>();
|
TriggerDialogViewModel viewModel = App.Current.Services.GetRequiredService<TriggerDialogViewModel>();
|
||||||
@@ -83,13 +83,33 @@ namespace DMS.WPF.ViewModels
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// 使用TriggerDataService添加触发器
|
// 创建包含菜单信息的 DTO
|
||||||
var createdTrigger = await _triggerDataService.AddTrigger(newTrigger);
|
CreateTriggerWithMenuDto dto = new CreateTriggerWithMenuDto();
|
||||||
|
if (_mapper != null)
|
||||||
if (createdTrigger != null )
|
|
||||||
{
|
{
|
||||||
// 触发器已添加到数据存储中,只需更新本地集合
|
dto.Trigger = _mapper.Map<Trigger>(result);
|
||||||
_notificationService.ShowSuccess("触发器创建成功");
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_notificationService?.ShowError("映射服务未初始化");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 创建菜单项
|
||||||
|
dto.TriggerMenu = new MenuBean()
|
||||||
|
{
|
||||||
|
Header = result.Name ?? result.Description,
|
||||||
|
Icon = "\uE945", // 使用触发器图标
|
||||||
|
TargetViewKey = nameof(TriggerDetailViewModel),
|
||||||
|
};
|
||||||
|
|
||||||
|
// 使用TriggerDataService添加触发器和菜单
|
||||||
|
var createdTriggerDto = await _triggerDataService.AddTriggerWithMenu(dto);
|
||||||
|
|
||||||
|
if (createdTriggerDto != null && createdTriggerDto.Trigger != null)
|
||||||
|
{
|
||||||
|
// 更新UI显示
|
||||||
|
_notificationService.ShowSuccess($"触发器创建成功:{createdTriggerDto.Trigger.Name ?? createdTriggerDto.Trigger.Description}");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user