tid; if (i18ntaxonomy_vocabulary($term->vid) == I18N_TAXONOMY_LOCALIZE) { $names[] = i18nstrings("taxonomy:term:$term->tid:name", $term->name); } else { $names[] = $term->name; } } 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('taxonomy_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')); // 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_taxonomy_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 .= '