X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/ad64a2d9487bb320ea88efc58c8bd9cc42d9c71e..5913c54d19b8f6775633176032161d49f9b2f1aa:/apps/wiki/views.py?ds=inline diff --git a/apps/wiki/views.py b/apps/wiki/views.py deleted file mode 100644 index ea6fa8bd..00000000 --- a/apps/wiki/views.py +++ /dev/null @@ -1,81 +0,0 @@ -import os - -from django.conf import settings -from django.views.generic.simple import direct_to_template -from django.http import HttpResponse, Http404 -from django.utils import simplejson as json - -from wiki.models import storage, Document, DocumentNotFound -from wiki.forms import DocumentForm -from datetime import datetime - -# import google_diff -import difflib - - -class DateTimeEncoder(json.JSONEncoder): - def default(self, obj): - if isinstance(obj, datetime): - return datetime.ctime(obj) + " " + (datetime.tzname(obj) or 'GMT') - return json.JSONEncoder.default(self, obj) - -def document_list(request, template_name = 'wiki/document_list.html'): - return direct_to_template(request, template_name, extra_context = { - 'document_list': storage.all(), - }) - - -def document_detail(request, name, template_name = 'wiki/document_details.html'): - try: - document = storage.get(name) - except DocumentNotFound: - raise Http404 - -# access_time = datetime.ctime(); -# last_documents = request.session.get("wiki_last_docs", []) -# -# if name not in last_documents: -# last_documents.insert(0, (name, access_time)) - - if request.method == 'POST': - - form = DocumentForm(request.POST, instance = document) - if form.is_valid(): - document = form.save() - return HttpResponse(json.dumps({'text': document.plain_text, 'meta': document.meta(), 'revision': document.revision()})) - else: - return HttpResponse(json.dumps({'errors': form.errors})) - else: - form = DocumentForm(instance = document) - - return direct_to_template(request, template_name, extra_context = { - 'document': document, - 'form': form, - }) - - -def document_gallery(request, directory): - try: - base_dir = os.path.join(settings.MEDIA_ROOT, settings.FILEBROWSER_DIRECTORY, directory) - images = [u'%s%s%s/%s' % (settings.MEDIA_URL, settings.FILEBROWSER_DIRECTORY, directory, f) for f in os.listdir(base_dir) if os.path.splitext(f)[1].lower() in (u'.jpg', u'.jpeg', u'.png')] - images.sort() - return HttpResponse(json.dumps(images)) - except (IndexError, OSError), exc: - import traceback - traceback.print_exc() - - raise Http404 - -def document_diff(request, name, revA, revB): - differ = difflib.HtmlDiff(wrapcolumn=60) - - docA = storage.get(name, int(revA)) - docB = storage.get(name, int(revB)) - - return HttpResponse(differ.make_table( - docA.plain_text.splitlines(), - docB.plain_text.splitlines() ) ) - - -def document_history(reuqest, name): - return HttpResponse( json.dumps(storage.history(name), cls=DateTimeEncoder), mimetype='application/json')