2010-10-12 07:35:23 +08:00
|
|
|
"""
|
|
|
|
Belgium-specific Form helpers
|
|
|
|
"""
|
2011-10-18 08:47:49 +08:00
|
|
|
|
|
|
|
from __future__ import absolute_import
|
|
|
|
|
|
|
|
from django.contrib.localflavor.be.be_provinces import PROVINCE_CHOICES
|
|
|
|
from django.contrib.localflavor.be.be_regions import REGION_CHOICES
|
2010-10-12 07:35:23 +08:00
|
|
|
from django.forms.fields import RegexField, Select
|
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
|
2011-10-18 08:47:49 +08:00
|
|
|
|
2010-10-12 07:35:23 +08:00
|
|
|
class BEPostalCodeField(RegexField):
|
|
|
|
"""
|
|
|
|
A form field that validates its input as a belgium postal code.
|
2011-10-18 08:47:49 +08:00
|
|
|
|
2010-10-12 07:35:23 +08:00
|
|
|
Belgium postal code is a 4 digits string. The first digit indicates
|
|
|
|
the province (except for the 3ddd numbers that are shared by the
|
|
|
|
eastern part of Flemish Brabant and Limburg and the and 1ddd that
|
|
|
|
are shared by the Brussels Capital Region, the western part of
|
|
|
|
Flemish Brabant and Walloon Brabant)
|
|
|
|
"""
|
|
|
|
default_error_messages = {
|
|
|
|
'invalid': _(
|
|
|
|
'Enter a valid postal code in the range and format 1XXX - 9XXX.'),
|
|
|
|
}
|
|
|
|
|
2011-05-03 19:52:04 +08:00
|
|
|
def __init__(self, max_length=None, min_length=None, *args, **kwargs):
|
2010-10-12 07:35:23 +08:00
|
|
|
super(BEPostalCodeField, self).__init__(r'^[1-9]\d{3}$',
|
2011-05-03 19:52:04 +08:00
|
|
|
max_length, min_length, *args, **kwargs)
|
2010-10-12 07:35:23 +08:00
|
|
|
|
|
|
|
class BEPhoneNumberField(RegexField):
|
|
|
|
"""
|
|
|
|
A form field that validates its input as a belgium phone number.
|
|
|
|
|
|
|
|
Landlines have a seven-digit subscriber number and a one-digit area code,
|
2011-10-18 08:47:49 +08:00
|
|
|
while smaller cities have a six-digit subscriber number and a two-digit
|
|
|
|
area code. Cell phones have a six-digit subscriber number and a two-digit
|
2010-10-12 07:35:23 +08:00
|
|
|
area code preceeded by the number 4.
|
2011-10-18 08:47:49 +08:00
|
|
|
0d ddd dd dd, 0d/ddd.dd.dd, 0d.ddd.dd.dd,
|
2010-10-12 07:35:23 +08:00
|
|
|
0dddddddd - dialling a bigger city
|
2011-10-18 08:47:49 +08:00
|
|
|
0dd dd dd dd, 0dd/dd.dd.dd, 0dd.dd.dd.dd,
|
2010-10-12 07:35:23 +08:00
|
|
|
0dddddddd - dialling a smaller city
|
2011-10-18 08:47:49 +08:00
|
|
|
04dd ddd dd dd, 04dd/ddd.dd.dd,
|
2010-10-12 07:35:23 +08:00
|
|
|
04dd.ddd.dd.dd, 04ddddddddd - dialling a mobile number
|
|
|
|
"""
|
|
|
|
default_error_messages = {
|
|
|
|
'invalid': _('Enter a valid phone number in one of the formats '
|
|
|
|
'0x xxx xx xx, 0xx xx xx xx, 04xx xx xx xx, '
|
|
|
|
'0x/xxx.xx.xx, 0xx/xx.xx.xx, 04xx/xx.xx.xx, '
|
|
|
|
'0x.xxx.xx.xx, 0xx.xx.xx.xx, 04xx.xx.xx.xx, '
|
|
|
|
'0xxxxxxxx or 04xxxxxxxx.'),
|
|
|
|
}
|
|
|
|
|
2011-05-03 19:52:04 +08:00
|
|
|
def __init__(self, max_length=None, min_length=None, *args, **kwargs):
|
2010-10-12 07:35:23 +08:00
|
|
|
super(BEPhoneNumberField, self).__init__(r'^[0]\d{1}[/. ]?\d{3}[. ]\d{2}[. ]?\d{2}$|^[0]\d{2}[/. ]?\d{2}[. ]?\d{2}[. ]?\d{2}$|^[0][4]\d{2}[/. ]?\d{2}[. ]?\d{2}[. ]?\d{2}$',
|
2011-05-03 19:52:04 +08:00
|
|
|
max_length, min_length, *args, **kwargs)
|
2010-10-12 07:35:23 +08:00
|
|
|
|
|
|
|
class BERegionSelect(Select):
|
|
|
|
"""
|
|
|
|
A Select widget that uses a list of belgium regions as its choices.
|
|
|
|
"""
|
|
|
|
def __init__(self, attrs=None):
|
|
|
|
super(BERegionSelect, self).__init__(attrs, choices=REGION_CHOICES)
|
|
|
|
|
|
|
|
class BEProvinceSelect(Select):
|
|
|
|
"""
|
|
|
|
A Select widget that uses a list of belgium provinces as its choices.
|
|
|
|
"""
|
|
|
|
def __init__(self, attrs=None):
|
|
|
|
super(BEProvinceSelect, self).__init__(attrs, choices=PROVINCE_CHOICES)
|