30đź‘Ť
âś…
This is done with the clean
method on the form. You need to set foo_date
and foo_time
to required=False
, though, because clean
is only called after every field has been validated (see also the documentation).
class FooForm(forms.Form)
# your field definitions
def clean(self):
data = self.cleaned_data
if data.get('foo_timestamp', None) or (data.get('foo_date', None) and data.get('foo_time', None)):
return data
else:
raise forms.ValidationError('Provide either a date and time or a timestamp')
10đź‘Ť
I found myself needing a “standard” way to do this, as my forms have several conditionally required fields. So I created a superclass with the following method:
def validate_required_field(self, cleaned_data, field_name, message="This field is required"):
if(field_name in cleaned_data and cleaned_data[field_name] is None):
self._errors[field_name] = self.error_class([message])
del cleaned_data[field_name]
And then in my form’s clean method I have:
def clean(self):
cleaned_data = super(FormClass, self).clean()
if(condition):
self.validate_required_field(cleaned_data, 'field_name')
It’s worked perfectly for me so far.
👤Elliott
- How to serialize queryset in get method in Django Rest Framework?
- Django and MPTT – get only leaf nodes
- Multiple User Types For Auth in Django
- Decorators run before function it is decorating is called?
Source:stackexchange.com