IDEMPIERE-369 Master Detail layout improvements. Performance tuning - reduce use of borderlayout.
This commit is contained in:
parent
caf7b53e5e
commit
45d88ff3ab
|
@ -189,6 +189,7 @@ DataStatusListener, IADTabpanel, IdSpace
|
|||
removeAttribute(ATTR_ON_ACTIVATE_POSTED);
|
||||
}
|
||||
});
|
||||
addEventListener("onPostInit", this);
|
||||
}
|
||||
|
||||
private void initComponents()
|
||||
|
@ -930,6 +931,11 @@ DataStatusListener, IADTabpanel, IdSpace
|
|||
else if (WPaymentEditor.ON_SAVE_PAYMENT.equals(event.getName())) {
|
||||
windowPanel.onSavePayment();
|
||||
}
|
||||
else if ("onPostInit".equals(event.getName())) {
|
||||
if (detailPane != null) {
|
||||
Events.postEvent(new Event(LayoutUtils.ON_REDRAW_EVENT, detailPane));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void navigateTo(DefaultTreeNode<MTreeNode> value) {
|
||||
|
|
|
@ -36,12 +36,9 @@ import org.zkoss.zk.ui.event.Event;
|
|||
import org.zkoss.zk.ui.event.EventListener;
|
||||
import org.zkoss.zk.ui.event.Events;
|
||||
import org.zkoss.zk.ui.event.KeyEvent;
|
||||
import org.zkoss.zul.Borderlayout;
|
||||
import org.zkoss.zul.Center;
|
||||
import org.zkoss.zul.Div;
|
||||
import org.zkoss.zul.North;
|
||||
import org.zkoss.zul.South;
|
||||
import org.zkoss.zul.Tab;
|
||||
import org.zkoss.zul.Vlayout;
|
||||
|
||||
/**
|
||||
*
|
||||
|
@ -58,9 +55,9 @@ public class ADWindowContent extends AbstractADWindowContent
|
|||
@SuppressWarnings("unused")
|
||||
private static final CLogger logger = CLogger.getCLogger(ADWindowContent.class);
|
||||
|
||||
private Borderlayout layout;
|
||||
private Vlayout layout;
|
||||
|
||||
private Center contentArea;
|
||||
private Div contentArea;
|
||||
|
||||
private Keylistener keyListener;
|
||||
|
||||
|
@ -71,7 +68,7 @@ public class ADWindowContent extends AbstractADWindowContent
|
|||
|
||||
protected Component doCreatePart(Component parent)
|
||||
{
|
||||
layout = new Borderlayout();
|
||||
layout = new Vlayout();
|
||||
if (parent != null) {
|
||||
layout.setParent(parent);
|
||||
layout.setSclass("adwindow-layout");
|
||||
|
@ -80,14 +77,13 @@ public class ADWindowContent extends AbstractADWindowContent
|
|||
}
|
||||
|
||||
//toolbar
|
||||
North n = new North();
|
||||
n.setParent(layout);
|
||||
n.setCollapsible(false);
|
||||
n.setSclass("adwindow-north");
|
||||
Div north = new Div();
|
||||
north.setParent(layout);
|
||||
north.setSclass("adwindow-north");
|
||||
Div div = new Div();
|
||||
div.setHflex("1");
|
||||
div.setVflex("1");
|
||||
n.appendChild(div);
|
||||
div.setStyle("height: 100%; width: 100%");
|
||||
north.appendChild(div);
|
||||
north.setVflex("0");
|
||||
toolbar.setParent(div);
|
||||
toolbar.setWindowNo(getWindowNo());
|
||||
breadCrumb = new BreadCrumb(getWindowNo());
|
||||
|
@ -96,19 +92,22 @@ public class ADWindowContent extends AbstractADWindowContent
|
|||
div.appendChild(breadCrumb);
|
||||
|
||||
//status bar
|
||||
South s = new South();
|
||||
layout.appendChild(s);
|
||||
s.setCollapsible(false);
|
||||
s.setSclass("adwindow-south");
|
||||
statusBar.setParent(s);
|
||||
Div south = new Div();
|
||||
south.setSclass("adwindow-south");
|
||||
south.setVflex("0");
|
||||
statusBar.setParent(south);
|
||||
|
||||
LayoutUtils.addSclass("adwindow-status", statusBar);
|
||||
|
||||
contentArea = new Center();
|
||||
contentArea = new Div();
|
||||
contentArea.setParent(layout);
|
||||
contentArea.setAutoscroll(true);
|
||||
contentArea.setVflex("1");
|
||||
contentArea.setHflex("1");
|
||||
contentArea.setStyle("overflow: auto;");
|
||||
adTabbox.createPart(contentArea);
|
||||
|
||||
layout.appendChild(south);
|
||||
|
||||
if (parent instanceof Tabpanel) {
|
||||
TabOnCloseHanlder handler = new TabOnCloseHanlder();
|
||||
((Tabpanel)parent).setOnCloseHandler(handler);
|
||||
|
@ -132,7 +131,7 @@ public class ADWindowContent extends AbstractADWindowContent
|
|||
return composite;
|
||||
}
|
||||
|
||||
public Borderlayout getComponent() {
|
||||
public Vlayout getComponent() {
|
||||
return layout;
|
||||
}
|
||||
|
||||
|
|
|
@ -586,6 +586,7 @@ public abstract class AbstractADWindowContent extends AbstractUIPart implements
|
|||
private void initFirstTabpanel() {
|
||||
adTabbox.getSelectedTabpanel().query(m_onlyCurrentRows, m_onlyCurrentDays, MRole.getDefault().getMaxQueryRecords());
|
||||
adTabbox.getSelectedTabpanel().activate(true);
|
||||
Events.echoEvent(new Event("onPostInit", adTabbox.getSelectedTabpanel()));
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -106,6 +106,8 @@ public class DetailPane extends Panel implements EventListener<Event>, IdSpace {
|
|||
|
||||
addEventListener(LayoutUtils.ON_REDRAW_EVENT, this);
|
||||
|
||||
addEventListener("onPostInit", this);
|
||||
|
||||
setId("detailPane");
|
||||
}
|
||||
|
||||
|
@ -405,6 +407,13 @@ public class DetailPane extends Panel implements EventListener<Event>, IdSpace {
|
|||
return;
|
||||
}
|
||||
LayoutUtils.redraw(this);
|
||||
} else if (event.getName().equals("onPostInit")) {
|
||||
IADTabpanel adtabpanel = getSelectedADTabpanel();
|
||||
if (adtabpanel != null) {
|
||||
GridView gridView = adtabpanel.getGridView();
|
||||
if (gridView != null && gridView.getListbox() != null)
|
||||
Clients.resize(gridView.getListbox());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -267,10 +267,17 @@ div.wc-modal, div.wc-modal-none, div.wc-highlighted, div.wc-highlighted-none {
|
|||
}
|
||||
|
||||
.menu-search-panel .z-comboitem-img {
|
||||
vertical-align:top;
|
||||
padding-bottom:4px;
|
||||
}
|
||||
|
||||
.z-comboitem-img {
|
||||
vertical-align:top;
|
||||
}
|
||||
|
||||
.z-combobox input {
|
||||
vertical-align:top;
|
||||
}
|
||||
|
||||
.menu-panel .z-toolbar-panel {
|
||||
padding-right: 0;
|
||||
}
|
||||
|
@ -477,16 +484,18 @@ div.wc-modal, div.wc-modal-none, div.wc-highlighted, div.wc-highlighted-none {
|
|||
}
|
||||
|
||||
.adwindow-north {
|
||||
height: 56px;
|
||||
width: 100%;
|
||||
padding: 0px;
|
||||
margin: 0px;
|
||||
border: none;
|
||||
border-bottom: 1px solid #C5C5C5 !important;
|
||||
}
|
||||
|
||||
.adwindow-south {
|
||||
border-left: none;
|
||||
border-right: none;
|
||||
}
|
||||
|
||||
.adwindow-layout .z-south {
|
||||
height: 20px;
|
||||
width: 100%;
|
||||
padding: 0px;
|
||||
margin: 0px;
|
||||
border-top: 1px solid #C5C5C5 !important;
|
||||
}
|
||||
|
||||
|
@ -497,12 +506,15 @@ div.wc-modal, div.wc-modal-none, div.wc-highlighted, div.wc-highlighted-none {
|
|||
|
||||
.adwindow-toolbar {
|
||||
border: 0px;
|
||||
height: 26px;
|
||||
}
|
||||
|
||||
.adwindow-breadcrumb {
|
||||
height: 30px;
|
||||
background-color: #FFF;
|
||||
padding: 0px;
|
||||
padding-left: 5px;
|
||||
border-bottom: 1px solid #C5C5C5 !important;
|
||||
}
|
||||
|
||||
.adwindow-detailpane {
|
||||
|
|
Loading…
Reference in New Issue