the translated name of the provider * 'url' => the url to the main page for the provider * 'settings_description' => a description of the provider that will be posted in the admin settings form */ function video_cck_brightcove_info() { return array( 'name' => t('Brightcove'), 'url' => VIDEO_CCK_BRIGHTCOVE_MAIN_URL, 'settings_description' => t('These settings specifically affect videos displayed from !brightcove.', array('!brightcove' => l('Brightcove', VIDEO_CCK_BRIGHTCOVE_MAIN_URL, array('target' => '_blank')))), ); } /** * hook video_cck_PROVIDER_settings * this should return a subform to be added to the video_cck_settings() admin settings page. * note that a form field will already be provided, at $form['PROVIDER'] (such as $form['brightcove']) * so if you want specific provider settings within that field, you can add the elements to that form field. */ function video_cck_brightcove_settings() { $form = array(); return $form; } /** * hook video_cck_PROVIDER_extract * this is called to extract the video code from a pasted URL or embed code. * @param $embed * an optional string with the pasted URL or embed code * @return * either an array of regex expressions to be tested, or a string with the video code to be used * if the hook tests the code itself, it should return either the string of the video code (if matched), or an empty array. * otherwise, the calling function will handle testing the embed code against each regex string in the returned array. */ function video_cck_brightcove_extract($embed = '') { return array( // &initVideoId=753308735& '@\&initVideoId=([^\&]*)\&@', // http://www.brightcove.com/title.jsp?title=753308735 '@brightcove\.com/title\.jsp\?title=(.*)@', ); } /** * hook video_cck_PROVIDER_video_link($video_code) * returns a link to view the video at the provider's site * @param $video_code * the string containing the video to watch * @return * a string containing the URL to view the video at the original provider's site */ function video_cck_brightcove_video_link($video_code) { return 'http://www.brightcove.com/title.jsp?title=' . $video_code; } /** * the embedded flash displaying the brightcove video */ function theme_video_cck_brightcove_flash($embed, $width, $height) { if ($embed) { $output .= ""; } return $output; } /** * hook video_cck_PROVIDER_thumbnail * returns the external url for a thumbnail of a specific video * TODO: make the args: ($embed, $field, $item), with $field/$item provided if we need it, but otherwise simplifying things * @param $field * the field of the requesting node * @param $item * the actual content of the field from the requesting node * @return * a URL pointing to the thumbnail */ function video_cck_brightcove_thumbnail($field, $item) { return NULL; } /** * hook video_cck_PROVIDER_video * this actually displays the full/normal-sized video we want, usually on the default page view * @param $embed * the video code for the video to embed * @param $width * the width to display the video * @param $height * the height to display the video * @param $field * the field info from the requesting node * @param $item * the actual content from the field * @return * the html of the embedded video */ function video_cck_brightcove_video($embed, $width, $height, $field, $item) { $output = theme('video_cck_brightcove_flash', $embed, $width, $height); return $output; } /** * hook video_cck_PROVIDER_video * this actually displays the preview-sized video we want, commonly for the teaser * @param $embed * the video code for the video to embed * @param $width * the width to display the video * @param $height * the height to display the video * @param $field * the field info from the requesting node * @param $item * the actual content from the field * @return * the html of the embedded video */ function video_cck_brightcove_preview($embed, $width, $height, $field, $item) { $output = theme('video_cck_brightcove_flash', $embed, $width, $height); return $output; }