Quintiq file version 2.0 
 | 
#parent: #root 
 | 
StaticMethod GenerateData ( 
 | 
  InterfaceDataset owner, 
 | 
  String werk, 
 | 
  const MacroPlan macroplan, 
 | 
  Date startdate, 
 | 
  Date enddate, 
 | 
  String executor 
 | 
) 
 | 
{ 
 | 
  TextBody: 
 | 
  [* 
 | 
    // 甄兰鸽 Aug-23-2024 (created) 
 | 
    loginfo                := maxobject(  owner, InterfaceLoginfo, loginfo, loginfo.Name() = Translations::InterfaceDataset_AOnlineAndMOfflinePlanPIR_Name(), loginfo.InterfaceDateTime() ); 
 | 
    if( not isnull( loginfo ) ){ 
 | 
      if( not loginfo.IsShow() ){ 
 | 
        loginfo.Delete(); 
 | 
      }else{ 
 | 
        loginfo.Last( false ); 
 | 
      } 
 | 
      owner.AOnlineAndMOfflinePlanPIR( relflush ); 
 | 
    } 
 | 
    nowdate                := DateTime::ActualTime(); 
 | 
    productids             := construct( Strings ); 
 | 
    loginfo                := owner.InterfaceLoginfo( relnew, ExecuteUser := executor 
 | 
                                                      , Name := Translations::InterfaceDataset_AOnlineAndMOfflinePlanPIR_Name() 
 | 
                                                      , InterfaceDateTime := nowdate 
 | 
                                                      , Message := '装配上线计划 + 机加下线计划 - PIR' 
 | 
                                                      , IsShow := false 
 | 
                                                      , Last := true 
 | 
                                                      , ReturnSuccess := true 
 | 
                                                      , ReturnMsg := 'Success' 
 | 
                                                      , Success := true 
 | 
                                                      ); 
 | 
    pir                    := owner.AOnlineAndMOfflinePlanPIR( relnew, ZPPPSCode := OS::GenerateGUIDAsString(), Werk := werk, Version := macroplan.ScenarioName(), StartDate := startdate, EndDate := enddate ); 
 | 
    loginfo.AOnlineAndMOfflinePlanPIR( relinsert, pir ); 
 | 
    traverse( macroplan, AssemblyOnlinePlanColumn, column, column.ColumnDate() >= startdate and column.ColumnDate() <= enddate ){ 
 | 
      traverse( column, AssemblyOnlinePlanCell, cell, ( werk = 'All' or cell.AssemblyOnlinePlanRow().ProductionLine().FindString( werk, 0 ) > -1 ) 
 | 
                and cell.AssemblyOnlinePlanRow().Type() = '1' ){ 
 | 
        quantityrow        := cell.AssemblyOnlinePlanRow(); 
 | 
        if( not exists( productids, Elements, e, e = quantityrow.ProductID() ) ){ 
 | 
          productids.Add( quantityrow.ProductID() ); 
 | 
        } 
 | 
     
 | 
        pir.PIRData( relnew, Product           := quantityrow.ProductID() 
 | 
                     , PlanningDate            := column.ColumnDate() 
 | 
                     , PlanningQty             := [Number]cell.Value()); 
 | 
      } 
 | 
    } 
 | 
     
 | 
    traverse( macroplan, OfflinePlanTable, table ){ 
 | 
      traverse( table, OfflinePlanColumn, column, column.ColumnDate() >= startdate and column.ColumnDate() <= enddate ){ 
 | 
        traverse( column, OfflinePlanCell, cell, ( werk = 'All' or cell.OfflinePlanRow().ProductionLine().FindString( werk, 0 ) > -1 ) 
 | 
                  and ( cell.OfflinePlanRow().ProductionLine() <> 'DL_MOMO' or cell.OfflinePlanRow().ProductionLine() <> 'CC_MOMO' ) 
 | 
                  and cell.OfflinePlanRow().Type() = '1' ){ 
 | 
          row              := cell.OfflinePlanRow(); 
 | 
          if( not exists( productids, Elements, e, e = row.ProductID() ) ){ 
 | 
            productids.Add( row.ProductID() ); 
 | 
          } 
 | 
          pirdata          := selectobject(  pir, PIRData, pirdata, pirdata.Product() = row.ProductID() and pirdata.PlanningDate() = column.ColumnDate() ); 
 | 
          if( isnull( pirdata ) ){ 
 | 
            pirdata          := pir.PIRData( relnew, Product         := row.ProductID() 
 | 
                                             , PlanningDate            := column.ColumnDate() 
 | 
                                             , PlanningQty             := 0 ); 
 | 
          } 
 | 
          pirdata.PlanningQty( pirdata.PlanningQty() + [Number]cell.Value() ); 
 | 
        } 
 | 
      } 
 | 
    } 
 | 
    traverse( productids, Elements, e ){ 
 | 
      for( date := startdate.StartOfWeek(); date <= enddate; date := ( date + Duration::Days( 1 ) ).Date() ){ 
 | 
        if( not exists( pir, PIRData, pirdata, pirdata.Product() = e and pirdata.PlanningDate() = date ) ){ 
 | 
          pir.PIRData( relnew, Product         := e 
 | 
                     , PlanningDate            := date 
 | 
                     , PlanningQty             := 0 ); 
 | 
        } 
 | 
      } 
 | 
    } 
 | 
    loginfo.TotalRow( pir.PIRData( relsize ) ); 
 | 
  *] 
 | 
} 
 |