Source code for enaml.qt.qt_stack_item

#------------------------------------------------------------------------------
#  Copyright (c) 2012, Enthought, Inc.
#  All rights reserved.
#------------------------------------------------------------------------------
from .qt.QtGui import QFrame
from .q_single_widget_layout import QSingleWidgetLayout
from .qt_container import QtContainer
from .qt_widget import QtWidget


class QStackItem(QFrame):
    """ A QFrame subclass which acts as an item QStack.

    """
    def __init__(self, *args, **kwargs):
        """ Initialize a QStackItem.

        Parameters
        ----------
        *args, **kwargs
            The position and keyword arguments required to initialize
            a QWidget.

        """
        super(QStackItem, self).__init__(*args, **kwargs)
        self._stack_widget = None
        self.setLayout(QSingleWidgetLayout())

    def stackWidget(self):
        """ Get the stack widget for this stack item.

        Returns
        -------
        result : QWidget or None
            The stack widget being managed by this item.

        """
        return self._stack_widget

    def setStackWidget(self, widget):
        """ Set the stack widget for this stack item.

        Parameters
        ----------
        widget : QWidget
            The QWidget to use as the stack widget in this item.

        """
        self._stack_widget = widget
        self.layout().setWidget(widget)


[docs]class QtStackItem(QtWidget): """ A Qt implementation of an Enaml StackItem. """ #-------------------------------------------------------------------------- # Setup Methods #--------------------------------------------------------------------------
[docs] def create_widget(self, parent, tree): """ Create the underlying QStackItem widget. """ return QStackItem(parent)
[docs] def init_layout(self): """ Initialize the layout for the underyling widget. """ super(QtStackItem, self).init_layout() self.widget().setStackWidget(self.stack_widget()) #-------------------------------------------------------------------------- # Utility Methods #--------------------------------------------------------------------------
[docs] def stack_widget(self): """ Find and return the stack widget child for this widget. Returns ------- result : QWidget or None The stack widget defined for this widget, or None if one is not defined. """ widget = None for child in self.children(): if isinstance(child, QtContainer): widget = child.widget() return widget #-------------------------------------------------------------------------- # Child Events #--------------------------------------------------------------------------
[docs] def child_removed(self, child): """ Handle the child added event for a QtStackItem. """ if isinstance(child, QtContainer): self.widget().setStackWidget(self.stack_widget())
[docs] def child_added(self, child): """ Handle the child added event for a QtStackItem. """ if isinstance(child, QtContainer): self.widget().setStackWidget(self.stack_widget()) #-------------------------------------------------------------------------- # Widget Update Methods #--------------------------------------------------------------------------
[docs] def set_visible(self, visible): """ An overridden visibility setter. This setter disables changing visibility on the widget since the visibility is controlled entirely by the parent stack. """ pass