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

« back to all changes in this revision

Viewing changes to www/dispatch/html.py

  • Committer: Matt Giuca
  • Date: 2010-07-22 02:12:36 UTC
  • mfrom: (1812.1.13 late-submit)
  • Revision ID: matt.giuca@gmail.com-20100722021236-k8kt4cqdtywzpk24
Merge from trunk late-submit.
Students may now submit projects after the deadline, but they are warned that the submission is late.
Lecturers are now given data on which submissions were made late, and how many days.
(LP: #598346)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# IVLE - Informatics Virtual Learning Environment
2
 
# Copyright (C) 2007-2008 The University of Melbourne
3
 
#
4
 
# This program is free software; you can redistribute it and/or modify
5
 
# it under the terms of the GNU General Public License as published by
6
 
# the Free Software Foundation; either version 2 of the License, or
7
 
# (at your option) any later version.
8
 
#
9
 
# This program is distributed in the hope that it will be useful,
10
 
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 
# GNU General Public License for more details.
13
 
#
14
 
# You should have received a copy of the GNU General Public License
15
 
# along with this program; if not, write to the Free Software
16
 
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
17
 
 
18
 
# Module: dispatch.html
19
 
# Author: Matt Giuca
20
 
# Date: 12/12/2007
21
 
 
22
 
# Provides functions for writing the dispatch-generated HTML header and footer
23
 
# content (the common parts of the HTML pages shared across the entire site).
24
 
# Does not include the login page. See login.py.
25
 
 
26
 
import conf
27
 
import conf.apps
28
 
from common import util
29
 
 
30
 
def write_html_head(req):
31
 
    """Writes the HTML header, given a request object.
32
 
 
33
 
    req: An IVLE request object. Reads attributes such as title. Also used to
34
 
    write to."""
35
 
 
36
 
    # Write the XHTML opening and head element
37
 
    if req.title != None:
38
 
        titlepart = ' - ' + req.title
39
 
    else:
40
 
        titlepart = ''
41
 
    req.write("""<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
42
 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
43
 
<html xmlns="http://www.w3.org/1999/xhtml">
44
 
<head>
45
 
  <title>IVLE%s</title>
46
 
  <meta http-equiv="Content-Type" content="%s; charset=utf-8" />
47
 
  <link rel="stylesheet" type="text/css" href="%s" />
48
 
""" % (titlepart, req.content_type, util.make_path('media/common/ivle.css')))
49
 
 
50
 
    # Write any app-specific style and script links
51
 
    for style in req.styles:
52
 
        req.write('  <link rel="stylesheet" type="text/css" href="%s" />\n'
53
 
            % util.make_path(style))
54
 
    for script in req.scripts:
55
 
        req.write('  <script type="text/javascript" src="%s" />\n'
56
 
            % util.make_path(script))
57
 
 
58
 
    req.write("</head>\n\n")
59
 
 
60
 
    # Open the body element and write a bunch of stuff there (the header)
61
 
    req.write("""<body>
62
 
<h1>IVLE - Informatics Virtual Learning Environment</h1>
63
 
""")
64
 
 
65
 
    if req.username:
66
 
        req.write("""<p>Hello, %s. <a href="%s">Logout</a></p>\n""" %
67
 
            (req.username, util.make_path('logout')))
68
 
    else:
69
 
        req.write("<p>Not logged in.</p>")
70
 
 
71
 
    # If the "debuginfo" app is installed, display a warning to the admin to
72
 
    # make sure it is removed in production.
73
 
    if "debuginfo" in conf.apps.app_url:
74
 
        req.write("<p>Warning: debuginfo is enabled. Remove this app from "
75
 
            "conf.apps.app_url when placed into production.</p>\n")
76
 
 
77
 
    print_apps_list(req)
78
 
 
79
 
def write_html_foot(req):
80
 
    """Writes the HTML footer, given a request object.
81
 
 
82
 
    req: An IVLE request object. Written to.
83
 
    """
84
 
    req.write("</body>\n</html>\n")
85
 
 
86
 
def print_apps_list(file):
87
 
    """Prints all app tabs, as a UL. Prints a list item for each app that has
88
 
    a tab.
89
 
 
90
 
    file: Object with a "write" method - ie. the request object.
91
 
    Reads from: conf
92
 
    """
93
 
    file.write('<ul class="apptabs">\n')
94
 
 
95
 
    for urlname in conf.apps.apps_in_tabs:
96
 
        app = conf.apps.app_url[urlname]
97
 
        file.write('  <li><a href="%s">%s</a></li>\n'
98
 
            % (util.make_path(urlname), app.name))
99
 
 
100
 
    file.write('</ul>\n')