-from portal.models import PendingUser
-from crispy_forms.helper import FormHelper
-from crispy_forms.layout import Submit
-
-class RegisterUserForm(forms.ModelForm):
- def __init__(self, *args, **kwargs):
- self.helper = FormHelper()
- self.helper.form_tag = False
- #self.helper.form_id = 'id-exampleForm'
- self.helper.form_class = 'blueForms'
- self.helper.form_method = 'post'
- #self.helper.form_action = 'submit_survey'
- self.helper.add_input(Submit('submit', 'Submit'))
- super(RegisterUserForm, self).__init__(*args, **kwargs)
-
- first_name = forms.CharField( widget=forms.TextInput )
- last_name = forms.CharField( widget=forms.TextInput )
- email = forms.CharField( widget=forms.TextInput )
- password = forms.CharField( widget=forms.PasswordInput )
- password2 = forms.CharField( widget=forms.PasswordInput )
- keypair = forms.CharField( widget=forms.PasswordInput )
- #keypair = forms.CharField( widget=forms.FileInput )
- class Meta:
- model = PendingUser
+from portal.models import PendingUser, PendingSlice
+#from crispy_forms.helper import FormHelper
+#from crispy_forms.layout import Submit
+from django.utils.translation import ugettext_lazy as _
+
+class UserRegisterForm(forms.Form): # Not ModelForm
+ """
+ Form for registering a new user account.
+
+ Validates that the requested username is not already in use, and
+ requires the password to be entered twice to catch typos.
+
+ Subclasses should feel free to add any additional validation they
+ need, but should avoid defining a ``save()`` method -- the actual
+ saving of collected user data is delegated to the active
+ registration backend.
+
+ """
+ required_css_class = 'required'
+
+ first_name = forms.RegexField(regex=r'^[\w.@+-]+$',
+ max_length=30,
+ label=_("First name"),
+ error_messages={'invalid': _("This value may contain only letters, numbers and @/./+/-/_ characters.")})
+ last_name = forms.RegexField(regex=r'^[\w.@+-]+$',
+ max_length=30,
+ label=_("Last name"),
+ error_messages={'invalid': _("This value may contain only letters, numbers and @/./+/-/_ characters.")})
+ affiliation = forms.RegexField(regex=r'^[\w.@+-]+$',
+ max_length=30,
+ label=_("Affiliation"),
+ error_messages={'invalid': _("This value may contain only letters, numbers and @/./+/-/_ characters.")})
+
+ email = forms.EmailField(label=_("E-mail"))
+ password1 = forms.CharField(widget=forms.PasswordInput,
+ label=_("Password"))
+ password2 = forms.CharField(widget=forms.PasswordInput,
+ label=_("Password (again)"))
+ keypair = forms.CharField( widget=forms.FileInput )
+
+ tos = forms.BooleanField(widget=forms.CheckboxInput,
+ label=_(u'I have read and agree to the Terms of Service'),
+ error_messages={'required': _("You must agree to the terms to register")})
+
+# def clean_username(self):
+# """
+# Validate that the username is alphanumeric and is not already
+# in use.
+#
+# """
+# existing = User.objects.filter(username__iexact=self.cleaned_data['username'])
+# if existing.exists():
+# raise forms.ValidationError(_("A user with that username already exists."))
+# else:
+# return self.cleaned_data['username']