/* * Smart GWT (GWT for SmartClient) * Copyright 2008 and beyond, Isomorphic Software, Inc. * * Smart GWT is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License version 3 * as published by the Free Software Foundation. Smart GWT is also * available under typical commercial license terms - see * http://smartclient.com/license * * This software 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 * Lesser General Public License for more details. */ package com.smartgwt.client.widgets.form.fields.events; import com.smartgwt.client.event.*; import com.smartgwt.client.core.*; import com.smartgwt.client.types.*; import com.smartgwt.client.data.*; import com.smartgwt.client.data.events.*; import com.smartgwt.client.rpc.*; import com.smartgwt.client.widgets.*; import com.smartgwt.client.widgets.events.*; import com.smartgwt.client.widgets.form.*; import com.smartgwt.client.widgets.form.validator.*; import com.smartgwt.client.widgets.form.fields.*; import com.smartgwt.client.widgets.tile.*; import com.smartgwt.client.widgets.tile.events.*; import com.smartgwt.client.widgets.grid.*; import com.smartgwt.client.widgets.grid.events.*; import com.smartgwt.client.widgets.chart.*; import com.smartgwt.client.widgets.layout.*; import com.smartgwt.client.widgets.layout.events.*; import com.smartgwt.client.widgets.menu.*; import com.smartgwt.client.widgets.tab.*; import com.smartgwt.client.widgets.toolbar.*; import com.smartgwt.client.widgets.tree.*; import com.smartgwt.client.widgets.tree.events.*; import com.smartgwt.client.widgets.viewer.*; import com.smartgwt.client.widgets.calendar.*; import com.smartgwt.client.widgets.calendar.events.*; import com.smartgwt.client.widgets.cube.*; import java.util.Date; import java.util.List; import java.util.Map; import java.util.HashMap; import com.google.gwt.user.client.ui.Widget; import com.google.gwt.core.client.JavaScriptObject; import com.google.gwt.user.client.Element; import com.smartgwt.client.util.*; import com.google.gwt.event.shared.*; import com.google.gwt.event.shared.HasHandlers; public class KeyPressEvent extends AbstractSmartEvent<KeyPressHandler> implements Cancellable { private boolean cancel = false; /** * Handler type. */ private static Type<KeyPressHandler> TYPE; /** * Fires a open event on all registered handlers in the handler manager.If no * such handlers exist, this method will do nothing. * * @param <S> The event source * @param source the source of the handlers * @param jsObj the native event */ public static <S extends HasKeyPressHandlers & HasHandlers> void fire( S source, JavaScriptObject jsObj) { if (TYPE != null) { KeyPressEvent event = new KeyPressEvent(jsObj); source.fireEvent(event); } } /** * Gets the type associated with this event. * * @return returns the handler type */ public static Type<KeyPressHandler> getType() { if (TYPE == null) { TYPE = new Type<KeyPressHandler>(); } return TYPE; } @Override protected void dispatch(KeyPressHandler handler) { handler.onKeyPress(this); } // Because of type erasure, our static type is // wild carded, yet the "real" type should use our I param. @SuppressWarnings("unchecked") @Override public final Type<KeyPressHandler> getAssociatedType() { return TYPE; } public KeyPressEvent(JavaScriptObject jsObj) { super(jsObj); } /** * Call this method to attempt to cancel the event. Note for general purpose APIs for managing whether user * input is allowed, use {@link com.smartgwt.client.widgets.form.fields.FormItem#addChangeHandler FormItem.change} * or {@link com.smartgwt.client.widgets.form.fields.FormItem#setInputTransformer FormItem.transformInput} instead. */ public void cancel() { cancel = true; } /** * @return true if cancelled */ public boolean isCancelled() { return cancel; } /** * Item over which the keypress occurred * * @return Item over which the keypress occurred */ public native FormItem getItem() /*-{ var jsObj = this.@com.smartgwt.client.event.AbstractSmartEvent::jsObj; return @com.smartgwt.client.widgets.form.fields.FormItem::getOrCreateRef(Lcom/google/gwt/core/client/JavaScriptObject;)(jsObj.item); }-*/; /** * Pointer to the item's form * * @return Pointer to the item's form */ public native DynamicForm getForm() /*-{ var jsObj = this.@com.smartgwt.client.event.AbstractSmartEvent::jsObj; return @com.smartgwt.client.widgets.form.DynamicForm::getOrCreateRef(Lcom/google/gwt/core/client/JavaScriptObject;)(jsObj.form); }-*/; /** * Name of the key pressed (Example: <code>"A"</code>, <code>"Enter"</code>) * * @return Name of the key pressed (Example: <code>"A"</code>, <code>"Enter"</code>) */ public native String getKeyName() /*-{ var jsObj = this.@com.smartgwt.client.event.AbstractSmartEvent::jsObj; return jsObj.keyName; }-*/; /** * If this was a character key, this is the numeric value for the character * * @return If this was a character key, this is the numeric value for the character. Note that * non-character keys like shift, alt, backspace return null */ public native Integer getCharacterValue() /*-{ var jsObj = this.@com.smartgwt.client.event.AbstractSmartEvent::jsObj; var ret = jsObj.characterValue; return (ret === undefined || ret == null) ? null : @com.smartgwt.client.util.JSOHelper::toInteger(I)(ret); }-*/; }