Class DualListBox
- All Implemented Interfaces:
- Animatable<DualListBox>,- CanDrop<DualListBox>,- SupportHelpIcon<DualListBox>,- Draggable<DualListBox>,- Fetchable<DualListBox>,- Focusable<DualListBox>,- HandleHotKey<DualListBox>,- BasedOnDataDescriptor<DualListBox>,- DifferentDataDisplayValue,- DifferentMultiDataDisplayValue,- Filterable<DualListBox>,- MultiValueFormItem<DualListBox>
Dual list box form item
The component implements two parallel lists. The lists display the values passed to the component. By default the component’s value set is displayed on the left. The user is able to move one or several items to the list on the right. The list on the right contains items selected by the user. These items are the component’s value. The component provides a selection option which enables the user to select several items from a value set and save it to a given field.
The dual list box component is a form item which means it can be placed on the Form component.
 The standalone use of this component requires the implementation of event and value handling from code.
The component enables the user to move items from one list to the other by clicking on them. Buttons above the list make it possible to move all items from one list to the other at the same time. Lists can be filtered individually if there is an input field above the list.
Supported events:
AnimationStart
 AnimationEnd,
 Drop,
 DragStart,
 DragEnd
 HotKey
 - Since:
- 4.0
- Author:
- JBStrap
- See Also:
- 
Field SummaryFields inherited from class com.jbstrap.ui.components.form.FormItemappends, clearButton, column, defaultState, defaultValue, description, formItemSize, helpIcon, label, labelPosition, labelSizes, modified, originalValue, params, prepends, required, showLabel, state, tabIndex, value, visibleFields inherited from class com.jbstrap.ui.Componentanimation, attributes, backgroundColor, borderColor, color, defaultHotKeyHandler, handlers, hotKeys, styleClasses, textAlign, toolTip, toolTipPosition
- 
Constructor SummaryConstructorsConstructorDescriptionDualListBox(DataDescriptorColumn column) Creates a dual list box based on the specified DataDescriptor component.DualListBox(DataDescriptorColumn column, String language) Creates a dual list box based on the specified DataDescriptor according to the language code.DualListBox(String name, String label) Creates an empty dual list box with the specified name and label.DualListBox(String name, String label, String language) Creates an empty dual list box with the specified name and label according to the language code.Creates a dual list box with the specified name and label.Creates an empty dual list box with the specified name and label.
- 
Method SummaryModifier and TypeMethodDescriptionfinal DualListBoxaddElement(Object dataValue, Object displayValue) Adds an item to the dual list box.final DualListBoxaddElements(Map<Object, Object> data) Adds multiple items to the dual list box.voidThe operations to be executed after the drawing of the componentfinal DualListBoxclear()Clears the value set of the dual list box and removes all items from the value set.voiddrawEditor(StringWriter writer) Draws the editor component.This method implements actual data retrieval.final DualListBoxGets the value set data from the database.final DualListBoxGets the dual list box’s value set data from the database, fulfilling the specified filter criterion.final CriteriaGets the filter criterion used to retrieve the value set.Gets the name of the DataDescriptor column containing value set data values.Gets the DataDescriptor associated with the dual list box value set.Gets the name of the DataDescriptor column containing the value set’s displayed values.Gets the DataDescriptor names for all specified display value.Gets the separator text.You cannot get a single displayed value of the dual list box since always multiple values are selected.Gets the displayed values for the selected items.Gets additional values from the relation table.final StringGets the database name of the relation table.You cannot get a single displayed value of the dual list box since always multiple values are selected.Gets the displayed values for the originally selected items.final StringGets the record-relation table join description.getValue()Gets the current value of the dual list box.Gets the relation table column name where the component’s value is saved to.voidinit()The component initialization method.booleanChecks if the component automatically retrieves its value set from the database.booleanSets if the component is enabled.booleanSets if the component can take multiple values.booleanSpecifies if the dual list box is displayed in read-only mode.voidonShow()The operations to be executed after the component is displayed on the clientfinal DualListBoxremoveElement(Object dataValue) Removes an item from the dual list box’s value set based on the item’s data value.setAutoFetchData(boolean autoFetch) Sets if the component should automatically query the data for the value set from the database.final DualListBoxsetCollator(Collator collator) Sets the collator instance sorting the value set.setCustomFetch(FetchEvent fetchEvent) Sets a custom query.final DualListBoxsetDataColumn(String columnName) Specifies the name of the DataDescriptor which contains value set data values.final DualListBoxsetDataDescriptor(DataDescriptor dataDesriptor) Sets the DataDescriptor associated with the value set.setDefaultValue(Object defaultValue) Sets the default value of the dual list box.setDispalyColumnNames(String... columnNames) Sets the columns containing the displayed value.final DualListBoxsetDisplayColumn(String columnName) Sets the name of the DataDescriptor column containing the value set’s displayed values.final DualListBoxsetDisplayColumnSeparator(String separator) Sets the separator text for the display values.setEnabled(boolean enabled) Enables/disables the dual list box.final DualListBoxsetExtendValues(String extendValues) This parameter enables you to save additional data to the relation table.final DualListBoxsetFilterCriteria(Criteria criteria) Sets the filter criterion used to filter the value set.final DualListBoxsetJoinTableName(String joinTableName) This method sets the name of the relation table.setReadOnly(boolean readOnly) Sets the form item to read-only mode.final DualListBoxsetRecordColumnName(String recordColumnName) You can use this setting to specify the way the saved record and the record in the relation table are joined.setSort(boolean sort) Specifies if the displayed values are sorted.Sets the dual list box value set according to the specified collator.Sets the current value of the dual list box.final DualListBoxsetValueColumnName(String valueColumnName) Sets the relation table column name where the component value is saved.
 The component value is a list of data values.Methods inherited from class com.jbstrap.ui.components.form.FormItem_addComponent, _setReverseShow, _setState, addComponent, addRecalcOnChangeColumn, addRecalcOnChangeColumns, addRecalcOnChangeColumns, addValueChangeHandler, clearValue, convertValueToJavaScript, convertValueToJavaScript, drawComponent, enableClearButton, eraseValue, getCalculateValue, getColumn, getComponents, getDataType, getDefaultState, getDescription, getFormItemSize, getLabel, getLabelPosition, getLabelSize, getLabelSize, getName, getOriginalValue, getParam, getParamAsBoolean, getParamAsDate, getParamAsDate, getParamAsDouble, getParamAsInteger, getParamAsLong, getParamAsNumber, getParamAsString, getRecalcOnChangeColumnsList, getState, getTabIndex, getValueAsBoolean, getValueAsDate, getValueAsDouble, getValueAsFloat, getValueAsInteger, getValueAsLong, getValueAsString, isAssignable, isAutoCalculate, isModified, isRequired, isReverseShow, isShowLabel, isVisible, onFormItemValueChanged, onHotKeyEventHandler, redraw, removeParam, resetState, runAfterDrawOnAddon, runOnHideOnAddon, runOnShowOnAddon, setCalculateValue, setDataType, setDataType, setDescription, setFocus, setFormItemSize, setLabel, setLabelPosition, setLabelSize, setLabelSize, setMargin, setModified, setObjectValue, setOriginalObjectValue, setOriginalValue, setPadding, setParam, setParams, setRequired, setShowLabel, setState, setTabIndex, setVisible, triggerFormChange, writeHTMLMethods inherited from class com.jbstrap.ui.Component_hide, _setAttribute, addAllowedRole, addComponent, addComponents, addDeniedRole, addHandler, addStyle, addStyleClass, addStyleClasses, clearfix, closeTag, combinateAccess, containsStyle, containsStyleClass, draw, drawSubComponents, error, flattendComponentTree, getAccess, getAccessMode, getAllowedRoles, getAttribute, getAttributes, getBackgroundColor, getBorderColor, getClient, getComponentById, getComponents, getComponentsByClass, getData, getDeniedRoles, getHandlers, getId, getLanguageCode, getParent, getParent, getRegisteredEvents, getStyle, getStyleClasses, getTextAlign, getTextColor, getToolTip, getToolTipPosition, getTypeName, getUI, insertComponentAfter, insertComponentBefore, isAccess, isDrawn, isEventBubbling, onHide, openTag, removeAllComponents, removeAllowedRole, removeAllStyleClasses, removeAttribute, removeComponent, removeComponent, removeComponents, removeDeniedRole, removeHandler, removeStyle, removeStyle, removeStyleClass, removeStyleClasses, replaceComponent, replaceStyleClass, runAfterDraw, runJavaScript, runJavaScript, runJavaScript, runOnHide, runOnShow, say, setAttribute, setBackgroundColor, setBorder, setBorderColor, setData, setDisplayType, setEventBubbling, setFlex, setFloating, setHeight100, setHeight25, setHeight50, setHeight75, setHeightAuto, setLanguage, setName, setOverflow, setParent, setScrollable, setSelectionType, setShadow, setStyle, setTextAlign, setTextColor, setToolTip, setToolTipPosition, setWidth100, setWidth25, setWidth50, setWidth75, setWidthAuto, showNotification, showNotification, showProcessIndicator, toggleStyleClassMethods inherited from class com.jbstrap.core.messagebus.MessageBuscloseMessageBus, messageBusOpened, openMessageBus, renewSubscription, sendMessageToMessageBus, subscribeMessageBus, unsubscribeAllListeners, unsubscribeMessageBusMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.jbstrap.ui.AnimatableaddAnimationEndHandler, addAnimationStartHandler, getAnimation, removeAnimation, setAnimationMethods inherited from interface com.jbstrap.ui.CanDropaddDropEventHandlerMethods inherited from interface com.jbstrap.ui.DraggableaddDragEndEventHandler, addDragStartEventHandler, setDraggableMethods inherited from interface com.jbstrap.ui.FetchableaddFetchDoneHandler, fireFetchDoneEventMethods inherited from interface com.jbstrap.ui.FocusableaddFocusHandler, addFocusInHandler, addFocusOutHandler, addLosesFocusHandlerMethods inherited from interface com.jbstrap.ui.HandleHotKeyaddHotKey, addHotKey, removeHotKey, removeHotKeysMethods inherited from interface com.jbstrap.ui.components.form.SupportHelpIcongetHelpIcon, getHelpText, setHelpIcon, setHelpText
- 
Constructor Details- 
DualListBoxCreates an empty dual list box with the specified name and label.- Parameters:
- name- Dual list box name
- label- Dual list box label text If- nullis specified, no label is assigned to the dual list box.
- Throws:
- NullPointerException- Thrown if the specified name is- null
 
- 
DualListBoxCreates an empty dual list box with the specified name and label according to the language code.- Parameters:
- name- Dual list box name
- label- Dual list box label text If- nullis specified, no label is assigned to the dual list box.
- language- Language code according to which the component is created If not specified or- nullis set, the framework’s default language code is used. The default language of the framework is set via the JBStrap parameter- JBStrapParamType.DEFAULT_LANGUAGE.
- Throws:
- NullPointerException- Thrown if the specified name is- null
 
- 
DualListBoxCreates an empty dual list box with the specified name and label.- Parameters:
- name- Dual list box name
- label- Dual list box label text If- nullis specified, no label is assigned to the dual list box.
- elements- Map containing the value set of the dual list box The map key is equal to the dual list box data value and the map value is the displayed value.
- Throws:
- NullPointerException- Thrown if the specified name is- null
- IllegalArgumentException- Thrown if the data value or the displayed value in the value set is- null
- See Also:
 
- 
DualListBoxCreates a dual list box with the specified name and label.- Parameters:
- name- Dual list box name
- label- Dual list box label text If- nullis specified, no label is assigned to the dual list box.
- language- Language code according to which the component is created If not specified or- nullis set, the framework’s default language code is used. The default language of the framework is set via the JBStrap parameter- JBStrapParamType.DEFAULT_LANGUAGE.
- elements- Map containing the value set of the dual list box The map key is equal to the dual list box data value and the map value is the displayed value.
- Throws:
- NullPointerException- Thrown if the specified name is- null
- IllegalArgumentException- Thrown if the data value or the displayed value in the value set is- null
- See Also:
 
- 
DualListBoxCreates a dual list box based on the specified DataDescriptor component. The method creates and sets the dual list box component based on the specified DataDescriptor column. The following parameters of the DataDescriptor are used: - DataDesriptorColumn.getTitle- Input field label set using the DataDescriptor column
- DataDescriptorColumn.isNullable()- If the field gets a value of- null, it is not designated as mandatory. If the field value is not set to- null, it is designated as a mandatory field.
- MetaParamName.DATADESCRIPTOR- The name of the DataDescriptor from where the dual list box retrieves its value set If the parameter is specified, the dual list box component’s value set is automatically read from the database and the component is populated with data upon being displayed.
- MetaParamName.DATA_COLUMN- Name of the DataDescriptor column containing the dual list box data value The data value of the dual list box is the value taken by the dual list box if the user selects the specified value from the value set.
- MetaParamName.DISPLAY_COLUMN- Name of the DataDescriptor column where the dual list box retrieves its values If you want to display multiple column values in the dual list box, all column names must be specified, separated with a comma (“,”). The displayed value is the value to be displayed on the interface upon being selected.
- MetaParamName.DISPLAY_COLUMN_SEPARATOR- If multiple column values are shown in the combobox component, this parameter specifies the column separator If no column separator is specified, values are listed in a consecutive order.
- MetaParamName.CRITERIA- This parameter specifies the filter criterion used to query the data. If no filter criterion is specified, all data values in the DataDescriptor are added to the dual list box as a value set.
- MetaParamName.AUTO_FETCH- Sets if the dual list box should automatically get value set items from the database If not specified, or provided as- true, the query is performed automatically. If- falseis specified, the query is not performed. Data query must be implemented from code by using the- fetchData()method.
- MetaParamName.MULTI_VALUE_JOIN_TABLE- Database relation table This parameter must be specified if multiple components can be selected. The parameter accepts a database table name in the same format as used in the database.
- MetaParamName.MULTI_VALUE_RECORD_COLUMN- This parameter links the saved record and the record in the relation table- To do this, specify the name of the column in the relation table. The record’s primary key is saved to this column. If the record has a composite key, all fields in the composite key’s columns must be listed. Field names must be listed separated with a comma in the same order as in the composite key. Specify fields in the same manner they are in the database. 
 If the relation table and record are not joined using the primary key, the join type must be specified by setting the field name in the relation table and making it equal (use the equals sign “=”) to the record attribute whose value is saved to the specified field.
 - E.g.: column=recordAttributeName. You can specify multiple field-attribute pairs separated with a comma. 
- MetaParamName.MULTI_VALUE_VALUE_COLUMN- This parameter specifies the column in the relation table containing the component value. The component value is a list of data values. If multiple values have been selected in the component, the relation table will also have multiple records. Upon record modification, relation table records are also updated. If the user deletes a value from the component, the corresponding relation table record is also deleted.
- MetaParamName.MULTI_VALUE_EXTEND_VALUES- If you want to save multiple relation table values, this parameter enables you to do so. The parameter assigns a static value to one or more fields in the relation table. Specify the field name in the relation table and a static value, preceded by an equals sign (“=”). (E.g.: column=12 or column=ABC)
 If you do not specify a static value, you can use the attribute of a saved record. Instead of a static value, specify the attribute name. E.g.: columnName=${recordAttributeName}. The specified data is saved to every relation table record. Multiple values can also be specified separated with commas.
- MetaParamName.SIZE- The input field size is set from the value specified here. (Available values: SMALL, MEDIUM, LARGE)
- MetaParamName.STATE- The input field state is set from these values. (Available values: DEFAULT, ERROR, WARNING, SUCCESS, INFO)
- MetaParamName.DEFAULT_VALUE- The value specified here is set as the input field’s default value. The value must be specified based on the field’s data type, in this case it must be a text value.
- MetaParamName.READ_ONLY- If- trueis set, the field is created as a read-only field. Otherwise, the field is created as writable and the user can freely modify its content.
- MetaParamName.ENABLED- If- falseis specified, the field is created as disabled. Otherwise the field is created as enabled.
- MetaParamName.HELP- If this parameter is specified, an icon is displayed next to the input field and the text specified here appears as a help text if the user moves the mouse over it
- MetaParamName.HELP_ICON- If an icon name is specified in the parameter, also listed in the enum- Icon, the default help icon is changed to the icon.
- MetaParamName.DESCRIPTION- The text specified here will appear below the field, in a smaller, italic font.
- MetaParamName.TAB_INDEX- The value specified here determines the order of the input focus (when the user presses the Tab key). The smaller the value is, the sooner the field receives focus. The greater the value is, the later the field gets focus. If the parameter is not specified, the field’s tab index receives the value of the field’s position in a sequence as specified in the DataDescriptor. If that is also not specified, the focus order is based on which data value was entered earlier into the DataDescriptor.
 - Parameters:
- column- DataDescriptor column used to create the field
- Throws:
- NullPointerException- Thrown if the parameter’s specified column is set to- null
- IllegalArgumentException- Thrown if the parameters DATA_VALUE or DISPLAY_VALUE are specified, but DATADESCRIPTOR is not specified or there are no columns in the DataDescriptor identified as DATADESCRIPTOR by the names specified in the parameters DATA_VALUE or DISPLAY_VALUE
- See Also:
 
- 
DualListBoxCreates a dual list box based on the specified DataDescriptor according to the language code. The method creates and sets the dual list box component based on the specified DataDescriptor column. The following parameters of the DataDescriptor are used: - DataDescriptorColumn.getTitle- Input field label set using the DataDescriptor column
- DataDescriptorColumn.isNullable()- If the field gets a value of- null, it is not designated as mandatory. If the field value is not set to- null, it is designated as a mandatory field.
- MetaParamName.DATADESCRIPTOR- The name of the DataDescriptor from where the dual list box retrieves its value set If the parameter is specified, the dual list box component automatically retrieves its value set from the database and is populated with data upon being displayed.
- MetaParamName.DATA_COLUMN- Name of the DataDescriptor column containing the dual list box data value The data value of the dual list box is the value taken by the dual list box if the user selects the specified value from the value set.
- MetaParamName.DISPLAY_COLUMN- Name of the DataDescriptor column from where the dual list box retrieves its values If you want to display the value of multiple columns in the dual list box, all column names must be specified separated with a “,” (comma). The displayed value is the value to be displayed on the interface.
- MetaParamName.DISPLAY_COLUMN_SEPARATOR- If multiple column values are shown in the combobox component, this parameter specifies the column separator If no column separator is specified, values are listed in a consecutive order.
- MetaParamName.CRITERIA- This parameter specifies the filter criterion used to query the data. If no filter criterion is specified, all data values in the DataDescriptor are added to the dual list box as a value set.
- MetaParamName.AUTO_FETCH- Sets if the dual list box should automatically get value set items from the database If not specified, or provided as- true, the query is performed automatically. If- falseis specified, the data query is not performed. It must be implemented from code by calling the- fetchData()method.
- MetaParamName.MULTI_VALUE_JOIN_TABLE- Relation table name in the database This parameter must be specified if multiple component values can be selected. The parameter accepts a database table name in the same format as used in the database.
- MetaParamName.MULTI_VALUE_RECORD_COLUMN- This parameter links the saved record and the record in the relation table- To do this, specify the name of the column in the relation table. The record’s primary key is saved to this column. If the record has a composite key, all column fields in the composite key from the relation table must be listed, separated with a comma in the same order as they are in the composite key. Specify fields in the same manner they are in the database. 
 If the relation table and record are not joined using the primary key, the join type must be specified by setting the field name in the relation table and making it equal (use the equals sign “=”) to the record attribute whose value is saved to the specified field.
 - E.g.: column=recordAttributeName. You can specify multiple field-attribute pairs separated with a comma. 
- MetaParamName.MULTI_VALUE_VALUE_COLUMN- This parameter specifies the column in the relation table containing the component value. The component value is a list of data values. If multiple values have been selected in the component, the relation table will also have multiple records. Upon record modification, relation table records are also updated. If the user deletes a value from the component, the corresponding relation table record is also deleted.
- MetaParamName.MULTI_VALUE_EXTEND_VALUES- If you want to save multiple relation table values, this parameter enables you to do so. The parameter assigns a static value to one or more fields in the relation table. Specify the field name in the relation table and a static value, preceded by an equals sign (“=”). (E.g.: column=12 or column=ABC)
 If you do not specify a static value, you can use the attribute of a saved record. Instead of a static value, specify the attribute name. E.g.: columnName=${recordAttributeName}. The specified data is saved to every relation table record. Multiple values can also be specified separated with commas.
- MetaParamName.SIZE- The input field size is set from the value specified here. (Available values: SMALL, MEDIUM, LARGE)
- MetaParamName.STATE- The input field state is set from these values. (Available values: DEFAULT, ERROR, WARNING, SUCCESS, INFO)
- MetaParamName.DEFAULT_VALUE- The value specified here is set as the input field’s default value. The value must be specified based on the field’s data type, in this case it must be a text value.
- MetaParamName.READ_ONLY- If- trueis set, the field is created as a read-only field. Otherwise, the field is created as writable and the user can freely modify its content.
- MetaParamName.ENABLED- If- falseis specified, the field is created as disabled. In all other cases the field is created as enabled.
- MetaParamName.HELP- If this parameter is specified, an icon is displayed next to the input field and the text specified here appears as a help text if the user moves the mouse over it.
- MetaParamName.HELP_ICON- If an icon name is specified in the parameter, also listed in the enum- Icon, the default help icon is changed to the icon.
- MetaParamName.DESCRIPTION- The text specified here will appear below the field, in a smaller, italic font.
- MetaParamName.TAB_INDEX- The value specified here determines the order of the input focus (when the user presses the Tab key). The smaller the value is, the sooner the field receives focus. The greater the value is, the later the field gets focus. If the parameter is not specified, the field’s tab index receives the value of the field’s position in a sequence as specified in the DataDescriptor. If that is also not specified, the focus order is based on which data value was entered earlier into the DataDescriptor.
 - Parameters:
- column- DataDescriptor column used to create the field
- language- Language code according to which the component is created If not specified or- nullis set, the framework’s default language code is used. The default language of the framework is set via the JBStrap parameter- JBStrapParamType.DEFAULT_LANGUAGE.
- Throws:
- NullPointerException- Thrown if the parameter’s specified column is set to- null
- IllegalArgumentException- Thrown if the parameters DATA_VALUE or DISPLAY_VALUE are specified, but DATADESCRIPTOR is not specified or there are no columns in the DataDescriptor identified as DATADESCRIPTOR by the names specified in the parameters DATA_VALUE or DISPLAY_VALUE
- See Also:
 
 
- 
- 
Method Details- 
setJoinTableNameThis method sets the name of the relation table. Values are saved to the relation table.- Specified by:
- setJoinTableNamein interface- MultiValueFormItem<DualListBox>
- Parameters:
- joinTableName- Table name for the relation table Specify the table name exactly the same way it is used in the database.
- Returns:
- Dual list box data value
 
- 
getJoinTableNameGets the database name of the relation table.- Specified by:
- getJoinTableNamein interface- MultiValueFormItem<DualListBox>
- Returns:
- Relation table name or nullif not specified
 
- 
setRecordColumnNameYou can use this setting to specify the way the saved record and the record in the relation table are joined. To do this, specify the name of the column in the relation table. The record’s primary key is saved to this column. If the record has a composite key, all fields in the composite key must be listed from the relation table, separated with a comma in the same order they are in the key. Specify fields in the same manner they are in the database. 
 If the relation table and record are not joined using the relation table, the join type must be specified by setting the field name in the relation table and making it equal (use the equals sign “=”) to the record attribute whose value is saved to the specified field.E.g.: column=recordAttributeName. You can use this format to assign multiple values separated with a comma. Set the name of the column in the relation table where you want to save the ID of the main record. If there are several columns, then the columns are separated by a comma (,).- Specified by:
- setRecordColumnNamein interface- MultiValueFormItem<DualListBox>
- Parameters:
- recordColumnName- Description of the record-relation table join
- Returns:
- Dual list box component
 
- 
getRecordColumnNameGets the record-relation table join description.- Specified by:
- getRecordColumnNamein interface- MultiValueFormItem<DualListBox>
- Returns:
- Description of the saved record-relation table record link or nullif not specified
 
- 
setValueColumnNameSets the relation table column name where the component value is saved.
 The component value is a list of data values. If multiple values have been selected in the component, the relation table will also have multiple records. Upon record modification, relation table records are also updated. If the user deletes a value from the component, the corresponding relation table record is also deleted.- Specified by:
- setValueColumnNamein interface- MultiValueFormItem<DualListBox>
- Parameters:
- valueColumnName- Relation table column name where the component value is saved to
- Returns:
- Dual list box component
 
- 
getValueColumnNameGets the relation table column name where the component’s value is saved to.- Specified by:
- getValueColumnNamein interface- MultiValueFormItem<DualListBox>
- Returns:
- Relation table column name where the dual list box value is saved or nullif not specified
 
- 
fetchDataGets the dual list box’s value set data from the database, fulfilling the specified filter criterion.- Parameters:
- criteria- Filter criterion used for the value set. If- nullis set, the value set is not filtered and all the records in the table are queried.
 
- 
addElementAdds an item to the dual list box. The new value is displayed automatically.- Parameters:
- dataValue- Data value of the item; taken by the dual list box upon being selected
- displayValue- The item’s display value
- Returns:
- Dual list box component
- Throws:
- IllegalArgumentException- Thrown if the specified data value or displayed value is- null
 
- 
addElementsAdds multiple items to the dual list box. New items are automatically displayed.- Parameters:
- data- Map with the new values The map key is a data value and the map value is the displayed value. A data value is the value taken by the dual list box upon being selected. A displayed value is the value visible to the user.
- Returns:
- Dual list box component
- Throws:
- IllegalArgumentException- Thrown if the data value or displayed value of any new item is- null
 
- 
removeElementRemoves an item from the dual list box’s value set based on the item’s data value.- Parameters:
- dataValue- The data value referencing the item to be removed
- Returns:
- Dual list box component
 
- 
clearClears the value set of the dual list box and removes all items from the value set.- Returns:
- Dual list box component
 
- 
setDataDescriptorSets the DataDescriptor associated with the value set.- Specified by:
- setDataDescriptorin interface- BasedOnDataDescriptor<DualListBox>
- Parameters:
- dataDesriptor- The DataDescriptor instance from where the component retrieves its value set
- Returns:
- Dual list box component
 
- 
getDataDescriptorGets the DataDescriptor associated with the dual list box value set.- Specified by:
- getDataDescriptorin interface- BasedOnDataDescriptor<DualListBox>
- Returns:
- DataDescriptor instance associated with the dual list box value set or nullif not specified
 
- 
setDataColumnSpecifies the name of the DataDescriptor which contains value set data values. A data value is a value taken by the dual list box if the item is selected.- Parameters:
- columnName- DataDescriptor column containing data values
- Returns:
- Dual list box component
- Throws:
- IllegalArgumentException- Thrown if there is not DataDescriptor set for the component or the specified DataDescriptor column is not included in the DataDescriptor
 
- 
getDataColumnNameGets the name of the DataDescriptor column containing value set data values.- Returns:
- DataDescriptor column name containing the value set’s data values or nullif not specified
 
- 
setDisplayColumnSets the name of the DataDescriptor column containing the value set’s displayed values.A displayed value is the value visible to the user. - Parameters:
- columnName- DataDescriptor column name
- Returns:
- Dual list box component
- Throws:
- IllegalArgumentException- Thrown if there is not DataDescriptor set for the component or the specified DataDescriptor column is not included in the DataDescriptor
 
- 
setDispalyColumnNamesSets the columns containing the displayed value. In case of multiple displayed values, the columns specified here are joined and the concatenated value is displayed.- Parameters:
- columnNames- A list of DataDescriptor columns containing the value set’s displayed values
- Returns:
- Dual list box component
- Throws:
- IllegalArgumentException- Thrown if there is not DataDescriptor set for the component or the specified DataDescriptor column is not included in the DataDescriptor
 
- 
getDisplayColumnNameGets the name of the DataDescriptor column containing the value set’s displayed values.- Returns:
- DataDescriptor column name containing the value set’s data values or nullif not specified If multiple DataDescriptor columns are displayed, the method returns the first specified name.
 
- 
getDisplayColumnNamesGets the DataDescriptor names for all specified display value.- Returns:
- A list of DataDescriptor column names containing the displayed values of the dual list box If no values are specified, an empty list is returned.
 
- 
setDisplayColumnSeparatorSets the separator text for the display values. The default separator is a space character. If multiple displayed value columns are specified for the dual list box component, column values are separated using this text.- Parameters:
- separator- Separator If- nullis specified, there is no separator text. Values are concatenated.
- Returns:
- Dual list box component
 
- 
getDisplayColumnSeparatorGets the separator text.- Returns:
- Separator text
 
- 
setValueSets the current value of the dual list box.- Overrides:
- setValuein class- FormItem<List<Object>,- DualListBox> 
- Parameters:
- value- Current value of the dual list box The current value of the dual list box is a list containing data values for the selected items. If- nullis specified, no selected item is included in the component.
- Returns:
- Form item component
 
- 
initDescription copied from class:ComponentThe component initialization method.Empty method, only needs to be overwritten when making a custom component, that needs to call an initializing JavaScript on the client side. The method is called by the framework after the component is drawn, but before the afterDraw() method. The use of this method during application development is not allowed. This method is meant for inner use only. - Overrides:
- initin class- FormItem<List<Object>,- DualListBox> 
- Throws:
- JavaScriptLoadError- If there was a JavaScript error during the initialization.
 
- 
afterDrawpublic void afterDraw()Description copied from class:ComponentThe operations to be executed after the drawing of the componentBy default, this is an empty method. It has to be overwritten on a component or page if additional operations have to be executed after the drawing process. One such operation is data retrieval, which shouldn't run in constructors so that the user could see results of an operation or navigation process. - Overrides:
- afterDrawin class- FormItem<List<Object>,- DualListBox> 
 
- 
onShowpublic void onShow()Description copied from class:ComponentThe operations to be executed after the component is displayed on the clientBy default, this is an empty method. It has to be overwritten on a component or page, if additional operations have to be executed after the component is displayed. This method is nearly identical to the afterDraw() method, they differ in when they are executed. This method runs after the component is displayed on the client. Meaning that it is executed even if the component isn't redrawn, but only set to be visible after being hidden. - Overrides:
- onShowin class- FormItem<List<Object>,- DualListBox> 
 
- 
getValueGets the current value of the dual list box.- Overrides:
- getValuein class- FormItem<List<Object>,- DualListBox> 
- Returns:
- A list of data values for the selected items (that is, items moved by the user from left to right)
 If the component’s value is null, the return value is alsonull.
 
- 
getDisplayValueYou cannot get a single displayed value of the dual list box since always multiple values are selected.- Specified by:
- getDisplayValuein interface- DifferentDataDisplayValue
- Returns:
- null
 
- 
getOriginalDisplayValueYou cannot get a single displayed value of the dual list box since always multiple values are selected.- Specified by:
- getOriginalDisplayValuein interface- DifferentDataDisplayValue
- Returns:
- null
 
- 
getDisplayValuesGets the displayed values for the selected items.- Specified by:
- getDisplayValuesin interface- DifferentMultiDataDisplayValue
- Returns:
- A list of displayed values selected by the user; nullis returned if the user has not selected any items
 
- 
getOriginalDisplayValuesGets the displayed values for the originally selected items.- Specified by:
- getOriginalDisplayValuesin interface- DifferentMultiDataDisplayValue
- Returns:
- A list of displayed values originally selected in the dual list box or nullif no items have been selected
 
- 
drawEditorDescription copied from class:FormItemDraws the editor component. You do not need to use this method during development, but all components extending the form item must implement it. Use the method to generate the input field’s HTML code. This code is then inserted into the corresponding DOM code when drawing the form item. - Specified by:
- drawEditorin class- FormItem<List<Object>,- DualListBox> 
- Parameters:
- writer- The HTML string writer class instance; write here the HTML code for the input field
 
- 
setSortSpecifies if the displayed values are sorted. By default, the value set is displayed sorted.- Parameters:
- sort- If- trueis set, the value set is displayed sorted
- Returns:
- Dual list box component
 
- 
setSortSets the dual list box value set according to the specified collator. By default, the dual list box value set is displayed in alphabetical order.- Parameters:
- sort- If- trueis specified, the value set is displayed sorted, otherwise it is displayed unsorted
- collator- Collator instance describing sorting
- Returns:
- Dual list box component
- See Also:
 
- 
setCollatorSets the collator instance sorting the value set.- Parameters:
- collator- Collator instance for sorting
- Returns:
- Dual list box component
 
- 
setDefaultValueSets the default value of the dual list box.- Specified by:
- setDefaultValuein class- FormItem<List<Object>,- DualListBox> 
- Parameters:
- defaultValue- A list of data values selected when the dual list box is in the default state
- Returns:
- Form item component
 
- 
getCriteriaGets the filter criterion used to retrieve the value set.- Specified by:
- getCriteriain interface- Filterable<DualListBox>
- Returns:
- Filter criterion used for the query or nullif no filter criterion is specified
 
- 
fetchDataGets the value set data from the database.- Specified by:
- fetchDatain interface- Fetchable<DualListBox>
- Specified by:
- fetchDatain interface- Filterable<DualListBox>
- Returns:
- The component
 
- 
setFilterCriteriaSets the filter criterion used to filter the value set.- Specified by:
- setFilterCriteriain interface- Filterable<DualListBox>
- Parameters:
- criteria- Filter criterion used for the value set
- Returns:
- Dual list box component
 
- 
setAutoFetchDataSets if the component should automatically query the data for the value set from the database. By default the dual list box value set is automatically queried from the database upon being displayed.- Specified by:
- setAutoFetchDatain interface- Fetchable<DualListBox>
- Specified by:
- setAutoFetchDatain interface- Filterable<DualListBox>
- Parameters:
- autoFetch- If set to- true, the query is executed automatically. Otherwise, the value set items are not automatically retrieved. It must be implemented from code by calling the- fetchData()method.
- Returns:
- Dual list box component
 
- 
isAutoFetchDatapublic boolean isAutoFetchData()Checks if the component automatically retrieves its value set from the database.- Specified by:
- isAutoFetchDatain interface- Fetchable<DualListBox>
- Specified by:
- isAutoFetchDatain interface- Filterable<DualListBox>
- Returns:
- If trueis set, the data for the value set is automatically queried, otherwise not.
 
- 
setReadOnlyDescription copied from class:FormItemSets the form item to read-only mode. By default, the form item is displayed as writable and the user can freely modify the form item value. If the component is set to read-only mode, the user is unable to modify the form item value.- Overrides:
- setReadOnlyin class- FormItem<List<Object>,- DualListBox> 
- Parameters:
- readOnly- If- trueis set, the form item is switched to read-only mode and the user is unable to modify the value. If- falseis set, the form item is switched to writable mode and the user is able to modify form item value.
- Returns:
- Form item component
 
- 
isReadOnlypublic boolean isReadOnly()Specifies if the dual list box is displayed in read-only mode. If the dual list box is displayed as read-only, the user is not allowed to move items from one list to the other.- Overrides:
- isReadOnlyin class- FormItem<List<Object>,- DualListBox> 
- Returns:
- If trueis set, the form element is visible, otherwisefalse
 
- 
setEnabledEnables/disables the dual list box. By default the dual list box is displayed as enabled. If the component is disabled, the user is not allowed to modify the component’s value (cannot move items from one list to the other).- Overrides:
- setEnabledin class- FormItem<List<Object>,- DualListBox> 
- Parameters:
- enabled- If- trueis set, the component is enabled, otherwise disabled
- Returns:
- Dual list box component
 
- 
isEnabledpublic boolean isEnabled()Sets if the component is enabled.- Overrides:
- isEnabledin class- Component<DualListBox>
- Returns:
- If trueis set, the dual list box is enabled Otherwise it is disabled.
 
- 
isMultiselectpublic boolean isMultiselect()Sets if the component can take multiple values. The method always returnstruebecause multiple selection is allowed in a dual list box.- Specified by:
- isMultiselectin interface- MultiValueFormItem<DualListBox>
- Returns:
- true
 
- 
setExtendValuesThis parameter enables you to save additional data to the relation table. The parameter assigns a static value to a relation table field. Specify the the relation table field first, then the static value, preceded by an equals sign (=). (E.g.: column=12 or column=ABC)
 If you do not specify a static value, you can use the attribute of a saved record. Instead of a static value, specify the attribute name. E.g.: columnName=${recordAttributeName}. The specified data is saved to every relation table record. If you specify not just a single additional value, specify a ist of values separated by commas.- Specified by:
- setExtendValuesin interface- MultiValueFormItem<DualListBox>
- Parameters:
- extendValues- The extended values to be added to the table
- Returns:
- Dual list box component
 
- 
getExtendValuesGets additional values from the relation table.- Specified by:
- getExtendValuesin interface- MultiValueFormItem<DualListBox>
- Returns:
- Additional values in the relation table or null
 
- 
setCustomFetchSets a custom query. When calling the fetchData method, the specifiedFetchEventimplementation is called, then callback methods are run on records returned by theonFetchmethod.- Parameters:
- fetchEvent- Custom query implementation
 
- 
fetchpublic List<Record> fetch(int startRow, int endRow, Criteria criteria, List<Order> orders, Client client) throws FindException, DataAccessException Description copied from interface:FetchableThis method implements actual data retrieval. TheFetchable.fetchData()function runs callback methods on the returned records.- Specified by:
- fetchin interface- Fetchable<DualListBox>
- Parameters:
- startRow- The first row of the query that appears in the returned list
- endRow- The last row of the query that appears in the returned list
- criteria- The criteria used during the query If- null, no criteria will be used, every record is queried.
- orders- The orderings that will be applied to the query results. If- null, the data will not be ordered.
- client- The client that started the query. If- null, the query will happen without checking for access rights.
- Returns:
- The list of records that meet the specified filter criteria.
- Throws:
- FindException- Occurs if an error was encountered during the query
- DataAccessException- Occurs if the user in the specified client has no access to read the data
 
 
-