Source code for pyface.workbench.action.toggle_view_visibility_action
# (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!
""" An action that toggles a view's visibility (ie. hides/shows it). """
from pyface.workbench.api import IView
from traits.api import Delegate, Instance
from .workbench_action import WorkbenchAction
[docs]class ToggleViewVisibilityAction(WorkbenchAction):
""" An action that toggles a view's visibility (ie. hides/shows it). """
# 'Action' interface ---------------------------------------------------
# The action's unique identifier (may be None).
id = Delegate("view", modify=True)
# The action's name (displayed on menus/tool bar tools etc).
name = Delegate("view", modify=True)
# The action's style.
style = "toggle"
# 'ViewAction' interface -----------------------------------------------
# The view that we toggle the visibility for.
view = Instance(IView)
# ------------------------------------------------------------------------
# 'Action' interface.
# ------------------------------------------------------------------------
[docs] def destroy(self):
""" Called when the action is no longer required. """
if self.view is not None:
self._remove_view_listeners(self.view)
# ------------------------------------------------------------------------
# Private interface.
# ------------------------------------------------------------------------
# Trait change handlers ------------------------------------------------
def _view_changed(self, old, new):
""" Static trait change handler. """
if old is not None:
self._remove_view_listeners(old)
if new is not None:
self._add_view_listeners(new)
self._refresh_checked()
return
# Methods -------------------------------------------------------------#
def _add_view_listeners(self, view):
""" Add listeners for trait events on a view. """
view.observe(self._refresh_checked, "visible")
view.observe(self._refresh_checked, "window")
def _remove_view_listeners(self, view):
""" Add listeners for trait events on a view. """
view.observe(self._refresh_checked, "visible", remove=True)
view.observe(self._refresh_checked, "window", remove=True)
def _refresh_checked(self, event=None):
""" Refresh the checked state of the action. """
self.checked = (
self.view is not None
and self.view.window is not None
and self.view.visible
)
def _toggle_view_visibility(self, view):
""" Toggle the visibility of a view. """
if view.visible:
view.hide()
else:
view.show()
return