The Multi-Column Listbox and Tree Widget Package Tablelist by Csaba Nemethi csaba.nemethi@t-online.de What Is Tablelist? ------------------ Tablelist is a library package for Tcl/Tk versions 8.0 or higher, written in pure Tcl/Tk code. It contains: - the implementation of the "tablelist" mega-widget, including a general utility module for mega-widgets; - a demo script containing a useful procedure that displays the configuration options of an arbitrary widget in a tablelist and enables you to edit their values interactively; - a demo script implementing a widget browser based on a tablelist used as multi-column listbox; - a demo script implementing a widget browser based on a tablelist used as multi-column tree widget; - a demo script implementing a directory viewer based on a tablelist used as multi-column tree widget; - a demo script showing several ways to improve the appearance of a tablelist widget; - four further demo scripts, illustrating the interactive cell editing with the aid of various widgets from the Tk core and from the packages tile, BWidget, Iwidgets, combobox (by Bryan Oakley), and Mentry; - one further demo script, with a tablelist widget containing embedded windows; - tile-based counterparts of the above-mentioned demo scripts; - a tutorial in HTML format; - reference pages in HTML format. A tablelist is a multi-column listbox and tree widget. The width of each column can be dynamic (i.e., just large enough to hold all its elements, including the header) or static (specified in characters or pixels). The columns are, per default, resizable. The alignment of each column can be specified as "left", "right", or "center". The columns, rows, and cells can be configured individually. Several of the global and column-specific options refer to the header titles, implemented as label widgets. For instance, the "-labelcommand" option specifies a Tcl command to be invoked when mouse button 1 is released over a header label. The most common value of this option sorts the items based on the respective column. The Tablelist package provides a great variety of tree styles controlling the look & feel of the column that displays the tree hierarchy with the aid of indentations and expand/collapse controls. Interactive editing of the elements of a tablelist widget can be enabled for individual cells and for entire columns. A great variety of widgets from the Tk core and from the packages tile, BWidget, Iwidgets, combobox, ctext, and Mentry (or Mentry_tile) is supported for being used as embedded edit window. In addition, a rich set of keyboard bindings is provided for a comfortable navigation between the editable cells. The Tcl command corresponding to a tablelist widget is very similar to the one associated with a normal listbox. There are column-, row-, and cell-specific counterparts of the "configure" and "cget" subcommands ("columnconfigure", "rowconfigure", "cellconfigure", ...). They can be used, among others, to insert images into the cells and the header labels, or to insert embedded windows into the cells. The "index", "nearest", and "see" command options refer to the rows, but similar subcommands are provided for the columns and cells ("columnindex", "cellindex", ...). The items can be sorted with the "sort", "sortbycolumn", and "sortbycolumnlist" command options. The bindings defined for the body of a tablelist widget make it behave just like a normal listbox. This includes the support for the virtual event <> (which is equivalent to <>). In addition, version 2.3 or higher of the widget callback package Wcb (written in pure Tcl/Tk code as well) can be used to define callbacks for the "activate", "selection set", and "selection clear" commands, and Wcb version 3.0 or higher also supports callbacks for the "activatecell", "cellselection set", and "cellselection clear" commands. The download location of Wcb is http://www.nemethi.de How to Get It? -------------- Tablelist is available for free download from the same URL as Wcb. The distribution file is "tablelist6.4.tar.gz" for UNIX and "tablelist6_4.zip" for Windows. These files contain the same information, except for the additional carriage return character preceding the linefeed at the end of each line in the text files for Windows. Tablelist is also included in tklib, which has the address http://core.tcl.tk/tklib How to Install It? ------------------ Install the package as a subdirectory of one of the directories given by the "auto_path" variable. For example, you can install it as a directory at the same level as the Tcl and Tk script libraries. The locations of these library directories are given by the "tcl_library" and "tk_library" variables, respectively. To install Tablelist on UNIX, "cd" to the desired directory and unpack the distribution file "tablelist6.4.tar.gz": gunzip -c tablelist6.4.tar.gz | tar -xf - On most UNIX systems this can be replaced with tar -zxf tablelist6.4.tar.gz Both commands will create a directory named "tablelist6.4 with the subdirectories "demos", "doc", and "scripts". On Windows, use WinZip or some other program capable of unpacking the distribution file "tablelist6_4.zip" into the directory "tablelist6.4", with the subdirectories "demos", "doc", and "scripts". The file "tablelistEdit.tcl" in the "scripts" directory is only needed for applications making use of interactive cell editing. Similarly, the file "tablelistMove.tcl" in the same directory is only required for scripts invoking the "move" or "movecolumn" tablelist command. Finally, the file "tablelistThemes.tcl" is only needed for applications using the package Tablelist_tile (see next section). Next, you should check the exact version number of your Tcl/Tk distribution, given by the "tcl_patchLevel" and "tk_patchLevel" variables. If you are using Tcl/Tk version 8.2.X, 8.3.0 - 8.3.2, or 8.4a1, then you should proceed as described in the "How to Install It?" section of the file "tablelist.html", located in the "doc" directory. How to Use It? -------------- The Tablelist distribution provides two packages, called Tablelist and Tablelist_tile. The main difference between the two is that Tablelist_tile enables the tile-based, theme-specific appearance of tablelist widgets; this package requires Tcl/Tk 8.4 or higher and tile 0.6 or higher. It is not possible to use both packages in one and the same application, because both are implemented in the same "tablelist" namespace and provide identical commands. To be able to use the commands and variables implemented in the package Tablelist, your scripts must contain one of the lines package require tablelist ?version? package require Tablelist ?version? Likewise, to be able to use the commands and variables implemented in the package Tablelist_tile, your scripts must contain one of the lines package require tablelist_tile ?version? package require Tablelist_tile ?version? Since the packages Tablelist and Tablelist_tile are implemented in the "tablelist" namespace, you must either import the procedures you need, or use qualified names like "tablelist::tablelist". For a detailed description of the commands and variables provided by Tablelist and of the examples contained in the "demos" directory, see the tutorial "tablelist.html" and the reference pages, all located in the "doc" directory.