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 }
|