namespace Admin.NET.Plugin.AiDOP.Entity.S8.OrderFlow;
///
/// S8-ORDER-CHAIN-BODY-PRODUCTION-ORDER-LEVEL-SEED-FIX-1:
/// S8 订单执行链路本体生产「损失因素」表(baseline + 订单级 SEED)。
///
/// factor_code 取值:MATERIAL / EQUIPMENT / QUALITY / EFFICIENCY / SUBTOTAL(小计行 sort_no=5)。
/// - count_value:baseline 9/6/3/12/30;订单级 round(baseline * ratio)。
/// - ratio_pct:baseline 30/20/10/40/100,订单级保持结构(按用户规则原值复制)。
/// - loss_hours:baseline 9.00/4.50/3.40/9.25/7.50(SUBTOTAL 7.50 来自 fixture,不是 4 因素之和);订单级 round(baseline*ratio,2)。
///
[SugarTable("ado_s8_order_flow_manufacturing_loss_factor", "S8 订单执行链路本体生产损失因素")]
[SugarIndex("idx_order_flow_mfg_loss_baseline", nameof(TenantId), OrderByType.Asc, nameof(FactoryId), OrderByType.Asc, nameof(FactorCode), OrderByType.Asc)]
[SugarIndex("idx_order_flow_mfg_loss_order", nameof(TenantId), OrderByType.Asc, nameof(FactoryId), OrderByType.Asc, nameof(OrderCode), OrderByType.Asc)]
[SugarIndex("idx_order_flow_mfg_loss_scenario", nameof(TenantId), OrderByType.Asc, nameof(FactoryId), OrderByType.Asc, nameof(ScenarioCode), OrderByType.Asc, nameof(IsDeleted), OrderByType.Asc)]
public class AdoS8OrderFlowManufacturingLossFactor
{
[SugarColumn(ColumnName = "id", IsPrimaryKey = true, ColumnDataType = "bigint")]
public long Id { get; set; }
/// NULL = baseline 行;非 NULL = 订单级行。
[SugarColumn(ColumnName = "order_id", ColumnDataType = "bigint", IsNullable = true)]
public long? OrderId { get; set; }
/// NULL = baseline 行;非 NULL = 订单业务键。
[SugarColumn(ColumnName = "order_code", Length = 64, IsNullable = true)]
public string? OrderCode { get; set; }
/// 因素编码:MATERIAL / EQUIPMENT / QUALITY / EFFICIENCY / SUBTOTAL。
[SugarColumn(ColumnName = "factor_code", Length = 32)]
public string FactorCode { get; set; } = string.Empty;
/// 因素名称:材料影响 / 设备影响 / 质量影响 / 作业效率损失 / 损失小计。
[SugarColumn(ColumnName = "factor_name", Length = 32)]
public string FactorName { get; set; } = string.Empty;
/// 件数。baseline 9/6/3/12/30;订单级 round(baseline*ratio)。SUBTOTAL = 30*ratio。
[SugarColumn(ColumnName = "count_value", ColumnDataType = "int", IsNullable = true)]
public int? CountValue { get; set; }
/// 占比百分比(0~100)。baseline 30/20/10/40/100;订单级保持结构(复制 baseline 值)。decimal(5,2)。
[SugarColumn(ColumnName = "ratio_pct", DecimalDigits = 2, Length = 5, IsNullable = true)]
public decimal? RatioPct { get; set; }
/// 损失工时(小时)。baseline 9.00/4.50/3.40/9.25/7.50;订单级 round(baseline*ratio,2)。decimal(8,2)。
[SugarColumn(ColumnName = "loss_hours", DecimalDigits = 2, Length = 8, IsNullable = true)]
public decimal? LossHours { get; set; }
/// 排序号 1..5(材料/设备/质量/效率/小计)。
[SugarColumn(ColumnName = "sort_no", ColumnDataType = "int")]
public int SortNo { get; set; }
/// BASELINE_PPT / ORDER_LEVEL。
[SugarColumn(ColumnName = "scenario_code", Length = 16)]
public string ScenarioCode { get; set; } = "BASELINE_PPT";
/// SEED / IMPORT / AGG。
[SugarColumn(ColumnName = "data_source", Length = 16)]
public string DataSource { get; set; } = "SEED";
[SugarColumn(ColumnName = "tenant_id", ColumnDataType = "bigint")]
public long TenantId { get; set; }
[SugarColumn(ColumnName = "factory_id", ColumnDataType = "bigint")]
public long FactoryId { get; set; }
[SugarColumn(ColumnName = "created_at")]
public DateTime CreatedAt { get; set; } = DateTime.Now;
[SugarColumn(ColumnName = "updated_at", IsNullable = true)]
public DateTime? UpdatedAt { get; set; }
[SugarColumn(ColumnName = "is_deleted", ColumnDataType = "boolean")]
public bool IsDeleted { get; set; }
}