annotate sites/all/modules/ctools/plugins/contexts/terms.inc @ 9:830c812b520f

added smtp module
author root <root@paio.local>
date Mon, 28 Oct 2013 15:34:27 +0000
parents ff03f76ab3fe
children
rev   line source
danielebarchiesi@0 1 <?php
danielebarchiesi@0 2
danielebarchiesi@0 3 /**
danielebarchiesi@0 4 * @file
danielebarchiesi@0 5 *
danielebarchiesi@0 6 * Plugin to provide a terms context
danielebarchiesi@0 7 */
danielebarchiesi@0 8
danielebarchiesi@0 9 /**
danielebarchiesi@0 10 * Plugins are described by creating a $plugin array which will be used
danielebarchiesi@0 11 * by the system that includes this file.
danielebarchiesi@0 12 */
danielebarchiesi@0 13 $plugin = array(
danielebarchiesi@0 14 'title' => t("Taxonomy terms"),
danielebarchiesi@0 15 'description' => t('Multiple taxonomy terms, as a group.'),
danielebarchiesi@0 16 'context' => 'ctools_context_create_terms',
danielebarchiesi@0 17 'keyword' => 'terms',
danielebarchiesi@0 18 // This context is deprecated and should not be usable in the UI.
danielebarchiesi@0 19 'no ui' => TRUE,
danielebarchiesi@0 20 'context name' => 'terms',
danielebarchiesi@0 21 'convert list' => array(
danielebarchiesi@0 22 'tid' => t('Term ID of first term'),
danielebarchiesi@0 23 'tids' => t('Term ID of all term, separated by + or ,'),
danielebarchiesi@0 24 'name' => t('Term name of first term'),
danielebarchiesi@0 25 'name_dashed' => t('Term name of first term, lowercased and spaces converted to dashes'),
danielebarchiesi@0 26 'names' => t('Term name of all terms, separated by + or ,'),
danielebarchiesi@0 27 'names_dashed' => t('Term name of all terms, separated by + or , and lowercased and spaces converted to dashes'),
danielebarchiesi@0 28 'vid' => t('Vocabulary ID of first term'),
danielebarchiesi@0 29 ),
danielebarchiesi@0 30 'convert' => 'ctools_context_terms_convert',
danielebarchiesi@0 31 );
danielebarchiesi@0 32
danielebarchiesi@0 33 /**
danielebarchiesi@0 34 * It's important to remember that $conf is optional here, because contexts
danielebarchiesi@0 35 * are not always created from the UI.
danielebarchiesi@0 36 */
danielebarchiesi@0 37 function ctools_context_create_terms($empty, $data = NULL, $conf = FALSE) {
danielebarchiesi@0 38 // The input is expected to be an object as created by ctools_break_phrase
danielebarchiesi@0 39 // which contains a group of terms.
danielebarchiesi@0 40
danielebarchiesi@0 41 $context = new ctools_context(array('terms', 'entity:taxonomy_term'));
danielebarchiesi@0 42 $context->plugin = 'terms';
danielebarchiesi@0 43
danielebarchiesi@0 44 if ($empty) {
danielebarchiesi@0 45 return $context;
danielebarchiesi@0 46 }
danielebarchiesi@0 47
danielebarchiesi@0 48 if (!empty($data) && is_object($data)) {
danielebarchiesi@0 49 $context->operator = $data->operator;
danielebarchiesi@0 50 $context->tids = $data->value;
danielebarchiesi@0 51 if (!isset($data->term)) {
danielebarchiesi@0 52 // load the first term:
danielebarchiesi@0 53 reset($context->tids);
danielebarchiesi@0 54 $data->term = taxonomy_term_load(current($context->tids));
danielebarchiesi@0 55 }
danielebarchiesi@0 56 $context->data = $data->term;
danielebarchiesi@0 57 $context->title = $data->term->name;
danielebarchiesi@0 58 $context->argument = implode($context->operator == 'or' ? '+' : ',', array_unique($context->tids));
danielebarchiesi@0 59 return $context;
danielebarchiesi@0 60 }
danielebarchiesi@0 61 }
danielebarchiesi@0 62
danielebarchiesi@0 63 /**
danielebarchiesi@0 64 * Convert a context into a string.
danielebarchiesi@0 65 */
danielebarchiesi@0 66 function ctools_context_terms_convert($context, $type) {
danielebarchiesi@0 67 switch ($type) {
danielebarchiesi@0 68 case 'tid':
danielebarchiesi@0 69 return $context->data->tid;
danielebarchiesi@0 70 case 'tids':
danielebarchiesi@0 71 return $context->argument;
danielebarchiesi@0 72 case 'name':
danielebarchiesi@0 73 return $context->data->name;
danielebarchiesi@0 74 case 'name_dashed':
danielebarchiesi@0 75 return drupal_strtolower(str_replace(' ', '-', $context->data->name));
danielebarchiesi@0 76 case 'names':
danielebarchiesi@0 77 case 'names_dashed':
danielebarchiesi@0 78 // We only run this query if this item was requested:
danielebarchiesi@0 79 if (!isset($context->names)) {
danielebarchiesi@0 80 if (empty($context->tids)) {
danielebarchiesi@0 81 $context->names = '';
danielebarchiesi@0 82 }
danielebarchiesi@0 83 else {
danielebarchiesi@0 84 $result = db_query('SELECT tid, name FROM {taxonomy_term_data} WHERE tid IN (:tids)', array(':tids' => $context->tids));
danielebarchiesi@0 85 foreach ($result as $term) {
danielebarchiesi@0 86 $names[$term->tid] = $term->name;
danielebarchiesi@0 87 if ($type == 'names_dashed') {
danielebarchiesi@0 88 $names[$term->tid] = drupal_strtolower(str_replace(' ', '-', $names[$term->tid]));
danielebarchiesi@0 89 }
danielebarchiesi@0 90 }
danielebarchiesi@0 91 $context->names = implode($context->operator == 'or' ? ' + ' : ', ', $names);
danielebarchiesi@0 92 }
danielebarchiesi@0 93 }
danielebarchiesi@0 94 return $context->names;
danielebarchiesi@0 95 case 'vid':
danielebarchiesi@0 96 return $context->data->vid;
danielebarchiesi@0 97 }
danielebarchiesi@0 98 }