✍️
Dev Patterns
  • Dev Patterns: Introduction
  • Drupal 8
    • Form Alter
      • data-twig-suggestion preprocess
      • Address field #after_build
    • Language
      • Language direction classes
      • Set twig variables for languages
      • Get the language direction (PHP)
    • Routes
      • Alter page title based on route
    • Preprocess Page
      • Preprocess users
      • Check if a node has body content and create a variable
    • Preprocess HTML
      • Check node ids and field values in preprocess_html
      • Add a body class based on route
    • General Theming
      • Preprocess Paragraph
      • Paragraph theme hook for a specific field value
      • Field theme hook suggestion based on the entity string
    • Twig
      • Twig include file
      • Twig loops
      • Loop index
    • Page alter
      • Page title theme hook
      • Page content type theme hook
      • Region alter
    • Users
      • Twig user variables
      • User view mode theme hook
    • Fields
      • Replace field name
      • Count number in a multi-value field array
    • Terminal
      • Query block ids for use with twig tweak
      • Check for available updates in terminal
  • Drupal 7
    • Create View modes programtically
    • Node form alter
    • Element Children
Powered by GitBook
On this page

Was this helpful?

  1. Drupal 8
  2. Form Alter

data-twig-suggestion preprocess

Alter an input by creating a twig theme hook

/**
 * Implements hook_form_alter().
 */
function dev_patterns_form_alter(&$form, FormStateInterface $form_state, $form_id) {
  if ($form["#id"] === "views-exposed-form-news-page-1") {
    $form['actions']['submit']['#attributes']['data-twig-suggestion'] = 'search_news';
  }
}

Then create the theme hook

/**
 * Implements hook_theme_suggestions_input_alter().
 */
function moscone_theme_suggestions_input_alter(&$suggestions, array $vars) {
  // Define the element.
  $element = $vars['element'];
  // Check for specifc hooks.
  if ((isset($element['#attributes']['data-twig-suggestion']) && ($element['#attributes']['data-twig-suggestion'] === 'search_news'))) {
    // Create a theme hook if there is a data-twig-suggestion for search_news
    $suggestions[] = 'input__search_news';
  }
}

PreviousForm AlterNextAddress field #after_build

Last updated 5 years ago

Was this helpful?