2007-03-31 17:05:54 +08:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
BR-specific Form helpers
|
|
|
|
"""
|
|
|
|
|
|
|
|
from django.newforms import ValidationError
|
2007-04-26 21:11:07 +08:00
|
|
|
from django.newforms.fields import Field, RegexField, CharField, Select, EMPTY_VALUES
|
2007-04-04 14:34:19 +08:00
|
|
|
from django.utils.encoding import smart_unicode
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
from django.utils.translation import ugettext
|
2007-03-31 17:05:54 +08:00
|
|
|
import re
|
|
|
|
|
|
|
|
phone_digits_re = re.compile(r'^(\d{2})[-\.]?(\d{4})[-\.]?(\d{4})$')
|
|
|
|
|
|
|
|
class BRZipCodeField(RegexField):
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super(BRZipCodeField, self).__init__(r'^\d{5}-\d{3}$',
|
|
|
|
max_length=None, min_length=None,
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
error_message=ugettext('Enter a zip code in the format XXXXX-XXX.'),
|
|
|
|
*args, **kwargs)
|
2007-03-31 17:05:54 +08:00
|
|
|
|
|
|
|
class BRPhoneNumberField(Field):
|
|
|
|
def clean(self, value):
|
|
|
|
super(BRPhoneNumberField, self).clean(value)
|
|
|
|
if value in EMPTY_VALUES:
|
|
|
|
return u''
|
|
|
|
value = re.sub('(\(|\)|\s+)', '', smart_unicode(value))
|
|
|
|
m = phone_digits_re.search(value)
|
|
|
|
if m:
|
|
|
|
return u'%s-%s-%s' % (m.group(1), m.group(2), m.group(3))
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
raise ValidationError(ugettext('Phone numbers must be in XX-XXXX-XXXX format.'))
|
2007-03-31 17:05:54 +08:00
|
|
|
|
|
|
|
class BRStateSelect(Select):
|
|
|
|
"""
|
2007-04-26 23:05:47 +08:00
|
|
|
A Select widget that uses a list of Brazilian states/territories
|
2007-03-31 17:05:54 +08:00
|
|
|
as its choices.
|
|
|
|
"""
|
|
|
|
def __init__(self, attrs=None):
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
from br_states import STATE_CHOICES
|
2007-03-31 17:05:54 +08:00
|
|
|
super(BRStateSelect, self).__init__(attrs, choices=STATE_CHOICES)
|
2007-04-26 21:11:07 +08:00
|
|
|
|
|
|
|
|
|
|
|
def DV_maker(v):
|
|
|
|
if v >= 2:
|
|
|
|
return 11 - v
|
|
|
|
return 0
|
|
|
|
|
|
|
|
class BRCPFField(CharField):
|
|
|
|
"""
|
|
|
|
This field validate a CPF number or a CPF string. A CPF number is
|
2007-04-26 23:05:47 +08:00
|
|
|
compounded by XXX.XXX.XXX-VD. The two last digits are check digits.
|
2007-04-26 21:11:07 +08:00
|
|
|
|
|
|
|
More information:
|
|
|
|
http://en.wikipedia.org/wiki/Cadastro_de_Pessoas_F%C3%ADsicas
|
|
|
|
"""
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super(BRCPFField, self).__init__(max_length=14, min_length=11, *args, **kwargs)
|
|
|
|
|
|
|
|
def clean(self, value):
|
|
|
|
"""
|
|
|
|
Value can be either a string in the format XXX.XXX.XXX-XX or an
|
|
|
|
11-digit number.
|
|
|
|
"""
|
|
|
|
value = super(BRCPFField, self).clean(value)
|
|
|
|
if value in EMPTY_VALUES:
|
|
|
|
return u''
|
|
|
|
orig_value = value[:]
|
|
|
|
if not value.isdigit():
|
|
|
|
value = re.sub("[-\.]", "", value)
|
|
|
|
try:
|
|
|
|
int(value)
|
|
|
|
except ValueError:
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
raise ValidationError(ugettext("This field requires only numbers."))
|
2007-04-26 21:11:07 +08:00
|
|
|
if len(value) != 11:
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
raise ValidationError(ugettext("This field requires at most 11 digits or 14 characters."))
|
2007-04-26 21:11:07 +08:00
|
|
|
orig_dv = value[-2:]
|
|
|
|
|
|
|
|
new_1dv = sum([i * int(value[idx]) for idx, i in enumerate(range(10, 1, -1))])
|
|
|
|
new_1dv = DV_maker(new_1dv % 11)
|
|
|
|
value = value[:-2] + str(new_1dv) + value[-1]
|
|
|
|
new_2dv = sum([i * int(value[idx]) for idx, i in enumerate(range(11, 1, -1))])
|
|
|
|
new_2dv = DV_maker(new_2dv % 11)
|
|
|
|
value = value[:-1] + str(new_2dv)
|
|
|
|
if value[-2:] != orig_dv:
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
raise ValidationError(ugettext("Invalid CPF number."))
|
2007-04-26 21:11:07 +08:00
|
|
|
|
|
|
|
return orig_value
|
|
|
|
|
|
|
|
class BRCNPJField(Field):
|
|
|
|
def clean(self, value):
|
|
|
|
"""
|
|
|
|
Value can be either a string in the format XX.XXX.XXX/XXXX-XX or a
|
|
|
|
group of 14 characters.
|
|
|
|
"""
|
|
|
|
value = super(BRCNPJField, self).clean(value)
|
|
|
|
if value in EMPTY_VALUES:
|
|
|
|
return u''
|
|
|
|
orig_value = value[:]
|
|
|
|
if not value.isdigit():
|
|
|
|
value = re.sub("[-/\.]", "", value)
|
|
|
|
try:
|
|
|
|
int(value)
|
|
|
|
except ValueError:
|
2007-04-26 23:05:47 +08:00
|
|
|
raise ValidationError("This field requires only numbers.")
|
2007-04-26 21:11:07 +08:00
|
|
|
if len(value) != 14:
|
|
|
|
raise ValidationError(
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
ugettext("This field requires at least 14 digits"))
|
2007-04-26 21:11:07 +08:00
|
|
|
orig_dv = value[-2:]
|
|
|
|
|
|
|
|
new_1dv = sum([i * int(value[idx]) for idx, i in enumerate(range(5, 1, -1) + range(9, 1, -1))])
|
|
|
|
new_1dv = DV_maker(new_1dv % 11)
|
|
|
|
value = value[:-2] + str(new_1dv) + value[-1]
|
|
|
|
new_2dv = sum([i * int(value[idx]) for idx, i in enumerate(range(6, 1, -1) + range(9, 1, -1))])
|
|
|
|
new_2dv = DV_maker(new_2dv % 11)
|
|
|
|
value = value[:-1] + str(new_2dv)
|
|
|
|
if value[-2:] != orig_dv:
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
raise ValidationError(ugettext("Invalid CNPJ number."))
|
2007-04-26 21:11:07 +08:00
|
|
|
|
|
|
|
return orig_value
|
|
|
|
|