/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common
* Development and Distribution License("CDDL") (collectively, the
* "License"). You may not use this file except in compliance with the
* License. You can obtain a copy of the License at
* http://www.netbeans.org/cddl-gplv2.html
* or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
* specific language governing permissions and limitations under the
* License. When distributing the software, include this License Header
* Notice in each file and include the License file at
* nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
* particular file as subject to the "Classpath" exception as provided
* by Sun in the GPL Version 2 section of the License file that
* accompanied this code. If applicable, add the following below the
* License Header, with the fields enclosed by brackets [] replaced by
* your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
*
* Contributor(s):
*
* The Original Software is NetBeans. The Initial Developer of the Original
* Software is Sun Microsystems, Inc. Portions Copyright 1997-2007 Sun
* Microsystems, Inc. All Rights Reserved.
*
* If you wish your version of this file to be governed by only the CDDL
* or only the GPL Version 2, indicate your decision by adding
* "[Contributor] elects to include this software in this distribution
* under the [CDDL or GPL Version 2] license." If you do not indicate a
* single choice of license, a recipient has the option to distribute
* your version of this file under either the CDDL, the GPL Version 2 or
* to extend the choice of license to its licensees as provided above.
* However, if you add GPL Version 2 code and therefore, elected the GPL
* Version 2 license, then the option applies only if the new code is
* made subject to such option by the copyright holder.
*/
package twopagecrudtable;
import com.sun.data.provider.RowKey;
import com.sun.data.provider.impl.CachedRowSetDataProvider;
import com.sun.rave.web.ui.appbase.AbstractPageBean;
import com.sun.webui.jsf.component.Body;
import com.sun.webui.jsf.component.Button;
import com.sun.webui.jsf.component.Calendar;
import com.sun.webui.jsf.component.DropDown;
import com.sun.webui.jsf.component.Form;
import com.sun.webui.jsf.component.Head;
import com.sun.webui.jsf.component.Html;
import com.sun.webui.jsf.component.Label;
import com.sun.webui.jsf.component.Link;
import com.sun.webui.jsf.component.MessageGroup;
import com.sun.webui.jsf.component.Page;
import com.sun.webui.jsf.component.TextField;
import javax.faces.FacesException;
import javax.faces.application.FacesMessage;
import javax.faces.component.UIComponent;
import javax.faces.component.UIInput;
import javax.faces.component.html.HtmlPanelGrid;
import javax.faces.context.FacesContext;
import javax.faces.event.ValueChangeEvent;
import javax.faces.validator.ValidatorException;
/**
* <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>
*/
public class UpdatePage extends AbstractPageBean {
// <editor-fold defaultstate="collapsed" desc="Managed Component Definition">
private int __placeholder;
/**
* <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 {
tripDataProvider.setCachedRowSet((javax.sql.rowset.CachedRowSet) getValue("#{SessionBean1.tripRowSet}"));
}
private Page page1 = new Page();
public Page getPage1() {
return page1;
}
public void setPage1(Page p) {
this.page1 = p;
}
private Html html1 = new Html();
public Html getHtml1() {
return html1;
}
public void setHtml1(Html h) {
this.html1 = h;
}
private Head head1 = new Head();
public Head getHead1() {
return head1;
}
public void setHead1(Head h) {
this.head1 = h;
}
private Link link1 = new Link();
public Link getLink1() {
return link1;
}
public void setLink1(Link l) {
this.link1 = l;
}
private Body body1 = new Body();
public Body getBody1() {
return body1;
}
public void setBody1(Body b) {
this.body1 = b;
}
private Form form1 = new Form();
public Form getForm1() {
return form1;
}
public void setForm1(Form f) {
this.form1 = f;
}
private HtmlPanelGrid mainPanel = new HtmlPanelGrid();
public HtmlPanelGrid getMainPanel() {
return mainPanel;
}
public void setMainPanel(HtmlPanelGrid hpg) {
this.mainPanel = hpg;
}
private HtmlPanelGrid tripPanel = new HtmlPanelGrid();
public HtmlPanelGrid getTripPanel() {
return tripPanel;
}
public void setTripPanel(HtmlPanelGrid hpg) {
this.tripPanel = hpg;
}
private Label label1 = new Label();
public Label getLabel1() {
return label1;
}
public void setLabel1(Label l) {
this.label1 = l;
}
private Calendar dateCalendar = new Calendar();
public Calendar getDateCalendar() {
return dateCalendar;
}
public void setDateCalendar(Calendar c) {
this.dateCalendar = c;
}
private Label label2 = new Label();
public Label getLabel2() {
return label2;
}
public void setLabel2(Label l) {
this.label2 = l;
}
private TextField fromCity = new TextField();
public TextField getFromCity() {
return fromCity;
}
public void setFromCity(TextField tf) {
this.fromCity = tf;
}
private Label label3 = new Label();
public Label getLabel3() {
return label3;
}
public void setLabel3(Label l) {
this.label3 = l;
}
private TextField toCity = new TextField();
public TextField getToCity() {
return toCity;
}
public void setToCity(TextField tf) {
this.toCity = tf;
}
private Label label4 = new Label();
public Label getLabel4() {
return label4;
}
public void setLabel4(Label l) {
this.label4 = l;
}
private DropDown tripType = new DropDown();
public DropDown getTripType() {
return tripType;
}
public void setTripType(DropDown dd) {
this.tripType = dd;
}
private HtmlPanelGrid buttonPanel = new HtmlPanelGrid();
public HtmlPanelGrid getButtonPanel() {
return buttonPanel;
}
public void setButtonPanel(HtmlPanelGrid hpg) {
this.buttonPanel = hpg;
}
private Button updateButton = new Button();
public Button getUpdateButton() {
return updateButton;
}
public void setUpdateButton(Button b) {
this.updateButton = b;
}
private Button cancel = new Button();
public Button getCancel() {
return cancel;
}
public void setCancel(Button b) {
this.cancel = b;
}
private MessageGroup messageGroup = new MessageGroup();
public MessageGroup getMessageGroup() {
return messageGroup;
}
public void setMessageGroup(MessageGroup mg) {
this.messageGroup = mg;
}
private CachedRowSetDataProvider tripDataProvider = new CachedRowSetDataProvider();
public CachedRowSetDataProvider getTripDataProvider() {
return tripDataProvider;
}
public void setTripDataProvider(CachedRowSetDataProvider crsdp) {
this.tripDataProvider = crsdp;
}
// </editor-fold>
/**
* <p>Construct a new Page bean instance.</p>
*/
public UpdatePage() {
}
/**
* <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("UpdatePage 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
Integer tid = (Integer) getSessionBean1().getCurrentTripId();
RowKey tripRowKey = tripDataProvider.findFirst("TRIP.TRIPID", tid);
tripDataProvider.setCursorRow(tripRowKey);
}
/**
* <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() {
// bind trip detail fields
java.sql.Date date = (java.sql.Date) tripDataProvider.getValue("TRIP.DEPDATE");
dateCalendar.setValue(date);
}
/**
* <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() {
tripDataProvider.close();
}
/**
* <p>Return a reference to the scoped data bean.</p>
*/
protected RequestBean1 getRequestBean1() {
return (RequestBean1) getBean("RequestBean1");
}
/**
* <p>Return a reference to the scoped data bean.</p>
*/
protected SessionBean1 getSessionBean1() {
return (SessionBean1) getBean("SessionBean1");
}
/**
* <p>Return a reference to the scoped data bean.</p>
*/
protected ApplicationBean1 getApplicationBean1() {
return (ApplicationBean1) getBean("ApplicationBean1");
}
public String updateButton_action() {
// TODO: Process the action. Return value is a navigation
// case name where null will return to the same page.
try {
java.util.Date uDate = (java.util.Date) dateCalendar.getValue();
if ( uDate != null ) {
java.sql.Date date = new java.sql.Date( uDate.getTime() );
tripDataProvider.setValue("TRIP.DEPDATE", date);
}
tripDataProvider.commitChanges();
} catch (Exception e) {
error("Cannot commit changes -- " + e);
log("Exception: " + e);
}
return "updated";
}
public String cancel_action() {
// TODO: Process the action. Return value is a navigation
// case name where null will return to the same page.
return "noUpdate";
}
public void tripType_processValueChange(ValueChangeEvent event) {
// TODO: Replace with your code
tripDataProvider.setValue("TRIP.TRIPTYPEID", tripType.getValue());
}
// Fix for 118985
private void multipleValidate(UIComponent component, Object value) {
String theCity = (String) value;
if ( theCity.length() > 32 ) {
((UIInput) component).setValid(false);
throw new ValidatorException(new FacesMessage("Error: City name must be less than 32 characters"));
}
for (int i = 0; i < theCity.length(); i++) {
if (Character.isDigit(theCity.charAt(i)) ) {
((UIInput) component).setValid(false);
throw new ValidatorException(new FacesMessage("Error: City name must contain no digits"));
}
}
}
public void fromCity_validate(FacesContext context, UIComponent component, Object value) {
multipleValidate(component, value);
}
public void toCity_validate(FacesContext context, UIComponent component, Object value) {
multipleValidate(component, value);
}
}
|