File: wizard_controller.py

package info (click to toggle)
enthought-traits-ui 2.0.5-1
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 15,204 kB
  • ctags: 9,623
  • sloc: python: 45,547; sh: 32; makefile: 19
file content (69 lines) | stat: -rw-r--r-- 2,156 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#------------------------------------------------------------------------------
# Copyright (c) 2005, Enthought, Inc.
# All rights reserved.
# 
# This software is provided without warranty under the terms of the BSD
# license included in enthought/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!
# 
# Author: Enthought, Inc.
# Description: <Enthought pyface package component>
#------------------------------------------------------------------------------
""" Abstract base class for all wizard controllers. """


# Enthought library imports.
from enthought.traits.api import Bool, HasTraits, Instance

# Local imports.
from wizard_page import WizardPage


class WizardController(HasTraits):
    """ Abstract base class for all wizard controllers. """

    #### 'WizardController' interface #########################################

    # The current page.
    current_page = Instance(WizardPage)

    # Is the wizard complete (i.e. should the 'Finish' button be enabled)?
    complete = Bool(False)

    ###########################################################################
    # 'WizardModel' interface.
    ###########################################################################

    def get_first_page(self):
        """ Returns the first page in the model. """

        return NotImplementedError()

    def get_next_page(self, page):
        """ Returns the next page. """

        raise NotImplementedError()

    def get_previous_page(self, page):
        """ Returns the previous page. """

        raise NotImplementedError()

    def is_first_page(self, page):
        """ Is the page the first page? """

        raise NotImplementedError()

    def is_last_page(self, page):
        """ Is the page the last page? """

        raise NotImplementedError()

    def dispose_pages(self):
        """ Dispose all the pages. """

        raise NotImplementedError()
    
#### EOF ######################################################################