(function(c) {
var b = { init: function(e) {
var f = { set_width: false, set_height: false, horizontalScroll: false, scrollInertia: 950, mouseWheel: true, mouseWheelPixels: "auto", autoDraggerLength: true, autoHideScrollbar: false, snapAmount: null, snapOffset: 0, scrollButtons: { enable: false, scrollType: "continuous", scrollSpeed: "auto", scrollAmount: 40 }, advanced: { updateOnBrowserResize: true, updateOnContentResize: false, autoExpandHorizontalScroll: false, autoScrollOnFocus: true, normalizeMouseWheelDelta: false }, contentTouchScroll: true, callbacks: { onScrollStart: function() {}, onScroll: function() {}, onTotalScroll: function() {}, onTotalScrollBack: function() {}, onTotalScrollOffset: 0, onTotalScrollBackOffset: 0, whileScrolling: function() {} }, theme: "light" },
e = c.extend(true, f, e);
return this.each(function() {
var m = c(this);
if (e.set_width) { m.css("width", e.set_width) }
if (e.set_height) { m.css("height", e.set_height) }
if (!c(document).data("mCustomScrollbar-index")) { c(document).data("mCustomScrollbar-index", "1") } else {
var t = parseInt(c(document).data("mCustomScrollbar-index"));
c(document).data("mCustomScrollbar-index", t + 1) }
m.wrapInner("
").addClass("mCustomScrollbar _mCS_" + c(document).data("mCustomScrollbar-index"));
var g = m.children(".mCustomScrollBox");
if (e.horizontalScroll) { g.addClass("mCSB_horizontal").wrapInner("");
var k = g.children(".mCSB_h_wrapper");
k.wrapInner("").children(".mCSB_container").css({ width: k.children().outerWidth(), position: "relative" }).unwrap() } else { g.wrapInner("") }
var o = g.children(".mCSB_container");
if (c.support.touch) { o.addClass("mCS_touch") }
o.after("");
var l = g.children(".mCSB_scrollTools"),
h = l.children(".mCSB_draggerContainer"),
q = h.children(".mCSB_dragger");
if (e.horizontalScroll) { q.data("minDraggerWidth", q.width()) } else { q.data("minDraggerHeight", q.height()) }
if (e.scrollButtons.enable) {
if (e.horizontalScroll) { l.prepend("").append("") } else { l.prepend("").append("") } }
g.bind("scroll", function() {
if (!m.is(".mCS_disabled")) { g.scrollTop(0).scrollLeft(0) } });
m.data({ mCS_Init: true, mCustomScrollbarIndex: c(document).data("mCustomScrollbar-index"), horizontalScroll: e.horizontalScroll, scrollInertia: e.scrollInertia, scrollEasing: "mcsEaseOut", mouseWheel: e.mouseWheel, mouseWheelPixels: e.mouseWheelPixels, autoDraggerLength: e.autoDraggerLength, autoHideScrollbar: e.autoHideScrollbar, snapAmount: e.snapAmount, snapOffset: e.snapOffset, scrollButtons_enable: e.scrollButtons.enable, scrollButtons_scrollType: e.scrollButtons.scrollType, scrollButtons_scrollSpeed: e.scrollButtons.scrollSpeed, scrollButtons_scrollAmount: e.scrollButtons.scrollAmount, autoExpandHorizontalScroll: e.advanced.autoExpandHorizontalScroll, autoScrollOnFocus: e.advanced.autoScrollOnFocus, normalizeMouseWheelDelta: e.advanced.normalizeMouseWheelDelta, contentTouchScroll: e.contentTouchScroll, onScrollStart_Callback: e.callbacks.onScrollStart, onScroll_Callback: e.callbacks.onScroll, onTotalScroll_Callback: e.callbacks.onTotalScroll, onTotalScrollBack_Callback: e.callbacks.onTotalScrollBack, onTotalScroll_Offset: e.callbacks.onTotalScrollOffset, onTotalScrollBack_Offset: e.callbacks.onTotalScrollBackOffset, whileScrolling_Callback: e.callbacks.whileScrolling, bindEvent_scrollbar_drag: false, bindEvent_content_touch: false, bindEvent_scrollbar_click: false, bindEvent_mousewheel: false, bindEvent_buttonsContinuous_y: false, bindEvent_buttonsContinuous_x: false, bindEvent_buttonsPixels_y: false, bindEvent_buttonsPixels_x: false, bindEvent_focusin: false, bindEvent_autoHideScrollbar: false, mCSB_buttonScrollRight: false, mCSB_buttonScrollLeft: false, mCSB_buttonScrollDown: false, mCSB_buttonScrollUp: false });
if (e.horizontalScroll) {
if (m.css("max-width") !== "none") {
if (!e.advanced.updateOnContentResize) { e.advanced.updateOnContentResize = true } } } else {
if (m.css("max-height") !== "none") {
var s = false,
r = parseInt(m.css("max-height"));
if (m.css("max-height").indexOf("%") >= 0) { s = r, r = m.parent().height() * s / 100 }
m.css("overflow", "hidden");
g.css("max-height", r) } }
m.mCustomScrollbar("update");
if (e.advanced.updateOnBrowserResize) {
var i, j = c(window).width(),
u = c(window).height();
c(window).bind("resize." + m.data("mCustomScrollbarIndex"), function() {
if (i) { clearTimeout(i) }
i = setTimeout(function() {
if (!m.is(".mCS_disabled") && !m.is(".mCS_destroyed")) {
var w = c(window).width(),
v = c(window).height();
if (j !== w || u !== v) {
if (m.css("max-height") !== "none" && s) { g.css("max-height", m.parent().height() * s / 100) }
m.mCustomScrollbar("update");
j = w;
u = v } } }, 150) }) }
if (e.advanced.updateOnContentResize) {
var p;
if (e.horizontalScroll) {
var n = o.outerWidth() } else {
var n = o.outerHeight() }
p = setInterval(function() {
if (e.horizontalScroll) {
if (e.advanced.autoExpandHorizontalScroll) { o.css({ position: "absolute", width: "auto" }).wrap("").css({ width: o.outerWidth(), position: "relative" }).unwrap() }
var v = o.outerWidth() } else {
var v = o.outerHeight() }
if (v != n) { m.mCustomScrollbar("update");
n = v } }, 300) } }) }, update: function() {
var n = c(this),
k = n.children(".mCustomScrollBox"),
q = k.children(".mCSB_container");
q.removeClass("mCS_no_scrollbar");
n.removeClass("mCS_disabled mCS_destroyed");
k.scrollTop(0).scrollLeft(0);
var y = k.children(".mCSB_scrollTools"),
o = y.children(".mCSB_draggerContainer"),
m = o.children(".mCSB_dragger");
if (n.data("horizontalScroll")) {
var A = y.children(".mCSB_buttonLeft"),
t = y.children(".mCSB_buttonRight"),
f = k.width();
if (n.data("autoExpandHorizontalScroll")) { q.css({ position: "absolute", width: "auto" }).wrap("").css({ width: q.outerWidth(), position: "relative" }).unwrap() }
var z = q.outerWidth() } else {
var w = y.children(".mCSB_buttonUp"),
g = y.children(".mCSB_buttonDown"),
r = k.height(),
i = q.outerHeight() }
if (i > r && !n.data("horizontalScroll")) { y.css("display", "block");
var s = o.height();
if (n.data("autoDraggerLength")) {
var u = Math.round(r / i * s),
l = m.data("minDraggerHeight");
if (u <= l) { m.css({ height: l }) } else {
if (u >= s - 10) {
var p = s - 10;
m.css({ height: p }) } else { m.css({ height: u }) } }
m.children(".mCSB_dragger_bar").css({ "line-height": m.height() + "px" }) }
var B = m.height(),
x = (i - r) / (s - B);
n.data("scrollAmount", x).mCustomScrollbar("scrolling", k, q, o, m, w, g, A, t);
var D = Math.abs(q.position().top);
n.mCustomScrollbar("scrollTo", D, { scrollInertia: 0, trigger: "internal" }) } else {
if (z > f && n.data("horizontalScroll")) { y.css("display", "block");
var h = o.width();
if (n.data("autoDraggerLength")) {
var j = Math.round(f / z * h),
C = m.data("minDraggerWidth");
if (j <= C) { m.css({ width: C }) } else {
if (j >= h - 10) {
var e = h - 10;
m.css({ width: e }) } else { m.css({ width: j }) } } }
var v = m.width(),
x = (z - f) / (h - v);
n.data("scrollAmount", x).mCustomScrollbar("scrolling", k, q, o, m, w, g, A, t);
var D = Math.abs(q.position().left);
n.mCustomScrollbar("scrollTo", D, { scrollInertia: 0, trigger: "internal" }) } else { k.unbind("mousewheel focusin");
if (n.data("horizontalScroll")) { m.add(q).css("left", 0) } else { m.add(q).css("top", 0) }
y.css("display", "none");
q.addClass("mCS_no_scrollbar");
n.data({ bindEvent_mousewheel: false, bindEvent_focusin: false }) } } }, scrolling: function(h, p, m, j, w, e, A, v) {
var k = c(this);
if (!k.data("bindEvent_scrollbar_drag")) {
var n, o;
if (c.support.msPointer) { j.bind("MSPointerDown", function(H) { H.preventDefault();
k.data({ on_drag: true });
j.addClass("mCSB_dragger_onDrag");
var G = c(this),
J = G.offset(),
F = H.originalEvent.pageX - J.left,
I = H.originalEvent.pageY - J.top;
if (F < G.width() && F > 0 && I < G.height() && I > 0) { n = I;
o = F } });
c(document).bind("MSPointerMove." + k.data("mCustomScrollbarIndex"), function(H) { H.preventDefault();
if (k.data("on_drag")) {
var G = j,
J = G.offset(),
F = H.originalEvent.pageX - J.left,
I = H.originalEvent.pageY - J.top;
D(n, o, I, F) } }).bind("MSPointerUp." + k.data("mCustomScrollbarIndex"), function(x) { k.data({ on_drag: false });
j.removeClass("mCSB_dragger_onDrag") }) } else { j.bind("mousedown touchstart", function(H) { H.preventDefault();
H.stopImmediatePropagation();
var G = c(this),
K = G.offset(),
F, J;
if (H.type === "touchstart") {
var I = H.originalEvent.touches[0] || H.originalEvent.changedTouches[0];
F = I.pageX - K.left;
J = I.pageY - K.top } else { k.data({ on_drag: true });
j.addClass("mCSB_dragger_onDrag");
F = H.pageX - K.left;
J = H.pageY - K.top }
if (F < G.width() && F > 0 && J < G.height() && J > 0) { n = J;
o = F } }).bind("touchmove", function(H) { H.preventDefault();
H.stopImmediatePropagation();
var K = H.originalEvent.touches[0] || H.originalEvent.changedTouches[0],
G = c(this),
J = G.offset(),
F = K.pageX - J.left,
I = K.pageY - J.top;
D(n, o, I, F) });
c(document).bind("mousemove." + k.data("mCustomScrollbarIndex"), function(H) {
if (k.data("on_drag")) {
var G = j,
J = G.offset(),
F = H.pageX - J.left,
I = H.pageY - J.top;
D(n, o, I, F) } }).bind("mouseup." + k.data("mCustomScrollbarIndex"), function(x) { k.data({ on_drag: false });
j.removeClass("mCSB_dragger_onDrag") }) }
k.data({ bindEvent_scrollbar_drag: true }) }
function D(G, H, I, F) {
if (k.data("horizontalScroll")) { k.mCustomScrollbar("scrollTo", (j.position().left - (H)) + F, { moveDragger: true, trigger: "internal" }) } else { k.mCustomScrollbar("scrollTo", (j.position().top - (G)) + I, { moveDragger: true, trigger: "internal" }) } }
if (c.support.touch && k.data("contentTouchScroll")) {
if (!k.data("bindEvent_content_touch")) {
var l, B, r, s, u, C, E;
p.bind("touchstart", function(x) { x.stopImmediatePropagation();
l = x.originalEvent.touches[0] || x.originalEvent.changedTouches[0];
B = c(this);
r = B.offset();
u = l.pageX - r.left;
s = l.pageY - r.top;
C = s;
E = u });
p.bind("touchmove", function(x) { x.preventDefault();
x.stopImmediatePropagation();
l = x.originalEvent.touches[0] || x.originalEvent.changedTouches[0];
B = c(this).parent();
r = B.offset();
u = l.pageX - r.left;
s = l.pageY - r.top;
if (k.data("horizontalScroll")) { k.mCustomScrollbar("scrollTo", E - u, { trigger: "internal" }) } else { k.mCustomScrollbar("scrollTo", C - s, { trigger: "internal" }) } }) } }
if (!k.data("bindEvent_scrollbar_click")) { m.bind("click", function(F) {
var x = (F.pageY - m.offset().top) * k.data("scrollAmount"),
y = c(F.target);
if (k.data("horizontalScroll")) { x = (F.pageX - m.offset().left) * k.data("scrollAmount") }
if (y.hasClass("mCSB_draggerContainer") || y.hasClass("mCSB_draggerRail")) { k.mCustomScrollbar("scrollTo", x, { trigger: "internal", scrollEasing: "draggerRailEase" }) } });
k.data({ bindEvent_scrollbar_click: true }) }
if (k.data("mouseWheel")) {
if (!k.data("bindEvent_mousewheel")) { h.bind("mousewheel", function(H, J) {
var G, F = k.data("mouseWheelPixels"),
x = Math.abs(p.position().top),
I = j.position().top,
y = m.height() - j.height();
if (k.data("normalizeMouseWheelDelta")) {
if (J < 0) { J = -1 } else { J = 1 } }
if (F === "auto") { F = 100 + Math.round(k.data("scrollAmount") / 2) }
if (k.data("horizontalScroll")) { I = j.position().left;
y = m.width() - j.width();
x = Math.abs(p.position().left) }
if ((J > 0 && I !== 0) || (J < 0 && I !== y)) { H.preventDefault();
H.stopImmediatePropagation() }
G = x - (J * F);
k.mCustomScrollbar("scrollTo", G, { trigger: "internal" }) });
k.data({ bindEvent_mousewheel: true }) } }
if (k.data("scrollButtons_enable")) {
if (k.data("scrollButtons_scrollType") === "pixels") {
if (k.data("horizontalScroll")) { v.add(A).unbind("mousedown touchstart MSPointerDown mouseup MSPointerUp mouseout MSPointerOut touchend", i, g);
k.data({ bindEvent_buttonsContinuous_x: false });
if (!k.data("bindEvent_buttonsPixels_x")) { v.bind("click", function(x) { x.preventDefault();
q(Math.abs(p.position().left) + k.data("scrollButtons_scrollAmount")) });
A.bind("click", function(x) { x.preventDefault();
q(Math.abs(p.position().left) - k.data("scrollButtons_scrollAmount")) });
k.data({ bindEvent_buttonsPixels_x: true }) } } else { e.add(w).unbind("mousedown touchstart MSPointerDown mouseup MSPointerUp mouseout MSPointerOut touchend", i, g);
k.data({ bindEvent_buttonsContinuous_y: false });
if (!k.data("bindEvent_buttonsPixels_y")) { e.bind("click", function(x) { x.preventDefault();
q(Math.abs(p.position().top) + k.data("scrollButtons_scrollAmount")) });
w.bind("click", function(x) { x.preventDefault();
q(Math.abs(p.position().top) - k.data("scrollButtons_scrollAmount")) });
k.data({ bindEvent_buttonsPixels_y: true }) } }
function q(x) {
if (!j.data("preventAction")) { j.data("preventAction", true);
k.mCustomScrollbar("scrollTo", x, { trigger: "internal" }) } } } else {
if (k.data("horizontalScroll")) { v.add(A).unbind("click");
k.data({ bindEvent_buttonsPixels_x: false });
if (!k.data("bindEvent_buttonsContinuous_x")) { v.bind("mousedown touchstart MSPointerDown", function(y) { y.preventDefault();
var x = z();
k.data({ mCSB_buttonScrollRight: setInterval(function() { k.mCustomScrollbar("scrollTo", Math.abs(p.position().left) + x, { trigger: "internal", scrollEasing: "easeOutCirc" }) }, 17) }) });
var i = function(x) { x.preventDefault();
clearInterval(k.data("mCSB_buttonScrollRight")) };
v.bind("mouseup touchend MSPointerUp mouseout MSPointerOut", i);
A.bind("mousedown touchstart MSPointerDown", function(y) { y.preventDefault();
var x = z();
k.data({ mCSB_buttonScrollLeft: setInterval(function() { k.mCustomScrollbar("scrollTo", Math.abs(p.position().left) - x, { trigger: "internal", scrollEasing: "easeOutCirc" }) }, 17) }) });
var g = function(x) { x.preventDefault();
clearInterval(k.data("mCSB_buttonScrollLeft")) };
A.bind("mouseup touchend MSPointerUp mouseout MSPointerOut", g);
k.data({ bindEvent_buttonsContinuous_x: true }) } } else { e.add(w).unbind("click");
k.data({ bindEvent_buttonsPixels_y: false });
if (!k.data("bindEvent_buttonsContinuous_y")) { e.bind("mousedown touchstart MSPointerDown", function(y) { y.preventDefault();
var x = z();
k.data({ mCSB_buttonScrollDown: setInterval(function() { k.mCustomScrollbar("scrollTo", Math.abs(p.position().top) + x, { trigger: "internal", scrollEasing: "easeOutCirc" }) }, 17) }) });
var t = function(x) { x.preventDefault();
clearInterval(k.data("mCSB_buttonScrollDown")) };
e.bind("mouseup touchend MSPointerUp mouseout MSPointerOut", t);
w.bind("mousedown touchstart MSPointerDown", function(y) { y.preventDefault();
var x = z();
k.data({ mCSB_buttonScrollUp: setInterval(function() { k.mCustomScrollbar("scrollTo", Math.abs(p.position().top) - x, { trigger: "internal", scrollEasing: "easeOutCirc" }) }, 17) }) });
var f = function(x) { x.preventDefault();
clearInterval(k.data("mCSB_buttonScrollUp")) };
w.bind("mouseup touchend MSPointerUp mouseout MSPointerOut", f);
k.data({ bindEvent_buttonsContinuous_y: true }) } }
function z() {
var x = k.data("scrollButtons_scrollSpeed");
if (k.data("scrollButtons_scrollSpeed") === "auto") { x = Math.round((k.data("scrollInertia") + 100) / 40) }
return x } } }
if (k.data("autoScrollOnFocus")) {
if (!k.data("bindEvent_focusin")) { h.bind("focusin", function() { h.scrollTop(0).scrollLeft(0);
var x = c(document.activeElement);
if (x.is("input,textarea,select,button,a[tabindex],area,object")) {
var G = p.position().top,
y = x.position().top,
F = h.height() - x.outerHeight();
if (k.data("horizontalScroll")) { G = p.position().left;
y = x.position().left;
F = h.width() - x.outerWidth() }
if (G + y < 0 || G + y > F) { k.mCustomScrollbar("scrollTo", y, { trigger: "internal" }) } } });
k.data({ bindEvent_focusin: true }) } }
if (k.data("autoHideScrollbar")) {
if (!k.data("bindEvent_autoHideScrollbar")) { h.bind("mouseenter", function(x) { h.addClass("mCS-mouse-over");
d.showScrollbar.call(h.children(".mCSB_scrollTools")) }).bind("mouseleave touchend", function(x) { h.removeClass("mCS-mouse-over");
if (x.type === "mouseleave") { d.hideScrollbar.call(h.children(".mCSB_scrollTools")) } });
k.data({ bindEvent_autoHideScrollbar: true }) } } }, scrollTo: function(e, f) {
var i = c(this),
o = { moveDragger: false, trigger: "external", callbacks: true, scrollInertia: i.data("scrollInertia"), scrollEasing: i.data("scrollEasing") },
f = c.extend(o, f),
p, g = i.children(".mCustomScrollBox"),
k = g.children(".mCSB_container"),
r = g.children(".mCSB_scrollTools"),
j = r.children(".mCSB_draggerContainer"),
h = j.children(".mCSB_dragger"),
t = draggerSpeed = f.scrollInertia,
q, s, m, l;
if (!k.hasClass("mCS_no_scrollbar")) { i.data({ mCS_trigger: f.trigger });
if (i.data("mCS_Init")) { f.callbacks = false }
if (e || e === 0) {
if (typeof(e) === "number") {
if (f.moveDragger) { p = e;
if (i.data("horizontalScroll")) { e = h.position().left * i.data("scrollAmount") } else { e = h.position().top * i.data("scrollAmount") }
draggerSpeed = 0 } else { p = e / i.data("scrollAmount") } } else {
if (typeof(e) === "string") {
var v;
if (e === "top") { v = 0 } else {
if (e === "bottom" && !i.data("horizontalScroll")) { v = k.outerHeight() - g.height() } else {
if (e === "left") { v = 0 } else {
if (e === "right" && i.data("horizontalScroll")) { v = k.outerWidth() - g.width() } else {
if (e === "first") { v = i.find(".mCSB_container").find(":first") } else {
if (e === "last") { v = i.find(".mCSB_container").find(":last") } else { v = i.find(e) } } } } } }
if (v.length === 1) {
if (i.data("horizontalScroll")) { e = v.position().left } else { e = v.position().top }
p = e / i.data("scrollAmount") } else { p = e = v } } }
if (i.data("horizontalScroll")) {
if (i.data("onTotalScrollBack_Offset")) { s = -i.data("onTotalScrollBack_Offset") }
if (i.data("onTotalScroll_Offset")) { l = g.width() - k.outerWidth() + i.data("onTotalScroll_Offset") }
if (p < 0) { p = e = 0;
clearInterval(i.data("mCSB_buttonScrollLeft"));
if (!s) { q = true } } else {
if (p >= j.width() - h.width()) { p = j.width() - h.width();
e = g.width() - k.outerWidth();
clearInterval(i.data("mCSB_buttonScrollRight"));
if (!l) { m = true } } else { e = -e } }
var n = i.data("snapAmount");
if (n) { e = Math.round(e / n) * n - i.data("snapOffset") }
d.mTweenAxis.call(this, h[0], "left", Math.round(p), draggerSpeed, f.scrollEasing);
d.mTweenAxis.call(this, k[0], "left", Math.round(e), t, f.scrollEasing, { onStart: function() {
if (f.callbacks && !i.data("mCS_tweenRunning")) { u("onScrollStart") }
if (i.data("autoHideScrollbar")) { d.showScrollbar.call(r) } }, onUpdate: function() {
if (f.callbacks) { u("whileScrolling") } }, onComplete: function() {
if (f.callbacks) { u("onScroll");
if (q || (s && k.position().left >= s)) { u("onTotalScrollBack") }
if (m || (l && k.position().left <= l)) { u("onTotalScroll") } }
h.data("preventAction", false);
i.data("mCS_tweenRunning", false);
if (i.data("autoHideScrollbar")) {
if (!g.hasClass("mCS-mouse-over")) { d.hideScrollbar.call(r) } } } }) } else {
if (i.data("onTotalScrollBack_Offset")) { s = -i.data("onTotalScrollBack_Offset") }
if (i.data("onTotalScroll_Offset")) { l = g.height() - k.outerHeight() + i.data("onTotalScroll_Offset") }
if (p < 0) { p = e = 0;
clearInterval(i.data("mCSB_buttonScrollUp"));
if (!s) { q = true } } else {
if (p >= j.height() - h.height()) { p = j.height() - h.height();
e = g.height() - k.outerHeight();
clearInterval(i.data("mCSB_buttonScrollDown"));
if (!l) { m = true } } else { e = -e } }
var n = i.data("snapAmount");
if (n) { e = Math.round(e / n) * n - i.data("snapOffset") }
d.mTweenAxis.call(this, h[0], "top", Math.round(p), draggerSpeed, f.scrollEasing);
d.mTweenAxis.call(this, k[0], "top", Math.round(e), t, f.scrollEasing, { onStart: function() {
if (f.callbacks && !i.data("mCS_tweenRunning")) { u("onScrollStart") }
if (i.data("autoHideScrollbar")) { d.showScrollbar.call(r) } }, onUpdate: function() {
if (f.callbacks) { u("whileScrolling") } }, onComplete: function() {
if (f.callbacks) { u("onScroll");
if (q || (s && k.position().top >= s)) { u("onTotalScrollBack") }
if (m || (l && k.position().top <= l)) { u("onTotalScroll") } }
h.data("preventAction", false);
i.data("mCS_tweenRunning", false);
if (i.data("autoHideScrollbar")) {
if (!g.hasClass("mCS-mouse-over")) { d.hideScrollbar.call(r) } } } }) }
if (i.data("mCS_Init")) { i.data({ mCS_Init: false }) } } }
function u(w) { this.mcs = { top: k.position().top, left: k.position().left, draggerTop: h.position().top, draggerLeft: h.position().left, topPct: Math.round((100 * Math.abs(k.position().top)) / Math.abs(k.outerHeight() - g.height())), leftPct: Math.round((100 * Math.abs(k.position().left)) / Math.abs(k.outerWidth() - g.width())) };
switch (w) {
case "onScrollStart":
i.data("mCS_tweenRunning", true).data("onScrollStart_Callback").call(i, this.mcs);
break;
case "whileScrolling":
i.data("whileScrolling_Callback").call(i, this.mcs);
break;
case "onScroll":
i.data("onScroll_Callback").call(i, this.mcs);
break;
case "onTotalScrollBack":
i.data("onTotalScrollBack_Callback").call(i, this.mcs);
break;
case "onTotalScroll":
i.data("onTotalScroll_Callback").call(i, this.mcs);
break } } }, stop: function() {
var g = c(this),
e = g.children().children(".mCSB_container"),
f = g.children().children().children().children(".mCSB_dragger");
d.mTweenAxisStop.call(this, e[0]);
d.mTweenAxisStop.call(this, f[0]) }, disable: function(e) {
var j = c(this),
f = j.children(".mCustomScrollBox"),
h = f.children(".mCSB_container"),
g = f.children(".mCSB_scrollTools"),
i = g.children().children(".mCSB_dragger");
f.unbind("mousewheel focusin mouseenter mouseleave touchend");
h.unbind("touchstart touchmove");
if (e) {
if (j.data("horizontalScroll")) { i.add(h).css("left", 0) } else { i.add(h).css("top", 0) } }
g.css("display", "none");
h.addClass("mCS_no_scrollbar");
j.data({ bindEvent_mousewheel: false, bindEvent_focusin: false, bindEvent_content_touch: false, bindEvent_autoHideScrollbar: false }).addClass("mCS_disabled") }, destroy: function() {
var e = c(this);
e.removeClass("mCustomScrollbar _mCS_" + e.data("mCustomScrollbarIndex")).addClass("mCS_destroyed").children().children(".mCSB_container").unwrap().children().unwrap().siblings(".mCSB_scrollTools").remove();
c(document).unbind("mousemove." + e.data("mCustomScrollbarIndex") + " mouseup." + e.data("mCustomScrollbarIndex") + " MSPointerMove." + e.data("mCustomScrollbarIndex") + " MSPointerUp." + e.data("mCustomScrollbarIndex"));
c(window).unbind("resize." + e.data("mCustomScrollbarIndex")) } },
d = { showScrollbar: function() { this.stop().animate({ opacity: 1 }, "fast") }, hideScrollbar: function() { this.stop().animate({ opacity: 0 }, "fast") }, mTweenAxis: function(g, i, h, f, o, y) {
var y = y || {},
v = y.onStart || function() {},
p = y.onUpdate || function() {},
w = y.onComplete || function() {};
var n = t(),
l, j = 0,
r = g.offsetTop,
s = g.style;
if (i === "left") { r = g.offsetLeft }
var m = h - r;
q();
e();
function t() {
if (window.performance && window.performance.now) {
return window.performance.now() } else {
if (window.performance && window.performance.webkitNow) {
return window.performance.webkitNow() } else {
if (Date.now) {
return Date.now() } else {
return new Date().getTime() } } } }
function x() {
if (!j) { v.call() }
j = t() - n;
u();
if (j >= g._time) { g._time = (j > g._time) ? j + l - (j - g._time) : j + l - 1;
if (g._time < j + 1) { g._time = j + 1 } }
if (g._time < f) { g._id = _request(x) } else { w.call() } }
function u() {
if (f > 0) { g.currVal = k(g._time, r, m, f, o);
s[i] = Math.round(g.currVal) + "px" } else { s[i] = h + "px" }
p.call() }
function e() { l = 1000 / 60;
g._time = j + l;
_request = (!window.requestAnimationFrame) ? function(z) { u();
return setTimeout(z, 0.01) } : window.requestAnimationFrame;
g._id = _request(x) }
function q() {
if (g._id == null) {
return }
if (!window.requestAnimationFrame) { clearTimeout(g._id) } else { window.cancelAnimationFrame(g._id) }
g._id = null }
function k(B, A, F, E, C) {
switch (C) {
case "linear":
return F * B / E + A;
break;
case "easeOutQuad":
B /= E;
return -F * B * (B - 2) + A;
break;
case "easeInOutQuad":
B /= E / 2;
if (B < 1) {
return F / 2 * B * B + A }
B--;
return -F / 2 * (B * (B - 2) - 1) + A;
break;
case "easeOutCubic":
B /= E;
B--;
return F * (B * B * B + 1) + A;
break;
case "easeOutQuart":
B /= E;
B--;
return -F * (B * B * B * B - 1) + A;
break;
case "easeOutQuint":
B /= E;
B--;
return F * (B * B * B * B * B + 1) + A;
break;
case "easeOutCirc":
B /= E;
B--;
return F * Math.sqrt(1 - B * B) + A;
break;
case "easeOutSine":
return F * Math.sin(B / E * (Math.PI / 2)) + A;
break;
case "easeOutExpo":
return F * (-Math.pow(2, -10 * B / E) + 1) + A;
break;
case "mcsEaseOut":
var D = (B /= E) * B,
z = D * B;
return A + F * (0.499999999999997 * z * D + -2.5 * D * D + 5.5 * z + -6.5 * D + 4 * B);
break;
case "draggerRailEase":
B /= E / 2;
if (B < 1) {
return F / 2 * B * B * B + A }
B -= 2;
return F / 2 * (B * B * B + 2) + A;
break } } }, mTweenAxisStop: function(e) {
if (e._id == null) {
return }
if (!window.requestAnimationFrame) { clearTimeout(e._id) } else { window.cancelAnimationFrame(e._id) }
e._id = null }, rafPolyfill: function() {
var f = ["ms", "moz", "webkit", "o"],
e = f.length;
while (--e > -1 && !window.requestAnimationFrame) { window.requestAnimationFrame = window[f[e] + "RequestAnimationFrame"];
window.cancelAnimationFrame = window[f[e] + "CancelAnimationFrame"] || window[f[e] + "CancelRequestAnimationFrame"] } } };
d.rafPolyfill.call();
c.support.touch = !!("ontouchstart" in window);
c.support.msPointer = window.navigator.msPointerEnabled;
var a = ("https:" == document.location.protocol) ? "https:" : "http:";
c.event.special.mousewheel || document.write('