| Quintiq file version 2.0 | 
| #parent: #root | 
| Method Generate ( | 
|   MachiningPipelineSearch search, | 
|   Product_MPs products | 
| ) | 
| { | 
|   TextBody: | 
|   [* | 
|     // 甄兰鸽 Jun-25-2024 (created) | 
|     startyearmonth          := search.MacroPlan().StartOfPlanning().StartOfMonth().Date(); | 
|     table                   := selectobject( this, Source.Report, report, not report.IsShow() ); | 
|     //清空之前存储的显示数据 | 
|     this.Clear( search.TimeUnit(), search.StartDate(), search.EndDate() ); | 
|     //过滤后的产品id | 
|     productids              := selectuniquevalues( products, Elements, product, true, product.ID() ); | 
|     sumrow                  := this.Row( relnew, Name := 'SUM', RowNr := table.Row( relsize ) ); | 
|     traverse( table, Row, row, productids.Find( row.Name() ) >= 0 ){ | 
|       showrow               := this.Row( relnew, Name := row.Name(), RowNr := row.RowNr() ); | 
|       traverse( this, Column, column ){ | 
|         daycells            := selectset( row, Cell, cell, cell.Column().TimeUnit() = Translations::MP_GlobalParameters_Day() and | 
|                                             cell.Column().StartDate() >= column.StartDate() and  | 
|                                             cell.Column().StartDate() <= column.EndDate() ); | 
|         maxinventory        := maxobject( daycells, Elements, e, e.Column().StartDate() ); | 
|         ccassemblyplanqty   := sum( daycells, Elements, cell, cell.CCAssemblyPlanQty() ); | 
|         ccproductionqty     := sum( daycells, Elements, cell, cell.CCProductionQty() ); | 
|         cctransferqty       := sum( daycells, Elements, cell, cell.CCTransferQty() ); | 
|         ccinventoryqty      := 0.0; | 
|         dlassemblyplanqty   := sum( daycells, Elements, cell, cell.DLAssemblyPlanQty() ); | 
|         dlproductionqty     := sum( daycells, Elements, cell, cell.DLProductionQty() ); | 
|         dltransferqty       := sum( daycells, Elements, cell, cell.DLTransferQty() ); | 
|         dlinventoryqty      := 0.0; | 
|         if( column.StartDate() = startyearmonth ){//当日期是计划开始第一个月时,计算库存是实际库存 | 
|           ccinventoryqty    := row.CCInventoryQty() + maxinventory.CCProductionQty() - maxinventory.CCToDLDepartureQty() + maxinventory.DLToCCArrivalQty() - maxinventory.CCAssemblyPlanQty(); | 
|           dlinventoryqty    := row.DLInventoryQty() + maxinventory.DLProductionQty() - maxinventory.DLToCCDepartureQty() + maxinventory.CCToDLArrivalQty() - maxinventory.DLAssemblyPlanQty(); | 
|         }else{ | 
|           beforecolumn      := column.PreviousColumn(); | 
|           beforeinventory   := selectobject( showrow, Cell, c, c.Column() = beforecolumn ); | 
|           ccinventoryqty    := beforeinventory.CCInventoryQty() + maxinventory.CCProductionQty() - maxinventory.CCToDLDepartureQty() + maxinventory.DLToCCArrivalQty() - maxinventory.CCAssemblyPlanQty(); | 
|           dlinventoryqty    := beforeinventory.DLInventoryQty() + maxinventory.DLProductionQty() - maxinventory.DLToCCDepartureQty() + maxinventory.DLToCCDepartureQty() - maxinventory.DLAssemblyPlanQty(); | 
|         } | 
|         sumcell  := selectobject( column, Cell, c, c.Row() = sumrow ); | 
|         if( isnull( sumcell ) ){ | 
|           sumcell           := column.Cell( relnew, CCAssemblyPlanQty  := 0,  | 
|                                              CCProductionQty           := 0,  | 
|                                              CCTransferQty             := 0, | 
|                                              CCInventoryQty            := 0,  | 
|                                              DLAssemblyPlanQty         := 0, | 
|                                              DLProductionQty           := 0,  | 
|                                              DLTransferQty             := 0, | 
|                                              DLInventoryQty            := 0 ); | 
|           sumrow.Cell( relinsert, sumcell ); | 
|         } | 
|         showcell            := column.Cell( relnew, CCAssemblyPlanQty  := ccassemblyplanqty,  | 
|                                              CCProductionQty           := ccproductionqty,  | 
|                                              CCTransferQty             := cctransferqty, | 
|                                              CCInventoryQty            := ccinventoryqty,  | 
|                                              DLAssemblyPlanQty         := dlassemblyplanqty, | 
|                                              DLProductionQty           := dlproductionqty,  | 
|                                              DLTransferQty             := dltransferqty, | 
|                                              DLInventoryQty            := dlinventoryqty ); | 
|         showrow.Cell( relinsert, showcell ); | 
|        | 
|         sumcell.Add( showcell ); | 
|       } | 
|     } | 
|     rows                    := selectsortedset( this, Row, row, row.Name(), row.RowNr() ); | 
|     i                       := 0; | 
|     traverse( rows, Elements, e ){ | 
|       e.RowNr( i ); | 
|       i                     := i + 1; | 
|     } | 
|   *] | 
| } |