From ef6169b8b1b100d36d214957e21728755f92e829 Mon Sep 17 00:00:00 2001 From: "dhruv.mittal" Date: Tue, 24 Dec 2024 12:56:06 +0530 Subject: [PATCH] Issue #3495607:Update preprocessing of checkboxes. --- web/themes/contrib/civictheme/includes/form_element.inc | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/web/themes/contrib/civictheme/includes/form_element.inc b/web/themes/contrib/civictheme/includes/form_element.inc index 25e10bdc4..d2ba3fd35 100644 --- a/web/themes/contrib/civictheme/includes/form_element.inc +++ b/web/themes/contrib/civictheme/includes/form_element.inc @@ -257,7 +257,7 @@ function civictheme_preprocess_fieldset__form_element__civictheme_field__checkbo 'value' => $value, 'name' => $name . '[' . $value . ']', 'id' => Html::cleanCssIdentifier($element['#id'] . '-' . $value), - 'is_checked' => is_array($element['#default_value']) ? in_array($value, $element['#default_value']) : $element['#default_value'] == $value, + 'is_checked' => is_array($element['#value']) ? in_array($value, $element['#value']) : $element['#value'] == $value, 'is_disabled' => isset($element['#attributes']['disabled']), // Checkboxes controls with a group cannot be required by definition. 'is_required' => FALSE, @@ -295,7 +295,7 @@ function civictheme_preprocess_fieldset__form_element__civictheme_field__radios( 'value' => $value, 'name' => $name, 'id' => Html::cleanCssIdentifier($element['#id'] . '-' . $value), - 'is_checked' => isset($element['#default_value']) ? (is_array($element['#default_value']) ? in_array($value, $element['#default_value']) : $element['#default_value'] == $value) : FALSE, + 'is_checked' => isset($element['#value']) ? (is_array($element['#value']) ? in_array($value, $element['#value']) : $element['#value'] == $value) : FALSE, 'is_disabled' => isset($element['#attributes']['disabled']), 'attributes' => $attributes, 'modifier_class' => $modifier_class, @@ -428,8 +428,9 @@ function _civictheme_preprocess_form_element__control(array &$variables): void { 'modifier_class' => $modifier_class, ]; - if ($element['#type'] == 'checkbox') { - $variables['control'][0]['is_checked'] = $element['#default_value'] ?? FALSE; + if ($element['#type'] === 'checkbox') { + $variables['control'][0]['is_checked'] = $element['#value'] ?? FALSE; + $variables['control'][0]['is_checked'] = (bool) $variables['control'][0]['is_checked']; } }