AdoS8Dtos.cs 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445
  1. namespace Admin.NET.Plugin.AiDOP.Dto.S8;
  2. public class AdoS8ExceptionQueryDto
  3. {
  4. public long TenantId { get; set; } = 1;
  5. public long FactoryId { get; set; } = 1;
  6. public string? Keyword { get; set; }
  7. public string? Status { get; set; }
  8. public string? StatusBucket { get; set; }
  9. public string? Severity { get; set; }
  10. public string? SceneCode { get; set; }
  11. /// <summary>模块码过滤(S1-S7),用于监控页下钻</summary>
  12. public string? ModuleCode { get; set; }
  13. public long? DeptId { get; set; }
  14. public bool? TimeoutFlag { get; set; }
  15. public string? ProcessNodeCode { get; set; }
  16. public string? RelatedObjectCode { get; set; }
  17. public DateTime? BeginTime { get; set; }
  18. public DateTime? EndTime { get; set; }
  19. /// <summary>是否包含 exception_type_code 为 NULL 的未分类历史异常;默认 false(隐藏)。</summary>
  20. public bool? IncludeUnclassified { get; set; }
  21. /// <summary>恢复状态筛选:RECOVERED / ACTIVE / 空=不限。</summary>
  22. public string? RecoveredStatus { get; set; }
  23. /// <summary>规则类型筛选:OUT_OF_RANGE / TIMEOUT / SHORTAGE / 空=不限;通过 source_rule_code join watch_rule.rule_type。</summary>
  24. public string? RuleType { get; set; }
  25. /// <summary>S8-DASHBOARD-DATA-ALIGN-S1S7-1:仅返回 module_code IN S1-S7 的异常;看板明细表传 true 与 KPI 口径对齐。
  26. /// 默认 false 以保证异常列表页(/aidop/s8/exceptions)行为不变。</summary>
  27. public bool? OnlyS1S7Modules { get; set; }
  28. public int Page { get; set; } = 1;
  29. public int PageSize { get; set; } = 20;
  30. }
  31. public class AdoS8ExceptionListItemDto
  32. {
  33. public long Id { get; set; }
  34. public long FactoryId { get; set; }
  35. public string ExceptionCode { get; set; } = string.Empty;
  36. public string Title { get; set; } = string.Empty;
  37. public string Status { get; set; } = string.Empty;
  38. public string? StatusLabel { get; set; }
  39. public string Severity { get; set; } = string.Empty;
  40. public string? SeverityLabel { get; set; }
  41. public decimal PriorityScore { get; set; }
  42. public string PriorityLevel { get; set; } = string.Empty;
  43. public string SceneCode { get; set; } = string.Empty;
  44. public string? SceneName { get; set; }
  45. /// <summary>S8-EXCEPTION-MODULE-DISPLAY-1:业务展示主口径(S1-S7)。SceneCode/SceneName 保留兼容期。</summary>
  46. public string? ModuleCode { get; set; }
  47. public string? ModuleName { get; set; }
  48. public long ResponsibleDeptId { get; set; }
  49. public string? ResponsibleDeptName { get; set; }
  50. public long OccurrenceDeptId { get; set; }
  51. public string? OccurrenceDeptName { get; set; }
  52. public long? AssigneeId { get; set; }
  53. public string? AssigneeName { get; set; }
  54. public DateTime? SlaDeadline { get; set; }
  55. public bool TimeoutFlag { get; set; }
  56. public DateTime CreatedAt { get; set; }
  57. public DateTime? ClosedAt { get; set; }
  58. public string? ExceptionTypeCode { get; set; }
  59. public DateTime? RecoveredAt { get; set; }
  60. public string? SourceRuleCode { get; set; }
  61. public string? SourceObjectType { get; set; }
  62. public string? SourceObjectId { get; set; }
  63. public string? DedupKey { get; set; }
  64. public DateTime? LastDetectedAt { get; set; }
  65. public string? RuleType { get; set; }
  66. }
  67. public class AdoS8ExceptionDetailDto : AdoS8ExceptionListItemDto
  68. {
  69. public string? Description { get; set; }
  70. public string SourceType { get; set; } = string.Empty;
  71. public long? ResponsibleGroupId { get; set; }
  72. public long? ReporterId { get; set; }
  73. public string? ReporterName { get; set; }
  74. public DateTime? AssignedAt { get; set; }
  75. public DateTime? UpdatedAt { get; set; }
  76. public long? ActiveFlowInstanceId { get; set; }
  77. public string? ActiveFlowBizType { get; set; }
  78. public long? VerifierId { get; set; }
  79. public string? VerifierName { get; set; }
  80. public DateTime? VerificationAssignedAt { get; set; }
  81. public DateTime? VerifiedAt { get; set; }
  82. public string? VerificationResult { get; set; }
  83. public string? VerificationRemark { get; set; }
  84. public long? SourceRuleId { get; set; }
  85. public string? RelatedObjectCode { get; set; }
  86. }
  87. public class AdoS8ManualReportCreateDto
  88. {
  89. public long TenantId { get; set; } = 1;
  90. public long FactoryId { get; set; } = 1;
  91. public string Title { get; set; } = string.Empty;
  92. public string? Description { get; set; }
  93. public string SceneCode { get; set; } = string.Empty;
  94. public string Severity { get; set; } = "FOLLOW";
  95. public long OccurrenceDeptId { get; set; }
  96. public long ResponsibleDeptId { get; set; }
  97. public long? ReporterId { get; set; }
  98. /// <summary>关联对象编码:当前按订单项 / 类订单项对象理解,允许重复,可为空。最长 64 字符(与 ado_s8_exception.related_object_code 一致)。</summary>
  99. public string? RelatedObjectCode { get; set; }
  100. // TASK-002-RESET-DIMENSION-MODEL-DEV-2B:手工提报维度选择(前端首版可不传,按 module_code 兜底;rule_mechanism 固定 MANUAL_REPORT)。
  101. public string? StageCode { get; set; }
  102. public string? OrderFlowCode { get; set; }
  103. }
  104. public class AdoS8ManualReportResultDto
  105. {
  106. public long ExceptionId { get; set; }
  107. public string ExceptionCode { get; set; } = string.Empty;
  108. public long TaskId { get; set; }
  109. }
  110. public class AdoS8TimelineItemDto
  111. {
  112. public long Id { get; set; }
  113. public string ActionCode { get; set; } = string.Empty;
  114. public string ActionLabel { get; set; } = string.Empty;
  115. public string? FromStatus { get; set; }
  116. public string? ToStatus { get; set; }
  117. public long? OperatorId { get; set; }
  118. public string? OperatorName { get; set; }
  119. public string? ActionRemark { get; set; }
  120. public DateTime CreatedAt { get; set; }
  121. }
  122. public class AdoS8DecisionItemDto
  123. {
  124. public long Id { get; set; }
  125. public string DecisionType { get; set; } = string.Empty;
  126. public long DecisionMakerId { get; set; }
  127. public string DecisionMakerName { get; set; } = string.Empty;
  128. public string? DecisionBasis { get; set; }
  129. public string? DecisionResult { get; set; }
  130. public string? DecisionRemark { get; set; }
  131. public DateTime DecisionTime { get; set; }
  132. }
  133. public class AdoS8EvidenceItemDto
  134. {
  135. public long Id { get; set; }
  136. public string EvidenceType { get; set; } = string.Empty;
  137. public string FileName { get; set; } = string.Empty;
  138. public string FileUrl { get; set; } = string.Empty;
  139. public string? SourceSystem { get; set; }
  140. public long? UploadedBy { get; set; }
  141. public DateTime UploadedAt { get; set; }
  142. }
  143. public class AdoS8CommentDto
  144. {
  145. public string? Remark { get; set; }
  146. }
  147. public class AdoS8TransferDto
  148. {
  149. public long AssigneeId { get; set; }
  150. public string? Remark { get; set; }
  151. }
  152. public class AdoS8AttachmentCreateDto
  153. {
  154. public string EvidenceType { get; set; } = "file";
  155. public string FileName { get; set; } = string.Empty;
  156. public string FileUrl { get; set; } = string.Empty;
  157. public string? SourceSystem { get; set; }
  158. public long? UploadedBy { get; set; }
  159. }
  160. // ── 监控汇总 DTO ─────────────────────────────────────────────────────────────
  161. public class AdoS8MonitoringSummaryQueryDto
  162. {
  163. public long TenantId { get; set; } = 1;
  164. public long FactoryId { get; set; } = 1;
  165. /// <summary>场景码过滤(不传 = 全部)</summary>
  166. public string? SceneCode { get; set; }
  167. /// <summary>模块码过滤(不传 = 全部)</summary>
  168. public string? ModuleCode { get; set; }
  169. public DateTime? BizDateFrom { get; set; }
  170. public DateTime? BizDateTo { get; set; }
  171. /// <summary>统一时间筛选:today / this_week / this_month。BizDateFrom/BizDateTo 已传时优先于 Period。</summary>
  172. public string? Period { get; set; }
  173. }
  174. /// <summary>单个模块的异常汇总行</summary>
  175. public class AdoS8ModuleSummaryItem
  176. {
  177. public string ModuleCode { get; set; } = string.Empty;
  178. public string ModuleLabel { get; set; } = string.Empty;
  179. public string SceneCode { get; set; } = string.Empty;
  180. public string SceneLabel { get; set; } = string.Empty;
  181. public int Total { get; set; }
  182. public int Red { get; set; }
  183. public int Yellow { get; set; }
  184. public int Green { get; set; }
  185. public int Timeout { get; set; }
  186. }
  187. /// <summary>监控汇总出参(综合全景页顶部 + 表格数据)</summary>
  188. public class AdoS8MonitoringSummaryDto
  189. {
  190. public int Total { get; set; }
  191. public int Red { get; set; }
  192. public int Yellow { get; set; }
  193. public int Green { get; set; }
  194. public int Timeout { get; set; }
  195. public List<AdoS8ModuleSummaryItem> ByModule { get; set; } = new();
  196. }
  197. // ── 9宫格 OrderGrid DTO ──────────────────────────────────────────────────────
  198. /// <summary>S1-S7 单个模块的订单健康分布(9宫格前7格)</summary>
  199. public class AdoS8ModuleOrderSummary
  200. {
  201. public string ModuleCode { get; set; } = string.Empty;
  202. public string ModuleLabel { get; set; } = string.Empty;
  203. /// <summary>绿色订单数(来自订单主数据,不从异常 severity 推导)。</summary>
  204. public int Green { get; set; }
  205. /// <summary>黄色订单数(FOLLOW 关注)。</summary>
  206. public int Yellow { get; set; }
  207. /// <summary>红色订单数(SERIOUS 严重,或黄色超时)。</summary>
  208. public int Red { get; set; }
  209. public int Total { get; set; }
  210. /// <summary>异常发生频率(每百订单异常数)</summary>
  211. public double Frequency { get; set; }
  212. /// <summary>平均处理时效(小时)</summary>
  213. public double AvgProcessHours { get; set; }
  214. /// <summary>异常关闭百分比</summary>
  215. public double CloseRate { get; set; }
  216. }
  217. /// <summary>S8格:按业务类别汇总(第8格)</summary>
  218. public class AdoS8CategorySummary
  219. {
  220. public string Category { get; set; } = string.Empty;
  221. public int Total { get; set; }
  222. public double AvgProcessHours { get; set; }
  223. public double CloseRate { get; set; }
  224. }
  225. /// <summary>S9格:按责任部门汇总(第9格)</summary>
  226. public class AdoS8DeptSummary
  227. {
  228. public string DeptName { get; set; } = string.Empty;
  229. public int Total { get; set; }
  230. public double AvgProcessHours { get; set; }
  231. public double CloseRate { get; set; }
  232. }
  233. /// <summary>9宫格完整出参</summary>
  234. public class AdoS8OrderGridDto
  235. {
  236. public List<AdoS8ModuleOrderSummary> Modules { get; set; } = new();
  237. public List<AdoS8CategorySummary> ByCategory { get; set; } = new();
  238. public List<AdoS8DeptSummary> ByDept { get; set; } = new();
  239. }
  240. /// <summary>S9 QDC 四主线聚合单项</summary>
  241. public class AdoS8QdcSummaryItemDto
  242. {
  243. /// <summary>主线码:QUALITY / DELIVERY / COST / INVENTORY</summary>
  244. public string Code { get; set; } = string.Empty;
  245. public string Title { get; set; } = string.Empty;
  246. public int Total { get; set; }
  247. public double? AvgProcessHours { get; set; }
  248. public double? OnTimeCloseRate { get; set; }
  249. public double? CloseRate { get; set; }
  250. public string? Remark { get; set; }
  251. }
  252. /// <summary>S9 QDC 四主线聚合出参</summary>
  253. public class AdoS8QdcSummaryDto
  254. {
  255. public List<AdoS8QdcSummaryItemDto> Items { get; set; } = new();
  256. }
  257. /// <summary>
  258. /// TASK-012-S9-QDC-RATIO-MIGRATION-2:S9 result KPI 单项(订单交付率/到货达成率/检验合格率/工单完工率)。
  259. /// 与 S9 QDC exception-side 卡片是不同语义;本期仅返回字典基础信息 + 占位 currentValue/targetRatio。
  260. /// 真实计算入口待 RATIO-REAL-1 后续任务接入。
  261. /// </summary>
  262. public class AdoS8ResultKpiItemDto
  263. {
  264. /// <summary>指标码(与 ado_s8_monitor_metric.metric_code 同源)</summary>
  265. public string MetricCode { get; set; } = string.Empty;
  266. public string MetricName { get; set; } = string.Empty;
  267. public string ObjectCode { get; set; } = string.Empty;
  268. public string Unit { get; set; } = "%";
  269. /// <summary>当前值占位;本期为 NULL 表示未计算</summary>
  270. public decimal? CurrentValue { get; set; }
  271. /// <summary>目标值;取自 ado_s8_monitor_metric.default_target_ratio</summary>
  272. public decimal? TargetRatio { get; set; }
  273. /// <summary>S8 dictionary 是否启用(本期均为 false,因 RATIO 已迁出 S8 watch_rule)</summary>
  274. public bool DictionaryEnabled { get; set; }
  275. public string? Remark { get; set; }
  276. }
  277. /// <summary>TASK-012-S9-QDC-RATIO-MIGRATION-2:result KPI summary 出参(mock 阶段)</summary>
  278. public class AdoS8ResultKpiSummaryDto
  279. {
  280. public List<AdoS8ResultKpiItemDto> Items { get; set; } = new();
  281. /// <summary>数据来源标记:DICTIONARY_MOCK = 字典 + 占位值;REAL = 真实计算(待后续任务)</summary>
  282. public string Source { get; set; } = "DICTIONARY_MOCK";
  283. }
  284. /// <summary>S8-DELIVERY-TREND-CHART-REPLACE-DUPLICATE-SECTION-1:Delivery 页近 N 日交付异常趋势出参。</summary>
  285. public class AdoS8DeliveryTrendDto
  286. {
  287. public List<AdoS8DeliveryTrendDayDto> Days { get; set; } = new();
  288. public AdoS8DeliveryTrendSummaryDto Summary { get; set; } = new();
  289. }
  290. public class AdoS8DeliveryTrendDayDto
  291. {
  292. /// <summary>日期短格式 MM/dd(图表 X 轴)</summary>
  293. public string Date { get; set; } = string.Empty;
  294. /// <summary>原始日期 yyyy-MM-dd</summary>
  295. public string RawDate { get; set; } = string.Empty;
  296. public int OrderChange { get; set; }
  297. public int DeliveryDelay { get; set; }
  298. public int PendingShipment { get; set; }
  299. public int Total { get; set; }
  300. }
  301. public class AdoS8DeliveryTrendSummaryDto
  302. {
  303. public int PeakValue { get; set; }
  304. public string? PeakDate { get; set; }
  305. public double AvgValue { get; set; }
  306. public int TodayValue { get; set; }
  307. /// <summary>今日相对昨日变化率(%);昨日为 0 时返回 null。</summary>
  308. public double? TodayChangeRate { get; set; }
  309. }
  310. /// <summary>S8-PROD-SUPPLY-TREND-CHART-REPLACE-DUPLICATE-SECTION-1:Production 页近 N 日生产异常趋势出参。</summary>
  311. public class AdoS8ProductionTrendDto
  312. {
  313. public List<AdoS8ProductionTrendDayDto> Days { get; set; } = new();
  314. public AdoS8DeliveryTrendSummaryDto Summary { get; set; } = new();
  315. }
  316. public class AdoS8ProductionTrendDayDto
  317. {
  318. public string Date { get; set; } = string.Empty;
  319. public string RawDate { get; set; } = string.Empty;
  320. public int EquipmentFault { get; set; }
  321. public int MaterialFault { get; set; }
  322. public int QualityFault { get; set; }
  323. public int Total { get; set; }
  324. }
  325. /// <summary>S8-PROD-SUPPLY-TREND-CHART-REPLACE-DUPLICATE-SECTION-1:Supply 页近 N 日供应异常趋势出参。</summary>
  326. public class AdoS8SupplyTrendDto
  327. {
  328. public List<AdoS8SupplyTrendDayDto> Days { get; set; } = new();
  329. public AdoS8DeliveryTrendSummaryDto Summary { get; set; } = new();
  330. }
  331. public class AdoS8SupplyTrendDayDto
  332. {
  333. public string Date { get; set; } = string.Empty;
  334. public string RawDate { get; set; } = string.Empty;
  335. public int SupplierEtaIssue { get; set; }
  336. public int SupplierShipIssue { get; set; }
  337. public int WarehouseReceiptAbnormal { get; set; }
  338. public int IqcIssue { get; set; }
  339. public int WarehousePutawayIssue { get; set; }
  340. public int WorkOrderKittingAbnormal { get; set; }
  341. public int WorkOrderIssueAbnormal { get; set; }
  342. public int Total { get; set; }
  343. }
  344. /// <summary>
  345. /// S8-SIDEBAR-TYPE-CARD-WINDOW-TOGGLE-1:右侧异常类型卡按时间窗口切片(LAST_24H / LAST_7D)出参。
  346. /// 同一窗口内 total / open / closed / avgProcessHours / closeRate 共用同一分母,避免跨窗口拼接误读。
  347. /// </summary>
  348. public class AdoS8DomainTypeMetricsDto
  349. {
  350. public string Domain { get; set; } = string.Empty;
  351. public string Window { get; set; } = string.Empty;
  352. public int Total { get; set; }
  353. public List<AdoS8DomainTypeMetricItemDto> Items { get; set; } = new();
  354. }
  355. public class AdoS8DomainTypeMetricItemDto
  356. {
  357. public string Key { get; set; } = string.Empty;
  358. public string Label { get; set; } = string.Empty;
  359. public string TypeCode { get; set; } = string.Empty;
  360. public int Total { get; set; }
  361. public int OpenCount { get; set; }
  362. public int ClosedCount { get; set; }
  363. /// <summary>已关闭样本均时(小时);无 closed 样本时 null,前端展示 --。</summary>
  364. public double? AvgProcessHours { get; set; }
  365. /// <summary>关闭率 %;total=0 时 null,前端展示 --。</summary>
  366. public double? CloseRate { get; set; }
  367. }
  368. public class AdoS8SubmitVerificationDto
  369. {
  370. public long VerifierId { get; set; }
  371. public string? Remark { get; set; }
  372. }
  373. public class AdoS8ApproveVerificationDto
  374. {
  375. public string? Remark { get; set; }
  376. }
  377. public class AdoS8RejectVerificationDto
  378. {
  379. public string Remark { get; set; } = string.Empty;
  380. }
  381. // TASK-002-RESET-DIMENSION-MODEL-DEV-1: S8 业务维度元数据 DTO
  382. public class AdoS8DimensionDto
  383. {
  384. public string DimensionCode { get; set; } = string.Empty;
  385. public string DimensionName { get; set; } = string.Empty;
  386. public bool Enabled { get; set; }
  387. public int SortNo { get; set; }
  388. public string? Remark { get; set; }
  389. }
  390. public class AdoS8DimensionNodeDto
  391. {
  392. public long Id { get; set; }
  393. public string DimensionCode { get; set; } = string.Empty;
  394. public string NodeCode { get; set; } = string.Empty;
  395. public string NodeName { get; set; } = string.Empty;
  396. public long? ParentId { get; set; }
  397. public int Level { get; set; }
  398. public string Path { get; set; } = string.Empty;
  399. public bool IsSelectable { get; set; }
  400. /// <summary>= !IsSelectable,供前端树选择器直接消费</summary>
  401. public bool Disabled { get; set; }
  402. public bool Enabled { get; set; }
  403. public int SortNo { get; set; }
  404. public string? Remark { get; set; }
  405. public List<AdoS8DimensionNodeDto> Children { get; set; } = new();
  406. }