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
|
# (C) Copyright 2005-2023 Enthought, Inc., Austin, TX
# All rights reserved.
#
# This software is provided without warranty under the terms of the BSD
# license included in 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!
""" The field interface. """
from traits.api import Any, HasTraits
from pyface.i_layout_widget import ILayoutWidget
from pyface.ui_traits import Alignment
class IField(ILayoutWidget):
""" The field interface.
A field is a widget that displays a value and (potentially) allows a user
to interact with it.
"""
#: The value held by the field.
value = Any()
#: The alignment of the field's content.
alignment = Alignment()
class MField(HasTraits):
""" The field mix-in. """
#: The value held by the field.
value = Any()
#: The alignment of the text in the field.
alignment = Alignment()
# ------------------------------------------------------------------------
# IWidget interface
# ------------------------------------------------------------------------
def create(self, parent=None):
""" Creates the toolkit specific control.
This method should create the control and assign it to the
:py:attr:``control`` trait.
"""
super().create(parent=parent)
self.show(self.visible)
self.enable(self.enabled)
def _initialize_control(self):
""" Perform any post-creation initialization for the control.
"""
super()._initialize_control()
self._set_control_value(self.value)
if self.alignment != 'default':
self._set_control_alignment(self.alignment)
def _add_event_listeners(self):
""" Set up toolkit-specific bindings for events """
super()._add_event_listeners()
self.observe(self._value_updated, "value", dispatch="ui")
self.observe(self._alignment_updated, "alignment", dispatch="ui")
def _remove_event_listeners(self):
""" Remove toolkit-specific bindings for events """
self.observe(
self._value_updated, "value", dispatch="ui", remove=True
)
self.observe(
self._alignment_updated, "alignment", dispatch="ui", remove=True
)
super()._remove_event_listeners()
# ------------------------------------------------------------------------
# Private interface
# ------------------------------------------------------------------------
def _get_control(self):
""" If control is not passed directly, get it from the trait. """
control = self.control
if control is None:
raise RuntimeError("Toolkit control does not exist.")
return control
# Toolkit control interface ---------------------------------------------
def _get_control_value(self):
""" Toolkit specific method to get the control's value. """
raise NotImplementedError()
def _set_control_value(self, value):
""" Toolkit specific method to set the control's value. """
raise NotImplementedError()
def _get_control_alignment(self):
""" Toolkit specific method to get the control's read_only state. """
raise NotImplementedError()
def _set_control_alignment(self, alignment):
""" Toolkit specific method to set the control's alignment. """
raise NotImplementedError()
# Trait change handlers -------------------------------------------------
def _value_updated(self, event):
value = event.new
if self.control is not None:
self._set_control_value(value)
def _alignment_updated(self, event):
alignment = event.new
if self.control is not None:
self._set_control_alignment(alignment)
|