From 8a6c0203c4e92908c2b26ba54feba4ce7e76d081 Mon Sep 17 00:00:00 2001 From: Marcelo Galigniana Date: Thu, 20 Apr 2023 00:40:56 -0300 Subject: Fixed #34488 -- Made ClearableFileInput preserve "Clear" checked attribute when form is invalid. --- django/contrib/admin/templates/admin/widgets/clearable_file_input.html | 2 +- django/forms/widgets.py | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) (limited to 'django') diff --git a/django/contrib/admin/templates/admin/widgets/clearable_file_input.html b/django/contrib/admin/templates/admin/widgets/clearable_file_input.html index fe71ebdb06..ab35253a0d 100644 --- a/django/contrib/admin/templates/admin/widgets/clearable_file_input.html +++ b/django/contrib/admin/templates/admin/widgets/clearable_file_input.html @@ -1,6 +1,6 @@ {% if widget.is_initial %}

{{ widget.initial_text }}: {{ widget.value }}{% if not widget.required %} - + {% endif %}
{{ widget.input_text }}:{% endif %} {% if widget.is_initial %}

{% endif %} 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) ): -- cgit v1.2.1