/* * To change this template, choose Tools | Templates * and open the template in the editor. */ package org.inbio.ara.germplasm; import com.sun.rave.web.ui.appbase.AbstractPageBean; import com.sun.webui.jsf.model.Option; import com.sun.webui.jsf.model.SingleSelectOptionsList; import java.util.ArrayList; import java.util.List; import java.util.Locale; import javax.faces.FacesException; import org.inbio.ara.AraSessionBean; import org.inbio.ara.admin.SelectionListSessionBean; import org.inbio.ara.admin.PersonSessionBean; import org.inbio.ara.dto.germplasm.BreedDTO; import org.inbio.ara.dto.inventory.TaxonDTO; import org.inbio.ara.persistence.taxonomy.TaxonomicalRangeEntity; import org.inbio.ara.util.BundleHelper; 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 NewBreed.java * @version Created on 08/04/2010, 09:27:09 AM * @author dasolano */ public class NewBreed 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> private SingleSelectOptionsList scientificName = new SingleSelectOptionsList(); /** * <p>Construct a new Page bean instance.</p> */ public NewBreed() { } /** * <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("NewBreed 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() { scientificName.setOptions(updateTaxonListAction()); } /** * <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() { } /** * Set the taxon list for germplasm * @param taxonList * @return */ private Option[] setTaxonListOptions(List<TaxonDTO> taxonList) { Option[] allOptionsInArray = null; Option option = null; ArrayList<Option> allOptions = new ArrayList<Option>(); option = new Option(null," -- "+BundleHelper.getDefaultBundleValue("drop_down_default",getMyLocale())+" --"); allOptions.add(option); if(taxonList != null) { for (TaxonDTO taxon : taxonList) { //System.out.println(taxon.getDefaultName()); option = new Option(taxon.getTaxonKey(), taxon.getDefaultName()); allOptions.add(option); } } allOptionsInArray = new Option[allOptions.size()]; return allOptions.toArray(allOptionsInArray); } /** * Update the taxon drop down * @return */ public Option[] updateTaxonListAction() { List<TaxonDTO> taxonList = getgermplasm$BreedSessionBean(). getGermplasmFacadeRemote(). getAllTaxonsByAnimaliaKingdomAndTaxonomicalRangeId(TaxonomicalRangeEntity.SPECIES.getId()); return this.setTaxonListOptions(taxonList); } /** * Performed the create breed action * @return */ public String saveBreed() { try { getgermplasm$BreedSessionBean().getBreedDTO().setUserName( getAraSessionBean().getGlobalUserName()); getgermplasm$BreedSessionBean().getGermplasmFacadeRemote().saveBreed( getgermplasm$BreedSessionBean().getBreedDTO()); getgermplasm$BreedSessionBean().getPagination().refreshList(); getgermplasm$BreedSessionBean().setBreedDTO(new BreedDTO()); MessageBean.setSuccessMessageFromBundle("create_breed_success", this.getMyLocale()); } catch(Exception e) { MessageBean.setErrorMessageFromBundle("error", this.getMyLocale()); } return null; } /** * @return the myLocale */ public Locale getMyLocale() { return this.getAraSessionBean().getCurrentLocale(); } /** * <p>Return a reference to the scoped data bean.</p> * * @return reference to the scoped data bean */ protected AraSessionBean getAraSessionBean() { return (AraSessionBean) getBean("AraSessionBean"); } /** * <p>Return a reference to the scoped data bean.</p> * * @return reference to the scoped data bean */ protected AccessionSessionBean getgermplasm$AccessionSessionBean() { return (AccessionSessionBean) getBean("germplasm$AccessionSessionBean"); } /** * <p>Return a reference to the scoped data bean.</p> * * @return reference to the scoped data bean */ protected SelectionListSessionBean getadmin$SelectionListSessionBean() { return (SelectionListSessionBean) getBean("admin$SelectionListSessionBean"); } /** * <p>Return a reference to the scoped data bean.</p> * * @return reference to the scoped data bean */ protected PersonSessionBean getadmin$PersonSessionBean() { return (PersonSessionBean) getBean("admin$PersonSessionBean"); } /** * <p>Return a reference to the scoped data bean.</p> * * @return reference to the scoped data bean */ protected BreedSessionBean getgermplasm$BreedSessionBean() { return (BreedSessionBean) getBean("germplasm$BreedSessionBean"); } /** * @return the scientificName */ public SingleSelectOptionsList getScientificName() { return scientificName; } /** * @param scientificName the scientificName to set */ public void setScientificName(SingleSelectOptionsList scientificName) { this.scientificName = scientificName; } }