Chris@0: ' . t('About') . ''; Chris@0: $output .= '
' . t('Layout Discovery allows modules or themes to register layouts, and for other modules to list the available layouts and render them.') . '
'; Chris@0: $output .= '' . t('For more information, see the online documentation for the Layout Discovery module.', [':layout-discovery-documentation' => 'https://www.drupal.org/docs/8/api/layout-api']) . '
'; Chris@0: return $output; Chris@0: } Chris@0: } Chris@0: Chris@0: /** Chris@0: * Implements hook_theme(). Chris@0: */ Chris@0: function layout_discovery_theme() { Chris@0: return \Drupal::service('plugin.manager.core.layout')->getThemeImplementations(); Chris@0: } Chris@0: Chris@0: /** Chris@0: * Prepares variables for layout templates. Chris@0: * Chris@0: * @param array &$variables Chris@0: * An associative array containing: Chris@0: * - content: An associative array containing the properties of the element. Chris@0: * Properties used: #settings, #layout. Chris@0: */ Chris@0: function template_preprocess_layout(&$variables) { Chris@0: $variables['settings'] = isset($variables['content']['#settings']) ? $variables['content']['#settings'] : []; Chris@0: $variables['layout'] = isset($variables['content']['#layout']) ? $variables['content']['#layout'] : []; Chris@0: Chris@0: // Create an attributes variable for each region. Chris@0: foreach (Element::children($variables['content']) as $name) { Chris@0: if (!isset($variables['content'][$name]['#attributes'])) { Chris@0: $variables['content'][$name]['#attributes'] = []; Chris@0: } Chris@0: $variables['region_attributes'][$name] = new Attribute($variables['content'][$name]['#attributes']); Chris@0: } Chris@0: }