X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=influences%2Fviews.py;h=3b26dac9d3f2b0b9d8959141adc3129d07223fef;hb=8fb8f376fcd56a83ed1a0d87ee2863bdf465eef9;hp=1c7edb44753aa0dec03275fc869373a3883930c5;hpb=c5cbeefd03ddece1d37e966ad0b6f56ece29113f;p=matthijs%2Fprojects%2Fxerxes.git diff --git a/influences/views.py b/influences/views.py index 1c7edb4..3b26dac 100644 --- a/influences/views.py +++ b/influences/views.py @@ -1,29 +1,53 @@ from django.shortcuts import render_to_response from django.shortcuts import get_object_or_404 -from django import newforms as forms from django.utils.translation import ugettext as _ +from django.contrib.auth.models import User from ee.influences.models import Character from ee.influences.models import Influence +from ee.tools.forms import ContextModelForm -class InfluenceForm(forms.ModelForm): - class Meta: - model = Influence - fields = ('character', 'contact', 'description') +class InfluenceForm(ContextModelForm): + class Meta: + model = Influence + fields = ('character', 'contact', 'description') + +class CharacterForm(ContextModelForm): + class Meta: + model = Character + fields = ('name') def add(request, character_id): - message = None - - if (request.method == "POST"): - f = InfluenceForm(request.POST) - if (f.is_valid()): - f.save() - message = _("Influence added.") - f = None - else: - f = InfluenceForm() - - if f: - # Only allow characters of the current user - f.fields['character']._set_queryset(request.user.character_set.all()) - - return render_to_response('influences/character_addinfluence.html', {'message' : message, 'form' : f}) + message = None + + initial = {} + if (character_id): + initial['character'] = character_id + + f = InfluenceForm(request=request, initial=initial) + if (f.is_valid()): + f.save() + message = _("Influence added.") + f = None + + if f: + # Only allow characters of the current user + f.fields['character']._set_queryset(request.user.character_set.all()) + + return render_to_response('influences/add.html', {'message' : message, 'form' : f}) + +def addCharacter(request): + message = None + f = CharacterForm(request=request) + if (f.is_valid()): + c = f.save(commit=False) + c.player = request.user + c.save() + message = _("Character added.") + f = None + + return render_to_response('influences/add_character.html', {'message' : message, 'form' : f}) + +def index(request): + characters = request.user.character_set.all() + influences = Influence.objects.filter(character__in=characters) + return render_to_response('influences/index.html', {'characters' : characters, 'influences' : influences})