summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/jetpack/modules/shortcodes/bandcamp.php')
-rw-r--r--plugins/jetpack/modules/shortcodes/bandcamp.php229
1 files changed, 0 insertions, 229 deletions
diff --git a/plugins/jetpack/modules/shortcodes/bandcamp.php b/plugins/jetpack/modules/shortcodes/bandcamp.php
deleted file mode 100644
index 312418f7..00000000
--- a/plugins/jetpack/modules/shortcodes/bandcamp.php
+++ /dev/null
@@ -1,229 +0,0 @@
-<?php
-// shortcode handler for [bandcamp], which inserts a bandcamp.com
-// music player (iframe, html5)
-//
-// [bandcamp album=119385304]
-// [bandcamp album=3462839126 bgcol=FFFFFF linkcol=4285BB size=venti]
-// [bandcamp track=2446959313]
-//
-function shortcode_handler_bandcamp( $atts ) {
- // there are no default values, but specify here anyway
- // to explicitly list supported atts
- $attributes = shortcode_atts(
- array(
- 'album' => null, // integer album id
- 'track' => null, // integer track id
- 'video' => null, // integer track id for video player
- 'size' => 'venti', // one of the supported sizes
- 'bgcol' => 'FFFFFF', // hex, no '#' prefix
- 'linkcol' => null, // hex, no '#' prefix
- 'layout' => null, // encoded layout url
- 'width' => null, // integer with optional "%"
- 'height' => null, // integer with optional "%"
- 'notracklist' => null, // may be string "true" (defaults false)
- 'tracklist' => null, // may be string "false" (defaults true)
- 'artwork' => null, // may be string "false" (alternately: "none") or "small" (default is large)
- 'minimal' => null, // may be string "true" (defaults false)
- 'theme' => null, // may be theme identifier string ("light"|"dark" so far)
- 'package' => null, // integer package id
- 't' => null, // integer track number
- 'tracks' => null, // comma separated list of allowed tracks
- 'esig' => null, // hex, no '#' prefix
- ),
- $atts,
- 'bandcamp'
- );
-
- $sizes = array(
- 'venti' => array(
- 'width' => 400,
- 'height' => 100,
- ),
- 'grande' => array(
- 'width' => 300,
- 'height' => 100,
- ),
- 'grande2' => array(
- 'width' => 300,
- 'height' => 355,
- ),
- 'grande3' => array(
- 'width' => 300,
- 'height' => 415,
- ),
- 'tall_album' => array(
- 'width' => 150,
- 'height' => 295,
- ),
- 'tall_track' => array(
- 'width' => 150,
- 'height' => 270,
- ),
- 'tall2' => array(
- 'width' => 150,
- 'height' => 450,
- ),
- 'short' => array(
- 'width' => 46,
- 'height' => 23,
- ),
- 'large' => array(
- 'width' => 350,
- 'height' => 470,
- ),
- 'medium' => array(
- 'width' => 450,
- 'height' => 120,
- ),
- 'small' => array(
- 'width' => 350,
- 'height' => 42,
- ),
- );
-
- $sizekey = $attributes['size'];
- $height = null;
- $width = null;
-
- $isVideo = false;
-
- // Build iframe url. For audio players, args are appended as
- // extra path segments for historical reasons having to
- // do with an IE-only flash bug which required this URL
- // to contain no querystring. Delay the actual joining
- // of args into a string until after we decide if it's
- // a video player or an audio player
- $argparts = array();
-
- if ( ! isset( $attributes['album'] ) && ! isset( $attributes['track'] ) && ! isset( $attributes['video'] ) ) {
- return "[bandcamp: shortcode must include 'track', 'album', or 'video' param]";
- }
-
- if ( isset( $attributes['track'] ) && is_numeric( $attributes['track'] ) ) {
- $track = esc_attr( $attributes['track'] );
- array_push( $argparts, "track={$track}" );
- } elseif ( isset( $attributes['video'] ) && is_numeric( $attributes['video'] ) ) {
- $track = esc_attr( $attributes['video'] ); // videos are referenced by track id
- $urlbase = '//bandcamp.com/EmbeddedPlayer/v=2';
- $isVideo = true;
- array_push( $argparts, "track={$track}" );
- }
- if ( isset( $attributes['album'] ) && is_numeric( $attributes['album'] ) ) {
- $album = esc_attr( $attributes['album'] );
- array_push( $argparts, "album={$album}" );
- }
-
- if ( $sizekey == 'tall' ) {
- if ( isset( $attributes['album'] ) ) {
- $sizekey .= '_album';
- } else {
- $sizekey .= '_track';
- }
- }
-
- // if size specified that we don't recognize, fall back on venti
- if ( empty( $sizes[ $sizekey ] ) ) {
- $sizekey = 'venti';
- $attributes['size'] = 'venti';
- }
-
- // use strict regex for digits + optional % instead of absint for height/width
- // 'width' and 'height' params in the iframe url get the exact string from the shortcode
- // args, whereas the inline style attribute must have "px" added to it if it has no "%"
- if ( isset( $attributes['width'] ) && preg_match( '|^([0-9]+)(%)?$|', $attributes['width'], $matches ) ) {
- $width = $csswidth = $attributes['width'];
- if ( sizeof( $matches ) < 3 ) {
- $csswidth .= 'px';
- }
- }
- if ( isset( $attributes['height'] ) && preg_match( '|^([0-9]+)(%)?$|', $attributes['height'], $matches ) ) {
- $height = $cssheight = $attributes['height'];
- if ( sizeof( $matches ) < 3 ) {
- $cssheight .= 'px';
- }
- }
-
- if ( ! $height ) {
- $height = $sizes[ $sizekey ]['height'];
- $cssheight = $height . 'px';
- }
-
- if ( ! $width ) {
- $width = $sizes[ $sizekey ]['width'];
- $csswidth = $width . 'px';
- }
-
- if ( isset( $attributes['layout'] ) ) {
- array_push( $argparts, "layout={$attributes['layout']}" );
- } elseif ( isset( $attributes['size'] ) && preg_match( '|^[a-zA-Z0-9]+$|', $attributes['size'] ) ) {
- array_push( $argparts, "size={$attributes['size']}" );
- }
-
- if ( isset( $attributes['bgcol'] ) && preg_match( '|^[0-9A-Fa-f]+$|', $attributes['bgcol'] ) ) {
- array_push( $argparts, "bgcol={$attributes['bgcol']}" );
- }
-
- if ( isset( $attributes['linkcol'] ) && preg_match( '|^[0-9A-Fa-f]+$|', $attributes['linkcol'] ) ) {
- array_push( $argparts, "linkcol={$attributes['linkcol']}" );
- }
-
- if ( isset( $attributes['package'] ) && preg_match( '|^[0-9]+$|', $attributes['package'] ) ) {
- array_push( $argparts, "package={$attributes['package']}" );
- }
-
- if ( isset( $attributes['t'] ) && preg_match( '|^[0-9]+$|', $attributes['t'] ) ) {
- array_push( $argparts, "t={$attributes['t']}" );
- }
-
- if ( $attributes['notracklist'] == 'true' ) {
- array_push( $argparts, 'notracklist=true' );
- }
-
- // 'tracklist' arg deprecates 'notracklist=true' to be less weird. note, behavior
- // if both are specified is undefined
- switch ( $attributes['tracklist'] ) {
- case 'false':
- case 'none':
- array_push( $argparts, 'tracklist=false' );
- break;
- }
-
- switch ( $attributes['artwork'] ) {
- case 'false':
- case 'none':
- case 'small':
- array_push( $argparts, 'artwork=' . $attributes['artwork'] );
- break;
- }
-
- if ( $attributes['minimal'] == 'true' ) {
- array_push( $argparts, 'minimal=true' );
- }
-
- if ( isset( $attributes['theme'] ) && preg_match( '|^[a-zA-Z_]+$|', $attributes['theme'] ) ) {
- array_push( $argparts, "theme={$attributes['theme']}" );
- }
-
- // param 'tracks' is signed digest param 'esig'
- if ( isset( $attributes['tracks'] ) && preg_match( '|^[0-9\,]+$|', $attributes['tracks'] ) ) {
- if ( isset( $attributes['esig'] ) && preg_match( '|^[0-9A-Fa-f]+$|', $attributes['esig'] ) ) {
- array_push( $argparts, "tracks={$attributes['tracks']}" );
- array_push( $argparts, "esig={$attributes['esig']}" );
- }
- }
-
- if ( $isVideo ) {
- $url = '//bandcamp.com/VideoEmbed?' . join( '&', $argparts );
- $extraAttrs = " mozallowfullscreen='1' webkitallowfullscreen='1' allowfullscreen='1'";
- } else {
- $url = '//bandcamp.com/EmbeddedPlayer/v=2/' . join( '/', $argparts ) . '/';
- $extraAttrs = '';
- }
-
- $iframe = '<iframe width="%s" height="%s" style="position: relative; display: block; width: %s; height: %s;" src="%s" allowtransparency="true" frameborder="0"%s></iframe>';
- $iframe = sprintf( $iframe, esc_attr( $width ), esc_attr( $height ), esc_attr( $csswidth ), esc_attr( $cssheight ), esc_url( $url ), $extraAttrs );
-
- return $iframe;
-}
-
-add_shortcode( 'bandcamp', 'shortcode_handler_bandcamp' );