lihongji
2024-07-28 e365ab19f5ec303d3701a2ab2d961c9ca0a5dbc6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
Quintiq file version 2.0
#parent: #root
Method GetActualCostPerPeriodSpecification (
  Period_MP period,
  output Real totalCost
) remote
{
  Description: 'Get the cost as per IsPlanning/IsBase/Others'
  TextBody:
  [*
    if( period.IsPlanning() ) //planning period, derive calculation
    {
      if( this.CostDriver() = Translations::MP_AccountAssignmentCostDriverInventory_Holding() )
      {
        totalCost := sum( this, Product_MP.ProductInStockingPoint_MP.ProductInStockingPointInPeriod, pispip,
                          pispip.Period_MP() = period,
                          pispip.GetBaseInventoryHoldingCost( this.AccountAssignment() ) );
      }    
      else if( this.CostDriver() = Translations::MP_AccountAssignmentCostDriverInventoryValue() )
      {
        totalCost := sum( this, Product_MP.ProductInStockingPoint_MP.ProductInStockingPointInPeriod, pispip,
                          pispip.Period_MP() = period,
                          pispip.GetBaseInventoryValuePerQuantity( this.AccountAssignment() ) * pispip.InventoryLevelEnd() );
      } 
    }
    else if( period.IsBase() ) //base period, disaggregate from planning period
    {
      totalCost := this.GetActualCosts( period.PlanningPeriod() ) * period.PlanningSystemRatio();
    }
    else  //non base non planning, sum from planning
    {
      traverse( this, Product_MP.ProductInStockingPoint_MP.ProductInStockingPointInPeriod, pispip, pispip.Period_MP() = period )
      {
        traverse( pispip.GetChildrenOfPeriodDimension(), Elements, childspip )
        {
          totalCost := totalCost + this.GetActualCosts( childspip.Period_MP() );
        }
      }                  
    }
  *]
}