IDEMPIERE-724 Zk: Make iDempiere theme more easily customizable. More efficient use of spaces and additional css class for sort tab.
This commit is contained in:
parent
03cbf184f3
commit
479df69cac
|
@ -35,6 +35,7 @@ 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.factory.ButtonFactory;
|
||||||
|
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;
|
||||||
import org.compiere.model.MRole;
|
import org.compiere.model.MRole;
|
||||||
|
@ -51,7 +52,6 @@ import org.zkoss.zk.ui.event.EventListener;
|
||||||
import org.zkoss.zk.ui.event.Events;
|
import org.zkoss.zk.ui.event.Events;
|
||||||
import org.zkoss.zk.ui.util.Clients;
|
import org.zkoss.zk.ui.util.Clients;
|
||||||
import org.zkoss.zul.Hlayout;
|
import org.zkoss.zul.Hlayout;
|
||||||
import org.zkoss.zul.Vbox;
|
|
||||||
import org.zkoss.zul.event.ListDataEvent;
|
import org.zkoss.zul.event.ListDataEvent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -110,10 +110,10 @@ public class ADSortTab extends Panel implements IADTabpanel
|
||||||
// UI variables
|
// UI variables
|
||||||
private Label noLabel = new Label();
|
private Label noLabel = new Label();
|
||||||
private Label yesLabel = new Label();
|
private Label yesLabel = new Label();
|
||||||
private Button bAdd = ButtonFactory.createNamedButton("Next", false, true);
|
private Button bAdd = ButtonFactory.createButton(null, ThemeManager.getThemeResource("images/MoveLeft16.png"), null);
|
||||||
private Button bRemove = ButtonFactory.createNamedButton("Previous", false, true);
|
private Button bRemove = ButtonFactory.createButton(null, ThemeManager.getThemeResource("images/MoveRight16.png"), null);
|
||||||
private Button bUp = ButtonFactory.createNamedButton("Parent", false, true);
|
private Button bUp = ButtonFactory.createButton(null, ThemeManager.getThemeResource("images/MoveUp16.png"), null);
|
||||||
private Button bDown = ButtonFactory.createNamedButton("Detail", false, true);
|
private Button bDown = ButtonFactory.createButton(null, ThemeManager.getThemeResource("images/MoveDown16.png"), null);
|
||||||
//
|
//
|
||||||
SimpleListModel noModel = new SimpleListModel() {
|
SimpleListModel noModel = new SimpleListModel() {
|
||||||
/**
|
/**
|
||||||
|
@ -291,9 +291,11 @@ public class ADSortTab extends Panel implements IADTabpanel
|
||||||
noModel.setMultiple(true);
|
noModel.setMultiple(true);
|
||||||
|
|
||||||
LayoutUtils.addSclass("btn-small", bAdd);
|
LayoutUtils.addSclass("btn-small", bAdd);
|
||||||
|
LayoutUtils.addSclass("btn-sorttab small-img-btn", bAdd);
|
||||||
bAdd.addEventListener(Events.ON_CLICK, actionListener);
|
bAdd.addEventListener(Events.ON_CLICK, actionListener);
|
||||||
|
|
||||||
LayoutUtils.addSclass("btn-small", bRemove);
|
LayoutUtils.addSclass("btn-small", bRemove);
|
||||||
|
LayoutUtils.addSclass("btn-sorttab small-img-btn", bRemove);
|
||||||
bRemove.addEventListener(Events.ON_CLICK, actionListener);
|
bRemove.addEventListener(Events.ON_CLICK, actionListener);
|
||||||
|
|
||||||
EventListener<Event> crossListMouseListener = new DragListener();
|
EventListener<Event> crossListMouseListener = new DragListener();
|
||||||
|
@ -310,21 +312,33 @@ public class ADSortTab extends Panel implements IADTabpanel
|
||||||
};
|
};
|
||||||
|
|
||||||
LayoutUtils.addSclass("btn-small", bUp);
|
LayoutUtils.addSclass("btn-small", bUp);
|
||||||
|
LayoutUtils.addSclass("btn-sorttab small-img-btn", bUp);
|
||||||
bUp.addEventListener(Events.ON_CLICK, actionListener2);
|
bUp.addEventListener(Events.ON_CLICK, actionListener2);
|
||||||
|
|
||||||
LayoutUtils.addSclass("btn-small", bDown);
|
LayoutUtils.addSclass("btn-small", bDown);
|
||||||
|
LayoutUtils.addSclass("btn-sorttab small-img-btn", bDown);
|
||||||
bDown.addEventListener(Events.ON_CLICK, actionListener2);
|
bDown.addEventListener(Events.ON_CLICK, actionListener2);
|
||||||
|
|
||||||
ListHead listHead = new ListHead();
|
ListHead listHead = new ListHead();
|
||||||
listHead.setParent(yesList);
|
listHead.setParent(yesList);
|
||||||
ListHeader listHeader = new ListHeader();
|
ListHeader listHeader = new ListHeader();
|
||||||
listHeader.appendChild(yesLabel);
|
listHeader.appendChild(yesLabel);
|
||||||
|
Hlayout yesButtonLayout = new Hlayout();
|
||||||
|
yesButtonLayout.appendChild(bUp);
|
||||||
|
yesButtonLayout.appendChild(bDown);
|
||||||
|
listHeader.appendChild(yesButtonLayout);
|
||||||
|
yesButtonLayout.setStyle("display: inline-block; float: right;");
|
||||||
listHeader.setParent(listHead);
|
listHeader.setParent(listHead);
|
||||||
|
|
||||||
listHead = new ListHead();
|
listHead = new ListHead();
|
||||||
listHead.setParent(noList);
|
listHead.setParent(noList);
|
||||||
listHeader = new ListHeader();
|
listHeader = new ListHeader();
|
||||||
listHeader.appendChild(noLabel);
|
listHeader.appendChild(noLabel);
|
||||||
|
Hlayout noButtonLayout = new Hlayout();
|
||||||
|
noButtonLayout.appendChild(bRemove);
|
||||||
|
noButtonLayout.appendChild(bAdd);
|
||||||
|
listHeader.appendChild(noButtonLayout);
|
||||||
|
noButtonLayout.setStyle("display: inline-block; float: right;");
|
||||||
listHeader.setParent(listHead);
|
listHeader.setParent(listHead);
|
||||||
|
|
||||||
Hlayout hlayout = new Hlayout();
|
Hlayout hlayout = new Hlayout();
|
||||||
|
@ -335,21 +349,10 @@ public class ADSortTab extends Panel implements IADTabpanel
|
||||||
noList.setHflex("1");
|
noList.setHflex("1");
|
||||||
noList.setVflex(true);
|
noList.setVflex(true);
|
||||||
hlayout.appendChild(noList);
|
hlayout.appendChild(noList);
|
||||||
Vbox vbox = new Vbox();
|
|
||||||
vbox.appendChild(bAdd);
|
|
||||||
vbox.appendChild(bRemove);
|
|
||||||
vbox.setWidth("46px");
|
|
||||||
vbox.setAlign("center");
|
|
||||||
hlayout.appendChild(vbox);
|
|
||||||
|
|
||||||
yesList.setVflex(true);
|
yesList.setVflex(true);
|
||||||
yesList.setHflex("1");
|
yesList.setHflex("1");
|
||||||
hlayout.appendChild(yesList);
|
hlayout.appendChild(yesList);
|
||||||
vbox = new Vbox();
|
|
||||||
vbox.appendChild(bUp);
|
|
||||||
vbox.appendChild(bDown);
|
|
||||||
vbox.setWidth("46px");
|
|
||||||
hlayout.appendChild(vbox);
|
|
||||||
|
|
||||||
addEventListener(ON_ACTIVATE_EVENT, new EventListener<Event>() {
|
addEventListener(ON_ACTIVATE_EVENT, new EventListener<Event>() {
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -316,7 +316,7 @@ html,body {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
}
|
}
|
||||||
|
|
||||||
.txt-btn img {
|
.txt-btn img, .small-img-btn img {
|
||||||
height: 16px;
|
height: 16px;
|
||||||
width: 16px;
|
width: 16px;
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
|
@ -328,6 +328,13 @@ html,body {
|
||||||
padding: 1px 5px;
|
padding: 1px 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.btn-sorttab {
|
||||||
|
box-shadow: 0px 0px 4px #bbb;
|
||||||
|
color: #555;
|
||||||
|
border: solid 1px #bbb;
|
||||||
|
text-shadow: 0px 1px 2px #888;
|
||||||
|
}
|
||||||
|
|
||||||
<%-- desktop --%>
|
<%-- desktop --%>
|
||||||
div.wc-modal, div.wc-modal-none, div.wc-highlighted, div.wc-highlighted-none {
|
div.wc-modal, div.wc-modal-none, div.wc-highlighted, div.wc-highlighted-none {
|
||||||
background-color: white;
|
background-color: white;
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 1.1 KiB |
Binary file not shown.
After Width: | Height: | Size: 2.8 KiB |
Binary file not shown.
After Width: | Height: | Size: 2.8 KiB |
Binary file not shown.
After Width: | Height: | Size: 1005 B |
Loading…
Reference in New Issue