de.jwic.controls.Button Maven / Gradle / Ivy
/*******************************************************************************
* Copyright 2015 xWic group (http://www.xwic.de)
*
* 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.
*
*******************************************************************************/
/*
* de.jwic.controls.ButtonControl
* $Id: Button.java,v 1.3 2011/09/09 15:09:01 adrianionescu12 Exp $
*/
package de.jwic.controls;
import de.jwic.base.IControlContainer;
import de.jwic.base.ImageRef;
import de.jwic.base.IncludeJsOption;
import de.jwic.base.JavaScriptSupport;
import de.jwic.controls.menu.Menu;
/**
* Represents the <button> html element. A button displays text and/or
* an image.
*
* The button is using the jQuery UI button element for representation by default. It is
* however possible, to switch back to the old jWic 4.x design by setting the templateName
* to "de.jwic.controls.ButtonLegacy".
*
* @author Florian Lippisch
* @version $Revision: 1.3 $
*/
@JavaScriptSupport
public class Button extends SelectableControl {
private static final long serialVersionUID = 1L;
private String title = null;
private ImageRef iconEnabled = null;
private ImageRef iconDisabled = null;
private String tooltip = null;
private String confirmMsg = "";
private Menu menu = null;
/**
* @param container
*/
public Button(IControlContainer container) {
super(container);
init();
}
/**
* @param container
* @param name
*/
public Button(IControlContainer container, String name) {
super(container, name);
init();
}
/* (non-Javadoc)
* @see de.jwic.base.Control#init()
*/
private void init() {
setCssClass("j-button");
if (title == null) {
title = getName();
}
}
/* (non-Javadoc)
* @see de.jwic.base.Control#actionPerformed(java.lang.String, java.lang.String)
*/
public void actionPerformed(String actionId, String parameter) {
click();
}
/**
* @return Returns the title.
*/
@IncludeJsOption
public String getTitle() {
return title;
}
/**
* @param title The title to set.
*/
public void setTitle(String title) {
this.title = title;
setRequireRedraw(true);
}
/**
* @return true if the button has non-empty title, false otherwise
*/
@IncludeJsOption
public boolean hasTitle(){
return title!=null && !title.isEmpty();
}
/**
* Returns the icon for the button depending on the state.
* @return
*/
public ImageRef getIcon() {
if (!isEnabled()) {
return iconDisabled != null ? iconDisabled : iconEnabled;
} else {
return iconEnabled;
}
}
/**
* @return
*/
@IncludeJsOption
public String getIconPath(){
ImageRef icon = this.getIcon();
return icon != null ? icon.getPath() : "";
}
/**
* Returns true if an icon is specified.
* @return
*/
@IncludeJsOption
public boolean hasIcon(){
return iconEnabled != null;
}
/**
* @return Returns the tooltip.
*/
@IncludeJsOption
public String getTooltip() {
return tooltip;
}
/**
* @param tooltip The tooltip to set.
*/
public void setTooltip(String tooltip) {
this.tooltip = tooltip;
requireRedraw();
}
/**
* @return Returns the confirmMsg.
*/
@IncludeJsOption
public String getConfirmMsg() {
return confirmMsg;
}
/**
* @param confirmMsg The confirmMsg to set.
*/
public void setConfirmMsg(String confirmMsg) {
this.confirmMsg = confirmMsg;
requireRedraw();
}
/**
* @return the iconDisabled
*/
public ImageRef getIconDisabled() {
return iconDisabled;
}
/**
* @return
*/
@IncludeJsOption
public String getIconDisabledPath(){
return this.iconDisabled != null ? this.iconDisabled.getPath() : "";
}
/**
* @param iconDisabled the iconDisabled to set
*/
public void setIconDisabled(ImageRef iconDisabled) {
this.iconDisabled = iconDisabled;
requireRedraw();
}
/**
* @return the iconEnabled
*/
public ImageRef getIconEnabled() {
return iconEnabled;
}
/**
* @return
*/
@IncludeJsOption
public String getIconEnabledPath() {
return iconEnabled != null ? iconEnabled.getPath() : "";
}
/**
* @param iconEnabled the iconEnabled to set
*/
public void setIconEnabled(ImageRef iconEnabled) {
this.iconEnabled = iconEnabled;
requireRedraw();
}
/**
* @return the menu
*/
public Menu getMenu() {
return menu;
}
/**
* @param menu the menu to set
*/
public void setMenu(Menu menu) {
this.menu = menu;
}
/**
* @return
*/
@IncludeJsOption
public String getMenuId(){
return menu != null ? menu.getControlID(): null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy