view gpp/polls/forms.py @ 552:9e42e6618168

For bitbucket issue #2, tweak the admin settings for the Post model to reduce slow queries. Define our own queryset() method so we can control the select_related(), and not have it cascade from post to topics to forums to categories. Removed 'topic' from list_display because MySQL still sucked with 2 inner joins. Now it seems to be tolerable with only one join to User.
author Brian Neal <bgneal@gmail.com>
date Wed, 25 Jan 2012 20:07:03 -0600
parents 1f139de929c4
children
line wrap: on
line source
"""Forms for the Polls application."""

from django import forms
from django.db.models import F

from polls.models import Choice


class VoteForm(forms.Form):
    """Form for voting in a poll."""
    choices = forms.ModelChoiceField(label='', empty_label=None,
            queryset=Choice.objects.none(), widget=forms.RadioSelect)

    def __init__(self, poll, *args, **kwargs):
        self.user = kwargs.pop('user', None)
        self.user_choice = kwargs.pop('user_choice', None)
        super(VoteForm, self).__init__(*args, **kwargs)
        self.fields['choices'].queryset = poll.choice_set.all()

    def clean(self):
        if self.user_choice:
            raise forms.ValidationError("You've already voted in this poll!")
        return self.cleaned_data

    def save(self):
        choice = self.cleaned_data['choices']
        Choice.objects.filter(id=choice.id).update(votes=F('votes') + 1)
        choice.voters.add(self.user)