| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490 |
- namespace Admin.NET.Plugin.AiDOP.Dto.S8.OrderFlow;
- /// <summary>
- /// ORDER-FLOW-S8-INTEGRATED-DOMAIN-RESET-1 t3a:S8 订单执行链路 DTO 契约。
- /// 仅定义类型,不携带业务常量 / 不引用 Entity / 不接 service 逻辑。
- /// 后续 t3b/t3c 切片负责 service + controller 把 DTO 接到 ado_s8_order_flow_* 与 ado_s8_exception 实时聚合。
- /// </summary>
- #region 订单档案
- public class AdoS8OrderFlowOrderQueryDto
- {
- public long? TenantId { get; set; }
- public long? FactoryId { get; set; }
- public string? Keyword { get; set; }
- public string? CurrentFlowCode { get; set; }
- public string? CustomerCode { get; set; }
- public string? ProductLine { get; set; }
- public string? Region { get; set; }
- public string? WorkflowStatus { get; set; }
- public string? ScenarioCode { get; set; }
- }
- public class AdoS8OrderFlowOrderListItemDto
- {
- public string OrderCode { get; set; } = string.Empty;
- public string ProductName { get; set; } = string.Empty;
- public string ProductLine { get; set; } = string.Empty;
- public string CustomerCode { get; set; } = string.Empty;
- public string CustomerName { get; set; } = string.Empty;
- public string CustomerType { get; set; } = string.Empty;
- public string Region { get; set; } = string.Empty;
- public string Priority { get; set; } = string.Empty;
- public string WorkflowStatus { get; set; } = string.Empty;
- public string CurrentOrderFlowCode { get; set; } = string.Empty;
- public string CurrentOrderFlowName { get; set; } = string.Empty;
- public string CurrentStatus { get; set; } = string.Empty;
- public DateTime ReleaseAt { get; set; }
- public decimal TargetCycleDays { get; set; }
- public decimal? ActualCycleDays { get; set; }
- public decimal? CurrentCycleDays { get; set; }
- public decimal? NodeVarianceDays { get; set; }
- public decimal? CumulativeVarianceDays { get; set; }
- /// <summary>来自 ado_s8_exception 实时聚合(order 主档表无 exception_count 列)。</summary>
- public int ExceptionCount { get; set; }
- public string ExceptionStatus { get; set; } = string.Empty;
- public int? ResponseMinutes { get; set; }
- public int? ProcessingMinutes { get; set; }
- public int? TotalLossMinutes { get; set; }
- public string ScenarioCode { get; set; } = string.Empty;
- public string DataSource { get; set; } = string.Empty;
- }
- public class AdoS8OrderFlowOrderDetailDto : AdoS8OrderFlowOrderListItemDto
- {
- public List<AdoS8OrderFlowStageDto> Lifecycle { get; set; } = new();
- }
- #endregion
- #region 阶段 / L2 / L3
- public class AdoS8OrderFlowStageDto
- {
- public string OrderFlowCode { get; set; } = string.Empty;
- public string OrderFlowName { get; set; } = string.Empty;
- public string? OwnerDept { get; set; }
- public int SortNo { get; set; }
- public decimal PlannedDays { get; set; }
- public decimal? ActualDays { get; set; }
- public DateTime TargetAt { get; set; }
- public DateTime? ActualStartAt { get; set; }
- public DateTime? ActualEndAt { get; set; }
- public string Status { get; set; } = string.Empty;
- public decimal? NodeVarianceDays { get; set; }
- public decimal? CumulativeVarianceDays { get; set; }
- public List<AdoS8OrderFlowSubstepDto> Substeps { get; set; } = new();
- }
- public class AdoS8OrderFlowSubstepDto
- {
- public string SubstepCode { get; set; } = string.Empty;
- public string SubstepName { get; set; } = string.Empty;
- public decimal PiHours { get; set; }
- public decimal? ActualHours { get; set; }
- public string Status { get; set; } = string.Empty;
- public int SortNo { get; set; }
- public List<AdoS8OrderFlowSubstepUnitDto> Units { get; set; } = new();
- }
- public class AdoS8OrderFlowSubstepUnitDto
- {
- public string UnitCode { get; set; } = string.Empty;
- public string UnitName { get; set; } = string.Empty;
- public decimal PiHours { get; set; }
- public decimal? ActualHours { get; set; }
- public string Status { get; set; } = string.Empty;
- public int SortNo { get; set; }
- }
- #endregion
- #region 订单 + 采购透视组合
- public class AdoS8OrderFlowChainDto
- {
- public AdoS8OrderFlowOrderDetailDto Order { get; set; } = new();
- public AdoS8OrderFlowProcurementPivotDto? ProcurementPivot { get; set; }
- }
- #endregion
- #region 聚合 / Baseline
- public class AdoS8OrderFlowAggregateQueryDto
- {
- public long? TenantId { get; set; }
- public long? FactoryId { get; set; }
- public string Scope { get; set; } = string.Empty;
- public List<string>? OrderCodes { get; set; }
- }
- public class AdoS8OrderFlowAggregateDto
- {
- public string Scope { get; set; } = string.Empty;
- public int TotalOrders { get; set; }
- public int TotalCustomers { get; set; }
- public decimal AvgResponseMinutes { get; set; }
- public decimal AvgProcessingMinutes { get; set; }
- public decimal AvgLossMinutes { get; set; }
- public List<AdoS8OrderFlowStageAggregateDto> StageAggregates { get; set; } = new();
- /// <summary>
- /// FINAL_ASSEMBLY_DELIVERY 末端协同聚合摘要(基线 / 当前两条路径均填充)。
- /// 派生自 ado_s8_exception 现有异常类型,不新增业务表 / 不新增异常类型 / 不读 S0|S4 业务表。
- /// 字段全 nullable,老调用方无感知。
- /// </summary>
- public AdoS8FinalAssemblyCollabSummaryDto? FinalAssemblyCollabSummary { get; set; }
- }
- public class AdoS8FinalAssemblyCollabSummaryDto
- {
- /// <summary>主门禁(GATE)—— key 为前端固定 object_code(如 GOODS_HANDOVER / SHIPMENT_CONFIRMATION)。无映射的门禁不出现在字典中。</summary>
- public Dictionary<string, AdoS8FinalAssemblyObjectStatDto> Gates { get; set; } = new();
- /// <summary>并行准备(PARALLEL)—— key 为前端固定 object_code(如 SHIPPING_PLAN)。无映射的准备项不出现在字典中。</summary>
- public Dictionary<string, AdoS8FinalAssemblyObjectStatDto> Parallels { get; set; } = new();
- }
- public class AdoS8FinalAssemblyObjectStatDto
- {
- /// <summary>主门禁口径下的"影响订单"数 = 命中候选异常类型的去重 RelatedObjectCode 数;并行准备口径下保持 null。</summary>
- public int? ImpactedOrderCount { get; set; }
- /// <summary>并行准备口径下的"风险订单"数 = 命中候选异常类型的去重 RelatedObjectCode 数;主门禁口径下保持 null。</summary>
- public int? RiskOrderCount { get; set; }
- /// <summary>主要风险标题:候选异常中按 Severity(SERIOUS 优先) → CreatedAt(降序) 取首条 Title。无命中保持 null。</summary>
- public string? TopRiskTitle { get; set; }
- /// <summary>主要风险严重度:与 TopRiskTitle 来自同一条异常。无命中保持 null。</summary>
- public string? TopRiskSeverity { get; set; }
- }
- public class AdoS8OrderFlowStageAggregateDto
- {
- public string OrderFlowCode { get; set; } = string.Empty;
- public string OrderFlowName { get; set; } = string.Empty;
- public decimal KpiAvgDays { get; set; }
- public decimal ActualAvgDays { get; set; }
- /// <summary>整数百分比(例如 59 / 96 / 85 / 89 / 96),不是 0.59 小数。</summary>
- public int OnTimeRate { get; set; }
- public int Green { get; set; }
- public int Yellow { get; set; }
- public int Red { get; set; }
- public int Pending { get; set; }
- }
- #endregion
- #region 采购透视
- public class AdoS8OrderFlowProcurementPivotQueryDto
- {
- public long? TenantId { get; set; }
- public long? FactoryId { get; set; }
- public string Scope { get; set; } = string.Empty;
- /// <summary>
- /// 订单编码 CSV(与产品设计 drawings API 对齐)。
- /// 例如:单订单 "SO-2026-001";多订单 "SO-2026-001,SO-2026-002,SO-2026-006"。
- /// 与 axios 默认 brackets 序列化不兼容,统一用 CSV 字符串避免 ASP.NET Core List 绑定二义性。
- /// </summary>
- public string? OrderCodes { get; set; }
- }
- public class AdoS8OrderFlowProcurementPivotDto
- {
- public string Scope { get; set; } = string.Empty;
- public List<AdoS8OrderFlowKeyMaterialDto> KeyMaterials { get; set; } = new();
- public List<AdoS8OrderFlowSupplierBreakdownDto> SupplierBreakdown { get; set; } = new();
- public List<AdoS8OrderFlowSpecBreakdownDto> SpecBreakdown { get; set; } = new();
- public Dictionary<string, List<AdoS8OrderFlowProcurementMatrixRowDto>> MatrixByMaterial { get; set; } = new();
- }
- public class AdoS8OrderFlowKeyMaterialDto
- {
- public string MaterialCode { get; set; } = string.Empty;
- public decimal AvgCycleDays { get; set; }
- public string CycleStatus { get; set; } = string.Empty;
- public int? ImpactCount { get; set; }
- public decimal? KitRate { get; set; }
- public string ResultStatus { get; set; } = string.Empty;
- }
- public class AdoS8OrderFlowSupplierBreakdownDto
- {
- public string MaterialCode { get; set; } = string.Empty;
- public string SupplierCode { get; set; } = string.Empty;
- public decimal AvgCycleDays { get; set; }
- public string Status { get; set; } = string.Empty;
- }
- public class AdoS8OrderFlowSpecBreakdownDto
- {
- public string MaterialCode { get; set; } = string.Empty;
- public string SpecCode { get; set; } = string.Empty;
- public decimal AvgCycleDays { get; set; }
- public string Status { get; set; } = string.Empty;
- }
- public class AdoS8OrderFlowProcurementMatrixRowDto
- {
- public string SupplierCode { get; set; } = string.Empty;
- public Dictionary<string, AdoS8OrderFlowProcurementMatrixCellDto> Cells { get; set; } = new();
- }
- public class AdoS8OrderFlowProcurementMatrixCellDto
- {
- public decimal CycleDays { get; set; }
- public string Status { get; set; } = string.Empty;
- }
- #endregion
- #region 关联异常
- public class AdoS8OrderFlowRelatedExceptionQueryDto
- {
- public long? TenantId { get; set; }
- public long? FactoryId { get; set; }
- public string OrderCode { get; set; } = string.Empty;
- public string? OrderFlowCode { get; set; }
- }
- #endregion
- #region 产品设计图号
- /// <summary>
- /// S8-ORDER-CHAIN-PRODUCT-DESIGN-DRAWING-PERSIST-1:产品设计图号查询入参。
- /// orderCodes 为空 → 默认聚合全 20 单(scope=BASELINE_PPT);
- /// orderCodes 非空 → 仅命中订单范围聚合(scope=CURRENT_FILTERED)。
- /// productType 仅过滤 drawings 列表,不改变 summary.categories 的"常规/非标/合计"三档结构。
- /// </summary>
- public class AdoS8OrderFlowProductDesignDrawingsQueryDto
- {
- public long? TenantId { get; set; }
- public long? FactoryId { get; set; }
- /// <summary>逗号分隔订单号;为空时默认全 20 单。</summary>
- public string? OrderCodes { get; set; }
- /// <summary>STANDARD / NON_STANDARD;为空时返回全量并保留三档汇总。</summary>
- public string? ProductType { get; set; }
- }
- /// <summary>查询条件回显,便于前端固定下钻状态。</summary>
- public class AdoS8OrderFlowProductDesignFilterDto
- {
- public List<string> OrderCodes { get; set; } = new();
- public string? ProductType { get; set; }
- }
- public class AdoS8OrderFlowProductDesignDrawingItemDto
- {
- public string OrderCode { get; set; } = string.Empty;
- public string DrawingNo { get; set; } = string.Empty;
- /// <summary>STANDARD / NON_STANDARD。</summary>
- public string ProductType { get; set; } = string.Empty;
- /// <summary>责任单位/岗位(研发中心 / 结构设计组 / 电气设计组 / 工艺设计组 / 设计审核组)。</summary>
- public string ResponsiblePerson { get; set; } = string.Empty;
- public DateTime PlannedStartDate { get; set; }
- public DateTime PlannedEndDate { get; set; }
- public DateTime? ActualStartDate { get; set; }
- public DateTime? ActualEndDate { get; set; }
- public decimal KpiDays { get; set; }
- public decimal? ActualDays { get; set; }
- public bool IsAchieved { get; set; }
- /// <summary>green / yellow / red / pending。</summary>
- public string Status { get; set; } = string.Empty;
- /// <summary>该图号对应台数;台数/占比/加权达成率三种口径的唯一来源。</summary>
- public int ProductQuantity { get; set; }
- }
- public class AdoS8OrderFlowProductDesignOverallSummaryDto
- {
- public int DrawingCount { get; set; }
- public int TotalQuantity { get; set; }
- public decimal KpiDays { get; set; }
- /// <summary>图号 actual_days 算术平均(非加权),保留小数原值,由前端格式化为 2 位。</summary>
- public decimal AvgActualDays { get; set; }
- /// <summary>按 product_quantity 加权达标率,小数 0~1,由前端格式化为整数百分比。</summary>
- public decimal AchievementRate { get; set; }
- }
- public class AdoS8OrderFlowProductDesignCategorySummaryDto
- {
- /// <summary>STANDARD / NON_STANDARD / TOTAL。</summary>
- public string ProductType { get; set; } = string.Empty;
- public string Name { get; set; } = string.Empty;
- public int DrawingCount { get; set; }
- public int TotalQuantity { get; set; }
- /// <summary>product_quantity 占合计比例,小数 0~1,由前端格式化为 1 位百分比。</summary>
- public decimal Ratio { get; set; }
- /// <summary>S8-ORDER-CHAIN-PRODUCT-DESIGN-PPT-STATIC-AND-SINGLE-ORDER-ALIGN-1:常规/合计返回 null,前端展示 --;非标返回真实平均设计周期。</summary>
- public decimal? AvgActualDays { get; set; }
- /// <summary>常规/合计返回 null,前端展示 --;非标返回 3 天 PRODUCT_DESIGN 阶段 KPI。</summary>
- public decimal? KpiDays { get; set; }
- /// <summary>常规/合计返回 null,前端展示 --;非标返回加权达成率。</summary>
- public decimal? AchievementRate { get; set; }
- /// <summary>green / yellow / red / ''(空 = 无数据,前端展示 --)。由 achievement_rate 分档得出,不再二次判定。</summary>
- public string Status { get; set; } = string.Empty;
- }
- public class AdoS8OrderFlowProductDesignSummaryDto
- {
- public AdoS8OrderFlowProductDesignOverallSummaryDto Overall { get; set; } = new();
- public List<AdoS8OrderFlowProductDesignCategorySummaryDto> Categories { get; set; } = new();
- }
- public class AdoS8OrderFlowProductDesignDrawingsDto
- {
- /// <summary>BASELINE_PPT(默认全 20 单)/ CURRENT_FILTERED(命中订单子集)。</summary>
- public string Scope { get; set; } = string.Empty;
- public AdoS8OrderFlowProductDesignFilterDto Filter { get; set; } = new();
- public AdoS8OrderFlowProductDesignSummaryDto Summary { get; set; } = new();
- public List<AdoS8OrderFlowProductDesignDrawingItemDto> Drawings { get; set; } = new();
- }
- #endregion
- #region 本体生产(设备制造) — S8-ORDER-CHAIN-BODY-PRODUCTION-ORDER-LEVEL-SEED-FIX-1
- /// <summary>
- /// 本体生产「工序明细 / 损失因素 / 操作员表现」三表透视查询入参。
- /// orderCodes CSV:与产品设计 drawings API、采购透视 API 对齐,避免 axios brackets 与 ASP.NET Core List 绑定二义性。
- /// scope=BASELINE_PPT 时 orderCodes 忽略;scope=CURRENT_FILTERED 时 orderCodes 为空返回空骨架(不静默 fallback baseline)。
- /// </summary>
- public class AdoS8OrderFlowManufacturingPivotQueryDto
- {
- public long? TenantId { get; set; }
- public long? FactoryId { get; set; }
- /// <summary>BASELINE_PPT | CURRENT_FILTERED</summary>
- public string Scope { get; set; } = string.Empty;
- /// <summary>逗号分隔订单号;scope=CURRENT_FILTERED 时使用。</summary>
- public string? OrderCodes { get; set; }
- }
- /// <summary>
- /// 工序明细行:P10 / P20 / P30 / P40 / TOTAL。
- /// pi_days / actual_days 保留 decimal(6,3) 精度;plan_qty 在 TOTAL 行为 null。
- /// achievement_rate 在 TOTAL 行 baseline 来自 fixture(0.9000)、订单级按 plan_qty 加权平均;其它行 baseline 复用。
- /// </summary>
- public class AdoS8OrderFlowManufacturingProcessDto
- {
- public string ProcessCode { get; set; } = string.Empty;
- public string ProcessName { get; set; } = string.Empty;
- public decimal PiDays { get; set; }
- public decimal ActualDays { get; set; }
- public string CycleStatus { get; set; } = string.Empty;
- public int? PlanQty { get; set; }
- public decimal? AchievementRate { get; set; }
- public string AchievementStatus { get; set; } = string.Empty;
- public int SortNo { get; set; }
- }
- /// <summary>损失因素行:MATERIAL / EQUIPMENT / QUALITY / EFFICIENCY / SUBTOTAL。</summary>
- public class AdoS8OrderFlowManufacturingLossFactorDto
- {
- public string FactorCode { get; set; } = string.Empty;
- public string FactorName { get; set; } = string.Empty;
- public int? CountValue { get; set; }
- public decimal? RatioPct { get; set; }
- public decimal? LossHours { get; set; }
- public int SortNo { get; set; }
- }
- /// <summary>操作员表现行:OP_ZHANG / OP_LI / OP_WANG。</summary>
- public class AdoS8OrderFlowManufacturingOperatorDto
- {
- public string OperatorCode { get; set; } = string.Empty;
- public string OperatorName { get; set; } = string.Empty;
- public decimal AvgHours { get; set; }
- public string Status { get; set; } = string.Empty;
- public int SortNo { get; set; }
- }
- /// <summary>本体生产透视聚合结果:scope + 工序 / 损失 / 操作员 三组。</summary>
- public class AdoS8OrderFlowManufacturingPivotDto
- {
- /// <summary>BASELINE_PPT | CURRENT_FILTERED</summary>
- public string Scope { get; set; } = string.Empty;
- public List<AdoS8OrderFlowManufacturingProcessDto> Processes { get; set; } = new();
- public List<AdoS8OrderFlowManufacturingLossFactorDto> LossFactors { get; set; } = new();
- public List<AdoS8OrderFlowManufacturingOperatorDto> Operators { get; set; } = new();
- }
- #endregion
- #region 总装发货 — S8-ORDER-CHAIN-ASSEMBLY-DELIVERY-DATA-LINEAGE-AUDIT-1
- /// <summary>
- /// 总装发货「主门禁里程碑 / 并行准备」透视查询入参。
- /// orderCodes CSV:与本体生产 / 产品设计 / 采购透视 API 对齐,规避 axios brackets 与 ASP.NET Core List 绑定二义性。
- /// scope=BASELINE_PPT 时 orderCodes 忽略;scope=CURRENT_FILTERED 时 orderCodes 为空返回空骨架(不静默 fallback baseline)。
- /// 与既有 aggregate.finalAssemblyCollabSummary 通道独立:本 API 提供门禁 KPI / 实际 / 偏差 / 齐套率,
- /// aggregate 仍保留异常派生通道作为补充。
- /// </summary>
- public class AdoS8FinalAssemblyPivotQueryDto
- {
- public long? TenantId { get; set; }
- public long? FactoryId { get; set; }
- /// <summary>BASELINE_PPT | CURRENT_FILTERED</summary>
- public string Scope { get; set; } = string.Empty;
- /// <summary>逗号分隔订单号;scope=CURRENT_FILTERED 时使用。</summary>
- public string? OrderCodes { get; set; }
- }
- /// <summary>
- /// 主门禁里程碑行:ASSEMBLY_COMPLETION / QUALITY_RELEASE / PACKAGING_COMPLETION / GOODS_HANDOVER / SHIPMENT_CONFIRMATION。
- /// planned_offset_days 为累计里程碑(0.6/1.2/1.8/2.4/3.0);末位 SHIPMENT_CONFIRMATION.actual_offset_days 守恒为 stage.actual_days。
- /// pending 单不进入聚合结果。
- /// </summary>
- public class AdoS8FinalAssemblyGateDto
- {
- public string GateCode { get; set; } = string.Empty;
- public string GateName { get; set; } = string.Empty;
- public decimal PlannedOffsetDays { get; set; }
- public decimal? ActualOffsetDays { get; set; }
- public decimal? VarianceDays { get; set; }
- public string Status { get; set; } = string.Empty;
- public int? ImpactedOrderCount { get; set; }
- public int? RiskOrderCount { get; set; }
- public string? TopRiskType { get; set; }
- public string? TopRiskLabel { get; set; }
- public string? OwnerSideText { get; set; }
- public int SortNo { get; set; }
- }
- /// <summary>
- /// 并行准备行:PACKAGING_MATERIAL_PREP / LABEL_DOC_PREP / SHIPPING_PLAN / SHIPPING_DOC_PREP。
- /// kitting_rate 取值 0.0000~1.0000;status 按 ≥0.95 green / ≥0.85 yellow / 否则 red 派生(seed 时固化,运行期不重判)。
- /// </summary>
- public class AdoS8FinalAssemblyParallelDto
- {
- public string PrepCode { get; set; } = string.Empty;
- public string PrepName { get; set; } = string.Empty;
- public decimal? KittingRate { get; set; }
- public string Status { get; set; } = string.Empty;
- public int? ImpactedOrderCount { get; set; }
- public int? RiskOrderCount { get; set; }
- public string? TopRiskType { get; set; }
- public string? TopRiskLabel { get; set; }
- public string? OwnerSideText { get; set; }
- public int SortNo { get; set; }
- }
- /// <summary>总装发货透视聚合结果:scope + 5 门禁 + 4 并行准备。</summary>
- public class AdoS8FinalAssemblyPivotDto
- {
- /// <summary>BASELINE_PPT | CURRENT_FILTERED</summary>
- public string Scope { get; set; } = string.Empty;
- public List<AdoS8FinalAssemblyGateDto> Gates { get; set; } = new();
- public List<AdoS8FinalAssemblyParallelDto> ParallelPreps { get; set; } = new();
- }
- #endregion
|