package com.fp.frontend.controller.pgeneral.date; 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.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.solicitud.SolicitudArmasController; import com.fp.frontend.controller.armas.solicitud.SolicitudTramiteController; import com.fp.frontend.controller.pgeneral.gene.CatalogDetailController; import com.fp.frontend.helper.MessageHelper; import com.fp.persistence.parmas.soli.TarmSolicitudTramite; import com.fp.persistence.pgeneral.date.TgeneNotAccountingDay; import com.fp.persistence.pgeneral.gene.TgeneCatalogDetail; /** * Clase controladora del bean TgeneNotAccountingDay. * * @author Jorge Vaca. * @version 2.1 */ @ManagedBean @ViewScoped public class TgeneNotAccountingDayController extends AbstractController { private static final long serialVersionUID = 1L; private List lmonths; public TgeneNotAccountingDayController() throws Exception { super(TgeneNotAccountingDay.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 = 10; // Cambiar al # reg a mirar. this.lrecord = new ArrayList<>(); this.beanalias = "NONACCOUNTINGDATE"; lmonths = CatalogDetailController.find("MONTHS"); } catch (Exception e) { MessageHelper.setMessageError(e); } } public void create() throws Exception { super.create(); record.setCatalogcode("MONTHS"); record.modifiedData.put("monthdesc", lmonths.get(0).getDescription()); } /** * Entrega el valor de: lmonths * @return List */ public List getLmonths() { return lmonths; } @SuppressWarnings("unchecked") @Override protected void querydatabase() { try { Request request = this.callerhelper.getRequest(); DtoQuery dto = super.getDtoQuery(true); dto.setOrderby("t.pk.catalog, t.pk.day"); // En en string van todos los campos de orden ("t.pk, t.nombre, t.cpais"). SubQuery subquery = new SubQuery("TgeneCatalogDetail", "description", "monthdesc", "i.pk.catalogcode = t.catalogcode and i.pk.catalog = t.pk.catalog"); dto.addSubQuery(subquery); 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); } } @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); } } @Override public void postCommit(Response response) throws Exception { super.postCommitGeneric(response, this.beanalias); } public void refreshMonth() { for (TgeneCatalogDetail catdet : lmonths) { if (catdet.getPk().getCatalog().compareTo(record.getPk().getCatalog()) == 0) { record.modifiedData.put("monthdesc", catdet.getDescription()); break; } } } /* * Metodo que retorna una fecha la cual es NDiasLaborablesPrevios anteriores a la fecha que es pasada como parametro * @param NDiasLaborablesPrevios - Entero positivo que indica el numero de dias previos buscados * */ public static Date diasLaborablesPreviosAUnaFecha(Date fecha, int NDiasLaborablesPrevios){ try { TgeneNotAccountingDayController cc = new TgeneNotAccountingDayController(); Calendar fechaCalendar = Calendar.getInstance(); fechaCalendar.setTime(fecha); int numDiasEncontrados = 0; while(numDiasEncontrados < NDiasLaborablesPrevios){ fechaCalendar.add(Calendar.DAY_OF_MONTH, -1); if(fechaCalendar.get(Calendar.DAY_OF_WEEK)!=Calendar.SATURDAY && fechaCalendar.get(Calendar.DAY_OF_WEEK)!=Calendar.SUNDAY){ cc.init(); cc.recperpage = 300; String codigoMes = String.valueOf(fechaCalendar.get(Calendar.MONTH)); codigoMes=((codigoMes.length()==1)?"0"+codigoMes:codigoMes); Integer dia = fechaCalendar.get(Calendar.DAY_OF_MONTH); TgeneNotAccountingDay diaNoLaborable = findByCatalogDay(codigoMes, dia); if(diaNoLaborable==null){ numDiasEncontrados+=1; } continue; } else{ fechaCalendar.add(Calendar.DAY_OF_MONTH, -1); } } return fechaCalendar.getTime(); } catch (Throwable e) { // TODO Auto-generated catch block e.printStackTrace(); return null; } } /* * Metodo que retorna una fecha la cual es NDiasLaborablesPrevios posterior a la fecha que es pasada como parametro * @param NDiasLaborablesPosteriores - Entero positivo que indica el numero de dias posterior de la fecha buscada * */ public static Date diasLaborablesPosterioresAUnaFecha(Date fecha, int NDiasLaborablesPosteriores){ try { TgeneNotAccountingDayController cc = new TgeneNotAccountingDayController(); Calendar fechaCalendar = Calendar.getInstance(); fechaCalendar.setTime(fecha); int numDiasEncontrados = 0; while(numDiasEncontrados < NDiasLaborablesPosteriores){ fechaCalendar.add(Calendar.DAY_OF_MONTH, 1); if(fechaCalendar.get(Calendar.DAY_OF_WEEK)!=Calendar.SATURDAY && fechaCalendar.get(Calendar.DAY_OF_WEEK)!=Calendar.SUNDAY){ cc.init(); cc.recperpage = 300; String codigoMes = String.valueOf(fechaCalendar.get(Calendar.MONTH)); codigoMes=((codigoMes.length()==1)?"0"+codigoMes:codigoMes); Integer dia = fechaCalendar.get(Calendar.DAY_OF_MONTH); TgeneNotAccountingDay diaNoLaborable = findByCatalogDay(codigoMes, dia); if(diaNoLaborable==null){ numDiasEncontrados+=1; } continue; } else{ fechaCalendar.add(Calendar.DAY_OF_MONTH, 1); } } return fechaCalendar.getTime(); } catch (Throwable e) { // TODO Auto-generated catch block e.printStackTrace(); return null; } } public static TgeneNotAccountingDay findByCatalogDay(String codigoMes, Integer dia){ try { TgeneNotAccountingDayController cc = new TgeneNotAccountingDayController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalog", codigoMes); cc.addFilter("pk.day", dia.toString()); cc.querydatabase(); if (cc.lrecord.size()>0) { return cc.lrecord.get(0); } return null; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } public static Boolean findDay(Integer codigoMes, Integer dia){ try { TgeneNotAccountingDayController cc = new TgeneNotAccountingDayController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalog", codigoMes.toString()); cc.addFilter("pk.day", dia.toString()); cc.querydatabase(); if (cc.lrecord.size()>0) { return true; } return false; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } public static Date isfechalaboral(Date fechalaboral){ Calendar calendario = Calendar.getInstance(); calendario.setTime(fechalaboral); if(calendario.get(Calendar.DAY_OF_WEEK)==Calendar.SATURDAY || calendario.get(Calendar.DAY_OF_WEEK)==Calendar.SUNDAY){ calendario.add(Calendar.DAY_OF_YEAR,1); fechalaboral=isfechalaboral(calendario.getTime()); } if(findDay(fechalaboral.getMonth(),fechalaboral.getDay())){ calendario.add(Calendar.DAY_OF_YEAR,1); fechalaboral=isfechalaboral(calendario.getTime()); } return fechalaboral; } public static Boolean findDaynuevo(String codigoMes, Integer dia){ try { TgeneNotAccountingDayController cc = new TgeneNotAccountingDayController(); cc.init(); cc.recperpage = 300; cc.addFilter("pk.catalog", codigoMes); cc.addFilter("pk.day", dia.toString()); cc.querydatabase(); if (cc.lrecord.size()>0) { return true; } return false; } catch (Throwable e) { MessageHelper.setMessageError(e); return null; } } }