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

Last change on this file since 12022 was 11317, checked in by mistic100, 13 years ago

feature:2322 Add two new trigger events for tag name display and tag url

  • Property svn:eol-style set to LF
File size: 14.2 KB
RevLine 
[476]1<?php
2// +-----------------------------------------------------------------------+
[8728]3// | Piwigo - a PHP based photo gallery                                    |
[2297]4// +-----------------------------------------------------------------------+
[8728]5// | Copyright(C) 2008-2011 Piwigo Team                  http://piwigo.org |
[2297]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// +-----------------------------------------------------------------------+
[476]23
[572]24/**
25 * returns the list of categories as a HTML string
26 *
27 * categories string returned contains categories as given in the input
[1866]28 * array $cat_informations. $cat_informations array must be an array
29 * of array( id=>?, name=>?, permalink=>?). If url input parameter is null,
[572]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 */
[569]37function get_cat_display_name($cat_informations,
[1092]38                              $url = '',
[569]39                              $replace_space = true)
[476]40{
[642]41  global $conf;
[1090]42
[5917]43  //$output = '<a href="'.get_absolute_root_url().$conf['home_page'].'">'.l10n('Home').'</a>';
44  $output = '';
[5924]45  $is_first=true;
[8247]46
[1866]47  foreach ($cat_informations as $cat)
[476]48  {
[1861]49    is_array($cat) or trigger_error(
[1866]50        'get_cat_display_name wrong type for category ', E_USER_WARNING
[1861]51      );
[2433]52
53    $cat['name'] = trigger_event(
54      'render_category_name',
55      $cat['name'],
56      'get_cat_display_name'
57      );
[5924]58
59    if ($is_first)
[5917]60    {
[5924]61      $is_first=false;
62    }
63    else
64    {
[5917]65      $output.= $conf['level_separator'];
66    }
[2433]67
[1092]68    if ( !isset($url) )
[569]69    {
[1861]70      $output.= $cat['name'];
[569]71    }
[1092]72    elseif ($url == '')
73    {
[1789]74      $output.= '<a href="'
[1748]75            .make_index_url(
[1131]76                array(
[1861]77                  'category' => $cat,
[1748]78                  )
[1131]79              )
80            .'">';
[1861]81      $output.= $cat['name'].'</a>';
[1092]82    }
[569]83    else
84    {
[1866]85      $output.= '<a href="'.PHPWG_ROOT_PATH.$url.$cat['id'].'">';
[1861]86      $output.= $cat['name'].'</a>';
[569]87    }
[476]88  }
[569]89  if ($replace_space)
90  {
91    return replace_space($output);
92  }
93  else
94  {
95    return $output;
96  }
[476]97}
98
99/**
[610]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,
[1092]113                                    $url = '',
[9367]114                                    $replace_space = true,
115                                    $single_link = false,
116                                    $link_class = null)
[610]117{
[1861]118  global $cache, $conf;
[610]119
[1861]120  if (!isset($cache['cat_names']))
[610]121  {
122    $query = '
[1866]123SELECT id, name, permalink
[610]124  FROM '.CATEGORIES_TABLE.'
125;';
[1866]126    $cache['cat_names'] = hash_from_query($query, 'id');
[610]127  }
[1090]128
[610]129  $output = '';
[9367]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  }
[610]140  $is_first = true;
141  foreach (explode(',', $uppercats) as $category_id)
142  {
[1861]143    $cat = $cache['cat_names'][$category_id];
[1090]144
[2433]145    $cat['name'] = trigger_event(
146      'render_category_name',
147      $cat['name'],
148      'get_cat_display_name_cache'
149      );
150
[610]151    if ($is_first)
152    {
153      $is_first = false;
154    }
155    else
156    {
[642]157      $output.= $conf['level_separator'];
[610]158    }
159
[9367]160    if ( !isset($url) or $single_link )
[610]161    {
[1861]162      $output.= $cat['name'];
[610]163    }
[1092]164    elseif ($url == '')
165    {
166      $output.= '
[1789]167<a href="'
[1131]168      .make_index_url(
169          array(
[1861]170            'category' => $cat,
[1131]171            )
172        )
[1861]173      .'">'.$cat['name'].'</a>';
[1092]174    }
[610]175    else
176    {
177      $output.= '
[1861]178<a href="'.PHPWG_ROOT_PATH.$url.$category_id.'">'.$cat['name'].'</a>';
[610]179    }
180  }
[9367]181 
182  if ($single_link and isset($single_url))
183  {
184    $output.= '</a>';
185  }
186
[610]187  if ($replace_space)
188  {
189    return replace_space($output);
190  }
191  else
192  {
193    return $output;
194  }
195}
196
197/**
[579]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 */
[8247]206function render_comment_content($content)
[579]207{
[8247]208  $content = htmlspecialchars($content);
[1031]209  $pattern = '/(https?:\/\/\S*)/';
210  $replacement = '<a href="$1" rel="nofollow">$1</a>';
211  $content = preg_replace($pattern, $replacement, $content);
212
[579]213  $content = nl2br($content);
[1090]214
[579]215  // replace _word_ by an underlined word
[1030]216  $pattern = '/\b_(\S*)_\b/';
217  $replacement = '<span style="text-decoration:underline;">$1</span>';
[579]218  $content = preg_replace($pattern, $replacement, $content);
[1090]219
[579]220  // replace *word* by a bolded word
[1030]221  $pattern = '/\b\*(\S*)\*\b/';
222  $replacement = '<span style="font-weight:bold;">$1</span>';
[579]223  $content = preg_replace($pattern, $replacement, $content);
[1090]224
[579]225  // replace /word/ by an italic word
[1031]226  $pattern = "/\/(\S*)\/(\s)/";
227  $replacement = '<span style="font-style:italic;">$1$2</span>';
228  $content = preg_replace($pattern, $replacement, $content);
[579]229
230  return $content;
231}
[817]232
233function get_cat_display_name_from_id($cat_id,
[1092]234                                      $url = '',
[817]235                                      $replace_space = true)
236{
237  $cat_info = get_cat_info($cat_id);
[1861]238  return get_cat_display_name($cat_info['upper_names'], $url, $replace_space);
[817]239}
[1113]240
241/**
[1119]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;
[1131]257
[1201]258  if (count ($tags) == 0 )
259  {
260    return '';
261  }
[1119]262  $output = '<ul class="tagSelection">';
263  foreach ($tags as $tag)
264  {
265    $output.=
266      '<li>'
267      .'<label>'
268      .'<input type="checkbox" name="'.$fieldname.'[]"'
[1815]269      .' value="'.$tag['id'].'"'
[1119]270      ;
271
[1815]272    if (in_array($tag['id'], $selecteds))
[1119]273    {
274      $output.= ' checked="checked"';
275    }
[1131]276
[1119]277    $output.=
[11317]278      '> '
[8725]279      .$tag['name']
[1119]280      .'</label>'
281      .'</li>'
282      ."\n"
283      ;
284  }
285  $output.= '</ul>';
286
287  return $output;
288}
289
290function name_compare($a, $b)
291{
[1310]292  return strcmp(strtolower($a['name']), strtolower($b['name']));
[1119]293}
294
[2409]295function tag_alpha_compare($a, $b)
296{
297  return strcmp(strtolower($a['url_name']), strtolower($b['url_name']));
298}
299
[1119]300/**
[1113]301 * exits the current script (either exit or redirect)
302 */
303function access_denied()
304{
[2265]305  global $user;
[1113]306
307  $login_url =
308      get_root_url().'identification.php?redirect='
309      .urlencode(urlencode($_SERVER['REQUEST_URI']));
310
[2543]311  set_status_header(401);
[2029]312  if ( isset($user) and !is_a_guest() )
[1113]313  {
[2884]314    echo '<meta http-equiv="Content-Type" content="text/html; charset=utf-8">';
[5021]315    echo '<div style="text-align:center;">'.l10n('You are not authorized to access the requested page').'<br>';
[6316]316    echo '<a href="'.get_root_url().'identification.php">'.l10n('Identification').'</a>&nbsp;';
[5021]317    echo '<a href="'.make_index_url().'">'.l10n('Home').'</a></div>';
[2543]318    echo str_repeat( ' ', 512); //IE6 doesn't error output if below a size
[1113]319    exit();
320  }
321  else
322  {
[1649]323    redirect_html($login_url);
[1113]324  }
325}
[1288]326
327/**
[1652]328 * exits the current script with 403 code
329 * @param string msg a message to display
330 * @param string alternate_url redirect to this url
331 */
332function page_forbidden($msg, $alternate_url=null)
333{
334  set_status_header(403);
335  if ($alternate_url==null)
336    $alternate_url = make_index_url();
337  redirect_html( $alternate_url,
338    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
[3185]339<h1 style="text-align:left; font-size:36px;">Forbidden</h1><br>'
[1652]340.$msg.'</div>',
341    5 );
342}
343
344/**
[1852]345 * exits the current script with 400 code
346 * @param string msg a message to display
347 * @param string alternate_url redirect to this url
348 */
349function bad_request($msg, $alternate_url=null)
350{
351  set_status_header(400);
352  if ($alternate_url==null)
353    $alternate_url = make_index_url();
354  redirect_html( $alternate_url,
355    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
[3185]356<h1 style="text-align:left; font-size:36px;">Bad request</h1><br>'
[1852]357.$msg.'</div>',
358    5 );
359}
360
361/**
[1288]362 * exits the current script with 404 code when a page cannot be found
363 * @param string msg a message to display
364 * @param string alternate_url redirect to this url
365 */
366function page_not_found($msg, $alternate_url=null)
367{
[1643]368  set_status_header(404);
[1288]369  if ($alternate_url==null)
370    $alternate_url = make_index_url();
[1649]371  redirect_html( $alternate_url,
[1288]372    '<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
[3185]373<h1 style="text-align:left; font-size:36px;">Page not found</h1><br>'
[1288]374.$msg.'</div>',
375    5 );
376}
[1606]377
[2502]378/**
379 * exits the current script with 500 http code
380 * this method can be called at any time (does not use template/language/user etc...)
381 * @param string msg a message to display
382 */
[5985]383function fatal_error($msg, $title=null, $show_trace=true)
[2502]384{
[5985]385  if (empty($title))
386  {
387    $title = 'Piwigo encountered a non recoverable error';
388  }
[8247]389
[2502]390  $btrace_msg = '';
[5985]391  if ($show_trace and function_exists('debug_backtrace'))
[2502]392  {
393    $bt = debug_backtrace();
394    for ($i=1; $i<count($bt); $i++)
395    {
396      $class = isset($bt[$i]['class']) ? (@$bt[$i]['class'].'::') : '';
397      $btrace_msg .= "#$i\t".$class.@$bt[$i]['function'].' '.@$bt[$i]['file']."(".@$bt[$i]['line'].")\n";
398    }
399    $btrace_msg = trim($btrace_msg);
400    $msg .= "\n";
401  }
402
[2747]403  $display = "<meta http-equiv='Content-Type' content='text/html; charset=utf-8'>
[5985]404<h1>$title</h1>
[2502]405<pre style='font-size:larger;background:white;color:red;padding:1em;margin:0;clear:both;display:block;width:auto;height:auto;overflow:auto'>
406<b>$msg</b>
407$btrace_msg
408</pre>\n";
409
410  @set_status_header(500);
[2543]411  echo $display.str_repeat( ' ', 300); //IE6 doesn't error output if below a size
[2502]412
413  if ( function_exists('ini_set') )
414  {// if possible turn off error display (we display it)
415    ini_set('display_errors', false);
416  }
417  error_reporting( E_ALL );
418  trigger_error( strip_tags($msg).$btrace_msg, E_USER_ERROR );
419  die(0); // just in case
420}
421
[1606]422/* returns the title to be displayed above thumbnails on tag page
423 */
424function get_tags_content_title()
425{
426  global $page;
[5021]427  $title = count($page['tags']) > 1 ? l10n('Tag') : l10n('Tag');
[1606]428  $title.= ' ';
429
430  for ($i=0; $i<count($page['tags']); $i++)
431  {
432    $title.= $i>0 ? ' + ' : '';
433
434    $title.=
435      '<a href="'
436      .make_index_url(
437        array(
438          'tags' => array( $page['tags'][$i] )
439          )
440        )
441      .'" title="'
[8665]442      .l10n('display photos linked to this tag')
[1606]443      .'">'
[11317]444      .trigger_event('render_tag_name', $page['tags'][$i]['name'])
[1606]445      .'</a>';
446
[5706]447    $remove_url = null;
448    if (count($page['tags']) == 1)
[1606]449    {
[5706]450      $remove_url = get_root_url().'tags.php';
451    }
452    else
453    {
[1606]454      $other_tags = $page['tags'];
[5706]455      unset($other_tags[$i]);
456      $remove_url = make_index_url(
457        array(
458          'tags' => $other_tags
[1606]459          )
[5706]460        );
461    }
[8247]462
[5706]463    $title.=
464      '<a href="'.$remove_url.'" style="border:none;" title="'
465      .l10n('remove this tag from the list')
466      .'"><img src="'
[1606]467        .get_root_url().get_themeconf('icon_dir').'/remove_s.png'
[5706]468      .'" alt="x" style="vertical-align:bottom;" class="button">'
469      .'</a>';
[1606]470  }
471  return $title;
472}
[1643]473
474/**
475  Sets the http status header (200,401,...)
476 */
477function set_status_header($code, $text='')
478{
479  if (empty($text))
480  {
481    switch ($code)
482    {
483      case 200: $text='OK';break;
484      case 301: $text='Moved permanently';break;
485      case 302: $text='Moved temporarily';break;
486      case 304: $text='Not modified';break;
487      case 400: $text='Bad request';break;
488      case 401: $text='Authorization required';break;
489      case 403: $text='Forbidden';break;
490      case 404: $text='Not found';break;
[2053]491      case 500: $text='Server error';break;
[2543]492      case 501: $text='Not implemented';break;
[2053]493      case 503: $text='Service unavailable';break;
[1643]494    }
495  }
[5682]496  $protocol = $_SERVER["SERVER_PROTOCOL"];
497  if ( ('HTTP/1.1' != $protocol) && ('HTTP/1.0' != $protocol) )
498    $protocol = 'HTTP/1.0';
[2053]499
[8247]500  header( "$protocol $code $text", true, $code );
[1744]501  trigger_action('set_status_header', $code, $text);
[1643]502}
[1769]503
[2117]504/** returns the category comment for rendering in html textual mode (subcatify)
505 * this is an event handler. don't call directly
506 */
507function render_category_literal_description($desc)
508{
509  return strip_tags($desc, '<span><p><a><br><b><i><small><big><strong><em>');
510}
[2349]511
[2488]512/*event handler for menu*/
513function register_default_menubar_blocks( $menu_ref_arr )
514{
515  $menu = & $menu_ref_arr[0];
516  if ($menu->get_id() != 'menubar')
517    return;
518  $menu->register_block( new RegisteredBlock( 'mbLinks', 'Links', 'piwigo'));
[6993]519  $menu->register_block( new RegisteredBlock( 'mbCategories', 'Albums', 'piwigo'));
[2488]520  $menu->register_block( new RegisteredBlock( 'mbTags', 'Related tags', 'piwigo'));
[5178]521  $menu->register_block( new RegisteredBlock( 'mbSpecials', 'Specials', 'piwigo'));
522  $menu->register_block( new RegisteredBlock( 'mbMenu', 'Menu', 'piwigo'));
523  $menu->register_block( new RegisteredBlock( 'mbIdentification', 'Identification', 'piwigo') );
[2488]524}
525
[6993]526?>
Note: See TracBrowser for help on using the repository browser.