category random replaced by a more generic category : list. You give a list

of element identifiers and it creates a page virtual temporary
category. random.php generates a randomized list of element id visible to
the user (according to permissions) and redirects to category.php.

Major problem : elements order is in id ascending order, I don't know how to
change order when having id1,id2,id3 and id2,id3,id1 (the display order is
the same)


git-svn-id: http://piwigo.org/svn/trunk@605 68402e56-0260-453c-a942-63ccdbb3a9ee
This commit is contained in:
plegall 2004-11-15 23:13:24 +00:00
commit 973e0f8806
5 changed files with 94 additions and 23 deletions

View file

@ -105,6 +105,10 @@ while ($row = mysql_fetch_array($result))
{
$url_link.= '&search='.$_GET['search'];
}
else if ($page['cat'] == 'list')
{
$url_link.= '&list='.$_GET['list'];
}
$template->assign_block_vars(
'thumbnails.line.thumbnail',

View file

@ -66,7 +66,7 @@ function check_restrictions( $category_id )
* - equals 'recent_pics'
* - equals 'recent_cats'
* - equals 'calendar'
* - equals 'random'
* - equals 'list'
*
* The function fills the global var $page['cat'] and returns nothing
*
@ -99,8 +99,7 @@ function check_cat_id( $cat )
or $cat == 'best_rated'
or $cat == 'recent_pics'
or $cat == 'recent_cats'
or $cat == 'calendar'
or $cat == 'random' )
or $cat == 'calendar' )
{
$page['cat'] = $cat;
}
@ -108,6 +107,12 @@ function check_cat_id( $cat )
{
$page['cat'] = $cat;
}
if ($cat == 'list'
and isset($_GET['list'])
and preg_match('/^\d+(,\d+)*$/', $_GET['list']))
{
$page['cat'] = 'list';
}
}
}
@ -434,7 +439,7 @@ SELECT galleries_url
// - most visited pictures
// - best rated pictures
// - recent pictures
// - random pictures
// - defined list (used for random)
// 3. determination of the title of the page
// 4. creation of the navigation bar
function initialize_category( $calling_page = 'category' )
@ -467,12 +472,13 @@ function initialize_category( $calling_page = 'category' )
}
else
{
if ( $page['cat'] == 'search'
or $page['cat'] == 'most_visited'
or $page['cat'] == 'recent_pics'
or $page['cat'] == 'recent_cats'
or $page['cat'] == 'best_rated'
or $page['cat'] == 'calendar' )
if ($page['cat'] == 'search'
or $page['cat'] == 'most_visited'
or $page['cat'] == 'recent_pics'
or $page['cat'] == 'recent_cats'
or $page['cat'] == 'best_rated'
or $page['cat'] == 'calendar'
or $page['cat'] == 'list')
{
// we must not show pictures of a forbidden category
if ( $user['forbidden_categories'] != '' )
@ -788,23 +794,17 @@ SELECT COUNT(1) AS count
$page['nb_image_page'] = $conf['top_number'] - $page['start'];
}
}
else if ($page['cat'] == 'random')
else if ($page['cat'] == 'list')
{
$page['title'] = $lang['random_cat'];
$page['where'] = 'WHERE 1=1';
if (isset($forbidden))
{
$page['where'] = 'WHERE '.$forbidden;
$page['where'].= ' AND '.$forbidden;
}
else
{
$page['where'] = 'WHERE 1=1';
}
$conf['order_by'] = ' ORDER BY RAND()';
$page['cat_nb_images'] = $conf['top_number'];
$page['nb_image_page'] = $page['cat_nb_images'];
$page['where'].= ' AND image_id IN ('.$_GET['list'].')';
$page['cat_nb_images'] = count(explode(',', $_GET['list']));
}
if (isset($query))