IDEMPIERE-800 Zk: Add API to ease implementation of consistent button style across the whole application.

This commit is contained in:
Heng Sin Low 2013-03-26 22:41:25 +08:00
parent bf14ca9958
commit b50ae57c3b
20 changed files with 369 additions and 172 deletions

View File

@ -0,0 +1,8 @@
-- Mar 26, 2013 8:15:58 PM MYT
-- IDEMPIERE-800 Zk: Add API for consistent button style
INSERT INTO AD_SysConfig (AD_SysConfig_ID,EntityType,ConfigurationLevel,Value,Description,AD_SysConfig_UU,Created,Updated,AD_Client_ID,AD_Org_ID,CreatedBy,IsActive,UpdatedBy,Name) VALUES (200029,'D','S','I','T-Text, I-Image, IT-Image and Text','c86d55be-3ae7-425e-a828-8f6cb1a6977c',TO_DATE('2013-03-26 20:15:56','YYYY-MM-DD HH24:MI:SS'),TO_DATE('2013-03-26 20:15:56','YYYY-MM-DD HH24:MI:SS'),0,0,100,'Y',100,'ZK_BUTTON_STYLE')
;
SELECT register_migration_script('201303261217_IDEMPIERE-800.sql') FROM dual
;

View File

@ -0,0 +1,8 @@
-- Mar 26, 2013 8:15:58 PM MYT
-- IDEMPIERE-800 Zk: Add API for consistent button style
INSERT INTO AD_SysConfig (AD_SysConfig_ID,EntityType,ConfigurationLevel,Value,Description,AD_SysConfig_UU,Created,Updated,AD_Client_ID,AD_Org_ID,CreatedBy,IsActive,UpdatedBy,Name) VALUES (200029,'D','S','I','T-Text, I-Image, IT-Image and Text','c86d55be-3ae7-425e-a828-8f6cb1a6977c',TO_TIMESTAMP('2013-03-26 20:15:56','YYYY-MM-DD HH24:MI:SS'),TO_TIMESTAMP('2013-03-26 20:15:56','YYYY-MM-DD HH24:MI:SS'),0,0,100,'Y',100,'ZK_BUTTON_STYLE')
;
SELECT register_migration_script('201303261217_IDEMPIERE-800.sql') FROM dual
;

View File

@ -23,9 +23,11 @@ import org.adempiere.util.ServerContext;
import org.adempiere.webui.AdempiereWebUI; import org.adempiere.webui.AdempiereWebUI;
import org.adempiere.webui.LayoutUtils; import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.component.Button; import org.adempiere.webui.component.Button;
import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.Panel; import org.adempiere.webui.component.Panel;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.desktop.IDesktop; import org.adempiere.webui.desktop.IDesktop;
import org.adempiere.webui.factory.ButtonFactory;
import org.adempiere.webui.part.WindowContainer; import org.adempiere.webui.part.WindowContainer;
import org.adempiere.webui.process.WProcessInfo; import org.adempiere.webui.process.WProcessInfo;
import org.adempiere.webui.session.SessionManager; import org.adempiere.webui.session.SessionManager;
@ -175,20 +177,14 @@ public class ProcessDialog extends Window implements EventListener<Event>, IProc
@SuppressWarnings("unused") @SuppressWarnings("unused")
String label = Msg.getMsg(Env.getCtx(), "Start"); String label = Msg.getMsg(Env.getCtx(), "Start");
// Invert - Unify OK/Cancel IDEMPIERE-77 // Invert - Unify OK/Cancel IDEMPIERE-77
//bOK = new Button(label.replaceAll("&", "")); bOK = ButtonFactory.createNamedButton(ConfirmPanel.A_OK);
bOK = new Button();
bOK.setImage(ThemeManager.getThemeResource("images/Ok16.png"));
bOK.setId("Ok"); bOK.setId("Ok");
bOK.addEventListener(Events.ON_CLICK, this); bOK.addEventListener(Events.ON_CLICK, this);
bOK.setSclass("action-image-text-button");
hbox.appendChild(bOK); hbox.appendChild(bOK);
//label = Msg.getMsg(Env.getCtx(), "Cancel"); Button btn = ButtonFactory.createNamedButton(ConfirmPanel.A_CANCEL);
Button btn = new Button();
btn.setImage(ThemeManager.getThemeResource("images/Cancel16.png"));
btn.setId("Cancel"); btn.setId("Cancel");
btn.addEventListener(Events.ON_CLICK, this); btn.addEventListener(Events.ON_CLICK, this);
btn.setSclass("action-image-text-button");
hbox.appendChild(btn); hbox.appendChild(btn);
div.appendChild(hbox); div.appendChild(hbox);
div.setStyle("padding: 10px; text-align: center; text-align: -webkit-center; text-align: -moz-center; "); div.setStyle("padding: 10px; text-align: center; text-align: -webkit-center; text-align: -moz-center; ");

View File

@ -33,11 +33,12 @@ import org.adempiere.util.ServerContext;
import org.adempiere.webui.AdempiereWebUI; import org.adempiere.webui.AdempiereWebUI;
import org.adempiere.webui.LayoutUtils; import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.component.Button; import org.adempiere.webui.component.Button;
import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.Panel; import org.adempiere.webui.component.Panel;
import org.adempiere.webui.component.VerticalBox; import org.adempiere.webui.component.VerticalBox;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.event.DialogEvents; import org.adempiere.webui.event.DialogEvents;
import org.adempiere.webui.theme.ThemeManager; import org.adempiere.webui.factory.ButtonFactory;
import org.adempiere.webui.window.FDialog; import org.adempiere.webui.window.FDialog;
import org.adempiere.webui.window.MultiFileDownloadDialog; import org.adempiere.webui.window.MultiFileDownloadDialog;
import org.compiere.Adempiere; import org.compiere.Adempiere;
@ -176,17 +177,13 @@ public class ProcessModalDialog extends Window implements EventListener<Event>,
Hbox hbox = new Hbox(); Hbox hbox = new Hbox();
hbox.setWidth("100%"); hbox.setWidth("100%");
hbox.setStyle("margin-top: 10px"); hbox.setStyle("margin-top: 10px");
Button btn = new Button(""); Button btn = ButtonFactory.createNamedButton(ConfirmPanel.A_OK);
btn.setImage(ThemeManager.getThemeResource("images/Ok24.png"));
LayoutUtils.addSclass("action-button", btn);
btn.setId("Ok"); btn.setId("Ok");
btn.addEventListener(Events.ON_CLICK, this); btn.addEventListener(Events.ON_CLICK, this);
hbox.appendChild(btn); hbox.appendChild(btn);
btn = new Button(""); btn = ButtonFactory.createNamedButton(ConfirmPanel.A_CANCEL);
btn.setImage(ThemeManager.getThemeResource("images/Cancel24.png"));
btn.setId("Cancel"); btn.setId("Cancel");
LayoutUtils.addSclass("action-button", btn);
btn.addEventListener(Events.ON_CLICK, this); btn.addEventListener(Events.ON_CLICK, this);
hbox.appendChild(btn); hbox.appendChild(btn);

View File

@ -92,7 +92,7 @@ public class WPaymentFormCheck extends PaymentFormCheck implements EventListener
sNumberField.setWidth("100pt"); sNumberField.setWidth("100pt");
sRoutingField.setWidth("70pt"); sRoutingField.setWidth("70pt");
sOnline.setLabel(Msg.getMsg(Env.getCtx(), "Online")); sOnline.setLabel(Msg.getMsg(Env.getCtx(), "Online"));
LayoutUtils.addSclass("action-text-button", sOnline); LayoutUtils.addSclass("txt-btn", sOnline);
sOnline.addActionListener(this); sOnline.addActionListener(this);
window.getPanel().setId("sPanel"); window.getPanel().setId("sPanel");

View File

@ -16,7 +16,6 @@ package org.adempiere.webui.apps.form;
import java.math.BigDecimal; import java.math.BigDecimal;
import org.adempiere.util.PaymentUtil; import org.adempiere.util.PaymentUtil;
import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.component.Button; import org.adempiere.webui.component.Button;
import org.adempiere.webui.component.Column; import org.adempiere.webui.component.Column;
import org.adempiere.webui.component.Columns; import org.adempiere.webui.component.Columns;
@ -30,6 +29,7 @@ import org.adempiere.webui.component.Row;
import org.adempiere.webui.component.Rows; import org.adempiere.webui.component.Rows;
import org.adempiere.webui.component.Textbox; import org.adempiere.webui.component.Textbox;
import org.adempiere.webui.editor.WNumberEditor; import org.adempiere.webui.editor.WNumberEditor;
import org.adempiere.webui.factory.ButtonFactory;
import org.adempiere.webui.window.FDialog; import org.adempiere.webui.window.FDialog;
import org.compiere.grid.PaymentFormCreditCard; import org.compiere.grid.PaymentFormCreditCard;
import org.compiere.model.GridTab; import org.compiere.model.GridTab;
@ -64,7 +64,7 @@ public class WPaymentFormCreditCard extends PaymentFormCreditCard implements Eve
private WNumberEditor kAmountField = new WNumberEditor(); private WNumberEditor kAmountField = new WNumberEditor();
private Label kApprovalLabel = new Label(); private Label kApprovalLabel = new Label();
private Textbox kApprovalField = new Textbox(); private Textbox kApprovalField = new Textbox();
private Button kOnline = new Button(); private Button kOnline = ButtonFactory.createNamedButton("Online");
private Label kStatus = new Label(); private Label kStatus = new Label();
public WPaymentFormCreditCard(int windowNo, GridTab mTab) { public WPaymentFormCreditCard(int windowNo, GridTab mTab) {
@ -85,8 +85,6 @@ public class WPaymentFormCreditCard extends PaymentFormCreditCard implements Eve
kExpLabel.setText(Msg.getMsg(Env.getCtx(), "Expires")); kExpLabel.setText(Msg.getMsg(Env.getCtx(), "Expires"));
kApprovalLabel.setText(Msg.translate(Env.getCtx(), "VoiceAuthCode")); kApprovalLabel.setText(Msg.translate(Env.getCtx(), "VoiceAuthCode"));
kAmountLabel.setText(Msg.getMsg(Env.getCtx(), "Amount")); kAmountLabel.setText(Msg.getMsg(Env.getCtx(), "Amount"));
kOnline.setLabel(Msg.getMsg(Env.getCtx(), "Online"));
LayoutUtils.addSclass("action-text-button", kOnline);
kOnline.addActionListener(this); kOnline.addActionListener(this);
window.getPanel().setId("kPanel"); window.getPanel().setId("kPanel");

View File

@ -75,7 +75,7 @@ public abstract class WPaymentFormDirect extends PaymentFormDirect implements Ev
tRoutingText.setText(Msg.translate(Env.getCtx(), "RoutingNo")); tRoutingText.setText(Msg.translate(Env.getCtx(), "RoutingNo"));
tNumberText.setText(Msg.translate(Env.getCtx(), "AccountNo")); tNumberText.setText(Msg.translate(Env.getCtx(), "AccountNo"));
tOnline.setLabel(Msg.getMsg(Env.getCtx(), "Online")); tOnline.setLabel(Msg.getMsg(Env.getCtx(), "Online"));
LayoutUtils.addSclass("action-text-button", tOnline); LayoutUtils.addSclass("txt-btn", tOnline);
tOnline.addActionListener(this); tOnline.addActionListener(this);
window.getPanel().setId("tPanel"); window.getPanel().setId("tPanel");

View File

@ -22,10 +22,7 @@ import java.util.Iterator;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.adempiere.webui.LayoutUtils; import org.adempiere.webui.factory.ButtonFactory;
import org.adempiere.webui.theme.ThemeManager;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events; import org.zkoss.zk.ui.event.Events;
import org.zkoss.zul.Hbox; import org.zkoss.zul.Hbox;
@ -75,6 +72,7 @@ public final class ConfirmPanel extends Hbox
private boolean m_withText = false; private boolean m_withText = false;
private Map<String, Button> buttonMap = new HashMap<String, Button>(); private Map<String, Button> buttonMap = new HashMap<String, Button>();
private boolean m_withImage = true;
/** /**
* Creates a button of the specified id * Creates a button of the specified id
@ -101,30 +99,8 @@ public final class ConfirmPanel extends Hbox
*/ */
public Button createButton(String name) public Button createButton(String name)
{ {
Button button = new Button(); Button button = ButtonFactory.createNamedButton(name, m_withText, m_withImage);
button.setName("btn"+name);
button.setId(name); button.setId(name);
String text = Msg.translate(Env.getCtx(), name);
if (!name.equals(text))
text = text.replaceAll("[&]", "");
else
text = null;
if (m_withText && text != null)
{
button.setImage(ThemeManager.getThemeResource("images/"+name+"16.png"));
button.setLabel(text);
LayoutUtils.addSclass("action-text-button", button);
}
else
{
button.setImage(ThemeManager.getThemeResource("images/"+name+"24.png"));
if (text != null)
button.setTooltiptext(text);
LayoutUtils.addSclass("action-button", button);
}
buttonMap.put(name, button); buttonMap.put(name, button);
return button; return button;
@ -146,7 +122,7 @@ public final class ConfirmPanel extends Hbox
boolean withHistoryButton, boolean withHistoryButton,
boolean withZoomButton) boolean withZoomButton)
{ {
this(withCancelButton, withRefreshButton, withResetButton, withCustomizeButton, withHistoryButton, withZoomButton, false); this(withCancelButton, withRefreshButton, withResetButton, withCustomizeButton, withHistoryButton, withZoomButton, ButtonFactory.isWithText());
} }
/** /**
@ -157,6 +133,7 @@ public final class ConfirmPanel extends Hbox
* @param withCustomizeButton with customize * @param withCustomizeButton with customize
* @param withHistoryButton with history * @param withHistoryButton with history
* @param withZoomButton with zoom * @param withZoomButton with zoom
* @param withText
*/ */
public ConfirmPanel(boolean withCancelButton, public ConfirmPanel(boolean withCancelButton,
boolean withRefreshButton, boolean withRefreshButton,
@ -165,8 +142,32 @@ public final class ConfirmPanel extends Hbox
boolean withHistoryButton, boolean withHistoryButton,
boolean withZoomButton, boolean withZoomButton,
boolean withText) boolean withText)
{
this(withCancelButton, withRefreshButton, withResetButton, withCustomizeButton, withHistoryButton, withZoomButton, withText, !withText ? true : ButtonFactory.isWithImage());
}
/**
* create confirm panel with multiple options
* @param withCancelButton with cancel
* @param withRefreshButton with refresh
* @param withResetButton with reset
* @param withCustomizeButton with customize
* @param withHistoryButton with history
* @param withZoomButton with zoom
* @param withText
* @param withImage Incude image for button. Note that image always included if withText is false
*/
public ConfirmPanel(boolean withCancelButton,
boolean withRefreshButton,
boolean withResetButton,
boolean withCustomizeButton,
boolean withHistoryButton,
boolean withZoomButton,
boolean withText,
boolean withImage)
{ {
m_withText = withText; m_withText = withText;
m_withImage = withImage;
init(); init();

View File

@ -21,8 +21,8 @@ import java.util.Properties;
import org.adempiere.util.Callback; import org.adempiere.util.Callback;
import org.adempiere.webui.AdempiereIdGenerator; import org.adempiere.webui.AdempiereIdGenerator;
import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.apps.AEnv; import org.adempiere.webui.apps.AEnv;
import org.adempiere.webui.factory.ButtonFactory;
import org.adempiere.webui.theme.ThemeManager; import org.adempiere.webui.theme.ThemeManager;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Msg; import org.compiere.util.Msg;
@ -55,13 +55,13 @@ public class Messagebox extends Window implements EventListener<Event>
private Text lblMsg = new Text(); private Text lblMsg = new Text();
private Button btnOk = new Button(); private Button btnOk;
private Button btnCancel = new Button(); private Button btnCancel;
private Button btnYes = new Button(); private Button btnYes;
private Button btnNo = new Button(); private Button btnNo;
private Button btnAbort = new Button(); private Button btnAbort;
private Button btnRetry = new Button(); private Button btnRetry;
private Button btnIgnore = new Button(); private Button btnIgnore;
private Image img = new Image(); private Image img = new Image();
@ -115,45 +115,39 @@ public class Messagebox extends Window implements EventListener<Event>
lblMsg.setEncode(false); lblMsg.setEncode(false);
lblMsg.setValue(msg); lblMsg.setValue(msg);
// Invert - Unify OK/Cancel IDEMPIERE-77 // Invert - Unify OK/Cancel IDEMPIERE-77
//btnOk.setLabel(Util.cleanAmp(Msg.getMsg(ctx, "OK"))); btnOk = ButtonFactory.createNamedButton(ConfirmPanel.A_OK);
btnOk.setImage(ThemeManager.getThemeResource("images/Ok16.png"));
btnOk.setId("btnOk"); btnOk.setId("btnOk");
btnOk.addEventListener(Events.ON_CLICK, this); btnOk.addEventListener(Events.ON_CLICK, this);
LayoutUtils.addSclass("action-text-button", btnOk);
//btnCancel.setLabel(Util.cleanAmp(Msg.getMsg(ctx, "Cancel"))); btnCancel = ButtonFactory.createNamedButton(ConfirmPanel.A_CANCEL);
btnCancel.setImage(ThemeManager.getThemeResource("images/Cancel16.png"));
btnCancel.addEventListener(Events.ON_CLICK, this); btnCancel.addEventListener(Events.ON_CLICK, this);
btnCancel.setId("btnCancel"); btnCancel.setId("btnCancel");
LayoutUtils.addSclass("action-text-button", btnCancel);
btnYes.setLabel(Util.cleanAmp(Msg.getMsg(ctx, "Yes"))); String yesLabel = Util.cleanAmp(Msg.getMsg(ctx, "Yes"));
btnYes.setImage(ThemeManager.getThemeResource("images/Ok16.png")); btnYes = ButtonFactory.createButton(ButtonFactory.isWithText() ? yesLabel : null,
ButtonFactory.isWithImage() ? (ButtonFactory.isWithText() ? ThemeManager.getThemeResource("images/Ok16.png") : ThemeManager.getThemeResource("images/Ok24.png")) : null,
ButtonFactory.isWithText() ? null : yesLabel);
btnYes.addEventListener(Events.ON_CLICK, this); btnYes.addEventListener(Events.ON_CLICK, this);
btnYes.setId("btnYes"); btnYes.setId("btnYes");
LayoutUtils.addSclass("action-text-button", btnYes);
btnNo.setLabel(Util.cleanAmp(Msg.getMsg(ctx, "No"))); String noLabel = Util.cleanAmp(Msg.getMsg(ctx, "No"));
btnNo.setImage(ThemeManager.getThemeResource("images/Cancel16.png")); btnNo = ButtonFactory.createButton(ButtonFactory.isWithText() ? noLabel : null,
ButtonFactory.isWithImage() ? ( ButtonFactory.isWithText() ? ThemeManager.getThemeResource("images/Cancel16.png") : ThemeManager.getThemeResource("images/Cancel24.png")) : null,
ButtonFactory.isWithText() ? null : noLabel);
btnNo.addEventListener(Events.ON_CLICK, this); btnNo.addEventListener(Events.ON_CLICK, this);
btnNo.setId("btnNo"); btnNo.setId("btnNo");
LayoutUtils.addSclass("action-text-button", btnNo);
btnAbort.setLabel("Abort"); btnAbort = ButtonFactory.createButton("Abort", null, null);
btnAbort.addEventListener(Events.ON_CLICK, this); btnAbort.addEventListener(Events.ON_CLICK, this);
btnAbort.setId("btnAbort"); btnAbort.setId("btnAbort");
LayoutUtils.addSclass("action-text-button", btnAbort);
btnRetry.setLabel("Retry"); btnRetry = ButtonFactory.createButton("Retry", null, null);
btnRetry.addEventListener(Events.ON_CLICK, this); btnRetry.addEventListener(Events.ON_CLICK, this);
btnRetry.setId("btnRetry"); btnRetry.setId("btnRetry");
LayoutUtils.addSclass("action-text-button", btnRetry);
btnIgnore.setLabel("Ignore"); btnIgnore = ButtonFactory.createNamedButton("Ignore");
btnIgnore.setImage(ThemeManager.getThemeResource("images/Ignore16.png"));
btnIgnore.addEventListener(Events.ON_CLICK, this); btnIgnore.addEventListener(Events.ON_CLICK, this);
btnIgnore.setId("btnIgnore"); btnIgnore.setId("btnIgnore");
LayoutUtils.addSclass("action-text-button", btnIgnore);
Panel pnlMessage = new Panel(); Panel pnlMessage = new Panel();
pnlMessage.setStyle(MESSAGE_PANEL_STYLE); pnlMessage.setStyle(MESSAGE_PANEL_STYLE);
@ -219,6 +213,8 @@ public class Messagebox extends Window implements EventListener<Event>
this.imgSrc = icon; this.imgSrc = icon;
this.callback = callback; this.callback = callback;
init();
btnOk.setVisible(false); btnOk.setVisible(false);
btnCancel.setVisible(false); btnCancel.setVisible(false);
btnYes.setVisible(false); btnYes.setVisible(false);
@ -248,8 +244,6 @@ public class Messagebox extends Window implements EventListener<Event>
if ((buttons & IGNORE) != 0) if ((buttons & IGNORE) != 0)
btnIgnore.setVisible(true); btnIgnore.setVisible(true);
init();
this.setTitle(title); this.setTitle(title);
this.setPosition("center"); this.setPosition("center");
this.setClosable(true); this.setClosable(true);

View File

@ -16,9 +16,8 @@ package org.adempiere.webui.component;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.apps.AEnv; import org.adempiere.webui.apps.AEnv;
import org.adempiere.webui.theme.ThemeManager; import org.adempiere.webui.factory.ButtonFactory;
import org.compiere.process.ProcessInfoLog; import org.compiere.process.ProcessInfoLog;
import org.compiere.util.DisplayType; import org.compiere.util.DisplayType;
import org.compiere.util.Env; import org.compiere.util.Env;
@ -42,7 +41,7 @@ public class ProcessInfoDialog extends Window implements EventListener<Event> {
private static final String MESSAGE_PANEL_STYLE = "text-align:left; word-break: break-all; overflow: auto; max-height: 250pt; min-width: 230pt; max-width: 450pt;"; private static final String MESSAGE_PANEL_STYLE = "text-align:left; word-break: break-all; overflow: auto; max-height: 250pt; min-width: 230pt; max-width: 450pt;";
private Text lblMsg = new Text(); private Text lblMsg = new Text();
private Button btnOk = new Button(); private Button btnOk = ButtonFactory.createNamedButton(ConfirmPanel.A_OK);
private Image img = new Image(); private Image img = new Image();
public static final String INFORMATION = "~./zul/img/msgbox/info-btn.png"; public static final String INFORMATION = "~./zul/img/msgbox/info-btn.png";
@ -64,9 +63,7 @@ public class ProcessInfoDialog extends Window implements EventListener<Event> {
lblMsg.setEncode(false); lblMsg.setEncode(false);
lblMsg.setValue(header); lblMsg.setValue(header);
btnOk.setImage(ThemeManager.getThemeResource("images/Ok16.png"));
btnOk.addEventListener(Events.ON_CLICK, this); btnOk.addEventListener(Events.ON_CLICK, this);
LayoutUtils.addSclass("action-text-button", btnOk);
Panel pnlMessage = new Panel(); Panel pnlMessage = new Panel();
pnlMessage.setStyle(MESSAGE_PANEL_STYLE); pnlMessage.setStyle(MESSAGE_PANEL_STYLE);

View File

@ -107,7 +107,7 @@ public class WAppsAction
{ {
m_button.setLabel(newToolTipText); m_button.setLabel(newToolTipText);
} }
LayoutUtils.addSclass("action-button", m_button); LayoutUtils.addSclass("img-btn", m_button);
} // Action } // Action
private Button m_button; private Button m_button;

View File

@ -0,0 +1,138 @@
/******************************************************************************
* Copyright (C) 2013 Heng Sin Low *
* Copyright (C) 2013 Trek Global *
* This program is free software; you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program 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 General Public License for more details. *
* You should have received a copy of the GNU General Public License along *
* with this program; if not, write to the Free Software Foundation, Inc., *
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
*****************************************************************************/
package org.adempiere.webui.factory;
import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.component.Button;
import org.adempiere.webui.theme.ThemeManager;
import org.compiere.model.MSysConfig;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.compiere.util.Util;
/**
* Factory class to create button with consistent look and feel
* @author hengsin
*
*/
public class ButtonFactory {
private static final String ZK_BUTTON_STYLE = "ZK_BUTTON_STYLE";
/**
* @return true if button should have text label
*/
public static final boolean isWithText() {
String type = MSysConfig.getValue(ZK_BUTTON_STYLE, "I");
return type.indexOf("T") >= 0;
}
/**
* @return true if button should include an image icon
*/
public static final boolean isWithImage() {
String type = MSysConfig.getValue(ZK_BUTTON_STYLE, "I");
return type.indexOf("I") >= 0;
}
/**
* Create named button with default style
* @param name
* @return new button instance
*/
public static Button createNamedButton(String name)
{
return createNamedButton(name, isWithText(), isWithImage());
}
/**
*
* @param name button name. If withText is true, the name will be used to
* lookup the button label from ad_message
* @param withText text button
* @param withImage image button
* @return new button instance
*/
public static Button createNamedButton(String name, boolean withText, boolean withImage)
{
Button button = new Button();
button.setName("btn"+name);
String text = Msg.translate(Env.getCtx(), name);
if (!name.equals(text))
text = text.replaceAll("[&]", "");
else
text = null;
if (withText && text != null)
{
button.setLabel(text);
if (withImage)
{
button.setImage(ThemeManager.getThemeResource("images/"+name+"16.png"));
}
LayoutUtils.addSclass("txt-btn", button);
}
else
{
button.setImage(ThemeManager.getThemeResource("images/"+name+"24.png"));
if (text != null)
button.setTooltiptext(text);
LayoutUtils.addSclass("img-btn", button);
}
//add named class for further customization option
String className = "btn-" + name.toLowerCase();
LayoutUtils.addSclass(className, button);
return button;
}
/**
* @param label
* @param image
* @param tooltiptext
* @return new button instance
*/
public static Button createButton(String label, String image, String tooltiptext)
{
Button button = new Button();
if (!Util.isEmpty(label))
{
button.setLabel(label);
if (!Util.isEmpty(image))
{
button.setImage(image);
LayoutUtils.addSclass("img-txt-btn", button);
}
else
{
LayoutUtils.addSclass("txt-btn", button);
}
}
else if (!Util.isEmpty(image))
{
button.setImage(image);
LayoutUtils.addSclass("img-btn", button);
}
if (!Util.isEmpty(tooltiptext))
{
button.setTooltiptext(tooltiptext);
}
return button;
}
}

View File

@ -31,6 +31,7 @@ import org.adempiere.model.MTabCustomization;
import org.adempiere.webui.adwindow.GridView; import org.adempiere.webui.adwindow.GridView;
import org.adempiere.webui.component.Button; import org.adempiere.webui.component.Button;
import org.adempiere.webui.component.Checkbox; import org.adempiere.webui.component.Checkbox;
import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.Label; import org.adempiere.webui.component.Label;
import org.adempiere.webui.component.ListHead; import org.adempiere.webui.component.ListHead;
import org.adempiere.webui.component.ListHeader; import org.adempiere.webui.component.ListHeader;
@ -38,6 +39,7 @@ import org.adempiere.webui.component.ListItem;
import org.adempiere.webui.component.Listbox; import org.adempiere.webui.component.Listbox;
import org.adempiere.webui.component.Panel; import org.adempiere.webui.component.Panel;
import org.adempiere.webui.component.SimpleListModel; import org.adempiere.webui.component.SimpleListModel;
import org.adempiere.webui.factory.ButtonFactory;
import org.adempiere.webui.theme.ThemeManager; import org.adempiere.webui.theme.ThemeManager;
import org.adempiere.webui.window.FDialog; import org.adempiere.webui.window.FDialog;
import org.compiere.model.GridTab; import org.compiere.model.GridTab;
@ -245,8 +247,7 @@ public class CustomizeGridViewPanel extends Panel
southPanel.setStyle("margin-top: 2px; margin-right: 4px"); southPanel.setStyle("margin-top: 2px; margin-right: 4px");
@SuppressWarnings("unused") @SuppressWarnings("unused")
String label = Msg.getMsg(Env.getCtx(), "save"); String label = Msg.getMsg(Env.getCtx(), "save");
Button bOK = new Button(); Button bOK = ButtonFactory.createNamedButton(ConfirmPanel.A_OK);
bOK.setImage(ThemeManager.getThemeResource("images/Ok16.png"));
bOK.setId("Ok"); bOK.setId("Ok");
EventListener<Event> onClickListener = new EventListener<Event>() EventListener<Event> onClickListener = new EventListener<Event>()
{ {
@ -261,11 +262,9 @@ public class CustomizeGridViewPanel extends Panel
}; };
bOK.addActionListener(onClickListener); bOK.addActionListener(onClickListener);
bOK.setSclass("action-button");
southPanel.appendChild(bOK); southPanel.appendChild(bOK);
label = Msg.getMsg(Env.getCtx(), "Cancel"); label = Msg.getMsg(Env.getCtx(), "Cancel");
Button btn = new Button(); Button btn = ButtonFactory.createNamedButton(ConfirmPanel.A_CANCEL);
btn.setImage(ThemeManager.getThemeResource("images/Cancel16.png"));
btn.setId("Cancel"); btn.setId("Cancel");
EventListener<Event> onClickCancelListener = new EventListener<Event>() EventListener<Event> onClickCancelListener = new EventListener<Event>()
{ {
@ -280,7 +279,6 @@ public class CustomizeGridViewPanel extends Panel
}; };
btn.addActionListener(onClickCancelListener); btn.addActionListener(onClickCancelListener);
btn.setSclass("action-button");
southPanel.appendChild(btn); southPanel.appendChild(btn);
south.appendChild(southPanel); south.appendChild(southPanel);

View File

@ -246,20 +246,20 @@ public class WAttachment extends Window implements EventListener<Event>
northPanel.appendChild(div); northPanel.appendChild(div);
bSave.setEnabled(false); bSave.setEnabled(false);
bSave.setSclass("action-button"); bSave.setSclass("img-btn");
bSave.setImage(ThemeManager.getThemeResource("images/Export24.png")); bSave.setImage(ThemeManager.getThemeResource("images/Export24.png"));
bSave.setTooltiptext(Msg.getMsg(Env.getCtx(), "AttachmentSave")); bSave.setTooltiptext(Msg.getMsg(Env.getCtx(), "AttachmentSave"));
bSave.addEventListener(Events.ON_CLICK, this); bSave.addEventListener(Events.ON_CLICK, this);
bLoad.setImage(ThemeManager.getThemeResource("images/Import24.png")); bLoad.setImage(ThemeManager.getThemeResource("images/Import24.png"));
bLoad.setSclass("action-button"); bLoad.setSclass("img-btn");
bLoad.setAttribute("org.zkoss.zul.image.preload", Boolean.TRUE); bLoad.setAttribute("org.zkoss.zul.image.preload", Boolean.TRUE);
bLoad.setTooltiptext(Msg.getMsg(Env.getCtx(), "Load")); bLoad.setTooltiptext(Msg.getMsg(Env.getCtx(), "Load"));
bLoad.setUpload(AdempiereWebUI.getUploadSetting()); bLoad.setUpload(AdempiereWebUI.getUploadSetting());
bLoad.addEventListener(Events.ON_UPLOAD, this); bLoad.addEventListener(Events.ON_UPLOAD, this);
bDelete.setImage(ThemeManager.getThemeResource("images/Delete24.png")); bDelete.setImage(ThemeManager.getThemeResource("images/Delete24.png"));
bDelete.setSclass("action-button"); bDelete.setSclass("img-btn");
bDelete.setTooltiptext(Msg.getMsg(Env.getCtx(), "Delete")); bDelete.setTooltiptext(Msg.getMsg(Env.getCtx(), "Delete"));
bDelete.addEventListener(Events.ON_CLICK, this); bDelete.addEventListener(Events.ON_CLICK, this);
@ -280,19 +280,19 @@ public class WAttachment extends Window implements EventListener<Event>
southPane.setHeight("30px"); southPane.setHeight("30px");
bCancel.setImage(ThemeManager.getThemeResource("images/Cancel24.png")); bCancel.setImage(ThemeManager.getThemeResource("images/Cancel24.png"));
bCancel.setSclass("action-button"); bCancel.setSclass("img-btn");
bCancel.addEventListener(Events.ON_CLICK, this); bCancel.addEventListener(Events.ON_CLICK, this);
bOk.setImage(ThemeManager.getThemeResource("images/Ok24.png")); bOk.setImage(ThemeManager.getThemeResource("images/Ok24.png"));
bOk.setSclass("action-button"); bOk.setSclass("img-btn");
bOk.addEventListener(Events.ON_CLICK, this); bOk.addEventListener(Events.ON_CLICK, this);
bDeleteAll.setImage(ThemeManager.getThemeResource("images/Delete24.png")); bDeleteAll.setImage(ThemeManager.getThemeResource("images/Delete24.png"));
bDeleteAll.setSclass("action-button"); bDeleteAll.setSclass("img-btn");
bDeleteAll.addEventListener(Events.ON_CLICK, this); bDeleteAll.addEventListener(Events.ON_CLICK, this);
bRefresh.setImage(ThemeManager.getThemeResource("images/Refresh24.png")); bRefresh.setImage(ThemeManager.getThemeResource("images/Refresh24.png"));
bRefresh.setSclass("action-button"); bRefresh.setSclass("img-btn");
bRefresh.addEventListener(Events.ON_CLICK, this); bRefresh.addEventListener(Events.ON_CLICK, this);
confirmPanel.appendChild(bDeleteAll); confirmPanel.appendChild(bDeleteAll);

View File

@ -21,6 +21,7 @@ import java.util.logging.Level;
import org.adempiere.webui.apps.AEnv; import org.adempiere.webui.apps.AEnv;
import org.adempiere.webui.component.Button; import org.adempiere.webui.component.Button;
import org.adempiere.webui.component.Checkbox; import org.adempiere.webui.component.Checkbox;
import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.FolderBrowser; import org.adempiere.webui.component.FolderBrowser;
import org.adempiere.webui.component.Label; import org.adempiere.webui.component.Label;
import org.adempiere.webui.component.ListHead; import org.adempiere.webui.component.ListHead;
@ -36,6 +37,7 @@ import org.adempiere.webui.component.Tabs;
import org.adempiere.webui.component.ToolBarButton; import org.adempiere.webui.component.ToolBarButton;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.event.DialogEvents; import org.adempiere.webui.event.DialogEvents;
import org.adempiere.webui.factory.ButtonFactory;
import org.adempiere.webui.theme.ThemeManager; import org.adempiere.webui.theme.ThemeManager;
import org.adempiere.webui.util.FeedbackManager; import org.adempiere.webui.util.FeedbackManager;
import org.compiere.Adempiere; import org.compiere.Adempiere;
@ -152,9 +154,8 @@ public class AboutWindow extends Window implements EventListener<Event> {
hbox.setParent(layout); hbox.setParent(layout);
hbox.setPack("end"); hbox.setPack("end");
hbox.setWidth("100%"); hbox.setWidth("100%");
hbox.setVflex("0"); hbox.setVflex("min");
Button btnOk = new Button(); Button btnOk = ButtonFactory.createNamedButton(ConfirmPanel.A_OK);
btnOk.setImage(ThemeManager.getThemeResource("images/Ok24.png"));
btnOk.addEventListener(Events.ON_CLICK, this); btnOk.addEventListener(Events.ON_CLICK, this);
btnOk.setParent(hbox); btnOk.setParent(hbox);

View File

@ -38,11 +38,11 @@ import java.util.logging.Level;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import org.adempiere.webui.AdempiereWebUI; import org.adempiere.webui.AdempiereWebUI;
import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.component.Button; import org.adempiere.webui.component.Button;
import org.adempiere.webui.component.Column; import org.adempiere.webui.component.Column;
import org.adempiere.webui.component.Columns; import org.adempiere.webui.component.Columns;
import org.adempiere.webui.component.Combobox; import org.adempiere.webui.component.Combobox;
import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.Grid; import org.adempiere.webui.component.Grid;
import org.adempiere.webui.component.Label; import org.adempiere.webui.component.Label;
import org.adempiere.webui.component.ListCell; import org.adempiere.webui.component.ListCell;
@ -64,6 +64,7 @@ import org.adempiere.webui.editor.WebEditorFactory;
import org.adempiere.webui.event.DialogEvents; import org.adempiere.webui.event.DialogEvents;
import org.adempiere.webui.event.ValueChangeEvent; import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener; import org.adempiere.webui.event.ValueChangeListener;
import org.adempiere.webui.factory.ButtonFactory;
import org.adempiere.webui.part.MultiTabPart; import org.adempiere.webui.part.MultiTabPart;
import org.adempiere.webui.theme.ThemeManager; import org.adempiere.webui.theme.ThemeManager;
import org.compiere.model.GridField; import org.compiere.model.GridField;
@ -304,26 +305,18 @@ public class FindWindow extends Window implements EventListener<Event>, ValueCha
**/ **/
private void initSimple() private void initSimple()
{ {
Button btnNew = new Button(); Button btnNew = ButtonFactory.createNamedButton(ConfirmPanel.A_NEW);
btnNew.setName("btnNew");
btnNew.setId("btnNew"); btnNew.setId("btnNew");
btnNew.setImage(ThemeManager.getThemeResource("images/New24.png"));
btnNew.addEventListener(Events.ON_CLICK,this); btnNew.addEventListener(Events.ON_CLICK,this);
LayoutUtils.addSclass("action-button", btnNew);
Button btnOk = new Button(); Button btnOk = ButtonFactory.createNamedButton(ConfirmPanel.A_OK);
btnOk.setName("btnOkSimple"); btnOk.setName("btnOkSimple");
btnOk.setId("btnOk"); btnOk.setId("btnOk");
btnOk.setImage(ThemeManager.getThemeResource("images/Ok24.png"));
btnOk.addEventListener(Events.ON_CLICK,this); btnOk.addEventListener(Events.ON_CLICK,this);
LayoutUtils.addSclass("action-button", btnOk);
Button btnCancel = new Button(); Button btnCancel = ButtonFactory.createNamedButton(ConfirmPanel.A_CANCEL);
btnCancel.setName("btnCancel");
btnCancel.setId("btnCancel"); btnCancel.setId("btnCancel");
btnCancel.setImage(ThemeManager.getThemeResource("images/Cancel24.png"));
btnCancel.addEventListener(Events.ON_CLICK,this); btnCancel.addEventListener(Events.ON_CLICK,this);
LayoutUtils.addSclass("action-button", btnCancel);
Panel pnlButtonRight = new Panel(); Panel pnlButtonRight = new Panel();
pnlButtonRight.appendChild(btnOk); pnlButtonRight.appendChild(btnOk);
@ -405,17 +398,12 @@ public class FindWindow extends Window implements EventListener<Event>, ValueCha
btnDelete.setImage(ThemeManager.getThemeResource("images/Delete24.png")); btnDelete.setImage(ThemeManager.getThemeResource("images/Delete24.png"));
btnDelete.addEventListener(Events.ON_CLICK, this); btnDelete.addEventListener(Events.ON_CLICK, this);
Button btnOk = new Button(); Button btnOk = ButtonFactory.createNamedButton(ConfirmPanel.A_OK);
btnOk.setName("btnOkAdv"); btnOk.setName("btnOkAdv");
btnOk.setImage(ThemeManager.getThemeResource("images/Ok24.png"));
btnOk.addEventListener(Events.ON_CLICK, this); btnOk.addEventListener(Events.ON_CLICK, this);
LayoutUtils.addSclass("action-button", btnOk);
Button btnCancel = new Button(); Button btnCancel = ButtonFactory.createNamedButton(ConfirmPanel.A_CANCEL);
btnCancel.setName("btnCancel");
btnCancel.setImage(ThemeManager.getThemeResource("images/Cancel24.png"));
btnCancel.addEventListener(Events.ON_CLICK, this); btnCancel.addEventListener(Events.ON_CLICK, this);
LayoutUtils.addSclass("action-button", btnCancel);
Panel pnlButtonRight = new Panel(); Panel pnlButtonRight = new Panel();
pnlButtonRight.appendChild(btnOk); pnlButtonRight.appendChild(btnOk);

View File

@ -70,15 +70,6 @@
<name>org.zkoss.zul.progressbox.position</name> <name>org.zkoss.zul.progressbox.position</name>
<value>center</value> <value>center</value>
</library-property> </library-property>
<library-property>
<name>org.zkoss.zul.Button.mold</name>
<value>trendy</value>
</library-property>
<library-property>
<name>org.adempiere.webui.component.Button.mold</name>
<value>trendy</value>
</library-property>
<library-property> <library-property>
<name>org.zkoss.zul.theme.fontSizeM <name>org.zkoss.zul.theme.fontSizeM
</name> </name>

View File

@ -12,7 +12,7 @@
<divarrow id="divArrowLeft" type="arrow-left"/> <divarrow id="divArrowLeft" type="arrow-left"/>
<divarrow id="divArrowRight" type="arrow-right"/> <divarrow id="divArrowRight" type="arrow-right"/>
<div> <div>
<button id="btnCurrentDate" mold="os" label="today"/> <button id="btnCurrentDate" label="today" sclass="btn-small"/>
<separator orient="vertical" spacing="2px"/> <separator orient="vertical" spacing="2px"/>
<label id="lblDate"/> <label id="lblDate"/>
<toolbarbutton id="btnRefresh" label="Refresh" class="refresh"/> <toolbarbutton id="btnRefresh" label="Refresh" class="refresh"/>

View File

@ -82,8 +82,7 @@ html,body {
} }
.login-btn { .login-btn {
height: 36px; padding: 4px 20px !important;
width: 72px;
} }
.login-east-panel, .login-west-panel { .login-east-panel, .login-west-panel {
@ -195,26 +194,103 @@ html,body {
} }
<%-- button --%> <%-- button --%>
.action-button { .z-button-os {
height: 30px; display: inline-block;
width: 48px; margin: 0px;
padding: 2px 10px;
font-size: 12px;
line-height: 20px;
text-align: center;
vertical-align: middle;
cursor: pointer;
background-color: #f5f5f5;
background-image: -moz-linear-gradient(top, #ffffff, #e6e6e6);
background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), to(#e6e6e6));
background-image: -webkit-linear-gradient(top, #ffffff, #e6e6e6);
background-image: -o-linear-gradient(top, #ffffff, #e6e6e6);
background-image: linear-gradient(to bottom, #ffffff, #e6e6e6);
background-repeat: repeat-x;
border: 1px solid #cccccc;
border-color: #e6e6e6 #e6e6e6 #bfbfbf;
border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);
border-bottom-color: #b3b3b3;
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#ffe6e6e6', GradientType=0);
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false);
zoom: 1;
-webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
-moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
} }
.action-text-button { .z-button-os:hover,
height: 30px; .z-button-os:focus,
min-width: 80px; .z-button-os:active,
.z-button-os.active,
.z-button-os.disabled,
.z-button-os[disabled] {
color: #333333;
background-color: #e6e6e6;
} }
.action-image-text-button { .z-button-os:active,
height: 30px; .z-button-os.active {
min-width: 80px; background-color: #cccccc \9;
} }
.action-button .z-button-cm img, .z-button-os:hover,
.action-text-button .z-button-cm img, .z-button-os:focus {
.action-image-text-button .z-button-cm img { color: #333333;
text-decoration: none;
background-position: 0 -15px;
-webkit-transition: background-position 0.1s linear;
-moz-transition: background-position 0.1s linear;
-o-transition: background-position 0.1s linear;
transition: background-position 0.1s linear;
}
.z-button-os:focus {
outline: 5px auto -webkit-focus-ring-color;
}
.z-button-os.active,
.z-button-os:active {
background-image: none;
outline: 0;
-webkit-box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), 0 1px 2px rgba(0, 0, 0, 0.05);
-moz-box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), 0 1px 2px rgba(0, 0, 0, 0.05);
box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), 0 1px 2px rgba(0, 0, 0, 0.05);
}
.z-button-os.disabled,
.z-button-os[disabled] {
cursor: default;
background-image: none;
opacity: 0.65;
filter: alpha(opacity=65);
-webkit-box-shadow: none;
-moz-box-shadow: none;
box-shadow: none;
}
.img-btn img {
height: 22px; height: 22px;
width: 22px; width: 22px;
background-color: transparent;
}
.txt-btn img {
height: 16px;
width: 16px;
background-color: transparent;
vertical-align: middle;
display: inline-block;
}
.z-button-os.btn-small {
padding: 1px 5px;
} }
<%-- desktop --%> <%-- desktop --%>
@ -503,7 +579,7 @@ div.wc-modal, div.wc-modal-none, div.wc-highlighted, div.wc-highlighted-none {
width: 100%; width: 100%;
} }
.activities-box .z-button .z-button-cm { .activities-box .z-button-os {
text-align: left; text-align: left;
} }
@ -826,20 +902,19 @@ span.z-tree-tee, span.z-tree-last, span.z-tree-firstspacer {
width: 99%; width: 99%;
} }
.editor-box .editor-button { .editor-button {
width: 32px; padding: 3px 8px;
padding: 0px; margin: 0px;
} }
.editor-box .editor-button img { .editor-button img {
vertical-align: middle; vertical-align: middle;
text-align: center; text-align: center;
width: 10px; width: 10px;
height: 10px; height: 10px;
} }
.editor-box .editor-button-column { .editor-button-column {
width: 28px !important;
} }
.number-box { .number-box {
@ -1065,6 +1140,13 @@ tbody.z-grid-empty-body td {
margin-top: 6px; margin-top: 6px;
} }
.toolbar-popup-window.process-buttons-popup .z-button-os {
white-space: nowrap;
width: 95%;
text-align: left;
margin: auto;
}
.toolbar-popup-window-cnt { .toolbar-popup-window-cnt {
} }

View File

@ -6,7 +6,7 @@
<hbox height="100%" pack="center" align="left"> <hbox height="100%" pack="center" align="left">
<image id="logo"/> <image id="logo"/>
<div id="menuLookup"/> <div id="menuLookup"/>
<button id="menuButton"/> <button id="menuButton" sclass="btn-small"/>
</hbox> </hbox>
</west> </west>
<center sclass="desktop-header-right"> <center sclass="desktop-header-right">