source: trunk/include/functions_html.inc.php @ 1866

Last change on this file since 1866 was 1866, checked in by rvelices, 17 years ago

feature 657: permalinks for categories

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 18.0 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | PhpWebGallery - a PHP based picture gallery                           |
4// | Copyright (C) 2002-2003 Pierrick LE GALL - pierrick@phpwebgallery.net |
5// | Copyright (C) 2003-2007 PhpWebGallery Team - http://phpwebgallery.net |
6// +-----------------------------------------------------------------------+
7// | file          : $Id: functions_html.inc.php 1866 2007-02-28 03:07:12Z rvelices $
8// | last update   : $Date: 2007-02-28 03:07:12 +0000 (Wed, 28 Feb 2007) $
9// | last modifier : $Author: rvelices $
10// | revision      : $Revision: 1866 $
11// +-----------------------------------------------------------------------+
12// | This program is free software; you can redistribute it and/or modify  |
13// | it under the terms of the GNU General Public License as published by  |
14// | the Free Software Foundation                                          |
15// |                                                                       |
16// | This program is distributed in the hope that it will be useful, but   |
17// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
18// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
19// | General Public License for more details.                              |
20// |                                                                       |
21// | You should have received a copy of the GNU General Public License     |
22// | along with this program; if not, write to the Free Software           |
23// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
24// | USA.                                                                  |
25// +-----------------------------------------------------------------------+
26
27function get_icon($date, $is_child_date = false)
28{
29  global $page, $user, $lang;
30
31  if (empty($date))
32  {
33    return '';
34  }
35
36  if (isset($page['get_icon_cache'][$date]))
37  {
38    if (! $page['get_icon_cache'][$date] )
39      return '';
40    return $page['get_icon_cache']['_icons_'][$is_child_date];
41  }
42
43  if (!preg_match('/^(\d{4})-(\d{2})-(\d{2})/', $date, $matches))
44  {// date can be empty, no icon to display
45    $page['get_icon_cache'][$date] = false;
46    return '';
47  }
48
49  list($devnull, $year, $month, $day) = $matches;
50  $unixtime = mktime( 0, 0, 0, $month, $day, $year );
51  if ($unixtime === false  // PHP 5.1.0 and above
52      or $unixtime === -1) // PHP prior to 5.1.0
53  {
54    $page['get_icon_cache'][$date] = false;
55    return '';
56  }
57
58  $diff = time() - $unixtime;
59  $day_in_seconds = 24*60*60;
60  $page['get_icon_cache'][$date] = false;
61  if ( $diff < $user['recent_period'] * $day_in_seconds )
62  {
63    if ( !isset($page['get_icon_cache']['_icons_'] ) )
64    {
65      $icons = array(false => 'recent', true => 'recent_by_child' );
66      $title = $lang['recent_image'].'&nbsp;'.$user['recent_period']
67          .'&nbsp;'.$lang['days'];
68      foreach ($icons as $key => $icon)
69      {
70        $icon_url = get_themeconf('icon_dir').'/'.$icon.'.png';
71        $size = getimagesize( PHPWG_ROOT_PATH.$icon_url );
72        $icon_url = get_root_url().$icon_url;
73        $output = '<img title="'.$title.'" src="'.$icon_url.'" class="icon" style="border:0;';
74        $output.= 'height:'.$size[1].'px;width:'.$size[0].'px" alt="(!)" />';
75        $page['get_icon_cache']['_icons_'][$key] = $output;
76      }
77    }
78    $page['get_icon_cache'][$date] = true;
79  }
80  if (! $page['get_icon_cache'][$date] )
81    return '';
82  return $page['get_icon_cache']['_icons_'][$is_child_date];
83}
84
85
86function create_navigation_bar(
87  $url, $nb_element, $start, $nb_element_page, $clean_url = false
88  )
89{
90  global $lang, $conf;
91
92  $pages_around = $conf['paginate_pages_around'];
93  $start_str = $clean_url ? '/start-' :
94    ( ( strstr($url, '?')===false ? '?':'&amp;') . 'start=' );
95
96  $navbar = '';
97
98  // current page detection
99  if (!isset($start)
100      or !is_numeric($start)
101      or (is_numeric($start) and $start < 0))
102  {
103    $start = 0;
104  }
105
106  // navigation bar useful only if more than one page to display !
107  if ($nb_element > $nb_element_page)
108  {
109    // current page and last page
110    $cur_page = ceil($start / $nb_element_page) + 1;
111    $maximum = ceil($nb_element / $nb_element_page);
112
113    // link to first page ?
114    if ($cur_page != 1)
115    {
116      $navbar.=
117        '<a href="'.$url.'" rel="start">'
118        .$lang['first_page']
119        .'</a>';
120    }
121    else
122    {
123      $navbar.= $lang['first_page'];
124    }
125    $navbar.= ' | ';
126    // link on previous page ?
127    if ($start != 0)
128    {
129      $previous = $start - $nb_element_page;
130
131      $navbar.=
132        '<a href="'
133        .$url.($previous > 0 ? $start_str.$previous : '')
134        .'" rel="prev">'
135        .$lang['previous_page']
136        .'</a>';
137    }
138    else
139    {
140      $navbar.= $lang['previous_page'];
141    }
142    $navbar.= ' |';
143
144    if ($cur_page > $pages_around + 1)
145    {
146      $navbar.= '&nbsp;<a href="'.$url.'">1</a>';
147
148      if ($cur_page > $pages_around + 2)
149      {
150        $navbar.= ' ...';
151      }
152    }
153
154    // inspired from punbb source code
155    for ($i = $cur_page - $pages_around, $stop = $cur_page + $pages_around + 1;
156         $i < $stop;
157         $i++)
158    {
159      if ($i < 1 or $i > $maximum)
160      {
161        continue;
162      }
163      else if ($i != $cur_page)
164      {
165        $temp_start = ($i - 1) * $nb_element_page;
166
167        $navbar.=
168          '&nbsp;'
169          .'<a href="'.$url
170          .($temp_start > 0 ? $start_str.$temp_start : '')
171          .'">'
172          .$i
173          .'</a>';
174      }
175      else
176      {
177        $navbar.=
178          '&nbsp;'
179          .'<span class="pageNumberSelected">'
180          .$i
181          .'</span>';
182      }
183    }
184
185    if ($cur_page < ($maximum - $pages_around))
186    {
187      $temp_start = ($maximum - 1) * $nb_element_page;
188
189      if ($cur_page < ($maximum - $pages_around - 1))
190      {
191        $navbar.= ' ...';
192      }
193
194      $navbar.= ' <a href="'.$url.$start_str.$temp_start.'">'.$maximum.'</a>';
195    }
196
197    $navbar.= ' | ';
198    // link on next page ?
199    if ($nb_element > $nb_element_page
200        and $start + $nb_element_page < $nb_element)
201    {
202      $next = $start + $nb_element_page;
203
204      $navbar.=
205        '<a href="'.$url.$start_str.$next.'" rel="next">'
206        .$lang['next_page']
207        .'</a>';
208    }
209    else
210    {
211      $navbar.= $lang['next_page'];
212    }
213
214    $navbar.= ' | ';
215    // link to last page ?
216    if ($cur_page != $maximum)
217    {
218      $temp_start = ($maximum - 1) * $nb_element_page;
219
220      $navbar.=
221        '<a href="'.$url.$start_str.$temp_start.'" rel="last">'
222        .$lang['last_page']
223        .'</a>';
224    }
225    else
226    {
227      $navbar.= $lang['last_page'];
228    }
229  }
230  return $navbar;
231}
232
233/**
234 * returns the list of categories as a HTML string
235 *
236 * categories string returned contains categories as given in the input
237 * array $cat_informations. $cat_informations array must be an array
238 * of array( id=>?, name=>?, permalink=>?). If url input parameter is null,
239 * returns only the categories name without links.
240 *
241 * @param array cat_informations
242 * @param string url
243 * @param boolean replace_space
244 * @return string
245 */
246function get_cat_display_name($cat_informations,
247                              $url = '',
248                              $replace_space = true)
249{
250  global $conf;
251
252  $output = '';
253  $is_first = true;
254  foreach ($cat_informations as $cat)
255  {
256    is_array($cat) or trigger_error(
257        'get_cat_display_name wrong type for category ', E_USER_WARNING
258      );
259    if ($is_first)
260    {
261      $is_first = false;
262    }
263    else
264    {
265      $output.= $conf['level_separator'];
266    }
267
268    if ( !isset($url) )
269    {
270      $output.= $cat['name'];
271    }
272    elseif ($url == '')
273    {
274      $output.= '<a href="'
275            .make_index_url(
276                array(
277                  'category' => $cat,
278                  )
279              )
280            .'">';
281      $output.= $cat['name'].'</a>';
282    }
283    else
284    {
285      $output.= '<a href="'.PHPWG_ROOT_PATH.$url.$cat['id'].'">';
286      $output.= $cat['name'].'</a>';
287    }
288  }
289  if ($replace_space)
290  {
291    return replace_space($output);
292  }
293  else
294  {
295    return $output;
296  }
297}
298
299/**
300 * returns the list of categories as a HTML string, with cache of names
301 *
302 * categories string returned contains categories as given in the input
303 * array $cat_informations. $uppercats is the list of category ids to
304 * display in the right order. If url input parameter is empty, returns only
305 * the categories name without links.
306 *
307 * @param string uppercats
308 * @param string url
309 * @param boolean replace_space
310 * @return string
311 */
312function get_cat_display_name_cache($uppercats,
313                                    $url = '',
314                                    $replace_space = true)
315{
316  global $cache, $conf;
317
318  if (!isset($cache['cat_names']))
319  {
320    $query = '
321SELECT id, name, permalink
322  FROM '.CATEGORIES_TABLE.'
323;';
324    $cache['cat_names'] = hash_from_query($query, 'id');
325  }
326
327  $output = '';
328  $is_first = true;
329  foreach (explode(',', $uppercats) as $category_id)
330  {
331    $cat = $cache['cat_names'][$category_id];
332
333    if ($is_first)
334    {
335      $is_first = false;
336    }
337    else
338    {
339      $output.= $conf['level_separator'];
340    }
341
342    if ( !isset($url) )
343    {
344      $output.= $cat['name'];
345    }
346    elseif ($url == '')
347    {
348      $output.= '
349<a href="'
350      .make_index_url(
351          array(
352            'category' => $cat,
353            )
354        )
355      .'">'.$cat['name'].'</a>';
356    }
357    else
358    {
359      $output.= '
360<a href="'.PHPWG_ROOT_PATH.$url.$category_id.'">'.$cat['name'].'</a>';
361    }
362  }
363  if ($replace_space)
364  {
365    return replace_space($output);
366  }
367  else
368  {
369    return $output;
370  }
371}
372
373/**
374 * returns the HTML code for a category item in the menu (for the main page)
375 *
376 * HTML code generated uses logical list tags ul and each category is an
377 * item li. The paramter given is the category informations as an array,
378 * used keys are : id, name, nb_images, max_date_last, date_last
379 * count_images, count_categories
380 *
381 * @param array categories
382 * @return string
383 */
384function get_html_menu_category($categories, $selected_category)
385{
386  global $lang;
387
388  $ref_level = 0;
389  $level = 0;
390  $menu = '';
391
392  foreach ($categories as $category)
393  {
394    $level = substr_count($category['global_rank'], '.') + 1;
395    if ($level > $ref_level)
396    {
397      $menu.= "\n<ul>";
398    }
399    else if ($level == $ref_level)
400    {
401      $menu.= "\n</li>";
402    }
403    else if ($level < $ref_level)
404    {
405      // we may have to close more than one level at the same time...
406      $menu.= "\n</li>";
407      $menu.= str_repeat("\n</ul></li>",($ref_level-$level));
408    }
409    $ref_level = $level;
410
411    $menu.= "\n\n".'<li';
412    if ($category['id'] == @$selected_category['id'])
413    {
414      $menu.= ' class="selected"';
415    }
416    $menu.= '>';
417
418    $url = make_index_url(
419            array(
420              'category' => $category
421              )
422            );
423
424    $menu.= "\n".'<a href="'.$url.'"';
425    if ($selected_category!=null
426        and $category['id'] == $selected_category['id_uppercat'])
427    {
428      $menu.= ' rel="up"';
429    }
430    $menu.= '>'.$category['name'].'</a>';
431
432    if ( $category['count_images']>0 )
433    {// at least one direct or indirect image
434      $menu.= "\n".'<span class="';
435      // at least one image in this category -> class menuInfoCat
436      $menu.= ($category['nb_images'] > 0 ? "menuInfoCat" 
437                                          : "menuInfoCatByChild").'"';
438      $menu.= ' title="';
439      $menu.= ' '.get_display_images_count
440                  (
441                    $category['nb_images'],
442                    $category['count_images'],
443                    $category['count_categories'],
444                    false,
445                    ' / '
446                  ).'">';
447      // show total number of images
448      $menu.= '['.$category['count_images'].']';
449      $menu.= '</span>';
450    }
451    $child_date_last = @$category['max_date_last']> @$category['date_last'];
452    $menu.= get_icon($category['max_date_last'], $child_date_last);
453  }
454
455  $menu.= str_repeat("\n</li></ul>",($level));
456
457  return $menu;
458}
459
460/**
461 * returns HTMLized comment contents retrieved from database
462 *
463 * newlines becomes br tags, _word_ becomes underline, /word/ becomes
464 * italic, *word* becomes bolded
465 *
466 * @param string content
467 * @return string
468 */
469function parse_comment_content($content)
470{
471  $pattern = '/(https?:\/\/\S*)/';
472  $replacement = '<a href="$1" rel="nofollow">$1</a>';
473  $content = preg_replace($pattern, $replacement, $content);
474
475  $content = nl2br($content);
476
477  // replace _word_ by an underlined word
478  $pattern = '/\b_(\S*)_\b/';
479  $replacement = '<span style="text-decoration:underline;">$1</span>';
480  $content = preg_replace($pattern, $replacement, $content);
481
482  // replace *word* by a bolded word
483  $pattern = '/\b\*(\S*)\*\b/';
484  $replacement = '<span style="font-weight:bold;">$1</span>';
485  $content = preg_replace($pattern, $replacement, $content);
486
487  // replace /word/ by an italic word
488  $pattern = "/\/(\S*)\/(\s)/";
489  $replacement = '<span style="font-style:italic;">$1$2</span>';
490  $content = preg_replace($pattern, $replacement, $content);
491
492  $content = '<div>'.$content.'</div>';
493  return $content;
494}
495
496function get_cat_display_name_from_id($cat_id,
497                                      $url = '',
498                                      $replace_space = true)
499{
500  $cat_info = get_cat_info($cat_id);
501  return get_cat_display_name($cat_info['upper_names'], $url, $replace_space);
502}
503
504/**
505 * Returns an HTML list of tags. It can be a multi select field or a list of
506 * checkboxes.
507 *
508 * @param string HTML field name
509 * @param array selected tag ids
510 * @return array
511 */
512function get_html_tag_selection(
513  $tags,
514  $fieldname,
515  $selecteds = array(),
516  $forbidden_categories = null
517  )
518{
519  global $conf;
520
521  if (count ($tags) == 0 )
522  {
523    return '';
524  }
525  $output = '<ul class="tagSelection">';
526  foreach ($tags as $tag)
527  {
528    $output.=
529      '<li>'
530      .'<label>'
531      .'<input type="checkbox" name="'.$fieldname.'[]"'
532      .' value="'.$tag['id'].'"'
533      ;
534
535    if (in_array($tag['id'], $selecteds))
536    {
537      $output.= ' checked="checked"';
538    }
539
540    $output.=
541      ' />'
542      .' '. $tag['name']
543      .'</label>'
544      .'</li>'
545      ."\n"
546      ;
547  }
548  $output.= '</ul>';
549
550  return $output;
551}
552
553function name_compare($a, $b)
554{
555  return strcmp(strtolower($a['name']), strtolower($b['name']));
556}
557
558/**
559 * exits the current script (either exit or redirect)
560 */
561function access_denied()
562{
563  global $user, $lang;
564
565  $login_url =
566      get_root_url().'identification.php?redirect='
567      .urlencode(urlencode($_SERVER['REQUEST_URI']));
568
569  if ( isset($user['is_the_guest']) and !$user['is_the_guest'] )
570  {
571    echo '<div style="text-align:center;">'.$lang['access_forbiden'].'<br />';
572    echo '<a href="'.get_root_url().'identification.php">'.$lang['identification'].'</a>&nbsp;';
573    echo '<a href="'.make_index_url().'">'.$lang['home'].'</a></div>';
574    exit();
575  }
576  else
577  {
578    set_status_header(401);
579    redirect_html($login_url);
580  }
581}
582
583/**
584 * exits the current script with 403 code
585 * @param string msg a message to display
586 * @param string alternate_url redirect to this url
587 */
588function page_forbidden($msg, $alternate_url=null)
589{
590  set_status_header(403);
591  if ($alternate_url==null)
592    $alternate_url = make_index_url();
593  redirect_html( $alternate_url,
594    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
595<h1 style="text-align:left; font-size:36px;">Forbidden</h1><br/>'
596.$msg.'</div>',
597    5 );
598}
599
600/**
601 * exits the current script with 400 code
602 * @param string msg a message to display
603 * @param string alternate_url redirect to this url
604 */
605function bad_request($msg, $alternate_url=null)
606{
607  set_status_header(400);
608  if ($alternate_url==null)
609    $alternate_url = make_index_url();
610  redirect_html( $alternate_url,
611    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
612<h1 style="text-align:left; font-size:36px;">Bad request</h1><br/>'
613.$msg.'</div>',
614    5 );
615}
616
617/**
618 * exits the current script with 404 code when a page cannot be found
619 * @param string msg a message to display
620 * @param string alternate_url redirect to this url
621 */
622function page_not_found($msg, $alternate_url=null)
623{
624  set_status_header(404);
625  if ($alternate_url==null)
626    $alternate_url = make_index_url();
627  redirect_html( $alternate_url,
628    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
629<h1 style="text-align:left; font-size:36px;">Page not found</h1><br/>'
630.$msg.'</div>',
631    5 );
632}
633
634/* returns the title to be displayed above thumbnails on tag page
635 */
636function get_tags_content_title()
637{
638  global $page;
639  $title = count($page['tags']) > 1 ? l10n('Tags') : l10n('Tag');
640  $title.= ' ';
641
642  for ($i=0; $i<count($page['tags']); $i++)
643  {
644    $title.= $i>0 ? ' + ' : '';
645
646    $title.=
647      '<a href="'
648      .make_index_url(
649        array(
650          'tags' => array( $page['tags'][$i] )
651          )
652        )
653      .'" title="'
654      .l10n('See pictures linked to this tag only')
655      .'">'
656      .$page['tags'][$i]['name']
657      .'</a>';
658
659    if ( count($page['tags'])>2 )
660    {
661      $other_tags = $page['tags'];
662      unset ( $other_tags[$i] );
663      $title.=
664        '<a href="'
665        .make_index_url(
666          array(
667            'tags' => $other_tags
668            )
669          )
670        .'" style="border:none;" title="'
671        .l10n('remove this tag')
672        .'"><img src="'
673        .get_root_url().get_themeconf('icon_dir').'/remove_s.png'
674        .'" alt="x" style="vertical-align:bottom;" class="button"/>'
675        .'</a>';
676    }
677
678  }
679  return $title;
680}
681
682/**
683  Sets the http status header (200,401,...)
684 */
685function set_status_header($code, $text='')
686{
687  if (empty($text))
688  {
689    switch ($code)
690    {
691      case 200: $text='OK';break;
692      case 301: $text='Moved permanently';break;
693      case 302: $text='Moved temporarily';break;
694      case 304: $text='Not modified';break;
695      case 400: $text='Bad request';break;
696      case 401: $text='Authorization required';break;
697      case 403: $text='Forbidden';break;
698      case 404: $text='Not found';break;
699    }
700  }
701  header("HTTP/1.1 $code $text");
702  header("Status: $code $text");
703  trigger_action('set_status_header', $code, $text);
704}
705
706/**
707 * set a class to display a counter
708 * .zero .one .plural
709 */
710function set_span_class($count)
711{
712  if ($count > 1) 
713  { 
714    return 'plural';
715  }
716  return ( $count == 0 ) ? 'zero':'one'; 
717}
718?>
Note: See TracBrowser for help on using the repository browser.