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
|
# (C) Copyright 2004-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!
""" Defines the various Boolean editors for the wxPython user interface toolkit.
"""
import wx
from .editor import Editor
# This needs to be imported in here for use by the editor factory for boolean
# editors (declared in traitsui). The editor factory's text_editor
# method will use the TextEditor in the ui.
from .text_editor import SimpleEditor as TextEditor
from .constants import ReadonlyColor
class SimpleEditor(Editor):
"""Simple style of editor for Boolean values, which displays a check box."""
def init(self, parent):
"""Finishes initializing the editor by creating the underlying toolkit
widget.
"""
self.control = wx.CheckBox(parent, -1, "")
self.control.Bind(wx.EVT_CHECKBOX, self.update_object)
self.set_tooltip()
def dispose(self):
self.control.Unbind(wx.EVT_CHECKBOX)
def update_object(self, event):
"""Handles the user clicking the checkbox."""
self.value = self.control.GetValue() != 0
def update_editor(self):
"""Updates the editor when the object trait changes externally to the
editor.
"""
self.control.SetValue(self.value)
class ReadonlyEditor(Editor):
"""Read-only style of editor for Boolean values, which displays static text
of either "True" or "False".
"""
def init(self, parent):
"""Finishes initializing the editor by creating the underlying toolkit
widget.
"""
self.control = wx.TextCtrl(parent, -1, "", style=wx.TE_READONLY)
self.control.SetBackgroundColour(ReadonlyColor)
# -------------------------------------------------------------------------
# Updates the editor when the object trait changes external to the editor:
#
# (Should normally be overridden in a subclass)
# -------------------------------------------------------------------------
def update_editor(self):
"""Updates the editor when the object trait changes externally to the
editor.
"""
if self.value:
self.control.SetValue("True")
else:
self.control.SetValue("False")
|