class Element in Express 8
Provides helper methods for Drupal render elements.
Hierarchy
- class \Drupal\bootstrap\Utility\ArrayObject implements \Drupal\bootstrap\Utility\IteratorAggregate, \Drupal\bootstrap\Utility\ArrayAccess, \Drupal\bootstrap\Utility\Serializable, \Drupal\bootstrap\Utility\Countable, RefinableCacheableDependencyInterface, AttachmentsInterface- class \Drupal\bootstrap\Utility\DrupalAttributes- class \Drupal\bootstrap\Utility\Element
 
 
- class \Drupal\bootstrap\Utility\DrupalAttributes
Expanded class hierarchy of Element
See also
53 files declare their use of Element
- Actions.php in themes/contrib/ bootstrap/ src/ Plugin/ Process/ Actions.php 
- Contains \Drupal\bootstrap\Plugin\Process\Actions.
- ActionsDropbutton.php in themes/contrib/ bootstrap/ src/ Plugin/ Process/ ActionsDropbutton.php 
- Contains \Drupal\bootstrap\Plugin\Process\ActionsDropbutton.
- Bootstrap.php in themes/contrib/ bootstrap/ src/ Bootstrap.php 
- Contains \Drupal\bootstrap\Bootstrap.
- BootstrapCarousel.php in themes/contrib/ bootstrap/ src/ Plugin/ Preprocess/ BootstrapCarousel.php 
- Contains \Drupal\bootstrap\Plugin\Preprocess\BootstrapCarousel.
- BootstrapDropdown.php in themes/contrib/ bootstrap/ src/ Plugin/ Preprocess/ BootstrapDropdown.php 
- Contains \Drupal\bootstrap\Plugin\Preprocess\BootstrapDropdown.
File
- themes/contrib/ bootstrap/ src/ Utility/ Element.php, line 22 
- Contains \Drupal\bootstrap\Utility\Element.
Namespace
Drupal\bootstrap\UtilityView source
class Element extends DrupalAttributes {
  /**
   * The current state of the form.
   *
   * @var \Drupal\Core\Form\FormStateInterface
   */
  protected $formState;
  /**
   * The element type.
   *
   * @var string
   */
  protected $type = FALSE;
  /**
   * {@inheritdoc}
   */
  protected $attributePrefix = '#';
  /**
   * Element constructor.
   *
   * @param array|string $element
   *   A render array element.
   * @param \Drupal\Core\Form\FormStateInterface $form_state
   *   The current state of the form.
   */
  public function __construct(&$element = [], FormStateInterface $form_state = NULL) {
    if (!is_array($element)) {
      $element = [
        '#markup' => $element instanceof MarkupInterface ? $element : new FormattableMarkup($element, []),
      ];
    }
    $this->array =& $element;
    $this->formState = $form_state;
  }
  /**
   * Magic get method.
   *
   * This is only for child elements, not properties.
   *
   * @param string $key
   *   The name of the child element to retrieve.
   *
   * @return \Drupal\bootstrap\Utility\Element
   *   The child element object.
   *
   * @throws \InvalidArgumentException
   *   Throws this error when the name is a property (key starting with #).
   */
  public function &__get($key) {
    if (\Drupal\Core\Render\Element::property($key)) {
      throw new \InvalidArgumentException('Cannot dynamically retrieve element property. Please use \\Drupal\\bootstrap\\Utility\\Element::getProperty instead.');
    }
    $instance = new self($this
      ->offsetGet($key, []));
    return $instance;
  }
  /**
   * Magic set method.
   *
   * This is only for child elements, not properties.
   *
   * @param string $key
   *   The name of the child element to set.
   * @param mixed $value
   *   The value of $name to set.
   *
   * @throws \InvalidArgumentException
   *   Throws this error when the name is a property (key starting with #).
   */
  public function __set($key, $value) {
    if (\Drupal\Core\Render\Element::property($key)) {
      throw new \InvalidArgumentException('Cannot dynamically retrieve element property. Use \\Drupal\\bootstrap\\Utility\\Element::setProperty instead.');
    }
    $this
      ->offsetSet($key, $value instanceof Element ? $value
      ->getArray() : $value);
  }
  /**
   * Magic isset method.
   *
   * This is only for child elements, not properties.
   *
   * @param string $name
   *   The name of the child element to check.
   *
   * @return bool
   *   TRUE or FALSE
   *
   * @throws \InvalidArgumentException
   *   Throws this error when the name is a property (key starting with #).
   */
  public function __isset($name) {
    if (\Drupal\Core\Render\Element::property($name)) {
      throw new \InvalidArgumentException('Cannot dynamically check if an element has a property. Use \\Drupal\\bootstrap\\Utility\\Element::unsetProperty instead.');
    }
    return parent::__isset($name);
  }
  /**
   * Magic unset method.
   *
   * This is only for child elements, not properties.
   *
   * @param mixed $name
   *   The name of the child element to unset.
   *
   * @throws \InvalidArgumentException
   *   Throws this error when the name is a property (key starting with #).
   */
  public function __unset($name) {
    if (\Drupal\Core\Render\Element::property($name)) {
      throw new \InvalidArgumentException('Cannot dynamically unset an element property. Use \\Drupal\\bootstrap\\Utility\\Element::hasProperty instead.');
    }
    parent::__unset($name);
  }
  /**
   * Appends a property with a value.
   *
   * @param string $name
   *   The name of the property to set.
   * @param mixed $value
   *   The value of the property to set.
   *
   * @return $this
   */
  public function appendProperty($name, $value) {
    $property =& $this
      ->getProperty($name);
    $value = $value instanceof Element ? $value
      ->getArray() : $value;
    // If property isn't set, just set it.
    if (!isset($property)) {
      $property = $value;
      return $this;
    }
    if (is_array($property)) {
      $property[] = Element::create($value)
        ->getArray();
    }
    else {
      $property .= (string) $value;
    }
    return $this;
  }
  /**
   * Identifies the children of an element array, optionally sorted by weight.
   *
   * The children of a element array are those key/value pairs whose key does
   * not start with a '#'. See drupal_render() for details.
   *
   * @param bool $sort
   *   Boolean to indicate whether the children should be sorted by weight.
   *
   * @return array
   *   The array keys of the element's children.
   */
  public function childKeys($sort = FALSE) {
    return \Drupal\Core\Render\Element::children($this->array, $sort);
  }
  /**
   * Retrieves the children of an element array, optionally sorted by weight.
   *
   * The children of a element array are those key/value pairs whose key does
   * not start with a '#'. See drupal_render() for details.
   *
   * @param bool $sort
   *   Boolean to indicate whether the children should be sorted by weight.
   *
   * @return \Drupal\bootstrap\Utility\Element[]
   *   An array child elements.
   */
  public function children($sort = FALSE) {
    $children = [];
    foreach ($this
      ->childKeys($sort) as $child) {
      $children[$child] = new self($this->array[$child]);
    }
    return $children;
  }
  /**
   * Adds a specific Bootstrap class to color a button based on its text value.
   *
   * @param bool $override
   *   Flag determining whether or not to override any existing set class.
   *
   * @return $this
   */
  public function colorize($override = TRUE) {
    $button = $this
      ->isButton();
    // @todo refactor this more so it's not just "button" specific.
    $prefix = $button ? 'btn' : 'has';
    // List of classes, based on the prefix.
    $classes = [
      "{$prefix}-primary",
      "{$prefix}-success",
      "{$prefix}-info",
      "{$prefix}-warning",
      "{$prefix}-danger",
      "{$prefix}-link",
      // Default should be last.
      "{$prefix}-default",
    ];
    // Set the class to "btn-default" if it shouldn't be colorized.
    $class = $button && !Bootstrap::getTheme()
      ->getSetting('button_colorize') ? 'btn-default' : FALSE;
    // Search for an existing class.
    if (!$class || !$override) {
      foreach ($classes as $value) {
        if ($this
          ->hasClass($value)) {
          $class = $value;
          break;
        }
      }
    }
    // Find a class based on the value of "value", "title" or "button_type".
    if (!$class) {
      $value = $this
        ->getProperty('value', $this
        ->getProperty('title', ''));
      $class = "{$prefix}-" . Bootstrap::cssClassFromString($value, $button ? $this
        ->getProperty('button_type', 'default') : 'default');
    }
    // Remove any existing classes and add the specified class.
    if ($class) {
      $this
        ->removeClass($classes)
        ->addClass($class);
      if ($button && $this
        ->getProperty('split')) {
        $this
          ->removeClass($classes, $this::SPLIT_BUTTON)
          ->addClass($class, $this::SPLIT_BUTTON);
      }
    }
    return $this;
  }
  /**
   * Creates a new \Drupal\bootstrap\Utility\Element instance.
   *
   * @param array|string $element
   *   A render array element or a string.
   * @param \Drupal\Core\Form\FormStateInterface $form_state
   *   A current FormState instance, if any.
   *
   * @return \Drupal\bootstrap\Utility\Element
   *   The newly created element instance.
   */
  public static function create(&$element = [], FormStateInterface $form_state = NULL) {
    return $element instanceof self ? $element : new self($element, $form_state);
  }
  /**
   * Creates a new standalone \Drupal\bootstrap\Utility\Element instance.
   *
   * It does not reference the original element passed. If an Element instance
   * is passed, it will clone it so it doesn't affect the original element.
   *
   * @param array|string|\Drupal\bootstrap\Utility\Element $element
   *   A render array element, string or Element instance.
   * @param \Drupal\Core\Form\FormStateInterface $form_state
   *   A current FormState instance, if any.
   *
   * @return \Drupal\bootstrap\Utility\Element
   *   The newly created element instance.
   */
  public static function createStandalone($element = [], FormStateInterface $form_state = NULL) {
    // Immediately return a cloned version if element is already an Element.
    if ($element instanceof self) {
      return clone $element;
    }
    $standalone = is_object($element) ? clone $element : $element;
    return static::create($standalone, $form_state);
  }
  /**
   * {@inheritdoc}
   */
  public function exchangeArray($data) {
    $old = parent::exchangeArray($data);
    return $old;
  }
  /**
   * Retrieves the render array for the element.
   *
   * @return array
   *   The element render array, passed by reference.
   */
  public function &getArray() {
    return $this->array;
  }
  /**
   * Retrieves a context value from the #context element property, if any.
   *
   * @param string $name
   *   The name of the context key to retrieve.
   * @param mixed $default
   *   Optional. The default value to use if the context $name isn't set.
   *
   * @return mixed|NULL
   *   The context value or the $default value if not set.
   */
  public function &getContext($name, $default = NULL) {
    $context =& $this
      ->getProperty('context', []);
    if (!isset($context[$name])) {
      $context[$name] = $default;
    }
    return $context[$name];
  }
  /**
   * Returns the error message filed against the given form element.
   *
   * Form errors higher up in the form structure override deeper errors as well
   * as errors on the element itself.
   *
   * @return string|null
   *   Either the error message for this element or NULL if there are no errors.
   *
   * @throws \BadMethodCallException
   *   When the element instance was not constructed with a valid form state
   *   object.
   */
  public function getError() {
    if (!$this->formState) {
      throw new \BadMethodCallException('The element instance must be constructed with a valid form state object to use this method.');
    }
    return $this->formState
      ->getError($this->array);
  }
  /**
   * Retrieves the render array for the element.
   *
   * @param string $name
   *   The name of the element property to retrieve, not including the # prefix.
   * @param mixed $default
   *   The default to set if property does not exist.
   *
   * @return mixed
   *   The property value, NULL if not set.
   */
  public function &getProperty($name, $default = NULL) {
    return $this
      ->offsetGet("#{$name}", $default);
  }
  /**
   * Returns the visible children of an element.
   *
   * @return array
   *   The array keys of the element's visible children.
   */
  public function getVisibleChildren() {
    return \Drupal\Core\Render\Element::getVisibleChildren($this->array);
  }
  /**
   * Indicates whether the element has an error set.
   *
   * @throws \BadMethodCallException
   *   When the element instance was not constructed with a valid form state
   *   object.
   */
  public function hasError() {
    $error = $this
      ->getError();
    return isset($error);
  }
  /**
   * Indicates whether the element has a specific property.
   *
   * @param string $name
   *   The property to check.
   */
  public function hasProperty($name) {
    return $this
      ->offsetExists("#{$name}");
  }
  /**
   * Indicates whether the element is a button.
   *
   * @return bool
   *   TRUE or FALSE.
   */
  public function isButton() {
    return !empty($this->array['#is_button']) || $this
      ->isType([
      'button',
      'submit',
      'reset',
      'image_button',
    ]) || $this
      ->hasClass('btn');
  }
  /**
   * Indicates whether the given element is empty.
   *
   * An element that only has #cache set is considered empty, because it will
   * render to the empty string.
   *
   * @return bool
   *   Whether the given element is empty.
   */
  public function isEmpty() {
    return \Drupal\Core\Render\Element::isEmpty($this->array);
  }
  /**
   * Indicates whether a property on the element is empty.
   *
   * @param string $name
   *   The property to check.
   *
   * @return bool
   *   Whether the given property on the element is empty.
   */
  public function isPropertyEmpty($name) {
    return $this
      ->hasProperty($name) && empty($this
      ->getProperty($name));
  }
  /**
   * Checks if a value is a render array.
   *
   * @param mixed $value
   *   The value to check.
   *
   * @return bool
   *   TRUE if the given value is a render array, otherwise FALSE.
   */
  public static function isRenderArray($value) {
    return is_array($value) && (isset($value['#type']) || isset($value['#theme']) || isset($value['#theme_wrappers']) || isset($value['#markup']) || isset($value['#attached']) || isset($value['#cache']) || isset($value['#lazy_builder']) || isset($value['#create_placeholder']) || isset($value['#pre_render']) || isset($value['#post_render']) || isset($value['#process']));
  }
  /**
   * Checks if the element is a specific type of element.
   *
   * @param string|array $type
   *   The element type(s) to check.
   *
   * @return bool
   *   TRUE if element is or one of $type.
   */
  public function isType($type) {
    $property = $this
      ->getProperty('type');
    return $property && in_array($property, is_array($type) ? $type : [
      $type,
    ]);
  }
  /**
   * Determines if an element is visible.
   *
   * @return bool
   *   TRUE if the element is visible, otherwise FALSE.
   */
  public function isVisible() {
    return \Drupal\Core\Render\Element::isVisibleElement($this->array);
  }
  /**
   * Maps an element's properties to its attributes array.
   *
   * @param array $map
   *   An associative array whose keys are element property names and whose
   *   values are the HTML attribute names to set on the corresponding
   *   property; e.g., array('#propertyname' => 'attributename'). If both names
   *   are identical except for the leading '#', then an attribute name value is
   *   sufficient and no property name needs to be specified.
   *
   * @return $this
   */
  public function map(array $map) {
    \Drupal\Core\Render\Element::setAttributes($this->array, $map);
    return $this;
  }
  /**
   * Prepends a property with a value.
   *
   * @param string $name
   *   The name of the property to set.
   * @param mixed $value
   *   The value of the property to set.
   *
   * @return $this
   */
  public function prependProperty($name, $value) {
    $property =& $this
      ->getProperty($name);
    $value = $value instanceof Element ? $value
      ->getArray() : $value;
    // If property isn't set, just set it.
    if (!isset($property)) {
      $property = $value;
      return $this;
    }
    if (is_array($property)) {
      array_unshift($property, Element::create($value)
        ->getArray());
    }
    else {
      $property = (string) $value . (string) $property;
    }
    return $this;
  }
  /**
   * Gets properties of a structured array element (keys beginning with '#').
   *
   * @return array
   *   An array of property keys for the element.
   */
  public function properties() {
    return \Drupal\Core\Render\Element::properties($this->array);
  }
  /**
   * Renders the final element HTML.
   *
   * @return \Drupal\Component\Render\MarkupInterface
   *   The rendered HTML.
   */
  public function render() {
    /** @var \Drupal\Core\Render\Renderer $renderer */
    $renderer = \Drupal::service('renderer');
    return $renderer
      ->render($this->array);
  }
  /**
   * Renders the final element HTML.
   *
   * @return \Drupal\Component\Render\MarkupInterface
   *   The rendered HTML.
   */
  public function renderPlain() {
    /** @var \Drupal\Core\Render\Renderer $renderer */
    $renderer = \Drupal::service('renderer');
    return $renderer
      ->renderPlain($this->array);
  }
  /**
   * Renders the final element HTML.
   *
   * (Cannot be executed within another render context.)
   *
   * @return \Drupal\Component\Render\MarkupInterface
   *   The rendered HTML.
   */
  public function renderRoot() {
    /** @var \Drupal\Core\Render\Renderer $renderer */
    $renderer = \Drupal::service('renderer');
    return $renderer
      ->renderRoot($this->array);
  }
  /**
   * Adds Bootstrap button size class to the element.
   *
   * @param string $class
   *   The full button size class to add. If none is provided, it will default
   *   to any set theme setting.
   * @param bool $override
   *   Flag indicating if the passed $class should be forcibly set. Setting
   *   this to FALSE allows any existing set class to persist.
   *
   * @return $this
   */
  public function setButtonSize($class = NULL, $override = TRUE) {
    // Immediately return if element is not a button.
    if (!$this
      ->isButton()) {
      return $this;
    }
    // Retrieve the button size classes from the specific setting's options.
    static $classes;
    if (!isset($classes)) {
      $classes = [];
      if ($button_size = Bootstrap::getTheme()
        ->getSettingPlugin('button_size')) {
        $classes = array_keys($button_size
          ->getOptions());
      }
    }
    // Search for an existing class.
    if (!$class || !$override) {
      foreach ($classes as $value) {
        if ($this
          ->hasClass($value)) {
          $class = $value;
          break;
        }
      }
    }
    // Attempt to get the default button size, if set.
    if (!$class) {
      $class = Bootstrap::getTheme()
        ->getSetting('button_size');
    }
    // Remove any existing classes and add the specified class.
    if ($class) {
      $this
        ->removeClass($classes)
        ->addClass($class);
      if ($this
        ->getProperty('split')) {
        $this
          ->removeClass($classes, $this::SPLIT_BUTTON)
          ->addClass($class, $this::SPLIT_BUTTON);
      }
    }
    return $this;
  }
  /**
   * Flags an element as having an error.
   *
   * @param string $message
   *   (optional) The error message to present to the user.
   *
   * @return $this
   *
   * @throws \BadMethodCallException
   *   When the element instance was not constructed with a valid form state
   *   object.
   */
  public function setError($message = '') {
    if (!$this->formState) {
      throw new \BadMethodCallException('The element instance must be constructed with a valid form state object to use this method.');
    }
    $this->formState
      ->setError($this->array, $message);
    return $this;
  }
  /**
   * Adds an icon to button element based on its text value.
   *
   * @param array $icon
   *   An icon render array.
   *
   * @return $this
   *
   * @see \Drupal\bootstrap\Bootstrap::glyphicon()
   */
  public function setIcon(array $icon = NULL) {
    if ($this
      ->isButton() && !Bootstrap::getTheme()
      ->getSetting('button_iconize')) {
      return $this;
    }
    if ($value = $this
      ->getProperty('value', $this
      ->getProperty('title'))) {
      $icon = isset($icon) ? $icon : Bootstrap::glyphiconFromString($value);
      $this
        ->setProperty('icon', $icon);
    }
    return $this;
  }
  /**
   * Sets the value for a property.
   *
   * @param string $name
   *   The name of the property to set.
   * @param mixed $value
   *   The value of the property to set.
   * @param bool $recurse
   *   Flag indicating wither to set the same property on child elements.
   *
   * @return $this
   */
  public function setProperty($name, $value, $recurse = FALSE) {
    $this->array["#{$name}"] = $value instanceof Element ? $value
      ->getArray() : $value;
    if ($recurse) {
      foreach ($this
        ->children() as $child) {
        $child
          ->setProperty($name, $value, $recurse);
      }
    }
    return $this;
  }
  /**
   * Converts an element description into a tooltip based on certain criteria.
   *
   * @param array|\Drupal\bootstrap\Utility\Element|NULL $target_element
   *   The target element render array the tooltip is to be attached to, passed
   *   by reference or an existing Element object. If not set, it will default
   *   this Element instance.
   * @param bool $input_only
   *   Toggle determining whether or not to only convert input elements.
   * @param int $length
   *   The length of characters to determine if description is "simple".
   *
   * @return $this
   */
  public function smartDescription(&$target_element = NULL, $input_only = TRUE, $length = NULL) {
    static $theme;
    if (!isset($theme)) {
      $theme = Bootstrap::getTheme();
    }
    // Determine if tooltips are enabled.
    static $enabled;
    if (!isset($enabled)) {
      $enabled = $theme
        ->getSetting('tooltip_enabled') && $theme
        ->getSetting('forms_smart_descriptions');
    }
    // Immediately return if tooltip descriptions are not enabled.
    if (!$enabled) {
      return $this;
    }
    // Allow a different element to attach the tooltip.
    /** @var Element $target */
    if (is_object($target_element) && $target_element instanceof self) {
      $target = $target_element;
    }
    elseif (isset($target_element) && is_array($target_element)) {
      $target = new self($target_element, $this->formState);
    }
    else {
      $target = $this;
    }
    // For "password_confirm" element types, move the target to the first
    // textfield.
    if ($target
      ->isType('password_confirm')) {
      $target = $target->pass1;
    }
    // Retrieve the length limit for smart descriptions.
    if (!isset($length)) {
      // Disable length checking by setting it to FALSE if empty.
      $length = (int) $theme
        ->getSetting('forms_smart_descriptions_limit') ?: FALSE;
    }
    // Retrieve the allowed tags for smart descriptions. This is primarily used
    // for display purposes only (i.e. non-UI/UX related elements that wouldn't
    // require a user to "click", like a link). Disable length checking by
    // setting it to FALSE if empty.
    static $allowed_tags;
    if (!isset($allowed_tags)) {
      $allowed_tags = array_filter(array_unique(array_map('trim', explode(',', $theme
        ->getSetting('forms_smart_descriptions_allowed_tags') . '')))) ?: FALSE;
    }
    // Return if element or target shouldn't have "simple" tooltip descriptions.
    $html = FALSE;
    // If the description is a render array, it must first be pre-rendered so
    // it can be later passed to Unicode::isSimple() if needed.
    $description = $this
      ->hasProperty('description') ? $this
      ->getProperty('description') : FALSE;
    if (static::isRenderArray($description)) {
      $description = static::createStandalone($description)
        ->renderPlain();
    }
    if (!$description || !is_string($description) && !$description instanceof MarkupInterface || $input_only && !$target
      ->hasProperty('input') || $target
      ->hasAttribute('data-toggle') || $target
      ->hasProperty('disabled') || !$this
      ->getProperty('smart_description', TRUE) || !$target
      ->getProperty('smart_description', TRUE) || !Unicode::isSimple($description, $length, $allowed_tags, $html)) {
      // Set the both the actual element and the target element
      // #smart_description property to FALSE.
      $this
        ->setProperty('smart_description', FALSE);
      $target
        ->setProperty('smart_description', FALSE);
      return $this;
    }
    // Default attributes type.
    $type = DrupalAttributes::ATTRIBUTES;
    // Use #label_attributes for 'checkbox' and 'radio' elements.
    if ($this
      ->isType([
      'checkbox',
      'radio',
    ])) {
      $type = DrupalAttributes::LABEL;
    }
    elseif ($this
      ->isType([
      'checkboxes',
      'radios',
    ])) {
      $type = DrupalAttributes::WRAPPER;
    }
    // Retrieve the proper attributes array.
    $attributes = $target
      ->getAttributes($type);
    // Set the tooltip attributes.
    $attributes['title'] = $allowed_tags !== FALSE ? Xss::filter((string) $description, $allowed_tags) : $description;
    $attributes['data-toggle'] = 'tooltip';
    if ($html || $allowed_tags === FALSE) {
      $attributes['data-html'] = 'true';
    }
    // Remove the element description so it isn't (re-)rendered later.
    $this
      ->unsetProperty('description');
    return $this;
  }
  /**
   * Removes a property from the element.
   *
   * @param string $name
   *   The name of the property to unset.
   *
   * @return $this
   */
  public function unsetProperty($name) {
    unset($this->array["#{$name}"]);
    return $this;
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| ArrayObject:: | protected | property | The array. | |
| ArrayObject:: | public | function | Adds attachments. Overrides AttachmentsInterface:: | |
| ArrayObject:: | public | function | Adds a dependency on an object: merges its cacheability metadata. Overrides RefinableCacheableDependencyInterface:: | |
| ArrayObject:: | public | function | Adds cache contexts. Overrides RefinableCacheableDependencyInterface:: | |
| ArrayObject:: | public | function | Adds cache tags. Overrides RefinableCacheableDependencyInterface:: | |
| ArrayObject:: | public | function | Appends the value. | |
| ArrayObject:: | public | function | Sort the entries by value. | |
| ArrayObject:: | public | function | Merges an object's cacheable metadata into the variables array. | |
| ArrayObject:: | public | function | Merges a render array's cacheable metadata into the variables array. | |
| ArrayObject:: | public | function | Get the number of public properties in the ArrayObject. | |
| ArrayObject:: | public | function | Creates a copy of the ArrayObject. | |
| ArrayObject:: | public | function | Gets attachments. Overrides AttachmentsInterface:: | |
| ArrayObject:: | public | function | The cache contexts associated with this object. Overrides CacheableDependencyInterface:: | |
| ArrayObject:: | public | function | The maximum age for which this object may be cached. Overrides CacheableDependencyInterface:: | |
| ArrayObject:: | public | function | The cache tags associated with this object. Overrides CacheableDependencyInterface:: | |
| ArrayObject:: | public | function | Creates a new iterator from an ArrayObject instance. | |
| ArrayObject:: | public | function | Sort the entries by key. | |
| ArrayObject:: | public | function | Merges multiple values into the array. | |
| ArrayObject:: | public | function | Merges the maximum age (in seconds) with the existing maximum age. Overrides RefinableCacheableDependencyInterface:: | |
| ArrayObject:: | public | function | Sort an array using a case insensitive "natural order" algorithm. | |
| ArrayObject:: | public | function | Sort entries using a "natural order" algorithm. | |
| ArrayObject:: | public | function | Returns whether the requested key exists. | |
| ArrayObject:: | public | function | Returns the value at the specified key. | |
| ArrayObject:: | public | function | Sets the value at the specified key to value. | |
| ArrayObject:: | public | function | Unsets the value at the specified key. | |
| ArrayObject:: | public | function | Serialize an ArrayObject. | |
| ArrayObject:: | public | function | Sets attachments. Overrides AttachmentsInterface:: | |
| ArrayObject:: | public | function | Sort entries with a user-defined function and maintain key association. | |
| ArrayObject:: | public | function | Sort the entries by keys using a user-defined comparison function. | |
| ArrayObject:: | public | function | Unserialize an ArrayObject. | |
| DrupalAttributes:: | protected | property | Stored attribute instances. | |
| DrupalAttributes:: | public | function | Add class(es) to an attributes object. | |
| DrupalAttributes:: | constant | Defines the "attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "body_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "content_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "description_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "footer_attributes" storage type constant. | ||
| DrupalAttributes:: | public | function | Retrieve a specific attribute from an attributes object. | |
| DrupalAttributes:: | public | function | Retrieves a specific attributes object. | |
| DrupalAttributes:: | public | function | Retrieves classes from an attributes object. | |
| DrupalAttributes:: | public | function | Indicates whether an attributes object has a specific attribute set. | |
| DrupalAttributes:: | public | function | Indicates whether an attributes object has a specific class. | |
| DrupalAttributes:: | constant | Defines the "header_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "heading_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "input_group_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "label_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "navbar_attributes" storage type constant. | ||
| DrupalAttributes:: | public | function | Removes an attribute from an attributes object. | |
| DrupalAttributes:: | public | function | Removes a class from an attributes object. | |
| DrupalAttributes:: | public | function | Replaces a class in an attributes object. | |
| DrupalAttributes:: | public | function | Sets an attribute on an attributes object. | |
| DrupalAttributes:: | public | function | Sets multiple attributes on an attributes object. | |
| DrupalAttributes:: | constant | Defines the "split_button_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "title_attributes" storage type constant. | ||
| DrupalAttributes:: | constant | Defines the "wrapper_attributes" storage type constant. | ||
| Element:: | protected | property | A prefix to use for retrieving attribute keys from the array. Overrides DrupalAttributes:: | |
| Element:: | protected | property | The current state of the form. | |
| Element:: | protected | property | The element type. | |
| Element:: | public | function | Appends a property with a value. | |
| Element:: | public | function | Identifies the children of an element array, optionally sorted by weight. | |
| Element:: | public | function | Retrieves the children of an element array, optionally sorted by weight. | |
| Element:: | public | function | Adds a specific Bootstrap class to color a button based on its text value. | |
| Element:: | public static | function | Creates a new \Drupal\bootstrap\Utility\Element instance. | |
| Element:: | public static | function | Creates a new standalone \Drupal\bootstrap\Utility\Element instance. | |
| Element:: | public | function | Exchange the array for another one. Overrides ArrayObject:: | |
| Element:: | public | function | Retrieves the render array for the element. | |
| Element:: | public | function | Retrieves a context value from the #context element property, if any. | |
| Element:: | public | function | Returns the error message filed against the given form element. | |
| Element:: | public | function | Retrieves the render array for the element. | |
| Element:: | public | function | Returns the visible children of an element. | |
| Element:: | public | function | Indicates whether the element has an error set. | |
| Element:: | public | function | Indicates whether the element has a specific property. | |
| Element:: | public | function | Indicates whether the element is a button. | |
| Element:: | public | function | Indicates whether the given element is empty. | |
| Element:: | public | function | Indicates whether a property on the element is empty. | |
| Element:: | public static | function | Checks if a value is a render array. | |
| Element:: | public | function | Checks if the element is a specific type of element. | |
| Element:: | public | function | Determines if an element is visible. | |
| Element:: | public | function | Maps an element's properties to its attributes array. | |
| Element:: | public | function | Prepends a property with a value. | |
| Element:: | public | function | Gets properties of a structured array element (keys beginning with '#'). | |
| Element:: | public | function | Renders the final element HTML. | |
| Element:: | public | function | Renders the final element HTML. | |
| Element:: | public | function | Renders the final element HTML. | |
| Element:: | public | function | Adds Bootstrap button size class to the element. | |
| Element:: | public | function | Flags an element as having an error. | |
| Element:: | public | function | Adds an icon to button element based on its text value. | |
| Element:: | public | function | Sets the value for a property. | |
| Element:: | public | function | Converts an element description into a tooltip based on certain criteria. | |
| Element:: | public | function | Removes a property from the element. | |
| Element:: | public | function | Element constructor. Overrides ArrayObject:: | |
| Element:: | public | function | Magic get method. Overrides ArrayObject:: | |
| Element:: | public | function | Magic isset method. Overrides ArrayObject:: | |
| Element:: | public | function | Magic set method. Overrides ArrayObject:: | |
| Element:: | public | function | Magic unset method. Overrides ArrayObject:: | 
