# Toplevel definitions in this module will be available in when
# rendering a Genshi template.
+import itertools
from itertools import cycle
from conifer.syrup import models
import django.forms
font-family: inherit;
vertical-align: baseline;
}
+
+li { margin-left: 16px; }
+
/* remember to define focus styles! */
:focus {
outline: 0;
color: black;
background: white;
}
-ol, ul {
- list-style: none;
-}
+
/* tables still need 'cellspacing="0"' in the markup */
table {
border-collapse: separate;
background-color: #448;
}
+
#header div#search {
float: right;
margin: 0;
tbody td, tbody th { vertical-align: top; }
#footer {
- margin: 12px;
- padding-bottom: 12px;
- background-color: #ddf;
- color: black;
- border-bottom: white 10px solid;
+ margin: 0;
+ padding-top: 16px;
+ color: #eee;
+ font-size: small;
}
+#footer a { color: white; text-decoration: underline; }
/* heading sizes and colours. */
.action a { font-weight: bold; }
#tabbar { margin: 18px 0; padding: 0; clear: both; }
-#tabbar li { display: inline; }
+#tabbar li { display: inline; margin: 0; }
#tabbar li a { padding: 15px 18px 5px 18px; background-color: #ddf; color: black; text-decoration: none; }
#tabbar li a:hover { background-color: #fc8; }
#sidepanel { width: 183px; float: right; text-align: right;}
#sidepanel div { margin: 6px 0; }
-#treepanel { width: 740px; }
+#treepanel { width: 740px; margin-top: 24px; }
.helptext {
margin-top: 30px; font-size: 90%;
.itemtree li.item_HEADING {
list-style-image: url(tango/folder.png);
+ margin-top: 24px;
}
.itemtree li.item_HEADING > a {
color: navy;
}
li.item_HEADING .headingmainline a.mainlink {
- border-bottom: #aaa 1px solid;
+ font-size: large; color: navy;
}
li.item_HEADING .headingmainline a.mainlink:hover {
unique_together = (('course', 'term', 'owner'))
def __unicode__(self):
- return u'%s %s %s' % (self.course, self.term, self.owner)
+ return u'%s: %s (%s, %s)' % (
+ self.course.code, self.course.name,
+ self.owner.last_name or self.owner.username,
+ self.term)
def list_display(self):
if self.code:
for item in items:
dct.setdefault(item.parent_heading, []).append(item)
for lst in dct.values():
- lst.sort(key=lambda item: item.sort_order) # sort in place
+ # TODO: what's the sort order?
+ lst.sort(key=lambda item: (item.item_type=='HEADING', item.title)) # sort in place
# walk the tree
out = []
def walk(parent, accum):
return Membership.objects.filter(group__site=self)
def get_students(self):
- return self.memberships(role='STUDT').order_by(
+ return self.members().filter(role='STUDT').order_by(
'user__last_name', 'user__first_name')
def get_instructors(self):
- return self.memberships(role='INSTR').order_by(
+ return self.members().filter(role='INSTR').order_by(
'user__last_name', 'user__first_name')
def can_edit(self, user):
if user.id == self.owner_id:
return True
try:
- mbr = self.members.get(user=user)
+ mbr = self.members().get(user=user)
except Member.DoesNotExist:
return False
return mbr.role in (u'INSTR', u'ASSIST')
def is_member(self, user):
assert user
return user.id == self.owner_id \
- or self.members.filter(user=user).exists()
+ or self.members().filter(user=user).exists()
#------------------------------------------------------------
# User membership in sites
# I use a raw SQL query here because I want the lookup to be as
# fast as possible. Caching would help too, but let's try this
# first. (todo, review later.)
+ return True # TODO: fixme!!!!
query = ('select count(*) from syrup_member '
'where user_id=%s and site_id=%s ')
if where:
if request.method != 'POST':
item = models.Item() # dummy object
- metadata_formset = metadata_formset_class(queryset=item.metadata_set.all())
return g.render('item/item_add_%s.xhtml' % item_type.lower(),
**locals())
else:
# fixme, this will need refactoring. But not yet.
author = request.user.get_full_name() or request.user.username
item = models.Item() # dummy object
- metadata_formset = metadata_formset_class(request.POST, queryset=item.metadata_set.all())
- assert metadata_formset.is_valid()
- def do_metadata(item):
- for obj in [obj for obj in metadata_formset.cleaned_data if obj]: # ignore empty dicts
- if not obj.get('DELETE'):
- item.metadata_set.create(name=obj['name'], value=obj['value'])
if item_type == 'HEADING':
title = request.POST.get('title', '').strip()
item = models.Item(
site=site,
item_type='HEADING',
- sort_order = next_order,
parent_heading=parent_item,
title=title,
)
item.save()
- do_metadata(item)
- item.save()
elif item_type == 'URL':
title = request.POST.get('title', '').strip()
url = request.POST.get('url', '').strip()
site=site,
item_type='URL',
parent_heading=parent_item,
- sort_order = next_order,
title=title,
url = url)
item.save()
- do_metadata(item)
- item.save()
elif item_type == 'ELEC':
title = request.POST.get('title', '').strip()
upload = request.FILES.get('file')
site=site,
item_type='ELEC',
parent_heading=parent_item,
- sort_order = next_order,
title=title,
fileobj_mimetype = upload.content_type,
)
item.fileobj.save(upload.name, upload)
item.save()
- do_metadata(item)
- item.save()
else:
raise NotImplementedError
site = parent_item.site
siblings = site.item_set.filter(parent_heading=parent_item)
- try:
- next_order = 1 + max(i.sort_order for i in siblings)
- except:
- next_order = 0
-
#----------
if request.method != 'POST':
else:
dct = dict(item_type='PHYS')
- item = site.item_set.create(parent_heading=parent_item,
- sort_order=next_order,
- title=dublin.get('dc:title','Untitled'),
- **dct)
- item.save()
+ try:
+ pubdate = dublin.get('dc:date')
+ pubdate = re.search('^([0-9]+)', pubdate).group(1)
+ pubdate = '%d-01-01' % int(pubdate)
+ except:
+ pubdate = None
- for dc, value in dublin.items():
- md = item.metadata_set.create(item=item, name=dc, value=value)
- # store the whole darn MARC-dict as well (JSON)
- item.metadata_set.create(item=item, name='syrup:marc', value=raw_pickitem)
+ item = site.item_set.create(parent_heading=parent_item,
+ title=dublin.get('dc:title','Untitled'),
+ author=dublin.get('dc:creator'),
+ publisher=dublin.get('dc:publisher',''),
+ published=pubdate,
+ **dct)
item.save()
return HttpResponseRedirect('../../../%d/meta' % item.id)
parent_item = item.parent_heading
if request.method != 'POST':
- metadata_formset = metadata_formset_class(queryset=item.metadata_set.all())
return g.render(template, **locals())
else:
- metadata_formset = metadata_formset_class(request.POST, queryset=item.metadata_set.all())
- assert metadata_formset.is_valid()
if 'file' in request.FILES:
# this is a 'replace-current-file' action.
upload = request.FILES.get('file')
else:
# generally update the item.
[setattr(item, k, v) for (k,v) in request.POST.items()]
- # generally update the metadata
- item.metadata_set.all().delete()
- for obj in [obj for obj in metadata_formset.cleaned_data if obj]: # ignore empty dicts
- if not obj.get('DELETE'):
- item.metadata_set.create(name=obj['name'], value=obj['value'])
item.save()
return HttpResponseRedirect(item.parent_url())
# get at the ints.
new_order = [int(n.split('_')[1]) for n in new_order]
print >> sys.stderr, new_order
- the_items = list(site.item_set.filter(parent_heading=parent_heading).order_by('sort_order'))
+ # TODO .orderBy, now there is no sort_order.
+ the_items = list(site.item_set.filter(parent_heading=parent_heading))
# sort the items by position in new_order
the_items.sort(key=lambda item: new_order.index(item.id))
for newnum, item in enumerate(the_items):
access = POST.get('access')
site.access = access
# drop all provided users. fixme, this could be optimized to do add/drops.
- models.Membership.objects.filter(site=site, provided=True).delete()
+ #models.Membership.objects.filter(site=site, provided=True).delete()
if site.access == u'STUDT':
initial_sections = site.sections()
# add the 'new section' if any
<?python
-title = _('Browse the Reserves')
+title = _('All Reserves, by Department')
+
+sites = models.Site.objects.order_by('course__department__name', 'course__code', 'owner__last_name').select_related()
+blocks = itertools.groupby(sites, lambda s: s.course.department)
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
</head>
<body>
<h1>${title}</h1>
- (Note: some reserve materials may require you
+ <div py:if="user.is_anonymous()">
+ (Note: some reserve materials may require you
to <a href="${ROOT}/accounts/login/?next=${ROOT}/">log in</a>)
+ </div>
+
+
+ <div py:for="(dept, ss) in blocks">
+ <h2>${dept}</h2>
+ <p py:for="site in ss" style="margin-left: 16px;">
+ <a href="${site.site_url()}">${site}</a>
+ </p>
+
+ </div>
+
+ <div style="background-color: #dcc; margin: 16px; padding: 8px;">
<h2>Choose from one of the options below:</h2>
<div class="itemadd">
<ul>
href="departments">Browse by Department</a></li>
</ul>
</div>
+ </div>
<div class="gap"/>
</body>
</html>
<div py:def="site_banner(site)" py:strip="True">
<div id="sitebanner">
${site_search(site)}
- <div class="deptident">${site.department}</div>
- <h1><a href="${site.site_url()}"><span py:if="site.code">${site.code}: </span>${site.title}</a></h1>
+ <div class="deptident">${site.course.department} • ${site.term.name}</div>
+ <h1><a href="${site.site_url()}"><span py:if="site.course">${site.course.code}: </span>${site.course.name}</a></h1>
</div>
</div>
<?python
title = _('Edit site permissions')
-instructors = [m for m in models.Member.objects.filter(site=site) if m.role in ('PROXY', 'INSTR')]
+instructors = site.get_instructors()
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
</div>
<div id="STUDT_panel" class="specific">
<h3>Course section numbers</h3>
- <?python
- current_sections = course.sections()
- my_sections = [s for s in models.campus.sections_taught_by(user.username) if not s in current_sections]
- ct_sections = [s for s in models.campus.sections_for_code_and_term(course.code, course.term.code) \
- if not s in current_sections]
- encode = lambda t,c,s: models.section_encode_safe((t,c,s))
- ?>
- <table class="pagetable">
- <thead>
- <tr>
- <th>Associated section</th><th>Remove?</th>
- </tr>
- </thead>
- <tbody>
- <tr py:for="(term, code, sec) in current_sections">
- <td>${code}, section ${sec}, in term ${term}</td>
- <td><input type="checkbox" name="remove_section_${encode(term,code,sec)}"/></td>
- </tr>
- </tbody>
- </table>
- <p>Add section:
- <select name="add_section">
- <option value="">--------</option>
- <optgroup py:for="label, sections in ((_('My Courses'), my_sections), (_('%s in term %s') % (course.code, course.term), ct_sections))"
- label="${label}" py:if="sections">
- <option py:for="(term, code, sec) in sections"
- value="${encode(term,code,sec)}">
- ${code}, section ${sec}, in term ${term}
- </option>
- </optgroup>
- </select>
- </p>
+ <p>Not implemented yet.</p>
</div>
<p><input type="submit" name="action_save_student" value="Save changes to student access"/></p>
<?python
is_edit = bool(item.id)
title = is_edit and _('Edit an electronic document') or _('Add a new electronic document')
-site_title = '%s: %s (%s)' % (site.code, site.title, site.term)
+site.title = '%s: %s (%s)' % (site.course.code, site.course.name, site.term)
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
<script type="text/javascript">
$(function() {$('input[name="title"]').focus();});
</script>
- ${item_metadata_formset_header()}
</head>
<body>
${site_banner(site)}
value="${item.title}"/></td></tr>
<tr><th>File</th><td><input type="file" name="file"/></td></tr>
</table>
- ${item_metadata_formset()}
<p><input type="submit" value="Upload file and Create item"/>
${go_back_link()}
</p>
<table class="metadata_table">
<tr><th>Title of document</th><td><input type="text" name="title"
value="${item.title}"/></td></tr>
+ <tr><th>Author</th><td><input type="text" name="author"
+ value="${item.author}"/></td></tr>
+ <tr><th>Publisher</th><td><input type="text" name="publisher"
+ value="${item.publisher}"/></td></tr>
+ <tr><th>Published</th><td><input type="text" name="published"
+ value="${item.published}"/></td></tr>
</table>
- ${item_metadata_formset()}
<p><input type="submit" value="Update title and metadata"/></p>
</form>
<h2>File contents</h2>
<?python
is_edit = bool(item.id)
title = is_edit and _('Edit a subheading') or _('Add a new subheading')
-site_title = '%s: %s (%s)' % (site.code, site.title, site.term)
+site.title = '%s: %s (%s)' % (site.course.code, site.course.name, site.term)
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
<script type="text/javascript">
$(function() {$('input[name="title"]').focus();});
</script>
- ${item_metadata_formset_header()}
</head>
<body>
${site_banner(site)}
value="${item.title}"/>
</td></tr>
</table>
- ${item_metadata_formset()}
<p>
<input py:if="not is_edit" type="submit" value="Add heading"/>
<input py:if="is_edit" type="submit" value="Update heading"/>
<?python
is_edit = bool(item.id)
title = is_edit and _('Edit a physical-item request') or _('Add a physical-item request')
-site_title = '%s: %s (%s)' % (site.code, site.title, site.term)
+site.title = '%s: %s (%s)' % (site.course.code, site.course.name, site.term)
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
${nested_title(parent_item)}
<div id="sidepanel">${offer_to_delete(item)}</div>
<h2>${title}</h2>
-
<form action=".?item_type=${item_type}" method="POST">
<table class="metadata_table">
<tr>
</tr>
</table>
<h2>Metadata</h2>
- ${item_metadata_formset(show_more=False)}
<p>
<input py:if="not is_edit" type="submit" value="Add heading"/>
<input py:if="is_edit" type="submit" value="Update physical-item request"/>
<?python
is_edit = bool(item.id)
title = is_edit and _('Edit a URL') or _('Add a new URL')
-site_title = '%s: %s (%s)' % (site.code, site.title, site.term)
+site.title = '%s: %s (%s)' % (site.course.code, site.course.name, site.term)
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
<script type="text/javascript">
$(function() {$('input[name="title"]').focus();});
</script>
- ${item_metadata_formset_header()}
</head>
<body>
${site_banner(site)}
<tr><th>Title</th><td><input type="text" name="title" value="${item.title}"/></td></tr>
<tr><th>URL</th><td><input type="text" name="url" value="${item.url}"/></td></tr>
</table>
- ${item_metadata_formset()}
<p>
<input py:if="not is_edit" type="submit" value="Add URL"/>
<input py:if="is_edit" type="submit" value="Update URL"/>
<?python
-site_title = '%s: %s (%s)' % (site.code, site.title, site.term)
+site_title = '%s: %s (%s)' % (site.course.code, site.course.name, site.term)
hier = item.hierarchy()[:-1]
if item.item_type == 'HEADING':
title = _('Delete this heading?')
else:
title = _('Delete this item?')
children = []
-metadata = item.metadata_set.all()
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
<?python
site = item.site
title = item.title
-site_title = '%s: %s (%s)' % (site.code, site.title, site.term)
+site_title = '%s: %s (%s)' % (site.course.code, site.course.name, site.term)
is_editor = site.can_edit(request.user)
item_tree = site.item_tree(subtree=item)
?>
<?python
from django.utils.simplejson import loads
-site_title = '%s: %s (%s)' % (site.code, site.title, site.term)
+site_title = '%s: %s (%s)' % (site.course.code, site.course.name, site.term)
hier = item.hierarchy()[:-1]
title = item.title
-smallint = item.smallint()
-metadata = item.metadata_set.all()
is_editor = site.can_edit(request.user)
?>
<html xmlns="http://www.w3.org/1999/xhtml"
py:with="avail, status = item.describe_physical_item_status()">
<th>Status</th><td><div class="${avail and 'available' or 'unavailable'}">${status}</div></td>
</tr>
- <tr py:if="smallint">
- <th>Small Number</th><td>${smallint}</td>
- </tr>
<tr py:if="item.url"><th>URL</th><td><a href="${item.url}">${item.url}</a></td></tr>
</table>
<div py:if="item.item_type=='ELEC'">
<tr><th/><td><a class="bigdownload" href="${item.item_url()}">Download</a></td></tr>
</table>
</div>
- <div py:if="metadata">
+ <h2>TODO: get metadata back...</h2>
+ <div py:if="False and metadata">
<h2 class="metadata_subhead">Additional metadata</h2>
<table class="metadata_table">
<tr py:for="attr in metadata">
<?python
-title = '%s: %s (%s)' % (site.code, site.title, site.term)
+title = '%s: %s (%s)' % (site.course.code, site.course.name, site.term)
item_tree = site.item_tree()
is_editor = site.can_edit(request.user)
is_joinable = site.is_joinable_by(request.user)