1.5.1 <jmoordbjsf:searchBetweenDates con <jmoordbjsf:autocomplete>

Cuando deseamos filtrar por los datos de un autocomplete con un <jmoordbjsf:betweenDateSearch>

formulario

<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html>
<ui:composition template="/layout/template.xhtml" 
                xmlns="http://www.w3.org/1999/xhtml"
                xmlns:h="http://java.sun.com/jsf/html"
                xmlns:f="http://java.sun.com/jsf/core"
                xmlns:b="http://bootsfaces.net/ui"
                xmlns:ui="http://java.sun.com/jsf/facelets"
                xmlns:p="http://primefaces.org/ui"
                xmlns:jmoordbjsf="http://jmoordbjsf.com/taglib"
                xmlns:e="http://xmlns.jcp.org/jsf/composite/extensions"
                >
    <ui:define name="content">


        <style>
            .thumbnail { max-width: 100%; }
            img.thumbnail:hover, img.thumbnail:focus {
                border: 1px solid;
                border-color: #428BCA;
            } 
        </style>

        <b:form id="form"  prependId="false"  rendered="#{p:ifAnyGranted('ADMINISTRADOR,  SECRETARIO ADMINISTRATIVO')}" onkeypress="if (event.keyCode == 13) {
                    return false;
                }">

            <b:growl  id="msgs"/>

            <b:panel collapsible="false" title="#{msg['titlelist.solicitudesporusuarios']}" id="content"   look="primary" > 
                <!--<b:panelGrid colSpans="2,10" size="xs">--> 

                <b:row>
                    <b:column medium-screen="25" >
                        <p:outputLabel  value="#{msg['field.usuario']}" />

                        <jmoordbjsf:autocomplete converter="#{usuarioConverter}"
                                                 completeMethod="#{solicitudesPorUsuariosController.usuarioServices.complete}"
                                                 labeltip1="#{msg['field.username']} #{p.username}"
                                                 labeltip2="#{msg['field.nombre']} #{p.nombre}"  
                                                 listener="#{solicitudesPorUsuariosController.handleAutocompleteOfListXhtml}"
                                                 value="#{solicitudesPorUsuariosController.usuarioSearch}"
                                                 itemLabel=" #{p.nombre}"
                                                 field="nombre"
                                                 dropdown="true"
                                                 minQueryLength="0"
                                                 disabled="false"
                                                 update=" :form:dataTable"
                                                 />

                    </b:column>


                    <b:column medium-screen="25" >


                        <jmoordbjsf:searchBetweenDate 
                            renderedMove="true"
                            labelDesde="#{msg['field.fechainicio']}"
                            valueDesde="#{solicitudesPorUsuariosController.fechaDesde}"
                            labelHasta="#{msg['field.fechafin']}"
                            valueHasta="#{solicitudesPorUsuariosController.fechaHasta}"
                            renderedList="true"  
                            search="#{solicitudesPorUsuariosController.searchBy('_betweendates',solicitudesPorUsuariosController.solicitud)}"
                            update=":form:dataTable "
                            />
                    </b:column>

                </b:row>


            </b:panel>
            <b:panel collapsible="false" id="dataTable" look="primary">

                <jmoordbjsf:paginator
                    controller="#{solicitudesPorUsuariosController}"                        
                    rowPage="#{solicitudesPorUsuariosController.rowPage}"                   
                    page="#{solicitudesPorUsuariosController.page}"
                    pages="#{solicitudesPorUsuariosController.pages}"
                    renderedPrint="#{solicitudesPorUsuariosController.availablePrint()}"                   
                    renderedNew="false"                 
                    renderedClear ="false"
                    skip="ajax:solicitudesPorUsuariosController.skip()" 
                    url = "/pages/viaje/new.xhtml"
                    />

                <p:dataTable value="#{solicitudesPorUsuariosController.solicitudDataModel}"
                             var="item"
                             id="dataTable2"
                             >

                    <f:facet name="header">
                        <p:outputLabel value="#{msg['titlelist.solicitudes']}"/>
                    </f:facet>
                    <p:column style="width:16px">
                        <p:rowToggler />
                    </p:column>

                    <p:column headerText="#{msg['field.idsolicitud']}" style="width:75px">
                        <h:outputText value="#{item.idsolicitud}"    />
                    </p:column>

                    <p:column headerText="#{msg['field.fechapartida']}" style="width:150px">
                        <h:outputText value="#{solicitudController.showDate(item.fechahorapartida)} #{solicitudController.showHour(item.fechahorapartida)}"    />
                    </p:column>
                    <p:column headerText="#{msg['field.fecharegreso']}" style="width:150px">
                        <h:outputText value="#{solicitudController.showDate(item.fechahoraregreso)} #{solicitudController.showHour(item.fechahoraregreso)}"    />
                    </p:column>
                    <p:column headerText="#{msg['field.solicita']}" style="width:150px">
                        <h:outputText value="#{item.usuario.get(0).nombre}"    />
                    </p:column>


                    <p:column headerText="#{msg['field.vistobueno']}"  >
                        <p:outputLabel value="#{secretarioAdministrativoController.columnNameVistoBuenoSecretarioAdministrativo(item.vistoBuenoSecretarioAdministrativo)}" 
                                       />
                    </p:column>
                    <p:column headerText="#{msg['field.estatus']}"  >
                        <p:outputLabel  value="#{item.estatus.idestatus}"    />
                    </p:column>





                    <p:rowExpansion>

                        <b:panelGrid id="panel" colSpans="2,10" size="sm" > 

                            <p:outputLabel value="#{msg['field.fecharegreso']}" />
                            <p:outputLabel value="#{solicitudesPorUsuariosController.showDate(item.fechahoraregreso)}"  />

                            <p:outputLabel value="#{msg['field.horaregreso']}" />
                            <p:outputLabel value="#{solicitudesPorUsuariosController.showHour(item.fechahoraregreso)}"  />

                            <p:outputLabel  value="#{msg['field.solicitadopor']}" />
                            <p:outputLabel  value="#{item.usuario.get(0).nombre}" id="solicitadopor"   />

                            <p:outputLabel  value="#{msg['field.responsable']}" />
                            <p:outputLabel  value="#{item.usuario.get(1).nombre}" id="responsable"   />



                            <p:outputLabel value="#{msg['field.objetivo']}"  />
                            <p:outputLabel value="#{item.objetivo}"   />
                            <p:outputLabel value="#{msg['field.lugares']}"/>
                            <p:outputLabel value="#{item.lugares}"    />




                            <p:outputLabel  value="#{msg['field.facultad']}" />
                            <p:repeat value="#{item.facultad}" var="car">
                                <p:outputLabel value="#{car.descripcion}"/>
                            </p:repeat>

                            <p:outputLabel  value="#{msg['field.carrera']}" />
                            <p:repeat value="#{item.carrera}" var="car">
                                <p:outputLabel value="#{car.descripcion}"/>
                            </p:repeat>
                            <p:outputLabel  value="#{msg['field.numerogrupos']}" />
                            <p:outputLabel  value="#{item.numerogrupo}" />



                            <p:outputLabel  value="#{msg['field.numerodevehiculos']}" />

                            <p:outputLabel  value="#{item.numerodevehiculos}"  />

                            <p:outputLabel  value="#{msg['field.pasajeros']}" >
                                <i class="pi pi-users"></i>
                            </p:outputLabel>
                            <p:outputLabel value="#{item.pasajeros}"   />

                            <p:outputLabel  value="#{msg['field.lugarpartida']}" />
                            <p:outputLabel value="#{item.lugarpartida}"  />
                            <p:outputLabel  value="#{msg['field.lugarllegada']}" >
                                <i class="pi pi-home"></i>
                            </p:outputLabel>
                            <p:outputLabel value="#{item.lugarllegada}" />


                            <p:outputLabel  value="#{msg['field.coordinador']}"  />
                            <p:outputLabel value="#{solicitudesPorUsuariosController.columnNameVistoBueno(item.vistoBueno)}"      />


                            <p:outputLabel  value="#{msg['field.secadministrativo']}" />
                            <p:outputLabel value="#{secretarioAdministrativoController.columnNameVistoBuenoSecretarioAdministrativo(item.vistoBuenoSecretarioAdministrativo)}"      />



                            <p:outputLabel value="#{msg['field.tiposolicitud']}" />
                            <p:outputLabel  value="#{item.tiposolicitud.idtiposolicitud}"    />

                            <p:outputLabel value="#{msg['field.estatus']}" />
                            <p:outputLabel  value="#{item.estatus.idestatus}"    />

                        </b:panelGrid>
                    </p:rowExpansion>
                </p:dataTable>
            </b:panel>

        </b:form>

        <jmoordbjsf:denegado renderedcondition="#{!p:ifAnyGranted('ADMINISTRADOR,  SECRETARIO ADMINISTRATIVO')}" />
    </ui:define>
</ui:composition>

CONTROLLER

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.avbravo.transporte.reportes;

// <editor-fold defaultstate="collapsed" desc="imports">
import com.avbravo.jmoordb.configuration.JmoordbContext;
import com.avbravo.jmoordb.configuration.JmoordbControllerEnvironment;
import com.avbravo.jmoordb.interfaces.IController;
import com.avbravo.jmoordbutils.printer.Printer;
import com.avbravo.jmoordb.mongodb.history.services.AutoincrementableServices;
import com.avbravo.jmoordb.mongodb.history.services.ErrorInfoServices;
import com.avbravo.jmoordbutils.DateUtil;
import com.avbravo.jmoordbutils.JmoordbResourcesFiles;

import com.avbravo.jmoordbutils.ReportUtils;
import com.avbravo.transporteejb.datamodel.SolicitudDataModel;
import com.avbravo.transporteejb.datamodel.ViajeDataModel;
import com.avbravo.transporteejb.entity.Solicitud;
import com.avbravo.transporteejb.entity.Usuario;
import com.avbravo.transporteejb.entity.VistoBueno;
import com.avbravo.transporteejb.repository.SolicitudRepository;
import com.avbravo.transporteejb.services.EstatusServices;
import com.avbravo.transporteejb.services.SolicitudServices;
import com.avbravo.transporteejb.services.UsuarioServices;
import com.avbravo.transporteejb.services.VistoBuenoServices;
import com.lowagie.text.Element;
import com.lowagie.text.Font;
import com.lowagie.text.FontFactory;
import com.lowagie.text.Paragraph;
import com.lowagie.text.pdf.PdfPTable;
import com.lowagie.text.pdf.PdfWriter;
import com.lowagie.text.PageSize;
import com.mongodb.client.model.Filters;

import java.io.ByteArrayOutputStream;

import java.util.ArrayList;
import java.io.Serializable;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import javax.annotation.PostConstruct;
import javax.faces.view.ViewScoped;
import javax.inject.Inject;
import javax.inject.Named;
import lombok.Getter;
import lombok.Setter;
import org.bson.Document;
import org.bson.conversions.Bson;
import org.primefaces.event.SelectEvent;
// </editor-fold>

/**
 *
 * @authoravbravo
 */
@Named
@ViewScoped
@Getter
@Setter
public class SolicitudesPorUsuariosController implements Serializable, IController {

// <editor-fold defaultstate="collapsed" desc="fields">  
    private static final long serialVersionUID = 1L;

    private Boolean writable = false;
    private Date fechaDesde;
    private Date fechaHasta;
    //DataModel
    private ViajeDataModel viajeDataModel;
    private SolicitudDataModel solicitudDataModel;

    Integer page = 1;
    Integer rowPage = 35;
    List<Integer> pages = new ArrayList<>();

    //Entity
    Usuario usuarioSearch= new Usuario();
    Solicitud solicitudSearch = new Solicitud();
    Solicitud solicitud = new Solicitud();

    //List
    List<Solicitud> solicitudList = new ArrayList<>();

    // </editor-fold>
    // <editor-fold defaultstate="collapsed" desc="repository">
    //Repository
    @Inject
    SolicitudRepository solicitudRepository;

    // </editor-fold>  
    // <editor-fold defaultstate="collapsed" desc="services">
    //Services
    @Inject
    AutoincrementableServices autoincrementableServices;
    @Inject
    EstatusServices estatusServices;
    @Inject
    ErrorInfoServices errorServices;
    @Inject
    VistoBuenoServices vistoBuenoServices;
    @Inject
    SolicitudServices solicitudServices;
    @Inject
    UsuarioServices usuarioServices;
    @Inject
    JmoordbResourcesFiles rf;
    @Inject
    Printer printer;
    // </editor-fold>  

    // </editor-fold>
// <editor-fold defaultstate="collapsed" desc="getter/setter">
    public List<Integer> getPages() {

        return solicitudRepository.listOfPage(rowPage);
    }

    // </editor-fold>
// <editor-fold defaultstate="collapsed" desc="constructor">
    public SolicitudesPorUsuariosController() {
    }

    // </editor-fold>
// <editor-fold defaultstate="collapsed" desc="init">
    @PostConstruct
    public void init() {
        try {
            fechaDesde = DateUtil.primerDiaDelMesEnFecha(DateUtil.anioActual(), DateUtil.mesActual());
            fechaHasta = DateUtil.ultimoDiaDelMesEnFecha(DateUtil.anioActual(), DateUtil.mesActual());
            /*
            configurar el ambiente del controller
             */
            HashMap parameters = new HashMap();
            Usuario jmoordb_user = (Usuario) JmoordbContext.get("jmoordb_user");
            //    parameters.put("P_EMPRESA", jmoordb_user.getEmpresa().getDescripcion());

            JmoordbControllerEnvironment jmc = new JmoordbControllerEnvironment.Builder()
                    .withController(this)
                    .withRepository(solicitudRepository)
                    .withEntity(solicitud)
                    .withService(solicitudServices)
                    .withNameFieldOfPage("page")
                    .withNameFieldOfRowPage("rowPage")
                    .withTypeKey("primary")
                    .withSearchLowerCase(false)
                    .withPathReportDetail("/resources/reportes/programacionvehicular/details.jasper")
                    .withPathReportAll("/resources/reportes/programacionvehicular/all.jasper")
                    .withparameters(parameters)
                    .withResetInSave(true)
                    .withAction("golist")
                    .build();

            start();

//            String action = "gonew";
//            if (getAction() != null) {
//                action = getAction();
//            }
//
//            if (action == null || action.equals("gonew") || action.equals("new") || action.equals("golist")) {
//                //inicializar
//
//            }
//            if (action.equals("view")) {
//                //view
//            }
            setSearchAndValue("searchViajesSinConductorController", "_betweendates");
        } catch (Exception e) {
            errorServices.errorMessage(nameOfClass(), nameOfMethod(), e.getLocalizedMessage());
        }
    }// </editor-fold>

// <editor-fold defaultstate="collapsed" desc="handleSelect">
    public void handleSelect(SelectEvent event) {
        try {
        } catch (Exception e) {
            errorServices.errorMessage(nameOfClass(), nameOfMethod(), e.getLocalizedMessage());
        }
    }// </editor-fold>

// <editor-fold defaultstate="collapsed" desc="move(Integer page)">
    @Override
    public void move(Integer page) {
        try {

            solicitudList = new ArrayList<>();
            this.page = page;
            solicitudDataModel = new SolicitudDataModel(solicitudList);
            Document doc;
            System.out.println("Usuario====> "+usuarioSearch.getUsername());
         Bson filter = Filters.eq("usuario.username", usuarioSearch.getUsername());
          solicitudList = solicitudRepository.filterBetweenDateWithoutHours(filter,
                    "fechahorapartida", fechaDesde,
                    "fechahoraregreso", fechaHasta,
                    new Document("fechahorapartida", -1));

           

            solicitudDataModel = new SolicitudDataModel(solicitudList);

        } catch (Exception e) {
            errorServices.errorMessage(nameOfClass(), nameOfMethod(), e.getLocalizedMessage());

        }

    }// </editor-fold>

    // <editor-fold defaultstate="collapsed" desc="String showDate(Date date)">
    public String showDate(Date date) {
        return solicitudServices.showDate(date);
    }// </editor-fold>
    // <editor-fold defaultstate="collapsed" desc="String showHour(Date date)">

    public String showHour(Date date) {
        return solicitudServices.showHour(date);

    }// </editor-fold>

    // <editor-fold defaultstate="collapsed" desc="String printAll()">
    @Override
    public String printAll() {

        com.lowagie.text.Document document = new com.lowagie.text.Document(PageSize.LETTER);
        ByteArrayOutputStream baos = new ByteArrayOutputStream();
        try {
            PdfWriter.getInstance(document, baos);
            //METADATA

            document.open();
            document.add(ReportUtils.paragraph("SOLICITUDES APROBADAS", FontFactory.getFont("arial", 12, Font.BOLD), Element.ALIGN_CENTER));

            String texto = "Desde " + DateUtil.showDate(fechaDesde) + "  Hasta: " + DateUtil.showDate(fechaHasta);
            document.add(ReportUtils.paragraph(texto, FontFactory.getFont("arial", 12, Font.BOLD), Element.ALIGN_CENTER));

            Date currentDate = new Date();
            String date = DateUtil.showDate(currentDate) + " " + DateUtil.showHour(currentDate);

            document.add(ReportUtils.paragraph("Fecha: " + date, FontFactory.getFont("arial", 8, Font.BOLD), Element.ALIGN_RIGHT));
            document.add(new Paragraph("\n"));

            //Numero de columnas
            PdfPTable table = new PdfPTable(5);

//Aqui indicamos el tamaño de cada columna
            table.setTotalWidth(new float[]{62, 75, 75, 90,90});

            table.setLockedWidth(true);

            table.addCell(ReportUtils.PdfCell("#", FontFactory.getFont("arial", 11, Font.BOLD), Element.ALIGN_CENTER));
            table.addCell(ReportUtils.PdfCell("Fecha Partida", FontFactory.getFont("arial", 11, Font.BOLD), Element.ALIGN_CENTER));
            table.addCell(ReportUtils.PdfCell("Fecha Regreso", FontFactory.getFont("arial", 11, Font.BOLD), Element.ALIGN_CENTER));
            table.addCell(ReportUtils.PdfCell("Solicita", FontFactory.getFont("arial", 11, Font.BOLD), Element.ALIGN_CENTER));
            table.addCell(ReportUtils.PdfCell("Responsable", FontFactory.getFont("arial", 11, Font.BOLD), Element.ALIGN_CENTER));

            for (Solicitud s : solicitudList) {

                String fechaPartida = DateUtil.showDate(s.getFechahorapartida()) + "             " + DateUtil.showHour(s.getFechahorapartida());
                String fechaRegreso = DateUtil.showDate(s.getFechahoraregreso()) + "             " + DateUtil.showHour(s.getFechahoraregreso());
                String fechaSolicitado = DateUtil.showDate(s.getFecha()) + "             " + DateUtil.showHour(s.getFecha());

                table.addCell(ReportUtils.PdfCell(s.getIdsolicitud().toString(), FontFactory.getFont("arial", 10, Font.NORMAL)));
                table.addCell(ReportUtils.PdfCell(fechaPartida, FontFactory.getFont("arial", 10, Font.NORMAL)));
                table.addCell(ReportUtils.PdfCell(fechaRegreso, FontFactory.getFont("arial", 10, Font.NORMAL)));
                table.addCell(ReportUtils.PdfCell(s.getUsuario().get(0).getNombre(), FontFactory.getFont("arial", 9, Font.NORMAL)));
                table.addCell(ReportUtils.PdfCell(s.getUsuario().get(1).getNombre(), FontFactory.getFont("arial", 9, Font.NORMAL)));

            }
            document.add(table);
        } catch (Exception ex) {
            System.out.println("Error " + ex.getMessage());
        }
        document.close();

        ReportUtils.printPDF(baos);
        return "";
    }
    // </editor-fold>  

    // <editor-fold defaultstate="collapsed" desc="Boolean availablePrint()">
    public Boolean availablePrint() {
        return !solicitudList.isEmpty();
    }
    // </editor-fold>  

    // <editor-fold defaultstate="collapsed" desc="String columnNameVistoBueno(VistoBueno vistoBueno) ">
    public String columnNameVistoBueno(VistoBueno vistoBueno) {
        return vistoBuenoServices.columnNameVistoBueno(vistoBueno);
    }
// </editor-fold>
}

Last updated