- Author:
- ActionScripted
- Posted:
- July 1, 2008
- Language:
- Python
- Version:
- .96
- Score:
- 3 (after 3 ratings)
Simple DecimalField class extension that automatically adds formatting and validation for comma-separated "decimals". Works wonderfully for price fields.
Could be extended to strip dollar signs or to be locale-agnostic.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | """ Stay DRY, import intcomma """
from django.contrib.humanize.templatetags.humanize import intcomma
class USDecimalHumanizedInput(forms.TextInput):
def __init__(self, initial=None, *args, **kwargs):
super(USDecimalHumanizedInput, self).__init__(*args, **kwargs)
def render(self, name, value, attrs=None):
value = intcomma(value)
return super(USDecimalHumanizedInput, self).render(name, value, attrs)
class USDecimalHumanizedField(forms.DecimalField):
"""
Use this as a drop-in replacement for forms.DecimalField()
"""
widget = USDecimalHumanizedInput
def clean(self, value):
value = value.replace(',','')
super(USDecimalHumanizedField, self).clean(value)
return value
|
More like this
- Generate and render HTML Table by LLyaudet 6 days ago
- My firs Snippets by GutemaG 1 week, 2 days ago
- FileField having auto upload_to path by junaidmgithub 1 month, 2 weeks ago
- LazyPrimaryKeyRelatedField by LLyaudet 1 month, 3 weeks ago
- CacheInDictManager by LLyaudet 1 month, 3 weeks ago
Comments
I've noticed that when initializing without an explicit initial value, the field defaults to the string "None".
Not sure how to change this, but it'd be great if it would just fall-back to an empty string ("").
#
Line 22 should be:
Otherwise the value never gets turned into a Decimal type.
#
Just in case anyone still uses this, to fix the "None" problem mentioned by ActionScripted, simply change line 10 so that:
if value: value = intcomma(value) else: value = ''
#
Please login first before commenting.