~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-19 05:59:35 UTC
  • Revision ID: grantw@unimelb.edu.au-20090519055935-mzyz7b2cryebamr4
Pretty dates in SubversionLogView.

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
 
        if not req.publicmode:
117
 
            for ancestor in ancestry:
118
 
                crumb = crumber.crumb(ancestor)
119
 
                if crumb is None:
120
 
                    continue
121
 
 
122
 
                if hasattr(crumb, 'extra_breadcrumbs_before'):
123
 
                    ctx['breadcrumbs'].extend(crumb.extra_breadcrumbs_before)
124
 
                ctx['breadcrumbs'].append(crumb)
125
 
                if hasattr(crumb, 'extra_breadcrumbs_after'):
126
 
                    ctx['breadcrumbs'].extend(crumb.extra_breadcrumbs_after)
127
 
 
128
 
            # If the view has specified text for a breadcrumb, add one.
129
 
            if self.breadcrumb_text:
130
 
                ctx['breadcrumbs'].append(ViewBreadcrumb(req, self))
131
 
 
132
 
            # Allow the view to add its own fake breadcrumbs.
133
 
            ctx['breadcrumbs'].extend(self.extra_breadcrumbs)
134
 
 
 
91
                                     "images/chrome/title.png")
135
92
        self.populate_headings(req, ctx)
136
93
        tmpl = loader.load(os.path.join(os.path.dirname(__file__), 
137
94
                                                        'ivle-headings.html'))
163
120
                continue
164
121
 
165
122
            for tab in plugin.tabs:
166
 
                # tab is a tuple: name, title, desc, icon, path, weight, admin
167
 
                # (Admin is optional, defaults to false)
 
123
                # tab is a tuple: name, title, desc, icon, path
168
124
                new_app = {}
169
125
                new_app['this_app'] = hasattr(self, 'tab') \
170
126
                                      and tab[0] == self.tab
178
134
                        ctx['favicon'] = icon_url
179
135
                else:
180
136
                    new_app['has_icon'] = False
181
 
                # The following check is here, so it is AFTER setting the
182
 
                # icon, but BEFORE actually installing the tab in the menu
183
 
                if len(tab) > 6 and tab[6]:
184
 
                    # Admin-only tab
185
 
                    if not (req.user and req.user.admin):
186
 
                        break
187
137
                new_app['path'] = req.make_path(tab[4])
188
138
                new_app['desc'] = tab[2]
189
139
                new_app['name'] = tab[1]
199
149
        scripts_init.
200
150
        """
201
151
        overlays = []
202
 
        styles = []
203
 
        scripts = []
204
 
        scripts_init = []
205
152
        if not self.allow_overlays:
206
 
            return (overlays, styles, scripts, scripts_init)
 
153
            return overlays
207
154
 
208
155
        for plugin in req.config.plugin_index[OverlayPlugin]:
209
156
            for overclass in plugin.overlays:
213
160
                #TODO: Re-factor this to look nicer
214
161
                for mplugin in overlay.plugin_scripts:
215
162
                    for path in overlay.plugin_scripts[mplugin]:
216
 
                        scripts.append(media_url(req, mplugin, path))
 
163
                        req.scripts.append(media_url(req, mplugin, path))
217
164
 
218
165
                for mplugin in overlay.plugin_styles:
219
166
                    for path in overlay.plugin_styles[mplugin]:
220
 
                        styles.append(media_url(req, mplugin, path))
 
167
                        req.styles.append(media_url(req, mplugin, path))
221
168
 
222
 
                scripts_init += overlay.plugin_scripts_init
 
169
                req.scripts_init += overlay.plugin_scripts_init
223
170
 
224
171
                overlays.append(overlay.render(req))
225
 
        return (overlays, styles, scripts, scripts_init)
 
172
        return overlays
226
173
 
227
174
    @classmethod
228
175
    def get_error_view(cls, e):
235
182
class XHTMLErrorView(XHTMLView):
236
183
    template = 'xhtmlerror.html'
237
184
 
238
 
    def __init__(self, req, context, lastobj):
239
 
        super(XHTMLErrorView, self).__init__(req, context)
240
 
        self.lastobj = lastobj
241
 
 
242
 
    def get_context_ancestry(self, req):
243
 
        return req.publisher.get_ancestors(self.lastobj)
 
185
    def __init__(self, req, exception):
 
186
        self.context = exception
244
187
 
245
188
    def populate(self, req, ctx):
246
 
        ctx['req'] = req
247
189
        ctx['exception'] = self.context
248
190
 
249
191
class XHTMLUnauthorizedView(XHTMLErrorView):
250
192
    template = 'xhtmlunauthorized.html'
251
193
 
252
 
    def __init__(self, req, exception, lastobj):
253
 
        super(XHTMLUnauthorizedView, self).__init__(req, exception, lastobj)
 
194
    def __init__(self, req, exception):
 
195
        super(XHTMLUnauthorizedView, self).__init__(req, exception)
254
196
 
255
 
        if not req.publicmode and req.user is None:
 
197
        if req.user is None:
256
198
            # Not logged in. Redirect to login page.
257
199
            if req.uri == '/':
258
200
                query_string = ''
261
203
            req.throw_redirect('/+login' + query_string)
262
204
 
263
205
        req.status = 403
264
 
 
265
 
class ViewBreadcrumb(object):
266
 
    def __init__(self, req, context):
267
 
        self.req = req
268
 
        self.context = context
269
 
 
270
 
    @property
271
 
    def text(self):
272
 
        return self.context.breadcrumb_text