package com.fp.frontend.controller.armas; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import javax.annotation.PostConstruct; import javax.faces.bean.ManagedBean; import javax.faces.bean.ViewScoped; import com.fp.dto.Request; import com.fp.dto.Response; import com.fp.dto.query.DtoQuery; import com.fp.dto.query.SubQuery; import com.fp.dto.save.DtoSave; import com.fp.frontend.controller.AbstractController; import com.fp.frontend.controller.armas.parametros.RequisitoController; import com.fp.frontend.helper.MessageHelper; import com.fp.persistence.parmas.param.TarmRequisito; import com.fp.persistence.parmas.param.TarmRequisitoPorTipoTramite; import com.fp.persistence.parmas.param.TarmTipoTramite; /** * Clase controladora del bean TarmRequisitoPorTipoTramite. * * @author Jorge Vaca. * @version 2.1 */ @SuppressWarnings("serial") @ManagedBean @ViewScoped public class RequisitoPorTipoTramiteController extends AbstractController { List ltipotramite; List lrequisito; public RequisitoPorTipoTramiteController() throws Exception { super(TarmRequisitoPorTipoTramite.class); } @PostConstruct private void postconstruct() { this.init(); ltipotramite = TipoTramiteController.find(); lrequisito = RequisitoController.find(); // Inicializa autoconsulta super.startQuery(); } /** * Incializa el controlador, cuando se esta utilizando una pagina que utliza el controlador. */ private void init() { try { recperpage = 15; // Cambiar al # reg a mirar. lrecord = new ArrayList<>(); beanalias = "REQUISITOPORTIPOTRAMITE"; } catch (Exception e) { MessageHelper.setMessageError(e); } } /** * Crea una instancia de TgeneTransactionProcess y marca el registro como nuevo. * * @throws Exception */ @Override public void create() throws Exception { super.create(); // record.getPk().setCtipotramite(super.getMfilters().get("pk.ctipotramite")); } @SuppressWarnings("unchecked") @Override protected void querydatabase() { try { DtoQuery dto = super.getDtoQuery(true); dto.setOrderby("t.pk.crequisito"); // Subquery SubQuery subquery = new SubQuery("TarmRequisito", "nombre", "nrequisito", "i.pk = t.pk.crequisito"); dto.addSubQuery(subquery); HashMap mtables = new HashMap(); mtables.put(beanalias, dto); // permite adicionar mas de una tabla. Request request = callerhelper.getRequest(); request.setQueryTables(mtables); Response resp = callerhelper.executeQuery(request); if (resp.getResponseCode().compareTo(Response.RESPONSE_OK) != 0) { lrecord = new ArrayList(); MessageHelper.setMessageError(resp); } else { lrecord = (List) resp.get(beanalias); super.postQuery(lrecord); } } catch (Throwable e) { MessageHelper.setMessageError(e); } } @Override public void save() { try { DtoSave dtosave = super.getDtoSave(); dtosave.setReturnpk(true); // Para que el core devuelva el pk de los registros nuevos. HashMap msave = new HashMap(); Request request = callerhelper.getRequest(); msave.put(beanalias, dtosave); // adicionar metadata de mantenimiento para cada tabla. request.setSaveTables(msave); Response resp = callerhelper.executeSave(request); if (resp.getResponseCode().compareTo(Response.RESPONSE_OK) == 0) { this.postCommit(resp); MessageHelper.setMessageInfo(resp); } else { MessageHelper.setMessageError(resp); } } catch (Throwable e) { MessageHelper.setMessageError(e); } } @Override public void postCommit(Response response) throws Exception { super.postCommitGeneric(response, beanalias); } /** * Fija la descripcion del perfil en el record */ public void setNombreReqisito() { for (TarmRequisito r : lrequisito) { if (r.getPk().compareTo(record.getPk().getCrequisito()) == 0) { record.put("nrequisito", r.getNombre()); } } } /** * @return the ltipotramite */ public List getLtipotramite() { return ltipotramite; } /** * @param ltipotramite the ltipotramite to set */ public void setLtipotramite(List ltipotramite) { this.ltipotramite = ltipotramite; } /** * @return the lrequisito */ public List getLrequisito() { return lrequisito; } /** * @param lrequisito the lrequisito to set */ public void setLrequisito(List lrequisito) { this.lrequisito = lrequisito; } /** * Entrega una lista de requisitos por tipo de tramite. * * @param ctipotramite * @return * @throws Exception */ public static List find(String ctipotramite) throws Exception { RequisitoPorTipoTramiteController r = new RequisitoPorTipoTramiteController(); r.addFilter("pk.ctipotramite", ctipotramite); r.querydatabase(); return r.getLrecord(); } }