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]; }