File: TextEditor_demo.py

package info (click to toggle)
python-traitsui 4.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 13,292 kB
  • sloc: python: 39,867; makefile: 120; sh: 5
file content (73 lines) | stat: -rw-r--r-- 2,342 bytes parent folder | download | duplicates (2)
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
"""
Edit a string, password, or integer

The TextEditor displays a Str, Password, or Int trait for the user to edit.

When editing a Str, consider styles 'simple' (one-line), 'custom' (multi-line),
or read-only (multi-line).

When editing a Password, use style 'simple' (shows asterisks).

When editing an Int, consider styles 'simple' and 'readonly'.
"""
# FIXME:? as of 7/1/2011, Password style 'text' showed typed characters.
# It no longer does. Should it?

# Imports:
from traits.api import HasTraits, Str, Int, Password

from traitsui.api import Item, Group, View

# The main demo class:
class TextEditorDemo ( HasTraits ):
    """ Defines the TextEditor demo class.
    """

    # Define a trait for each of three TextEditor variants:
    string_trait = Str( "sample string" )
    int_trait    = Int( 1 )
    password     = Password

    # TextEditor display with multi-line capability (for a string):
    text_str_group = Group(
        Item( 'string_trait', style = 'simple',  label = 'Simple' ),
        Item( '_' ),
        Item( 'string_trait', style = 'custom',  label = 'Custom' ),
        Item( '_' ),
        # text style is the same as simple, not shown.
        Item( 'string_trait', style = 'readonly', label = 'ReadOnly' ),
        label = 'String'
    )

    # TextEditor display without multi-line capability (for an integer):
    text_int_group = Group(
        Item( 'int_trait', style = 'simple',   label = 'Simple' ),
        # custom and text styles are not useful for editing integers, not shown:
        Item( '_' ),
        Item( 'int_trait', style = 'readonly', label = 'ReadOnly' ),
        label = 'Integer'
    )

    # TextEditor display with secret typing capability (for Password traits):
    text_pass_group = Group(
        Item( 'password', style = 'simple',   label = 'Simple' ),
        # custom and text style are the same as simple, not shown.
        label = 'Password'
    )

    # The view includes one group per data type. These will be displayed
    # on separate tabbed panels:
    traits_view = View(
        text_str_group,
        text_pass_group,
        text_int_group,
        title   = 'TextEditor',
        buttons = [ 'OK' ]
    )

# Create the demo:
demo =  TextEditorDemo()

# Run the demo (if invoked from the command line):
if __name__ == "__main__":
    demo.configure_traits()