/[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.19 - (hide annotations) (download) (as text)
Fri Jun 20 04:07:50 2008 UTC (17 months ago) by nancyw
Branch: DRUPAL-6--1
Changes since 1.19.2.11.2.18: +3 -4 lines
File MIME type: text/x-php
#268382 by NancyDru for Junyor - changed htmlspecialchars_decode to decode_entities.
1 jaza 1.17 <?php
2 nancyw 1.19.2.11.2.19 // $Id: taxonomy_browser.module,v 1.19.2.11.2.18 2008/06/16 19:09:42 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     foreach ($voc->nodes as $key => $type) {
338     $voc_node_types[] = $node_types[$type];
339     }
340     $count_types = count($voc_node_types);
341     if (count($voc_node_types) == 1) {
342     $node_type_list = $voc_node_types[0];
343     }
344     else {
345     $node_type_list = implode(', ', $voc_node_types);
346     }
347    
348 nancyw 1.19.2.5 $tree = taxonomy_get_tree($v);
349     $term_opts = array();
350    
351     if ($tree) {
352     foreach ($tree as $term) {
353 nancyw 1.19.2.11.2.1 $opt_string = null;
354 nancyw 1.19.2.10 if ($count_nodes) {
355 nancyw 1.19.2.11.2.16 $count = taxonomy_term_count_nodes($term->tid);
356 nancyw 1.19.2.10 if ($count > 0 || $show_unused) {
357 nancyw 1.19.2.11.2.19 $opt_string = decode_entities(check_plain($term->name)) .' ('. $count .')';
358 nancyw 1.19.2.10 }
359     }
360     else {
361 nancyw 1.19.2.11.2.19 $opt_string = decode_entities(check_plain($term->name));
362 nancyw 1.19.2.11.2.1 }
363     if ($opt_string) {
364     $term_opts[$term->tid] = str_repeat('-', $term->depth) . $opt_string;
365 nancyw 1.19.2.10 }
366 nancyw 1.19.2.5 }
367     }
368    
369 nancyw 1.19.2.11.2.12 $vocname = filter_xss($voc->name);
370 nancyw 1.19.2.10 if (!empty($term_opts)) {
371 nancyw 1.19.2.11.2.1 $form['taxonomy'][$v] = array(
372     '#type' => $select_type,
373 nancyw 1.19.2.11.2.12 '#title' => $vocname,
374 nancyw 1.19.2.10 '#options' => $term_opts,
375     '#multiple' => true,
376 nancyw 1.19.2.11.2.7 '#description' => $voc->description
377 nancyw 1.19.2.11.2.12 .' &nbsp;'. t('"!name" is used for: !types.', array('!name' => '<strong>'. $vocname .'</strong>', '!types' => $node_type_list)),
378 nancyw 1.19.2.10 '#size' => min(10, count($term_opts)),
379 nancyw 1.19.2.11.2.1 '#prefix' => '<div class="taxonomy_browser_'. $select_type .'">',
380 nancyw 1.19.2.10 '#suffix' => '</div>',
381 nancyw 1.19.2.11.2.7 '#field_suffix' => $node_type_list,
382 nancyw 1.19.2.10 '#weight' => $i,
383     );
384 nancyw 1.19.2.11.2.7 ++$i;
385 nancyw 1.19.2.10 }
386 jaza 1.17 }
387    
388     $form['submit'] = array(
389     '#type' => 'submit',
390     '#value' => t('Search'),
391 nancyw 1.19.2.11.2.7 // '#submit' => TRUE,
392     );
393 nancyw 1.19.2.1
394     return $form;
395 jaza 1.17 }
396    
397     /**
398 nancyw 1.19.2.11.2.3 * Implementation of hook_theme().
399     */
400     function taxonomy_browser_theme() {
401     return array(
402     'taxonomy_browser_page' => array(
403     'arguments' => array('form'),
404     ),
405     );
406     }
407    
408     /**
409 jaza 1.17 * Themable form output for the category browser page.
410     */
411     function theme_taxonomy_browser_page($form) {
412     $output = '';
413    
414     $vocabularies = variable_get('taxonomy_browser_vocabularies', array());
415     if (empty($vocabularies)) {
416 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'))));
417 jaza 1.17 return ' ';
418     }
419    
420 nancyw 1.19.2.2 $output .= drupal_render($form);
421 jaza 1.17 return $output;
422     }
423    
424     /**
425     * Implementation of hook_form_validate().
426     */
427 nancyw 1.19.2.11.2.1 function taxonomy_browser_form_validate($form, &$form_state) {
428 nancyw 1.19.2.11.2.4
429     $include_children = $form_state['values']['include_children'];
430     $tids = _taxonomy_browser_get_tid_list($form_state['values']['taxonomy'], $include_children);
431    
432     $operator = $form_state['values']['operator'] ? 'or' : 'and';
433    
434     if ($operator == 'and' && $include_children == true) {
435     form_set_error('operator', t('You must use "Items containing <strong>any</strong>" to include child terms.'));
436     }
437    
438 jaza 1.17 if (empty($tids)) {
439     form_set_error('taxonomy', t('You must select at least one category in your search.'));
440     }
441     else {
442 nancyw 1.19.2.11.2.7 // $node_type = (isset($form_values['node_filter']) && $form_values['node_filter'] != 'all') ? $form_values['node_filter'] : NULL;
443     $node_type = str_replace(',0', '', implode(',', $form_state['values']['node_filter']));
444    
445 jaza 1.17 if (!taxonomy_browser_count_nodes($tids, $operator, 0, $node_type)) {
446     form_set_error('taxonomy', t('No posts match your criteria.'));
447     }
448     }
449     }
450    
451     /**
452     * Implementation of hook_form_submit().
453     */
454 nancyw 1.19.2.11.2.1 function taxonomy_browser_form_submit($form, &$form_state) {
455 jaza 1.17 $tids = _taxonomy_browser_get_tid_list();
456 nancyw 1.19.2.1
457 nancyw 1.19.2.11.2.1 $operator = $form_state['values']['operator'] ? 'or' : 'and';
458 jaza 1.17 $str_tids = ($operator == 'and') ? implode(',', $tids) : implode('+', $tids);
459 nancyw 1.19.2.11.2.4
460 nancyw 1.19.2.11.2.7 $types = array_filter($form_state['values']['node_filter']);
461     $node_type = str_replace(',0', '', implode(',', $types));
462    
463     if ($types) {
464     $redir = array('taxonomy/term/'. $str_tids, (isset($node_type) ? 'type='. $node_type : ''));
465     }
466     else {
467     $redir = 'taxonomy/term/'. $str_tids;
468     }
469    
470     $form_state['redirect'] = $redir;
471 jaza 1.17 }
472    
473 nancyw 1.19.2.11.2.4 //********************************************************************
474 nancyw 1.19.2.11.2.12 //* Module Functions : Private
475 nancyw 1.19.2.11.2.4 //********************************************************************
476 jaza 1.17
477     /**
478 nancyw 1.19.2.11.2.12 * Get the output to be displayed by the block.
479     *
480     * @param
481     * $delta - integer for the block number.
482     *
483     * @return
484     * array containing the title ("subject") and content of the block.
485     */
486     function _taxonomy_browser_block_view($delta) {
487     $block = array();
488     switch ($delta) {
489     case 0:
490     $block = array(
491     'content' => drupal_get_form('taxonomy_browser_form'),
492     );
493     break;
494     }
495     return $block;
496     }
497    
498     /**
499 jaza 1.17 * Private function to count the number of nodes found by the user's query.
500     */
501     function taxonomy_browser_count_nodes($tids = array(), $operator = 'or', $depth = 0, $nodetype = NULL) {
502     if (count($tids) > 0) {
503     // For each term ID, generate an array of descendant term IDs to the right depth.
504     $descendant_tids = array();
505     if ($depth === 'all') {
506     $depth = NULL;
507     }
508     foreach ($tids as $index => $tid) {
509     $term = taxonomy_get_term($tid);
510     $tree = taxonomy_get_tree($term->vid, $tid, -1, $depth);
511     $descendant_tids[] = array_merge(array($tid), array_map('_taxonomy_get_tid_from_term', $tree));
512     }
513    
514 nancyw 1.19.2.3 $type_where = null;
515     if ($nodetype) {
516 nancyw 1.19.2.11.2.7 // $type_where = "n.type = '". db_escape_string($nodetype) ."'";
517     $type_where = "n.type IN ('". implode("', '", explode(',', db_escape_string($nodetype))) ."')";
518 nancyw 1.19.2.3 }
519 nancyw 1.19.2.11.2.7
520 jaza 1.17 if ($operator == 'or') {
521     $str_tids = implode(',', call_user_func_array('array_merge', $descendant_tids));
522    
523 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";
524 jaza 1.17 }
525     else {
526     $joins = '';
527     $wheres = array();
528 nancyw 1.19.2.3 if ($type_where) {
529     $wheres[] = $type_where;
530     }
531 jaza 1.17 foreach ($descendant_tids as $index => $tids) {
532 nancyw 1.19.2.11.2.1 $joins .= 'INNER JOIN {term_node} tn'. $index .' ON n.nid = tn'. $index .'.nid ';
533 jaza 1.17 $wheres[] = 'tn'. $index .'.tid IN ('. implode(',', $tids) .')';
534     }
535 nancyw 1.19.2.11.2.1 $sql_count = 'SELECT COUNT(n.nid) FROM {node} n '. $joins .' WHERE '. implode(' AND ', $wheres);
536 jaza 1.17 }
537    
538     return db_result(db_query(db_rewrite_sql($sql_count)));
539     }
540    
541     return 0;
542     }
543    
544     /**
545     * Transforms an unpredictably and irregularly nested set of tids (as returned
546     * from a taxonomy form) into a linear array of tids.
547     */
548 nancyw 1.19.2.11.2.4 function _taxonomy_browser_get_tid_list($tids = null, $include_children = false) {
549 jaza 1.17 static $tid_list;
550 nancyw 1.19.2.11.2.4
551 jaza 1.17 if (isset($tids) && is_array($tids)) {
552     $tid_list = array();
553     foreach ($tids as $key => $tid) {
554     if (!empty($tid)) {
555     if (is_array($tid)) {
556     foreach ($tid as $key2 => $tid2) {
557     if (!empty($tid2)) {
558 nancyw 1.19.2.11.2.4 $tid_list[$tid2] = $tid2;
559 jaza 1.17 }
560     }
561     }
562     else {
563 nancyw 1.19.2.11.2.4 $tid_list[$tid] = $tid;
564 jaza 1.17 }
565 nancyw 1.19.2.11.2.4 } /* end !empty */
566     } /* end foreach */
567 jaza 1.17 }
568    
569 nancyw 1.19.2.11.2.4 if ($include_children) {
570     foreach ($tid_list as $tid) {
571     _taxonomy_browser_get_kids($tid_list, $tid);
572     }
573     }
574    
575 jaza 1.17 return $tid_list;
576     }
577    
578 nancyw 1.19.2.11.2.4 function _taxonomy_browser_get_kids(&$tid_list, $tid) {
579     $children = taxonomy_get_children($tid);
580     if ($children) {
581     foreach ($children as $child_tid => $child_term) {
582     _taxonomy_browser_get_kids($tid_list, $child_tid);
583     }
584     }
585     else {
586     $tid_list[$tid] = $tid;
587     }
588     }
589    
590 jaza 1.17 /**
591     * Provides default guideline text.
592     */
593     function _taxonomy_browser_guidelines_default() {
594     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>');
595     }

  ViewVC Help
Powered by ViewVC 1.1.2