View Javadoc
1   /*
2    * The Kuali Financial System, a comprehensive financial management system for higher education.
3    * 
4    * Copyright 2005-2014 The Kuali Foundation
5    * 
6    * This program is free software: you can redistribute it and/or modify
7    * it under the terms of the GNU Affero General Public License as
8    * published by the Free Software Foundation, either version 3 of the
9    * License, or (at your option) any later version.
10   * 
11   * This program is distributed in the hope that it will be useful,
12   * but WITHOUT ANY WARRANTY; without even the implied warranty of
13   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14   * GNU Affero General Public License for more details.
15   * 
16   * You should have received a copy of the GNU Affero General Public License
17   * along with this program.  If not, see <http://www.gnu.org/licenses/>.
18   */
19  package org.kuali.kfs.module.purap.document.validation.impl;
20  
21  import org.kuali.kfs.module.purap.PurapKeyConstants;
22  import org.kuali.kfs.module.purap.PurapPropertyConstants;
23  import org.kuali.kfs.module.purap.businessobject.PurApAccountingLine;
24  import org.kuali.kfs.sys.businessobject.AccountingLine;
25  import org.kuali.kfs.sys.document.validation.GenericValidation;
26  import org.kuali.kfs.sys.document.validation.event.AttributedDocumentEvent;
27  import org.kuali.rice.krad.util.GlobalVariables;
28  
29  public class PurchasingUpdateAccountingLineValidation extends GenericValidation {
30  
31      private AccountingLine updatedAccountingLine;
32  
33      public boolean validate(AttributedDocumentEvent event) {
34          //this is necessary because sometimes this method is called for baseline accounts, should not be needed once baseline is removed
35          if(updatedAccountingLine instanceof PurApAccountingLine) {
36              return verifyAccountingLinePercent((PurApAccountingLine) updatedAccountingLine);
37          }//else
38          return true;
39      }
40  
41      /**
42       * Verifies that the accounting line percent is a whole number.
43       * 
44       * @param purapAccountingLine the accounting line to be validated
45       * @return boolean false if the accounting line percent is not a whole number.
46       */
47      protected boolean verifyAccountingLinePercent(PurApAccountingLine purapAccountingLine) {
48          // make sure it's a whole number
49          if (purapAccountingLine.getAccountLinePercent().stripTrailingZeros().scale() > 0) {
50              GlobalVariables.getMessageMap().putError(PurapPropertyConstants.ACCOUNTS, PurapKeyConstants.ERROR_PURCHASING_PERCENT_NOT_WHOLE, purapAccountingLine.getAccountLinePercent().toPlainString());
51  
52              return false;
53          }
54  
55          return true;
56      }
57  
58      public AccountingLine getUpdatedAccountingLine() {
59          return updatedAccountingLine;
60      }
61  
62      public void setUpdatedAccountingLine(AccountingLine updatedAccountingLine) {
63          this.updatedAccountingLine = updatedAccountingLine;
64      }
65  
66  }