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

« back to all changes in this revision

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

  • Committer: David Coles
  • Date: 2010-02-11 02:35:41 UTC
  • Revision ID: coles.david@gmail.com-20100211023541-376jeqqfrh2m2upx
Fix spelling of 'privileges'

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
 
import ivle.conf
32
 
import ivle.util
 
31
from ivle.webapp.publisher import NoPath
 
32
from ivle.webapp.breadcrumbs import Breadcrumber
33
33
 
34
34
class XHTMLView(BaseView):
35
35
    """
39
39
    """
40
40
 
41
41
    template = 'template.html'
42
 
    plugin_scripts = {}
43
 
    plugin_styles = {}
44
42
    allow_overlays = True
45
 
    overlay_blacklist = []
46
 
 
47
 
    def __init__(self, req, **kwargs):
48
 
        for key in kwargs:
49
 
            setattr(self, key, kwargs[key])
 
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)
 
59
 
 
60
    def filter(self, stream, ctx):
 
61
        return stream
50
62
 
51
63
    def render(self, req):
52
64
        req.content_type = 'text/html' # TODO: Detect application/xhtml+xml
61
73
                        inspect.getmodule(self).__file__), self.template) 
62
74
        loader = genshi.template.TemplateLoader(".", auto_reload=True)
63
75
        tmpl = loader.load(app_template)
64
 
        app = tmpl.generate(viewctx)
 
76
        app = self.filter(tmpl.generate(viewctx), viewctx)
65
77
 
 
78
        view_scripts = []
66
79
        for plugin in self.plugin_scripts:
67
80
            for path in self.plugin_scripts[plugin]:
68
 
                req.scripts.append(media_url(req, plugin, path))
 
81
                view_scripts.append(media_url(req, plugin, path))
69
82
 
 
83
        view_styles = []
70
84
        for plugin in self.plugin_styles:
71
85
            for path in self.plugin_styles[plugin]:
72
 
                req.styles.append(media_url(req, plugin, path))
 
86
                view_styles.append(media_url(req, plugin, path))
73
87
 
74
88
        # Global template
75
89
        ctx = genshi.template.Context()
76
 
        # XXX: Leave this here!! (Before req.styles is read)
77
 
        ctx['overlays'] = self.render_overlays(req) if req.user else []
 
90
 
 
91
        overlay_bits = self.render_overlays(req) if req.user else [[]]*4
 
92
        ctx['overlays'] = overlay_bits[0]
78
93
 
79
94
        ctx['styles'] = [media_url(req, CorePlugin, 'ivle.css')]
80
 
        ctx['styles'] += req.styles
 
95
        ctx['styles'] += view_styles
 
96
        ctx['styles'] += overlay_bits[1]
81
97
 
82
98
        ctx['scripts'] = [media_url(req, CorePlugin, path) for path in
83
99
                           ('util.js', 'json2.js', 'md5.js')]
84
 
        ctx['scripts'] += req.scripts
 
100
        ctx['scripts'].append(media_url(req, '+external/jquery', 'jquery.js'))
 
101
        ctx['scripts'] += view_scripts
 
102
        ctx['scripts'] += overlay_bits[2]
85
103
 
86
 
        ctx['scripts_init'] = req.scripts_init
 
104
        ctx['scripts_init'] = self.scripts_init + overlay_bits[3]
87
105
        ctx['app_template'] = app
 
106
        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
 
88
134
        self.populate_headings(req, ctx)
89
135
        tmpl = loader.load(os.path.join(os.path.dirname(__file__), 
90
136
                                                        'ivle-headings.html'))
95
141
 
96
142
    def populate_headings(self, req, ctx):
97
143
        ctx['favicon'] = None
98
 
        ctx['root_dir'] = ivle.conf.root_dir
99
 
        ctx['public_host'] = ivle.conf.public_host
 
144
        ctx['root_dir'] = req.config['urls']['root']
 
145
        ctx['public_host'] = req.config['urls']['public_host']
 
146
        ctx['svn_base'] = req.config['urls']['svn_addr']
100
147
        ctx['write_javascript_settings'] = req.write_javascript_settings
101
148
        if req.user:
102
149
            ctx['login'] = req.user.login
117
164
            for tab in plugin.tabs:
118
165
                # tab is a tuple: name, title, desc, icon, path
119
166
                new_app = {}
120
 
                new_app['this_app'] = hasattr(self, 'appname') \
121
 
                                      and tab[0] == self.appname
 
167
                new_app['this_app'] = hasattr(self, 'tab') \
 
168
                                      and tab[0] == self.tab
122
169
 
123
170
                # Icon name
124
171
                if tab[3] is not None:
129
176
                        ctx['favicon'] = icon_url
130
177
                else:
131
178
                    new_app['has_icon'] = False
132
 
                new_app['path'] = ivle.util.make_path(tab[4])
 
179
                new_app['path'] = req.make_path(tab[4])
133
180
                new_app['desc'] = tab[2]
134
181
                new_app['name'] = tab[1]
135
182
                new_app['weight'] = tab[5]
144
191
        scripts_init.
145
192
        """
146
193
        overlays = []
 
194
        styles = []
 
195
        scripts = []
 
196
        scripts_init = []
147
197
        if not self.allow_overlays:
148
 
            return overlays
 
198
            return (overlays, styles, scripts, scripts_init)
149
199
 
150
200
        for plugin in req.config.plugin_index[OverlayPlugin]:
151
201
            for overclass in plugin.overlays:
155
205
                #TODO: Re-factor this to look nicer
156
206
                for mplugin in overlay.plugin_scripts:
157
207
                    for path in overlay.plugin_scripts[mplugin]:
158
 
                        req.scripts.append(media_url(req, mplugin, path))
 
208
                        scripts.append(media_url(req, mplugin, path))
159
209
 
160
210
                for mplugin in overlay.plugin_styles:
161
211
                    for path in overlay.plugin_styles[mplugin]:
162
 
                        req.styles.append(media_url(req, mplugin, path))
 
212
                        styles.append(media_url(req, mplugin, path))
163
213
 
164
 
                req.scripts_init += overlay.plugin_scripts_init
 
214
                scripts_init += overlay.plugin_scripts_init
165
215
 
166
216
                overlays.append(overlay.render(req))
167
 
        return overlays
 
217
        return (overlays, styles, scripts, scripts_init)
168
218
 
169
219
    @classmethod
170
220
    def get_error_view(cls, e):
177
227
class XHTMLErrorView(XHTMLView):
178
228
    template = 'xhtmlerror.html'
179
229
 
180
 
    def __init__(self, req, exception):
181
 
        self.context = exception
 
230
    def __init__(self, req, context, lastobj):
 
231
        super(XHTMLErrorView, self).__init__(req, context)
 
232
        self.lastobj = lastobj
 
233
 
 
234
    def get_context_ancestry(self, req):
 
235
        return req.publisher.get_ancestors(self.lastobj)
182
236
 
183
237
    def populate(self, req, ctx):
 
238
        ctx['req'] = req
184
239
        ctx['exception'] = self.context
185
240
 
186
241
class XHTMLUnauthorizedView(XHTMLErrorView):
187
242
    template = 'xhtmlunauthorized.html'
188
243
 
189
 
    def __init__(self, req, exception):
190
 
        super(XHTMLUnauthorizedView, self).__init__(req, exception)
 
244
    def __init__(self, req, exception, lastobj):
 
245
        super(XHTMLUnauthorizedView, self).__init__(req, exception, lastobj)
191
246
 
192
 
        if req.user is None:
 
247
        if not req.publicmode and req.user is None:
193
248
            # Not logged in. Redirect to login page.
194
249
            if req.uri == '/':
195
250
                query_string = ''
198
253
            req.throw_redirect('/+login' + query_string)
199
254
 
200
255
        req.status = 403
 
256
 
 
257
class ViewBreadcrumb(object):
 
258
    def __init__(self, req, context):
 
259
        self.req = req
 
260
        self.context = context
 
261
 
 
262
    @property
 
263
    def text(self):
 
264
        return self.context.breadcrumb_text