Quintiq file version 2.0 
 | 
#parent: #root 
 | 
Method Generate ( 
 | 
  FinancialSalesSearch search, 
 | 
  Product_MPs products 
 | 
) 
 | 
{ 
 | 
  TextBody: 
 | 
  [* 
 | 
    // 甄兰鸽 Jun-25-2024 (created) 
 | 
    table      := selectobject( this, FinancialSalesSource.FinancialSalesReport, report, not report.IsShow() ); 
 | 
    allunit    := '<All>'; 
 | 
    //清空之前存储的显示数据 
 | 
    this.Clear(); 
 | 
    //过滤后的产品id 
 | 
    productids := selectuniquevalues( products, Elements, product, ( search.Generation() = allunit or product.Generation() = search.Generation() ) 
 | 
                                      and ( search.MqbMlb() = allunit or product.MQBMLB() = search.MqbMlb() ) 
 | 
                                      and ( search.Power() = allunit or product.Power() = search.Power() ), product.ID() ); 
 | 
    sumrow     := this.FinancialSalesRow( relnew, Name := 'SUM', Unit := search.Unit(), RowNr := table.FinancialSalesRow( relsize ) ); 
 | 
    traverse( table, FinancialSalesRow, row, row.Unit() = search.Unit() ){ 
 | 
      productid  := construct( Strings ); 
 | 
      productid.Add( row.Name() ); 
 | 
       
 | 
      if( productids.ContainsAll( productid ) ){ 
 | 
        showrow := this.FinancialSalesRow( relnew, Name := row.Name(), Unit := row.Unit(), RowNr := row.RowNr() ); 
 | 
         
 | 
        traverse( row, FinancialSalesCell, cell, not cell.FinancialSalesColumn().IsDay() ){ 
 | 
          column   := selectobject( this, FinancialSalesColumn, column, column.Name() = cell.FinancialSalesColumn().Name() and not column.IsDay()); 
 | 
           
 | 
          sumcell  := selectobject( column, FinancialSalesCell, c, c.FinancialSalesRow() = sumrow ); 
 | 
          if( isnull( sumcell ) ){ 
 | 
            sumcell := column.FinancialSalesCell( relnew, Value := '0' ); 
 | 
            sumrow.FinancialSalesCell( relinsert, sumcell ); 
 | 
          } 
 | 
           
 | 
          showcell := column.FinancialSalesCell( relnew, Value := cell.Value() ); 
 | 
          showrow.FinancialSalesCell( relinsert, showcell ); 
 | 
          value := [Real]cell.Value() + [Real]sumcell.Value(); 
 | 
          sumcell.Value( [String]value ); 
 | 
        } 
 | 
      } 
 | 
    } 
 | 
  *] 
 | 
} 
 |