Source code for enaml.widgets.status_bar

#------------------------------------------------------------------------------
# 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 Typed, ForwardTyped, Bool

from enaml.core.declarative import d_, observe

from .status_item import StatusItem
from .widget import Widget, ProxyWidget


class ProxyStatusBar(ProxyWidget):
    """ The abstract definition of a proxy StatusBar object.

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

    def set_size_grip_enabled(self, enabled):
        raise NotImplementedError

    def show_message(self, message, timeout=0):
        raise NotImplementedError

    def clear_message(self):
        raise NotImplementedError


[docs] class StatusBar(Widget): """ A widget used as a status bar in a MainWindow. A status bar can be used to display temporary messages or display persistent widgets by declaring StatusItem children. """ #: Whether or not the size grip in the right corner is enabled. size_grip_enabled = d_(Bool(True)) #: A reference to the ProxyStatusBar object. proxy = Typed(ProxyStatusBar)
[docs] def status_items(self): """ Get the list of status items defined on the status bar. """ return [c for c in self.children if isinstance(c, StatusItem)]
#-------------------------------------------------------------------------- # Observers #-------------------------------------------------------------------------- @observe('size_grip_enabled') def _update_proxy(self, change): """ Update the proxy when the status bar data changes. """ # The superclass implementation is sufficient. super(StatusBar, self)._update_proxy(change) #-------------------------------------------------------------------------- # Public API #--------------------------------------------------------------------------
[docs] def show_message(self, message, timeout=0): """ Show a temporary message in the status bar. Parameters ---------- message : unicode The message to show in the status bar. timeout : int, optional The number of milliseconds to show the message. The default is 0, which will show the message until a new message is shown or 'clear_message()' is called. """ if self.proxy_is_active: self.proxy.show_message(message, timeout)
[docs] def clear_message(self): """ Clear any temporary message displayed in the status bar. """ if self.proxy_is_active: self.proxy.clear_message()