2015-08-18 00:00:26 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* User page callbacks for the Search module.
|
|
|
|
*/
|
|
|
|
|
2015-09-04 20:20:09 +00:00
|
|
|
use Drupal\Component\Utility\UrlHelper;
|
2015-08-18 00:00:26 +00:00
|
|
|
use Drupal\Core\Language\LanguageInterface;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implements hook_theme_suggestions_HOOK().
|
|
|
|
*/
|
|
|
|
function search_theme_suggestions_search_result(array $variables) {
|
|
|
|
return array('search_result__' . $variables['plugin_id']);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Prepares variables for individual search result templates.
|
|
|
|
*
|
|
|
|
* Default template: search-result.html.twig
|
|
|
|
*
|
|
|
|
* @param array $variables
|
|
|
|
* An array with the following elements:
|
|
|
|
* - result: Individual search result.
|
|
|
|
* - plugin_id: Plugin the search results came from.
|
|
|
|
* - title_prefix: Additional output populated by modules, intended to be
|
|
|
|
* displayed in front of the main title tag that appears in the template.
|
|
|
|
* - title_suffix: Additional output populated by modules, intended to be
|
|
|
|
* displayed after the main title tag that appears in the template.
|
|
|
|
* - title_attributes: HTML attributes for the title.
|
|
|
|
* - content_attributes: HTML attributes for the content.
|
|
|
|
*/
|
|
|
|
function template_preprocess_search_result(&$variables) {
|
|
|
|
$language_interface = \Drupal::languageManager()->getCurrentLanguage();
|
|
|
|
|
|
|
|
$result = $variables['result'];
|
2015-09-04 20:20:09 +00:00
|
|
|
$variables['url'] = UrlHelper::stripDangerousProtocols($result['link']);
|
|
|
|
$variables['title'] = $result['title'];
|
2015-08-18 00:00:26 +00:00
|
|
|
if (isset($result['language']) && $result['language'] != $language_interface->getId() && $result['language'] != LanguageInterface::LANGCODE_NOT_SPECIFIED) {
|
|
|
|
$variables['title_attributes']['lang'] = $result['language'];
|
|
|
|
$variables['content_attributes']['lang'] = $result['language'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$info = array();
|
|
|
|
if (!empty($result['plugin_id'])) {
|
2015-09-04 20:20:09 +00:00
|
|
|
$info['plugin_id'] = $result['plugin_id'];
|
2015-08-18 00:00:26 +00:00
|
|
|
}
|
|
|
|
if (!empty($result['user'])) {
|
|
|
|
$info['user'] = $result['user'];
|
|
|
|
}
|
|
|
|
if (!empty($result['date'])) {
|
|
|
|
$info['date'] = format_date($result['date'], 'short');
|
|
|
|
}
|
|
|
|
if (isset($result['extra']) && is_array($result['extra'])) {
|
|
|
|
$info = array_merge($info, $result['extra']);
|
|
|
|
}
|
|
|
|
// Check for existence. User search does not include snippets.
|
|
|
|
$variables['snippet'] = isset($result['snippet']) ? $result['snippet'] : '';
|
|
|
|
// Provide separated and grouped meta information..
|
|
|
|
$variables['info_split'] = $info;
|
|
|
|
$variables['info'] = array(
|
|
|
|
'#type' => 'inline_template',
|
|
|
|
'#template' => '{{ info|safe_join(" - ") }}',
|
|
|
|
'#context' => array('info' => $info),
|
|
|
|
);
|
|
|
|
}
|