trait CompositeFormElementTrait in Drupal 9
Same name and namespace in other branches
- 8 core/lib/Drupal/Core/Render/Element/CompositeFormElementTrait.php \Drupal\Core\Render\Element\CompositeFormElementTrait
- 10 core/lib/Drupal/Core/Render/Element/CompositeFormElementTrait.php \Drupal\Core\Render\Element\CompositeFormElementTrait
Provides a trait for radios, checkboxes, and similar composite form elements.
Any form element that is comprised of several distinct parts can use this trait to add support for a composite title or description.
Hierarchy
- trait \Drupal\Core\Render\Element\CompositeFormElementTrait
File
- core/
lib/ Drupal/ Core/ Render/ Element/ CompositeFormElementTrait.php, line 11
Namespace
Drupal\Core\Render\ElementView source
trait CompositeFormElementTrait {
/**
* Adds form element theming to an element if its title or description is set.
*
* This is used as a pre render function for checkboxes and radios.
*/
public static function preRenderCompositeFormElement($element) {
// Set the element's title attribute to show #title as a tooltip, if needed.
if (isset($element['#title']) && $element['#title_display'] == 'attribute') {
$element['#attributes']['title'] = $element['#title'];
if (!empty($element['#required'])) {
// Append an indication that this field is required.
$element['#attributes']['title'] .= ' (' . t('Required') . ')';
}
}
if (isset($element['#title']) || isset($element['#description'])) {
// @see #type 'fieldgroup'
$element['#attributes']['id'] = $element['#id'] . '--wrapper';
$element['#theme_wrappers'][] = 'fieldset';
$element['#attributes']['class'][] = 'fieldgroup';
$element['#attributes']['class'][] = 'form-composite';
}
return $element;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
CompositeFormElementTrait:: |
public static | function | Adds form element theming to an element if its title or description is set. |