IDEMPIERE-5570 Zk: Improve readability of code (#1819)

- for org.adempiere.webui.editor package
This commit is contained in:
hengsin 2023-05-03 19:54:00 +08:00 committed by GitHub
parent f82777c527
commit 66b8271c2b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
38 changed files with 1174 additions and 418 deletions

View File

@ -33,12 +33,12 @@ public interface IInputValidator {
/**
* Get Valid Input
* @return String
* @return Expected input string from user
*/
public String getValidInput();
/**
* Set Valid Input
* Set string to validate against user input
* @param validInput
*/
public void setValidInput(String validInput);
@ -46,7 +46,7 @@ public interface IInputValidator {
/**
* Is Input Valid
* @param input
* @return boolean
* @return true if input validate against {@link #getValidInput()}
*/
public boolean isValid(String input);
}

View File

@ -16,7 +16,7 @@ package org.adempiere.webui.editor;
import org.adempiere.webui.adwindow.IADTabpanel;
/**
*
* Interface for process button
* @author hengsin
*
*/
@ -28,13 +28,28 @@ public interface IProcessButton {
*/
public int getProcess_ID();
/**
* @return AD_InfoWindow_ID
*/
public int getInfoWindow_ID();
/**
* @return {@link IADTabpanel} instance that own this button
*/
public IADTabpanel getADTabpanel();
/**
* @return Column Name
*/
public String getColumnName();
/**
* @return Description
*/
public String getDescription();
/**
* @return Display text
*/
public String getDisplay();
}

View File

@ -13,12 +13,14 @@
package org.adempiere.webui.editor;
/**
*
* Interface for field editor that support zoom to AD window.
* @author Low Heng Sin
*
*/
public interface IZoomableEditor {
/**
* Zoom to AD window
*/
public void actionZoom();
}

View File

@ -40,9 +40,8 @@ import org.zkoss.zul.ListModelList;
import org.zkoss.zul.ListSubModel;
/**
*
* Model to get filter list from lookup and info window/panel
* @author hengsin
*
*/
public class InfoListSubModel implements ListSubModel<ValueNamePair> {
@ -88,6 +87,7 @@ public class InfoListSubModel implements ListSubModel<ValueNamePair> {
public ListModel<ValueNamePair> getSubModel(Object value, int nRows) {
ListModelList<ValueNamePair> model = new ListModelList<>();
if (value != null && !Util.isEmpty(value.toString(), true)) {
//build query text from input value
String queryText = value.toString().trim();
StringBuilder queryBuilder = new StringBuilder(queryText);
queryBuilder.append("?autocomplete={");
@ -108,6 +108,7 @@ public class InfoListSubModel implements ListSubModel<ValueNamePair> {
queryBuilder.append("}");
queryText = queryBuilder.toString();
//build model from infopanel/infowindow processing of query text
final InfoPanel ip = InfoManager.create(lookup, gridField, tableName, keyColumnName, queryText, false, getWhereClause());
if (ip != null && ip.loadedOK()) {
int rowCount = ip.getRowCount();

View File

@ -30,6 +30,7 @@ import org.compiere.model.MAccountLookup;
import org.compiere.model.MRole;
import org.compiere.util.CLogger;
import org.compiere.util.DB;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.zkoss.zk.au.out.AuScript;
import org.zkoss.zk.ui.event.Event;
@ -37,9 +38,9 @@ import org.zkoss.zk.ui.event.Events;
import org.zkoss.zk.ui.util.Clients;
/**
*
* Default editor for {@link DisplayType#Account}. <br/>
* Implemented with {@link Combinationbox} component and {@link WAccountDialog} dialog.
* @author Low Heng Sin
*
*/
public class WAccountEditor extends WEditor implements ContextMenuListener
{
@ -112,7 +113,7 @@ public class WAccountEditor extends WEditor implements ContextMenuListener
}
/**
* Button - Start Dialog
* Button - open {@link WAccountDialog}.
*/
public void cmd_button()
{
@ -158,16 +159,16 @@ public class WAccountEditor extends WEditor implements ContextMenuListener
Clients.response(new AuScript(script));
}
});
//
} // cmd_button
/**
* Text - try to find Alias or start Dialog
* Process input text - try to find Alias or open Dialog
*/
public void cmd_text()
{
String text = getComponent().getText();
log.info("Text=" + text);
if (log.isLoggable(Level.INFO))
log.info("Text=" + text);
if (text == null || text.length() == 0 || text.equals("%"))
{
cmd_button();
@ -224,8 +225,9 @@ public class WAccountEditor extends WEditor implements ContextMenuListener
}
else
cmd_button();
} // actionPerformed
} // cmd_text
@Override
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equals(event.getName()) || Events.ON_OK.equals(event.getName()))
@ -238,18 +240,17 @@ public class WAccountEditor extends WEditor implements ContextMenuListener
}
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;
}
@Override
public boolean isReadWrite() {
return getComponent().isEnabled();
}
@Override
public void setReadWrite(boolean readWrite) {
getComponent().setEnabled(readWrite);

View File

@ -1,3 +1,26 @@
/***********************************************************************
* This file is part of iDempiere ERP Open Source *
* http://www.idempiere.org *
* *
* Copyright (C) Contributors *
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* of the License, or (at your option) any later version. *
* *
* 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., 51 Franklin Street, Fifth Floor, Boston, *
* MA 02110-1301, USA. *
* *
* Contributors: *
**********************************************************************/
package org.adempiere.webui.editor;
import java.sql.PreparedStatement;
@ -29,6 +52,11 @@ import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
/**
* Default editor for {@link DisplayType#Assignment}.<br/>
* Implemented with {@link EditorBox} component, {@link WAssignmentDialog} and {@link InfoSchedule} dialog.
* @author hengsin
*/
public class WAssignmentEditor extends WEditor implements ContextMenuListener {
private static final String RETRIEVE_RESOURCE_ASSIGNMENT_SQL = "SELECT r.Name,ra.AssignDateFrom,ra.Qty,uom.UOMSymbol "
@ -43,6 +71,7 @@ public class WAssignmentEditor extends WEditor implements ContextMenuListener {
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK};
private boolean m_readWrite;
/** S_ResourceAssignment_ID */
private Object m_value;
private DateFormat m_dateFormat = DisplayType.getDateFormat(DisplayType.DateTime);
@ -68,6 +97,9 @@ public class WAssignmentEditor extends WEditor implements ContextMenuListener {
initComponents();
}
/**
* Init component and context menu
*/
private void initComponents() {
getComponent().getTextbox().setReadonly(true);
if (ThemeManager.isUseFontIconForImage())
@ -82,8 +114,6 @@ public class WAssignmentEditor extends WEditor implements ContextMenuListener {
getComponent().getTextbox().setPlaceholder(gridField.getPlaceholder());
}
@Override
public String[] getEvents() {
return LISTENER_EVENTS;
@ -161,6 +191,7 @@ public class WAssignmentEditor extends WEditor implements ContextMenuListener {
}
@Override
public void onEvent(Event event) throws Exception {
//
if (Events.ON_CLICK.equalsIgnoreCase(event.getName()))
@ -184,7 +215,7 @@ public class WAssignmentEditor extends WEditor implements ContextMenuListener {
}
}
// Start VAssignment Dialog
// Open WAssignmentDialog Dialog
if (S_ResourceAssignment_ID != 0)
{
final WAssignmentDialog vad = new WAssignmentDialog (ma, true, true);
@ -200,7 +231,7 @@ public class WAssignmentEditor extends WEditor implements ContextMenuListener {
vad.setTitle(null);
LayoutUtils.openPopupWindow(this.getComponent().getTextbox(), vad);
}
// Start InfoSchedule directly
// Open InfoSchedule directly
else
{
final InfoSchedule is = new InfoSchedule(ma, true, new Callback<MResourceAssignment>() {
@ -227,10 +258,18 @@ public class WAssignmentEditor extends WEditor implements ContextMenuListener {
}
/**
* Zoom to window for S_ResourceAssignment
*/
private void actionZoom() {
AEnv.zoom(gridField.getGridTab().getAD_Table_ID(), (Integer)getValue());
}
/**
* Fire {@link ValueChangeEvent} after changes from InfoSchedule or WAssignmentDialog.
* @param oldValue
* @param ma MResourceAssignment
*/
private void processNewValue(final Integer oldValue, MResourceAssignment ma) {
// Set Value
if (ma != null && ma.getS_ResourceAssignment_ID() != 0)

View File

@ -26,11 +26,14 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.window.WMediaDialog;
import org.compiere.model.GridField;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
/**
* Default editor for {@link DisplayType#Binary}.<br/>
* Implemented with {@link Button} component and {@link WMediaDialog} dialog.
* @author Low Heng Sin
*/
public class WBinaryEditor extends WEditor
@ -41,8 +44,10 @@ public class WBinaryEditor extends WEditor
private static final CLogger log = CLogger.getCLogger(WBinaryEditor.class);
private boolean m_mandatory;
/** Binary data */
private Object m_data;
/** ADWindow instance that own this editor */
private ADWindow adwindow;
/**
@ -66,6 +71,9 @@ public class WBinaryEditor extends WEditor
init();
}
/**
* Init component
*/
private void init()
{
label.setValue(" ");
@ -73,7 +81,7 @@ public class WBinaryEditor extends WEditor
getComponent().setTooltiptext(gridField.getDescription());
}
@Override
@Override
public String getDisplay()
{
return getComponent().getLabel();
@ -145,6 +153,7 @@ public class WBinaryEditor extends WEditor
return LISTENER_EVENTS;
}
@Override
public void onEvent(Event event) throws Exception
{
if (Events.ON_CLICK.equals(event.getName()))

View File

@ -47,8 +47,7 @@ import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
/**
* This class is based on org.compiere.grid.ed.VButton written by Jorg Janke.
* @author Jorg Janke
* Default editor for {@link DisplayType#Button}.
*
* Modifications - UI Compatibility
* @author ashley
@ -69,7 +68,7 @@ public class WButtonEditor extends WEditor implements IProcessButton
private String m_text;
private boolean m_mandatory;
private Object m_value;
/** List of Key/Name */
/** Value:Name. AD_Ref_List values for PaymentRule, DocAction or Posted reference. */
private HashMap<String,String> m_values = null;
/** Description as ToolTip */
@ -147,11 +146,17 @@ public class WButtonEditor extends WEditor implements IProcessButton
return AD_InfoWindow_ID;
} // getInfoWindow_ID
/**
* @return GridField
*/
public GridField getGridField()
{
return gridfield;
}
/**
* Init component
*/
private void init()
{
label.setValue(" ");
@ -233,7 +238,6 @@ public class WButtonEditor extends WEditor implements IProcessButton
return m_mandatory;
}
@Override
public void setMandatory(boolean mandatory)
{
@ -288,6 +292,9 @@ public class WButtonEditor extends WEditor implements IProcessButton
getComponent().setEnabled(readWrite);
}
/**
* @return AD_Ref_List Value:Name HashMap
*/
public HashMap<String, String> getValues()
{
return m_values;
@ -338,12 +345,19 @@ public class WButtonEditor extends WEditor implements IProcessButton
} // readReference
/**
* @param actionListener
*/
public void addActionListener(ActionListener actionListener)
{
if (!actionListeners.contains(actionListener))
actionListeners.add(actionListener);
}
/**
* @param actionListener
* @return true if found and remove
*/
public boolean removeActionListener(ActionListener actionListener)
{
return actionListeners.remove(actionListener);
@ -355,6 +369,7 @@ public class WButtonEditor extends WEditor implements IProcessButton
return LISTENER_EVENTS;
}
@Override
public void onEvent(Event event) throws Exception
{
if (Events.ON_CLICK.equals(event.getName()))
@ -369,6 +384,9 @@ public class WButtonEditor extends WEditor implements IProcessButton
}
}
/**
* @param adTabpanel
*/
public void setADTabpanel(IADTabpanel adTabpanel) {
this.adTabpanel = adTabpanel;
}

View File

@ -22,6 +22,7 @@ import org.adempiere.webui.apps.graph.model.ChartModel;
import org.compiere.model.GridField;
import org.compiere.model.MChart;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.zkoss.zk.ui.event.AfterSizeEvent;
import org.zkoss.zk.ui.event.Event;
@ -31,7 +32,8 @@ import org.zkoss.zul.Panel;
import org.zkoss.zul.Panelchildren;
/**
* This class is based on org.compiere.grid.ed.WImageEditor and WGraph written by Low Heng Sin.
* Default editor for {@link DisplayType#Chart}.<br/>
* A readonly editor that render chart from {@link MChart} model to {@link Panel} component.
* @author Low Heng Sin
*
* Modifications - chart display
@ -78,6 +80,9 @@ public class WChartEditor extends WEditor
init();
}
/**
* Re-render chart
*/
private void createChart() {
if (chartHeight > 0 && chartWidth > 0) {
chartDiv.getChildren().clear();
@ -96,22 +101,32 @@ public class WChartEditor extends WEditor
return (Panel) component;
}
/**
* Init component
*/
private void init()
{
Panelchildren pc = new Panelchildren();
getComponent().appendChild(pc);
pc.setSclass("chart-field");
chartDiv = new Div();
//chart is render in ON_AFTER_SIZE event
chartDiv.addEventListener(Events.ON_AFTER_SIZE, this);
pc.appendChild(chartDiv);
}
/**
* @return {@link MChart#getName()}
*/
@Override
public String getDisplay()
{
return chartModel.get_Translation(MChart.COLUMNNAME_Name);
}
/**
* Always return null
*/
@Override
public Object getValue()
{
@ -124,23 +139,34 @@ public class WChartEditor extends WEditor
return false;
}
/**
* No op.
*/
@Override
public void setMandatory(boolean mandatory)
{
;
}
/**
* Always return true
*/
@Override
public boolean isReadWrite() {
return true;
}
/**
* No op.
*/
@Override
public void setReadWrite(boolean readWrite) {
}
/**
* No op.
*/
@Override
public void setValue(Object value)
{
@ -153,6 +179,7 @@ public class WChartEditor extends WEditor
return LISTENER_EVENTS;
}
@Override
public void onEvent(Event event) throws Exception
{
if (event instanceof AfterSizeEvent && chartModel != null && chartModel.getAD_Chart_ID() > 0)
@ -181,6 +208,9 @@ public class WChartEditor extends WEditor
}
}
/**
* Call {@link #createChart()} to re-render chart.
*/
@Override
public void dynamicDisplay() {
super.dynamicDisplay();

View File

@ -13,7 +13,6 @@
*****************************************************************************/
package org.adempiere.webui.editor;
import java.beans.PropertyChangeEvent;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedHashSet;
@ -77,7 +76,8 @@ import org.zkoss.zul.Menuitem;
import org.zkoss.zul.South;
/**
*
* Default editor for {@link DisplayType#ChosenMultipleSelectionList} and {@link DisplayType#ChosenMultipleSelectionTable}.<br/>
* Implemented with {@link ChosenSearchBox} component.
* @author hengsin
*
*/
@ -94,12 +94,16 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
private Lookup lookup;
/** comma separated value list of selected records */
private Object oldValue;
/** CCache listener to auto refresh lookup */
private CCacheListener tableCacheListener;
/** true if editor is handling onSelect event */
private boolean onselecting = false;
/** Model for {@link Chosenbox} inside {@link ChosenSearchBox} */
private ListModelList<ValueNamePair> model = new ListModelList<>();
/**
@ -122,6 +126,13 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
this(new ChosenSearchBox(new ChosenboxEditor()), gridField, tableEditor, editorConfiguration);
}
/**
*
* @param comp
* @param gridField
* @param tableEditor
* @param editorConfiguration
*/
private WChosenboxListEditor(Component comp, GridField gridField, boolean tableEditor, IEditorConfiguration editorConfiguration)
{
super(comp, gridField, tableEditor, editorConfiguration);
@ -133,9 +144,9 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
* Constructor for use if a grid field is unavailable
*
* @param lookup Store of selectable data
* @param label column name (not displayed)
* @param label field label
* @param description description of component
* @param mandatory whether a selection must be made
* @param mandatory whether field is mandatory
* @param readonly whether or not the editor is read only
* @param updateable whether the editor contents can be changed
*/
@ -159,6 +170,15 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
this(new ChosenSearchBox(new ChosenboxEditor()), lookup, label, description, mandatory, readonly, updateable);
}
/**
* @param comp
* @param lookup
* @param label
* @param description
* @param mandatory
* @param readonly
* @param updateable
*/
private WChosenboxListEditor(Component comp, Lookup lookup, String label, String description, boolean mandatory, boolean readonly, boolean updateable)
{
super(comp, label, description, mandatory, readonly, updateable);
@ -174,7 +194,6 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
/**
* For ease of porting swing form
* @param columnName
* @param mandatory
* @param isReadOnly
@ -200,6 +219,14 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
this(new ChosenSearchBox(new ChosenboxEditor()), columnName, mandatory, isReadOnly, isUpdateable, lookup);
}
/**
* @param comp
* @param columnName
* @param mandatory
* @param isReadOnly
* @param isUpdateable
* @param lookup
*/
private WChosenboxListEditor(Component comp, String columnName, boolean mandatory, boolean isReadOnly, boolean isUpdateable, Lookup lookup)
{
super(comp, columnName, null, null, mandatory, isReadOnly, isUpdateable);
@ -211,6 +238,9 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Init component, lookup and popup menu
*/
private void init()
{
getComponent().setHflex("true");
@ -226,6 +256,7 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
else
getComponent().getButton().setImage(imageUrl);
//open chosenbox dropdown
getComponent().getButton().addEventListener(Events.ON_CLICK, e -> {
if (getComponent().isEnabled()) {
if (!getComponent().getChosenbox().isOpen()) {
@ -277,6 +308,9 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
updateModel();
}
/**
* @return comma separated name list of selected records
*/
@Override
public String getDisplay()
{
@ -300,6 +334,9 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
return oldValue;
}
/**
* @return comma separated value list of selected records
*/
private String getValueFromComponent()
{
StringBuilder retVal = new StringBuilder();
@ -323,7 +360,7 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
/**
* @param value
* @param value comma separated value list of selected records
*/
public void setValue(Object value)
{
@ -331,7 +368,7 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
return;
}
if (value != null && value instanceof String && !Util.isEmpty((String) value, true))
if (value != null && value instanceof String && !Util.isEmpty((String) value, true))
{
String[] values = ((String)value).split("[,]");
Set<ValueNamePair> selected = new LinkedHashSet<>();
@ -399,6 +436,9 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
getComponent().setEnabled(readWrite);
}
/**
* Update {@link #model}
*/
private void updateModel()
{
List<ValueNamePair> list = new ArrayList<>();
@ -453,6 +493,7 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
/**
* @param event
*/
@Override
public void onEvent(Event event)
{
if (Events.ON_SELECT.equalsIgnoreCase(event.getName()))
@ -461,6 +502,10 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
/**
* Handle ON_SELECT event
* @param newValue
*/
private void updateValue(Object newValue) {
try {
onselecting = true;
@ -482,6 +527,10 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
/**
* @param newValue
* @return true if newValue is different from {@link #oldValue}
*/
private boolean isValueChange(Object newValue) {
return (oldValue == null && newValue != null) || (oldValue != null && newValue == null)
|| ((oldValue != null && newValue != null) && !oldValue.equals(newValue));
@ -494,7 +543,8 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
/**
* action for requery menu
* Action for re-query menu.<br/>
* Refresh lookup
*/
protected void actionRefresh()
{
@ -555,15 +605,6 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
@Override
public void propertyChange(PropertyChangeEvent evt)
{
if ("FieldValue".equals(evt.getPropertyName()))
{
setValue(evt.getNewValue());
}
}
@Override
public void dynamicDisplay(Properties ctx)
{
@ -578,6 +619,9 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
super.dynamicDisplay(ctx);
}
/**
* Setup {@link #tableCacheListener}
*/
private void createCacheListener() {
if (lookup != null) {
String columnName = lookup.getColumnName();
@ -589,8 +633,10 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
/**
* Custom {@link Chosenbox} class for setup and cleanup of tableCacheListener
*/
private final static class ChosenboxEditor extends Chosenbox<ValueNamePair> {
/**
* generated serial id
*/
@ -632,7 +678,7 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
/**
*
* clean up tableCacheListener
*/
protected void cleanup() {
if (editor != null && editor.tableCacheListener != null) {
@ -642,6 +688,9 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
/**
* CCache listener class to auto refresh lookup
*/
private static class CCacheListener extends CCache<String, Object> {
/**
* generated serial
@ -682,6 +731,9 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
/**
* Assistant dialog to manage selection of items and to change ordering of selected items.
*/
private class WChosenboxListAssistant extends Window implements EventListener<Event> {
private static final long serialVersionUID = 1043859495570181469L;
private Button bAdd, bRemove, bUp, bDown;
@ -734,12 +786,14 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
mainLayout.appendChild(center);
center.setAutoscroll(true);
//Listener for add and remove button
EventListener<Event> actionListener = new EventListener<Event>() {
public void onEvent(Event event) throws Exception {
migrateValueAcrossLists(event);
}
};
//Listener for up and down button
EventListener<Event> actionListener2 = new EventListener<Event>() {
public void onEvent(Event event) throws Exception {
migrateValueWithinSelectedList(event);
@ -815,6 +869,7 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
@Override
public void onEvent(Event event) throws Exception {
if (event.getTarget() == bOk) {
@ -841,6 +896,15 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
return btn;
}
/**
* @param lb
* @param model
* @param mouseListener
* @param crossListMouseListener
* @param isItemDraggable
* @param headerLabel
* @param buttonsLayout
*/
private void initListboxAndModel(Listbox lb, SimpleListModel model, EventListener<Event> mouseListener, EventListener<Event> crossListMouseListener, boolean isItemDraggable, String headerLabel, Hlayout buttonsLayout) {
lb.addEventListener(Events.ON_RIGHT_CLICK, this);
ZKUpdateUtil.setHflex(lb, "1");
@ -913,6 +977,10 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
return retValue;
}
/**
* @param model
* @return opposite model
*/
private SimpleListModel getModel(SimpleListModel model) {
SimpleListModel retValue = null;
@ -925,6 +993,10 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
return retValue;
}
/**
* Handle event from add button, remove button and double click.
* @param event
*/
private void migrateValueAcrossLists (Event event) {
Object source = event.getTarget();
if (source instanceof ListItem)
@ -940,6 +1012,12 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
migrateLists (listFrom, listTo, endIndex);
} // migrateValueAcrossLists
/**
* Move selected items from listFrom to listTo at endIndex
* @param listFrom
* @param listTo
* @param endIndex
*/
private void migrateLists (final Listbox listFrom, final Listbox listTo, final int endIndex) {
int index = 0;
final SimpleListModel lmFrom = getModel(listFrom);
@ -954,12 +1032,18 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
selObjects.add(selObject);
}
doTransfer(index, selObjects, lmFrom, lmTo, listFrom, listTo, endIndex);
doTransfer(selObjects, lmFrom, lmTo, listTo, endIndex);
}
private void doTransfer(int index, List<ValueNamePair > selObjects, SimpleListModel lmFrom, SimpleListModel lmTo, Listbox listFrom , Listbox listTo , int endIndex) {
index = 0;
/**
* Move selected items from lmFrom to lmTo at endIndex
* @param selObjects
* @param lmFrom
* @param lmTo
* @param listTo
* @param endIndex
*/
private void doTransfer(List<ValueNamePair > selObjects, SimpleListModel lmFrom, SimpleListModel lmTo, Listbox listTo , int endIndex) {
Arrays.sort(selObjects.toArray());
for (ValueNamePair selObject : selObjects) {
lmFrom.removeElement(selObject);
@ -972,10 +1056,14 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
/**
* Listener for DropEvent
*/
private class DragListener implements EventListener<Event> {
public DragListener() {
}
@Override
public void onEvent(Event event) throws Exception {
if (event instanceof DropEvent) {
int endIndex = 0;
@ -1009,6 +1097,13 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
/**
* Move selected items to endIndex
* @param selModel
* @param selListbox
* @param endIndex
* @param selObjects
*/
private void migrateValueWithinSelectedList (SimpleListModel selModel, Listbox selListbox, int endIndex, List<ValueNamePair > selObjects) {
int iniIndex =0;
Arrays.sort(selObjects.toArray());
@ -1029,6 +1124,11 @@ public class WChosenboxListEditor extends WEditor implements ContextMenuListener
}
}
/**
* Handle event from up and down button. <br/>
* Move selected items up/down within {@link #selectedList}.
* @param event
*/
private void migrateValueWithinSelectedList (Event event) {
Object[] selObjects = selectedList.getSelectedItems().toArray();
if (selObjects == null)

View File

@ -13,7 +13,6 @@
*****************************************************************************/
package org.adempiere.webui.editor;
import java.beans.PropertyChangeEvent;
import java.util.LinkedHashSet;
import java.util.Properties;
import java.util.Set;
@ -41,9 +40,11 @@ import org.compiere.model.MSysConfig;
import org.compiere.model.MTable;
import org.compiere.model.X_AD_CtxHelp;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Util;
import org.compiere.util.ValueNamePair;
import org.zkoss.addon.chosenbox.Chosenbox;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
@ -53,25 +54,32 @@ import org.zkoss.zul.ListModelList;
import org.zkoss.zul.ListSubModel;
/**
*
* Default editor for {@link DisplayType#ChosenMultipleSelectionSearch}.
* Implemented with {@link ChosenSearchBox} component.
* @author hengsin
*
*/
public class WChosenboxSearchEditor extends WEditor implements ContextMenuListener
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_SELECT};
private Lookup lookup;
/** Foreign table name */
private String m_tableName = null;
/** Foreign key column name */
private String m_keyColumnName = null;
/** Column name for {@link #lookup} */
private String columnName;
/** comma separated value list of selected records */
private String value;
private InfoPanel infoPanel = null;
/** Image URL or font icon sclass for choosebox button */
private String imageUrl;
private MyListModel model = new MyListModel();
/** Model for {@link Chosenbox} */
private InfoListSubModel subModel = null;
private static final CLogger log = CLogger.getCLogger(WChosenboxSearchEditor.class);
private static final int DEFAULT_MAX_AUTO_COMPLETE_ROWS = 500;
/** true when editor is handling ON_SELECT event */
private boolean onselecting;
/**
@ -118,7 +126,6 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
getComponent().setEnabled(readWrite);
}
/**
* Constructor for use if a grid field is unavailable
*
@ -144,6 +151,13 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
init();
}
/**
* @param columnName
* @param mandatory
* @param readonly
* @param updateable
* @param lookup
*/
public WChosenboxSearchEditor(String columnName, boolean mandatory, boolean readonly, boolean updateable,
Lookup lookup)
{
@ -163,7 +177,6 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
/**
* initialise editor
* @param columnName columnName
*/
private void init()
{
@ -249,6 +262,9 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
return value;
}
/**
* @return comma separated value list of selected records
*/
private String getValueFromComponent()
{
StringBuilder retVal = new StringBuilder();
@ -271,6 +287,9 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
return retVal.length() > 0 ? retVal.toString() : null;
}
/**
* @return comma separated name list of selected records
*/
@Override
public String getDisplay()
{
@ -288,6 +307,7 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
return display.toString();
}
@Override
public void onEvent(Event e)
{
if (Events.ON_CLICK.equals(e.getName()))
@ -322,20 +342,16 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
}
}
/**
* @param newValue
* @return true if newValue is different from {@link #value}
*/
private boolean isValueChange(Object newValue) {
return (value == null && newValue != null) || (value != null && newValue == null)
|| ((value != null && newValue != null) && !value.equals(newValue));
}
@Override
public void propertyChange(PropertyChangeEvent evt)
{
if ("FieldValue".equals(evt.getPropertyName()))
{
setValue(evt.getNewValue());
}
}
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.PREFERENCE_EVENT.equals(evt.getContextEvent()))
@ -350,6 +366,10 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
}
}
/**
* Process selected items from info panel/window
* @param value
*/
private void processSelectedKeys (Object value)
{
if (log.isLoggable(Level.FINE))
@ -431,13 +451,19 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
} // actionCombo
/**
* Fire ValueChangeEvent for newValue
* @param newValue
*/
protected void fireValueChangeEvent(Object newValue) {
ValueChangeEvent evt = new ValueChangeEvent(this, this.getColumnName(), getValue(), newValue);
// -> ADTabpanel - valuechange
fireValueChange(evt);
}
/**
* Open info panel/window
*/
private void actionButton()
{
if (lookup == null)
@ -461,7 +487,10 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
showInfoPanel(ip);
}
/**
* Open {@link InfoPanel}
* @param ip InfoPanel
*/
protected void showInfoPanel(final InfoPanel ip) {
ip.setVisible(true);
ip.setStyle("border: 2px");
@ -498,7 +527,7 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
}
/**
* Sets m_tableName and m_keyColumnName
* Set {@link #m_tableName} and {@link #m_keyColumnName}
*/
private void setTableAndKeyColumn() {
if (lookup != null && lookup instanceof MLookup) {
@ -529,6 +558,9 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
}
}
/**
* @return where clause from {@link #lookup} validation code.
*/
private String getWhereClause()
{
String whereClause = "";
@ -563,7 +595,7 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
return whereClause;
} // getWhereClause
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;
@ -575,6 +607,9 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
getComponent().setTableEditorMode(b);
}
/**
* @return {@link Lookup}
*/
public Lookup getLookup() {
return lookup;
}
@ -588,10 +623,12 @@ public class WChosenboxSearchEditor extends WEditor implements ContextMenuListen
super.dynamicDisplay(ctx);
}
/**
* {@link ListSubModel} for {@link Chosenbox} auto complete
*/
private class MyListModel extends ListModelList<ValueNamePair> implements ListSubModel<ValueNamePair> {
/**
*
* generated serial id
*/
private static final long serialVersionUID = -1210525428410505409L;

View File

@ -38,6 +38,7 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.theme.ThemeManager;
import org.compiere.model.GridField;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.compiere.util.Util;
@ -52,7 +53,8 @@ import org.zkoss.zul.Html;
import org.zkoss.zul.Menuitem;
/**
*
* Default editor for {@link DisplayType#Color}.<br/>
* Implemented with {@link EditorBox} component and HTML color type (&lt;input type="color"&gt;).
* @author Nicolas Micoud (TGI)
*
*/
@ -62,10 +64,11 @@ public class WColorEditor extends WEditor implements ContextMenuListener
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK};
public static final String COLOR_PICKER_EVENT = "COLOR_PICKER";
/** Hex coded color value, for e.g #FF0000 */
private String oldValue;
/** Place holder text for text box */
private String placeHolder;
/** Hidden text box with type set to color. Use to open HTML native color picker. */
private Textbox colorbox;
/**
@ -160,6 +163,9 @@ public class WColorEditor extends WEditor implements ContextMenuListener
return null;
}
/**
* Init component and context menu
*/
private void init()
{
if (log.isLoggable(Level.INFO)) log.info("Initializing component");
@ -169,6 +175,10 @@ public class WColorEditor extends WEditor implements ContextMenuListener
addChangeLogMenu(popupMenu);
}
/**
* Add entries to popup context menu
* @param popupMenu
*/
protected void addColorEditorMenu(WEditorPopupMenu popupMenu) {
Menuitem editor = new Menuitem();
editor.setAttribute("EVENT", WEditorPopupMenu.RESET_EVENT);
@ -191,6 +201,7 @@ public class WColorEditor extends WEditor implements ContextMenuListener
popupMenu.appendChild(editor);
}
@Override
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.RESET_EVENT.equals(evt.getContextEvent()))
@ -229,6 +240,9 @@ public class WColorEditor extends WEditor implements ContextMenuListener
fillTextbox();
}
/**
* Fill half of text box with entered color value
*/
private void fillTextbox() {
String style="background-color: transparent !important;";
if (!Util.isEmpty(oldValue, true))
@ -241,7 +255,7 @@ public class WColorEditor extends WEditor implements ContextMenuListener
}
/**
* @param color hex color string
* @param color hex coded color string
* @return background fill style
*/
protected String getBackgroundFillStyle(String color) {
@ -271,6 +285,7 @@ public class WColorEditor extends WEditor implements ContextMenuListener
getComponent().getButton().setEnabled(readWrite);
}
@Override
public void onEvent(Event event)
{
if (Events.ON_CLICK.equalsIgnoreCase(event.getName()))
@ -283,12 +298,19 @@ public class WColorEditor extends WEditor implements ContextMenuListener
}
}
/**
* Open HTML native color picker
*/
public void openColorPicker() {
String uid = colorbox.getUuid();
String script = "(function(){let wgt = zk.Widget.$('#"+uid+"');wgt.$n().click();})()";
Clients.response(new AuScript(script));
}
/**
* Process newValue from color picker
* @param newValue
*/
protected void processNewValue(String newValue) {
if (oldValue != null && newValue != null && oldValue.equals(newValue)) {
return;
@ -301,6 +323,7 @@ public class WColorEditor extends WEditor implements ContextMenuListener
oldValue = getComponent().getTextbox().getValue();
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;

View File

@ -31,6 +31,7 @@ import org.adempiere.webui.desktop.DashboardController;
import org.compiere.model.GridField;
import org.compiere.model.MDashboardContent;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Util;
import org.zkoss.zk.ui.event.Event;
@ -41,6 +42,8 @@ import org.zkoss.zul.Panel;
import org.zkoss.zul.Panelchildren;
/**
* Default editor for {@link DisplayType#DashboardContent}.<br/>
* A readonly editor that render dashboard content from {@link MDashboardContents} to {@link Panel} component.
* @author hengsin
*
*/
@ -64,7 +67,7 @@ public class WDashboardContentEditor extends WEditor {
/**
*
* @param gridField
* @param gridField GridField for PA_DashboardContent_ID
* @param windowNo
* @param tableEditor
* @param editorConfiguration
@ -97,8 +100,8 @@ public class WDashboardContentEditor extends WEditor {
}
}
/* (non-Javadoc)
* @see org.adempiere.webui.editor.WEditor#setReadWrite(boolean)
/**
* No op.
*/
@Override
public void setReadWrite(boolean readWrite) {
@ -112,29 +115,32 @@ public class WDashboardContentEditor extends WEditor {
return false;
}
/* (non-Javadoc)
* @see org.adempiere.webui.editor.WEditor#setValue(java.lang.Object)
/**
* No op.
*/
@Override
public void setValue(Object value) {
}
/* (non-Javadoc)
* @see org.adempiere.webui.editor.WEditor#getValue()
/**
* Always return null.
*/
@Override
public Object getValue() {
return null;
}
/* (non-Javadoc)
* @see org.adempiere.webui.editor.WEditor#getDisplay()
/**
* Always return null.
*/
@Override
public String getDisplay() {
return null;
}
/**
* Post {@link #ON_RENDER_CONTENT} event to render dashboard content.
*/
@Override
public void dynamicDisplay() {
super.dynamicDisplay();
@ -149,6 +155,10 @@ public class WDashboardContentEditor extends WEditor {
return (Panel) super.getComponent();
}
/**
* Render dashboard content
* @throws Exception
*/
private void render() throws Exception {
Panel panel = getComponent();
panel.setSclass("dashboard-field-panel");

View File

@ -29,11 +29,13 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.window.WFieldRecordInfo;
import org.compiere.model.GridField;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
/**
*
* Default editor for {@link DisplayType#Date}.<br/>
* Implemented with {@link Datebox} component.
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 12, 2007
* @version $Revision: 0.10 $
@ -72,16 +74,15 @@ public class WDateEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Constructor for use if a grid field is unavailable
*
* @param label
* column name (not displayed)
* field label
* @param description
* description of component
* field description
* @param mandatory
* whether a selection must be made
* whether field is mandatory
* @param readonly
* whether or not the editor is read only
* @param updateable
@ -94,6 +95,9 @@ public class WDateEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Default constructor
*/
public WDateEditor()
{
this("Date", "Date", false, false, true);
@ -113,6 +117,9 @@ public class WDateEditor extends WEditor implements ContextMenuListener
super(new Datebox(), columnName, title, null, mandatory, readonly, updateable);
}
/**
* Init component and context menu
*/
private void init()
{
popupMenu = new WEditorPopupMenu(false, false, isShowPreference());
@ -122,7 +129,7 @@ public class WDateEditor extends WEditor implements ContextMenuListener
getComponent().setPlaceholder(gridField.getPlaceholder());
}
@Override
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equalsIgnoreCase(event.getName()) || Events.ON_OK.equalsIgnoreCase(event.getName()))
@ -149,18 +156,14 @@ public class WDateEditor extends WEditor implements ContextMenuListener
@Override
public String getDisplay()
{
// Elaine 2008/07/29
return getComponent().getText();
//
}
@Override
public Timestamp getValue()
{
// Elaine 2008/07/25
if(getComponent().getValue() == null) return null;
return Timestamp.valueOf(getComponent().getValue().toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime());
//
}
@Override
@ -211,12 +214,12 @@ public class WDateEditor extends WEditor implements ContextMenuListener
getComponent().setEnabled(readWrite);
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;
}
@Override
public void onMenu(ContextMenuEvent evt) {
if (WEditorPopupMenu.CHANGE_LOG_EVENT.equals(evt.getContextEvent()))

View File

@ -37,7 +37,8 @@ import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
/**
*
* Default editor for {@link DisplayType#DateTime} and {@link DisplayType#TimestampWithTimeZone}.
* Implemented with {@link DatetimeBox} component.
* @author Low Heng Sin
*/
public class WDatetimeEditor extends WEditor implements ContextMenuListener
@ -65,6 +66,8 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
/**
*
* @param gridField
* @param tableEditor
* @param editorConfiguration
*/
public WDatetimeEditor(GridField gridField, boolean tableEditor, IEditorConfiguration editorConfiguration)
{
@ -72,16 +75,15 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Constructor for use if a grid field is unavailable
*
* @param label
* column name (not displayed)
* field label
* @param description
* description of component
* field description
* @param mandatory
* whether a selection must be made
* whether a field is mandatory
* @param readonly
* whether or not the editor is read only
* @param updateable
@ -94,6 +96,9 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Default constructor
*/
public WDatetimeEditor()
{
this(Msg.getMsg(Env.getCtx(), "DateTime"), Msg.getMsg(Env.getCtx(), "DateTime"), false, false, true);
@ -105,7 +110,7 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
* @param mandatory
* @param readonly
* @param updateable
* @param title
* @param title field label
*/
public WDatetimeEditor(String columnName, boolean mandatory, boolean readonly, boolean updateable,
String title)
@ -114,6 +119,9 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Init component and popup context menu
*/
private void init()
{
popupMenu = new WEditorPopupMenu(false, false, isShowPreference());
@ -145,6 +153,9 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
}
}
/**
* @return true if this is for {@link DisplayType#TimestampWithTimeZone}
*/
private boolean isTimestampWithTimeZone()
{
if (gridField != null)
@ -189,18 +200,14 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
@Override
public String getDisplay()
{
// Elaine 2008/07/29
return getComponent().getText();
//
}
@Override
public Object getValue()
{
// Elaine 2008/07/25
if(getComponent().getValue() == null) return null;
return Timestamp.valueOf(getComponent().getValue().toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime());
//
}
@Override
@ -260,18 +267,17 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
return getComponent().isEnabled();
}
@Override
public void setReadWrite(boolean readWrite) {
getComponent().setEnabled(readWrite);
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;
}
@Override
public void onMenu(ContextMenuEvent evt) {
if (WEditorPopupMenu.CHANGE_LOG_EVENT.equals(evt.getContextEvent()))
@ -285,7 +291,6 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
}
}
/* (non-Javadoc)
* @see org.adempiere.webui.editor.WEditor#setFieldStyle(java.lang.String)
*/

View File

@ -28,7 +28,9 @@ import org.adempiere.util.GridRowCtx;
import org.adempiere.webui.AdempiereWebUI;
import org.adempiere.webui.ClientInfo;
import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.adwindow.ADTabpanel;
import org.adempiere.webui.adwindow.ADWindow;
import org.adempiere.webui.adwindow.GridTabRowRenderer;
import org.adempiere.webui.adwindow.IFieldEditorContainer;
import org.adempiere.webui.component.Bandbox;
import org.adempiere.webui.component.Button;
@ -39,6 +41,8 @@ import org.adempiere.webui.component.EditorBox;
import org.adempiere.webui.component.Label;
import org.adempiere.webui.component.NumberBox;
import org.adempiere.webui.component.Paymentbox;
import org.adempiere.webui.component.WListItemRenderer;
import org.adempiere.webui.component.WListbox;
import org.adempiere.webui.event.ContextMenuListener;
import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener;
@ -61,6 +65,7 @@ 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.Combobox;
import org.zkoss.zul.Html;
import org.zkoss.zul.Menuitem;
import org.zkoss.zul.Textbox;
import org.zkoss.zul.Timebox;
@ -68,17 +73,22 @@ import org.zkoss.zul.impl.InputElement;
import org.zkoss.zul.impl.XulElement;
/**
*
* Base class for field editor.
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 11, 2007
* @version $Revision: 0.10 $
*/
public abstract class WEditor implements EventListener<Event>, PropertyChangeListener, IInputValidator
{
private static final String[] lISTENER_EVENTS = {};
/** Component attribute to store reference to WEditor instance */
public static final String IDEMPIERE_EDITOR_ATTR = "idempiere.editor";
private static final String[] lISTENER_EVENTS = {};
/** Max display length for string editor */
public static final int MAX_DISPLAY_LENGTH = 35;
/** Event to indicate start of editing a text field */
public static final String INIT_EDIT_EVENT = "onInitEdit";
protected GridField gridField;
@ -87,12 +97,14 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
protected Label label;
/** Component of this editor */
protected Component component;
protected boolean mandatory;
protected ArrayList<ValueChangeListener> listeners = new ArrayList<ValueChangeListener>();
/** label text */
private String strLabel;
private String description;
@ -101,18 +113,22 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
private String columnName;
/** Context menu */
protected WEditorPopupMenu popupMenu;
/** true if it is use inside a grid/list view */
protected boolean tableEditor;
/** true if this is use for process parameter field */
private boolean isProcessParameter;
/** Optional expected input string */
private String sValidInput;
private final List<DynamicDisplayListener> dynamicDisplayListeners = new ArrayList<>();
/**
* call to show context menu of this field.
* call to show context menu of this field.<br/>
* must call after append component of this field to parent
*/
public void showMenu() {
@ -235,21 +251,19 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
* Normal zk component just fire onChange event when user loss focus
* call this method with true value let component fire event when user type first character
*
* remark: editor set true for this method also need handle INIT_EDIT_EVENT to take effect,
* can refer implement at {@link WStringEditor#onEvent(Event)}
* By default, zk component fire onChange event when component loss focus.<br/>
* Call this method with true value let component fire event when user type first character.
* <br/>
* Note: editor that set this to true also need to handle INIT_EDIT_EVENT to take effect,
* please see implementation at {@link WStringEditor#onEvent(Event)} for reference.
* @param isChangeEventWhenEditing
*/
public void setChangeEventWhenEditing (boolean isChangeEventWhenEditing){
this.component.setWidgetOverride("isChangeEventWhenEditing", String.valueOf(isChangeEventWhenEditing));
}
/**
* Method is used to distinguish between 2 similar WSearchEditors
*
* @return description
*/
public String getDescription()
{
@ -258,37 +272,28 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
* Constructor for use if a grid field is unavailable
* Constructor to use if a grid field is unavailable
*
* @param comp The editor's component
* @param label column name (not displayed)
* @param label field label
* @param description description of component
* @param mandatory whether a selection must be made
* @param mandatory whether field is mandatory
* @param readonly whether or not the editor is read only
* @param updateable whether the editor contents can be changed
*/
public WEditor(Component comp, String label, String description, boolean mandatory, boolean readonly, boolean updateable)
{
if (comp == null)
{
throw new IllegalArgumentException("Component cannot be null");
}
this.setComponent(comp);
this.setMandatory(mandatory);
this.readOnly = readonly;
this.description = description;
this.strLabel = label;
init();
this(comp, null, label, description, mandatory, readonly, updateable);
}
/**
* Constructor for use if a grid field is unavailable
* Constructor to use if a grid field is unavailable
*
* @param comp The editor's component
* @param label column name (not displayed)
* @param columnName column name
* @param label field label
* @param description description of component
* @param mandatory whether a selection must be made
* @param mandatory whether field is mandatory
* @param readonly whether or not the editor is read only
* @param updateable whether the editor contents can be changed
*/
@ -318,6 +323,9 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
this.component = comp;
}
/**
* Init label and component
*/
private void init()
{
label = new Label("");
@ -338,7 +346,7 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
component.addEventListener(INIT_EDIT_EVENT, this);
component.setAttribute("idempiere.editor", this);
component.setAttribute(IDEMPIERE_EDITOR_ATTR, this);
component.addEventListener(Events.ON_FOCUS, e -> {
ADWindow adwindow = ADWindow.findADWindow(component);
@ -349,7 +357,6 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
*
* @return grid field for this editor ( can be null )
*/
public GridField getGridField()
@ -358,8 +365,7 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
*
* @return columnNames
* @return column name
*/
public String getColumnName()
{
@ -368,10 +374,10 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
/**
* Remove the table qualifier from the supplied column name.
*
* <p>
* The column name may be prefixed with the table name
* i.e. <code>[table name].[column name]</code>.
* The function returns
* The function returns the [column name] part.
*
* @param originalColumnName The column name to clean
* @return the column name with any table qualifier removed
@ -391,6 +397,9 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
return cleanColumnName;
}
/**
* @param columnName
*/
protected void setColumnName(String columnName)
{
String cleanColumnName = cleanColumnName(columnName);
@ -424,6 +433,7 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
* Handle PropertyChangeEvent from {@link #gridField}.
* @param evt
*/
public void propertyChange(final PropertyChangeEvent evt)
@ -444,7 +454,7 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
* @param listener
* @param listener ValueChangeListener
*/
public void addValueChangeListener(ValueChangeListener listener)
{
@ -457,11 +467,19 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
listeners.add(listener);
}
/**
* @param listener
* @return true if listener is found and remove from {@link #listeners}
*/
public boolean removeValuechangeListener(ValueChangeListener listener)
{
return listeners.remove(listener);
}
/**
* Fire ValueChangeEvent to ValueChangeListener in {@link #listeners}
* @param event
*/
protected void fireValueChange(ValueChangeEvent event)
{
//copy to array to avoid concurrent modification exception
@ -490,7 +508,7 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
/**
*
* @return editable
* @return true if editable
*/
public abstract boolean isReadWrite();
@ -505,8 +523,8 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
/**
*
* @param visible
* @param labelVisible
* @param visible visibility for component
* @param labelVisible visibility for label
*/
public void setVisible(boolean visible, boolean labelVisible)
{
@ -516,7 +534,7 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
/**
*
* @return is visible
* @return true if component is visible
*/
public boolean isVisible()
{
@ -524,7 +542,8 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
* Indicating error with changing the style.
* Indicating error with changing the style.<br/>
* No op. here, for subclass to implement.
* @param error
*/
public void setBackground(boolean error)
@ -532,11 +551,17 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
* Set background color of component.<br/>
* No op. here, for subclass to implement.
* @param color
*/
public void setBackground(Color color)
{
}
@Override
public String toString()
{
StringBuilder sb = new StringBuilder(30);
@ -548,14 +573,13 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
*
* Set editor value
* @param value
*/
abstract public void setValue(Object value);
/**
*
* @return Object
* @return Object, current value of editor
*/
abstract public Object getValue();
@ -565,10 +589,19 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
*/
abstract public String getDisplay();
/**
* @param value
* @return display text for grid view, for consumption by {@link #getDisplayComponent()}
*/
public String getDisplayTextForGridView(Object value) {
return getDisplayTextForGridView(null, value);
}
/**
* @param gridRowCtx {@link GridRowCtx}
* @param value
* @return display text for grid view, for consumption by {@link #getDisplayComponent()}
*/
public String getDisplayTextForGridView(GridRowCtx gridRowCtx, Object value) {
this.setValue(value);
String s = getDisplay();
@ -580,7 +613,7 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
/**
*
* @return list of events
* @return list of {@link #component} events that this editor will listen to
*/
public String[] getEvents()
{
@ -605,20 +638,24 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
/**
*
* @return boolean
* @return true if field is mandatory
*/
public boolean isMandatory()
{
return this.mandatory;
}
/**
* Dynamic update of component state
*/
public void dynamicDisplay()
{
dynamicDisplay(gridField != null ? gridField.getVO().ctx : Env.getCtx());
}
/**
* allow subclass to perform dynamic loading of data
* Dynamic update of component state
* @param ctx
*/
public void dynamicDisplay(Properties ctx)
{
@ -627,20 +664,31 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
updateStyle();
}
if (!dynamicDisplayListeners.isEmpty())
dynamicDisplayListeners.stream().forEach(e -> e.onDynamicDisplay(ctx, this));
if (!dynamicDisplayListeners.isEmpty())
dynamicDisplayListeners.stream().forEach(e -> e.onDynamicDisplay(ctx, this));
}
/**
* Update label and component style
* @param applyDictionaryStyle
*/
public void updateStyle(boolean applyDictionaryStyle) {
applyLabelStyles(applyDictionaryStyle);
applyFieldStyles(applyDictionaryStyle);
}
/**
* Update label and component style
*/
public void updateStyle() {
applyLabelStyles(true);
applyFieldStyles(true);
}
/**
* Update label styles
* @param applyDictionaryStyle
*/
protected void applyLabelStyles(boolean applyDictionaryStyle) {
if (label != null) {
boolean zoomable = isZoomable();
@ -673,6 +721,10 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
}
/**
* Set label style
* @param style sclass name (@sclass=) or zclass name (@zclass=) or css style string
*/
protected void setLabelStyle(String style) {
if (label != null) {
if (style != null && style.toLowerCase().startsWith(MStyle.SCLASS_PREFIX)) {
@ -684,11 +736,13 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
} else {
label.setStyle(style);
}
// if (this instanceof WRadioGroupEditor)
// System.out.println(getComponent().getUuid() + " label stype="+label.getStyle());
}
}
/**
* Update field styles
* @param applyDictionaryStyle
*/
protected void applyFieldStyles(boolean applyDictionaryStyle) {
String style = null;
if (applyDictionaryStyle && gridField.getAD_FieldStyle_ID() > 0)
@ -699,6 +753,10 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
setFieldMandatoryStyle(applyDictionaryStyle);
}
/**
* Add mandatory style to field
* @param applyStyle
*/
private void setFieldMandatoryStyle(boolean applyStyle) {
HtmlBasedComponent component = (HtmlBasedComponent) getComponent();
if (component != null) {
@ -709,6 +767,10 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
}
/**
* Set field style
* @param style sclass name (@sclass=) or zclass name (@zclass=) or css style string
*/
protected void setFieldStyle(String style) {
HtmlBasedComponent component = (HtmlBasedComponent) getComponent();
if (style != null && style.startsWith(MStyle.SCLASS_PREFIX)) {
@ -744,13 +806,18 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
return true;
}
/**
* Build css inline style from AD_Style record
* @param AD_Style_ID
* @return css inline style string
*/
protected String buildStyle(int AD_Style_ID) {
MStyle style = MStyle.get(Env.getCtx(), AD_Style_ID);
return style.buildStyle(ThemeManager.getTheme(), getStyleEvaluatee());
}
/**
* Stretch editor component to fill container
* Stretch editor component to fill parent
*/
public void fillHorizontal() {
//stretch component to fill grid cell
@ -811,15 +878,24 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
updateStyle();
}
/**
* @return true if mandatory style should be added to editor
*/
public boolean isMandatoryStyle() {
return mandatory && !readOnly && (isProcessParameter || getGridField().isEditable(true)) && isNullOrEmpty();
}
/**
* @return true if current value of editor is null or empty
*/
public boolean isNullOrEmpty() {
Object value = getValue();
return value == null || value.toString().trim().length() == 0;
}
/**
* @return true if editor support zoom command
*/
public boolean isZoomable() {
WEditorPopupMenu menu = getPopupMenu();
if (menu != null && menu.isZoomEnabled() && this instanceof IZoomableEditor) {
@ -829,18 +905,23 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
}
public void setTableEditor(boolean b) {
tableEditor = b;
/**
* Set grid view mode. Have no effect if editor doesn't has a separate grid view mode.
* @param tableEditorMode
*/
public void setTableEditor(boolean tableEditorMode) {
tableEditor = tableEditorMode;
}
/**
* @return boolean
* @return true if preference dialog is available and accessible
*/
protected boolean isShowPreference() {
return MRole.getDefault().isShowPreference() && gridField != null && !gridField.isEncrypted() && !gridField.isEncryptedColumn() && !gridField.isVirtualColumn();
}
/**
* Add record info entry to context menu
* @param popupMenu
*/
protected void addChangeLogMenu(WEditorPopupMenu popupMenu) {
@ -851,6 +932,7 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
* Add text editor dialog entry to context menu
* @param popupMenu
*/
protected void addTextEditorMenu(WEditorPopupMenu popupMenu) {
@ -865,6 +947,10 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
popupMenu.appendChild(editor);
}
/**
* @param comp
* @return true if comp is own by this editor instance
*/
public boolean isComponentOfEditor(Component comp) {
if (comp == getComponent())
return true;
@ -903,24 +989,38 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
return false;
}
/**
* @return true if editor is use for process parameter field
*/
public boolean isProcessParameter() {
return isProcessParameter;
}
/**
* Set to true if editor is use for process parameter field
* @param isProcessParameter
*/
public void setProcessParameter(boolean isProcessParameter) {
this.isProcessParameter = isProcessParameter;
}
/**
* return component use for display value in grid view mode in non edit status
* if return null, a label will replace.
* because each row must has one instance of this component, don't cache it. just create new instance
* @return
* Return component use for display mode in {@link ADTabpanel} grid view ({@link GridTabRowRenderer}) or custom editor
* of {@link WListItemRenderer}.<br/>
* For {@link GridTabRowRenderer}, only {@link Html} is supported and will use content
* from {@link #getDisplayTextForGridView(GridRowCtx, Object)}.<br/>
* For {@link WListItemRenderer}, {@link Html}, {@link Label} and {@link InputElement} is supported.<br/>
* Return null to use the default of {@link ADTabpanel} or {@link WListbox}.<br/>
* Note: because each row must has one instance of this component, don't reuse, must always create new instance.<br/>
* @return Display {@link Component}
*/
public Component getDisplayComponent() {
return null;
}
/**
* Set focus to next editor
*/
protected void focusNext() {
Component comp = getComponent();
Component parent = comp.getParent();
@ -933,6 +1033,10 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
}
/**
* Return Evaluatee for {@link #buildStyle(int)} use.
* @return Evaluatee
*/
protected Evaluatee getStyleEvaluatee() {
return new EvaluateeWrapper(this, gridField, tableEditor);
}
@ -987,24 +1091,23 @@ public abstract class WEditor implements EventListener<Event>, PropertyChangeLis
}
/**
* add listener
* @param listener
* add listener for {@link #dynamicDisplay(Properties)}
* @param listener {@link DynamicDisplayListener}
*/
public void addDynamicDisplayListener(DynamicDisplayListener listener) {
dynamicDisplayListeners.add(listener);
}
/**
*
* @param listener
* @return true if listener is found and remove from listener list
* @param listener {@link DynamicDisplayListener}
* @return true if listener is found and remove from listener list ({@link #dynamicDisplayListeners}).
*/
public boolean removeDynamicDisplayListener(DynamicDisplayListener listener) {
return dynamicDisplayListeners.remove(listener);
}
/**
* interface for dynamic display event
* interface for dynamic display listener
*/
public static interface DynamicDisplayListener {
/**

View File

@ -41,7 +41,7 @@ import org.zkoss.zk.ui.event.Events;
import org.zkoss.zul.Menuitem;
/**
*
* Popup context menu for {@link WEditor}.
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 25, 2007
* @version $Revision: 0.10 $
@ -49,16 +49,17 @@ import org.zkoss.zul.Menuitem;
public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
{
/**
*
* generated serial id
*/
private static final long serialVersionUID = 6190279880520042885L;
/** Menu item attribute to store context menu event name (zoom, requery, etc) */
public static final String EVENT_ATTRIBUTE = "EVENT";
public static final String ZOOM_EVENT = "ZOOM";
public static final String REQUERY_EVENT = "REQUERY";
public static final String PREFERENCE_EVENT = "VALUE_PREFERENCE";
public static final String NEW_EVENT = "NEW_RECORD";
public static final String UPDATE_EVENT = "UPDATE_RECORD"; // Elaine 2009/02/16 - update record
public static final String UPDATE_EVENT = "UPDATE_RECORD";
public static final String SHOWLOCATION_EVENT = "SHOW_LOCATION";
public static final String CHANGE_LOG_EVENT = "CHANGE_LOG";
public static final String EDITOR_EVENT = "EDITOR";
@ -67,7 +68,7 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
public static final String DRILL_EVENT = "DRILL";
private boolean newEnabled = true;
private boolean updateEnabled = true; // Elaine 2009/02/16 - update record
private boolean updateEnabled = true;
private boolean zoomEnabled = true;
private boolean requeryEnabled = true;
private boolean preferencesEnabled = true;
@ -78,15 +79,20 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
private Menuitem requeryItem;
private Menuitem prefItem;
private Menuitem newItem;
private Menuitem updateItem; // Elaine 2009/02/16 - update record
private Menuitem updateItem;
private Menuitem showLocationItem;
private Menuitem drillItem;
private ArrayList<ContextMenuListener> menuListeners = new ArrayList<ContextMenuListener>();
/**
* @param zoom
* @param requery
* @param preferences
*/
public WEditorPopupMenu(boolean zoom, boolean requery, boolean preferences)
{
this(zoom, requery, preferences, false, false, false, false, null); // no check zoom
this(zoom, requery, preferences, false, false, false, false, null);
}
@Deprecated
@ -107,6 +113,15 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
this(zoom, requery, preferences, newRecord, updateRecord, false, null);
}
/**
* @param zoom
* @param requery
* @param preferences
* @param newRecord
* @param updateRecord
* @param showLocation
* @param lookup
*/
public WEditorPopupMenu(boolean zoom, boolean requery, boolean preferences, boolean newRecord, boolean updateRecord, boolean showLocation, Lookup lookup)
{
this(zoom, requery, preferences, newRecord, updateRecord, showLocation, false, lookup);
@ -119,6 +134,7 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
* @param newRecord - enable new record (ignored and recalculated if lookup is received)
* @param updateRecord - enable update record (ignored and recalculated if lookup is received)
* @param showLocation - enable show location in menu
* @param drillEnabled - enable drill assistant menu
* @param lookup - when this parameter is received then new and update are calculated based on the zoom and quickentry
*/
public WEditorPopupMenu(boolean zoom, boolean requery, boolean preferences, boolean newRecord, boolean updateRecord, boolean showLocation, boolean drillEnabled, Lookup lookup)
@ -128,7 +144,7 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
this.requeryEnabled = requery;
this.preferencesEnabled = preferences;
this.newEnabled = newRecord;
this.updateEnabled = updateRecord; // Elaine 2009/02/16 - update record
this.updateEnabled = updateRecord;
this.showLocation = showLocation;
this.drillEnabled = drillEnabled;
@ -182,7 +198,13 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
init();
}
boolean hasQuickEntryField(int winID, int winIDPO, String tableName) {
/**
* @param winID
* @param winIDPO
* @param tableName
* @return true if window has quick entry fields (i.e AD_Field.IsQuickEntry=Y)
*/
protected boolean hasQuickEntryField(int winID, int winIDPO, String tableName) {
return DB.getSQLValueEx(null,
"SELECT COUNT(*) "
+ "FROM AD_Field f "
@ -197,10 +219,16 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
winID,winIDPO,tableName) > 0;
}
/**
* @return true if zoom is enable
*/
public boolean isZoomEnabled() {
return zoomEnabled;
}
/**
* Init context menu items
*/
private void init()
{
if (zoomEnabled)
@ -256,7 +284,6 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
this.appendChild(newItem);
}
// Elaine 2009/02/16 - update record
if (updateEnabled)
{
updateItem = new Menuitem();
@ -297,12 +324,17 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
}
}
/**
* Add context menu listener
* @param listener {@link ContextMenuListener}
*/
public void addMenuListener(ContextMenuListener listener)
{
if (!menuListeners.contains(listener))
menuListeners.add(listener);
}
@Override
public void onEvent(Event event)
{
String evt = (String)event.getTarget().getAttribute(EVENT_ATTRIBUTE);
@ -320,6 +352,10 @@ public class WEditorPopupMenu extends Menupopup implements EventListener<Event>
}
}
/**
* Add field suggestion context menu item
* @param field
*/
public void addSuggestion(final GridField field) {
if (!MRole.getDefault().isTableAccessExcluded(MFieldSuggestion.Table_ID)) {
Menuitem editor = new Menuitem(Msg.getElement(Env.getCtx(), "AD_FieldSuggestion_ID"));

View File

@ -21,12 +21,14 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.theme.ThemeManager;
import org.compiere.model.GridField;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
/**
*
* Default editor for {@link DisplayType#FilePath}.<br/>
* Implemented with {@link FilenameBox} (with upload disable) and {@link FolderBrowser} component.
* @author Low Heng Sin
*
*/
@ -37,6 +39,7 @@ public class WFileDirectoryEditor extends WEditor
@SuppressWarnings("unused")
private static final CLogger log = CLogger.getCLogger(WFileDirectoryEditor.class);
/** absolute folder/directory path */
private String oldValue;
/**
@ -109,6 +112,7 @@ public class WFileDirectoryEditor extends WEditor
getComponent().setEnabled(readWrite);
}
@Override
public void onEvent(Event event)
{
String newValue = null;
@ -134,6 +138,10 @@ public class WFileDirectoryEditor extends WEditor
processNewValue(newValue);
}
/**
* Process newValue from user input
* @param newValue
*/
protected void processNewValue(String newValue) {
if (oldValue != null && newValue != null && oldValue.equals(newValue)) {
return;
@ -146,7 +154,7 @@ public class WFileDirectoryEditor extends WEditor
}
/**
* Load file
* Open folder selection dialog ({@link FolderBrowser}.
*/
private void cmd_file()
{
@ -162,6 +170,7 @@ public class WFileDirectoryEditor extends WEditor
});
} // cmd_file
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;

View File

@ -27,13 +27,15 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.theme.ThemeManager;
import org.compiere.model.GridField;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.zkoss.util.media.Media;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
import org.zkoss.zk.ui.event.UploadEvent;
/**
*
* Default editor for {@link DisplayType#FileName}.<br/>
* Implemented with {@link FilenameBox} component with upload enabled.
* @author Low Heng Sin
*
*/
@ -43,6 +45,7 @@ public class WFilenameEditor extends WEditor
private static final CLogger log = CLogger.getCLogger(WFilenameEditor.class);
/** absolute folder path + file name */
private String oldValue;
/**
@ -117,6 +120,7 @@ public class WFilenameEditor extends WEditor
getComponent().setEnabled(readWrite);
}
@Override
public void onEvent(Event event)
{
String newValue = null;
@ -140,6 +144,10 @@ public class WFilenameEditor extends WEditor
processNewValue(newValue);
}
/**
* Process newValue from user input
* @param newValue
*/
protected void processNewValue(String newValue) {
if (oldValue != null && newValue != null && oldValue.equals(newValue)) {
return;
@ -151,13 +159,14 @@ public class WFilenameEditor extends WEditor
fireValueChange(changeEvent);
}
/**
* Process uploaded file from file selection dialog
* @param file {@link Media}
*/
private void processUploadMedia(Media file) {
if (file == null)
return;
// String fileName = System.getProperty("java.io.tmpdir") + System.getProperty("file.separator") + ;
// File tempFile = new File(fileName);
FileOutputStream fos = null;
String fileName = null;
try {
@ -203,6 +212,7 @@ public class WFilenameEditor extends WEditor
processNewValue(getComponent().getText());
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;

View File

@ -41,10 +41,9 @@ import org.zkoss.zul.Html;
/**
* HTML Editor
* <p> Implementation of an editor to show HTML content </p>
* Default editor for html (AD_Field.IsHtml=Y) text display type (String, PrinterName, Text, TextLong and Memo). <br/>
* Implemented with {@link Html} component and html editor dialog ({@link WTextEditorDialog}) to show and edit HTML content.
*
* Based on contribution from
* @author muriloht (muriloht@devcoffee.com.br, http://www.devcoffee.com.br)
* @version $Id: WHTMLEditor.java, v1.0 11/11/2014 20:25:06, muriloht Exp $
*/
@ -55,7 +54,7 @@ public class WHtmlEditor extends WEditor implements ContextMenuListener
private AbstractADWindowContent adwindowContent;
/** HTML Model */
/** HTML component */
private Html box = null;
private boolean m_mandatory;
@ -91,6 +90,9 @@ public class WHtmlEditor extends WEditor implements ContextMenuListener
return (Div) component;
}
/**
* Init component and context menu.
*/
private void init()
{
if (log.isLoggable(Level.INFO)) log.info("Initializing component");
@ -133,7 +135,6 @@ public class WHtmlEditor extends WEditor implements ContextMenuListener
return m_mandatory;
}
@Override
public void setMandatory(boolean mandatory)
{
@ -198,6 +199,9 @@ public class WHtmlEditor extends WEditor implements ContextMenuListener
}
}
/**
* Open text and html editor dialog ({@link WTextEditorDialog}.
*/
private void editorEvent() {
adwindowContent = findADWindowContent();
final WTextEditorDialog dialog = new WTextEditorDialog(gridField.getVO().Header, getDisplay(),
@ -230,6 +234,9 @@ public class WHtmlEditor extends WEditor implements ContextMenuListener
dialog.focus();
}
/**
* @return AbstractADWindowContent that own the component of this editor instance
*/
private AbstractADWindowContent findADWindowContent() {
Component parent = getComponent().getParent();
while(parent != null) {

View File

@ -23,6 +23,7 @@ import org.adempiere.webui.window.WImageDialog;
import org.compiere.model.GridField;
import org.compiere.model.MImage;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.zkoss.image.AImage;
import org.zkoss.zk.ui.Component;
@ -34,10 +35,9 @@ import org.zkoss.zul.Cell;
import org.zkoss.zul.Image;
/**
* This class is based on org.compiere.grid.ed.VImage written by Jorg Janke.
* @author Jorg Janke
* Default editor for {@link DisplayType#Image}.<br/>
* Implemented with {@link Image} component and {@link WImageDialog}.
*
* Modifications - UI Compatibility
* @author Low Heng Sin
*/
public class WImageEditor extends WEditor
@ -94,6 +94,9 @@ public class WImageEditor extends WEditor
return (Image) component;
}
/**
* Init component
*/
private void init()
{
AImage img = null;
@ -189,6 +192,7 @@ public class WImageEditor extends WEditor
return LISTENER_EVENTS;
}
@Override
public void onEvent(Event event) throws Exception
{
if (Events.ON_CLICK.equals(event.getName()) && readwrite)
@ -221,8 +225,8 @@ public class WImageEditor extends WEditor
}
}
/* (non-Javadoc)
* @see org.adempiere.webui.editor.WEditor#fillHorizontal()
/**
* No op., doesn't support stretch of component.
*/
@Override
public void fillHorizontal() {

View File

@ -17,7 +17,6 @@
package org.adempiere.webui.editor;
import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;
import java.util.logging.Level;
@ -38,6 +37,7 @@ import org.compiere.model.GridField;
import org.compiere.model.MLocation;
import org.compiere.model.MLocationLookup;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.zkoss.zk.ui.event.Event;
@ -46,11 +46,12 @@ import org.zkoss.zk.ui.event.Events;
import org.zkoss.zk.ui.event.OpenEvent;
/**
* Default editor for {@link DisplayType#Location}.<br/>
* Implemented with {@link Locationbox} component and {@link WLocationDialog}.
* @author Sendy Yagambrum
* @date July 16, 2007
*
* This class is based on VLocation written by Jorg Janke
**/
*/
public class WLocationEditor extends WEditor implements EventListener<Event>, PropertyChangeListener, ContextMenuListener, IZoomableEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK};
@ -97,6 +98,9 @@ public class WLocationEditor extends WEditor implements EventListener<Event>, Pr
init();
}
/**
* Init component and context menu
*/
private void init()
{
if (ThemeManager.isUseFontIconForImage())
@ -164,7 +168,7 @@ public class WLocationEditor extends WEditor implements EventListener<Event>, Pr
/**
* Return Editor value
* @return value
* @return C_Location_ID
*/
public int getC_Location_ID()
{
@ -173,22 +177,12 @@ public class WLocationEditor extends WEditor implements EventListener<Event>, Pr
return m_value.getC_Location_ID();
}
/**
* Property Change Listener
* @param evt PropertyChangeEvent
*/
public void propertyChange (PropertyChangeEvent evt)
{
if (evt.getPropertyName().equals(org.compiere.model.GridField.PROPERTY))
setValue(evt.getNewValue());
}
@Override
public void onEvent(Event event) throws Exception
{
//
if ("onClick".equals(event.getName()))
{
if (log.isLoggable(Level.CONFIG)) log.config( "actionPerformed - " + m_value);
if (log.isLoggable(Level.CONFIG)) log.config( "onEvent - " + m_value);
final WLocationDialog ld = new WLocationDialog(Msg.getMsg(Env.getCtx(), "Location"), m_value, gridField);
final int oldValue = m_value == null ? 0 : m_value.getC_Location_ID();
ld.addEventListener(DialogEvents.ON_WINDOW_CLOSE, new EventListener<Event>() {

View File

@ -19,7 +19,6 @@ package org.adempiere.webui.editor;
import static org.compiere.model.SystemIDs.WINDOW_WAREHOUSE_LOCATOR;
import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
@ -50,6 +49,7 @@ import org.compiere.model.MWarehouse;
import org.compiere.model.X_M_MovementLine;
import org.compiere.util.CLogger;
import org.compiere.util.DB;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.zkoss.zk.ui.event.Event;
@ -57,25 +57,26 @@ import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
/**
* Locator Editor : Based on VLocator
* Default editor for {@link DisplayType#Locator}.<br/>
* Implemented with {@link EditorBox} component and {@link WLocatorDialog}.
*
* @author Niraj Sohun
* @date Jul 23, 2007
*/
public class WLocatorEditor extends WEditor implements EventListener<Event>, PropertyChangeListener, ContextMenuListener, IZoomableEditor
{
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK};
private MLocatorLookup m_mLocator;
/** M_Locator_ID */
private Object m_value;
private int m_WindowNo;
private static final CLogger log = CLogger.getCLogger(WLocatorEditor.class);
/**
* IDE Constructor
*/
/**
* Default Constructor
*/
public WLocatorEditor()
{
this("M_Locator_ID", false, false, true, null, 0);
@ -91,7 +92,6 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
* @param mLocator locator (lookup) model
* @param windowNo window no
*/
public WLocatorEditor( String columnName, boolean mandatory, boolean isReadOnly,
boolean isUpdateable, MLocatorLookup mLocator, int windowNo)
{
@ -105,8 +105,8 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
getComponent().setButtonImage(ThemeManager.getThemeResource("images/Locator16.png"));
getComponent().getTextbox().setReadonly(true);
m_WindowNo = windowNo; //Yvonne: move it b4 setDefault_Locator_ID()
setDefault_Locator_ID(); // set default locator, teo_sarca [ 1661546 ]
m_WindowNo = windowNo;
setDefault_Locator_ID();
}
/**
@ -133,7 +133,7 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
getComponent().setButtonImage(ThemeManager.getThemeResource("images/Locator16.png"));
getComponent().getTextbox().setReadonly(true);
setDefault_Locator_ID(); // set default locator, teo_sarca [ 1661546 ]
setDefault_Locator_ID();
m_WindowNo = gridField.getWindowNo();
@ -145,6 +145,10 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
}
}
/**
* @param value
*/
@Override
public void setValue(Object value)
{
setValue (value, false);
@ -152,10 +156,9 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
/**
* Set Value
* @param value value
* @param fire data binding
* @param value new value
* @param fire true to fire value change event
*/
private void setValue (Object value, boolean fire)
{
if(m_mLocator==null)
@ -187,7 +190,6 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
* Return Editor value
* @return value
*/
public Object getValue()
{
if (getM_Locator_ID() == 0)
@ -214,9 +216,8 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
/**
* Get M_Locator_ID
* @return id
* @return M_Locator_ID
*/
public int getM_Locator_ID()
{
if (m_value != null
@ -227,15 +228,16 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
} // getM_Locator_ID
/**
* Return Display Value
* @return display value
* Return Display text
* @return display text
*/
@Override
public String getDisplay()
{
return getComponent().getText();
} // getDisplay
@Override
public void onEvent(Event event) throws Exception
{
if (Events.ON_CLICK.equalsIgnoreCase(event.getName()))
@ -244,15 +246,13 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
int only_Warehouse_ID = getOnly_Warehouse_ID();
int only_Product_ID = getOnly_Product_ID();
if (log.isLoggable(Level.CONFIG)) log.config("Only Warehouse_ID=" + only_Warehouse_ID + ", Product_ID=" + only_Product_ID);
if (log.isLoggable(Level.CONFIG)) log.config("Only Warehouse_ID=" + only_Warehouse_ID + ", Only Product_ID=" + only_Product_ID);
// Text Entry ok
if (event.getTarget() == getComponent() && actionText(only_Warehouse_ID, only_Product_ID))
return;
// Button - Start Dialog
int M_Locator_ID = 0;
if (m_value instanceof Integer)
@ -269,7 +269,6 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
public void onEvent(Event event) throws Exception {
m_mLocator.setOnly_Warehouse_ID(0);
// redisplay
if (!ld.isChanged())
return;
setValue (ld.getValue(), true);
@ -300,6 +299,9 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
}
}
/**
* Refresh MLocator lookup
*/
public void actionRefresh()
{
if (m_mLocator != null)
@ -315,13 +317,12 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
}
}
@Override
public void actionZoom()
{
int AD_Window_ID = MTable.get(Env.getCtx(), MLocator.Table_ID).getAD_Window_ID();
if (AD_Window_ID <= 0)
AD_Window_ID = WINDOW_WAREHOUSE_LOCATOR; // hardcoded window Warehouse & Locators
log.info("");
//
MQuery zoomQuery = new MQuery();
zoomQuery.addRestriction(MLocator.COLUMNNAME_M_Locator_ID, MQuery.EQUAL, getValue());
@ -330,6 +331,7 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
AEnv.zoom(AD_Window_ID, zoomQuery);
}
@Override
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.REQUERY_EVENT.equals(evt.getContextEvent()))
@ -352,19 +354,18 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
}
/**
* Hit Enter in Text Field
* Process input text from user
* @param only_Warehouse_ID if not 0 restrict warehouse
* @param only_Product_ID of not 0 restricted product
* @return true if found
*/
private boolean actionText(int only_Warehouse_ID, int only_Product_ID)
{
String text = getComponent().getText();
log.fine(text);
if (log.isLoggable(Level.FINE))
log.fine(text);
// Null
if (text == null || text.length() == 0)
{
if (isMandatory())
@ -382,7 +383,6 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
text = text.toUpperCase() + "%";
// Look up - see MLocatorLookup.run
StringBuffer sql = new StringBuffer("SELECT M_Locator_ID FROM M_Locator ")
.append(" WHERE IsActive='Y' AND UPPER(Value) LIKE ")
.append(DB.TO_STRING(text));
@ -457,7 +457,7 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
* Set Field/WindowNo for ValuePreference (NOP)
* @param mField Model Field
*/
@Deprecated(forRemoval = true, since = "11")
public void setField (org.compiere.model.GridField mField)
{
} // setField
@ -466,7 +466,6 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
* Get Warehouse restriction if any.
* @return M_Warehouse_ID or 0
*/
protected int getOnly_Warehouse_ID()
{
//IDEMPIERE-4882 : Load Locator To field value as per Warehouse TO field value
@ -495,6 +494,7 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
}
catch (Exception ex)
{
log.log(Level.WARNING, ex.getMessage(), ex);
}
return only_Warehouse_ID;
@ -504,7 +504,6 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
* Get Product restriction if any.
* @return M_Product_ID or 0
*/
protected int getOnly_Product_ID()
{
if (!Env.isSOTrx(Env.getCtx(), m_WindowNo))
@ -528,6 +527,7 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
}
catch (Exception ex)
{
log.log(Level.WARNING, ex.getMessage(), ex);
}
return only_Product_ID;
} // getOnly_Product_ID
@ -538,11 +538,9 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
*
* @since 3.1.4
*/
private void setDefault_Locator_ID()
{
// teo_sarca, FR [ 1661546 ] Mandatory locator fields should use defaults
if (!isMandatory() || m_mLocator == null)
{
return;
@ -572,20 +570,10 @@ public class WLocatorEditor extends WEditor implements EventListener<Event>, Pro
setValue(Integer.valueOf(loc.get_ID()));
}
/**
* Property Change Listener
* @param evt PropertyChangeEvent
*/
public void propertyChange (PropertyChangeEvent evt)
{
if (evt.getPropertyName().equals(org.compiere.model.GridField.PROPERTY))
setValue(evt.getNewValue());
}
/**
* return listener events to be associated with editor component
*/
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;

View File

@ -38,6 +38,8 @@ import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
/**
* Default editor for {@link DisplayType#ID} and {@link DisplayType#isNumeric(int)}.<br/>
* Implemented with {@link NumberBox}.
*
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 11, 2007
@ -55,30 +57,34 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
public static final int MAX_DISPLAY_LENGTH = 35;
public static final int MIN_DISPLAY_LENGTH = 11;
/** Integer or BigDecimal */
private Object oldValue;
private int displayType;
private String originalStyle;
/**
* Default constructor, default to {@link DisplayType#Number}.
*/
public WNumberEditor()
{
this(DisplayType.Number);
}
/**
*
* @param displayType
*/
*
* @param displayType
*/
public WNumberEditor(int displayType)
{
this("Number", false, false, true, displayType, "");
}
/**
*
* @param gridField
*/
*
* @param gridField
*/
public WNumberEditor(GridField gridField)
{
this(gridField, false, null);
@ -107,6 +113,13 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Create new {@link NumberBox} instance.
* @param gridField
* @param tableEditor
* @param editorConfiguration
* @return NumberBox
*/
protected static NumberBox newNumberBox(GridField gridField, boolean tableEditor, IEditorConfiguration editorConfiguration) {
if (editorConfiguration != null && editorConfiguration instanceof INumberEditorConfiguration) {
INumberEditorConfiguration config = (INumberEditorConfiguration) editorConfiguration;
@ -119,7 +132,7 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
/**
*
* @param gridField
* @param integral
* @param integral true to create NumberBox for DisplayType.Integer
*/
public WNumberEditor(GridField gridField, boolean integral)
{
@ -153,6 +166,9 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Init component and context menu
*/
private void init()
{
setChangeEventWhenEditing (true);
@ -166,8 +182,6 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
displayLength = MIN_DISPLAY_LENGTH;
if (!tableEditor)
getComponent().getDecimalbox().setCols(displayLength);
// else
// getComponent().getDecimalbox().setCols(0);
}
if (DisplayType.isID(displayType))
@ -199,6 +213,7 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
* Event handler
* @param event
*/
@Override
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equalsIgnoreCase(event.getName()) || Events.ON_OK.equalsIgnoreCase(event.getName()))
@ -238,7 +253,9 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
/**
* IDEMPIERE-2553 - Enter amounts without decimal separator
* @param oldValue
* @return
* @return oldValue (if oldValue is already with decimal point)<br/>
* or oldValue divided by AutomaticDecimalPlacesForAmoun value from Env context
* (for e.g, if AutomaticDecimalPlacesForAmoun=2, oldValue/100)
*/
public BigDecimal addDecimalPlaces(BigDecimal oldValue){
if(oldValue.toString().contains("."))
@ -257,8 +274,11 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
divisor = BigDecimal.TEN.pow(decimalPlaces);
BigDecimal newValue = oldValue.divide(divisor, decimalPlaces, RoundingMode.HALF_UP);
return newValue;
} //getAddDecimalPlaces
} //addDecimalPlaces
/**
* @return NumberBox
*/
@Override
public NumberBox getComponent() {
return (NumberBox) component;
@ -310,6 +330,7 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
* Handle context menu events
* @param evt
*/
@Override
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.PREFERENCE_EVENT.equals(evt.getContextEvent()))
@ -330,8 +351,9 @@ public class WNumberEditor extends WEditor implements ContextMenuListener
getComponent().setTableEditorMode(b);
}
/* (non-Javadoc)
* @see org.adempiere.webui.editor.WEditor#setFieldStyle(java.lang.String)
/**
* Set field style to Decimalbox inside {@link NumberBox}.
* @param style
*/
@Override
protected void setFieldStyle(String style) {

View File

@ -31,14 +31,17 @@ import org.adempiere.webui.window.WPAttributeDialog;
import org.compiere.model.GridField;
import org.compiere.model.GridTab;
import org.compiere.model.Lookup;
import org.compiere.model.MPAttributeLookup;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
/**
*
* Default editor for {@link DisplayType#PAttribute}.<br/>
* Implemented with {@link PAttributebox} component and {@link WPAttributeDialog} dialog.
* @author Low Heng Sin
*
*/
@ -50,10 +53,12 @@ public class WPAttributeEditor extends WEditor implements ContextMenuListener
protected int m_WindowNo;
/** {@link MPAttributeLookup} */
protected Lookup m_mPAttribute;
protected int m_C_BPartner_ID;
/** M_AttributeSetInstance_ID */
protected Object m_value;
/** No Instance Key */
@ -83,12 +88,14 @@ public class WPAttributeEditor extends WEditor implements ContextMenuListener
initComponents();
}
/**
* Init component and context menu
*/
private void initComponents() {
if (ThemeManager.isUseFontIconForImage())
getComponent().getButton().setIconSclass("z-icon-PAttribute");
else
getComponent().setButtonImage(ThemeManager.getThemeResource("images/PAttribute16.png"));
// getComponent().addEventListener(Events.ON_CLICK, this); // IDEMPIERE-426 - dup listener, already set at WEditor
m_WindowNo = gridField.getWindowNo();
m_mPAttribute = gridField.getLookup();
@ -141,6 +148,7 @@ public class WPAttributeEditor extends WEditor implements ContextMenuListener
return getComponent().getText();
}
@Override
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equals(event.getName()) || Events.ON_OK.equals(event.getName()))
@ -169,11 +177,10 @@ public class WPAttributeEditor extends WEditor implements ContextMenuListener
}
/**
* Start dialog
* Open {@link WPAttributeDialog}
*/
private void cmd_dialog()
{
//
Integer oldValue = (Integer)getValue ();
final int oldValueInt = oldValue == null ? 0 : oldValue.intValue ();
int M_AttributeSetInstance_ID = oldValueInt;
@ -247,6 +254,11 @@ public class WPAttributeEditor extends WEditor implements ContextMenuListener
}
} // cmd_dialog
/**
* Process new M_AttributeSetInstance_ID from {@link WPAttributeDialog}.
* @param oldValueInt
* @param M_AttributeSetInstance_ID
*/
private void processChanges(int oldValueInt, int M_AttributeSetInstance_ID) {
if (log.isLoggable(Level.FINEST)) log.finest("Changed M_AttributeSetInstance_ID=" + M_AttributeSetInstance_ID);
m_value = new Object(); // force re-query display
@ -264,11 +276,13 @@ public class WPAttributeEditor extends WEditor implements ContextMenuListener
}
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;
}
@Override
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.ZOOM_EVENT.equals(evt.getContextEvent()))
@ -281,6 +295,9 @@ public class WPAttributeEditor extends WEditor implements ContextMenuListener
}
}
/**
* Zoom to record of {@link #getValue()}.
*/
public void actionZoom()
{
AEnv.actionZoom(m_mPAttribute, getValue());

View File

@ -17,17 +17,21 @@
package org.adempiere.webui.editor;
import org.adempiere.webui.component.Textbox;
import org.compiere.model.GridField;
/**
*
* Default editor for encrypted (AD_Field.IsEncrypted=Y) text display type (String, PrinterName, Text, TextLong and Memo).<br/>
* Extend {@link WStringEditor} and set {@link Textbox} to type="password".
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 12, 2007
* @version $Revision: 0.10 $
*/
public class WPasswordEditor extends WStringEditor
{
/**
* Default constructor
*/
public WPasswordEditor()
{
super();

View File

@ -45,7 +45,8 @@ import org.zkoss.zk.ui.event.Events;
import org.zkoss.zul.Comboitem;
/**
*
* Default editor for {@link DisplayType#Payment}.<br/>
* Implemented with {@link Paymentbox} component, {@link WPaymentFormWindow} and {@link IPaymentForm} service.
* @author Elaine
*
*/
@ -56,6 +57,8 @@ public class WPaymentEditor extends WEditor implements ListDataListener, Context
public final static String[] LISTENER_EVENTS = {Events.ON_SELECT};
private MPaymentLookup lookup;
/** Payment rule (Cash, credit card, etc) */
private Object oldValue;
/**
@ -78,6 +81,9 @@ public class WPaymentEditor extends WEditor implements ListDataListener, Context
init();
}
/**
* Init component and context menu
*/
private void init()
{
getComponent().getCombobox().setAutocomplete(true);
@ -213,6 +219,9 @@ public class WPaymentEditor extends WEditor implements ListDataListener, Context
getComponent().setEnabled(readWrite, readWrite && !m_onlyRule);
}
/**
* Refresh lookup list
*/
private void refreshList()
{
if (getComponent().getCombobox().getItemCount() > 0)
@ -368,17 +377,23 @@ public class WPaymentEditor extends WEditor implements ListDataListener, Context
@Override
public void intervalRemoved(javax.swing.event.ListDataEvent e) {}
/**
* @param newValue
* @return true if newValue is different from {@link #oldValue}
*/
private boolean isValueChange(Object newValue) {
return (oldValue == null && newValue != null) || (oldValue != null && newValue == null)
|| ((oldValue != null && newValue != null) && !oldValue.equals(newValue));
}
@Override
public String[] getEvents() {
return LISTENER_EVENTS;
}
/* (non-Javadoc)
* @see org.adempiere.webui.editor.WEditor#setFieldStyle(java.lang.String)
/**
* Set style to combobox inside {@link Paymentbox}
* @param style
*/
@Override
protected void setFieldStyle(String style) {
@ -404,6 +419,9 @@ public class WPaymentEditor extends WEditor implements ListDataListener, Context
}
}
/**
* Refresh lookup list
*/
public void actionRefresh()
{
if (lookup != null)

View File

@ -20,7 +20,6 @@
package org.adempiere.webui.editor;
import java.beans.PropertyChangeEvent;
import java.math.BigDecimal;
import java.sql.Timestamp;
import java.util.List;
@ -59,7 +58,8 @@ import org.zkoss.zul.Radio;
import org.zkoss.zul.Radiogroup;
/**
*
* Default editor for {@link DisplayType#RadiogroupList}.<br/>
* Implemented with {@link RadioGroupEditor} component.
* @author hengsin
*
*/
@ -76,8 +76,10 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
}
private Lookup lookup;
/** selected value */
private Object oldValue;
/** true when editor is handling ON_CHECK event */
private boolean onselecting = false;
/**
@ -105,10 +107,10 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
/**
* Constructor for use if a grid field is unavailable
*
* @param lookup Store of selectable data
* @param label column name (not displayed)
* @param lookup Lookup list
* @param label field label
* @param description description of component
* @param mandatory whether a selection must be made
* @param mandatory whether a field is mandatory
* @param readonly whether or not the editor is read only
* @param updateable whether the editor contents can be changed
*/
@ -145,6 +147,9 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
init();
}
/**
* Init lookup and context menu
*/
private void init()
{
boolean zoom= false;
@ -200,6 +205,7 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
return retVal;
}
@Override
public void setValue(Object value)
{
if (onselecting) {
@ -293,6 +299,9 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
getComponent().setEnabled(readWrite);
}
/**
* Refresh lookup list
*/
private void refreshList()
{
if (getComponent().getItemCount() > 0)
@ -372,6 +381,7 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
getComponent().setValue(oldValue);
}
@Override
public void onEvent(Event event)
{
if (Events.ON_CHECK.equalsIgnoreCase(event.getName()))
@ -398,16 +408,24 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
}
}
/**
* @param newValue
* @return true if newValue is different from {@link #oldValue}
*/
private boolean isValueChange(Object newValue) {
return (oldValue == null && newValue != null) || (oldValue != null && newValue == null)
|| ((oldValue != null && newValue != null) && !oldValue.equals(newValue));
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;
}
/**
* Refresh lookup list
*/
public void actionRefresh()
{
if (lookup != null)
@ -430,11 +448,15 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
}
}
/**
* @return Lookup
*/
public Lookup getLookup()
{
return lookup;
}
@Override
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.REQUERY_EVENT.equals(evt.getContextEvent()))
@ -457,14 +479,6 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
}
}
public void propertyChange(PropertyChangeEvent evt)
{
if ("FieldValue".equals(evt.getPropertyName()))
{
setValue(evt.getNewValue());
}
}
@Override
public void dynamicDisplay(Properties ctx)
{
@ -487,6 +501,9 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
getPopupMenu().addContextElement(getComponent().radioGroup);
}
/**
* Container for {@link Radiogroup} and {@link Radio} component.
*/
private static class RadioGroupEditor extends Hlayout {
/**
* generated serial id
@ -495,6 +512,9 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
private Radiogroup radioGroup;
private boolean enabled;
/**
* Default constructor
*/
private RadioGroupEditor() {
newRadioGroup();
appendChild(radioGroup);
@ -503,6 +523,9 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
setStyle("white-space: normal");
}
/**
* Create new {@link Radiogroup} instance.
*/
private void newRadioGroup() {
radioGroup = new Radiogroup();
}
@ -519,6 +542,10 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
}
}
/**
* @param value
* @return true if value equals to value of selected {@link Radio} item.
*/
public boolean isSelected(Object value) {
Radio radio = getSelectedItem();
if (radio != null && radio.getValue() != null && value != null) {
@ -527,16 +554,26 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
return false;
}
/**
* @return selected {@link Radio} item
*/
public Radio getSelectedItem() {
return radioGroup.getSelectedItem();
}
/**
* Set {@link #radioGroup} selected item to item
* @param item
*/
public void setSelectedItem(Radio item) {
if (item != null && item.isSelected())
item.setSelected(false);
radioGroup.setSelectedItem(item);
}
/**
* Remove all {@link Radio} items from {@link #radioGroup}
*/
public void removeAllItems() {
List<Radio> items = radioGroup.getItems();
for (Radio radio : items) {
@ -544,6 +581,10 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
}
}
/**
* Set selected item by newValue
* @param newValue
*/
public void setValue(Object newValue) {
boolean found = false;
if (newValue != null) {
@ -560,10 +601,18 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
setSelectedItem(null);
}
/**
* @return radio item count
*/
public int getItemCount() {
return radioGroup.getItemCount();
}
/**
* Add new {@link Radio} item
* @param name
* @param value
*/
public void appendItem(String name, String value) {
if (Util.isEmpty(name))
return;
@ -571,6 +620,12 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
radioGroup.appendChild(radio);
}
/**
* Create new {@link Radio} item.
* @param name
* @param value
* @return {@link Radio}
*/
protected Radio newRadio(String name, Object value) {
Radio radio = new Radio(name);
radio.setValue(value);
@ -579,6 +634,11 @@ public class WRadioGroupEditor extends WEditor implements ContextMenuListener, L
return radio;
}
/**
* Add new {@link Radio} item
* @param name
* @param key
*/
public void appendItem(String name, int key) {
if (Util.isEmpty(name))
return;

View File

@ -61,7 +61,9 @@ import org.zkoss.zk.ui.sys.ComponentCtrl;
import org.zkoss.zul.Div;
/**
*
* Default editor for {@link DisplayType#RecordID} and {@link DisplayType#RecordUU}.<br/>
* Implemented with composite component of {@link Textbox} and {@link ToolBarButton}.<br/>
* The editor uses {@link WRecordIDDialog} for edit or viewing.
* @author Peter Takacs, Cloudempiere
*
*/
@ -69,12 +71,12 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
/** Is Read/Write enabled on the editor */
private boolean m_ReadWrite;
/** Old value (Record_ID) */
/** Record_ID or Record_UU value */
private Object recordIDValue;
/** Old value (AD_Table_ID) */
/** AD_Table_ID value */
private Object tableIDValue;
/** Current tab's AD_Table_ID GrodField */
/** Current tab's AD_Table_ID GridField */
private GridField tableIDGridField;
// UI components
@ -82,7 +84,7 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
private ToolBarButton editButton;
private ToolBarButton zoomButton;
// images
// image url for toolbar button
private static final String IMAGES_CONTEXT_ZOOM_PNG = "images/Zoom16.png";
private static final String IMAGES_CONTEXT_EDIT_RECORD_PNG = "images/EditRecord16.png";
@ -101,6 +103,9 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
init();
}
/**
* Init component and context menu
*/
private void init() {
if(gridTab != null) {
tableIDGridField = gridTab.getField("AD_Table_ID");
@ -155,6 +160,10 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
}
}
/**
* Handle AFTER_PAGE_ATTACHED callback to get AD_Table_ID grid field from find window
* @param t
*/
private void afterPageAttached(Object t) {
if (t instanceof Component) {
Component component = (Component) t;
@ -173,25 +182,28 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
field = field.clone(gridField.getVO().ctx);
field.loadLookupNoValidate();
Lookup lookup = field.getLookup();
if (lookup != null && lookup instanceof MLookup)
{
MLookup mLookup = (MLookup) lookup;
mLookup.getLookupInfo().tabNo = FindWindow.TABNO;
if (field.getVO().ValidationCodeLookup != null && !field.getVO().ValidationCodeLookup.isEmpty())
if (lookup != null && lookup instanceof MLookup)
{
mLookup.getLookupInfo().ValidationCode = field.getVO().ValidationCodeLookup;
MLookup mLookup = (MLookup) lookup;
mLookup.getLookupInfo().tabNo = FindWindow.TABNO;
if (field.getVO().ValidationCodeLookup != null && !field.getVO().ValidationCodeLookup.isEmpty())
{
mLookup.getLookupInfo().ValidationCode = field.getVO().ValidationCodeLookup;
mLookup.getLookupInfo().IsValidated = false;
}
}
}
tableIDGridField = field;
if (tableIDValue != null)
tableIDGridField.setValue(tableIDValue, false);
tableIDGridField = field;
if (tableIDValue != null)
tableIDGridField.setValue(tableIDValue, false);
}
}
}
}
/**
* Refresh text box display text
*/
private void actionRefresh()
{
recordTextBox.setValue(getDisplay());
@ -221,7 +233,6 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
}
}
@Override
public void onMenu(ContextMenuEvent evt)
{
@ -257,6 +268,7 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
return m_ReadWrite;
}
@Override
public void propertyChange(PropertyChangeEvent evt)
{
if (GridField.PROPERTY.equals(evt.getPropertyName()))
@ -286,10 +298,9 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
/**
* Set Value
* @param value value
* @param fire data binding
* @param value new value
* @param fire true to fire value change event
*/
private void setValue (Object value, boolean fire) {
if (value == null || Util.isEmpty(value.toString(), true)) {
recordTextBox.setValue("");
@ -453,7 +464,7 @@ public class WRecordIDEditor extends WEditor implements ContextMenuListener, IZo
/**
* Get AD_Table_ID
* @return Object
* @return AD_Table_ID value
*/
public Object getAD_Table_ID() {
return tableIDValue;

View File

@ -20,7 +20,6 @@ package org.adempiere.webui.editor;
import static org.compiere.model.SystemIDs.COLUMN_C_INVOICELINE_M_PRODUCT_ID;
import static org.compiere.model.SystemIDs.COLUMN_C_INVOICE_C_BPARTNER_ID;
import java.beans.PropertyChangeEvent;
import java.util.Properties;
import java.util.logging.Level;
@ -40,6 +39,7 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener;
import org.adempiere.webui.factory.InfoManager;
import org.adempiere.webui.grid.WQuickEntry;
import org.adempiere.webui.info.InfoWindow;
import org.adempiere.webui.panel.IHelpContext;
import org.adempiere.webui.panel.InfoPanel;
import org.adempiere.webui.part.WindowContainer;
@ -72,8 +72,8 @@ import org.zkoss.zk.ui.event.InputEvent;
import org.zkoss.zk.ui.util.Clients;
/**
* Search Editor for web UI.
* Web UI port of search type VLookup
* Default editor for {@link DisplayType#Search} and {@link DisplayType#SearchUU}.<br/>
* Implemented with {@link CustomSearchBox} component and {@link InfoPanel}, {@link InfoWindow} dialog.
*
* @author Ashley G Ramdass
*
@ -82,20 +82,28 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
{
private static final int DEFAULT_MAX_AUTO_COMPLETE_ROWS = 500;
private static final String[] LISTENER_EVENTS = {Events.ON_CLICK, Events.ON_CHANGE, Events.ON_OK};
/** Boolean component attribute to store whether info panel is open */
public static final String ATTRIBUTE_IS_INFO_PANEL_OPEN = "ATTRIBUTE_IS_INFO_PANEL_OPEN";
protected Lookup lookup;
/** Reference/target table name */
private String m_tableName = null;
/** Reference/target key column name */
private String m_keyColumnName = null;
/** Source/field column name */
private String columnName;
/** ID or UUID value */
private Object value;
protected InfoPanel infoPanel = null;
/** Image URL or font icon sclass for CustomSearchbox button */
private String imageUrl;
/** Model for auto complete search */
private InfoListSubModel listModel = null;
private static final CLogger log = CLogger.getCLogger(WSearchEditor.class);
private static final String IN_PROGRESS_IMAGE = "~./zk/img/progress3.gif";
/** ADWindow instance that own this editor */
protected ADWindow adwindow;
/**
@ -148,9 +156,9 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
* Constructor for use if a grid field is unavailable
*
* @param lookup Store of selectable data
* @param label column name (not displayed)
* @param label field label
* @param description description of component
* @param mandatory whether a selection must be made
* @param mandatory whether field is mandatory
* @param readonly whether or not the editor is read only
* @param updateable whether the editor contents can be changed
*/
@ -169,6 +177,14 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
init();
}
/**
*
* @param columnName
* @param mandatory
* @param readonly
* @param updateable
* @param lookup
*/
public WSearchEditor(String columnName, boolean mandatory, boolean readonly, boolean updateable,
Lookup lookup)
{
@ -187,8 +203,7 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
/**
* initialise editor
* @param columnName columnName
* Initialise component and context menu
*/
private void init()
{
@ -327,6 +342,7 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
return getComponent().getText();
}
@Override
public void onEvent(Event e)
{
if (Events.ON_CHANGE.equals(e.getName()))
@ -354,7 +370,7 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
&& !isQuickFormComp
&& isReadWrite())
{
// open Info window similar to swing client
// open Info window
if (infoPanel != null)
{
infoPanel.detach();
@ -376,32 +392,33 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
}
}
@Override
public void propertyChange(PropertyChangeEvent evt)
{
if ("FieldValue".equals(evt.getPropertyName()))
{
actionRefresh(evt.getNewValue());
}
}
/**
* Refresh editor value
* @param value
*/
protected void actionRefresh(Object value)
{
// boolean mandatory = isMandatory();
// AEnv.actionRefresh(lookup, value, mandatory);
setValue(value);
}
/**
* Zoom to window for reference/target table
*/
public void actionZoom()
{
AEnv.actionZoom(lookup, getValue());
}
/**
* Zoom to window for reference/target table
* @param value
*/
private void actionZoom(Object value)
{
AEnv.actionZoom(lookup, value);
}
@Override
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.REQUERY_EVENT.equals(evt.getContextEvent()))
@ -427,7 +444,6 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
}
actionQuickEntry(true);
}
// Elaine 2009/02/16 - update record
else if (WEditorPopupMenu.UPDATE_EVENT.equals(evt.getContextEvent()))
{
if (infoPanel != null)
@ -445,9 +461,12 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
{
actionDrill();
}
//
}
/**
* Process text input from user
* @param text
*/
protected void actionText(String text)
{
// Nothing entered
@ -464,6 +483,7 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
if (m_tableName == null) // sets table name & key column
setTableAndKeyColumn();
// process input text with infopanel/infowindow
final InfoPanel ip = InfoManager.create(lookup, gridField, m_tableName, m_keyColumnName, getComponent().getText(), false, getWhereClause());
if (ip != null && ip.loadedOK() && ip.getRowCount() == 1)
{
@ -516,6 +536,9 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
resetButtonState();
} // actionText
/**
* Open drill assistant dialog
*/
protected void actionDrill() {
if(getGridField() == null || getGridField().getGridTab() == null)
return;
@ -530,6 +553,9 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
AEnv.actionDrill(data, windowNo);
}
/**
* Reset state of {@link CustomSearchBox} button to default
*/
protected void resetButtonState() {
getComponent().getButton().setEnabled(true);
if (ThemeManager.isUseFontIconForImage())
@ -539,7 +565,11 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
getComponent().invalidate();
}
/**
* Process value from InfoPanel/InfoWindow.<br/>
* Fire ValueChangeEvent.
* @param value
*/
protected void actionCombo (Object value)
{
if (log.isLoggable(Level.FINE))
@ -640,8 +670,6 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
setValue(Integer.valueOf(result));
actionCombo (Integer.valueOf(result)); // data binding
lookup.refresh();
//setValue(getValue());
}
});
@ -657,6 +685,10 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
}
} // actionQuickEntry
/**
* Handle onClick event from {@link CustomSearchBox} button.
* @param queryValue
*/
protected void actionButton(String queryValue)
{
if (lookup == null)
@ -675,8 +707,6 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
if (log.isLoggable(Level.FINE))
log.fine(lookup.getColumnName() + ", Zoom=" + lookup.getZoom() + " (" + whereClause + ")");
// boolean resetValue = false; // Reset value so that is always treated as new entry
// Replace Value with name if no value exists
if (queryValue.length() == 0 && getComponent().getText().length() > 0)
queryValue = getComponent().getText();
@ -689,7 +719,10 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
showInfoPanel(ip);
}
/**
* Open InfoPanel/InfoWindow dialog
* @param ip InfoPanel
*/
public void showInfoPanel(final InfoPanel ip) {
ip.setVisible(true);
ip.setStyle("border: 2px");
@ -749,7 +782,7 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
}
/**
* Sets m_tableName and m_keyColumnName
* Set {@link #m_tableName} and {@link #m_keyColumnName}.
*/
private void setTableAndKeyColumn() {
if (lookup != null && lookup instanceof MLookup) {
@ -780,6 +813,10 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
}
}
/**
* Parse where clause from lookup validation code.
* @return where clause
*/
private String getWhereClause()
{
String whereClause = "";
@ -800,9 +837,6 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
else if (validation.length() > 0)
whereClause += " AND " + validation;
// log.finest("ZoomQuery=" + (lookup.getZoomQuery()==null ? "" : lookup.getZoomQuery().getWhereClause())
// + ", Validation=" + lookup.getValidation());
if (whereClause.indexOf('@') != -1)
{
String validated = Env.parseContext(Env.getCtx(), lookup.getWindowNo(), whereClause, false);
@ -819,12 +853,13 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
return whereClause;
} // getWhereClause
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;
}
@Override
public void valueChange(ValueChangeEvent evt)
{
if ("zoom".equals(evt.getPropertyName()))
@ -847,12 +882,15 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
getComponent().setTableEditorMode(b);
}
/**
* @return true if InfoPanel/InfoWindow dialog is active
*/
public boolean isShowingDialog (){
return infoPanel != null;
}
/**
* Create new WSearhEditor instance for C_Invoice.C_BPartner_ID column.
* @param windowNo
* @return WSearchEditor
*/
@ -872,6 +910,7 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
}
/**
* Create new WSearchEditor instance for C_InvoiceLine.M_Product_ID column.
* @param windowNo
* @return WSearchEditor
*/
@ -890,7 +929,6 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
return null;
}
@Override
public void dynamicDisplay(Properties ctx) {
if (lookup instanceof MLookup) {
@ -911,6 +949,9 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
return s;
}
/**
* Search box component
*/
static class CustomSearchBox extends ComboEditorBox {
/**
@ -918,6 +959,9 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
*/
private static final long serialVersionUID = 7490301044763375829L;
/**
* Set script for spin animation when editor is processing user input text
*/
@Override
public void onPageAttached(Page newpage, Page oldpage) {
super.onPageAttached(newpage, oldpage);

View File

@ -43,7 +43,8 @@ import org.zkoss.zk.ui.event.Events;
import org.zkoss.zk.ui.sys.ComponentCtrl;
/**
*
* Default editor for text display type (String, PrinterName, Text, TextLong and Memo).<br/>
* Implemented with {@link Textbox} or {@link Combobox} (AD_Field.IsAutocomplete=Y) component and {@link WTextEditorDialog} dialog.
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 11, 2007
* @version $Revision: 0.10 $
@ -57,7 +58,7 @@ public class WStringEditor extends WEditor implements ContextMenuListener
private AbstractADWindowContent adwindowContent;
/**
* to ease porting of swing form
* Default constructor
*/
public WStringEditor()
{
@ -99,7 +100,6 @@ public class WStringEditor extends WEditor implements ContextMenuListener
}
/**
* to ease porting of swing form
* @param columnName
* @param mandatory
* @param isReadOnly
@ -135,6 +135,10 @@ public class WStringEditor extends WEditor implements ContextMenuListener
getComponent().setReadonly(!readWrite);
}
/**
* Init component and context menu
* @param obscureType
*/
private void init(String obscureType)
{
setChangeEventWhenEditing (true);
@ -194,6 +198,7 @@ public class WStringEditor extends WEditor implements ContextMenuListener
getComponent().addCallback(ComponentCtrl.AFTER_PAGE_DETACHED, t -> ((AbstractComponent)t).setWidgetListener("onBind", null));
}
@Override
public void onEvent(Event event)
{
boolean isStartEdit = INIT_EDIT_EVENT.equalsIgnoreCase (event.getName());
@ -242,6 +247,10 @@ public class WStringEditor extends WEditor implements ContextMenuListener
oldValue = getComponent().getValue();
}
/**
* Set type of textbox to password or text
* @param password true to set type to password
*/
protected void setTypePassword(boolean password)
{
if (password)
@ -260,6 +269,7 @@ public class WStringEditor extends WEditor implements ContextMenuListener
return LISTENER_EVENTS;
}
@Override
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.PREFERENCE_EVENT.equals(evt.getContextEvent()))
@ -325,6 +335,9 @@ public class WStringEditor extends WEditor implements ContextMenuListener
actionRefresh();
}
/**
* Refresh auto complete combo
*/
public void actionRefresh() {
//refresh auto complete list
if (gridField.isAutocomplete()) {
@ -337,6 +350,10 @@ public class WStringEditor extends WEditor implements ContextMenuListener
}
}
/**
* Find AbstractADWindowContent instance that own this editor
* @return AbstractADWindowContent
*/
private AbstractADWindowContent findADWindowContent() {
Component parent = getComponent().getParent();
while(parent != null) {

View File

@ -20,7 +20,6 @@
package org.adempiere.webui.editor;
import java.beans.PropertyChangeEvent;
import java.math.BigDecimal;
import java.sql.Timestamp;
import java.util.Properties;
@ -80,7 +79,8 @@ import org.zkoss.zul.Comboitem;
import org.zkoss.zul.Menuitem;
/**
*
* Default editor for display type TableDir, TableDirUU, Table, TableUU and List.
* Implemented with {@link EditorCombobox} or {@link EditorAutoComplete} (AD_Field.IsAutoComplete=Y) component.
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 12, 2007
* @version $Revision: 0.10 $
@ -88,11 +88,13 @@ import org.zkoss.zul.Menuitem;
public class WTableDirEditor extends WEditor implements ListDataListener,
ContextMenuListener, IZoomableEditor
{
/** custom script for up arrow key processed */
private static final String UP_PRESSED_OVERRIDE_SCRIPT = "function(evt) {"
+ " if (!this.isOpen()) this.open();"
+ " this.$upPressed_(evt);"
+ "}";
/** custom script for down arrow key processed */
private static final String DOWN_PRESSED_OVERRIDE_SCRIPT = "function(evt) {"
+ " if (!this.isOpen()) this.open();"
+ " this.$dnPressed_(evt);"
@ -109,15 +111,22 @@ ContextMenuListener, IZoomableEditor
}
private Lookup lookup;
/** ID, UUID or AD_RefList Value */
private Object oldValue;
/** Reference/target table name */
private String m_tableName = null;
/** Reference/target key column name */
private String m_keyColumnName = null;
/** Context menu item attribute to store context menu event name/id */
public static final String SHORT_LIST_EVENT = "SHORT_LIST"; // IDEMPIERE 90
/** true if lookup only contain short list items (i.e with IsShortList=Y) */
protected boolean onlyShortListItems; // IDEMPIERE 90
/** CCache listener to auto refresh lookup list */
private CCacheListener tableCacheListener;
/** true if editor is handling ON_SELECT event */
private boolean onselecting = false;
private boolean retainSelectedValueAfterRefresh = true;
@ -149,9 +158,9 @@ ContextMenuListener, IZoomableEditor
* Constructor for use if a grid field is unavailable
*
* @param lookup Store of selectable data
* @param label column name (not displayed)
* @param label field label
* @param description description of component
* @param mandatory whether a selection must be made
* @param mandatory whether field is mandatory
* @param readonly whether or not the editor is read only
* @param updateable whether the editor contents can be changed
*/
@ -160,11 +169,29 @@ ContextMenuListener, IZoomableEditor
this(lookup, label, description, mandatory, readonly, updateable, false);
}
/**
* @param lookup
* @param label
* @param description
* @param mandatory
* @param readonly
* @param updateable
* @param autocomplete
*/
public WTableDirEditor(Lookup lookup, String label, String description, boolean mandatory, boolean readonly, boolean updateable, boolean autocomplete)
{
this(autocomplete ? new EditorAutoComplete() : new EditorCombobox(), lookup, label, description, mandatory, readonly, updateable);
}
/**
* @param comp
* @param lookup
* @param label
* @param description
* @param mandatory
* @param readonly
* @param updateable
*/
private WTableDirEditor(Component comp, Lookup lookup, String label, String description, boolean mandatory, boolean readonly, boolean updateable)
{
super(comp, label, description, mandatory, readonly, updateable);
@ -181,7 +208,6 @@ ContextMenuListener, IZoomableEditor
}
/**
* For ease of porting swing form
* @param columnName
* @param mandatory
* @param isReadOnly
@ -193,11 +219,27 @@ ContextMenuListener, IZoomableEditor
this(columnName, mandatory, isReadOnly, isUpdateable, lookup, false);
}
/**
* @param columnName
* @param mandatory
* @param isReadOnly
* @param isUpdateable
* @param lookup
* @param autocomplete
*/
public WTableDirEditor(String columnName, boolean mandatory, boolean isReadOnly, boolean isUpdateable, Lookup lookup, boolean autocomplete)
{
this(autocomplete ? new EditorAutoComplete() : new EditorCombobox(), columnName, mandatory, isReadOnly, isUpdateable, lookup);
}
/**
* @param comp Component
* @param columnName
* @param mandatory
* @param isReadOnly
* @param isUpdateable
* @param lookup
*/
private WTableDirEditor(Component comp, String columnName, boolean mandatory, boolean isReadOnly, boolean isUpdateable, Lookup lookup)
{
super(comp, columnName, null, null, mandatory, isReadOnly, isUpdateable);
@ -210,6 +252,9 @@ ContextMenuListener, IZoomableEditor
init();
}
/**
* Init component and context menu
*/
private void init()
{
ZKUpdateUtil.setWidth(getComponent(), "200px");
@ -249,7 +294,7 @@ ContextMenuListener, IZoomableEditor
refreshList();
}
String tableName_temp = lookup.getColumnName(); // Returns AD_Org.AD_Org_ID
String tableName_temp = lookup.getColumnName(); // Returns [table name].[key column name]
int posPoint = tableName_temp.indexOf(".");
String tableName = tableName_temp.substring(0, posPoint);
@ -299,6 +344,9 @@ ContextMenuListener, IZoomableEditor
getComponent().setPlaceholder(gridField.getPlaceholder());
}
/**
* Create {@link #tableCacheListener} instance
*/
private void createCacheListener() {
if (lookup != null) {
String columnName = lookup.getColumnName();
@ -339,6 +387,7 @@ ContextMenuListener, IZoomableEditor
return retVal;
}
@Override
public void setValue(Object value)
{
if (onselecting) {
@ -437,6 +486,9 @@ ContextMenuListener, IZoomableEditor
getComponent().setButtonVisible(readWrite);
}
/**
* Refresh lookup list
*/
private void refreshList()
{
if (getComponent().getItemCount() > 0)
@ -544,6 +596,7 @@ ContextMenuListener, IZoomableEditor
getComponent().setValue(oldValue);
}
@Override
public void onEvent(Event event)
{
if (Events.ON_SELECT.equalsIgnoreCase(event.getName()))
@ -607,27 +660,38 @@ ContextMenuListener, IZoomableEditor
}
}
/**
* @param newValue
* @return true if newValue is different from {@link #oldValue}
*/
private boolean isValueChange(Object newValue) {
return (oldValue == null && newValue != null) || (oldValue != null && newValue == null)
|| ((oldValue != null && newValue != null) && !oldValue.equals(newValue));
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;
}
@Override
public void contentsChanged(ListDataEvent e)
{
refreshList();
}
@Override
public void intervalAdded(ListDataEvent e)
{}
@Override
public void intervalRemoved(ListDataEvent e)
{}
/**
* Refresh lookup list
*/
public void actionRefresh()
{
if (lookup != null)
@ -653,16 +717,23 @@ ContextMenuListener, IZoomableEditor
/* (non-Javadoc)
* @see org.adempiere.webui.editor.IZoomableEditor#actionZoom()
*/
@Override
public void actionZoom()
{
AEnv.actionZoom(lookup, getValue());
}
/**
* @return Lookup
*/
public Lookup getLookup()
{
return lookup;
}
/**
* Open drill assistant dialog
*/
protected void actionDrill() {
if(getGridField() == null || getGridField().getGridTab() == null)
return;
@ -681,7 +752,7 @@ ContextMenuListener, IZoomableEditor
}
/**
* Sets m_tableName and m_keyColumnName
* Set {@link #m_tableName} and {@link #m_keyColumnName}.
*/
private void setTableAndKeyColumn() {
if (lookup != null && lookup instanceof MLookup) {
@ -756,6 +827,9 @@ ContextMenuListener, IZoomableEditor
AEnv.showWindow(vqe);
} // actionQuickEntry
/**
* Open {@link WLocationDialog}
*/
protected void actionLocation() {
int BPLocation_ID = 0;
Object value = getValue();
@ -776,6 +850,7 @@ ContextMenuListener, IZoomableEditor
} // actionLocation
@Override
public void onMenu(ContextMenuEvent evt)
{
if (WEditorPopupMenu.REQUERY_EVENT.equals(evt.getContextEvent()))
@ -833,14 +908,6 @@ ContextMenuListener, IZoomableEditor
// IDEMPIERE 90
}
public void propertyChange(PropertyChangeEvent evt)
{
if ("FieldValue".equals(evt.getPropertyName()))
{
setValue(evt.getNewValue());
}
}
@Override
public void dynamicDisplay(Properties ctx)
{
@ -872,6 +939,9 @@ ContextMenuListener, IZoomableEditor
return s;
}
/**
* Custom {@link Combobox} class
*/
private static class EditorCombobox extends Combobox implements ITableDirEditor {
/**
* generated serial id
@ -888,6 +958,9 @@ ContextMenuListener, IZoomableEditor
super.setPage(page);
}
/**
* Create CCache listener
*/
@Override
public void onPageAttached(Page newpage, Page oldpage) {
super.onPageAttached(newpage, oldpage);
@ -914,7 +987,7 @@ ContextMenuListener, IZoomableEditor
}
/**
*
* Clean up CCache listener
*/
public void cleanup() {
if (editor.tableCacheListener != null) {
@ -929,6 +1002,9 @@ ContextMenuListener, IZoomableEditor
}
}
/**
* Custom {@link AutoComplete} class
*/
private static class EditorAutoComplete extends AutoComplete implements ITableDirEditor {
/**
* generated serial id
@ -945,6 +1021,9 @@ ContextMenuListener, IZoomableEditor
super.setPage(page);
}
/**
* Create CCache listener instance
*/
@Override
public void onPageAttached(Page newpage, Page oldpage) {
super.onPageAttached(newpage, oldpage);
@ -971,7 +1050,7 @@ ContextMenuListener, IZoomableEditor
}
/**
*
* Clean up CCache listener
*/
public void cleanup() {
if (editor.tableCacheListener != null) {
@ -997,6 +1076,9 @@ ContextMenuListener, IZoomableEditor
}
/**
* CCache listener to auto refresh lookup list
*/
private static class CCacheListener extends CCache<String, Object> {
/**
* generated serial
@ -1052,7 +1134,6 @@ ContextMenuListener, IZoomableEditor
}
/**
*
* @return true if current selected value is always retain after refresh of list
*/
public boolean isRetainSelectedValueAfterRefresh() {

View File

@ -26,11 +26,13 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.window.WFieldRecordInfo;
import org.compiere.model.GridField;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
/**
*
* Default editor for {@link DisplayType#Time}.<br/>
* Implemented with {@link Timebox} component.
* @author Low Heng Sin
*/
public class WTimeEditor extends WEditor implements ContextMenuListener
@ -85,11 +87,11 @@ public class WTimeEditor extends WEditor implements ContextMenuListener
* Constructor for use if a grid field is unavailable
*
* @param label
* column name (not displayed)
* field label
* @param description
* description of component
* @param mandatory
* whether a selection must be made
* whether field is mandatory
* @param readonly
* whether or not the editor is read only
* @param updateable
@ -102,12 +104,18 @@ public class WTimeEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Default constructor
*/
public WTimeEditor()
{
this("Time", "Time", false, false, true);
init();
} // VDate
}
/**
* Init component and context menu
*/
private void init()
{
getComponent().setCols(10);
@ -118,6 +126,7 @@ public class WTimeEditor extends WEditor implements ContextMenuListener
getComponent().setPlaceholder(gridField.getPlaceholder());
}
@Override
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equalsIgnoreCase(event.getName()) || Events.ON_OK.equalsIgnoreCase(event.getName()))
@ -153,18 +162,14 @@ public class WTimeEditor extends WEditor implements ContextMenuListener
@Override
public String getDisplay()
{
// Elaine 2008/07/29
return getComponent().getText();
//
}
@Override
public Object getValue()
{
// Elaine 2008/07/25
if(getComponent().getValue() == null) return null;
return new Timestamp(getComponent().getValue().getTime());
//
}
@Override
@ -196,7 +201,6 @@ public class WTimeEditor extends WEditor implements ContextMenuListener
return !getComponent().isReadonly();
}
@Override
public void setReadWrite(boolean readWrite) {
getComponent().setReadonly(!readWrite);

View File

@ -42,6 +42,7 @@ import org.adempiere.webui.event.ContextMenuListener;
import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.session.SessionManager;
import org.compiere.model.GridField;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.compiere.util.NamePair;
@ -55,17 +56,24 @@ import org.zkoss.zul.Menu;
import org.zkoss.zul.Menuitem;
/**
* Default editor for {@link DisplayType#TimeZoneId}.<br/>
* Implemented with {@link Combobox} component.
* @author hengsin
*
*/
public class WTimeZoneEditor extends WEditor implements ContextMenuListener {
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE};
/** Time zone context menu name/id */
private static final String TIME_ZONE = "TIME_ZONE";
/** Context popup menu attribute to indicate time zone context menu items have been added */
private static final String TIME_ZONE_ADDED = "TIME_ZONE_ADDED";
/** Context menu attribute to indicate this is a context menu item */
private static final String TIME_ZONE_ITEM_ATTR = "TIME_ZONE_ITEM";
/** Context menu attribute to store time zone id */
private static final String TIME_ZONE_ID_ATTR = "TIME_ZONE_ID";
/** Time zone id */
private String oldValue;
/**
@ -114,6 +122,9 @@ public class WTimeZoneEditor extends WEditor implements ContextMenuListener {
init();
}
/**
* Init component and context menu
*/
private void init() {
popupMenu = new WEditorPopupMenu(false, false, isShowPreference());
popupMenu.addMenuListener(this);
@ -150,6 +161,9 @@ public class WTimeZoneEditor extends WEditor implements ContextMenuListener {
getComponent().addEventListener(Events.ON_BLUR, e -> onBlur());
}
/**
* Handle onBlur event of component
*/
private void onBlur() {
Comboitem item = getComponent().getSelectedItem();
if (item == null)
@ -178,6 +192,10 @@ public class WTimeZoneEditor extends WEditor implements ContextMenuListener {
}
}
/**
* @param newValue
* @return true if newValue is different from {@link #oldValue}
*/
private boolean isValueChange(String newValue) {
return (oldValue == null && newValue != null) || (oldValue != null && newValue == null)
|| ((oldValue != null && newValue != null) && !oldValue.equals(newValue));
@ -214,6 +232,11 @@ public class WTimeZoneEditor extends WEditor implements ContextMenuListener {
}
}
/**
* Process customId enter by user
* @param customId
* @return true if customId is valid and added to Combobox
*/
private boolean processCustomZoneId(String customId) {
TimeZone timeZone = TimeZone.getTimeZone(customId);
if (timeZone != null && timeZone.getID().equals(customId)) {
@ -327,6 +350,10 @@ public class WTimeZoneEditor extends WEditor implements ContextMenuListener {
}
/**
* Process time zone id from time zone context menu
* @param id
*/
private void setTimeZoneFromContextMenu(String id) {
String newValue = id;
String currentValue = oldValue;
@ -349,14 +376,17 @@ public class WTimeZoneEditor extends WEditor implements ContextMenuListener {
}
/**
* Add time zone menu item to context menu popup
* @param popupMenu
*/
private void addTimeZoneMenu(WEditorPopupMenu popupMenu) {
if (popupMenu != null && isReadWrite() && popupMenu.getAttribute(TIME_ZONE_ADDED) == null) {
//time zone id from browser
ClientInfo clientInfo = SessionManager.getAppDesktop().getClientInfo();
if (clientInfo != null && clientInfo.timeZone != null) {
TimeZone firstSameRule = null;
TimeZone found = null;
//match by id, fallback to first with same rawOffset+DSTSavings+useDayLightTime
for(int i = 0; i < getComponent().getItemCount(); i++) {
String id = getComponent().getItemAtIndex(i).getValue();
TimeZone tz = TimeZone.getTimeZone(id);
@ -385,6 +415,7 @@ public class WTimeZoneEditor extends WEditor implements ContextMenuListener {
if (popupMenu.getAttribute(TIME_ZONE_ADDED) == null) {
List<String> labels = new ArrayList<String>();
List<String> ids = new ArrayList<String>();
//match by rawOffset
for(int i = 0; i < getComponent().getItemCount(); i++) {
String id = getComponent().getItemAtIndex(i).getValue();
tz = TimeZone.getTimeZone(id);

View File

@ -20,7 +20,7 @@ package org.adempiere.webui.editor;
import org.compiere.model.GridField;
/**
*
* Simple text editor for unknown display type.
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 12, 2007
* @version $Revision: 0.10 $

View File

@ -25,9 +25,14 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.theme.ThemeManager;
import org.adempiere.webui.window.WFieldRecordInfo;
import org.compiere.model.GridField;
import org.compiere.util.DisplayType;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
/**
* Default editor for {@link DisplayType#URL}.<br/>
* Implemented with {@link Urlbox} component.
*/
public class WUrlEditor extends WEditor implements ContextMenuListener
{
private static final String[] LISTENER_EVENTS = {Events.ON_CHANGE, Events.ON_OK};
@ -110,7 +115,7 @@ public class WUrlEditor extends WEditor implements ContextMenuListener
getComponent().setEnabled(readWrite);
}
@Override
public void onEvent(Event event)
{
if (Events.ON_CHANGE.equals(event.getName()) || Events.ON_OK.equals(event.getName()))
@ -128,6 +133,7 @@ public class WUrlEditor extends WEditor implements ContextMenuListener
}
}
@Override
public String[] getEvents()
{
return LISTENER_EVENTS;

View File

@ -17,7 +17,6 @@
package org.adempiere.webui.editor;
import java.beans.PropertyChangeEvent;
import java.util.logging.Level;
import org.adempiere.webui.ValuePreference;
@ -28,13 +27,15 @@ import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.window.WFieldRecordInfo;
import org.compiere.model.GridField;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
/**
*
* Default editor for {@link DisplayType#YesNo}. <br/>
* Implemented with {@link Checkbox} component.
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 11, 2007
* @version $Revision: 0.10 $
@ -88,6 +89,9 @@ public class WYesNoEditor extends WEditor implements ContextMenuListener
init();
}
/**
* Init component and context menu
*/
private void init()
{
if (gridField != null)
@ -102,6 +106,7 @@ public class WYesNoEditor extends WEditor implements ContextMenuListener
addChangeLogMenu(popupMenu);
}
@Override
public void onEvent(Event event)
{
if (Events.ON_CHECK.equalsIgnoreCase(event.getName()))
@ -113,14 +118,6 @@ public class WYesNoEditor extends WEditor implements ContextMenuListener
}
}
public void propertyChange(PropertyChangeEvent evt)
{
if (evt.getPropertyName().equals(org.compiere.model.GridField.PROPERTY))
{
setValue(evt.getNewValue());
}
}
@Override
public String getDisplay()
{

View File

@ -29,7 +29,7 @@ import org.compiere.util.CCache;
import org.osgi.framework.Constants;
/**
*
* Static methods to create new {@link WEditor} instance for {@link GridField}.
* @author <a href="mailto:agramdass@gmail.com">Ashley G Ramdass</a>
* @date Mar 12, 2007
* @version $Revision: 0.10 $