# $Id: DialogWindow.py,v 1.18 2006/07/02 13:08:53 marcusva Exp $
#
# Copyright (c) 2004-2006, Marcus von Appen
# All rights reserved.
# Redistribution and use in source and binary forms, with or without 
# modification, are permitted provided that the following conditions are met:
#
#  * Redistributions of source code must retain the above copyright notice, 
#    this list of conditions and the following disclaimer.
#  * Redistributions in binary form must reproduce the above copyright notice,
#    this list of conditions and the following disclaimer in the documentation 
#    and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
# POSSIBILITY OF SUCH DAMAGE.

"""A modal window suitable for dialogs and similar purposes."""

from Window import Window
from ocempgui.events import EventManager

class DialogWindow (Window):
    """DialogWindow (title=None) -> DialogWindow

    A modal window widget, which blocks any other input.

    The DialogWindow sets itself and its children in a modal state by
    limiting the event distribution to itself.
    
    Default action (invoked by activate()):
    See the Window class.
    
    Mnemonic action (invoked by activate_mnemonic()):
    See the Window class.
    """
    def __init__ (self, title=None):
        Window.__init__ (self, title)

    def set_event_manager (self, manager):
        """D.set_event_manager (...) -> None

        Sets the event manager of the DialogWindow.

        Sets the event manager of the DialogWindow and invokes the
        grab_events() method for the DialogWindow.
        """
        if (manager == None) and (self.manager != None):
            self.manager.event_grabber = None
        Window.set_event_manager (self, manager)
        if self.manager != None:
            self.manager.event_grabber = self

    def destroy (self):
        """D.destroy () -> None

        Destroys the DialogWindow and removes it from its event system.
        """
        self._stop_events = True
        if self.manager != None:
            self.manager.event_grabber = None
        Window.destroy (self)


syntax highlighted by Code2HTML, v. 0.9.1