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

« back to all changes in this revision

Viewing changes to ivle/webapp/admin/templates/offering.html

Replaced Python config files (conf.py) with new config files system, using
    configobj (INI-file style config files).

setup.py config now produces ./etc/ivle.conf, a new-style config file.
ivle/conf/conf.py is now part of the IVLE source code. It reads the new config
file and provides the same legacy interface, so all of IVLE still functions,
including setup.py config.

Added /etc to the source tree (config files will be stored here).
Added configobj as a dependency in doc/setup/install_proc.txt.

setup.py install copies ./etc/ivle.conf into /etc/ivle/ivle.conf.

Removed boilerplate code generation from setup/configure.py (that code is now
part of ivle/conf/conf.py which is now in the source tree).

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
<html xmlns="http://www.w3.org/1999/xhtml"
2
 
      xmlns:py="http://genshi.edgewall.org/">
3
 
  <head>
4
 
    <title>${context.subject.name} (${context.semester.year} semester ${context.semester.semester})</title>
5
 
  </head>
6
 
  <body>
7
 
    <h1>${context.subject.name}</h1>
8
 
    <div id="ivle_padding">
9
 
      <div class="contextactions">
10
 
        <a py:if="'edit' in permissions"
11
 
           class="editaction"
12
 
           href="${req.publisher.generate(context, OfferingEdit)}">
13
 
           Change details
14
 
        </a>
15
 
        <a py:if="'enrol' in permissions"
16
 
           class="groupaction"
17
 
           href="${req.publisher.generate(context, None, ('+enrolments', '+new'))}">
18
 
          Enrol users
19
 
        </a>
20
 
      </div>
21
 
 
22
 
      <div py:if="context.description" style="margin-bottom: 1em;">
23
 
        <div style="margin-bottom: 0.5em;">${context.description}</div>
24
 
        <a py:if="context.url" class="webaction" href="${context.url}">Home page</a>
25
 
      </div>
26
 
 
27
 
      <div py:if="'edit' in permissions or context.projects.count() > 0"
28
 
           class="majorsection">
29
 
        <h2>Projects</h2>
30
 
        <py:choose test="context.projects.count()">
31
 
          <p py:when="0">
32
 
            There are no projects for this offering.
33
 
          </p>
34
 
          <py:otherwise>
35
 
            <ul class="paddedlist">
36
 
              <li py:for="project in context.projects"
37
 
                  py:attrs="{'class': 'project closed'}
38
 
                            if project.has_deadline_passed(req.user)
39
 
                            else {'class': 'project'}"
40
 
                  py:with="principal = project.project_set.get_submission_principal(req.user)">
41
 
                <py:choose test="project.url not in (None, '')">
42
 
                  <a py:when="True" href="${project.url}">${project.name}</a>
43
 
                  <span py:otherwise="">${project.name}</span> 
44
 
                </py:choose>
45
 
                &ndash;
46
 
                <span py:content="format_submission_principal(req.user, principal)" /> &ndash;
47
 
                <!-- XXX This deadline does not take the student's extensions into account. -->
48
 
                <span title="${'Closed' if project.has_deadline_passed(req.user) else 'Due'}: ${format_datetime(project.deadline)}">
49
 
                  ${'closed' if project.has_deadline_passed(req.user) else 'due'} ${format_datetime_short(project.deadline)}
50
 
                </span>
51
 
                <py:if test="principal is not None"
52
 
                       py:with="submissions = project.get_submissions_for_principal(principal)">
53
 
                  &ndash;
54
 
                  <py:choose test="submissions.count()">
55
 
                    <span py:when="0">
56
 
                      not yet submitted
57
 
                    </span>
58
 
                    <span py:otherwise=""
59
 
                          py:with="latest = submissions.last()"
60
 
                          title="Submitted: ${format_datetime(latest.date_submitted)}">
61
 
                      last submitted ${format_datetime_short(latest.date_submitted)}
62
 
                      <a class="verifyaction" href="${latest.get_verify_url(req.user)}">Verify</a>
63
 
                    </span>
64
 
                  </py:choose>
65
 
                </py:if>
66
 
                <br />
67
 
                ${project.synopsis}
68
 
              </li>
69
 
            </ul>
70
 
            <py:if test="context.get_open_projects_for_user(req.user).count() > 0">
71
 
              <p>
72
 
                To submit to a project that has not yet closed, use the file
73
 
                browser to navigate to the file or directory that you wish to
74
 
                submit, click &ldquo;More actions...&rdquo;,
75
 
                &ldquo;Submit&rdquo;, and then select the correct project.
76
 
              </p>
77
 
              <p>
78
 
                If the project to which you intend to submit is not listed,
79
 
                ensure that you are in the correct directory, or a subdirectory
80
 
                thereof. For solo projects, you must be inside the subject's
81
 
                &ldquo;mywork&rdquo; directory. For group projects, you must be
82
 
                inside the directory for the assigned group.
83
 
              </p>
84
 
              <p>
85
 
                You may resubmit a project as you wish until the deadline, but
86
 
                a new submission will overwrite any made earlier.
87
 
              </p>
88
 
            </py:if>
89
 
          </py:otherwise>
90
 
        </py:choose>
91
 
 
92
 
        <a py:if="'edit' in permissions"
93
 
           class="manageaction"
94
 
           href="${req.publisher.generate(context, None, '+projects')}">
95
 
          Manage projects
96
 
        </a>
97
 
      </div>
98
 
 
99
 
      <div py:if="'edit' in permissions or context.worksheets.count() > 0"
100
 
           class="majorsection">
101
 
        <h2>Worksheets</h2>
102
 
        <py:choose test="context.worksheets.count()">
103
 
          <p py:when="0">
104
 
            There are no worksheets for this offering.
105
 
            <a class="addaction" href="${req.publisher.generate(context, None, ('+worksheets', '+new'))}">Create one now</a>
106
 
          </p>
107
 
          <div py:otherwise="">
108
 
            <ul id="tutorial-toc">
109
 
              <py:for each="worksheet in worksheets">
110
 
                <li>
111
 
                  <!-- Can't generate a URL directly to the worksheet, since this is a fake worksheet. -->
112
 
                  <a href="${req.publisher.generate(context)}/+worksheets/${worksheet.id}">${worksheet.name}</a>
113
 
                  <py:if test="worksheet.assessable">
114
 
                    <ul>
115
 
                      <li class="${worksheet.complete_class}">
116
 
                        Completed ${worksheet.mand_done}/${worksheet.total}${worksheet.optional_message}
117
 
                      </li>
118
 
                    </ul>
119
 
                  </py:if>
120
 
                </li>
121
 
              </py:for>
122
 
            </ul>
123
 
            <py:if test="exercises_total > 0">
124
 
              <ul>
125
 
                <li class="${worksheets_complete_class}">
126
 
                  Total exercises completed: ${exercises_done}/${exercises_total} (${exercises_pct}%)
127
 
                </li>
128
 
              </ul> 
129
 
              <p>
130
 
                <span style="font-weight: bold;">Mark:</span> ${worksheet_mark}/${worksheet_max_mark}
131
 
              </p>
132
 
            </py:if>
133
 
            <a py:if="'edit' in permissions"
134
 
               class="manageaction"
135
 
               href="${req.publisher.generate(context, None, ('+worksheets', '+edit'))}">
136
 
              Manage worksheets
137
 
            </a><br />
138
 
            <a py:if="'edit' in permissions"
139
 
               class="manageaction"
140
 
               href="/+exercises">
141
 
              Manage exercises
142
 
            </a>
143
 
          </div>
144
 
        </py:choose>
145
 
      </div>
146
 
    </div>
147
 
  </body>
148
 
</html>
149
 
    
150