You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1061 lines
33 KiB
1061 lines
33 KiB
1 year ago
|
/*! Magnific Popup - v1.1.0 - 2016-02-20
|
||
|
* http://dimsemenov.com/plugins/magnific-popup/
|
||
|
* Copyright (c) 2016 Dmitry Semenov; */
|
||
|
!(function (a) {
|
||
|
"function" == typeof define && define.amd
|
||
|
? define(["jquery"], a)
|
||
|
: a(
|
||
|
"object" == typeof exports
|
||
|
? require("jquery")
|
||
|
: window.jQuery || window.Zepto
|
||
|
);
|
||
|
})(function (a) {
|
||
|
var b,
|
||
|
c,
|
||
|
d,
|
||
|
e,
|
||
|
f,
|
||
|
g,
|
||
|
h = "Close",
|
||
|
i = "BeforeClose",
|
||
|
j = "AfterClose",
|
||
|
k = "BeforeAppend",
|
||
|
l = "MarkupParse",
|
||
|
m = "Open",
|
||
|
n = "Change",
|
||
|
o = "mfp",
|
||
|
p = "." + o,
|
||
|
q = "mfp-ready",
|
||
|
r = "mfp-removing",
|
||
|
s = "mfp-prevent-close",
|
||
|
t = function () {},
|
||
|
u = !!window.jQuery,
|
||
|
v = a(window),
|
||
|
w = function (a, c) {
|
||
|
b.ev.on(o + a + p, c);
|
||
|
},
|
||
|
x = function (b, c, d, e) {
|
||
|
var f = document.createElement("div");
|
||
|
return (
|
||
|
(f.className = "mfp-" + b),
|
||
|
d && (f.innerHTML = d),
|
||
|
e ? c && c.appendChild(f) : ((f = a(f)), c && f.appendTo(c)),
|
||
|
f
|
||
|
);
|
||
|
},
|
||
|
y = function (c, d) {
|
||
|
b.ev.triggerHandler(o + c, d),
|
||
|
b.st.callbacks &&
|
||
|
((c = c.charAt(0).toLowerCase() + c.slice(1)),
|
||
|
b.st.callbacks[c] &&
|
||
|
b.st.callbacks[c].apply(b, a.isArray(d) ? d : [d]));
|
||
|
},
|
||
|
z = function (c) {
|
||
|
return (
|
||
|
(c === g && b.currTemplate.closeBtn) ||
|
||
|
((b.currTemplate.closeBtn = a(
|
||
|
b.st.closeMarkup.replace("%title%", b.st.tClose)
|
||
|
)),
|
||
|
(g = c)),
|
||
|
b.currTemplate.closeBtn
|
||
|
);
|
||
|
},
|
||
|
A = function () {
|
||
|
a.magnificPopup.instance ||
|
||
|
((b = new t()), b.init(), (a.magnificPopup.instance = b));
|
||
|
},
|
||
|
B = function () {
|
||
|
var a = document.createElement("p").style,
|
||
|
b = ["ms", "O", "Moz", "Webkit"];
|
||
|
if (void 0 !== a.transition) return !0;
|
||
|
for (; b.length; ) if (b.pop() + "Transition" in a) return !0;
|
||
|
return !1;
|
||
|
};
|
||
|
(t.prototype = {
|
||
|
constructor: t,
|
||
|
init: function () {
|
||
|
var c = navigator.appVersion;
|
||
|
(b.isLowIE = b.isIE8 = document.all && !document.addEventListener),
|
||
|
(b.isAndroid = /android/gi.test(c)),
|
||
|
(b.isIOS = /iphone|ipad|ipod/gi.test(c)),
|
||
|
(b.supportsTransition = B()),
|
||
|
(b.probablyMobile =
|
||
|
b.isAndroid ||
|
||
|
b.isIOS ||
|
||
|
/(Opera Mini)|Kindle|webOS|BlackBerry|(Opera Mobi)|(Windows Phone)|IEMobile/i.test(
|
||
|
navigator.userAgent
|
||
|
)),
|
||
|
(d = a(document)),
|
||
|
(b.popupsCache = {});
|
||
|
},
|
||
|
open: function (c) {
|
||
|
var e;
|
||
|
if (c.isObj === !1) {
|
||
|
(b.items = c.items.toArray()), (b.index = 0);
|
||
|
var g,
|
||
|
h = c.items;
|
||
|
for (e = 0; e < h.length; e++)
|
||
|
if (((g = h[e]), g.parsed && (g = g.el[0]), g === c.el[0])) {
|
||
|
b.index = e;
|
||
|
break;
|
||
|
}
|
||
|
} else
|
||
|
(b.items = a.isArray(c.items) ? c.items : [c.items]),
|
||
|
(b.index = c.index || 0);
|
||
|
if (b.isOpen) return void b.updateItemHTML();
|
||
|
(b.types = []),
|
||
|
(f = ""),
|
||
|
c.mainEl && c.mainEl.length ? (b.ev = c.mainEl.eq(0)) : (b.ev = d),
|
||
|
c.key
|
||
|
? (b.popupsCache[c.key] || (b.popupsCache[c.key] = {}),
|
||
|
(b.currTemplate = b.popupsCache[c.key]))
|
||
|
: (b.currTemplate = {}),
|
||
|
(b.st = a.extend(!0, {}, a.magnificPopup.defaults, c)),
|
||
|
(b.fixedContentPos =
|
||
|
"auto" === b.st.fixedContentPos
|
||
|
? !b.probablyMobile
|
||
|
: b.st.fixedContentPos),
|
||
|
b.st.modal &&
|
||
|
((b.st.closeOnContentClick = !1),
|
||
|
(b.st.closeOnBgClick = !1),
|
||
|
(b.st.showCloseBtn = !1),
|
||
|
(b.st.enableEscapeKey = !1)),
|
||
|
b.bgOverlay ||
|
||
|
((b.bgOverlay = x("bg").on("click" + p, function () {
|
||
|
b.close();
|
||
|
})),
|
||
|
(b.wrap = x("wrap")
|
||
|
.attr("tabindex", -1)
|
||
|
.on("click" + p, function (a) {
|
||
|
b._checkIfClose(a.target) && b.close();
|
||
|
})),
|
||
|
(b.container = x("container", b.wrap))),
|
||
|
(b.contentContainer = x("content")),
|
||
|
b.st.preloader &&
|
||
|
(b.preloader = x("preloader", b.container, b.st.tLoading));
|
||
|
var i = a.magnificPopup.modules;
|
||
|
for (e = 0; e < i.length; e++) {
|
||
|
var j = i[e];
|
||
|
(j = j.charAt(0).toUpperCase() + j.slice(1)), b["init" + j].call(b);
|
||
|
}
|
||
|
y("BeforeOpen"),
|
||
|
b.st.showCloseBtn &&
|
||
|
(b.st.closeBtnInside
|
||
|
? (w(l, function (a, b, c, d) {
|
||
|
c.close_replaceWith = z(d.type);
|
||
|
}),
|
||
|
(f += " mfp-close-btn-in"))
|
||
|
: b.wrap.append(z())),
|
||
|
b.st.alignTop && (f += " mfp-align-top"),
|
||
|
b.fixedContentPos
|
||
|
? b.wrap.css({
|
||
|
overflow: b.st.overflowY,
|
||
|
overflowX: "hidden",
|
||
|
overflowY: b.st.overflowY,
|
||
|
})
|
||
|
: b.wrap.css({ top: v.scrollTop(), position: "absolute" }),
|
||
|
(b.st.fixedBgPos === !1 ||
|
||
|
("auto" === b.st.fixedBgPos && !b.fixedContentPos)) &&
|
||
|
b.bgOverlay.css({ height: d.height(), position: "absolute" }),
|
||
|
b.st.enableEscapeKey &&
|
||
|
d.on("keyup" + p, function (a) {
|
||
|
27 === a.keyCode && b.close();
|
||
|
}),
|
||
|
v.on("resize" + p, function () {
|
||
|
b.updateSize();
|
||
|
}),
|
||
|
b.st.closeOnContentClick || (f += " mfp-auto-cursor"),
|
||
|
f && b.wrap.addClass(f);
|
||
|
var k = (b.wH = v.height()),
|
||
|
n = {};
|
||
|
if (b.fixedContentPos && b._hasScrollBar(k)) {
|
||
|
var o = b._getScrollbarSize();
|
||
|
o && (n.marginRight = o);
|
||
|
}
|
||
|
b.fixedContentPos &&
|
||
|
(b.isIE7
|
||
|
? a("body, html").css("overflow", "hidden")
|
||
|
: (n.overflow = "hidden"));
|
||
|
var r = b.st.mainClass;
|
||
|
return (
|
||
|
b.isIE7 && (r += " mfp-ie7"),
|
||
|
r && b._addClassToMFP(r),
|
||
|
b.updateItemHTML(),
|
||
|
y("BuildControls"),
|
||
|
a("html").css(n),
|
||
|
b.bgOverlay.add(b.wrap).prependTo(b.st.prependTo || a(document.body)),
|
||
|
(b._lastFocusedEl = document.activeElement),
|
||
|
setTimeout(function () {
|
||
|
b.content
|
||
|
? (b._addClassToMFP(q), b._setFocus())
|
||
|
: b.bgOverlay.addClass(q),
|
||
|
d.on("focusin" + p, b._onFocusIn);
|
||
|
}, 16),
|
||
|
(b.isOpen = !0),
|
||
|
b.updateSize(k),
|
||
|
y(m),
|
||
|
c
|
||
|
);
|
||
|
},
|
||
|
close: function () {
|
||
|
b.isOpen &&
|
||
|
(y(i),
|
||
|
(b.isOpen = !1),
|
||
|
b.st.removalDelay && !b.isLowIE && b.supportsTransition
|
||
|
? (b._addClassToMFP(r),
|
||
|
setTimeout(function () {
|
||
|
b._close();
|
||
|
}, b.st.removalDelay))
|
||
|
: b._close());
|
||
|
},
|
||
|
_close: function () {
|
||
|
y(h);
|
||
|
var c = r + " " + q + " ";
|
||
|
if (
|
||
|
(b.bgOverlay.detach(),
|
||
|
b.wrap.detach(),
|
||
|
b.container.empty(),
|
||
|
b.st.mainClass && (c += b.st.mainClass + " "),
|
||
|
b._removeClassFromMFP(c),
|
||
|
b.fixedContentPos)
|
||
|
) {
|
||
|
var e = { marginRight: "" };
|
||
|
b.isIE7 ? a("body, html").css("overflow", "") : (e.overflow = ""),
|
||
|
a("html").css(e);
|
||
|
}
|
||
|
d.off("keyup" + p + " focusin" + p),
|
||
|
b.ev.off(p),
|
||
|
b.wrap.attr("class", "mfp-wrap").removeAttr("style"),
|
||
|
b.bgOverlay.attr("class", "mfp-bg"),
|
||
|
b.container.attr("class", "mfp-container"),
|
||
|
!b.st.showCloseBtn ||
|
||
|
(b.st.closeBtnInside && b.currTemplate[b.currItem.type] !== !0) ||
|
||
|
(b.currTemplate.closeBtn && b.currTemplate.closeBtn.detach()),
|
||
|
b.st.autoFocusLast && b._lastFocusedEl && a(b._lastFocusedEl).focus(),
|
||
|
(b.currItem = null),
|
||
|
(b.content = null),
|
||
|
(b.currTemplate = null),
|
||
|
(b.prevHeight = 0),
|
||
|
y(j);
|
||
|
},
|
||
|
updateSize: function (a) {
|
||
|
if (b.isIOS) {
|
||
|
var c = document.documentElement.clientWidth / window.innerWidth,
|
||
|
d = window.innerHeight * c;
|
||
|
b.wrap.css("height", d), (b.wH = d);
|
||
|
} else b.wH = a || v.height();
|
||
|
b.fixedContentPos || b.wrap.css("height", b.wH), y("Resize");
|
||
|
},
|
||
|
updateItemHTML: function () {
|
||
|
var c = b.items[b.index];
|
||
|
b.contentContainer.detach(),
|
||
|
b.content && b.content.detach(),
|
||
|
c.parsed || (c = b.parseEl(b.index));
|
||
|
var d = c.type;
|
||
|
if (
|
||
|
(y("BeforeChange", [b.currItem ? b.currItem.type : "", d]),
|
||
|
(b.currItem = c),
|
||
|
!b.currTemplate[d])
|
||
|
) {
|
||
|
var f = b.st[d] ? b.st[d].markup : !1;
|
||
|
y("FirstMarkupParse", f),
|
||
|
f ? (b.currTemplate[d] = a(f)) : (b.currTemplate[d] = !0);
|
||
|
}
|
||
|
e && e !== c.type && b.container.removeClass("mfp-" + e + "-holder");
|
||
|
var g = b["get" + d.charAt(0).toUpperCase() + d.slice(1)](
|
||
|
c,
|
||
|
b.currTemplate[d]
|
||
|
);
|
||
|
b.appendContent(g, d),
|
||
|
(c.preloaded = !0),
|
||
|
y(n, c),
|
||
|
(e = c.type),
|
||
|
b.container.prepend(b.contentContainer),
|
||
|
y("AfterChange");
|
||
|
},
|
||
|
appendContent: function (a, c) {
|
||
|
(b.content = a),
|
||
|
a
|
||
|
? b.st.showCloseBtn && b.st.closeBtnInside && b.currTemplate[c] === !0
|
||
|
? b.content.find(".mfp-close").length || b.content.append(z())
|
||
|
: (b.content = a)
|
||
|
: (b.content = ""),
|
||
|
y(k),
|
||
|
b.container.addClass("mfp-" + c + "-holder"),
|
||
|
b.contentContainer.append(b.content);
|
||
|
},
|
||
|
parseEl: function (c) {
|
||
|
var d,
|
||
|
e = b.items[c];
|
||
|
if (
|
||
|
(e.tagName
|
||
|
? (e = { el: a(e) })
|
||
|
: ((d = e.type), (e = { data: e, src: e.src })),
|
||
|
e.el)
|
||
|
) {
|
||
|
for (var f = b.types, g = 0; g < f.length; g++)
|
||
|
if (e.el.hasClass("mfp-" + f[g])) {
|
||
|
d = f[g];
|
||
|
break;
|
||
|
}
|
||
|
(e.src = e.el.attr("data-mfp-src")),
|
||
|
e.src || (e.src = e.el.attr("href"));
|
||
|
}
|
||
|
return (
|
||
|
(e.type = d || b.st.type || "inline"),
|
||
|
(e.index = c),
|
||
|
(e.parsed = !0),
|
||
|
(b.items[c] = e),
|
||
|
y("ElementParse", e),
|
||
|
b.items[c]
|
||
|
);
|
||
|
},
|
||
|
addGroup: function (a, c) {
|
||
|
var d = function (d) {
|
||
|
(d.mfpEl = this), b._openClick(d, a, c);
|
||
|
};
|
||
|
c || (c = {});
|
||
|
var e = "click.magnificPopup";
|
||
|
(c.mainEl = a),
|
||
|
c.items
|
||
|
? ((c.isObj = !0), a.off(e).on(e, d))
|
||
|
: ((c.isObj = !1),
|
||
|
c.delegate
|
||
|
? a.off(e).on(e, c.delegate, d)
|
||
|
: ((c.items = a), a.off(e).on(e, d)));
|
||
|
},
|
||
|
_openClick: function (c, d, e) {
|
||
|
var f =
|
||
|
void 0 !== e.midClick ? e.midClick : a.magnificPopup.defaults.midClick;
|
||
|
if (
|
||
|
f ||
|
||
|
!(2 === c.which || c.ctrlKey || c.metaKey || c.altKey || c.shiftKey)
|
||
|
) {
|
||
|
var g =
|
||
|
void 0 !== e.disableOn
|
||
|
? e.disableOn
|
||
|
: a.magnificPopup.defaults.disableOn;
|
||
|
if (g)
|
||
|
if (a.isFunction(g)) {
|
||
|
if (!g.call(b)) return !0;
|
||
|
} else if (v.width() < g) return !0;
|
||
|
c.type && (c.preventDefault(), b.isOpen && c.stopPropagation()),
|
||
|
(e.el = a(c.mfpEl)),
|
||
|
e.delegate && (e.items = d.find(e.delegate)),
|
||
|
b.open(e);
|
||
|
}
|
||
|
},
|
||
|
updateStatus: function (a, d) {
|
||
|
if (b.preloader) {
|
||
|
c !== a && b.container.removeClass("mfp-s-" + c),
|
||
|
d || "loading" !== a || (d = b.st.tLoading);
|
||
|
var e = { status: a, text: d };
|
||
|
y("UpdateStatus", e),
|
||
|
(a = e.status),
|
||
|
(d = e.text),
|
||
|
b.preloader.html(d),
|
||
|
b.preloader.find("a").on("click", function (a) {
|
||
|
a.stopImmediatePropagation();
|
||
|
}),
|
||
|
b.container.addClass("mfp-s-" + a),
|
||
|
(c = a);
|
||
|
}
|
||
|
},
|
||
|
_checkIfClose: function (c) {
|
||
|
if (!a(c).hasClass(s)) {
|
||
|
var d = b.st.closeOnContentClick,
|
||
|
e = b.st.closeOnBgClick;
|
||
|
if (d && e) return !0;
|
||
|
if (
|
||
|
!b.content ||
|
||
|
a(c).hasClass("mfp-close") ||
|
||
|
(b.preloader && c === b.preloader[0])
|
||
|
)
|
||
|
return !0;
|
||
|
if (c === b.content[0] || a.contains(b.content[0], c)) {
|
||
|
if (d) return !0;
|
||
|
} else if (e && a.contains(document, c)) return !0;
|
||
|
return !1;
|
||
|
}
|
||
|
},
|
||
|
_addClassToMFP: function (a) {
|
||
|
b.bgOverlay.addClass(a), b.wrap.addClass(a);
|
||
|
},
|
||
|
_removeClassFromMFP: function (a) {
|
||
|
this.bgOverlay.removeClass(a), b.wrap.removeClass(a);
|
||
|
},
|
||
|
_hasScrollBar: function (a) {
|
||
|
return (
|
||
|
(b.isIE7 ? d.height() : document.body.scrollHeight) > (a || v.height())
|
||
|
);
|
||
|
},
|
||
|
_setFocus: function () {
|
||
|
(b.st.focus ? b.content.find(b.st.focus).eq(0) : b.wrap).focus();
|
||
|
},
|
||
|
_onFocusIn: function (c) {
|
||
|
return c.target === b.wrap[0] || a.contains(b.wrap[0], c.target)
|
||
|
? void 0
|
||
|
: (b._setFocus(), !1);
|
||
|
},
|
||
|
_parseMarkup: function (b, c, d) {
|
||
|
var e;
|
||
|
d.data && (c = a.extend(d.data, c)),
|
||
|
y(l, [b, c, d]),
|
||
|
a.each(c, function (c, d) {
|
||
|
if (void 0 === d || d === !1) return !0;
|
||
|
if (((e = c.split("_")), e.length > 1)) {
|
||
|
var f = b.find(p + "-" + e[0]);
|
||
|
if (f.length > 0) {
|
||
|
var g = e[1];
|
||
|
"replaceWith" === g
|
||
|
? f[0] !== d[0] && f.replaceWith(d)
|
||
|
: "img" === g
|
||
|
? f.is("img")
|
||
|
? f.attr("src", d)
|
||
|
: f.replaceWith(
|
||
|
a("<img>").attr("src", d).attr("class", f.attr("class"))
|
||
|
)
|
||
|
: f.attr(e[1], d);
|
||
|
}
|
||
|
} else b.find(p + "-" + c).html(d);
|
||
|
});
|
||
|
},
|
||
|
_getScrollbarSize: function () {
|
||
|
if (void 0 === b.scrollbarSize) {
|
||
|
var a = document.createElement("div");
|
||
|
(a.style.cssText =
|
||
|
"width: 99px; height: 99px; overflow: scroll; position: absolute; top: -9999px;"),
|
||
|
document.body.appendChild(a),
|
||
|
(b.scrollbarSize = a.offsetWidth - a.clientWidth),
|
||
|
document.body.removeChild(a);
|
||
|
}
|
||
|
return b.scrollbarSize;
|
||
|
},
|
||
|
}),
|
||
|
(a.magnificPopup = {
|
||
|
instance: null,
|
||
|
proto: t.prototype,
|
||
|
modules: [],
|
||
|
open: function (b, c) {
|
||
|
return (
|
||
|
A(),
|
||
|
(b = b ? a.extend(!0, {}, b) : {}),
|
||
|
(b.isObj = !0),
|
||
|
(b.index = c || 0),
|
||
|
this.instance.open(b)
|
||
|
);
|
||
|
},
|
||
|
close: function () {
|
||
|
return a.magnificPopup.instance && a.magnificPopup.instance.close();
|
||
|
},
|
||
|
registerModule: function (b, c) {
|
||
|
c.options && (a.magnificPopup.defaults[b] = c.options),
|
||
|
a.extend(this.proto, c.proto),
|
||
|
this.modules.push(b);
|
||
|
},
|
||
|
defaults: {
|
||
|
disableOn: 0,
|
||
|
key: null,
|
||
|
midClick: !1,
|
||
|
mainClass: "",
|
||
|
preloader: !0,
|
||
|
focus: "",
|
||
|
closeOnContentClick: !1,
|
||
|
closeOnBgClick: !0,
|
||
|
closeBtnInside: !0,
|
||
|
showCloseBtn: !0,
|
||
|
enableEscapeKey: !0,
|
||
|
modal: !1,
|
||
|
alignTop: !1,
|
||
|
removalDelay: 0,
|
||
|
prependTo: null,
|
||
|
fixedContentPos: "auto",
|
||
|
fixedBgPos: "auto",
|
||
|
overflowY: "auto",
|
||
|
closeMarkup:
|
||
|
'<button title="%title%" type="button" class="mfp-close">×</button>',
|
||
|
tClose: "Close (Esc)",
|
||
|
tLoading: "Loading...",
|
||
|
autoFocusLast: !0,
|
||
|
},
|
||
|
}),
|
||
|
(a.fn.magnificPopup = function (c) {
|
||
|
A();
|
||
|
var d = a(this);
|
||
|
if ("string" == typeof c)
|
||
|
if ("open" === c) {
|
||
|
var e,
|
||
|
f = u ? d.data("magnificPopup") : d[0].magnificPopup,
|
||
|
g = parseInt(arguments[1], 10) || 0;
|
||
|
f.items
|
||
|
? (e = f.items[g])
|
||
|
: ((e = d), f.delegate && (e = e.find(f.delegate)), (e = e.eq(g))),
|
||
|
b._openClick({ mfpEl: e }, d, f);
|
||
|
} else
|
||
|
b.isOpen && b[c].apply(b, Array.prototype.slice.call(arguments, 1));
|
||
|
else
|
||
|
(c = a.extend(!0, {}, c)),
|
||
|
u ? d.data("magnificPopup", c) : (d[0].magnificPopup = c),
|
||
|
b.addGroup(d, c);
|
||
|
return d;
|
||
|
});
|
||
|
var C,
|
||
|
D,
|
||
|
E,
|
||
|
F = "inline",
|
||
|
G = function () {
|
||
|
E && (D.after(E.addClass(C)).detach(), (E = null));
|
||
|
};
|
||
|
a.magnificPopup.registerModule(F, {
|
||
|
options: {
|
||
|
hiddenClass: "hide",
|
||
|
markup: "",
|
||
|
tNotFound: "Content not found",
|
||
|
},
|
||
|
proto: {
|
||
|
initInline: function () {
|
||
|
b.types.push(F),
|
||
|
w(h + "." + F, function () {
|
||
|
G();
|
||
|
});
|
||
|
},
|
||
|
getInline: function (c, d) {
|
||
|
if ((G(), c.src)) {
|
||
|
var e = b.st.inline,
|
||
|
f = a(c.src);
|
||
|
if (f.length) {
|
||
|
var g = f[0].parentNode;
|
||
|
g &&
|
||
|
g.tagName &&
|
||
|
(D || ((C = e.hiddenClass), (D = x(C)), (C = "mfp-" + C)),
|
||
|
(E = f.after(D).detach().removeClass(C))),
|
||
|
b.updateStatus("ready");
|
||
|
} else b.updateStatus("error", e.tNotFound), (f = a("<div>"));
|
||
|
return (c.inlineElement = f), f;
|
||
|
}
|
||
|
return b.updateStatus("ready"), b._parseMarkup(d, {}, c), d;
|
||
|
},
|
||
|
},
|
||
|
});
|
||
|
var H,
|
||
|
I = "ajax",
|
||
|
J = function () {
|
||
|
H && a(document.body).removeClass(H);
|
||
|
},
|
||
|
K = function () {
|
||
|
J(), b.req && b.req.abort();
|
||
|
};
|
||
|
a.magnificPopup.registerModule(I, {
|
||
|
options: {
|
||
|
settings: null,
|
||
|
cursor: "mfp-ajax-cur",
|
||
|
tError: '<a href="%url%">The content</a> could not be loaded.',
|
||
|
},
|
||
|
proto: {
|
||
|
initAjax: function () {
|
||
|
b.types.push(I),
|
||
|
(H = b.st.ajax.cursor),
|
||
|
w(h + "." + I, K),
|
||
|
w("BeforeChange." + I, K);
|
||
|
},
|
||
|
getAjax: function (c) {
|
||
|
H && a(document.body).addClass(H), b.updateStatus("loading");
|
||
|
var d = a.extend(
|
||
|
{
|
||
|
url: c.src,
|
||
|
success: function (d, e, f) {
|
||
|
var g = { data: d, xhr: f };
|
||
|
y("ParseAjax", g),
|
||
|
b.appendContent(a(g.data), I),
|
||
|
(c.finished = !0),
|
||
|
J(),
|
||
|
b._setFocus(),
|
||
|
setTimeout(function () {
|
||
|
b.wrap.addClass(q);
|
||
|
}, 16),
|
||
|
b.updateStatus("ready"),
|
||
|
y("AjaxContentAdded");
|
||
|
},
|
||
|
error: function () {
|
||
|
J(),
|
||
|
(c.finished = c.loadError = !0),
|
||
|
b.updateStatus(
|
||
|
"error",
|
||
|
b.st.ajax.tError.replace("%url%", c.src)
|
||
|
);
|
||
|
},
|
||
|
},
|
||
|
b.st.ajax.settings
|
||
|
);
|
||
|
return (b.req = a.ajax(d)), "";
|
||
|
},
|
||
|
},
|
||
|
});
|
||
|
var L,
|
||
|
M = function (c) {
|
||
|
if (c.data && void 0 !== c.data.title) return c.data.title;
|
||
|
var d = b.st.image.titleSrc;
|
||
|
if (d) {
|
||
|
if (a.isFunction(d)) return d.call(b, c);
|
||
|
if (c.el) return c.el.attr(d) || "";
|
||
|
}
|
||
|
return "";
|
||
|
};
|
||
|
a.magnificPopup.registerModule("image", {
|
||
|
options: {
|
||
|
markup:
|
||
|
'<div class="mfp-figure"><div class="mfp-close"></div><figure><div class="mfp-img"></div><figcaption><div class="mfp-bottom-bar"><div class="mfp-title"></div><div class="mfp-counter"></div></div></figcaption></figure></div>',
|
||
|
cursor: "mfp-zoom-out-cur",
|
||
|
titleSrc: "title",
|
||
|
verticalFit: !0,
|
||
|
tError: '<a href="%url%">The image</a> could not be loaded.',
|
||
|
},
|
||
|
proto: {
|
||
|
initImage: function () {
|
||
|
var c = b.st.image,
|
||
|
d = ".image";
|
||
|
b.types.push("image"),
|
||
|
w(m + d, function () {
|
||
|
"image" === b.currItem.type &&
|
||
|
c.cursor &&
|
||
|
a(document.body).addClass(c.cursor);
|
||
|
}),
|
||
|
w(h + d, function () {
|
||
|
c.cursor && a(document.body).removeClass(c.cursor),
|
||
|
v.off("resize" + p);
|
||
|
}),
|
||
|
w("Resize" + d, b.resizeImage),
|
||
|
b.isLowIE && w("AfterChange", b.resizeImage);
|
||
|
},
|
||
|
resizeImage: function () {
|
||
|
var a = b.currItem;
|
||
|
if (a && a.img && b.st.image.verticalFit) {
|
||
|
var c = 0;
|
||
|
b.isLowIE &&
|
||
|
(c =
|
||
|
parseInt(a.img.css("padding-top"), 10) +
|
||
|
parseInt(a.img.css("padding-bottom"), 10)),
|
||
|
a.img.css("max-height", b.wH - c);
|
||
|
}
|
||
|
},
|
||
|
_onImageHasSize: function (a) {
|
||
|
a.img &&
|
||
|
((a.hasSize = !0),
|
||
|
L && clearInterval(L),
|
||
|
(a.isCheckingImgSize = !1),
|
||
|
y("ImageHasSize", a),
|
||
|
a.imgHidden &&
|
||
|
(b.content && b.content.removeClass("mfp-loading"),
|
||
|
(a.imgHidden = !1)));
|
||
|
},
|
||
|
findImageSize: function (a) {
|
||
|
var c = 0,
|
||
|
d = a.img[0],
|
||
|
e = function (f) {
|
||
|
L && clearInterval(L),
|
||
|
(L = setInterval(function () {
|
||
|
return d.naturalWidth > 0
|
||
|
? void b._onImageHasSize(a)
|
||
|
: (c > 200 && clearInterval(L),
|
||
|
c++,
|
||
|
void (3 === c
|
||
|
? e(10)
|
||
|
: 40 === c
|
||
|
? e(50)
|
||
|
: 100 === c && e(500)));
|
||
|
}, f));
|
||
|
};
|
||
|
e(1);
|
||
|
},
|
||
|
getImage: function (c, d) {
|
||
|
var e = 0,
|
||
|
f = function () {
|
||
|
c &&
|
||
|
(c.img[0].complete
|
||
|
? (c.img.off(".mfploader"),
|
||
|
c === b.currItem &&
|
||
|
(b._onImageHasSize(c), b.updateStatus("ready")),
|
||
|
(c.hasSize = !0),
|
||
|
(c.loaded = !0),
|
||
|
y("ImageLoadComplete"))
|
||
|
: (e++, 200 > e ? setTimeout(f, 100) : g()));
|
||
|
},
|
||
|
g = function () {
|
||
|
c &&
|
||
|
(c.img.off(".mfploader"),
|
||
|
c === b.currItem &&
|
||
|
(b._onImageHasSize(c),
|
||
|
b.updateStatus("error", h.tError.replace("%url%", c.src))),
|
||
|
(c.hasSize = !0),
|
||
|
(c.loaded = !0),
|
||
|
(c.loadError = !0));
|
||
|
},
|
||
|
h = b.st.image,
|
||
|
i = d.find(".mfp-img");
|
||
|
if (i.length) {
|
||
|
var j = document.createElement("img");
|
||
|
(j.className = "mfp-img"),
|
||
|
c.el &&
|
||
|
c.el.find("img").length &&
|
||
|
(j.alt = c.el.find("img").attr("alt")),
|
||
|
(c.img = a(j).on("load.mfploader", f).on("error.mfploader", g)),
|
||
|
(j.src = c.src),
|
||
|
i.is("img") && (c.img = c.img.clone()),
|
||
|
(j = c.img[0]),
|
||
|
j.naturalWidth > 0 ? (c.hasSize = !0) : j.width || (c.hasSize = !1);
|
||
|
}
|
||
|
return (
|
||
|
b._parseMarkup(d, { title: M(c), img_replaceWith: c.img }, c),
|
||
|
b.resizeImage(),
|
||
|
c.hasSize
|
||
|
? (L && clearInterval(L),
|
||
|
c.loadError
|
||
|
? (d.addClass("mfp-loading"),
|
||
|
b.updateStatus("error", h.tError.replace("%url%", c.src)))
|
||
|
: (d.removeClass("mfp-loading"), b.updateStatus("ready")),
|
||
|
d)
|
||
|
: (b.updateStatus("loading"),
|
||
|
(c.loading = !0),
|
||
|
c.hasSize ||
|
||
|
((c.imgHidden = !0),
|
||
|
d.addClass("mfp-loading"),
|
||
|
b.findImageSize(c)),
|
||
|
d)
|
||
|
);
|
||
|
},
|
||
|
},
|
||
|
});
|
||
|
var N,
|
||
|
O = function () {
|
||
|
return (
|
||
|
void 0 === N &&
|
||
|
(N = void 0 !== document.createElement("p").style.MozTransform),
|
||
|
N
|
||
|
);
|
||
|
};
|
||
|
a.magnificPopup.registerModule("zoom", {
|
||
|
options: {
|
||
|
enabled: !1,
|
||
|
easing: "ease-in-out",
|
||
|
duration: 300,
|
||
|
opener: function (a) {
|
||
|
return a.is("img") ? a : a.find("img");
|
||
|
},
|
||
|
},
|
||
|
proto: {
|
||
|
initZoom: function () {
|
||
|
var a,
|
||
|
c = b.st.zoom,
|
||
|
d = ".zoom";
|
||
|
if (c.enabled && b.supportsTransition) {
|
||
|
var e,
|
||
|
f,
|
||
|
g = c.duration,
|
||
|
j = function (a) {
|
||
|
var b = a
|
||
|
.clone()
|
||
|
.removeAttr("style")
|
||
|
.removeAttr("class")
|
||
|
.addClass("mfp-animated-image"),
|
||
|
d = "all " + c.duration / 1e3 + "s " + c.easing,
|
||
|
e = {
|
||
|
position: "fixed",
|
||
|
zIndex: 9999,
|
||
|
left: 0,
|
||
|
top: 0,
|
||
|
"-webkit-backface-visibility": "hidden",
|
||
|
},
|
||
|
f = "transition";
|
||
|
return (
|
||
|
(e["-webkit-" + f] = e["-moz-" + f] = e["-o-" + f] = e[f] = d),
|
||
|
b.css(e),
|
||
|
b
|
||
|
);
|
||
|
},
|
||
|
k = function () {
|
||
|
b.content.css("visibility", "visible");
|
||
|
};
|
||
|
w("BuildControls" + d, function () {
|
||
|
if (b._allowZoom()) {
|
||
|
if (
|
||
|
(clearTimeout(e),
|
||
|
b.content.css("visibility", "hidden"),
|
||
|
(a = b._getItemToZoom()),
|
||
|
!a)
|
||
|
)
|
||
|
return void k();
|
||
|
(f = j(a)),
|
||
|
f.css(b._getOffset()),
|
||
|
b.wrap.append(f),
|
||
|
(e = setTimeout(function () {
|
||
|
f.css(b._getOffset(!0)),
|
||
|
(e = setTimeout(function () {
|
||
|
k(),
|
||
|
setTimeout(function () {
|
||
|
f.remove(), (a = f = null), y("ZoomAnimationEnded");
|
||
|
}, 16);
|
||
|
}, g));
|
||
|
}, 16));
|
||
|
}
|
||
|
}),
|
||
|
w(i + d, function () {
|
||
|
if (b._allowZoom()) {
|
||
|
if ((clearTimeout(e), (b.st.removalDelay = g), !a)) {
|
||
|
if (((a = b._getItemToZoom()), !a)) return;
|
||
|
f = j(a);
|
||
|
}
|
||
|
f.css(b._getOffset(!0)),
|
||
|
b.wrap.append(f),
|
||
|
b.content.css("visibility", "hidden"),
|
||
|
setTimeout(function () {
|
||
|
f.css(b._getOffset());
|
||
|
}, 16);
|
||
|
}
|
||
|
}),
|
||
|
w(h + d, function () {
|
||
|
b._allowZoom() && (k(), f && f.remove(), (a = null));
|
||
|
});
|
||
|
}
|
||
|
},
|
||
|
_allowZoom: function () {
|
||
|
return "image" === b.currItem.type;
|
||
|
},
|
||
|
_getItemToZoom: function () {
|
||
|
return b.currItem.hasSize ? b.currItem.img : !1;
|
||
|
},
|
||
|
_getOffset: function (c) {
|
||
|
var d;
|
||
|
d = c ? b.currItem.img : b.st.zoom.opener(b.currItem.el || b.currItem);
|
||
|
var e = d.offset(),
|
||
|
f = parseInt(d.css("padding-top"), 10),
|
||
|
g = parseInt(d.css("padding-bottom"), 10);
|
||
|
e.top -= a(window).scrollTop() - f;
|
||
|
var h = {
|
||
|
width: d.width(),
|
||
|
height: (u ? d.innerHeight() : d[0].offsetHeight) - g - f,
|
||
|
};
|
||
|
return (
|
||
|
O()
|
||
|
? (h["-moz-transform"] = h.transform =
|
||
|
"translate(" + e.left + "px," + e.top + "px)")
|
||
|
: ((h.left = e.left), (h.top = e.top)),
|
||
|
h
|
||
|
);
|
||
|
},
|
||
|
},
|
||
|
});
|
||
|
var P = "iframe",
|
||
|
Q = "//about:blank",
|
||
|
R = function (a) {
|
||
|
if (b.currTemplate[P]) {
|
||
|
var c = b.currTemplate[P].find("iframe");
|
||
|
c.length &&
|
||
|
(a || (c[0].src = Q),
|
||
|
b.isIE8 && c.css("display", a ? "block" : "none"));
|
||
|
}
|
||
|
};
|
||
|
a.magnificPopup.registerModule(P, {
|
||
|
options: {
|
||
|
markup:
|
||
|
'<div class="mfp-iframe-scaler"><div class="mfp-close"></div><iframe class="mfp-iframe" src="//about:blank" frameborder="0" allowfullscreen></iframe></div>',
|
||
|
srcAction: "iframe_src",
|
||
|
patterns: {
|
||
|
youtube: {
|
||
|
index: "youtube.com",
|
||
|
id: "v=",
|
||
|
src: "//www.youtube.com/embed/%id%?autoplay=1",
|
||
|
},
|
||
|
vimeo: {
|
||
|
index: "vimeo.com/",
|
||
|
id: "/",
|
||
|
src: "//player.vimeo.com/video/%id%?autoplay=1",
|
||
|
},
|
||
|
gmaps: { index: "//maps.google.", src: "%id%&output=embed" },
|
||
|
},
|
||
|
},
|
||
|
proto: {
|
||
|
initIframe: function () {
|
||
|
b.types.push(P),
|
||
|
w("BeforeChange", function (a, b, c) {
|
||
|
b !== c && (b === P ? R() : c === P && R(!0));
|
||
|
}),
|
||
|
w(h + "." + P, function () {
|
||
|
R();
|
||
|
});
|
||
|
},
|
||
|
getIframe: function (c, d) {
|
||
|
var e = c.src,
|
||
|
f = b.st.iframe;
|
||
|
a.each(f.patterns, function () {
|
||
|
return e.indexOf(this.index) > -1
|
||
|
? (this.id &&
|
||
|
(e =
|
||
|
"string" == typeof this.id
|
||
|
? e.substr(
|
||
|
e.lastIndexOf(this.id) + this.id.length,
|
||
|
e.length
|
||
|
)
|
||
|
: this.id.call(this, e)),
|
||
|
(e = this.src.replace("%id%", e)),
|
||
|
!1)
|
||
|
: void 0;
|
||
|
});
|
||
|
var g = {};
|
||
|
return (
|
||
|
f.srcAction && (g[f.srcAction] = e),
|
||
|
b._parseMarkup(d, g, c),
|
||
|
b.updateStatus("ready"),
|
||
|
d
|
||
|
);
|
||
|
},
|
||
|
},
|
||
|
});
|
||
|
var S = function (a) {
|
||
|
var c = b.items.length;
|
||
|
return a > c - 1 ? a - c : 0 > a ? c + a : a;
|
||
|
},
|
||
|
T = function (a, b, c) {
|
||
|
return a.replace(/%curr%/gi, b + 1).replace(/%total%/gi, c);
|
||
|
};
|
||
|
a.magnificPopup.registerModule("gallery", {
|
||
|
options: {
|
||
|
enabled: !1,
|
||
|
arrowMarkup:
|
||
|
'<button title="%title%" type="button" class="mfp-arrow mfp-arrow-%dir%"></button>',
|
||
|
preload: [0, 2],
|
||
|
navigateByImgClick: !0,
|
||
|
arrows: !0,
|
||
|
tPrev: "Previous (Left arrow key)",
|
||
|
tNext: "Next (Right arrow key)",
|
||
|
tCounter: "%curr% of %total%",
|
||
|
},
|
||
|
proto: {
|
||
|
initGallery: function () {
|
||
|
var c = b.st.gallery,
|
||
|
e = ".mfp-gallery";
|
||
|
return (
|
||
|
(b.direction = !0),
|
||
|
c && c.enabled
|
||
|
? ((f += " mfp-gallery"),
|
||
|
w(m + e, function () {
|
||
|
c.navigateByImgClick &&
|
||
|
b.wrap.on("click" + e, ".mfp-img", function () {
|
||
|
return b.items.length > 1 ? (b.next(), !1) : void 0;
|
||
|
}),
|
||
|
d.on("keydown" + e, function (a) {
|
||
|
37 === a.keyCode ? b.prev() : 39 === a.keyCode && b.next();
|
||
|
});
|
||
|
}),
|
||
|
w("UpdateStatus" + e, function (a, c) {
|
||
|
c.text &&
|
||
|
(c.text = T(c.text, b.currItem.index, b.items.length));
|
||
|
}),
|
||
|
w(l + e, function (a, d, e, f) {
|
||
|
var g = b.items.length;
|
||
|
e.counter = g > 1 ? T(c.tCounter, f.index, g) : "";
|
||
|
}),
|
||
|
w("BuildControls" + e, function () {
|
||
|
if (b.items.length > 1 && c.arrows && !b.arrowLeft) {
|
||
|
var d = c.arrowMarkup,
|
||
|
e = (b.arrowLeft = a(
|
||
|
d.replace(/%title%/gi, c.tPrev).replace(/%dir%/gi, "left")
|
||
|
).addClass(s)),
|
||
|
f = (b.arrowRight = a(
|
||
|
d
|
||
|
.replace(/%title%/gi, c.tNext)
|
||
|
.replace(/%dir%/gi, "right")
|
||
|
).addClass(s));
|
||
|
e.click(function () {
|
||
|
b.prev();
|
||
|
}),
|
||
|
f.click(function () {
|
||
|
b.next();
|
||
|
}),
|
||
|
b.container.append(e.add(f));
|
||
|
}
|
||
|
}),
|
||
|
w(n + e, function () {
|
||
|
b._preloadTimeout && clearTimeout(b._preloadTimeout),
|
||
|
(b._preloadTimeout = setTimeout(function () {
|
||
|
b.preloadNearbyImages(), (b._preloadTimeout = null);
|
||
|
}, 16));
|
||
|
}),
|
||
|
void w(h + e, function () {
|
||
|
d.off(e),
|
||
|
b.wrap.off("click" + e),
|
||
|
(b.arrowRight = b.arrowLeft = null);
|
||
|
}))
|
||
|
: !1
|
||
|
);
|
||
|
},
|
||
|
next: function () {
|
||
|
(b.direction = !0), (b.index = S(b.index + 1)), b.updateItemHTML();
|
||
|
},
|
||
|
prev: function () {
|
||
|
(b.direction = !1), (b.index = S(b.index - 1)), b.updateItemHTML();
|
||
|
},
|
||
|
goTo: function (a) {
|
||
|
(b.direction = a >= b.index), (b.index = a), b.updateItemHTML();
|
||
|
},
|
||
|
preloadNearbyImages: function () {
|
||
|
var a,
|
||
|
c = b.st.gallery.preload,
|
||
|
d = Math.min(c[0], b.items.length),
|
||
|
e = Math.min(c[1], b.items.length);
|
||
|
for (a = 1; a <= (b.direction ? e : d); a++)
|
||
|
b._preloadItem(b.index + a);
|
||
|
for (a = 1; a <= (b.direction ? d : e); a++)
|
||
|
b._preloadItem(b.index - a);
|
||
|
},
|
||
|
_preloadItem: function (c) {
|
||
|
if (((c = S(c)), !b.items[c].preloaded)) {
|
||
|
var d = b.items[c];
|
||
|
d.parsed || (d = b.parseEl(c)),
|
||
|
y("LazyLoad", d),
|
||
|
"image" === d.type &&
|
||
|
(d.img = a('<img class="mfp-img" />')
|
||
|
.on("load.mfploader", function () {
|
||
|
d.hasSize = !0;
|
||
|
})
|
||
|
.on("error.mfploader", function () {
|
||
|
(d.hasSize = !0), (d.loadError = !0), y("LazyLoadError", d);
|
||
|
})
|
||
|
.attr("src", d.src)),
|
||
|
(d.preloaded = !0);
|
||
|
}
|
||
|
},
|
||
|
},
|
||
|
});
|
||
|
var U = "retina";
|
||
|
a.magnificPopup.registerModule(U, {
|
||
|
options: {
|
||
|
replaceSrc: function (a) {
|
||
|
return a.src.replace(/\.\w+$/, function (a) {
|
||
|
return "@2x" + a;
|
||
|
});
|
||
|
},
|
||
|
ratio: 1,
|
||
|
},
|
||
|
proto: {
|
||
|
initRetina: function () {
|
||
|
if (window.devicePixelRatio > 1) {
|
||
|
var a = b.st.retina,
|
||
|
c = a.ratio;
|
||
|
(c = isNaN(c) ? c() : c),
|
||
|
c > 1 &&
|
||
|
(w("ImageHasSize." + U, function (a, b) {
|
||
|
b.img.css({
|
||
|
"max-width": b.img[0].naturalWidth / c,
|
||
|
width: "100%",
|
||
|
});
|
||
|
}),
|
||
|
w("ElementParse." + U, function (b, d) {
|
||
|
d.src = a.replaceSrc(d, c);
|
||
|
}));
|
||
|
}
|
||
|
},
|
||
|
},
|
||
|
}),
|
||
|
A();
|
||
|
});
|