2002-03-17 14:19:13 -04:00
|
|
|
# -*-mode: python; fill-column: 75; tab-width: 8; coding: iso-latin-1-unix -*-
|
2004-07-18 03:16:08 -03:00
|
|
|
#
|
2001-03-21 03:42:07 -04:00
|
|
|
# $Id$
|
|
|
|
#
|
|
|
|
# Tix Demostration Program
|
|
|
|
#
|
|
|
|
# This sample program is structured in such a way so that it can be
|
2002-03-17 14:19:13 -04:00
|
|
|
# executed from the Tix demo program "tixwidgets.py": it must have a
|
2001-03-21 03:42:07 -04:00
|
|
|
# procedure called "RunSample". It should also have the "if" statment
|
|
|
|
# at the end of this file so that it can be run as a standalone
|
|
|
|
# program.
|
|
|
|
|
|
|
|
# This file demonstrates how to use the TixTree widget to display
|
|
|
|
# dynamic hierachical data (the files in the Unix file system)
|
|
|
|
#
|
|
|
|
|
|
|
|
import Tix, os
|
|
|
|
|
|
|
|
def RunSample(w):
|
|
|
|
top = Tix.Frame(w, relief=Tix.RAISED, bd=1)
|
|
|
|
tree = Tix.Tree(top, options='separator "/"')
|
|
|
|
tree.pack(expand=1, fill=Tix.BOTH, padx=10, pady=10, side=Tix.LEFT)
|
|
|
|
tree['opencmd'] = lambda dir=None, w=tree: opendir(w, dir)
|
|
|
|
|
|
|
|
# The / directory is added in the "open" mode. The user can open it
|
|
|
|
# and then browse its subdirectories ...
|
|
|
|
adddir(tree, "/")
|
|
|
|
|
|
|
|
box = Tix.ButtonBox(w, orientation=Tix.HORIZONTAL)
|
|
|
|
box.add('ok', text='Ok', underline=0, command=w.destroy, width=6)
|
|
|
|
box.add('cancel', text='Cancel', underline=0, command=w.destroy, width=6)
|
|
|
|
box.pack(side=Tix.BOTTOM, fill=Tix.X)
|
|
|
|
top.pack(side=Tix.TOP, fill=Tix.BOTH, expand=1)
|
|
|
|
|
|
|
|
def adddir(tree, dir):
|
|
|
|
if dir == '/':
|
2004-07-18 03:16:08 -03:00
|
|
|
text = '/'
|
2001-03-21 03:42:07 -04:00
|
|
|
else:
|
2004-07-18 03:16:08 -03:00
|
|
|
text = os.path.basename(dir)
|
2001-03-21 03:42:07 -04:00
|
|
|
tree.hlist.add(dir, itemtype=Tix.IMAGETEXT, text=text,
|
2004-07-18 03:16:08 -03:00
|
|
|
image=tree.tk.call('tix', 'getimage', 'folder'))
|
2001-03-21 03:42:07 -04:00
|
|
|
try:
|
2004-07-18 03:16:08 -03:00
|
|
|
os.listdir(dir)
|
|
|
|
tree.setmode(dir, 'open')
|
2001-03-21 03:42:07 -04:00
|
|
|
except os.error:
|
2004-07-18 03:16:08 -03:00
|
|
|
# No read permission ?
|
|
|
|
pass
|
2001-03-21 03:42:07 -04:00
|
|
|
|
|
|
|
# This function is called whenever the user presses the (+) indicator or
|
|
|
|
# double clicks on a directory whose mode is "open". It loads the files
|
|
|
|
# inside that directory into the Tree widget.
|
|
|
|
#
|
|
|
|
# Note we didn't specify the closecmd option for the Tree widget, so it
|
|
|
|
# performs the default action when the user presses the (-) indicator or
|
|
|
|
# double clicks on a directory whose mode is "close": hide all of its child
|
|
|
|
# entries
|
|
|
|
def opendir(tree, dir):
|
|
|
|
entries = tree.hlist.info_children(dir)
|
|
|
|
if entries:
|
2004-07-18 03:16:08 -03:00
|
|
|
# We have already loaded this directory. Let's just
|
|
|
|
# show all the child entries
|
|
|
|
#
|
|
|
|
# Note: since we load the directory only once, it will not be
|
|
|
|
# refreshed if the you add or remove files from this
|
|
|
|
# directory.
|
|
|
|
#
|
|
|
|
for entry in entries:
|
|
|
|
tree.hlist.show_entry(entry)
|
2001-03-21 03:42:07 -04:00
|
|
|
files = os.listdir(dir)
|
|
|
|
for file in files:
|
2004-07-18 03:16:08 -03:00
|
|
|
if os.path.isdir(dir + '/' + file):
|
|
|
|
adddir(tree, dir + '/' + file)
|
|
|
|
else:
|
|
|
|
tree.hlist.add(dir + '/' + file, itemtype=Tix.IMAGETEXT, text=file,
|
|
|
|
image=tree.tk.call('tix', 'getimage', 'file'))
|
2001-03-21 03:42:07 -04:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
root = Tix.Tk()
|
|
|
|
RunSample(root)
|
|
|
|
root.mainloop()
|