2
3 - 实现触发器与菜单联动功能,现在可以同时创建触发器及其关联的菜单项
4 - 添加触发器更改事件系统,用于通知UI和其他组件触发器状态的变化
5 - 优化触发器管理服务,改进了添加、修改和删除触发器的逻辑
6 - 将CreateTriggerAsync方法重命名为AddTriggerAsync,使其语义更准确
7 - 修改UpdateTriggerAsync方法的参数和返回值类型,提高一致性
8 - 添加CreateTriggerWithMenuAsync方法用于同时创建触发器和菜单
9 - 在应用层重构触发器管理逻辑,增加事务支持确保数据一致性
10 - 更新菜单管理服务,改进并发安全处理
11 - 调整数据存储服务,使其同步触发器和菜单更新
12 - 更新触发器对话框和列表视图模型,提升用户体验
13 - 在依赖注入容器中注册触发器服务
14 - 修复设备数据服务中的异步调用问题,确保菜单项的正确处理
15 - 添加缺失的触发器项映射配置
16 - 创建TriggerChangedEventArgs类处理触发器更改事件
65 lines
2.4 KiB
C#
65 lines
2.4 KiB
C#
using DMS.Application.DTOs;
|
||
using DMS.Core.Models.Triggers;
|
||
|
||
namespace DMS.Application.Interfaces.Management
|
||
{
|
||
/// <summary>
|
||
/// 触发器管理服务接口 (负责 CRUD 操作)
|
||
/// </summary>
|
||
public interface ITriggerManagementService
|
||
{
|
||
/// <summary>
|
||
/// 获取所有触发器定义
|
||
/// </summary>
|
||
/// <returns>触发器定义列表</returns>
|
||
List<Trigger> GetAllTriggersAsync();
|
||
|
||
/// <summary>
|
||
/// 根据 ID 获取触发器定义
|
||
/// </summary>
|
||
/// <param name="id">触发器 ID</param>
|
||
/// <returns>触发器定义 DTO,如果未找到则返回 null</returns>
|
||
Task<Trigger> GetTriggerByIdAsync(int id);
|
||
|
||
/// <summary>
|
||
/// 创建一个新的触发器定义
|
||
/// </summary>
|
||
/// <param name="triggerDto">要创建的触发器定义 DTO</param>
|
||
/// <returns>创建成功的触发器定义 DTO</returns>
|
||
Task<Trigger> AddTriggerAsync(Trigger triggerDto);
|
||
|
||
/// <summary>
|
||
/// 创建触发器及其关联菜单
|
||
/// </summary>
|
||
/// <param name="dto">包含触发器和菜单信息的数据传输对象</param>
|
||
/// <returns>包含新创建触发器和菜单信息的数据传输对象</returns>
|
||
Task<CreateTriggerWithMenuDto> CreateTriggerWithMenuAsync(CreateTriggerWithMenuDto dto);
|
||
|
||
/// <summary>
|
||
/// 更新一个已存在的触发器定义
|
||
/// </summary>
|
||
/// <param name="id">要更新的触发器 ID</param>
|
||
/// <param name="triggerDto">包含更新信息的触发器定义 DTO</param>
|
||
/// <returns>更新后的触发器定义 DTO,如果未找到则返回 null</returns>
|
||
Task<int> UpdateTriggerAsync( Trigger trigger);
|
||
|
||
/// <summary>
|
||
/// 删除一个触发器定义
|
||
/// </summary>
|
||
/// <param name="id">要删除的触发器 ID</param>
|
||
/// <returns>删除成功返回 true,否则返回 false</returns>
|
||
Task<bool> DeleteTriggerAsync(int id);
|
||
|
||
/// <summary>
|
||
/// 获取与指定变量关联的所有触发器定义
|
||
/// </summary>
|
||
/// <param name="variableId">变量 ID</param>
|
||
/// <returns>该变量关联的触发器定义列表</returns>
|
||
Task<List<Trigger>> GetTriggersForVariableAsync(int variableId);
|
||
|
||
/// <summary>
|
||
/// 异步加载所有触发器数据
|
||
/// </summary>
|
||
Task LoadAllTriggersAsync();
|
||
}
|
||
} |