/*
* The Kuali Financial System, a comprehensive financial management system for higher education.
*
* Copyright 2005-2014 The Kuali Foundation
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.kuali.kfs.coa.businessobject;
import java.sql.Date;
import java.util.Arrays;
import org.apache.commons.lang.StringUtils;
import org.kuali.kfs.sys.KFSPropertyConstants;
import org.kuali.kfs.sys.ObjectUtil;
import org.kuali.kfs.sys.context.SpringContext;
import org.kuali.rice.core.api.util.type.KualiDecimal;
import org.kuali.rice.kew.api.doctype.DocumentTypeService;
import org.kuali.rice.kew.doctype.bo.DocumentType;
import org.kuali.rice.kew.doctype.bo.DocumentTypeEBO;
import org.kuali.rice.kim.api.identity.Person;
import org.kuali.rice.kim.api.identity.PersonService;
import org.kuali.rice.krad.bo.GlobalBusinessObjectDetailBase;
/**
*
*/
public class AccountDelegateGlobalDetail extends GlobalBusinessObjectDetailBase {
private static final long serialVersionUID = -8089154029664644867L;
private String accountDelegateUniversalId;
private String financialDocumentTypeCode;
private KualiDecimal approvalFromThisAmount;
private KualiDecimal approvalToThisAmount;
private boolean accountDelegatePrimaryRoutingIndicator;
private Date accountDelegateStartDate;
private Person accountDelegate;
private transient DocumentTypeEBO financialSystemDocumentTypeCode;
/**
* Default constructor.
*/
public AccountDelegateGlobalDetail() {
super();
}
public AccountDelegateGlobalDetail(AccountDelegateModelDetail model) {
accountDelegatePrimaryRoutingIndicator = model.getAccountDelegatePrimaryRoutingIndicator();
// KFSCNTRB-1403: don't populate the account delegate with the start date inherited from the model, just put today's date there
//accountDelegateStartDate = model.getAccountDelegateStartDate();
java.util.Date utilDate = new java.util.Date(); // default C'Tor for java.util.Date populates the date with the current date
accountDelegateStartDate = new java.sql.Date(utilDate.getTime()); // now populate accountDelegateStartDate
accountDelegateUniversalId = model.getAccountDelegateUniversalId();
approvalFromThisAmount = model.getApprovalFromThisAmount();
approvalToThisAmount = model.getApprovalToThisAmount();
financialDocumentTypeCode = model.getFinancialDocumentTypeCode();
}
/**
* Gets the financialSystemDocumentTypeCode attribute.
* @return Returns the financialSystemDocumentTypeCode.
*/
public DocumentTypeEBO getFinancialSystemDocumentTypeCode() {
if ( StringUtils.isBlank( financialDocumentTypeCode ) ) {
financialSystemDocumentTypeCode = null;
} else {
if ( financialSystemDocumentTypeCode == null || !StringUtils.equals(financialDocumentTypeCode, financialSystemDocumentTypeCode.getName() ) ) {
org.kuali.rice.kew.api.doctype.DocumentType temp = SpringContext.getBean(DocumentTypeService.class).getDocumentTypeByName(financialDocumentTypeCode);
if ( temp != null ) {
financialSystemDocumentTypeCode = DocumentType.from( temp );
} else {
financialSystemDocumentTypeCode = null;
}
}
}
return financialSystemDocumentTypeCode;
}
/**
* Gets the accountDelegateUniversalId attribute.
*
* @return Returns the accountDelegateUniversalId
*/
public String getAccountDelegateUniversalId() {
return accountDelegateUniversalId;
}
/**
* Sets the accountDelegateUniversalId attribute.
*
* @param accountDelegateUniversalId The accountDelegateUniversalId to set.
*/
public void setAccountDelegateUniversalId(String accountDelegateUniversalId) {
this.accountDelegateUniversalId = accountDelegateUniversalId;
}
/**
* Gets the financialDocumentTypeCode attribute.
*
* @return Returns the financialDocumentTypeCode
*/
public String getFinancialDocumentTypeCode() {
return financialDocumentTypeCode;
}
/**
* Sets the financialDocumentTypeCode attribute.
*
* @param financialDocumentTypeCode The financialDocumentTypeCode to set.
*/
public void setFinancialDocumentTypeCode(String financialDocumentTypeCode) {
this.financialDocumentTypeCode = financialDocumentTypeCode;
}
/**
* Gets the approvalFromThisAmount attribute.
*
* @return Returns the approvalFromThisAmount
*/
public KualiDecimal getApprovalFromThisAmount() {
return approvalFromThisAmount;
}
/**
* Sets the approvalFromThisAmount attribute.
*
* @param approvalFromThisAmount The approvalFromThisAmount to set.
*/
public void setApprovalFromThisAmount(KualiDecimal approvalFromThisAmount) {
this.approvalFromThisAmount = approvalFromThisAmount;
}
/**
* Gets the approvalToThisAmount attribute.
*
* @return Returns the approvalToThisAmount
*/
public KualiDecimal getApprovalToThisAmount() {
return approvalToThisAmount;
}
/**
* Sets the approvalToThisAmount attribute.
*
* @param approvalToThisAmount The approvalToThisAmount to set.
*/
public void setApprovalToThisAmount(KualiDecimal approvalToThisAmount) {
this.approvalToThisAmount = approvalToThisAmount;
}
/**
* Gets the accountDelegatePrimaryRoutingIndicator attribute.
*
* @return Returns the accountDelegatePrimaryRoutingIndicator
*/
public boolean getAccountDelegatePrimaryRoutingIndicator() {
return accountDelegatePrimaryRoutingIndicator;
}
/**
* Sets the accountDelegatePrimaryRoutingIndicator attribute.
*
* @param accountDelegatePrimaryRoutingIndicator The accountDelegatePrimaryRoutingIndicator to set.
* @deprecated
*/
@Deprecated
public void setAccountDelegatePrimaryRoutingIndicator(boolean accountDelegatePrimaryRoutingIndicator) {
this.accountDelegatePrimaryRoutingIndicator = accountDelegatePrimaryRoutingIndicator;
}
/**
* Gets the accountDelegateStartDate attribute.
*
* @return Returns the accountDelegateStartDate
*/
public Date getAccountDelegateStartDate() {
return accountDelegateStartDate;
}
/**
* Sets the accountDelegateStartDate attribute.
*
* @param accountDelegateStartDate The accountDelegateStartDate to set.
*/
public void setAccountDelegateStartDate(Date accountDelegateStartDate) {
this.accountDelegateStartDate = accountDelegateStartDate;
}
public Person getAccountDelegate() {
accountDelegate = SpringContext.getBean(PersonService.class).updatePersonIfNecessary(accountDelegateUniversalId, accountDelegate);
return accountDelegate;
}
/**
* @param accountDelegate The accountDelegate to set.
* @deprecated
*/
@Deprecated
public void setAccountDelegate(Person accountDelegate) {
this.accountDelegate = accountDelegate;
}
/**
* @see java.lang.Object#equals(java.lang.Object)
*/
@Override
public boolean equals(Object obj) {
if (obj != null) {
if (this.getClass().equals(obj.getClass())) {
AccountDelegateGlobalDetail other = (AccountDelegateGlobalDetail) obj;
if (StringUtils.equalsIgnoreCase(getDocumentNumber(), other.getDocumentNumber())) {
if (StringUtils.equalsIgnoreCase(this.financialDocumentTypeCode, other.financialDocumentTypeCode)) {
if (this.accountDelegatePrimaryRoutingIndicator == other.accountDelegatePrimaryRoutingIndicator) {
if (StringUtils.equalsIgnoreCase(this.accountDelegateUniversalId, other.accountDelegateUniversalId)) {
return true;
}
}
}
}
}
}
return false;
}
/**
* @see java.lang.Object#hashCode()
*/
@Override
public int hashCode() {
return ObjectUtil.generateHashCode(this, Arrays.asList(KFSPropertyConstants.DOCUMENT_NUMBER,"financialDocumentTypeCode", "accountDelegatePrimaryRoutingIndicator", "accountDelegateUniversalId" ));
}
}