/* init.js - initialization and configuration of the widgets
*/
if (typeof window.IriSP === "undefined") {
window.IriSP = {};
}
/* The Metadataplayer Object, single point of entry, replaces IriSP.init_player */
IriSP.Metadataplayer = function(config) {
IriSP.log("IriSP.Metadataplayer constructor");
for (var key in IriSP.guiDefaults) {
if (IriSP.guiDefaults.hasOwnProperty(key) && !config.hasOwnProperty(key)) {
config[key] = IriSP.guiDefaults[key]
}
}
var _container = document.getElementById(config.container);
_container.innerHTML = '<h3 class="Ldt-Loader">Loading... Chargement...</h3>';
this.sourceManager = new IriSP.Model.Directory();
this.config = config;
this.__events = {};
this.loadLibs();
}
IriSP.Metadataplayer.prototype.toString = function() {
return 'Metadataplayer in #' + this.config.container;
}
IriSP.Metadataplayer.prototype.on = function(_event, _callback) {
if (typeof this.__events[_event] === "undefined") {
this.__events[_event] = [];
}
this.__events[_event].push(_callback);
}
IriSP.Metadataplayer.prototype.trigger = function(_event, _data) {
var _element = this;
IriSP._(this.__events[_event]).each(function(_callback) {
_callback.call(_element, _data);
});
}
IriSP.Metadataplayer.prototype.loadLibs = function() {
IriSP.log("IriSP.Metadataplayer.prototype.loadLibs");
var $L = $LAB
.script(IriSP.getLib("underscore"))
.script(IriSP.getLib("Mustache"))
.script(IriSP.getLib("jQuery"));
if (typeof JSON == "undefined") {
$L.script(IriSP.getLib("json"));
}
$L.wait()
.script(IriSP.getLib("jQueryUI"));
/* widget specific requirements */
for(var _i = 0; _i < this.config.widgets.length; _i++) {
var _t = this.config.widgets[_i].type;
if (typeof IriSP.widgetsRequirements[_t] !== "undefined" && typeof IriSP.widgetsRequirements[_t].requires !== "undefined" ) {
for (var _j = 0; _j < IriSP.widgetsRequirements[_t].requires.length; _j++) {
$L.script(IriSP.getLib(IriSP.widgetsRequirements[_t].requires[_j]));
}
}
}
var _this = this;
$L.wait(function() {
_this.onLibsLoaded();
});
}
IriSP.Metadataplayer.prototype.onLibsLoaded = function() {
IriSP.log("IriSP.Metadataplayer.prototype.onLibsLoaded");
if (typeof IriSP.jQuery === "undefined" && typeof window.jQuery !== "undefined") {
IriSP.jQuery = window.jQuery.noConflict();
}
if (typeof IriSP._ === "undefined" && typeof window._ !== "undefined") {
IriSP._ = window._;
}
IriSP.loadCss(IriSP.getLib("cssjQueryUI"));
IriSP.loadCss(this.config.css);
// this.videoData = this.loadMetadata(this.config.player.metadata);
this.$ = IriSP.jQuery('#' + this.config.container);
this.$.css({
"width": this.config.width,
"clear": "both"
});
if (typeof this.config.height !== "undefined") {
this.$.css("height", this.config.height);
}
this.widgets = [];
var _this = this;
for(var i = 0; i < this.config.widgets.length; i++) {
this.loadWidget(this.config.widgets[i], function(_widget) {
_this.widgets.push(_widget)
});
};
this.$.find('.Ldt-Loader').detach();
/*
this.videoData.onLoad(function() {
_this.onVideoDataLoaded();
});
*/
}
IriSP.Metadataplayer.prototype.loadMetadata = function(_metadataInfo) {
if (typeof _metadataInfo.serializer === "undefined" && typeof _metadataInfo.format !== "undefined") {
_metadataInfo.serializer = IriSP.serializers[_metadataInfo.format];
}
if (typeof _metadataInfo.url === "undefined" && typeof _metadataInfo.src !== "undefined") {
_metadataInfo.url = _metadataInfo.src;
}
if (typeof _metadataInfo.url !== "undefined" && typeof _metadataInfo.serializer !== "undefined") {
return this.sourceManager.remoteSource(_metadataInfo);
} else {
return this.sourceManager.newLocalSource(_metadataInfo);
}
}
// TODO: REMOVE !
IriSP.Metadataplayer.prototype.onVideoDataLoaded = function() {
/* Setting default media from metadata */
if (typeof this.videoData !== "undefined") {
var _media;
if (typeof this.videoData.mainMedia !== "undefined") {
_media = this.videoData.getElement(this.videoData.mainMedia);
}
if (this.config.player.type === "mashup" || this.config.player.type === "mashup-html") {
if (typeof _media === "undefined" || _media.elementType !== "mashup") {
var _mashups = this.videoData.getMashups();
if (_mashups.length) {
_media = _mashups[0];
}
}
} else {
if (typeof _media === "undefined" || _media.elementType !== "media") {
var _medias = this.videoData.getMedias();
if (_medias.length) {
_media = _medias[0];
}
}
}
this.videoData.currentMedia = _media;
/* Getting video URL from metadata if it's not in the player config options */
if (typeof _media !== "undefined" && typeof _media.video !== "undefined" && typeof this.config.player.video === "undefined") {
this.config.player.video = _media.video;
if (typeof this.config.player.streamer == "undefined" && typeof _media.streamer !== "undefined") {
this.config.player.streamer = _media.streamer;
}
}
}
if (typeof this.config.player.video === "string" && this.config.player.url_transform === "function") {
this.config.player.video = this.config.player.url_transform(this.config.player.video);
}
var _pop,
_divs = this.layoutDivs("video",this.config.player.height || undefined),
containerDiv = _divs[0],
spacerDiv = _divs[1],
_this = this,
_types = {
"html5" : /\.(ogg|ogv|webm)$/,
"youtube" : /^(https?:\/\/)?(www\.)?youtube\.com/,
"vimeo" : /^(https?:\/\/)?(www\.)?vimeo\.com/,
"dailymotion" : /^(https?:\/\/)?(www\.)?dailymotion\.com/
};
if (this.config.player.type === "auto") {
this.config.player.type = "jwplayer";
IriSP._(_types).each(function(_v, _k) {
if (_v.test(_this.config.player.video)) {
_this.config.player.type = _k
}
});
}
switch(this.config.player.type) {
case "html5":
var _tmpId = Popcorn.guid("video"),
_videoEl = IriSP.jQuery('<video>');
_videoEl.attr({
"src" : this.config.player.video,
"id" : _tmpId
})
if(this.config.player.hasOwnProperty("width")) {
_videoEl.attr("width", this.config.player.width);
}
if(this.config.player.hasOwnProperty("height")) {
_videoEl.attr("height", this.config.player.height);
}
IriSP.jQuery("#" + containerDiv).append(_videoEl);
_pop = Popcorn("#" + _tmpId);
break;
case "html5-audio":
var _tmpId = Popcorn.guid("audio"),
_videoEl = IriSP.jQuery('<audio>');
_videoEl.attr({
"src" : this.config.player.video,
"id" : _tmpId
})
if(this.config.player.hasOwnProperty("width")) {
_videoEl.attr("width", this.config.player.width);
}
if(this.config.player.hasOwnProperty("height")) {
_videoEl.attr("height", this.config.player.height);
}
IriSP.jQuery("#" + containerDiv).append(_videoEl);
_pop = Popcorn("#" + _tmpId);
break;
case "jwplayer":
var opts = IriSP.jQuery.extend({}, this.config.player);
delete opts.container;
delete opts.type;
if (typeof opts.streamer === "function") {
opts.streamer = opts.streamer(opts.video);
}
if (typeof opts.streamer === "string") {
opts.video = opts.video.replace(opts.streamer,"");
}
opts.file = opts.video;
delete opts.video;
delete opts.metadata;
if(!opts.hasOwnProperty("flashplayer")) {
opts.flashplayer = IriSP.getLib("jwPlayerSWF");
}
if(!opts.hasOwnProperty("controlbar.position")) {
opts["controlbar.position"] = "none";
}
_pop = new IriSP.PopcornReplacement.jwplayer("#" + containerDiv, opts);
break;
case "youtube":
// Popcorn.youtube wants us to specify the size of the player in the style attribute of its container div.
IriSP.jQuery("#" + containerDiv).css({
width : this.config.player.width + "px",
height : this.config.player.height + "px"
});
var _urlparts = this.config.player.video.split(/[?&]/),
_params = {};
for (var _j = 1; _j < _urlparts.length; _j++) {
var _ppart = _urlparts[_j].split('=');
_params[_ppart[0]] = decodeURIComponent(_ppart[1]);
}
_params.controls = 0;
_params.modestbranding = 1;
_url = _urlparts[0] + '?' + IriSP.jQuery.param(_params);
_pop = Popcorn.youtube("#" + containerDiv, _url);
break;
case "vimeo":
// Popcorn.vimeo wants us to specify the size of the player in the style attribute of its container div.
IriSP.jQuery("#" + containerDiv).css({
width : this.config.player.width + "px",
height : this.config.player.height + "px"
});
_pop = Popcorn.vimeo("#" + containerDiv, this.config.player.video);
break;
case "dailymotion":
_pop = new IriSP.PopcornReplacement.dailymotion("#" + containerDiv, this.config.player);
break;
case "mashup":
_pop = new IriSP.PopcornReplacement.mashup("#" + containerDiv, this.config.player);
break;
case "allocine":
_pop = new IriSP.PopcornReplacement.allocine("#" + containerDiv, this.config.player);
break;
case "mashup-html":
_pop = new IriSP.PopcornReplacement.htmlMashup("#" + containerDiv, this.config.player, this.videoData);
break;
default:
_pop = undefined;
};
this.popcorn = _pop;
/* Now Loading Widgets */
this.widgets = [];
var _this = this;
for(var i = 0; i < this.config.widgets.length; i++) {
this.loadWidget(this.config.widgets[i], function(_widget) {
_this.widgets.push(_widget)
});
};
this.$.find('.Ldt-Loader').detach();
}
IriSP.Metadataplayer.prototype.loadWidget = function(_widgetConfig, _callback) {
/* Creating containers if needed */
if (typeof _widgetConfig.container === "undefined") {
var _divs = this.layoutDivs(_widgetConfig.type);
_widgetConfig.container = _divs[0];
}
var _this = this;
if (typeof IriSP.Widgets[_widgetConfig.type] !== "undefined") {
IriSP._.defer(function() {
_callback(new IriSP.Widgets[_widgetConfig.type](_this, _widgetConfig));
});
} else {
/* Loading Widget CSS */
if (typeof IriSP.widgetsRequirements[_widgetConfig.type] === "undefined" || typeof IriSP.widgetsRequirements[_widgetConfig.type].noCss === "undefined" || !IriSP.widgetsRequirements[_widgetConfig.type].noCss) {
IriSP.loadCss(IriSP.widgetsDir + '/' + _widgetConfig.type + '.css');
}
/* Loading Widget JS */
$LAB.script(IriSP.widgetsDir + '/' + _widgetConfig.type + '.js').wait(function() {
_callback(new IriSP.Widgets[_widgetConfig.type](_this, _widgetConfig));
});
}
}
/** create a subdiv with an unique id, and a spacer div as well.
@param widgetName the name of the widget.
@return an array of the form [createdivId, spacerdivId].
*/
IriSP.Metadataplayer.prototype.layoutDivs = function(_name, _height) {
if (typeof(_name) === "undefined") {
_name = "";
}
var newDiv = IriSP._.uniqueId(this.config.container + "_widget_" + _name + "_"),
spacerDiv = IriSP._.uniqueId("LdtPlayer_spacer_"),
divHtml = IriSP.jQuery('<div>')
.attr("id",newDiv)
.css({
width: this.config.width + "px",
position: "relative",
clear: "both"
}),
spacerHtml = IriSP.jQuery('<div>')
.attr("id",spacerDiv)
.css({
width: this.config.width + "px",
height: this.config.spacer_div_height + "px",
position: "relative",
clear: "both"
});
if (typeof _height !== "undefined") {
divHtml.css("height", _height);
}
this.$.append(divHtml);
this.$.append(spacerHtml);
return [newDiv, spacerDiv];
};
IriSP.Metadataplayer.prototype.on