taxonomy.tokens.inc

Same filename in other branches
  1. 7.x modules/taxonomy/taxonomy.tokens.inc
  2. 9 core/modules/taxonomy/taxonomy.tokens.inc
  3. 8.9.x core/modules/taxonomy/taxonomy.tokens.inc
  4. 10 core/modules/taxonomy/taxonomy.tokens.inc

Builds placeholder replacement tokens for taxonomy terms and vocabularies.

File

core/modules/taxonomy/taxonomy.tokens.inc

View source
<?php


/**
 * @file
 * Builds placeholder replacement tokens for taxonomy terms and vocabularies.
 */
use Drupal\Core\Datetime\Entity\DateFormat;
use Drupal\Core\Language\LanguageInterface;
use Drupal\Core\Render\BubbleableMetadata;
use Drupal\taxonomy\Entity\Vocabulary;

/**
 * Implements hook_token_info().
 */
function taxonomy_token_info() {
    $types['term'] = [
        'name' => t("Taxonomy terms"),
        'description' => t("Tokens related to taxonomy terms."),
        'needs-data' => 'term',
    ];
    $types['vocabulary'] = [
        'name' => t("Vocabularies"),
        'description' => t("Tokens related to taxonomy vocabularies."),
        'needs-data' => 'vocabulary',
    ];
    // Taxonomy term related variables.
    $term['tid'] = [
        'name' => t("Term ID"),
        'description' => t("The unique ID of the taxonomy term."),
    ];
    $term['name'] = [
        'name' => t("Name"),
        'description' => t("The name of the taxonomy term."),
    ];
    $term['description'] = [
        'name' => t("Description"),
        'description' => t("The optional description of the taxonomy term."),
    ];
    $term['node-count'] = [
        'name' => t("Node count"),
        'description' => t("The number of nodes tagged with the taxonomy term."),
    ];
    $term['url'] = [
        'name' => t("URL"),
        'description' => t("The URL of the taxonomy term."),
    ];
    // Taxonomy vocabulary related variables.
    $vocabulary['vid'] = [
        'name' => t("Vocabulary ID"),
        'description' => t("The unique ID of the taxonomy vocabulary."),
    ];
    $vocabulary['name'] = [
        'name' => t("Name"),
        'description' => t("The name of the taxonomy vocabulary."),
    ];
    $vocabulary['description'] = [
        'name' => t("Description"),
        'description' => t("The optional description of the taxonomy vocabulary."),
    ];
    $vocabulary['node-count'] = [
        'name' => t("Node count"),
        'description' => t("The number of nodes tagged with terms belonging to the taxonomy vocabulary."),
    ];
    $vocabulary['term-count'] = [
        'name' => t("Term count"),
        'description' => t("The number of terms belonging to the taxonomy vocabulary."),
    ];
    // Chained tokens for taxonomies
    $term['vocabulary'] = [
        'name' => t("Vocabulary"),
        'description' => t("The vocabulary the taxonomy term belongs to."),
        'type' => 'vocabulary',
    ];
    $term['parent'] = [
        'name' => t("Parent term"),
        'description' => t("The parent term of the taxonomy term, if one exists."),
        'type' => 'term',
    ];
    $term['changed'] = [
        'name' => t("Date changed"),
        'description' => t("The date the taxonomy was most recently updated."),
        'type' => 'date',
    ];
    return [
        'types' => $types,
        'tokens' => [
            'term' => $term,
            'vocabulary' => $vocabulary,
        ],
    ];
}

/**
 * Implements hook_tokens().
 */
function taxonomy_tokens($type, $tokens, array $data, array $options, BubbleableMetadata $bubbleable_metadata) {
    $token_service = \Drupal::token();
    if (isset($options['langcode'])) {
        $url_options['language'] = \Drupal::languageManager()->getLanguage($options['langcode']);
        $langcode = $options['langcode'];
    }
    else {
        $langcode = LanguageInterface::LANGCODE_DEFAULT;
    }
    $replacements = [];
    if ($type == 'term' && !empty($data['term'])) {
        $term = $data['term'];
        $term = \Drupal::service('entity.repository')->getTranslationFromContext($term, $options['langcode'] ?? NULL);
        foreach ($tokens as $name => $original) {
            switch ($name) {
                case 'tid':
                    $replacements[$original] = $term->id();
                    break;
                case 'name':
                    $replacements[$original] = $term->label();
                    break;
                case 'description':
                    // "processed" returns a \Drupal\Component\Render\MarkupInterface via
                    // check_markup().
                    $replacements[$original] = $term->description->processed;
                    break;
                case 'url':
                    $replacements[$original] = $term->toUrl('canonical', [
                        'absolute' => TRUE,
                    ])
                        ->toString();
                    break;
                case 'node-count':
                    $query = \Drupal::database()->select('taxonomy_index');
                    $query->condition('tid', $term->id());
                    $query->addTag('term_node_count');
                    $count = $query->countQuery()
                        ->execute()
                        ->fetchField();
                    $replacements[$original] = $count;
                    break;
                case 'vocabulary':
                    $vocabulary = Vocabulary::load($term->bundle());
                    $bubbleable_metadata->addCacheableDependency($vocabulary);
                    $replacements[$original] = $vocabulary->label();
                    break;
                case 'parent':
                    $taxonomy_storage = \Drupal::entityTypeManager()->getStorage('taxonomy_term');
                    if ($parents = $taxonomy_storage->loadParents($term->id())) {
                        $parent = array_pop($parents);
                        $bubbleable_metadata->addCacheableDependency($parent);
                        $replacements[$original] = $parent->getName();
                    }
                    break;
                case 'changed':
                    $date_format = DateFormat::load('medium');
                    $bubbleable_metadata->addCacheableDependency($date_format);
                    $replacements[$original] = \Drupal::service('date.formatter')->format($term->getChangedTime(), 'medium', '', NULL, $langcode);
                    break;
            }
        }
        if ($vocabulary_tokens = $token_service->findWithPrefix($tokens, 'vocabulary')) {
            $vocabulary = Vocabulary::load($term->bundle());
            $replacements += $token_service->generate('vocabulary', $vocabulary_tokens, [
                'vocabulary' => $vocabulary,
            ], $options, $bubbleable_metadata);
        }
        if ($vocabulary_tokens = $token_service->findWithPrefix($tokens, 'parent')) {
            $taxonomy_storage = \Drupal::entityTypeManager()->getStorage('taxonomy_term');
            if ($parents = $taxonomy_storage->loadParents($term->id())) {
                $parent = array_pop($parents);
                $replacements += $token_service->generate('term', $vocabulary_tokens, [
                    'term' => $parent,
                ], $options, $bubbleable_metadata);
            }
        }
        if ($changed_tokens = $token_service->findWithPrefix($tokens, 'changed')) {
            $replacements += $token_service->generate('date', $changed_tokens, [
                'date' => $term->getChangedTime(),
            ], $options, $bubbleable_metadata);
        }
    }
    elseif ($type == 'vocabulary' && !empty($data['vocabulary'])) {
        $vocabulary = $data['vocabulary'];
        foreach ($tokens as $name => $original) {
            switch ($name) {
                case 'vid':
                    $replacements[$original] = $vocabulary->id();
                    break;
                case 'name':
                    $replacements[$original] = $vocabulary->label();
                    break;
                case 'description':
                    $build = [
                        '#markup' => $vocabulary->getDescription(),
                    ];
                    // @todo Fix in https://www.drupal.org/node/2577827
                    $replacements[$original] = \Drupal::service('renderer')->renderInIsolation($build);
                    break;
                case 'term-count':
                    $replacements[$original] = \Drupal::entityQuery('taxonomy_term')->accessCheck(TRUE)
                        ->condition('vid', $vocabulary->id())
                        ->addTag('vocabulary_term_count')
                        ->count()
                        ->execute();
                    break;
                case 'node-count':
                    $taxonomy_storage = \Drupal::entityTypeManager()->getStorage('taxonomy_term');
                    $replacements[$original] = $taxonomy_storage->nodeCount($vocabulary->id());
                    break;
            }
        }
    }
    return $replacements;
}

Functions

Title Deprecated Summary
taxonomy_tokens Implements hook_tokens().
taxonomy_token_info Implements hook_token_info().

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.