36 var lameIE = $.browser.msie && $.browser.version < 9;
45 $.fn.media =
function(options, f1, f2) {
46 if (options ==
'undo') {
47 return this.each(
function() {
49 var html = $this.data(
'media.origHTML');
51 $this.replaceWith(html);
55 return this.each(
function() {
56 if (typeof options ==
'function') {
61 var o = getSettings(
this, options);
63 if (typeof f1 ==
'function') f1(
this, o);
65 var r = getTypesRegExp();
66 var m = r.exec(o.src.toLowerCase()) || [
''];
68 o.type ? m[0] = o.type : m.shift();
69 for (var i=0; i < m.length; i++) {
70 fn = m[i].toLowerCase();
71 if (isDigit(fn[0])) fn =
'fn' + fn;
75 var player = $.fn.media[fn+
'_player'];
76 if (!o.params) o.params = {};
78 var num = player.autoplayAttr ==
'autostart';
79 o.params[player.autoplayAttr ||
'autoplay'] = num ? (o.autoplay ? 1 : 0) : o.autoplay ?
true :
false;
81 var $div = $.fn.media[fn](
this, o);
83 $div.css(
'backgroundColor', o.bgColor).width(o.width);
86 var $temp = $(
'<div></div>').append(
this);
87 $div.data(
'media.origHTML', $temp.html());
91 if (typeof f2 ==
'function') f2(
this, $div[0], o, player.name);
103 $.fn.media.mapFormat =
function(format, player) {
104 if (!format || !player || !$.fn.media.defaults.players[player])
return;
105 format = format.toLowerCase();
106 if (isDigit(format[0])) format =
'fn' + format;
107 $.fn.media[format] = $.fn.media[player];
108 $.fn.media[format+
'_player'] = $.fn.media.defaults.players[player];
112 $.fn.media.defaults = {
119 params: { wmode:
'transparent'},
124 expressInstaller: null,
127 flvPlayer:
'mediaplayer.swf',
128 mp3Player:
'mediaplayer.swf',
132 inplaceInstallPrompt:
'true',
133 isWindowless:
'true',
144 $.fn.media.defaults.players = {
148 types:
'flv,mp3,swf',
149 mimetype:
'application/x-shockwave-flash',
150 pluginspage:
'http://www.adobe.com/go/getflashplayer',
152 classid:
'clsid:d27cdb6e-ae6d-11cf-96b8-444553540000',
153 type:
'application/x-oleobject',
154 codebase:
'http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=' + $.fn.media.defaults.flashVersion
160 mimetype:
'video/quicktime',
161 pluginspage:
'http://www.apple.com/quicktime/download/',
162 types:
'aif,aiff,aac,au,bmp,gsm,mov,mid,midi,mpg,mpeg,mp4,m4a,psd,qt,qtif,qif,qti,snd,tif,tiff,wav,3g2,3gp',
164 classid:
'clsid:02BF25D5-8C17-4B23-BC80-D3488ABDDC6B',
165 codebase:
'http://www.apple.com/qtactivex/qtplugin.cab'
171 types:
'ra,ram,rm,rpm,rv,smi,smil',
172 mimetype:
'audio/x-pn-realaudio-plugin',
173 pluginspage:
'http://www.real.com/player/',
174 autoplayAttr:
'autostart',
176 classid:
'clsid:CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA'
181 title:
'Windows Media',
182 types:
'asx,asf,avi,wma,wmv',
183 mimetype: $.browser.mozilla && isFirefoxWMPPluginInstalled() ?
'application/x-ms-wmp' :
'application/x-mplayer2',
184 pluginspage:
'http://www.microsoft.com/Windows/MediaPlayer/',
185 autoplayAttr:
'autostart',
188 classid:
'clsid:6BF52A52-394A-11d3-B153-00C04F79FAA6',
189 type:
'application/x-oleobject'
215 function isFirefoxWMPPluginInstalled() {
216 var plugs = navigator.plugins;
217 for (var i = 0; i < plugs.length; i++) {
218 var plugin = plugs[i];
219 if (plugin[
'filename'] ==
'np-mswmp.dll')
227 for (var player in $.fn.media.defaults.players) {
228 var types = $.fn.media.defaults.players[player].types;
229 $.each(types.split(
','),
function(i,o) {
230 if (isDigit(o[0])) o =
'fn' + o;
231 $.fn.media[o] = $.fn.media[player] = getGenerator(player);
232 $.fn.media[o+
'_player'] = $.fn.media.defaults.players[player];
236 function getTypesRegExp() {
238 for (var player in $.fn.media.defaults.players) {
239 if (types.length) types +=
',';
240 types += $.fn.media.defaults.players[player].types;
242 return new RegExp(
'\\.(' + types.replace(/,/ig,
'|') +
')\\b');
245 function getGenerator(player) {
246 return function(el, options) {
247 return generate(el, options, player);
251 function isDigit(c) {
252 return '0123456789'.indexOf(c) > -1;
256 function getSettings(el, options) {
257 options = options || {};
259 var cls = el.className ||
'';
261 var meta = $.metadata ? $el.metadata() : $.meta ? $el.data() : {};
263 var w = meta.width || parseInt(((cls.match(/\bw:(\d+)/)||[])[1]||0)) || parseInt(((cls.match(/\bwidth:(\d+)/)||[])[1]||0));
264 var h = meta.height || parseInt(((cls.match(/\bh:(\d+)/)||[])[1]||0)) || parseInt(((cls.match(/\bheight:(\d+)/)||[])[1]||0))
266 if (w) meta.width = w;
267 if (h) meta.height = h;
268 if (cls) meta.cls = cls;
271 var dataName = 'data-';
272 for (var i=0; i < el.attributes.length; i++) {
273 var
a = el.attributes[i], n = $.trim(a.name);
274 var index = n.indexOf(dataName);
276 n = n.substring(dataName.length);
281 var a = $.fn.media.defaults;
285 var p = { params: { bgColor: options.bgColor || $.fn.media.defaults.bgColor } };
286 var opts = $.extend({},
a,
b, c);
287 $.each([
'attrs',
'params',
'flashvars',
'silverlight'],
function(i,o) {
288 opts[o] = $.extend({}, p[o] || {}, a[o] || {}, b[o] || {}, c[o] || {});
291 if (typeof opts.caption ==
'undefined') opts.caption = $el.text();
294 opts.src = opts.src || $el.attr(
'href') || $el.attr(
'src') ||
'unknown';
303 $.fn.media.swf =
function(el, opts) {
304 if (!window.SWFObject && !window.swfobject) {
306 if (opts.flashvars) {
308 for (var f in opts.flashvars)
309 a.push(f +
'=' + opts.flashvars[f]);
310 if (!opts.params) opts.params = {};
311 opts.params.flashvars = a.join(
'&');
313 return generate(el, opts,
'flash');
316 var
id = el.id ? (
' id="'+el.id+
'"') :
'';
317 var cls = opts.cls ? (
' class="' + opts.cls +
'"') :
'';
318 var $div = $(
'<div' +
id + cls +
'>');
321 if (window.swfobject) {
322 $(el).after($div).appendTo($div);
323 if (!el.id) el.id =
'movie_player_' + counter++;
326 swfobject.embedSWF(opts.src, el.id, opts.width, opts.height, opts.flashVersion,
327 opts.expressInstaller, opts.flashvars, opts.params, opts.attrs);
331 $(el).after($div).remove();
332 var so =
new SWFObject(opts.src,
'movie_player_' + counter++, opts.width, opts.height, opts.flashVersion, opts.bgColor);
333 if (opts.expressInstaller) so.useExpressInstall(opts.expressInstaller);
335 for (var p in opts.params)
336 if (p !=
'bgColor') so.addParam(p, opts.params[p]);
337 for (var f in opts.flashvars)
338 so.addVariable(f, opts.flashvars[f]);
342 if (opts.caption) $(
'<div>').appendTo($div).html(opts.caption);
347 $.fn.media.flv = $.fn.media.mp3 =
function(el, opts) {
349 var player = /\.mp3\b/i.test(src) ? opts.mp3Player : opts.flvPlayer;
350 var key = opts.flvKeyName;
351 src = encodeURIComponent(src);
353 opts.src = opts.src +
'?'+key+
'=' + (src);
356 opts.flashvars = $.extend({}, srcObj, opts.flashvars );
357 return $.fn.media.swf(el, opts);
363 $.fn.media.xaml =
function(el, opts) {
364 if (!window.Sys || !window.Sys.Silverlight) {
365 if ($.fn.media.xaml.warning)
return;
366 $.fn.media.xaml.warning = 1;
367 alert(
'You must include the Silverlight.js script.');
374 background: opts.bgColor,
375 inplaceInstallPrompt: opts.silverlight.inplaceInstallPrompt,
376 isWindowless: opts.silverlight.isWindowless,
377 framerate: opts.silverlight.framerate,
378 version: opts.silverlight.version
381 onError: opts.silverlight.onError,
382 onLoad: opts.silverlight.onLoad
385 var id1 = el.id ? (
' id="'+el.id+
'"') :
'';
386 var id2 = opts.id ||
'AG' + counter++;
388 var cls = opts.cls ? (
' class="' + opts.cls +
'"') :
'';
389 var $div = $(
'<div' + id1 + cls +
'>');
390 $(el).after($div).remove();
392 Sys.Silverlight.createObjectEx({
394 initParams: opts.silverlight.initParams,
395 userContext: opts.silverlight.userContext,
397 parentElement: $div[0],
402 if (opts.caption) $(
'<div>').appendTo($div).html(opts.caption);
409 function generate(el, opts, player) {
411 var o = $.fn.media.defaults.players[player];
413 if (player ==
'iframe') {
414 o = $(
'<iframe' +
' width="' + opts.width +
'" height="' + opts.height +
'" >');
415 o.attr(
'src', opts.src);
416 o.css(
'backgroundColor', o.bgColor);
418 else if (player ==
'img') {
420 o.attr(
'src', opts.src);
421 opts.width && o.attr(
'width', opts.width);
422 opts.height && o.attr(
'height', opts.height);
423 o.css(
'backgroundColor', o.bgColor);
426 var a = [
'<object width="' + opts.width +
'" height="' + opts.height +
'" '];
427 for (var key in opts.attrs)
428 a.push(key +
'="'+opts.attrs[key]+
'" ');
429 for (var key in o.ieAttrs || {}) {
430 var v = o.ieAttrs[key];
431 if (key ==
'codebase' && window.location.protocol ==
'https:')
432 v = v.replace(
'http',
'https');
433 a.push(key +
'="'+v+
'" ');
435 a.push(
'></ob'+
'ject'+
'>');
436 var p = [
'<param name="' + (o.oUrl ||
'src') +
'" value="' + opts.src +
'">'];
437 for (var key in opts.params)
438 p.push(
'<param name="'+ key +
'" value="' + opts.params[key] +
'">');
439 var o = document.createElement(a.join(
''));
440 for (var i=0; i < p.length; i++)
441 o.appendChild(document.createElement(p[i]));
443 else if (opts.standards) {
445 var a = [
'<object type="' + o.mimetype +
'" width="' + opts.width +
'" height="' + opts.height +
'"'];
446 if (opts.src) a.push(
' data="' + opts.src +
'" ');
447 if ($.browser.msie) {
448 for (var key in o.ieAttrs || {}) {
449 var v = o.ieAttrs[key];
450 if (key ==
'codebase' && window.location.protocol ==
'https:')
451 v = v.replace(
'http',
'https');
452 a.push(key +
'="'+v+
'" ');
456 a.push(
'<param name="' + (o.oUrl ||
'src') +
'" value="' + opts.src +
'">');
457 for (var key in opts.params) {
458 if (key ==
'wmode' && player !=
'flash')
460 a.push(
'<param name="'+ key +
'" value="' + opts.params[key] +
'">');
463 a.push(
'<div><p><strong>'+o.title+
' Required</strong></p><p>'+o.title+
' is required to view this media. <a href="'+o.pluginspage+
'">Download Here</a>.</p></div>');
464 a.push(
'</ob'+
'ject'+
'>');
467 var a = [
'<embed width="' + opts.width +
'" height="' + opts.height +
'" style="display:block"'];
468 if (opts.src) a.push(
' src="' + opts.src +
'" ');
469 for (var key in opts.attrs)
470 a.push(key +
'="'+opts.attrs[key]+
'" ');
471 for (var key in o.eAttrs || {})
472 a.push(key +
'="'+o.eAttrs[key]+
'" ');
473 for (var key in opts.params) {
474 if (key ==
'wmode' && player !=
'flash')
476 a.push(key +
'="'+opts.params[key]+
'" ');
478 a.push(
'></em'+
'bed'+
'>');
481 var
id = el.id ? (
' id="'+el.id+
'"') :
'';
482 var cls = opts.cls ? (
' class="' + opts.cls +
'"') :
'';
483 var $div = $(
'<div' +
id + cls +
'>');
484 $el.after($div).remove();
485 (lameIE || player ==
'iframe' || player ==
'img') ? $div.append(o) : $div.html(a.join(
''));
486 if (opts.caption) $(
'<div>').appendTo($div).html(opts.caption);