Quintiq file version 2.0
|
#parent: #root
|
StaticMethod RefreshData (
|
InterfaceDataset interface,
|
const MacroPlan macroPlan,
|
const Archive archive
|
)
|
{
|
TextBody:
|
[*
|
//根据当前版本的下线计划
|
allunit := OfflinePlanArchiveVersion::GetDefaultAllUnit();
|
name := OfflinePlanArchiveVersion::GetDefaultName();
|
interface.OfflinePlanArchiveSearch( relnew, Product := allunit, ProductionLine := allunit, TimeUnit := Translations::MP_GlobalParameters_Day(), Unit := allunit, StartDate := Date::MinDate(), EndDate := Date::MaxDate() );
|
table := selectobject( interface, OfflinePlanArchiveVersion, version, not version.IsShow() );
|
if( isnull( table ) ){
|
table := interface.OfflinePlanArchiveVersion( relnew, ID := name, Name := name );
|
}
|
//showtable := selectobject( interface, OfflinePlanArchiveVersion, version, version.IsShow() );
|
//if( isnull( table ) ){
|
// showtable := interface.OfflinePlanArchiveVersion( relnew, ID := name, Name := name, IsShow := true );
|
//}
|
nopcolumns := selectuniquevalues( macroPlan, NewOfflinePlanTable.NewOfflinePlanColumn, nopcolumn, not exists( table, Column, column, column.TimeUnit() = Translations::MP_GlobalParameters_Day() and column.StartDate() = nopcolumn.StartDate() ), nopcolumn.StartDate() );
|
table.GenerateColumn( nopcolumns );
|
noptable := maxobject( macroPlan, NewOfflinePlanTable, noptable, noptable.SaveDateTime() );
|
actproductiondatas := selectset( archive,ActualDailyProductionData,data,true );
|
actproductiontree := NamedValueTree::Create();
|
for( i := 0; i< actproductiondatas.Size(); i++ ){
|
actproduction := actproductiondatas.Element( i );
|
actproductionKey := actproduction.ProductNo() + actproduction.ProductionDate().AsQUILL();
|
actproductionhandle := actproductiontree.GetHandle( actproductionKey );
|
actproductiontree.Root().AddChild( actproductionhandle,i );
|
}
|
traverse( noptable, NewOfflinePlanRow, noprow ){
|
row := table.GetRow( noprow );
|
traverse( noprow, NewOfflinePlanCell, nopcell ){
|
column := selectobject( table, Column, column, column.TimeUnit() = Translations::MP_GlobalParameters_Day() and column.StartDate() = nopcell.NewOfflinePlanColumn().StartDate() );
|
cell := selectobject( row, Cell, cell, cell.Column() = column );
|
actproductionKey := noprow.ProductID() + column.StartDate().AsQUILL();
|
actproductionhandle:= actproductiontree.GetHandle( actproductionKey );
|
actproductionindex := guard( actproductiontree.Root().Child( actproductionhandle ),null( NamedValue ));
|
|
actproductionqty := 0.0;
|
if( not isnull( actproductionindex )){
|
actproduction := actproductiondatas.Element( actproductionindex.GetValueAsNumber() );
|
actproductionqty := actproduction.ActualOut();
|
}
|
cell.ActualProductionQty( actproductionqty );
|
cell.InventoryWeight( nopcell.InventoryWeight() );
|
// cell.ProductionSerialNumber( nopcell.ProductionSerialNumber() );
|
cell.Quantity( nopcell.Quantity() );
|
// cell.Shift( nopcell.Shift() );
|
// cell.Value( nopcell.Value() );
|
}
|
}
|
//showtable.Generate( search, products );
|
*]
|
}
|