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 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160
|
#------------------------------------------------------------------------------
# Copyright (c) 2005, Enthought, Inc.
# All rights reserved.
#
# This software is provided without warranty under the terms of the BSD
# license included in enthought/LICENSE.txt and may be redistributed only
# under the conditions described in the aforementioned license. The license
# is also available online at http://www.enthought.com/licenses/BSD.txt
# Thanks for using Enthought open source!
#
# Author: David C. Morrill
# Date: 10/21/2004
# Description: Define the Tkinter implementation of the various boolean editors
# and the boolean editor factory.
#
# Symbols defined: ToolkitEditorFactory
#
#------------------------------------------------------------------------------
#-------------------------------------------------------------------------------
# Imports:
#-------------------------------------------------------------------------------
import tk
from enthought.traits.api import Dict, Str, Any, true
from editor import Editor
from text_editor import SimpleEditor as TextEditor
from text_editor import ToolkitEditorFactory as EditorFactory
from helper import TkDelegate
#-------------------------------------------------------------------------------
# Trait definitions:
#-------------------------------------------------------------------------------
# Map from user input text to other value:
mapping_trait = Dict( Str, Any, { 'True': True,
'true': True,
't': True,
'yes': True,
'y': True,
'False': False,
'false': False,
'f': False,
'no': False,
'n': False,
} )
#-------------------------------------------------------------------------------
# 'ToolkitEditorFactory' class:
#-------------------------------------------------------------------------------
class ToolkitEditorFactory ( EditorFactory ):
#---------------------------------------------------------------------------
# Trait definitions:
#---------------------------------------------------------------------------
# These definitions override definitions in the 'text_editor' version:
mapping = mapping_trait # Dictionary mapping user input to other values
#---------------------------------------------------------------------------
# 'Editor' factory methods:
#---------------------------------------------------------------------------
def simple_editor ( self, ui, object, name, description, parent ):
return SimpleEditor( parent,
factory = self,
ui = ui,
object = object,
name = name,
description = description )
def text_editor ( self, ui, object, name, description, parent ):
return TextEditor( parent,
factory = self,
ui = ui,
object = object,
name = name,
description = description )
def readonly_editor ( self, ui, object, name, description, parent ):
return ReadonlyEditor( parent,
factory = self,
ui = ui,
object = object,
name = name,
description = description )
#-------------------------------------------------------------------------------
# 'SimpleEditor' class:
#-------------------------------------------------------------------------------
class SimpleEditor ( Editor ):
#---------------------------------------------------------------------------
# Finishes initializing the editor by creating the underlying toolkit
# widget:
#---------------------------------------------------------------------------
def init ( self, parent ):
""" Finishes initializing the editor by creating the underlying toolkit
widget.
"""
var = tk.IntVar()
self.control = control = tk.Checkbutton( parent,
text = '',
variable = var,
anchor = 'w' )
control.configure( command = TkDelegate( self.update_object,
var = var )() )
#---------------------------------------------------------------------------
# Handles the user clicking on the checkbox:
#---------------------------------------------------------------------------
def update_object ( self, delegate ):
""" Handles the user clicking on the checkbox.
"""
self.value = (delegate.var.get() != 0)
#---------------------------------------------------------------------------
# Updates the editor when the object trait changes external to the editor:
#---------------------------------------------------------------------------
def update_editor ( self ):
""" Updates the editor when the object trait changes external to the
editor.
"""
self.control.cget( 'variable' ).set( self.value )
#-------------------------------------------------------------------------------
# 'ReadonlyEditor' class:
#-------------------------------------------------------------------------------
class ReadonlyEditor ( Editor ):
#---------------------------------------------------------------------------
# Finishes initializing the editor by creating the underlying toolkit
# widget:
#---------------------------------------------------------------------------
def init ( self, parent ):
""" Finishes initializing the editor by creating the underlying toolkit
widget.
"""
self.control = tk.Label( parent, text = '', anchor = 'e' )
#---------------------------------------------------------------------------
# Updates the editor when the object trait changes external to the editor:
#
# (Should normally be overridden in a subclass)
#---------------------------------------------------------------------------
def update_editor ( self ):
""" Updates the editor when the object trait changes external to the
editor.
"""
self.control.configure( text = [ 'False', 'True' ][ self.value ] )
|