theme.inc in Brightcove Video Connect 7.5
Same filename and directory in other branches
Theme funciton for the module.
File
brightcove_field/theme.incView source
<?php
/**
* @file
* Theme funciton for the module.
*/
/**
* Theme callback for a Brightcove browse button.
* Currently it's just a thin wrapper around the theme_button()
* function which only returns a button of type submit. The themed
* representation is just adapted to achieve an input html tag
* of the type button.
*
* @see nodereference_explorer.module
*/
function theme_brightcove_field_browse_button($element) {
drupal_add_js(drupal_get_path('module', 'brightcove_field') . '/js/brightcove.js');
$element['#button_type'] = 'button';
// TODO: review after the field part is stable
$button = theme('button', array(
'element' => $element,
));
return str_ireplace('type="submit"', 'type="button"', $button);
}
/**
* Theme callback for Brightcove browse table item.
*
* @param item
* Video item.
*
* @return
* Themed item form.
*/
function theme_brightcove_field_browse_item($variables) {
$form = drupal_get_form('brightcove_field_browser_form' . $variables['item']['brightcove_id'], $variables['item']);
return drupal_render($form);
}
/**
* Theme callback for Brightcove browse table.
*
* @param $variables
* Array of video items.
*
* @return
* Themed browse table.
*/
function theme_brightcove_field_browse_items($variables) {
$rowcount = 0;
$activerow = 0;
$rows = array();
foreach ($variables['items'] as $item) {
// TODO test these after field port is stable
$themed = theme('brightcove_field_browse_item', array(
'item' => $item,
));
$rowcount++;
if ($rowcount == 4) {
$activerow++;
$rowcount = 1;
}
$rows[$activerow][] = $themed;
}
// TODO test these after field port is stable
return theme('table', array(
'header' => array(),
'rows' => $rows,
));
}
/**
* The brightcove_field_embed theme function preprocess function.
*
* @param $variables
*/
function brightcove_field_preprocess_brightcove_field_embed(&$variables) {
if (!isset($variables['player'])) {
watchdog('brightcove', 'Brightcove player is missing.', array(), WATCHDOG_ERROR);
}
$player = brightcove_player_load($variables['player']);
$variables['id'] = 'myExperience-' . $variables['id'];
$variables['bgcolor'] = '#FFFFFF';
$variables['width'] = isset($variables['width']) ? $variables['width'] : BRIGHTCOVE_DEFAULT_VIDEO_WIDTH;
$variables['height'] = isset($variables['height']) ? $variables['height'] : BRIGHTCOVE_DEFAULT_VIDEO_HEIGHT;
$variables['responsive'] = FALSE;
$variables['smart_api'] = FALSE;
// If player should be responsive.
if (!is_null($player) && $player->responsive || variable_get('brightcove_player_responsive', FALSE)) {
$variables['responsive'] = TRUE;
drupal_add_css(drupal_get_path('module', 'brightcove_field') . '/styles/responsive.css');
}
// If we should use Smart player API.
if (variable_get('brightcove_player_smart_api', FALSE)) {
$variables['smart_api'] = TRUE;
// Add width and height to client side to be able to use it by Smart Player API.
drupal_add_js(array(
'brightcoveField' => array(
$variables['id'] => array(
'width' => $variables['width'],
'height' => $variables['height'],
),
),
), 'setting');
}
if (isset($variables['brightcove_id'])) {
$variables['player_id'] = isset($player->player_id) ? $player->player_id : '';
$variables['player_key'] = isset($player->player_key) ? $player->player_key : '';
if (drupal_strtolower($variables['type']) == 'brightcove') {
$variables['is_vid'] = TRUE;
}
elseif (drupal_strtolower($variables['type']) == 'brightcove-player') {
$variables['is_vid'] = FALSE;
}
}
}
Functions
Name | Description |
---|---|
brightcove_field_preprocess_brightcove_field_embed | The brightcove_field_embed theme function preprocess function. |
theme_brightcove_field_browse_button | Theme callback for a Brightcove browse button. Currently it's just a thin wrapper around the theme_button() function which only returns a button of type submit. The themed representation is just adapted to achieve an input html tag of the type… |
theme_brightcove_field_browse_item | Theme callback for Brightcove browse table item. |
theme_brightcove_field_browse_items | Theme callback for Brightcove browse table. |