following Art's lead with a open_courses template
authorgfawcett <gfawcett@6d9bc8c9-1ec2-4278-b937-99fde70a366f>
Thu, 20 Nov 2008 03:26:01 +0000 (03:26 +0000)
committergfawcett <gfawcett@6d9bc8c9-1ec2-4278-b937-99fde70a366f>
Thu, 20 Nov 2008 03:26:01 +0000 (03:26 +0000)
git-svn-id: svn://svn.open-ils.org/ILS-Contrib/servres/trunk@33 6d9bc8c9-1ec2-4278-b937-99fde70a366f

conifer/static/main.css
conifer/syrup/views.py
conifer/templates/course_detail.xhtml
conifer/templates/open_courses.xhtml [new file with mode: 0644]
conifer/templates/paginate.xhtml [new file with mode: 0644]
conifer/templates/welcome.xhtml

index c26a6aa..beeaf9a 100644 (file)
@@ -46,4 +46,17 @@ a:hover {  text-decoration: underline;  }
 #tabbar li { display: inline; }
 #tabbar li a { padding: 18 18 4 18; background-color: #ddf; color: black; text-decoration: none; }
 #tabbar li a:hover { background-color: #fc8; }
+/* 
 #tabbar li.active a { background-color: #fa6; font-weight: bold; }
+*/
+
+.pagination_controls {
+    text-align: center;
+}
+
+.pagination_controls .nums {
+    padding: 0 24; 
+}
+
+.pagetable td { border: #ddd 1px solid; padding: 4 8; }
+.pagetable thead th { font-size: smaller; text-align: left; padding: 2 8; }
\ No newline at end of file
index a432b27..eb6ea75 100644 (file)
@@ -34,17 +34,21 @@ def welcome(request):
     return g.render('welcome.xhtml')
 
 def open_courses(request):
-    pgstart = request.GET.get('start')
-    if not pgstart:
-        pgstart = 1
-    paginator = Paginator(models.Course.objects.filter(moderated=False), 5)
-    return g.render('open_courses.xhtml', paginator=paginator, pgstart=pgstart)
+    page_num = int(request.GET.get('page', 1))
+    count = int(request.GET.get('count', 5))
+    paginator = Paginator(models.Course.objects.filter(moderated=False), count)
+    return g.render('open_courses.xhtml', paginator=paginator,
+                    page_num=page_num,
+                    count=count)
 
 @login_required
 def my_courses(request):
     return g.render('my_courses.xhtml')
 
-@login_required
 def course_detail(request, course_id):
     course = get_object_or_404(models.Course, pk=course_id)
+    if course.moderated and request.user.is_anonymous():
+        #fixme, don't stop access just if anonymous, but rather if not
+        #allowed to access. We need to set up a permissions model.
+        return login_required(lambda *args: None)(request)
     return g.render('course_detail.xhtml', course=course)
index f76a969..abfc640 100644 (file)
@@ -10,5 +10,8 @@ title = '%s: %s (%s)' % (course.code, course.title, course.term)
 </head>
 <body>
   <h1>${title}</h1>
+  <p>${course.department}</p>
+  <h2>Reserve Items</h2>
+  (not implemented yet)
 </body>
 </html>
diff --git a/conifer/templates/open_courses.xhtml b/conifer/templates/open_courses.xhtml
new file mode 100644 (file)
index 0000000..2385172
--- /dev/null
@@ -0,0 +1,24 @@
+<?python
+title = 'Open Courses'
+?>
+<html xmlns="http://www.w3.org/1999/xhtml"
+      xmlns:xi="http://www.w3.org/2001/XInclude"
+      xmlns:py="http://genshi.edgewall.org/">
+<xi:include href="master.xhtml"/>
+<xi:include href="paginate.xhtml"/>
+<head>
+  <title>${title}</title>
+</head>
+<body>
+  <h1>${title}</h1>
+  <tr py:def="pageheader()">
+    <th>Term</th><th>Code</th><th>Title</th>
+  </tr>
+  <tr py:def="pagerow(item)">
+    <td>${item.term}</td>
+    <td><a href="../course/${item.id}/">${item.code}</a></td>
+    <td><a href="../course/${item.id}/">${item.title}</a></td>
+  </tr>
+  ${pagetable(paginator, start, count, pagerow, pageheader)}
+</body>
+</html>
diff --git a/conifer/templates/paginate.xhtml b/conifer/templates/paginate.xhtml
new file mode 100644 (file)
index 0000000..b04dde3
--- /dev/null
@@ -0,0 +1,32 @@
+<html xmlns="http://www.w3.org/1999/xhtml"
+      xmlns:py="http://genshi.edgewall.org/"
+      xmlns:xi="http://www.w3.org/2001/XInclude"
+      py:strip="">
+<div py:def="pagetable(paginator, start, count, pagerow, pagehead=None)"
+     py:with="page = paginator.page(page_num)">
+  <table class="pagetable">
+    <thead py:if="pagehead">
+      ${pagehead()}
+    </thead>
+    <tbody>
+      <tr py:strip="True" py:for="item in page.object_list">
+       ${pagerow(item)}
+      </tr>
+    </tbody>
+  </table>
+  <div class="pagination_controls" py:if="paginator.num_pages > 1">
+    <span py:if="page.has_previous()" class="prev">
+      <a href=".?page=${page.previous_page_number()}&amp;count=${count}">Previous</a>
+    </span>
+    <span class="nums">
+      <span py:for="pp in range(1, 1+paginator.num_pages)">
+       <a style="font-weight: ${pp == page_num and 'bold' or 'normal'}"
+          href=".?page=${pp}&amp;count=${count}">${pp}</a>
+      </span>
+    </span>
+    <span py:if="page.has_next()" class="next">
+      <a href=".?page=${page.next_page_number()}&amp;count=${count}">Next</a>
+    </span>
+  </div>
+</div>
+</html>
\ No newline at end of file
index 7486f43..3726961 100644 (file)
@@ -10,7 +10,7 @@ title = 'Welcome!'
 </head>
 <body>
   <div style="float: right; margin: 0 24; background-color: #feb; padding: 24;">
-    <p><a href="/accounts/login/?next=/syrup/">Log in</a></p>
+    <p py:if="not user.is_authenticated()"><a href="/accounts/login/?next=/syrup/">Log in</a></p>
     <p><a href="opencourse">Browse Open Courses</a></p>
     <p><a href="/public/search">Search the Reserves</a></p>
   </div>