tid; $names[] = i18ntaxonomy_translate_term_name($term); } if ($names) { $title = check_plain(implode(', ', $names)); drupal_set_title($title); switch ($op) { case 'page': // Build breadcrumb based on first hierarchy of first term: $current->tid = $tids[0]; $breadcrumb = array(); while ($parents = taxonomy_get_parents($current->tid)) { $current = array_shift($parents); $breadcrumb[] = l($current->name, 'taxonomy/term/'. $current->tid); } $breadcrumb[] = l(t('Home'), NULL); $breadcrumb = array_reverse($breadcrumb); drupal_set_breadcrumb($breadcrumb); $output = theme('i18ntaxonomy_term_page', $tids, taxonomy_select_nodes($tids, $terms['operator'], $depth, TRUE)); drupal_add_feed(url('taxonomy/term/'. $str_tids .'/'. $depth .'/feed'), 'RSS - '. $title); return $output; break; case 'feed': $channel['link'] = url('taxonomy/term/'. $str_tids .'/'. $depth, array('absolute' => TRUE)); $channel['title'] = variable_get('site_name', 'Drupal') .' - '. $title; // Only display the description if we have a single term, to avoid clutter and confusion. if (count($tids) == 1) { $terms = array(taxonomy_get_term($tids[0])); $terms = i18ntaxonomy_localize_terms($terms, array('description')); $terms['operator'] = 'or'; // HTML will be removed from feed description, so no need to filter here. $channel['description'] = $terms[0]->description; } $result = taxonomy_select_nodes($tids, $terms['operator'], $depth, FALSE); $items = array(); while ($row = db_fetch_object($result)) { $items[] = $row->nid; } node_feed($items, $channel); break; default: drupal_not_found(); } } else { drupal_not_found(); } } } /** * Render a taxonomy term page HTML output. * * @param $tids * An array of term ids. * @param $result * A pager_query() result, such as that performed by taxonomy_select_nodes(). * * @ingroup themeable */ function theme_i18ntaxonomy_term_page($tids, $result) { drupal_add_css(drupal_get_path('module', 'taxonomy') .'/taxonomy.css'); $output = ''; // Only display the description if we have a single term, to avoid clutter and confusion. if (count($tids) == 1) { $term = taxonomy_get_term($tids[0]); if (i18ntaxonomy_vocabulary($term->vid) == I18N_TAXONOMY_LOCALIZE) { $description = i18nstrings("taxonomy:term:$term->tid:description", $term->description); } else { $description = $term->description; } // Check that a description is set. if (!empty($description)) { $output .= '
'; $output .= filter_xss_admin($description); $output .= '
'; } } $output .= taxonomy_render_nodes($result); return $output; } /** * Helper function for autocompletion. * * @ TODO Optimized localization. We cannot just i18nstrings() huge lists of terms. */ function i18ntaxonomy_autocomplete($vid, $string = '') { // The user enters a comma-separated list of tags. We only autocomplete the last tag. $array = drupal_explode_tags($string); // Is this vocabulary localizable? $localizable = i18ntaxonomy_vocabulary($vid) == I18N_TAXONOMY_LOCALIZE; // Fetch last tag. $last_string = trim(array_pop($array)); $matches = array(); if ($last_string != '') { $result = db_query_range(db_rewrite_sql("SELECT t.tid, t.name FROM {term_data} t WHERE t.vid = %d AND LOWER(t.name) LIKE LOWER('%%%s%%')", 't', 'tid'), $vid, $last_string, 0, 10); $prefix = count($array) ? implode(', ', $array) .', ' : ''; while ($tag = db_fetch_object($result)) { $n = $tag->name; // Commas and quotes in terms are special cases, so encode 'em. if (strpos($tag->name, ',') !== FALSE || strpos($tag->name, '"') !== FALSE) { $n = '"'. str_replace('"', '""', $tag->name) .'"'; } $matches[$prefix . $n] = check_plain($tag->name); } } drupal_json($matches); }