metatag.tokens.inc in Metatag 7
Same filename and directory in other branches
Custom tokens for Metatag.
File
metatag.tokens.incView source
<?php
/**
* @file
* Custom tokens for Metatag.
*/
/**
* Implements hook_token_info().
*/
function metatag_token_info() {
$info = array();
$info['types']['metatag'] = array(
'name' => t('Meta tags'),
'description' => t('Generated by the Metatag module, may not be used to fill in other meta tags.'),
);
$metatag_info = metatag_get_info();
foreach ($metatag_info['tags'] as $value) {
if (isset($value['group'], $metatag_info['groups'][$value['group']], $metatag_info['groups'][$value['group']]['label'])) {
$label = $metatag_info['groups'][$value['group']]['label'] . ': ' . $value['label'];
}
else {
$label = t('Basic tags: @label', array(
'@label' => $value['label'],
));
}
$info['tokens']['metatag'][$value['name']] = array(
'name' => $label,
'description' => isset($value['description']) ? $value['description'] : '',
);
}
if (module_exists('taxonomy')) {
$info['tokens']['term']['metatag'] = array(
'name' => t('Meta tags'),
'description' => t('Meta tags for this taxonomy term.'),
'type' => 'metatag',
);
}
if (module_exists('node')) {
$info['tokens']['node']['metatag'] = array(
'name' => t('Meta tags'),
'description' => t('Meta tags for this node.'),
'type' => 'metatag',
);
}
if (module_exists('user')) {
$info['tokens']['user']['metatag'] = array(
'name' => t('Meta tags'),
'description' => t('Meta tags for this user.'),
'type' => 'metatag',
);
}
// A custom pager.
$pager = variable_get('metatag_pager_string', 'Page PAGER | ');
$page = str_replace('PAGER', 12, $pager);
$info['tokens']['current-page']['pager'] = array(
'name' => t('Custom pager'),
'description' => t('A custom pager (from the Metatag module). Currently set to "@pager" which would be output as e.g. "@page".', array(
'@pager' => $pager,
'@page' => $page,
)),
);
// Custom summary tokens for each long text field.
$supported_types = array(
'text_long',
'text_with_summary',
);
if (variable_get('metatag_summary_text_field', FALSE)) {
$supported_types[] = 'text';
}
$trim_length = variable_get('metatag_summary_length', 200);
foreach (field_read_fields() as $field_name => $field) {
if (!empty($field['module'])) {
if (in_array($field['type'], $supported_types)) {
$instances = field_read_instances(array(
'field_name' => $field_name,
));
foreach ($instances as $instance) {
if (!empty($instance['entity_type']) && !empty($instance['label'])) {
$info['tokens'][$instance['entity_type']][$field_name . '-summary'] = array(
'name' => t('@label (summary)', array(
'@label' => $instance['label'],
)),
'description' => t('A summary of the @label field, trimmed to @length characters.', array(
'@label' => $instance['label'],
'@length' => $trim_length,
)),
);
}
}
}
}
}
return $info;
}
/**
* Implements hook_tokens().
*/
function metatag_tokens($type, $tokens, array $data = array(), array $options = array()) {
$replacements = array();
$sanitize = !empty($options['sanitize']);
// Metatag tokens.
if ($type == 'metatag' && !empty($data['metatag'])) {
$metatag = $data['metatag'];
foreach ($tokens as $name => $original) {
if (isset($metatag[$name])) {
$replacements[$original] = $sanitize ? filter_xss($metatag[$name]) : $metatag[$name];
}
}
}
// Token tokens.
if ($type == 'term' && !empty($data['term'])) {
$term = $data['term'];
if ($metatag_tokens = token_find_with_prefix($tokens, 'metatag')) {
$result = metatag_token_generate_array($term, 'taxonomy_term', $term->vocabulary_machine_name);
$replacements += token_generate('metatag', $metatag_tokens, array(
'metatag' => $result,
), $options);
}
}
// Node tokens.
if ($type == 'node' && !empty($data['node'])) {
$node = $data['node'];
if ($metatag_tokens = token_find_with_prefix($tokens, 'metatag')) {
$result = metatag_token_generate_array($node, 'node', $node->type);
$replacements += token_generate('metatag', $metatag_tokens, array(
'metatag' => $result,
), $options);
}
}
// User tokens.
if ($type == 'user' && !empty($data['user'])) {
$account = $data['user'];
if ($metatag_tokens = token_find_with_prefix($tokens, 'metatag')) {
$result = metatag_token_generate_array($account, 'user', 'user');
$replacements += token_generate('metatag', $metatag_tokens, array(
'metatag' => $result,
), $options);
}
}
// Custom pager.
if ($type == 'current-page') {
foreach ($tokens as $name => $original) {
switch ($name) {
case 'pager':
$pager = metatag_get_current_pager();
if (!empty($pager)) {
$replacements[$original] = $pager;
}
break;
}
}
}
// Summary tokens. It is safe to rely upon an "entity" token type here because
// it is added by the Token module.
if ($type == 'entity' && isset($options['entity'], $options['entity_type'])) {
$trim_length = variable_get('metatag_summary_length', 200);
foreach ($tokens as $name => $original) {
if (substr($name, -8) == '-summary') {
// The field name is the token name minus "-summary".
$field_name = substr($name, 0, -8);
// Work out the requested language, if appropriate.
if (isset($options['language'])) {
$language_code = $options['language']->language;
}
else {
$language_code = NULL;
}
$entity = $options['entity'];
$entity_type = $options['entity_type'];
list($entity_id, $revision_id, $bundle) = entity_extract_ids($entity_type, $entity);
$items = field_get_items($entity_type, $entity, $field_name, $language_code);
if (!empty($items)) {
$instance = field_info_instance($entity_type, $field_name, $bundle);
$field_langcode = field_language($entity_type, $entity, $field_name, $language_code);
// If the summary was filled in it is not empty, use it.
if (!empty($items[0]['summary'])) {
$output = $sanitize ? _text_sanitize($instance, $field_langcode, $items[0], 'summary') : $items[0]['summary'];
}
else {
$output = $sanitize ? _text_sanitize($instance, $field_langcode, $items[0], 'value') : $items[0]['value'];
}
if (!empty($output)) {
// Trim the summary.
$output = text_summary($output, $instance['settings']['text_processing'] ? $items[0]['format'] : NULL, $trim_length);
if (!empty($output)) {
$replacements[$original] = $output;
}
}
}
}
}
}
return $replacements;
}
/**
* Generate an array of meta tags for a given entity.
*/
function metatag_token_generate_array($entity, $entity_type, $bundle) {
if (metatag_entity_supports_metatags($entity_type, $bundle)) {
$token_type = token_get_entity_mapping('entity', $entity_type);
$instance = metatag_get_entity_metatags_instance($entity, $entity_type, $bundle);
$options = array();
$options['token data'][$token_type] = $entity;
$options['entity'] = $entity;
$metatags = array();
if (!empty($entity->metatags)) {
$language = metatag_entity_get_language($entity_type, $entity);
if (!empty($entity->metatags[$language])) {
$metatags = $entity->metatags[$language];
}
}
$metatags += metatag_config_load_with_defaults($instance);
// Process it for entity metatag replacement to avoid infinite recursion.
$metatags = _metatag_token_process_metatag($metatags, $token_type);
$result = array();
foreach ($metatags as $metatag => $data) {
if ($metatag_instance = metatag_get_instance($metatag, $data)) {
$result[$metatag] = $metatag_instance
->getValue($options);
}
}
return $result;
}
return NULL;
}
/**
* Loop through metatags to avoid recursion on entity tokens.
*
* It will replace entity metatag token to its actual entity metatag field
* value.
*
* @param array $metatags
* An array of entity metatag tokens.
* @param string $token_type
* The entity token type, such as 'node' or 'term'.
*
* @return array
* Return metatags array with entity metatag tokens replaced.
*/
function _metatag_token_process_metatag(array $metatags, $token_type) {
foreach ($metatags as $metatag => $data) {
// Skip values that are not strings.
if (!is_string($data['value'])) {
continue;
}
// Explode all metatag token in field.
$data_tokens = token_scan($data['value']);
if (isset($data_tokens[$token_type])) {
foreach ($data_tokens[$token_type] as $key => $value) {
$metatag_parts = explode(':', $key);
// Check entity metatag token. Like [<entity_token_type>:metatag:<xyz>].
if ($metatag_parts[0] == 'metatag') {
$entity_field = implode(':', array_slice($metatag_parts, 1));
// If a value is not set here it will trigger an infinite loop.
$metatags[$metatag]['value'] = '';
// If the meta tag was defined then try parsing it.
if (!empty($metatags[$entity_field]['value'])) {
// Entity metatag field may contain other entity metatag token
// that need to be replaced too.
$replaced_value = metatag_token_entitymetatagtoken_replace($metatags, $metatags[$entity_field]['value'], $token_type);
$metatags[$metatag]['value'] = str_replace($value, $replaced_value, $metatags[$metatag]['value']);
}
}
}
}
}
return $metatags;
}
/**
* Replace entity metatag token with actual entity metatag field value.
*
* @param array $metatags
* An array entity metatag tokens.
* @param string $token
* A token to be replaced.
* @param string $token_type
* The entity token type, such as 'node' or 'term'.
* @param array $search_tokens
* An array of tokens to search for.
* @param array $replace_tokens
* An array of tokens to be replaced.
*
* @return string
* The replaced value of $token.
*/
function metatag_token_entitymetatagtoken_replace(array $metatags, $token, $token_type, array $search_tokens = array(), array $replace_tokens = array()) {
$data_tokens = token_scan($token);
// Check field has tokens.
if (isset($data_tokens[$token_type])) {
// Go through each token in field and find entity metatag tokens.
foreach ($data_tokens[$token_type] as $key => $value) {
$metatag_parts = explode(':', $key);
if ($metatag_parts[0] == 'metatag' && !in_array($value, $search_tokens)) {
// Entity metatag field value.
$entity_field = implode(':', array_slice($metatag_parts, 1));
$replaced_value = metatag_token_entitymetatagtoken_replace($metatags, $metatags[$entity_field]['value'], $token_type, $replace_tokens, $search_tokens);
$replace_tokens[] = $replaced_value;
$search_tokens[] = $value;
}
}
return str_replace($search_tokens, $replace_tokens, $token);
}
else {
return $token;
}
}
Functions
Name | Description |
---|---|
metatag_tokens | Implements hook_tokens(). |
metatag_token_entitymetatagtoken_replace | Replace entity metatag token with actual entity metatag field value. |
metatag_token_generate_array | Generate an array of meta tags for a given entity. |
metatag_token_info | Implements hook_token_info(). |
_metatag_token_process_metatag | Loop through metatags to avoid recursion on entity tokens. |