This section explains all the options available to instances of widget::listentry. Please note that a few
of the options can be set only at instance construction time. The majority of the options can however be
set both during construction- and runtime.
WIDGETCONSTRUCTION-TIMEONLYOPTIONS-ordered boolean
This options tells the new widget instance whether the list it manages is ordered or not. If it is
ordered the widget will show buttons with which the selected entries can be moved around, editing
the order.
The default is false, indicating an unordered list.
-allow-duplicates boolean
This options tells the new widget instance whether we are allowed to add a string to the list
multiple times, or not.
The default is false, indicating that duplicates are not allowed.
-values cmdprefix
This option specifies a callback for the management of a predefined list of strings a user may
enter.
If specified the widget will use a combobox instead of a plain entry field and fill its list
during widget construction using the data delivered by this callback. The callback will be
further invoked whenever a new value is entered into the main list, to save the extended list of
predefined values.
The signature of this callback is
{*}cmdprefixget
In this form the callback is expected to return a list of strings. The strings are loaded
into the list of the internal combobox for quick access by the user.
It will be invoked once, during widget construction, to load the list of predefined strings
a user may enter.
{*}cmdprefixsetvalues
In this form the callback is given a list of new strings and expected to save them
somewhere for future use.
The return value of the callback is ignored.
This form is invoked whenever the user entered a new string into the main list. The order
of strings in values represents the order used to show them in the combobox's list.
-validate cmdprefix
This option specifies a callback which is invoked after every change of the contents of the
internal entry field. The signature of this callback is
{*}cmdprefixtexterrvar
where text is the string to validate, and errvar the name of a variable the callback can
store an error message into when it detects invalid data.
The widget expects that the callback returns a boolean value, where true indicates that
text is valid.
The default validation, when no callback was specified, will treat the empty string as invalid,
and everything else as valid.
Pleasenote that the widget will prevent the entry of duplicate values into the main list,
regardless of the validity of the input otherwise. This is in keeping with that this widget is
meant for the entry of unordered lists, essentially a set of strings.
-transform cmdprefix
This option specifies a callback which is invoked whenever a newly entered element is moved from
the entry field to the main list, or the entry field is validated, as part of a check for
duplicates, if such are not allowed. The callback is given the text in the entry field and has to
return the text which is actually added to, or checked against the list.
The use case for this callback is essentially inputnormalization. The most simple case of such
would be, for example the use of
string tolower
to case on the data. More complex example can be thought of, like rewriting of multiple syntaxes of
input to a canonical form. The signature of this callback is
{*}cmdprefixtext
where text is the string to transform.
The widget expects that the callback returns the transformed string.
The default is to not transform the entered strings.
-browse cmdprefix
If this option is specified the widget will display a "Search" button and invoke the callback
provided by the option whenever the user clicks on that button. The signature of the callback is
{*}cmdprefixcookievar
where the cookie variable provides access to context information the callback may wish to
preserve between invokations. The initial value stored in the variable is the empty string.
After that it is whatever the callback wishes to store.
The widget expects that the callback returns a list of strings, which are then added to the
list, modulo validity and duplicate checks.
By default there is no browse callback and no button shown.
WIDGETGENERALOPTIONS-listvariable varname
This option specifies the variable holding the list to be manipulated by the widget. Any changes
to the list outside of the widget are automatically imported into the widget. Similarly, all
changes made to the list by the widget are automatically exported to this variable.
-state normal|disabled
This option specifies the status of the widget, normal (= active), or disabled. A disabled widget
can not be edited.
The default is normal.
-height integer
This option specifies the height of the internal listbox, in lines.
The default is 20.
-skin-add string
-skin-remove string
-skin-up string
-skin-down string
-skin-browse string
-skin-tip-add string
-skin-tip-remove string
-skin-tip-up string
-skin-tip-down string
-skin-tip-browse string
-skin-tip-main string
-skin-tip-entry string
-skin-tip-list string
-skin-tip-empty string
-skin-tip-duplicate string
-skin-tip-add-none string
-skin-tip-remove-none string
-skin-img-add image
-skin-img-remove image
-skin-img-up string
-skin-img-down string
-skin-img-browse string
-skin-invalid-color color
These options all modify the appearance of the widget, i.e. its skin.
All options taking a string argument influence the various labels shown, with the -skin-tip-*
options influencing the tooltips shown on hovering the over various parts in particular.
All the strings are run through msgcat first, enabling text localization through message catalogs.
The default values are keys into the message catalogs which are part of the package itself.
The options taking images modify the images shown on the buttons for adding and removing elements
of the list. They default to the PNG images distributed with the package itself.
The single option taking a color value modifies the color used to highlight invalid data entered
into the internal entry field of the widget. This option defaults to yellow.