style and heading-level changes. Add-new-course now requires an extra perm.
authorgfawcett <gfawcett@6d9bc8c9-1ec2-4278-b937-99fde70a366f>
Sun, 8 Mar 2009 20:25:24 +0000 (20:25 +0000)
committergfawcett <gfawcett@6d9bc8c9-1ec2-4278-b937-99fde70a366f>
Sun, 8 Mar 2009 20:25:24 +0000 (20:25 +0000)
I'm not sure how in practice we will give add-course permissions to
instructors. How do we know which ones are the instructors?

I think our backend for user-information is going to have to grow an
(optional) is_user_an_instructor() test. We can also add an
Instructors group in Django which will give the required permission.

git-svn-id: svn://svn.open-ils.org/ILS-Contrib/servres/trunk@154 6d9bc8c9-1ec2-4278-b937-99fde70a366f

conifer/static/main.css
conifer/syrup/views.py
conifer/templates/browse_courses.xhtml
conifer/templates/my_courses.xhtml
conifer/templates/welcome.xhtml

index 83071f7..2f48e42 100644 (file)
@@ -56,7 +56,7 @@ h2 { font-size: 135%; }
 h3 { font-size: 120%; }
 
 h1 { color: navy; }
-h2 { color: #338; }
+h2 { color: #336; }
 h3, h4 { color: darkgreen; }
 h1 a, h2 a { color: navy; }
 
@@ -123,7 +123,7 @@ padding-left: 25;
 .itemtree .editlinks a { color: navy; }
 
 .itemadd { 
-    margin-top: 30; font-size: smaller;
+    margin-top: 30; font-size: 90%;
     padding: 10; background-color: #eef; 
 }
 .itemadd a { color: navy; }
@@ -195,7 +195,7 @@ p.todo, div.todo { background-color: #fdd; padding: 6; margin: 12; border-left:
 
 #coursebanner { background-color: #f2e4cc; margin: -12 -12 0 -12; padding: 8; }
 
-#coursebanner h1 { padding: 0; font-size: 110%; }
+#coursebanner h1 { padding: 0; font-size: 125%; }
 
 #edit_course_link { margin: 8 0 8 0; font-size: 95%; }
 
index c59ac15..94c9cfc 100644 (file)
@@ -177,9 +177,10 @@ if COURSE_CODE_LIST:
         choices = choices)
     NewCourseForm.base_fields['code'].empty_label = empty_label
     
-# todo, how do we decide who can create new course sites?
 @login_required
 def add_new_course(request):
+    if not request.user.has_perm('add_course'):
+        return HttpResponseForbidden('You are not allowed to create course sites.') # fixme, prettier msg.
     return add_or_edit_course(request)
 
 @instructors_only
index 938b243..bcdfba4 100644 (file)
@@ -1,5 +1,5 @@
 <?python
-title = _('Welcome to Syrup E-Reserves!')
+title = _('Browse the Reserves')
 ?>
 <html xmlns="http://www.w3.org/1999/xhtml"
       xmlns:xi="http://www.w3.org/2001/XInclude"
@@ -9,9 +9,10 @@ title = _('Welcome to Syrup E-Reserves!')
   <title>${title}</title>
 </head>
 <body>
-  <h2>Browse</h2> (Note: some course materials may require you
+  <h1>${title}</h1> 
+  (Note: some course materials may require you
     to <a href="/accounts/login/?next=/syrup/">log in</a>)
-    <h3>Choose from one of the options below:</h3>
+    <h2>Choose from one of the options below:</h2>
     <ul>
         <li><a href="instructors">Browse by Instructor</a></li>
         <li><a href="departments">Browse by Department</a></li>
index e0ed1a4..115d72c 100644 (file)
@@ -1,5 +1,5 @@
 <?python
-title = _('Welcome to Syrup E-Reserves!')
+title = _('My Courses')
 ?>
 <html xmlns="http://www.w3.org/1999/xhtml"
       xmlns:xi="http://www.w3.org/2001/XInclude"
@@ -9,7 +9,7 @@ title = _('Welcome to Syrup E-Reserves!')
   <title>${title}</title>
 </head>
 <body>
-  <h2>My Courses</h2>
+  <h1>${title}</h1>
   <?python
     if user.is_authenticated():
         my_courses = user.courses()
@@ -20,8 +20,10 @@ title = _('Welcome to Syrup E-Reserves!')
   <p py:for="course in my_courses" style="font-size: large;">
     <a href="${course.id}/">${course.list_display()}</a>
   </p>
-  <p><a href="new/">Add a new course</a></p>
-  <p><a href="invitation/">Join a course using an Invitation Code</a></p>
   <div class="gap"/>
+  <div class="itemadd">
+  <p py:if="user.has_perm('add_course')"><a href="new/">Create a new course site</a></p>
+  <p><a href="invitation/">Join a course using an Invitation Code</a></p>
+  </div>
 </body>
 </html>
index 7607d07..a224bbc 100644 (file)
@@ -9,7 +9,8 @@ title = _('Welcome!')
   <title>${title}</title>
 </head>
 <body>
-  <h1>News</h1>
+  <!-- !opting *not* to put a heading on the welcome page, so that the News items can be used to customize it. -->
+  <h1 style="visibility: hidden;">Welcome!</h1>
   <div class="newsitem" py:for="news in models.NewsItem.objects.all().order_by('-published','-id')[0:5]">
     <h2>${news.subject}</h2>
     <div>${news.generated_body()}</div>