IDEMPIERE-2427:ZK7 / Grid Customisation Available Choices not sorted by login language
This commit is contained in:
parent
be17f8a145
commit
997f145013
|
@ -15,8 +15,11 @@ package org.adempiere.webui.component;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.Comparator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.zkoss.lang.Objects;
|
||||||
import org.zkoss.zul.AbstractListModel;
|
import org.zkoss.zul.AbstractListModel;
|
||||||
import org.zkoss.zul.Listbox;
|
import org.zkoss.zul.Listbox;
|
||||||
import org.zkoss.zul.Listcell;
|
import org.zkoss.zul.Listcell;
|
||||||
|
@ -24,13 +27,14 @@ import org.zkoss.zul.Listitem;
|
||||||
import org.zkoss.zul.ListitemRenderer;
|
import org.zkoss.zul.ListitemRenderer;
|
||||||
import org.zkoss.zul.ListitemRendererExt;
|
import org.zkoss.zul.ListitemRendererExt;
|
||||||
import org.zkoss.zul.event.ListDataEvent;
|
import org.zkoss.zul.event.ListDataEvent;
|
||||||
|
import org.zkoss.zul.ext.Sortable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Low Heng Sin
|
* @author Low Heng Sin
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class SimpleListModel extends AbstractListModel<Object> implements ListitemRenderer<Object>, ListitemRendererExt {
|
public class SimpleListModel extends AbstractListModel<Object> implements ListitemRenderer<Object>, ListitemRendererExt, Sortable<Object> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -39,6 +43,10 @@ public class SimpleListModel extends AbstractListModel<Object> implements Listit
|
||||||
|
|
||||||
protected List<Object> list;
|
protected List<Object> list;
|
||||||
|
|
||||||
|
private Comparator<Object> _sorting;
|
||||||
|
|
||||||
|
private boolean _sortDir;
|
||||||
|
|
||||||
private int[] maxLength;
|
private int[] maxLength;
|
||||||
|
|
||||||
public SimpleListModel() {
|
public SimpleListModel() {
|
||||||
|
@ -50,6 +58,7 @@ public class SimpleListModel extends AbstractListModel<Object> implements Listit
|
||||||
this.list = (List<Object>)list;
|
this.list = (List<Object>)list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Object getElementAt(int index) {
|
public Object getElementAt(int index) {
|
||||||
if (index >= 0 && index < list.size())
|
if (index >= 0 && index < list.size())
|
||||||
return list.get(index);
|
return list.get(index);
|
||||||
|
@ -57,6 +66,7 @@ public class SimpleListModel extends AbstractListModel<Object> implements Listit
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public int getSize() {
|
public int getSize() {
|
||||||
return list.size();
|
return list.size();
|
||||||
}
|
}
|
||||||
|
@ -111,14 +121,17 @@ public class SimpleListModel extends AbstractListModel<Object> implements Listit
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public int getControls() {
|
public int getControls() {
|
||||||
return DETACH_ON_RENDER;
|
return DETACH_ON_RENDER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Listcell newListcell(Listitem item) {
|
public Listcell newListcell(Listitem item) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Listitem newListitem(Listbox listbox) {
|
public Listitem newListitem(Listbox listbox) {
|
||||||
ListItem item = new ListItem();
|
ListItem item = new ListItem();
|
||||||
item.applyProperties();
|
item.applyProperties();
|
||||||
|
@ -159,4 +172,20 @@ public class SimpleListModel extends AbstractListModel<Object> implements Listit
|
||||||
public int indexOf(Object value) {
|
public int indexOf(Object value) {
|
||||||
return list.indexOf(value);
|
return list.indexOf(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void sort(Comparator<Object> cmpr, boolean ascending) {
|
||||||
|
_sorting = cmpr;
|
||||||
|
_sortDir = ascending;
|
||||||
|
Collections.sort(list, cmpr);
|
||||||
|
fireEvent(ListDataEvent.STRUCTURE_CHANGED, -1, -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getSortDirection(Comparator<Object> cmpr) {
|
||||||
|
if (Objects.equals(_sorting, cmpr))
|
||||||
|
return _sortDir ?
|
||||||
|
"ascending" : "descending";
|
||||||
|
return "natural";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,7 @@ package org.adempiere.webui.panel;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.Comparator;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -41,11 +42,13 @@ 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.theme.ThemeManager;
|
||||||
import org.adempiere.webui.window.FDialog;
|
import org.adempiere.webui.window.FDialog;
|
||||||
|
import org.compiere.model.I_AD_Field;
|
||||||
import org.compiere.model.MField;
|
import org.compiere.model.MField;
|
||||||
import org.compiere.model.MRefList;
|
import org.compiere.model.MRefList;
|
||||||
import org.compiere.model.MRole;
|
import org.compiere.model.MRole;
|
||||||
import org.compiere.model.MTab;
|
import org.compiere.model.MTab;
|
||||||
import org.compiere.model.Query;
|
import org.compiere.model.Query;
|
||||||
|
import org.compiere.model.X_AD_Tab_Customization;
|
||||||
import org.compiere.util.CLogger;
|
import org.compiere.util.CLogger;
|
||||||
import org.compiere.util.Env;
|
import org.compiere.util.Env;
|
||||||
import org.compiere.util.Msg;
|
import org.compiere.util.Msg;
|
||||||
|
@ -144,10 +147,11 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
|
|
||||||
yesList.setVflex(true);
|
yesList.setVflex(true);
|
||||||
noList.setVflex(true);
|
noList.setVflex(true);
|
||||||
|
|
||||||
EventListener<Event> mouseListener = new EventListener<Event>()
|
EventListener<Event> mouseListener = new EventListener<Event>()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@Override
|
||||||
public void onEvent(Event event) throws Exception
|
public void onEvent(Event event) throws Exception
|
||||||
{
|
{
|
||||||
if (Events.ON_DOUBLE_CLICK.equals(event.getName()))
|
if (Events.ON_DOUBLE_CLICK.equals(event.getName()))
|
||||||
|
@ -161,6 +165,7 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
//
|
//
|
||||||
EventListener<Event> actionListener = new EventListener<Event>()
|
EventListener<Event> actionListener = new EventListener<Event>()
|
||||||
{
|
{
|
||||||
|
@Override
|
||||||
public void onEvent(Event event) throws Exception {
|
public void onEvent(Event event) throws Exception {
|
||||||
migrateValueAcrossLists(event);
|
migrateValueAcrossLists(event);
|
||||||
}
|
}
|
||||||
|
@ -184,6 +189,7 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
|
|
||||||
actionListener = new EventListener<Event>()
|
actionListener = new EventListener<Event>()
|
||||||
{
|
{
|
||||||
|
@Override
|
||||||
public void onEvent(Event event) throws Exception {
|
public void onEvent(Event event) throws Exception {
|
||||||
migrateValueWithinYesList(event);
|
migrateValueWithinYesList(event);
|
||||||
}
|
}
|
||||||
|
@ -214,7 +220,10 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
listHead.setParent(noList);
|
listHead.setParent(noList);
|
||||||
listHeader = new ListHeader();
|
listHeader = new ListHeader();
|
||||||
listHeader.appendChild(noLabel);
|
listHeader.appendChild(noLabel);
|
||||||
|
listHeader.setSort("auto");
|
||||||
|
listHeader.setSortDirection("ascending");
|
||||||
|
//http://books.zkoss.org/wiki/ZK%20Configuration%20Reference/zk.xml/The%20Library%20Properties/org.zkoss.zul.listbox.autoSort
|
||||||
|
noList.setAttribute("org.zkoss.zul.listbox.autoSort", "true");
|
||||||
Hlayout noButtonLayout = new Hlayout();
|
Hlayout noButtonLayout = new Hlayout();
|
||||||
|
|
||||||
noButtonLayout.appendChild(bRemove);
|
noButtonLayout.appendChild(bRemove);
|
||||||
|
@ -268,6 +277,7 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
LayoutUtils.addSclass("dialog-footer", confirmPanel);
|
LayoutUtils.addSclass("dialog-footer", confirmPanel);
|
||||||
|
|
||||||
EventListener<Event> onClickListener = new EventListener<Event>() {
|
EventListener<Event> onClickListener = new EventListener<Event>() {
|
||||||
|
@Override
|
||||||
public void onEvent(Event event) throws Exception {
|
public void onEvent(Event event) throws Exception {
|
||||||
if (event.getTarget().equals(
|
if (event.getTarget().equals(
|
||||||
confirmPanel.getButton(ConfirmPanel.A_OK))) {
|
confirmPanel.getButton(ConfirmPanel.A_OK))) {
|
||||||
|
@ -298,7 +308,7 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
boolean baseLanguage = Env.isBaseLanguage(Env.getCtx(), "AD_Field");
|
boolean baseLanguage = Env.isBaseLanguage(Env.getCtx(), "AD_Field");
|
||||||
Query query = null;
|
Query query = null;
|
||||||
|
|
||||||
query = new Query(Env.getCtx(), MField.Table_Name, "AD_Tab_ID=? AND (IsDisplayed='Y' OR IsDisplayedGrid='Y') AND IsActive='Y'", null);
|
query = new Query(Env.getCtx(), I_AD_Field.Table_Name, "AD_Tab_ID=? AND (IsDisplayed='Y' OR IsDisplayedGrid='Y') AND IsActive='Y'", null);
|
||||||
query.setOrderBy("SeqNoGrid, Name, SeqNo");
|
query.setOrderBy("SeqNoGrid, Name, SeqNo");
|
||||||
query.setParameters(new Object [] {m_AD_Tab_ID});
|
query.setParameters(new Object [] {m_AD_Tab_ID});
|
||||||
query.setApplyAccessFilter(true);
|
query.setApplyAccessFilter(true);
|
||||||
|
@ -319,7 +329,7 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
if (baseLanguage)
|
if (baseLanguage)
|
||||||
name = field.getName();
|
name = field.getName();
|
||||||
else
|
else
|
||||||
name = field.get_Translation(MField.COLUMNNAME_Name);
|
name = field.get_Translation(I_AD_Field.COLUMNNAME_Name);
|
||||||
|
|
||||||
ListElement pp = new ListElement(key, name);
|
ListElement pp = new ListElement(key, name);
|
||||||
if (tableSeqs != null && tableSeqs.size() > 0 ) {
|
if (tableSeqs != null && tableSeqs.size() > 0 ) {
|
||||||
|
@ -359,7 +369,7 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
|
|
||||||
ValueNamePair pp = new ValueNamePair(null, null);
|
ValueNamePair pp = new ValueNamePair(null, null);
|
||||||
lstGridMode.addItem(pp);
|
lstGridMode.addItem(pp);
|
||||||
ValueNamePair[] list = MRefList.getList(Env.getCtx(), MTabCustomization.ISDISPLAYEDGRID_AD_Reference_ID, false);
|
ValueNamePair[] list = MRefList.getList(Env.getCtx(), X_AD_Tab_Customization.ISDISPLAYEDGRID_AD_Reference_ID, false);
|
||||||
for (int i = 0;i < list.length; i++ ) {
|
for (int i = 0;i < list.length; i++ ) {
|
||||||
lstGridMode.addItem(list[i]);
|
lstGridMode.addItem(list[i]);
|
||||||
if (m_tabcust != null && list[i].getValue().equals(m_tabcust.getIsDisplayedGrid()))
|
if (m_tabcust != null && list[i].getValue().equals(m_tabcust.getIsDisplayedGrid()))
|
||||||
|
@ -637,8 +647,7 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/**
|
||||||
/**
|
|
||||||
* @author eslatis
|
* @author eslatis
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -652,6 +661,7 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void onEvent(Event event) throws Exception {
|
public void onEvent(Event event) throws Exception {
|
||||||
if (event instanceof DropEvent)
|
if (event instanceof DropEvent)
|
||||||
{
|
{
|
||||||
|
@ -669,7 +679,6 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
Listbox listTo = (Listbox)endItem.getListbox();
|
Listbox listTo = (Listbox)endItem.getListbox();
|
||||||
endIndex = yesList.getIndexOfItem(endItem);
|
endIndex = yesList.getIndexOfItem(endItem);
|
||||||
migrateLists (listFrom,listTo,endIndex);
|
migrateLists (listFrom,listTo,endIndex);
|
||||||
|
|
||||||
}else if (startItem.getListbox() == endItem.getListbox() && startItem.getListbox() == yesList)
|
}else if (startItem.getListbox() == endItem.getListbox() && startItem.getListbox() == yesList)
|
||||||
{
|
{
|
||||||
List<ListElement> selObjects = new ArrayList<ListElement>();
|
List<ListElement> selObjects = new ArrayList<ListElement>();
|
||||||
|
@ -718,3 +727,4 @@ public class CustomizeGridViewPanel extends Panel
|
||||||
}
|
}
|
||||||
|
|
||||||
} //CustomizeGridViewPanel
|
} //CustomizeGridViewPanel
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue