com.vaadin.client.debug.internal.DebugButton Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vaadin-client Show documentation
Show all versions of vaadin-client Show documentation
Vaadin is a web application framework for Rich Internet Applications (RIA).
Vaadin enables easy development and maintenance of fast and
secure rich web
applications with a stunning look and feel and a wide browser support.
It features a server-side architecture with the majority of the logic
running
on the server. Ajax technology is used at the browser-side to ensure a
rich
and interactive user experience.
/*
* Copyright 2000-2014 Vaadin Ltd.
*
* 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.vaadin.client.debug.internal;
import com.google.gwt.user.client.ui.Button;
/**
* Simple extension of {@link Button} that is preconfigured with for use in
* {@link VDebugWindow}. Uses icon-font for icons, and allows title to be
* specified in the constructor.
*
* @since 7.1
* @author Vaadin Ltd
*/
public class DebugButton extends Button {
protected boolean active = false;
/**
* Creates a {@link Button} with the given icon-font icon. The icon id will
* be used in the data-icon attribute of an <i> -tag.
*
* @param icon
* Identifier for the desired icon in an icon-font
*/
public DebugButton(Icon icon) {
this(icon, null, null);
}
/*-
public DebugButton(String caption) {
this(null, null, caption);
}
public DebugButton(String caption, String title) {
this(null, title, caption);
}
-*/
/**
* Creates a {@link Button} with the given icon-font icon and title
* (tooltip). The icon id will be used in the data-icon attribute of
* an <i> -tag.
*
* @param icon
* Identifier for the desired icon in an icon-font
* @param title
* Button title (tooltip)
*
*/
public DebugButton(Icon icon, String title) {
this(icon, title, null);
}
/**
* Creates a {@link Button} with the given icon-font icon, title (tooltip),
* and caption. The icon id will be used in the data-icon attribute
* of an <i> -tag.
*
* @param icon
* Identifier for the desired icon in an icon-font
* @param title
* Title (tooltip)
* @param caption
* Button baption
*/
public DebugButton(Icon icon, String title, String caption) {
super((icon != null ? icon : "") + (caption != null ? caption : ""));
if (title != null) {
setTitle(title);
}
setStylePrimaryName(VDebugWindow.STYLENAME_BUTTON);
}
/**
* Adds or removes a stylename, indicating whether or not the button is in
* it's active state.
*
* @param active
*/
public void setActive(boolean active) {
this.active = active;
setStyleDependentName(VDebugWindow.STYLENAME_ACTIVE, active);
}
/**
* Indicates wheter the Button is currently in its active state or not
*
* @return true if the Button is active, false otherwise
*/
public boolean isActive() {
return active;
}
}