diff options
| author | Marcelo Galigniana <marcelogaligniana@gmail.com> | 2023-04-20 00:40:56 -0300 |
|---|---|---|
| committer | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2023-04-21 07:48:27 +0200 |
| commit | 8a6c0203c4e92908c2b26ba54feba4ce7e76d081 (patch) | |
| tree | 35898f92027d101b12d15a53131036291c92c4f8 /django/forms/widgets.py | |
| parent | fb535e0a9033bd58d4bcb31876508e895c9b866d (diff) | |
Fixed #34488 -- Made ClearableFileInput preserve "Clear" checked attribute when form is invalid.
Diffstat (limited to 'django/forms/widgets.py')
| -rw-r--r-- | django/forms/widgets.py | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/django/forms/widgets.py b/django/forms/widgets.py index 3d6091c250..b4a9583364 100644 --- a/django/forms/widgets.py +++ b/django/forms/widgets.py @@ -433,6 +433,7 @@ class ClearableFileInput(FileInput): initial_text = _("Currently") input_text = _("Change") template_name = "django/forms/widgets/clearable_file_input.html" + checked = False def clear_checkbox_name(self, name): """ @@ -475,10 +476,12 @@ class ClearableFileInput(FileInput): } ) context["widget"]["attrs"].setdefault("disabled", False) + context["widget"]["attrs"]["checked"] = self.checked return context def value_from_datadict(self, data, files, name): upload = super().value_from_datadict(data, files, name) + self.checked = self.clear_checkbox_name(name) in data if not self.is_required and CheckboxInput().value_from_datadict( data, files, self.clear_checkbox_name(name) ): |
