Order submitter and supporter fields by full name in ApplicationManagerForm.

This commit is contained in:
Emanuel Schuetze 2011-11-01 06:47:10 +01:00
parent 66c078b333
commit a23164a906
2 changed files with 24 additions and 2 deletions

View File

@ -10,12 +10,30 @@
:license: GNU GPL, see LICENSE for more details. :license: GNU GPL, see LICENSE for more details.
""" """
from django.forms import ModelForm, Form, CharField, Textarea, TextInput from django.forms import ModelForm, Form, CharField, Textarea, TextInput, ModelMultipleChoiceField, ModelChoiceField
from django.contrib.auth.models import User
from django.utils.translation import ugettext as _ from django.utils.translation import ugettext as _
from openslides.application.models import Application from openslides.application.models import Application
class UserModelChoiceField(ModelChoiceField):
"""
Extend ModelChoiceField for users so that the choices are
listed as 'first_name last_name' instead of just 'username'.
"""
def label_from_instance(self, obj):
return obj.get_full_name()
class UserModelMultipleChoiceField(ModelMultipleChoiceField):
"""
Extend ModelMultipleChoiceField for users so that the choices are
listed as 'first_name last_name' instead of just 'username'.
"""
def label_from_instance(self, obj):
return obj.get_full_name()
class ApplicationForm(Form): class ApplicationForm(Form):
error_css_class = 'error' error_css_class = 'error'
required_css_class = 'required' required_css_class = 'required'
@ -29,6 +47,10 @@ class ApplicationManagerForm(ModelForm):
error_css_class = 'error' error_css_class = 'error'
required_css_class = 'required' required_css_class = 'required'
users = User.objects.all().exclude(profile=None).order_by("first_name")
submitter = UserModelChoiceField(queryset=users, label=_("Submitter"))
supporter = UserModelMultipleChoiceField(queryset=users, label=_("Supporters"))
class Meta: class Meta:
model = Application model = Application
exclude = ('number', 'status', 'permitted', 'log') exclude = ('number', 'status', 'permitted', 'log')

View File

@ -75,7 +75,7 @@ def view(request, application_id, newest=False):
version = application.public_version version = application.public_version
revisions = application.versions revisions = application.versions
actions = application.get_allowed_actions(user=request.user) actions = application.get_allowed_actions(user=request.user)
return { return {
'application': application, 'application': application,
'revisions': revisions, 'revisions': revisions,