Files
@ 2aae2af55dea
Branch filter:
Location: symposion_app/vendor/symposion/teams/forms.py - annotation
2aae2af55dea
2.0 KiB
text/x-python
Disable client-side validation on credit_note forms
* HTML5 browsers have some clevers to do client-side validation of
forms
* Django activates this by default for certain field types
* However, in this case, there are three forms on this page. We rely
on two of them being invalid in order to figure out what processing
to do.
* So we need to disable the client-side validation.
* HTML5 browsers have some clevers to do client-side validation of
forms
* Django activates this by default for certain field types
* However, in this case, there are three forms on this page. We rely
on two of them being invalid in order to figure out what processing
to do.
* So we need to disable the client-side validation.
4272c8f8a8b4 4272c8f8a8b4 cee36ad983e5 cee36ad983e5 3207621058b8 cee36ad983e5 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 36ab6d599ffc fb5eaea880cb fb5eaea880cb 3207621058b8 3207621058b8 3207621058b8 36ab6d599ffc 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 36ab6d599ffc 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 36ab6d599ffc 4272c8f8a8b4 3207621058b8 36ab6d599ffc 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 36ab6d599ffc 3207621058b8 3207621058b8 36ab6d599ffc 4272c8f8a8b4 36ab6d599ffc 4272c8f8a8b4 3207621058b8 36ab6d599ffc 4272c8f8a8b4 3207621058b8 36ab6d599ffc 4272c8f8a8b4 4272c8f8a8b4 36ab6d599ffc 4272c8f8a8b4 36ab6d599ffc 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 4272c8f8a8b4 aad54984c5a8 aad54984c5a8 | from django import forms
from django.utils.html import escape
from django.utils.safestring import mark_safe
from django.utils.translation import ugettext_lazy as _
from django.contrib.auth.models import User
from symposion.teams.models import Membership
class TeamInvitationForm(forms.Form):
required_css_class = 'label-required'
email = forms.EmailField(label=_("Email"),
help_text=_("email address must be that of an account on this "
"conference site"))
def __init__(self, *args, **kwargs):
self.team = kwargs.pop("team")
super(TeamInvitationForm, self).__init__(*args, **kwargs)
def clean(self):
cleaned_data = super(TeamInvitationForm, self).clean()
email = cleaned_data.get("email")
if email is None:
raise forms.ValidationError(_("valid email address required"))
try:
user = User.objects.get(email=email)
except User.DoesNotExist:
# eventually we can invite them but for now assume they are
# already on the site
raise forms.ValidationError(
mark_safe(_("no account with email address <b>%s</b> found on this conference "
"site") % escape(email)))
state = self.team.get_state_for_user(user)
if state in ["member", "manager"]:
raise forms.ValidationError(_("user already in team"))
if state in ["invited"]:
raise forms.ValidationError(_("user already invited to team"))
self.user = user
self.state = state
return cleaned_data
def invite(self):
if self.state is None:
Membership.objects.create(team=self.team, user=self.user, state="invited")
elif self.state == "applied":
# if they applied we shortcut invitation process
membership = Membership.objects.filter(team=self.team, user=self.user)
membership.update(state="member")
|