2007-02-16 05:26:43 +08:00
|
|
|
"""
|
|
|
|
UK-specific Form helpers
|
|
|
|
"""
|
|
|
|
|
2007-12-19 12:43:47 +08:00
|
|
|
import re
|
|
|
|
|
|
|
|
from django.newforms.fields import CharField, Select
|
|
|
|
from django.newforms import ValidationError
|
2008-06-18 21:10:05 +08:00
|
|
|
from django.utils.translation import ugettext_lazy as _
|
2007-02-16 05:26:43 +08:00
|
|
|
|
2007-12-19 12:43:47 +08:00
|
|
|
class UKPostcodeField(CharField):
|
2007-02-16 05:26:43 +08:00
|
|
|
"""
|
|
|
|
A form field that validates its input is a UK postcode.
|
|
|
|
|
|
|
|
The regular expression used is sourced from the schema for British Standard
|
|
|
|
BS7666 address types: http://www.govtalk.gov.uk/gdsc/schemas/bs7666-v2-0.xsd
|
2007-12-19 12:43:47 +08:00
|
|
|
|
|
|
|
The value is uppercased and a space added in the correct place, if required.
|
2007-02-16 05:26:43 +08:00
|
|
|
"""
|
2007-12-17 16:05:27 +08:00
|
|
|
default_error_messages = {
|
2008-06-18 21:10:05 +08:00
|
|
|
'invalid': _(u'Enter a valid postcode.'),
|
2007-12-17 16:05:27 +08:00
|
|
|
}
|
2007-12-19 12:43:47 +08:00
|
|
|
outcode_pattern = '[A-PR-UWYZ]([0-9]{1,2}|([A-HIK-Y][0-9](|[0-9]|[ABEHMNPRVWXY]))|[0-9][A-HJKSTUW])'
|
|
|
|
incode_pattern = '[0-9][ABD-HJLNP-UW-Z]{2}'
|
|
|
|
postcode_regex = re.compile(r'^(GIR 0AA|%s %s)$' % (outcode_pattern, incode_pattern))
|
|
|
|
space_regex = re.compile(r' *(%s)$' % incode_pattern)
|
2007-12-17 16:05:27 +08:00
|
|
|
|
2007-12-19 12:43:47 +08:00
|
|
|
def clean(self, value):
|
|
|
|
value = super(UKPostcodeField, self).clean(value)
|
|
|
|
if value == u'':
|
|
|
|
return value
|
|
|
|
postcode = value.upper().strip()
|
|
|
|
# Put a single space before the incode (second part).
|
|
|
|
postcode = self.space_regex.sub(r' \1', postcode)
|
|
|
|
if not self.postcode_regex.search(postcode):
|
|
|
|
raise ValidationError(self.default_error_messages['invalid'])
|
|
|
|
return postcode
|
2007-12-03 08:35:31 +08:00
|
|
|
|
|
|
|
class UKCountySelect(Select):
|
|
|
|
"""
|
|
|
|
A Select widget that uses a list of UK Counties/Regions as its choices.
|
|
|
|
"""
|
|
|
|
def __init__(self, attrs=None):
|
|
|
|
from uk_regions import UK_REGION_CHOICES
|
|
|
|
super(UKCountySelect, self).__init__(attrs, choices=UK_REGION_CHOICES)
|
|
|
|
|
|
|
|
class UKNationSelect(Select):
|
|
|
|
"""
|
|
|
|
A Select widget that uses a list of UK Nations as its choices.
|
|
|
|
"""
|
|
|
|
def __init__(self, attrs=None):
|
|
|
|
from uk_regions import UK_NATIONS_CHOICES
|
|
|
|
super(UKNationSelect, self).__init__(attrs, choices=UK_NATIONS_CHOICES)
|