package com.fp.frontend.controller.pgeneral.gene; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import javax.annotation.PostConstruct; import javax.faces.bean.ManagedBean; import javax.faces.bean.ViewScoped; import org.primefaces.event.SelectEvent; import com.fp.dto.Request; import com.fp.dto.Response; import com.fp.dto.query.DtoQuery; import com.fp.dto.save.DtoSave; import com.fp.frontend.controller.AbstractController; import com.fp.frontend.controller.pgeneral.lov.CatalogLovController; import com.fp.frontend.helper.MessageHelper; import com.fp.persistence.pgeneral.gene.TgeneCatalog; import com.fp.persistence.pgeneral.gene.TgeneCatalogDetail; /** * Clase controladora del bean TgeneCatalogDetail. * * @author Jorge Vaca. * @version 2.1 */ @SuppressWarnings("serial") @ManagedBean @ViewScoped public class CatalogDetailController extends AbstractController { public CatalogDetailController() throws Exception { super(TgeneCatalogDetail.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 { this.recperpage = 15; // Cambiar al # reg a mirar. this.lrecord = new ArrayList<>(); this.beanalias = "CATALOGDETAIL"; } 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 { if (super.getMfilters().get("pk.catalogcode") == null) { MessageHelper.setMessageError("msg_catalogrequird"); return; } super.create(); this.record.getPk().setCatalogcode(super.getMfilters().get("pk.catalogcode")); } @SuppressWarnings("unchecked") @Override protected void querydatabase() { try { DtoQuery dto = super.getDtoQuery(true); dto.setOrderby("t.description"); HashMap mtables = new HashMap(); mtables.put(this.beanalias, dto); // permite adicionar mas de una tabla. Request request = this.callerhelper.getRequest(); 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); } } @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 = this.callerhelper.getRequest(); 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 openCatalogLov() { Map> params = new HashMap<>(); CatalogLovController.openLov(params); } public void onReturnCatalogLov(SelectEvent event) throws Exception { TgeneCatalog t = (TgeneCatalog) event.getObject(); super.addFilter("pk.catalogcode", t.getPk()); super.addField("catalogname", t.getDescription()); this.query(); } /** * Entrega una lista de objetos TgeneCatalogDetail * @param catalogcode Có de catálogo * @return lrecord Lista de objetos TgeneCatalogDetail */ public static List find(String catalogcode) { try { CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 10000; cc.addFilter("pk.catalogcode", catalogcode); cc.querydatabase(); if ((cc.lrecord != null) && !cc.lrecord.isEmpty()) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Entrega una lista de objetos TgeneCatalogDetail * @param catalogcode Có de catálogo * @param legalcode Código legal * @return lrecord Lista de objetos TgeneCatalogDetail */ public static List find(String catalogcode, String legalcode) { try { CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalogcode", catalogcode); cc.addFilter("legalcode", legalcode); cc.querydatabase(); if ((cc.lrecord != null) && !cc.lrecord.isEmpty()) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Entrega una lista de objetos TgeneCatalogDetail * @param catalogcode Có de catálogo * @param catalog Código catalogo * @return lrecord Lista de objetos TgeneCatalogDetail */ public static List findCatalog(String catalogcode, String catalog) { try { CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalogcode", catalogcode); cc.addFilter("pk.catalog", catalog); cc.querydatabase(); if ((cc.lrecord != null) && !cc.lrecord.isEmpty()) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Encuentra por los codigos de catalogo * @param catalogcode * @param catalog * @return */ public static TgeneCatalogDetail findCatalogo(String catalogcode, String catalog) { try { if(catalogcode==null || catalog ==null || catalogcode.isEmpty() || catalog.isEmpty()){ return null; } CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalogcode", catalogcode); cc.addFilter("pk.catalog", catalog); 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 que consulta por Catalog y Catalogcode ambos requeridos */ public static TgeneCatalogDetail findxCodigoCodcatalogo(String catalog, String catalogcode) { try {//TgeneCatalogDetailKey if(catalog!=null && catalogcode!=null){ CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalogcode", catalogcode); cc.addFilter("pk.catalog", catalog); cc.querydatabase(); if ((cc.lrecord != null) && !cc.lrecord.isEmpty()) { return cc.lrecord.get(0); } } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Obtiene un elemento del catalogo por su codigo * @param catalog * @return */ public static TgeneCatalogDetail findxCodigo(String catalog) { try {//TgeneCatalogDetailKey CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalog", catalog); cc.querydatabase(); if ((cc.lrecord != null) && !cc.lrecord.isEmpty()) { return cc.lrecord.get(0); } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Obtiene un elemento del catalogo por su codigo de catalogo * @param catalog * @return */ public static List findByCatalogcode(String catalogcode) { try {//TgeneCatalogDetailKey CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalogcode", catalogcode); cc.querydatabase(); if (cc.lrecord !=null && !cc.lrecord.isEmpty()) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } /** * Obtiene un elemento del catalogo por su codigo de catalogo * y descripcion * @param catalog * @return */ public static TgeneCatalogDetail findByCatalogcodeDescrption(String catalogcode,String descrption) { try {//TgeneCatalogDetailKey if(catalogcode==null || descrption ==null || catalogcode.isEmpty() || descrption.isEmpty()){ return null; } CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalogcode", catalogcode); cc.addFilter("description", descrption); 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 que llena lal lista de géneros */ public static List getListGender(){ List gender = new ArrayList(); String[] male = {"M", "MASCULINO"}; String[] female = {"F", "FEMENINO"}; gender.add(male); gender.add(female); return gender; } /** * Entrega una lista de objetos TgeneCatalogDetail * @param catalogcode Có de catálogo * @return lrecord Lista de objetos TgeneCatalogDetail */ public static List findClientType(String catalogcode, String legalcode) { try { CatalogDetailController cc = new CatalogDetailController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalogcode", catalogcode); cc.addFilter("legalcode", legalcode); cc.querydatabase(); if ((cc.lrecord != null) && !cc.lrecord.isEmpty()) { return cc.lrecord; } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } }