~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to ivle/webapp/base/xhtml.py

Port the tos app to the new framework, and fix ivle.webapp.help's reference
to it.

Show diffs side-by-side

added added

removed removed

Lines of Context:
24
24
 
25
25
from ivle.webapp.media import media_url
26
26
from ivle.webapp.base.views import BaseView
 
27
from ivle.webapp.base.plugins import OverlayPlugin
 
28
from ivle.webapp.errors import HTTPError, Unauthorized
27
29
import ivle.conf
28
30
import ivle.util
29
31
 
37
39
    template = 'template.html'
38
40
    plugin_scripts = {}
39
41
    plugin_styles = {}
 
42
    overlay_blacklist = []
40
43
 
41
44
    def __init__(self, req, **kwargs):
42
45
        for key in kwargs:
68
71
 
69
72
        # Global template
70
73
        ctx = genshi.template.Context()
 
74
        # XXX: Leave this here!! (Before req.styles is read)
 
75
        ctx['overlays'] = self.render_overlays(req)
71
76
        ctx['app_styles'] = req.styles
72
77
        ctx['scripts'] = req.scripts
73
78
        ctx['scripts_init'] = req.scripts_init
76
81
        tmpl = loader.load(os.path.join(os.path.dirname(__file__), 
77
82
                                                        'ivle-headings.html'))
78
83
        req.write(tmpl.generate(ctx).render('xhtml', doctype='xhtml'))
 
84
        
 
85
    def populate(self, req, ctx):
 
86
        raise NotImplementedError()
79
87
 
80
88
    def populate_headings(self, req, ctx):
81
89
        ctx['favicon'] = None
88
96
            ctx['nick'] = req.user.nick
89
97
        else:
90
98
            ctx['login'] = None
 
99
            ctx['logged_in'] = False
91
100
        ctx['publicmode'] = req.publicmode
92
101
        ctx['apps_in_tabs'] = []
 
102
        if hasattr(self, 'help'):
 
103
            ctx['help_path'] = self.help
93
104
        for urlname in ivle.conf.apps.apps_in_tabs:
94
105
            new_app = {}
95
106
            app = ivle.conf.apps.app_url[urlname]
108
119
            new_app['desc'] = app.desc
109
120
            new_app['name'] = app.name
110
121
            ctx['apps_in_tabs'].append(new_app)
 
122
            
 
123
    def render_overlays(self, req):
 
124
        """Generate XML streams for the overlays.
 
125
        
 
126
        Returns a list of streams. Populates the scripts, styles, and 
 
127
        scripts_init.
 
128
        """
 
129
        overlays = []
 
130
        for plugin in req.plugin_index[OverlayPlugin]:
 
131
            for overclass in plugin.overlays:
 
132
                if overclass in self.overlay_blacklist:
 
133
                    continue
 
134
                overlay = overclass(req)
 
135
                #TODO: Re-factor this to look nicer
 
136
                for mplugin in overlay.plugin_scripts:
 
137
                    for path in overlay.plugin_scripts[mplugin]:
 
138
                        req.scripts.append(media_url(req, mplugin, path))
 
139
 
 
140
                for mplugin in overlay.plugin_styles:
 
141
                    for path in overlay.plugin_styles[mplugin]:
 
142
                        req.styles.append(media_url(req, mplugin, path))
 
143
 
 
144
                req.scripts_init += overlay.plugin_scripts_init
 
145
 
 
146
                overlays.append(overlay.render(req))
 
147
        return overlays
 
148
 
 
149
    @classmethod
 
150
    def get_error_view(cls, e):
 
151
        view_map = {HTTPError:    XHTMLErrorView,
 
152
                    Unauthorized: XHTMLUnauthorizedView}
 
153
        for exccls in inspect.getmro(type(e)):
 
154
            if exccls in view_map:
 
155
                return view_map[exccls]
 
156
 
 
157
class XHTMLErrorView(XHTMLView):
 
158
    template = 'xhtmlerror.html'
 
159
 
 
160
    def __init__(self, req, exception):
 
161
        self.context = exception
 
162
 
 
163
    def populate(self, req, ctx):
 
164
        ctx['exception'] = self.context
 
165
 
 
166
class XHTMLUnauthorizedView(XHTMLErrorView):
 
167
    template = 'xhtmlunauthorized.html'
 
168
 
 
169
    def __init__(self, req, exception):
 
170
        super(XHTMLUnauthorizedView, self).__init__(req, exception)
 
171
        if req.user is None:
 
172
            # Not logged in. Redirect to login page.
 
173
            req.throw_redirect('/') # XXX: Need proper URL.
 
174
 
 
175
        req.status = 403