t('MPEG-1 Audio Layer 3 (mp3)'),
'wav' => t('Waveform Audio Format (wav)'),
'ra' => t('Real Audio (ra)'),
'mid' => t('Musical Instrument Digital Interface (mid)'),
'ogg' => t('Ogg Vorbis (ogg)'),
);
}
function emaudio_custom_url_info() {
$features = array(
array(t('Thumbnails'), t('No'), ''),
array(t('Autoplay'), t('Yes'), ''),
array(t('RSS attachment'), t('No'), ''),
);
return array(
'provider' => 'custom_url',
'name' => t('Custom URL'),
'url' => '',
'settings_description' => t('These settings specifically affect how custom audio files are displayed. When a field uses a URL it determines to be a link directly to an audio file, it will embed that file into the content. Installing the Flowplayer module will give the embedded player a nicer look.', array('@flowplayer' => 'http://drupal.org/project/flowplayer')),
'supported_features' => $features,
'weight' => 9,
);
}
function emaudio_custom_url_settings() {
$form = array();
$form['emaudio_custom_url_supported_types'] = array(
'#type' => 'checkboxes',
'#title' => t('Supported Types'),
'#options' => _emaudio_custom_url_default_types(),
'#default_value' => _emaudio_custom_url_supported_types(),
'#description' => t('Select the audio types you wish to support. When a custom url with that type is entered into an embedded audio field, it will be parsed and displayed appropriately. If a type is not supported, then it will be ignored.'),
);
return $form;
}
/**
* Retrieves the types that are supported by Custom URLs.
*/
function _emaudio_custom_url_supported_types() {
return variable_get('emaudio_custom_url_supported_types', array_keys(_emaudio_custom_url_default_types()));
}
function emaudio_custom_url_extract($embed = '') {
$types = implode('|', _emaudio_custom_url_supported_types());
$baseurl = preg_quote(url(null, array('absolute' => TRUE)), '@');
return array(
'@' . $baseurl . '(.*' . '\.(?:' . $types . ')' . '(\?.*)?)@i',
'@(.*\.(?:'. $types .')(\?.*)?)@i'
);
}
function emaudio_custom_url_data($field, $item) {
$data = array();
// adding the version control
$data['emaudio_custom_url_data_version'] = 1;
// attempt to get info from headers
$response = emfield_request_header('custom_url', $item['embed']);
if ($response->code == 200) {
$data['url'] = $item['embed'];
$data['size'] = $response->headers['Content-Length'];
$data['mime'] = $response->headers['Content-Type'];
}
// @todo replace ['type'] with converted mime info if available
$types = implode('|', _emaudio_custom_url_supported_types());
$regex = '@\.('. $types .')@i';
if (preg_match($regex, $item['embed'], $matches)) {
$data['type'] = $matches[1];
}
return $data;
}
/**
* hook emfield_PROVIDER_rss
*/
function emaudio_custom_url_rss($item, $teaser = NULL) {
if ($item['value']) {
if ($item['data']['emaudio_custom_url_data_version'] >= 1) {
$data = $item['data'];
}
else {
$data = emaudio_custom_url_data(NULL, $item);
}
$file = array();
if ($data['size'] > 0) {
$file['filepath'] = $data['url'];
$file['filesize'] = $data['size'];
$file['filemime'] = $data['mime'];
}
return $file;
}
}
function theme_emaudio_custom_url_flash($url = NULL, $width = 0, $height = 0, $field = NULL, $data = array(), $node = NULL, $autoplay = FALSE) {
// Validate url
if (!valid_url($url, TRUE) && !valid_url($url)) {
return '';
}
// Display the audio using Flowplayer if it's available.
if (module_exists('flowplayer')) {
$config = array(
'clip' => array(
'autoPlay' => $autoplay,
'url' => url($url, array('absolute' => TRUE)),
),
);
$attributes = array(
'style' => "width:{$width}px;height:{$height}px;",
);
return theme('flowplayer', $config, 'emaudio_custom_url_flash', $attributes);
}
// Display the custom URL using the embed tag.
switch($data['data']['type']) {
case 'wav':
case 'ra':
case 'mp3':
case 'mid':
$autoplay = $autoplay ? 'true' : 'false';
return "";
}
}
/**
* hook emaudio_PROVIDER_audio
* this actually displays the full/normal-sized video we want, usually on the default page view
* @param $embed
* the video code for the audio to embed
* @param $width
* the width to display the audio
* @param $height
* the height to display the audio
* @param $field
* the field info from the requesting node
* @param $item
* the actual content from the field
* @return
* the html of the embedded audio
*/
function emaudio_custom_url_audio($url = NULL, $width = 0, $height = 0, $field = NULL, $data = array(), $node = NULL, $autoplay = FALSE) {
return theme('emaudio_custom_url_flash', $url, $width, $height, $field, $data, $node, $autoplay);
}
/**
* Implementation of hook_emfield_subtheme.
*/
function emaudio_custom_url_emfield_subtheme() {
return array(
'emaudio_custom_url_flash' => array(
'arguments' => array('url' => NULL, 'width' => NULL, 'height' => NULL, 'field' => NULL, 'data' => NULL, 'node' => NULL, 'autoplay' => NULL),
'file' => 'providers/custom_url.inc'
)
);
}