/* Ara - capture species and specimen data * * Copyright (C) 2009 INBio (Instituto Nacional de Biodiversidad) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.inbio.ara.admin; import com.sun.rave.web.ui.appbase.AbstractPageBean; import java.util.ArrayList; import java.util.Locale; import javax.faces.FacesException; import javax.faces.component.html.HtmlCommandButton; import javax.faces.component.html.HtmlDataTable; import javax.faces.component.html.HtmlInputText; import javax.faces.component.html.HtmlPanelGrid; import javax.faces.context.FacesContext; import org.inbio.ara.AraSessionBean; import org.inbio.ara.dto.inventory.PersonDTO; import org.inbio.ara.util.AddRemoveList; import org.inbio.ara.util.MessageBean; /** * <p>Page bean that corresponds to a similarly named JSP page. This * class contains component definitions (and initialization code) for * all components that you have defined on this page, as well as * lifecycle methods and event handlers where you may add behavior * to respond to incoming events.</p> * * @version ListPerson.java * @version Created on 06/10/2009, 02:34:27 PM * @author esmata */ public class ListPerson extends AbstractPageBean { // <editor-fold defaultstate="collapsed" desc="Managed Component Definition"> /** * <p>Automatically managed component initialization. <strong>WARNING:</strong> * This method is automatically generated, so any user-specified code inserted * here is subject to being replaced.</p> */ private void _init() throws Exception { } // </editor-fold> //Contexto utilizado para obtener el current locale private FacesContext context; private Locale myLocale; //Binding de la tabla private HtmlDataTable PersonTable = new HtmlDataTable(); //Variable que contiene los datos de la paginacion para ser mostrados en la tabla private String quantityTotal = new String(); //Variable que contiene los datos de la pagina private HtmlPanelGrid alertMessage = new HtmlPanelGrid(); private HtmlPanelGrid mainPanel = new HtmlPanelGrid(); private HtmlCommandButton btnSimpleSearch = new HtmlCommandButton(); //Boton busqueda simple private HtmlInputText txSimpleSearch = new HtmlInputText(); //Input text de busqueda simple /** * <p>Construct a new Page bean instance.</p> */ public ListPerson() { } /** * <p>Callback method that is called whenever a page is navigated to, * either directly via a URL, or indirectly via page navigation. * Customize this method to acquire resources that will be needed * for event handlers and lifecycle methods, whether or not this * page is performing post back processing.</p> * * <p>Note that, if the current request is a postback, the property * values of the components do <strong>not</strong> represent any * values submitted with this request. Instead, they represent the * property values that were saved for this view when it was rendered.</p> */ @Override public void init() { // Perform initializations inherited from our superclass super.init(); // Perform application initialization that must complete // *before* managed components are initialized // TODO - add your own initialiation code here // <editor-fold defaultstate="collapsed" desc="Managed Component Initialization"> // Initialize automatically managed components // *Note* - this logic should NOT be modified try { _init(); } catch (Exception e) { log("ListPerson Initialization Failure", e); throw e instanceof FacesException ? (FacesException) e: new FacesException(e); } // </editor-fold> // Perform application initialization that must complete // *after* managed components are initialized // TODO - add your own initialization code here } /** * <p>Callback method that is called after the component tree has been * restored, but before any event processing takes place. This method * will <strong>only</strong> be called on a postback request that * is processing a form submit. Customize this method to allocate * resources that will be required in your event handlers.</p> */ @Override public void preprocess() { } /** * <p>Callback method that is called just before rendering takes place. * This method will <strong>only</strong> be called for the page that * will actually be rendered (and not, for example, on a page that * handled a postback and then navigated to a different page). Customize * this method to allocate resources that will be required for rendering * this page.</p> */ @Override public void prerender() { PersonSessionBean psb = this.getPersonSessionBean(); //Inicializar el dataprovider la primera vez (si la paginaciĆ³n es nula) if (psb.getPagination()==null) { psb.initDataProvider(); } //Actualizar los datos del paginador else psb.getPagination().refreshList(); } /** * <p>Callback method that is called after rendering is completed for * this request, if <code>init()</code> was called (regardless of whether * or not this was the page that was actually rendered). Customize this * method to release resources acquired in the <code>init()</code>, * <code>preprocess()</code>, or <code>prerender()</code> methods (or * acquired during execution of an event handler).</p> */ @Override public void destroy() { } /** * Metodo ejecutado por el boton para crear una nueva persona * @return */ public String btnPersonNew(){ //Limpiar el current DTO this.getPersonSessionBean().setCurrentPerson(new PersonDTO()); //Setear con una nueva instancia los AddRemove components this.getPersonSessionBean().setArProfilesNew(new AddRemoveList()); this.getPersonSessionBean().setArInstitutionesNew(new AddRemoveList()); return "new"; } /** * Metodo ejecutado por el boton para editar persona * @return */ public String btnPersonEdit(){ int n = this.getPersonTable().getRowCount(); ArrayList<PersonDTO> selectedPersons = new ArrayList(); for (int i = 0; i < n; i++) { //Obtener elementos seleccionados this.getPersonTable().setRowIndex(i); PersonDTO aux = (PersonDTO) this.getPersonTable().getRowData(); if (aux.isSelected()) { selectedPersons.add(aux); } } if(selectedPersons == null || selectedPersons.size() == 0){ //En caso de que no se seleccione ningun elemento MessageBean.setErrorMessageFromBundle("not_selected", this.getMyLocale()); return null; } else if(selectedPersons.size() == 1){ //En caso de que solo se seleccione un elemento this.getPersonSessionBean().setCurrentPerson(selectedPersons.get(0)); //Seteo los addremove this.getPersonSessionBean().setArInstitutionesEdit(new AddRemoveList()); this.getPersonSessionBean().setArProfilesEdit(new AddRemoveList()); //Le indico al prerender del edit que solo cargue una ves los selected de addremove this.getPersonSessionBean().setFirstTime(true); return "edit"; } else{ //En caso de que sea seleccion multiple MessageBean.setErrorMessageFromBundle("not_yet", this.getMyLocale()); return null; } } /** * Metodo ejecutado por el boton para eliminar una persona * @return */ public String btnPersonDelete(){ int n = this.getPersonTable().getRowCount(); ArrayList<PersonDTO> selectedPersons = new ArrayList(); for (int i = 0; i < n; i++) { //Obtener elementos seleccionados this.getPersonTable().setRowIndex(i); PersonDTO aux = (PersonDTO) this.getPersonTable().getRowData(); if (aux.isSelected()) { selectedPersons.add(aux); } } if(selectedPersons == null || selectedPersons.size() == 0){ //En caso de que no se seleccione ningun elemento MessageBean.setErrorMessageFromBundle("not_selected", this.getMyLocale()); return null; } else if(selectedPersons.size() == 1){ //En caso de que solo se seleccione un elemento PersonDTO selected = selectedPersons.get(0); //Mandar a borrar la audiencia try{ this.getPersonSessionBean().deletePerson(selected.getPersonKey()); } catch(Exception e){ MessageBean.setErrorMessageFromBundle("imposible_to_delete", this.getMyLocale()); return null; } //Refrescar la lista de personas PersonSessionBean psb = this.getPersonSessionBean(); psb.getPagination().refreshList(); //Notificar al usuario MessageBean.setSuccessMessageFromBundle("delete_success", this.getMyLocale()); return null; } else{ //En caso de que sea seleccion multiple MessageBean.setErrorMessageFromBundle("not_yet", this.getMyLocale()); return null; } } /** * Performed the simple search * @return */ public String btnSimpleSearch_action() { String userInput = ""; System.out.println(" Paginacion al inicio "+this.getPersonSessionBean().getPagination()); if(this.getTxSimpleSearch().getValue()!= null) userInput = this.getTxSimpleSearch().getValue().toString(); userInput = userInput.trim(); if(userInput.length()==0){ //Se desabilitan las banderas de busqueda simple y avanzada this.getPersonSessionBean().setQueryModeSimple(false); } else{ //Setear el string para consulta simple del SessionBean this.getPersonSessionBean().setConsultaSimple(userInput); //Indicarle al SessionBean que el paginador debe "trabajar" en modo busqueda simple this.getPersonSessionBean().setQueryModeSimple(true); } //Set the first result of the query System.out.println(" Paginacion al final "+this.getPersonSessionBean().getPagination()); this.getPersonSessionBean().getPagination().firstResults(); return null; } /** * <p>Return a reference to the scoped data bean.</p> * * @return reference to the scoped data bean */ protected PersonSessionBean getPersonSessionBean() { return (PersonSessionBean) getBean("admin$PersonSessionBean"); } /** * <p>Return a reference to the scoped data bean.</p> * * @return reference to the scoped data bean */ protected AraSessionBean getAraSessionBean() { return (AraSessionBean) getBean("AraSessionBean"); } /** * @return the PersonTable */ public HtmlDataTable getPersonTable() { return PersonTable; } /** * @param PersonTable the PersonTable to set */ public void setPersonTable(HtmlDataTable PersonTable) { this.PersonTable = PersonTable; } /** * @return the quantityTotal */ public String getQuantityTotal() { quantityTotal = this.getPersonSessionBean().getQuantityTotal(); return quantityTotal; } /** * @param quantityTotal the quantityTotal to set */ public void setQuantityTotal(String quantityTotal) { this.quantityTotal = quantityTotal; } /** * @return the myLocale */ public Locale getMyLocale() { return this.getAraSessionBean().getCurrentLocale(); } /** * @return the alertMessage */ public HtmlPanelGrid getAlertMessage() { return alertMessage; } /** * @param alertMessage the alertMessage to set */ public void setAlertMessage(HtmlPanelGrid alertMessage) { this.alertMessage = alertMessage; } /** * @return the mainPanel */ public HtmlPanelGrid getMainPanel() { return mainPanel; } /** * @param mainPanel the mainPanel to set */ public void setMainPanel(HtmlPanelGrid mainPanel) { this.mainPanel = mainPanel; } /** * @return the btnSimpleSearch */ public HtmlCommandButton getBtnSimpleSearch() { return btnSimpleSearch; } /** * @param btnSimpleSearch the btnSimpleSearch to set */ public void setBtnSimpleSearch(HtmlCommandButton btnSimpleSearch) { this.btnSimpleSearch = btnSimpleSearch; } /** * @return the txSimpleSearch */ public HtmlInputText getTxSimpleSearch() { return txSimpleSearch; } /** * @param txSimpleSearch the txSimpleSearch to set */ public void setTxSimpleSearch(HtmlInputText txSimpleSearch) { this.txSimpleSearch = txSimpleSearch; } }