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

Last change on this file since 22505 was 22505, checked in by flop25, 11 years ago

bug:2896
thx to Kaare
apply render_element_description inside get_thumbnail_title()

  • Property svn:eol-style set to LF
File size: 17.0 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | Piwigo - a PHP based photo gallery                                    |
4// +-----------------------------------------------------------------------+
5// | Copyright(C) 2008-2013 Piwigo Team                  http://piwigo.org |
6// | Copyright(C) 2003-2008 PhpWebGallery Team    http://phpwebgallery.net |
7// | Copyright(C) 2002-2003 Pierrick LE GALL   http://le-gall.net/pierrick |
8// +-----------------------------------------------------------------------+
9// | This program is free software; you can redistribute it and/or modify  |
10// | it under the terms of the GNU General Public License as published by  |
11// | the Free Software Foundation                                          |
12// |                                                                       |
13// | This program is distributed in the hope that it will be useful, but   |
14// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
15// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
16// | General Public License for more details.                              |
17// |                                                                       |
18// | You should have received a copy of the GNU General Public License     |
19// | along with this program; if not, write to the Free Software           |
20// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
21// | USA.                                                                  |
22// +-----------------------------------------------------------------------+
23
24/**
25 * returns the list of categories as a HTML string
26 *
27 * categories string returned contains categories as given in the input
28 * array $cat_informations. $cat_informations array must be an array
29 * of array( id=>?, name=>?, permalink=>?). If url input parameter is null,
30 * returns only the categories name without links.
31 *
32 * @param array cat_informations
33 * @param string url
34 * @param boolean replace_space
35 * @return string
36 */
37function get_cat_display_name($cat_informations,
38                              $url = '',
39                              $replace_space = false)
40{
41  global $conf;
42
43  //$output = '<a href="'.get_absolute_root_url().$conf['home_page'].'">'.l10n('Home').'</a>';
44  $output = '';
45  $is_first=true;
46
47  foreach ($cat_informations as $cat)
48  {
49    is_array($cat) or trigger_error(
50        'get_cat_display_name wrong type for category ', E_USER_WARNING
51      );
52
53    $cat['name'] = trigger_event(
54      'render_category_name',
55      $cat['name'],
56      'get_cat_display_name'
57      );
58
59    if ($is_first)
60    {
61      $is_first=false;
62    }
63    else
64    {
65      $output.= $conf['level_separator'];
66    }
67
68    if ( !isset($url) )
69    {
70      $output.= $cat['name'];
71    }
72    elseif ($url == '')
73    {
74      $output.= '<a href="'
75            .make_index_url(
76                array(
77                  'category' => $cat,
78                  )
79              )
80            .'">';
81      $output.= $cat['name'].'</a>';
82    }
83    else
84    {
85      $output.= '<a href="'.PHPWG_ROOT_PATH.$url.$cat['id'].'">';
86      $output.= $cat['name'].'</a>';
87    }
88  }
89  if ($replace_space)
90  {
91    return replace_space($output);
92  }
93  else
94  {
95    return $output;
96  }
97}
98
99/**
100 * returns the list of categories as a HTML string, with cache of names
101 *
102 * categories string returned contains categories as given in the input
103 * array $cat_informations. $uppercats is the list of category ids to
104 * display in the right order. If url input parameter is empty, returns only
105 * the categories name without links.
106 *
107 * @param string uppercats
108 * @param string url
109 * @param boolean replace_space
110 * @return string
111 */
112function get_cat_display_name_cache($uppercats,
113                                    $url = '',
114                                    $replace_space = false,
115                                    $single_link = false,
116                                    $link_class = null)
117{
118  global $cache, $conf;
119
120  if (!isset($cache['cat_names']))
121  {
122    $query = '
123SELECT id, name, permalink
124  FROM '.CATEGORIES_TABLE.'
125;';
126    $cache['cat_names'] = hash_from_query($query, 'id');
127  }
128
129  $output = '';
130  if ($single_link)
131  {
132    $single_url = get_root_url().$url.array_pop(explode(',', $uppercats));
133    $output.= '<a href="'.$single_url.'"';
134    if (isset($link_class))
135    {
136      $output.= ' class="'.$link_class.'"';
137    }
138    $output.= '>';
139  }
140  $is_first = true;
141  foreach (explode(',', $uppercats) as $category_id)
142  {
143    $cat = $cache['cat_names'][$category_id];
144
145    $cat['name'] = trigger_event(
146      'render_category_name',
147      $cat['name'],
148      'get_cat_display_name_cache'
149      );
150
151    if ($is_first)
152    {
153      $is_first = false;
154    }
155    else
156    {
157      $output.= $conf['level_separator'];
158    }
159
160    if ( !isset($url) or $single_link )
161    {
162      $output.= $cat['name'];
163    }
164    elseif ($url == '')
165    {
166      $output.= '
167<a href="'
168      .make_index_url(
169          array(
170            'category' => $cat,
171            )
172        )
173      .'">'.$cat['name'].'</a>';
174    }
175    else
176    {
177      $output.= '
178<a href="'.PHPWG_ROOT_PATH.$url.$category_id.'">'.$cat['name'].'</a>';
179    }
180  }
181
182  if ($single_link and isset($single_url))
183  {
184    $output.= '</a>';
185  }
186
187  if ($replace_space)
188  {
189    return replace_space($output);
190  }
191  else
192  {
193    return $output;
194  }
195}
196
197/**
198 * returns HTMLized comment contents retrieved from database
199 *
200 * newlines becomes br tags, _word_ becomes underline, /word/ becomes
201 * italic, *word* becomes bolded
202 *
203 * @param string content
204 * @return string
205 */
206function render_comment_content($content)
207{
208  $content = htmlspecialchars($content);
209  $pattern = '/(https?:\/\/\S*)/';
210  $replacement = '<a href="$1" rel="nofollow">$1</a>';
211  $content = preg_replace($pattern, $replacement, $content);
212
213  $content = nl2br($content);
214
215  // replace _word_ by an underlined word
216  $pattern = '/\b_(\S*)_\b/';
217  $replacement = '<span style="text-decoration:underline;">$1</span>';
218  $content = preg_replace($pattern, $replacement, $content);
219
220  // replace *word* by a bolded word
221  $pattern = '/\b\*(\S*)\*\b/';
222  $replacement = '<span style="font-weight:bold;">$1</span>';
223  $content = preg_replace($pattern, $replacement, $content);
224
225  // replace /word/ by an italic word
226  $pattern = "/\/(\S*)\/(\s)/";
227  $replacement = '<span style="font-style:italic;">$1$2</span>';
228  $content = preg_replace($pattern, $replacement, $content);
229
230  return $content;
231}
232
233function get_cat_display_name_from_id($cat_id,
234                                      $url = '',
235                                      $replace_space = false)
236{
237  $cat_info = get_cat_info($cat_id);
238  return get_cat_display_name($cat_info['upper_names'], $url, $replace_space);
239}
240
241/**
242 * Returns an HTML list of tags. It can be a multi select field or a list of
243 * checkboxes.
244 *
245 * @param string HTML field name
246 * @param array selected tag ids
247 * @return array
248 */
249function get_html_tag_selection(
250  $tags,
251  $fieldname,
252  $selecteds = array(),
253  $forbidden_categories = null
254  )
255{
256  global $conf;
257
258  if (count ($tags) == 0 )
259  {
260    return '';
261  }
262  $output = '<ul class="tagSelection">';
263  foreach ($tags as $tag)
264  {
265    $output.=
266      '<li>'
267      .'<label>'
268      .'<input type="checkbox" name="'.$fieldname.'[]"'
269      .' value="'.$tag['id'].'"'
270      ;
271
272    if (in_array($tag['id'], $selecteds))
273    {
274      $output.= ' checked="checked"';
275    }
276
277    $output.=
278      '> '
279      .$tag['name']
280      .'</label>'
281      .'</li>'
282      ."\n"
283      ;
284  }
285  $output.= '</ul>';
286
287  return $output;
288}
289
290function name_compare($a, $b)
291{
292  return strcmp(strtolower($a['name']), strtolower($b['name']));
293}
294
295function tag_alpha_compare($a, $b)
296{
297  global $cache;
298
299  foreach (array($a, $b) as $tag)
300  {
301    if (!isset($cache[__FUNCTION__][ $tag['name'] ]))
302    {
303      $cache[__FUNCTION__][ $tag['name'] ] = transliterate($tag['name']);
304    }
305  }
306
307  return strcmp($cache[__FUNCTION__][ $a['name'] ], $cache[__FUNCTION__][ $b['name'] ]);
308}
309
310/**
311 * exits the current script (either exit or redirect)
312 */
313function access_denied()
314{
315  global $user;
316
317  $login_url =
318      get_root_url().'identification.php?redirect='
319      .urlencode(urlencode($_SERVER['REQUEST_URI']));
320
321  set_status_header(401);
322  if ( isset($user) and !is_a_guest() )
323  {
324    echo '<meta http-equiv="Content-Type" content="text/html; charset=utf-8">';
325    echo '<div style="text-align:center;">'.l10n('You are not authorized to access the requested page').'<br>';
326    echo '<a href="'.get_root_url().'identification.php">'.l10n('Identification').'</a>&nbsp;';
327    echo '<a href="'.make_index_url().'">'.l10n('Home').'</a></div>';
328    echo str_repeat( ' ', 512); //IE6 doesn't error output if below a size
329    exit();
330  }
331  else
332  {
333    redirect_html($login_url);
334  }
335}
336
337/**
338 * exits the current script with 403 code
339 * @param string msg a message to display
340 * @param string alternate_url redirect to this url
341 */
342function page_forbidden($msg, $alternate_url=null)
343{
344  set_status_header(403);
345  if ($alternate_url==null)
346    $alternate_url = make_index_url();
347  redirect_html( $alternate_url,
348    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
349<h1 style="text-align:left; font-size:36px;">'.l10n('Forbidden').'</h1><br>'
350.$msg.'</div>',
351    5 );
352}
353
354/**
355 * exits the current script with 400 code
356 * @param string msg a message to display
357 * @param string alternate_url redirect to this url
358 */
359function bad_request($msg, $alternate_url=null)
360{
361  set_status_header(400);
362  if ($alternate_url==null)
363    $alternate_url = make_index_url();
364  redirect_html( $alternate_url,
365    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
366<h1 style="text-align:left; font-size:36px;">'.l10n('Bad request').'</h1><br>'
367.$msg.'</div>',
368    5 );
369}
370
371/**
372 * exits the current script with 404 code when a page cannot be found
373 * @param string msg a message to display
374 * @param string alternate_url redirect to this url
375 */
376function page_not_found($msg, $alternate_url=null)
377{
378  set_status_header(404);
379  if ($alternate_url==null)
380    $alternate_url = make_index_url();
381  redirect_html( $alternate_url,
382    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
383<h1 style="text-align:left; font-size:36px;">'.l10n('Page not found').'</h1><br>'
384.$msg.'</div>',
385    5 );
386}
387
388/**
389 * exits the current script with 500 http code
390 * this method can be called at any time (does not use template/language/user etc...)
391 * @param string msg a message to display
392 */
393function fatal_error($msg, $title=null, $show_trace=true)
394{
395  if (empty($title))
396  {
397    $title = l10n('Piwigo encountered a non recoverable error');
398  }
399
400  $btrace_msg = '';
401  if ($show_trace and function_exists('debug_backtrace'))
402  {
403    $bt = debug_backtrace();
404    for ($i=1; $i<count($bt); $i++)
405    {
406      $class = isset($bt[$i]['class']) ? (@$bt[$i]['class'].'::') : '';
407      $btrace_msg .= "#$i\t".$class.@$bt[$i]['function'].' '.@$bt[$i]['file']."(".@$bt[$i]['line'].")\n";
408    }
409    $btrace_msg = trim($btrace_msg);
410    $msg .= "\n";
411  }
412
413  $display = "<meta http-equiv='Content-Type' content='text/html; charset=utf-8'>
414<h1>$title</h1>
415<pre style='font-size:larger;background:white;color:red;padding:1em;margin:0;clear:both;display:block;width:auto;height:auto;overflow:auto'>
416<b>$msg</b>
417$btrace_msg
418</pre>\n";
419
420  @set_status_header(500);
421  echo $display.str_repeat( ' ', 300); //IE6 doesn't error output if below a size
422
423  if ( function_exists('ini_set') )
424  {// if possible turn off error display (we display it)
425    ini_set('display_errors', false);
426  }
427  error_reporting( E_ALL );
428  trigger_error( strip_tags($msg).$btrace_msg, E_USER_ERROR );
429  die(0); // just in case
430}
431
432/* returns the title to be displayed above thumbnails on tag page
433 */
434function get_tags_content_title()
435{
436  global $page;
437  $title = '<a href="'.get_root_url().'tags.php" title="'.l10n('display available tags').'">'
438    . l10n( count($page['tags']) > 1 ? 'Tags' : 'Tag' )
439    . '</a> ';
440
441  for ($i=0; $i<count($page['tags']); $i++)
442  {
443    $title.= $i>0 ? ' + ' : '';
444
445    $title.=
446      '<a href="'
447      .make_index_url(
448        array(
449          'tags' => array( $page['tags'][$i] )
450          )
451        )
452      .'" title="'
453      .l10n('display photos linked to this tag')
454      .'">'
455      .trigger_event('render_tag_name', $page['tags'][$i]['name'])
456      .'</a>';
457
458    if (count($page['tags']) > 2)
459    {
460      $other_tags = $page['tags'];
461      unset($other_tags[$i]);
462      $remove_url = make_index_url(
463        array(
464          'tags' => $other_tags
465          )
466        );
467
468      $title.=
469        '<a href="'.$remove_url.'" style="border:none;" title="'
470        .l10n('remove this tag from the list')
471        .'"><img src="'
472          .get_root_url().get_themeconf('icon_dir').'/remove_s.png'
473        .'" alt="x" style="vertical-align:bottom;">'
474        .'</a>';
475    }
476  }
477  return $title;
478}
479
480/**
481  Sets the http status header (200,401,...)
482 */
483function set_status_header($code, $text='')
484{
485  if (empty($text))
486  {
487    switch ($code)
488    {
489      case 200: $text='OK';break;
490      case 301: $text='Moved permanently';break;
491      case 302: $text='Moved temporarily';break;
492      case 304: $text='Not modified';break;
493      case 400: $text='Bad request';break;
494      case 401: $text='Authorization required';break;
495      case 403: $text='Forbidden';break;
496      case 404: $text='Not found';break;
497      case 500: $text='Server error';break;
498      case 501: $text='Not implemented';break;
499      case 503: $text='Service unavailable';break;
500    }
501  }
502  $protocol = $_SERVER["SERVER_PROTOCOL"];
503  if ( ('HTTP/1.1' != $protocol) && ('HTTP/1.0' != $protocol) )
504    $protocol = 'HTTP/1.0';
505
506  header( "$protocol $code $text", true, $code );
507  trigger_action('set_status_header', $code, $text);
508}
509
510/** returns the category comment for rendering in html textual mode (subcatify)
511 * this is an event handler. don't call directly
512 */
513function render_category_literal_description($desc)
514{
515  return strip_tags($desc, '<span><p><a><br><b><i><small><big><strong><em>');
516}
517
518/*event handler for menu*/
519function register_default_menubar_blocks( $menu_ref_arr )
520{
521  $menu = & $menu_ref_arr[0];
522  if ($menu->get_id() != 'menubar')
523    return;
524  $menu->register_block( new RegisteredBlock( 'mbLinks', 'Links', 'piwigo'));
525  $menu->register_block( new RegisteredBlock( 'mbCategories', 'Albums', 'piwigo'));
526  $menu->register_block( new RegisteredBlock( 'mbTags', 'Related tags', 'piwigo'));
527  $menu->register_block( new RegisteredBlock( 'mbSpecials', 'Specials', 'piwigo'));
528  $menu->register_block( new RegisteredBlock( 'mbMenu', 'Menu', 'piwigo'));
529  $menu->register_block( new RegisteredBlock( 'mbIdentification', 'Identification', 'piwigo') );
530}
531
532/**
533 */
534function render_element_name($info)
535{
536  $name = $info['name'];
537  if (!empty($name))
538  {
539    $name = trigger_event('render_element_name', $name);
540    return $name;
541  }
542
543  return get_name_from_file($info['file']);
544}
545
546function render_element_description($info)
547{
548  $comment = $info['comment'];
549  if (!empty($comment))
550  {
551    $comment = trigger_event('render_element_description', $comment);
552    return $comment;
553  }
554  return '';
555}
556
557/**
558 * returns the title of the thumbnail based on photo properties
559 */
560function get_thumbnail_title($info, $title, $comment)
561{
562  global $conf, $user;
563
564  $details = array();
565
566  if (!empty($info['hit']))
567  {
568    $details[] = $info['hit'].' '.strtolower(l10n('Visits'));
569  }
570
571  if ($conf['rate'] and !empty($info['rating_score']))
572  {
573    $details[] = strtolower(l10n('Rating score')).' '.$info['rating_score'];
574  }
575
576  if (isset($info['nb_comments']) and $info['nb_comments'] != 0)
577  {
578    $details[] = l10n_dec('%d comment', '%d comments', $info['nb_comments']);
579  }
580
581  if (count($details) > 0)
582  {
583    $title.= ' ('.implode(', ', $details).')';
584  }
585
586  if (!empty($comment))
587  {
588    $info['comment'] = trigger_event('render_element_description', $info['comment']); 
589    $title.= ' '.substr($info['comment'], 0, 100).(strlen($info['comment']) > 100 ? '...' : '');
590  }
591
592  $title = htmlspecialchars(strip_tags($title));
593  $title = trigger_event('get_thumbnail_title', $title, $info);
594  return $title;
595}
596
597/** optional event handler to protect src image urls */
598function get_src_image_url_protection_handler($url, $src_image)
599{
600  return get_action_url($src_image->id, $src_image->is_original() ? 'e' : 'r', false);
601}
602
603/** optional event handler to protect element urls */
604function get_element_url_protection_handler($url, $infos)
605{
606  global $conf;
607  if ('images'==$conf['original_url_protection'])
608  {// protect only images and not other file types (for example large movies that we don't want to send through our file proxy)
609    $ext = get_extension($infos['path']);
610    if (!in_array($ext, $conf['picture_ext']))
611    {
612      return $url;
613    }
614  }
615  return get_action_url($infos['id'], 'e', false);
616}
617
618
619function flush_page_messages()
620{
621  global $template, $page;
622  if ($template->get_template_vars('page_refresh') === null)
623  {
624    foreach (array('errors','infos','warnings') as $mode)
625    {
626      if (isset($_SESSION['page_'.$mode]))
627      {
628        $page[$mode] = array_merge($page[$mode], $_SESSION['page_'.$mode]);
629        unset($_SESSION['page_'.$mode]);
630      }
631
632      if (count($page[$mode]) != 0)
633      {
634        $template->assign($mode, $page[$mode]);
635      }
636    }
637  }
638}
639
640?>
Note: See TracBrowser for help on using the repository browser.