Quintiq file version 2.0
|
#parent: #root
|
Method Comparison (
|
RecycleBin recycleBin,
|
const Archive archive
|
) as LocalTable
|
{
|
TextBody:
|
[*
|
// rislai Jul-17-2024 (created)
|
macroPlan := this.MacroPlan();
|
table := recycleBin.LocalTable( relnew,Name := LocalCell_ProductionComparison::GetTableName());
|
|
actualDailyProductionDatas := selectset( archive,ActualDailyProductionData,data,true );
|
actualDailyProductionDataIndexTree := NamedValueTree::Create();
|
for( i := 0; i< actualDailyProductionDatas.Size(); i++ ){
|
actualDailyProductionData := actualDailyProductionDatas.Element( i );
|
actualDailyProductionDataKey := actualDailyProductionData.ProductNo() + actualDailyProductionData.ProductionDate().AsQUILL();
|
actualDailyProductionDataHandle := actualDailyProductionDataIndexTree.GetHandle( actualDailyProductionDataKey );
|
actualDailyProductionDataIndexTree.Root().AddChild( actualDailyProductionDataHandle,i );
|
}
|
|
localColumns := construct( LocalColumns );
|
localColumnIndexTree := NamedValueTree::Create();
|
traverse( this,NewOfflinePlanColumn,column,column.StartDate() >= macroPlan.StartOfPlanning().Date()){
|
localColumn := table.LocalColumn( relnew,CustomDate := column.StartDate(),TimeUnit := "Day");
|
localColumnHandle := localColumnIndexTree.GetHandle( column.StartDate().AsQUILL() );
|
localColumns.Add( localColumn );
|
localColumnIndexTree.Root().AddChild( localColumnHandle,localColumns.Size() - 1 );
|
}
|
|
traverse( this,NewOfflinePlanRow,row,row.Type() = "1" ){
|
productID := row.ProductID();
|
productLine := row.ProductionLine();
|
localRow := table.LocalRow( relnew,Index := table.GetRowIndexCache(),CustomName := productID + " > " + productLine,ProductID := productID,ProductionLine := productLine );
|
traverse( row,NewOfflinePlanCell,cell,cell.NewOfflinePlanColumn().StartDate() >= macroPlan.StartOfPlanning().Date() ){
|
localColumnHandle := localColumnIndexTree.GetHandle( cell.NewOfflinePlanColumn().StartDate().AsQUILL() );
|
localColumnIndex := guard( localColumnIndexTree.Root().Child( localColumnHandle ),null( NamedValue ));
|
if( not isnull( localColumnIndex )){
|
actualDailyProductionDataKey := productID + cell.NewOfflinePlanColumn().StartDate().AsQUILL();
|
actualDailyProductionDataHandle := actualDailyProductionDataIndexTree.GetHandle( actualDailyProductionDataKey );
|
actualDailyProductionDataIndex := guard( actualDailyProductionDataIndexTree.Root().Child( actualDailyProductionDataHandle ),null( NamedValue ));
|
|
actualDailyProductionVolume := 0.0;
|
if( not isnull( actualDailyProductionDataIndex )){
|
actualDailyProductionData := actualDailyProductionDatas.Element( actualDailyProductionDataIndex.GetValueAsNumber() );
|
actualDailyProductionVolume := actualDailyProductionData.ActualOut();
|
}
|
localColumn := localColumns.Element( localColumnIndex.GetValueAsNumber() );
|
localRow.LocalCell( relnew,LocalCell_ProductionComparison ,LocalColumn := localColumn,
|
Plan := cell.Quantity(),Actual := actualDailyProductionVolume );
|
}
|
}
|
}
|
traverse( table,LocalColumn,column ){
|
if( column.LocalCell( relsize ) = 0 ){
|
column.Delete();
|
}
|
}
|
// maxCellCount := table.LocalRow( relsize );
|
|
//traverse( table,LocalColumn,column ){
|
// cellIndexTree := NamedValueTree::Create();
|
// columnKey := column.CustomDate().AsQUILL();
|
// count := 0;
|
// traverse( column,LocalCell,cell ){
|
// rowKey := cell.LocalRow().CustomName();
|
// cellHandle := cellIndexTree.GetHandle( rowKey + columnKey );
|
// cellIndexTree.Root().AddChild( cellHandle,count );
|
// count++;
|
// }
|
// traverse( table,LocalRow,row ){
|
// rowKey := row.CustomName();
|
// cellHandle := cellIndexTree.GetHandle( rowKey + columnKey );
|
// cellCount := guard( cellIndexTree.Root().Child( cellHandle ),null( NamedValue ));
|
// if( isnull( cellCount )){
|
// row.LocalCell( relnew,LocalCell_ProductionComparison ,LocalColumn := column,
|
// Plan := 0,Actual := 0 );
|
// }
|
// }
|
//}
|
|
traverse( table,LocalRow,row ){
|
cellCountTree := NamedValueTree::Create();
|
traverse( row,LocalCell,cell ){
|
cellHandle := cellCountTree.GetHandle( cell.LocalColumn().CustomDate().AsQUILL());
|
cellCountTree.Root().AddChild( cellHandle,0 );
|
}
|
traverse( table,LocalColumn,column ){
|
cellHandle := cellCountTree.GetHandle( column.CustomDate().AsQUILL());
|
cell := guard( cellCountTree.Root().Child( cellHandle ),null( NamedValue ));
|
if( isnull( cell )){
|
row.LocalCell( relnew,LocalCell_ProductionComparison ,LocalColumn := column,Plan := 0,Actual := 0 );
|
}
|
}
|
}
|
|
startDate := minselect( table,LocalColumn,localColumn,localColumn.CustomDate() ).CustomDate();
|
endDate := maxselect( table,LocalColumn,localColumn,localColumn.CustomDate() ).CustomDate();
|
for( i := startDate.StartOfWeek(); i <= endDate.StartOfNextWeek(); i := i.StartOfNextWeek() ){
|
timeUnit := "Week";
|
localColumnHandle := localColumnIndexTree.GetHandle( i.AsQUILL() + timeUnit);
|
localColumn := table.LocalColumn( relnew,CustomDate := i,TimeUnit := timeUnit );
|
localColumns.Add( localColumn );
|
localColumnIndexTree.Root().AddChild( localColumnHandle,localColumns.Size() - 1 );
|
}
|
for( i := startDate.StartOfMonth(); i <= endDate.StartOfNextMonth(); i := i.StartOfNextMonth() ){
|
timeUnit := "Month";
|
localColumnHandle := localColumnIndexTree.GetHandle( i.AsQUILL() + timeUnit);
|
localColumn := table.LocalColumn( relnew,CustomDate := i,TimeUnit := timeUnit );
|
localColumns.Add( localColumn );
|
localColumnIndexTree.Root().AddChild( localColumnHandle,localColumns.Size() - 1 );
|
}
|
traverse( table,LocalRow,row ){
|
traverse( table,LocalColumn,column,column.TimeUnit() = "Week"){
|
actual := sum( row,LocalCell.astype( LocalCell_ProductionComparison ),cell,
|
cell.LocalColumn().TimeUnit() = "Day" and
|
cell.LocalColumn().CustomDate() >= column.CustomDate() and
|
cell.LocalColumn().CustomDate() < column.CustomDate().StartOfNextWeek(), cell.Actual());
|
plan := sum( row,LocalCell.astype( LocalCell_ProductionComparison ),cell,
|
cell.LocalColumn().TimeUnit() = "Day" and
|
cell.LocalColumn().CustomDate() >= column.CustomDate() and
|
cell.LocalColumn().CustomDate() < column.CustomDate().StartOfNextWeek(), cell.Plan());
|
|
row.LocalCell( relnew,LocalCell_ProductionComparison,LocalColumn := column,Actual := actual,Plan := plan );
|
}
|
}
|
traverse( table,LocalRow,row ){
|
traverse( table,LocalColumn,column,column.TimeUnit() = "Month"){
|
actual := sum( row,LocalCell.astype( LocalCell_ProductionComparison ),cell,
|
cell.LocalColumn().TimeUnit() = "Day" and
|
cell.LocalColumn().CustomDate() >= column.CustomDate() and
|
cell.LocalColumn().CustomDate() < column.CustomDate().StartOfNextMonth(), cell.Actual());
|
plan := sum( row,LocalCell.astype( LocalCell_ProductionComparison ),cell,
|
cell.LocalColumn().TimeUnit() = "Day" and
|
cell.LocalColumn().CustomDate() >= column.CustomDate() and
|
cell.LocalColumn().CustomDate() < column.CustomDate().StartOfNextMonth(), cell.Plan());
|
|
row.LocalCell( relnew,LocalCell_ProductionComparison,LocalColumn := column,Actual := actual,Plan := plan );
|
}
|
}
|
|
return table;
|
*]
|
}
|