com.github.gwtbootstrap.client.ui.Button Maven / Gradle / Ivy
/*
* Copyright 2012 GWT-Bootstrap
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.github.gwtbootstrap.client.ui;
import com.github.gwtbootstrap.client.ui.base.*;
import com.github.gwtbootstrap.client.ui.constants.ButtonType;
import com.github.gwtbootstrap.client.ui.constants.Constants;
import com.github.gwtbootstrap.client.ui.constants.DismissType;
import com.github.gwtbootstrap.client.ui.constants.IconType;
import com.github.gwtbootstrap.client.ui.resources.ButtonSize;
import com.google.gwt.dom.client.Document;
import com.google.gwt.dom.client.Element;
import com.google.gwt.dom.client.NativeEvent;
import com.google.gwt.event.dom.client.*;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.user.client.ui.HasEnabled;
//@formatter:off
/**
* Button with optional icon.
*
*
*
UiBinder Usage:
*
*
* {@code Delete }
*
*
* All arguments are optional.
*
*
* @since 2.0.4.0
*
* @author Carlos Alexandro Becker
* @author Dominik Mayer
* @author Sven Jacobs
*
* @see Bootstrap
* documentation
* @see ButtonGroup
* @see ButtonToolbar
* @see DropdownButton
* @see SplitDropdownButton
* @see NavbarButton
*/
// @formatter:on
public class Button extends IconAnchor implements HasClickHandlers,
HasDoubleClickHandlers, HasEnabled, HasType,
HasAllDragAndDropHandlers, HasAllFocusHandlers, HasAllGestureHandlers,
HasAllKeyHandlers, HasAllMouseHandlers, HasAllTouchHandlers {
private final LoadingStateBehavior state = new LoadingStateBehavior();
private ButtonType type;
private ButtonSize size;
/**
* Creates an empty Button.
*/
public Button() {
super();
addStyleName(Constants.BTN);
}
/**
* Creates an Button with ClickHandler
* @param handler Butotn ClickHandler
*/
public Button(ClickHandler handler) {
this();
addClickHandler(handler);
}
/**
* Creates a Button with the given caption.
*
* @param caption
* the caption of the Button
*/
public Button(String caption) {
this();
setText(caption);
}
/**
* Create Button with click handler.
* @param caption the caption of the Button
* @param handler Button Click Handler
*/
public Button(String caption, ClickHandler handler) {
this(caption);
addClickHandler(handler);
}
/**
* Creates a Button with the given caption and icon.
*
* @param caption
* the caption of the Button
* @param icon
* the Icon on the caption's left
*/
public Button(String caption, IconType icon) {
this(caption);
setIcon(icon);
}
/**
* Creates a Button with the given caption and icon and ClickHandler.
*
* @param caption
* the caption of the Button
* @param icon
* the Icon on the caption's left
* @param handler
* the ClickHandler of the Button.
*/
public Button(String caption, IconType icon, ClickHandler handler) {
this(caption, icon);
addClickHandler(handler);
}
/**
* Sets the type of the Button.
*
* Different types give the button a different look.
*
* @param type
* the type of the Button.
*/
public void setType(ButtonType type) {
this.type = type;
StyleHelper.changeStyle(this, type, ButtonType.class);
}
/**
* Sets the size of the Button.
*
* @param size
* the size of the Button.
*/
public void setSize(ButtonSize size) {
this.size = size;
StyleHelper.changeStyle(this, size, ButtonSize.class);
}
/**
* Whether the Button is enabled or disabled.
*
* A disabled widget cannot be used.
*
* @return false
if the Button is disabled.
*/
public boolean isEnabled() {
return !getStyleName().contains(Constants.DISABLED);
}
/**
* Sets whether the Button is enabled or disabled.
*
* A disabled widget cannot be used.
*
* @param enabled
* false
if the Button should be disabled. Default:
* true
*/
public void setEnabled(boolean enabled) {
if (enabled)
removeStyleName(Constants.DISABLED);
else
addStyleName(Constants.DISABLED);
}
/**
* Enable ou disable the data-toggle behavior.
*
* @param toggle
* true
will enable this behavior.
* false
will disable it or do nothing if it never
* was enabled.
*/
public void setToggle(boolean toggle) {
if (toggle)
getElement().setAttribute(Constants.DATA_TOGGLE, "button");
else
getElement().removeAttribute(Constants.DATA_TOGGLE);
}
/**
* Verify if the property "toggle" is set.
*
* @return true: if the data-toggle is equal 'button'
* false: otherwise
*/
public boolean isToggle() {
return getElement().getAttribute(Constants.DATA_TOGGLE).equals("button");
}
/**
* Verify if the button is toggled.
* @return true: if yes (it will contain the "active" styleclass
* false: otherwise.
*/
public boolean isToggled() {
return getStyleName().toLowerCase().contains("active");
}
/**
* Set a Loading Text to show when some action are in work with this button.
*
* @see LoadingStateBehavior
* @param text
*/
public void setLoadingText(String text) {
if (text == null || text.trim().isEmpty()) {
getElement().removeAttribute(Constants.DATA_LOADING_TEXT);
return;
}
getElement().setAttribute(Constants.DATA_LOADING_TEXT, text);
}
/**
* Set a Loading Text to show when some action are completed with this
* button.
*
* @see LoadingStateBehavior
* @param text
*/
public void setCompleteText(String text) {
if (text == null || text.trim().isEmpty()) {
getElement().removeAttribute(Constants.DATA_COMPLETE_TEXT);
return;
}
getElement().setAttribute(Constants.DATA_COMPLETE_TEXT, text);
}
/**
* A simple DSL to change the button state to loading, complete, or reset
* it.
*
* @return
*/
public LoadingStateBehavior state() {
return state;
}
/**
* A simple class to encapsulate the button state managing from the user.
*
* @author Carlos Alexandro Becker
*/
public class LoadingStateBehavior {
/**
* put the button in the loading state.
*/
public void loading() {
setLoadingBehavior("loading");
}
/**
* reset the button state.
*/
public void reset() {
setLoadingBehavior("reset");
}
/**
* put the button in the completed state.
*/
public void complete() {
setLoadingBehavior("complete");
}
private void setLoadingBehavior(String behavior) {
// Remove icon because it will be removed by Bootstrap's "$(element).button(behavior)" anyway
icon.removeFromParent();
setLoadingBehavior(getElement(), behavior);
// Recreate icon and add it to inner content with setText()
icon = new Icon(icon.getIconType());
setText(getElement().getInnerText());
}
private native void setLoadingBehavior(Element e, String behavior) /*-{
$wnd.jQuery(e).button(behavior);
}-*/;
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addClickHandler(ClickHandler handler) {
return addDomHandler(handler, ClickEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addDoubleClickHandler(DoubleClickHandler handler) {
return addDomHandler(handler, DoubleClickEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addDragEndHandler(DragEndHandler handler) {
return addDomHandler(handler, DragEndEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addDragEnterHandler(DragEnterHandler handler) {
return addDomHandler(handler, DragEnterEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addDragLeaveHandler(DragLeaveHandler handler) {
return addDomHandler(handler, DragLeaveEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addDragHandler(DragHandler handler) {
return addDomHandler(handler, DragEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addDragOverHandler(DragOverHandler handler) {
return addDomHandler(handler, DragOverEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addDragStartHandler(DragStartHandler handler) {
return addDomHandler(handler, DragStartEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addDropHandler(DropHandler handler) {
return addDomHandler(handler, DropEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addFocusHandler(FocusHandler handler) {
return addDomHandler(handler, FocusEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addBlurHandler(BlurHandler handler) {
return addDomHandler(handler, BlurEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addGestureStartHandler(
GestureStartHandler handler) {
return addDomHandler(handler, GestureStartEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addGestureChangeHandler(
GestureChangeHandler handler) {
return addDomHandler(handler, GestureChangeEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addGestureEndHandler(GestureEndHandler handler) {
return addDomHandler(handler, GestureEndEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addKeyUpHandler(KeyUpHandler handler) {
return addDomHandler(handler, KeyUpEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addKeyDownHandler(KeyDownHandler handler) {
return addDomHandler(handler, KeyDownEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addKeyPressHandler(KeyPressHandler handler) {
return addDomHandler(handler, KeyPressEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addMouseDownHandler(MouseDownHandler handler) {
return addDomHandler(handler, MouseDownEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addMouseUpHandler(MouseUpHandler handler) {
return addDomHandler(handler, MouseUpEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addMouseOutHandler(MouseOutHandler handler) {
return addDomHandler(handler, MouseOutEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addMouseOverHandler(MouseOverHandler handler) {
return addDomHandler(handler, MouseOverEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addMouseMoveHandler(MouseMoveHandler handler) {
return addDomHandler(handler, MouseMoveEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addMouseWheelHandler(MouseWheelHandler handler) {
return addDomHandler(handler, MouseWheelEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addTouchStartHandler(TouchStartHandler handler) {
return addDomHandler(handler, TouchStartEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addTouchMoveHandler(TouchMoveHandler handler) {
return addDomHandler(handler, TouchMoveEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addTouchEndHandler(TouchEndHandler handler) {
return addDomHandler(handler, TouchEndEvent.getType());
}
/**
* {@inheritDoc}
*/
public HandlerRegistration addTouchCancelHandler(TouchCancelHandler handler) {
return addDomHandler(handler, TouchCancelEvent.getType());
}
/**
* Get Button Type
* @return Current Button Type
*/
public ButtonType getType() {
return type;
}
/**
* Get Button Size
* @return Current Button Size
*/
public ButtonSize getSize() {
return size;
}
/**
* Set element as a Block Level Button
* @param block true:Block Level false:Default
*/
public void setBlock(boolean block) {
setStyleName(Constants.BTN_BLOCK, block);
}
/**
* Programmatic equivalent of the user clicking the button.
*/
public void click() {
NativeEvent event = Document.get().createClickEvent(0, 0, 0, 0, 0, false, false, false, false);
DomEvent.fireNativeEvent(event, this);
}
/**
* Buttons can act as a dismiss button when inside a {@link Modal} or {@link Alert}.
*
* UiBinder example:
*
* <b:Modal>
* <b:ModalFooter>
* <b:Button text="Close" dismiss="MODAL"/>
* </b:ModalFooter>
* </b:Modal>
*
*
* See Bootstrap documentation.
*
* @param type Type of dismiss ("modal" or "alert")
* @since 2.3.2.0
*/
public void setDismiss(final DismissType type) {
getElement().setAttribute(Constants.DATA_DISMISS, type.get());
}
}