Source code for enaml.widgets.page

#------------------------------------------------------------------------------
# Copyright (c) 2013, 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 Str, Bool, Event, Typed, ForwardTyped

from enaml.core.declarative import d_, observe
from enaml.icon import Icon

from .container import Container
from .widget import Widget, ProxyWidget


class ProxyPage(ProxyWidget):
    """ The abstract definition for a proxy Page.

    """
    #: A reference to the Page declaration.
    declaration = ForwardTyped(lambda: Page)

    def set_title(self, title):
        raise NotImplementedError

    def set_icon(self, icon):
        raise NotImplementedError

    def set_closable(self, closable):
        raise NotImplementedError


[docs] class Page(Widget): """ A widget which can be used as a page in a Notebook control. A Page is a widget which can be used as a child of a Notebook control. It can have at most a single child widget which is an instance of Container. """ #: The title to use for the page in the notebook. title = d_(Str()) #: The icon to use for the page tab. icon = d_(Typed(Icon)) #: Whether or not this individual page is closable. Note that the #: 'tabs_closable' flag on the parent Notebook must be set to True #: for this to have any effect. closable = d_(Bool(True)) #: An event fired when the user closes the page by clicking on #: the tab's close button. closed = d_(Event(), writable=False) #: A reference to the ProxyPage object. proxy = Typed(ProxyPage)
[docs] def page_widget(self): """ Get the page widget defined for the page. The last child Container is the page widget. """ for child in reversed(self.children): if isinstance(child, Container): return child
#-------------------------------------------------------------------------- # Observers #-------------------------------------------------------------------------- @observe('title', 'closable', 'icon') def _update_proxy(self, change): """ Send the member state change to the proxy. """ # The superclass implementation is sufficient super(Page, self)._update_proxy(change) #-------------------------------------------------------------------------- # Private API #-------------------------------------------------------------------------- def _handle_close(self): """ A method called by the proxy when the user closes the page. """ self.visible = False self.closed() # TODO spend some time thinking about the open/close api # I would rather everything be consistent, which likely # means destroy-on-close behavior should be the norm. def open(self): #msg = "The 'open()' method will be removed in Enaml version " #msg += "0.8.0. Use 'show()' instead." #import warnings #warnings.warn(msg, FutureWarning, stacklevel=2) self.show() def close(self): #msg = "The 'close()' method will be removed in Enaml version " #msg += "0.8.0. Use 'hide()' instead." #import warnings #warnings.warn(msg, FutureWarning, stacklevel=2) self.hide()