|
|
|
@ -17,7 +17,8 @@ use Drupal\user\UserInterface; |
|
|
|
* |
|
|
|
* |
|
|
|
* Adds body classes if certain regions have content. |
|
|
|
* Adds body classes if certain regions have content. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_html(&$variables) { |
|
|
|
function olivesarchives_preprocess_html(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
if (theme_get_setting('mobile_menu_all_widths') === 1) { |
|
|
|
if (theme_get_setting('mobile_menu_all_widths') === 1) { |
|
|
|
$variables['attributes']['class'][] = 'is-always-mobile-nav'; |
|
|
|
$variables['attributes']['class'][] = 'is-always-mobile-nav'; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -37,20 +38,39 @@ function olivesarchives_preprocess_html(&$variables) { |
|
|
|
// stylesheet for primary menu. |
|
|
|
// stylesheet for primary menu. |
|
|
|
$variables['noscript_styles'] = [ |
|
|
|
$variables['noscript_styles'] = [ |
|
|
|
'#type' => 'html_tag', |
|
|
|
'#type' => 'html_tag', |
|
|
|
'#noscript' => TRUE, |
|
|
|
'#noscript' => true, |
|
|
|
'#tag' => 'link', |
|
|
|
'#tag' => 'link', |
|
|
|
'#attributes' => [ |
|
|
|
'#attributes' => [ |
|
|
|
'rel' => 'stylesheet', |
|
|
|
'rel' => 'stylesheet', |
|
|
|
'href' => $variables['olivesarchives_path'] . '/css/components/navigation/nav-primary-no-js.css?' . $query_string, |
|
|
|
'href' => $variables['olivesarchives_path'] . '/css/components/navigation/nav-primary-no-js.css?' . $query_string, |
|
|
|
], |
|
|
|
], |
|
|
|
]; |
|
|
|
]; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// add body class based on path |
|
|
|
|
|
|
|
// Get the current internal path (e.g., /node/123). |
|
|
|
|
|
|
|
$current_path = \Drupal::service('path.current')->getPath(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Get the path alias (returns the alias OR the internal path if no alias exists). |
|
|
|
|
|
|
|
$path_output = \Drupal::service('path_alias.manager')->getAliasByPath($current_path); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Only add the class if the returned path is different from the internal path |
|
|
|
|
|
|
|
// (meaning a custom alias exists) AND it's not empty. |
|
|
|
|
|
|
|
if ($path_output && $path_output !== $current_path) { |
|
|
|
|
|
|
|
$clean_alias = \Drupal\Component\Utility\Html::cleanCssIdentifier($path_output); |
|
|
|
|
|
|
|
$variables['attributes']['class'][] = $clean_alias; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
// Optional: Else, you could choose to add the system path class instead: |
|
|
|
|
|
|
|
// else { |
|
|
|
|
|
|
|
// $variables['attributes']['class'][] = \Drupal\Component\Utility\Html::cleanCssIdentifier($current_path); |
|
|
|
|
|
|
|
// } |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for page title templates. |
|
|
|
* Implements hook_preprocess_HOOK() for page title templates. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_page_title(&$variables) { |
|
|
|
function olivesarchives_preprocess_page_title(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
// Since the title and the shortcut link are both block level elements, |
|
|
|
// Since the title and the shortcut link are both block level elements, |
|
|
|
// positioning them next to each other is much simpler with a wrapper div. |
|
|
|
// positioning them next to each other is much simpler with a wrapper div. |
|
|
|
if (!empty($variables['title_suffix']['add_or_remove_shortcut']) && $variables['title']) { |
|
|
|
if (!empty($variables['title_suffix']['add_or_remove_shortcut']) && $variables['title']) { |
|
|
|
@ -71,7 +91,7 @@ function olivesarchives_preprocess_page_title(&$variables) { |
|
|
|
|
|
|
|
|
|
|
|
// Unset shortcut link on front page. |
|
|
|
// Unset shortcut link on front page. |
|
|
|
$variables['is_front'] = \Drupal::service('path.matcher')->isFrontPage(); |
|
|
|
$variables['is_front'] = \Drupal::service('path.matcher')->isFrontPage(); |
|
|
|
if ($variables['is_front'] === TRUE) { |
|
|
|
if ($variables['is_front'] === true) { |
|
|
|
unset($variables['title_suffix']['add_or_remove_shortcut']); |
|
|
|
unset($variables['title_suffix']['add_or_remove_shortcut']); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
@ -79,7 +99,8 @@ function olivesarchives_preprocess_page_title(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for maintenance-page.html.twig. |
|
|
|
* Implements hook_preprocess_HOOK() for maintenance-page.html.twig. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_maintenance_page(&$variables) { |
|
|
|
function olivesarchives_preprocess_maintenance_page(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
// By default, site_name is set to Drupal if no db connection is available |
|
|
|
// By default, site_name is set to Drupal if no db connection is available |
|
|
|
// or during site installation. Setting site_name to an empty string makes |
|
|
|
// or during site installation. Setting site_name to an empty string makes |
|
|
|
// the site and update pages look cleaner. |
|
|
|
// the site and update pages look cleaner. |
|
|
|
@ -95,7 +116,8 @@ function olivesarchives_preprocess_maintenance_page(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for node.html.twig. |
|
|
|
* Implements hook_preprocess_HOOK() for node.html.twig. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_node(&$variables) { |
|
|
|
function olivesarchives_preprocess_node(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
// Remove the "Add new comment" link on teasers or when the comment form is |
|
|
|
// Remove the "Add new comment" link on teasers or when the comment form is |
|
|
|
// displayed on the page. |
|
|
|
// displayed on the page. |
|
|
|
if ($variables['teaser'] || !empty($variables['content']['comments']['comment_form'])) { |
|
|
|
if ($variables['teaser'] || !empty($variables['content']['comments']['comment_form'])) { |
|
|
|
@ -103,7 +125,7 @@ function olivesarchives_preprocess_node(&$variables) { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Apply custom date formatter to "date" field. |
|
|
|
// Apply custom date formatter to "date" field. |
|
|
|
if (!empty($variables['date']) && !empty($variables['display_submitted']) && $variables['display_submitted'] === TRUE) { |
|
|
|
if (!empty($variables['date']) && !empty($variables['display_submitted']) && $variables['display_submitted'] === true) { |
|
|
|
$variables['date'] = \Drupal::service('date.formatter')->format($variables['node']->getCreatedTime(), 'olivesarchives_medium'); |
|
|
|
$variables['date'] = \Drupal::service('date.formatter')->format($variables['node']->getCreatedTime(), 'olivesarchives_medium'); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -118,7 +140,8 @@ function olivesarchives_preprocess_node(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for block.html.twig. |
|
|
|
* Implements hook_preprocess_HOOK() for block.html.twig. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_block(&$variables) { |
|
|
|
function olivesarchives_preprocess_block(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
if (!empty($variables['elements']['#id'])) { |
|
|
|
if (!empty($variables['elements']['#id'])) { |
|
|
|
/** @var \Drupal\block\BlockInterface $block */ |
|
|
|
/** @var \Drupal\block\BlockInterface $block */ |
|
|
|
$block = \Drupal::entityTypeManager() |
|
|
|
$block = \Drupal::entityTypeManager() |
|
|
|
@ -138,8 +161,7 @@ function olivesarchives_preprocess_block(&$variables) { |
|
|
|
if ($region === 'primary_menu') { |
|
|
|
if ($region === 'primary_menu') { |
|
|
|
$variables['#attached']['library'][] = 'olivesarchives/search-narrow'; |
|
|
|
$variables['#attached']['library'][] = 'olivesarchives/search-narrow'; |
|
|
|
$variables['content']['actions']['submit']['#theme_wrappers'] = ['input__submit__header_search']; |
|
|
|
$variables['content']['actions']['submit']['#theme_wrappers'] = ['input__submit__header_search']; |
|
|
|
} |
|
|
|
} elseif ($region === 'secondary_menu') { |
|
|
|
elseif ($region === 'secondary_menu') { |
|
|
|
|
|
|
|
$variables['#attached']['library'][] = 'olivesarchives/search-wide'; |
|
|
|
$variables['#attached']['library'][] = 'olivesarchives/search-wide'; |
|
|
|
$variables['content']['actions']['submit']['#theme_wrappers'] = ['input__submit__header_search']; |
|
|
|
$variables['content']['actions']['submit']['#theme_wrappers'] = ['input__submit__header_search']; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -167,7 +189,8 @@ function olivesarchives_preprocess_block(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_theme_suggestions_HOOK_alter() for menu. |
|
|
|
* Implements hook_theme_suggestions_HOOK_alter() for menu. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_theme_suggestions_menu_alter(&$suggestions, array $variables) { |
|
|
|
function olivesarchives_theme_suggestions_menu_alter(&$suggestions, array $variables) |
|
|
|
|
|
|
|
{ |
|
|
|
if (isset($variables['attributes']['region'])) { |
|
|
|
if (isset($variables['attributes']['region'])) { |
|
|
|
$suggestions[] = 'menu__' . $variables['attributes']['region']; |
|
|
|
$suggestions[] = 'menu__' . $variables['attributes']['region']; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -176,7 +199,8 @@ function olivesarchives_theme_suggestions_menu_alter(&$suggestions, array $varia |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_menu(&$variables) { |
|
|
|
function olivesarchives_preprocess_menu(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
if (isset($variables['attributes']['region'])) { |
|
|
|
if (isset($variables['attributes']['region'])) { |
|
|
|
if ($variables['attributes']['region'] === 'sidebar') { |
|
|
|
if ($variables['attributes']['region'] === 'sidebar') { |
|
|
|
$variables['attributes']['class'][] = 'menu--sidebar'; |
|
|
|
$variables['attributes']['class'][] = 'menu--sidebar'; |
|
|
|
@ -188,7 +212,8 @@ function olivesarchives_preprocess_menu(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_theme_suggestions_HOOK_alter() for form templates. |
|
|
|
* Implements hook_theme_suggestions_HOOK_alter() for form templates. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_theme_suggestions_form_alter(array &$suggestions, array $variables) { |
|
|
|
function olivesarchives_theme_suggestions_form_alter(array &$suggestions, array $variables) |
|
|
|
|
|
|
|
{ |
|
|
|
if ($variables['element']['#form_id'] === 'search_block_form') { |
|
|
|
if ($variables['element']['#form_id'] === 'search_block_form') { |
|
|
|
$suggestions[] = 'form__search_block_form'; |
|
|
|
$suggestions[] = 'form__search_block_form'; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -197,7 +222,8 @@ function olivesarchives_theme_suggestions_form_alter(array &$suggestions, array |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_form_alter() for adding classes and placeholder text to the search forms. |
|
|
|
* Implements hook_form_alter() for adding classes and placeholder text to the search forms. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_form_alter(&$form, FormStateInterface $form_state, $form_id) { |
|
|
|
function olivesarchives_form_alter(&$form, FormStateInterface $form_state, $form_id) |
|
|
|
|
|
|
|
{ |
|
|
|
if (isset($form['actions']['submit']) && (count($form['actions'])) <= 2) { |
|
|
|
if (isset($form['actions']['submit']) && (count($form['actions'])) <= 2) { |
|
|
|
$form['actions']['submit']['#attributes']['class'][] = 'button--primary'; |
|
|
|
$form['actions']['submit']['#attributes']['class'][] = 'button--primary'; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -222,7 +248,8 @@ function olivesarchives_form_alter(&$form, FormStateInterface $form_state, $form |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_theme_suggestions_HOOK_alter() for block(). |
|
|
|
* Implements hook_theme_suggestions_HOOK_alter() for block(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_theme_suggestions_block_alter(&$suggestions, array $variables) { |
|
|
|
function olivesarchives_theme_suggestions_block_alter(&$suggestions, array $variables) |
|
|
|
|
|
|
|
{ |
|
|
|
if (!empty($variables['elements']['#id'])) { |
|
|
|
if (!empty($variables['elements']['#id'])) { |
|
|
|
|
|
|
|
|
|
|
|
/** @var \Drupal\block\BlockInterface $block */ |
|
|
|
/** @var \Drupal\block\BlockInterface $block */ |
|
|
|
@ -245,7 +272,8 @@ function olivesarchives_theme_suggestions_block_alter(&$suggestions, array $vari |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for menu-local-tasks templates. |
|
|
|
* Implements hook_preprocess_HOOK() for menu-local-tasks templates. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_menu_local_tasks(&$variables) { |
|
|
|
function olivesarchives_preprocess_menu_local_tasks(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
foreach (Element::children($variables['primary']) as $key) { |
|
|
|
foreach (Element::children($variables['primary']) as $key) { |
|
|
|
$variables['primary'][$key]['#level'] = 'primary'; |
|
|
|
$variables['primary'][$key]['#level'] = 'primary'; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -257,8 +285,9 @@ function olivesarchives_preprocess_menu_local_tasks(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_form_element(). |
|
|
|
* Implements hook_preprocess_form_element(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_form_element(&$variables) { |
|
|
|
function olivesarchives_preprocess_form_element(&$variables) |
|
|
|
if (in_array($variables['element']['#type'] ?? FALSE, ['checkbox', 'radio'], TRUE)) { |
|
|
|
{ |
|
|
|
|
|
|
|
if (in_array($variables['element']['#type'] ?? false, ['checkbox', 'radio'], true)) { |
|
|
|
$variables['attributes']['class'][] = 'form-type-boolean'; |
|
|
|
$variables['attributes']['class'][] = 'form-type-boolean'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -274,18 +303,20 @@ function olivesarchives_preprocess_form_element(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_form_element_label(&$variables) { |
|
|
|
function olivesarchives_preprocess_form_element_label(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$variables['attributes']['class'][] = 'form-item__label'; |
|
|
|
$variables['attributes']['class'][] = 'form-item__label'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_input(&$variables) { |
|
|
|
function olivesarchives_preprocess_input(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
if ( |
|
|
|
if ( |
|
|
|
!empty($variables['element']['#title_display']) && |
|
|
|
!empty($variables['element']['#title_display']) |
|
|
|
$variables['element']['#title_display'] === 'attribute' && |
|
|
|
&& $variables['element']['#title_display'] === 'attribute' |
|
|
|
!empty((string) $variables['element']['#title']) |
|
|
|
&& !empty((string) $variables['element']['#title']) |
|
|
|
) { |
|
|
|
) { |
|
|
|
$variables['attributes']['title'] = (string) $variables['element']['#title']; |
|
|
|
$variables['attributes']['title'] = (string) $variables['element']['#title']; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -309,7 +340,7 @@ function olivesarchives_preprocess_input(&$variables) { |
|
|
|
'week', |
|
|
|
'week', |
|
|
|
]; |
|
|
|
]; |
|
|
|
|
|
|
|
|
|
|
|
if (in_array($type_html, $text_types_html, TRUE)) { |
|
|
|
if (in_array($type_html, $text_types_html, true)) { |
|
|
|
$variables['attributes']['class'][] = 'form-element'; |
|
|
|
$variables['attributes']['class'][] = 'form-element'; |
|
|
|
$variables['attributes']['class'][] = Html::getClass('form-element--type-' . $type_html); |
|
|
|
$variables['attributes']['class'][] = Html::getClass('form-element--type-' . $type_html); |
|
|
|
$variables['attributes']['class'][] = Html::getClass('form-element--api-' . $type_api); |
|
|
|
$variables['attributes']['class'][] = Html::getClass('form-element--api-' . $type_api); |
|
|
|
@ -321,7 +352,7 @@ function olivesarchives_preprocess_input(&$variables) { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (in_array($type_html, ['checkbox', 'radio'], TRUE)) { |
|
|
|
if (in_array($type_html, ['checkbox', 'radio'], true)) { |
|
|
|
$variables['attributes']['class'][] = 'form-boolean'; |
|
|
|
$variables['attributes']['class'][] = 'form-boolean'; |
|
|
|
$variables['attributes']['class'][] = Html::getClass('form-boolean--type-' . $type_html); |
|
|
|
$variables['attributes']['class'][] = Html::getClass('form-boolean--type-' . $type_html); |
|
|
|
} |
|
|
|
} |
|
|
|
@ -330,7 +361,8 @@ function olivesarchives_preprocess_input(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_textarea(&$variables) { |
|
|
|
function olivesarchives_preprocess_textarea(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$variables['attributes']['class'][] = 'form-element'; |
|
|
|
$variables['attributes']['class'][] = 'form-element'; |
|
|
|
$variables['attributes']['class'][] = 'form-element--type-textarea'; |
|
|
|
$variables['attributes']['class'][] = 'form-element--type-textarea'; |
|
|
|
$variables['attributes']['class'][] = 'form-element--api-textarea'; |
|
|
|
$variables['attributes']['class'][] = 'form-element--api-textarea'; |
|
|
|
@ -339,34 +371,38 @@ function olivesarchives_preprocess_textarea(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_select(&$variables) { |
|
|
|
function olivesarchives_preprocess_select(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$variables['attributes']['class'][] = 'form-element'; |
|
|
|
$variables['attributes']['class'][] = 'form-element'; |
|
|
|
$variables['attributes']['class'][] = $variables['element']['#multiple'] ? |
|
|
|
$variables['attributes']['class'][] = $variables['element']['#multiple'] |
|
|
|
'form-element--type-select-multiple' : |
|
|
|
? 'form-element--type-select-multiple' |
|
|
|
'form-element--type-select'; |
|
|
|
: 'form-element--type-select'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_checkboxes(&$variables) { |
|
|
|
function olivesarchives_preprocess_checkboxes(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$variables['attributes']['class'][] = 'form-boolean-group'; |
|
|
|
$variables['attributes']['class'][] = 'form-boolean-group'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_radios(&$variables) { |
|
|
|
function olivesarchives_preprocess_radios(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$variables['attributes']['class'][] = 'form-boolean-group'; |
|
|
|
$variables['attributes']['class'][] = 'form-boolean-group'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_field(&$variables) { |
|
|
|
function olivesarchives_preprocess_field(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$rich_field_types = ['text_with_summary', 'text', 'text_long']; |
|
|
|
$rich_field_types = ['text_with_summary', 'text', 'text_long']; |
|
|
|
|
|
|
|
|
|
|
|
if (in_array($variables['field_type'], $rich_field_types, TRUE)) { |
|
|
|
if (in_array($variables['field_type'], $rich_field_types, true)) { |
|
|
|
$variables['attributes']['class'][] = 'text-content'; |
|
|
|
$variables['attributes']['class'][] = 'text-content'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -378,7 +414,8 @@ function olivesarchives_preprocess_field(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_field_multiple_value_form(&$variables) { |
|
|
|
function olivesarchives_preprocess_field_multiple_value_form(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
// Make disabled available for the template. |
|
|
|
// Make disabled available for the template. |
|
|
|
$variables['disabled'] = !empty($variables['element']['#disabled']); |
|
|
|
$variables['disabled'] = !empty($variables['element']['#disabled']); |
|
|
|
|
|
|
|
|
|
|
|
@ -417,8 +454,7 @@ function olivesarchives_preprocess_field_multiple_value_form(&$variables) { |
|
|
|
if (is_array($cell) && isset($cell['data'])) { |
|
|
|
if (is_array($cell) && isset($cell['data'])) { |
|
|
|
$cell = $cell + ['class' => []]; |
|
|
|
$cell = $cell + ['class' => []]; |
|
|
|
$cell['class'][] = 'is-disabled'; |
|
|
|
$cell['class'][] = 'is-disabled'; |
|
|
|
} |
|
|
|
} else { |
|
|
|
else { |
|
|
|
|
|
|
|
// We have to modify the structure of this header cell. |
|
|
|
// We have to modify the structure of this header cell. |
|
|
|
$cell = [ |
|
|
|
$cell = [ |
|
|
|
'data' => $cell, |
|
|
|
'data' => $cell, |
|
|
|
@ -433,14 +469,15 @@ function olivesarchives_preprocess_field_multiple_value_form(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for menu-local-task templates. |
|
|
|
* Implements hook_preprocess_HOOK() for menu-local-task templates. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_menu_local_task(&$variables) { |
|
|
|
function olivesarchives_preprocess_menu_local_task(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$variables['link']['#options']['attributes']['class'][] = 'tabs__link'; |
|
|
|
$variables['link']['#options']['attributes']['class'][] = 'tabs__link'; |
|
|
|
$variables['link']['#options']['attributes']['class'][] = 'js-tabs-link'; |
|
|
|
$variables['link']['#options']['attributes']['class'][] = 'js-tabs-link'; |
|
|
|
|
|
|
|
|
|
|
|
// Ensure is-active class is set when the tab is active. The generic active |
|
|
|
// Ensure is-active class is set when the tab is active. The generic active |
|
|
|
// link handler applies stricter comparison rules than what is necessary for |
|
|
|
// link handler applies stricter comparison rules than what is necessary for |
|
|
|
// tabs. |
|
|
|
// tabs. |
|
|
|
if (isset($variables['is_active']) && $variables['is_active'] === TRUE) { |
|
|
|
if (isset($variables['is_active']) && $variables['is_active'] === true) { |
|
|
|
$variables['link']['#options']['attributes']['class'][] = 'is-active'; |
|
|
|
$variables['link']['#options']['attributes']['class'][] = 'is-active'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -452,7 +489,8 @@ function olivesarchives_preprocess_menu_local_task(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements template_preprocess_HOOK() for fieldset. |
|
|
|
* Implements template_preprocess_HOOK() for fieldset. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_fieldset(&$variables) { |
|
|
|
function olivesarchives_preprocess_fieldset(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$element = $variables['element']; |
|
|
|
$element = $variables['element']; |
|
|
|
$composite_types = ['checkboxes', 'radios']; |
|
|
|
$composite_types = ['checkboxes', 'radios']; |
|
|
|
|
|
|
|
|
|
|
|
@ -475,9 +513,9 @@ function olivesarchives_preprocess_fieldset(&$variables) { |
|
|
|
if (!empty($variables['attributes']['class'])) { |
|
|
|
if (!empty($variables['attributes']['class'])) { |
|
|
|
$container_inline_key = array_search('container-inline', $variables['attributes']['class']); |
|
|
|
$container_inline_key = array_search('container-inline', $variables['attributes']['class']); |
|
|
|
|
|
|
|
|
|
|
|
if ($container_inline_key !== FALSE) { |
|
|
|
if ($container_inline_key !== false) { |
|
|
|
unset($variables['attributes']['class'][$container_inline_key]); |
|
|
|
unset($variables['attributes']['class'][$container_inline_key]); |
|
|
|
$variables['inline_items'] = TRUE; |
|
|
|
$variables['inline_items'] = true; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
@ -485,14 +523,16 @@ function olivesarchives_preprocess_fieldset(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_theme_suggestions_HOOK_alter(). |
|
|
|
* Implements hook_theme_suggestions_HOOK_alter(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_theme_suggestions_user_alter(&$suggestions, $variables) { |
|
|
|
function olivesarchives_theme_suggestions_user_alter(&$suggestions, $variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$suggestions[] = 'user__' . $variables['elements']['#view_mode']; |
|
|
|
$suggestions[] = 'user__' . $variables['elements']['#view_mode']; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
* Implements hook_preprocess_HOOK(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_field__node__created(&$variables) { |
|
|
|
function olivesarchives_preprocess_field__node__created(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
foreach (Element::children($variables['items']) as $item) { |
|
|
|
foreach (Element::children($variables['items']) as $item) { |
|
|
|
unset($variables['items'][$item]['content']['#prefix']); |
|
|
|
unset($variables['items'][$item]['content']['#prefix']); |
|
|
|
} |
|
|
|
} |
|
|
|
@ -501,14 +541,16 @@ function olivesarchives_preprocess_field__node__created(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for setting classes. |
|
|
|
* Implements hook_preprocess_HOOK() for setting classes. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_filter_caption(&$variables) { |
|
|
|
function olivesarchives_preprocess_filter_caption(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$variables['classes'] = isset($variables['classes']) && !empty($variables['classes']) ? $variables['classes'] . ' caption' : 'caption'; |
|
|
|
$variables['classes'] = isset($variables['classes']) && !empty($variables['classes']) ? $variables['classes'] . ' caption' : 'caption'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_form_FORM_ID_alter(). |
|
|
|
* Implements hook_form_FORM_ID_alter(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_form_node_preview_form_select_alter(&$form, FormStateInterface $form_state, $form_id) { |
|
|
|
function olivesarchives_form_node_preview_form_select_alter(&$form, FormStateInterface $form_state, $form_id) |
|
|
|
|
|
|
|
{ |
|
|
|
$form['backlink']['#options']['attributes']['class'][] = 'button'; |
|
|
|
$form['backlink']['#options']['attributes']['class'][] = 'button'; |
|
|
|
$form['backlink']['#options']['attributes']['class'][] = 'button--small'; |
|
|
|
$form['backlink']['#options']['attributes']['class'][] = 'button--small'; |
|
|
|
$form['backlink']['#options']['attributes']['class'][] = 'button--icon-back'; |
|
|
|
$form['backlink']['#options']['attributes']['class'][] = 'button--icon-back'; |
|
|
|
@ -519,7 +561,8 @@ function olivesarchives_form_node_preview_form_select_alter(&$form, FormStateInt |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for comment.html.twig. |
|
|
|
* Implements hook_preprocess_HOOK() for comment.html.twig. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_comment(&$variables) { |
|
|
|
function olivesarchives_preprocess_comment(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
// Getting the node creation time stamp from the comment object. |
|
|
|
// Getting the node creation time stamp from the comment object. |
|
|
|
$date = $variables['comment']->getCreatedTime(); |
|
|
|
$date = $variables['comment']->getCreatedTime(); |
|
|
|
// Formatting "created" as "X days ago". |
|
|
|
// Formatting "created" as "X days ago". |
|
|
|
@ -529,7 +572,8 @@ function olivesarchives_preprocess_comment(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_HOOK() for field--comment.html.twig. |
|
|
|
* Implements hook_preprocess_HOOK() for field--comment.html.twig. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_field__comment(&$variables) { |
|
|
|
function olivesarchives_preprocess_field__comment(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
// Add a comment_count. |
|
|
|
// Add a comment_count. |
|
|
|
$variables['comment_count'] = count(array_filter($variables['comments'], 'is_numeric', ARRAY_FILTER_USE_KEY)); |
|
|
|
$variables['comment_count'] = count(array_filter($variables['comments'], 'is_numeric', ARRAY_FILTER_USE_KEY)); |
|
|
|
|
|
|
|
|
|
|
|
@ -550,7 +594,8 @@ function olivesarchives_preprocess_field__comment(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_element_info_alter(). |
|
|
|
* Implements hook_element_info_alter(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_element_info_alter(&$info) { |
|
|
|
function olivesarchives_element_info_alter(&$info) |
|
|
|
|
|
|
|
{ |
|
|
|
if (array_key_exists('text_format', $info)) { |
|
|
|
if (array_key_exists('text_format', $info)) { |
|
|
|
$info['text_format']['#pre_render'][] = [OlivesarchivesPreRender::class, 'textFormat']; |
|
|
|
$info['text_format']['#pre_render'][] = [OlivesarchivesPreRender::class, 'textFormat']; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -565,7 +610,8 @@ function olivesarchives_element_info_alter(&$info) { |
|
|
|
* |
|
|
|
* |
|
|
|
* @todo Remove when https://www.drupal.org/node/3016343 is fixed. |
|
|
|
* @todo Remove when https://www.drupal.org/node/3016343 is fixed. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_text_format_wrapper(&$variables) { |
|
|
|
function olivesarchives_preprocess_text_format_wrapper(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
$description_attributes = []; |
|
|
|
$description_attributes = []; |
|
|
|
if (!empty($variables['attributes']['id'])) { |
|
|
|
if (!empty($variables['attributes']['id'])) { |
|
|
|
$description_attributes['id'] = $variables['attributes']['aria-describedby'] = $variables['attributes']['id']; |
|
|
|
$description_attributes['id'] = $variables['attributes']['aria-describedby'] = $variables['attributes']['id']; |
|
|
|
@ -577,7 +623,8 @@ function olivesarchives_preprocess_text_format_wrapper(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_search_result(). |
|
|
|
* Implements hook_preprocess_search_result(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_search_result(&$variables) { |
|
|
|
function olivesarchives_preprocess_search_result(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
// Apply custom date formatter to "date" field. |
|
|
|
// Apply custom date formatter to "date" field. |
|
|
|
if (!empty($variables['result']['date'])) { |
|
|
|
if (!empty($variables['result']['date'])) { |
|
|
|
$variables['info_date'] = \Drupal::service('date.formatter')->format($variables['result']['node']->getCreatedTime(), 'olivesarchives_medium'); |
|
|
|
$variables['info_date'] = \Drupal::service('date.formatter')->format($variables['result']['node']->getCreatedTime(), 'olivesarchives_medium'); |
|
|
|
@ -587,7 +634,8 @@ function olivesarchives_preprocess_search_result(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_links__comment(). |
|
|
|
* Implements hook_preprocess_links__comment(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_links__comment(&$variables) { |
|
|
|
function olivesarchives_preprocess_links__comment(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
foreach ($variables['links'] as &$link) { |
|
|
|
foreach ($variables['links'] as &$link) { |
|
|
|
$link['link']['#options']['attributes']['class'][] = 'comment__links-link'; |
|
|
|
$link['link']['#options']['attributes']['class'][] = 'comment__links-link'; |
|
|
|
} |
|
|
|
} |
|
|
|
@ -596,16 +644,17 @@ function olivesarchives_preprocess_links__comment(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_preprocess_table(). |
|
|
|
* Implements hook_preprocess_table(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_preprocess_table(&$variables) { |
|
|
|
function olivesarchives_preprocess_table(&$variables) |
|
|
|
|
|
|
|
{ |
|
|
|
// Mark the whole table and the first cells if rows are draggable. |
|
|
|
// Mark the whole table and the first cells if rows are draggable. |
|
|
|
if (!empty($variables['rows'])) { |
|
|
|
if (!empty($variables['rows'])) { |
|
|
|
$draggable_row_found = FALSE; |
|
|
|
$draggable_row_found = false; |
|
|
|
foreach ($variables['rows'] as &$row) { |
|
|
|
foreach ($variables['rows'] as &$row) { |
|
|
|
/** @var \Drupal\Core\Template\Attribute $row['attributes'] */ |
|
|
|
/** @var \Drupal\Core\Template\Attribute $row['attributes'] */ |
|
|
|
if (!empty($row['attributes']) && $row['attributes']->hasClass('draggable')) { |
|
|
|
if (!empty($row['attributes']) && $row['attributes']->hasClass('draggable')) { |
|
|
|
if (!$draggable_row_found) { |
|
|
|
if (!$draggable_row_found) { |
|
|
|
$variables['attributes']['class'][] = 'draggable-table'; |
|
|
|
$variables['attributes']['class'][] = 'draggable-table'; |
|
|
|
$draggable_row_found = TRUE; |
|
|
|
$draggable_row_found = true; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
@ -615,7 +664,8 @@ function olivesarchives_preprocess_table(&$variables) { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Implements hook_form_views_exposed_form_alter(). |
|
|
|
* Implements hook_form_views_exposed_form_alter(). |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function olivesarchives_form_views_exposed_form_alter(&$form) { |
|
|
|
function olivesarchives_form_views_exposed_form_alter(&$form) |
|
|
|
|
|
|
|
{ |
|
|
|
$form['#attributes']['class'][] = 'form--inline'; |
|
|
|
$form['#attributes']['class'][] = 'form--inline'; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -638,7 +688,8 @@ function olivesarchives_form_views_exposed_form_alter(&$form) { |
|
|
|
* |
|
|
|
* |
|
|
|
* @internal |
|
|
|
* @internal |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
function _olivesarchives_hex_to_hsl(string $hex_string) { |
|
|
|
function _olivesarchives_hex_to_hsl(string $hex_string) |
|
|
|
|
|
|
|
{ |
|
|
|
// Convert hexcode pairs to rgb values (0-255). |
|
|
|
// Convert hexcode pairs to rgb values (0-255). |
|
|
|
$hex_val = trim($hex_string, '#'); |
|
|
|
$hex_val = trim($hex_string, '#'); |
|
|
|
$r0 = hexdec($hex_val[0] . $hex_val[1]); |
|
|
|
$r0 = hexdec($hex_val[0] . $hex_val[1]); |
|
|
|
@ -657,8 +708,7 @@ function _olivesarchives_hex_to_hsl(string $hex_string) { |
|
|
|
|
|
|
|
|
|
|
|
if ($delta == 0) { |
|
|
|
if ($delta == 0) { |
|
|
|
$h = 0; |
|
|
|
$h = 0; |
|
|
|
} |
|
|
|
} else { |
|
|
|
else { |
|
|
|
|
|
|
|
switch ($c_max) { |
|
|
|
switch ($c_max) { |
|
|
|
case $r: |
|
|
|
case $r: |
|
|
|
$h = fmod((($g - $b) / $delta), 6); |
|
|
|
$h = fmod((($g - $b) / $delta), 6); |
|
|
|
|