2004-08-06 11:35:07 +02:00
|
|
|
<?php
|
|
|
|
// +-----------------------------------------------------------------------+
|
2008-04-05 00:57:23 +02:00
|
|
|
// | Piwigo - a PHP based picture gallery |
|
|
|
|
// +-----------------------------------------------------------------------+
|
2009-01-05 00:09:15 +01:00
|
|
|
// | Copyright(C) 2008-2009 Piwigo Team http://piwigo.org |
|
2008-04-05 00:57:23 +02:00
|
|
|
// | Copyright(C) 2003-2008 PhpWebGallery Team http://phpwebgallery.net |
|
|
|
|
// | Copyright(C) 2002-2003 Pierrick LE GALL http://le-gall.net/pierrick |
|
|
|
|
// +-----------------------------------------------------------------------+
|
2004-08-06 11:35:07 +02:00
|
|
|
// | This program is free software; you can redistribute it and/or modify |
|
|
|
|
// | it under the terms of the GNU General Public License as published by |
|
|
|
|
// | the Free Software Foundation |
|
|
|
|
// | |
|
|
|
|
// | This program is distributed in the hope that it will be useful, but |
|
|
|
|
// | WITHOUT ANY WARRANTY; without even the implied warranty of |
|
|
|
|
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
|
|
|
// | General Public License for more details. |
|
|
|
|
// | |
|
|
|
|
// | You should have received a copy of the GNU General Public License |
|
|
|
|
// | along with this program; if not, write to the Free Software |
|
|
|
|
// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
|
|
|
|
// | USA. |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
|
2006-12-02 00:31:19 +01:00
|
|
|
function get_icon($date, $is_child_date = false)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2009-02-05 04:04:27 +01:00
|
|
|
global $cache, $user;
|
2004-08-06 11:35:07 +02:00
|
|
|
|
2006-02-13 23:15:56 +01:00
|
|
|
if (empty($date))
|
2004-08-21 15:50:54 +02:00
|
|
|
{
|
2006-12-08 00:21:54 +01:00
|
|
|
return '';
|
2004-08-21 15:50:54 +02:00
|
|
|
}
|
2008-03-23 01:04:46 +01:00
|
|
|
|
2009-02-05 04:04:27 +01:00
|
|
|
if (isset($cache['get_icon'][$date]))
|
2006-02-13 23:15:56 +01:00
|
|
|
{
|
2009-02-05 04:04:27 +01:00
|
|
|
if (! $cache['get_icon'][$date] )
|
2006-12-08 00:21:54 +01:00
|
|
|
return '';
|
2009-02-05 04:04:27 +01:00
|
|
|
return $cache['get_icon']['_icons_'][$is_child_date];
|
2006-02-13 23:15:56 +01:00
|
|
|
}
|
|
|
|
|
2009-02-05 04:04:27 +01:00
|
|
|
if (!isset($cache['get_icon']['sql_recent_date']))
|
2007-03-07 19:51:58 +01:00
|
|
|
{
|
|
|
|
// Use MySql date in order to standardize all recent "actions/queries"
|
2009-02-05 04:04:27 +01:00
|
|
|
list($cache['get_icon']['sql_recent_date']) =
|
2008-01-14 22:08:26 +01:00
|
|
|
mysql_fetch_array(pwg_query('select SUBDATE(
|
|
|
|
CURRENT_DATE,INTERVAL '.$user['recent_period'].' DAY)'));
|
2007-03-07 19:51:58 +01:00
|
|
|
}
|
|
|
|
|
2009-02-05 04:04:27 +01:00
|
|
|
$cache['get_icon'][$date] = false;
|
|
|
|
if ( $date > $cache['get_icon']['sql_recent_date'] )
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2009-02-05 04:04:27 +01:00
|
|
|
if ( !isset($cache['get_icon']['_icons_'] ) )
|
2006-12-08 00:21:54 +01:00
|
|
|
{
|
|
|
|
$icons = array(false => 'recent', true => 'recent_by_child' );
|
2008-03-08 02:38:37 +01:00
|
|
|
$title = sprintf(
|
|
|
|
l10n('elements posted during the last %d days'),
|
|
|
|
$user['recent_period']
|
|
|
|
);
|
2006-12-08 00:21:54 +01:00
|
|
|
foreach ($icons as $key => $icon)
|
|
|
|
{
|
|
|
|
$icon_url = get_themeconf('icon_dir').'/'.$icon.'.png';
|
|
|
|
$size = getimagesize( PHPWG_ROOT_PATH.$icon_url );
|
|
|
|
$icon_url = get_root_url().$icon_url;
|
|
|
|
$output = '<img title="'.$title.'" src="'.$icon_url.'" class="icon" style="border:0;';
|
|
|
|
$output.= 'height:'.$size[1].'px;width:'.$size[0].'px" alt="(!)" />';
|
2009-02-05 04:04:27 +01:00
|
|
|
$cache['get_icon']['_icons_'][$key] = $output;
|
2006-12-08 00:21:54 +01:00
|
|
|
}
|
|
|
|
}
|
2009-02-05 04:04:27 +01:00
|
|
|
$cache['get_icon'][$date] = true;
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
2008-01-14 22:08:26 +01:00
|
|
|
|
2009-02-05 04:04:27 +01:00
|
|
|
if (! $cache['get_icon'][$date] )
|
2006-12-08 00:21:54 +01:00
|
|
|
return '';
|
2009-02-05 04:04:27 +01:00
|
|
|
return $cache['get_icon']['_icons_'][$is_child_date];
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
|
|
|
|
2006-03-16 23:34:45 +01:00
|
|
|
function create_navigation_bar(
|
|
|
|
$url, $nb_element, $start, $nb_element_page, $clean_url = false
|
|
|
|
)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2008-03-08 02:38:37 +01:00
|
|
|
global $conf;
|
2004-12-13 23:54:44 +01:00
|
|
|
|
|
|
|
$pages_around = $conf['paginate_pages_around'];
|
2006-10-17 04:03:14 +02:00
|
|
|
$start_str = $clean_url ? '/start-' :
|
2008-10-18 03:07:13 +02:00
|
|
|
( ( strpos($url, '?')===false ? '?':'&') . 'start=' );
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-12-13 23:59:25 +01:00
|
|
|
$navbar = '';
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-12-13 23:54:44 +01:00
|
|
|
// current page detection
|
|
|
|
if (!isset($start)
|
|
|
|
or !is_numeric($start)
|
|
|
|
or (is_numeric($start) and $start < 0))
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
|
|
|
$start = 0;
|
|
|
|
}
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-12-13 23:54:44 +01:00
|
|
|
// navigation bar useful only if more than one page to display !
|
|
|
|
if ($nb_element > $nb_element_page)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2004-12-13 23:59:25 +01:00
|
|
|
// current page and last page
|
2004-12-13 23:54:44 +01:00
|
|
|
$cur_page = ceil($start / $nb_element_page) + 1;
|
|
|
|
$maximum = ceil($nb_element / $nb_element_page);
|
|
|
|
|
|
|
|
// link to first page ?
|
|
|
|
if ($cur_page != 1)
|
|
|
|
{
|
2006-03-16 23:34:45 +01:00
|
|
|
$navbar.=
|
2008-05-20 02:56:49 +02:00
|
|
|
'<a href="'.$url.'" rel="first">'
|
2008-01-30 23:07:07 +01:00
|
|
|
.l10n('first_page')
|
2006-03-16 23:34:45 +01:00
|
|
|
.'</a>';
|
2004-12-13 23:54:44 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2008-01-30 23:07:07 +01:00
|
|
|
$navbar.= l10n('first_page');
|
2004-12-13 23:54:44 +01:00
|
|
|
}
|
2004-12-13 23:59:25 +01:00
|
|
|
$navbar.= ' | ';
|
2004-12-13 23:54:44 +01:00
|
|
|
// link on previous page ?
|
2006-03-16 23:34:45 +01:00
|
|
|
if ($start != 0)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
|
|
|
$previous = $start - $nb_element_page;
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2006-03-16 23:34:45 +01:00
|
|
|
$navbar.=
|
|
|
|
'<a href="'
|
|
|
|
.$url.($previous > 0 ? $start_str.$previous : '')
|
|
|
|
.'" rel="prev">'
|
2008-01-30 23:07:07 +01:00
|
|
|
.l10n('previous_page')
|
2006-03-16 23:34:45 +01:00
|
|
|
.'</a>';
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
2004-12-13 23:54:44 +01:00
|
|
|
else
|
|
|
|
{
|
2008-01-30 23:07:07 +01:00
|
|
|
$navbar.= l10n('previous_page');
|
2004-12-13 23:54:44 +01:00
|
|
|
}
|
2006-02-10 03:10:41 +01:00
|
|
|
$navbar.= ' |';
|
2004-12-13 23:54:44 +01:00
|
|
|
|
|
|
|
if ($cur_page > $pages_around + 1)
|
|
|
|
{
|
2006-03-16 23:34:45 +01:00
|
|
|
$navbar.= ' <a href="'.$url.'">1</a>';
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2005-01-08 01:18:39 +01:00
|
|
|
if ($cur_page > $pages_around + 2)
|
|
|
|
{
|
|
|
|
$navbar.= ' ...';
|
|
|
|
}
|
2004-12-13 23:54:44 +01:00
|
|
|
}
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-12-13 23:54:44 +01:00
|
|
|
// inspired from punbb source code
|
|
|
|
for ($i = $cur_page - $pages_around, $stop = $cur_page + $pages_around + 1;
|
|
|
|
$i < $stop;
|
|
|
|
$i++)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2004-12-13 23:54:44 +01:00
|
|
|
if ($i < 1 or $i > $maximum)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
else if ($i != $cur_page)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2004-12-13 23:54:44 +01:00
|
|
|
$temp_start = ($i - 1) * $nb_element_page;
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2006-03-16 23:34:45 +01:00
|
|
|
$navbar.=
|
|
|
|
' '
|
|
|
|
.'<a href="'.$url
|
|
|
|
.($temp_start > 0 ? $start_str.$temp_start : '')
|
|
|
|
.'">'
|
|
|
|
.$i
|
|
|
|
.'</a>';
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2006-03-16 23:34:45 +01:00
|
|
|
$navbar.=
|
|
|
|
' '
|
|
|
|
.'<span class="pageNumberSelected">'
|
|
|
|
.$i
|
|
|
|
.'</span>';
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
|
|
|
}
|
2004-12-13 23:54:44 +01:00
|
|
|
|
|
|
|
if ($cur_page < ($maximum - $pages_around))
|
|
|
|
{
|
|
|
|
$temp_start = ($maximum - 1) * $nb_element_page;
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2005-01-08 01:18:39 +01:00
|
|
|
if ($cur_page < ($maximum - $pages_around - 1))
|
|
|
|
{
|
|
|
|
$navbar.= ' ...';
|
|
|
|
}
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2006-03-16 23:34:45 +01:00
|
|
|
$navbar.= ' <a href="'.$url.$start_str.$temp_start.'">'.$maximum.'</a>';
|
2004-12-13 23:54:44 +01:00
|
|
|
}
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-12-13 23:59:25 +01:00
|
|
|
$navbar.= ' | ';
|
2004-12-13 23:54:44 +01:00
|
|
|
// link on next page ?
|
2006-03-16 23:34:45 +01:00
|
|
|
if ($nb_element > $nb_element_page
|
|
|
|
and $start + $nb_element_page < $nb_element)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
|
|
|
$next = $start + $nb_element_page;
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2006-03-16 23:34:45 +01:00
|
|
|
$navbar.=
|
|
|
|
'<a href="'.$url.$start_str.$next.'" rel="next">'
|
2008-01-30 23:07:07 +01:00
|
|
|
.l10n('next_page')
|
2006-03-16 23:34:45 +01:00
|
|
|
.'</a>';
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
2004-12-13 23:54:44 +01:00
|
|
|
else
|
|
|
|
{
|
2008-01-30 23:07:07 +01:00
|
|
|
$navbar.= l10n('next_page');
|
2004-12-13 23:54:44 +01:00
|
|
|
}
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-12-18 23:05:30 +01:00
|
|
|
$navbar.= ' | ';
|
2004-12-13 23:54:44 +01:00
|
|
|
// link to last page ?
|
|
|
|
if ($cur_page != $maximum)
|
|
|
|
{
|
|
|
|
$temp_start = ($maximum - 1) * $nb_element_page;
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2006-03-16 23:34:45 +01:00
|
|
|
$navbar.=
|
|
|
|
'<a href="'.$url.$start_str.$temp_start.'" rel="last">'
|
2008-01-30 23:07:07 +01:00
|
|
|
.l10n('last_page')
|
2006-03-16 23:34:45 +01:00
|
|
|
.'</a>';
|
2004-12-13 23:54:44 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2008-01-30 23:07:07 +01:00
|
|
|
$navbar.= l10n('last_page');
|
2004-12-13 23:54:44 +01:00
|
|
|
}
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
2004-12-13 23:59:25 +01:00
|
|
|
return $navbar;
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
|
|
|
|
2004-10-23 11:00:26 +02:00
|
|
|
/**
|
|
|
|
* returns the list of categories as a HTML string
|
|
|
|
*
|
|
|
|
* categories string returned contains categories as given in the input
|
2007-02-28 04:07:12 +01:00
|
|
|
* array $cat_informations. $cat_informations array must be an array
|
|
|
|
* of array( id=>?, name=>?, permalink=>?). If url input parameter is null,
|
2004-10-23 11:00:26 +02:00
|
|
|
* returns only the categories name without links.
|
|
|
|
*
|
|
|
|
* @param array cat_informations
|
|
|
|
* @param string url
|
|
|
|
* @param boolean replace_space
|
|
|
|
* @return string
|
|
|
|
*/
|
2004-10-21 23:17:46 +02:00
|
|
|
function get_cat_display_name($cat_informations,
|
2006-03-22 02:01:47 +01:00
|
|
|
$url = '',
|
2004-10-21 23:17:46 +02:00
|
|
|
$replace_space = true)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2004-12-12 22:06:39 +01:00
|
|
|
global $conf;
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-08-06 11:35:07 +02:00
|
|
|
$output = '';
|
2004-10-21 23:17:46 +02:00
|
|
|
$is_first = true;
|
2007-02-28 04:07:12 +01:00
|
|
|
foreach ($cat_informations as $cat)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2007-02-27 02:56:16 +01:00
|
|
|
is_array($cat) or trigger_error(
|
2007-02-28 04:07:12 +01:00
|
|
|
'get_cat_display_name wrong type for category ', E_USER_WARNING
|
2007-02-27 02:56:16 +01:00
|
|
|
);
|
2008-07-12 16:57:24 +02:00
|
|
|
|
|
|
|
$cat['name'] = trigger_event(
|
|
|
|
'render_category_name',
|
|
|
|
$cat['name'],
|
|
|
|
'get_cat_display_name'
|
|
|
|
);
|
|
|
|
|
2004-10-21 23:17:46 +02:00
|
|
|
if ($is_first)
|
|
|
|
{
|
|
|
|
$is_first = false;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2004-12-12 22:06:39 +01:00
|
|
|
$output.= $conf['level_separator'];
|
2004-10-21 23:17:46 +02:00
|
|
|
}
|
|
|
|
|
2006-03-22 02:01:47 +01:00
|
|
|
if ( !isset($url) )
|
2004-10-21 23:17:46 +02:00
|
|
|
{
|
2007-02-27 02:56:16 +01:00
|
|
|
$output.= $cat['name'];
|
2004-10-21 23:17:46 +02:00
|
|
|
}
|
2006-03-22 02:01:47 +01:00
|
|
|
elseif ($url == '')
|
|
|
|
{
|
2007-02-08 02:31:05 +01:00
|
|
|
$output.= '<a href="'
|
2007-01-23 23:03:06 +01:00
|
|
|
.make_index_url(
|
2006-04-06 04:23:54 +02:00
|
|
|
array(
|
2007-02-27 02:56:16 +01:00
|
|
|
'category' => $cat,
|
2007-01-23 23:03:06 +01:00
|
|
|
)
|
2006-04-06 04:23:54 +02:00
|
|
|
)
|
|
|
|
.'">';
|
2007-02-27 02:56:16 +01:00
|
|
|
$output.= $cat['name'].'</a>';
|
2006-03-22 02:01:47 +01:00
|
|
|
}
|
2004-10-21 23:17:46 +02:00
|
|
|
else
|
|
|
|
{
|
2007-02-28 04:07:12 +01:00
|
|
|
$output.= '<a href="'.PHPWG_ROOT_PATH.$url.$cat['id'].'">';
|
2007-02-27 02:56:16 +01:00
|
|
|
$output.= $cat['name'].'</a>';
|
2004-10-21 23:17:46 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($replace_space)
|
|
|
|
{
|
|
|
|
return replace_space($output);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return $output;
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-11-20 18:23:42 +01:00
|
|
|
/**
|
|
|
|
* returns the list of categories as a HTML string, with cache of names
|
|
|
|
*
|
|
|
|
* categories string returned contains categories as given in the input
|
|
|
|
* array $cat_informations. $uppercats is the list of category ids to
|
|
|
|
* display in the right order. If url input parameter is empty, returns only
|
|
|
|
* the categories name without links.
|
|
|
|
*
|
|
|
|
* @param string uppercats
|
|
|
|
* @param string url
|
|
|
|
* @param boolean replace_space
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
function get_cat_display_name_cache($uppercats,
|
2006-03-22 02:01:47 +01:00
|
|
|
$url = '',
|
2004-11-20 18:23:42 +01:00
|
|
|
$replace_space = true)
|
|
|
|
{
|
2007-02-27 02:56:16 +01:00
|
|
|
global $cache, $conf;
|
2004-11-20 18:23:42 +01:00
|
|
|
|
2007-02-27 02:56:16 +01:00
|
|
|
if (!isset($cache['cat_names']))
|
2004-11-20 18:23:42 +01:00
|
|
|
{
|
|
|
|
$query = '
|
2007-02-28 04:07:12 +01:00
|
|
|
SELECT id, name, permalink
|
2004-11-20 18:23:42 +01:00
|
|
|
FROM '.CATEGORIES_TABLE.'
|
|
|
|
;';
|
2007-02-28 04:07:12 +01:00
|
|
|
$cache['cat_names'] = hash_from_query($query, 'id');
|
2004-11-20 18:23:42 +01:00
|
|
|
}
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-11-20 18:23:42 +01:00
|
|
|
$output = '';
|
|
|
|
$is_first = true;
|
|
|
|
foreach (explode(',', $uppercats) as $category_id)
|
|
|
|
{
|
2007-02-27 02:56:16 +01:00
|
|
|
$cat = $cache['cat_names'][$category_id];
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2008-07-12 16:57:24 +02:00
|
|
|
$cat['name'] = trigger_event(
|
|
|
|
'render_category_name',
|
|
|
|
$cat['name'],
|
|
|
|
'get_cat_display_name_cache'
|
|
|
|
);
|
|
|
|
|
2004-11-20 18:23:42 +01:00
|
|
|
if ($is_first)
|
|
|
|
{
|
|
|
|
$is_first = false;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2004-12-12 22:06:39 +01:00
|
|
|
$output.= $conf['level_separator'];
|
2004-11-20 18:23:42 +01:00
|
|
|
}
|
|
|
|
|
2006-03-22 02:01:47 +01:00
|
|
|
if ( !isset($url) )
|
2004-11-20 18:23:42 +01:00
|
|
|
{
|
2007-02-27 02:56:16 +01:00
|
|
|
$output.= $cat['name'];
|
2004-11-20 18:23:42 +01:00
|
|
|
}
|
2006-03-22 02:01:47 +01:00
|
|
|
elseif ($url == '')
|
|
|
|
{
|
|
|
|
$output.= '
|
2007-02-08 02:31:05 +01:00
|
|
|
<a href="'
|
2006-04-06 04:23:54 +02:00
|
|
|
.make_index_url(
|
|
|
|
array(
|
2007-02-27 02:56:16 +01:00
|
|
|
'category' => $cat,
|
2006-04-06 04:23:54 +02:00
|
|
|
)
|
|
|
|
)
|
2007-02-27 02:56:16 +01:00
|
|
|
.'">'.$cat['name'].'</a>';
|
2006-03-22 02:01:47 +01:00
|
|
|
}
|
2004-11-20 18:23:42 +01:00
|
|
|
else
|
|
|
|
{
|
|
|
|
$output.= '
|
2007-02-27 02:56:16 +01:00
|
|
|
<a href="'.PHPWG_ROOT_PATH.$url.$category_id.'">'.$cat['name'].'</a>';
|
2004-11-20 18:23:42 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($replace_space)
|
|
|
|
{
|
|
|
|
return replace_space($output);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-08-06 11:35:07 +02:00
|
|
|
/**
|
2006-03-15 23:44:35 +01:00
|
|
|
* returns the HTML code for a category item in the menu (for the main page)
|
2004-08-06 11:35:07 +02:00
|
|
|
*
|
|
|
|
* HTML code generated uses logical list tags ul and each category is an
|
|
|
|
* item li. The paramter given is the category informations as an array,
|
2006-12-08 00:21:54 +01:00
|
|
|
* used keys are : id, name, nb_images, max_date_last, date_last
|
2006-12-02 00:31:19 +01:00
|
|
|
* count_images, count_categories
|
2004-08-06 11:35:07 +02:00
|
|
|
*
|
2004-11-23 23:31:24 +01:00
|
|
|
* @param array categories
|
2004-08-06 11:35:07 +02:00
|
|
|
* @return string
|
|
|
|
*/
|
2007-02-27 02:56:16 +01:00
|
|
|
function get_html_menu_category($categories, $selected_category)
|
2004-08-06 11:35:07 +02:00
|
|
|
{
|
2004-11-23 23:31:24 +01:00
|
|
|
$ref_level = 0;
|
2005-12-09 23:54:51 +01:00
|
|
|
$level = 0;
|
2007-07-20 01:45:57 +02:00
|
|
|
|
|
|
|
$menu = trigger_event('get_html_menu_category', '',
|
|
|
|
$categories, $selected_category);
|
|
|
|
if (strlen($menu))
|
|
|
|
{
|
|
|
|
return $menu;
|
|
|
|
}
|
2006-02-12 22:52:16 +01:00
|
|
|
|
2004-11-23 23:31:24 +01:00
|
|
|
foreach ($categories as $category)
|
|
|
|
{
|
2005-09-25 20:31:55 +02:00
|
|
|
$level = substr_count($category['global_rank'], '.') + 1;
|
2004-11-23 23:31:24 +01:00
|
|
|
if ($level > $ref_level)
|
|
|
|
{
|
2005-11-18 23:45:16 +01:00
|
|
|
$menu.= "\n<ul>";
|
2005-09-25 20:31:55 +02:00
|
|
|
}
|
|
|
|
else if ($level == $ref_level)
|
|
|
|
{
|
2005-11-18 23:45:16 +01:00
|
|
|
$menu.= "\n</li>";
|
2004-11-23 23:31:24 +01:00
|
|
|
}
|
|
|
|
else if ($level < $ref_level)
|
|
|
|
{
|
2004-12-14 00:53:45 +01:00
|
|
|
// we may have to close more than one level at the same time...
|
2005-09-25 20:31:55 +02:00
|
|
|
$menu.= "\n</li>";
|
2005-11-18 23:45:16 +01:00
|
|
|
$menu.= str_repeat("\n</ul></li>",($ref_level-$level));
|
2004-11-23 23:31:24 +01:00
|
|
|
}
|
|
|
|
$ref_level = $level;
|
2004-08-06 11:35:07 +02:00
|
|
|
|
2005-11-18 23:45:16 +01:00
|
|
|
$menu.= "\n\n".'<li';
|
2007-02-27 02:56:16 +01:00
|
|
|
if ($category['id'] == @$selected_category['id'])
|
2004-11-23 23:31:24 +01:00
|
|
|
{
|
- new : HTML BODY identifier to let CSS stylesheets manage specific
behaviour.
- deletion : admin/search useless
- improvement : in admin/user_list, special behaviour for true/false fields
(expand, show_comments)
- new : gallery_title and gallery_description are displayed at the top of
each page.
- improvement : simplification in HTML for categories menu.
- improvement : standardization of presentation in all public pages
(identification, registration, search, profile, notification, comments,
etc.)
(not in ChangeLog, below this line)
- add forgotten notification.php (should have been added in a previous
commit)
- [template cclear] deletion of useless class .bouton
- [template cclear] for test purpose, new presentation of register page
(using FORM.filter)
- [template cclear] adaptation of admin/group_list from template default
- [template cclear] deletion of obsolete admin/infos_images
- [template cclear] deletion of obsolete admin/search_username
- [template cclear] new icon register.png
git-svn-id: http://piwigo.org/svn/trunk@850 68402e56-0260-453c-a942-63ccdbb3a9ee
2005-08-26 00:43:47 +02:00
|
|
|
$menu.= ' class="selected"';
|
2004-11-23 23:31:24 +01:00
|
|
|
}
|
- new : HTML BODY identifier to let CSS stylesheets manage specific
behaviour.
- deletion : admin/search useless
- improvement : in admin/user_list, special behaviour for true/false fields
(expand, show_comments)
- new : gallery_title and gallery_description are displayed at the top of
each page.
- improvement : simplification in HTML for categories menu.
- improvement : standardization of presentation in all public pages
(identification, registration, search, profile, notification, comments,
etc.)
(not in ChangeLog, below this line)
- add forgotten notification.php (should have been added in a previous
commit)
- [template cclear] deletion of useless class .bouton
- [template cclear] for test purpose, new presentation of register page
(using FORM.filter)
- [template cclear] adaptation of admin/group_list from template default
- [template cclear] deletion of obsolete admin/infos_images
- [template cclear] deletion of obsolete admin/search_username
- [template cclear] new icon register.png
git-svn-id: http://piwigo.org/svn/trunk@850 68402e56-0260-453c-a942-63ccdbb3a9ee
2005-08-26 00:43:47 +02:00
|
|
|
$menu.= '>';
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2006-04-06 04:23:54 +02:00
|
|
|
$url = make_index_url(
|
|
|
|
array(
|
2007-02-27 02:56:16 +01:00
|
|
|
'category' => $category
|
2006-04-06 04:23:54 +02:00
|
|
|
)
|
|
|
|
);
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2007-03-09 23:52:22 +01:00
|
|
|
$title = get_display_images_count
|
|
|
|
(
|
|
|
|
$category['nb_images'],
|
|
|
|
$category['count_images'],
|
|
|
|
$category['count_categories'],
|
|
|
|
false,
|
|
|
|
' / '
|
|
|
|
);
|
|
|
|
|
2007-07-20 01:45:57 +02:00
|
|
|
$menu.= '<a href="'.$url.'"';
|
2007-02-27 02:56:16 +01:00
|
|
|
if ($selected_category!=null
|
|
|
|
and $category['id'] == $selected_category['id_uppercat'])
|
2006-02-10 03:10:41 +01:00
|
|
|
{
|
|
|
|
$menu.= ' rel="up"';
|
|
|
|
}
|
2008-07-12 16:57:24 +02:00
|
|
|
$menu.= ' title="'.$title.'">';
|
|
|
|
$menu.= trigger_event(
|
|
|
|
'render_category_name',
|
|
|
|
$category['name'],
|
|
|
|
'get_html_menu_category'
|
|
|
|
);
|
|
|
|
$menu.= '</a>';
|
2004-08-06 11:35:07 +02:00
|
|
|
|
2007-02-20 02:40:40 +01:00
|
|
|
if ( $category['count_images']>0 )
|
|
|
|
{// at least one direct or indirect image
|
2006-12-02 00:31:19 +01:00
|
|
|
$menu.= "\n".'<span class="';
|
2007-02-20 02:40:40 +01:00
|
|
|
// at least one image in this category -> class menuInfoCat
|
2007-10-02 07:38:54 +02:00
|
|
|
$menu.= ($category['nb_images'] > 0 ? "menuInfoCat"
|
2006-12-02 00:31:19 +01:00
|
|
|
: "menuInfoCatByChild").'"';
|
2007-03-09 23:52:22 +01:00
|
|
|
$menu.= ' title=" '.$title.'">';
|
2007-02-20 02:40:40 +01:00
|
|
|
// show total number of images
|
|
|
|
$menu.= '['.$category['count_images'].']';
|
2005-08-18 23:31:21 +02:00
|
|
|
$menu.= '</span>';
|
2004-11-23 23:31:24 +01:00
|
|
|
}
|
2006-12-08 01:12:44 +01:00
|
|
|
$child_date_last = @$category['max_date_last']> @$category['date_last'];
|
2006-12-08 00:21:54 +01:00
|
|
|
$menu.= get_icon($category['max_date_last'], $child_date_last);
|
2004-08-06 11:35:07 +02:00
|
|
|
}
|
2005-11-18 23:45:16 +01:00
|
|
|
|
|
|
|
$menu.= str_repeat("\n</li></ul>",($level));
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-08-06 11:35:07 +02:00
|
|
|
return $menu;
|
|
|
|
}
|
2004-10-23 19:56:46 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* returns HTMLized comment contents retrieved from database
|
|
|
|
*
|
|
|
|
* newlines becomes br tags, _word_ becomes underline, /word/ becomes
|
|
|
|
* italic, *word* becomes bolded
|
|
|
|
*
|
|
|
|
* @param string content
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
function parse_comment_content($content)
|
|
|
|
{
|
2006-02-10 03:10:41 +01:00
|
|
|
$pattern = '/(https?:\/\/\S*)/';
|
|
|
|
$replacement = '<a href="$1" rel="nofollow">$1</a>';
|
2006-02-09 21:38:07 +01:00
|
|
|
$content = preg_replace($pattern, $replacement, $content);
|
2006-02-10 03:10:41 +01:00
|
|
|
|
|
|
|
$content = nl2br($content);
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-10-23 19:56:46 +02:00
|
|
|
// replace _word_ by an underlined word
|
2006-02-09 21:38:07 +01:00
|
|
|
$pattern = '/\b_(\S*)_\b/';
|
|
|
|
$replacement = '<span style="text-decoration:underline;">$1</span>';
|
2004-10-23 19:56:46 +02:00
|
|
|
$content = preg_replace($pattern, $replacement, $content);
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-10-23 19:56:46 +02:00
|
|
|
// replace *word* by a bolded word
|
2006-02-09 21:38:07 +01:00
|
|
|
$pattern = '/\b\*(\S*)\*\b/';
|
|
|
|
$replacement = '<span style="font-weight:bold;">$1</span>';
|
2004-10-23 19:56:46 +02:00
|
|
|
$content = preg_replace($pattern, $replacement, $content);
|
2006-03-21 02:27:21 +01:00
|
|
|
|
2004-10-23 19:56:46 +02:00
|
|
|
// replace /word/ by an italic word
|
2006-02-10 03:10:41 +01:00
|
|
|
$pattern = "/\/(\S*)\/(\s)/";
|
|
|
|
$replacement = '<span style="font-style:italic;">$1$2</span>';
|
|
|
|
$content = preg_replace($pattern, $replacement, $content);
|
2004-10-23 19:56:46 +02:00
|
|
|
|
2006-04-25 22:38:11 +02:00
|
|
|
$content = '<div>'.$content.'</div>';
|
2004-10-23 19:56:46 +02:00
|
|
|
return $content;
|
|
|
|
}
|
2005-08-17 16:25:38 +02:00
|
|
|
|
|
|
|
function get_cat_display_name_from_id($cat_id,
|
2006-03-22 02:01:47 +01:00
|
|
|
$url = '',
|
2005-08-17 16:25:38 +02:00
|
|
|
$replace_space = true)
|
|
|
|
{
|
|
|
|
$cat_info = get_cat_info($cat_id);
|
2007-02-27 02:56:16 +01:00
|
|
|
return get_cat_display_name($cat_info['upper_names'], $url, $replace_space);
|
2005-08-17 16:25:38 +02:00
|
|
|
}
|
2006-03-30 02:37:07 +02:00
|
|
|
|
2006-04-03 00:26:19 +02:00
|
|
|
/**
|
|
|
|
* Returns an HTML list of tags. It can be a multi select field or a list of
|
|
|
|
* checkboxes.
|
|
|
|
*
|
|
|
|
* @param string HTML field name
|
|
|
|
* @param array selected tag ids
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function get_html_tag_selection(
|
|
|
|
$tags,
|
|
|
|
$fieldname,
|
|
|
|
$selecteds = array(),
|
|
|
|
$forbidden_categories = null
|
|
|
|
)
|
|
|
|
{
|
|
|
|
global $conf;
|
2006-04-06 04:23:54 +02:00
|
|
|
|
2006-04-19 00:57:05 +02:00
|
|
|
if (count ($tags) == 0 )
|
|
|
|
{
|
|
|
|
return '';
|
|
|
|
}
|
2006-04-03 00:26:19 +02:00
|
|
|
$output = '<ul class="tagSelection">';
|
|
|
|
foreach ($tags as $tag)
|
|
|
|
{
|
|
|
|
$output.=
|
|
|
|
'<li>'
|
|
|
|
.'<label>'
|
|
|
|
.'<input type="checkbox" name="'.$fieldname.'[]"'
|
2007-02-14 02:37:38 +01:00
|
|
|
.' value="'.$tag['id'].'"'
|
2006-04-03 00:26:19 +02:00
|
|
|
;
|
|
|
|
|
2007-02-14 02:37:38 +01:00
|
|
|
if (in_array($tag['id'], $selecteds))
|
2006-04-03 00:26:19 +02:00
|
|
|
{
|
|
|
|
$output.= ' checked="checked"';
|
|
|
|
}
|
2006-04-06 04:23:54 +02:00
|
|
|
|
2006-04-03 00:26:19 +02:00
|
|
|
$output.=
|
|
|
|
' />'
|
2006-04-29 12:29:32 +02:00
|
|
|
.' '. $tag['name']
|
2006-04-03 00:26:19 +02:00
|
|
|
.'</label>'
|
|
|
|
.'</li>'
|
|
|
|
."\n"
|
|
|
|
;
|
|
|
|
}
|
|
|
|
$output.= '</ul>';
|
|
|
|
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
function name_compare($a, $b)
|
|
|
|
{
|
2006-05-15 23:22:43 +02:00
|
|
|
return strcmp(strtolower($a['name']), strtolower($b['name']));
|
2006-04-03 00:26:19 +02:00
|
|
|
}
|
|
|
|
|
2008-07-01 04:09:21 +02:00
|
|
|
function tag_alpha_compare($a, $b)
|
|
|
|
{
|
|
|
|
return strcmp(strtolower($a['url_name']), strtolower($b['url_name']));
|
|
|
|
}
|
|
|
|
|
2006-03-30 02:37:07 +02:00
|
|
|
/**
|
|
|
|
* exits the current script (either exit or redirect)
|
|
|
|
*/
|
|
|
|
function access_denied()
|
|
|
|
{
|
2008-03-08 02:38:37 +01:00
|
|
|
global $user;
|
2006-03-30 02:37:07 +02:00
|
|
|
|
|
|
|
$login_url =
|
|
|
|
get_root_url().'identification.php?redirect='
|
|
|
|
.urlencode(urlencode($_SERVER['REQUEST_URI']));
|
|
|
|
|
2008-09-17 03:48:31 +02:00
|
|
|
set_status_header(401);
|
2007-06-06 00:01:15 +02:00
|
|
|
if ( isset($user) and !is_a_guest() )
|
2006-03-30 02:37:07 +02:00
|
|
|
{
|
2008-11-19 16:46:49 +01:00
|
|
|
echo '<meta http-equiv="Content-Type" content="text/html; charset=utf-8">';
|
2008-01-30 23:07:07 +01:00
|
|
|
echo '<div style="text-align:center;">'.l10n('access_forbiden').'<br />';
|
|
|
|
echo '<a href="'.get_root_url().'identification.php">'.l10n('identification').'</a> ';
|
|
|
|
echo '<a href="'.make_index_url().'">'.l10n('home').'</a></div>';
|
2008-09-17 03:48:31 +02:00
|
|
|
echo str_repeat( ' ', 512); //IE6 doesn't error output if below a size
|
2006-03-30 02:37:07 +02:00
|
|
|
exit();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2006-12-11 07:04:53 +01:00
|
|
|
redirect_html($login_url);
|
2006-03-30 02:37:07 +02:00
|
|
|
}
|
|
|
|
}
|
2006-04-28 07:12:25 +02:00
|
|
|
|
2006-12-13 02:05:38 +01:00
|
|
|
/**
|
|
|
|
* exits the current script with 403 code
|
|
|
|
* @param string msg a message to display
|
|
|
|
* @param string alternate_url redirect to this url
|
|
|
|
*/
|
|
|
|
function page_forbidden($msg, $alternate_url=null)
|
|
|
|
{
|
|
|
|
set_status_header(403);
|
|
|
|
if ($alternate_url==null)
|
|
|
|
$alternate_url = make_index_url();
|
|
|
|
redirect_html( $alternate_url,
|
|
|
|
'<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
|
|
|
|
<h1 style="text-align:left; font-size:36px;">Forbidden</h1><br/>'
|
|
|
|
.$msg.'</div>',
|
|
|
|
5 );
|
|
|
|
}
|
|
|
|
|
2007-02-23 14:18:34 +01:00
|
|
|
/**
|
|
|
|
* exits the current script with 400 code
|
|
|
|
* @param string msg a message to display
|
|
|
|
* @param string alternate_url redirect to this url
|
|
|
|
*/
|
|
|
|
function bad_request($msg, $alternate_url=null)
|
|
|
|
{
|
|
|
|
set_status_header(400);
|
|
|
|
if ($alternate_url==null)
|
|
|
|
$alternate_url = make_index_url();
|
|
|
|
redirect_html( $alternate_url,
|
|
|
|
'<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
|
|
|
|
<h1 style="text-align:left; font-size:36px;">Bad request</h1><br/>'
|
|
|
|
.$msg.'</div>',
|
|
|
|
5 );
|
|
|
|
}
|
|
|
|
|
2006-04-28 07:12:25 +02:00
|
|
|
/**
|
|
|
|
* exits the current script with 404 code when a page cannot be found
|
|
|
|
* @param string msg a message to display
|
|
|
|
* @param string alternate_url redirect to this url
|
|
|
|
*/
|
|
|
|
function page_not_found($msg, $alternate_url=null)
|
|
|
|
{
|
2006-12-08 01:12:44 +01:00
|
|
|
set_status_header(404);
|
2006-04-28 07:12:25 +02:00
|
|
|
if ($alternate_url==null)
|
|
|
|
$alternate_url = make_index_url();
|
2006-12-11 07:04:53 +01:00
|
|
|
redirect_html( $alternate_url,
|
2006-04-28 07:12:25 +02:00
|
|
|
'<div style="text-align:left; margin-left:5em;margin-bottom:5em;">
|
|
|
|
<h1 style="text-align:left; font-size:36px;">Page not found</h1><br/>'
|
|
|
|
.$msg.'</div>',
|
|
|
|
5 );
|
|
|
|
}
|
2006-11-14 03:53:24 +01:00
|
|
|
|
2008-09-05 03:24:01 +02:00
|
|
|
/**
|
|
|
|
* exits the current script with 500 http code
|
|
|
|
* this method can be called at any time (does not use template/language/user etc...)
|
|
|
|
* @param string msg a message to display
|
|
|
|
*/
|
|
|
|
function fatal_error($msg)
|
|
|
|
{
|
|
|
|
$btrace_msg = '';
|
|
|
|
if (function_exists('debug_backtrace'))
|
|
|
|
{
|
|
|
|
$bt = debug_backtrace();
|
|
|
|
for ($i=1; $i<count($bt); $i++)
|
|
|
|
{
|
|
|
|
$class = isset($bt[$i]['class']) ? (@$bt[$i]['class'].'::') : '';
|
|
|
|
$btrace_msg .= "#$i\t".$class.@$bt[$i]['function'].' '.@$bt[$i]['file']."(".@$bt[$i]['line'].")\n";
|
|
|
|
}
|
|
|
|
$btrace_msg = trim($btrace_msg);
|
|
|
|
$msg .= "\n";
|
|
|
|
}
|
|
|
|
|
2008-10-15 19:55:18 +02:00
|
|
|
$display = "<meta http-equiv='Content-Type' content='text/html; charset=utf-8'>
|
|
|
|
<h1>Piwigo encountered a non recoverable error</h1>
|
2008-09-05 03:24:01 +02:00
|
|
|
<pre style='font-size:larger;background:white;color:red;padding:1em;margin:0;clear:both;display:block;width:auto;height:auto;overflow:auto'>
|
|
|
|
<b>$msg</b>
|
|
|
|
$btrace_msg
|
|
|
|
</pre>\n";
|
|
|
|
|
|
|
|
@set_status_header(500);
|
2008-09-17 03:48:31 +02:00
|
|
|
echo $display.str_repeat( ' ', 300); //IE6 doesn't error output if below a size
|
2008-09-05 03:24:01 +02:00
|
|
|
|
|
|
|
if ( function_exists('ini_set') )
|
|
|
|
{// if possible turn off error display (we display it)
|
|
|
|
ini_set('display_errors', false);
|
|
|
|
}
|
|
|
|
error_reporting( E_ALL );
|
|
|
|
trigger_error( strip_tags($msg).$btrace_msg, E_USER_ERROR );
|
|
|
|
die(0); // just in case
|
|
|
|
}
|
|
|
|
|
2006-11-14 03:53:24 +01:00
|
|
|
/* returns the title to be displayed above thumbnails on tag page
|
|
|
|
*/
|
|
|
|
function get_tags_content_title()
|
|
|
|
{
|
|
|
|
global $page;
|
|
|
|
$title = count($page['tags']) > 1 ? l10n('Tags') : l10n('Tag');
|
|
|
|
$title.= ' ';
|
|
|
|
|
|
|
|
for ($i=0; $i<count($page['tags']); $i++)
|
|
|
|
{
|
|
|
|
$title.= $i>0 ? ' + ' : '';
|
|
|
|
|
|
|
|
$title.=
|
|
|
|
'<a href="'
|
|
|
|
.make_index_url(
|
|
|
|
array(
|
|
|
|
'tags' => array( $page['tags'][$i] )
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.'" title="'
|
2008-03-08 02:38:37 +01:00
|
|
|
.l10n('See elements linked to this tag only')
|
2006-11-14 03:53:24 +01:00
|
|
|
.'">'
|
|
|
|
.$page['tags'][$i]['name']
|
|
|
|
.'</a>';
|
|
|
|
|
|
|
|
if ( count($page['tags'])>2 )
|
|
|
|
{
|
|
|
|
$other_tags = $page['tags'];
|
|
|
|
unset ( $other_tags[$i] );
|
|
|
|
$title.=
|
|
|
|
'<a href="'
|
|
|
|
.make_index_url(
|
|
|
|
array(
|
|
|
|
'tags' => $other_tags
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.'" style="border:none;" title="'
|
|
|
|
.l10n('remove this tag')
|
|
|
|
.'"><img src="'
|
|
|
|
.get_root_url().get_themeconf('icon_dir').'/remove_s.png'
|
|
|
|
.'" alt="x" style="vertical-align:bottom;" class="button"/>'
|
|
|
|
.'</a>';
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
return $title;
|
|
|
|
}
|
2006-12-08 01:12:44 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the http status header (200,401,...)
|
|
|
|
*/
|
|
|
|
function set_status_header($code, $text='')
|
|
|
|
{
|
|
|
|
if (empty($text))
|
|
|
|
{
|
|
|
|
switch ($code)
|
|
|
|
{
|
|
|
|
case 200: $text='OK';break;
|
|
|
|
case 301: $text='Moved permanently';break;
|
|
|
|
case 302: $text='Moved temporarily';break;
|
|
|
|
case 304: $text='Not modified';break;
|
|
|
|
case 400: $text='Bad request';break;
|
|
|
|
case 401: $text='Authorization required';break;
|
|
|
|
case 403: $text='Forbidden';break;
|
|
|
|
case 404: $text='Not found';break;
|
2007-07-07 04:10:11 +02:00
|
|
|
case 500: $text='Server error';break;
|
2008-09-17 03:48:31 +02:00
|
|
|
case 501: $text='Not implemented';break;
|
2007-07-07 04:10:11 +02:00
|
|
|
case 503: $text='Service unavailable';break;
|
2006-12-08 01:12:44 +01:00
|
|
|
}
|
|
|
|
}
|
2007-07-07 04:10:11 +02:00
|
|
|
$protocol = $_SERVER["SERVER_PROTOCOL"];
|
|
|
|
if ( ('HTTP/1.1' != $protocol) && ('HTTP/1.0' != $protocol) )
|
|
|
|
$protocol = 'HTTP/1.0';
|
|
|
|
|
|
|
|
if ( version_compare( phpversion(), '4.3.0', '>=' ) )
|
|
|
|
{
|
|
|
|
header( "$protocol $code $text", true, $code );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
header( "$protocol $code $text" );
|
|
|
|
}
|
2007-01-23 02:22:52 +01:00
|
|
|
trigger_action('set_status_header', $code, $text);
|
2006-12-08 01:12:44 +01:00
|
|
|
}
|
2007-01-30 08:00:17 +01:00
|
|
|
|
2007-10-02 07:38:54 +02:00
|
|
|
/** returns the category comment for rendering in html textual mode (subcatify)
|
|
|
|
* this is an event handler. don't call directly
|
|
|
|
*/
|
|
|
|
function render_category_literal_description($desc)
|
|
|
|
{
|
|
|
|
return strip_tags($desc, '<span><p><a><br><b><i><small><big><strong><em>');
|
2007-01-30 08:00:17 +01:00
|
|
|
}
|
2008-05-17 22:40:27 +02:00
|
|
|
|
2008-07-01 04:09:21 +02:00
|
|
|
/** returns the argument_ids array with new sequenced keys based on related
|
2008-05-17 22:40:27 +02:00
|
|
|
* names. Sequence is not case sensitive.
|
|
|
|
* Warning: By definition, this function breaks original keys
|
|
|
|
*/
|
|
|
|
function order_by_name($element_ids,$name)
|
|
|
|
{
|
|
|
|
$ordered_element_ids = array();
|
|
|
|
foreach ($element_ids as $k_id => $element_id)
|
|
|
|
{
|
|
|
|
$key = strtolower($name[$element_id]) .'-'. $name[$element_id] .'-'. $k_id;
|
|
|
|
$ordered_element_ids[$key] = $element_id;
|
|
|
|
}
|
|
|
|
ksort($ordered_element_ids);
|
|
|
|
return $ordered_element_ids;
|
|
|
|
}
|
|
|
|
|
2008-08-28 02:32:39 +02:00
|
|
|
/*event handler for menu*/
|
|
|
|
function register_default_menubar_blocks( $menu_ref_arr )
|
|
|
|
{
|
|
|
|
$menu = & $menu_ref_arr[0];
|
|
|
|
if ($menu->get_id() != 'menubar')
|
|
|
|
return;
|
|
|
|
$menu->register_block( new RegisteredBlock( 'mbLinks', 'Links', 'piwigo'));
|
|
|
|
$menu->register_block( new RegisteredBlock( 'mbCategories', 'Categories', 'piwigo'));
|
|
|
|
$menu->register_block( new RegisteredBlock( 'mbTags', 'Related tags', 'piwigo'));
|
|
|
|
$menu->register_block( new RegisteredBlock( 'mbSpecials', 'special_categories', 'piwigo'));
|
|
|
|
$menu->register_block( new RegisteredBlock( 'mbMenu', 'title_menu', 'piwigo'));
|
|
|
|
$menu->register_block( new RegisteredBlock( 'mbIdentification', 'identification', 'piwigo') );
|
|
|
|
}
|
|
|
|
|
2008-10-18 03:07:13 +02:00
|
|
|
?>
|