* minor numberbox layout enhancement

* [2308105] WListbox should always re-render when row is select/deselect.
  - previous patch break InfoPanel
* Editable grid view
This commit is contained in:
Heng Sin Low 2008-11-21 20:27:15 +00:00
parent 02378c140d
commit 23f4b5e5ae
28 changed files with 770 additions and 366 deletions

View File

@ -27,9 +27,11 @@ import org.adempiere.webui.LayoutUtils;
import org.compiere.model.GridField;
import org.compiere.model.GridTab;
import org.compiere.model.GridTable;
import org.zkoss.zk.au.out.AuEcho;
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.util.Clients;
import org.zkoss.zkex.zul.Borderlayout;
import org.zkoss.zkex.zul.Center;
import org.zkoss.zkex.zul.South;
@ -69,6 +71,8 @@ public class GridPanel extends Borderlayout implements EventListener
private Paging paging;
private GridTabListItemRenderer renderer;
public GridPanel()
{
super();
@ -136,13 +140,21 @@ public class GridPanel extends Borderlayout implements EventListener
}
if (paging.getActivePage() != pgNo)
paging.setActivePage(pgNo);
if (listbox.getSelectedIndex() != pgIndex)
if (listbox.getSelectedIndex() != pgIndex) {
renderer.stopEditing(false);
listModel.updateComponent(listbox.getSelectedIndex());
listModel.updateComponent(pgIndex);
listbox.setSelectedIndex(pgIndex);
}
} else {
if (listbox.getSelectedIndex() != rowIndex)
if (listbox.getSelectedIndex() != rowIndex) {
renderer.stopEditing(false);
listModel.updateComponent(listbox.getSelectedIndex());
listModel.updateComponent(rowIndex);
listbox.setSelectedIndex(rowIndex);
}
}
}
public void setPageSize(int pageSize)
{
@ -207,7 +219,8 @@ public class GridPanel extends Borderlayout implements EventListener
center.appendChild(listbox);
this.appendChild(center);
if (pageSize > 0) {
if (pageSize > 0)
{
paging = new Paging();
paging.setPageSize(pageSize);
paging.setTotalSize(tableModel.getRowCount());
@ -216,13 +229,25 @@ public class GridPanel extends Borderlayout implements EventListener
south.appendChild(paging);
this.appendChild(south);
paging.addEventListener(ZulEvents.ON_PAGING, this);
//workaround for layout problem
this.setVisible(false);
Clients.response(new AuEcho(this, "postRender", null));
}
}
public void postRender()
{
this.setVisible(true);
this.getParent().invalidate();
}
private void updateModel() {
listModel = new GridTableListModel((GridTable)tableModel, windowNo);
listModel.setPageSize(pageSize);
listbox.setItemRenderer(listModel);
if (renderer != null)
renderer.stopEditing(false);
renderer = new GridTabListItemRenderer(gridTab, windowNo);
listbox.setItemRenderer(renderer);
listbox.setModel(listModel);
}
@ -239,7 +264,8 @@ public class GridPanel extends Borderlayout implements EventListener
return;
else if (event.getTarget() == listbox)
{
updateModelIndex();
int index = listbox.getSelectedIndex();
onSelectedRowChange(index);
}
else if (event.getTarget() == paging)
{
@ -249,20 +275,34 @@ public class GridPanel extends Borderlayout implements EventListener
listbox.clearSelection();
listModel.setPage(pgNo);
listbox.setSelectedIndex(0);
updateModelIndex();
onSelectedRowChange(0);
}
}
}
private void updateModelIndex() {
private void onSelectedRowChange(int index) {
if (updateModelIndex()) {
listModel.updateComponent(index);
listbox.setSelectedIndex(index);
} else if (!renderer.isInitialize()) {
listModel.updateComponent(index);
listbox.setSelectedIndex(index);
}
}
private boolean updateModelIndex() {
int rowIndex = listbox.getSelectedIndex();
if (pageSize > 0) {
int start = listModel.getPage() * listModel.getPageSize();
rowIndex = start + rowIndex;
}
if (gridTab.getCurrentRow() != rowIndex)
if (gridTab.getCurrentRow() != rowIndex) {
renderer.stopEditing(true);
gridTab.navigate(rowIndex);
return true;
}
return false;
}
public Listbox getListbox() {

View File

@ -0,0 +1,258 @@
/******************************************************************************
* Copyright (C) 2008 Low Heng Sin *
* 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.component;
import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import org.adempiere.webui.editor.WEditor;
import org.adempiere.webui.editor.WEditorPopupMenu;
import org.adempiere.webui.editor.WebEditorFactory;
import org.adempiere.webui.event.ContextMenuListener;
import org.adempiere.webui.util.GridTabDataBinder;
import org.compiere.model.GridField;
import org.compiere.model.GridTab;
import org.compiere.model.MAccountLookup;
import org.compiere.model.MLookup;
import org.compiere.model.MLookupFactory;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.NamePair;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
import org.zkoss.zul.Listbox;
import org.zkoss.zul.Listcell;
import org.zkoss.zul.Listitem;
import org.zkoss.zul.ListitemRenderer;
import org.zkoss.zul.ListitemRendererExt;
/**
* ListItem renderer for GridTab list box.
* @author hengsin
*
*/
public class GridTabListItemRenderer implements ListitemRenderer, ListitemRendererExt {
private GridTab gridTab;
private int windowNo;
private GridTabDataBinder dataBinder;
private Map<GridField, WEditor> editors = new HashMap<GridField, WEditor>();
/**
*
* @param gridTab
* @param windowNo
*/
public GridTabListItemRenderer(GridTab gridTab, int windowNo) {
this.gridTab = gridTab;
this.windowNo = windowNo;
this.dataBinder = new GridTabDataBinder(gridTab);
}
/**
* @param listitem
* @param data
* @see ListitemRenderer#render(Listitem, Object)
*/
public void render(Listitem listitem, Object data) throws Exception {
Object[] values = (Object[])data;
int columnCount = gridTab.getTableModel().getColumnCount();
GridField[] gridField = gridTab.getFields();
for (int i = 0; i < columnCount; i++) {
if (!gridField[i].isDisplayed()) {
continue;
}
if (editors.get(gridField[i]) == null)
editors.put(gridField[i], WebEditorFactory.getEditor(gridField[i], true));
int rowIndex = listitem.getIndex();
Listcell cell = null;
if (rowIndex == gridTab.getCurrentRow() && gridField[i].isEditable(true)) {
cell = getEditorCell(gridField[i], values[i], i);
cell.setParent(listitem);
} else {
if (gridField[i].getDisplayType() == DisplayType.YesNo) {
cell = new Listcell("", null);
cell.setParent(listitem);
cell.setStyle("text-align:center");
createReadonlyCheckbox(values[i], cell);
} else {
cell = new Listcell(getDisplayText(values[i], i), null);
cell.setParent(listitem);
}
}
CellListener listener = new CellListener((Listbox) listitem.getParent());
cell.addEventListener(Events.ON_DOUBLE_CLICK, listener);
}
}
private void createReadonlyCheckbox(Object value, Listcell cell) {
Checkbox checkBox = new Checkbox();
if (value != null && "true".equalsIgnoreCase(value.toString()))
checkBox.setChecked(true);
else
checkBox.setChecked(false);
checkBox.setDisabled(true);
checkBox.setParent(cell);
}
private Listcell getEditorCell(GridField gridField, Object object, int i) {
Listcell cell = new Listcell("", null);
WEditor editor = editors.get(gridField);
if (editor != null) {
editor.addValueChangeListener(dataBinder);
cell.appendChild(editor.getComponent());
gridField.addPropertyChangeListener(editor);
editor.setValue(gridField.getValue());
WEditorPopupMenu popupMenu = editor.getPopupMenu();
if (popupMenu != null)
{
popupMenu.addMenuListener((ContextMenuListener)editor);
cell.appendChild(popupMenu);
}
}
return cell;
}
/**
* Detach all editor and optionally set the current value of the editor as cell label.
* @param updateCellLabel
*/
public void stopEditing(boolean updateCellLabel) {
for (Entry<GridField, WEditor> entry : editors.entrySet()) {
if (entry.getValue().getComponent().getParent() != null) {
if (updateCellLabel) {
Listcell cell = (Listcell) entry.getValue().getComponent().getParent();
if (entry.getKey().getDisplayType() == DisplayType.YesNo) {
cell.setLabel("");
createReadonlyCheckbox(entry.getValue().getValue(), cell);
} else {
cell.setLabel(getDisplayText(entry.getValue().getValue(), getColumnIndex(entry.getKey())));
}
}
entry.getValue().getComponent().detach();
entry.getKey().removePropertyChangeListener(entry.getValue());
entry.getValue().removeValuechangeListener(dataBinder);
}
}
}
private int getColumnIndex(GridField field) {
GridField[] fields = gridTab.getFields();
for(int i = 0; i < fields.length; i++) {
if (fields[i] == field)
return i;
}
return 0;
}
/**
* @see ListitemRendererExt#getControls()
*/
public int getControls() {
return DETACH_ON_RENDER;
}
/**
* @param item
* @see ListitemRendererExt#newListcell(Listitem)
*/
public Listcell newListcell(Listitem item) {
ListCell listCell = new ListCell();
listCell.applyProperties();
listCell.setParent(item);
return listCell;
}
/**
* @param listbox
* @see ListitemRendererExt#newListitem(Listbox)
*/
public Listitem newListitem(Listbox listbox) {
ListItem item = new ListItem();
item.applyProperties();
return item;
}
private String getDisplayText(Object value, int columnIndex)
{
if (value == null)
return "";
GridField[] gridField = gridTab.getFields();
if (gridTab.getTableModel().getColumnClass(columnIndex).equals(Integer.class))
{
if (gridField[columnIndex].isLookup())
{
NamePair namepair = null;
if (gridField[columnIndex].getDisplayType() == DisplayType.Account)
{
MAccountLookup lookup = new MAccountLookup(Env.getCtx(), windowNo);
namepair = lookup.get(value);
}
else
{
MLookup lookup = MLookupFactory.get(
Env.getCtx(), windowNo, 0, gridField[columnIndex].getAD_Column_ID(),
gridField[columnIndex].getDisplayType());
namepair = lookup.get(value);
}
if (namepair != null)
return namepair.getName();
else
return "";
}
else
return value.toString();
}
else if (gridTab.getTableModel().getColumnClass(columnIndex).equals(Timestamp.class))
{
SimpleDateFormat dateFormat = DisplayType.getDateFormat(DisplayType.Date);
return dateFormat.format((Timestamp)value);
}
else
return value.toString();
}
class CellListener implements EventListener {
private Listbox _listbox;
public CellListener(Listbox listbox) {
_listbox = listbox;
}
public void onEvent(Event event) throws Exception {
if (Events.ON_DOUBLE_CLICK.equals(event.getName())) {
Event evt = new Event(Events.ON_DOUBLE_CLICK, _listbox);
Events.sendEvent(_listbox, evt);
}
}
}
/**
* Is renderer initialize
* @return boolean
*/
public boolean isInitialize() {
return !editors.isEmpty();
}
}

View File

@ -12,33 +12,17 @@
*****************************************************************************/
package org.adempiere.webui.component;
import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.Comparator;
import org.compiere.model.DataStatusEvent;
import org.compiere.model.DataStatusListener;
import org.compiere.model.GridField;
import org.compiere.model.GridTable;
import org.compiere.model.MAccountLookup;
import org.compiere.model.MLookup;
import org.compiere.model.MLookupFactory;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.NamePair;
import org.zkoss.zk.ui.Executions;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
import org.zkoss.zul.AbstractListModel;
import org.zkoss.zul.ListModel;
import org.zkoss.zul.ListModelExt;
import org.zkoss.zul.Listbox;
import org.zkoss.zul.Listcell;
import org.zkoss.zul.Listitem;
import org.zkoss.zul.ListitemComparator;
import org.zkoss.zul.ListitemRenderer;
import org.zkoss.zul.ListitemRendererExt;
import org.zkoss.zul.event.ListDataEvent;
/**
@ -46,8 +30,7 @@ import org.zkoss.zul.event.ListDataEvent;
* @author Low Heng Sin
*
*/
public class GridTableListModel extends AbstractListModel implements ListitemRenderer,
ListitemRendererExt, DataStatusListener, ListModelExt {
public class GridTableListModel extends AbstractListModel implements DataStatusListener, ListModelExt {
private GridTable tableModel;
private GridField[] gridField;
@ -148,124 +131,6 @@ ListitemRendererExt, DataStatusListener, ListModelExt {
}
}
/**
* @param listitem
* @param data
* @see ListitemRenderer#render(Listitem, Object)
*/
public void render(Listitem listitem, Object data) throws Exception {
Object[] values = (Object[])data;
int columnCount = tableModel.getColumnCount();
for (int i = 0; i < columnCount; i++) {
if (!gridField[i].isDisplayed()) {
continue;
}
Listcell cell = null;
if (gridField[i].getDisplayType() == DisplayType.YesNo) {
cell = new Listcell("", null);
cell.setParent(listitem);
cell.setStyle("text-align:center");
Checkbox checkBox = new Checkbox();
if (values[i] != null && "true".equalsIgnoreCase(values[i].toString()))
checkBox.setChecked(true);
else
checkBox.setChecked(false);
checkBox.setDisabled(true);
checkBox.setParent(cell);
} else {
cell = new Listcell(getCell(values[i], i), null);
cell.setParent(listitem);
}
CellListener listener = new CellListener((Listbox) listitem.getParent());
cell.addEventListener(Events.ON_DOUBLE_CLICK, listener);
}
}
class CellListener implements EventListener {
private Listbox _listbox;
public CellListener(Listbox listbox) {
_listbox = listbox;
}
public void onEvent(Event event) throws Exception {
if (Events.ON_DOUBLE_CLICK.equals(event.getName())) {
Event evt = new Event(Events.ON_DOUBLE_CLICK, _listbox);
Events.sendEvent(_listbox, evt);
}
}
}
private String getCell(Object obj, int columnIndex)
{
if (obj == null)
return "";
if (tableModel.getColumnClass(columnIndex).equals(Integer.class))
{
if (gridField[columnIndex].isLookup())
{
NamePair namepair = null;
if (gridField[columnIndex].getDisplayType() == DisplayType.Account)
{
MAccountLookup lookup = new MAccountLookup(Env.getCtx(), windowNo);
namepair = lookup.get(obj);
}
else
{
MLookup lookup = MLookupFactory.get(
Env.getCtx(), windowNo, 0, gridField[columnIndex].getAD_Column_ID(),
gridField[columnIndex].getDisplayType());
namepair = lookup.get(obj);
}
if (namepair != null)
return namepair.getName();
else
return "";
}
else
return obj.toString();
}
else if (tableModel.getColumnClass(columnIndex).equals(Timestamp.class))
{
SimpleDateFormat dateFormat = DisplayType.getDateFormat(DisplayType.Date);
return dateFormat.format((Timestamp)obj);
}
else
return obj.toString();
}
/**
* @see ListitemRendererExt#getControls()
*/
public int getControls() {
return DETACH_ON_RENDER;
}
/**
* @param item
* @see ListitemRendererExt#newListcell(Listitem)
*/
public Listcell newListcell(Listitem item) {
ListCell listCell = new ListCell();
listCell.applyProperties();
listCell.setParent(item);
return listCell;
}
/**
* @param listbox
* @see ListitemRendererExt#newListitem(Listbox)
*/
public Listitem newListitem(Listbox listbox) {
ListItem item = new ListItem();
item.applyProperties();
return item;
}
/**
* @param e
* @see DataStatusListener#dataStatusChanged(DataStatusEvent)
@ -277,6 +142,26 @@ ListitemRendererExt, DataStatusListener, ListModelExt {
}
/**
* Request components that attached to this model to re-render a row.
* @param row
*/
public void updateComponent(int row) {
updateComponent(row, row);
}
/**
* Request components that attached to this model to re-render a range of row.
* @param fromRow
* @param toRow
*/
public void updateComponent(int fromRow, int toRow) {
//must run from the UI thread
if (Executions.getCurrent() != null) {
fireEvent(ListDataEvent.CONTENTS_CHANGED, fromRow, toRow);
}
}
/**
* @param cmpr
* @param ascending

View File

@ -27,8 +27,10 @@ import java.util.Vector;
import org.adempiere.webui.event.WTableModelEvent;
import org.adempiere.webui.event.WTableModelListener;
import org.zkoss.zk.ui.Executions;
import org.zkoss.zul.ListModelExt;
import org.zkoss.zul.ListModelList;
import org.zkoss.zul.event.ListDataEvent;
/**
* This is a ListModel to be used with Listbox.
@ -362,4 +364,24 @@ public class ListModelTable extends ListModelList implements ListModelExt
public int getRowCount() {
return getSize();
}
/**
* Request components that attached to this model to re-render a row.
* @param row
*/
public void updateComponent(int row) {
updateComponent(row, row);
}
/**
* Request components that attached to this model to re-render a range of row.
* @param fromRow
* @param toRow
*/
public void updateComponent(int fromRow, int toRow) {
//must run from the UI thread
if (Executions.getCurrent() != null) {
fireEvent(ListDataEvent.CONTENTS_CHANGED, fromRow, toRow);
}
}
}

View File

@ -23,6 +23,9 @@ import java.text.ParseException;
import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.apps.AEnv;
import org.zkoss.zhtml.Table;
import org.zkoss.zhtml.Td;
import org.zkoss.zhtml.Tr;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
import org.zkoss.zul.Decimalbox;
@ -67,20 +70,40 @@ public class NumberBox extends Div
private void init()
{
Table grid = new Table();
appendChild(grid);
grid.setStyle("border: none; padding: 0px; margin: 0px;");
grid.setDynamicProperty("border", "0");
grid.setDynamicProperty("cellpadding", "0");
grid.setDynamicProperty("cellspacing", "0");
Tr tr = new Tr();
grid.appendChild(tr);
tr.setStyle("border: none; padding: 0px; margin: 0px; white-space:nowrap; ");
Td td = new Td();
tr.appendChild(td);
td.setStyle("border: none; padding: 0px; margin: 0px;");
decimalBox = new Decimalbox();
if (integral)
decimalBox.setScale(0);
decimalBox.setStyle("display: inline;");
td.appendChild(decimalBox);
Td btnColumn = new Td();
tr.appendChild(btnColumn);
btnColumn.setStyle("border: none; padding: 0px; margin: 0px;");
btnColumn.setSclass("editor-button");
btn = new Button();
btn.setImage("/images/Calculator10.png");
btn.setTabindex(-1);
LayoutUtils.addSclass("editor-button", btn);
btnColumn.appendChild(btn);
popup = getCalculatorPopup();
LayoutUtils.addSclass("editor-button", btn);
btn.setPopup(popup);
btn.setStyle("text-align: center;");
appendChild(decimalBox);
appendChild(btn);
appendChild(popup);
String style = AEnv.isFirefox2() ? "display: inline" : "display: inline-block";

View File

@ -936,6 +936,8 @@ public class WListbox extends Listbox implements TableValueChangeListener, WTabl
// if the event was caused by an ID Column and the value is a boolean
// then set the IDColumn's select field
if (col >= 0 && row >=0)
{
if (this.getValueAt(row, col) instanceof IDColumn
&& event.getNewValue() instanceof Boolean)
{
@ -949,6 +951,7 @@ public class WListbox extends Listbox implements TableValueChangeListener, WTabl
{
this.setValueAt(event.getNewValue(), row, col);
}
}
return;
}
@ -1008,9 +1011,20 @@ public class WListbox extends Listbox implements TableValueChangeListener, WTabl
{
this.repaint();
}
else
else if ((event.getType() == WTableModelEvent.CONTENTS_CHANGED)
&& event.getFirstRow() != WTableModelEvent.ALL_ROWS
&& !m_readWriteColumn.isEmpty())
{
this.setModel(this.getModel());
int[] indices = this.getSelectedIndices();
ListModelTable model = this.getModel();
if (event.getLastRow() > event.getFirstRow())
model.updateComponent(event.getFirstRow(), event.getLastRow());
else
model.updateComponent(event.getFirstRow());
if (indices != null && indices.length > 0)
{
this.setSelectedIndices(indices);
}
}
return;

View File

@ -36,7 +36,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WAccountEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE, Events.ON_FOCUS};
private MAccountLookup m_mAccount;
@ -173,6 +173,10 @@ public class WAccountEditor extends WEditor
{
cmd_button();
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
public String[] getEvents()

View File

@ -23,6 +23,8 @@ public class WAssignmentEditor extends WEditor {
private final static CLogger log = CLogger.getCLogger(WAssignmentEditor.class);
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_FOCUS};
private boolean m_readWrite;
private Object m_value;
private PreparedStatement m_pstmt;
@ -39,10 +41,15 @@ public class WAssignmentEditor extends WEditor {
private void initComponents() {
getComponent().getTextbox().setReadonly(true);
getComponent().setButtonImage("images/Assignment10.png");
getComponent().addEventListener(Events.ON_CLICK, this);
}
@Override
public String[] getEvents() {
return LISTENER_EVENTS;
}
@Override
public EditorBox getComponent() {
return (EditorBox) component;
@ -119,6 +126,8 @@ public class WAssignmentEditor extends WEditor {
public void onEvent(Event event) throws Exception {
//
if (Events.ON_CLICK.equalsIgnoreCase(event.getName()))
{
Integer oldValue = (Integer)getValue();
int S_ResourceAssignment_ID = oldValue == null ? 0 : oldValue.intValue();
MResourceAssignment ma = new MResourceAssignment(Env.getCtx(), S_ResourceAssignment_ID, null);
@ -144,5 +153,10 @@ public class WAssignmentEditor extends WEditor {
fireValueChange(vce);
}
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
}

View File

@ -26,7 +26,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WBinaryEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_FOCUS};
/** Logger */
private static CLogger log = CLogger.getCLogger(WBinaryEditor.class);
@ -45,8 +45,6 @@ public class WBinaryEditor extends WEditor
label.setValue(" ");
getComponent().setLabel("-");
getComponent().setTooltiptext(gridField.getDescription());
getComponent().addEventListener(Events.ON_CLICK, this);
}
@Override
@ -129,5 +127,9 @@ public class WBinaryEditor extends WEditor
if (!dialog.isCancel() && dialog.isChange())
m_data = dialog.getData();
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
}

View File

@ -48,7 +48,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WButtonEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_FOCUS};
private static final CLogger logger;
@ -100,7 +100,6 @@ public class WButtonEditor extends WEditor
label.setValue(" ");
getComponent().setLabel(gridField.getHeader());
getComponent().setTooltiptext(gridField.getDescription());
getComponent().addEventListener(Events.ON_CLICK, this);
String columnName = super.getColumnName();
if (columnName.equals("PaymentRule"))
@ -275,5 +274,9 @@ public class WButtonEditor extends WEditor
evtListener.actionPerformed(actionEvent);
}
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
}

View File

@ -37,7 +37,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WDateEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE};
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE, Events.ON_FOCUS};
private static final CLogger logger;
static
@ -104,6 +104,8 @@ public class WDateEditor extends WEditor
}
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equalsIgnoreCase(event.getName()))
{
Date date = getComponent().getValue();
Timestamp newValue = null;
@ -117,6 +119,11 @@ public class WDateEditor extends WEditor
super.fireValueChange(changeEvent);
oldValue = newValue;
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
@Override
public String getDisplay()

View File

@ -29,7 +29,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WDatetimeEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE};
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE, Events.ON_FOCUS};
private static final CLogger logger;
static
@ -97,6 +97,8 @@ public class WDatetimeEditor extends WEditor
}
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equalsIgnoreCase(event.getName()))
{
Date date = getComponent().getValue();
Timestamp newValue = null;
@ -110,6 +112,11 @@ public class WDatetimeEditor extends WEditor
super.fireValueChange(changeEvent);
oldValue = newValue;
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
@Override
public String getDisplay()

View File

@ -292,6 +292,11 @@ public abstract class WEditor implements EventListener, PropertyChangeListener
listeners.add(listener);
}
public boolean removeValuechangeListener(ValueChangeListener listener)
{
return listeners.remove(listener);
}
protected void fireValueChange(ValueChangeEvent event)
{
for (ValueChangeListener listener : listeners)

View File

@ -35,7 +35,7 @@ import org.zkoss.zul.Fileupload;
*/
public class WFilenameEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE, Events.ON_FOCUS};
private static final CLogger log = CLogger.getCLogger(WFilenameEditor.class);
@ -98,6 +98,10 @@ public class WFilenameEditor extends WEditor
{
cmd_file();
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
/**

View File

@ -33,7 +33,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WImageEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_FOCUS};
private static final CLogger logger;
@ -66,7 +66,6 @@ public class WImageEditor extends WEditor
private void init()
{
getComponent().setLabel("-");
getComponent().addEventListener(Events.ON_CLICK, this);
}
@Override
@ -151,5 +150,9 @@ public class WImageEditor extends WEditor
ValueChangeEvent vce = new ValueChangeEvent(this, gridField.getColumnName(), oldValue, newValue);
fireValueChange(vce);
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
}

View File

@ -40,7 +40,7 @@ import org.zkoss.zk.ui.event.Events;
**/
public class WLocationEditor extends WEditor implements EventListener, PropertyChangeListener
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_FOCUS};
private static CLogger log = CLogger.getCLogger(WLocationEditor.class);
private static final long serialVersionUID = 1L;
@ -163,6 +163,10 @@ public class WLocationEditor extends WEditor implements EventListener, PropertyC
}
setValue(ii);
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
/**

View File

@ -49,7 +49,7 @@ import org.zkoss.zk.ui.event.Events;
public class WLocatorEditor extends WEditor implements EventListener, PropertyChangeListener
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_FOCUS};
private String m_columnName;
private MLocatorLookup m_mLocator;
@ -177,9 +177,10 @@ public class WLocatorEditor extends WEditor implements EventListener, PropertyCh
} // getDisplay
public void onEvent(Event event) throws Exception
{
if (Events.ON_CLICK.equalsIgnoreCase(event.getName()))
{
// Warehouse/Product
int only_Warehouse_ID = getOnly_Warehouse_ID();
int only_Product_ID = getOnly_Product_ID();
@ -215,6 +216,11 @@ public class WLocatorEditor extends WEditor implements EventListener, PropertyCh
return;
setValue (ld.getValue(), true);
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
/**
* Hit Enter in Text Field

View File

@ -39,7 +39,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WNumberEditor extends WEditor
{
public static final String[] LISTENER_EVENTS = {Events.ON_CHANGE};
public static final String[] LISTENER_EVENTS = {Events.ON_CHANGE, Events.ON_FOCUS};
public static final int MAX_DISPLAY_LENGTH = 20;
@ -104,12 +104,19 @@ public class WNumberEditor extends WEditor
* @param event
*/
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equalsIgnoreCase(event.getName()))
{
BigDecimal newValue = getComponent().getValue();
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), oldValue, newValue);
super.fireValueChange(changeEvent);
oldValue = newValue;
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
@Override
public NumberBox getComponent() {

View File

@ -38,7 +38,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WPAttributeEditor extends WEditor implements ContextMenuListener
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE, Events.ON_FOCUS};
private static final CLogger log = CLogger.getCLogger(WPAttributeEditor.class);
@ -130,6 +130,10 @@ public class WPAttributeEditor extends WEditor implements ContextMenuListener
{
cmd_dialog();
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
/**

View File

@ -56,7 +56,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WSearchEditor extends WEditor implements ContextMenuListener, ValueChangeListener, IZoomableEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE, Events.ON_OK};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE, Events.ON_OK, Events.ON_FOCUS};
private Lookup lookup;
private String m_tableName = null;
private String m_keyColumnName = null;
@ -216,8 +216,17 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
}
else if (Events.ON_CLICK.equals(e.getName()))
{
if (infoPanel != null)
{
infoPanel.detach();
infoPanel = null;
}
actionButton("");
}
else if (Events.ON_FOCUS.equalsIgnoreCase(e.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}

View File

@ -44,12 +44,14 @@ public class WStringEditor extends WEditor implements ContextMenuListener
{
private static final String EDITOR_EVENT = "EDITOR";
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE};
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE, Events.ON_FOCUS};
private String oldText;
private WEditorPopupMenu popupMenu;
private boolean tableEditor = false;
/**
* to ease porting of swing form
*/
@ -58,10 +60,14 @@ public class WStringEditor extends WEditor implements ContextMenuListener
this("String", false, false, true, 30, 30, "", null);
}
public WStringEditor(GridField gridField)
public WStringEditor(GridField gridField) {
this(gridField, false);
}
public WStringEditor(GridField gridField, boolean tableEditor)
{
super(new Textbox(), gridField);
this.tableEditor = tableEditor;
init(gridField.getObscureType());
}
@ -111,6 +117,8 @@ public class WStringEditor extends WEditor implements ContextMenuListener
}
getComponent().setCols(displayLength);
if (!tableEditor)
{
if (gridField.getDisplayType() == DisplayType.Text)
{
getComponent().setMultiline(true);
@ -126,6 +134,7 @@ public class WStringEditor extends WEditor implements ContextMenuListener
getComponent().setMultiline(true);
getComponent().setRows(8);
}
}
getComponent().setObscureType(obscureType);
@ -148,6 +157,10 @@ public class WStringEditor extends WEditor implements ContextMenuListener
super.fireValueChange(changeEvent);
oldText = newText;
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
@Override

View File

@ -50,7 +50,7 @@ import org.zkoss.zk.ui.event.Events;
public class WTableDirEditor extends WEditor implements ListDataListener,
ContextMenuListener, IZoomableEditor
{
public final static String[] LISTENER_EVENTS = {Events.ON_SELECT};
public final static String[] LISTENER_EVENTS = {Events.ON_SELECT, Events.ON_FOCUS};
private static final CLogger logger;
@ -258,12 +258,19 @@ ContextMenuListener, IZoomableEditor
}
public void onEvent(Event event)
{
if (Events.ON_SELECT.equalsIgnoreCase(event.getName()))
{
Object newValue = getValue();
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), oldValue, newValue);
super.fireValueChange(changeEvent);
oldValue = newValue;
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
public String[] getEvents()
{

View File

@ -30,7 +30,7 @@ import org.zkoss.zul.Timebox;
*/
public class WTimeEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE};
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE, Events.ON_FOCUS};
private static final CLogger logger;
static
@ -89,6 +89,8 @@ public class WTimeEditor extends WEditor
} // VDate
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equalsIgnoreCase(event.getName()))
{
Date date = getComponent().getValue();
Timestamp newValue = null;
@ -102,6 +104,11 @@ public class WTimeEditor extends WEditor
super.fireValueChange(changeEvent);
oldValue = newValue;
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
@Override
public String getDisplay()

View File

@ -29,7 +29,7 @@ import org.zkoss.zk.ui.event.Events;
public class WUrlEditor extends WEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE};
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE, Events.ON_FOCUS};
public WUrlEditor(GridField gridField)
{
@ -108,6 +108,10 @@ public class WUrlEditor extends WEditor
FDialog.warn(0, this.getComponent(), "URLnotValid", message);
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
public String[] getEvents()

View File

@ -37,7 +37,7 @@ import org.zkoss.zk.ui.event.Events;
*/
public class WYesNoEditor extends WEditor
{
public static final String[] LISTENER_EVENTS = {Events.ON_CHECK};
public static final String[] LISTENER_EVENTS = {Events.ON_CHECK, Events.ON_FOCUS};
private static final CLogger logger;
static
@ -61,12 +61,19 @@ public class WYesNoEditor extends WEditor
}
public void onEvent(Event event)
{
if (Events.ON_CHECK.equalsIgnoreCase(event.getName()))
{
Boolean newValue = (Boolean)getValue();
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), oldValue, newValue);
super.fireValueChange(changeEvent);
oldValue = newValue;
}
else if (Events.ON_FOCUS.equalsIgnoreCase(event.getName()) && gridField != null)
{
this.setReadWrite(gridField.isEditable(true));
}
}
public void propertyChange(PropertyChangeEvent evt)
{

View File

@ -76,7 +76,7 @@ public class WebEditorFactory
}
else
{
editor = new WStringEditor(gridField);
editor = new WStringEditor(gridField, tableEditor);
}
}
/** File */

View File

@ -45,14 +45,12 @@ import org.adempiere.webui.editor.WEditor;
import org.adempiere.webui.editor.WEditorPopupMenu;
import org.adempiere.webui.editor.WebEditorFactory;
import org.adempiere.webui.event.ContextMenuListener;
import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener;
import org.adempiere.webui.util.GridTabDataBinder;
import org.adempiere.webui.window.FDialog;
import org.compiere.model.DataStatusEvent;
import org.compiere.model.DataStatusListener;
import org.compiere.model.GridField;
import org.compiere.model.GridTab;
import org.compiere.model.GridTable;
import org.compiere.model.GridWindow;
import org.compiere.model.MLookup;
import org.compiere.model.MTree;
@ -94,7 +92,7 @@ import org.zkoss.zul.Treeitem;
* @author Low Heng Sin
*/
public class ADTabpanel extends Div implements Evaluatee, EventListener,
DataStatusListener, ValueChangeListener, IADTabpanel
DataStatusListener, IADTabpanel
{
private static final CLogger logger;
@ -134,6 +132,8 @@ DataStatusListener, ValueChangeListener, IADTabpanel
private Tree tree = null;
private GridTabDataBinder dataBinder;
public ADTabpanel()
{
init();
@ -169,6 +169,7 @@ DataStatusListener, ValueChangeListener, IADTabpanel
this.gridTab = gridTab;
this.windowPanel = winPanel;
gridTab.addDataStatusListener(this);
this.dataBinder = new GridTabDataBinder(gridTab);
this.getChildren().clear();
@ -373,7 +374,7 @@ DataStatusListener, ValueChangeListener, IADTabpanel
}
else
{
editor.addValueChangeListener(this);
editor.addValueChangeListener(dataBinder);
}
if (editor.getComponent() instanceof HtmlBasedComponent) {
@ -835,57 +836,6 @@ DataStatusListener, ValueChangeListener, IADTabpanel
}
}
public void valueChange(ValueChangeEvent e)
{
if (gridTab.isProcessed()) // only active records
{
Object source = e.getSource();
if (source instanceof WEditor)
{
if (!((WEditor)source).isReadWrite())
{
logger.config("(" + gridTab.toString() + ") " + e.getPropertyName());
return;
}
}
else
{
logger.config("(" + gridTab.toString() + ") " + e.getPropertyName());
return;
}
} // processed
logger.config("(" + gridTab.toString() + ") "
+ e.getPropertyName() + "=" + e.getNewValue() + " (" + e.getOldValue() + ") "
+ (e.getOldValue() == null ? "" : e.getOldValue().getClass().getName()));
// Get Row/Col Info
GridTable mTable = gridTab.getTableModel();
int row = gridTab.getCurrentRow();
int col = mTable.findColumn(e.getPropertyName());
//
if (e.getNewValue() == null && e.getOldValue() != null
&& e.getOldValue().toString().length() > 0) // some editors return "" instead of null
// this is the original code from GridController, don't know what it does there but it breaks ignore button for web ui
// mTable.setChanged (true);
mTable.setValueAt (e.getNewValue(), row, col);
else
{
// mTable.setValueAt (e.getNewValue(), row, col, true);
mTable.setValueAt (e.getNewValue(), row, col); // -> dataStatusChanged -> dynamicDisplay
// Force Callout
if ( e.getPropertyName().equals("S_ResourceAssignment_ID") )
{
GridField mField = gridTab.getField(col);
if (mField != null && mField.getCallout().length() > 0)
{
gridTab.processFieldChange(mField); // Dependencies & Callout
}
}
}
} // ValueChange
public void switchRowPresentation() {
if (formComponent.isVisible()) {
formComponent.setVisible(false);

View File

@ -0,0 +1,95 @@
/******************************************************************************
* Copyright (C) 2008 Low Heng Sin *
* 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.util;
import org.adempiere.webui.editor.WEditor;
import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener;
import org.compiere.model.GridField;
import org.compiere.model.GridTab;
import org.compiere.model.GridTable;
import org.compiere.util.CLogger;
/**
* Transfer data from editor to GridTab
* @author hengsin
*
*/
public class GridTabDataBinder implements ValueChangeListener {
private final static CLogger logger = CLogger.getCLogger(GridTabDataBinder.class);
private GridTab gridTab;
/**
*
* @param gridTab
*/
public GridTabDataBinder(GridTab gridTab) {
this.gridTab = gridTab;
}
/**
* @param e
*/
public void valueChange(ValueChangeEvent e)
{
if (gridTab.isProcessed()) // only active records
{
Object source = e.getSource();
if (source instanceof WEditor)
{
if (!((WEditor)source).isReadWrite())
{
logger.config("(" + gridTab.toString() + ") " + e.getPropertyName());
return;
}
}
else
{
logger.config("(" + gridTab.toString() + ") " + e.getPropertyName());
return;
}
} // processed
logger.config("(" + gridTab.toString() + ") "
+ e.getPropertyName() + "=" + e.getNewValue() + " (" + e.getOldValue() + ") "
+ (e.getOldValue() == null ? "" : e.getOldValue().getClass().getName()));
// Get Row/Col Info
GridTable mTable = gridTab.getTableModel();
int row = gridTab.getCurrentRow();
int col = mTable.findColumn(e.getPropertyName());
//
if (e.getNewValue() == null && e.getOldValue() != null
&& e.getOldValue().toString().length() > 0) // some editors return "" instead of null
// this is the original code from GridController, don't know what it does there but it breaks ignore button for web ui
// mTable.setChanged (true);
mTable.setValueAt (e.getNewValue(), row, col);
else
{
// mTable.setValueAt (e.getNewValue(), row, col, true);
mTable.setValueAt (e.getNewValue(), row, col); // -> dataStatusChanged -> dynamicDisplay
// Force Callout
if ( e.getPropertyName().equals("S_ResourceAssignment_ID") )
{
GridField mField = gridTab.getField(col);
if (mField != null && mField.getCallout().length() > 0)
{
gridTab.processFieldChange(mField); // Dependencies & Callout
}
}
}
} // ValueChange
}