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
|
"""
Apply / Revert
Provides support in a dialog box for an "Apply" button which modifies the
object being viewed, and a "Revert" button, which returns the object to its
starting state (before any "Apply").
Note that this does not automatically provide a full (multi-step incremental)
Undo capability.
"""
from traits.api import HasTraits, Str, List
from traitsui.api import Item, View, Handler, HGroup, VGroup
# 'ApplyRevert_Handler' class:
class ApplyRevert_Handler(Handler):
def apply(self, info):
object = info.object
object.stack.insert(0, object.input)
object.queue.append(object.input)
def revert(self, info):
# Do something exciting here...
print 'revert called...'
# 'ApplyRevertDemo' class:
class ApplyRevertDemo(HasTraits):
# Trait definitions:
input = Str
stack = List
queue = List
# Traits view definitions:
traits_view = View(
VGroup(
VGroup(
Item('input',
show_label = False
),
label = 'Input',
show_border = True
),
HGroup(
VGroup(
Item('stack',
show_label = False,
height = 50,
width = 100,
style = 'readonly'
),
label = 'Stack',
show_border = True
),
VGroup(
Item('queue',
show_label = False,
height = 50,
width = 100,
style = 'readonly'
),
label = 'Queue',
show_border = True
)
)
),
resizable = True,
height = 300,
title = 'Apply/Revert example',
buttons = [ 'Apply', 'Revert' ],
kind = 'modal',
handler = ApplyRevert_Handler
)
# Create the demo:
modal_popup = ApplyRevertDemo()
# Run the demo (if invoked from the command line):
if __name__ == '__main__':
modal_popup.configure_traits()
|