/*jquery.mb.YTPlayer 05-04-2017
_ jquery.mb.components
_ email: matteo@open-lab.com
_ Copyright (c) 2001-2017. Matteo Bicocchi (Pupunzi);
_ blog: http://pupunzi.open-lab.com
_ Open Lab s.r.l., Florence - Italy
*/
function onYouTubeIframeAPIReady() {
ytp.YTAPIReady || (ytp.YTAPIReady = !0, jQuery(document).trigger("YTAPIReady"))
}
function uncamel(a) {
return a.replace(/([A-Z])/g, function(a) {
return "-" + a.toLowerCase()
})
}
function setUnit(a, b) {
return "string" != typeof a || a.match(/^[\-0-9\.]+jQuery/) ? "" + a + b : a
}
function setFilter(a, b, c) {
var d = uncamel(b),
e = jQuery.browser.mozilla ? "" : jQuery.CSS.sfx;
a[e + "filter"] = a[e + "filter"] || "", c = setUnit(c > jQuery.CSS.filters[b].max ? jQuery.CSS.filters[b].max : c, jQuery.CSS.filters[b].unit), a[e + "filter"] += d + "(" + c + ") ", delete a[b]
}
var ytp = ytp || {},
getYTPVideoID = function(a) {
var b, c;
return a.indexOf("youtu.be") > 0 ? (b = a.substr(a.lastIndexOf("/") + 1, a.length), c = b.indexOf("?list=") > 0 ? b.substr(b.lastIndexOf("="), b.length) : null, b = c ? b.substr(0, b.lastIndexOf("?")) : b) : a.indexOf("http") > -1 ? (b = a.match(/[\\?&]v=([^]*)/)[1], c = a.indexOf("list=") > 0 ? a.match(/[\\?&]list=([^]*)/)[1] : null) : (b = a.length > 15 ? null : a, c = b ? null : a), {
videoID: b,
playlistID: c
}
};
! function(jQuery, ytp) {
jQuery.mbYTPlayer = {
name: "jquery.mb.YTPlayer",
version: "3.0.12",
build: "6159",
author: "Matteo Bicocchi (pupunzi)",
apiKey: "",
defaults: {
containment: "body",
ratio: "auto",
videoURL: null,
playlistURL: null,
startAt: 0,
stopAt: 0,
autoPlay: !0,
vol: 50,
addRaster: !1,
mask: !1,
opacity: 1,
quality: "default",
mute: !1,
loop: !0,
fadeOnStartTime: 500,
showControls: !0,
showAnnotations: !1,
showYTLogo: !0,
stopMovieOnBlur: !0,
realfullscreen: !0,
mobileFallbackImage: null,
gaTrack: !0,
optimizeDisplay: !0,
anchor: "center,center",
onReady: function(a) {},
onError: function(a, b) {}
},
controls: {
play: "P",
pause: "p",
mute: "M",
unmute: "A",
onlyYT: "O",
showSite: "R",
ytLogo: "Y"
},
controlBar: null,
loading: null,
locationProtocol: "https:",
filters: {
grayscale: {
value: 0,
unit: "%"
},
hue_rotate: {
value: 0,
unit: "deg"
},
invert: {
value: 0,
unit: "%"
},
opacity: {
value: 0,
unit: "%"
},
saturate: {
value: 0,
unit: "%"
},
sepia: {
value: 0,
unit: "%"
},
brightness: {
value: 0,
unit: "%"
},
contrast: {
value: 0,
unit: "%"
},
blur: {
value: 0,
unit: "px"
}
},
buildPlayer: function(options) {
return this.each(function() {
var YTPlayer = this,
$YTPlayer = jQuery(YTPlayer);
YTPlayer.loop = 0, YTPlayer.opt = {}, YTPlayer.state = {}, YTPlayer.filters = jQuery.mbYTPlayer.filters, YTPlayer.filtersEnabled = !0, YTPlayer.id = YTPlayer.id || "YTP_" + (new Date).getTime(), $YTPlayer.addClass("mb_YTPlayer");
var property = $YTPlayer.data("property") && "string" == typeof $YTPlayer.data("property") ? eval("(" + $YTPlayer.data("property") + ")") : $YTPlayer.data("property");
"undefined" != typeof property && "undefined" != typeof property.vol && (property.vol = 0 === property.vol ? property.vol = 1 : property.vol), jQuery.extend(YTPlayer.opt, jQuery.mbYTPlayer.defaults, options, property), YTPlayer.hasChanged || (YTPlayer.defaultOpt = {}, jQuery.extend(YTPlayer.defaultOpt, jQuery.mbYTPlayer.defaults, options)), "true" == YTPlayer.opt.loop && (YTPlayer.opt.loop = 9999), YTPlayer.isRetina = window.retina || window.devicePixelRatio > 1;
var isIframe = function() {
var a = !1;
try {
self.location.href != top.location.href && (a = !0)
} catch (b) {
a = !0
}
return a
};
YTPlayer.canGoFullScreen = !(jQuery.browser.msie || jQuery.browser.opera || isIframe()), YTPlayer.canGoFullScreen || (YTPlayer.opt.realfullscreen = !1), $YTPlayer.attr("id") || $YTPlayer.attr("id", "ytp_" + (new Date).getTime());
var playerID = "iframe_" + YTPlayer.id;
YTPlayer.isAlone = !1, YTPlayer.hasFocus = !0, YTPlayer.videoID = this.opt.videoURL ? getYTPVideoID(this.opt.videoURL).videoID : $YTPlayer.attr("href") ? getYTPVideoID($YTPlayer.attr("href")).videoID : !1, YTPlayer.playlistID = this.opt.videoURL ? getYTPVideoID(this.opt.videoURL).playlistID : $YTPlayer.attr("href") ? getYTPVideoID($YTPlayer.attr("href")).playlistID : !1, YTPlayer.opt.showAnnotations = YTPlayer.opt.showAnnotations ? "0" : "3";
var playerVars = {
modestbranding: 1,
autoplay: 0,
controls: 0,
showinfo: 0,
rel: 0,
enablejsapi: 1,
version: 3,
playerapiid: playerID,
origin: "*",
allowfullscreen: !0,
wmode: "transparent",
iv_load_policy: YTPlayer.opt.showAnnotations
};
if (document.createElement("video").canPlayType && jQuery.extend(playerVars, {
html5: 1
}), jQuery.browser.msie && jQuery.browser.version < 9 && (this.opt.opacity = 1), YTPlayer.isSelf = "self" == YTPlayer.opt.containment, YTPlayer.defaultOpt.containment = YTPlayer.opt.containment = jQuery("self" == YTPlayer.opt.containment ? this : YTPlayer.opt.containment), YTPlayer.isBackground = YTPlayer.opt.containment.is("body"), !YTPlayer.isBackground || !ytp.backgroundIsInited) {
var isPlayer = YTPlayer.opt.containment.is(jQuery(this));
YTPlayer.canPlayOnMobile = isPlayer && 0 === jQuery(this).children().length, YTPlayer.isPlayer = !1, isPlayer ? YTPlayer.isPlayer = !0 : $YTPlayer.hide();
var overlay = jQuery("
").css({
position: "absolute",
top: 0,
left: 0,
width: "100%",
height: "100%"
}).addClass("YTPOverlay");
YTPlayer.isPlayer && overlay.on("click", function() {
$YTPlayer.YTPTogglePlay()
});
var wrapper = jQuery("").addClass("mbYTP_wrapper").attr("id", "wrapper_" + YTPlayer.id);
wrapper.css({
position: "absolute",
zIndex: 0,
minWidth: "100%",
minHeight: "100%",
left: 0,
top: 0,
overflow: "hidden",
opacity: 0
});
var playerBox = jQuery("").attr("id", playerID).addClass("playerBox");
if (playerBox.css({
position: "absolute",
zIndex: 0,
width: "100%",
height: "100%",
top: 0,
left: 0,
overflow: "hidden"
}), wrapper.append(playerBox), YTPlayer.opt.containment.children().not("script, style").each(function() {
"static" == jQuery(this).css("position") && jQuery(this).css("position", "relative")
}), YTPlayer.isBackground ? (jQuery("body").css({
boxSizing: "border-box"
}), wrapper.css({
position: "fixed",
top: 0,
left: 0,
zIndex: 0
}), $YTPlayer.hide()) : "static" == YTPlayer.opt.containment.css("position") && YTPlayer.opt.containment.css({
position: "relative"
}), YTPlayer.opt.containment.prepend(wrapper), YTPlayer.wrapper = wrapper, playerBox.css({
opacity: 1
}), jQuery.browser.mobile || (playerBox.after(overlay), YTPlayer.overlay = overlay), YTPlayer.isBackground || overlay.on("mouseenter", function() {
YTPlayer.controlBar && YTPlayer.controlBar.length && YTPlayer.controlBar.addClass("visible")
}).on("mouseleave", function() {
YTPlayer.controlBar && YTPlayer.controlBar.length && YTPlayer.controlBar.removeClass("visible")
}), ytp.YTAPIReady) setTimeout(function() {
jQuery(document).trigger("YTAPIReady")
}, 100);
else {
jQuery("#YTAPI").remove();
var tag = jQuery("").attr({
src: jQuery.mbYTPlayer.locationProtocol + "//www.youtube.com/iframe_api?v=" + jQuery.mbYTPlayer.version,
id: "YTAPI"
});
jQuery("head").prepend(tag)
}
if (jQuery.browser.mobile && !YTPlayer.canPlayOnMobile) return YTPlayer.opt.mobileFallbackImage && wrapper.css({
backgroundImage: "url(" + YTPlayer.opt.mobileFallbackImage + ")",
backgroundPosition: "center center",
backgroundSize: "cover",
backgroundRepeat: "no-repeat",
opacity: 1
}), $YTPlayer.remove(), void jQuery(document).trigger("YTPUnavailable");
jQuery(document).on("YTAPIReady", function() {
YTPlayer.isBackground && ytp.backgroundIsInited || YTPlayer.isInit || (YTPlayer.isBackground && (ytp.backgroundIsInited = !0), YTPlayer.opt.autoPlay = "undefined" == typeof YTPlayer.opt.autoPlay ? !!YTPlayer.isBackground : YTPlayer.opt.autoPlay, YTPlayer.opt.vol = YTPlayer.opt.vol ? YTPlayer.opt.vol : 100, jQuery.mbYTPlayer.getDataFromAPI(YTPlayer), jQuery(YTPlayer).on("YTPChanged", function() {
if (!YTPlayer.isInit) {
if (YTPlayer.isInit = !0, jQuery.browser.mobile && YTPlayer.canPlayOnMobile) {
if (YTPlayer.opt.containment.outerWidth() > jQuery(window).width()) {
YTPlayer.opt.containment.css({
maxWidth: "100%"
});
var h = .563 * YTPlayer.opt.containment.outerWidth();
YTPlayer.opt.containment.css({
maxHeight: h
})
}
return void new YT.Player(playerID, {
videoId: YTPlayer.videoID.toString(),
width: "100%",
height: h,
playerVars: playerVars,
events: {
onReady: function(a) {
YTPlayer.player = a.target, playerBox.css({
opacity: 1
}), YTPlayer.wrapper.css({
opacity: 1
})
}
}
})
}
new YT.Player(playerID, {
videoId: YTPlayer.videoID.toString(),
playerVars: playerVars,
events: {
onReady: function(a) {
YTPlayer.player = a.target, YTPlayer.isReady || (YTPlayer.isReady = !YTPlayer.isPlayer || YTPlayer.opt.autoPlay, YTPlayer.playerEl = YTPlayer.player.getIframe(), jQuery(YTPlayer.playerEl).unselectable(), $YTPlayer.optimizeDisplay(), jQuery(window).off("resize.YTP_" + YTPlayer.id).on("resize.YTP_" + YTPlayer.id, function() {
$YTPlayer.optimizeDisplay()
}), jQuery.mbYTPlayer.checkForState(YTPlayer))
},
onStateChange: function(event) {
if ("function" == typeof event.target.getPlayerState) {
var state = event.target.getPlayerState();
if (YTPlayer.preventTrigger) return void(YTPlayer.preventTrigger = !1);
YTPlayer.state = state;
var eventType;
switch (state) {
case -1:
eventType = "YTPUnstarted";
break;
case 0:
eventType = "YTPEnd";
break;
case 1:
eventType = "YTPPlay", YTPlayer.controlBar.length && YTPlayer.controlBar.find(".mb_YTPPlaypause").html(jQuery.mbYTPlayer.controls.pause), "undefined" != typeof _gaq && eval(YTPlayer.opt.gaTrack) && _gaq.push(["_trackEvent", "YTPlayer", "Play", YTPlayer.hasData ? YTPlayer.videoData.title : YTPlayer.videoID.toString()]), "undefined" != typeof ga && eval(YTPlayer.opt.gaTrack) && ga("send", "event", "YTPlayer", "play", YTPlayer.hasData ? YTPlayer.videoData.title : YTPlayer.videoID.toString());
break;
case 2:
eventType = "YTPPause", YTPlayer.controlBar.length && YTPlayer.controlBar.find(".mb_YTPPlaypause").html(jQuery.mbYTPlayer.controls.play);
break;
case 3:
YTPlayer.player.setPlaybackQuality(YTPlayer.opt.quality), eventType = "YTPBuffering", YTPlayer.controlBar.length && YTPlayer.controlBar.find(".mb_YTPPlaypause").html(jQuery.mbYTPlayer.controls.play);
break;
case 5:
eventType = "YTPCued"
}
var YTPEvent = jQuery.Event(eventType);
YTPEvent.time = YTPlayer.currentTime, YTPlayer.canTrigger && jQuery(YTPlayer).trigger(YTPEvent)
}
},
onPlaybackQualityChange: function(a) {
var b = a.target.getPlaybackQuality(),
c = jQuery.Event("YTPQualityChange");
c.quality = b, jQuery(YTPlayer).trigger(c)
},
onError: function(a) {
150 == a.data && (console.log("Embedding this video is restricted by Youtube."), YTPlayer.isPlayList && jQuery(YTPlayer).playNext()), 2 == a.data && YTPlayer.isPlayList && jQuery(YTPlayer).playNext(), "function" == typeof YTPlayer.opt.onError && YTPlayer.opt.onError($YTPlayer, a)
}
}
})
}
}))
}), $YTPlayer.off("YTPTime.mask"), jQuery.mbYTPlayer.applyMask(YTPlayer)
}
})
},
getDataFromAPI: function(a) {
if (a.videoData = jQuery.mbStorage.get("YTPlayer_data_" + a.videoID), jQuery(a).off("YTPData.YTPlayer").on("YTPData.YTPlayer", function() {
if (a.hasData && a.isPlayer && !a.opt.autoPlay) {
var b = a.videoData.thumb_max || a.videoData.thumb_high || a.videoData.thumb_medium;
a.opt.containment.css({
background: "rgba(0,0,0,0.5) url(" + b + ") center center",
backgroundSize: "cover"
}), a.opt.backgroundUrl = b
}
}), a.videoData) setTimeout(function() {
a.opt.ratio = "auto" == a.opt.ratio ? "16/9" : a.opt.ratio, a.dataReceived = !0, jQuery(a).trigger("YTPChanged");
var b = jQuery.Event("YTPData");
b.prop = {};
for (var c in a.videoData) b.prop[c] = a.videoData[c];
jQuery(a).trigger(b)
}, a.opt.fadeOnStartTime), a.hasData = !0;
else if (jQuery.mbYTPlayer.apiKey) jQuery.getJSON(jQuery.mbYTPlayer.locationProtocol + "//www.googleapis.com/youtube/v3/videos?id=" + a.videoID + "&key=" + jQuery.mbYTPlayer.apiKey + "&part=snippet", function(b) {
function c(b) {
a.videoData = {}, a.videoData.id = a.videoID, a.videoData.channelTitle = b.channelTitle, a.videoData.title = b.title, a.videoData.description = b.description.length < 400 ? b.description : b.description.substring(0, 400) + " ...", a.videoData.aspectratio = "auto" == a.opt.ratio ? "16/9" : a.opt.ratio, a.opt.ratio = a.videoData.aspectratio, a.videoData.thumb_max = b.thumbnails.maxres ? b.thumbnails.maxres.url : null, a.videoData.thumb_high = b.thumbnails.high ? b.thumbnails.high.url : null, a.videoData.thumb_medium = b.thumbnails.medium ? b.thumbnails.medium.url : null, jQuery.mbStorage.set("YTPlayer_data_" + a.videoID, a.videoData)
}
a.dataReceived = !0, jQuery(a).trigger("YTPChanged"), c(b.items[0].snippet), a.hasData = !0;
var d = jQuery.Event("YTPData");
d.prop = {};
for (var e in a.videoData) d.prop[e] = a.videoData[e];
jQuery(a).trigger(d)
});
else {
if (setTimeout(function() {
jQuery(a).trigger("YTPChanged")
}, 50), a.isPlayer && !a.opt.autoPlay) {
var b = jQuery.mbYTPlayer.locationProtocol + "//i.ytimg.com/vi/" + a.videoID + "/hqdefault.jpg";
b && a.opt.containment.css({
background: "rgba(0,0,0,0.5) url(" + b + ") center center",
backgroundSize: "cover"
}), a.opt.backgroundUrl = b
}
a.videoData = null, a.opt.ratio = "auto" == a.opt.ratio ? "16/9" : a.opt.ratio
}!a.isPlayer || a.opt.autoPlay || jQuery.browser.mobile || (a.loading = jQuery("").addClass("loading").html("Loading").hide(), jQuery(a).append(a.loading), a.loading.fadeIn())
},
removeStoredData: function() {
jQuery.mbStorage.remove()
},
getVideoData: function() {
var a = this.get(0);
return a.videoData
},
getVideoID: function() {
var a = this.get(0);
return a.videoID || !1
},
setVideoQuality: function(a) {
var b = this.get(0);
b.player.setPlaybackQuality(a)
},
playlist: function(a, b, c, d) {
var e = this,
f = e.get(0);
return f.isPlayList = !0, b && (a = jQuery.shuffle(a)), f.videoID || (f.videos = a, f.videoCounter = 0, f.videoLength = a.length, jQuery(f).data("property", a[0]), jQuery(f).mb_YTPlayer()), "function" == typeof c && jQuery(f).one("YTPChanged", function() {
c(f)
}), jQuery(f).on("YTPEnd", function() {
d = "undefined" == typeof d ? !0 : d, jQuery(f).playNext(d)
}), this
},
playNext: function(a) {
var b = this.get(0);
return b.checkForStartAt && (clearTimeout(b.checkForStartAt), clearInterval(b.getState)), b.videoCounter++, b.videoCounter >= b.videoLength && a && (b.videoCounter = 0), b.videoCounter < b.videoLength ? jQuery(b).YTPChangeMovie(b.videos[b.videoCounter]) : b.videoCounter--, this
},
playPrev: function() {
var a = this.get(0);
return a.checkForStartAt && (clearInterval(a.checkForStartAt), clearInterval(a.getState)), a.videoCounter--, a.videoCounter < 0 && (a.videoCounter = a.videoLength - 1), jQuery(a).YTPChangeMovie(a.videos[a.videoCounter]), this
},
playIndex: function(a) {
var b = this.get(0);
return a -= 1, b.checkForStartAt && (clearInterval(b.checkForStartAt), clearInterval(b.getState)), b.videoCounter = a, b.videoCounter >= b.videoLength - 1 && (b.videoCounter = b.videoLength - 1), jQuery(b).YTPChangeMovie(b.videos[b.videoCounter]), this
},
changeMovie: function(a) {
var b = this,
c = b.get(0);
c.opt.startAt = 0, c.opt.stopAt = 0, c.opt.mask = !1, c.opt.mute = !0, c.hasData = !1, c.hasChanged = !0, c.player.loopTime = void 0, a && jQuery.extend(c.opt, a), c.videoID = getYTPVideoID(c.opt.videoURL).videoID, "true" == c.opt.loop && (c.opt.loop = 9999), jQuery(c.playerEl).CSSAnimate({
opacity: 0
}, c.opt.fadeOnStartTime, function() {
var a = jQuery.Event("YTPChangeMovie");
a.time = c.currentTime, a.videoId = c.videoID, jQuery(c).trigger(a), jQuery(c).YTPGetPlayer().cueVideoByUrl(encodeURI(jQuery.mbYTPlayer.locationProtocol + "//www.youtube.com/v/" + c.videoID), 1, c.opt.quality), jQuery(c).optimizeDisplay(), jQuery.mbYTPlayer.checkForState(c), jQuery.mbYTPlayer.getDataFromAPI(c)
}), jQuery.mbYTPlayer.applyMask(c)
},
getPlayer: function() {
return jQuery(this).get(0).player
},
playerDestroy: function() {
var a = this.get(0);
ytp.YTAPIReady = !0, ytp.backgroundIsInited = !1, a.isInit = !1, a.videoID = null, a.isReady = !1;
var b = a.wrapper;
return b.remove(), jQuery("#controlBar_" + a.id).remove(), clearInterval(a.checkForStartAt), clearInterval(a.getState), this
},
fullscreen: function(real) {
function hideMouse() {
YTPlayer.overlay.css({
cursor: "none"
})
}
function RunPrefixMethod(a, b) {
for (var c, d, e = ["webkit", "moz", "ms", "o", ""], f = 0; f < e.length && !a[c];) {
if (c = b, "" == e[f] && (c = c.substr(0, 1).toLowerCase() + c.substr(1)), c = e[f] + c, d = typeof a[c], "undefined" != d) return e = [e[f]], "function" == d ? a[c]() : a[c];
f++
}
}
function launchFullscreen(a) {
RunPrefixMethod(a, "RequestFullScreen")
}
function cancelFullscreen() {
(RunPrefixMethod(document, "FullScreen") || RunPrefixMethod(document, "IsFullScreen")) && RunPrefixMethod(document, "CancelFullScreen")
}
var YTPlayer = this.get(0);
"undefined" == typeof real && (real = YTPlayer.opt.realfullscreen), real = eval(real);
var controls = jQuery("#controlBar_" + YTPlayer.id),
fullScreenBtn = controls.find(".mb_OnlyYT"),
videoWrapper = YTPlayer.isSelf ? YTPlayer.opt.containment : YTPlayer.wrapper;
if (real) {
var fullscreenchange = jQuery.browser.mozilla ? "mozfullscreenchange" : jQuery.browser.webkit ? "webkitfullscreenchange" : "fullscreenchange";
jQuery(document).off(fullscreenchange).on(fullscreenchange, function() {
var a = RunPrefixMethod(document, "IsFullScreen") || RunPrefixMethod(document, "FullScreen");
a ? (jQuery(YTPlayer).YTPSetVideoQuality("default"), jQuery(YTPlayer).trigger("YTPFullScreenStart")) : (YTPlayer.isAlone = !1, 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
}), YTPlayer.isBackground ? jQuery("body").after(controls) : YTPlayer.wrapper.before(controls), jQuery(window).resize(), jQuery(YTPlayer).trigger("YTPFullScreenEnd"))
})
}
return YTPlayer.isAlone ? (jQuery(document).off("mousemove.YTPlayer"), clearTimeout(YTPlayer.hideCursor), YTPlayer.overlay.css({
cursor: "auto"
}), real ? cancelFullscreen() : (videoWrapper.CSSAnimate({
opacity: YTPlayer.opt.opacity
}, YTPlayer.opt.fadeOnStartTime), videoWrapper.css({
zIndex: 0
})), fullScreenBtn.html(jQuery.mbYTPlayer.controls.onlyYT), YTPlayer.isAlone = !1) : (jQuery(document).on("mousemove.YTPlayer", function(a) {
YTPlayer.overlay.css({
cursor: "auto"
}), clearTimeout(YTPlayer.hideCursor), jQuery(a.target).parents().is(".mb_YTPBar") || (YTPlayer.hideCursor = setTimeout(hideMouse, 3e3))
}), hideMouse(), real ? (videoWrapper.css({
opacity: 0
}), videoWrapper.addClass("YTPFullscreen"), launchFullscreen(videoWrapper.get(0)), setTimeout(function() {
videoWrapper.CSSAnimate({
opacity: 1
}, 2 * YTPlayer.opt.fadeOnStartTime), YTPlayer.wrapper.append(controls), jQuery(YTPlayer).optimizeDisplay(), YTPlayer.player.seekTo(YTPlayer.player.getCurrentTime() + .1, !0)
}, YTPlayer.opt.fadeOnStartTime)) : videoWrapper.css({
zIndex: 1e4
}).CSSAnimate({
opacity: 1
}, 2 * YTPlayer.opt.fadeOnStartTime), fullScreenBtn.html(jQuery.mbYTPlayer.controls.showSite), YTPlayer.isAlone = !0), this
},
toggleLoops: function() {
var a = this.get(0),
b = a.opt;
return 1 == b.loop ? b.loop = 0 : (b.startAt ? a.player.seekTo(b.startAt) : a.player.playVideo(), b.loop = 1), this
},
play: function() {
var a = this.get(0);
if (!a.isReady) return this;
a.player.playVideo(), a.wrapper.CSSAnimate({
opacity: a.isAlone ? 1 : a.opt.opacity
}, 4 * a.opt.fadeOnStartTime), jQuery(a.playerEl).CSSAnimate({
opacity: 1
}, 2 * a.opt.fadeOnStartTime);
var b = jQuery("#controlBar_" + a.id),
c = b.find(".mb_YTPPlaypause");
return c.html(jQuery.mbYTPlayer.controls.pause), a.state = 1, a.orig_background = jQuery(a).css("background-image"), this
},
togglePlay: function(a) {
var b = this.get(0);
return 1 == b.state ? this.YTPPause() : this.YTPPlay(), "function" == typeof a && a(b.state), this
},
stop: function() {
var a = this.get(0),
b = jQuery("#controlBar_" + a.id),
c = b.find(".mb_YTPPlaypause");
return c.html(jQuery.mbYTPlayer.controls.play), a.player.stopVideo(), this
},
pause: function() {
var a = this.get(0);
return a.player.pauseVideo(), a.state = 2, this
},
seekTo: function(a) {
var b = this.get(0);
return b.player.seekTo(a, !0), this
},
setVolume: function(a) {
var b = this.get(0);
return a || b.opt.vol || 0 != b.player.getVolume() ? !a && b.player.getVolume() > 0 || a && b.opt.vol == a ? b.isMute ? jQuery(b).YTPUnmute() : jQuery(b).YTPMute() : (b.opt.vol = a, b.player.setVolume(b.opt.vol), b.volumeBar && b.volumeBar.length && b.volumeBar.updateSliderVal(a)) : jQuery(b).YTPUnmute(), this
},
toggleVolume: function() {
var a = this.get(0);
if (a) return a.player.isMuted() ? (jQuery(a).YTPUnmute(), !0) : (jQuery(a).YTPMute(), !1)
},
mute: function() {
var a = this.get(0);
if (!a.isMute) {
a.player.mute(), a.isMute = !0, a.player.setVolume(0), a.volumeBar && a.volumeBar.length && a.volumeBar.width() > 10 && a.volumeBar.updateSliderVal(0);
var b = jQuery("#controlBar_" + a.id),
c = b.find(".mb_YTPMuteUnmute");
c.html(jQuery.mbYTPlayer.controls.unmute), jQuery(a).addClass("isMuted"), a.volumeBar && a.volumeBar.length && a.volumeBar.addClass("muted");
var d = jQuery.Event("YTPMuted");
return d.time = a.currentTime, a.canTrigger && jQuery(a).trigger(d), this
}
},
unmute: function() {
var a = this.get(0);
if (a.isMute) {
a.player.unMute(), a.isMute = !1, a.player.setVolume(a.opt.vol), a.volumeBar && a.volumeBar.length && a.volumeBar.updateSliderVal(a.opt.vol > 10 ? a.opt.vol : 10);
var b = jQuery("#controlBar_" + a.id),
c = b.find(".mb_YTPMuteUnmute");
c.html(jQuery.mbYTPlayer.controls.mute), jQuery(a).removeClass("isMuted"), a.volumeBar && a.volumeBar.length && a.volumeBar.removeClass("muted");
var d = jQuery.Event("YTPUnmuted");
return d.time = a.currentTime, a.canTrigger && jQuery(a).trigger(d), this
}
},
applyFilter: function(a, b) {
return this.each(function() {
var c = this;
c.filters[a].value = b, c.filtersEnabled && jQuery(c).YTPEnableFilters()
})
},
applyFilters: function(a) {
return this.each(function() {
var b = this;
if (!b.isReady) return void jQuery(b).on("YTPReady", function() {
jQuery(b).YTPApplyFilters(a)
});
for (var c in a) jQuery(b).YTPApplyFilter(c, a[c]);
jQuery(b).trigger("YTPFiltersApplied")
})
},
toggleFilter: function(a, b) {
return this.each(function() {
var c = this;
c.filters[a].value ? c.filters[a].value = 0 : c.filters[a].value = b, c.filtersEnabled && jQuery(this).YTPEnableFilters()
})
},
toggleFilters: function(a) {
return this.each(function() {
var b = this;
b.filtersEnabled ? (jQuery(b).trigger("YTPDisableFilters"), jQuery(b).YTPDisableFilters()) : (jQuery(b).YTPEnableFilters(), jQuery(b).trigger("YTPEnableFilters")), "function" == typeof a && a(b.filtersEnabled)
})
},
disableFilters: function() {
return this.each(function() {
var a = this,
b = jQuery(a.playerEl);
b.css("-webkit-filter", ""), b.css("filter", ""), a.filtersEnabled = !1
})
},
enableFilters: function() {
return this.each(function() {
var a = this,
b = jQuery(a.playerEl),
c = "";
for (var d in a.filters) a.filters[d].value && (c += d.replace("_", "-") + "(" + a.filters[d].value + a.filters[d].unit + ") ");
b.css("-webkit-filter", c), b.css("filter", c), a.filtersEnabled = !0
})
},
removeFilter: function(a, b) {
return this.each(function() {
var c = this;
if ("function" == typeof a && (b = a, a = null), a) jQuery(this).YTPApplyFilter(a, 0), "function" == typeof b && b(a);
else
for (var d in c.filters) jQuery(this).YTPApplyFilter(d, 0), "function" == typeof b && b(d)
})
},
getFilters: function() {
var a = this.get(0);
return a.filters
},
addMask: function(a) {
var b = this.get(0),
c = b.overlay;
a || (a = b.actualMask);
var d = jQuery("
").attr("src", a).on("load", function() {
c.CSSAnimate({
opacity: 0
}, b.opt.fadeOnStartTime, function() {
b.hasMask = !0, d.remove(), c.css({
backgroundImage: "url(" + a + ")",
backgroundRepeat: "no-repeat",
backgroundPosition: "center center",
backgroundSize: "cover"
}), c.CSSAnimate({
opacity: 1
}, b.opt.fadeOnStartTime)
})
});
return this
},
removeMask: function() {
var a = this.get(0),
b = a.overlay;
return b.CSSAnimate({
opacity: 0
}, a.opt.fadeOnStartTime, function() {
a.hasMask = !1, b.css({
backgroundImage: "",
backgroundRepeat: "",
backgroundPosition: "",
backgroundSize: ""
}), b.CSSAnimate({
opacity: 1
}, a.opt.fadeOnStartTime)
}), this
},
applyMask: function(a) {
var b = jQuery(a);
if (b.off("YTPTime.mask"), a.opt.mask)
if ("string" == typeof a.opt.mask) b.YTPAddMask(a.opt.mask), a.actualMask = a.opt.mask;
else if ("object" == typeof a.opt.mask) {
for (var c in a.opt.mask)
if (a.opt.mask[c]) {
jQuery("
").attr("src", a.opt.mask[c])
}
a.opt.mask[0] && b.YTPAddMask(a.opt.mask[0]), b.on("YTPTime.mask", function(c) {
for (var d in a.opt.mask) c.time == d && (a.opt.mask[d] ? (b.YTPAddMask(a.opt.mask[d]), a.actualMask = a.opt.mask[d]) : b.YTPRemoveMask())
})
}
},
toggleMask: function() {
var a = this.get(0),
b = $(a);
return a.hasMask ? b.YTPRemoveMask() : b.YTPAddMask(), this
},
manageProgress: function() {
var a = this.get(0),
b = jQuery("#controlBar_" + a.id),
c = b.find(".mb_YTPProgress"),
d = b.find(".mb_YTPLoaded"),
e = b.find(".mb_YTPseekbar"),
f = c.outerWidth(),
g = Math.floor(a.player.getCurrentTime()),
h = Math.floor(a.player.getDuration()),
i = g * f / h,
j = 0,
k = 100 * a.player.getVideoLoadedFraction();
return d.css({
left: j,
width: k + "%"
}), e.css({
left: 0,
width: i
}), {
totalTime: h,
currentTime: g
}
},
buildControls: function(YTPlayer) {
var data = YTPlayer.opt;
if (data.showYTLogo = data.showYTLogo || data.printUrl, !jQuery("#controlBar_" + YTPlayer.id).length) {
YTPlayer.controlBar = jQuery("").attr("id", "controlBar_" + YTPlayer.id).addClass("mb_YTPBar").css({
whiteSpace: "noWrap",
position: YTPlayer.isBackground ? "fixed" : "absolute",
zIndex: YTPlayer.isBackground ? 1e4 : 1e3
}).hide();
var buttonBar = jQuery("").addClass("buttonBar"),
playpause = jQuery("" + jQuery.mbYTPlayer.controls.play + "").addClass("mb_YTPPlaypause ytpicon").click(function() {
1 == YTPlayer.player.getPlayerState() ? jQuery(YTPlayer).YTPPause() : jQuery(YTPlayer).YTPPlay()
}),
MuteUnmute = jQuery("" + jQuery.mbYTPlayer.controls.mute + "").addClass("mb_YTPMuteUnmute ytpicon").click(function() {
0 == YTPlayer.player.getVolume() ? jQuery(YTPlayer).YTPUnmute() : jQuery(YTPlayer).YTPMute()
}),
volumeBar = jQuery("").addClass("mb_YTPVolumeBar").css({
display: "inline-block"
});
YTPlayer.volumeBar = volumeBar;
var idx = jQuery("").addClass("mb_YTPTime"),
vURL = data.videoURL ? data.videoURL : "";
vURL.indexOf("http") < 0 && (vURL = jQuery.mbYTPlayer.locationProtocol + "//www.youtube.com/watch?v=" + data.videoURL);
var movieUrl = jQuery("").html(jQuery.mbYTPlayer.controls.ytLogo).addClass("mb_YTPUrl ytpicon").attr("title", "view on YouTube").on("click", function() {
window.open(vURL, "viewOnYT")
}),
onlyVideo = jQuery("").html(jQuery.mbYTPlayer.controls.onlyYT).addClass("mb_OnlyYT ytpicon").on("click", function() {
jQuery(YTPlayer).YTPFullscreen(data.realfullscreen)
}),
progressBar = jQuery("").addClass("mb_YTPProgress").css("position", "absolute").click(function(a) {
timeBar.css({
width: a.clientX - timeBar.offset().left
}), YTPlayer.timeW = a.clientX - timeBar.offset().left, YTPlayer.controlBar.find(".mb_YTPLoaded").css({
width: 0
});
var b = Math.floor(YTPlayer.player.getDuration());
YTPlayer["goto"] = timeBar.outerWidth() * b / progressBar.outerWidth(), YTPlayer.player.seekTo(parseFloat(YTPlayer["goto"]), !0), YTPlayer.controlBar.find(".mb_YTPLoaded").css({
width: 0
})
}),
loadedBar = jQuery("").addClass("mb_YTPLoaded").css("position", "absolute"),
timeBar = jQuery("").addClass("mb_YTPseekbar").css("position", "absolute");
progressBar.append(loadedBar).append(timeBar), buttonBar.append(playpause).append(MuteUnmute).append(volumeBar).append(idx), data.showYTLogo && buttonBar.append(movieUrl), (YTPlayer.isBackground || eval(YTPlayer.opt.realfullscreen) && !YTPlayer.isBackground) && buttonBar.append(onlyVideo), YTPlayer.controlBar.append(buttonBar).append(progressBar), YTPlayer.isBackground ? jQuery("body").after(YTPlayer.controlBar) : (YTPlayer.controlBar.addClass("inlinePlayer"), YTPlayer.wrapper.before(YTPlayer.controlBar)), volumeBar.simpleSlider({
initialval: YTPlayer.opt.vol,
scale: 100,
orientation: "h",
callback: function(a) {
0 == a.value ? jQuery(YTPlayer).YTPMute() : jQuery(YTPlayer).YTPUnmute(), YTPlayer.player.setVolume(a.value), YTPlayer.isMute || (YTPlayer.opt.vol = a.value)
}
})
}
},
checkForState: function(YTPlayer) {
var interval = YTPlayer.opt.showControls ? 100 : 400;
return clearInterval(YTPlayer.getState), jQuery.contains(document, YTPlayer) ? (jQuery.mbYTPlayer.checkForStart(YTPlayer), void(YTPlayer.getState = setInterval(function() {
var prog = jQuery(YTPlayer).YTPManageProgress(),
$YTPlayer = jQuery(YTPlayer),
data = YTPlayer.opt,
startAt = YTPlayer.opt.startAt ? YTPlayer.opt.startAt : 1,
stopAt = YTPlayer.opt.stopAt > YTPlayer.opt.startAt ? YTPlayer.opt.stopAt : 0;
if (stopAt = stopAt < YTPlayer.player.getDuration() ? stopAt : 0, YTPlayer.currentTime != prog.currentTime) {
var YTPEvent = jQuery.Event("YTPTime");
YTPEvent.time = YTPlayer.currentTime, jQuery(YTPlayer).trigger(YTPEvent)
}
if (YTPlayer.currentTime = prog.currentTime, YTPlayer.totalTime = YTPlayer.player.getDuration(), 0 == YTPlayer.player.getVolume() ? $YTPlayer.addClass("isMuted") : $YTPlayer.removeClass("isMuted"), YTPlayer.opt.showControls && (prog.totalTime ? YTPlayer.controlBar.find(".mb_YTPTime").html(jQuery.mbYTPlayer.formatTime(prog.currentTime) + " / " + jQuery.mbYTPlayer.formatTime(prog.totalTime)) : YTPlayer.controlBar.find(".mb_YTPTime").html("-- : -- / -- : --")), eval(YTPlayer.opt.stopMovieOnBlur) && (document.hasFocus() ? document.hasFocus() && !YTPlayer.hasFocus && -1 != YTPlayer.state && 0 != YTPlayer.state && (YTPlayer.hasFocus = !0, $YTPlayer.YTPPlay()) : 1 == YTPlayer.state && (YTPlayer.hasFocus = !1, $YTPlayer.YTPPause())), YTPlayer.controlBar.length && YTPlayer.controlBar.outerWidth() <= 400 && !YTPlayer.isCompact ? (YTPlayer.controlBar.addClass("compact"), YTPlayer.isCompact = !0, !YTPlayer.isMute && YTPlayer.volumeBar && YTPlayer.volumeBar.updateSliderVal(YTPlayer.opt.vol)) : YTPlayer.controlBar.length && YTPlayer.controlBar.outerWidth() > 400 && YTPlayer.isCompact && (YTPlayer.controlBar.removeClass("compact"), YTPlayer.isCompact = !1, !YTPlayer.isMute && YTPlayer.volumeBar && YTPlayer.volumeBar.updateSliderVal(YTPlayer.opt.vol)), 1 == YTPlayer.player.getPlayerState() && (parseFloat(YTPlayer.player.getDuration() - .5) < YTPlayer.player.getCurrentTime() || stopAt > 0 && parseFloat(YTPlayer.player.getCurrentTime()) > stopAt)) {
if (YTPlayer.isEnded) return;
if (YTPlayer.isEnded = !0, setTimeout(function() {
YTPlayer.isEnded = !1
}, 1e3), YTPlayer.isPlayList) {
if (!data.loop || data.loop > 0 && YTPlayer.player.loopTime === data.loop - 1) {
YTPlayer.player.loopTime = void 0, clearInterval(YTPlayer.getState);
var YTPEnd = jQuery.Event("YTPEnd");
return YTPEnd.time = YTPlayer.currentTime, void jQuery(YTPlayer).trigger(YTPEnd)
}
} else if (!data.loop || data.loop > 0 && YTPlayer.player.loopTime === data.loop - 1) return YTPlayer.player.loopTime = void 0, YTPlayer.preventTrigger = !0, YTPlayer.state = 2, jQuery(YTPlayer).YTPPause(), void YTPlayer.wrapper.CSSAnimate({
opacity: 0
}, YTPlayer.opt.fadeOnStartTime, function() {
YTPlayer.controlBar.length && YTPlayer.controlBar.find(".mb_YTPPlaypause").html(jQuery.mbYTPlayer.controls.play);
var a = jQuery.Event("YTPEnd");
a.time = YTPlayer.currentTime, jQuery(YTPlayer).trigger(a), YTPlayer.player.seekTo(startAt, !0), YTPlayer.isBackground ? YTPlayer.orig_background && jQuery(YTPlayer).css("background-image", YTPlayer.orig_background) : YTPlayer.opt.backgroundUrl && YTPlayer.isPlayer && (YTPlayer.opt.backgroundUrl = YTPlayer.opt.backgroundUrl || YTPlayer.orig_background, YTPlayer.opt.containment.css({
background: "url(" + YTPlayer.opt.backgroundUrl + ") center center",
backgroundSize: "cover"
}))
});
YTPlayer.player.loopTime = YTPlayer.player.loopTime ? ++YTPlayer.player.loopTime : 1, startAt = startAt || 1, YTPlayer.preventTrigger = !0, YTPlayer.state = 2, jQuery(YTPlayer).YTPPause(), YTPlayer.player.seekTo(startAt, !0), $YTPlayer.YTPPlay()
}
}, interval))) : (jQuery(YTPlayer).YTPPlayerDestroy(), clearInterval(YTPlayer.getState), void clearInterval(YTPlayer.checkForStartAt))
},
getTime: function() {
var a = this.get(0);
return jQuery.mbYTPlayer.formatTime(a.currentTime)
},
getTotalTime: function() {
var a = this.get(0);
return jQuery.mbYTPlayer.formatTime(a.totalTime)
},
checkForStart: function(a) {
var b = jQuery(a);
if (!jQuery.contains(document, a)) return void jQuery(a).YTPPlayerDestroy();
if (a.preventTrigger = !0, a.state = 2, jQuery(a).YTPPause(), jQuery(a).muteYTPVolume(), jQuery("#controlBar_" + a.id).remove(), a.controlBar = !1, a.opt.showControls && jQuery.mbYTPlayer.buildControls(a), a.opt.addRaster) {
var c = "dot" == a.opt.addRaster ? "raster-dot" : "raster";
a.overlay.addClass(a.isRetina ? c + " retina" : c)
} else a.overlay.removeClass(function(a, b) {
var c = b.split(" "),
d = [];
return jQuery.each(c, function(a, b) {
/raster.*/.test(b) && d.push(b)
}), d.push("retina"), d.join(" ")
});
var d = a.opt.startAt ? a.opt.startAt : 1;
a.player.playVideo(), a.player.seekTo(d, !0), a.checkForStartAt = setInterval(function() {
jQuery(a).YTPMute();
var c = a.player.getVideoLoadedFraction() >= d / a.player.getDuration();
if (a.player.getDuration() > 0 && a.player.getCurrentTime() >= d && c) {
clearInterval(a.checkForStartAt), "function" == typeof a.opt.onReady && a.opt.onReady(a), a.isReady = !0;
var e = jQuery.Event("YTPReady");
if (e.time = a.currentTime, jQuery(a).trigger(e), a.preventTrigger = !0, a.state = 2, jQuery(a).YTPPause(), a.opt.mute || jQuery(a).YTPUnmute(), a.canTrigger = !0, a.opt.autoPlay) {
var f = jQuery.Event("YTPStart");
f.time = a.currentTime, jQuery(a).trigger(f), jQuery(a.playerEl).CSSAnimate({
opacity: 1
}, 1e3), b.YTPPlay(), a.wrapper.CSSAnimate({
opacity: a.isAlone ? 1 : a.opt.opacity
}, 2 * a.opt.fadeOnStartTime), jQuery.browser.safari && (a.safariPlay = setInterval(function() {
1 != a.state ? b.YTPPlay() : clearInterval(a.safariPlay)
}, 10)), b.on("YTPReady", function() {
b.YTPPlay()
})
} else a.player.pauseVideo(), a.isPlayer || (jQuery(a.playerEl).CSSAnimate({
opacity: 1
}, a.opt.fadeOnStartTime), a.wrapper.CSSAnimate({
opacity: a.isAlone ? 1 : a.opt.opacity
}, a.opt.fadeOnStartTime)), a.controlBar.length && a.controlBar.find(".mb_YTPPlaypause").html(jQuery.mbYTPlayer.controls.play);
a.isPlayer && !a.opt.autoPlay && a.loading && a.loading.length && (a.loading.html("Ready"), setTimeout(function() {
a.loading.fadeOut()
}, 100)), a.controlBar && a.controlBar.length && a.controlBar.slideDown(1e3)
} else jQuery.browser.safari && (a.player.playVideo(), d >= 0 && a.player.seekTo(d, !0))
}, 1)
},
setAnchor: function(a) {
var b = this;
b.optimizeDisplay(a)
},
getAnchor: function() {
var a = this.get(0);
return a.opt.anchor
},
formatTime: function(a) {
var b = Math.floor(a / 60),
c = Math.floor(a - 60 * b);
return (9 >= b ? "0" + b : b) + " : " + (9 >= c ? "0" + c : c)
}
}, jQuery.fn.optimizeDisplay = function(anchor) {
var YTPlayer = this.get(0),
playerBox = jQuery(YTPlayer.playerEl),
vid = {};
YTPlayer.opt.anchor = anchor || YTPlayer.opt.anchor, YTPlayer.opt.anchor = "undefined " != typeof YTPlayer.opt.anchor ? YTPlayer.opt.anchor : "center,center";
var YTPAlign = YTPlayer.opt.anchor.split(",");
if (YTPlayer.opt.optimizeDisplay) {
var abundance = YTPlayer.isPlayer ? 0 : 80,
win = {},
el = YTPlayer.wrapper;
win.width = el.outerWidth(), win.height = el.outerHeight() + abundance, YTPlayer.opt.ratio = eval(YTPlayer.opt.ratio), console.debug(YTPlayer.opt.ratio), vid.width = win.width, vid.height = Math.ceil(vid.width / YTPlayer.opt.ratio), vid.marginTop = Math.ceil(-((vid.height - win.height) / 2)), vid.marginLeft = 0;
var lowest = vid.height < win.height;
lowest && (vid.height = win.height, vid.width = Math.ceil(vid.height * YTPlayer.opt.ratio), vid.marginTop = 0, vid.marginLeft = Math.ceil(-((vid.width - win.width) / 2)));
for (var a in YTPAlign)
if (YTPAlign.hasOwnProperty(a)) {
var al = YTPAlign[a].replace(/ /g, "");
switch (al) {
case "top":
vid.marginTop = lowest ? -((vid.height - win.height) / 2) : 0;
break;
case "bottom":
vid.marginTop = lowest ? 0 : -(vid.height - win.height);
break;
case "left":
vid.marginLeft = 0;
break;
case "right":
vid.marginLeft = lowest ? -(vid.width - win.width) : 0;
break;
default:
vid.width > win.width && (vid.marginLeft = -((vid.width - win.width) / 2))
}
}
} else vid.width = "100%", vid.height = "100%", vid.marginTop = 0, vid.marginLeft = 0;
playerBox.css({
width: vid.width,
height: vid.height,
marginTop: vid.marginTop,
marginLeft: vid.marginLeft,
maxWidth: "initial"
})
}, jQuery.shuffle = function(a) {
for (var b = a.slice(), c = b.length, d = c; d--;) {
var e = parseInt(Math.random() * c),
f = b[d];
b[d] = b[e], b[e] = f
}
return b
}, 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")
})
}, jQuery.fn.YTPlayer = jQuery.mbYTPlayer.buildPlayer, jQuery.fn.YTPGetPlayer = jQuery.mbYTPlayer.getPlayer, jQuery.fn.YTPGetVideoID = jQuery.mbYTPlayer.getVideoID, jQuery.fn.YTPChangeMovie = jQuery.mbYTPlayer.changeMovie, jQuery.fn.YTPPlayerDestroy = jQuery.mbYTPlayer.playerDestroy, jQuery.fn.YTPPlay = jQuery.mbYTPlayer.play, jQuery.fn.YTPTogglePlay = jQuery.mbYTPlayer.togglePlay, jQuery.fn.YTPStop = jQuery.mbYTPlayer.stop, jQuery.fn.YTPPause = jQuery.mbYTPlayer.pause, jQuery.fn.YTPSeekTo = jQuery.mbYTPlayer.seekTo, jQuery.fn.YTPlaylist = jQuery.mbYTPlayer.playlist, jQuery.fn.YTPPlayNext = jQuery.mbYTPlayer.playNext, jQuery.fn.YTPPlayPrev = jQuery.mbYTPlayer.playPrev, jQuery.fn.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.YTPGetVideoData = jQuery.mbYTPlayer.getVideoData, jQuery.fn.YTPFullscreen = jQuery.mbYTPlayer.fullscreen, jQuery.fn.YTPToggleLoops = jQuery.mbYTPlayer.toggleLoops, jQuery.fn.YTPSetVideoQuality = jQuery.mbYTPlayer.setVideoQuality, jQuery.fn.YTPManageProgress = jQuery.mbYTPlayer.manageProgress, jQuery.fn.YTPApplyFilter = jQuery.mbYTPlayer.applyFilter, jQuery.fn.YTPApplyFilters = jQuery.mbYTPlayer.applyFilters, jQuery.fn.YTPToggleFilter = jQuery.mbYTPlayer.toggleFilter, jQuery.fn.YTPToggleFilters = jQuery.mbYTPlayer.toggleFilters, jQuery.fn.YTPRemoveFilter = jQuery.mbYTPlayer.removeFilter, jQuery.fn.YTPDisableFilters = jQuery.mbYTPlayer.disableFilters, jQuery.fn.YTPEnableFilters = jQuery.mbYTPlayer.enableFilters, 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.YTPSetAnchor = jQuery.mbYTPlayer.setAnchor, jQuery.fn.YTPGetAnchor = jQuery.mbYTPlayer.getAnchor, jQuery.fn.mb_YTPlayer = jQuery.mbYTPlayer.buildPlayer, jQuery.fn.playNext = jQuery.mbYTPlayer.playNext, jQuery.fn.playPrev = jQuery.mbYTPlayer.playPrev, jQuery.fn.changeMovie = jQuery.mbYTPlayer.changeMovie, jQuery.fn.getVideoID = jQuery.mbYTPlayer.getVideoID, jQuery.fn.getPlayer = jQuery.mbYTPlayer.getPlayer, jQuery.fn.playerDestroy = jQuery.mbYTPlayer.playerDestroy, jQuery.fn.fullscreen = jQuery.mbYTPlayer.fullscreen, jQuery.fn.buildYTPControls = jQuery.mbYTPlayer.buildControls, jQuery.fn.playYTP = jQuery.mbYTPlayer.play, jQuery.fn.toggleLoops = jQuery.mbYTPlayer.toggleLoops, jQuery.fn.stopYTP = jQuery.mbYTPlayer.stop, jQuery.fn.pauseYTP = jQuery.mbYTPlayer.pause, jQuery.fn.seekToYTP = jQuery.mbYTPlayer.seekTo, jQuery.fn.muteYTPVolume = jQuery.mbYTPlayer.mute, jQuery.fn.unmuteYTPVolume = jQuery.mbYTPlayer.unmute, jQuery.fn.setYTPVolume = jQuery.mbYTPlayer.setVolume, jQuery.fn.setVideoQuality = jQuery.mbYTPlayer.setVideoQuality, jQuery.fn.manageYTPProgress = jQuery.mbYTPlayer.manageProgress, jQuery.fn.YTPGetDataFromFeed = jQuery.mbYTPlayer.getVideoData
}(jQuery, ytp), jQuery.support.CSStransition = function() {
var a = document.body || document.documentElement,
b = a.style;
return void 0 !== b.transition || void 0 !== b.WebkitTransition || void 0 !== b.MozTransition || void 0 !== b.MsTransition || void 0 !== b.OTransition
}(), jQuery.CSS = {
name: "mb.CSSAnimate",
author: "Matteo Bicocchi",
version: "2.0.0",
transitionEnd: "transitionEnd",
sfx: "",
filters: {
blur: {
min: 0,
max: 100,
unit: "px"
},
brightness: {
min: 0,
max: 400,
unit: "%"
},
contrast: {
min: 0,
max: 400,
unit: "%"
},
grayscale: {
min: 0,
max: 100,
unit: "%"
},
hueRotate: {
min: 0,
max: 360,
unit: "deg"
},
invert: {
min: 0,
max: 100,
unit: "%"
},
saturate: {
min: 0,
max: 400,
unit: "%"
},
sepia: {
min: 0,
max: 100,
unit: "%"
}
},
normalizeCss: function(a) {
var b = jQuery.extend(!0, {}, a);
jQuery.browser.webkit || jQuery.browser.opera ? jQuery.CSS.sfx = "-webkit-" : jQuery.browser.mozilla ? jQuery.CSS.sfx = "-moz-" : jQuery.browser.msie && (jQuery.CSS.sfx = "-ms-");
for (var c in b) {
"transform" === c && (b[jQuery.CSS.sfx + "transform"] = b[c], delete b[c]), "transform-origin" === c && (b[jQuery.CSS.sfx + "transform-origin"] = a[c], delete b[c]), "filter" !== c || jQuery.browser.mozilla || (b[jQuery.CSS.sfx + "filter"] = a[c], delete b[c]), "blur" === c && setFilter(b, "blur", a[c]), "brightness" === c && setFilter(b, "brightness", a[c]), "contrast" === c && setFilter(b, "contrast", a[c]), "grayscale" === c && setFilter(b, "grayscale", a[c]), "hueRotate" === c && setFilter(b, "hueRotate", a[c]), "invert" === c && setFilter(b, "invert", a[c]), "saturate" === c && setFilter(b, "saturate", a[c]), "sepia" === c && setFilter(b, "sepia", a[c]);
var d = "";
"x" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " translateX(" + setUnit(a[c], "px") + ")", delete b[c]), "y" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " translateY(" + setUnit(a[c], "px") + ")", delete b[c]), "z" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " translateZ(" + setUnit(a[c], "px") + ")", delete b[c]), "rotate" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " rotate(" + setUnit(a[c], "deg") + ")", delete b[c]), "rotateX" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " rotateX(" + setUnit(a[c], "deg") + ")", delete b[c]), "rotateY" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " rotateY(" + setUnit(a[c], "deg") + ")", delete b[c]), "rotateZ" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " rotateZ(" + setUnit(a[c], "deg") + ")", delete b[c]), "scale" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " scale(" + setUnit(a[c], "") + ")", delete b[c]), "scaleX" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " scaleX(" + setUnit(a[c], "") + ")", delete b[c]), "scaleY" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " scaleY(" + setUnit(a[c], "") + ")", delete b[c]), "scaleZ" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " scaleZ(" + setUnit(a[c], "") + ")", delete b[c]), "skew" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " skew(" + setUnit(a[c], "deg") + ")", delete b[c]), "skewX" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " skewX(" + setUnit(a[c], "deg") + ")", delete b[c]), "skewY" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " skewY(" + setUnit(a[c], "deg") + ")", delete b[c]), "perspective" === c && (d = jQuery.CSS.sfx + "transform", b[d] = b[d] || "", b[d] += " perspective(" + setUnit(a[c], "px") + ")", delete b[c])
}
return b
},
getProp: function(a) {
var b = [];
for (var c in a) b.indexOf(c) < 0 && b.push(uncamel(c));
return b.join(",")
},
animate: function(a, b, c, d, e) {
return this.each(function() {
function f() {
g.called = !0, g.CSSAIsRunning = !1, h.off(jQuery.CSS.transitionEnd + "." + g.id), clearTimeout(g.timeout), h.css(jQuery.CSS.sfx + "transition", ""), "function" == typeof e && e.apply(g), "function" == typeof g.CSSqueue && (g.CSSqueue(), g.CSSqueue = null)
}
var g = this,
h = jQuery(this);
g.id = g.id || "CSSA_" + (new Date).getTime();
var i = i || {
type: "noEvent"
};
if (g.CSSAIsRunning && g.eventType == i.type && !jQuery.browser.msie && jQuery.browser.version <= 9) return void(g.CSSqueue = function() {
h.CSSAnimate(a, b, c, d, e)
});
if (g.CSSqueue = null, g.eventType = i.type, 0 !== h.length && a) {
if (a = jQuery.normalizeCss(a), g.CSSAIsRunning = !0, "function" == typeof b && (e = b, b = jQuery.fx.speeds._default), "function" == typeof c && (d = c, c = 0), "string" == typeof c && (e = c, c = 0), "function" == typeof d && (e = d, d = "cubic-bezier(0.65,0.03,0.36,0.72)"), "string" == typeof b)
for (var j in jQuery.fx.speeds) {
if (b == j) {
b = jQuery.fx.speeds[j];
break
}
b = jQuery.fx.speeds._default
}
if (b || (b = jQuery.fx.speeds._default), "string" == typeof e && (d = e, e = null), !jQuery.support.CSStransition) {
for (var k in a) {
if ("transform" === k && delete a[k], "filter" === k && delete a[k], "transform-origin" === k && delete a[k], "auto" === a[k] && delete a[k], "x" === k) {
var l = a[k],
m = "left";
a[m] = l, delete a[k]
}
if ("y" === k) {
var l = a[k],
m = "top";
a[m] = l, delete a[k]
}("-ms-transform" === k || "-ms-filter" === k) && delete a[k]
}
return void h.delay(c).animate(a, b, e)
}
var n = {
"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)"
};
n[d] && (d = n[d]), h.off(jQuery.CSS.transitionEnd + "." + g.id);
var o = jQuery.CSS.getProp(a),
p = {};
jQuery.extend(p, a), p[jQuery.CSS.sfx + "transition-property"] = o, p[jQuery.CSS.sfx + "transition-duration"] = b + "ms", p[jQuery.CSS.sfx + "transition-delay"] = c + "ms", p[jQuery.CSS.sfx + "transition-timing-function"] = d, setTimeout(function() {
h.one(jQuery.CSS.transitionEnd + "." + g.id, f), h.css(p)
}, 1), g.timeout = setTimeout(function() {
return g.called || !e ? (g.called = !1, void(g.CSSAIsRunning = !1)) : (h.css(jQuery.CSS.sfx + "transition", ""), e.apply(g), g.CSSAIsRunning = !1, void("function" == typeof g.CSSqueue && (g.CSSqueue(), g.CSSqueue = null)))
}, b + c + 10)
}
})
}
}, jQuery.fn.CSSAnimate = jQuery.CSS.animate, jQuery.normalizeCss = jQuery.CSS.normalizeCss, jQuery.fn.css3 = function(a) {
return this.each(function() {
var b = jQuery(this),
c = jQuery.normalizeCss(a);
b.css(c)
})
};
var nAgt = navigator.userAgent;
if (!jQuery.browser) {
var isTouchSupported = function() {
var a = nAgt.msMaxTouchPoints,
b = "ontouchstart" in document.createElement("div");
return !(!a && !b)
};
jQuery.browser = {}, jQuery.browser.mozilla = !1, jQuery.browser.webkit = !1, jQuery.browser.opera = !1, jQuery.browser.safari = !1, jQuery.browser.chrome = !1, jQuery.browser.androidStock = !1, jQuery.browser.msie = !1, jQuery.browser.edge = !1, jQuery.browser.hasTouch = isTouchSupported(), jQuery.browser.ua = nAgt, jQuery.browser.name = navigator.appName, jQuery.browser.fullVersion = "" + parseFloat(navigator.appVersion), jQuery.browser.majorVersion = parseInt(navigator.appVersion, 10);
var nameOffset, verOffset, ix;
if (-1 != (verOffset = nAgt.indexOf("Opera"))) jQuery.browser.opera = !0, jQuery.browser.name = "Opera", jQuery.browser.fullVersion = nAgt.substring(verOffset + 6), -1 != (verOffset = nAgt.indexOf("Version")) && (jQuery.browser.fullVersion = nAgt.substring(verOffset + 8));
else if (-1 != (verOffset = nAgt.indexOf("OPR"))) jQuery.browser.opera = !0, jQuery.browser.name = "Opera", jQuery.browser.fullVersion = nAgt.substring(verOffset + 4);
else if (-1 != (verOffset = nAgt.indexOf("MSIE"))) jQuery.browser.msie = !0, jQuery.browser.name = "Microsoft Internet Explorer", jQuery.browser.fullVersion = nAgt.substring(verOffset + 5);
else if (-1 != nAgt.indexOf("Trident")) {
jQuery.browser.msie = !0, jQuery.browser.name = "Microsoft Internet Explorer";
var start = nAgt.indexOf("rv:") + 3,
end = start + 4;
jQuery.browser.fullVersion = nAgt.substring(start, end)
} else -1 != (verOffset = nAgt.indexOf("Edge")) ? (jQuery.browser.edge = !0, jQuery.browser.name = "Microsoft Edge", jQuery.browser.fullVersion = nAgt.substring(verOffset + 5)) : -1 != (verOffset = nAgt.indexOf("Chrome")) ? (jQuery.browser.webkit = !0, jQuery.browser.chrome = !0, jQuery.browser.name = "Chrome", jQuery.browser.fullVersion = nAgt.substring(verOffset + 7)) : -1 < nAgt.indexOf("mozilla/5.0") && -1 < nAgt.indexOf("android ") && -1 < nAgt.indexOf("applewebkit") && !(-1 < nAgt.indexOf("chrome")) ? (verOffset = nAgt.indexOf("Chrome"), jQuery.browser.webkit = !0, jQuery.browser.androidStock = !0, jQuery.browser.name = "androidStock", jQuery.browser.fullVersion = nAgt.substring(verOffset + 7)) : -1 != (verOffset = nAgt.indexOf("Safari")) ? (jQuery.browser.webkit = !0, jQuery.browser.safari = !0, jQuery.browser.name = "Safari", jQuery.browser.fullVersion = nAgt.substring(verOffset + 7), -1 != (verOffset = nAgt.indexOf("Version")) && (jQuery.browser.fullVersion = nAgt.substring(verOffset + 8))) : -1 != (verOffset = nAgt.indexOf("AppleWebkit")) ? (jQuery.browser.webkit = !0, jQuery.browser.safari = !0, jQuery.browser.name = "Safari", jQuery.browser.fullVersion = nAgt.substring(verOffset + 7), -1 != (verOffset = nAgt.indexOf("Version")) && (jQuery.browser.fullVersion = nAgt.substring(verOffset + 8))) : -1 != (verOffset = nAgt.indexOf("Firefox")) ? (jQuery.browser.mozilla = !0, jQuery.browser.name = "Firefox", jQuery.browser.fullVersion = nAgt.substring(verOffset + 8)) : (nameOffset = nAgt.lastIndexOf(" ") + 1) < (verOffset = nAgt.lastIndexOf("/")) && (jQuery.browser.name = nAgt.substring(nameOffset, verOffset), jQuery.browser.fullVersion = nAgt.substring(verOffset + 1), jQuery.browser.name.toLowerCase() == jQuery.browser.name.toUpperCase() && (jQuery.browser.name = navigator.appName)); - 1 != (ix = jQuery.browser.fullVersion.indexOf(";")) && (jQuery.browser.fullVersion = jQuery.browser.fullVersion.substring(0, ix)), -1 != (ix = jQuery.browser.fullVersion.indexOf(" ")) && (jQuery.browser.fullVersion = jQuery.browser.fullVersion.substring(0, ix)), jQuery.browser.majorVersion = parseInt("" + jQuery.browser.fullVersion, 10), isNaN(jQuery.browser.majorVersion) && (jQuery.browser.fullVersion = "" + parseFloat(navigator.appVersion), jQuery.browser.majorVersion = parseInt(navigator.appVersion, 10)), jQuery.browser.version = jQuery.browser.majorVersion
}
jQuery.browser.android = /Android/i.test(nAgt), jQuery.browser.blackberry = /BlackBerry|BB|PlayBook/i.test(nAgt), jQuery.browser.ios = /iPhone|iPad|iPod|webOS/i.test(nAgt), jQuery.browser.operaMobile = /Opera Mini/i.test(nAgt), jQuery.browser.windowsMobile = /IEMobile|Windows Phone/i.test(nAgt), jQuery.browser.kindle = /Kindle|Silk/i.test(nAgt), jQuery.browser.mobile = jQuery.browser.android || jQuery.browser.blackberry || jQuery.browser.ios || jQuery.browser.windowsMobile || jQuery.browser.operaMobile || jQuery.browser.kindle, jQuery.isMobile = jQuery.browser.mobile, jQuery.isTablet = jQuery.browser.mobile && 765 < jQuery(window).width(), jQuery.isAndroidDefault = jQuery.browser.android && !/chrome/i.test(nAgt);
var nAgt = navigator.userAgent;
if (!jQuery.browser) {
jQuery.browser = {}, jQuery.browser.mozilla = !1, jQuery.browser.webkit = !1, jQuery.browser.opera = !1, jQuery.browser.safari = !1, jQuery.browser.chrome = !1, jQuery.browser.androidStock = !1, jQuery.browser.msie = !1, jQuery.browser.ua = nAgt, jQuery.browser.name = navigator.appName, jQuery.browser.fullVersion = "" + parseFloat(navigator.appVersion), jQuery.browser.majorVersion = parseInt(navigator.appVersion, 10);
var nameOffset, verOffset, ix;
if (-1 != (verOffset = nAgt.indexOf("Opera"))) jQuery.browser.opera = !0, jQuery.browser.name = "Opera", jQuery.browser.fullVersion = nAgt.substring(verOffset + 6), -1 != (verOffset = nAgt.indexOf("Version")) && (jQuery.browser.fullVersion = nAgt.substring(verOffset + 8));
else if (-1 != (verOffset = nAgt.indexOf("OPR"))) jQuery.browser.opera = !0, jQuery.browser.name = "Opera", jQuery.browser.fullVersion = nAgt.substring(verOffset + 4);
else if (-1 != (verOffset = nAgt.indexOf("MSIE"))) jQuery.browser.msie = !0, jQuery.browser.name = "Microsoft Internet Explorer", jQuery.browser.fullVersion = nAgt.substring(verOffset + 5);
else if (-1 != nAgt.indexOf("Trident") || -1 != nAgt.indexOf("Edge")) {
jQuery.browser.msie = !0, jQuery.browser.name = "Microsoft Internet Explorer";
var start = nAgt.indexOf("rv:") + 3,
end = start + 4;
jQuery.browser.fullVersion = nAgt.substring(start, end)
} else -1 != (verOffset = nAgt.indexOf("Chrome")) ? (jQuery.browser.webkit = !0, jQuery.browser.chrome = !0, jQuery.browser.name = "Chrome", jQuery.browser.fullVersion = nAgt.substring(verOffset + 7)) : nAgt.indexOf("mozilla/5.0") > -1 && nAgt.indexOf("android ") > -1 && nAgt.indexOf("applewebkit") > -1 && !(nAgt.indexOf("chrome") > -1) ? (verOffset = nAgt.indexOf("Chrome"), jQuery.browser.webkit = !0, jQuery.browser.androidStock = !0, jQuery.browser.name = "androidStock", jQuery.browser.fullVersion = nAgt.substring(verOffset + 7)) : -1 != (verOffset = nAgt.indexOf("Safari")) ? (jQuery.browser.webkit = !0, jQuery.browser.safari = !0, jQuery.browser.name = "Safari", jQuery.browser.fullVersion = nAgt.substring(verOffset + 7), -1 != (verOffset = nAgt.indexOf("Version")) && (jQuery.browser.fullVersion = nAgt.substring(verOffset + 8))) : -1 != (verOffset = nAgt.indexOf("AppleWebkit")) ? (jQuery.browser.webkit = !0, jQuery.browser.safari = !0, jQuery.browser.name = "Safari", jQuery.browser.fullVersion = nAgt.substring(verOffset + 7), -1 != (verOffset = nAgt.indexOf("Version")) && (jQuery.browser.fullVersion = nAgt.substring(verOffset + 8))) : -1 != (verOffset = nAgt.indexOf("Firefox")) ? (jQuery.browser.mozilla = !0, jQuery.browser.name = "Firefox", jQuery.browser.fullVersion = nAgt.substring(verOffset + 8)) : (nameOffset = nAgt.lastIndexOf(" ") + 1) < (verOffset = nAgt.lastIndexOf("/")) && (jQuery.browser.name = nAgt.substring(nameOffset, verOffset), jQuery.browser.fullVersion = nAgt.substring(verOffset + 1), jQuery.browser.name.toLowerCase() == jQuery.browser.name.toUpperCase() && (jQuery.browser.name = navigator.appName)); - 1 != (ix = jQuery.browser.fullVersion.indexOf(";")) && (jQuery.browser.fullVersion = jQuery.browser.fullVersion.substring(0, ix)), -1 != (ix = jQuery.browser.fullVersion.indexOf(" ")) && (jQuery.browser.fullVersion = jQuery.browser.fullVersion.substring(0, ix)), jQuery.browser.majorVersion = parseInt("" + jQuery.browser.fullVersion, 10), isNaN(jQuery.browser.majorVersion) && (jQuery.browser.fullVersion = "" + parseFloat(navigator.appVersion), jQuery.browser.majorVersion = parseInt(navigator.appVersion, 10)), jQuery.browser.version = jQuery.browser.majorVersion
}
jQuery.browser.android = /Android/i.test(nAgt), jQuery.browser.blackberry = /BlackBerry|BB|PlayBook/i.test(nAgt), jQuery.browser.ios = /iPhone|iPad|iPod|webOS/i.test(nAgt), jQuery.browser.operaMobile = /Opera Mini/i.test(nAgt), jQuery.browser.windowsMobile = /IEMobile|Windows Phone/i.test(nAgt), jQuery.browser.kindle = /Kindle|Silk/i.test(nAgt), jQuery.browser.mobile = jQuery.browser.android || jQuery.browser.blackberry || jQuery.browser.ios || jQuery.browser.windowsMobile || jQuery.browser.operaMobile || jQuery.browser.kindle, jQuery.isMobile = jQuery.browser.mobile, jQuery.isTablet = jQuery.browser.mobile && jQuery(window).width() > 765, jQuery.isAndroidDefault = jQuery.browser.android && !/chrome/i.test(nAgt),
function(a) {
a.simpleSlider = {
defaults: {
initialval: 0,
scale: 100,
orientation: "h",
readonly: !1,
callback: !1
},
events: {
start: a.browser.mobile ? "touchstart" : "mousedown",
end: a.browser.mobile ? "touchend" : "mouseup",
move: a.browser.mobile ? "touchmove" : "mousemove"
},
init: function(b) {
return this.each(function() {
var c = this,
d = a(c);
d.addClass("simpleSlider"), c.opt = {}, a.extend(c.opt, a.simpleSlider.defaults, b), a.extend(c.opt, d.data());
var e = "h" == c.opt.orientation ? "horizontal" : "vertical",
e = a("").addClass("level").addClass(e);
d.prepend(e), c.level = e, d.css({
cursor: "default"
}), "auto" == c.opt.scale && (c.opt.scale = a(c).outerWidth()), d.updateSliderVal(), c.opt.readonly || (d.on(a.simpleSlider.events.start, function(b) {
a.browser.mobile && (b = b.changedTouches[0]), c.canSlide = !0, d.updateSliderVal(b), "h" == c.opt.orientation ? d.css({
cursor: "col-resize"
}) : d.css({
cursor: "row-resize"
}), b.preventDefault(), b.stopPropagation()
}), a(document).on(a.simpleSlider.events.move, function(b) {
a.browser.mobile && (b = b.changedTouches[0]), c.canSlide && (a(document).css({
cursor: "default"
}), d.updateSliderVal(b), b.preventDefault(), b.stopPropagation())
}).on(a.simpleSlider.events.end, function() {
a(document).css({
cursor: "auto"
}), c.canSlide = !1, d.css({
cursor: "auto"
})
}))
})
},
updateSliderVal: function(b) {
var c = this.get(0);
if (c.opt) {
c.opt.initialval = "number" == typeof c.opt.initialval ? c.opt.initialval : c.opt.initialval(c);
var d = a(c).outerWidth(),
e = a(c).outerHeight();
c.x = "object" == typeof b ? b.clientX + document.body.scrollLeft - this.offset().left : "number" == typeof b ? b * d / c.opt.scale : c.opt.initialval * d / c.opt.scale, c.y = "object" == typeof b ? b.clientY + document.body.scrollTop - this.offset().top : "number" == typeof b ? (c.opt.scale - c.opt.initialval - b) * e / c.opt.scale : c.opt.initialval * e / c.opt.scale, c.y = this.outerHeight() - c.y, c.scaleX = c.x * c.opt.scale / d, c.scaleY = c.y * c.opt.scale / e, c.outOfRangeX = c.scaleX > c.opt.scale ? c.scaleX - c.opt.scale : 0 > c.scaleX ? c.scaleX : 0, c.outOfRangeY = c.scaleY > c.opt.scale ? c.scaleY - c.opt.scale : 0 > c.scaleY ? c.scaleY : 0, c.outOfRange = "h" == c.opt.orientation ? c.outOfRangeX : c.outOfRangeY, c.value = "undefined" != typeof b ? "h" == c.opt.orientation ? c.x >= this.outerWidth() ? c.opt.scale : 0 >= c.x ? 0 : c.scaleX : c.y >= this.outerHeight() ? c.opt.scale : 0 >= c.y ? 0 : c.scaleY : "h" == c.opt.orientation ? c.scaleX : c.scaleY, "h" == c.opt.orientation ? c.level.width(Math.floor(100 * c.x / d) + "%") : c.level.height(Math.floor(100 * c.y / e)), "function" == typeof c.opt.callback && c.opt.callback(c)
}
}
}, a.fn.simpleSlider = a.simpleSlider.init, a.fn.updateSliderVal = a.simpleSlider.updateSliderVal
}(jQuery), ! function(a) {
a.mbCookie = {
set: function(a, b, c, d) {
b = JSON.stringify(b), c || (c = 7), d = d ? "; domain=" + d : "";
var e, f = new Date;
f.setTime(f.getTime() + 864e5 * c), e = "; expires=" + f.toGMTString(), document.cookie = a + "=" + b + e + "; path=/" + d
},
get: function(a) {
for (var b = a + "=", c = document.cookie.split(";"), d = 0; d < c.length; d++) {
for (var e = c[d];
" " == e.charAt(0);) e = e.substring(1, e.length);
if (0 == e.indexOf(b)) return JSON.parse(e.substring(b.length, e.length))
}
return null
},
remove: function(b) {
a.mbCookie.set(b, "", -1)
}
}, a.mbStorage = {
set: function(a, b) {
b = JSON.stringify(b), localStorage.setItem(a, b)
},
get: function(a) {
return localStorage[a] ? JSON.parse(localStorage[a]) : null
},
remove: function(a) {
a ? localStorage.removeItem(a) : localStorage.clear()
}
}
}(jQuery);