org.opencms.gwt.client.ui.CmsMenuButton Maven / Gradle / Ivy
Show all versions of opencms-gwt Show documentation
/*
* This library is part of OpenCms -
* the Open Source Content Management System
*
* Copyright (c) Alkacon Software GmbH & Co. KG (http://www.alkacon.com)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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.
*
* For further information about Alkacon Software, please see the
* company website: http://www.alkacon.com
*
* For further information about OpenCms, please see the
* project website: http://www.opencms.org
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.opencms.gwt.client.ui;
import org.opencms.gwt.client.ui.I_CmsButton.ButtonStyle;
import org.opencms.util.CmsStringUtil;
import com.google.gwt.core.client.GWT;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.dom.client.HasClickHandlers;
import com.google.gwt.event.logical.shared.CloseEvent;
import com.google.gwt.event.logical.shared.CloseHandler;
import com.google.gwt.event.logical.shared.ResizeEvent;
import com.google.gwt.event.logical.shared.ResizeHandler;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.uibinder.client.UiBinder;
import com.google.gwt.uibinder.client.UiConstructor;
import com.google.gwt.uibinder.client.UiField;
import com.google.gwt.user.client.Event;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.PopupPanel;
import com.google.gwt.user.client.ui.Widget;
/**
* Provides a menu button.
*
* @since 8.0.0
*/
public class CmsMenuButton extends Composite implements HasClickHandlers {
/**
* @see com.google.gwt.uibinder.client.UiBinder
*/
interface I_CmsMenuButtonUiBinder extends UiBinder {
// GWT interface, nothing to do here
}
/** The ui-binder instance for this class. */
private static I_CmsMenuButtonUiBinder uiBinder = GWT.create(I_CmsMenuButtonUiBinder.class);
/** The menu button. */
@UiField
protected CmsPushButton m_button;
/** The menu content. */
protected CmsToolbarPopup m_popup;
/** Registration of the window resize handler. */
protected HandlerRegistration m_resizeRegistration;
/** Flag if the menu is open. */
private boolean m_isOpen;
/** Flag if the menu opens to the right hand side. */
private boolean m_isOpenRight;
/**
* Constructor.
*
* @param buttonText the menu button text
* @param imageClass the menu button image sprite class
*/
@UiConstructor
public CmsMenuButton(String buttonText, String imageClass) {
this();
if (CmsStringUtil.isNotEmptyOrWhitespaceOnly(buttonText)) {
m_button.setText(buttonText);
}
m_button.setImageClass(imageClass);
}
/**
* Constructor.
*/
protected CmsMenuButton() {
initWidget(uiBinder.createAndBindUi(this));
m_button.setSize(I_CmsButton.Size.big);
m_button.setButtonStyle(ButtonStyle.MENU, null);
m_button.addStyleName(I_CmsButton.ButtonStyle.FONT_ICON.getCssClassName());
m_isOpen = false;
m_popup = new CmsToolbarPopup(m_button, false, getElement());
m_popup.addCloseHandler(new CloseHandler() {
public void onClose(CloseEvent event) {
autoClose();
if (m_resizeRegistration != null) {
m_resizeRegistration.removeHandler();
m_resizeRegistration = null;
}
}
});
}
/**
* @see com.google.gwt.event.dom.client.HasClickHandlers#addClickHandler(com.google.gwt.event.dom.client.ClickHandler)
*/
public HandlerRegistration addClickHandler(ClickHandler handler) {
return addDomHandler(handler, ClickEvent.getType());
}
/**
* Removes all content from menu.
*/
public void clear() {
m_popup.clear();
}
/**
* Closes the menu and fires the on toggle event.
*/
public void closeMenu() {
m_popup.hide();
}
/**
* Disables the menu button.
*
* @param disabledReason the reason to set in the button title
*/
public void disable(String disabledReason) {
m_button.disable(disabledReason);
getElement().setPropertyBoolean("disabled", true);
}
/**
* Enables or disables the button.
*/
public void enable() {
m_button.enable();
getElement().setPropertyBoolean("disabled", false);
}
/**
* Hides the menu content as well as the menu connector.
*/
public void hide() {
m_popup.hide();
}
/**
* Returns if the menu is open.
*
* @return true
if the menu is opened
*/
public boolean isOpen() {
return m_isOpen;
}
/**
* Returns the isOpenRight.
*
* @return the isOpenRight
*/
public boolean isOpenRight() {
return m_isOpenRight;
}
/**
* @see com.google.gwt.user.client.ui.Composite#onBrowserEvent(com.google.gwt.user.client.Event)
*/
@Override
public void onBrowserEvent(Event event) {
// Should not act on button if disabled.
if (!isEnabled()) {
return;
}
super.onBrowserEvent(event);
}
/**
* Opens the menu and fires the on toggle event.
*/
public void openMenu() {
m_isOpen = true;
setButtonDown();
m_popup.show();
m_popup.position();
m_resizeRegistration = Window.addResizeHandler(new ResizeHandler() {
public void onResize(ResizeEvent event) {
m_popup.position();
}
});
}
/**
* Enables or disables the button.
*
* @param enabled if true, enables the button, else disables it
*/
public void setEnabled(boolean enabled) {
if (enabled) {
enable();
} else {
m_button.setEnabled(enabled);
getElement().setPropertyBoolean("disabled", true);
}
}
/**
* This will set the menu content widget.
*
* @param widget the widget to set as content
*/
public void setMenuWidget(Widget widget) {
m_popup.remove(widget);
m_popup.add(widget);
}
/**
* Sets the isOpenRight.
*
* @param isOpenRight the isOpenRight to set
*/
public void setOpenRight(boolean isOpenRight) {
m_isOpenRight = isOpenRight;
}
/**
* Sets the isToolbarMode.
*
* @param isToolbarMode the isToolbarMode to set
*/
public void setToolbarMode(boolean isToolbarMode) {
m_popup.setToolbarMode(isToolbarMode);
}
/**
* Shows the menu content as well as the menu connector.
*/
public void show() {
m_popup.show();
}
/**
* Called on auto close.
*/
protected void autoClose() {
setButtonUp();
}
/**
* Returns the popup content.
*
* @return the popup content
*/
protected CmsPopup getPopup() {
return m_popup;
}
/**
* Hides the menu content without altering the button state.
*/
protected void hideMenu() {
m_popup.hide();
if (m_resizeRegistration != null) {
m_resizeRegistration.removeHandler();
m_resizeRegistration = null;
}
}
/**
* Returns if this button is enabled.
*
* @return true
if the button is enabled
*/
protected boolean isEnabled() {
return !getElement().getPropertyBoolean("disabled");
}
/**
* Sets the button to its 'down state'.
*/
protected void setButtonDown() {
m_button.setDown(true);
}
/**
* Sets button to state up, hides menu fragments (not the content pop-up) and fires the toggle event.
*/
protected void setButtonUp() {
m_isOpen = false;
m_button.setDown(false);
}
}