assign(
array(
'ID' => $category['id'],
'TN_SRC' => DerivativeImage::thumb_url(array(
'id' => $category['representative_picture_id'],
'path' => $category['path'],
)),
'TN_ALT' => strip_tags($category['name']),
'URL' => make_index_url(array('category' => $category)),
'CAPTION_NB_IMAGES' => get_display_images_count
(
$category['nb_images'],
$category['count_images'],
$category['count_categories'],
true,
'
'
),
'DESCRIPTION' =>
trigger_change('render_category_literal_description',
trigger_change('render_category_description',
@$category['comment'],
'subcatify_category_description')),
'NAME' => trigger_change(
'render_category_name',
$category['name'],
'subcatify_category_name'
),
)
);
$template->set_filename('extended_description_content', realpath(EXTENDED_DESC_PATH . 'template/cat.tpl'));
return $template->parse('extended_description_content', true);
}
return '';
}
/**
* Return html code for a photo
*
* @int id: picture id
* @int album: album to display picture in (default: null)
* @string size: picture size (default: M)
* @bool html: return complete html structure (default: true)
* @bool link: add a link to the picture (default: true)
*/
function extdesc_get_photo_sized($param)
{
global $template;
$default_params = array(
'id' => array('\d+', null),
'album' => array('\d+', null),
'size' => array('SQ|TH|XXS|XS|S|M|L|XL|XXL', 'M'),
'html' => array('boolean', true),
'link' => array('boolean', true),
);
$params = extdesc_parse_parameters($param, $default_params);
// check picture id
if (empty($params['id'])) return 'missing picture id';
// parameters
$deriv_type = extdesc_get_deriv_type($params['size']);
// get picture
$query = 'SELECT * FROM ' . IMAGES_TABLE . ' WHERE id = '.$params['id'].';';
$result = pwg_query($query);
if (pwg_db_num_rows($result))
{
$picture = pwg_db_fetch_assoc($result);
// url
if ($params['link'])
{
if (!empty($params['album']))
{
$query = '
SELECT id, name, permalink
FROM '.CATEGORIES_TABLE.'
WHERE id = '.$params['album'].'
;';
$category = pwg_db_fetch_assoc(pwg_query($query));
$url = make_picture_url(array(
'image_id' => $picture['id'],
'category' => array(
'id' => $category['id'],
'name' => $category['name'],
'permalink' => $category['permalink'],
)));
}
else
{
$url = make_picture_url(array('image_id' => $picture['id']));
}
}
// image
$src_image = new SrcImage($picture);
$derivatives = DerivativeImage::get_all($src_image);
$selected_derivative = $derivatives[$deriv_type];
$template->assign(array(
'ed_image' => array(
'selected_derivative' => $selected_derivative,
'ALT_IMG' => $picture['file'],
)));
// output
if ($params['html'])
{
$template->set_filename('extended_description_content', realpath(EXTENDED_DESC_PATH . 'template/picture_content.tpl'));
$content = $template->parse('extended_description_content', true);
if ($params['link']) return ''.$content.'';
else return $content;
}
else
{
return $selected_derivative->get_url();
}
}
return 'invalid picture id';
}
/**
* Return html code for a random photo
*
* @int album: select picture from this album (default: all)
* @string size: picture size (default: M)
* @bool html: return complete html structure (default: true)
* @bool link: add a link to the picture (default: false)
*/
function extdesc_get_random_photo($param)
{
$default_params = array(
'album' => array('\d+', null),
'cat' => array('\d+', null), // historical
'size' => array('SQ|TH|XXS|XS|S|M|L|XL|XXL', 'M'),
'html' => array('boolean', true),
'link' => array('boolean', false),
);
$params = extdesc_parse_parameters($param, $default_params);
// check album id
if ( empty($params['album']) and !empty($params['cat']) )
{
$params['album'] = $params['cat'];
}
// get picture id
$query = '
SELECT id, category_id
FROM '.IMAGES_TABLE.'
JOIN '.IMAGE_CATEGORY_TABLE.' ON image_id = id';
if (empty($params['album']))
{
$query.= '
WHERE 1=1 '
.get_sql_condition_FandF(array(
'forbidden_categories' => 'category_id',
'visible_categories' => 'category_id',
'visible_images' => 'id'
),
'AND'
);
}
else
{
$query.= '
WHERE category_id = '.$params['album'];
}
$query.= '
ORDER BY '.DB_RANDOM_FUNCTION.'()
LIMIT 1
;';
$result = pwg_query($query);
if (pwg_db_num_rows($result))
{
list($params['id'], $params['album']) = pwg_db_fetch_row($result);
return extdesc_get_photo_sized($params);
}
return '';
}
/**
* Return html code for a nivo slider (album or list is mandatory)
*
* @int album: select pictures from this album
* @int nb_images: display only x pictures (default: 10)
* @string random: random sort order (default: no)
*
* @string list: pictures id separated by a comma
*
* @string size: picture size (default: M)
* @int speed: slideshow duration (default: 3)
* @bool title: display picture name (default: false)
* @string effect: transition effect (default: fade)
* @bool arrows: display navigation arrows (default: true)
* @string control: display navigation bar (default: true)
* @bool elastic: adapt slider size to each picture (default: true)
* @int thumbs_size: size of thumbnails if control=thumb (default: 80)
*/
function extdesc_get_slider($param)
{
global $template, $conf;
$default_params = array(
'album' => array('\d+', null),
'nb_images' => array('\d+', 10),
'random' => array('boolean', false),
'list' => array('[\d,]+', null),
'size' => array('SQ|TH|XXS|XS|S|M|L|XL|XXL', 'M'),
'speed' => array('\d+', 5),
'title' => array('boolean', false),
'effect' => array('[a-zA-Z]+', 'fade'),
'arrows' => array('boolean', true),
'control' => array('yes|no|true|false|thumb', true),
'elastic' => array('boolean', true),
'thumbs_size' => array('\d+', 80),
);
$params = extdesc_parse_parameters($param, $default_params);
// check size
$deriv_type = extdesc_get_deriv_type($params['size']);
$enabled = ImageStdParams::get_defined_type_map();
if (empty($enabled[ $deriv_type ]))
{
return '(nivoSlider) size disabled';
}
// parameters
if ($params['control'] === 'thumb')
{
$params['control'] = true;
$params['control_thumbs'] = true;
}
else
{
$params['control'] = filter_var($params['control'], FILTER_VALIDATE_BOOLEAN);
$params['control_thumbs'] = false;
}
$tpl_vars = $params;
// pictures from album...
if (!empty($params['album']))
{
// get image order inside category
if ($params['random'])
{
$order_by = DB_RANDOM_FUNCTION.'()';
}
else
{
$query = '
SELECT image_order
FROM '.CATEGORIES_TABLE.'
WHERE id = '.$params['album'].'
;';
list($order_by) = pwg_db_fetch_row(pwg_query($query));
if (empty($order_by))
{
$order_by = str_replace('ORDER BY ', null, $conf['order_by_inside_category']);
}
}
// get pictures ids
$query = '
SELECT image_id
FROM '.IMAGE_CATEGORY_TABLE.' as ic
INNER JOIN '.IMAGES_TABLE.' as i
ON i.id = ic.image_id
WHERE category_id = '.$params['album'].'
ORDER BY '.$order_by.'
LIMIT '.$params['nb_images'].'
;';
$ids = array_from_query($query, 'image_id');
if (empty($ids))
{
return '(nivoSlider) no photos in album #'.$params['album'];
}
$ids = implode(',', $ids);
}
// ...or pictures list
else if (empty($params['list']))
{
return '(nivoSlider) missing album id or photos list';
}
else
{
$ids = $params['list'];
}
// get pictures
$query = '
SELECT *
FROM '.IMAGES_TABLE.'
WHERE id IN ('.$ids.')
ORDER BY FIND_IN_SET(id, "'.$ids.'")
;';
$pictures = hash_from_query($query, 'id');
foreach ($pictures as $row)
{
// url
if (!empty($params['album']))
{
$url = make_picture_url(array(
'image_id' => $row['id'],
'category' => array(
'id' => $params['album'],
'name' => '',
'permalink' => '',
)));
}
else
{
$url = make_picture_url(array('image_id' => $row['id']));
}
$name = render_element_name($row);
$tpl_vars['elements'][] = array(
'ID' => $row['id'],
'TN_ALT' => htmlspecialchars(strip_tags($name)),
'NAME' => $name,
'URL' => $url,
'src_image' => new SrcImage($row),
);
}
list($tpl_vars['img_size']['w'], $tpl_vars['img_size']['h']) =
$enabled[ $deriv_type ]->sizing->ideal_size;
$tpl_vars['id'] = crc32(uniqid($ids)); // need a unique id if we have multiple sliders
$tpl_vars['derivative_params'] = ImageStdParams::get_by_type($deriv_type);
if ($params['control_thumbs'])
{
$tpl_vars['derivative_params_thumb'] = ImageStdParams::get_custom(
$params['thumbs_size'], $params['thumbs_size'], 1,
$params['thumbs_size'], $params['thumbs_size']
);
}
$template->assign(array(
'EXTENDED_DESC_PATH' => EXTENDED_DESC_PATH,
'SLIDER'=> $tpl_vars,
));
$template->set_filename('extended_description_content', realpath(EXTENDED_DESC_PATH . 'template/slider.tpl'));
return $template->parse('extended_description_content', true);
}
/**
* Return html code for login link
*
* @bool html: return complete html structure (default: true)
* @string text: link text, translatable (default: Login)
*/
function extdesc_get_login_link($param)
{
$default_params = array(
'html' => array('boolean', true),
'text' => array('".*"', ''),
);
$params = extdesc_parse_parameters($param, $default_params);
$url =
get_root_url().'identification.php?redirect='
.urlencode(urlencode($_SERVER['REQUEST_URI']));
if ($params['html'])
{
if (empty($params['text']))
{
$params['text'] = l10n('Login');
}
else
{
$params['text'] = get_user_language_desc(mb_substr($params['text'], 1, -1));
}
return '' . $params['text'] . '';
}
else
{
return $url;
}
}
/**
* Parse tags parameters
*/
function extdesc_parse_parameters($param, $default_params)
{
if (is_array($param))
{
return $param;
}
$params = array();
foreach ($default_params as $name => $value)
{
$is_bool = false;
if ($value[0] == 'boolean')
{
$is_bool = true;
$value[0] = 'yes|no|true|false';
}
if (preg_match('#'.$name.'=('.$value[0].')#', $param, $matches))
{
$params[$name] = $matches[1];
if ($is_bool)
{
$params[$name] = filter_var($params[$name], FILTER_VALIDATE_BOOLEAN);
}
}
else
{
$params[$name] = $value[1];
}
}
return $params;
}
/**
* Translates shorthand sizes to internal names
*/
function extdesc_get_deriv_type($size)
{
$size = strtoupper($size);
$size_map = array(
'SQ' => IMG_SQUARE,
'TH' => IMG_THUMB,
'XXS' => IMG_XXSMALL,
'XS' => IMG_XSMALL,
'S' => IMG_SMALL,
'M' => IMG_MEDIUM,
'L' => IMG_LARGE,
'XL' => IMG_XLARGE,
'XXL' => IMG_XXLARGE,
);
if (!array_key_exists($size, $size_map))
{
$size = 'M';
}
return $size_map[$size];
}