/* * 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.egf.web.actions.budget; import com.opensymphony.xwork2.validator.annotations.Validation; import org.apache.commons.lang.StringUtils; import org.apache.log4j.Logger; import org.apache.struts2.convention.annotation.Action; import org.apache.struts2.convention.annotation.ParentPackage; import org.apache.struts2.convention.annotation.Result; import org.apache.struts2.convention.annotation.Results; import org.apache.struts2.interceptor.validation.SkipValidation; import org.egov.commons.CFinancialYear; import org.egov.commons.dao.FinancialYearDAO; import org.egov.eis.service.EisCommonService; import org.egov.infra.config.core.ApplicationThreadLocals; import org.egov.infra.web.struts.actions.BaseFormAction; import org.egov.infra.workflow.entity.State; import org.egov.infra.workflow.service.SimpleWorkflowService; import org.egov.infstr.services.PersistenceService; import org.egov.model.budget.Budget; import org.egov.model.budget.BudgetDetail; import org.egov.pims.commons.Position; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import java.util.ArrayList; import java.util.Collections; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; @ParentPackage("egov") @Validation @Results({ @Result(name = BudgetAction.NEW, location = "budget-" + BudgetAction.NEW + ".jsp"), @Result(name = "referenceBudgets", location = "budget-referenceBudgets.jsp"), @Result(name = "search", location = "budget-search.jsp"), @Result(name = "parentbudgets", location = "budget-parentbudgets.jsp"), @Result(name = "success", type = "redirect", location = "budget.action"), @Result(name = BudgetAction.EDIT, location = "budget-" + BudgetAction.EDIT + ".jsp") }) public class BudgetAction extends BaseFormAction { @Autowired @Qualifier("persistenceService") private PersistenceService persistenceService; private static final long serialVersionUID = 1L; private Budget budget = new Budget(); private PersistenceService<Budget, Long> budgetService; private PersistenceService<CFinancialYear, Long> finYearService; private List<String> isbereList; private List<Budget> budgetList = new ArrayList<Budget>(); private static final String SEARCH = "search"; private Integer parentId; private Integer referenceId; private Map<Long, String> parMap = new HashMap<Long, String>(); private SimpleWorkflowService<Budget> budgetWorkflowService; private String target = "", bere = ""; private Long tempId = null; private List<Budget> parentBudgets; private static final String PARENTBUDGETS = "parentbudgets"; private static final Logger LOGGER = Logger.getLogger(BudgetAction.class); private EisCommonService eisCommonService = null; private List<Budget> referenceBudgetList = new ArrayList<Budget>(); private CFinancialYear financialYear; private FinancialYearDAO financialYearDAO; private Long financialYearId; public BudgetAction() { addRelatedEntity("financialYear", CFinancialYear.class); } @Override public Object getModel() { return budget; } @Override public String execute() { return INDEX; } @Override public void prepare() { super.prepare(); isbereList = new ArrayList<String>(); isbereList.add("BE"); isbereList.add("RE"); // consider isactiveforPosting since ui supports this one addDropdownData("financialYearList", getPersistenceService().findAllBy("from CFinancialYear where isActive=true order by finYearRange desc ")); addDropdownData("referenceBudgetList", Collections.EMPTY_LIST); setupDropdownDataExcluding("financialYear"); } @SkipValidation @Action(value = "/budget/budget-newform") public String newform() { return NEW; } @Action(value = "/budget/budget-create") public String create() { addMaterializedPath(budget); budgetService.create(budget); if (getParentId() != null && getParentId() > 0) budget.setParent(budgetService.findById(Long.valueOf(getParentId()), false)); if (getReferenceId() != null && getReferenceId() != -1) budget.setReferenceBudget(budgetService.findById(Long.valueOf(getReferenceId()), false)); if (budget.getParent() != null && budget.getParent().getIsPrimaryBudget() == true) budget.setIsPrimaryBudget(true); final Position p = eisCommonService.getPositionByUserId(ApplicationThreadLocals.getUserId()); budget.start().withOwner(p); addActionMessage(getMessage("budget.create")); target = "SUCCESS"; return NEW; } /** * */ private void addMaterializedPath(final Budget budget) { String materializedPath = ""; String count = ""; if (getParentId() != null && getParentId() > 0) { final Budget parent = budgetService.findById(Long.valueOf(getParentId()), false); if (parent != null) materializedPath = parent.getMaterializedPath(); } List<Budget> parallelBudgets = null; if (getParentId() == null || getParentId() <= 0) parallelBudgets = budgetService.findAllBy("from Budget b where b.parent is null"); else parallelBudgets = budgetService.findAllBy("from Budget b where b.parent.id=?", Long.valueOf(getParentId())); if (parallelBudgets != null) count = String.valueOf(parallelBudgets.size() + 1); if (materializedPath == null || materializedPath.isEmpty()) materializedPath = count; else materializedPath = materializedPath + "." + count; if (LOGGER.isDebugEnabled()) LOGGER.debug("MaterializedPath..." + materializedPath); budget.setMaterializedPath(materializedPath); } protected String getMessage(final String key) { return getText(key); } // fetch all RE budgets which have not been assigned as reference budget for any budget @SkipValidation @Action(value = "/budget/budget-ajaxLoadReferenceBudgets") public String ajaxLoadReferenceBudgets() { referenceBudgetList = new ArrayList<Budget>(); financialYear = financialYearDAO.getFinancialYearById(financialYear.getId()); final CFinancialYear previousYear = financialYearDAO.getFinancialYearByFinYearRange(computeYearRange(financialYear .getFinYearRange())); referenceBudgetList.addAll(getReferenceBudgetsFor(previousYear)); return "referenceBudgets"; } private List getReferenceBudgetsFor(final CFinancialYear previousYear) { return persistenceService.findAllBy("from Budget where isactivebudget = 1 and state.type='Budget' and isbere='RE' and " + "state.value='NEW' and financialYear.id = " + previousYear.getId() + " and id not in (select referenceBudget.id from Budget where" + " financialYear.id=" + financialYear.getId() + " and referenceBudget is not null) order by name"); } private String computeYearRange(final String range) { if (StringUtils.isNotBlank(range)) { final String[] list = range.split("-"); return subtract(list[0]) + "-" + subtract(list[1]); } return ""; } protected String subtract(final String value) { final int val = Integer.parseInt(value) - 1; if (val < 10) return "0" + val; return String.valueOf(val); } @Action(value = "/budget/budget-save") public String save() { if (getParentId() != null && getParentId() > 0) budget.setParent(budgetService.findById(Long.valueOf(getParentId()), false)); if (getReferenceId() != null && getReferenceId() > 0) budget.setReferenceBudget(budgetService.findById(Long.valueOf(getReferenceId()), false)); if (budget.getState() != null){ State state = (State) persistenceService.find("from org.egov.infra.workflow.entity.State where id=?", budget .getState().getId()); } // This fix is for Phoenix Migration.budget.setState(state); persistenceService.getSession().flush(); budgetService.persist(budget); addActionMessage(getMessage("budget.update")); target = "SUCCESS"; return NEW; } @SkipValidation public String list() { budgetList = budgetService .findAllBy( " from Budget b where b.financialYear=? and b.state in (from org.egov.infra.workflow.entity.State where type='Budget' and value='NEW' ) ", budget.getFinancialYear()); if (budgetList.isEmpty()) target = "EMPTY"; return SEARCH; } @SkipValidation @Action(value = "/budget/budget-edit") public String edit() { budget = budgetService.findById(budget.getId(), false); if (budget.getParent() != null) setParentId(Integer.valueOf(budget.getParent().getId().toString())); if (budget.getReferenceBudget() != null) setReferenceId(Integer.valueOf(budget.getReferenceBudget().getId().toString())); // check the budget detail is exist for this budget definiton final List<BudgetDetail> budgetDetailList = persistenceService.findAllBy(" from BudgetDetail where budget=?", budget); financialYear = financialYearDAO.getFinancialYearById(budget.getFinancialYear().getId()); final CFinancialYear previousYear = financialYearDAO.getFinancialYearByFinYearRange(computeYearRange(financialYear .getFinYearRange())); referenceBudgetList.addAll(getReferenceBudgetsFor(previousYear)); if (budget.getReferenceBudget() != null) referenceBudgetList.add(budget.getReferenceBudget()); if (budgetDetailList.isEmpty()) target = "allowToEdit"; else target = "NotAllowToEdit"; return EDIT; } @SkipValidation @Action(value = "/budget/budget-search") public String search() { target = "NONE"; return SEARCH; } public List<String> getIsbereList() { return isbereList; } /** * @return budget */ public Budget getBudget() { return budget; } /** * @param budget the budget to set */ public void setBudget(final Budget budget) { this.budget = budget; } /** * @param budgetService the budgetService to set */ public void setBudgetService(final PersistenceService<Budget, Long> budgetService) { this.budgetService = budgetService; } /** * @return budgetList */ public List<Budget> getBudgetList() { return budgetList; } /** * @return parentId */ public Integer getParentId() { return parentId; } /** * @param parentId the parentId to set */ public void setParentId(final Integer parentId) { this.parentId = parentId; } /** * @return parMap */ public Map<Long, String> getParMap() { List<Budget> parList = null; if (budget == null || budget.getId() == null) parList = getPersistenceService() .findAllBy( "from Budget b where b.isbere='BE' and b.id not in (select budget from BudgetDetail) and b.state in (from org.egov.infra.workflow.entity.State where type='Budget' and value='NEW' ) "); else parList = getPersistenceService() .findAllBy( "from Budget b where b.isbere='BE' and b.id not in (select budget from BudgetDetail) and b.state in (from org.egov.infra.workflow.entity.State where type='Budget' and value='NEW' ) and b.id!=" + budget.getId()); for (final Budget b : parList) parMap.put(b.getId(), b.getName()); return parMap; } /** * @param parMap the parMap to set */ public void setParMap(final Map<Long, String> parMap) { this.parMap = parMap; } @Override public void validate() { if (getParentId() != null && getParentId() > 0) { final Budget b = budgetService.findById(Long.valueOf(getParentId()), false); if (!b.getIsbere().equals(budget.getIsbere())) addFieldError("parentId", getText("budget.parent.invalid", new String[] { budget.getIsbere() })); } final Date dt = new Date(); if (budget.getFinancialYear() != null) { final CFinancialYear finyear = finYearService.findByNamedQuery("validateFinancialYear", budget.getFinancialYear() .getId(), dt, dt, dt); if (finyear == null) addFieldError("financialYear", getText("budget.finyear.invalid")); } if (budget.getIsPrimaryBudget() && budget.getFinancialYear() != null && (getParentId() == null || getParentId() <= 0)) { final List<Budget> list = getPersistenceService().findAllBy( " from Budget where isbere=? and financialYear=? and isPrimaryBudget=1 and parent is null", budget.getIsbere(), budget.getFinancialYear()); if (list != null && list.size() > 1) addFieldError( "isPrimaryBudget", getText("budget.primary.invalid2", new String[] { budget.getFinancialYear().getFinYearRange(), budget.getIsbere() })); } } /** * @param finYearService the finYearService to set */ public void setFinYearService(final PersistenceService<CFinancialYear, Long> finYearService) { this.finYearService = finYearService; } /** * @param workflowService the workflowService to set */ public void setBudgetWorkflowService(final SimpleWorkflowService<Budget> workflowService) { budgetWorkflowService = workflowService; } public String getTarget() { return target; } public void setTarget(final String target) { this.target = target; } @SkipValidation @Action(value = "/budget/budget-ajaxLoadParentBudgets") public String ajaxLoadParentBudgets() { if (tempId == null) parentBudgets = getPersistenceService().findAllBy("from Budget b where b.isbere=? and b.id not in " + "(select budget from BudgetDetail) and b.state in (from org.egov.infra.workflow.entity.State where " + "type='Budget' and value='NEW' ) and b.financialYear.id=?", bere, financialYearId); else parentBudgets = getPersistenceService().findAllBy("from Budget b where b.isbere=? and b.id not in " + "(select budget from BudgetDetail) and b.state in (from org.egov.infra.workflow.entity.State where " + "type='Budget' and value='NEW' ) and b.financialYear.id=? and b.id!=" + tempId, bere, financialYearId); return PARENTBUDGETS; } public List<Budget> getParentBudgets() { return parentBudgets; } public String getBere() { return bere; } public void setBere(final String bere) { this.bere = bere; } public void setEisCommonService(final EisCommonService eisCommonService) { this.eisCommonService = eisCommonService; } public Long getTempId() { return tempId; } public void setTempId(final Long tempId) { this.tempId = tempId; } public void setFinancialYear(final CFinancialYear financialYear) { this.financialYear = financialYear; } public CFinancialYear getFinancialYear() { return financialYear; } public void setReferenceBudgetList(final List<Budget> referenceBudgetList) { this.referenceBudgetList = referenceBudgetList; } public List<Budget> getReferenceBudgetList() { return referenceBudgetList; } public void setFinancialYearDAO(final FinancialYearDAO financialYearDAO) { this.financialYearDAO = financialYearDAO; } public void setReferenceId(final Integer referenceId) { this.referenceId = referenceId; } public Integer getReferenceId() { return referenceId; } public void setFinancialYearId(final Long financialYearId) { this.financialYearId = financialYearId; } public Long getFinancialYearId() { return financialYearId; } }