2929 lines
108 KiB
JavaScript
2929 lines
108 KiB
JavaScript
|
/**********************************************
|
|||
|
* @File Name: jquery.mb.YTPlayer.src.js
|
|||
|
* @Author: Matteo Bicocchi
|
|||
|
* @Date: 2020-03-16
|
|||
|
* @Email: matbicoc@gmail.com
|
|||
|
*
|
|||
|
* @Last Modified by: Matteo Bicocchi
|
|||
|
* @Last Modified time: 2020-03-18
|
|||
|
* @Copyright: 2020. Matteo Bicocchi
|
|||
|
*
|
|||
|
* Open Lab s.r.l., Florence - Italy
|
|||
|
* @blog: http://pupunzi.open-lab.com
|
|||
|
* @site: http://pupunzi.com
|
|||
|
****************************************************/
|
|||
|
|
|||
|
|
|||
|
var ytp = ytp || {};
|
|||
|
|
|||
|
let YTPRndSuffix = new Date().getTime();
|
|||
|
let YTPTimerLabels = {
|
|||
|
init : "YTPlayerInit_" + YTPRndSuffix,
|
|||
|
startPlaying: "YTPlayerStartPlay_" + YTPRndSuffix
|
|||
|
};
|
|||
|
|
|||
|
function onYouTubeIframeAPIReady() {
|
|||
|
if (ytp.YTAPIReady)
|
|||
|
return;
|
|||
|
|
|||
|
ytp.YTAPIReady = true;
|
|||
|
jQuery(document).trigger('YTAPIReady')
|
|||
|
}
|
|||
|
|
|||
|
let getYTPVideoID = function (url) {
|
|||
|
let videoID, playlistID;
|
|||
|
if (url.indexOf('youtu.be') > 0 || url.indexOf('youtube.com/embed') > 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: '3.3.9',
|
|||
|
build : '7581',
|
|||
|
author : 'Matteo Bicocchi (pupunzi)',
|
|||
|
apiKey : '',
|
|||
|
|
|||
|
/*
|
|||
|
* Default options for the player
|
|||
|
*/
|
|||
|
defaults : {
|
|||
|
/**
|
|||
|
videoURL (string)
|
|||
|
the complete Youtube video URL or the short url or the videoID
|
|||
|
*/
|
|||
|
videoURL: null,
|
|||
|
|
|||
|
/**
|
|||
|
containment (string)
|
|||
|
default containment for the player
|
|||
|
*/
|
|||
|
containment: 'body',
|
|||
|
|
|||
|
/**
|
|||
|
ratio (string or number)
|
|||
|
"auto", "16/9", "4/3" or number: 4/3, 16/9
|
|||
|
*/
|
|||
|
ratio: 'auto',
|
|||
|
|
|||
|
/**
|
|||
|
fadeOnStartTime (int)
|
|||
|
fade in timing at video start
|
|||
|
*/
|
|||
|
fadeOnStartTime: 1000,
|
|||
|
|
|||
|
/**
|
|||
|
startAt (int)
|
|||
|
start second
|
|||
|
*/
|
|||
|
startAt: 0,
|
|||
|
|
|||
|
/**
|
|||
|
stopAt (int)
|
|||
|
stop second
|
|||
|
*/
|
|||
|
stopAt: 0,
|
|||
|
|
|||
|
/**
|
|||
|
autoPlay (bool)
|
|||
|
on page load video should start or pause
|
|||
|
*/
|
|||
|
autoPlay: true,
|
|||
|
|
|||
|
/**
|
|||
|
delayAtStart (bool)
|
|||
|
If the YT API don't fire the event the player will try to start anyway after...
|
|||
|
*/
|
|||
|
delayAtStart: 1000,
|
|||
|
|
|||
|
/**
|
|||
|
coverImage (string)
|
|||
|
The path to the image to be used as cover if the autoPlay option is set to false
|
|||
|
*/
|
|||
|
coverImage: false,
|
|||
|
|
|||
|
/**
|
|||
|
loop (bool or int)
|
|||
|
video should loop or not; if number it will loop for the specified times
|
|||
|
*/
|
|||
|
loop: true,
|
|||
|
|
|||
|
/**
|
|||
|
addRaster (bool)
|
|||
|
shows a raster image over the video (added via CSS)
|
|||
|
You can change the raster image via CSS:
|
|||
|
.YTPOverlay.raster { background: url(images/raster.png)}
|
|||
|
*/
|
|||
|
addRaster: false,
|
|||
|
|
|||
|
/**
|
|||
|
mask (bool or object) the key is the second and the value is the path to the image
|
|||
|
Ex: mask:{ 0:'assets/mask-1.png', 5:'assets/mask-2.png', 30: false, 50:'assets/mask-3.png'}
|
|||
|
*/
|
|||
|
mask: false,
|
|||
|
|
|||
|
/**
|
|||
|
opacity (int)
|
|||
|
0 to 1
|
|||
|
*/
|
|||
|
opacity: 1,
|
|||
|
|
|||
|
/**
|
|||
|
quality (string)
|
|||
|
@deprecated
|
|||
|
|
|||
|
setPlaybackQuality has been deprecated on the YT API and doesn't work anymore
|
|||
|
“small”, “medium”, “large”, “hd720”, “hd1080”, “highres”, "default"
|
|||
|
*/
|
|||
|
quality: 'default',
|
|||
|
|
|||
|
/**
|
|||
|
vol (int)
|
|||
|
0 to 100
|
|||
|
*/
|
|||
|
vol: 50,
|
|||
|
|
|||
|
/**
|
|||
|
mute (bool)
|
|||
|
mute the video at start
|
|||
|
*/
|
|||
|
mute: false,
|
|||
|
|
|||
|
/**
|
|||
|
showControls (bool)
|
|||
|
shows the control bar at the bottom of the containment
|
|||
|
*/
|
|||
|
showControls: true,
|
|||
|
|
|||
|
/**
|
|||
|
anchor (string)
|
|||
|
center,top,bottom,left,right combined in pair
|
|||
|
*/
|
|||
|
anchor: 'center,center',
|
|||
|
|
|||
|
/**
|
|||
|
showAnnotations (bool)
|
|||
|
display the annotations on video
|
|||
|
*/
|
|||
|
showAnnotations: false,
|
|||
|
|
|||
|
/**
|
|||
|
cc_load_policy (bool)
|
|||
|
display the subtitles
|
|||
|
*/
|
|||
|
cc_load_policy: false,
|
|||
|
|
|||
|
/**
|
|||
|
showYTLogo (bool)
|
|||
|
display the Youtube logotype inside the button bar
|
|||
|
*/
|
|||
|
showYTLogo: true,
|
|||
|
|
|||
|
/**
|
|||
|
useOnMobile (bool)
|
|||
|
activate the player also on mobile
|
|||
|
*/
|
|||
|
useOnMobile: true,
|
|||
|
|
|||
|
/**
|
|||
|
playOnlyIfVisible (bool)
|
|||
|
play the video only if the containment is on screen
|
|||
|
*/
|
|||
|
playOnlyIfVisible: false,
|
|||
|
|
|||
|
/**
|
|||
|
onScreenPercentage (bool)
|
|||
|
percentage of the player height the video should stop or start when visible
|
|||
|
*/
|
|||
|
onScreenPercentage: 30,
|
|||
|
|
|||
|
/**
|
|||
|
* goFullScreenOnPlay (bool)
|
|||
|
* if the player containment is set to "self" this allow the video to go fullscreen when played
|
|||
|
*/
|
|||
|
goFullScreenOnPlay: false,
|
|||
|
|
|||
|
/**
|
|||
|
stopMovieOnBlur (bool)
|
|||
|
stop the video if the window loose the focus
|
|||
|
*/
|
|||
|
stopMovieOnBlur: true,
|
|||
|
|
|||
|
/**
|
|||
|
realfullscreen (bool)
|
|||
|
the video when in full screen covers all the display
|
|||
|
*/
|
|||
|
realFullscreen: true,
|
|||
|
|
|||
|
/**
|
|||
|
optimizeDisplay (bool)
|
|||
|
The video always fit the containment without displaying the black strips
|
|||
|
*/
|
|||
|
optimizeDisplay: true,
|
|||
|
|
|||
|
/**
|
|||
|
abundance (bool)
|
|||
|
the abudance of the video size
|
|||
|
*/
|
|||
|
abundance: 0.3,
|
|||
|
|
|||
|
/**
|
|||
|
gaTrack (bool)
|
|||
|
track the video plays on GA
|
|||
|
*/
|
|||
|
gaTrack: true,
|
|||
|
|
|||
|
/**
|
|||
|
remember_last_time (bool)
|
|||
|
when the page is reloaded the video will start from the last position
|
|||
|
*/
|
|||
|
remember_last_time: false,
|
|||
|
|
|||
|
/**
|
|||
|
addFilters (bool or string)
|
|||
|
add one or more CSS filters as object to the video
|
|||
|
Ex: {sepia: 50, hue_rotate : 220}
|
|||
|
*/
|
|||
|
addFilters: false,
|
|||
|
|
|||
|
/**
|
|||
|
useNoCookie (bool)
|
|||
|
use https://www.youtube-nocookie.com host to serve the video
|
|||
|
*/
|
|||
|
useNoCookie: true,
|
|||
|
|
|||
|
/**
|
|||
|
onReady (function)
|
|||
|
a callback function fired once the player is ready
|
|||
|
*/
|
|||
|
onReady: function (player) {
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
onReady (function)
|
|||
|
a callback function fired if there's an error
|
|||
|
*/
|
|||
|
onError: function (player, err) {
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
onEnd (function)
|
|||
|
a callback function fired when the video ends
|
|||
|
*/
|
|||
|
onEnd: function () {
|
|||
|
}
|
|||
|
},
|
|||
|
/**
|
|||
|
* @fontface icons
|
|||
|
* */
|
|||
|
controls : {
|
|||
|
play : 'P',
|
|||
|
pause : 'p',
|
|||
|
mute : 'M',
|
|||
|
unmute : 'A',
|
|||
|
onlyYT : 'O',
|
|||
|
showSite: 'R',
|
|||
|
ytLogo : 'Y'
|
|||
|
},
|
|||
|
controlBar : null,
|
|||
|
locationProtocol: 'https:',
|
|||
|
|
|||
|
/**
|
|||
|
* Applicable filters
|
|||
|
*/
|
|||
|
defaultFilters: {
|
|||
|
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'}
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* build the player
|
|||
|
* @param options
|
|||
|
* @returns [players]
|
|||
|
*/
|
|||
|
buildPlayer: function (options) {
|
|||
|
|
|||
|
if (!ytp.YTAPIReady && typeof window.YT === 'undefined') {
|
|||
|
jQuery('#YTAPI').remove();
|
|||
|
let tag = jQuery('<script>').attr({
|
|||
|
'src': 'https://www.youtube.com/iframe_api?v=' + jQuery.mbYTPlayer.version,
|
|||
|
'id' : 'YTAPI'
|
|||
|
});
|
|||
|
jQuery('head').prepend(tag)
|
|||
|
} else {
|
|||
|
setTimeout(function () {
|
|||
|
jQuery(document).trigger('YTAPIReady');
|
|||
|
ytp.YTAPIReady = true
|
|||
|
}, 100)
|
|||
|
}
|
|||
|
|
|||
|
function isIframe() {
|
|||
|
let isIfr = false;
|
|||
|
try {
|
|||
|
if (self.location.href !== top.location.href) isIfr = true
|
|||
|
} catch (e) {
|
|||
|
isIfr = true
|
|||
|
}
|
|||
|
return isIfr
|
|||
|
}
|
|||
|
|
|||
|
return this.each(function () {
|
|||
|
let YTPlayer = this;
|
|||
|
let $YTPlayer = jQuery(YTPlayer);
|
|||
|
$YTPlayer.hide();
|
|||
|
YTPlayer.loop = 0;
|
|||
|
YTPlayer.state = 0;
|
|||
|
YTPlayer.filters = jQuery.extend(true, {}, jQuery.mbYTPlayer.defaultFilters);
|
|||
|
YTPlayer.filtersEnabled = true;
|
|||
|
YTPlayer.id = YTPlayer.id || 'YTP_' + new Date().getTime();
|
|||
|
$YTPlayer.addClass('mb_YTPlayer');
|
|||
|
|
|||
|
/**
|
|||
|
Set properties
|
|||
|
*/
|
|||
|
let property = $YTPlayer.data('property') && typeof $YTPlayer.data('property') == 'string' ?
|
|||
|
eval('(' + $YTPlayer.data('property') + ')') :
|
|||
|
$YTPlayer.data('property');
|
|||
|
|
|||
|
if (typeof property !== 'object')
|
|||
|
property = {};
|
|||
|
|
|||
|
YTPlayer.opt = jQuery.extend(true, {}, jQuery.mbYTPlayer.defaults, YTPlayer.opt, options, property);
|
|||
|
|
|||
|
YTPRndSuffix = getYTPVideoID(YTPlayer.opt.videoURL).videoID;
|
|||
|
YTPTimerLabels = {
|
|||
|
init : "YTPlayerInit_" + YTPRndSuffix,
|
|||
|
startPlaying: "YTPlayerStartPlay_" + YTPRndSuffix
|
|||
|
};
|
|||
|
|
|||
|
console.time(YTPTimerLabels.init);
|
|||
|
console.time(YTPTimerLabels.startPlaying);
|
|||
|
|
|||
|
YTPlayer.opt.elementId = YTPlayer.id;
|
|||
|
|
|||
|
if (YTPlayer.opt.vol === 0) {
|
|||
|
YTPlayer.opt.vol = 1;
|
|||
|
YTPlayer.opt.mute = true
|
|||
|
}
|
|||
|
|
|||
|
if (YTPlayer.opt.loop && typeof YTPlayer.opt.loop === 'boolean') {
|
|||
|
YTPlayer.opt.loop = 9999
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
Disable fullScreen if is in an iframe or full-screen API is not available
|
|||
|
*/
|
|||
|
let fullScreenAvailable = document.fullscreenEnabled || document.webkitFullscreenEnabled || document.mozFullScreenEnabled || document.msFullscreenEnabled;
|
|||
|
YTPlayer.opt.realFullscreen = isIframe() || !fullScreenAvailable ? false : YTPlayer.opt.realFullscreen;
|
|||
|
|
|||
|
/**
|
|||
|
Manage annotations
|
|||
|
*/
|
|||
|
YTPlayer.opt.showAnnotations = YTPlayer.opt.showAnnotations ? '1' : '3';
|
|||
|
|
|||
|
/**
|
|||
|
Manage show subtitle and caption
|
|||
|
*/
|
|||
|
YTPlayer.opt.cc_load_policy = YTPlayer.opt.cc_load_policy ? '1' : '0';
|
|||
|
|
|||
|
/**
|
|||
|
Manage cover image
|
|||
|
*/
|
|||
|
YTPlayer.opt.coverImage = YTPlayer.opt.coverImage || YTPlayer.opt.backgroundImage;
|
|||
|
|
|||
|
/**
|
|||
|
Manage Quality
|
|||
|
the setPlaybackQuality has been deprecated by YT
|
|||
|
*/
|
|||
|
YTPlayer.opt.quality = 'hd1080';
|
|||
|
|
|||
|
YTPlayer.opt.containment = YTPlayer.opt.containment === 'self' ? $YTPlayer : jQuery(YTPlayer.opt.containment);
|
|||
|
YTPlayer.isRetina = (window.retina || window.devicePixelRatio > 1);
|
|||
|
|
|||
|
YTPlayer.opt.ratio = YTPlayer.opt.ratio === 'auto' ? 16 / 9 : YTPlayer.opt.ratio;
|
|||
|
YTPlayer.opt.ratio = eval(YTPlayer.opt.ratio);
|
|||
|
|
|||
|
let origContainmentBackground = YTPlayer.opt.containment.css('background-image');
|
|||
|
origContainmentBackground = (origContainmentBackground === 'none') ? null : origContainmentBackground;
|
|||
|
YTPlayer.orig_containment_background = origContainmentBackground;
|
|||
|
|
|||
|
if (!$YTPlayer.attr('id'))
|
|||
|
$YTPlayer.attr('id', 'ytp_' + new Date().getTime());
|
|||
|
|
|||
|
YTPlayer.playerID = 'iframe_' + YTPlayer.id;
|
|||
|
|
|||
|
YTPlayer.isAlone = false;
|
|||
|
YTPlayer.hasFocus = true;
|
|||
|
YTPlayer.videoID = YTPlayer.opt.videoURL ?
|
|||
|
getYTPVideoID(YTPlayer.opt.videoURL).videoID : $YTPlayer.attr('href') ?
|
|||
|
getYTPVideoID($YTPlayer.attr('href')).videoID :
|
|||
|
false;
|
|||
|
|
|||
|
/**
|
|||
|
Check if it is a video list
|
|||
|
*/
|
|||
|
YTPlayer.playlistID = YTPlayer.opt.videoURL ?
|
|||
|
getYTPVideoID(YTPlayer.opt.videoURL).playlistID : $YTPlayer.attr('href') ?
|
|||
|
getYTPVideoID($YTPlayer.attr('href')).playlistID :
|
|||
|
false;
|
|||
|
|
|||
|
let start_from_last = 0;
|
|||
|
if (jQuery.mbCookie.get('YTPlayer_start_from' + YTPlayer.videoID))
|
|||
|
start_from_last = parseFloat(jQuery.mbCookie.get('YTPlayer_start_from' + YTPlayer.videoID));
|
|||
|
if (YTPlayer.opt.remember_last_time && start_from_last) {
|
|||
|
YTPlayer.start_from_last = start_from_last;
|
|||
|
jQuery.mbCookie.remove('YTPlayer_start_from' + YTPlayer.videoID)
|
|||
|
}
|
|||
|
|
|||
|
YTPlayer.isPlayer = $YTPlayer.is(YTPlayer.opt.containment);
|
|||
|
YTPlayer.isBackground = YTPlayer.opt.containment.is('body');
|
|||
|
|
|||
|
if (YTPlayer.isBackground && ytp.backgroundIsInited)
|
|||
|
return;
|
|||
|
|
|||
|
/**
|
|||
|
Hide the placeholder if it's not the target of the player
|
|||
|
*/
|
|||
|
if (YTPlayer.isPlayer)
|
|||
|
$YTPlayer.show();
|
|||
|
|
|||
|
/**
|
|||
|
create the overlay
|
|||
|
*/
|
|||
|
YTPlayer.overlay = jQuery('<div/>').css({
|
|||
|
position: 'absolute',
|
|||
|
top : 0,
|
|||
|
left : 0,
|
|||
|
width : '100%',
|
|||
|
height : '100%'
|
|||
|
}).addClass('YTPOverlay');
|
|||
|
|
|||
|
$YTPlayer.changeCoverImage();
|
|||
|
|
|||
|
/**
|
|||
|
create the wrapper
|
|||
|
*/
|
|||
|
YTPlayer.wrapper = jQuery('<div/>').attr('id', 'wrapper_' + YTPlayer.id).css({
|
|||
|
position : 'absolute',
|
|||
|
zIndex : 0,
|
|||
|
minWidth : '100%',
|
|||
|
minHeight: '100%',
|
|||
|
left : 0,
|
|||
|
top : 0,
|
|||
|
overflow : 'hidden',
|
|||
|
opacity : 0
|
|||
|
}).addClass('mbYTP_wrapper');
|
|||
|
|
|||
|
/**
|
|||
|
If is an inline player toggle play if the overlay is clicked
|
|||
|
*/
|
|||
|
if (YTPlayer.isPlayer) {
|
|||
|
let inlinePlayButtonCss = jQuery.mbBrowser.mobile ? "inlinePlayButtonMobile" : "inlinePlayButton";
|
|||
|
YTPlayer.inlinePlayButton = jQuery('<div/>').addClass(inlinePlayButtonCss).html(jQuery.mbYTPlayer.controls.play);
|
|||
|
$YTPlayer.append(YTPlayer.inlinePlayButton);
|
|||
|
YTPlayer.inlinePlayButton.on('click', function (e) {
|
|||
|
|
|||
|
$YTPlayer.YTPPlay();
|
|||
|
/**
|
|||
|
* Hide the PLAY button on play
|
|||
|
*/
|
|||
|
YTPlayer.inlinePlayButton.hide();
|
|||
|
|
|||
|
/**
|
|||
|
* set the fullscreen on play
|
|||
|
*/
|
|||
|
if (YTPlayer.opt.goFullScreenOnPlay) {
|
|||
|
$YTPlayer.YTPFullscreen();
|
|||
|
}
|
|||
|
|
|||
|
e.stopPropagation()
|
|||
|
});
|
|||
|
|
|||
|
if (YTPlayer.opt.autoPlay)
|
|||
|
YTPlayer.inlinePlayButton.hide();
|
|||
|
|
|||
|
YTPlayer.overlay.on('click', function () {
|
|||
|
$YTPlayer.YTPTogglePlay();
|
|||
|
|
|||
|
if (YTPlayer.opt.goFullScreenOnPlay) {
|
|||
|
$YTPlayer.YTPFullscreen();
|
|||
|
}
|
|||
|
|
|||
|
}).css({cursor: 'pointer'})
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
create the playerBox where the YT iframe will be placed
|
|||
|
*/
|
|||
|
let playerBox = jQuery('<div/>').attr('id', YTPlayer.playerID).addClass('playerBox');
|
|||
|
playerBox.css({
|
|||
|
position: 'absolute',
|
|||
|
zIndex : 0,
|
|||
|
width : '100%',
|
|||
|
height : '100%',
|
|||
|
top : 0,
|
|||
|
left : 0,
|
|||
|
overflow: 'hidden',
|
|||
|
opacity : 1
|
|||
|
});
|
|||
|
|
|||
|
YTPlayer.wrapper.append(playerBox);
|
|||
|
playerBox.after(YTPlayer.overlay);
|
|||
|
|
|||
|
if (YTPlayer.isPlayer) {
|
|||
|
YTPlayer.inlineWrapper = jQuery('<div/>').addClass('inline-YTPlayer');
|
|||
|
|
|||
|
YTPlayer.inlineWrapper.css({
|
|||
|
position: 'relative',
|
|||
|
maxWidth: YTPlayer.opt.containment.css('width')
|
|||
|
});
|
|||
|
|
|||
|
YTPlayer.opt.containment.css({
|
|||
|
position : 'relative',
|
|||
|
paddingBottom: '56.25%',
|
|||
|
overflow : 'hidden',
|
|||
|
height : 0
|
|||
|
});
|
|||
|
YTPlayer.opt.containment.wrap(YTPlayer.inlineWrapper)
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
Loop all the elements inside the container and check if their position is not "static"
|
|||
|
*/
|
|||
|
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'
|
|||
|
});
|
|||
|
|
|||
|
YTPlayer.wrapper.css({
|
|||
|
position: 'fixed',
|
|||
|
top : 0,
|
|||
|
left : 0,
|
|||
|
zIndex : 0
|
|||
|
})
|
|||
|
|
|||
|
} else if (YTPlayer.opt.containment.css('position') === 'static') {
|
|||
|
|
|||
|
YTPlayer.opt.containment.css({
|
|||
|
position: 'relative'
|
|||
|
});
|
|||
|
$YTPlayer.show()
|
|||
|
}
|
|||
|
YTPlayer.opt.containment.prepend(YTPlayer.wrapper);
|
|||
|
|
|||
|
if (!YTPlayer.isBackground) {
|
|||
|
YTPlayer.overlay.on('mouseenter', function () {
|
|||
|
if (YTPlayer.controlBar && YTPlayer.controlBar.length)
|
|||
|
YTPlayer.controlBar.addClass('visible')
|
|||
|
}).on('mouseleave', function () {
|
|||
|
if (YTPlayer.controlBar && YTPlayer.controlBar.length)
|
|||
|
YTPlayer.controlBar.removeClass('visible')
|
|||
|
})
|
|||
|
}
|
|||
|
|
|||
|
if (jQuery.mbBrowser.mobile && !YTPlayer.opt.useOnMobile) {
|
|||
|
if (YTPlayer.opt.coverImage) {
|
|||
|
YTPlayer.wrapper.css({
|
|||
|
backgroundImage : 'url(' + YTPlayer.opt.coverImage + ')',
|
|||
|
backgroundPosition: 'center center',
|
|||
|
backgroundSize : 'cover',
|
|||
|
backgroundRepeat : 'no-repeat',
|
|||
|
opacity : 1
|
|||
|
});
|
|||
|
|
|||
|
YTPlayer.wrapper.css({opacity: 1})
|
|||
|
}
|
|||
|
return $YTPlayer
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
If is on device start playing on first touch
|
|||
|
*/
|
|||
|
if (jQuery.mbBrowser.mobile && YTPlayer.opt.autoPlay && YTPlayer.opt.useOnMobile)
|
|||
|
jQuery('body').one('touchstart', function () {
|
|||
|
YTPlayer.player.playVideo()
|
|||
|
});
|
|||
|
|
|||
|
jQuery(document).one('YTAPIReady', function () {
|
|||
|
$YTPlayer.trigger('YTAPIReady_' + YTPlayer.id);
|
|||
|
ytp.YTAPIReady = true
|
|||
|
});
|
|||
|
|
|||
|
YTPlayer.isOnScreen = jQuery.mbYTPlayer.isOnScreen(YTPlayer, YTPlayer.opt.onScreenPercentage);
|
|||
|
|
|||
|
$YTPlayer.one('YTAPIReady_' + YTPlayer.id, function () {
|
|||
|
|
|||
|
let YTPlayer = this;
|
|||
|
let $YTPlayer = jQuery(YTPlayer);
|
|||
|
|
|||
|
if ((YTPlayer.isBackground && ytp.backgroundIsInited) || YTPlayer.isInit)
|
|||
|
return;
|
|||
|
|
|||
|
if (YTPlayer.isBackground)
|
|||
|
ytp.backgroundIsInited = true;
|
|||
|
|
|||
|
YTPlayer.opt.autoPlay = typeof YTPlayer.opt.autoPlay == 'undefined' ? (!!YTPlayer.isBackground) : YTPlayer.opt.autoPlay;
|
|||
|
YTPlayer.opt.vol = YTPlayer.opt.vol ? YTPlayer.opt.vol : 100;
|
|||
|
|
|||
|
jQuery.mbYTPlayer.getDataFromAPI(YTPlayer);
|
|||
|
|
|||
|
jQuery(YTPlayer).on('YTPChanged', function (e) {
|
|||
|
|
|||
|
if (YTPlayer.isInit)
|
|||
|
return;
|
|||
|
|
|||
|
YTPlayer.isInit = true;
|
|||
|
|
|||
|
/** Initialize the YT player ------------------------------------
|
|||
|
* Youtube player variables
|
|||
|
* @type {{modestbranding: number, autoplay: number, controls: number, showinfo: number, rel: number, enablejsapi: number, version: number, playerapiid: string, origin: string, allowfullscreen: boolean, iv_load_policy: (string|*|jQuery.mbYTPlayer.opt.showAnnotations), playsinline: number}}
|
|||
|
*/
|
|||
|
let playerVars = {
|
|||
|
'modestbranding' : 1,
|
|||
|
'autoplay' : 0,
|
|||
|
'controls' : 0,
|
|||
|
'showinfo' : 0,
|
|||
|
'rel' : 0,
|
|||
|
'enablejsapi' : 1,
|
|||
|
'version' : 3,
|
|||
|
'playerapiid' : YTPlayer.playerID,
|
|||
|
'origin' : '*',
|
|||
|
'allowfullscreen': true,
|
|||
|
'wmode' : 'transparent',
|
|||
|
'iv_load_policy' : YTPlayer.opt.showAnnotations,
|
|||
|
'cc_load_policy' : YTPlayer.opt.cc_load_policy,
|
|||
|
'playsinline' : jQuery.mbBrowser.mobile && !YTPlayer.isPlayer ? 1 : 0,
|
|||
|
|
|||
|
/**
|
|||
|
Check if the mbBrowser can play HTML5 videos
|
|||
|
*/
|
|||
|
'html5': document.createElement('video').canPlayType ? 1 : 0
|
|||
|
};
|
|||
|
|
|||
|
new YT.Player(YTPlayer.playerID, {
|
|||
|
//videoId: YTPlayer.videoID.toString(),
|
|||
|
host : YTPlayer.opt.useNoCookie ? 'https://www.youtube-nocookie.com' : 'https://www.youtube.com',
|
|||
|
playerVars: playerVars,
|
|||
|
events : {
|
|||
|
'onReady' : function (event) {
|
|||
|
YTPlayer.player = event.target;
|
|||
|
YTPlayer.player.loadVideoById({
|
|||
|
videoId : YTPlayer.videoID.toString(),
|
|||
|
suggestedQuality: YTPlayer.opt.quality
|
|||
|
});
|
|||
|
|
|||
|
$YTPlayer.trigger('YTPlayerIsReady_' + YTPlayer.id)
|
|||
|
},
|
|||
|
/**
|
|||
|
* on State Change
|
|||
|
* @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;
|
|||
|
|
|||
|
let state = event.target.getPlayerState();
|
|||
|
|
|||
|
if (YTPlayer.preventTrigger || YTPlayer.isStarting) {
|
|||
|
YTPlayer.preventTrigger = false;
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
YTPlayer.state = state;
|
|||
|
// console.debug(YTPlayer.state);
|
|||
|
|
|||
|
if (event.data === YT.PlayerState.PLAYING) {
|
|||
|
event.target.setPlaybackQuality(YTPlayer.opt.quality)
|
|||
|
}
|
|||
|
|
|||
|
let eventType;
|
|||
|
switch (state) {
|
|||
|
|
|||
|
/** unstarted */
|
|||
|
case -1:
|
|||
|
eventType = 'YTPUnstarted';
|
|||
|
break;
|
|||
|
|
|||
|
/** unstarted */
|
|||
|
case 0:
|
|||
|
eventType = 'YTPRealEnd';
|
|||
|
break;
|
|||
|
|
|||
|
/** play */
|
|||
|
case 1:
|
|||
|
eventType = 'YTPPlay';
|
|||
|
if (YTPlayer.controlBar.length)
|
|||
|
YTPlayer.controlBar.find('.mb_YTPPlayPause').html(jQuery.mbYTPlayer.controls.pause);
|
|||
|
|
|||
|
if (YTPlayer.isPlayer)
|
|||
|
YTPlayer.inlinePlayButton.hide();
|
|||
|
|
|||
|
jQuery(document).off('mousedown.YTPstart');
|
|||
|
break;
|
|||
|
|
|||
|
/** pause */
|
|||
|
case 2:
|
|||
|
eventType = 'YTPPause';
|
|||
|
if (YTPlayer.controlBar.length)
|
|||
|
YTPlayer.controlBar.find('.mb_YTPPlayPause').html(jQuery.mbYTPlayer.controls.play);
|
|||
|
|
|||
|
if (YTPlayer.isPlayer)
|
|||
|
YTPlayer.inlinePlayButton.show();
|
|||
|
break;
|
|||
|
|
|||
|
/** buffer */
|
|||
|
case 3:
|
|||
|
// YTPlayer.player.setPlaybackQuality('default');
|
|||
|
YTPlayer.player.setPlaybackQuality(YTPlayer.opt.quality);
|
|||
|
eventType = 'YTPBuffering';
|
|||
|
if (YTPlayer.controlBar.length)
|
|||
|
YTPlayer.controlBar.find('.mb_YTPPlayPause').html(jQuery.mbYTPlayer.controls.play);
|
|||
|
break;
|
|||
|
|
|||
|
/** cued */
|
|||
|
case 5:
|
|||
|
eventType = 'YTPCued';
|
|||
|
break;
|
|||
|
|
|||
|
default:
|
|||
|
break
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
Trigger state events
|
|||
|
*/
|
|||
|
let YTPEvent = jQuery.Event(eventType);
|
|||
|
YTPEvent.time = YTPlayer.currentTime;
|
|||
|
jQuery(YTPlayer).trigger(YTPEvent)
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* onPlaybackQualityChange
|
|||
|
* @param e
|
|||
|
*/
|
|||
|
'onPlaybackQualityChange': function (e) {
|
|||
|
let quality = e.target.getPlaybackQuality();
|
|||
|
let YTPQualityChange = jQuery.Event('YTPQualityChange');
|
|||
|
YTPQualityChange.quality = quality;
|
|||
|
jQuery(YTPlayer).trigger(YTPQualityChange)
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* onError
|
|||
|
* @param err
|
|||
|
*
|
|||
|
2 – The request contains an invalid parameter value. For example, this error occurs if you specify a video ID that does not have 11 characters, or if the video ID contains invalid characters, such as exclamation points or asterisks.
|
|||
|
5 – The requested content cannot be played in an HTML5 player or another error related to the HTML5 player has occurred.
|
|||
|
100 – The video requested was not found. This error occurs when a video has been removed (for any reason) or has been marked as private.
|
|||
|
101 – The owner of the requested video does not allow it to be played in embedded players.
|
|||
|
150 – This error is the same as 101. It's just a 101 error in disguise!
|
|||
|
*/
|
|||
|
'onError': function (err) {
|
|||
|
|
|||
|
if (typeof YTPlayer.opt.onError == 'function')
|
|||
|
YTPlayer.opt.onError($YTPlayer, err);
|
|||
|
|
|||
|
console.debug("error:", err);
|
|||
|
|
|||
|
switch (err.data) {
|
|||
|
case 2:
|
|||
|
console.error('video ID:: ' + YTPlayer.videoID + ': The request contains an invalid parameter value. For example, this error occurs if you specify a video ID that does not have 11 characters, or if the video ID contains invalid characters, such as exclamation points or asterisks.');
|
|||
|
break;
|
|||
|
case 5:
|
|||
|
console.error('video ID:: ' + YTPlayer.videoID + ': The requested content cannot be played in an HTML5 player or another error related to the HTML5 player has occurred.');
|
|||
|
break;
|
|||
|
case 100:
|
|||
|
console.error('video ID:: ' + YTPlayer.videoID + ': The video requested was not found. This error occurs when a video has been removed (for any reason) or has been marked as private.');
|
|||
|
break;
|
|||
|
case 101:
|
|||
|
case 150:
|
|||
|
console.error('video ID:: ' + YTPlayer.videoID + ': The video doesn\'t exist or The owner does not allow it to be played in embedded players.');
|
|||
|
break
|
|||
|
}
|
|||
|
|
|||
|
if (YTPlayer.isList)
|
|||
|
jQuery(YTPlayer).YTPPlayNext()
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
$YTPlayer.on('YTPlayerIsReady_' + YTPlayer.id, function () {
|
|||
|
|
|||
|
if (YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
YTPlayer.playerEl = YTPlayer.player.getIframe();
|
|||
|
jQuery(YTPlayer.playerEl).unselectable();
|
|||
|
$YTPlayer.optimizeDisplay();
|
|||
|
|
|||
|
/**
|
|||
|
* Optimize display on resize
|
|||
|
*/
|
|||
|
jQuery(window).off('resize.YTP_' + YTPlayer.id).on('resize.YTP_' + YTPlayer.id, function () {
|
|||
|
$YTPlayer.optimizeDisplay()
|
|||
|
});
|
|||
|
|
|||
|
/**
|
|||
|
* Optimize display on orientation change
|
|||
|
*/
|
|||
|
jQuery(window).off('orientationchange.YTP_' + YTPlayer.id).on('orientationchange.YTP_' + YTPlayer.id, function () {
|
|||
|
$YTPlayer.optimizeDisplay()
|
|||
|
});
|
|||
|
|
|||
|
/**
|
|||
|
* Set the time of the last visit progress
|
|||
|
*/
|
|||
|
if (YTPlayer.opt.remember_last_time) {
|
|||
|
jQuery(window).on('unload.YTP_' + YTPlayer.id, function () {
|
|||
|
let current_time = YTPlayer.player.getCurrentTime();
|
|||
|
jQuery.mbCookie.set('YTPlayer_start_from' + YTPlayer.videoID, current_time, 0)
|
|||
|
})
|
|||
|
}
|
|||
|
|
|||
|
$YTPlayer.YTPCheckForState()
|
|||
|
|
|||
|
})
|
|||
|
})
|
|||
|
});
|
|||
|
|
|||
|
$YTPlayer.off('YTPTime.mask');
|
|||
|
jQuery.mbYTPlayer.applyMask(YTPlayer);
|
|||
|
|
|||
|
console.timeEnd(YTPTimerLabels.init);
|
|||
|
|
|||
|
setTimeout(function () {
|
|||
|
if (!ytp.YTAPIReady && typeof window.YT == "object") {
|
|||
|
jQuery(document).trigger('YTAPIReady');
|
|||
|
ytp.YTAPIReady = true;
|
|||
|
console.error("YTPlayer: More then a call to the YT API has been detected")
|
|||
|
}
|
|||
|
}, YTPlayer.opt.delayAtStart)
|
|||
|
})
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
*
|
|||
|
* @param YTPlayer
|
|||
|
* @param perc
|
|||
|
* @returns {boolean}
|
|||
|
*/
|
|||
|
isOnScreen: function (YTPlayer, perc) {
|
|||
|
perc = perc || 10;
|
|||
|
let playerBox = YTPlayer.wrapper;
|
|||
|
let winTop = jQuery(window).scrollTop();
|
|||
|
let winBottom = winTop + jQuery(window).height();
|
|||
|
|
|||
|
let margin = (playerBox.height() * perc) / 100;
|
|||
|
let elTop = playerBox.offset().top + margin;
|
|||
|
let elBottom = playerBox.offset().top + (playerBox.height() - margin);
|
|||
|
|
|||
|
return ((elBottom <= winBottom) && (elTop >= winTop))
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getDataFromAPI
|
|||
|
* @param YTPlayer
|
|||
|
*/
|
|||
|
getDataFromAPI: function (YTPlayer) {
|
|||
|
|
|||
|
YTPlayer.videoData = jQuery.mbStorage.get('YTPlayer_data_' + YTPlayer.videoID);
|
|||
|
if (YTPlayer.videoData) {
|
|||
|
setTimeout(function () {
|
|||
|
YTPlayer.dataReceived = true;
|
|||
|
|
|||
|
let YTPChanged = jQuery.Event('YTPChanged');
|
|||
|
YTPChanged.time = YTPlayer.currentTime;
|
|||
|
YTPChanged.videoId = YTPlayer.videoID;
|
|||
|
YTPChanged.opt = YTPlayer.opt;
|
|||
|
|
|||
|
//console.debug("videoData:",YTPlayer.videoData)
|
|||
|
|
|||
|
jQuery(YTPlayer).trigger(YTPChanged);
|
|||
|
|
|||
|
let YTPData = jQuery.Event('YTPData');
|
|||
|
YTPData.prop = {};
|
|||
|
|
|||
|
for (let x in YTPlayer.videoData)
|
|||
|
if (YTPlayer.videoData.hasOwnProperty(x))
|
|||
|
YTPData.prop[x] = YTPlayer.videoData[x];
|
|||
|
|
|||
|
jQuery(YTPlayer).trigger(YTPData)
|
|||
|
|
|||
|
}, YTPlayer.opt.fadeOnStartTime);
|
|||
|
|
|||
|
YTPlayer.hasData = true
|
|||
|
|
|||
|
} else if (jQuery.mbYTPlayer.apiKey) {
|
|||
|
|
|||
|
/**
|
|||
|
* Get video info from API3 (needs api key)
|
|||
|
* snippet,player,contentDetails,statistics,status
|
|||
|
*/
|
|||
|
|
|||
|
jQuery.getJSON('https://www.googleapis.com/youtube/v3/videos?id=' + YTPlayer.videoID + '&key=' + jQuery.mbYTPlayer.apiKey + '&part=snippet', function (data) {
|
|||
|
YTPlayer.dataReceived = true;
|
|||
|
|
|||
|
let YTPChanged = jQuery.Event('YTPChanged');
|
|||
|
YTPChanged.time = YTPlayer.currentTime;
|
|||
|
YTPChanged.videoId = YTPlayer.videoID;
|
|||
|
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.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)
|
|||
|
}
|
|||
|
|
|||
|
if (!data.items[0]) {
|
|||
|
YTPlayer.videoData = {};
|
|||
|
YTPlayer.hasData = false
|
|||
|
} else {
|
|||
|
parseYTPlayer_data(data.items[0].snippet);
|
|||
|
YTPlayer.hasData = true
|
|||
|
}
|
|||
|
|
|||
|
let YTPData = jQuery.Event('YTPData');
|
|||
|
YTPData.prop = {};
|
|||
|
for (let x in YTPlayer.videoData)
|
|||
|
YTPData.prop[x] = YTPlayer.videoData[x];
|
|||
|
|
|||
|
jQuery(YTPlayer).trigger(YTPData)
|
|||
|
})
|
|||
|
.fail(function (jqxhr) {
|
|||
|
console.error("YT data error:: ", jqxhr);
|
|||
|
YTPlayer.hasData = false;
|
|||
|
|
|||
|
let YTPChanged = jQuery.Event('YTPChanged');
|
|||
|
YTPChanged.time = YTPlayer.currentTime;
|
|||
|
YTPChanged.videoId = YTPlayer.videoID;
|
|||
|
jQuery(YTPlayer).trigger(YTPChanged)
|
|||
|
})
|
|||
|
} else {
|
|||
|
|
|||
|
setTimeout(function () {
|
|||
|
let YTPChanged = jQuery.Event('YTPChanged');
|
|||
|
YTPChanged.time = YTPlayer.currentTime;
|
|||
|
YTPChanged.videoId = YTPlayer.videoID;
|
|||
|
jQuery(YTPlayer).trigger(YTPChanged)
|
|||
|
}, 10);
|
|||
|
YTPlayer.videoData = null
|
|||
|
}
|
|||
|
|
|||
|
YTPlayer.opt.ratio = YTPlayer.opt.ratio == 'auto' ? 16 / 9 : YTPlayer.opt.ratio;
|
|||
|
|
|||
|
if (YTPlayer.isPlayer && !YTPlayer.opt.autoPlay) { //&& ( !jQuery.mbBrowser.mobile && !jQuery.isTablet )
|
|||
|
YTPlayer.loading = jQuery('<div/>').addClass('loading').html('Loading').hide();
|
|||
|
jQuery(YTPlayer).append(YTPlayer.loading);
|
|||
|
YTPlayer.loading.fadeIn()
|
|||
|
}
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* removeStoredData
|
|||
|
*/
|
|||
|
removeStoredData: function () {
|
|||
|
jQuery.mbStorage.remove()
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getVideoData
|
|||
|
* @returns {*|YTPlayer.videoData}
|
|||
|
*/
|
|||
|
getVideoData: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
return YTPlayer.videoData
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getVideoID
|
|||
|
* @returns {*|YTPlayer.videoID|boolean}
|
|||
|
*/
|
|||
|
getVideoID: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
return YTPlayer.videoID || false
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getPlaylistID
|
|||
|
* @returns {*|YTPlayer.videoID|boolean}
|
|||
|
*/
|
|||
|
getPlaylistID : function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
return YTPlayer.playlistID || false
|
|||
|
},
|
|||
|
/**
|
|||
|
* setVideoQuality
|
|||
|
* @deprecated
|
|||
|
*
|
|||
|
* @param quality
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
setVideoQuality: function (quality) {
|
|||
|
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let time = YTPlayer.player.getCurrentTime();
|
|||
|
jQuery(YTPlayer).YTPPause();
|
|||
|
YTPlayer.opt.quality = quality;
|
|||
|
YTPlayer.player.setPlaybackQuality(quality);
|
|||
|
YTPlayer.player.seekTo(time); // or set to CurrentTime using player.getCurrentTime()
|
|||
|
jQuery(YTPlayer).YTPPlay();
|
|||
|
return this;
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getVideoQuality
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
getVideoQuality: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let quality = YTPlayer.player.getPlaybackQuality();
|
|||
|
return quality
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* playlist
|
|||
|
* @param videos -> Array or String (videoList ID)
|
|||
|
* @param shuffle
|
|||
|
* @param callback
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*
|
|||
|
* To retrieve a Youtube playlist the Youtube API key is required:
|
|||
|
* https://console.developers.google.com/
|
|||
|
* jQuery.mbYTPlayer.apiKey
|
|||
|
*/
|
|||
|
playlist: function (videos, shuffle, callback) {
|
|||
|
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
YTPlayer.isList = true;
|
|||
|
|
|||
|
if (shuffle)
|
|||
|
videos = jQuery.shuffle(videos);
|
|||
|
|
|||
|
if (!YTPlayer.videoID) {
|
|||
|
YTPlayer.videos = videos;
|
|||
|
YTPlayer.videoCounter = 1;
|
|||
|
YTPlayer.videoLength = videos.length;
|
|||
|
jQuery(YTPlayer).data('property', videos[0]);
|
|||
|
jQuery(YTPlayer).YTPlayer()
|
|||
|
}
|
|||
|
|
|||
|
if (typeof callback == 'function')
|
|||
|
jQuery(YTPlayer).on('YTPChanged', function () {
|
|||
|
callback(YTPlayer)
|
|||
|
});
|
|||
|
|
|||
|
jQuery(YTPlayer).on('YTPEnd', function () {
|
|||
|
jQuery(YTPlayer).YTPPlayNext()
|
|||
|
});
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* playNext
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
playNext: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
YTPlayer.videoCounter++;
|
|||
|
if (YTPlayer.videoCounter > YTPlayer.videoLength)
|
|||
|
YTPlayer.videoCounter = 1;
|
|||
|
jQuery(YTPlayer).YTPPlayIndex(YTPlayer.videoCounter);
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* playPrev
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
playPrev: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
YTPlayer.videoCounter--;
|
|||
|
if (YTPlayer.videoCounter <= 0)
|
|||
|
YTPlayer.videoCounter = YTPlayer.videoLength;
|
|||
|
jQuery(YTPlayer).YTPPlayIndex(YTPlayer.videoCounter);
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* playIndex
|
|||
|
* @param idx
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
playIndex: function (idx) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
if (YTPlayer.checkForStartAt) {
|
|||
|
clearInterval(YTPlayer.checkForStartAt);
|
|||
|
clearInterval(YTPlayer.getState)
|
|||
|
}
|
|||
|
YTPlayer.videoCounter = idx;
|
|||
|
|
|||
|
if (YTPlayer.videoCounter >= YTPlayer.videoLength)
|
|||
|
YTPlayer.videoCounter = YTPlayer.videoLength;
|
|||
|
|
|||
|
let video = YTPlayer.videos[YTPlayer.videoCounter - 1];
|
|||
|
|
|||
|
jQuery(YTPlayer).YTPChangeVideo(video);
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* changeVideo
|
|||
|
* @param opt
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
changeVideo: function (opt) {
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
YTPlayer.opt.startAt = 0;
|
|||
|
YTPlayer.opt.stopAt = 0;
|
|||
|
YTPlayer.opt.mask = false;
|
|||
|
YTPlayer.opt.mute = true;
|
|||
|
YTPlayer.opt.autoPlay = true;
|
|||
|
YTPlayer.opt.addFilters = false;
|
|||
|
YTPlayer.opt.coverImage = false;
|
|||
|
|
|||
|
YTPlayer.hasData = false;
|
|||
|
YTPlayer.hasChanged = true;
|
|||
|
|
|||
|
YTPlayer.player.loopTime = undefined;
|
|||
|
|
|||
|
if (opt)
|
|||
|
jQuery.extend(YTPlayer.opt, opt);
|
|||
|
|
|||
|
YTPlayer.videoID = getYTPVideoID(YTPlayer.opt.videoURL).videoID;
|
|||
|
|
|||
|
if (YTPlayer.opt.loop && typeof YTPlayer.opt.loop == 'boolean')
|
|||
|
YTPlayer.opt.loop = 9999;
|
|||
|
|
|||
|
YTPlayer.wrapper.css({
|
|||
|
background: 'none'
|
|||
|
});
|
|||
|
|
|||
|
jQuery(YTPlayer.playerEl).CSSAnimate({
|
|||
|
opacity: 0
|
|||
|
}, YTPlayer.opt.fadeOnStartTime, function () {
|
|||
|
|
|||
|
jQuery.mbYTPlayer.getDataFromAPI(YTPlayer);
|
|||
|
|
|||
|
$YTPlayer.YTPGetPlayer().loadVideoById({
|
|||
|
videoId : YTPlayer.videoID,
|
|||
|
suggestedQuality: YTPlayer.opt.quality
|
|||
|
});
|
|||
|
|
|||
|
$YTPlayer.YTPPause();
|
|||
|
$YTPlayer.optimizeDisplay();
|
|||
|
|
|||
|
if (YTPlayer.checkForStartAt) {
|
|||
|
clearInterval(YTPlayer.checkForStartAt);
|
|||
|
clearInterval(YTPlayer.getState)
|
|||
|
}
|
|||
|
$YTPlayer.YTPCheckForState()
|
|||
|
});
|
|||
|
|
|||
|
let YTPChangeVideo = jQuery.Event('YTPChangeVideo');
|
|||
|
YTPChangeVideo.time = YTPlayer.currentTime;
|
|||
|
jQuery(YTPlayer).trigger(YTPChangeVideo);
|
|||
|
|
|||
|
jQuery.mbYTPlayer.applyMask(YTPlayer);
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getPlayer
|
|||
|
* @returns {player}
|
|||
|
*/
|
|||
|
getPlayer: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
return !YTPlayer.isReady ? null : YTPlayer.player
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* playerDestroy
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
playerDestroy: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
ytp.YTAPIReady = true;
|
|||
|
ytp.backgroundIsInited = false;
|
|||
|
YTPlayer.isInit = false;
|
|||
|
YTPlayer.videoID = null;
|
|||
|
YTPlayer.isReady = false;
|
|||
|
YTPlayer.wrapper.remove();
|
|||
|
jQuery('#controlBar_' + YTPlayer.id).remove();
|
|||
|
clearInterval(YTPlayer.checkForStartAt);
|
|||
|
clearInterval(YTPlayer.getState);
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* fullscreen
|
|||
|
* @param real
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
fullscreen: function (real) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (typeof real == 'undefined')
|
|||
|
real = eval(YTPlayer.opt.realFullscreen);
|
|||
|
|
|||
|
let controls = jQuery('#controlBar_' + YTPlayer.id);
|
|||
|
let fullScreenBtn = controls.find('.mb_OnlyYT');
|
|||
|
let videoWrapper = YTPlayer.isPlayer ? YTPlayer.opt.containment : YTPlayer.wrapper;
|
|||
|
|
|||
|
if (real) {
|
|||
|
let fullscreenchange = jQuery.mbBrowser.mozilla ? 'mozfullscreenchange' : jQuery.mbBrowser.webkit ? 'webkitfullscreenchange' : 'fullscreenchange';
|
|||
|
jQuery(document).off(fullscreenchange).on(fullscreenchange, function () {
|
|||
|
let 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('YTPFullscreen');
|
|||
|
videoWrapper.CSSAnimate({
|
|||
|
opacity: YTPlayer.opt.opacity
|
|||
|
}, YTPlayer.opt.fadeOnStartTime);
|
|||
|
|
|||
|
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).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('YTPFullscreen');
|
|||
|
launchFullscreen(videoWrapper.get(0));
|
|||
|
|
|||
|
setTimeout(function () {
|
|||
|
videoWrapper.CSSAnimate({
|
|||
|
opacity: 1
|
|||
|
}, YTPlayer.opt.fadeOnStartTime * 2);
|
|||
|
|
|||
|
videoWrapper.append(controls);
|
|||
|
jQuery(YTPlayer).optimizeDisplay();
|
|||
|
YTPlayer.player.seekTo(YTPlayer.player.getCurrentTime() + .1, true)
|
|||
|
|
|||
|
}, YTPlayer.opt.fadeOnStartTime)
|
|||
|
} else
|
|||
|
videoWrapper.css({
|
|||
|
zIndex: 10000
|
|||
|
}).CSSAnimate({
|
|||
|
opacity: 1
|
|||
|
}, YTPlayer.opt.fadeOnStartTime * 2);
|
|||
|
fullScreenBtn.html(jQuery.mbYTPlayer.controls.showSite);
|
|||
|
YTPlayer.isAlone = true
|
|||
|
} else {
|
|||
|
jQuery(document).off('mousemove.YTPlayer');
|
|||
|
clearTimeout(YTPlayer.hideCursor);
|
|||
|
YTPlayer.overlay.css({
|
|||
|
cursor: 'auto'
|
|||
|
});
|
|||
|
if (real) {
|
|||
|
cancelFullscreen()
|
|||
|
} else {
|
|||
|
videoWrapper.CSSAnimate({
|
|||
|
opacity: YTPlayer.opt.opacity
|
|||
|
}, YTPlayer.opt.fadeOnStartTime);
|
|||
|
videoWrapper.css({
|
|||
|
zIndex: 0
|
|||
|
})
|
|||
|
}
|
|||
|
fullScreenBtn.html(jQuery.mbYTPlayer.controls.onlyYT);
|
|||
|
YTPlayer.isAlone = false
|
|||
|
}
|
|||
|
|
|||
|
function RunPrefixMethod(obj, method) {
|
|||
|
let pfx = ['webkit', 'moz', 'ms', 'o', ''];
|
|||
|
let 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
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* toggleLoops
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
toggleLoops: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let 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
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* play
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
play: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let $YTPlayer = jQuery(YTPlayer);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
setTimeout(function () {
|
|||
|
$YTPlayer.YTPSetAbundance(YTPlayer.opt.abundance)
|
|||
|
}, 300);
|
|||
|
|
|||
|
YTPlayer.player.playVideo();
|
|||
|
|
|||
|
jQuery(YTPlayer.playerEl).css({
|
|||
|
opacity: 1
|
|||
|
});
|
|||
|
|
|||
|
YTPlayer.wrapper.css({
|
|||
|
backgroundImage: 'none'
|
|||
|
});
|
|||
|
|
|||
|
YTPlayer.wrapper.CSSAnimate({
|
|||
|
opacity: YTPlayer.isAlone ? 1 : YTPlayer.opt.opacity
|
|||
|
}, YTPlayer.opt.fadeOnStartTime);
|
|||
|
|
|||
|
let controls = jQuery('#controlBar_' + YTPlayer.id);
|
|||
|
let playBtn = controls.find('.mb_YTPPlayPause');
|
|||
|
playBtn.html(jQuery.mbYTPlayer.controls.pause);
|
|||
|
YTPlayer.state = 1;
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* togglePlay
|
|||
|
* @param callback
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
togglePlay: function (callback) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
if (YTPlayer.state === 1)
|
|||
|
this.YTPPause();
|
|||
|
else
|
|||
|
this.YTPPlay();
|
|||
|
|
|||
|
if (typeof callback == 'function')
|
|||
|
callback(YTPlayer.state);
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* stop
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
stop: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
let controls = jQuery('#controlBar_' + YTPlayer.id);
|
|||
|
let playBtn = controls.find('.mb_YTPPlayPause');
|
|||
|
playBtn.html(jQuery.mbYTPlayer.controls.play);
|
|||
|
YTPlayer.player.stopVideo();
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* pause
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
pause: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
if (YTPlayer.opt.abundance < .2)
|
|||
|
this.YTPSetAbundance(.2);
|
|||
|
|
|||
|
YTPlayer.player.pauseVideo();
|
|||
|
YTPlayer.state = 2;
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* seekTo
|
|||
|
* @param sec
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
seekTo: function (sec) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
YTPlayer.player.seekTo(sec, true);
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
*
|
|||
|
* @returns {*}
|
|||
|
*/
|
|||
|
getPlaybackRate: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
return YTPlayer.player.getPlaybackRate()
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* setPlaybackRate
|
|||
|
* @param val:Number
|
|||
|
* 0.25, 0.5, 1, 1.5, 2
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
setPlaybackRate: function (val) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
YTPlayer.player.setPlaybackRate(val);
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* setVolume
|
|||
|
* @param val
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
setVolume: function (val) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
YTPlayer.opt.vol = val;
|
|||
|
this.YTPUnmute();
|
|||
|
YTPlayer.player.setVolume(YTPlayer.opt.vol);
|
|||
|
|
|||
|
if (YTPlayer.volumeBar && YTPlayer.volumeBar.length)
|
|||
|
YTPlayer.volumeBar.updateSliderVal(val);
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
/**
|
|||
|
* getVolume
|
|||
|
* @returns {*}
|
|||
|
*/
|
|||
|
getVolume: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
return YTPlayer.player.getVolume()
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* toggleVolume
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
toggleVolume: function () {
|
|||
|
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
if (YTPlayer.isMute) {
|
|||
|
if (!jQuery.mbBrowser.mobile)
|
|||
|
this.YTPSetVolume(YTPlayer.opt.vol);
|
|||
|
this.YTPUnmute()
|
|||
|
} else {
|
|||
|
this.YTPMute()
|
|||
|
}
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* mute
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
mute: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
if (YTPlayer.isMute)
|
|||
|
return this;
|
|||
|
YTPlayer.player.mute();
|
|||
|
YTPlayer.isMute = true;
|
|||
|
YTPlayer.player.setVolume(0);
|
|||
|
if (YTPlayer.volumeBar && YTPlayer.volumeBar.length && YTPlayer.volumeBar.width() > 10) {
|
|||
|
YTPlayer.volumeBar.updateSliderVal(0)
|
|||
|
}
|
|||
|
let controls = jQuery('#controlBar_' + YTPlayer.id);
|
|||
|
let 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');
|
|||
|
let YTPEvent = jQuery.Event('YTPMuted');
|
|||
|
YTPEvent.time = YTPlayer.currentTime;
|
|||
|
|
|||
|
if (!YTPlayer.preventTrigger)
|
|||
|
jQuery(YTPlayer).trigger(YTPEvent);
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* unmute
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
unmute: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
if (!YTPlayer.isMute)
|
|||
|
return this;
|
|||
|
|
|||
|
YTPlayer.player.unMute();
|
|||
|
YTPlayer.isMute = false;
|
|||
|
jQuery(YTPlayer).YTPSetVolume(YTPlayer.opt.vol);
|
|||
|
if (YTPlayer.volumeBar && YTPlayer.volumeBar.length)
|
|||
|
YTPlayer.volumeBar.updateSliderVal(YTPlayer.opt.vol > 10 ? YTPlayer.opt.vol : 10);
|
|||
|
let controls = jQuery('#controlBar_' + YTPlayer.id);
|
|||
|
let 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');
|
|||
|
let YTPEvent = jQuery.Event('YTPUnmuted');
|
|||
|
YTPEvent.time = YTPlayer.currentTime;
|
|||
|
|
|||
|
if (!YTPlayer.preventTrigger)
|
|||
|
jQuery(YTPlayer).trigger(YTPEvent);
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/* FILTERS ---------------------------------------------------------------------------------------------------------*/
|
|||
|
|
|||
|
/**
|
|||
|
* applyFilter
|
|||
|
* @param filter
|
|||
|
* @param value
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
applyFilter: function (filter, value) {
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
YTPlayer.filters[filter].value = value;
|
|||
|
if (YTPlayer.filtersEnabled)
|
|||
|
$YTPlayer.YTPEnableFilters()
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* applyFilters
|
|||
|
* @param filters
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
applyFilters: function (filters) {
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady) {
|
|||
|
jQuery(YTPlayer).on('YTPReady', function () {
|
|||
|
$YTPlayer.YTPApplyFilters(filters)
|
|||
|
});
|
|||
|
return this
|
|||
|
}
|
|||
|
|
|||
|
for (let key in filters) {
|
|||
|
$YTPlayer.YTPApplyFilter(key, filters[key])
|
|||
|
}
|
|||
|
|
|||
|
$YTPlayer.trigger('YTPFiltersApplied')
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* toggleFilter
|
|||
|
* @param filter
|
|||
|
* @param value
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
toggleFilter: function (filter, value) {
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
if (!YTPlayer.filters[filter].value)
|
|||
|
YTPlayer.filters[filter].value = value;
|
|||
|
else
|
|||
|
YTPlayer.filters[filter].value = 0;
|
|||
|
|
|||
|
if (YTPlayer.filtersEnabled)
|
|||
|
jQuery(YTPlayer).YTPEnableFilters();
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* toggleFilters
|
|||
|
* @param callback
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
toggleFilters: function (callback) {
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return 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);
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* disableFilters
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
disableFilters: function () {
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
let iframe = jQuery(YTPlayer.playerEl);
|
|||
|
iframe.css('-webkit-filter', '');
|
|||
|
iframe.css('filter', '');
|
|||
|
YTPlayer.filtersEnabled = false;
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* enableFilters
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
enableFilters: function () {
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
let iframe = jQuery(YTPlayer.playerEl);
|
|||
|
let filterStyle = '';
|
|||
|
for (let 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
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* removeFilter
|
|||
|
* @param filter
|
|||
|
* @param callback
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
removeFilter: function (filter, callback) {
|
|||
|
let $YTPlayer = this;
|
|||
|
let YTPlayer = $YTPlayer.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
if (typeof filter == 'function') {
|
|||
|
callback = filter;
|
|||
|
filter = null
|
|||
|
}
|
|||
|
|
|||
|
if (!filter) {
|
|||
|
for (let key in YTPlayer.filters) {
|
|||
|
if (YTPlayer.filters.hasOwnProperty(key)) {
|
|||
|
$YTPlayer.YTPApplyFilter(key, 0);
|
|||
|
if (typeof callback == 'function')
|
|||
|
callback(key);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
YTPlayer.filters = jQuery.extend(true, {}, jQuery.mbYTPlayer.defaultFilters)
|
|||
|
|
|||
|
} else {
|
|||
|
$YTPlayer.YTPApplyFilter(filter, 0);
|
|||
|
if (typeof callback == 'function') callback(filter)
|
|||
|
}
|
|||
|
|
|||
|
let YTPEvent = jQuery.Event('YTPFiltersApplied');
|
|||
|
$YTPlayer.trigger(YTPEvent);
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getFilters
|
|||
|
* @returns {filters}
|
|||
|
*/
|
|||
|
getFilters: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return this;
|
|||
|
|
|||
|
return YTPlayer.filters
|
|||
|
},
|
|||
|
|
|||
|
/* MASK ---------------------------------------------------------------------------------------------------------*/
|
|||
|
|
|||
|
/**
|
|||
|
* addMask
|
|||
|
* @param mask
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
addMask: function (mask) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
if (!mask)
|
|||
|
mask = YTPlayer.actualMask;
|
|||
|
|
|||
|
let tempImg = jQuery('<img/>').attr('src', mask).on('load', function () {
|
|||
|
YTPlayer.overlay.CSSAnimate({
|
|||
|
opacity: 0
|
|||
|
}, YTPlayer.opt.fadeOnStartTime, function () {
|
|||
|
YTPlayer.hasMask = true;
|
|||
|
tempImg.remove();
|
|||
|
YTPlayer.overlay.css({
|
|||
|
backgroundImage : 'url(' + mask + ')',
|
|||
|
backgroundRepeat : 'no-repeat',
|
|||
|
backgroundPosition: 'center center',
|
|||
|
backgroundSize : 'cover'
|
|||
|
});
|
|||
|
YTPlayer.overlay.CSSAnimate({
|
|||
|
opacity: 1
|
|||
|
}, YTPlayer.opt.fadeOnStartTime)
|
|||
|
})
|
|||
|
});
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* removeMask
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
removeMask: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
YTPlayer.overlay.CSSAnimate({
|
|||
|
opacity: 0
|
|||
|
}, YTPlayer.opt.fadeOnStartTime, function () {
|
|||
|
YTPlayer.hasMask = false;
|
|||
|
YTPlayer.overlay.css({
|
|||
|
backgroundImage : '',
|
|||
|
backgroundRepeat : '',
|
|||
|
backgroundPosition: '',
|
|||
|
backgroundSize : ''
|
|||
|
});
|
|||
|
YTPlayer.overlay.CSSAnimate({
|
|||
|
opacity: 1
|
|||
|
}, YTPlayer.opt.fadeOnStartTime)
|
|||
|
});
|
|||
|
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* Apply mask
|
|||
|
* @param YTPlayer
|
|||
|
*/
|
|||
|
applyMask: function (YTPlayer) {
|
|||
|
let $YTPlayer = jQuery(YTPlayer);
|
|||
|
|
|||
|
$YTPlayer.off('YTPTime.mask');
|
|||
|
|
|||
|
if (YTPlayer.opt.mask) {
|
|||
|
if (typeof YTPlayer.opt.mask == 'string') {
|
|||
|
|
|||
|
$YTPlayer.YTPAddMask(YTPlayer.opt.mask);
|
|||
|
YTPlayer.actualMask = YTPlayer.opt.mask
|
|||
|
|
|||
|
} else if (typeof YTPlayer.opt.mask == 'object') {
|
|||
|
|
|||
|
for (let time in YTPlayer.opt.mask) {
|
|||
|
|
|||
|
if (YTPlayer.opt.mask[time])
|
|||
|
img = jQuery('<img/>').attr('src', YTPlayer.opt.mask[time])
|
|||
|
}
|
|||
|
|
|||
|
if (YTPlayer.opt.mask[0])
|
|||
|
$YTPlayer.YTPAddMask(YTPlayer.opt.mask[0]);
|
|||
|
|
|||
|
$YTPlayer.on('YTPTime.mask', function (e) {
|
|||
|
|
|||
|
for (let time in YTPlayer.opt.mask) {
|
|||
|
if (e.time === time)
|
|||
|
if (!YTPlayer.opt.mask[time]) {
|
|||
|
$YTPlayer.YTPRemoveMask()
|
|||
|
} else {
|
|||
|
$YTPlayer.YTPAddMask(YTPlayer.opt.mask[time]);
|
|||
|
YTPlayer.actualMask = YTPlayer.opt.mask[time]
|
|||
|
}
|
|||
|
}
|
|||
|
})
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* toggleMask
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
toggleMask: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
|
|||
|
let $YTPlayer = jQuery(YTPlayer);
|
|||
|
if (YTPlayer.hasMask)
|
|||
|
$YTPlayer.YTPRemoveMask();
|
|||
|
else
|
|||
|
$YTPlayer.YTPAddMask();
|
|||
|
return this
|
|||
|
},
|
|||
|
|
|||
|
/* CONTROLS --------------------------------------------------------------------------------------------------------*/
|
|||
|
|
|||
|
/**
|
|||
|
* manageProgress
|
|||
|
* @returns {{totalTime: number, currentTime: number}}
|
|||
|
*/
|
|||
|
manageProgress: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let controls = jQuery('#controlBar_' + YTPlayer.id);
|
|||
|
let progressBar = controls.find('.mb_YTPProgress');
|
|||
|
let loadedBar = controls.find('.mb_YTPLoaded');
|
|||
|
let timeBar = controls.find('.mb_YTPseekbar');
|
|||
|
let totW = progressBar.outerWidth();
|
|||
|
let currentTime = Math.floor(YTPlayer.player.getCurrentTime());
|
|||
|
let totalTime = Math.floor(YTPlayer.player.getDuration());
|
|||
|
let timeW = (currentTime * totW) / totalTime;
|
|||
|
let startLeft = 0;
|
|||
|
let loadedW = YTPlayer.player.getVideoLoadedFraction() * 100;
|
|||
|
loadedBar.css({
|
|||
|
left : startLeft,
|
|||
|
width: loadedW + '%'
|
|||
|
});
|
|||
|
timeBar.css({
|
|||
|
left : 0,
|
|||
|
width: timeW
|
|||
|
});
|
|||
|
return {
|
|||
|
totalTime : totalTime,
|
|||
|
currentTime: currentTime
|
|||
|
}
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* buildControls
|
|||
|
* @param YTPlayer
|
|||
|
*/
|
|||
|
buildControls: function (YTPlayer) {
|
|||
|
|
|||
|
jQuery('#controlBar_' + YTPlayer.id).remove();
|
|||
|
if (!YTPlayer.opt.showControls) {
|
|||
|
YTPlayer.controlBar = false;
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
YTPlayer.opt.showYTLogo = YTPlayer.opt.showYTLogo || YTPlayer.opt.printUrl;
|
|||
|
if (jQuery('#controlBar_' + YTPlayer.id).length)
|
|||
|
return;
|
|||
|
YTPlayer.controlBar = jQuery('<div/>').attr('id', 'controlBar_' + YTPlayer.id).addClass('mb_YTPBar').css({
|
|||
|
whiteSpace: 'noWrap',
|
|||
|
position : YTPlayer.isBackground ? 'fixed' : 'absolute',
|
|||
|
zIndex : YTPlayer.isBackground ? 10000 : 1000
|
|||
|
}).hide().on('click', function (e) {
|
|||
|
e.stopPropagation()
|
|||
|
});
|
|||
|
let buttonBar = jQuery('<div/>').addClass('buttonBar');
|
|||
|
/**
|
|||
|
* play/pause button
|
|||
|
* */
|
|||
|
let playpause = jQuery('<span>' + jQuery.mbYTPlayer.controls.play + '</span>').addClass('mb_YTPPlayPause ytpicon').on('click', function (e) {
|
|||
|
e.stopPropagation();
|
|||
|
jQuery(YTPlayer).YTPTogglePlay()
|
|||
|
});
|
|||
|
/**
|
|||
|
* mute/unmute button
|
|||
|
* */
|
|||
|
let MuteUnmute = jQuery('<span>' + jQuery.mbYTPlayer.controls.mute + '</span>').addClass('mb_YTPMuteUnmute ytpicon').on('click', function (e) {
|
|||
|
e.stopPropagation();
|
|||
|
jQuery(YTPlayer).YTPToggleVolume()
|
|||
|
});
|
|||
|
/**
|
|||
|
* volume bar
|
|||
|
* */
|
|||
|
let volumeBar = jQuery('<div/>').addClass('mb_YTPVolumeBar').css({
|
|||
|
display: 'inline-block'
|
|||
|
});
|
|||
|
YTPlayer.volumeBar = volumeBar;
|
|||
|
|
|||
|
/**
|
|||
|
* time elapsed
|
|||
|
* */
|
|||
|
let idx = jQuery('<span/>').addClass('mb_YTPTime');
|
|||
|
let vURL = YTPlayer.opt.videoURL ? YTPlayer.opt.videoURL : '';
|
|||
|
if (vURL.indexOf('http') < 0) vURL = 'https://www.youtube.com/watch?v=' + YTPlayer.opt.videoURL;
|
|||
|
let movieUrl = jQuery('<span/>').html(jQuery.mbYTPlayer.controls.ytLogo).addClass('mb_YTPUrl ytpicon').attr('title', 'view on YouTube').on('click', function () {
|
|||
|
window.open(vURL, 'viewOnYT')
|
|||
|
});
|
|||
|
let onlyVideo = jQuery('<span/>').html(jQuery.mbYTPlayer.controls.onlyYT).addClass('mb_OnlyYT ytpicon').on('click', function (e) {
|
|||
|
e.stopPropagation();
|
|||
|
jQuery(YTPlayer).YTPFullscreen(YTPlayer.opt.realFullscreen)
|
|||
|
});
|
|||
|
let progressBar = jQuery('<div/>').addClass('mb_YTPProgress').css('position', 'absolute').on('click', function (e) {
|
|||
|
e.stopPropagation();
|
|||
|
timeBar.css({
|
|||
|
width: (e.clientX - timeBar.offset().left)
|
|||
|
});
|
|||
|
YTPlayer.timeW = e.clientX - timeBar.offset().left;
|
|||
|
YTPlayer.controlBar.find('.mb_YTPLoaded').css({
|
|||
|
width: 0
|
|||
|
});
|
|||
|
let 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
|
|||
|
})
|
|||
|
});
|
|||
|
let loadedBar = jQuery('<div/>').addClass('mb_YTPLoaded').css('position', 'absolute');
|
|||
|
let timeBar = jQuery('<div/>').addClass('mb_YTPseekbar').css('position', 'absolute');
|
|||
|
progressBar.append(loadedBar).append(timeBar);
|
|||
|
buttonBar.append(playpause).append(MuteUnmute).append(volumeBar).append(idx);
|
|||
|
|
|||
|
if (YTPlayer.opt.showYTLogo) {
|
|||
|
buttonBar.append(movieUrl)
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Full screen button
|
|||
|
*/
|
|||
|
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)
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Volume slider
|
|||
|
*/
|
|||
|
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
|
|||
|
}
|
|||
|
|
|||
|
})
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* changeCoverImage
|
|||
|
*
|
|||
|
* @param imageURL
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
changeCoverImage: function (imageURL) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
if (YTPlayer.opt.coverImage || YTPlayer.orig_containment_background) {
|
|||
|
let bgndURL = imageURL || (YTPlayer.opt.coverImage ? 'url(' + YTPlayer.opt.coverImage + ') center center' : YTPlayer.orig_containment_background);
|
|||
|
if (bgndURL)
|
|||
|
YTPlayer.opt.containment.css({
|
|||
|
background : bgndURL,
|
|||
|
backgroundSize : 'cover',
|
|||
|
backgroundRepeat : 'no-repeat',
|
|||
|
backgroundAttachment: 'fixed'
|
|||
|
})
|
|||
|
}
|
|||
|
return this;
|
|||
|
},
|
|||
|
|
|||
|
/* MANAGE PLAYER STATE ------------------------------------------------------------------------------------------*/
|
|||
|
|
|||
|
/**
|
|||
|
* checkForState
|
|||
|
*/
|
|||
|
checkForState: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let $YTPlayer = jQuery(YTPlayer);
|
|||
|
|
|||
|
clearInterval(YTPlayer.getState);
|
|||
|
let interval = 100;
|
|||
|
//Checking if player has been removed from the scene
|
|||
|
if (!jQuery.contains(document, YTPlayer)) {
|
|||
|
$YTPlayer.YTPPlayerDestroy();
|
|||
|
clearInterval(YTPlayer.getState);
|
|||
|
clearInterval(YTPlayer.checkForStartAt);
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
jQuery.mbYTPlayer.checkForStart(YTPlayer);
|
|||
|
|
|||
|
YTPlayer.getState = setInterval(function () {
|
|||
|
let $YTPlayer = jQuery(YTPlayer);
|
|||
|
|
|||
|
if (!YTPlayer.isReady)
|
|||
|
return;
|
|||
|
|
|||
|
let prog = jQuery(YTPlayer).YTPManageProgress();
|
|||
|
|
|||
|
let stopAt = YTPlayer.opt.stopAt > YTPlayer.opt.startAt ? YTPlayer.opt.stopAt : 0;
|
|||
|
stopAt = stopAt < YTPlayer.player.getDuration() ? stopAt : 0;
|
|||
|
|
|||
|
if (YTPlayer.currentTime != prog.currentTime) {
|
|||
|
let YTPEvent = jQuery.Event('YTPTime');
|
|||
|
YTPEvent.time = YTPlayer.currentTime;
|
|||
|
jQuery(YTPlayer).trigger(YTPEvent)
|
|||
|
}
|
|||
|
|
|||
|
YTPlayer.currentTime = prog.currentTime;
|
|||
|
YTPlayer.totalTime = YTPlayer.player.getDuration();
|
|||
|
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('-- : -- / -- : --')
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Manage video pause on window blur
|
|||
|
*/
|
|||
|
if (eval(YTPlayer.opt.stopMovieOnBlur)) {
|
|||
|
if (!document.hasFocus()) {
|
|||
|
if (YTPlayer.state == 1) {
|
|||
|
YTPlayer.hasFocus = false;
|
|||
|
YTPlayer.preventTrigger = true;
|
|||
|
$YTPlayer.YTPPause()
|
|||
|
}
|
|||
|
} else if (document.hasFocus() && !YTPlayer.hasFocus && !(YTPlayer.state == -1 || YTPlayer.state == 0)) {
|
|||
|
YTPlayer.hasFocus = true;
|
|||
|
YTPlayer.preventTrigger = true;
|
|||
|
$YTPlayer.YTPPlay()
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Manage video pause if not on screen
|
|||
|
*/
|
|||
|
if (YTPlayer.opt.playOnlyIfVisible) {
|
|||
|
let isOnScreen = jQuery.mbYTPlayer.isOnScreen(YTPlayer, YTPlayer.opt.onScreenPercentage);
|
|||
|
if (!isOnScreen && YTPlayer.state == 1) {
|
|||
|
YTPlayer.isOnScreen = false;
|
|||
|
$YTPlayer.YTPPause()
|
|||
|
} else if (isOnScreen && !YTPlayer.isOnScreen) {
|
|||
|
YTPlayer.isOnScreen = true;
|
|||
|
YTPlayer.player.playVideo()
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (YTPlayer.controlBar.length && 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.length && YTPlayer.controlBar.outerWidth() > 400 && YTPlayer.isCompact) {
|
|||
|
YTPlayer.controlBar.removeClass('compact');
|
|||
|
YTPlayer.isCompact = false;
|
|||
|
|
|||
|
if (!YTPlayer.isMute && YTPlayer.volumeBar)
|
|||
|
YTPlayer.volumeBar.updateSliderVal(YTPlayer.opt.vol)
|
|||
|
}
|
|||
|
// the video is ended
|
|||
|
if (YTPlayer.player.getPlayerState() > 0 && ((parseFloat(YTPlayer.player.getDuration() - (YTPlayer.opt.fadeOnStartTime / 1000)) < 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.isList) {
|
|||
|
if (!YTPlayer.opt.loop || (YTPlayer.opt.loop > 0 && YTPlayer.player.loopTime === YTPlayer.opt.loop - 1)) {
|
|||
|
YTPlayer.player.loopTime = undefined;
|
|||
|
clearInterval(YTPlayer.getState);
|
|||
|
let YTPEnd = jQuery.Event('YTPEnd');
|
|||
|
YTPEnd.time = YTPlayer.currentTime;
|
|||
|
jQuery(YTPlayer).trigger(YTPEnd);
|
|||
|
return
|
|||
|
}
|
|||
|
} else if (!YTPlayer.opt.loop || (YTPlayer.opt.loop > 0 && YTPlayer.player.loopTime === YTPlayer.opt.loop - 1)) {
|
|||
|
YTPlayer.player.loopTime = undefined;
|
|||
|
|
|||
|
YTPlayer.state = 2;
|
|||
|
|
|||
|
$YTPlayer.changeCoverImage(YTPlayer);
|
|||
|
|
|||
|
jQuery(YTPlayer).YTPPause();
|
|||
|
YTPlayer.wrapper.CSSAnimate({
|
|||
|
opacity: 0
|
|||
|
}, YTPlayer.opt.fadeOnStartTime, function () {
|
|||
|
|
|||
|
if (YTPlayer.controlBar.length)
|
|||
|
YTPlayer.controlBar.find('.mb_YTPPlayPause').html(jQuery.mbYTPlayer.controls.play);
|
|||
|
|
|||
|
$YTPlayer.changeCoverImage();
|
|||
|
|
|||
|
let YTPEnd = jQuery.Event('YTPEnd');
|
|||
|
YTPEnd.time = YTPlayer.currentTime;
|
|||
|
jQuery(YTPlayer).trigger(YTPEnd);
|
|||
|
YTPlayer.player.seekTo(YTPlayer.opt.startAt, true);
|
|||
|
});
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
YTPlayer.player.loopTime = YTPlayer.player.loopTime ? ++YTPlayer.player.loopTime : 1;
|
|||
|
YTPlayer.opt.startAt = YTPlayer.opt.startAt || 1;
|
|||
|
YTPlayer.preventTrigger = true;
|
|||
|
YTPlayer.state = 2;
|
|||
|
YTPlayer.player.seekTo(YTPlayer.opt.startAt, true)
|
|||
|
}
|
|||
|
}, interval)
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* checkForStart
|
|||
|
* @param YTPlayer
|
|||
|
*/
|
|||
|
checkForStart: function (YTPlayer) {
|
|||
|
let $YTPlayer = jQuery(YTPlayer);
|
|||
|
|
|||
|
/* If the player has been removed from scene destroy it */
|
|||
|
if (!jQuery.contains(document, YTPlayer)) {
|
|||
|
$YTPlayer.YTPPlayerDestroy();
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
/* CREATE CONTROL BAR */
|
|||
|
jQuery.mbYTPlayer.buildControls(YTPlayer);
|
|||
|
|
|||
|
if (YTPlayer.overlay)
|
|||
|
if (YTPlayer.opt.addRaster) {
|
|||
|
let 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
|
|||
|
let 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.preventTrigger = true;
|
|||
|
YTPlayer.state = 2;
|
|||
|
YTPlayer.preventTrigger = true;
|
|||
|
|
|||
|
YTPlayer.player.mute();
|
|||
|
YTPlayer.player.playVideo();
|
|||
|
YTPlayer.isStarting = true;
|
|||
|
|
|||
|
let startAt = YTPlayer.start_from_last ? YTPlayer.start_from_last : YTPlayer.opt.startAt ? YTPlayer.opt.startAt : 1;
|
|||
|
|
|||
|
YTPlayer.preventTrigger = true;
|
|||
|
YTPlayer.checkForStartAt = setInterval(function () {
|
|||
|
|
|||
|
YTPlayer.player.mute();
|
|||
|
YTPlayer.player.seekTo(startAt, true);
|
|||
|
|
|||
|
let canPlayVideo = YTPlayer.player.getVideoLoadedFraction() >= startAt / YTPlayer.player.getDuration();
|
|||
|
|
|||
|
if (jQuery.mbBrowser.mobile)
|
|||
|
canPlayVideo = true;
|
|||
|
|
|||
|
if (YTPlayer.player.getDuration() > 0 && YTPlayer.player.getCurrentTime() >= startAt && canPlayVideo) {
|
|||
|
YTPlayer.start_from_last = null;
|
|||
|
|
|||
|
YTPlayer.preventTrigger = true;
|
|||
|
$YTPlayer.YTPPause();
|
|||
|
|
|||
|
clearInterval(YTPlayer.checkForStartAt);
|
|||
|
|
|||
|
if (typeof YTPlayer.opt.onReady == 'function')
|
|||
|
YTPlayer.opt.onReady(YTPlayer);
|
|||
|
|
|||
|
YTPlayer.isReady = true;
|
|||
|
|
|||
|
$YTPlayer.YTPRemoveFilter();
|
|||
|
|
|||
|
if (YTPlayer.opt.addFilters) {
|
|||
|
$YTPlayer.YTPApplyFilters(YTPlayer.opt.addFilters)
|
|||
|
} else {
|
|||
|
$YTPlayer.YTPApplyFilters()
|
|||
|
}
|
|||
|
$YTPlayer.YTPEnableFilters();
|
|||
|
let YTPready = jQuery.Event('YTPReady');
|
|||
|
YTPready.time = YTPlayer.currentTime;
|
|||
|
$YTPlayer.trigger(YTPready);
|
|||
|
|
|||
|
YTPlayer.state = 2;
|
|||
|
|
|||
|
if (!YTPlayer.opt.mute) {
|
|||
|
|
|||
|
if (YTPlayer.opt.autoPlay) {
|
|||
|
console.debug('We muted the audio to make the video \'auto-play\' according with the latest vendor policy. ' +
|
|||
|
'The audio will unmute at the first user interaction with the page');
|
|||
|
YTPlayer.player.mute();
|
|||
|
YTPlayer.forcedMuted = true;
|
|||
|
/**
|
|||
|
* If autoPlay is set to true and mute is set to false
|
|||
|
* Browsers will not auto-play
|
|||
|
* Start playing audio after the first click
|
|||
|
*/
|
|||
|
jQuery(document).on('mousedown.YTPstartAudio', function () {
|
|||
|
if (YTPlayer.forcedMuted) {
|
|||
|
console.debug("AAAAAAA");
|
|||
|
YTPlayer.player.unMute();
|
|||
|
YTPlayer.forcedMuted = false;
|
|||
|
jQuery(document).off('mousedown.YTPstartAudio')
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
jQuery(window).on("scroll", function () {
|
|||
|
console.debug("AAAAA")
|
|||
|
})
|
|||
|
|
|||
|
} else {
|
|||
|
YTPlayer.player.unMute()
|
|||
|
}
|
|||
|
|
|||
|
} else {
|
|||
|
$YTPlayer.YTPMute()
|
|||
|
}
|
|||
|
|
|||
|
if (typeof _gaq != 'undefined' && eval(YTPlayer.opt.gaTrack))
|
|||
|
_gaq.push(['_trackEvent', 'YTPlayer', 'Play', (YTPlayer.hasData ? YTPlayer.videoData.title : YTPlayer.videoID.toString())]);
|
|||
|
else if (typeof ga != 'undefined' && eval(YTPlayer.opt.gaTrack))
|
|||
|
ga('send', 'event', 'YTPlayer', 'play', (YTPlayer.hasData ? YTPlayer.videoData.title : YTPlayer.videoID.toString()));
|
|||
|
|
|||
|
if (YTPlayer.opt.autoPlay) {
|
|||
|
|
|||
|
let YTPStart = jQuery.Event('YTPStart');
|
|||
|
YTPStart.time = YTPlayer.currentTime;
|
|||
|
jQuery(YTPlayer).trigger(YTPStart);
|
|||
|
|
|||
|
YTPlayer.isStarting = false;
|
|||
|
|
|||
|
/* Fix for Safari freeze */
|
|||
|
if (jQuery.mbBrowser.os.name === 'mac' && jQuery.mbBrowser.safari) {
|
|||
|
jQuery('body').one('mousedown.YTPstart', function () {
|
|||
|
$YTPlayer.YTPPlay()
|
|||
|
})
|
|||
|
}
|
|||
|
$YTPlayer.YTPPlay();
|
|||
|
console.timeEnd(YTPTimerLabels.startPlaying)
|
|||
|
} else {
|
|||
|
YTPlayer.preventTrigger = true;
|
|||
|
$YTPlayer.YTPPause();
|
|||
|
|
|||
|
if (YTPlayer.start_from_last)
|
|||
|
YTPlayer.player.seekTo(startAt, true);
|
|||
|
|
|||
|
setTimeout(function () {
|
|||
|
YTPlayer.preventTrigger = true;
|
|||
|
$YTPlayer.YTPPause();
|
|||
|
|
|||
|
if (!YTPlayer.isPlayer) {
|
|||
|
if (!YTPlayer.opt.coverImage) {
|
|||
|
jQuery(YTPlayer.playerEl).CSSAnimate({
|
|||
|
opacity: 1
|
|||
|
}, YTPlayer.opt.fadeOnStartTime);
|
|||
|
YTPlayer.wrapper.CSSAnimate({
|
|||
|
opacity: YTPlayer.isAlone ? 1 : YTPlayer.opt.opacity
|
|||
|
}, YTPlayer.opt.fadeOnStartTime)
|
|||
|
} else {
|
|||
|
YTPlayer.wrapper.css({opacity: 0});
|
|||
|
setTimeout(function () {
|
|||
|
$YTPlayer.changeCoverImage()
|
|||
|
}, YTPlayer.opt.fadeOnStartTime)
|
|||
|
}
|
|||
|
}
|
|||
|
YTPlayer.isStarting = false
|
|||
|
}, 500);
|
|||
|
|
|||
|
if (YTPlayer.controlBar.length)
|
|||
|
YTPlayer.controlBar.find('.mb_YTPPlayPause').html(jQuery.mbYTPlayer.controls.play)
|
|||
|
}
|
|||
|
|
|||
|
if (YTPlayer.isPlayer && !YTPlayer.opt.autoPlay && (YTPlayer.loading && YTPlayer.loading.length)) {
|
|||
|
YTPlayer.loading.html('Ready');
|
|||
|
setTimeout(function () {
|
|||
|
YTPlayer.loading.fadeOut()
|
|||
|
}, 100)
|
|||
|
}
|
|||
|
|
|||
|
if (YTPlayer.controlBar && YTPlayer.controlBar.length)
|
|||
|
YTPlayer.controlBar.slideDown(1000)
|
|||
|
}
|
|||
|
|
|||
|
if (jQuery.mbBrowser.os.name === 'mac' && jQuery.mbBrowser.safari) {
|
|||
|
YTPlayer.player.playVideo();
|
|||
|
if (startAt >= 0)
|
|||
|
YTPlayer.player.seekTo(startAt, true)
|
|||
|
}
|
|||
|
|
|||
|
}, 100);
|
|||
|
|
|||
|
return $YTPlayer
|
|||
|
},
|
|||
|
|
|||
|
/* TIME METHODS -------------------------------------------------------------------------------------------*/
|
|||
|
|
|||
|
/**
|
|||
|
* getTime
|
|||
|
* @returns {string} time
|
|||
|
*/
|
|||
|
getTime: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
return jQuery.mbYTPlayer.formatTime(YTPlayer.currentTime)
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getTotalTime
|
|||
|
* @returns {string} total time
|
|||
|
*/
|
|||
|
getTotalTime: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
return jQuery.mbYTPlayer.formatTime(YTPlayer.totalTime)
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* formatTime
|
|||
|
* @param s
|
|||
|
* @returns {string}
|
|||
|
*/
|
|||
|
formatTime: function (s) {
|
|||
|
let min = Math.floor(s / 60);
|
|||
|
let sec = Math.floor(s - (60 * min));
|
|||
|
return (min <= 9 ? '0' + min : min) + ' : ' + (sec <= 9 ? '0' + sec : sec)
|
|||
|
},
|
|||
|
|
|||
|
/* PLAYER POSITION AND SIZE OPTIMIZATION-------------------------------------------------------------------------------------------*/
|
|||
|
|
|||
|
/**
|
|||
|
* setAnchor
|
|||
|
* @param anchor
|
|||
|
*/
|
|||
|
setAnchor: function (anchor) {
|
|||
|
let $YTplayer = this;
|
|||
|
$YTplayer.optimizeDisplay(anchor)
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getAnchor
|
|||
|
*/
|
|||
|
getAnchor: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
return YTPlayer.opt.anchor
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* setAbundance
|
|||
|
* @param val
|
|||
|
* @param updateOptions
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
setAbundance: function (val, updateOptions) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let $YTPlayer = this;
|
|||
|
if (updateOptions)
|
|||
|
YTPlayer.opt.abundance = val;
|
|||
|
$YTPlayer.optimizeDisplay(YTPlayer.opt.anchor, val);
|
|||
|
return $YTPlayer
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* getAbundance
|
|||
|
* @returns {*}
|
|||
|
*/
|
|||
|
getAbundance: function () {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
return YTPlayer.opt.abundance
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* setOption
|
|||
|
* @param opt
|
|||
|
* @param val
|
|||
|
* @returns {jQuery.mbYTPlayer}
|
|||
|
*/
|
|||
|
setOption: function (opt, val) {
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let $YTPlayer = this;
|
|||
|
YTPlayer.opt[opt] = val;
|
|||
|
return $YTPlayer
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
/**
|
|||
|
* optimizeDisplay
|
|||
|
* @param anchor
|
|||
|
* @param abundanceX
|
|||
|
*/
|
|||
|
jQuery.fn.optimizeDisplay = function (anchor, abundanceX) {
|
|||
|
|
|||
|
let YTPlayer = this.get(0);
|
|||
|
let vid = {};
|
|||
|
let el = YTPlayer.wrapper;
|
|||
|
let iframe = jQuery(YTPlayer.playerEl);
|
|||
|
|
|||
|
YTPlayer.opt.anchor = anchor || YTPlayer.opt.anchor;
|
|||
|
|
|||
|
// console.debug(YTPlayer.opt.anchor);
|
|||
|
|
|||
|
YTPlayer.opt.anchor = typeof YTPlayer.opt.anchor != 'undefined ' ? YTPlayer.opt.anchor : 'center,center';
|
|||
|
let YTPAlign = YTPlayer.opt.anchor.split(',');
|
|||
|
let ab = abundanceX ? abundanceX : YTPlayer.opt.abundance;
|
|||
|
|
|||
|
if (YTPlayer.opt.optimizeDisplay) {
|
|||
|
let abundance = el.height() * ab;
|
|||
|
let win = {};
|
|||
|
win.width = el.outerWidth();
|
|||
|
win.height = el.outerHeight() + abundance;
|
|||
|
|
|||
|
YTPlayer.opt.ratio = YTPlayer.opt.ratio === 'auto' ? 16 / 9 : YTPlayer.opt.ratio;
|
|||
|
YTPlayer.opt.ratio = eval(YTPlayer.opt.ratio);
|
|||
|
|
|||
|
vid.width = win.width + abundance;
|
|||
|
vid.height = Math.ceil(vid.width / YTPlayer.opt.ratio);
|
|||
|
vid.marginTop = Math.ceil(-((vid.height - win.height + abundance) / 2));
|
|||
|
vid.marginLeft = -(abundance / 2);
|
|||
|
let lowest = vid.height < win.height;
|
|||
|
|
|||
|
if (lowest) {
|
|||
|
vid.height = win.height + abundance;
|
|||
|
vid.width = Math.ceil(vid.height * YTPlayer.opt.ratio);
|
|||
|
vid.marginTop = -(abundance / 2);
|
|||
|
vid.marginLeft = Math.ceil(-((vid.width - win.width) / 2))
|
|||
|
}
|
|||
|
|
|||
|
for (let a in YTPAlign) {
|
|||
|
if (YTPAlign.hasOwnProperty(a)) {
|
|||
|
let al = YTPAlign[a].replace(/ /g, '');
|
|||
|
|
|||
|
switch (al) {
|
|||
|
case 'top':
|
|||
|
vid.marginTop = -abundance;
|
|||
|
break;
|
|||
|
case 'bottom':
|
|||
|
vid.marginTop = Math.ceil(-(vid.height - win.height) - (abundance / 2));
|
|||
|
break;
|
|||
|
case 'left':
|
|||
|
vid.marginLeft = -(abundance);
|
|||
|
break;
|
|||
|
case 'right':
|
|||
|
vid.marginLeft = Math.ceil(-(vid.width - win.width) + (abundance / 2));
|
|||
|
break
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
} else {
|
|||
|
vid.width = '100%';
|
|||
|
vid.height = '100%';
|
|||
|
vid.marginTop = 0;
|
|||
|
vid.marginLeft = 0
|
|||
|
}
|
|||
|
|
|||
|
iframe.css({
|
|||
|
width : vid.width,
|
|||
|
height : vid.height,
|
|||
|
marginTop : vid.marginTop,
|
|||
|
marginLeft: vid.marginLeft,
|
|||
|
maxWidth : 'initial'
|
|||
|
})
|
|||
|
|
|||
|
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
/* UTILITIES -----------------------------------------------------------------------------------------------------------------------*/
|
|||
|
|
|||
|
/**
|
|||
|
* shuffle
|
|||
|
* @param arr
|
|||
|
* @returns {Array|string|Blob|*}
|
|||
|
*
|
|||
|
*/
|
|||
|
jQuery.shuffle = function (arr) {
|
|||
|
let newArray = arr.slice();
|
|||
|
let len = newArray.length;
|
|||
|
let i = len;
|
|||
|
while (i--) {
|
|||
|
let p = parseInt(Math.random() * len);
|
|||
|
let t = newArray[i];
|
|||
|
newArray[i] = newArray[p];
|
|||
|
newArray[p] = t
|
|||
|
}
|
|||
|
return newArray;
|
|||
|
};
|
|||
|
|
|||
|
/**
|
|||
|
* Unselectable
|
|||
|
* @returns {*}
|
|||
|
*/
|
|||
|
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')
|
|||
|
})
|
|||
|
};
|
|||
|
|
|||
|
/* EXTERNAL METHODS -----------------------------------------------------------------------------------------------------------------------*/
|
|||
|
|
|||
|
jQuery.fn.YTPlayer = jQuery.mbYTPlayer.buildPlayer;
|
|||
|
jQuery.fn.mb_YTPlayer = jQuery.mbYTPlayer.buildPlayer;
|
|||
|
|
|||
|
jQuery.fn.YTPCheckForState = jQuery.mbYTPlayer.checkForState;
|
|||
|
|
|||
|
jQuery.fn.YTPGetPlayer = jQuery.mbYTPlayer.getPlayer;
|
|||
|
jQuery.fn.YTPGetVideoID = jQuery.mbYTPlayer.getVideoID;
|
|||
|
jQuery.fn.YTPGetPlaylistID = jQuery.mbYTPlayer.getPlaylistID;
|
|||
|
jQuery.fn.YTPChangeVideo = jQuery.fn.YTPChangeMovie = jQuery.mbYTPlayer.changeVideo;
|
|||
|
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.YTPGetPlaybackRate = jQuery.mbYTPlayer.getPlaybackRate;
|
|||
|
jQuery.fn.YTPSetPlaybackRate = jQuery.mbYTPlayer.setPlaybackRate;
|
|||
|
|
|||
|
jQuery.fn.changeCoverImage = jQuery.mbYTPlayer.changeCoverImage;
|
|||
|
|
|||
|
jQuery.fn.YTPlaylist = jQuery.mbYTPlayer.playlist;
|
|||
|
jQuery.fn.YTPPlayNext = jQuery.mbYTPlayer.playNext;
|
|||
|
jQuery.fn.YTPPlayPrev = jQuery.mbYTPlayer.playPrev;
|
|||
|
jQuery.fn.YTPPlayIndex = jQuery.mbYTPlayer.playIndex;
|
|||
|
|
|||
|
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.YTPGetVolume = jQuery.mbYTPlayer.getVolume;
|
|||
|
|
|||
|
jQuery.fn.YTPGetVideoData = jQuery.mbYTPlayer.getVideoData;
|
|||
|
jQuery.fn.YTPFullscreen = jQuery.mbYTPlayer.fullscreen;
|
|||
|
jQuery.fn.YTPToggleLoops = jQuery.mbYTPlayer.toggleLoops;
|
|||
|
jQuery.fn.YTPManageProgress = jQuery.mbYTPlayer.manageProgress;
|
|||
|
|
|||
|
jQuery.fn.YTPSetVideoQuality = jQuery.mbYTPlayer.setVideoQuality;
|
|||
|
jQuery.fn.YTPGetVideoQuality = jQuery.mbYTPlayer.getVideoQuality;
|
|||
|
|
|||
|
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;
|
|||
|
jQuery.fn.YTPGetFilters = jQuery.mbYTPlayer.getFilters;
|
|||
|
|
|||
|
jQuery.fn.YTPGetTime = jQuery.mbYTPlayer.getTime;
|
|||
|
jQuery.fn.YTPGetTotalTime = jQuery.mbYTPlayer.getTotalTime;
|
|||
|
|
|||
|
jQuery.fn.YTPAddMask = jQuery.mbYTPlayer.addMask;
|
|||
|
jQuery.fn.YTPRemoveMask = jQuery.mbYTPlayer.removeMask;
|
|||
|
jQuery.fn.YTPToggleMask = jQuery.mbYTPlayer.toggleMask;
|
|||
|
|
|||
|
jQuery.fn.YTPGetAbundance = jQuery.mbYTPlayer.getAbundance;
|
|||
|
jQuery.fn.YTPSetAbundance = jQuery.mbYTPlayer.setAbundance;
|
|||
|
|
|||
|
jQuery.fn.YTPSetAnchor = jQuery.mbYTPlayer.setAnchor;
|
|||
|
jQuery.fn.YTPGetAnchor = jQuery.mbYTPlayer.getAnchor;
|
|||
|
|
|||
|
jQuery.fn.YTPSetOption = jQuery.mbYTPlayer.setOption
|
|||
|
|
|||
|
})(jQuery, ytp);
|
|||
|
/*___________________________________________________________________________________________________________________________________________________
|
|||
|
_ jquery.mb.components _
|
|||
|
_ _
|
|||
|
_ file: jquery.mb.mbBrowser.min.js _
|
|||
|
_ last modified: 24/05/17 19.56 _
|
|||
|
_ _
|
|||
|
_ Open Lab s.r.l., Florence - Italy _
|
|||
|
_ _
|
|||
|
_ email: matbicoc@gmail.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-2017. Matteo Bicocchi (Pupunzi); _
|
|||
|
___________________________________________________________________________________________________________________________________________________*/
|
|||
|
var nAgt=navigator.userAgent;jQuery.mbBrowser=jQuery.mbBrowser||{};jQuery.mbBrowser.mozilla=!1;jQuery.mbBrowser.webkit=!1;jQuery.mbBrowser.opera=!1;jQuery.mbBrowser.safari=!1;jQuery.mbBrowser.chrome=!1;jQuery.mbBrowser.androidStock=!1;jQuery.mbBrowser.msie=!1;jQuery.mbBrowser.edge=!1;jQuery.mbBrowser.ua=nAgt;function isTouchSupported(){var a=nAgt.msMaxTouchPoints,e="ontouchstart"in document.createElement("div");return a||e?!0:!1}
|
|||
|
var getOS=function(){var a={version:"Unknown version",name:"Unknown OS"};-1!=navigator.appVersion.indexOf("Win")&&(a.name="Windows");-1!=navigator.appVersion.indexOf("Mac")&&0>navigator.appVersion.indexOf("Mobile")&&(a.name="Mac");-1!=navigator.appVersion.indexOf("Linux")&&(a.name="Linux");/Mac OS X/.test(nAgt)&&!/Mobile/.test(nAgt)&&(a.version=/Mac OS X ([\._\d]+)/.exec(nAgt)[1],a.version=a.version.replace(/_/g,".").substring(0,5));/Windows/.test(nAgt)&&(a.version="Unknown.Unknown");/Windows NT 5.1/.test(nAgt)&&
|
|||
|
(a.version="5.1");/Windows NT 6.0/.test(nAgt)&&(a.version="6.0");/Windows NT 6.1/.test(nAgt)&&(a.version="6.1");/Windows NT 6.2/.test(nAgt)&&(a.version="6.2");/Windows NT 10.0/.test(nAgt)&&(a.version="10.0");/Linux/.test(nAgt)&&/Linux/.test(nAgt)&&(a.version="Unknown.Unknown");a.name=a.name.toLowerCase();a.major_version="Unknown";a.minor_version="Unknown";"Unknown.Unknown"!=a.version&&(a.major_version=parseFloat(a.version.split(".")[0]),a.minor_version=parseFloat(a.version.split(".")[1]));return a};
|
|||
|
jQuery.mbBrowser.os=getOS();jQuery.mbBrowser.hasTouch=isTouchSupported();jQuery.mbBrowser.name=navigator.appName;jQuery.mbBrowser.fullVersion=""+parseFloat(navigator.appVersion);jQuery.mbBrowser.majorVersion=parseInt(navigator.appVersion,10);var nameOffset,verOffset,ix;
|
|||
|
if(-1!=(verOffset=nAgt.indexOf("Opera")))jQuery.mbBrowser.opera=!0,jQuery.mbBrowser.name="Opera",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+6),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+8));else if(-1!=(verOffset=nAgt.indexOf("OPR")))jQuery.mbBrowser.opera=!0,jQuery.mbBrowser.name="Opera",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+4);else if(-1!=(verOffset=nAgt.indexOf("MSIE")))jQuery.mbBrowser.msie=!0,jQuery.mbBrowser.name="Microsoft Internet Explorer",
|
|||
|
jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+5);else if(-1!=nAgt.indexOf("Trident")){jQuery.mbBrowser.msie=!0;jQuery.mbBrowser.name="Microsoft Internet Explorer";var start=nAgt.indexOf("rv:")+3,end=start+4;jQuery.mbBrowser.fullVersion=nAgt.substring(start,end)}else-1!=(verOffset=nAgt.indexOf("Edge"))?(jQuery.mbBrowser.edge=!0,jQuery.mbBrowser.name="Microsoft Edge",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+5)):-1!=(verOffset=nAgt.indexOf("Chrome"))?(jQuery.mbBrowser.webkit=!0,jQuery.mbBrowser.chrome=
|
|||
|
!0,jQuery.mbBrowser.name="Chrome",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+7)):-1<nAgt.indexOf("mozilla/5.0")&&-1<nAgt.indexOf("android ")&&-1<nAgt.indexOf("applewebkit")&&!(-1<nAgt.indexOf("chrome"))?(verOffset=nAgt.indexOf("Chrome"),jQuery.mbBrowser.webkit=!0,jQuery.mbBrowser.androidStock=!0,jQuery.mbBrowser.name="androidStock",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+7)):-1!=(verOffset=nAgt.indexOf("Safari"))?(jQuery.mbBrowser.webkit=!0,jQuery.mbBrowser.safari=!0,jQuery.mbBrowser.name=
|
|||
|
"Safari",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+7),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+8))):-1!=(verOffset=nAgt.indexOf("AppleWebkit"))?(jQuery.mbBrowser.webkit=!0,jQuery.mbBrowser.safari=!0,jQuery.mbBrowser.name="Safari",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+7),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+8))):-1!=(verOffset=nAgt.indexOf("Firefox"))?(jQuery.mbBrowser.mozilla=
|
|||
|
!0,jQuery.mbBrowser.name="Firefox",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+8)):(nameOffset=nAgt.lastIndexOf(" ")+1)<(verOffset=nAgt.lastIndexOf("/"))&&(jQuery.mbBrowser.name=nAgt.substring(nameOffset,verOffset),jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+1),jQuery.mbBrowser.name.toLowerCase()==jQuery.mbBrowser.name.toUpperCase()&&(jQuery.mbBrowser.name=navigator.appName));
|
|||
|
-1!=(ix=jQuery.mbBrowser.fullVersion.indexOf(";"))&&(jQuery.mbBrowser.fullVersion=jQuery.mbBrowser.fullVersion.substring(0,ix));-1!=(ix=jQuery.mbBrowser.fullVersion.indexOf(" "))&&(jQuery.mbBrowser.fullVersion=jQuery.mbBrowser.fullVersion.substring(0,ix));jQuery.mbBrowser.majorVersion=parseInt(""+jQuery.mbBrowser.fullVersion,10);isNaN(jQuery.mbBrowser.majorVersion)&&(jQuery.mbBrowser.fullVersion=""+parseFloat(navigator.appVersion),jQuery.mbBrowser.majorVersion=parseInt(navigator.appVersion,10));
|
|||
|
jQuery.mbBrowser.version=jQuery.mbBrowser.majorVersion;jQuery.mbBrowser.android=/Android/i.test(nAgt);jQuery.mbBrowser.blackberry=/BlackBerry|BB|PlayBook/i.test(nAgt);jQuery.mbBrowser.ios=/iPhone|iPad|iPod|webOS/i.test(nAgt);jQuery.mbBrowser.operaMobile=/Opera Mini/i.test(nAgt);jQuery.mbBrowser.windowsMobile=/IEMobile|Windows Phone/i.test(nAgt);jQuery.mbBrowser.kindle=/Kindle|Silk/i.test(nAgt);
|
|||
|
jQuery.mbBrowser.mobile=jQuery.mbBrowser.android||jQuery.mbBrowser.blackberry||jQuery.mbBrowser.ios||jQuery.mbBrowser.windowsMobile||jQuery.mbBrowser.operaMobile||jQuery.mbBrowser.kindle;jQuery.isMobile=jQuery.mbBrowser.mobile;jQuery.isTablet=jQuery.mbBrowser.mobile&&765<jQuery(window).width();jQuery.isAndroidDefault=jQuery.mbBrowser.android&&!/chrome/i.test(nAgt);jQuery.mbBrowser=jQuery.mbBrowser;
|
|||
|
jQuery.mbBrowser.versionCompare=function(a,e){if("stringstring"!=typeof a+typeof e)return!1;for(var c=a.split("."),d=e.split("."),b=0,f=Math.max(c.length,d.length);b<f;b++){if(c[b]&&!d[b]&&0<parseInt(c[b])||parseInt(c[b])>parseInt(d[b]))return 1;if(d[b]&&!c[b]&&0<parseInt(d[b])||parseInt(c[b])<parseInt(d[b]))return-1}return 0};
|
|||
|
/*
|
|||
|
* ******************************************************************************
|
|||
|
* jquery.mb.components
|
|||
|
* file: jquery.mb.CSSAnimate.min.js
|
|||
|
*
|
|||
|
* Copyright (c) 2001-2014. Matteo Bicocchi (Pupunzi);
|
|||
|
* Open lab srl, Firenze - Italy
|
|||
|
* email: matbicoc@gmail.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
|
|||
|
* *****************************************************************************
|
|||
|
*/
|
|||
|
|
|||
|
jQuery.support.CSStransition=function(){var d=(document.body||document.documentElement).style;return void 0!==d.transition||void 0!==d.WebkitTransition||void 0!==d.MozTransition||void 0!==d.MsTransition||void 0!==d.OTransition}();function uncamel(d){return d.replace(/([A-Z])/g,function(a){return"-"+a.toLowerCase()})}function setUnit(d,a){return"string"!==typeof d||d.match(/^[\-0-9\.]+jQuery/)?""+d+a:d}
|
|||
|
function setFilter(d,a,b){var c=uncamel(a),g=jQuery.mbBrowser.mozilla?"":jQuery.CSS.sfx;d[g+"filter"]=d[g+"filter"]||"";b=setUnit(b>jQuery.CSS.filters[a].max?jQuery.CSS.filters[a].max:b,jQuery.CSS.filters[a].unit);d[g+"filter"]+=c+"("+b+") ";delete d[a]}
|
|||
|
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(d){var a=jQuery.extend(!0,{},d);jQuery.mbBrowser.webkit||jQuery.mbBrowser.opera?jQuery.CSS.sfx=
|
|||
|
"-webkit-":jQuery.mbBrowser.mozilla?jQuery.CSS.sfx="-moz-":jQuery.mbBrowser.msie&&(jQuery.CSS.sfx="-ms-");jQuery.CSS.sfx="";for(var b in a){"transform"===b&&(a[jQuery.CSS.sfx+"transform"]=a[b],delete a[b]);"transform-origin"===b&&(a[jQuery.CSS.sfx+"transform-origin"]=d[b],delete a[b]);"filter"!==b||jQuery.mbBrowser.mozilla||(a[jQuery.CSS.sfx+"filter"]=d[b],delete a[b]);"blur"===b&&setFilter(a,"blur",d[b]);"brightness"===b&&setFilter(a,"brightness",d[b]);"contrast"===b&&setFilter(a,"contrast",d[b]);"grayscale"===
|
|||
|
b&&setFilter(a,"grayscale",d[b]);"hueRotate"===b&&setFilter(a,"hueRotate",d[b]);"invert"===b&&setFilter(a,"invert",d[b]);"saturate"===b&&setFilter(a,"saturate",d[b]);"sepia"===b&&setFilter(a,"sepia",d[b]);if("x"===b){var c=jQuery.CSS.sfx+"transform";a[c]=a[c]||"";a[c]+=" translateX("+setUnit(d[b],"px")+")";delete a[b]}"y"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" translateY("+setUnit(d[b],"px")+")",delete a[b]);"z"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" translateZ("+
|
|||
|
setUnit(d[b],"px")+")",delete a[b]);"rotate"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" rotate("+setUnit(d[b],"deg")+")",delete a[b]);"rotateX"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" rotateX("+setUnit(d[b],"deg")+")",delete a[b]);"rotateY"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" rotateY("+setUnit(d[b],"deg")+")",delete a[b]);"rotateZ"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" rotateZ("+setUnit(d[b],"deg")+")",delete a[b]);"scale"===b&&
|
|||
|
(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" scale("+setUnit(d[b],"")+")",delete a[b]);"scaleX"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" scaleX("+setUnit(d[b],"")+")",delete a[b]);"scaleY"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" scaleY("+setUnit(d[b],"")+")",delete a[b]);"scaleZ"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" scaleZ("+setUnit(d[b],"")+")",delete a[b]);"skew"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" skew("+setUnit(d[b],
|
|||
|
"deg")+")",delete a[b]);"skewX"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" skewX("+setUnit(d[b],"deg")+")",delete a[b]);"skewY"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" skewY("+setUnit(d[b],"deg")+")",delete a[b]);"perspective"===b&&(c=jQuery.CSS.sfx+"transform",a[c]=a[c]||"",a[c]+=" perspective("+setUnit(d[b],"px")+")",delete a[b])}return a},getProp:function(d){var a=[],b;for(b in d)0>a.indexOf(b)&&a.push(uncamel(b));return a.join(",")},animate:function(d,a,b,c,g){return this.each(function(){function n(){e.called=
|
|||
|
!0;e.CSSAIsRunning=!1;h.off(jQuery.CSS.transitionEnd+"."+e.id);clearTimeout(e.timeout);h.css(jQuery.CSS.sfx+"transition","");"function"==typeof g&&g.apply(e);"function"==typeof e.CSSqueue&&(e.CSSqueue(),e.CSSqueue=null)}var e=this,h=jQuery(this);e.id=e.id||"CSSA_"+(new Date).getTime();var k=k||{type:"noEvent"};if(e.CSSAIsRunning&&e.eventType==k.type&&!jQuery.mbBrowser.msie&&9>=jQuery.mbBrowser.version)e.CSSqueue=function(){h.CSSAnimate(d,a,b,c,g)};else if(e.CSSqueue=null,e.eventType=k.type,0!==h.length&&
|
|||
|
d){d=jQuery.normalizeCss(d);e.CSSAIsRunning=!0;"function"==typeof a&&(g=a,a=jQuery.fx.speeds._default);"function"==typeof b&&(c=b,b=0);"string"==typeof b&&(g=b,b=0);"function"==typeof c&&(g=c,c="cubic-bezier(0.65,0.03,0.36,0.72)");if("string"==typeof a)for(var l in jQuery.fx.speeds)if(a==l){a=jQuery.fx.speeds[l];break}else a=jQuery.fx.speeds._default;a||(a=jQuery.fx.speeds._default);"string"===typeof g&&(c=g,g=null);if(jQuery.support.CSStransition){var f={"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)"};
|
|||
|
f[c]&&(c=f[c]);h.off(jQuery.CSS.transitionEnd+"."+e.id);f=jQuery.CSS.getProp(d);var m={};jQuery.extend(m,d);m[jQuery.CSS.sfx+"transition-property"]=f;m[jQuery.CSS.sfx+"transition-duration"]=a+"ms";m[jQuery.CSS.sfx+"transition-delay"]=b+"ms";m[jQuery.CSS.sfx+"transition-timing-function"]=c;setTimeout(function(){h.one(jQuery.CSS.transitionEnd+"."+e.id,n);h.css(m)},1);e.timeout=setTimeout(function(){e.called||!g?(e.called=!1,e.CSSAIsRunning=!1):(h.css(jQuery.CSS.sfx+"transition",""),g.apply(e),e.CSSAIsRunning=
|
|||
|
!1,"function"==typeof e.CSSqueue&&(e.CSSqueue(),e.CSSqueue=null))},a+b+10)}else{for(f in d)"transform"===f&&delete d[f],"filter"===f&&delete d[f],"transform-origin"===f&&delete d[f],"auto"===d[f]&&delete d[f],"x"===f&&(k=d[f],l="left",d[l]=k,delete d[f]),"y"===f&&(k=d[f],l="top",d[l]=k,delete d[f]),"-ms-transform"!==f&&"-ms-filter"!==f||delete d[f];h.delay(b).animate(d,a,g)}}})}};jQuery.fn.CSSAnimate=jQuery.CSS.animate;jQuery.normalizeCss=jQuery.CSS.normalizeCss;
|
|||
|
jQuery.fn.css3=function(d){return this.each(function(){var a=jQuery(this),b=jQuery.normalizeCss(d);a.css(b)})};
|
|||
|
/*___________________________________________________________________________________________________________________________________________________
|
|||
|
_ jquery.mb.components _
|
|||
|
_ _
|
|||
|
_ file: jquery.mb.simpleSlider.min.js _
|
|||
|
_ last modified: 09/05/17 19.31 _
|
|||
|
_ _
|
|||
|
_ 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-2017. Matteo Bicocchi (Pupunzi); _
|
|||
|
___________________________________________________________________________________________________________________________________________________*/
|
|||
|
(function(b){b.simpleSlider={defaults:{initialval:0,maxval:100,orientation:"h",readonly:!1,callback:!1},events:{start:b.mbBrowser.mobile?"touchstart":"mousedown",end:b.mbBrowser.mobile?"touchend":"mouseup",move:b.mbBrowser.mobile?"touchmove":"mousemove"},init:function(d){return this.each(function(){var a=this,c=b(a);c.addClass("simpleSlider");a.opt={};b.extend(a.opt,b.simpleSlider.defaults,d);b.extend(a.opt,c.data());var f="h"===a.opt.orientation?"horizontal":"vertical";f=b("<div/>").addClass("level").addClass(f);
|
|||
|
c.prepend(f);a.level=f;c.css({cursor:"default"});"auto"==a.opt.maxval&&(a.opt.maxval=b(a).outerWidth());c.updateSliderVal();a.opt.readonly||(c.on(b.simpleSlider.events.start,function(e){b.mbBrowser.mobile&&(e=e.changedTouches[0]);a.canSlide=!0;c.updateSliderVal(e);"h"===a.opt.orientation?c.css({cursor:"col-resize"}):c.css({cursor:"row-resize"});a.lastVal=a.val;b.mbBrowser.mobile||(e.preventDefault(),e.stopPropagation())}),b(document).on(b.simpleSlider.events.move,function(e){b.mbBrowser.mobile&&(e=e.changedTouches[0]);
|
|||
|
a.canSlide&&(b(document).css({cursor:"default"}),c.updateSliderVal(e),b.mbBrowser.mobile||(e.preventDefault(),e.stopPropagation()))}).on(b.simpleSlider.events.end,function(){b(document).css({cursor:"auto"});a.canSlide=!1;c.css({cursor:"auto"})}))})},updateSliderVal:function(d){var a=this.get(0);if(a.opt){a.opt.initialval="number"==typeof a.opt.initialval?a.opt.initialval:a.opt.initialval(a);var c=b(a).outerWidth(),f=b(a).outerHeight();a.x="object"==typeof d?d.clientX+document.body.scrollLeft-this.offset().left:
|
|||
|
"number"==typeof d?d*c/a.opt.maxval:a.opt.initialval*c/a.opt.maxval;a.y="object"==typeof d?d.clientY+document.body.scrollTop-this.offset().top:"number"==typeof d?(a.opt.maxval-a.opt.initialval-d)*f/a.opt.maxval:a.opt.initialval*f/a.opt.maxval;a.y=this.outerHeight()-a.y;a.scaleX=a.x*a.opt.maxval/c;a.scaleY=a.y*a.opt.maxval/f;a.outOfRangeX=a.scaleX>a.opt.maxval?a.scaleX-a.opt.maxval:0>a.scaleX?a.scaleX:0;a.outOfRangeY=a.scaleY>a.opt.maxval?a.scaleY-a.opt.maxval:0>a.scaleY?a.scaleY:0;a.outOfRange="h"===
|
|||
|
a.opt.orientation?a.outOfRangeX:a.outOfRangeY;a.value="undefined"!=typeof d?"h"===a.opt.orientation?a.x>=this.outerWidth()?a.opt.maxval:0>=a.x?0:a.scaleX:a.y>=this.outerHeight()?a.opt.maxval:0>=a.y?0:a.scaleY:"h"===a.opt.orientation?a.scaleX:a.scaleY;"h"===a.opt.orientation?a.level.width(Math.floor(100*a.x/c)+"%"):a.level.height(Math.floor(100*a.y/f));a.lastVal===a.value&&("h"===a.opt.orientation&&(a.x>=this.outerWidth()||0>=a.x)||"h"!==a.opt.orientation&&(a.y>=this.outerHeight()||0>=a.y))||("function"===
|
|||
|
typeof a.opt.callback&&a.opt.callback(a),a.lastVal=a.value)}}};b.fn.simpleSlider=b.simpleSlider.init;b.fn.updateSliderVal=b.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(d){d.mbCookie={set:function(a,c,f,b){"object"==typeof c&&(c=JSON.stringify(c));b=b?"; domain="+b:"";var e=new Date,d="";0<f&&(e.setTime(e.getTime()+864E5*f),d="; expires="+e.toGMTString());document.cookie=a+"="+c+d+"; path=/"+b},get:function(a){a+="=";for(var c=document.cookie.split(";"),d=0;d<c.length;d++){for(var b=c[d];" "==b.charAt(0);)b=b.substring(1,b.length);if(0==b.indexOf(a))try{return JSON.parse(b.substring(a.length,b.length))}catch(e){return b.substring(a.length,b.length)}}return null},
|
|||
|
remove:function(a){d.mbCookie.set(a,"",-1)}};d.mbStorage={set:function(a,c){"object"==typeof c&&(c=JSON.stringify(c));localStorage.setItem(a,c)},get:function(a){if(localStorage[a])try{return JSON.parse(localStorage[a])}catch(c){return localStorage[a]}else return null},remove:function(a){a?localStorage.removeItem(a):localStorage.clear()}}})(jQuery);
|
|||
|
/*___________________________________________________________________________________________________________________________________________________
|
|||
|
_ jquery.mb.components _
|
|||
|
_ _
|
|||
|
_ file: jquery.mbBrowser.min.js _
|
|||
|
_ last modified: 1/23/21 4:18 PM _
|
|||
|
_ _
|
|||
|
_ 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-2021. Matteo Bicocchi (Pupunzi); _
|
|||
|
___________________________________________________________________________________________________________________________________________________*/
|
|||
|
|
|||
|
var nAgt=navigator.userAgent;jQuery.mbBrowser={};jQuery.mbBrowser.mozilla=!1;jQuery.mbBrowser.webkit=!1;jQuery.mbBrowser.opera=!1;jQuery.mbBrowser.safari=!1;jQuery.mbBrowser.chrome=!1;jQuery.mbBrowser.androidStock=!1;jQuery.mbBrowser.msie=!1;jQuery.mbBrowser.edge=!1;jQuery.mbBrowser.ua=nAgt;function isTouchSupported(){var a=nAgt.msMaxTouchPoints,e="ontouchstart"in document.createElement("div");return a||e?!0:!1}
|
|||
|
var getOS=function(){var a={version:"Unknown version",name:"Unknown OS"};-1!=navigator.appVersion.indexOf("Win")&&(a.name="Windows");-1!=navigator.appVersion.indexOf("Mac")&&0>navigator.appVersion.indexOf("Mobile")&&(a.name="Mac");-1!=navigator.appVersion.indexOf("Linux")&&(a.name="Linux");/Mac OS X/.test(nAgt)&&!/Mobile/.test(nAgt)&&(a.version=/Mac OS X ([\._\d]+)/.exec(nAgt)[1],a.version=a.version.replace(/_/g,".").substring(0,5));/Windows/.test(nAgt)&&(a.version="Unknown.Unknown");/Windows NT 5.1/.test(nAgt)&&
|
|||
|
(a.version="5.1");/Windows NT 6.0/.test(nAgt)&&(a.version="6.0");/Windows NT 6.1/.test(nAgt)&&(a.version="6.1");/Windows NT 6.2/.test(nAgt)&&(a.version="6.2");/Windows NT 10.0/.test(nAgt)&&(a.version="10.0");/Linux/.test(nAgt)&&/Linux/.test(nAgt)&&(a.version="Unknown.Unknown");a.name=a.name.toLowerCase();a.major_version="Unknown";a.minor_version="Unknown";"Unknown.Unknown"!=a.version&&(a.major_version=parseFloat(a.version.split(".")[0]),a.minor_version=parseFloat(a.version.split(".")[1]));return a};
|
|||
|
jQuery.mbBrowser.os=getOS();jQuery.mbBrowser.hasTouch=isTouchSupported();jQuery.mbBrowser.name=navigator.appName;jQuery.mbBrowser.fullVersion=""+parseFloat(navigator.appVersion);jQuery.mbBrowser.majorVersion=parseInt(navigator.appVersion,10);var nameOffset,verOffset,ix;
|
|||
|
if(-1!=(verOffset=nAgt.indexOf("Opera")))jQuery.mbBrowser.opera=!0,jQuery.mbBrowser.name="Opera",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+6),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+8));else if(-1!=(verOffset=nAgt.indexOf("OPR")))jQuery.mbBrowser.opera=!0,jQuery.mbBrowser.name="Opera",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+4);else if(-1!=(verOffset=nAgt.indexOf("MSIE")))jQuery.mbBrowser.msie=!0,jQuery.mbBrowser.name=
|
|||
|
"Microsoft Internet Explorer",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+5);else if(-1!=nAgt.indexOf("Trident")){jQuery.mbBrowser.msie=!0;jQuery.mbBrowser.name="Microsoft Internet Explorer";var start=nAgt.indexOf("rv:")+3,end=start+4;jQuery.mbBrowser.fullVersion=nAgt.substring(start,end)}else-1!=(verOffset=nAgt.indexOf("Edge"))?(jQuery.mbBrowser.edge=!0,jQuery.mbBrowser.name="Microsoft Edge",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+5)):-1!=(verOffset=nAgt.indexOf("Chrome"))?
|
|||
|
(jQuery.mbBrowser.webkit=!0,jQuery.mbBrowser.chrome=!0,jQuery.mbBrowser.name="Chrome",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+7)):-1<nAgt.indexOf("mozilla/5.0")&&-1<nAgt.indexOf("android ")&&-1<nAgt.indexOf("applewebkit")&&!(-1<nAgt.indexOf("chrome"))?(verOffset=nAgt.indexOf("Chrome"),jQuery.mbBrowser.webkit=!0,jQuery.mbBrowser.androidStock=!0,jQuery.mbBrowser.name="androidStock",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+7)):-1!=(verOffset=nAgt.indexOf("Safari"))?(jQuery.mbBrowser.webkit=
|
|||
|
!0,jQuery.mbBrowser.safari=!0,jQuery.mbBrowser.name="Safari",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+7),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+8))):-1!=(verOffset=nAgt.indexOf("AppleWebkit"))?(jQuery.mbBrowser.webkit=!0,jQuery.mbBrowser.safari=!0,jQuery.mbBrowser.name="Safari",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+7),-1!=(verOffset=nAgt.indexOf("Version"))&&(jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+
|
|||
|
8))):-1!=(verOffset=nAgt.indexOf("Firefox"))?(jQuery.mbBrowser.mozilla=!0,jQuery.mbBrowser.name="Firefox",jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+8)):(nameOffset=nAgt.lastIndexOf(" ")+1)<(verOffset=nAgt.lastIndexOf("/"))&&(jQuery.mbBrowser.name=nAgt.substring(nameOffset,verOffset),jQuery.mbBrowser.fullVersion=nAgt.substring(verOffset+1),jQuery.mbBrowser.name.toLowerCase()==jQuery.mbBrowser.name.toUpperCase()&&(jQuery.mbBrowser.name=navigator.appName));
|
|||
|
-1!=(ix=jQuery.mbBrowser.fullVersion.indexOf(";"))&&(jQuery.mbBrowser.fullVersion=jQuery.mbBrowser.fullVersion.substring(0,ix));-1!=(ix=jQuery.mbBrowser.fullVersion.indexOf(" "))&&(jQuery.mbBrowser.fullVersion=jQuery.mbBrowser.fullVersion.substring(0,ix));jQuery.mbBrowser.majorVersion=parseInt(""+jQuery.mbBrowser.fullVersion,10);isNaN(jQuery.mbBrowser.majorVersion)&&(jQuery.mbBrowser.fullVersion=""+parseFloat(navigator.appVersion),jQuery.mbBrowser.majorVersion=parseInt(navigator.appVersion,10));
|
|||
|
jQuery.mbBrowser.version=jQuery.mbBrowser.majorVersion;jQuery.mbBrowser.android=/Android/i.test(nAgt);jQuery.mbBrowser.blackberry=/BlackBerry|BB|PlayBook/i.test(nAgt);jQuery.mbBrowser.ios=/iPhone|iPad|iPod|webOS/i.test(nAgt);jQuery.mbBrowser.operaMobile=/Opera Mini/i.test(nAgt);jQuery.mbBrowser.windowsMobile=/IEMobile|Windows Phone/i.test(nAgt);jQuery.mbBrowser.kindle=/Kindle|Silk/i.test(nAgt);
|
|||
|
jQuery.mbBrowser.mobile=jQuery.mbBrowser.android||jQuery.mbBrowser.blackberry||jQuery.mbBrowser.ios||jQuery.mbBrowser.windowsMobile||jQuery.mbBrowser.operaMobile||jQuery.mbBrowser.kindle;jQuery.isMobile=jQuery.mbBrowser.mobile;jQuery.isTablet=jQuery.mbBrowser.mobile&&765<jQuery(window).width();jQuery.isAndroidDefault=jQuery.mbBrowser.android&&!/chrome/i.test(nAgt);jQuery.mbBrowser=jQuery.mbBrowser;
|
|||
|
jQuery.mbBrowser.versionCompare=function(a,e){if("stringstring"!=typeof a+typeof e)return!1;for(var c=a.split("."),d=e.split("."),b=0,f=Math.max(c.length,d.length);b<f;b++){if(c[b]&&!d[b]&&0<parseInt(c[b])||parseInt(c[b])>parseInt(d[b]))return 1;if(d[b]&&!c[b]&&0<parseInt(d[b])||parseInt(c[b])<parseInt(d[b]))return-1}return 0};
|