| Quintiq file version 2.0 | 
| #parent: #root | 
| StaticMethod DeductionOfReplacementLoss ( | 
|   MacroPlan macroPlan, | 
|   OfflinePlanTable opt | 
| ) | 
| { | 
|   TextBody: | 
|   [* | 
|     // 保存上一份存档 | 
|     newOPT := OfflinePlanCell::SaveAsDraft( macroPlan, opt ); | 
|      | 
|     // 执行换型损失 | 
|     allProductionLines := selectuniquevalues( newOPT, OfflinePlanRow, tempORR, true, tempORR.ProductionLine() ); | 
|      | 
|     traverse ( allProductionLines, Elements, pl ) { | 
|       oprs := selectset( newOPT, OfflinePlanRow, tempORT, tempORT.ProductionLine() = pl and ( tempORT.Type() = "1" or tempORT.Type() = "2" ) ); | 
|        | 
|       traverse ( newOPT, OfflinePlanColumn, opc,  | 
|                  opc.ColumnDate() >= macroPlan.StartOfPlanning().Date()  | 
|     //             opc.ColumnDate() >= macroPlan.StartOfPlanning().Date() and opc.ColumnDate() <= Date::Construct( 2024, 4, 17 ) // 测试时可以过滤时间 | 
|                 ) { | 
|         for ( i := 1; i < 10; i++ ) { | 
|           firstOrderCell  := select( oprs, Elements.OfflinePlanCell, tempOPC, tempOPC.OfflinePlanColumn() = opc and tempOPC.Value() = ( "#" + i.Format( "N(LPad0(2))" ) ) ); | 
|           secondOrderCell := select( oprs, Elements.OfflinePlanCell, tempOPC, tempOPC.OfflinePlanColumn() = opc and tempOPC.Value() = ( "#" + ( i + 1 ).Format( "N(LPad0(2))" ) ) ); | 
|           // 换型损失参数 | 
|           cls        := select( macroPlan, ChangeLossSetting, tempCLS,  | 
|                                 guard( tempCLS.ProductFirst().ID()  = firstOrderCell.OfflinePlanRow().ProductID() , false ) and | 
|                                 guard( tempCLS.ProductSecond().ID() = secondOrderCell.OfflinePlanRow().ProductID(), false ) and | 
|                                 guard( tempCLS.StartDate()          <= opc.ColumnDate()                           , false ) and | 
|                                 guard( tempCLS.EndDate()            >= opc.ColumnDate()                           , false ) | 
|                                ); | 
|           if ( not isnull( firstOrderCell ) and not isnull( secondOrderCell ) and not isnull( cls ) ) { | 
|             firstQuantityCell := select( oprs, Elements.OfflinePlanCell, tempOPC,  | 
|                                          tempOPC.OfflinePlanColumn() = opc     and  | 
|                                          tempOPC.OfflinePlanRow().Type() = "1" and  | 
|                                          tempOPC.OfflinePlanRow().ProductID() = firstOrderCell.OfflinePlanRow().ProductID() | 
|                                         ); | 
|             firstQuantityCell.Value( [String] ( [Number]firstQuantityCell.Value() - cls.ChangeLossNumber() ) );                  | 
|     //        info( "当前列时间:", opc.ColumnDate().Format( "Y-M2-D2" ), "    当前序号:", i, "    单元格的值:", firstOrderCell.Value(), "    产品名:", firstOrderCell.OfflinePlanRow().ProductID(), | 
|     //              "下一个序号:", i + 1, "    单元格的值:", secondOrderCell.Value(), "    产品名:", secondOrderCell.OfflinePlanRow().ProductID() ); | 
|           } | 
|         } | 
|       } | 
|     } | 
|      | 
|     // 重置总计行 | 
|     totalOPRs := selectset( newOPT, OfflinePlanRow, tempOPR, tempOPR.Type() = "3" ); | 
|     traverse ( newOPT, OfflinePlanColumn, opc, opc.OfflinePlanCell( relsize ) > 0 and opc.ColumnDate() >= macroPlan.StartOfPlanning().Date() ) { | 
|       traverse ( totalOPRs, Elements, totalOPR ) { | 
|         total     := sum( opc, OfflinePlanCell, tempOPC, tempOPC.OfflinePlanRow().ProductionLine() = totalOPR.ProductionLine() and tempOPC.OfflinePlanRow().Type() = "1", [Real]tempOPC.Value() ); | 
|         totalCell := select( totalOPR, OfflinePlanCell, tempOPC, tempOPC.OfflinePlanColumn() = opc ); | 
|         totalCell.Value( [String]total ); | 
|       } | 
|     } | 
|   *] | 
| } |