1637 lines
73 KiB
JavaScript
Executable File
1637 lines
73 KiB
JavaScript
Executable File
/*___________________________________________________________________________________________________________________________________________________
|
|
_ jquery.mb.components _
|
|
_ _
|
|
_ file: jquery.mb.YTPlayer.src.js _
|
|
_ last modified: 01/07/15 19.35 _
|
|
_ _
|
|
_ Open Lab s.r.l., Florence - Italy _
|
|
_ _
|
|
_ email: matteo@open-lab.com _
|
|
_ site: http://pupunzi.com _
|
|
_ http://open-lab.com _
|
|
_ blog: http://pupunzi.open-lab.com _
|
|
_ Q&A: http://jquery.pupunzi.com _
|
|
_ _
|
|
_ Licences: MIT, GPL _
|
|
_ http://www.opensource.org/licenses/mit-license.php _
|
|
_ http://www.gnu.org/licenses/gpl.html _
|
|
_ _
|
|
_ Copyright (c) 2001-2015. Matteo Bicocchi (Pupunzi); _
|
|
___________________________________________________________________________________________________________________________________________________*/
|
|
var ytp = ytp || {};
|
|
|
|
function onYouTubeIframeAPIReady() {
|
|
if( ytp.YTAPIReady ) return;
|
|
ytp.YTAPIReady = true;
|
|
jQuery( document ).trigger( "YTAPIReady" );
|
|
}
|
|
|
|
var getYTPVideoID = function( url ) {
|
|
var videoID, playlistID;
|
|
if( url.indexOf( "youtu.be" ) > 0 ) {
|
|
videoID = url.substr( url.lastIndexOf( "/" ) + 1, url.length );
|
|
playlistID = videoID.indexOf( "?list=" ) > 0 ? videoID.substr( videoID.lastIndexOf( "=" ), videoID.length ) : null;
|
|
videoID = playlistID ? videoID.substr( 0, videoID.lastIndexOf( "?" ) ) : videoID;
|
|
} else if( url.indexOf( "http" ) > -1 ) {
|
|
//videoID = url.match( /([\/&]v\/([^&#]*))|([\\?&]v=([^&#]*))/ )[ 1 ];
|
|
videoID = url.match( /[\\?&]v=([^&#]*)/ )[ 1 ];
|
|
playlistID = url.indexOf( "list=" ) > 0 ? url.match( /[\\?&]list=([^&#]*)/ )[ 1 ] : null;
|
|
} else {
|
|
videoID = url.length > 15 ? null : url;
|
|
playlistID = videoID ? null : url;
|
|
}
|
|
return {
|
|
videoID: videoID,
|
|
playlistID: playlistID
|
|
};
|
|
};
|
|
|
|
( function( jQuery, ytp ) {
|
|
|
|
jQuery.mbYTPlayer = {
|
|
name: "jquery.mb.YTPlayer",
|
|
version: "2.9.7",
|
|
build: "5748",
|
|
author: "Matteo Bicocchi",
|
|
apiKey: "",
|
|
defaults: {
|
|
containment: "body",
|
|
ratio: "auto", // "auto", "16/9", "4/3"
|
|
videoURL: null,
|
|
playlistURL: null,
|
|
startAt: 0,
|
|
stopAt: 0,
|
|
autoPlay: true,
|
|
vol: 50, // 1 to 100
|
|
addRaster: false,
|
|
opacity: 1,
|
|
quality: "default", //or “default” “small”, “medium”, “large”, “hd720”, “hd1080”, “highres”
|
|
mute: false,
|
|
loop: true,
|
|
showControls: true,
|
|
showAnnotations: false,
|
|
showYTLogo: true,
|
|
stopMovieOnBlur: true,
|
|
realfullscreen: true,
|
|
gaTrack: true,
|
|
optimizeDisplay: true,
|
|
onReady: function( player ) {}
|
|
},
|
|
/* @fontface icons */
|
|
controls: {
|
|
play: "P",
|
|
pause: "p",
|
|
mute: "M",
|
|
unmute: "A",
|
|
onlyYT: "O",
|
|
showSite: "R",
|
|
ytLogo: "Y"
|
|
},
|
|
locationProtocol: "https:",
|
|
/**
|
|
*
|
|
* @param options
|
|
* @returns [players]
|
|
*/
|
|
buildPlayer: function( options ) {
|
|
return this.each( function() {
|
|
var YTPlayer = this;
|
|
var $YTPlayer = jQuery( YTPlayer );
|
|
YTPlayer.loop = 0;
|
|
YTPlayer.opt = {};
|
|
YTPlayer.state = {};
|
|
YTPlayer.filtersEnabled = true;
|
|
YTPlayer.filters = {
|
|
grayscale: {
|
|
value: 0,
|
|
unit: "%"
|
|
},
|
|
hue_rotate: {
|
|
value: 0,
|
|
unit: "deg"
|
|
},
|
|
invert: {
|
|
value: 0,
|
|
unit: "%"
|
|
},
|
|
opacity: {
|
|
value: 0,
|
|
unit: "%"
|
|
},
|
|
saturate: {
|
|
value: 0,
|
|
unit: "%"
|
|
},
|
|
sepia: {
|
|
value: 0,
|
|
unit: "%"
|
|
},
|
|
brightness: {
|
|
value: 0,
|
|
unit: "%"
|
|
},
|
|
contrast: {
|
|
value: 0,
|
|
unit: "%"
|
|
},
|
|
blur: {
|
|
value: 0,
|
|
unit: "px"
|
|
}
|
|
};
|
|
$YTPlayer.addClass( "mb_YTPlayer" );
|
|
var property = $YTPlayer.data( "property" ) && typeof $YTPlayer.data( "property" ) == "string" ? eval( '(' + $YTPlayer.data( "property" ) + ')' ) : $YTPlayer.data( "property" );
|
|
if( typeof property != "undefined" && typeof property.vol != "undefined" ) property.vol = property.vol === 0 ? property.vol = 1 : property.vol;
|
|
|
|
jQuery.extend( YTPlayer.opt, jQuery.mbYTPlayer.defaults, options, property );
|
|
|
|
if( !YTPlayer.hasChanged ) {
|
|
YTPlayer.defaultOpt = {};
|
|
jQuery.extend( YTPlayer.defaultOpt, jQuery.mbYTPlayer.defaults, options, property );
|
|
}
|
|
|
|
if( YTPlayer.opt.loop == "true" )
|
|
YTPlayer.opt.loop = 9999;
|
|
|
|
YTPlayer.isRetina = ( window.retina || window.devicePixelRatio > 1 );
|
|
var isIframe = function() {
|
|
var isIfr = false;
|
|
try {
|
|
if( self.location.href != top.location.href ) isIfr = true;
|
|
} catch( e ) {
|
|
isIfr = true;
|
|
}
|
|
return isIfr;
|
|
};
|
|
YTPlayer.canGoFullScreen = !( jQuery.browser.msie || jQuery.browser.opera || isIframe() );
|
|
if( !YTPlayer.canGoFullScreen ) YTPlayer.opt.realfullscreen = false;
|
|
if( !$YTPlayer.attr( "id" ) ) $YTPlayer.attr( "id", "video_" + new Date().getTime() );
|
|
var playerID = "mbYTP_" + YTPlayer.id;
|
|
YTPlayer.isAlone = false;
|
|
YTPlayer.hasFocus = true;
|
|
var videoID = this.opt.videoURL ? getYTPVideoID( this.opt.videoURL ).videoID : $YTPlayer.attr( "href" ) ? getYTPVideoID( $YTPlayer.attr( "href" ) ).videoID : false;
|
|
var playlistID = this.opt.videoURL ? getYTPVideoID( this.opt.videoURL ).playlistID : $YTPlayer.attr( "href" ) ? getYTPVideoID( $YTPlayer.attr( "href" ) ).playlistID : false;
|
|
YTPlayer.videoID = videoID;
|
|
YTPlayer.playlistID = playlistID;
|
|
YTPlayer.opt.showAnnotations = ( YTPlayer.opt.showAnnotations ) ? '0' : '3';
|
|
var playerVars = {
|
|
'autoplay': 0,
|
|
'modestbranding': 1,
|
|
'controls': 0,
|
|
'showinfo': 0,
|
|
'rel': 0,
|
|
'enablejsapi': 1,
|
|
'version': 3,
|
|
'playerapiid': playerID,
|
|
'origin': '*',
|
|
'allowfullscreen': true,
|
|
'wmode': 'transparent',
|
|
'iv_load_policy': YTPlayer.opt.showAnnotations
|
|
};
|
|
if( document.createElement( 'video' ).canPlayType ) jQuery.extend( playerVars, {
|
|
'html5': 1
|
|
} );
|
|
if( jQuery.browser.msie && jQuery.browser.version < 9 ) this.opt.opacity = 1;
|
|
var playerBox = jQuery( "<div/>" ).attr( "id", playerID ).addClass( "playerBox" );
|
|
var overlay = jQuery( "<div/>" ).css( {
|
|
position: "absolute",
|
|
top: 0,
|
|
left: 0,
|
|
width: "100%",
|
|
height: "100%"
|
|
} ).addClass( "YTPOverlay" );
|
|
YTPlayer.isSelf = YTPlayer.opt.containment == "self";
|
|
YTPlayer.defaultOpt.containment = YTPlayer.opt.containment = YTPlayer.opt.containment == "self" ? jQuery( this ) : jQuery( YTPlayer.opt.containment );
|
|
YTPlayer.isBackground = YTPlayer.opt.containment.get( 0 ).tagName.toLowerCase() == "body";
|
|
if( YTPlayer.isBackground && ytp.backgroundIsInited ) return;
|
|
var isPlayer = YTPlayer.opt.containment.is( jQuery( this ) );
|
|
YTPlayer.canPlayOnMobile = isPlayer && jQuery( this ).children().length === 0;
|
|
if( !isPlayer ) {
|
|
$YTPlayer.hide();
|
|
} else {
|
|
YTPlayer.isPlayer = true;
|
|
}
|
|
if( jQuery.browser.mobile && !YTPlayer.canPlayOnMobile ) {
|
|
$YTPlayer.remove();
|
|
return;
|
|
}
|
|
var wrapper = jQuery( "<div/>" ).addClass( "mbYTP_wrapper" ).attr( "id", "wrapper_" + playerID );
|
|
wrapper.css( {
|
|
position: "absolute",
|
|
zIndex: 0,
|
|
minWidth: "100%",
|
|
minHeight: "100%",
|
|
left: 0,
|
|
top: 0,
|
|
overflow: "hidden",
|
|
opacity: 0
|
|
} );
|
|
|
|
playerBox.css( {
|
|
position: "absolute",
|
|
zIndex: 0,
|
|
width: "100%",
|
|
height: "100%",
|
|
top: 0,
|
|
left: 0,
|
|
overflow: "hidden"
|
|
} );
|
|
wrapper.append( playerBox );
|
|
YTPlayer.opt.containment.children().not( "script, style" ).each( function() {
|
|
if( jQuery( this ).css( "position" ) == "static" ) jQuery( this ).css( "position", "relative" );
|
|
} );
|
|
if( YTPlayer.isBackground ) {
|
|
jQuery( "body" ).css( {
|
|
boxSizing: "border-box"
|
|
} );
|
|
wrapper.css( {
|
|
position: "fixed",
|
|
top: 0,
|
|
left: 0,
|
|
zIndex: 0
|
|
} );
|
|
$YTPlayer.hide();
|
|
} else if( YTPlayer.opt.containment.css( "position" ) == "static" )
|
|
YTPlayer.opt.containment.css( {
|
|
position: "relative"
|
|
} );
|
|
|
|
YTPlayer.opt.containment.prepend( wrapper );
|
|
YTPlayer.wrapper = wrapper;
|
|
playerBox.css( {
|
|
opacity: 1
|
|
} );
|
|
if( !jQuery.browser.mobile ) {
|
|
playerBox.after( overlay );
|
|
YTPlayer.overlay = overlay;
|
|
}
|
|
|
|
if( !YTPlayer.isBackground ) {
|
|
overlay.on( "mouseenter", function() {
|
|
if( YTPlayer.controlBar ) YTPlayer.controlBar.addClass( "visible" );
|
|
} ).on( "mouseleave", function() {
|
|
if( YTPlayer.controlBar ) YTPlayer.controlBar.removeClass( "visible" );
|
|
} );
|
|
}
|
|
if( !ytp.YTAPIReady ) {
|
|
jQuery( "#YTAPI" ).remove();
|
|
var tag = jQuery( "<script></script>" ).attr( {
|
|
"src": jQuery.mbYTPlayer.locationProtocol + "//www.youtube.com/iframe_api?v=" + jQuery.mbYTPlayer.version,
|
|
"id": "YTAPI"
|
|
} );
|
|
jQuery( "head" ).prepend( tag );
|
|
} else {
|
|
setTimeout( function() {
|
|
jQuery( document ).trigger( "YTAPIReady" );
|
|
}, 100 )
|
|
}
|
|
|
|
jQuery( document ).on( "YTAPIReady", function() {
|
|
if( ( YTPlayer.isBackground && ytp.backgroundIsInited ) || YTPlayer.isInit ) return;
|
|
if( YTPlayer.isBackground ) {
|
|
ytp.backgroundIsInited = true;
|
|
}
|
|
|
|
YTPlayer.opt.autoPlay = typeof YTPlayer.opt.autoPlay == "undefined" ? ( YTPlayer.isBackground ? true : false ) : YTPlayer.opt.autoPlay;
|
|
YTPlayer.opt.vol = YTPlayer.opt.vol ? YTPlayer.opt.vol : 100;
|
|
jQuery.mbYTPlayer.getDataFromAPI( YTPlayer );
|
|
jQuery( YTPlayer ).on( "YTPChanged", function() {
|
|
if( YTPlayer.isInit ) return;
|
|
YTPlayer.isInit = true;
|
|
//if is mobile && isPlayer fallback to the default YT player
|
|
if( jQuery.browser.mobile && YTPlayer.canPlayOnMobile ) {
|
|
// Try to adjust the player dimention
|
|
if( YTPlayer.opt.containment.outerWidth() > jQuery( window ).width() ) {
|
|
YTPlayer.opt.containment.css( {
|
|
maxWidth: "100%"
|
|
} );
|
|
var h = YTPlayer.opt.containment.outerWidth() * .6;
|
|
YTPlayer.opt.containment.css( {
|
|
maxHeight: h
|
|
} );
|
|
}
|
|
new YT.Player( playerID, {
|
|
videoId: YTPlayer.videoID.toString(),
|
|
height: '100%',
|
|
width: '100%',
|
|
events: {
|
|
'onReady': function( event ) {
|
|
YTPlayer.player = event.target;
|
|
playerBox.css( {
|
|
opacity: 1
|
|
} );
|
|
YTPlayer.wrapper.css( {
|
|
opacity: 1
|
|
} );
|
|
}
|
|
}
|
|
} );
|
|
return;
|
|
}
|
|
new YT.Player( playerID, {
|
|
videoId: YTPlayer.videoID.toString(),
|
|
playerVars: playerVars,
|
|
events: {
|
|
'onReady': function( event ) {
|
|
YTPlayer.player = event.target;
|
|
if( YTPlayer.isReady ) return;
|
|
YTPlayer.isReady = YTPlayer.isPlayer && !YTPlayer.opt.autoPlay ? false : true;
|
|
YTPlayer.playerEl = YTPlayer.player.getIframe();
|
|
|
|
$( YTPlayer.playerEl ).unselectable();
|
|
|
|
$YTPlayer.optimizeDisplay();
|
|
YTPlayer.videoID = videoID;
|
|
jQuery( window ).on( "resize.YTP", function() {
|
|
$YTPlayer.optimizeDisplay();
|
|
} );
|
|
|
|
jQuery.mbYTPlayer.checkForState( YTPlayer );
|
|
|
|
// Trigger state events
|
|
/*
|
|
var YTPEvent = jQuery.Event( "YTPUnstarted" );
|
|
YTPEvent.time = YTPlayer.player.time;
|
|
jQuery( YTPlayer ).trigger( YTPEvent );
|
|
*/
|
|
},
|
|
/**
|
|
*
|
|
* @param event
|
|
*
|
|
* -1 (unstarted)
|
|
* 0 (ended)
|
|
* 1 (playing)
|
|
* 2 (paused)
|
|
* 3 (buffering)
|
|
* 5 (video cued).
|
|
*
|
|
*
|
|
*/
|
|
'onStateChange': function( event ) {
|
|
if( typeof event.target.getPlayerState != "function" ) return;
|
|
var state = event.target.getPlayerState();
|
|
|
|
if( YTPlayer.state == state ) return;
|
|
|
|
if( YTPlayer.preventTrigger ) {
|
|
YTPlayer.preventTrigger = false;
|
|
return
|
|
}
|
|
|
|
YTPlayer.state = state;
|
|
var eventType;
|
|
switch( state ) {
|
|
case -1: //----------------------------------------------- unstarted
|
|
eventType = "YTPUnstarted";
|
|
break;
|
|
case 0: //------------------------------------------------ ended
|
|
eventType = "YTPEnd";
|
|
break;
|
|
case 1: //------------------------------------------------ play
|
|
eventType = "YTPPlay";
|
|
if( YTPlayer.controlBar ) YTPlayer.controlBar.find( ".mb_YTPPlaypause" ).html( jQuery.mbYTPlayer.controls.pause );
|
|
|
|
if( typeof _gaq != "undefined" && eval( YTPlayer.opt.gaTrack ) ) _gaq.push( [ '_trackEvent', 'YTPlayer', 'Play', ( YTPlayer.hasData ? YTPlayer.videoData.title : YTPlayer.videoID.toString() ) ] );
|
|
if( typeof ga != "undefined" && eval( YTPlayer.opt.gaTrack ) ) ga( 'send', 'event', 'YTPlayer', 'play', ( YTPlayer.hasData ? YTPlayer.videoData.title : YTPlayer.videoID.toString() ) );
|
|
|
|
break;
|
|
case 2: //------------------------------------------------ pause
|
|
eventType = "YTPPause";
|
|
if( YTPlayer.controlBar ) YTPlayer.controlBar.find( ".mb_YTPPlaypause" ).html( jQuery.mbYTPlayer.controls.play );
|
|
break;
|
|
case 3: //------------------------------------------------ buffer
|
|
YTPlayer.player.setPlaybackQuality( YTPlayer.opt.quality );
|
|
eventType = "YTPBuffering";
|
|
if( YTPlayer.controlBar ) YTPlayer.controlBar.find( ".mb_YTPPlaypause" ).html( jQuery.mbYTPlayer.controls.play );
|
|
break;
|
|
case 5: //------------------------------------------------ cued
|
|
eventType = "YTPCued";
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
// Trigger state events
|
|
var YTPEvent = jQuery.Event( eventType );
|
|
YTPEvent.time = YTPlayer.player.time;
|
|
if( YTPlayer.canTrigger ) jQuery( YTPlayer ).trigger( YTPEvent );
|
|
},
|
|
/**
|
|
*
|
|
* @param e
|
|
*/
|
|
'onPlaybackQualityChange': function( e ) {
|
|
var quality = e.target.getPlaybackQuality();
|
|
var YTPQualityChange = jQuery.Event( "YTPQualityChange" );
|
|
YTPQualityChange.quality = quality;
|
|
jQuery( YTPlayer ).trigger( YTPQualityChange );
|
|
},
|
|
/**
|
|
*
|
|
* @param err
|
|
*/
|
|
'onError': function( err ) {
|
|
if( err.data == 150 ) {
|
|
console.log( "Embedding this video is restricted by Youtube." );
|
|
if( YTPlayer.isPlayList ) jQuery( YTPlayer ).playNext();
|
|
}
|
|
if( err.data == 2 && YTPlayer.isPlayList ) jQuery( YTPlayer ).playNext();
|
|
if( typeof YTPlayer.opt.onError == "function" ) YTPlayer.opt.onError( $YTPlayer, err );
|
|
}
|
|
}
|
|
} );
|
|
} );
|
|
} )
|
|
} );
|
|
},
|
|
/**
|
|
*
|
|
* @param YTPlayer
|
|
*/
|
|
getDataFromAPI: function( YTPlayer ) {
|
|
YTPlayer.videoData = jQuery.mbStorage.get( "YTPlayer_data_" + YTPlayer.videoID );
|
|
jQuery( YTPlayer ).off( "YTPData.YTPlayer" ).on( "YTPData.YTPlayer", function() {
|
|
if( YTPlayer.hasData ) {
|
|
|
|
if( YTPlayer.isPlayer && !YTPlayer.opt.autoPlay ) {
|
|
var bgndURL = YTPlayer.videoData.thumb_max || YTPlayer.videoData.thumb_high || YTPlayer.videoData.thumb_medium;
|
|
YTPlayer.opt.containment.css( {
|
|
background: "rgba(0,0,0,0.5) url(" + bgndURL + ") center center",
|
|
backgroundSize: "cover"
|
|
} );
|
|
YTPlayer.opt.backgroundUrl = bgndURL;
|
|
}
|
|
}
|
|
} );
|
|
|
|
if( YTPlayer.videoData ) {
|
|
|
|
setTimeout( function() {
|
|
YTPlayer.opt.ratio = YTPlayer.opt.ratio == "auto" ? "16/9" : YTPlayer.opt.ratio;
|
|
YTPlayer.dataReceived = true;
|
|
jQuery( YTPlayer ).trigger( "YTPChanged" );
|
|
var YTPData = jQuery.Event( "YTPData" );
|
|
YTPData.prop = {};
|
|
for( var x in YTPlayer.videoData ) YTPData.prop[ x ] = YTPlayer.videoData[ x ];
|
|
jQuery( YTPlayer ).trigger( YTPData );
|
|
}, 500 );
|
|
|
|
YTPlayer.hasData = true;
|
|
} else if( jQuery.mbYTPlayer.apiKey ) {
|
|
// Get video info from API3 (needs api key)
|
|
// snippet,player,contentDetails,statistics,status
|
|
jQuery.getJSON( jQuery.mbYTPlayer.locationProtocol + "//www.googleapis.com/youtube/v3/videos?id=" + YTPlayer.videoID + "&key=" + jQuery.mbYTPlayer.apiKey + "&part=snippet", function( data ) {
|
|
YTPlayer.dataReceived = true;
|
|
jQuery( YTPlayer ).trigger( "YTPChanged" );
|
|
|
|
function parseYTPlayer_data( data ) {
|
|
YTPlayer.videoData = {};
|
|
YTPlayer.videoData.id = YTPlayer.videoID;
|
|
YTPlayer.videoData.channelTitle = data.channelTitle;
|
|
YTPlayer.videoData.title = data.title;
|
|
YTPlayer.videoData.description = data.description.length < 400 ? data.description : data.description.substring( 0, 400 ) + " ...";
|
|
YTPlayer.videoData.aspectratio = YTPlayer.opt.ratio == "auto" ? "16/9" : YTPlayer.opt.ratio;
|
|
YTPlayer.opt.ratio = YTPlayer.videoData.aspectratio;
|
|
YTPlayer.videoData.thumb_max = data.thumbnails.maxres ? data.thumbnails.maxres.url : null;
|
|
YTPlayer.videoData.thumb_high = data.thumbnails.high ? data.thumbnails.high.url : null;
|
|
YTPlayer.videoData.thumb_medium = data.thumbnails.medium ? data.thumbnails.medium.url : null;
|
|
jQuery.mbStorage.set( "YTPlayer_data_" + YTPlayer.videoID, YTPlayer.videoData );
|
|
}
|
|
parseYTPlayer_data( data.items[ 0 ].snippet );
|
|
YTPlayer.hasData = true;
|
|
var YTPData = jQuery.Event( "YTPData" );
|
|
YTPData.prop = {};
|
|
for( var x in YTPlayer.videoData ) YTPData.prop[ x ] = YTPlayer.videoData[ x ];
|
|
jQuery( YTPlayer ).trigger( YTPData );
|
|
} );
|
|
} else {
|
|
setTimeout( function() {
|
|
jQuery( YTPlayer ).trigger( "YTPChanged" );
|
|
}, 50 );
|
|
if( YTPlayer.isPlayer && !YTPlayer.opt.autoPlay ) {
|
|
var bgndURL = jQuery.mbYTPlayer.locationProtocol + "//i.ytimg.com/vi/" + YTPlayer.videoID + "/hqdefault.jpg";
|
|
YTPlayer.opt.containment.css( {
|
|
background: "rgba(0,0,0,0.5) url(" + bgndURL + ") center center",
|
|
backgroundSize: "cover"
|
|
} );
|
|
YTPlayer.opt.backgroundUrl = bgndURL;
|
|
}
|
|
YTPlayer.videoData = null;
|
|
YTPlayer.opt.ratio = YTPlayer.opt.ratio == "auto" ? "16/9" : YTPlayer.opt.ratio;
|
|
}
|
|
if( YTPlayer.isPlayer && !YTPlayer.opt.autoPlay ) {
|
|
YTPlayer.loading = jQuery( "<div/>" ).addClass( "loading" ).html( "Loading" ).hide();
|
|
jQuery( YTPlayer ).append( YTPlayer.loading );
|
|
YTPlayer.loading.fadeIn();
|
|
}
|
|
},
|
|
/**
|
|
*
|
|
*/
|
|
removeStoredData: function() {
|
|
jQuery.mbStorage.remove();
|
|
},
|
|
/**
|
|
*
|
|
* @returns {*|YTPlayer.videoData}
|
|
*/
|
|
getVideoData: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
return YTPlayer.videoData;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {*|YTPlayer.videoID|boolean}
|
|
*/
|
|
getVideoID: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
return YTPlayer.videoID || false;
|
|
},
|
|
/**
|
|
*
|
|
* @param quality
|
|
*/
|
|
setVideoQuality: function( quality ) {
|
|
var YTPlayer = this.get( 0 );
|
|
if( !jQuery.browser.chrome ) YTPlayer.player.setPlaybackQuality( quality );
|
|
},
|
|
/**
|
|
* @param videos
|
|
* @param shuffle
|
|
* @param callback
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
|
|
playlist: function( videos, shuffle, callback ) {
|
|
var $YTPlayer = this;
|
|
var YTPlayer = $YTPlayer.get( 0 );
|
|
YTPlayer.isPlayList = true;
|
|
if( shuffle ) videos = jQuery.shuffle( videos );
|
|
if( !YTPlayer.videoID ) {
|
|
YTPlayer.videos = videos;
|
|
YTPlayer.videoCounter = 0;
|
|
YTPlayer.videoLength = videos.length;
|
|
jQuery( YTPlayer ).data( "property", videos[ 0 ] );
|
|
jQuery( YTPlayer ).mb_YTPlayer();
|
|
}
|
|
if( typeof callback == "function" ) jQuery( YTPlayer ).one( "YTPChanged", function() {
|
|
callback( YTPlayer );
|
|
} );
|
|
jQuery( YTPlayer ).on( "YTPEnd", function() {
|
|
jQuery( YTPlayer ).playNext();
|
|
} );
|
|
return $YTPlayer;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
playNext: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
YTPlayer.videoCounter++;
|
|
if( YTPlayer.videoCounter >= YTPlayer.videoLength ) YTPlayer.videoCounter = 0;
|
|
jQuery( YTPlayer ).changeMovie( YTPlayer.videos[ YTPlayer.videoCounter ] );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
playPrev: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
YTPlayer.videoCounter--;
|
|
if( YTPlayer.videoCounter < 0 ) YTPlayer.videoCounter = YTPlayer.videoLength - 1;
|
|
jQuery( YTPlayer ).changeMovie( YTPlayer.videos[ YTPlayer.videoCounter ] );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param opt
|
|
*/
|
|
changeMovie: function( opt ) {
|
|
|
|
var YTPlayer = this.get( 0 );
|
|
YTPlayer.opt.startAt = 0;
|
|
YTPlayer.opt.stopAt = 0;
|
|
YTPlayer.opt.mute = true;
|
|
YTPlayer.hasData = false;
|
|
YTPlayer.hasChanged = true;
|
|
YTPlayer.player.LoopTime = undefined;
|
|
|
|
if( opt ) jQuery.extend( YTPlayer.opt, YTPlayer.defaultOpt, opt );
|
|
YTPlayer.videoID = getYTPVideoID( YTPlayer.opt.videoURL ).videoID;
|
|
|
|
if( YTPlayer.opt.loop == "true" )
|
|
YTPlayer.opt.loop = 9999;
|
|
|
|
jQuery( YTPlayer.playerEl ).CSSAnimate( {
|
|
opacity: 0
|
|
}, 200, function() {
|
|
|
|
var YTPChangeMovie = jQuery.Event( "YTPChangeMovie" );
|
|
YTPChangeMovie.time = YTPlayer.player.time;
|
|
YTPChangeMovie.videoId = YTPlayer.videoID;
|
|
jQuery( YTPlayer ).trigger( YTPChangeMovie );
|
|
|
|
jQuery( YTPlayer ).YTPGetPlayer().cueVideoByUrl( encodeURI( jQuery.mbYTPlayer.locationProtocol + "//www.youtube.com/v/" + YTPlayer.videoID ), 1, YTPlayer.opt.quality );
|
|
jQuery.mbYTPlayer.checkForState( YTPlayer );
|
|
jQuery( YTPlayer ).optimizeDisplay();
|
|
jQuery.mbYTPlayer.getDataFromAPI( YTPlayer );
|
|
return this;
|
|
} );
|
|
},
|
|
/**
|
|
*
|
|
* @returns {player}
|
|
*/
|
|
getPlayer: function() {
|
|
return jQuery( this ).get( 0 ).player;
|
|
},
|
|
playerDestroy: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
ytp.YTAPIReady = false;
|
|
ytp.backgroundIsInited = false;
|
|
YTPlayer.isInit = false;
|
|
YTPlayer.videoID = null;
|
|
var playerBox = YTPlayer.wrapper;
|
|
playerBox.remove();
|
|
jQuery( "#controlBar_" + YTPlayer.id ).remove();
|
|
clearInterval( YTPlayer.checkForStartAt );
|
|
clearInterval( YTPlayer.getState );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param real
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
fullscreen: function( real ) {
|
|
var YTPlayer = this.get( 0 );
|
|
if( typeof real == "undefined" ) real = YTPlayer.opt.realfullscreen;
|
|
real = eval( real );
|
|
var controls = jQuery( "#controlBar_" + YTPlayer.id );
|
|
var fullScreenBtn = controls.find( ".mb_OnlyYT" );
|
|
var videoWrapper = YTPlayer.isSelf ? YTPlayer.opt.containment : YTPlayer.wrapper;
|
|
//var videoWrapper = YTPlayer.wrapper;
|
|
if( real ) {
|
|
var fullscreenchange = jQuery.browser.mozilla ? "mozfullscreenchange" : jQuery.browser.webkit ? "webkitfullscreenchange" : "fullscreenchange";
|
|
jQuery( document ).off( fullscreenchange ).on( fullscreenchange, function() {
|
|
var isFullScreen = RunPrefixMethod( document, "IsFullScreen" ) || RunPrefixMethod( document, "FullScreen" );
|
|
if( !isFullScreen ) {
|
|
YTPlayer.isAlone = false;
|
|
fullScreenBtn.html( jQuery.mbYTPlayer.controls.onlyYT );
|
|
jQuery( YTPlayer ).YTPSetVideoQuality( YTPlayer.opt.quality );
|
|
videoWrapper.removeClass( "fullscreen" );
|
|
videoWrapper.CSSAnimate( {
|
|
opacity: YTPlayer.opt.opacity
|
|
}, 500 );
|
|
videoWrapper.css( {
|
|
zIndex: 0
|
|
} );
|
|
if( YTPlayer.isBackground ) {
|
|
jQuery( "body" ).after( controls );
|
|
} else {
|
|
YTPlayer.wrapper.before( controls );
|
|
}
|
|
jQuery( window ).resize();
|
|
jQuery( YTPlayer ).trigger( "YTPFullScreenEnd" );
|
|
} else {
|
|
jQuery( YTPlayer ).YTPSetVideoQuality( "default" );
|
|
jQuery( YTPlayer ).trigger( "YTPFullScreenStart" );
|
|
}
|
|
} );
|
|
}
|
|
if( !YTPlayer.isAlone ) {
|
|
function hideMouse() {
|
|
YTPlayer.overlay.css( {
|
|
cursor: "none"
|
|
} );
|
|
}
|
|
jQuery( document ).on( "mousemove.YTPlayer", function( e ) {
|
|
YTPlayer.overlay.css( {
|
|
cursor: "auto"
|
|
} );
|
|
clearTimeout( YTPlayer.hideCursor );
|
|
if( !jQuery( e.target ).parents().is( ".mb_YTPBar" ) ) YTPlayer.hideCursor = setTimeout( hideMouse, 3000 );
|
|
} );
|
|
hideMouse();
|
|
if( real ) {
|
|
videoWrapper.css( {
|
|
opacity: 0
|
|
} );
|
|
videoWrapper.addClass( "fullscreen" );
|
|
launchFullscreen( videoWrapper.get( 0 ) );
|
|
setTimeout( function() {
|
|
videoWrapper.CSSAnimate( {
|
|
opacity: 1
|
|
}, 1000 );
|
|
YTPlayer.wrapper.append( controls );
|
|
jQuery( YTPlayer ).optimizeDisplay();
|
|
YTPlayer.player.seekTo( YTPlayer.player.getCurrentTime() + .1, true );
|
|
}, 500 )
|
|
} else videoWrapper.css( {
|
|
zIndex: 10000
|
|
} ).CSSAnimate( {
|
|
opacity: 1
|
|
}, 1000 );
|
|
fullScreenBtn.html( jQuery.mbYTPlayer.controls.showSite );
|
|
YTPlayer.isAlone = true;
|
|
} else {
|
|
jQuery( document ).off( "mousemove.YTPlayer" );
|
|
YTPlayer.overlay.css( {
|
|
cursor: "auto"
|
|
} );
|
|
if( real ) {
|
|
cancelFullscreen();
|
|
} else {
|
|
videoWrapper.CSSAnimate( {
|
|
opacity: YTPlayer.opt.opacity
|
|
}, 500 );
|
|
videoWrapper.css( {
|
|
zIndex: 0
|
|
} );
|
|
}
|
|
fullScreenBtn.html( jQuery.mbYTPlayer.controls.onlyYT );
|
|
YTPlayer.isAlone = false;
|
|
}
|
|
|
|
function RunPrefixMethod( obj, method ) {
|
|
var pfx = [ "webkit", "moz", "ms", "o", "" ];
|
|
var p = 0,
|
|
m, t;
|
|
while( p < pfx.length && !obj[ m ] ) {
|
|
m = method;
|
|
if( pfx[ p ] == "" ) {
|
|
m = m.substr( 0, 1 ).toLowerCase() + m.substr( 1 );
|
|
}
|
|
m = pfx[ p ] + m;
|
|
t = typeof obj[ m ];
|
|
if( t != "undefined" ) {
|
|
pfx = [ pfx[ p ] ];
|
|
return( t == "function" ? obj[ m ]() : obj[ m ] );
|
|
}
|
|
p++;
|
|
}
|
|
}
|
|
|
|
function launchFullscreen( element ) {
|
|
RunPrefixMethod( element, "RequestFullScreen" );
|
|
}
|
|
|
|
function cancelFullscreen() {
|
|
if( RunPrefixMethod( document, "FullScreen" ) || RunPrefixMethod( document, "IsFullScreen" ) ) {
|
|
RunPrefixMethod( document, "CancelFullScreen" );
|
|
}
|
|
}
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
toggleLoops: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
var data = YTPlayer.opt;
|
|
if( data.loop == 1 ) {
|
|
data.loop = 0;
|
|
} else {
|
|
if( data.startAt ) {
|
|
YTPlayer.player.seekTo( data.startAt );
|
|
} else {
|
|
YTPlayer.player.playVideo();
|
|
}
|
|
data.loop = 1;
|
|
}
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
play: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
if( !YTPlayer.isReady ) return;
|
|
|
|
/*
|
|
var controls = jQuery( "#controlBar_" + YTPlayer.id );
|
|
var playBtn = controls.find( ".mb_YTPPlaypause" );
|
|
playBtn.html( jQuery.mbYTPlayer.controls.pause );
|
|
*/
|
|
|
|
YTPlayer.player.playVideo();
|
|
YTPlayer.wrapper.CSSAnimate( {
|
|
opacity: YTPlayer.isAlone ? 1 : YTPlayer.opt.opacity
|
|
}, 2000 );
|
|
|
|
jQuery( YTPlayer.playerEl ).CSSAnimate( {
|
|
opacity: 1
|
|
}, 1000 );
|
|
|
|
jQuery( YTPlayer ).css( "background-image", "none" );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param callback
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
togglePlay: function( callback ) {
|
|
var YTPlayer = this.get( 0 );
|
|
if( YTPlayer.state == 1 ) this.YTPPause();
|
|
else this.YTPPlay();
|
|
if( typeof callback == "function" ) {
|
|
callback( YTPlayer.state );
|
|
}
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
stop: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
var controls = jQuery( "#controlBar_" + YTPlayer.id );
|
|
var playBtn = controls.find( ".mb_YTPPlaypause" );
|
|
playBtn.html( jQuery.mbYTPlayer.controls.play );
|
|
YTPlayer.player.stopVideo();
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
pause: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
/*
|
|
var controls = jQuery( "#controlBar_" + YTPlayer.id );
|
|
var playBtn = controls.find( ".mb_YTPPlaypause" );
|
|
playBtn.html( jQuery.mbYTPlayer.controls.play );
|
|
*/
|
|
YTPlayer.player.pauseVideo();
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param val
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
seekTo: function( val ) {
|
|
var YTPlayer = this.get( 0 );
|
|
YTPlayer.player.seekTo( val, true );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param val
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
setVolume: function( val ) {
|
|
var YTPlayer = this.get( 0 );
|
|
if( !val && !YTPlayer.opt.vol && YTPlayer.player.getVolume() == 0 ) jQuery( YTPlayer ).YTPUnmute();
|
|
else if( ( !val && YTPlayer.player.getVolume() > 0 ) || ( val && YTPlayer.opt.vol == val ) ) {
|
|
if( !YTPlayer.isMute ) jQuery( YTPlayer ).YTPMute();
|
|
else jQuery( YTPlayer ).YTPUnmute();
|
|
} else {
|
|
YTPlayer.opt.vol = val;
|
|
YTPlayer.player.setVolume( YTPlayer.opt.vol );
|
|
if( YTPlayer.volumeBar && YTPlayer.volumeBar.length ) YTPlayer.volumeBar.updateSliderVal( val )
|
|
}
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
mute: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
if( YTPlayer.isMute ) return;
|
|
YTPlayer.player.mute();
|
|
YTPlayer.isMute = true;
|
|
YTPlayer.player.setVolume( 0 );
|
|
if( YTPlayer.volumeBar && YTPlayer.volumeBar.length && YTPlayer.volumeBar.width() > 10 ) {
|
|
YTPlayer.volumeBar.updateSliderVal( 0 );
|
|
}
|
|
var controls = jQuery( "#controlBar_" + YTPlayer.id );
|
|
var muteBtn = controls.find( ".mb_YTPMuteUnmute" );
|
|
muteBtn.html( jQuery.mbYTPlayer.controls.unmute );
|
|
jQuery( YTPlayer ).addClass( "isMuted" );
|
|
if( YTPlayer.volumeBar && YTPlayer.volumeBar.length ) YTPlayer.volumeBar.addClass( "muted" );
|
|
var YTPEvent = jQuery.Event( "YTPMuted" );
|
|
YTPEvent.time = YTPlayer.player.time;
|
|
if( YTPlayer.canTrigger ) jQuery( YTPlayer ).trigger( YTPEvent );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
unmute: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
if( !YTPlayer.isMute ) return;
|
|
YTPlayer.player.unMute();
|
|
YTPlayer.isMute = false;
|
|
YTPlayer.player.setVolume( YTPlayer.opt.vol );
|
|
if( YTPlayer.volumeBar && YTPlayer.volumeBar.length ) YTPlayer.volumeBar.updateSliderVal( YTPlayer.opt.vol > 10 ? YTPlayer.opt.vol : 10 );
|
|
var controls = jQuery( "#controlBar_" + YTPlayer.id );
|
|
var muteBtn = controls.find( ".mb_YTPMuteUnmute" );
|
|
muteBtn.html( jQuery.mbYTPlayer.controls.mute );
|
|
jQuery( YTPlayer ).removeClass( "isMuted" );
|
|
if( YTPlayer.volumeBar && YTPlayer.volumeBar.length ) YTPlayer.volumeBar.removeClass( "muted" );
|
|
var YTPEvent = jQuery.Event( "YTPUnmuted" );
|
|
YTPEvent.time = YTPlayer.player.time;
|
|
if( YTPlayer.canTrigger ) jQuery( YTPlayer ).trigger( YTPEvent );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param filter
|
|
* @param value
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
applyFilter: function( filter, value ) {
|
|
var YTPlayer = this.get( 0 );
|
|
YTPlayer.filters[ filter ].value = value;
|
|
if( YTPlayer.filtersEnabled ) this.YTPEnableFilters();
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param filters
|
|
* @returns {jQuery.mbYTPlayer}
|
|
*/
|
|
applyFilters: function( filters ) {
|
|
var YTPlayer = this.get( 0 );
|
|
this.on( "YTPReady", function() {
|
|
for( var key in filters ) {
|
|
YTPlayer.filters[ key ].value = filters[ key ];
|
|
jQuery( YTPlayer ).YTPApplyFilter( key, filters[ key ] );
|
|
}
|
|
jQuery( YTPlayer ).trigger( "YTPFiltersApplied" );
|
|
} );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param filter
|
|
* @param value
|
|
* @returns {*}
|
|
*/
|
|
toggleFilter: function( filter, value ) {
|
|
return this.each( function() {
|
|
var YTPlayer = this;
|
|
if( !YTPlayer.filters[ filter ].value ) YTPlayer.filters[ filter ].value = value;
|
|
else YTPlayer.filters[ filter ].value = 0;
|
|
if( YTPlayer.filtersEnabled ) jQuery( this ).YTPEnableFilters();
|
|
} )
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param callback
|
|
* @returns {*}
|
|
*/
|
|
toggleFilters: function( callback ) {
|
|
return this.each( function() {
|
|
var YTPlayer = this;
|
|
if( YTPlayer.filtersEnabled ) {
|
|
jQuery( YTPlayer ).trigger( "YTPDisableFilters" );
|
|
jQuery( YTPlayer ).YTPDisableFilters();
|
|
} else {
|
|
jQuery( YTPlayer ).YTPEnableFilters();
|
|
jQuery( YTPlayer ).trigger( "YTPEnableFilters" );
|
|
}
|
|
if( typeof callback == "function" ) callback( YTPlayer.filtersEnabled );
|
|
} )
|
|
},
|
|
/**
|
|
*
|
|
* @returns {*}
|
|
*/
|
|
disableFilters: function() {
|
|
return this.each( function() {
|
|
var YTPlayer = this;
|
|
var iframe = jQuery( YTPlayer.playerEl );
|
|
iframe.css( "-webkit-filter", "" );
|
|
iframe.css( "filter", "" );
|
|
YTPlayer.filtersEnabled = false;
|
|
} )
|
|
},
|
|
/**
|
|
*
|
|
* @returns {*}
|
|
*/
|
|
enableFilters: function() {
|
|
return this.each( function() {
|
|
var YTPlayer = this;
|
|
var iframe = jQuery( YTPlayer.playerEl );
|
|
var filterStyle = "";
|
|
for( var key in YTPlayer.filters ) {
|
|
if( YTPlayer.filters[ key ].value ) filterStyle += key.replace( "_", "-" ) + "(" + YTPlayer.filters[ key ].value + YTPlayer.filters[ key ].unit + ") ";
|
|
}
|
|
iframe.css( "-webkit-filter", filterStyle );
|
|
iframe.css( "filter", filterStyle );
|
|
YTPlayer.filtersEnabled = true;
|
|
} )
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @param filter
|
|
* @param callback
|
|
* @returns {*}
|
|
*/
|
|
removeFilter: function( filter, callback ) {
|
|
return this.each( function() {
|
|
if( typeof filter == "function" ) {
|
|
callback = filter;
|
|
filter = null;
|
|
}
|
|
var YTPlayer = this;
|
|
if( !filter )
|
|
for( var key in YTPlayer.filters ) {
|
|
jQuery( this ).YTPApplyFilter( key, 0 );
|
|
if( typeof callback == "function" ) callback( key );
|
|
} else {
|
|
jQuery( this ).YTPApplyFilter( filter, 0 );
|
|
if( typeof callback == "function" ) callback( filter );
|
|
}
|
|
} );
|
|
return this;
|
|
},
|
|
/**
|
|
*
|
|
* @returns {{totalTime: number, currentTime: number}}
|
|
*/
|
|
manageProgress: function() {
|
|
var YTPlayer = this.get( 0 );
|
|
var controls = jQuery( "#controlBar_" + YTPlayer.id );
|
|
var progressBar = controls.find( ".mb_YTPProgress" );
|
|
var loadedBar = controls.find( ".mb_YTPLoaded" );
|
|
var timeBar = controls.find( ".mb_YTPseekbar" );
|
|
var totW = progressBar.outerWidth();
|
|
var currentTime = Math.floor( YTPlayer.player.getCurrentTime() );
|
|
var totalTime = Math.floor( YTPlayer.player.getDuration() );
|
|
var timeW = ( currentTime * totW ) / totalTime;
|
|
var startLeft = 0;
|
|
var loadedW = YTPlayer.player.getVideoLoadedFraction() * 100;
|
|
loadedBar.css( {
|
|
left: startLeft,
|
|
width: loadedW + "%"
|
|
} );
|
|
timeBar.css( {
|
|
left: 0,
|
|
width: timeW
|
|
} );
|
|
return {
|
|
totalTime: totalTime,
|
|
currentTime: currentTime
|
|
};
|
|
},
|
|
/**
|
|
*
|
|
* @param YTPlayer
|
|
*/
|
|
buildControls: function( YTPlayer ) {
|
|
var data = YTPlayer.opt;
|
|
// @data.printUrl: is deprecated; use data.showYTLogo
|
|
data.showYTLogo = data.showYTLogo || data.printUrl;
|
|
if( jQuery( "#controlBar_" + YTPlayer.id ).length ) return;
|
|
YTPlayer.controlBar = jQuery( "<span/>" ).attr( "id", "controlBar_" + YTPlayer.id ).addClass( "mb_YTPBar" ).css( {
|
|
whiteSpace: "noWrap",
|
|
position: YTPlayer.isBackground ? "fixed" : "absolute",
|
|
zIndex: YTPlayer.isBackground ? 10000 : 1000
|
|
} ).hide();
|
|
var buttonBar = jQuery( "<div/>" ).addClass( "buttonBar" );
|
|
/* play/pause button*/
|
|
var playpause = jQuery( "<span>" + jQuery.mbYTPlayer.controls.play + "</span>" ).addClass( "mb_YTPPlaypause ytpicon" ).click( function() {
|
|
if( YTPlayer.player.getPlayerState() == 1 ) jQuery( YTPlayer ).YTPPause();
|
|
else jQuery( YTPlayer ).YTPPlay();
|
|
} );
|
|
/* mute/unmute button*/
|
|
var MuteUnmute = jQuery( "<span>" + jQuery.mbYTPlayer.controls.mute + "</span>" ).addClass( "mb_YTPMuteUnmute ytpicon" ).click( function() {
|
|
if( YTPlayer.player.getVolume() == 0 ) {
|
|
jQuery( YTPlayer ).YTPUnmute();
|
|
} else {
|
|
jQuery( YTPlayer ).YTPMute();
|
|
}
|
|
} );
|
|
/* volume bar*/
|
|
var volumeBar = jQuery( "<div/>" ).addClass( "mb_YTPVolumeBar" ).css( {
|
|
display: "inline-block"
|
|
} );
|
|
YTPlayer.volumeBar = volumeBar;
|
|
/* time elapsed */
|
|
var idx = jQuery( "<span/>" ).addClass( "mb_YTPTime" );
|
|
var vURL = data.videoURL ? data.videoURL : "";
|
|
if( vURL.indexOf( "http" ) < 0 ) vURL = jQuery.mbYTPlayer.locationProtocol + "//www.youtube.com/watch?v=" + data.videoURL;
|
|
var movieUrl = jQuery( "<span/>" ).html( jQuery.mbYTPlayer.controls.ytLogo ).addClass( "mb_YTPUrl ytpicon" ).attr( "title", "view on YouTube" ).on( "click", function() {
|
|
window.open( vURL, "viewOnYT" )
|
|
} );
|
|
var onlyVideo = jQuery( "<span/>" ).html( jQuery.mbYTPlayer.controls.onlyYT ).addClass( "mb_OnlyYT ytpicon" ).on( "click", function() {
|
|
jQuery( YTPlayer ).YTPFullscreen( data.realfullscreen );
|
|
} );
|
|
var progressBar = jQuery( "<div/>" ).addClass( "mb_YTPProgress" ).css( "position", "absolute" ).click( function( e ) {
|
|
timeBar.css( {
|
|
width: ( e.clientX - timeBar.offset().left )
|
|
} );
|
|
YTPlayer.timeW = e.clientX - timeBar.offset().left;
|
|
YTPlayer.controlBar.find( ".mb_YTPLoaded" ).css( {
|
|
width: 0
|
|
} );
|
|
var totalTime = Math.floor( YTPlayer.player.getDuration() );
|
|
YTPlayer.goto = ( timeBar.outerWidth() * totalTime ) / progressBar.outerWidth();
|
|
YTPlayer.player.seekTo( parseFloat( YTPlayer.goto ), true );
|
|
YTPlayer.controlBar.find( ".mb_YTPLoaded" ).css( {
|
|
width: 0
|
|
} );
|
|
} );
|
|
var loadedBar = jQuery( "<div/>" ).addClass( "mb_YTPLoaded" ).css( "position", "absolute" );
|
|
var timeBar = jQuery( "<div/>" ).addClass( "mb_YTPseekbar" ).css( "position", "absolute" );
|
|
progressBar.append( loadedBar ).append( timeBar );
|
|
buttonBar.append( playpause ).append( MuteUnmute ).append( volumeBar ).append( idx );
|
|
if( data.showYTLogo ) {
|
|
buttonBar.append( movieUrl );
|
|
}
|
|
if( YTPlayer.isBackground || ( eval( YTPlayer.opt.realfullscreen ) && !YTPlayer.isBackground ) ) buttonBar.append( onlyVideo );
|
|
YTPlayer.controlBar.append( buttonBar ).append( progressBar );
|
|
if( !YTPlayer.isBackground ) {
|
|
YTPlayer.controlBar.addClass( "inlinePlayer" );
|
|
YTPlayer.wrapper.before( YTPlayer.controlBar );
|
|
} else {
|
|
jQuery( "body" ).after( YTPlayer.controlBar );
|
|
}
|
|
volumeBar.simpleSlider( {
|
|
initialval: YTPlayer.opt.vol,
|
|
scale: 100,
|
|
orientation: "h",
|
|
callback: function( el ) {
|
|
if( el.value == 0 ) {
|
|
jQuery( YTPlayer ).YTPMute();
|
|
} else {
|
|
jQuery( YTPlayer ).YTPUnmute();
|
|
}
|
|
YTPlayer.player.setVolume( el.value );
|
|
if( !YTPlayer.isMute ) YTPlayer.opt.vol = el.value;
|
|
}
|
|
} );
|
|
},
|
|
/**
|
|
*
|
|
*
|
|
* */
|
|
checkForState: function( YTPlayer ) {
|
|
var interval = YTPlayer.opt.showControls ? 100 : 400;
|
|
clearInterval( YTPlayer.getState );
|
|
//Checking if player has been removed from scene
|
|
if( !jQuery.contains( document, YTPlayer ) ) {
|
|
jQuery( YTPlayer ).YTPPlayerDestroy();
|
|
clearInterval( YTPlayer.getState );
|
|
clearInterval( YTPlayer.checkForStartAt );
|
|
return;
|
|
}
|
|
jQuery.mbYTPlayer.checkForStart( YTPlayer );
|
|
YTPlayer.getState = setInterval( function() {
|
|
var prog = jQuery( YTPlayer ).YTPManageProgress();
|
|
var $YTPlayer = jQuery( YTPlayer );
|
|
var data = YTPlayer.opt;
|
|
var startAt = YTPlayer.opt.startAt ? YTPlayer.opt.startAt : 1;
|
|
var stopAt = YTPlayer.opt.stopAt > YTPlayer.opt.startAt ? YTPlayer.opt.stopAt : 0;
|
|
stopAt = stopAt < YTPlayer.player.getDuration() ? stopAt : 0;
|
|
if( YTPlayer.player.time != prog.currentTime ) {
|
|
var YTPEvent = jQuery.Event( "YTPTime" );
|
|
YTPEvent.time = YTPlayer.player.time;
|
|
jQuery( YTPlayer ).trigger( YTPEvent );
|
|
}
|
|
YTPlayer.player.time = prog.currentTime;
|
|
if( YTPlayer.player.getVolume() == 0 ) $YTPlayer.addClass( "isMuted" );
|
|
else $YTPlayer.removeClass( "isMuted" );
|
|
if( YTPlayer.opt.showControls )
|
|
if( prog.totalTime ) {
|
|
YTPlayer.controlBar.find( ".mb_YTPTime" ).html( jQuery.mbYTPlayer.formatTime( prog.currentTime ) + " / " + jQuery.mbYTPlayer.formatTime( prog.totalTime ) );
|
|
} else {
|
|
YTPlayer.controlBar.find( ".mb_YTPTime" ).html( "-- : -- / -- : --" );
|
|
}
|
|
if( eval( YTPlayer.opt.stopMovieOnBlur ) )
|
|
if( !document.hasFocus() ) {
|
|
if( YTPlayer.state == 1 ) {
|
|
YTPlayer.hasFocus = false;
|
|
$YTPlayer.YTPPause();
|
|
}
|
|
} else if( document.hasFocus() && !YTPlayer.hasFocus && !( YTPlayer.state == -1 || YTPlayer.state == 0 ) ) {
|
|
YTPlayer.hasFocus = true;
|
|
$YTPlayer.YTPPlay();
|
|
}
|
|
if( YTPlayer.controlBar && YTPlayer.controlBar.outerWidth() <= 400 && !YTPlayer.isCompact ) {
|
|
YTPlayer.controlBar.addClass( "compact" );
|
|
YTPlayer.isCompact = true;
|
|
if( !YTPlayer.isMute && YTPlayer.volumeBar ) YTPlayer.volumeBar.updateSliderVal( YTPlayer.opt.vol );
|
|
} else if( YTPlayer.controlBar && YTPlayer.controlBar.outerWidth() > 400 && YTPlayer.isCompact ) {
|
|
YTPlayer.controlBar.removeClass( "compact" );
|
|
YTPlayer.isCompact = false;
|
|
if( !YTPlayer.isMute && YTPlayer.volumeBar ) YTPlayer.volumeBar.updateSliderVal( YTPlayer.opt.vol );
|
|
}
|
|
if( YTPlayer.player.getPlayerState() == 1 && ( parseFloat( YTPlayer.player.getDuration() - 1.5 ) < YTPlayer.player.getCurrentTime() || ( stopAt > 0 && parseFloat( YTPlayer.player.getCurrentTime() ) > stopAt ) ) ) {
|
|
if( YTPlayer.isEnded ) return;
|
|
YTPlayer.isEnded = true;
|
|
setTimeout( function() {
|
|
YTPlayer.isEnded = false
|
|
}, 1000 );
|
|
|
|
if( YTPlayer.isPlayList ) {
|
|
|
|
if( !data.loop || ( data.loop > 0 && YTPlayer.player.LoopTime === data.loop - 1 ) ) {
|
|
|
|
YTPlayer.player.LoopTime = undefined;
|
|
clearInterval( YTPlayer.getState );
|
|
var YTPEnd = jQuery.Event( "YTPEnd" );
|
|
YTPEnd.time = YTPlayer.player.time;
|
|
jQuery( YTPlayer ).trigger( YTPEnd );
|
|
|
|
return;
|
|
}
|
|
|
|
} else if( !data.loop || ( data.loop > 0 && YTPlayer.player.LoopTime === data.loop - 1 ) ) {
|
|
|
|
YTPlayer.player.LoopTime = undefined;
|
|
|
|
YTPlayer.preventTrigger = true;
|
|
$( YTPlayer ).YTPPause();
|
|
|
|
// YTPlayer.player.pauseVideo();
|
|
|
|
YTPlayer.wrapper.CSSAnimate( {
|
|
opacity: 0
|
|
}, 1000, function() {
|
|
|
|
var YTPEnd = jQuery.Event( "YTPEnd" );
|
|
YTPEnd.time = YTPlayer.player.time;
|
|
jQuery( YTPlayer ).trigger( YTPEnd );
|
|
|
|
YTPlayer.player.seekTo( startAt, true );
|
|
if( !YTPlayer.isBackground ) {
|
|
YTPlayer.opt.containment.css( {
|
|
background: "rgba(0,0,0,0.5) url(" + YTPlayer.opt.backgroundUrl + ") center center",
|
|
backgroundSize: "cover"
|
|
} );
|
|
}
|
|
} );
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
YTPlayer.player.LoopTime = YTPlayer.player.LoopTime ? ++YTPlayer.player.LoopTime : 1;
|
|
startAt = startAt || 1;
|
|
YTPlayer.player.pauseVideo();
|
|
YTPlayer.player.seekTo( startAt, true );
|
|
$YTPlayer.YTPPlay();
|
|
|
|
|
|
}
|
|
}, interval );
|
|
},
|
|
/**
|
|
*
|
|
* */
|
|
checkForStart: function( YTPlayer ) {
|
|
var $YTPlayer = jQuery( YTPlayer );
|
|
//Checking if player has been removed from scene
|
|
if( !jQuery.contains( document, YTPlayer ) ) {
|
|
jQuery( YTPlayer ).YTPPlayerDestroy();
|
|
return
|
|
}
|
|
if( jQuery.browser.chrome ) YTPlayer.opt.quality = "default";
|
|
//YTPlayer.player.pauseVideo();
|
|
jQuery( YTPlayer ).muteYTPVolume();
|
|
jQuery( "#controlBar_" + YTPlayer.id ).remove();
|
|
if( YTPlayer.opt.showControls ) jQuery.mbYTPlayer.buildControls( YTPlayer );
|
|
if( YTPlayer.opt.addRaster ) {
|
|
var classN = YTPlayer.opt.addRaster == "dot" ? "raster-dot" : "raster";
|
|
YTPlayer.overlay.addClass( YTPlayer.isRetina ? classN + " retina" : classN );
|
|
} else {
|
|
YTPlayer.overlay.removeClass( function( index, classNames ) {
|
|
// change the list into an array
|
|
var current_classes = classNames.split( " " ),
|
|
// array of classes which are to be removed
|
|
classes_to_remove = [];
|
|
jQuery.each( current_classes, function( index, class_name ) {
|
|
// if the classname begins with bg add it to the classes_to_remove array
|
|
if( /raster.*/.test( class_name ) ) {
|
|
classes_to_remove.push( class_name );
|
|
}
|
|
} );
|
|
classes_to_remove.push( "retina" );
|
|
// turn the array back into a string
|
|
return classes_to_remove.join( " " );
|
|
} )
|
|
}
|
|
YTPlayer.checkForStartAt = setInterval( function() {
|
|
jQuery( YTPlayer ).YTPMute();
|
|
var startAt = YTPlayer.opt.startAt ? YTPlayer.opt.startAt : 1;
|
|
var canPlayVideo = ( YTPlayer.player.getVideoLoadedFraction() > startAt / YTPlayer.player.getDuration() );
|
|
if( YTPlayer.player.getDuration() > 0 && YTPlayer.player.getCurrentTime() >= startAt && canPlayVideo ) {
|
|
clearInterval( YTPlayer.checkForStartAt );
|
|
YTPlayer.isReady = true;
|
|
if( typeof YTPlayer.opt.onReady == "function" )
|
|
YTPlayer.opt.onReady( YTPlayer );
|
|
|
|
var YTPready = jQuery.Event( "YTPReady" );
|
|
YTPready.time = YTPlayer.player.time;
|
|
jQuery( YTPlayer ).trigger( YTPready );
|
|
|
|
//YTPlayer.player.pauseVideo();
|
|
|
|
if( !YTPlayer.opt.mute ) jQuery( YTPlayer ).YTPUnmute();
|
|
YTPlayer.canTrigger = true;
|
|
if( YTPlayer.opt.autoPlay ) {
|
|
$YTPlayer.YTPPlay();
|
|
|
|
var YTPStart = jQuery.Event( "YTPStart" );
|
|
YTPStart.time = YTPlayer.player.time;
|
|
jQuery( YTPlayer ).trigger( YTPStart );
|
|
|
|
$YTPlayer.css( "background-image", "none" );
|
|
jQuery( YTPlayer.playerEl ).CSSAnimate( {
|
|
opacity: 1
|
|
}, 1000 );
|
|
YTPlayer.wrapper.CSSAnimate( {
|
|
opacity: YTPlayer.isAlone ? 1 : YTPlayer.opt.opacity
|
|
}, 1000 );
|
|
} else {
|
|
YTPlayer.player.pauseVideo();
|
|
if( !YTPlayer.isPlayer ) {
|
|
jQuery( YTPlayer.playerEl ).CSSAnimate( {
|
|
opacity: 1
|
|
}, 1000 );
|
|
YTPlayer.wrapper.CSSAnimate( {
|
|
opacity: YTPlayer.isAlone ? 1 : YTPlayer.opt.opacity
|
|
}, 1000 );
|
|
}
|
|
}
|
|
|
|
if( YTPlayer.isPlayer && !YTPlayer.opt.autoPlay ) {
|
|
YTPlayer.loading.html( "Ready" );
|
|
setTimeout( function() {
|
|
YTPlayer.loading.fadeOut();
|
|
|
|
|
|
}, 100 )
|
|
}
|
|
if( YTPlayer.controlBar ) YTPlayer.controlBar.slideDown( 1000 );
|
|
} else {
|
|
//YTPlayer.player.playVideo();
|
|
if( startAt >= 0 ) YTPlayer.player.seekTo( startAt, true );
|
|
}
|
|
}, 1000 );
|
|
},
|
|
/**
|
|
*
|
|
* @param s
|
|
* @returns {string}
|
|
*/
|
|
formatTime: function( s ) {
|
|
var min = Math.floor( s / 60 );
|
|
var sec = Math.floor( s - ( 60 * min ) );
|
|
return( min <= 9 ? "0" + min : min ) + " : " + ( sec <= 9 ? "0" + sec : sec );
|
|
}
|
|
};
|
|
/**
|
|
*
|
|
* @returns {boolean}
|
|
*/
|
|
jQuery.fn.toggleVolume = function() {
|
|
var YTPlayer = this.get( 0 );
|
|
if( !YTPlayer ) return;
|
|
if( YTPlayer.player.isMuted() ) {
|
|
jQuery( YTPlayer ).YTPUnmute();
|
|
return true;
|
|
} else {
|
|
jQuery( YTPlayer ).YTPMute();
|
|
return false;
|
|
}
|
|
};
|
|
/**
|
|
*
|
|
*/
|
|
jQuery.fn.optimizeDisplay = function() {
|
|
var YTPlayer = this.get( 0 );
|
|
var data = YTPlayer.opt;
|
|
var playerBox = jQuery( YTPlayer.playerEl );
|
|
var win = {};
|
|
var el = YTPlayer.wrapper;
|
|
win.width = el.outerWidth();
|
|
win.height = el.outerHeight();
|
|
var margin = 24;
|
|
var overprint = 100;
|
|
var vid = {};
|
|
if( data.optimizeDisplay ) {
|
|
vid.width = win.width + ( ( win.width * margin ) / 100 );
|
|
vid.height = data.ratio == "16/9" ? Math.ceil( ( 9 * win.width ) / 16 ) : Math.ceil( ( 3 * win.width ) / 4 );
|
|
vid.marginTop = -( ( vid.height - win.height ) / 2 );
|
|
vid.marginLeft = -( ( win.width * ( margin / 2 ) ) / 100 );
|
|
if( vid.height < win.height ) {
|
|
vid.height = win.height + ( ( win.height * margin ) / 100 );
|
|
vid.width = data.ratio == "16/9" ? Math.floor( ( 16 * win.height ) / 9 ) : Math.floor( ( 4 * win.height ) / 3 );
|
|
vid.marginTop = -( ( win.height * ( margin / 2 ) ) / 100 );
|
|
vid.marginLeft = -( ( vid.width - win.width ) / 2 );
|
|
}
|
|
vid.width += overprint;
|
|
vid.height += overprint;
|
|
vid.marginTop -= overprint / 2;
|
|
vid.marginLeft -= overprint / 2;
|
|
} else {
|
|
vid.width = "100%";
|
|
vid.height = "100%";
|
|
vid.marginTop = 0;
|
|
vid.marginLeft = 0;
|
|
}
|
|
playerBox.css( {
|
|
width: vid.width,
|
|
height: vid.height,
|
|
marginTop: vid.marginTop,
|
|
marginLeft: vid.marginLeft
|
|
} );
|
|
};
|
|
/**
|
|
*
|
|
* @param arr
|
|
* @returns {Array|string|Blob|*}
|
|
*
|
|
*/
|
|
jQuery.shuffle = function( arr ) {
|
|
var newArray = arr.slice();
|
|
var len = newArray.length;
|
|
var i = len;
|
|
while( i-- ) {
|
|
var p = parseInt( Math.random() * len );
|
|
var t = newArray[ i ];
|
|
newArray[ i ] = newArray[ p ];
|
|
newArray[ p ] = t;
|
|
}
|
|
return newArray;
|
|
};
|
|
|
|
jQuery.fn.unselectable = function() {
|
|
return this.each( function() {
|
|
jQuery( this ).css( {
|
|
"-moz-user-select": "none",
|
|
"-webkit-user-select": "none",
|
|
"user-select": "none"
|
|
} ).attr( "unselectable", "on" );
|
|
} );
|
|
};
|
|
|
|
|
|
/* Exposed public method */
|
|
jQuery.fn.YTPlayer = jQuery.mbYTPlayer.buildPlayer;
|
|
jQuery.fn.YTPGetPlayer = jQuery.mbYTPlayer.getPlayer;
|
|
jQuery.fn.YTPGetVideoID = jQuery.mbYTPlayer.getVideoID;
|
|
jQuery.fn.YTPChangeMovie = jQuery.mbYTPlayer.changeMovie;
|
|
jQuery.fn.YTPPlayerDestroy = jQuery.mbYTPlayer.playerDestroy;
|
|
|
|
jQuery.fn.YTPPlay = jQuery.mbYTPlayer.play;
|
|
jQuery.fn.YTPTogglePlay = jQuery.mbYTPlayer.togglePlay;
|
|
jQuery.fn.YTPStop = jQuery.mbYTPlayer.stop;
|
|
jQuery.fn.YTPPause = jQuery.mbYTPlayer.pause;
|
|
jQuery.fn.YTPSeekTo = jQuery.mbYTPlayer.seekTo;
|
|
|
|
jQuery.fn.YTPlaylist = jQuery.mbYTPlayer.playlist;
|
|
jQuery.fn.YTPPlayNext = jQuery.mbYTPlayer.playNext;
|
|
jQuery.fn.YTPPlayPrev = jQuery.mbYTPlayer.playPrev;
|
|
|
|
jQuery.fn.YTPMute = jQuery.mbYTPlayer.mute;
|
|
jQuery.fn.YTPUnmute = jQuery.mbYTPlayer.unmute;
|
|
jQuery.fn.YTPToggleVolume = jQuery.mbYTPlayer.toggleVolume;
|
|
jQuery.fn.YTPSetVolume = jQuery.mbYTPlayer.setVolume;
|
|
|
|
jQuery.fn.YTPGetVideoData = jQuery.mbYTPlayer.getVideoData;
|
|
jQuery.fn.YTPFullscreen = jQuery.mbYTPlayer.fullscreen;
|
|
jQuery.fn.YTPToggleLoops = jQuery.mbYTPlayer.toggleLoops;
|
|
jQuery.fn.YTPSetVideoQuality = jQuery.mbYTPlayer.setVideoQuality;
|
|
jQuery.fn.YTPManageProgress = jQuery.mbYTPlayer.manageProgress;
|
|
|
|
jQuery.fn.YTPApplyFilter = jQuery.mbYTPlayer.applyFilter;
|
|
jQuery.fn.YTPApplyFilters = jQuery.mbYTPlayer.applyFilters;
|
|
jQuery.fn.YTPToggleFilter = jQuery.mbYTPlayer.toggleFilter;
|
|
jQuery.fn.YTPToggleFilters = jQuery.mbYTPlayer.toggleFilters;
|
|
jQuery.fn.YTPRemoveFilter = jQuery.mbYTPlayer.removeFilter;
|
|
jQuery.fn.YTPDisableFilters = jQuery.mbYTPlayer.disableFilters;
|
|
jQuery.fn.YTPEnableFilters = jQuery.mbYTPlayer.enableFilters;
|
|
|
|
|
|
/**
|
|
*
|
|
* @deprecated
|
|
*
|
|
**/
|
|
jQuery.fn.mb_YTPlayer = jQuery.mbYTPlayer.buildPlayer;
|
|
jQuery.fn.playNext = jQuery.mbYTPlayer.playNext;
|
|
jQuery.fn.playPrev = jQuery.mbYTPlayer.playPrev;
|
|
jQuery.fn.changeMovie = jQuery.mbYTPlayer.changeMovie;
|
|
jQuery.fn.getVideoID = jQuery.mbYTPlayer.getVideoID;
|
|
jQuery.fn.getPlayer = jQuery.mbYTPlayer.getPlayer;
|
|
jQuery.fn.playerDestroy = jQuery.mbYTPlayer.playerDestroy;
|
|
jQuery.fn.fullscreen = jQuery.mbYTPlayer.fullscreen;
|
|
jQuery.fn.buildYTPControls = jQuery.mbYTPlayer.buildControls;
|
|
jQuery.fn.playYTP = jQuery.mbYTPlayer.play;
|
|
jQuery.fn.toggleLoops = jQuery.mbYTPlayer.toggleLoops;
|
|
jQuery.fn.stopYTP = jQuery.mbYTPlayer.stop;
|
|
jQuery.fn.pauseYTP = jQuery.mbYTPlayer.pause;
|
|
jQuery.fn.seekToYTP = jQuery.mbYTPlayer.seekTo;
|
|
jQuery.fn.muteYTPVolume = jQuery.mbYTPlayer.mute;
|
|
jQuery.fn.unmuteYTPVolume = jQuery.mbYTPlayer.unmute;
|
|
jQuery.fn.setYTPVolume = jQuery.mbYTPlayer.setVolume;
|
|
jQuery.fn.setVideoQuality = jQuery.mbYTPlayer.setVideoQuality;
|
|
jQuery.fn.manageYTPProgress = jQuery.mbYTPlayer.manageProgress;
|
|
jQuery.fn.YTPGetDataFromFeed = jQuery.mbYTPlayer.getVideoData;
|
|
|
|
|
|
} )( jQuery, ytp );
|
|
;
|
|
/*
|
|
* ******************************************************************************
|
|
* jquery.mb.components
|
|
* file: jquery.mb.CSSAnimate.min.js
|
|
*
|
|
* Copyright (c) 2001-2014. Matteo Bicocchi (Pupunzi);
|
|
* Open lab srl, Firenze - Italy
|
|
* email: matteo@open-lab.com
|
|
* site: http://pupunzi.com
|
|
* blog: http://pupunzi.open-lab.com
|
|
* http://open-lab.com
|
|
*
|
|
* Licences: MIT, GPL
|
|
* http://www.opensource.org/licenses/mit-license.php
|
|
* http://www.gnu.org/licenses/gpl.html
|
|
*
|
|
* last modified: 26/03/14 21.40
|
|
* *****************************************************************************
|
|
*/
|
|
|
|
function uncamel(a){return a.replace(/([A-Z])/g,function(a){return"-"+a.toLowerCase()})}function setUnit(a,b){return"string"!=typeof a||a.match(/^[\-0-9\.]+jQuery/)?""+a+b:a}function setFilter(a,b,c){var d=uncamel(b),e=jQuery.browser.mozilla?"":jQuery.CSS.sfx;a[e+"filter"]=a[e+"filter"]||"",c=setUnit(c>jQuery.CSS.filters[b].max?jQuery.CSS.filters[b].max:c,jQuery.CSS.filters[b].unit),a[e+"filter"]+=d+"("+c+") ",delete a[b]}jQuery.support.CSStransition=function(){var a=document.body||document.documentElement,b=a.style;return void 0!==b.transition||void 0!==b.WebkitTransition||void 0!==b.MozTransition||void 0!==b.MsTransition||void 0!==b.OTransition}(),jQuery.CSS={name:"mb.CSSAnimate",author:"Matteo Bicocchi",version:"2.0.0",transitionEnd:"transitionEnd",sfx:"",filters:{blur:{min:0,max:100,unit:"px"},brightness:{min:0,max:400,unit:"%"},contrast:{min:0,max:400,unit:"%"},grayscale:{min:0,max:100,unit:"%"},hueRotate:{min:0,max:360,unit:"deg"},invert:{min:0,max:100,unit:"%"},saturate:{min:0,max:400,unit:"%"},sepia:{min:0,max:100,unit:"%"}},normalizeCss:function(a){var b=jQuery.extend(!0,{},a);jQuery.browser.webkit||jQuery.browser.opera?jQuery.CSS.sfx="-webkit-":jQuery.browser.mozilla?jQuery.CSS.sfx="-moz-":jQuery.browser.msie&&(jQuery.CSS.sfx="-ms-");for(var c in b){"transform"===c&&(b[jQuery.CSS.sfx+"transform"]=b[c],delete b[c]),"transform-origin"===c&&(b[jQuery.CSS.sfx+"transform-origin"]=a[c],delete b[c]),"filter"!==c||jQuery.browser.mozilla||(b[jQuery.CSS.sfx+"filter"]=a[c],delete b[c]),"blur"===c&&setFilter(b,"blur",a[c]),"brightness"===c&&setFilter(b,"brightness",a[c]),"contrast"===c&&setFilter(b,"contrast",a[c]),"grayscale"===c&&setFilter(b,"grayscale",a[c]),"hueRotate"===c&&setFilter(b,"hueRotate",a[c]),"invert"===c&&setFilter(b,"invert",a[c]),"saturate"===c&&setFilter(b,"saturate",a[c]),"sepia"===c&&setFilter(b,"sepia",a[c]);var d="";"x"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" translateX("+setUnit(a[c],"px")+")",delete b[c]),"y"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" translateY("+setUnit(a[c],"px")+")",delete b[c]),"z"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" translateZ("+setUnit(a[c],"px")+")",delete b[c]),"rotate"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" rotate("+setUnit(a[c],"deg")+")",delete b[c]),"rotateX"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" rotateX("+setUnit(a[c],"deg")+")",delete b[c]),"rotateY"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" rotateY("+setUnit(a[c],"deg")+")",delete b[c]),"rotateZ"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" rotateZ("+setUnit(a[c],"deg")+")",delete b[c]),"scale"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" scale("+setUnit(a[c],"")+")",delete b[c]),"scaleX"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" scaleX("+setUnit(a[c],"")+")",delete b[c]),"scaleY"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" scaleY("+setUnit(a[c],"")+")",delete b[c]),"scaleZ"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" scaleZ("+setUnit(a[c],"")+")",delete b[c]),"skew"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" skew("+setUnit(a[c],"deg")+")",delete b[c]),"skewX"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" skewX("+setUnit(a[c],"deg")+")",delete b[c]),"skewY"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" skewY("+setUnit(a[c],"deg")+")",delete b[c]),"perspective"===c&&(d=jQuery.CSS.sfx+"transform",b[d]=b[d]||"",b[d]+=" perspective("+setUnit(a[c],"px")+")",delete b[c])}return b},getProp:function(a){var b=[];for(var c in a)b.indexOf(c)<0&&b.push(uncamel(c));return b.join(",")},animate:function(a,b,c,d,e){return this.each(function(){function o(){f.called=!0,f.CSSAIsRunning=!1,g.off(jQuery.CSS.transitionEnd+"."+f.id),clearTimeout(f.timeout),g.css(jQuery.CSS.sfx+"transition",""),"function"==typeof e&&e.apply(f),"function"==typeof f.CSSqueue&&(f.CSSqueue(),f.CSSqueue=null)}var f=this,g=jQuery(this);f.id=f.id||"CSSA_"+(new Date).getTime();var h=h||{type:"noEvent"};if(f.CSSAIsRunning&&f.eventType==h.type&&!jQuery.browser.msie&&jQuery.browser.version<=9)return f.CSSqueue=function(){g.CSSAnimate(a,b,c,d,e)},void 0;if(f.CSSqueue=null,f.eventType=h.type,0!==g.length&&a){if(a=jQuery.normalizeCss(a),f.CSSAIsRunning=!0,"function"==typeof b&&(e=b,b=jQuery.fx.speeds._default),"function"==typeof c&&(d=c,c=0),"string"==typeof c&&(e=c,c=0),"function"==typeof d&&(e=d,d="cubic-bezier(0.65,0.03,0.36,0.72)"),"string"==typeof b)for(var i in jQuery.fx.speeds){if(b==i){b=jQuery.fx.speeds[i];break}b=jQuery.fx.speeds._default}if(b||(b=jQuery.fx.speeds._default),"string"==typeof e&&(d=e,e=null),!jQuery.support.CSStransition){for(var j in a){if("transform"===j&&delete a[j],"filter"===j&&delete a[j],"transform-origin"===j&&delete a[j],"auto"===a[j]&&delete a[j],"x"===j){var k=a[j],l="left";a[l]=k,delete a[j]}if("y"===j){var k=a[j],l="top";a[l]=k,delete a[j]}("-ms-transform"===j||"-ms-filter"===j)&&delete a[j]}return g.delay(c).animate(a,b,e),void 0}var m={"default":"ease","in":"ease-in",out:"ease-out","in-out":"ease-in-out",snap:"cubic-bezier(0,1,.5,1)",easeOutCubic:"cubic-bezier(.215,.61,.355,1)",easeInOutCubic:"cubic-bezier(.645,.045,.355,1)",easeInCirc:"cubic-bezier(.6,.04,.98,.335)",easeOutCirc:"cubic-bezier(.075,.82,.165,1)",easeInOutCirc:"cubic-bezier(.785,.135,.15,.86)",easeInExpo:"cubic-bezier(.95,.05,.795,.035)",easeOutExpo:"cubic-bezier(.19,1,.22,1)",easeInOutExpo:"cubic-bezier(1,0,0,1)",easeInQuad:"cubic-bezier(.55,.085,.68,.53)",easeOutQuad:"cubic-bezier(.25,.46,.45,.94)",easeInOutQuad:"cubic-bezier(.455,.03,.515,.955)",easeInQuart:"cubic-bezier(.895,.03,.685,.22)",easeOutQuart:"cubic-bezier(.165,.84,.44,1)",easeInOutQuart:"cubic-bezier(.77,0,.175,1)",easeInQuint:"cubic-bezier(.755,.05,.855,.06)",easeOutQuint:"cubic-bezier(.23,1,.32,1)",easeInOutQuint:"cubic-bezier(.86,0,.07,1)",easeInSine:"cubic-bezier(.47,0,.745,.715)",easeOutSine:"cubic-bezier(.39,.575,.565,1)",easeInOutSine:"cubic-bezier(.445,.05,.55,.95)",easeInBack:"cubic-bezier(.6,-.28,.735,.045)",easeOutBack:"cubic-bezier(.175, .885,.32,1.275)",easeInOutBack:"cubic-bezier(.68,-.55,.265,1.55)"};m[d]&&(d=m[d]),g.off(jQuery.CSS.transitionEnd+"."+f.id);var n=jQuery.CSS.getProp(a),p={};jQuery.extend(p,a),p[jQuery.CSS.sfx+"transition-property"]=n,p[jQuery.CSS.sfx+"transition-duration"]=b+"ms",p[jQuery.CSS.sfx+"transition-delay"]=c+"ms",p[jQuery.CSS.sfx+"transition-timing-function"]=d,setTimeout(function(){g.one(jQuery.CSS.transitionEnd+"."+f.id,o),g.css(p)},1),f.timeout=setTimeout(function(){return f.called||!e?(f.called=!1,f.CSSAIsRunning=!1,void 0):(g.css(jQuery.CSS.sfx+"transition",""),e.apply(f),f.CSSAIsRunning=!1,"function"==typeof f.CSSqueue&&(f.CSSqueue(),f.CSSqueue=null),void 0)},b+c+10)}})}},jQuery.fn.CSSAnimate=jQuery.CSS.animate,jQuery.normalizeCss=jQuery.CSS.normalizeCss,jQuery.fn.css3=function(a){return this.each(function(){var b=jQuery(this),c=jQuery.normalizeCss(a);b.css(c)})};
|
|
;/*
|
|
* ******************************************************************************
|
|
* jquery.mb.components
|
|
* file: jquery.mb.browser.min.js
|
|
*
|
|
* Copyright (c) 2001-2014. Matteo Bicocchi (Pupunzi);
|
|
* Open lab srl, Firenze - Italy
|
|
* email: matteo@open-lab.com
|
|
* site: http://pupunzi.com
|
|
* blog: http://pupunzi.open-lab.com
|
|
* http://open-lab.com
|
|
*
|
|
* Licences: MIT, GPL
|
|
* http://www.opensource.org/licenses/mit-license.php
|
|
* http://www.gnu.org/licenses/gpl.html
|
|
*
|
|
* last modified: 26/03/14 21.43
|
|
* *****************************************************************************
|
|
*/
|
|
|
|
var nAgt=navigator.userAgent;if(!jQuery.browser){jQuery.browser={},jQuery.browser.mozilla=!1,jQuery.browser.webkit=!1,jQuery.browser.opera=!1,jQuery.browser.safari=!1,jQuery.browser.chrome=!1,jQuery.browser.msie=!1,jQuery.browser.ua=nAgt,jQuery.browser.name=navigator.appName,jQuery.browser.fullVersion=""+parseFloat(navigator.appVersion),jQuery.browser.majorVersion=parseInt(navigator.appVersion,10);var nameOffset,verOffset,ix;if(-1!=(verOffset=nAgt.indexOf("Opera")))jQuery.browser.opera=!0,jQuery.browser.name="Opera",jQuery.browser.fullVersion=nAgt.substring(verOffset+6),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.browser.fullVersion=nAgt.substring(verOffset+8));else if(-1!=(verOffset=nAgt.indexOf("OPR")))jQuery.browser.opera=!0,jQuery.browser.name="Opera",jQuery.browser.fullVersion=nAgt.substring(verOffset+4);else if(-1!=(verOffset=nAgt.indexOf("MSIE")))jQuery.browser.msie=!0,jQuery.browser.name="Microsoft Internet Explorer",jQuery.browser.fullVersion=nAgt.substring(verOffset+5);else if(-1!=nAgt.indexOf("Trident")){jQuery.browser.msie=!0,jQuery.browser.name="Microsoft Internet Explorer";var start=nAgt.indexOf("rv:")+3,end=start+4;jQuery.browser.fullVersion=nAgt.substring(start,end)}else-1!=(verOffset=nAgt.indexOf("Chrome"))?(jQuery.browser.webkit=!0,jQuery.browser.chrome=!0,jQuery.browser.name="Chrome",jQuery.browser.fullVersion=nAgt.substring(verOffset+7)):-1!=(verOffset=nAgt.indexOf("Safari"))?(jQuery.browser.webkit=!0,jQuery.browser.safari=!0,jQuery.browser.name="Safari",jQuery.browser.fullVersion=nAgt.substring(verOffset+7),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.browser.fullVersion=nAgt.substring(verOffset+8))):-1!=(verOffset=nAgt.indexOf("AppleWebkit"))?(jQuery.browser.webkit=!0,jQuery.browser.name="Safari",jQuery.browser.fullVersion=nAgt.substring(verOffset+7),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.browser.fullVersion=nAgt.substring(verOffset+8))):-1!=(verOffset=nAgt.indexOf("Firefox"))?(jQuery.browser.mozilla=!0,jQuery.browser.name="Firefox",jQuery.browser.fullVersion=nAgt.substring(verOffset+8)):(nameOffset=nAgt.lastIndexOf(" ")+1)<(verOffset=nAgt.lastIndexOf("/"))&&(jQuery.browser.name=nAgt.substring(nameOffset,verOffset),jQuery.browser.fullVersion=nAgt.substring(verOffset+1),jQuery.browser.name.toLowerCase()==jQuery.browser.name.toUpperCase()&&(jQuery.browser.name=navigator.appName));-1!=(ix=jQuery.browser.fullVersion.indexOf(";"))&&(jQuery.browser.fullVersion=jQuery.browser.fullVersion.substring(0,ix)),-1!=(ix=jQuery.browser.fullVersion.indexOf(" "))&&(jQuery.browser.fullVersion=jQuery.browser.fullVersion.substring(0,ix)),jQuery.browser.majorVersion=parseInt(""+jQuery.browser.fullVersion,10),isNaN(jQuery.browser.majorVersion)&&(jQuery.browser.fullVersion=""+parseFloat(navigator.appVersion),jQuery.browser.majorVersion=parseInt(navigator.appVersion,10)),jQuery.browser.version=jQuery.browser.majorVersion}jQuery.browser.android=/Android/i.test(nAgt),jQuery.browser.blackberry=/BlackBerry|BB|PlayBook/i.test(nAgt),jQuery.browser.ios=/iPhone|iPad|iPod|webOS/i.test(nAgt),jQuery.browser.operaMobile=/Opera Mini/i.test(nAgt),jQuery.browser.windowsMobile=/IEMobile|Windows Phone/i.test(nAgt),jQuery.browser.kindle=/Kindle|Silk/i.test(nAgt),jQuery.browser.mobile=jQuery.browser.android||jQuery.browser.blackberry||jQuery.browser.ios||jQuery.browser.windowsMobile||jQuery.browser.operaMobile||jQuery.browser.kindle,jQuery.isMobile=jQuery.browser.mobile,jQuery.isTablet=jQuery.browser.mobile&&jQuery(window).width()>765,jQuery.isAndroidDefault=jQuery.browser.android&&!/chrome/i.test(nAgt);
|
|
;/*___________________________________________________________________________________________________________________________________________________
|
|
_ jquery.mb.components _
|
|
_ _
|
|
_ file: jquery.mb.simpleSlider.min.js _
|
|
_ last modified: 16/05/15 23.45 _
|
|
_ _
|
|
_ Open Lab s.r.l., Florence - Italy _
|
|
_ _
|
|
_ email: matteo@open-lab.com _
|
|
_ site: http://pupunzi.com _
|
|
_ http://open-lab.com _
|
|
_ blog: http://pupunzi.open-lab.com _
|
|
_ Q&A: http://jquery.pupunzi.com _
|
|
_ _
|
|
_ Licences: MIT, GPL _
|
|
_ http://www.opensource.org/licenses/mit-license.php _
|
|
_ http://www.gnu.org/licenses/gpl.html _
|
|
_ _
|
|
_ Copyright (c) 2001-2015. Matteo Bicocchi (Pupunzi); _
|
|
___________________________________________________________________________________________________________________________________________________*/
|
|
|
|
!function(a){/iphone|ipod|ipad|android|ie|blackberry|fennec/.test(navigator.userAgent.toLowerCase());var c="ontouchstart"in window||window.navigator&&window.navigator.msPointerEnabled&&window.MSGesture||window.DocumentTouch&&document instanceof DocumentTouch||!1;a.simpleSlider={defaults:{initialval:0,scale:100,orientation:"h",readonly:!1,callback:!1},events:{start:c?"touchstart":"mousedown",end:c?"touchend":"mouseup",move:c?"touchmove":"mousemove"},init:function(b){return this.each(function(){var d=this,e=a(d);e.addClass("simpleSlider"),d.opt={},a.extend(d.opt,a.simpleSlider.defaults,b),a.extend(d.opt,e.data());var f="h"==d.opt.orientation?"horizontal":"vertical",g=a("<div/>").addClass("level").addClass(f);e.prepend(g),d.level=g,e.css({cursor:"default"}),"auto"==d.opt.scale&&(d.opt.scale=a(d).outerWidth()),e.updateSliderVal(),d.opt.readonly||(e.on(a.simpleSlider.events.start,function(a){c&&(a=a.changedTouches[0]),d.canSlide=!0,e.updateSliderVal(a),e.css({cursor:"col-resize"}),a.preventDefault(),a.stopPropagation()}),a(document).on(a.simpleSlider.events.move,function(b){c&&(b=b.changedTouches[0]),d.canSlide&&(a(document).css({cursor:"default"}),e.updateSliderVal(b),b.preventDefault(),b.stopPropagation())}).on(a.simpleSlider.events.end,function(){a(document).css({cursor:"auto"}),d.canSlide=!1,e.css({cursor:"auto"})}))})},updateSliderVal:function(b){function g(a,b){return Math.floor(100*a/b)}var c=this,d=c.get(0);d.opt.initialval="number"==typeof d.opt.initialval?d.opt.initialval:d.opt.initialval(d);var e=a(d).outerWidth(),f=a(d).outerHeight();d.x="object"==typeof b?b.clientX+document.body.scrollLeft-c.offset().left:"number"==typeof b?b*e/d.opt.scale:d.opt.initialval*e/d.opt.scale,d.y="object"==typeof b?b.clientY+document.body.scrollTop-c.offset().top:"number"==typeof b?(d.opt.scale-d.opt.initialval-b)*f/d.opt.scale:d.opt.initialval*f/d.opt.scale,d.y=c.outerHeight()-d.y,d.scaleX=d.x*d.opt.scale/e,d.scaleY=d.y*d.opt.scale/f,d.outOfRangeX=d.scaleX>d.opt.scale?d.scaleX-d.opt.scale:d.scaleX<0?d.scaleX:0,d.outOfRangeY=d.scaleY>d.opt.scale?d.scaleY-d.opt.scale:d.scaleY<0?d.scaleY:0,d.outOfRange="h"==d.opt.orientation?d.outOfRangeX:d.outOfRangeY,d.value="undefined"!=typeof b?"h"==d.opt.orientation?d.x>=c.outerWidth()?d.opt.scale:d.x<=0?0:d.scaleX:d.y>=c.outerHeight()?d.opt.scale:d.y<=0?0:d.scaleY:"h"==d.opt.orientation?d.scaleX:d.scaleY,"h"==d.opt.orientation?d.level.width(g(d.x,e)+"%"):d.level.height(g(d.y,f)),"function"==typeof d.opt.callback&&d.opt.callback(d)}},a.fn.simpleSlider=a.simpleSlider.init,a.fn.updateSliderVal=a.simpleSlider.updateSliderVal}(jQuery);
|
|
;/*___________________________________________________________________________________________________________________________________________________
|
|
_ jquery.mb.components _
|
|
_ _
|
|
_ file: jquery.mb.storage.min.js _
|
|
_ last modified: 24/05/15 16.08 _
|
|
_ _
|
|
_ Open Lab s.r.l., Florence - Italy _
|
|
_ _
|
|
_ email: matteo@open-lab.com _
|
|
_ site: http://pupunzi.com _
|
|
_ http://open-lab.com _
|
|
_ blog: http://pupunzi.open-lab.com _
|
|
_ Q&A: http://jquery.pupunzi.com _
|
|
_ _
|
|
_ Licences: MIT, GPL _
|
|
_ http://www.opensource.org/licenses/mit-license.php _
|
|
_ http://www.gnu.org/licenses/gpl.html _
|
|
_ _
|
|
_ Copyright (c) 2001-2015. Matteo Bicocchi (Pupunzi); _
|
|
___________________________________________________________________________________________________________________________________________________*/
|
|
|
|
!function(a){a.mbCookie={set:function(a,b,c,d){b=JSON.stringify(b),c||(c=7),d=d?"; domain="+d:"";var f,e=new Date;e.setTime(e.getTime()+1e3*60*60*24*c),f="; expires="+e.toGMTString(),document.cookie=a+"="+b+f+"; path=/"+d},get:function(a){for(var b=a+"=",c=document.cookie.split(";"),d=0;d<c.length;d++){for(var e=c[d];" "==e.charAt(0);)e=e.substring(1,e.length);if(0==e.indexOf(b))return JSON.parse(e.substring(b.length,e.length))}return null},remove:function(b){a.mbCookie.set(b,"",-1)}},a.mbStorage={set:function(a,b){b=JSON.stringify(b),localStorage.setItem(a,b)},get:function(a){return localStorage[a]?JSON.parse(localStorage[a]):null},remove:function(a){a?localStorage.removeItem(a):localStorage.clear()}}}(jQuery);
|