/[drupal]/contributions/modules/taxonomy_browser/taxonomy_browser.module
ViewVC logotype

Contents of /contributions/modules/taxonomy_browser/taxonomy_browser.module

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.19.2.11.2.20 - (hide annotations) (download) (as text)
Tue Jul 22 00:47:02 2008 UTC (16 months ago) by nancyw
Branch: DRUPAL-6--1
Changes since 1.19.2.11.2.19: +13 -6 lines
File MIME type: text/x-php
Improve error checking.
1 jaza 1.17 <?php
2 nancyw 1.19.2.11.2.20 // $Id: taxonomy_browser.module,v 1.19.2.11.2.19 2008/06/20 04:07:50 nancyw Exp $
3 jaza 1.17 // Original by Moshe Weitzman (weitzmna@tejasa.com)
4    
5     /**
6     * @file
7     * Enables users to construct their own view of content from terms across
8     * multiple vocabularies.
9     */
10    
11 nancyw 1.19.2.11.2.4 //*******************************************************************
12 nancyw 1.19.2.11.2.7 //* Drupal Hooks : General Overview
13 nancyw 1.19.2.11.2.4 //*******************************************************************
14 jaza 1.17
15     /**
16     * Implementation of hook_menu().
17     */
18 nancyw 1.19.2.11.2.1 function taxonomy_browser_menu() {
19 jaza 1.17 $items = array();
20    
21 nancyw 1.19.2.11.2.1 $items['taxonomy_browser'] = array(
22     'title' => 'Category Browser',
23     'page callback' => 'taxonomy_browser_page',
24     'access arguments' => array('access content'),
25 nancyw 1.19.2.11.2.5 'description' => 'Find content on your own terms.',
26 nancyw 1.19.2.11.2.1 );
27 nancyw 1.19.2.1
28 nancyw 1.19.2.11.2.1 $items['admin/settings/taxonomy-browser'] = array(
29     'title' => 'Taxonomy Browser',
30     'description' => 'Set usage guidelines and included vocabularies.',
31     'page callback' => 'drupal_get_form',
32     'page arguments' => array('taxonomy_browser_admin_settings'),
33     'access arguments' => array('administer site configuration'),
34     );
35    
36 jaza 1.17 return $items;
37     }
38    
39     /**
40 nancyw 1.19.2.11.2.2 * Implementation of hook_init().
41     */
42     function taxonomy_browser_init() {
43     drupal_add_css(drupal_get_path('module', 'taxonomy_browser') .'/taxonomy_browser.css');
44     }
45    
46     /**
47 jaza 1.17 * Implementation of hook_help().
48     */
49 nancyw 1.19.2.11.2.1 function taxonomy_browser_help($path, $arg) {
50     switch ($path) {
51 jaza 1.17 case 'admin/modules#description':
52     return t('An interface for viewing content grouped by arbitrary taxonomy terms.');
53     case 'taxonomy_browser':
54 nancyw 1.19.2.11.2.7 $output = check_markup(variable_get('taxonomy_browser_guidelines', _taxonomy_browser_guidelines_default()));
55     if (user_access('administer site configuration')) {
56 nancyw 1.19.2.11.2.14 $output .= '<p class="links">'. l(t('Go to Taxonomy Browser settings'), 'admin/settings/taxonomy-browser', array('query' => drupal_get_destination())) .'</p>';
57 nancyw 1.19.2.11.2.7 }
58     return $output;
59     }
60     }
61    
62     /**
63     * Implementation of hook_perm().
64     */
65     function taxonomy_browser_perm() {
66     if (variable_get('taxonomy_browser_need_perm', false)) {
67     return array('access taxonomy browser');
68     }
69     else {
70     return array();
71 jaza 1.17 }
72     }
73    
74 nancyw 1.19.2.11.2.7 /**
75     * Implementation of hook_menu_alter().
76     */
77     function taxonomy_browser_menu_alter(&$callbacks) {
78     $callbacks['taxonomy_browser']['access arguments'] = array(variable_get('taxonomy_browser_need_perm', false) ? 'access taxonomy browser' : 'access content');
79     }
80    
81 nancyw 1.19.2.11.2.4 //********************************************************************
82 nancyw 1.19.2.11.2.7 //* Drupal Hooks : Core
83 nancyw 1.19.2.11.2.4 //********************************************************************
84 jaza 1.17
85     /**
86 nancyw 1.19.2.11.2.12 * Implementation of hook_block().
87     */
88     function taxonomy_browser_block($op = 'list', $delta = 0, $edit = array()) {
89     $block = array();
90     switch ($op) {
91     case 'list':
92     $block[0]['info'] = t('Category browser');
93     return $block;
94    
95     case 'view':
96 nancyw 1.19.2.11.2.14 switch ($delta) {
97 nancyw 1.19.2.11.2.12 case 0:
98     $block = _taxonomy_browser_block_view($delta);
99     break;
100     }
101     return $block;
102     }
103     }
104    
105     /**
106 nancyw 1.19.2.11.2.7 * Settings form.
107 jaza 1.17 */
108 nancyw 1.19.2.1 function taxonomy_browser_admin_settings() {
109     if (!module_exists('node_type_filter') && !drupal_set_message()) {
110 nancyw 1.19.2.11.2.1 drupal_set_message(t('You do not have the node_type_filter module installed. This means that the "restrict search by content type" option will not be available on the category browser page.'), 'status');
111 jaza 1.17 }
112 nancyw 1.19.2.11.2.7
113 nancyw 1.19.2.11.2.18 drupal_add_js(drupal_get_path('module', 'taxonomy_browser') .'/taxonomy_browser.js', 'module');
114    
115 jaza 1.17 $form['taxonomy_browser_guidelines'] = array(
116     '#title' => t('Guidelines'),
117     '#type' => 'textarea',
118     '#default_value' => variable_get('taxonomy_browser_guidelines', _taxonomy_browser_guidelines_default()),
119 nancyw 1.19.2.11.2.7 '#rows' => 2,
120 jaza 1.17 '#description' => t('Instructions which should appear at top of the category browser main page'),
121 nancyw 1.19.2.11.2.1 );
122 nancyw 1.19.2.11.2.7
123 nancyw 1.19.2.5 $form['taxonomy_browser_select_type'] = array(
124     '#title' => t('Selection type'),
125     '#type' => 'radios',
126 nancyw 1.19.2.11.2.14 '#default_value' => variable_get('taxonomy_browser_select_type', 1),
127 nancyw 1.19.2.7 '#options' => array(t('Selection box'), t('Check boxes')),
128 nancyw 1.19.2.9 '#description' => t('This option determines whether the user will see a selection list or check boxes.'),
129 nancyw 1.19.2.11.2.7 '#prefix' => '<div class="taxonomy_browser_radios">',
130     '#suffix' => '</div>',
131 nancyw 1.19.2.11.2.1 );
132 nancyw 1.19.2.11.2.7
133 nancyw 1.19.2.11.2.8 $form['taxonomy_browser_default_op'] = array(
134     '#title' => t('"Items containing" default'),
135     '#type' => 'radios',
136     '#default_value' => variable_get('taxonomy_browser_default_op', 0),
137     '#options' => array(t('All'), t('Any')),
138     '#description' => t('This option determines which "Items containing" choice is the default.'),
139     '#prefix' => '<div class="taxonomy_browser_radios">',
140     '#suffix' => '</div>',
141     );
142    
143 nancyw 1.19.2.10 $form['taxonomy_browser_count_nodes'] = array(
144     '#title' => t('Show node count'),
145     '#type' => 'checkbox',
146     '#default_value' => variable_get('taxonomy_browser_count_nodes', false),
147     '#description' => t('Do you want to display the count of nodes tagged with each term? This can be SQL-intensive.'),
148 nancyw 1.19.2.11.2.1 );
149 nancyw 1.19.2.11.2.7
150 nancyw 1.19.2.10 $form['taxonomy_browser_show_unused'] = array(
151     '#title' => t('Show unused terms'),
152     '#type' => 'checkbox',
153     '#default_value' => variable_get('taxonomy_browser_show_unused', false),
154 nancyw 1.19.2.11.2.14 '#description' => t('Do you want to display the term if no nodes are tagged with that term? This requires "Show node count" to be selected; if it is not seleted, all terms will be shown.'),
155 nancyw 1.19.2.11.2.1 );
156 nancyw 1.19.2.11.2.7
157 nancyw 1.19.2.11.2.4 $form['taxonomy_browser_allow_children'] = array(
158     '#title' => t('Allow child terms to be included'),
159     '#type' => 'checkbox',
160     '#default_value' => variable_get('taxonomy_browser_allow_children', false),
161     '#description' => t('Do you want the user to see a check box to include child terms (sub-terms)?'),
162     );
163 nancyw 1.19.2.5
164 nancyw 1.19.2.11.2.7 $form['taxonomy_browser_need_perm'] = array(
165     '#title' => t('Requires permission'),
166     '#type' => 'checkbox',
167     '#default_value' => variable_get('taxonomy_browser_need_perm', false),
168     '#description' => t('Do you want to require permission to see the browser page? If you change this you need to clear the menu cache, such as at <a href="!clear">the Performance page</a>.', array('!clear' => url('admin/settings/performance'))),
169     );
170    
171 nancyw 1.19.2.11.2.14 $select = array();
172     $vocabularies = taxonomy_get_vocabularies();
173 jaza 1.17 foreach ($vocabularies as $vocabulary) {
174     $select[$vocabulary->vid] = $vocabulary->name;
175     }
176 nancyw 1.19.2.11.2.1
177 jaza 1.17 $form['taxonomy_browser_vocabularies'] = array(
178     '#title' => t('Included Vocabularies'),
179 nancyw 1.19.2.11.2.14 '#type' => 'checkboxes',
180 jaza 1.17 '#default_value' => variable_get('taxonomy_browser_vocabularies', array()),
181     '#options' => $select,
182 nancyw 1.19.2.8 '#description' => t('Select the vocabularies the user can select from on the category browser page.'),
183 nancyw 1.19.2.11.2.14 '#prefix' => '<div class="taxonomy_browser_checkboxes">',
184     '#suffix' => '</div>',
185 nancyw 1.19.2.11.2.1 );
186 nancyw 1.19.2.11.2.14
187 nancyw 1.19.2.8 if (module_exists('node_type_filter')) {
188 nancyw 1.19.2.11.2.14 $filter_options = node_get_types('names');
189 nancyw 1.19.2.8 $form['taxonomy_browser_omit'] = array(
190 nancyw 1.19.2.11.2.14 '#type' => 'checkboxes',
191 nancyw 1.19.2.8 '#title' => t('Omit content types'),
192     '#options' => $filter_options,
193 nancyw 1.19.2.11.2.3 '#default_value' => variable_get('taxonomy_browser_omit', array('')),
194 nancyw 1.19.2.8 '#description' => t('If any of these types is selected, it will be omitted from the list on the "Category Browser" page.'),
195 nancyw 1.19.2.11.2.14 '#prefix' => '<div class="taxonomy_browser_checkboxes">',
196     '#suffix' => '</div>',
197 nancyw 1.19.2.11.2.1 );
198 nancyw 1.19.2.8 }
199 jaza 1.17
200 nancyw 1.19.2.11.2.1 return system_settings_form($form);
201 jaza 1.17 }
202    
203 nancyw 1.19.2.11.2.4 function taxonomy_browser_admin_settings_validate($form, &$form_state) {
204     if ($form_state['values']['taxonomy_browser_count_nodes'] == false
205     && $form_state['values']['taxonomy_browser_show_unused'] == true) {
206     form_set_error('taxonomy_browser_show_unused', t('"Show unused" requires "count nodes."'));
207     }
208     }
209    
210     //********************************************************************
211     //* Module Functions : Public
212     //********************************************************************
213 jaza 1.17
214     /**
215     * Menu callback: the query building interface for nodes selected based on
216     * taxonomy terms.
217     */
218     function taxonomy_browser_page() {
219 nancyw 1.19.2.1 $output .= drupal_get_form('taxonomy_browser_form');
220     return $output;
221     }
222    
223     function taxonomy_browser_form() {
224 jaza 1.17 $form = array();
225 nancyw 1.19.2.11.2.7 $selection_types = array('select', 'checkboxes');
226 nancyw 1.19.2.11.2.14 $select_type = $selection_types[variable_get('taxonomy_browser_select_type', 1)];
227 nancyw 1.19.2.10 $count_nodes = variable_get('taxonomy_browser_count_nodes', false);
228     $show_unused = variable_get('taxonomy_browser_show_unused', false);
229 nancyw 1.19.2.11.2.4 $allow_children = variable_get('taxonomy_browser_allow_children', false);
230 nancyw 1.19.2.11.2.7 $node_types = node_get_types('names');
231 nancyw 1.19.2.11.2.11
232 jaza 1.17 $form['scope'] = array(
233     '#type' => 'fieldset',
234     '#title' => t('Scope'),
235 nancyw 1.19.2.11.2.6 '#collapsible' => true,
236     '#collapsed' => false,
237 nancyw 1.19.2.11.2.7 '#attributes' => array('class' => 'taxonomy_browser_scope'),
238 nancyw 1.19.2.11.2.6 );
239 nancyw 1.19.2.11.2.4
240 nancyw 1.19.2.1 if (module_exists('node_type_filter')) {
241 nancyw 1.19.2.11 if ($count_nodes) {
242     $total_count = 0;
243 nancyw 1.19.2.11.2.11 $result = db_query('SELECT DISTINCT(type), COUNT(nid) AS count FROM {node} WHERE status=1 GROUP BY type ORDER BY type');
244 nancyw 1.19.2.11 while ($counter = db_fetch_array($result)) {
245 nancyw 1.19.2.11.2.7 // Check if we know about this type - a disabled module could have orphans.
246 nancyw 1.19.2.11.2.11 if (isset($node_types[$counter['type']])) {
247     $node_types[$counter['type']] .= ' ('. $counter['count'] .')';
248 nancyw 1.19.2.11.2.7 }
249     else {
250 nancyw 1.19.2.11.2.11 $node_types['unknown'] .= '<em>'. $counter['type'];
251     $node_types['unknown'] .= '</em>??? ('. $counter['count'] .') ';
252 nancyw 1.19.2.11.2.7 watchdog('Taxonomy Browser', 'Unknown content type found: @type', array('@type' => $counter['type']), WATCHDOG_WARNING);
253     }
254 nancyw 1.19.2.11 $total_count += $counter['count'];
255     }
256     }
257 nancyw 1.19.2.11.2.11
258 nancyw 1.19.2.11.2.15 $omit = array_filter(variable_get('taxonomy_browser_omit', array()));
259 nancyw 1.19.2.10 if (!empty($omit)) {
260 nancyw 1.19.2.11.2.1 foreach ($omit as $omit_type) {
261 nancyw 1.19.2.11.2.11 unset($node_types[$omit_type]);
262 nancyw 1.19.2.10 }
263     }
264 nancyw 1.19.2.11.2.13 $desc = t('Not selecting any type is the same as selecting all types.');
265     if ($count_nodes) {
266     $desc .= ' '. t('The total count of all types is !count.', array('!count' => $total_count));
267     }
268 jaza 1.17 $form['scope']['node_filter'] = array(
269 nancyw 1.19.2.11.2.7 '#type' => $select_type,
270 jaza 1.17 '#title' => t('Restrict search by content type'),
271 nancyw 1.19.2.11.2.7 '#options' => $node_types,
272     '#multiple' => true,
273     '#prefix' => '<div class="taxonomy_browser_checkboxes">',
274     '#suffix' => '</div>',
275 nancyw 1.19.2.11.2.13 '#description' => $desc,
276 nancyw 1.19.2.11.2.7 );
277 jaza 1.17 }
278 nancyw 1.19.2.11.2.9 else {
279     $form['scope']['node_filter'] = array(
280     '#type' => value,
281     '#value' => array(),
282     );
283     }
284 jaza 1.17
285     $form['scope']['operator'] = array(
286     '#type' => 'radios',
287     '#title' => t('Items containing'),
288     '#options' => array(t('<strong>all</strong> terms'), t('<strong>any</strong> terms')),
289 nancyw 1.19.2.11.2.8 '#default_value' => variable_get('taxonomy_browser_default_op', 0),
290 nancyw 1.19.2.11.2.7 '#prefix' => '<div class="taxonomy_browser_radios">',
291     '#suffix' => '</div>',
292     );
293 jaza 1.17
294 nancyw 1.19.2.11.2.14 $vocabularies = array_filter(variable_get('taxonomy_browser_vocabularies', array()));
295 nancyw 1.19.2.11.2.10 // Has the admin selected any vocabs?
296     if (count($vocabularies) == 0) {
297 nancyw 1.19.2.11.2.14 $vocabs = taxonomy_get_vocabularies();
298     foreach ($vocabs as $vocabulary) {
299     $vocabularies[$vocabulary->vid] = 1;
300     }
301 nancyw 1.19.2.11.2.10 }
302 nancyw 1.19.2.11.2.4
303     if ($allow_children) {
304     $form['children'] = array(
305     '#type' => 'fieldset',
306     '#title' => t('Include Children'),
307 nancyw 1.19.2.11.2.6 '#collapsible' => true,
308     '#collapsed' => false,
309 nancyw 1.19.2.11.2.4 );
310     $form['children']['include_children'] = array(
311     '#type' => 'checkbox',
312     '#title' => t('Automatically include children (sub-terms)'),
313     '#description' => t('If you select a term with children (sub-terms), do you want those child terms automatically included in the search? This requires that "Items containing" be "any."'),
314     );
315     }
316     else {
317 nancyw 1.19.2.11.2.7 $form['include_children'] = array(
318 nancyw 1.19.2.11.2.4 '#type' => 'value',
319     '#value' => false,
320     );
321     }
322 jaza 1.17
323     $form['taxonomy'] = array(
324     '#type' => 'fieldset',
325     '#title' => t('Categories'),
326 nancyw 1.19.2.5 '#collapsible' => true,
327     '#collapsed' => false,
328 jaza 1.17 '#tree' => TRUE,
329     );
330 weitzman 1.19
331 nancyw 1.19.2.11.2.1 $selection_types = array('select', 'checkboxes');
332 weitzman 1.19 $i = 0;
333 nancyw 1.19.2.11.2.14 foreach ($vocabularies as $v => $sel) {
334 nancyw 1.19.2.11.2.1 $voc = taxonomy_vocabulary_load($v);
335 nancyw 1.19.2.11.2.7
336     $voc_node_types = array();
337 nancyw 1.19.2.11.2.20 if (isset($voc->nodes) && !empty($voc->nodes)) {
338     foreach ($voc->nodes as $key => $type) {
339     $voc_node_types[] = $node_types[$type];
340     }
341     }
342     else {
343     drupal_set_message(t('The %name vocabulary does not appear to be associated with any content types.', array('%name' => $voc->name)), 'warning');
344 nancyw 1.19.2.11.2.7 }
345 nancyw 1.19.2.11.2.20
346 nancyw 1.19.2.11.2.7 $count_types = count($voc_node_types);
347     if (count($voc_node_types) == 1) {
348     $node_type_list = $voc_node_types[0];
349     }
350     else {
351     $node_type_list = implode(', ', $voc_node_types);
352     }
353    
354 nancyw 1.19.2.5 $tree = taxonomy_get_tree($v);
355     $term_opts = array();
356    
357     if ($tree) {
358     foreach ($tree as $term) {
359 nancyw 1.19.2.11.2.1 $opt_string = null;
360 nancyw 1.19.2.10 if ($count_nodes) {
361 nancyw 1.19.2.11.2.16 $count = taxonomy_term_count_nodes($term->tid);
362 nancyw 1.19.2.10 if ($count > 0 || $show_unused) {
363 nancyw 1.19.2.11.2.19 $opt_string = decode_entities(check_plain($term->name)) .' ('. $count .')';
364 nancyw 1.19.2.10 }
365     }
366     else {
367 nancyw 1.19.2.11.2.19 $opt_string = decode_entities(check_plain($term->name));
368 nancyw 1.19.2.11.2.1 }
369     if ($opt_string) {
370     $term_opts[$term->tid] = str_repeat('-', $term->depth) . $opt_string;
371 nancyw 1.19.2.10 }
372 nancyw 1.19.2.5 }
373     }
374    
375 nancyw 1.19.2.11.2.20 $vocname = check_plain($voc->name);
376     $description = $voc->description ? decode_entities(check_markup($voc->description)) : null;
377     $description .= t('"!name" is used for: !types.', array('!name' => '<strong>'. $vocname .'</strong>', '!types' => (empty($node_type_list) ? '<em>'. t('nothing') .'</em>' : $node_type_list)));
378 nancyw 1.19.2.10 if (!empty($term_opts)) {
379 nancyw 1.19.2.11.2.1 $form['taxonomy'][$v] = array(
380     '#type' => $select_type,
381 nancyw 1.19.2.11.2.12 '#title' => $vocname,
382 nancyw 1.19.2.10 '#options' => $term_opts,
383     '#multiple' => true,
384 nancyw 1.19.2.11.2.20 '#description' => $description,
385 nancyw 1.19.2.10 '#size' => min(10, count($term_opts)),
386 nancyw 1.19.2.11.2.1 '#prefix' => '<div class="taxonomy_browser_'. $select_type .'">',
387 nancyw 1.19.2.10 '#suffix' => '</div>',
388 nancyw 1.19.2.11.2.7 '#field_suffix' => $node_type_list,
389 nancyw 1.19.2.10 '#weight' => $i,
390     );
391 nancyw 1.19.2.11.2.7 ++$i;
392 nancyw 1.19.2.10 }
393 jaza 1.17 }
394    
395     $form['submit'] = array(
396     '#type' => 'submit',
397     '#value' => t('Search'),
398 nancyw 1.19.2.11.2.7 // '#submit' => TRUE,
399     );
400 nancyw 1.19.2.1
401     return $form;
402 jaza 1.17 }
403    
404     /**
405 nancyw 1.19.2.11.2.3 * Implementation of hook_theme().
406     */
407     function taxonomy_browser_theme() {
408     return array(
409     'taxonomy_browser_page' => array(
410     'arguments' => array('form'),
411     ),
412     );
413     }
414    
415     /**
416 jaza 1.17 * Themable form output for the category browser page.
417     */
418     function theme_taxonomy_browser_page($form) {
419     $output = '';
420    
421     $vocabularies = variable_get('taxonomy_browser_vocabularies', array());
422     if (empty($vocabularies)) {
423 nancyw 1.19.2.2 form_set_error('taxonomy_browser_page', t('You must select the vocabularies to display from the <a href="%link">taxonomy browser settings page</a>.', array('%link' => url('admin/settings/taxonomy_browser'))));
424 jaza 1.17 return ' ';
425     }
426    
427 nancyw 1.19.2.2 $output .= drupal_render($form);
428 jaza 1.17 return $output;
429     }
430    
431     /**
432     * Implementation of hook_form_validate().
433     */
434 nancyw 1.19.2.11.2.1 function taxonomy_browser_form_validate($form, &$form_state) {
435 nancyw 1.19.2.11.2.4
436     $include_children = $form_state['values']['include_children'];
437     $tids = _taxonomy_browser_get_tid_list($form_state['values']['taxonomy'], $include_children);
438    
439     $operator = $form_state['values']['operator'] ? 'or' : 'and';
440    
441     if ($operator == 'and' && $include_children == true) {
442     form_set_error('operator', t('You must use "Items containing <strong>any</strong>" to include child terms.'));
443     }
444    
445 jaza 1.17 if (empty($tids)) {
446     form_set_error('taxonomy', t('You must select at least one category in your search.'));
447     }
448     else {
449 nancyw 1.19.2.11.2.7 // $node_type = (isset($form_values['node_filter']) && $form_values['node_filter'] != 'all') ? $form_values['node_filter'] : NULL;
450     $node_type = str_replace(',0', '', implode(',', $form_state['values']['node_filter']));
451    
452 jaza 1.17 if (!taxonomy_browser_count_nodes($tids, $operator, 0, $node_type)) {
453     form_set_error('taxonomy', t('No posts match your criteria.'));
454     }
455     }
456     }
457    
458     /**
459     * Implementation of hook_form_submit().
460     */
461 nancyw 1.19.2.11.2.1 function taxonomy_browser_form_submit($form, &$form_state) {
462 jaza 1.17 $tids = _taxonomy_browser_get_tid_list();
463 nancyw 1.19.2.1
464 nancyw 1.19.2.11.2.1 $operator = $form_state['values']['operator'] ? 'or' : 'and';
465 jaza 1.17 $str_tids = ($operator == 'and') ? implode(',', $tids) : implode('+', $tids);
466 nancyw 1.19.2.11.2.4
467 nancyw 1.19.2.11.2.7 $types = array_filter($form_state['values']['node_filter']);
468     $node_type = str_replace(',0', '', implode(',', $types));
469    
470     if ($types) {
471     $redir = array('taxonomy/term/'. $str_tids, (isset($node_type) ? 'type='. $node_type : ''));
472     }
473     else {
474     $redir = 'taxonomy/term/'. $str_tids;
475     }
476    
477     $form_state['redirect'] = $redir;
478 jaza 1.17 }
479    
480 nancyw 1.19.2.11.2.4 //********************************************************************
481 nancyw 1.19.2.11.2.12 //* Module Functions : Private
482 nancyw 1.19.2.11.2.4 //********************************************************************
483 jaza 1.17
484     /**
485 nancyw 1.19.2.11.2.12 * Get the output to be displayed by the block.
486     *
487     * @param
488     * $delta - integer for the block number.
489     *
490     * @return
491     * array containing the title ("subject") and content of the block.
492     */
493     function _taxonomy_browser_block_view($delta) {
494     $block = array();
495     switch ($delta) {
496     case 0:
497     $block = array(
498     'content' => drupal_get_form('taxonomy_browser_form'),
499     );
500     break;
501     }
502     return $block;
503     }
504    
505     /**
506 jaza 1.17 * Private function to count the number of nodes found by the user's query.
507     */
508     function taxonomy_browser_count_nodes($tids = array(), $operator = 'or', $depth = 0, $nodetype = NULL) {
509     if (count($tids) > 0) {
510     // For each term ID, generate an array of descendant term IDs to the right depth.
511     $descendant_tids = array();
512     if ($depth === 'all') {
513     $depth = NULL;
514     }
515     foreach ($tids as $index => $tid) {
516     $term = taxonomy_get_term($tid);
517     $tree = taxonomy_get_tree($term->vid, $tid, -1, $depth);
518     $descendant_tids[] = array_merge(array($tid), array_map('_taxonomy_get_tid_from_term', $tree));
519     }
520    
521 nancyw 1.19.2.3 $type_where = null;
522     if ($nodetype) {
523 nancyw 1.19.2.11.2.7 // $type_where = "n.type = '". db_escape_string($nodetype) ."'";
524     $type_where = "n.type IN ('". implode("', '", explode(',', db_escape_string($nodetype))) ."')";
525 nancyw 1.19.2.3 }
526 nancyw 1.19.2.11.2.7
527 jaza 1.17 if ($operator == 'or') {
528     $str_tids = implode(',', call_user_func_array('array_merge', $descendant_tids));
529    
530 nancyw 1.19.2.3 $sql_count = 'SELECT COUNT(n.nid) FROM {node} n INNER JOIN {term_node} tn USING(nid) WHERE '. ($type_where ? $type_where .' AND ' : null) ."tn.tid IN ($str_tids) ORDER BY n.sticky DESC, n.title ASC";
531 jaza 1.17 }
532     else {
533     $joins = '';
534     $wheres = array();
535 nancyw 1.19.2.3 if ($type_where) {
536     $wheres[] = $type_where;
537     }
538 jaza 1.17 foreach ($descendant_tids as $index => $tids) {
539 nancyw 1.19.2.11.2.1 $joins .= 'INNER JOIN {term_node} tn'. $index .' ON n.nid = tn'. $index .'.nid ';
540 jaza 1.17 $wheres[] = 'tn'. $index .'.tid IN ('. implode(',', $tids) .')';
541     }
542 nancyw 1.19.2.11.2.1 $sql_count = 'SELECT COUNT(n.nid) FROM {node} n '. $joins .' WHERE '. implode(' AND ', $wheres);
543 jaza 1.17 }
544    
545     return db_result(db_query(db_rewrite_sql($sql_count)));
546     }
547    
548     return 0;
549     }
550    
551     /**
552     * Transforms an unpredictably and irregularly nested set of tids (as returned
553     * from a taxonomy form) into a linear array of tids.
554     */
555 nancyw 1.19.2.11.2.4 function _taxonomy_browser_get_tid_list($tids = null, $include_children = false) {
556 jaza 1.17 static $tid_list;
557 nancyw 1.19.2.11.2.4
558 jaza 1.17 if (isset($tids) && is_array($tids)) {
559     $tid_list = array();
560     foreach ($tids as $key => $tid) {
561     if (!empty($tid)) {
562     if (is_array($tid)) {
563     foreach ($tid as $key2 => $tid2) {
564     if (!empty($tid2)) {
565 nancyw 1.19.2.11.2.4 $tid_list[$tid2] = $tid2;
566 jaza 1.17 }
567     }
568     }
569     else {
570 nancyw 1.19.2.11.2.4 $tid_list[$tid] = $tid;
571 jaza 1.17 }
572 nancyw 1.19.2.11.2.4 } /* end !empty */
573     } /* end foreach */
574 jaza 1.17 }
575    
576 nancyw 1.19.2.11.2.4 if ($include_children) {
577     foreach ($tid_list as $tid) {
578     _taxonomy_browser_get_kids($tid_list, $tid);
579     }
580     }
581    
582 jaza 1.17 return $tid_list;
583     }
584    
585 nancyw 1.19.2.11.2.4 function _taxonomy_browser_get_kids(&$tid_list, $tid) {
586     $children = taxonomy_get_children($tid);
587     if ($children) {
588     foreach ($children as $child_tid => $child_term) {
589     _taxonomy_browser_get_kids($tid_list, $child_tid);
590     }
591     }
592     else {
593     $tid_list[$tid] = $tid;
594     }
595     }
596    
597 jaza 1.17 /**
598     * Provides default guideline text.
599     */
600     function _taxonomy_browser_guidelines_default() {
601     return t('<p>You may select multiple items from each list by holding down the <code>Ctrl</code> (Mac: <code>command</code>) key while left-clicking each item.</p>');
602     }

  ViewVC Help
Powered by ViewVC 1.1.2