mastowall/masonry.pkgd.min.js
2023-11-10 17:17:00 +01:00

1069 lines
36 KiB
JavaScript

/*!
* Masonry PACKAGED v4.2.2
* Cascading grid layout library
* https://masonry.desandro.com
* MIT License
* by David DeSandro
*/
!function(t, e) {
"function" == typeof define && define.amd ? define("jquery-bridget/jquery-bridget", ["jquery"], function(i) {
return e(t, i)
}) : "object" == typeof module && module.exports ? module.exports = e(t, require("jquery")) : t.jQueryBridget = e(t, t.jQuery)
}(window, function(t, e) {
"use strict";
function i(i, r, a) {
function h(t, e, n) {
var o,
r = "$()." + i + '("' + e + '")';
return t.each(function(t, h) {
var u = a.data(h, i);
if (!u)
return void s(i + " not initialized. Cannot call methods, i.e. " + r);
var d = u[e];
if (!d || "_" == e.charAt(0))
return void s(r + " is not a valid method");
var l = d.apply(u, n);
o = void 0 === o ? l : o
}), void 0 !== o ? o : t
}
function u(t, e) {
t.each(function(t, n) {
var o = a.data(n, i);
o ? (o.option(e), o._init()) : (o = new r(n, e), a.data(n, i, o))
})
}
a = a || e || t.jQuery,
a && (r.prototype.option || (r.prototype.option = function(t) {
a.isPlainObject(t) && (this.options = a.extend(!0, this.options, t))
}), a.fn[i] = function(t) {
if ("string" == typeof t) {
var e = o.call(arguments, 1);
return h(this, t, e)
}
return u(this, t), this
}, n(a))
}
function n(t) {
!t || t && t.bridget || (t.bridget = i)
}
var o = Array.prototype.slice,
r = t.console,
s = "undefined" == typeof r ? function() {} : function(t) {
r.error(t)
};
return n(e || t.jQuery), i
}),
function(t, e) {
"function" == typeof define && define.amd ? define("ev-emitter/ev-emitter", e) : "object" == typeof module && module.exports ? module.exports = e() : t.EvEmitter = e()
}("undefined" != typeof window ? window : this, function() {
function t() {}
var e = t.prototype;
return e.on = function(t, e) {
if (t && e) {
var i = this._events = this._events || {},
n = i[t] = i[t] || [];
return -1 == n.indexOf(e) && n.push(e), this
}
}, e.once = function(t, e) {
if (t && e) {
this.on(t, e);
var i = this._onceEvents = this._onceEvents || {},
n = i[t] = i[t] || {};
return n[e] = !0, this
}
}, e.off = function(t, e) {
var i = this._events && this._events[t];
if (i && i.length) {
var n = i.indexOf(e);
return -1 != n && i.splice(n, 1), this
}
}, e.emitEvent = function(t, e) {
var i = this._events && this._events[t];
if (i && i.length) {
i = i.slice(0),
e = e || [];
for (var n = this._onceEvents && this._onceEvents[t], o = 0; o < i.length; o++) {
var r = i[o],
s = n && n[r];
s && (this.off(t, r), delete n[r]),
r.apply(this, e)
}
return this
}
}, e.allOff = function() {
delete this._events,
delete this._onceEvents
}, t
}),
function(t, e) {
"function" == typeof define && define.amd ? define("get-size/get-size", e) : "object" == typeof module && module.exports ? module.exports = e() : t.getSize = e()
}(window, function() {
"use strict";
function t(t) {
var e = parseFloat(t),
i = -1 == t.indexOf("%") && !isNaN(e);
return i && e
}
function e() {}
function i() {
for (var t = {
width: 0,
height: 0,
innerWidth: 0,
innerHeight: 0,
outerWidth: 0,
outerHeight: 0
}, e = 0; u > e; e++) {
var i = h[e];
t[i] = 0
}
return t
}
function n(t) {
var e = getComputedStyle(t);
return e || a("Style returned " + e + ". Are you running this code in a hidden iframe on Firefox? See https://bit.ly/getsizebug1"), e
}
function o() {
if (!d) {
d = !0;
var e = document.createElement("div");
e.style.width = "200px",
e.style.padding = "1px 2px 3px 4px",
e.style.borderStyle = "solid",
e.style.borderWidth = "1px 2px 3px 4px",
e.style.boxSizing = "border-box";
var i = document.body || document.documentElement;
i.appendChild(e);
var o = n(e);
s = 200 == Math.round(t(o.width)),
r.isBoxSizeOuter = s,
i.removeChild(e)
}
}
function r(e) {
if (o(), "string" == typeof e && (e = document.querySelector(e)), e && "object" == typeof e && e.nodeType) {
var r = n(e);
if ("none" == r.display)
return i();
var a = {};
a.width = e.offsetWidth,
a.height = e.offsetHeight;
for (var d = a.isBorderBox = "border-box" == r.boxSizing, l = 0; u > l; l++) {
var c = h[l],
f = r[c],
m = parseFloat(f);
a[c] = isNaN(m) ? 0 : m
}
var p = a.paddingLeft + a.paddingRight,
g = a.paddingTop + a.paddingBottom,
y = a.marginLeft + a.marginRight,
v = a.marginTop + a.marginBottom,
_ = a.borderLeftWidth + a.borderRightWidth,
z = a.borderTopWidth + a.borderBottomWidth,
E = d && s,
b = t(r.width);
b !== !1 && (a.width = b + (E ? 0 : p + _));
var x = t(r.height);
return x !== !1 && (a.height = x + (E ? 0 : g + z)), a.innerWidth = a.width - (p + _), a.innerHeight = a.height - (g + z), a.outerWidth = a.width + y, a.outerHeight = a.height + v, a
}
}
var s,
a = "undefined" == typeof console ? e : function(t) {
console.error(t)
},
h = ["paddingLeft", "paddingRight", "paddingTop", "paddingBottom", "marginLeft", "marginRight", "marginTop", "marginBottom", "borderLeftWidth", "borderRightWidth", "borderTopWidth", "borderBottomWidth"],
u = h.length,
d = !1;
return r
}),
function(t, e) {
"use strict";
"function" == typeof define && define.amd ? define("desandro-matches-selector/matches-selector", e) : "object" == typeof module && module.exports ? module.exports = e() : t.matchesSelector = e()
}(window, function() {
"use strict";
var t = function() {
var t = window.Element.prototype;
if (t.matches)
return "matches";
if (t.matchesSelector)
return "matchesSelector";
for (var e = ["webkit", "moz", "ms", "o"], i = 0; i < e.length; i++) {
var n = e[i],
o = n + "MatchesSelector";
if (t[o])
return o
}
}();
return function(e, i) {
return e[t](i)
}
}),
function(t, e) {
"function" == typeof define && define.amd ? define("fizzy-ui-utils/utils", ["desandro-matches-selector/matches-selector"], function(i) {
return e(t, i)
}) : "object" == typeof module && module.exports ? module.exports = e(t, require("desandro-matches-selector")) : t.fizzyUIUtils = e(t, t.matchesSelector)
}(window, function(t, e) {
var i = {};
i.extend = function(t, e) {
for (var i in e)
t[i] = e[i];
return t
},
i.modulo = function(t, e) {
return (t % e + e) % e
};
var n = Array.prototype.slice;
i.makeArray = function(t) {
if (Array.isArray(t))
return t;
if (null === t || void 0 === t)
return [];
var e = "object" == typeof t && "number" == typeof t.length;
return e ? n.call(t) : [t]
},
i.removeFrom = function(t, e) {
var i = t.indexOf(e);
-1 != i && t.splice(i, 1)
},
i.getParent = function(t, i) {
for (; t.parentNode && t != document.body;)
if (t = t.parentNode, e(t, i))
return t
},
i.getQueryElement = function(t) {
return "string" == typeof t ? document.querySelector(t) : t
},
i.handleEvent = function(t) {
var e = "on" + t.type;
this[e] && this[e](t)
},
i.filterFindElements = function(t, n) {
t = i.makeArray(t);
var o = [];
return t.forEach(function(t) {
if (t instanceof HTMLElement) {
if (!n)
return void o.push(t);
e(t, n) && o.push(t);
for (var i = t.querySelectorAll(n), r = 0; r < i.length; r++)
o.push(i[r])
}
}), o
},
i.debounceMethod = function(t, e, i) {
i = i || 100;
var n = t.prototype[e],
o = e + "Timeout";
t.prototype[e] = function() {
var t = this[o];
clearTimeout(t);
var e = arguments,
r = this;
this[o] = setTimeout(function() {
n.apply(r, e),
delete r[o]
}, i)
}
},
i.docReady = function(t) {
var e = document.readyState;
"complete" == e || "interactive" == e ? setTimeout(t) : document.addEventListener("DOMContentLoaded", t)
},
i.toDashed = function(t) {
return t.replace(/(.)([A-Z])/g, function(t, e, i) {
return e + "-" + i
}).toLowerCase()
};
var o = t.console;
return i.htmlInit = function(e, n) {
i.docReady(function() {
var r = i.toDashed(n),
s = "data-" + r,
a = document.querySelectorAll("[" + s + "]"),
h = document.querySelectorAll(".js-" + r),
u = i.makeArray(a).concat(i.makeArray(h)),
d = s + "-options",
l = t.jQuery;
u.forEach(function(t) {
var i,
r = t.getAttribute(s) || t.getAttribute(d);
try {
i = r && JSON.parse(r)
} catch (a) {
return void (o && o.error("Error parsing " + s + " on " + t.className + ": " + a))
}
var h = new e(t, i);
l && l.data(t, n, h)
})
})
}, i
}),
function(t, e) {
"function" == typeof define && define.amd ? define("outlayer/item", ["ev-emitter/ev-emitter", "get-size/get-size"], e) : "object" == typeof module && module.exports ? module.exports = e(require("ev-emitter"), require("get-size")) : (t.Outlayer = {}, t.Outlayer.Item = e(t.EvEmitter, t.getSize))
}(window, function(t, e) {
"use strict";
function i(t) {
for (var e in t)
return !1;
return e = null, !0
}
function n(t, e) {
t && (this.element = t, this.layout = e, this.position = {
x: 0,
y: 0
}, this._create())
}
function o(t) {
return t.replace(/([A-Z])/g, function(t) {
return "-" + t.toLowerCase()
})
}
var r = document.documentElement.style,
s = "string" == typeof r.transition ? "transition" : "WebkitTransition",
a = "string" == typeof r.transform ? "transform" : "WebkitTransform",
h = {
WebkitTransition: "webkitTransitionEnd",
transition: "transitionend"
}[s],
u = {
transform: a,
transition: s,
transitionDuration: s + "Duration",
transitionProperty: s + "Property",
transitionDelay: s + "Delay"
},
d = n.prototype = Object.create(t.prototype);
d.constructor = n,
d._create = function() {
this._transn = {
ingProperties: {},
clean: {},
onEnd: {}
},
this.css({
position: "absolute"
})
},
d.handleEvent = function(t) {
var e = "on" + t.type;
this[e] && this[e](t)
},
d.getSize = function() {
this.size = e(this.element)
},
d.css = function(t) {
var e = this.element.style;
for (var i in t) {
var n = u[i] || i;
e[n] = t[i]
}
},
d.getPosition = function() {
var t = getComputedStyle(this.element),
e = this.layout._getOption("originLeft"),
i = this.layout._getOption("originTop"),
n = t[e ? "left" : "right"],
o = t[i ? "top" : "bottom"],
r = parseFloat(n),
s = parseFloat(o),
a = this.layout.size;
-1 != n.indexOf("%") && (r = r / 100 * a.width),
-1 != o.indexOf("%") && (s = s / 100 * a.height),
r = isNaN(r) ? 0 : r,
s = isNaN(s) ? 0 : s,
r -= e ? a.paddingLeft : a.paddingRight,
s -= i ? a.paddingTop : a.paddingBottom,
this.position.x = r,
this.position.y = s
},
d.layoutPosition = function() {
var t = this.layout.size,
e = {},
i = this.layout._getOption("originLeft"),
n = this.layout._getOption("originTop"),
o = i ? "paddingLeft" : "paddingRight",
r = i ? "left" : "right",
s = i ? "right" : "left",
a = this.position.x + t[o];
e[r] = this.getXValue(a),
e[s] = "";
var h = n ? "paddingTop" : "paddingBottom",
u = n ? "top" : "bottom",
d = n ? "bottom" : "top",
l = this.position.y + t[h];
e[u] = this.getYValue(l),
e[d] = "",
this.css(e),
this.emitEvent("layout", [this])
},
d.getXValue = function(t) {
var e = this.layout._getOption("horizontal");
return this.layout.options.percentPosition && !e ? t / this.layout.size.width * 100 + "%" : t + "px"
},
d.getYValue = function(t) {
var e = this.layout._getOption("horizontal");
return this.layout.options.percentPosition && e ? t / this.layout.size.height * 100 + "%" : t + "px"
},
d._transitionTo = function(t, e) {
this.getPosition();
var i = this.position.x,
n = this.position.y,
o = t == this.position.x && e == this.position.y;
if (this.setPosition(t, e), o && !this.isTransitioning)
return void this.layoutPosition();
var r = t - i,
s = e - n,
a = {};
a.transform = this.getTranslate(r, s),
this.transition({
to: a,
onTransitionEnd: {
transform: this.layoutPosition
},
isCleaning: !0
})
},
d.getTranslate = function(t, e) {
var i = this.layout._getOption("originLeft"),
n = this.layout._getOption("originTop");
return t = i ? t : -t, e = n ? e : -e, "translate3d(" + t + "px, " + e + "px, 0)"
},
d.goTo = function(t, e) {
this.setPosition(t, e),
this.layoutPosition()
},
d.moveTo = d._transitionTo,
d.setPosition = function(t, e) {
this.position.x = parseFloat(t),
this.position.y = parseFloat(e)
},
d._nonTransition = function(t) {
this.css(t.to),
t.isCleaning && this._removeStyles(t.to);
for (var e in t.onTransitionEnd)
t.onTransitionEnd[e].call(this)
},
d.transition = function(t) {
if (!parseFloat(this.layout.options.transitionDuration))
return void this._nonTransition(t);
var e = this._transn;
for (var i in t.onTransitionEnd)
e.onEnd[i] = t.onTransitionEnd[i];
for (i in t.to)
e.ingProperties[i] = !0,
t.isCleaning && (e.clean[i] = !0);
if (t.from) {
this.css(t.from);
var n = this.element.offsetHeight;
n = null
}
this.enableTransition(t.to),
this.css(t.to),
this.isTransitioning = !0
};
var l = "opacity," + o(a);
d.enableTransition = function() {
if (!this.isTransitioning) {
var t = this.layout.options.transitionDuration;
t = "number" == typeof t ? t + "ms" : t,
this.css({
transitionProperty: l,
transitionDuration: t,
transitionDelay: this.staggerDelay || 0
}),
this.element.addEventListener(h, this, !1)
}
},
d.onwebkitTransitionEnd = function(t) {
this.ontransitionend(t)
},
d.onotransitionend = function(t) {
this.ontransitionend(t)
};
var c = {
"-webkit-transform": "transform"
};
d.ontransitionend = function(t) {
if (t.target === this.element) {
var e = this._transn,
n = c[t.propertyName] || t.propertyName;
if (delete e.ingProperties[n], i(e.ingProperties) && this.disableTransition(), n in e.clean && (this.element.style[t.propertyName] = "", delete e.clean[n]), n in e.onEnd) {
var o = e.onEnd[n];
o.call(this),
delete e.onEnd[n]
}
this.emitEvent("transitionEnd", [this])
}
},
d.disableTransition = function() {
this.removeTransitionStyles(),
this.element.removeEventListener(h, this, !1),
this.isTransitioning = !1
},
d._removeStyles = function(t) {
var e = {};
for (var i in t)
e[i] = "";
this.css(e)
};
var f = {
transitionProperty: "",
transitionDuration: "",
transitionDelay: ""
};
return d.removeTransitionStyles = function() {
this.css(f)
}, d.stagger = function(t) {
t = isNaN(t) ? 0 : t,
this.staggerDelay = t + "ms"
}, d.removeElem = function() {
this.element.parentNode.removeChild(this.element),
this.css({
display: ""
}),
this.emitEvent("remove", [this])
}, d.remove = function() {
return s && parseFloat(this.layout.options.transitionDuration) ? (this.once("transitionEnd", function() {
this.removeElem()
}), void this.hide()) : void this.removeElem()
}, d.reveal = function() {
delete this.isHidden,
this.css({
display: ""
});
var t = this.layout.options,
e = {},
i = this.getHideRevealTransitionEndProperty("visibleStyle");
e[i] = this.onRevealTransitionEnd,
this.transition({
from: t.hiddenStyle,
to: t.visibleStyle,
isCleaning: !0,
onTransitionEnd: e
})
}, d.onRevealTransitionEnd = function() {
this.isHidden || this.emitEvent("reveal")
}, d.getHideRevealTransitionEndProperty = function(t) {
var e = this.layout.options[t];
if (e.opacity)
return "opacity";
for (var i in e)
return i
}, d.hide = function() {
this.isHidden = !0,
this.css({
display: ""
});
var t = this.layout.options,
e = {},
i = this.getHideRevealTransitionEndProperty("hiddenStyle");
e[i] = this.onHideTransitionEnd,
this.transition({
from: t.visibleStyle,
to: t.hiddenStyle,
isCleaning: !0,
onTransitionEnd: e
})
}, d.onHideTransitionEnd = function() {
this.isHidden && (this.css({
display: "none"
}), this.emitEvent("hide"))
}, d.destroy = function() {
this.css({
position: "",
left: "",
right: "",
top: "",
bottom: "",
transition: "",
transform: ""
})
}, n
}),
function(t, e) {
"use strict";
"function" == typeof define && define.amd ? define("outlayer/outlayer", ["ev-emitter/ev-emitter", "get-size/get-size", "fizzy-ui-utils/utils", "./item"], function(i, n, o, r) {
return e(t, i, n, o, r)
}) : "object" == typeof module && module.exports ? module.exports = e(t, require("ev-emitter"), require("get-size"), require("fizzy-ui-utils"), require("./item")) : t.Outlayer = e(t, t.EvEmitter, t.getSize, t.fizzyUIUtils, t.Outlayer.Item)
}(window, function(t, e, i, n, o) {
"use strict";
function r(t, e) {
var i = n.getQueryElement(t);
if (!i)
return void (h && h.error("Bad element for " + this.constructor.namespace + ": " + (i || t)));
this.element = i,
u && (this.$element = u(this.element)),
this.options = n.extend({}, this.constructor.defaults),
this.option(e);
var o = ++l;
this.element.outlayerGUID = o,
c[o] = this,
this._create();
var r = this._getOption("initLayout");
r && this.layout()
}
function s(t) {
function e() {
t.apply(this, arguments)
}
return e.prototype = Object.create(t.prototype), e.prototype.constructor = e, e
}
function a(t) {
if ("number" == typeof t)
return t;
var e = t.match(/(^\d*\.?\d*)(\w*)/),
i = e && e[1],
n = e && e[2];
if (!i.length)
return 0;
i = parseFloat(i);
var o = m[n] || 1;
return i * o
}
var h = t.console,
u = t.jQuery,
d = function() {},
l = 0,
c = {};
r.namespace = "outlayer",
r.Item = o,
r.defaults = {
containerStyle: {
position: "relative"
},
initLayout: !0,
originLeft: !0,
originTop: !0,
resize: !0,
resizeContainer: !0,
transitionDuration: "0.4s",
hiddenStyle: {
opacity: 0,
transform: "scale(0.001)"
},
visibleStyle: {
opacity: 1,
transform: "scale(1)"
}
};
var f = r.prototype;
n.extend(f, e.prototype),
f.option = function(t) {
n.extend(this.options, t)
},
f._getOption = function(t) {
var e = this.constructor.compatOptions[t];
return e && void 0 !== this.options[e] ? this.options[e] : this.options[t]
},
r.compatOptions = {
initLayout: "isInitLayout",
horizontal: "isHorizontal",
layoutInstant: "isLayoutInstant",
originLeft: "isOriginLeft",
originTop: "isOriginTop",
resize: "isResizeBound",
resizeContainer: "isResizingContainer"
},
f._create = function() {
this.reloadItems(),
this.stamps = [],
this.stamp(this.options.stamp),
n.extend(this.element.style, this.options.containerStyle);
var t = this._getOption("resize");
t && this.bindResize()
},
f.reloadItems = function() {
this.items = this._itemize(this.element.children)
},
f._itemize = function(t) {
for (var e = this._filterFindItemElements(t), i = this.constructor.Item, n = [], o = 0; o < e.length; o++) {
var r = e[o],
s = new i(r, this);
n.push(s)
}
return n
},
f._filterFindItemElements = function(t) {
return n.filterFindElements(t, this.options.itemSelector)
},
f.getItemElements = function() {
return this.items.map(function(t) {
return t.element
})
},
f.layout = function() {
this._resetLayout(),
this._manageStamps();
var t = this._getOption("layoutInstant"),
e = void 0 !== t ? t : !this._isLayoutInited;
this.layoutItems(this.items, e),
this._isLayoutInited = !0
},
f._init = f.layout,
f._resetLayout = function() {
this.getSize()
},
f.getSize = function() {
this.size = i(this.element)
},
f._getMeasurement = function(t, e) {
var n,
o = this.options[t];
o ? ("string" == typeof o ? n = this.element.querySelector(o) : o instanceof HTMLElement && (n = o), this[t] = n ? i(n)[e] : o) : this[t] = 0
},
f.layoutItems = function(t, e) {
t = this._getItemsForLayout(t),
this._layoutItems(t, e),
this._postLayout()
},
f._getItemsForLayout = function(t) {
return t.filter(function(t) {
return !t.isIgnored
})
},
f._layoutItems = function(t, e) {
if (this._emitCompleteOnItems("layout", t), t && t.length) {
var i = [];
t.forEach(function(t) {
var n = this._getItemLayoutPosition(t);
n.item = t,
n.isInstant = e || t.isLayoutInstant,
i.push(n)
}, this),
this._processLayoutQueue(i)
}
},
f._getItemLayoutPosition = function() {
return {
x: 0,
y: 0
}
},
f._processLayoutQueue = function(t) {
this.updateStagger(),
t.forEach(function(t, e) {
this._positionItem(t.item, t.x, t.y, t.isInstant, e)
}, this)
},
f.updateStagger = function() {
var t = this.options.stagger;
return null === t || void 0 === t ? void (this.stagger = 0) : (this.stagger = a(t), this.stagger)
},
f._positionItem = function(t, e, i, n, o) {
n ? t.goTo(e, i) : (t.stagger(o * this.stagger), t.moveTo(e, i))
},
f._postLayout = function() {
this.resizeContainer()
},
f.resizeContainer = function() {
var t = this._getOption("resizeContainer");
if (t) {
var e = this._getContainerSize();
e && (this._setContainerMeasure(e.width, !0), this._setContainerMeasure(e.height, !1))
}
},
f._getContainerSize = d,
f._setContainerMeasure = function(t, e) {
if (void 0 !== t) {
var i = this.size;
i.isBorderBox && (t += e ? i.paddingLeft + i.paddingRight + i.borderLeftWidth + i.borderRightWidth : i.paddingBottom + i.paddingTop + i.borderTopWidth + i.borderBottomWidth),
t = Math.max(t, 0),
this.element.style[e ? "width" : "height"] = t + "px"
}
},
f._emitCompleteOnItems = function(t, e) {
function i() {
o.dispatchEvent(t + "Complete", null, [e])
}
function n() {
s++,
s == r && i()
}
var o = this,
r = e.length;
if (!e || !r)
return void i();
var s = 0;
e.forEach(function(e) {
e.once(t, n)
})
},
f.dispatchEvent = function(t, e, i) {
var n = e ? [e].concat(i) : i;
if (this.emitEvent(t, n), u)
if (this.$element = this.$element || u(this.element), e) {
var o = u.Event(e);
o.type = t,
this.$element.trigger(o, i)
} else
this.$element.trigger(t, i)
},
f.ignore = function(t) {
var e = this.getItem(t);
e && (e.isIgnored = !0)
},
f.unignore = function(t) {
var e = this.getItem(t);
e && delete e.isIgnored
},
f.stamp = function(t) {
t = this._find(t),
t && (this.stamps = this.stamps.concat(t), t.forEach(this.ignore, this))
},
f.unstamp = function(t) {
t = this._find(t),
t && t.forEach(function(t) {
n.removeFrom(this.stamps, t),
this.unignore(t)
}, this)
},
f._find = function(t) {
return t ? ("string" == typeof t && (t = this.element.querySelectorAll(t)), t = n.makeArray(t)) : void 0
},
f._manageStamps = function() {
this.stamps && this.stamps.length && (this._getBoundingRect(), this.stamps.forEach(this._manageStamp, this))
},
f._getBoundingRect = function() {
var t = this.element.getBoundingClientRect(),
e = this.size;
this._boundingRect = {
left: t.left + e.paddingLeft + e.borderLeftWidth,
top: t.top + e.paddingTop + e.borderTopWidth,
right: t.right - (e.paddingRight + e.borderRightWidth),
bottom: t.bottom - (e.paddingBottom + e.borderBottomWidth)
}
},
f._manageStamp = d,
f._getElementOffset = function(t) {
var e = t.getBoundingClientRect(),
n = this._boundingRect,
o = i(t),
r = {
left: e.left - n.left - o.marginLeft,
top: e.top - n.top - o.marginTop,
right: n.right - e.right - o.marginRight,
bottom: n.bottom - e.bottom - o.marginBottom
};
return r
},
f.handleEvent = n.handleEvent,
f.bindResize = function() {
t.addEventListener("resize", this),
this.isResizeBound = !0
},
f.unbindResize = function() {
t.removeEventListener("resize", this),
this.isResizeBound = !1
},
f.onresize = function() {
this.resize()
},
n.debounceMethod(r, "onresize", 100),
f.resize = function() {
this.isResizeBound && this.needsResizeLayout() && this.layout()
},
f.needsResizeLayout = function() {
var t = i(this.element),
e = this.size && t;
return e && t.innerWidth !== this.size.innerWidth
},
f.addItems = function(t) {
var e = this._itemize(t);
return e.length && (this.items = this.items.concat(e)), e
},
f.appended = function(t) {
var e = this.addItems(t);
e.length && (this.layoutItems(e, !0), this.reveal(e))
},
f.prepended = function(t) {
var e = this._itemize(t);
if (e.length) {
var i = this.items.slice(0);
this.items = e.concat(i),
this._resetLayout(),
this._manageStamps(),
this.layoutItems(e, !0),
this.reveal(e),
this.layoutItems(i)
}
},
f.reveal = function(t) {
if (this._emitCompleteOnItems("reveal", t), t && t.length) {
var e = this.updateStagger();
t.forEach(function(t, i) {
t.stagger(i * e),
t.reveal()
})
}
},
f.hide = function(t) {
if (this._emitCompleteOnItems("hide", t), t && t.length) {
var e = this.updateStagger();
t.forEach(function(t, i) {
t.stagger(i * e),
t.hide()
})
}
},
f.revealItemElements = function(t) {
var e = this.getItems(t);
this.reveal(e)
},
f.hideItemElements = function(t) {
var e = this.getItems(t);
this.hide(e)
},
f.getItem = function(t) {
for (var e = 0; e < this.items.length; e++) {
var i = this.items[e];
if (i.element == t)
return i
}
},
f.getItems = function(t) {
t = n.makeArray(t);
var e = [];
return t.forEach(function(t) {
var i = this.getItem(t);
i && e.push(i)
}, this), e
},
f.remove = function(t) {
var e = this.getItems(t);
this._emitCompleteOnItems("remove", e),
e && e.length && e.forEach(function(t) {
t.remove(),
n.removeFrom(this.items, t)
}, this)
},
f.destroy = function() {
var t = this.element.style;
t.height = "",
t.position = "",
t.width = "",
this.items.forEach(function(t) {
t.destroy()
}),
this.unbindResize();
var e = this.element.outlayerGUID;
delete c[e],
delete this.element.outlayerGUID,
u && u.removeData(this.element, this.constructor.namespace)
},
r.data = function(t) {
t = n.getQueryElement(t);
var e = t && t.outlayerGUID;
return e && c[e]
},
r.create = function(t, e) {
var i = s(r);
return i.defaults = n.extend({}, r.defaults), n.extend(i.defaults, e), i.compatOptions = n.extend({}, r.compatOptions), i.namespace = t, i.data = r.data, i.Item = s(o), n.htmlInit(i, t), u && u.bridget && u.bridget(t, i), i
};
var m = {
ms: 1,
s: 1e3
};
return r.Item = o, r
}),
function(t, e) {
"function" == typeof define && define.amd ? define(["outlayer/outlayer", "get-size/get-size"], e) : "object" == typeof module && module.exports ? module.exports = e(require("outlayer"), require("get-size")) : t.Masonry = e(t.Outlayer, t.getSize)
}(window, function(t, e) {
var i = t.create("masonry");
i.compatOptions.fitWidth = "isFitWidth";
var n = i.prototype;
return n._resetLayout = function() {
this.getSize(),
this._getMeasurement("columnWidth", "outerWidth"),
this._getMeasurement("gutter", "outerWidth"),
this.measureColumns(),
this.colYs = [];
for (var t = 0; t < this.cols; t++)
this.colYs.push(0);
this.maxY = 0,
this.horizontalColIndex = 0
}, n.measureColumns = function() {
if (this.getContainerWidth(), !this.columnWidth) {
var t = this.items[0],
i = t && t.element;
this.columnWidth = i && e(i).outerWidth || this.containerWidth
}
var n = this.columnWidth += this.gutter,
o = this.containerWidth + this.gutter,
r = o / n,
s = n - o % n,
a = s && 1 > s ? "round" : "floor";
r = Math[a](r),
this.cols = Math.max(r, 1)
}, n.getContainerWidth = function() {
var t = this._getOption("fitWidth"),
i = t ? this.element.parentNode : this.element,
n = e(i);
this.containerWidth = n && n.innerWidth
}, n._getItemLayoutPosition = function(t) {
t.getSize();
var e = t.size.outerWidth % this.columnWidth,
i = e && 1 > e ? "round" : "ceil",
n = Math[i](t.size.outerWidth / this.columnWidth);
n = Math.min(n, this.cols);
for (var o = this.options.horizontalOrder ? "_getHorizontalColPosition" : "_getTopColPosition", r = this[o](n, t), s = {
x: this.columnWidth * r.col,
y: r.y
}, a = r.y + t.size.outerHeight, h = n + r.col, u = r.col; h > u; u++)
this.colYs[u] = a;
return s
}, n._getTopColPosition = function(t) {
var e = this._getTopColGroup(t),
i = Math.min.apply(Math, e);
return {
col: e.indexOf(i),
y: i
}
}, n._getTopColGroup = function(t) {
if (2 > t)
return this.colYs;
for (var e = [], i = this.cols + 1 - t, n = 0; i > n; n++)
e[n] = this._getColGroupY(n, t);
return e
}, n._getColGroupY = function(t, e) {
if (2 > e)
return this.colYs[t];
var i = this.colYs.slice(t, t + e);
return Math.max.apply(Math, i)
}, n._getHorizontalColPosition = function(t, e) {
var i = this.horizontalColIndex % this.cols,
n = t > 1 && i + t > this.cols;
i = n ? 0 : i;
var o = e.size.outerWidth && e.size.outerHeight;
return this.horizontalColIndex = o ? i + t : this.horizontalColIndex, {
col: i,
y: this._getColGroupY(i, t)
}
}, n._manageStamp = function(t) {
var i = e(t),
n = this._getElementOffset(t),
o = this._getOption("originLeft"),
r = o ? n.left : n.right,
s = r + i.outerWidth,
a = Math.floor(r / this.columnWidth);
a = Math.max(0, a);
var h = Math.floor(s / this.columnWidth);
h -= s % this.columnWidth ? 0 : 1,
h = Math.min(this.cols - 1, h);
for (var u = this._getOption("originTop"), d = (u ? n.top : n.bottom) + i.outerHeight, l = a; h >= l; l++)
this.colYs[l] = Math.max(d, this.colYs[l])
}, n._getContainerSize = function() {
this.maxY = Math.max.apply(Math, this.colYs);
var t = {
height: this.maxY
};
return this._getOption("fitWidth") && (t.width = this._getContainerFitWidth()), t
}, n._getContainerFitWidth = function() {
for (var t = 0, e = this.cols; --e && 0 === this.colYs[e];)
t++;
return (this.cols - t) * this.columnWidth - this.gutter
}, n.needsResizeLayout = function() {
var t = this.containerWidth;
return this.getContainerWidth(), t != this.containerWidth
}, i
});