1 feat: 实现触发器-菜单联动功能和事件系统
2
3 - 实现触发器与菜单联动功能,现在可以同时创建触发器及其关联的菜单项
4 - 添加触发器更改事件系统,用于通知UI和其他组件触发器状态的变化
5 - 优化触发器管理服务,改进了添加、修改和删除触发器的逻辑
6 - 将CreateTriggerAsync方法重命名为AddTriggerAsync,使其语义更准确
7 - 修改UpdateTriggerAsync方法的参数和返回值类型,提高一致性
8 - 添加CreateTriggerWithMenuAsync方法用于同时创建触发器和菜单
9 - 在应用层重构触发器管理逻辑,增加事务支持确保数据一致性
10 - 更新菜单管理服务,改进并发安全处理
11 - 调整数据存储服务,使其同步触发器和菜单更新
12 - 更新触发器对话框和列表视图模型,提升用户体验
13 - 在依赖注入容器中注册触发器服务
14 - 修复设备数据服务中的异步调用问题,确保菜单项的正确处理
15 - 添加缺失的触发器项映射配置
16 - 创建TriggerChangedEventArgs类处理触发器更改事件
This commit is contained in:
@@ -7,6 +7,7 @@ using System.Threading.Tasks;
|
||||
using System.Linq;
|
||||
using System.Diagnostics;
|
||||
using DMS.Application.Interfaces;
|
||||
using DMS.Application.DTOs;
|
||||
|
||||
namespace DMS.Application.Services.Database
|
||||
{
|
||||
@@ -62,7 +63,7 @@ namespace DMS.Application.Services.Database
|
||||
/// </summary>
|
||||
/// <param name="trigger">要创建的触发器定义。</param>
|
||||
/// <returns>新创建的触发器定义。</returns>
|
||||
public async Task<Trigger> CreateTriggerAsync(Trigger trigger)
|
||||
public async Task<Trigger> AddTriggerAsync(Trigger trigger)
|
||||
{
|
||||
try
|
||||
{
|
||||
@@ -71,19 +72,6 @@ namespace DMS.Application.Services.Database
|
||||
// 添加触发器定义
|
||||
var addedTrigger = await _repositoryManager.Triggers.AddAsync(trigger);
|
||||
|
||||
// // 添加关联的变量ID
|
||||
// if (trigger.Variables != null && trigger.Variables.Any())
|
||||
// {
|
||||
// var triggerVariables = trigger.Variables.Select(variableId => new DbTriggerVariable
|
||||
// {
|
||||
// TriggerDefinitionId = addedTrigger.Id,
|
||||
// VariableId = variableId
|
||||
// })
|
||||
// .ToList();
|
||||
//
|
||||
// await _repositoryManager.AddTriggerVariablesAsync(triggerVariables);
|
||||
// }
|
||||
|
||||
await _repositoryManager.CommitAsync();
|
||||
return addedTrigger;
|
||||
}
|
||||
@@ -94,6 +82,62 @@ namespace DMS.Application.Services.Database
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 异步创建触发器及其关联菜单。
|
||||
/// </summary>
|
||||
/// <param name="dto">包含触发器和菜单信息的数据传输对象。</param>
|
||||
/// <returns>包含新创建触发器和菜单信息的数据传输对象。</returns>
|
||||
public async Task<CreateTriggerWithMenuDto> CreateTriggerWithMenuAsync(CreateTriggerWithMenuDto dto)
|
||||
{
|
||||
try
|
||||
{
|
||||
await _repositoryManager.BeginTranAsync();
|
||||
|
||||
// 创建触发器
|
||||
var createdTrigger = await _repositoryManager.Triggers.AddAsync(dto.Trigger);
|
||||
if (createdTrigger == null || createdTrigger.Id == 0)
|
||||
{
|
||||
throw new InvalidOperationException($"添加触发器失败:{createdTrigger}");
|
||||
}
|
||||
|
||||
// 确保DTO中的触发器对象也更新为新创建的触发器
|
||||
dto.Trigger = createdTrigger;
|
||||
|
||||
// 创建菜单
|
||||
if (dto.TriggerMenu != null)
|
||||
{
|
||||
// 使用现有的菜单查找逻辑来获取父菜单
|
||||
var parentMenu = await _repositoryManager.Menus.GetMenuByTargetIdAsync(Core.Enums.MenuType.TriggerMenu, 0);
|
||||
if (parentMenu != null)
|
||||
{
|
||||
// 设置菜单的关联信息
|
||||
dto.TriggerMenu.ParentId = parentMenu.Id;
|
||||
dto.TriggerMenu.MenuType = Core.Enums.MenuType.TriggerMenu;
|
||||
dto.TriggerMenu.TargetId = createdTrigger.Id;
|
||||
|
||||
// 添加菜单到数据库
|
||||
var addMenu = await _repositoryManager.Menus.AddAsync(dto.TriggerMenu);
|
||||
if (addMenu == null || addMenu.Id == 0)
|
||||
{
|
||||
throw new InvalidOperationException($"添加触发器菜单失败:{addMenu}");
|
||||
}
|
||||
|
||||
// 更新dto中的菜单对象
|
||||
dto.TriggerMenu = addMenu;
|
||||
}
|
||||
}
|
||||
|
||||
await _repositoryManager.CommitAsync();
|
||||
|
||||
return dto;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
await _repositoryManager.RollbackAsync();
|
||||
throw new ApplicationException($"创建触发器及其菜单时发生错误,操作已回滚,错误信息:{ex.Message}", ex);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 异步更新一个已存在的触发器定义及其关联的变量ID。
|
||||
/// </summary>
|
||||
@@ -108,25 +152,6 @@ namespace DMS.Application.Services.Database
|
||||
// 更新触发器定义
|
||||
var rowsAffected = await _repositoryManager.Triggers.UpdateAsync(trigger);
|
||||
|
||||
// if (rowsAffected > 0)
|
||||
// {
|
||||
// // 删除旧的关联关系
|
||||
// await _repositoryManager.DeleteTriggerVariablesByTriggerIdAsync(trigger.Id);
|
||||
//
|
||||
// // 插入新的关联关系
|
||||
// if (trigger.Variables != null && trigger.Variables.Any())
|
||||
// {
|
||||
// var triggerVariables = trigger.Variables.Select(variableId => new DbTriggerVariable
|
||||
// {
|
||||
// TriggerDefinitionId = trigger.Id,
|
||||
// VariableId = variableId
|
||||
// })
|
||||
// .ToList();
|
||||
//
|
||||
// await _repositoryManager.AddTriggerVariablesAsync(triggerVariables);
|
||||
// }
|
||||
// }
|
||||
|
||||
await _repositoryManager.CommitAsync();
|
||||
return rowsAffected;
|
||||
}
|
||||
@@ -148,9 +173,6 @@ namespace DMS.Application.Services.Database
|
||||
{
|
||||
await _repositoryManager.BeginTranAsync();
|
||||
|
||||
// // 删除关联的变量关系
|
||||
// await _repositoryManager.DeleteTriggerVariablesByTriggerIdAsync(id);
|
||||
|
||||
// 删除触发器本身
|
||||
var rowsAffected = await _repositoryManager.Triggers.DeleteByIdAsync(id);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user