X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=influences%2Fviews.py;h=7f7b2621f918a588e03e7e356853b0d45514ffb7;hb=dec395df81b874a8b88e34935712f9265d412eef;hp=85124e4c0c6c98b5377f6b21ef3b2315b980fd22;hpb=0b494d055e958c91e98cc4bd2823e035bc140860;p=matthijs%2Fprojects%2Fxerxes.git diff --git a/influences/views.py b/influences/views.py index 85124e4..7f7b262 100644 --- a/influences/views.py +++ b/influences/views.py @@ -1,30 +1,22 @@ +from django import forms from django.contrib.auth.decorators import login_required from django.shortcuts import render_to_response from django.shortcuts import get_object_or_404 from django.template import RequestContext from django.utils.translation import ugettext as _ from django.contrib.auth.models import User +from django.contrib.contenttypes.models import ContentType from django.core.urlresolvers import reverse from django.http import HttpResponseRedirect, HttpResponseForbidden from django.views.generic.list_detail import object_detail, object_list -from ee.influences.models import Character -from ee.influences.models import Influence -from ee.tools.forms import ContextModelForm - - - -class InfluenceForm(ContextModelForm): - class Meta: - model = Influence - fields = ('character', 'contact', 'summary', 'description') - -class CharacterForm(ContextModelForm): - class Meta: - model = Character - fields = ('name') +from threadedcomments.models import ThreadedComment +from threadedcomments.views import free_comment, _preview +from xerxes.influences.models import Character +from xerxes.influences.models import Influence +from forms import get_influence_comment_form, InfluenceForm, CharacterForm @login_required -def add(request, character_id=None): +def add_influence(request, character_id=None): initial = {} # Get the current user's characters chars = request.user.character_set.all() @@ -50,10 +42,10 @@ def add(request, character_id=None): # Redirect to the just saved influence return HttpResponseRedirect(reverse('influences_influence_detail', args=[influence.id])) - return render_to_response('influences/add.html', {'form' : f}, RequestContext(request)) + return render_to_response('influences/add_influence.html', {'form' : f}, RequestContext(request)) @login_required -def addCharacter(request): +def add_character(request): f = CharacterForm(request=request) if (f.is_valid()): character = f.save(commit=False) @@ -87,7 +79,7 @@ def character_list(request): def character_detail(request, object_id): o = Character.objects.get(pk=object_id) # Don't show other player's characters - if (o.player != request.user): + if (not request.user.is_staff and o.player != request.user): return HttpResponseForbidden("Forbidden -- Trying to view somebody else's character") return render_to_response('influences/character_detail.html', {'object' : o}, RequestContext(request)) @@ -97,12 +89,53 @@ def influence_list(request): os = Influence.objects.filter(character__player=request.user) return render_to_response('influences/influence_list.html', {'object_list' : os}, RequestContext(request)) +def influence_comment_preview(request, context_processors, extra_context, **kwargs): + # Use a custom template + kwargs['template'] = 'influences/influence_comment_preview.html' + # The object to be show in the influence detail + extra_context['object'] = get_object_or_404(Influence, pk=kwargs['object_id']) + return _preview(request, context_processors, extra_context, **kwargs) + @login_required def influence_detail(request, object_id): + o = Influence.objects.get(pk=object_id) # Don't show other player's influences - if (o.character.player != request.user): + if (not request.user.is_staff and o.character.player != request.user): return HttpResponseForbidden("Forbidden -- Trying to view influences of somebody else's character") - return render_to_response('influences/influence_detail.html', {'object' : o}, RequestContext(request)) + + # Show all comments to staff, but only public comments to other + # users + comments = o.get_comments(private=request.user.is_staff) + + context = { + 'object' : o, + 'comments' : comments, + 'comment_form' : get_influence_comment_form(request.user.is_staff, None)() + } + return render_to_response('influences/influence_detail.html', context, RequestContext(request)) + +@login_required +def influence_comment(request, object_id, parent_id=None): + kwargs = {} + # Add the content_type, since we don't put in in the url explicitly + kwargs['content_type'] = ContentType.objects.get_for_model(Influence).id + # Find the comment to which we're replying, so we can get the right form for it. + if parent_id: + reply_to = get_object_or_404(ThreadedComment, id=parent_id) + else: + reply_to = None + + # Find the right form class + kwargs['form_class'] = get_influence_comment_form(request.user.is_staff, reply_to) + # Override the model, so we don't get a free comment, but a normal + # one. We can't use threadedcomments' comment view for that, since + # that hardcodes the form_class. + kwargs['model'] = ThreadedComment + # Set a custom preview view + kwargs['preview'] = influence_comment_preview + if parent_id: + kwargs['prefix'] = "reply-to-%s" % (parent_id) + return free_comment(request, object_id=object_id, parent_id=parent_id, **kwargs) # vim: set sts=4 sw=4 expandtab: