package com.fp.frontend.controller.armas.solicitud; import java.util.ArrayList; import java.util.Date; 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.AbstractDataTransport; 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.util.EstadosSolicitudBPM; import com.fp.frontend.helper.MessageHelper; import com.fp.persistence.parmas.soli.TarmSolicitud; import com.fp.persistence.pcustomer.gene.TcustPersonDetail; /** * Clase controladora del bean TarmSolicitud. * * @author Jorge Vaca. * @version 2.1 */ @SuppressWarnings("serial") @ManagedBean @ViewScoped public class SolicitudArmasController extends AbstractController { private ListlistaEstadoSolicitud; public SolicitudArmasController() throws Exception { super(TarmSolicitud.class); } @PostConstruct private void postconstruct() { this.init(); // 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 = "SOLICITUD"; listaEstadoSolicitud= new ArrayList(); this.create(); } 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(); } @Override protected void querydatabase() { try { listaEstadoSolicitud = new ArrayList<>(); DtoQuery dto = super.getDtoQuery(true); dto.setMultirecord(false); //nombre SubQuery snombre= new SubQuery ("TcustPersonDetail", "name", "nombre", "i.pk.personcode = t.personcode and i.pk.dateto=(select max(dt.pk.dateto) from TcustPersonDetail dt where dt.pk.personcode=t.personcode)"); SubQuery snumerodocumento= new SubQuery ("TcustPersonDetail", "identification", "identification", "i.pk.personcode = t.personcode and i.pk.dateto=(select max(dt.pk.dateto) from TcustPersonDetail dt where dt.pk.personcode=t.personcode)"); SubQuery identificationcatalog= new SubQuery ("TcustPersonDetail", "identificationcatalog", "identificationcatalog", "i.pk.personcode = t.personcode and i.pk.dateto=(select max(dt.pk.dateto) from TcustPersonDetail dt where dt.pk.personcode=t.personcode)"); SubQuery identificationcatalogcode= new SubQuery ("TcustPersonDetail", "identificationcatalogcode", "identificationcatalogcode", "i.pk.personcode = t.personcode and i.pk.dateto=(select max(dt.pk.dateto) from TcustPersonDetail dt where dt.pk.personcode=t.personcode)"); //tramite // TarmTramite SubQuery codigoTramite= new SubQuery ("TarmTramite", "pk", "pk", "i.pk = t.ctramite"); SubQuery tramitetipoautorizacion= new SubQuery ("TarmTramite", "tipoautorizacion", "tipoautorizacion", "i.pk = t.ctramite"); SubQuery tramitetipoautorizacioncode= new SubQuery ("TarmTramite","tipoautorizacioncodigo", "tipoautorizacioncodigo", "i.pk = t.ctramite"); SubQuery tramitecategoria= new SubQuery ("TarmTramite", "categoria", "categoria", "i.pk = t.ctramite"); SubQuery tramitecategoriacodigo= new SubQuery ("TarmTramite","categoriacodigo", "categoriacodigo", "i.pk = t.ctramite"); SubQuery tramiteusoactividad= new SubQuery ("TarmTramite", "usoactividad", "usoactividad", "i.pk = t.ctramite"); SubQuery tramiteusoactividadcodigo= new SubQuery ("TarmTramite","usoactividadcodigo", "usoactividadcodigo", "i.pk = t.ctramite"); //estado SubQuery estado= new SubQuery("TgeneCatalogDetail","description","estadoSolicitud","i.pk.catalog=t.estado and i.pk.catalogcode=t.estadocodigo"); dto.addSubQuery(estado); dto.addSubQuery(snumerodocumento); dto.addSubQuery(snombre); dto.addSubQuery(identificationcatalog); dto.addSubQuery(identificationcatalogcode); dto.addSubQuery(codigoTramite); dto.addSubQuery(tramitetipoautorizacion); dto.addSubQuery(tramitetipoautorizacioncode); dto.addSubQuery(tramitecategoria); dto.addSubQuery(tramitecategoriacodigo); dto.addSubQuery(tramiteusoactividad); dto.addSubQuery(tramiteusoactividadcodigo); HashMap mtables = new HashMap(); mtables.put(beanalias, dto); // permite adicionar mas de una tabla. Request request = callerhelper.getRequest(); request.setQueryTables(mtables); request.put("queryalias", "ESTADOSSOLICITUDBPMQUERY"); request.put("codigosolicitudbpm", this.getMfilters().get("numerosolicitud")); Response resp = callerhelper.executeQuery(request); if(resp.get("LISTASESTADOSOLICITUDBPM")!=null){ System.out.println("------------"+resp.get("LISTASESTADOSOLICITUDBPM").toString()); List listaEstadosSolicitud = (List)resp.get("LISTASESTADOSOLICITUDBPM"); for (Object[] item : listaEstadosSolicitud) { EstadosSolicitudBPM estados = new EstadosSolicitudBPM(); estados.setActividad(item[0]!=null?item[0].toString():""); estados.setUsuarioasignado(item[1]!=null?item[1].toString():""); estados.setGrupoasignado(item[2]!=null?item[2].toString():""); estados.setEstado(item[3]!=null?item[3].toString():""); estados.setFechacreacion(item[4]!=null?(Date)item[4]:null); estados.setFechainicio(item[5]!=null?(Date)item[5]:null); estados.setFechacompleta(item[6]!=null?(Date)item[6]:null); listaEstadoSolicitud.add(estados); } } if (resp.getResponseCode().compareTo(Response.RESPONSE_OK) != 0) { lrecord = new ArrayList(); MessageHelper.setMessageError(resp); } else { record = (TarmSolicitud) resp.get(beanalias); super.postQuery((AbstractDataTransport) resp.get(beanalias)); } } 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); } public void fijaPersona(TcustPersonDetail persondetail) throws Exception { if (persondetail == null) { return; } record.setPersoncode(persondetail.getPk().getPersoncode()); } public void fijaInicioFlujoEnNO() throws Exception { record.setInicioFlujo("N"); } public void fijaInicioFlujoEnYES() throws Exception { record.setInicioFlujo("Y"); } public static TarmSolicitud findxSolicitudCodpersona(String codigoSolicitud,String codigoPersona) { try { SolicitudArmasController cc = new SolicitudArmasController(); cc.init(); cc.recperpage = 10000; cc.addFilter("pk", codigoSolicitud); cc.addFilter("personcode", codigoPersona); cc.querydatabase(); if (cc.record != null) { return cc.record; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } public static TarmSolicitud findByCSolicitud(String cSolicitud) { try { SolicitudArmasController cc = new SolicitudArmasController(); cc.init(); cc.recperpage = 10000; cc.addFilter("pk", cSolicitud); cc.queryDBNormal(); if (cc.lrecord.size()>0) { return cc.lrecord.get(0); } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } public static List findByCTramite(String cTramite) { try { SolicitudArmasController cc = new SolicitudArmasController(); cc.init(); cc.recperpage = 10000; cc.addFilter("ctramite", cTramite); cc.queryDBNormal(); if (cc.lrecord.size()>0) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * * Metodo para encopntrar los tramites pertenecientes a una persona * @param cPersona codigo de la persona * @param cTramite codigo del tramite * @return Listado de las solicitudes encontradas */ public static List findByPersonaCTramite(Integer cPersona, String cTramite) { try { SolicitudArmasController cc = new SolicitudArmasController(); cc.init(); cc.recperpage = 10000; cc.addFilter("ctramite", cTramite); cc.addFilter("personcode", String.valueOf(cPersona)); cc.queryDBNormal(); if (cc.lrecord.size()>0) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } // Version del metodo querydatabase normal sin filtros adicionales protected void queryDBNormal() { try { DtoQuery dto = super.getDtoQuery(true); dto.setOrderby("t.pk"); // 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); } } public void update(TarmSolicitud bean) throws Exception{ record=bean; super.update(); } public static TarmSolicitud find(String codigoSolicitud) { try { if(codigoSolicitud == null || codigoSolicitud.isEmpty()){ return null; } SolicitudArmasController cc = new SolicitudArmasController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk", codigoSolicitud); cc.querydatabase(); if (cc.record != null) { return cc.record; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } public List getListaEstadoSolicitud() { return listaEstadoSolicitud; } public void setListaEstadoSolicitud( List listaEstadoSolicitud) { this.listaEstadoSolicitud = listaEstadoSolicitud; } }