1604 lines
60 KiB
Python
Executable File
1604 lines
60 KiB
Python
Executable File
# -*-mode: python; fill-column: 75; tab-width: 8; coding: iso-latin-1-unix -*-
|
|
#
|
|
# $Id$
|
|
#
|
|
# Tix.py -- Tix widget wrappers.
|
|
#
|
|
# For Tix, see http://tix.sourceforge.net
|
|
#
|
|
# - Sudhir Shenoy (sshenoy@gol.com), Dec. 1995.
|
|
# based on an idea of Jean-Marc Lugrin (lugrin@ms.com)
|
|
#
|
|
# NOTE: In order to minimize changes to Tkinter.py, some of the code here
|
|
# (TixWidget.__init__) has been taken from Tkinter (Widget.__init__)
|
|
# and will break if there are major changes in Tkinter.
|
|
#
|
|
# The Tix widgets are represented by a class hierarchy in python with proper
|
|
# inheritance of base classes.
|
|
#
|
|
# As a result after creating a 'w = StdButtonBox', I can write
|
|
# w.ok['text'] = 'Who Cares'
|
|
# or w.ok['bg'] = w['bg']
|
|
# or even w.ok.invoke()
|
|
# etc.
|
|
#
|
|
# Compare the demo tixwidgets.py to the original Tcl program and you will
|
|
# appreciate the advantages.
|
|
#
|
|
|
|
import string
|
|
from Tkinter import *
|
|
from Tkinter import _flatten, _cnfmerge, _default_root
|
|
|
|
# WARNING - TkVersion is a limited precision floating point number
|
|
if TkVersion < 3.999:
|
|
raise ImportError, "This version of Tix.py requires Tk 4.0 or higher"
|
|
|
|
import _tkinter # If this fails your Python may not be configured for Tk
|
|
# TixVersion = string.atof(tkinter.TIX_VERSION) # If this fails your Python may not be configured for Tix
|
|
# WARNING - TixVersion is a limited precision floating point number
|
|
|
|
# Some more constants (for consistency with Tkinter)
|
|
WINDOW = 'window'
|
|
TEXT = 'text'
|
|
STATUS = 'status'
|
|
IMMEDIATE = 'immediate'
|
|
IMAGE = 'image'
|
|
IMAGETEXT = 'imagetext'
|
|
BALLOON = 'balloon'
|
|
AUTO = 'auto'
|
|
ACROSSTOP = 'acrosstop'
|
|
|
|
# BEWARE - this is implemented by copying some code from the Widget class
|
|
# in Tkinter (to override Widget initialization) and is therefore
|
|
# liable to break.
|
|
import Tkinter, os
|
|
|
|
# Could probably add this to Tkinter.Misc
|
|
class tixCommand:
|
|
"""The tix command provides access to miscellaneous elements
|
|
of Tix's internal state and the Tix application context.
|
|
Most of the information manipulated by this command per
|
|
tains to the application as a whole, or to a screen or
|
|
display, rather than to a particular window. The command
|
|
can take any of a number of different forms depending on
|
|
the option argument.
|
|
|
|
This is a mixin class, assumed to be mixed to Tkinter.Tk
|
|
that supports the self.tk.call method.
|
|
"""
|
|
def tix_addbitmapdir(self, directory):
|
|
"""Tix maintains a list of directory under which which
|
|
the tix_getimage and tix_getbitmap commands will
|
|
search for image files. The standard bitmap direc
|
|
tory is $TIX_LIBRARY/bitmaps. The addbitmapdir com
|
|
mand adds directory into this list. By using this
|
|
command, the image files of an applications can
|
|
also be located using the tix_getimage or tix_getbitmap
|
|
command.
|
|
"""
|
|
return self.tk.call('tix', 'addbitmapdir', directory)
|
|
|
|
def tix_cget(self, option):
|
|
"""Returns the current value of the configuration
|
|
option given by option. Option may be any of the
|
|
options described in the CONFIGURATION OPTIONS section.
|
|
"""
|
|
return self.tk.call('tix', 'cget', option)
|
|
|
|
def tix_configure(self, cnf=None, **kw):
|
|
"""Query or modify the configuration options of the
|
|
Tix application context. If no option is specified,
|
|
returns a list describing all of the available
|
|
options (see Tk_ConfigureInfo for information on
|
|
the format of this list). If option is specified
|
|
with no value, then the command returns a list
|
|
describing the one named option (this list will be
|
|
identical to the corresponding sublist of the value
|
|
returned if no option is specified). If one or
|
|
more option-value pairs are specified, then the
|
|
command modifies the given option(s) to have the
|
|
given value(s); in this case the command returns an
|
|
empty string. Option may be any of the options
|
|
described in the CONFIGURATION OPTIONS section.
|
|
"""
|
|
return apply(self.tk.call, ('tix', configure) +
|
|
self._options(cnf,kw) )
|
|
|
|
def tix_filedialog(self, dlgclass=None):
|
|
"""Returns the file selection dialog that may be
|
|
shared among different modules of this application.
|
|
This command will create a file selection dialog
|
|
widget when it is called the first time. This dialog
|
|
will be returned by all subsequent calls to tix
|
|
filedialog. An optional dlgclass parameter can be
|
|
passed to specified what type of file selection
|
|
dialog widget is desired. Possible options are 'tix'
|
|
'FileSelectDialog' or 'tixExFileSelectDialog'.
|
|
"""
|
|
if dlgclass is not None:
|
|
return self.tk.call('tix', 'filedialog', dlgclass)
|
|
else:
|
|
return self.tk.call('tix', 'filedialog')
|
|
|
|
def tix_getbitmap(self, name):
|
|
"""Locates a bitmap file of the name name.xpm or name
|
|
in one of the bitmap directories (self, see the
|
|
tix_addbitmapdir command above). By using tix_getbitmap,
|
|
you can advoid hard coding the pathnames of
|
|
the bitmap files in your application. When successful,
|
|
it returns the complete pathname of the bitmap
|
|
file, prefixed with the character '@'. The returned
|
|
value can be used to configure the -bitmap option
|
|
of the TK and Tix widgets.
|
|
"""
|
|
return self.tk.call('tix', 'getbitmap', name)
|
|
|
|
def tix_getimage(self, name):
|
|
"""Locates an image file of the name name.xpm,
|
|
name.xbm or name.ppm in one of the bitmap directo
|
|
ries (see the addbitmapdir command above). If more
|
|
than one file with the same name (but different
|
|
extensions) exist, then the image type is chosen
|
|
according to the depth of the X display: xbm images
|
|
are chosen on monochrome displays and color images
|
|
are chosen on color displays. By using tix getim
|
|
age, you can advoid hard coding the pathnames of
|
|
the image files in your application. When success
|
|
ful, this command returns the name of the newly
|
|
created image, which can be used to configure the
|
|
-image option of the TK and Tix widgets.
|
|
"""
|
|
return self.tk.call('tix', 'getimage', name)
|
|
|
|
def tix_option_get(self, name):
|
|
"""Gets the options manitained by the Tix
|
|
scheme mechanism. Available options are:
|
|
|
|
active_bg active_fg bg
|
|
bold_font dark1_bg dark1_fg
|
|
dark2_bg dark2_fg disabled_fg
|
|
fg fixed_font font
|
|
inactive_bg inactive_fg input1_bg
|
|
input2_bg italic_font light1_bg
|
|
light1_fg light2_bg light2_fg
|
|
menu_font output1_bg output2_bg
|
|
select_bg select_fg selector
|
|
"""
|
|
# could use self.tk.globalgetvar('tixOption', name)
|
|
return self.tk.call('tix', 'option', 'get', name)
|
|
|
|
def tix_resetoptions(self, newScheme, newFontSet, newScmPrio=None):
|
|
"""Resets the scheme and fontset of the Tix application
|
|
to newScheme and newFontSet, respectively.
|
|
This affects only those widgets created after this
|
|
call. Therefore, it is best to call the resetop
|
|
tions command before the creation of any widgets in
|
|
a Tix application.
|
|
|
|
The optional parameter newScmPrio can be given to
|
|
reset the priority level of the TK options set by
|
|
the Tix schemes.
|
|
|
|
Because of the way TK handles the X option database, after
|
|
tixwish has started up, it is not possible to reset the
|
|
color schemes and font sets using the tix config command.
|
|
Instead, the tix resetoptions command must be used.
|
|
"""
|
|
if newScmPrio is not None:
|
|
return self.tk.call('tix', 'resetoptions', newScheme, newFontSet, newScmPrio)
|
|
else:
|
|
return self.tk.call('tix', 'resetoptions', newScheme, newFontSet)
|
|
|
|
class Tk(Tkinter.Tk, tixCommand):
|
|
"""Toplevel widget of Tix which represents mostly the main window
|
|
of an application. It has an associated Tcl interpreter."""
|
|
def __init__(self, screenName=None, baseName=None, className='Tix'):
|
|
Tkinter.Tk.__init__(self, screenName, baseName, className)
|
|
tixlib = os.environ.get('TIX_LIBRARY')
|
|
self.tk.eval('global auto_path; lappend auto_path [file dir [info nameof]]')
|
|
if tixlib is not None:
|
|
self.tk.eval('global auto_path; lappend auto_path {%s}' % tixlib)
|
|
self.tk.eval('global tcl_pkgPath; lappend tcl_pkgPath {%s}' % tixlib)
|
|
# Load Tix - this should work dynamically or statically
|
|
# If it's static, lib/tix8.1/pkgIndex.tcl should have
|
|
# 'load {} Tix'
|
|
# If it's dynamic, lib/tix8.1/pkgIndex.tcl should have
|
|
# 'load libtix8.1.8.3.so Tix'
|
|
self.tk.eval('package require Tix')
|
|
|
|
|
|
# The Tix 'tixForm' geometry manager
|
|
class Form:
|
|
"""The Tix Form geometry manager
|
|
|
|
Widgets can be arranged by specifying attachments to other widgets.
|
|
See Tix documentation for complete details"""
|
|
|
|
def config(self, cnf={}, **kw):
|
|
apply(self.tk.call, ('tixForm', self._w) + self._options(cnf, kw))
|
|
|
|
form = config
|
|
|
|
def __setitem__(self, key, value):
|
|
Form.form(self, {key: value})
|
|
|
|
def check(self):
|
|
return self.tk.call('tixForm', 'check', self._w)
|
|
|
|
def forget(self):
|
|
self.tk.call('tixForm', 'forget', self._w)
|
|
|
|
def grid(self, xsize=0, ysize=0):
|
|
if (not xsize) and (not ysize):
|
|
x = self.tk.call('tixForm', 'grid', self._w)
|
|
y = self.tk.splitlist(x)
|
|
z = ()
|
|
for x in y:
|
|
z = z + (self.tk.getint(x),)
|
|
return z
|
|
self.tk.call('tixForm', 'grid', self._w, xsize, ysize)
|
|
|
|
def info(self, option=None):
|
|
if not option:
|
|
return self.tk.call('tixForm', 'info', self._w)
|
|
if option[0] != '-':
|
|
option = '-' + option
|
|
return self.tk.call('tixForm', 'info', self._w, option)
|
|
|
|
def slaves(self):
|
|
return map(self._nametowidget,
|
|
self.tk.splitlist(
|
|
self.tk.call(
|
|
'tixForm', 'slaves', self._w)))
|
|
|
|
|
|
|
|
|
|
Tkinter.Widget.__bases__ = Tkinter.Widget.__bases__ + (Form,)
|
|
|
|
class TixWidget(Tkinter.Widget):
|
|
"""A TixWidget class is used to package all (or most) Tix widgets.
|
|
|
|
Widget initialization is extended in two ways:
|
|
1) It is possible to give a list of options which must be part of
|
|
the creation command (so called Tix 'static' options). These cannot be
|
|
given as a 'config' command later.
|
|
2) It is possible to give the name of an existing TK widget. These are
|
|
child widgets created automatically by a Tix mega-widget. The Tk call
|
|
to create these widgets is therefore bypassed in TixWidget.__init__
|
|
|
|
Both options are for use by subclasses only.
|
|
"""
|
|
def __init__ (self, master=None, widgetName=None,
|
|
static_options=None, cnf={}, kw={}):
|
|
# Merge keywords and dictionary arguments
|
|
if kw:
|
|
cnf = _cnfmerge((cnf, kw))
|
|
else:
|
|
cnf = _cnfmerge(cnf)
|
|
|
|
# Move static options into extra. static_options must be
|
|
# a list of keywords (or None).
|
|
extra=()
|
|
if static_options:
|
|
for k,v in cnf.items()[:]:
|
|
if k in static_options:
|
|
extra = extra + ('-' + k, v)
|
|
del cnf[k]
|
|
|
|
self.widgetName = widgetName
|
|
Widget._setup(self, master, cnf)
|
|
|
|
# If widgetName is None, this is a dummy creation call where the
|
|
# corresponding Tk widget has already been created by Tix
|
|
if widgetName:
|
|
apply(self.tk.call, (widgetName, self._w) + extra)
|
|
|
|
# Non-static options - to be done via a 'config' command
|
|
if cnf:
|
|
Widget.config(self, cnf)
|
|
|
|
# Dictionary to hold subwidget names for easier access. We can't
|
|
# use the children list because the public Tix names may not be the
|
|
# same as the pathname component
|
|
self.subwidget_list = {}
|
|
|
|
# We set up an attribute access function so that it is possible to
|
|
# do w.ok['text'] = 'Hello' rather than w.subwidget('ok')['text'] = 'Hello'
|
|
# when w is a StdButtonBox.
|
|
# We can even do w.ok.invoke() because w.ok is subclassed from the
|
|
# Button class if you go through the proper constructors
|
|
def __getattr__(self, name):
|
|
if self.subwidget_list.has_key(name):
|
|
return self.subwidget_list[name]
|
|
raise AttributeError, name
|
|
|
|
def set_silent(self, value):
|
|
"""Set a variable without calling its action routine"""
|
|
self.tk.call('tixSetSilent', self._w, value)
|
|
|
|
def subwidget(self, name):
|
|
"""Return the named subwidget (which must have been created by
|
|
the sub-class)."""
|
|
n = self._subwidget_name(name)
|
|
if not n:
|
|
raise TclError, "Subwidget " + name + " not child of " + self._name
|
|
# Remove header of name and leading dot
|
|
n = n[len(self._w)+1:]
|
|
return self._nametowidget(n)
|
|
|
|
def subwidgets_all(self):
|
|
"""Return all subwidgets."""
|
|
names = self._subwidget_names()
|
|
if not names:
|
|
return []
|
|
retlist = []
|
|
for name in names:
|
|
name = name[len(self._w)+1:]
|
|
try:
|
|
retlist.append(self._nametowidget(name))
|
|
except:
|
|
# some of the widgets are unknown e.g. border in LabelFrame
|
|
pass
|
|
return retlist
|
|
|
|
def _subwidget_name(self,name):
|
|
"""Get a subwidget name (returns a String, not a Widget !)"""
|
|
try:
|
|
return self.tk.call(self._w, 'subwidget', name)
|
|
except TclError:
|
|
return None
|
|
|
|
def _subwidget_names(self):
|
|
"""Return the name of all subwidgets."""
|
|
try:
|
|
x = self.tk.call(self._w, 'subwidgets', '-all')
|
|
return self.tk.split(x)
|
|
except TclError:
|
|
return None
|
|
|
|
def config_all(self, option, value):
|
|
"""Set configuration options for all subwidgets (and self)."""
|
|
if option == '':
|
|
return
|
|
elif type(option) != type(''):
|
|
option = `option`
|
|
if type(value) != type(''):
|
|
value = `value`
|
|
names = self._subwidget_names()
|
|
for name in names:
|
|
self.tk.call(name, 'configure', '-' + option, value)
|
|
|
|
# Subwidgets are child widgets created automatically by mega-widgets.
|
|
# In python, we have to create these subwidgets manually to mirror their
|
|
# existence in Tk/Tix.
|
|
class TixSubWidget(TixWidget):
|
|
"""Subwidget class.
|
|
|
|
This is used to mirror child widgets automatically created
|
|
by Tix/Tk as part of a mega-widget in Python (which is not informed
|
|
of this)"""
|
|
|
|
def __init__(self, master, name,
|
|
destroy_physically=1, check_intermediate=1):
|
|
if check_intermediate:
|
|
path = master._subwidget_name(name)
|
|
try:
|
|
path = path[len(master._w)+1:]
|
|
plist = string.splitfields(path, '.')
|
|
except:
|
|
plist = []
|
|
|
|
if (not check_intermediate) or len(plist) < 2:
|
|
# immediate descendant
|
|
TixWidget.__init__(self, master, None, None, {'name' : name})
|
|
else:
|
|
# Ensure that the intermediate widgets exist
|
|
parent = master
|
|
for i in range(len(plist) - 1):
|
|
n = string.joinfields(plist[:i+1], '.')
|
|
try:
|
|
w = master._nametowidget(n)
|
|
parent = w
|
|
except KeyError:
|
|
# Create the intermediate widget
|
|
parent = TixSubWidget(parent, plist[i],
|
|
destroy_physically=0,
|
|
check_intermediate=0)
|
|
TixWidget.__init__(self, parent, None, None, {'name' : name})
|
|
self.destroy_physically = destroy_physically
|
|
|
|
def destroy(self):
|
|
# For some widgets e.g., a NoteBook, when we call destructors,
|
|
# we must be careful not to destroy the frame widget since this
|
|
# also destroys the parent NoteBook thus leading to an exception
|
|
# in Tkinter when it finally calls Tcl to destroy the NoteBook
|
|
for c in self.children.values(): c.destroy()
|
|
if self.master.children.has_key(self._name):
|
|
del self.master.children[self._name]
|
|
if self.master.subwidget_list.has_key(self._name):
|
|
del self.master.subwidget_list[self._name]
|
|
if self.destroy_physically:
|
|
# This is bypassed only for a few widgets
|
|
self.tk.call('destroy', self._w)
|
|
|
|
|
|
# Useful func. to split Tcl lists and return as a dict. From Tkinter.py
|
|
def _lst2dict(lst):
|
|
dict = {}
|
|
for x in lst:
|
|
dict[x[0][1:]] = (x[0][1:],) + x[1:]
|
|
return dict
|
|
|
|
# Useful class to create a display style - later shared by many items.
|
|
# Contributed by Steffen Kremser
|
|
class DisplayStyle:
|
|
"""DisplayStyle - handle configuration options shared by
|
|
(multiple) Display Items"""
|
|
|
|
def __init__(self, itemtype, cnf={}, **kw ):
|
|
master = _default_root # global from Tkinter
|
|
if not master and cnf.has_key('refwindow'): master=cnf['refwindow']
|
|
elif not master and kw.has_key('refwindow'): master= kw['refwindow']
|
|
elif not master: raise RuntimeError, "Too early to create display style: no root window"
|
|
self.tk = master.tk
|
|
self.stylename = apply(self.tk.call, ('tixDisplayStyle', itemtype) +
|
|
self._options(cnf,kw) )
|
|
|
|
def __str__(self):
|
|
return self.stylename
|
|
|
|
def _options(self, cnf, kw ):
|
|
if kw and cnf:
|
|
cnf = _cnfmerge((cnf, kw))
|
|
elif kw:
|
|
cnf = kw
|
|
opts = ()
|
|
for k, v in cnf.items():
|
|
opts = opts + ('-'+k, v)
|
|
return opts
|
|
|
|
def delete(self):
|
|
self.tk.call(self.stylename, 'delete')
|
|
del(self)
|
|
|
|
def __setitem__(self,key,value):
|
|
self.tk.call(self.stylename, 'configure', '-%s'%key, value)
|
|
|
|
def config(self, cnf={}, **kw):
|
|
return _lst2dict(
|
|
self.tk.split(
|
|
apply(self.tk.call,
|
|
(self.stylename, 'configure') + self._options(cnf,kw))))
|
|
|
|
def __getitem__(self,key):
|
|
return self.tk.call(self.stylename, 'cget', '-%s'%key)
|
|
|
|
|
|
######################################################
|
|
### The Tix Widget classes - in alphabetical order ###
|
|
######################################################
|
|
|
|
class Balloon(TixWidget):
|
|
"""Balloon help widget.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
label Label
|
|
message Message"""
|
|
|
|
def __init__(self, master=None, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixBalloon', ['options'], cnf, kw)
|
|
self.subwidget_list['label'] = _dummyLabel(self, 'label',
|
|
destroy_physically=0)
|
|
self.subwidget_list['message'] = _dummyLabel(self, 'message',
|
|
destroy_physically=0)
|
|
|
|
def bind_widget(self, widget, cnf={}, **kw):
|
|
"""Bind balloon widget to another.
|
|
One balloon widget may be bound to several widgets at the same time"""
|
|
apply(self.tk.call,
|
|
(self._w, 'bind', widget._w) + self._options(cnf, kw))
|
|
|
|
def unbind_widget(self, widget):
|
|
self.tk.call(self._w, 'unbind', widget._w)
|
|
|
|
class ButtonBox(TixWidget):
|
|
"""ButtonBox - A container for pushbuttons.
|
|
Subwidgets are the buttons added with the add method.
|
|
"""
|
|
def __init__(self, master=None, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixButtonBox',
|
|
['orientation', 'options'], cnf, kw)
|
|
|
|
def add(self, name, cnf={}, **kw):
|
|
"""Add a button with given name to box."""
|
|
|
|
btn = apply(self.tk.call,
|
|
(self._w, 'add', name) + self._options(cnf, kw))
|
|
self.subwidget_list[name] = _dummyButton(self, name)
|
|
return btn
|
|
|
|
def invoke(self, name):
|
|
if self.subwidget_list.has_key(name):
|
|
self.tk.call(self._w, 'invoke', name)
|
|
|
|
class ComboBox(TixWidget):
|
|
"""ComboBox - an Entry field with a dropdown menu. The user can select a
|
|
choice by either typing in the entry subwdget or selecting from the
|
|
listbox subwidget.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
entry Entry
|
|
arrow Button
|
|
slistbox ScrolledListBox
|
|
tick Button
|
|
cross Button : present if created with the fancy option"""
|
|
|
|
def __init__ (self, master=None, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixComboBox',
|
|
['editable', 'dropdown', 'fancy', 'options'],
|
|
cnf, kw)
|
|
self.subwidget_list['label'] = _dummyLabel(self, 'label')
|
|
self.subwidget_list['entry'] = _dummyEntry(self, 'entry')
|
|
self.subwidget_list['arrow'] = _dummyButton(self, 'arrow')
|
|
self.subwidget_list['slistbox'] = _dummyScrolledListBox(self,
|
|
'slistbox')
|
|
try:
|
|
self.subwidget_list['tick'] = _dummyButton(self, 'tick')
|
|
self.subwidget_list['cross'] = _dummyButton(self, 'cross')
|
|
except TypeError:
|
|
# unavailable when -fancy not specified
|
|
pass
|
|
|
|
def add_history(self, str):
|
|
self.tk.call(self._w, 'addhistory', str)
|
|
|
|
def append_history(self, str):
|
|
self.tk.call(self._w, 'appendhistory', str)
|
|
|
|
def insert(self, index, str):
|
|
self.tk.call(self._w, 'insert', index, str)
|
|
|
|
def pick(self, index):
|
|
self.tk.call(self._w, 'pick', index)
|
|
|
|
class Control(TixWidget):
|
|
"""Control - An entry field with value change arrows. The user can
|
|
adjust the value by pressing the two arrow buttons or by entering
|
|
the value directly into the entry. The new value will be checked
|
|
against the user-defined upper and lower limits.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
incr Button
|
|
decr Button
|
|
entry Entry
|
|
label Label"""
|
|
|
|
def __init__ (self, master=None, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixControl', ['options'], cnf, kw)
|
|
self.subwidget_list['incr'] = _dummyButton(self, 'incr')
|
|
self.subwidget_list['decr'] = _dummyButton(self, 'decr')
|
|
self.subwidget_list['label'] = _dummyLabel(self, 'label')
|
|
self.subwidget_list['entry'] = _dummyEntry(self, 'entry')
|
|
|
|
def decrement(self):
|
|
self.tk.call(self._w, 'decr')
|
|
|
|
def increment(self):
|
|
self.tk.call(self._w, 'incr')
|
|
|
|
def invoke(self):
|
|
self.tk.call(self._w, 'invoke')
|
|
|
|
def update(self):
|
|
self.tk.call(self._w, 'update')
|
|
|
|
class DirList(TixWidget):
|
|
"""DirList - displays a list view of a directory, its previous
|
|
directories and its sub-directories. The user can choose one of
|
|
the directories displayed in the list or change to another directory.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
hlist HList
|
|
hsb Scrollbar
|
|
vsb Scrollbar"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixDirList', ['options'], cnf, kw)
|
|
self.subwidget_list['hlist'] = _dummyHList(self, 'hlist')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
def chdir(self, dir):
|
|
self.tk.call(self._w, 'chdir', dir)
|
|
|
|
class DirTree(TixWidget):
|
|
"""DirTree - Directory Listing in a hierarchical view.
|
|
Displays a tree view of a directory, its previous directories and its
|
|
sub-directories. The user can choose one of the directories displayed
|
|
in the list or change to another directory.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
hlist HList
|
|
hsb Scrollbar
|
|
vsb Scrollbar"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixDirTree', ['options'], cnf, kw)
|
|
self.subwidget_list['hlist'] = _dummyHList(self, 'hlist')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
def chdir(self, dir):
|
|
self.tk.call(self._w, 'chdir', dir)
|
|
|
|
class DirSelectBox(TixWidget):
|
|
"""DirSelectBox - Motif style file select box.
|
|
It is generally used for
|
|
the user to choose a file. FileSelectBox stores the files mostly
|
|
recently selected into a ComboBox widget so that they can be quickly
|
|
selected again.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
selection ComboBox
|
|
filter ComboBox
|
|
dirlist ScrolledListBox
|
|
filelist ScrolledListBox"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixDirSelectBox', ['options'], cnf, kw)
|
|
self.subwidget_list['dirlist'] = _dummyDirList(self, 'dirlist')
|
|
self.subwidget_list['dircbx'] = _dummyFileComboBox(self, 'dircbx')
|
|
|
|
class ExFileSelectBox(TixWidget):
|
|
"""ExFileSelectBox - MS Windows style file select box.
|
|
It provides an convenient method for the user to select files.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
cancel Button
|
|
ok Button
|
|
hidden Checkbutton
|
|
types ComboBox
|
|
dir ComboBox
|
|
file ComboBox
|
|
dirlist ScrolledListBox
|
|
filelist ScrolledListBox"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixExFileSelectBox', ['options'], cnf, kw)
|
|
self.subwidget_list['cancel'] = _dummyButton(self, 'cancel')
|
|
self.subwidget_list['ok'] = _dummyButton(self, 'ok')
|
|
self.subwidget_list['hidden'] = _dummyCheckbutton(self, 'hidden')
|
|
self.subwidget_list['types'] = _dummyComboBox(self, 'types')
|
|
self.subwidget_list['dir'] = _dummyComboBox(self, 'dir')
|
|
self.subwidget_list['dirlist'] = _dummyDirList(self, 'dirlist')
|
|
self.subwidget_list['file'] = _dummyComboBox(self, 'file')
|
|
self.subwidget_list['filelist'] = _dummyScrolledListBox(self, 'filelist')
|
|
|
|
def filter(self):
|
|
self.tk.call(self._w, 'filter')
|
|
|
|
def invoke(self):
|
|
self.tk.call(self._w, 'invoke')
|
|
|
|
|
|
# Should inherit from a Dialog class
|
|
class DirSelectDialog(TixWidget):
|
|
"""The DirSelectDialog widget presents the directories in the file
|
|
system in a dialog window. The user can use this dialog window to
|
|
navigate through the file system to select the desired directory.
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
dirbox DirSelectDialog"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixDirSelectDialog',
|
|
['options'], cnf, kw)
|
|
self.subwidget_list['dirbox'] = _dummyDirSelectBox(self, 'dirbox')
|
|
# cancel and ok buttons are missing
|
|
|
|
def popup(self):
|
|
self.tk.call(self._w, 'popup')
|
|
|
|
def popdown(self):
|
|
self.tk.call(self._w, 'popdown')
|
|
|
|
|
|
# Should inherit from a Dialog class
|
|
class ExFileSelectDialog(TixWidget):
|
|
"""ExFileSelectDialog - MS Windows style file select dialog.
|
|
It provides an convenient method for the user to select files.
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
fsbox ExFileSelectBox"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixExFileSelectDialog',
|
|
['options'], cnf, kw)
|
|
self.subwidget_list['fsbox'] = _dummyExFileSelectBox(self, 'fsbox')
|
|
|
|
def popup(self):
|
|
self.tk.call(self._w, 'popup')
|
|
|
|
def popdown(self):
|
|
self.tk.call(self._w, 'popdown')
|
|
|
|
class FileSelectBox(TixWidget):
|
|
"""ExFileSelectBox - Motif style file select box.
|
|
It is generally used for
|
|
the user to choose a file. FileSelectBox stores the files mostly
|
|
recently selected into a ComboBox widget so that they can be quickly
|
|
selected again.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
selection ComboBox
|
|
filter ComboBox
|
|
dirlist ScrolledListBox
|
|
filelist ScrolledListBox"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixFileSelectBox', ['options'], cnf, kw)
|
|
self.subwidget_list['dirlist'] = _dummyScrolledListBox(self, 'dirlist')
|
|
self.subwidget_list['filelist'] = _dummyScrolledListBox(self, 'filelist')
|
|
self.subwidget_list['filter'] = _dummyComboBox(self, 'filter')
|
|
self.subwidget_list['selection'] = _dummyComboBox(self, 'selection')
|
|
|
|
def apply_filter(self): # name of subwidget is same as command
|
|
self.tk.call(self._w, 'filter')
|
|
|
|
def invoke(self):
|
|
self.tk.call(self._w, 'invoke')
|
|
|
|
# Should inherit from a Dialog class
|
|
class FileSelectDialog(TixWidget):
|
|
"""FileSelectDialog - Motif style file select dialog.
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
btns StdButtonBox
|
|
fsbox FileSelectBox"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixFileSelectDialog',
|
|
['options'], cnf, kw)
|
|
self.subwidget_list['btns'] = _dummyStdButtonBox(self, 'btns')
|
|
self.subwidget_list['fsbox'] = _dummyFileSelectBox(self, 'fsbox')
|
|
|
|
def popup(self):
|
|
self.tk.call(self._w, 'popup')
|
|
|
|
def popdown(self):
|
|
self.tk.call(self._w, 'popdown')
|
|
|
|
class FileEntry(TixWidget):
|
|
"""FileEntry - Entry field with button that invokes a FileSelectDialog.
|
|
The user can type in the filename manually. Alternatively, the user can
|
|
press the button widget that sits next to the entry, which will bring
|
|
up a file selection dialog.
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
button Button
|
|
entry Entry"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixFileEntry',
|
|
['dialogtype', 'options'], cnf, kw)
|
|
self.subwidget_list['button'] = _dummyButton(self, 'button')
|
|
self.subwidget_list['entry'] = _dummyEntry(self, 'entry')
|
|
|
|
def invoke(self):
|
|
self.tk.call(self._w, 'invoke')
|
|
|
|
def file_dialog(self):
|
|
# XXX return python object
|
|
pass
|
|
|
|
class HList(TixWidget):
|
|
"""HList - Hierarchy display widget can be used to display any data
|
|
that have a hierarchical structure, for example, file system directory
|
|
trees. The list entries are indented and connected by branch lines
|
|
according to their places in the hierachy.
|
|
|
|
Subwidgets - None"""
|
|
|
|
def __init__ (self,master=None,cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixHList',
|
|
['columns', 'options'], cnf, kw)
|
|
|
|
def add(self, entry, cnf={}, **kw):
|
|
return apply(self.tk.call,
|
|
(self._w, 'add', entry) + self._options(cnf, kw))
|
|
|
|
def add_child(self, parent=None, cnf={}, **kw):
|
|
if not parent:
|
|
parent = ''
|
|
return apply(self.tk.call,
|
|
(self._w, 'addchild', parent) + self._options(cnf, kw))
|
|
|
|
def anchor_set(self, entry):
|
|
self.tk.call(self._w, 'anchor', 'set', entry)
|
|
|
|
def anchor_clear(self):
|
|
self.tk.call(self._w, 'anchor', 'clear')
|
|
|
|
def column_width(self, col=0, width=None, chars=None):
|
|
if not chars:
|
|
return self.tk.call(self._w, 'column', 'width', col, width)
|
|
else:
|
|
return self.tk.call(self._w, 'column', 'width', col,
|
|
'-char', chars)
|
|
|
|
def delete_all(self):
|
|
self.tk.call(self._w, 'delete', 'all')
|
|
|
|
def delete_entry(self, entry):
|
|
self.tk.call(self._w, 'delete', 'entry', entry)
|
|
|
|
def delete_offsprings(self, entry):
|
|
self.tk.call(self._w, 'delete', 'offsprings', entry)
|
|
|
|
def delete_siblings(self, entry):
|
|
self.tk.call(self._w, 'delete', 'siblings', entry)
|
|
|
|
def dragsite_set(self, index):
|
|
self.tk.call(self._w, 'dragsite', 'set', index)
|
|
|
|
def dragsite_clear(self):
|
|
self.tk.call(self._w, 'dragsite', 'clear')
|
|
|
|
def dropsite_set(self, index):
|
|
self.tk.call(self._w, 'dropsite', 'set', index)
|
|
|
|
def dropsite_clear(self):
|
|
self.tk.call(self._w, 'dropsite', 'clear')
|
|
|
|
def header_create(self, col, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'header', 'create', col) + self._options(cnf, kw))
|
|
|
|
def header_configure(self, col, cnf={}, **kw):
|
|
if cnf is None:
|
|
return _lst2dict(
|
|
self.tk.split(
|
|
self.tk.call(self._w, 'header', 'configure', col)))
|
|
apply(self.tk.call, (self._w, 'header', 'configure', col)
|
|
+ self._options(cnf, kw))
|
|
|
|
def header_cget(self, col, opt):
|
|
return self.tk.call(self._w, 'header', 'cget', col, opt)
|
|
|
|
def header_exists(self, col):
|
|
return self.tk.call(self._w, 'header', 'exists', col)
|
|
|
|
def header_delete(self, col):
|
|
self.tk.call(self._w, 'header', 'delete', col)
|
|
|
|
def header_size(self, col):
|
|
return self.tk.call(self._w, 'header', 'size', col)
|
|
|
|
def hide_entry(self, entry):
|
|
self.tk.call(self._w, 'hide', 'entry', entry)
|
|
|
|
def indicator_create(self, entry, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'indicator', 'create', entry) + self._options(cnf, kw))
|
|
|
|
def indicator_configure(self, entry, cnf={}, **kw):
|
|
if cnf is None:
|
|
return _lst2dict(
|
|
self.tk.split(
|
|
self.tk.call(self._w, 'indicator', 'configure', entry)))
|
|
apply(self.tk.call,
|
|
(self._w, 'indicator', 'configure', entry) + self._options(cnf, kw))
|
|
|
|
def indicator_cget(self, entry, opt):
|
|
return self.tk.call(self._w, 'indicator', 'cget', entry, opt)
|
|
|
|
def indicator_exists(self, entry):
|
|
return self.tk.call (self._w, 'indicator', 'exists', entry)
|
|
|
|
def indicator_delete(self, entry):
|
|
self.tk.call(self._w, 'indicator', 'delete', entry)
|
|
|
|
def indicator_size(self, entry):
|
|
return self.tk.call(self._w, 'indicator', 'size', entry)
|
|
|
|
def info_anchor(self):
|
|
return self.tk.call(self._w, 'info', 'anchor')
|
|
|
|
def info_children(self, entry=None):
|
|
c = self.tk.call(self._w, 'info', 'children', entry)
|
|
return self.tk.splitlist(c)
|
|
|
|
def info_data(self, entry):
|
|
return self.tk.call(self._w, 'info', 'data', entry)
|
|
|
|
def info_exists(self, entry):
|
|
return self.tk.call(self._w, 'info', 'exists', entry)
|
|
|
|
def info_hidden(self, entry):
|
|
return self.tk.call(self._w, 'info', 'hidden', entry)
|
|
|
|
def info_next(self, entry):
|
|
return self.tk.call(self._w, 'info', 'next', entry)
|
|
|
|
def info_parent(self, entry):
|
|
return self.tk.call(self._w, 'info', 'parent', entry)
|
|
|
|
def info_prev(self, entry):
|
|
return self.tk.call(self._w, 'info', 'prev', entry)
|
|
|
|
def info_selection(self):
|
|
c = self.tk.call(self._w, 'info', 'selection')
|
|
return self.tk.splitlist(c)
|
|
|
|
def item_cget(self, entry, col, opt):
|
|
return self.tk.call(self._w, 'item', 'cget', entry, col, opt)
|
|
|
|
def item_configure(self, entry, col, cnf={}, **kw):
|
|
if cnf is None:
|
|
return _lst2dict(
|
|
self.tk.split(
|
|
self.tk.call(self._w, 'item', 'configure', entry, col)))
|
|
apply(self.tk.call, (self._w, 'item', 'configure', entry, col) +
|
|
self._options(cnf, kw))
|
|
|
|
def item_create(self, entry, col, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'item', 'create', entry, col) + self._options(cnf, kw))
|
|
|
|
def item_exists(self, entry, col):
|
|
return self.tk.call(self._w, 'item', 'exists', entry, col)
|
|
|
|
def item_delete(self, entry, col):
|
|
self.tk.call(self._w, 'item', 'delete', entry, col)
|
|
|
|
def nearest(self, y):
|
|
return self.tk.call(self._w, 'nearest', y)
|
|
|
|
def see(self, entry):
|
|
self.tk.call(self._w, 'see', entry)
|
|
|
|
def selection_clear(self, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'selection', 'clear') + self._options(cnf, kw))
|
|
|
|
def selection_includes(self, entry):
|
|
return self.tk.call(self._w, 'selection', 'includes', entry)
|
|
|
|
def selection_set(self, first, last=None):
|
|
self.tk.call(self._w, 'selection', 'set', first, last)
|
|
|
|
def show_entry(self, entry):
|
|
return self.tk.call(self._w, 'show', 'entry', entry)
|
|
|
|
def xview(self, *args):
|
|
apply(self.tk.call, (self._w, 'xview') + args)
|
|
|
|
def yview(self, *args):
|
|
apply(self.tk.call, (self._w, 'yview') + args)
|
|
|
|
class InputOnly(TixWidget):
|
|
"""InputOnly - Invisible widget.
|
|
|
|
Subwidgets - None"""
|
|
|
|
def __init__ (self,master=None,cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixInputOnly', None, cnf, kw)
|
|
|
|
class LabelEntry(TixWidget):
|
|
"""LabelEntry - Entry field with label. Packages an entry widget
|
|
and a label into one mega widget. It can beused be used to simplify
|
|
the creation of ``entry-form'' type of interface.
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
label Label
|
|
entry Entry"""
|
|
|
|
def __init__ (self,master=None,cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixLabelEntry',
|
|
['labelside','options'], cnf, kw)
|
|
self.subwidget_list['label'] = _dummyLabel(self, 'label')
|
|
self.subwidget_list['entry'] = _dummyEntry(self, 'entry')
|
|
|
|
class LabelFrame(TixWidget):
|
|
"""LabelFrame - Labelled Frame container. Packages a frame widget
|
|
and a label into one mega widget. To create widgets inside a
|
|
LabelFrame widget, one creates the new widgets relative to the
|
|
frame subwidget and manage them inside the frame subwidget.
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
label Label
|
|
frame Frame"""
|
|
|
|
def __init__ (self,master=None,cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixLabelFrame',
|
|
['labelside','options'], cnf, kw)
|
|
self.subwidget_list['label'] = _dummyLabel(self, 'label')
|
|
self.subwidget_list['frame'] = _dummyFrame(self, 'frame')
|
|
|
|
|
|
class ListNoteBook(TixWidget):
|
|
"""A ListNoteBook widget is very similar to the TixNoteBook widget:
|
|
it can be used to display many windows in a limited space using a
|
|
notebook metaphor. The notebook is divided into a stack of pages
|
|
(windows). At one time only one of these pages can be shown.
|
|
The user can navigate through these pages by
|
|
choosing the name of the desired page in the hlist subwidget."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixDirList', ['options'], cnf, kw)
|
|
self.subwidget_list['hlist'] = _dummyHList(self, 'hlist')
|
|
self.subwidget_list['shlist'] = _dummyScrolledHList(self, 'vsb')
|
|
|
|
|
|
def add(self, name, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'add', name) + self._options(cnf, kw))
|
|
self.subwidget_list[name] = TixSubWidget(self, name)
|
|
return self.subwidget_list[name]
|
|
|
|
def raise_page(self, name): # raise is a python keyword
|
|
self.tk.call(self._w, 'raise', name)
|
|
|
|
class Meter(TixWidget):
|
|
"""The Meter widget can be used to show the progress of a background
|
|
job which may take a long time to execute.
|
|
"""
|
|
|
|
def __init__(self, master=None, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixMeter',
|
|
['options'], cnf, kw)
|
|
|
|
class NoteBook(TixWidget):
|
|
"""NoteBook - Multi-page container widget (tabbed notebook metaphor).
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
nbframe NoteBookFrame
|
|
<pages> page widgets added dynamically with the add method"""
|
|
|
|
def __init__ (self,master=None,cnf={}, **kw):
|
|
TixWidget.__init__(self,master,'tixNoteBook', ['options'], cnf, kw)
|
|
self.subwidget_list['nbframe'] = TixSubWidget(self, 'nbframe',
|
|
destroy_physically=0)
|
|
|
|
def add(self, name, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'add', name) + self._options(cnf, kw))
|
|
self.subwidget_list[name] = TixSubWidget(self, name)
|
|
return self.subwidget_list[name]
|
|
|
|
def delete(self, name):
|
|
self.tk.call(self._w, 'delete', name)
|
|
|
|
def page(self, name):
|
|
return self.subwidget(name)
|
|
|
|
def pages(self):
|
|
# Can't call subwidgets_all directly because we don't want .nbframe
|
|
names = self.tk.split(self.tk.call(self._w, 'pages'))
|
|
ret = []
|
|
for x in names:
|
|
ret.append(self.subwidget(x))
|
|
return ret
|
|
|
|
def raise_page(self, name): # raise is a python keyword
|
|
self.tk.call(self._w, 'raise', name)
|
|
|
|
def raised(self):
|
|
return self.tk.call(self._w, 'raised')
|
|
|
|
class NoteBookFrame(TixWidget):
|
|
"""Will be added when Tix documentation is available !!!"""
|
|
pass
|
|
|
|
class OptionMenu(TixWidget):
|
|
"""OptionMenu - creates a menu button of options.
|
|
|
|
Subwidget Class
|
|
--------- -----
|
|
menubutton Menubutton
|
|
menu Menu"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixOptionMenu', ['options'], cnf, kw)
|
|
self.subwidget_list['menubutton'] = _dummyMenubutton(self, 'menubutton')
|
|
self.subwidget_list['menu'] = _dummyMenu(self, 'menu')
|
|
|
|
def add_command(self, name, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'add', 'command', name) + self._options(cnf, kw))
|
|
|
|
def add_separator(self, name, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'add', 'separator', name) + self._options(cnf, kw))
|
|
|
|
def delete(self, name):
|
|
self.tk.call(self._w, 'delete', name)
|
|
|
|
def disable(self, name):
|
|
self.tk.call(self._w, 'disable', name)
|
|
|
|
def enable(self, name):
|
|
self.tk.call(self._w, 'enable', name)
|
|
|
|
class PanedWindow(TixWidget):
|
|
"""PanedWindow - Multi-pane container widget
|
|
allows the user to interactively manipulate the sizes of several
|
|
panes. The panes can be arranged either vertically or horizontally.The
|
|
user changes the sizes of the panes by dragging the resize handle
|
|
between two panes.
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
<panes> g/p widgets added dynamically with the add method."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixPanedWindow', ['orientation', 'options'], cnf, kw)
|
|
|
|
def add(self, name, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'add', name) + self._options(cnf, kw))
|
|
self.subwidget_list[name] = TixSubWidget(self, name,
|
|
check_intermediate=0)
|
|
return self.subwidget_list[name]
|
|
|
|
def panes(self):
|
|
names = self.tk.call(self._w, 'panes')
|
|
ret = []
|
|
for x in names:
|
|
ret.append(self.subwidget(x))
|
|
return ret
|
|
|
|
class PopupMenu(TixWidget):
|
|
"""PopupMenu widget can be used as a replacement of the tk_popup command.
|
|
The advantage of the Tix PopupMenu widget is it requires less application
|
|
code to manipulate.
|
|
|
|
|
|
Subwidgets Class
|
|
---------- -----
|
|
menubutton Menubutton
|
|
menu Menu"""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixPopupMenu', ['options'], cnf, kw)
|
|
self.subwidget_list['menubutton'] = _dummyMenubutton(self, 'menubutton')
|
|
self.subwidget_list['menu'] = _dummyMenu(self, 'menu')
|
|
|
|
def bind_widget(self, widget):
|
|
self.tk.call(self._w, 'bind', widget._w)
|
|
|
|
def unbind_widget(self, widget):
|
|
self.tk.call(self._w, 'unbind', widget._w)
|
|
|
|
def post_widget(self, widget, x, y):
|
|
self.tk.call(self._w, 'post', widget._w, x, y)
|
|
|
|
class ResizeHandle(TixWidget):
|
|
"""Internal widget to draw resize handles on Scrolled widgets."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixResizeHandle',
|
|
['options'], cnf, kw)
|
|
|
|
def attach_widget(self, widget):
|
|
self.tk.call(self._w, 'attachwidget', widget._w)
|
|
|
|
class ScrolledHList(TixWidget):
|
|
"""ScrolledHList - HList with automatic scrollbars."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixScrolledHList', ['options'],
|
|
cnf, kw)
|
|
self.subwidget_list['hlist'] = _dummyHList(self, 'hlist')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
class ScrolledListBox(TixWidget):
|
|
"""ScrolledListBox - Listbox with automatic scrollbars."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixScrolledListBox', ['options'], cnf, kw)
|
|
self.subwidget_list['listbox'] = _dummyListbox(self, 'listbox')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
class ScrolledText(TixWidget):
|
|
"""ScrolledText - Text with automatic scrollbars."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixScrolledText', ['options'], cnf, kw)
|
|
self.subwidget_list['text'] = _dummyText(self, 'text')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
class ScrolledTList(TixWidget):
|
|
"""ScrolledTList - TList with automatic scrollbars."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixScrolledTList', ['options'],
|
|
cnf, kw)
|
|
self.subwidget_list['tlist'] = _dummyTList(self, 'tlist')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
class ScrolledWindow(TixWidget):
|
|
"""ScrolledWindow - Window with automatic scrollbars."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixScrolledWindow', ['options'], cnf, kw)
|
|
self.subwidget_list['window'] = _dummyFrame(self, 'window')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
class Select(TixWidget):
|
|
"""Select - Container of button subwidgets. It can be used to provide
|
|
radio-box or check-box style of selection options for the user.
|
|
|
|
Subwidgets are buttons added dynamically using the add method."""
|
|
|
|
def __init__(self, master, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixSelect',
|
|
['allowzero', 'radio', 'orientation', 'labelside',
|
|
'options'],
|
|
cnf, kw)
|
|
self.subwidget_list['label'] = _dummyLabel(self, 'label')
|
|
|
|
def add(self, name, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'add', name) + self._options(cnf, kw))
|
|
self.subwidget_list[name] = _dummyButton(self, name)
|
|
return self.subwidget_list[name]
|
|
|
|
def invoke(self, name):
|
|
self.tk.call(self._w, 'invoke', name)
|
|
|
|
class StdButtonBox(TixWidget):
|
|
"""StdButtonBox - Standard Button Box (OK, Apply, Cancel and Help) """
|
|
|
|
def __init__(self, master=None, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixStdButtonBox',
|
|
['orientation', 'options'], cnf, kw)
|
|
self.subwidget_list['ok'] = _dummyButton(self, 'ok')
|
|
self.subwidget_list['apply'] = _dummyButton(self, 'apply')
|
|
self.subwidget_list['cancel'] = _dummyButton(self, 'cancel')
|
|
self.subwidget_list['help'] = _dummyButton(self, 'help')
|
|
|
|
def invoke(self, name):
|
|
if self.subwidget_list.has_key(name):
|
|
self.tk.call(self._w, 'invoke', name)
|
|
|
|
class TList(TixWidget):
|
|
"""TList - Hierarchy display widget which can be
|
|
used to display data in a tabular format. The list entries of a TList
|
|
widget are similar to the entries in the Tk listbox widget. The main
|
|
differences are (1) the TList widget can display the list entries in a
|
|
two dimensional format and (2) you can use graphical images as well as
|
|
multiple colors and fonts for the list entries.
|
|
|
|
Subwidgets - None"""
|
|
|
|
def __init__ (self,master=None,cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixTList', ['options'], cnf, kw)
|
|
|
|
def active_set(self, index):
|
|
self.tk.call(self._w, 'active', 'set', index)
|
|
|
|
def active_clear(self):
|
|
self.tk.call(self._w, 'active', 'clear')
|
|
|
|
def anchor_set(self, index):
|
|
self.tk.call(self._w, 'anchor', 'set', index)
|
|
|
|
def anchor_clear(self):
|
|
self.tk.call(self._w, 'anchor', 'clear')
|
|
|
|
def delete(self, from_, to=None):
|
|
self.tk.call(self._w, 'delete', from_, to)
|
|
|
|
def dragsite_set(self, index):
|
|
self.tk.call(self._w, 'dragsite', 'set', index)
|
|
|
|
def dragsite_clear(self):
|
|
self.tk.call(self._w, 'dragsite', 'clear')
|
|
|
|
def dropsite_set(self, index):
|
|
self.tk.call(self._w, 'dropsite', 'set', index)
|
|
|
|
def dropsite_clear(self):
|
|
self.tk.call(self._w, 'dropsite', 'clear')
|
|
|
|
def insert(self, index, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'insert', index) + self._options(cnf, kw))
|
|
|
|
def info_active(self):
|
|
return self.tk.call(self._w, 'info', 'active')
|
|
|
|
def info_anchor(self):
|
|
return self.tk.call(self._w, 'info', 'anchor')
|
|
|
|
def info_down(self, index):
|
|
return self.tk.call(self._w, 'info', 'down', index)
|
|
|
|
def info_left(self, index):
|
|
return self.tk.call(self._w, 'info', 'left', index)
|
|
|
|
def info_right(self, index):
|
|
return self.tk.call(self._w, 'info', 'right', index)
|
|
|
|
def info_selection(self):
|
|
c = self.tk.call(self._w, 'info', 'selection')
|
|
return self.tk.splitlist(c)
|
|
|
|
def info_size(self):
|
|
return self.tk.call(self._w, 'info', 'size')
|
|
|
|
def info_up(self, index):
|
|
return self.tk.call(self._w, 'info', 'up', index)
|
|
|
|
def nearest(self, x, y):
|
|
return self.tk.call(self._w, 'nearest', x, y)
|
|
|
|
def see(self, index):
|
|
self.tk.call(self._w, 'see', index)
|
|
|
|
def selection_clear(self, cnf={}, **kw):
|
|
apply(self.tk.call,
|
|
(self._w, 'selection', 'clear') + self._options(cnf, kw))
|
|
|
|
def selection_includes(self, index):
|
|
return self.tk.call(self._w, 'selection', 'includes', index)
|
|
|
|
def selection_set(self, first, last=None):
|
|
self.tk.call(self._w, 'selection', 'set', first, last)
|
|
|
|
def xview(self, *args):
|
|
apply(self.tk.call, (self._w, 'xview') + args)
|
|
|
|
def yview(self, *args):
|
|
apply(self.tk.call, (self._w, 'yview') + args)
|
|
|
|
class Tree(TixWidget):
|
|
"""Tree - The tixTree widget can be used to display hierachical
|
|
data in a tree form. The user can adjust
|
|
the view of the tree by opening or closing parts of the tree."""
|
|
|
|
def __init__(self, master=None, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixTree',
|
|
['options'], cnf, kw)
|
|
self.subwidget_list['hlist'] = _dummyHList(self, 'hlist')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
def autosetmode(self):
|
|
self.tk.call(self._w, 'autosetmode')
|
|
|
|
def close(self, entrypath):
|
|
self.tk.call(self._w, 'close', entrypath)
|
|
|
|
def getmode(self, entrypath):
|
|
return self.tk.call(self._w, 'getmode', entrypath)
|
|
|
|
def open(self, entrypath):
|
|
self.tk.call(self._w, 'open', entrypath)
|
|
|
|
def setmode(self, entrypath, mode='none'):
|
|
self.tk.call(self._w, 'setmode', entrypath, mode)
|
|
|
|
|
|
# Could try subclassing Tree for CheckList - would need another arg to init
|
|
class CheckList(TixWidget):
|
|
"""The CheckList widget
|
|
displays a list of items to be selected by the user. CheckList acts
|
|
similarly to the Tk checkbutton or radiobutton widgets, except it is
|
|
capable of handling many more items than checkbuttons or radiobuttons.
|
|
"""
|
|
|
|
def __init__(self, master=None, cnf={}, **kw):
|
|
TixWidget.__init__(self, master, 'tixCheckList',
|
|
['options'], cnf, kw)
|
|
self.subwidget_list['hlist'] = _dummyHList(self, 'hlist')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
def autosetmode(self):
|
|
self.tk.call(self._w, 'autosetmode')
|
|
|
|
def close(self, entrypath):
|
|
self.tk.call(self._w, 'close', entrypath)
|
|
|
|
def getmode(self, entrypath):
|
|
return self.tk.call(self._w, 'getmode', entrypath)
|
|
|
|
def open(self, entrypath):
|
|
self.tk.call(self._w, 'open', entrypath)
|
|
|
|
def getselection(self, mode='on'):
|
|
'''Mode can be on, off, default'''
|
|
self.tk.call(self._w, 'getselection', mode)
|
|
|
|
def getstatus(self, entrypath):
|
|
self.tk.call(self._w, 'getstatus', entrypath)
|
|
|
|
def setstatus(self, entrypath, mode='on'):
|
|
self.tk.call(self._w, 'setstatus', entrypath, mode)
|
|
|
|
|
|
###########################################################################
|
|
### The subclassing below is used to instantiate the subwidgets in each ###
|
|
### mega widget. This allows us to access their methods directly. ###
|
|
###########################################################################
|
|
|
|
class _dummyButton(Button, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyCheckbutton(Checkbutton, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyEntry(Entry, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyFrame(Frame, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyLabel(Label, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyListbox(Listbox, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyMenu(Menu, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyMenubutton(Menubutton, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyScrollbar(Scrollbar, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyText(Text, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyScrolledListBox(ScrolledListBox, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['listbox'] = _dummyListbox(self, 'listbox')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
class _dummyHList(HList, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyScrolledHList(ScrolledHList, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['hlist'] = _dummyHList(self, 'hlist')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
class _dummyTList(TList, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
class _dummyComboBox(ComboBox, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['entry'] = _dummyEntry(self, 'entry')
|
|
self.subwidget_list['arrow'] = _dummyButton(self, 'arrow')
|
|
# I'm not sure about this destroy_physically=0 in all cases;
|
|
# it may depend on if -dropdown is true; I've added as a trial
|
|
self.subwidget_list['slistbox'] = _dummyScrolledListBox(self,
|
|
'slistbox',
|
|
destroy_physically=0)
|
|
self.subwidget_list['listbox'] = _dummyListbox(self, 'listbox',
|
|
destroy_physically=0)
|
|
|
|
class _dummyDirList(DirList, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['hlist'] = _dummyHList(self, 'hlist')
|
|
self.subwidget_list['vsb'] = _dummyScrollbar(self, 'vsb')
|
|
self.subwidget_list['hsb'] = _dummyScrollbar(self, 'hsb')
|
|
|
|
class _dummyDirSelectBox(DirSelectBox, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['dirlist'] = _dummyDirList(self, 'dirlist')
|
|
self.subwidget_list['dircbx'] = _dummyFileComboBox(self, 'dircbx')
|
|
|
|
class _dummyExFileSelectBox(ExFileSelectBox, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['cancel'] = _dummyButton(self, 'cancel')
|
|
self.subwidget_list['ok'] = _dummyButton(self, 'ok')
|
|
self.subwidget_list['hidden'] = _dummyCheckbutton(self, 'hidden')
|
|
self.subwidget_list['types'] = _dummyComboBox(self, 'types')
|
|
self.subwidget_list['dir'] = _dummyComboBox(self, 'dir')
|
|
self.subwidget_list['dirlist'] = _dummyScrolledListBox(self, 'dirlist')
|
|
self.subwidget_list['file'] = _dummyComboBox(self, 'file')
|
|
self.subwidget_list['filelist'] = _dummyScrolledListBox(self, 'filelist')
|
|
|
|
class _dummyFileSelectBox(FileSelectBox, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['dirlist'] = _dummyScrolledListBox(self, 'dirlist')
|
|
self.subwidget_list['filelist'] = _dummyScrolledListBox(self, 'filelist')
|
|
self.subwidget_list['filter'] = _dummyComboBox(self, 'filter')
|
|
self.subwidget_list['selection'] = _dummyComboBox(self, 'selection')
|
|
|
|
class _dummyFileComboBox(ComboBox, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['dircbx'] = _dummyComboBox(self, 'dircbx')
|
|
|
|
class _dummyStdButtonBox(StdButtonBox, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=1):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
self.subwidget_list['ok'] = _dummyButton(self, 'ok')
|
|
self.subwidget_list['apply'] = _dummyButton(self, 'apply')
|
|
self.subwidget_list['cancel'] = _dummyButton(self, 'cancel')
|
|
self.subwidget_list['help'] = _dummyButton(self, 'help')
|
|
|
|
class _dummyNoteBookFrame(NoteBookFrame, TixSubWidget):
|
|
def __init__(self, master, name, destroy_physically=0):
|
|
TixSubWidget.__init__(self, master, name, destroy_physically)
|
|
|
|
########################
|
|
### Utility Routines ###
|
|
########################
|
|
|
|
# Returns the qualified path name for the widget. Normally used to set
|
|
# default options for subwidgets. See tixwidgets.py
|
|
def OptionName(widget):
|
|
return widget.tk.call('tixOptionName', widget._w)
|
|
|
|
# Called with a dictionary argument of the form
|
|
# {'*.c':'C source files', '*.txt':'Text Files', '*':'All files'}
|
|
# returns a string which can be used to configure the fsbox file types
|
|
# in an ExFileSelectBox. i.e.,
|
|
# '{{*} {* - All files}} {{*.c} {*.c - C source files}} {{*.txt} {*.txt - Text Files}}'
|
|
def FileTypeList(dict):
|
|
s = ''
|
|
for type in dict.keys():
|
|
s = s + '{{' + type + '} {' + type + ' - ' + dict[type] + '}} '
|
|
return s
|
|
|
|
# Still to be done:
|
|
class CObjView(TixWidget):
|
|
"""This file implements the Canvas Object View widget. This is a base
|
|
class of IconView. It implements automatic placement/adjustment of the
|
|
scrollbars according to the canvas objects inside the canvas subwidget.
|
|
The scrollbars are adjusted so that the canvas is just large enough
|
|
to see all the objects.
|
|
"""
|
|
pass
|
|
|