lazhen
2024-07-15 dc3aca2eff3cf269dbc0f57b958d69f917618223
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
Quintiq file version 2.0
#parent: #root
Method GetHasValidUnit (
  output Strings feedback_o,
  output Strings sanitycheckfeedback_o
) declarative remote as Boolean
{
  Description: 'Check if operation in campaign type is linked to campaign type'
  TextBody:
  [*
    isvalid := this.GetHasValidUnit();
    
    if( not isnull( feedback_o ) and not isvalid )
    {
      operationname := MacroPlan::GetSubstituteName( this.Operation().Name() );
      operationunit := MacroPlan::GetSubstituteName( guard( this.Operation().Unit().Name(), '' ) );
      campaigntypename := MacroPlan::GetSubstituteName( guard( this.CampaignType_MP().Name(), '' ) );
      campaigntypeunit := MacroPlan::GetSubstituteName( guard( this.CampaignType_MP().Unit().Name(), '' ) );
      feedback_o.Add( SanityCheckMessage::GetFormattedMessage( Translations::MP_OperationInCampaignType_Instance( operationname, campaigntypename ),
                                                               Translations::MP_OperationInCampaignType_ViolateHasValidUnit( operationunit, campaigntypeunit ) ) );
      sanitycheckfeedback_o.Add( SanityCheckCategoryLevel::GetSanityCheckCategoryDataIssue() );
    }
    
    return isvalid;
  *]
}