lazhen
2024-09-06 db7a0a9394d11c51b478579d6aa24790b7deaa4c
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
Quintiq file version 2.0
#parent: #root
Method GetHasValidAccountCostFactor (
  output Strings feedback_o,
  output Strings sanitycheckfb_o
) declarative remote as Boolean
{
  Description: 'Validate if factor of min and max account costs is less than or equal to limit'
  TextBody:
  [*
    // desmondt Nov-3-2014 (created)
    isvalid := true;
    factorlimit := this.MacroPlan().GlobalParameters_MP().DifferenceFactor1e6();
    
    if( this.MaxCost().IsFinite() and this.MinCost().IsFinite() )
    {
      costdifffactor := guard( this.MaxCost() / this.MinCost(), this.MaxCost() );
      isvalid := costdifffactor < factorlimit;
    }
    
    if( not isnull( feedback_o ) and not isvalid )
    {
      formatfactorlimit := factorlimit.Format( "N(Dec(0), Thousands)" );
      formatmincost := this.MinCost().Format( "N(Dec(0), Thousands)" );
      formatmaxcost := this.MaxCost().Format( "N(Dec(0), Thousands)" );
      feedback_o.Add( SanityCheckMessage::GetFormattedMessage( Translations::MP_Account_MP_Instance( this ),
                                                               Translations::MP_Account_ViolateHasValidAccountCostRange( formatmincost, formatmaxcost, formatfactorlimit ) ) );
      sanitycheckfb_o.Add( SanityCheckCategoryLevel::GetSanityCheckCategoryDataWarning() );                                                           
    }
    
    return isvalid;
  *]
}