123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- <?php
- /**
- * @file
- * Plugin to provide a terms context.
- */
- /**
- * Plugins are described by creating a $plugin array which will be used
- * by the system that includes this file.
- */
- $plugin = array(
- 'title' => t("Taxonomy terms"),
- 'description' => t('Multiple taxonomy terms, as a group.'),
- 'context' => 'ctools_context_create_terms',
- 'keyword' => 'terms',
- // This context is deprecated and should not be usable in the UI.
- 'no ui' => TRUE,
- 'context name' => 'terms',
- 'convert list' => array(
- 'tid' => t('Term ID of first term'),
- 'tids' => t('Term ID of all term, separated by + or ,'),
- 'name' => t('Term name of first term'),
- 'name_dashed' => t('Term name of first term, lowercased and spaces converted to dashes'),
- 'names' => t('Term name of all terms, separated by + or ,'),
- 'names_dashed' => t('Term name of all terms, separated by + or , and lowercased and spaces converted to dashes'),
- 'vid' => t('Vocabulary ID of first term'),
- ),
- 'convert' => 'ctools_context_terms_convert',
- );
- /**
- * It's important to remember that $conf is optional here, because contexts
- * are not always created from the UI.
- */
- function ctools_context_create_terms($empty, $data = NULL, $conf = FALSE) {
- // The input is expected to be an object as created by ctools_break_phrase
- // which contains a group of terms.
- $context = new ctools_context(array('terms', 'entity:taxonomy_term'));
- $context->plugin = 'terms';
- if ($empty) {
- return $context;
- }
- if (!empty($data) && is_object($data)) {
- $context->operator = $data->operator;
- $context->tids = $data->value;
- if (!isset($data->term)) {
- // Load the first term:
- reset($context->tids);
- $data->term = taxonomy_term_load(current($context->tids));
- }
- $context->data = $data->term;
- $context->title = $data->term->name;
- $context->argument = implode($context->operator == 'or' ? '+' : ',', array_unique($context->tids));
- return $context;
- }
- }
- /**
- * Convert a context into a string.
- */
- function ctools_context_terms_convert($context, $type) {
- switch ($type) {
- case 'tid':
- return $context->data->tid;
- case 'tids':
- return $context->argument;
- case 'name':
- return $context->data->name;
- case 'name_dashed':
- return drupal_strtolower(str_replace(' ', '-', $context->data->name));
- case 'names':
- case 'names_dashed':
- // We only run this query if this item was requested:
- if (!isset($context->names)) {
- if (empty($context->tids)) {
- $context->names = '';
- }
- else {
- $result = db_query('SELECT tid, name FROM {taxonomy_term_data} WHERE tid IN (:tids)', array(':tids' => $context->tids));
- foreach ($result as $term) {
- $names[$term->tid] = $term->name;
- if ($type == 'names_dashed') {
- $names[$term->tid] = drupal_strtolower(str_replace(' ', '-', $names[$term->tid]));
- }
- }
- $context->names = implode($context->operator == 'or' ? ' + ' : ', ', $names);
- }
- }
- return $context->names;
- case 'vid':
- return $context->data->vid;
- }
- }
|