from django.forms.util import ErrorList
+import wlrepo
+
#
# Some useful decorators
def with_repo(view):
"""Open a repository for this view"""
def view_with_repo(request, *args, **kwargs):
- kwargs['repo'] = hg.Repository(settings.REPOSITORY_PATH)
+ kwargs['repo'] = wlrepo.MercurialLibrary(settings.REPOSITORY_PATH)
return view(request, *args, **kwargs)
return view_with_repo
# View all files
#
@with_repo
-def file_list(request, repo):
- #
- latest_default = repo.get_branch_tip('default')
-
- fl = []
- for file in repo.repo[latest_default]:
- m = re.match(u'^pub_([^/]+).xml$', file.decode('utf-8'), re.UNICODE)
- if m is not None:
- fl.append(m.group(1))
-
- bookform = forms.BookUploadForm()
-
+def file_list(request, repo):
+ import api.forms
+ bookform = api.forms.DocumentUploadForm()
return direct_to_template(request, 'explorer/file_list.html', extra_context={
- 'files': fl, 'bookform': bookform,
+ 'files': repo.documents(), 'bookform': bookform,
})
@permission_required('explorer.can_add_files')
print "validating sform"
if sform.is_valid():
valid = True
- if sform.cleaned_data['autoxml']:
- print "validating dcform"
- valid = dcform.is_valid()
+# if sform.cleaned_data['autoxml']:
+# print "validating dcform"
+# valid = dcform.is_valid()
print "valid is ", valid
+
if valid:
uri = path + '$' + sform.cleaned_data['partname']
child_rpath = file_path(uri)
fulltext = sform.cleaned_data['fulltext']
fulltext = fulltext.replace(u'<include-tag-placeholder />',
- librarian.xinclude_forURI('wlrepo://'+uri) )
+ librarian.xinclude_forURI(u'wlrepo://'+uri) )
repo._write_file(rpath, fulltext.encode('utf-8'))
if sform.cleaned_data['autoxml']:
# this is a horrible hack - really
bi = dcparser.BookInfo.from_element(librarian.DEFAULT_BOOKINFO.to_etree())
- bi.update(dcform.cleaned_data)
+ bi.update(dcform.data)
newtext = librarian.wrap_text(newtext, \
unicode(date.today()), bookinfo=bi )
if repo.in_branch(split_action, file_branch(path, request.user)):
# redirect to success
+ import urllib
+ uri = urllib.quote( unicode(uri).encode('utf-8'))
return HttpResponseRedirect( reverse('split-success',\
- kwargs={'path': path})+'?child='+uri)
+ kwargs={'path': path})+'?child='+uri )
else:
try: # to read the current DC
repo = hg.Repository(settings.REPOSITORY_PATH)