123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- <?php
- /**
- * @file media_vimeo/includes/themes/media_vimeo.theme.inc
- *
- * Theme and preprocess functions for Media: Vimeo.
- */
- /**
- * Preprocess function for theme('media_vimeo_video').
- */
- function media_vimeo_preprocess_media_vimeo_video(&$variables) {
- // Build the URL for display.
- $uri = $variables['uri'];
- $wrapper = file_stream_wrapper_get_instance_by_uri($uri);
- $parts = $wrapper->get_parameters();
- $variables['video_id'] = check_plain($parts['v']);
- $variables['width'] = isset($variables['width']) ? $variables['width'] : media_vimeo_variable_get('width');
- $variables['height'] = isset($variables['height']) ? $variables['height'] : media_vimeo_variable_get('height');
- $variables['autoplay'] = isset($variables['autoplay']) ? $variables['autoplay'] : media_vimeo_variable_get('autoplay');
- $variables['fullscreen'] = isset($variables['fullscreen']) ? $variables['fullscreen'] : media_vimeo_variable_get('fullscreen');
- $variables['autoplay'] = $variables['autoplay'] ? 1 : 0;
- $variables['fullscreen'] = $variables['fullscreen'] ? 'true' : 'false';
- $variables['wrapper_id'] = 'media_vimeo_' . $variables['video_id'] . '_' . $variables['id'];
- // For users with JavaScript, these object and embed tags will be replaced
- // by an iframe, so that we can support users without Flash.
- $variables['output'] = <<<OUTPUT
- <object width="{$variables['width']}" height="{$variables['height']}">
- <param name="movie" value="http://vimeo.com/moogaloop.swf?clip_id={$variables['video_id']}">
- <param name="allowFullScreen" value="{$variables['fullscreen']}"></param>
- <param name="wmode" value="transparent" />
- <embed src="http://vimeo.com/moogaloop.swf?clip_id={$variables['video_id']}" type="application/x-shockwave-flash" width="{$variables['width']}" height="{$variables['height']}" allowfullscreen="{$variables['fullscreen']}"></embed>
- </object>
- OUTPUT;
- // Pass the settings to replace the object tag with an iframe.
- $settings = array(
- 'media_vimeo' => array(
- $variables['wrapper_id'] => array(
- 'width' => $variables['width'],
- 'height' => $variables['height'],
- 'video_id' => $variables['video_id'],
- 'fullscreen' => $variables['fullscreen'],
- 'id' => $variables['wrapper_id'] .'_iframe',
- ),
- ),
- );
- if ($variables['autoplay']) {
- $settings['media_vimeo'][$variables['wrapper_id']]['options'] = array(
- 'autoplay' => $variables['autoplay'],
- );
- }
- drupal_add_js($settings, 'setting');
- drupal_add_js(drupal_get_path('module', 'media_vimeo') . '/js/media_vimeo.js');
- drupal_add_css(drupal_get_path('module', 'media_vimeo') . '/css/media_vimeo.css');
- drupal_add_js(drupal_get_path('module', 'media_vimeo') . '/js/flash_detect_min.js');
- }
- function theme_media_vimeo_field_formatter_styles($variables) {
- $element = $variables['element'];
- $style = $variables['style'];
- $variables['file'] = $element['#item'];
- $variables['uri'] = $variables['file']['uri'];
- $variables['style_name'] = $style['name'];
- return theme('media_vimeo_embed', $variables);
- }
- /**
- * Preview for Styles UI.
- */
- function theme_media_vimeo_preview_style($variables) {
- $variables['uri'] = media_vimeo_variable_get('preview_uri');
- $variables['field_type'] = 'file';
- $variables['object'] = file_uri_to_object($variables['uri']);
- return theme('styles', $variables);
- }
- /**
- * NOTE: Deprecated with Styles version 2.
- */
- function theme_media_vimeo_styles($variables) {
- $style = $variables['style'];
- $variables['file'] = $variables['object'];
- $variables['uri'] = $variables['object']->uri;
- $variables['style_name'] = $style['name'];
- return theme('media_vimeo_embed', $variables);
- }
- /**
- * @todo: get this working
- *
- * This code is for embedding videos in WYSIYWG areas, not currently working.
- * NOTE: Deprecated with Styles version 2.
- */
- function theme_media_vimeo_embed($variables) {
- $preset_name = $variables['preset_name'];
- $preset = styles_containers_available_styles('file', 'media_vimeo', $preset_name);
- $output = '';
- if (!empty($preset)) {
- // Build the URL for display.
- $uri = $variables['uri'];
- $wrapper = file_stream_wrapper_get_instance_by_uri($uri);
- $parts = $wrapper->get_parameters();
- $fullscreen_value = $autoplay = 'false';
- $in_browser = $thumbnail = FALSE;
- foreach ($preset['effects'] as $effect) {
- switch ($effect['name']) {
- case 'autoplay':
- $autoplay = $effect['data']['autoplay'] ? 'true' : 'false';
- break;
- case 'resize':
- $width = $effect['data']['width'];
- $height = $effect['data']['height'];
- break;
- case 'fullscreen':
- $fullscreen_value = $effect['data']['fullscreen'] ? 'true' : 'false';
- break;
- case 'thumbnail':
- $thumbnail = $effect['data']['thumbnail'];
- }
- }
- if (isset($variables['object']->override)) {
- $override = $variables['object']->override;
- if (isset($override['width'])) {
- $width = $override['width'];
- }
- if (isset($override['height'])) {
- $height = $override['height'];
- }
- if (isset($override['wysiwyg'])) {
- $thumbnail = TRUE;
- }
- if (isset($override['browser']) && $override['browser']) {
- $in_browser = TRUE;
- $thumbnail = TRUE;
- }
- }
- $width = isset($width) ? $width : media_vimeo_variable_get('width');
- $height = isset($height) ? $height : media_vimeo_variable_get('height');
- $video_id = check_plain($parts['v']);
- if ($thumbnail) {
- // @todo Clean this up.
- $image_variables = array(
- 'path' => $wrapper->getOriginalThumbnailPath(),
- 'alt' => $variables['alt'],
- 'title' => $variables['title'],
- 'getsize' => FALSE,
- );
- if (isset($preset['image_style'])) {
- $image_variables['path'] = $wrapper->getLocalThumbnailPath();
- $image_variables['style_name'] = $preset['image_style'];
- $output = theme('image_style', $image_variables);
- }
- else {
- // We need to add this style attribute here so that it doesn't get lost
- // If you resize a video in a node, save it, edit it, but don't adjust
- // the sizing of the video while editing, the size will revert to the
- // default. Adding the specific size here retains the original resizing
- $WYSIWYG = isset($variables['object']->override['style']) ? $variables['object']->override['style'] : '';
- $image_variables['attributes'] = array('width' => $width, 'height' => $height, 'style' => $WYSIWYG);
- $output = theme('image', $image_variables);
- }
- if ($in_browser) {
- // Add an overlay that says 'Vimeo' to media library browser thumbnails.
- $output .= '<span />';
- }
- }
- else {
- $output = theme('media_vimeo_video', array('uri' => $uri, 'width' => $width, 'height' => $height, 'autoplay' => ($autoplay == 'true' ? TRUE : NULL), 'fullscreen' => ($fullscreen_value == 'true' ? TRUE : NULL)));
- }
- }
- return $output;
- }
|