Reduce preprocess hooks usage by adding add_class() & set_attributes() filters

Created on 23 September 2022, over 2 years ago
Updated 23 June 2023, almost 2 years ago

Problem/Motivation

We use preprocess hooks in UI Suite themes and it appears we are always doing the 2 same stuff:

Preprocess are PHP function and are not expected to be written by the front developer, so they reduce the ownership of the design system maintainer, so let's remove them.

Proposed resolution for: the theme base path

We can take inspiration from ECA module and its use of tokens: https://www.drupal.org/project/eca/issues/3278918 β†’
However, there is token to get theme path in Drupal Core and we may need take inspiration from: https://www.drupal.org/project/theme_filter β†’

card:
  label: Card
  fields:
    media:
      label: Media
      preview:
        - type: html_tag
          tag: img
          attributes:
            src: "[path-to-theme:absolute]assets/card.png"

Proposed resolution for: adding attributes to a children component

It may be managed by ✨ Create twig filters: |add_class and |set_attribute Fixed so we need to evaluate those new filters.

We can also introduce new properties (add_class, set_attribute...) and namespacing in pattern definitions. Example:

card:
  label: Card
  fields:
    action_buttons:
      type: render
      add_class: 
      - mdc-card__action
      set_attribute: 
        role: action
      preview:
        - type: "pattern_preview"
          id: "button"
        - type: "pattern_preview"
          id: "button"
 
✨ Feature request
Status

Fixed

Version

2.0

Component

Code

Created by

πŸ‡«πŸ‡·France pdureau Paris

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

Production build 0.71.5 2024