You are here

podcastalley.inc in Embedded Media Field 6.3

This include processes Podcastalley audio files for use by emaudio.module.

File

contrib/emaudio/providers/podcastalley.inc
View source
<?php

/**
 * @file
 * This include processes Podcastalley audio files for use by emaudio.module.
 */
define('EMAUDIO_PODCASTALLEY_MAIN_URL', 'http://www.podcastalley.com');

/**
 * Implementation of hook emaudio_podcastalley_info().
 *
 * This returns information relevant to a specific 3rd party audio provider.
 *
 * @return
 *   An array of strings requested by various admin and other forms.
 *   'name' => 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.
 *   'supported_features' => An array of rows describing the state of certain supported features by the provider.
 *      These will be rendered in a table, with the columns being 'Feature', 'Supported', 'Notes'.
 */
function emaudio_podcastalley_info() {
  $features = array(
    array(
      t('Autoplay'),
      t('No'),
      '',
    ),
    array(
      t('RSS Attachment'),
      t('No'),
      '',
    ),
    array(
      t('Thumbnails'),
      t('No'),
      t(''),
    ),
  );
  return array(
    'provider' => 'Podcast Alley',
    'name' => t('Podcast Alley'),
    'url' => EMAUDIO_PODCASTALLEY_MAIN_URL,
    'settings_description' => t('These settings specifically affect audio podcasts displayed from <a href="@podcastalley" target="_blank">Podcast Alley</a>.', array(
      '@podcastalley' => EMAUDIO_PODCASTALLEY_MAIN_URL,
    )),
    'supported_features' => $features,
  );
}

/**
 * Implementation of hook emaudio_podcastalley_settings().
 *
 * This should return a subform to be added to the emaudio_settings() admin settings page.
 * Note that a form field will already be provided, at $form['podcastalley'].
 * So if you want specific provider settings within that field, you can add the elements to that form field.
 */
function emaudio_podcastalley_settings() {
  $form = array();
  return $form;
}

/**
 * Implementation of hook emaudio_podcastalley_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
 *   audio code to be used. If the hook tests the code itself, it should return
 *   either the string of the audio 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 emaudio_podcastalley_extract($embed = '') {

  // http://www.podcastalley.com/podcast_details.php?pod_id=929#
  return array(
    '@podcastalley\\.com/podcast_details\\.php\\?pod_id=([0-9]+)@i',
  );
}

/**
 * The embedded flash displaying the podcastalley audio.
 *
 * Default width is 419, height is 202.
 */
function theme_emaudio_podcastalley_flash($embed, $width, $height, $autoplay) {
  if ($embed) {

    /*
    if ($autoplay) {
      $autoplay_value = '&autostart=1';
    }
    */
    $output .= "\n        <object classid=\"clsid:d27cdb6e-ae6d-11cf-96b8-444553540000\" codebase=\"http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,47,0\"width=\"{$width}\" height=\"{$height}\" id=\"wimpy\" align=\"center\">\n      <param name=\"allowScriptAccess\" value=\"sameDomain\" />\n      <param name=\"movie\" value=\"http://www.podcastalley.com/player/wimpy.swf?wimpyApp=http://www.podcastalley.com/player/playlist.php?pod_id=" . $embed . "&u=1.xml&wimpySkin=http://www.podcastalley.com/player/paskin.xml&wW=419&wH=202&forceXMLplaylist=yes&defaultVisualExt=jpg&theVolume=100&bufferAudio=0&infoDisplayTime=3&iTextStyle=scroller&startPlayingOnload=yes&popUpHelp=no\" />\n\n      <param name=\"loop\" value=\"false\" />\n      <param name=\"menu\" value=\"false\" />\n      <param name=\"quality\" value=\"high\" />\n      <param name=\"scale\" value=\"noscale\" />\n      <param name=\"salign\" value=\"lt\" />\n      <param name=\"bgcolor\" value=\"#000000\" />\n      <embed src=\"http://www.podcastalley.com/player/wimpy.swf?wimpyApp=http://www.podcastalley.com/player/playlist.php?pod_id=" . $embed . "&u=1.xml&wimpySkin=http://www.podcastalley.com/player/paskin.xml&wW=419&wH=202&forceXMLplaylist=yes&defaultVisualExt=jpg&theVolume=100&bufferAudio=0&infoDisplayTime=3&iTextStyle=scroller&startPlayingOnload=yes&popUpHelp=no\" loop=\"false\" menu=\"false\" quality=\"high\" width=\"419\" height=\"202\" scale=\"noscale\" salign=\"lt\" name=\"wimpy\" align=\"center\" bgcolor=\"#000000\" allowScriptAccess=\"sameDomain\" type=\"application/x-shockwave-flash\" pluginspage=\"http://www.macromedia.com/go/getflashplayer\" />\n    </object>\n    \n";
  }
  return $output;
}

/**
 * Implementation of hook emaudio_podcastalley_thumbnail.
 *
 * Returns the external url for a thumbnail of a specific audio.
 * 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 emaudio_podcastalley_thumbnail($field, $item, $formatter, $node, $width, $height) {
  return '';
}

/**
 * Implementation of hook emaudio_podcastalley_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_podcastalley_audio($embed, $width, $height, $field, $item, $node, $autoplay) {
  $output = theme('emaudio_podcastalley_flash', $embed, $width, $height, $autoplay);
  return $output;
}

/**
 * Implementation of hook emaudio_podcastalley_preview().
 *
 * This actually displays the preview-sized video we want, commonly for the teaser.
 *
 * @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_podcastalley_preview($embed, $width, $height, $field, $item, $node, $autoplay) {
  $output = theme('emaudio_podcastalley_flash', $embed, $width, $height, $autoplay);
  return $output;
}

/**
 * Implementation of hook_emfield_subtheme.
 */
function emaudio_podcastalley_emfield_subtheme() {
  return array(
    'emaudio_podcastalley_flash' => array(
      'arguments' => array(
        'embed' => NULL,
        'width' => NULL,
        'height' => NULL,
        'autoplay' => NULL,
      ),
      'file' => 'providers/podcastalley.inc',
    ),
  );
}

Functions

Namesort descending Description
emaudio_podcastalley_audio Implementation of hook emaudio_podcastalley_audio().
emaudio_podcastalley_emfield_subtheme Implementation of hook_emfield_subtheme.
emaudio_podcastalley_extract Implementation of hook emaudio_podcastalley_extract().
emaudio_podcastalley_info Implementation of hook emaudio_podcastalley_info().
emaudio_podcastalley_preview Implementation of hook emaudio_podcastalley_preview().
emaudio_podcastalley_settings Implementation of hook emaudio_podcastalley_settings().
emaudio_podcastalley_thumbnail Implementation of hook emaudio_podcastalley_thumbnail.
theme_emaudio_podcastalley_flash The embedded flash displaying the podcastalley audio.

Constants

Namesort descending Description
EMAUDIO_PODCASTALLEY_MAIN_URL @file This include processes Podcastalley audio files for use by emaudio.module.