package com.fp.frontend.controller.armas.solicitud; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; 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.ManagedProperty; 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.Filter; import com.fp.dto.save.DtoSave; import com.fp.frontend.controller.AbstractController; import com.fp.frontend.controller.pentaho.PentahoController; import com.fp.frontend.controller.pgeneral.gene.CatalogDetailController; import com.fp.frontend.helper.MessageHelper; import com.fp.persistence.parmas.soli.TarmDecomiso; import com.fp.persistence.parmas.soli.TarmSolicitudTramite; import com.fp.persistence.pgeneral.gene.TgeneCatalogDetail; /** * Clase controladora del bean TarmDecomiso. * * @author C.P. * @version 2.1 */ @SuppressWarnings("serial") @ManagedBean @ViewScoped public class DecomisoController extends AbstractController { /** * Constructor * @throws Exception */ public DecomisoController() throws Exception { super(TarmDecomiso.class); } /** * Metodo invocado despues de instanciar el controlador */ @PostConstruct private void postconstruct() { this.init(); // Inicializa autoconsulta super.startQuery(); } /** * Incializa variables del controlador, cuando se esta utilizando una pagina que utliza el controlador. */ private void init() { try { this.recperpage = 10; // Cambiar al # reg a mirar. this.lrecord = new ArrayList<>(); this.beanalias = "DECOMISO"; } catch (Exception e) { MessageHelper.setMessageError(e); } } /* (non-Javadoc) * @see com.fp.frontend.controller.AbstractController#querydatabase() */ @SuppressWarnings("unchecked") @Override protected void querydatabase() { try { Request request = this.callerhelper.getRequest(); DtoQuery dto = super.getDtoQuery(true); dto.setOrderby("t.pk"); // En en string van todos los campos de orden ("t.pk, t.nombre, t.cpais"). if(getMfilelds().get("ccentrocontroldestino")!=null){ Filter filtro = new Filter(); filtro.setSql(getMfilelds().get("ccentrocontroldestino").toString()); dto.addFiltro(filtro); } HashMap mtables = new HashMap(); mtables.put(this.beanalias, dto); // permite adicionar mas de una tabla. request.setQueryTables(mtables); Response resp = this.callerhelper.executeQuery(request); if (resp.getResponseCode().compareTo(Response.RESPONSE_OK) != 0) { this.lrecord = new ArrayList(); MessageHelper.setMessageError(resp); } else { this.lrecord = (List) resp.get(this.beanalias); super.postQuery(this.lrecord); } } catch (Throwable e) { MessageHelper.setMessageError(e); } } protected void querydatabaseSimple() { try { Request request = this.callerhelper.getRequest(); DtoQuery dto = super.getDtoQuery(true); dto.setOrderby("t.pk"); // En en string van todos los campos de orden ("t.pk, t.nombre, t.cpais"). Filter filtroFinal = new Filter(); String format = new SimpleDateFormat("MM-YY").format(Calendar.getInstance().getTime()); String sqlFiltro = "TO_CHAR(t.fecharegistro, 'MM-YY') = '"+format+"'"; filtroFinal.setSql(sqlFiltro); dto.addFiltro(filtroFinal); HashMap mtables = new HashMap(); mtables.put(this.beanalias, dto); // permite adicionar mas de una tabla. request.setQueryTables(mtables); Response resp = this.callerhelper.executeQuery(request); if (resp.getResponseCode().compareTo(Response.RESPONSE_OK) != 0) { this.lrecord = new ArrayList(); MessageHelper.setMessageError(resp); } else { this.lrecord = (List) resp.get(this.beanalias); super.postQuery(this.lrecord); } } catch (Throwable e) { MessageHelper.setMessageError(e); } } /* (non-Javadoc) * @see com.fp.frontend.controller.AbstractController#save() */ @Override public void save(){ try { Request request = this.callerhelper.getRequest(); DtoSave dtosave = super.getDtoSave(); if(!dtosave.pendingProcess()){ return; } HashMap msave = new HashMap(); msave.put(this.beanalias, dtosave); // adicionar metadata de mantenimiento para cada tabla. request.setSaveTables(msave); Response resp = this.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); } } public void updateDecomiso(TarmDecomiso bean) throws Exception{ record = bean; record.setIsnew(false); record.put("ORIGINALBEAN", bean.get("ORIGINALBEAN")); super.update(); } @ManagedProperty(value = "#{pentahoController}") private PentahoController pentahoController; public PentahoController getPentahoController() { return pentahoController; } public void setPentahoController(PentahoController pentahoController) { this.pentahoController = pentahoController; } /** * Método para obtener el decomiso por el codigo de decomiso * @param cRecibo * @return */ public static TarmDecomiso findByCodigo(String cRecibo) { try { DecomisoController cc = new DecomisoController(); cc. init(); cc.recperpage = 300; cc.addFilter("pk", cRecibo); cc.querydatabase(); if (cc.lrecord != null && !cc.lrecord.isEmpty()) { return cc.lrecord.get(0); } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Metodo para filtrar por codigo de centro de control * @param ccentroControl * @param numerotransaccion * @return */ public static List findByCodigoCentroControl(String ccentroControl, String numerotransaccion) { try { DecomisoController cc = new DecomisoController(); cc. init(); cc.recperpage = 10000; if(ccentroControl!=null && !ccentroControl.isEmpty()){ cc.addFilter("ccentrocontrol", ccentroControl); } if(numerotransaccion!=null && !numerotransaccion.isEmpty()){ cc.addFilter("numerotransaccion", numerotransaccion); } cc.querydatabase(); if (cc.lrecord != null && !cc.lrecord.isEmpty()) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Metodo para filtrar por codigo de centro de control * @param ccentroControl * @return */ public static List findByCentroControl(String ccentroControl) { try { DecomisoController cc = new DecomisoController(); cc. init(); cc.recperpage = 10000; if(ccentroControl!=null && !ccentroControl.isEmpty()){ cc.addField("ccentrocontroldestino","(ccentrocontrol='"+ccentroControl+"' and ccentrocontroldestino is null) or (ccentrocontroldestino='"+ccentroControl+"')"); } cc.querydatabase(); if (cc.lrecord != null && !cc.lrecord.isEmpty()) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Metodo para filtrar por OrganismoControl y Unidad * @param organismoControlCode * @return */ public static List findByOrganismoControlUnidad(String organismoControlCode, String unidadCode) { try { DecomisoController cc = new DecomisoController(); cc. init(); cc.recperpage = 10000; TgeneCatalogDetail organismoControlCatalog = CatalogDetailController.findCatalogo("INSTITUCION", organismoControlCode); if(organismoControlCatalog!=null && unidadCode!=null){ cc.addField("ccentrocontroldestino","(unidad='"+unidadCode+"' and organismocontrol='"+organismoControlCatalog.getDescription()+"')"); } cc.querydatabase(); if (cc.lrecord != null && !cc.lrecord.isEmpty()) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Metodo para filtrar por OrganismoControl * * @param numeroRecibo numero de recibo * @param tipoProceso tipo de proceso * @param organismoControl organismo de control * @return */ public static boolean findReciboByTipoProcesoOrganismoControl(String numeroRecibo, String tipoProceso, String organismoControl) { try { DecomisoController cc = new DecomisoController(); cc.init(); cc.recperpage = 1000; if (numeroRecibo != null && !numeroRecibo.isEmpty()) { cc.addFilter("numerorecibo", numeroRecibo); } if (tipoProceso != null && !tipoProceso.isEmpty()) { cc.addFilter("tipoproceso", tipoProceso); } if (organismoControl != null && !organismoControl.isEmpty()) { cc.addFilter("ccentrocontrol", organismoControl); } cc.querydatabaseSimple(); if (cc.lrecord != null && cc.lrecord.size() > 0) { return true; } return false; } catch (Throwable e) { MessageHelper.setMessageError(e); return false; } } public static TarmDecomiso find(String numerotransaccion) { try { DecomisoController cc = new DecomisoController(); cc. init(); cc.recperpage = 300; cc.addFilter("numerotransaccion", numerotransaccion); cc.querydatabase(); if (cc.lrecord != null && cc.lrecord.size()>0) { return cc.lrecord.get(0); } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } }