Source code for enaml.widgets.action
#------------------------------------------------------------------------------
# Copyright (c) 2012, Enthought, Inc.
# All rights reserved.
#------------------------------------------------------------------------------
from traits.api import Unicode, Bool, Str
from enaml.core.messenger import Messenger
from enaml.core.trait_types import EnamlEvent
[docs]class Action(Messenger):
""" A non visible widget used in a ToolBar or Menu.
An Action represents an actionable item in a ToolBar or a Menu.
Though an Action itself is a non-visible component, it will be
rendered in an appropriate fashion for the location where it is
used.
"""
#: The text label associate with the action.
text = Unicode
#: The tool tip text to use for this action. Typically displayed
#: as a small label when the user hovers over the action.
tool_tip = Unicode
#: The text that is displayed in the status bar when the user
#: hovers over the action.
status_tip = Unicode
#: The source url for the icon to use for the Action.
icon_source = Str
#: Whether or not the action can be checked.
checkable = Bool(False)
#: Whether or not the action is checked. This value only has meaning
#: if 'checkable' is set to True.
checked = Bool(False)
#: Whether or not the item representing the action is enabled.
enabled = Bool(True)
#: Whether or not the item representing the action is visible.
visible = Bool(True)
#: Whether or not the action should be treated as a separator. If
#: this value is True, none of the other values have meaning.
separator = Bool(False)
#: An event fired when the action is triggered by user interaction.
triggered = EnamlEvent
#: An event fired when a checkable action changes its checked state.
toggled = EnamlEvent
#--------------------------------------------------------------------------
# Initialization
#--------------------------------------------------------------------------
[docs] def snapshot(self):
""" Returns the snapshot dict for the Action.
"""
snap = super(Action, self).snapshot()
snap['text'] = self.text
snap['tool_tip'] = self.tool_tip
snap['status_tip'] = self.status_tip
snap['icon_source'] = self.icon_source
snap['checkable'] = self.checkable
snap['checked'] = self.checked
snap['enabled'] = self.enabled
snap['visible'] = self.visible
snap['separator'] = self.separator
return snap
[docs] def bind(self):
""" Binds the change handlers for the Action.
"""
super(Action, self).bind()
attrs = (
'text', 'tool_tip', 'status_tip', 'icon_source', 'checkable',
'checked', 'enabled', 'visible', 'separator'
)
self.publish_attributes(*attrs)
#--------------------------------------------------------------------------
# Message Handling
#--------------------------------------------------------------------------
[docs] def on_action_triggered(self, content):
""" Handle the 'triggered' action from the client widget.
"""
self.set_guarded(checked=content['checked'])
self.triggered()
[docs] def on_action_toggled(self, content):
""" Handle the 'toggled' action from the client widget.
"""
self.set_guarded(checked=content['checked'])
self.toggled()