Provided by: tklib_0.8~20230222-1_all bug

NAME

       widget_listentry - widget::listentry widget

SYNOPSIS

       package require Tcl  8.5

       package require Tk  8.5

       package require widget::listentry  ?0.1.2?

       package require widget::validator  ?0.1?

       package require widget::scrolledwindow

       package require snit

       package require tooltip

       package require img::png

       package require msgcat

       widget::listentry pathname ?options?

       widgetCmd destroy

       widgetCmd configure

       widgetCmd configure option value ...

       widgetCmd configure option

       widgetCmd cget option

       {*}cmdprefix get

       {*}cmdprefix set values

       {*}cmdprefix text errvar

       {*}cmdprefix text

       {*}cmdprefix cookievar

________________________________________________________________________________________________________________

DESCRIPTION

       This  package  provides  a  megawidget  for  the interactive entry of ordered and unordered lists.  For a
       simpler and more restricted megawidget please see the package widget::listsimple.

CLASS API

       The widget class supports a single command, for the creation of widgets.

       widget::listentry pathname ?options?
              This command creates and configures new instances of the widget.

              For details on the available options please see section Widget Options.

              The result of the command is the pathname of the new widget.

INSTANCE API

       All widget instances supported the following methods.

       widgetCmd destroy
              This method destroys the widget.  Any further access to the widget will generate errors.

              The result of the command is the empty string.

       widgetCmd configure
              This method comes in three variants. This variant here  returns  a  list  containing  the  current
              configuration of the widget, i.e. the values for all options.

              For details on the available options please see section Widget Options.

       widgetCmd configure option value ...
              This  method  comes  in  three  variants.  This  variant here reconfigures the widget, setting the
              specified options to the given values.

              Note that it is not possible to change the construction-time only options.

              For details on the available options please see section Widget General Options.

              The result of the command is the empty string.

       widgetCmd configure option
              This method comes in three variants. This variant here is an alias for the method cget  below  and
              identical to it.

       widgetCmd cget option
              This method returns the current value of the specified option.

              For details on the available options please see section Widget Options.

WIDGET OPTIONS

       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.

   WIDGET CONSTRUCTION-TIME ONLY OPTIONS
       -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

              {*}cmdprefix get
                     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.

              {*}cmdprefix set values
                     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

              {*}cmdprefix text errvar
                     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.

              Please  note  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 input normalization. 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

              {*}cmdprefix text
                     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

              {*}cmdprefix cookievar
                     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.

   WIDGET GENERAL OPTIONS
       -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.

EXAMPLE

BUGS, IDEAS, FEEDBACK

       This document, and the package it describes, will undoubtedly contain bugs and  other  problems.   Please
       report      such      in     the     category     widget::listentry     of     the     Tklib     Trackers
       [http://core.tcl.tk/tklib/reportlist].  Please also report any ideas for enhancements you  may  have  for
       either package and/or documentation.

KEYWORDS

       data  entry  lists,  data  entry ordered list, data entry set of strings, data entry unordered list, list
       entry panel, set entry panel, widget

tklib                                                 0.1.2                                widget_listentry(3tk)