function theme_slick_image in Slick Carousel 7.2
Returns HTML for a slick_image.
Parameters
array $variables: An associative array containing:
- item: Associative array of image data, which may include "uri", "alt", "width", "height", "title" and "attributes".
- image_style: The name of the style to alter the original image.
- url: A string containing the link 'url'.
- item_attributes: Associative array of attributes to be placed in the img.
- settings: An array of options.
2 theme calls to theme_slick_image()
- slick_get_image in includes/
slick.global.inc - Returns the image/video/audio either using Picture mapping, or lazyload.
- slick_get_media_overlay in includes/
slick.extras.inc - Builds Youtube/ Vimeo overlay as file entity don't support nested file.
File
- templates/
slick.theme.inc, line 358 - Hooks and preprocess functions for the Slick module.
Code
function theme_slick_image(array $variables) {
$element = $variables['element'];
$elements = array(
'captions',
'item',
'item_attributes',
'image_style',
'settings',
'url',
'url_attributes',
);
// Faking variables as we don't do preprocess.
foreach ($elements as $key) {
$variables[$key] = isset($element["#{$key}"]) ? $element["#{$key}"] : array();
}
// Load the supported formatter variables for the possesive blazy wrapper.
$settings =& $variables['settings'];
$item = $variables['item'];
$image_attributes =& $variables['item_attributes'];
$url_attributes =& $variables['url_attributes'];
$iframe_attributes = array();
if (isset($settings['content_attributes'])) {
$iframe_attributes =& $settings['content_attributes'];
}
// Modifies variables.
foreach (array(
'icon',
'lightbox',
'media_switch',
) as $key) {
$settings[$key] = isset($settings[$key]) ? $settings[$key] : '';
}
$build = '';
$type = empty($item['type']) ? 'image' : $item['type'];
$media = !empty($item['embed_url']) && $type != 'image';
$switch = $settings['media_switch'];
$uri = $item['uri'];
$settings['image_url'] = empty($variables['image_style']) ? file_create_url($uri) : image_style_url($variables['image_style'], $uri);
$settings['ratio'] = empty($settings['ratio']) ? '' : str_replace(':', '', $settings['ratio']);
// Build attributes.
$attributes = array(
'class' => array(
'media',
'media--' . $type,
),
);
if ($switch) {
$attributes['class'][] = 'media--switch';
}
foreach (array(
'width',
'height',
'alt',
'title',
) as $key) {
if (isset($item[$key])) {
if (array_key_exists($key, $image_attributes)) {
continue;
}
$image_attributes[$key] = $item[$key];
}
}
// Picture integration, else Slick lazyload, or regular image.
$params = $image_attributes;
if (empty($params['breakpoints'])) {
$image_attributes['class'][] = 'media__image media__element';
// Aspect ratio to fix layout reflow with lazyloaded images responsively.
if (!empty($settings['ratio'])) {
$attributes['class'][] = 'media--ratio media--ratio--' . $settings['ratio'];
if (!empty($image_attributes['height']) && in_array($settings['ratio'], array(
'enforced',
'fluid',
))) {
$attributes['style'] = 'padding-bottom: ' . round($image_attributes['height'] / $image_attributes['width'] * 100, 2) . '%';
}
}
if (!empty($settings['background'])) {
// @todo Blazy integration with multi-serving bakground images.
// slick_build_breakpoint_attributes($attributes, $settings);
$attributes['class'][] = 'b-bg media--background';
}
if (!empty($settings['lazy'])) {
$attributes['class'][] = 'media--loading';
// Attach data-attributes to the either DIV or IMG container.
$image_attributes['src'] = '';
slick_build_breakpoint_attributes($image_attributes, $settings);
// Do not pass to theme_image() as D7 doesn't support data URI, yet.
$build = '<img' . drupal_attributes($image_attributes) . ' />';
}
else {
$params['path'] = $settings['image_url'];
$build = theme('image', $params);
}
}
else {
$params['uri'] = $uri;
$build = theme('picture', $params);
}
// With CSS background, IMG may be emptied, so add to the container instead.
if (!empty($settings['thumbnail_style'])) {
$attributes['data-thumb'] = image_style_url($settings['thumbnail_style'], $uri);
}
// Prepares a media player.
// build : If iframe switch disabled, use iframe only, remove image.
// player: If no colorbox/photobox, it is an image to iframe switcher.
// data- : Gets consistent with colorbox to share JS manipulation.
// @todo re-check blazy 'data-src' IFRAME lazyload against blazy.media.js.
if ($media) {
$build = empty($switch) ? '' : $build;
$settings['player'] = empty($settings['lightbox']) && $switch != 'content';
$iframe_attributes['data-media'] = drupal_json_encode(array(
'type' => $type,
'scheme' => $item['scheme'],
));
$iframe_attributes['data-lazy'] = $item['embed_url'];
$iframe_attributes['src'] = empty($settings['iframe_lazy']) ? $item['embed_url'] : 'about:blank';
$iframe_attributes['class'][] = 'media__iframe media__element';
if ($settings['player']) {
$attributes['class'][] = 'media--player';
$build .= '<iframe' . drupal_attributes($iframe_attributes) . ' allowfullscreen></iframe>';
$build .= '<span class="media-icon media-icon--close"></span>';
$build .= '<span class="media-icon media-icon--play"></span>';
}
}
$build .= $settings['icon'];
$build = '<div' . drupal_attributes($attributes) . '>' . $build . '</div>';
// The link to content or lightboxes.
if (!empty($variables['url'])) {
if (!empty($settings['lightbox'])) {
$lightbox = TRUE;
$icon = '<span class="media-icon media-icon--lightbox media-icon--' . $settings['lightbox'] . '"></span>';
$build .= empty($settings['icon']) ? $icon : $settings['icon'];
if (!empty($settings['has_pattern'])) {
$build .= '<div class="slide__pattern"></div>';
}
}
$link_options = empty($url_attributes) ? array() : array(
'attributes' => $url_attributes,
);
$link_options['html'] = TRUE;
$build = l($build, $variables['url'], $link_options);
if (isset($lightbox) && !empty($variables['captions']['lightbox'])) {
$build .= '<div class="litebox-caption element-invisible">' . $variables['captions']['lightbox'] . '</div>';
}
}
return $build;
}