Source code for enaml.widgets.abstract_button
#------------------------------------------------------------------------------
# Copyright (c) 2013-2023, Nucleic Development Team.
#
# Distributed under the terms of the Modified BSD License.
#
# The full license is in the file LICENSE, distributed with this software.
#------------------------------------------------------------------------------
from atom.api import (
Bool, Str, Coerced, Event, Typed, ForwardTyped, set_default
)
from enaml.core.declarative import d_, observe
from enaml.icon import Icon
from enaml.layout.geometry import Size
from .control import Control, ProxyControl
def ButtonGroup():
from .button_group import ButtonGroup
return ButtonGroup
class ProxyAbstractButton(ProxyControl):
""" The abstract definition of a proxy AbstractButton object.
"""
#: A reference to the AbstractButton declaration.
declaration = ForwardTyped(lambda: AbstractButton)
def set_text(self, text):
raise NotImplementedError
def set_icon(self, icon):
raise NotImplementedError
def set_icon_size(self, size):
raise NotImplementedError
def set_group(self, group):
raise NotImplementedError
def set_checkable(self, checkable):
raise NotImplementedError
def set_checked(self, checked):
raise NotImplementedError
[docs]
class AbstractButton(Control):
""" A base class for creating button-like controls.
"""
#: The text to use as the button's label.
text = d_(Str())
#: The source url for the icon to use for the button.
icon = d_(Typed(Icon))
#: The size to use for the icon. The default is an invalid size
#: and indicates that an appropriate default should be used.
icon_size = d_(Coerced(Size, (-1, -1)))
#: Group to which this button belongs to.
group = d_(ForwardTyped(ButtonGroup))
#: Whether or not the button is checkable. The default is False.
checkable = d_(Bool(False))
#: Whether a checkable button is currently checked.
checked = d_(Bool(False))
#: Fired when the button is pressed then released. The payload will
#: be the current checked state. This event is triggered by the
#: proxy object when the button is clicked.
clicked = d_(Event(bool), writable=False)
#: Fired when a checkable button is toggled. The payload will be
#: the current checked state. This event is triggered by the
#: proxy object when a togglable button is toggled.
toggled = d_(Event(bool), writable=False)
#: Buttons hug their contents' width weakly by default.
hug_width = set_default('weak')
#: A reference to the ProxyAbstractButton object.
proxy = Typed(ProxyAbstractButton)
[docs]
def __init__(self, parent=None, **kwargs):
super(AbstractButton, self).__init__(parent, **kwargs)
# Overridden to synchronize the group_members member of the group
if self.group:
self.group.group_members.add(self)
#--------------------------------------------------------------------------
# Observers
#--------------------------------------------------------------------------
@observe('text', 'icon', 'icon_size', 'group', 'checkable', 'checked')
def _update_proxy(self, change):
""" An observer which updates the proxy widget.
"""
# The superclass implementation is sufficient.
super(AbstractButton, self)._update_proxy(change)
#--------------------------------------------------------------------------
# Post Setattr Handlers
#--------------------------------------------------------------------------
def _post_setattr_group(self, old, new):
""" Update the group_members of the group this button belongs too.
"""
if old:
old.group_members.remove(self)
if new:
new.group_members.add(self)