/*
* eGov suite of products aim to improve the internal efficiency,transparency,
* accountability and the service delivery of the government organizations.
*
* Copyright (C) <2015> eGovernments Foundation
*
* The updated version of eGov suite of products as by eGovernments Foundation
* is available at http://www.egovernments.org
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see http://www.gnu.org/licenses/ or
* http://www.gnu.org/licenses/gpl.html .
*
* In addition to the terms of the GPL license to be adhered to in using this
* program, the following additional terms are to be complied with:
*
* 1) All versions of this program, verbatim or modified must carry this
* Legal Notice.
*
* 2) Any misrepresentation of the origin of the material is prohibited. It
* is required that all modified versions of this material be marked in
* reasonable ways as different from the original version.
*
* 3) This license does not grant any rights to any user of the program
* with regards to rights under trademark law for use of the trade names
* or trademarks of eGovernments Foundation.
*
* In case of any queries, you can reach eGovernments Foundation at contact@egovernments.org.
*/
package org.egov.works.abstractestimate.entity;
import java.math.BigDecimal;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
import javax.validation.constraints.NotNull;
import org.egov.infra.persistence.entity.AbstractAuditable;
import org.egov.model.budget.BudgetUsage;
import org.egov.works.models.estimate.DepositWorksUsage;
@Entity
@Table(name = "EGW_ESTIMATE_APPROPRIATION")
@NamedQueries({
@NamedQuery(name = AbstractEstimateAppropriation.BUDGETUSAGE_BY_ESTIMATE_AND_FINANCIALYEAR, query = "from AbstractEstimateAppropriation aep where aep.budgetUsage.id=(select max(budgetUsage.id) from AbstractEstimateAppropriation aep1 where aep1.abstractEstimate.id=? and aep1.budgetUsage.financialYearId=?)"),
@NamedQuery(name = AbstractEstimateAppropriation.BUDGETUSAGE_BY_ESTIMATE, query = "from AbstractEstimateAppropriation aep where aep.budgetUsage.id=(select max(budgetUsage.id) from AbstractEstimateAppropriation aep where aep.abstractEstimate.id=?)"),
@NamedQuery(name = AbstractEstimateAppropriation.DEPOSITWORKSUSAGE_BY_ESTIMATE_AND_FINANCIALYEAR, query = "from AbstractEstimateAppropriation aep where aep.abstractEstimate.id=? and aep.depositWorksUsage.financialYear.id=?"),
@NamedQuery(name = AbstractEstimateAppropriation.DEPOSITWORKSUSAGE_BY_ESTIMATE, query = "from AbstractEstimateAppropriation aep where aep.depositWorksUsage.id=(select max(depositWorksUsage.id) from AbstractEstimateAppropriation aep where aep.abstractEstimate.id=?)") })
@SequenceGenerator(name = AbstractEstimateAppropriation.SEQ_EGW_ESTIMATEAPPROPRIATION, sequenceName = AbstractEstimateAppropriation.SEQ_EGW_ESTIMATEAPPROPRIATION, allocationSize = 1)
public class AbstractEstimateAppropriation extends AbstractAuditable {
private static final long serialVersionUID = -5988721723683140437L;
public static final String BUDGETUSAGE_BY_ESTIMATE_AND_FINANCIALYEAR = "getBudgetUsageForEstimateByFinYear";
public static final String BUDGETUSAGE_BY_ESTIMATE = "getLatestBudgetUsageForEstimate";
public static final String DEPOSITWORKSUSAGE_BY_ESTIMATE_AND_FINANCIALYEAR = "getDepositWorksUsageForEstimateByFinYear";
public static final String DEPOSITWORKSUSAGE_BY_ESTIMATE = "getLatestDepositWorksUsageForEstimate";
public static final String SEQ_EGW_ESTIMATEAPPROPRIATION = "SEQ_EGW_ESTIMATE_APPROPRIATION";
@Id
@GeneratedValue(generator = SEQ_EGW_ESTIMATEAPPROPRIATION, strategy = GenerationType.SEQUENCE)
private Long id;
@NotNull
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "abstractestimate", nullable = false)
private AbstractEstimate abstractEstimate;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "budgetusage")
private BudgetUsage budgetUsage;
private BigDecimal balanceAvailable;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "depositworksusage")
private DepositWorksUsage depositWorksUsage;
@Override
public Long getId() {
return id;
}
@Override
public void setId(final Long id) {
this.id = id;
}
public DepositWorksUsage getDepositWorksUsage() {
return depositWorksUsage;
}
public void setDepositWorksUsage(final DepositWorksUsage depositWorksUsage) {
this.depositWorksUsage = depositWorksUsage;
}
public BudgetUsage getBudgetUsage() {
return budgetUsage;
}
public void setBudgetUsage(final BudgetUsage budgetUsage) {
this.budgetUsage = budgetUsage;
}
public AbstractEstimate getAbstractEstimate() {
return abstractEstimate;
}
public void setAbstractEstimate(final AbstractEstimate abstractEstimate) {
this.abstractEstimate = abstractEstimate;
}
public BigDecimal getBalanceAvailable() {
return balanceAvailable;
}
public void setBalanceAvailable(final BigDecimal balanceAvailable) {
this.balanceAvailable = balanceAvailable;
}
}