/* * 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; } }