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

« back to all changes in this revision

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

  • Committer: William Grant
  • Date: 2009-05-26 03:06:53 UTC
  • Revision ID: grantw@unimelb.edu.au-20090526030653-axxawt0o5ws4icbt
Remove ivle.conf usage from ivle.studpath.

Show diffs side-by-side

added added

removed removed

Lines of Context:
28
28
from ivle.webapp.base.views import BaseView
29
29
from ivle.webapp.base.plugins import ViewPlugin, OverlayPlugin
30
30
from ivle.webapp.errors import HTTPError, Unauthorized
31
 
from ivle.webapp.publisher import NoPath
32
 
from ivle.webapp.breadcrumbs import Breadcrumber
33
31
 
34
32
class XHTMLView(BaseView):
35
33
    """
39
37
    """
40
38
 
41
39
    template = 'template.html'
 
40
    plugin_scripts = {}
 
41
    plugin_styles = {}
42
42
    allow_overlays = True
43
 
    breadcrumb_text = None
44
 
 
45
 
    def __init__(self, *args, **kwargs):
46
 
        super(XHTMLView, self).__init__(*args, **kwargs)
47
 
 
48
 
        self.overlay_blacklist = []
49
 
 
50
 
        self.plugin_scripts = {}
51
 
        self.plugin_styles = {}
52
 
        self.scripts_init = []
53
 
 
54
 
        self.extra_breadcrumbs = []
55
 
        self.overlay_blacklist = []
56
 
 
57
 
    def get_context_ancestry(self, req):
58
 
        return req.publisher.get_ancestors(self.context)
 
43
    overlay_blacklist = []
 
44
 
 
45
    def __init__(self, req, **kwargs):
 
46
        for key in kwargs:
 
47
            setattr(self, key, kwargs[key])
59
48
 
60
49
    def filter(self, stream, ctx):
61
50
        return stream
75
64
        tmpl = loader.load(app_template)
76
65
        app = self.filter(tmpl.generate(viewctx), viewctx)
77
66
 
78
 
        view_scripts = []
79
67
        for plugin in self.plugin_scripts:
80
68
            for path in self.plugin_scripts[plugin]:
81
 
                view_scripts.append(media_url(req, plugin, path))
 
69
                req.scripts.append(media_url(req, plugin, path))
82
70
 
83
 
        view_styles = []
84
71
        for plugin in self.plugin_styles:
85
72
            for path in self.plugin_styles[plugin]:
86
 
                view_styles.append(media_url(req, plugin, path))
 
73
                req.styles.append(media_url(req, plugin, path))
87
74
 
88
75
        # Global template
89
76
        ctx = genshi.template.Context()
90
 
 
91
 
        overlay_bits = self.render_overlays(req) if req.user else [[]]*4
92
 
        ctx['overlays'] = overlay_bits[0]
 
77
        # XXX: Leave this here!! (Before req.styles is read)
 
78
        ctx['overlays'] = self.render_overlays(req) if req.user else []
93
79
 
94
80
        ctx['styles'] = [media_url(req, CorePlugin, 'ivle.css')]
95
 
        ctx['styles'] += view_styles
96
 
        ctx['styles'] += overlay_bits[1]
 
81
        ctx['styles'] += req.styles
97
82
 
98
83
        ctx['scripts'] = [media_url(req, CorePlugin, path) for path in
99
84
                           ('util.js', 'json2.js', 'md5.js')]
100
85
        ctx['scripts'].append(media_url(req, '+external/jquery', 'jquery.js'))
101
 
        ctx['scripts'] += view_scripts
102
 
        ctx['scripts'] += overlay_bits[2]
 
86
        ctx['scripts'] += req.scripts
103
87
 
104
 
        ctx['scripts_init'] = self.scripts_init + overlay_bits[3]
 
88
        ctx['scripts_init'] = req.scripts_init
105
89
        ctx['app_template'] = app
106
90
        ctx['title_img'] = media_url(req, CorePlugin,
107
 
                                     "images/chrome/root-breadcrumb.png")
108
 
        try:
109
 
            ancestry = self.get_context_ancestry(req)
110
 
        except NoPath:
111
 
            ancestry = []
112
 
 
113
 
        crumber = Breadcrumber(req)
114
 
 
115
 
        ctx['breadcrumbs'] = []
116
 
        for ancestor in ancestry:
117
 
            crumb = crumber.crumb(ancestor)
118
 
            if crumb is None:
119
 
                continue
120
 
 
121
 
            if hasattr(crumb, 'extra_breadcrumbs_before'):
122
 
                ctx['breadcrumbs'].extend(crumb.extra_breadcrumbs_before)
123
 
            ctx['breadcrumbs'].append(crumb)
124
 
            if hasattr(crumb, 'extra_breadcrumbs_after'):
125
 
                ctx['breadcrumbs'].extend(crumb.extra_breadcrumbs_after)
126
 
 
127
 
        # If the view has specified text for a breadcrumb, add one.
128
 
        if self.breadcrumb_text:
129
 
            ctx['breadcrumbs'].append(ViewBreadcrumb(req, self))
130
 
 
131
 
        # Allow the view to add its own fake breadcrumbs.
132
 
        ctx['breadcrumbs'].extend(self.extra_breadcrumbs)
133
 
 
 
91
                                     "images/chrome/title.png")
134
92
        self.populate_headings(req, ctx)
135
93
        tmpl = loader.load(os.path.join(os.path.dirname(__file__), 
136
94
                                                        'ivle-headings.html'))
162
120
                continue
163
121
 
164
122
            for tab in plugin.tabs:
165
 
                # tab is a tuple: name, title, desc, icon, path, weight, admin
166
 
                # (Admin is optional, defaults to false)
 
123
                # tab is a tuple: name, title, desc, icon, path
167
124
                new_app = {}
168
125
                new_app['this_app'] = hasattr(self, 'tab') \
169
126
                                      and tab[0] == self.tab
177
134
                        ctx['favicon'] = icon_url
178
135
                else:
179
136
                    new_app['has_icon'] = False
180
 
                # The following check is here, so it is AFTER setting the
181
 
                # icon, but BEFORE actually installing the tab in the menu
182
 
                if len(tab) > 6 and tab[6]:
183
 
                    # Admin-only tab
184
 
                    if not (req.user and req.user.admin):
185
 
                        break
186
137
                new_app['path'] = req.make_path(tab[4])
187
138
                new_app['desc'] = tab[2]
188
139
                new_app['name'] = tab[1]
198
149
        scripts_init.
199
150
        """
200
151
        overlays = []
201
 
        styles = []
202
 
        scripts = []
203
 
        scripts_init = []
204
152
        if not self.allow_overlays:
205
 
            return (overlays, styles, scripts, scripts_init)
 
153
            return overlays
206
154
 
207
155
        for plugin in req.config.plugin_index[OverlayPlugin]:
208
156
            for overclass in plugin.overlays:
212
160
                #TODO: Re-factor this to look nicer
213
161
                for mplugin in overlay.plugin_scripts:
214
162
                    for path in overlay.plugin_scripts[mplugin]:
215
 
                        scripts.append(media_url(req, mplugin, path))
 
163
                        req.scripts.append(media_url(req, mplugin, path))
216
164
 
217
165
                for mplugin in overlay.plugin_styles:
218
166
                    for path in overlay.plugin_styles[mplugin]:
219
 
                        styles.append(media_url(req, mplugin, path))
 
167
                        req.styles.append(media_url(req, mplugin, path))
220
168
 
221
 
                scripts_init += overlay.plugin_scripts_init
 
169
                req.scripts_init += overlay.plugin_scripts_init
222
170
 
223
171
                overlays.append(overlay.render(req))
224
 
        return (overlays, styles, scripts, scripts_init)
 
172
        return overlays
225
173
 
226
174
    @classmethod
227
175
    def get_error_view(cls, e):
234
182
class XHTMLErrorView(XHTMLView):
235
183
    template = 'xhtmlerror.html'
236
184
 
237
 
    def __init__(self, req, context, lastobj):
238
 
        super(XHTMLErrorView, self).__init__(req, context)
239
 
        self.lastobj = lastobj
240
 
 
241
 
    def get_context_ancestry(self, req):
242
 
        return req.publisher.get_ancestors(self.lastobj)
 
185
    def __init__(self, req, exception):
 
186
        self.context = exception
243
187
 
244
188
    def populate(self, req, ctx):
245
 
        ctx['req'] = req
246
189
        ctx['exception'] = self.context
247
190
 
248
191
class XHTMLUnauthorizedView(XHTMLErrorView):
249
192
    template = 'xhtmlunauthorized.html'
250
193
 
251
 
    def __init__(self, req, exception, lastobj):
252
 
        super(XHTMLUnauthorizedView, self).__init__(req, exception, lastobj)
 
194
    def __init__(self, req, exception):
 
195
        super(XHTMLUnauthorizedView, self).__init__(req, exception)
253
196
 
254
 
        if not req.publicmode and req.user is None:
 
197
        if req.user is None:
255
198
            # Not logged in. Redirect to login page.
256
199
            if req.uri == '/':
257
200
                query_string = ''
260
203
            req.throw_redirect('/+login' + query_string)
261
204
 
262
205
        req.status = 403
263
 
 
264
 
class ViewBreadcrumb(object):
265
 
    def __init__(self, req, context):
266
 
        self.req = req
267
 
        self.context = context
268
 
 
269
 
    @property
270
 
    def text(self):
271
 
        return self.context.breadcrumb_text