1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
|
#==============================================================================
# Main Tablelist and Tablelist_tile package module.
#
# Copyright (c) 2000-2025 Csaba Nemethi (E-mail: csaba.nemethi@t-online.de)
#==============================================================================
namespace eval tablelist {
proc - {} { return [expr {$::tcl_version >= 8.5 ? "-" : ""}] }
package require Tk 8.4[-]
#
# Public variables:
#
variable version 7.6
variable library [file dirname [file normalize [info script]]]
#
# Creates a new tablelist widget:
#
namespace export tablelist
#
# Sort the items of a tablelist widget by one or more of its columns:
#
namespace export sortByColumn addToSortColumns
#
# Helper procedures used in binding scripts:
#
namespace export convEventFields getTablelistPath getTablelistColumn \
delaySashPosUpdates
#
# Register various widgets for interactive cell editing:
#
namespace export addBWidgetEntry addBWidgetSpinBox addBWidgetComboBox
namespace export addIncrEntryfield addIncrDateTimeWidget \
addIncrSpinner addIncrSpinint addIncrCombobox
namespace export addCtext addOakleyCombobox
namespace export addDateMentry addTimeMentry addDateTimeMentry \
addFixedPointMentry addIPAddrMentry addIPv6AddrMentry
}
package provide tablelist::common $tablelist::version
#
# The following procedure, invoked in "tablelist.tcl" and
# "tablelist_tile.tcl", sets the variable tablelist::usingTile
# to the given value and sets a trace on this variable.
#
proc tablelist::useTile {bool} {
variable usingTile $bool
trace add variable usingTile {write unset} \
[list tablelist::restoreUsingTile $bool]
}
#
# The following trace procedure is executed whenever the variable
# tablelist::usingTile is written or unset. It restores the
# variable to its original value, given by the first argument.
#
proc tablelist::restoreUsingTile {origVal varName index op} {
variable usingTile $origVal
switch $op {
write {
return -code error "it is not supported to use both Tablelist and\
Tablelist_tile in the same application"
}
unset {
trace add variable usingTile {write unset} \
[list tablelist::restoreUsingTile $origVal]
}
}
}
proc tablelist::createTkAliases {} {
foreach cmd {frame label} {
if {[llength [info commands ::tk::$cmd]] == 0} {
interp alias {} tk::$cmd {} $cmd
}
}
}
tablelist::createTkAliases
#
# Everything else needed is lazily loaded on demand, via the dispatcher
# set up in the subdirectory "scripts" (see the file "tclIndex").
#
lappend auto_path [file join $tablelist::library scripts]
#
# Load the packages mwutil, scaleutil, and scaleutilmisc from the directory
# "scripts/utils". Take into account that mwutil is also included in Mentry,
# Scrollutil, and Tsw, and scaleutil is also included in Scrollutil and Tsw.
#
proc tablelist::loadUtils {} {
if {[catch {package present mwutil} version] == 0 &&
[package vcompare $version 2.25] < 0} {
package forget mwutil
}
package require mwutil 2.25[-]
if {[catch {package present scaleutil} version] == 0 &&
[package vcompare $version 1.15] < 0} {
package forget scaleutil
}
package require scaleutil 1.15[-]
package require scaleutilmisc 1.7.1[-]
}
tablelist::loadUtils
|