1 ajax.inc views_ajax_autocomplete_taxonomy($vocabulary_name, $tags_typed = '')

Page callback for views taxonomy autocomplete.

Parameters

$vid: The vocabulary id of the tags which should be returned.

$tags_typed: The typed string of the user.

See also

taxonomy_autocomplete()

Related topics

File

core/modules/views/includes/ajax.inc, line 285
Handles the server side AJAX interactions of Views.

Code

function views_ajax_autocomplete_taxonomy($vocabulary_name, $tags_typed = '') {
  // The user enters a comma-separated list of tags. We only autocomplete the last tag.
  $tags_typed = backdrop_explode_tags($tags_typed);
  $tag_last = backdrop_strtolower(array_pop($tags_typed));

  $matches = array();
  if ($tag_last != '') {

    $query = db_select('taxonomy_term_data', 't');
    $query->addTag('translatable');
    $query->addTag('taxonomy_term_access');

    // Do not select already entered terms.
    if (!empty($tags_typed)) {
      $query->condition('t.name', $tags_typed, 'NOT IN');
    }
    // Select rows that match by term name.
    $tags_return = $query
    ->fields('t', array('tid', 'name'))
      ->condition('t.vocabulary', $vocabulary_name)
      ->condition('t.name', '%' . db_like($tag_last) . '%', 'LIKE')
      ->range(0, 10)
      ->execute()
      ->fetchAllKeyed();

    $prefix = count($tags_typed) ? backdrop_implode_tags($tags_typed) . ', ' : '';

    $term_matches = array();
    foreach ($tags_return as $tid => $name) {
      $n = $name;
      // Term names containing commas or quotes must be wrapped in quotes.
      if (strpos($name, ',') !== FALSE || strpos($name, '"') !== FALSE) {
        $n = '"' . str_replace('"', '""', $name) . '"';
      }
      // Add term name to list of matches.
      $term_matches[$prefix . $n] = check_plain($name);
    }
  }

  backdrop_json_output($term_matches);
}