Files
paperclip-wallet/assets/scripts/materialize.min.js

5717 lines
254 KiB
JavaScript
Executable File
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/*!
* Materialize v1.0.0 (http://materializecss.com)
* Copyright 2014-2017 Materialize
* MIT License (https://raw.githubusercontent.com/Dogfalo/materialize/master/LICENSE)
*/
var _get = function t(e, i, n) {
null === e && (e = Function.prototype);
var s = Object.getOwnPropertyDescriptor(e, i);
if (void 0 === s) {
var o = Object.getPrototypeOf(e);
return null === o ? void 0 : t(o, i, n)
}
if ("value" in s) return s.value;
var a = s.get;
return void 0 !== a ? a.call(n) : void 0
},
_createClass = function() {
function n(t, e) {
for (var i = 0; i < e.length; i++) {
var n = e[i];
n.enumerable = n.enumerable || !1, n.configurable = !0, "value" in n && (n.writable = !0), Object.defineProperty(t, n.key, n)
}
}
return function(t, e, i) {
return e && n(t.prototype, e), i && n(t, i), t
}
}();
function _possibleConstructorReturn(t, e) {
if (!t) throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
return !e || "object" != typeof e && "function" != typeof e ? t : e
}
function _inherits(t, e) {
if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e);
t.prototype = Object.create(e && e.prototype, {
constructor: {
value: t,
enumerable: !1,
writable: !0,
configurable: !0
}
}), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e)
}
function _classCallCheck(t, e) {
if (!(t instanceof e)) throw new TypeError("Cannot call a class as a function")
}
window.cash = function() {
var i, o = document,
a = window,
t = Array.prototype,
r = t.slice,
n = t.filter,
s = t.push,
e = function() {},
h = function(t) {
return typeof t == typeof e && t.call
},
d = function(t) {
return "string" == typeof t
},
l = /^#[\w-]*$/,
u = /^\.[\w-]*$/,
c = /<.+>/,
p = /^\w+$/;
function v(t, e) {
e = e || o;
var i = u.test(t) ? e.getElementsByClassName(t.slice(1)) : p.test(t) ? e.getElementsByTagName(t) : e.querySelectorAll(t);
return i
}
function f(t) {
if (!i) {
var e = (i = o.implementation.createHTMLDocument(null)).createElement("base");
e.href = o.location.href, i.head.appendChild(e)
}
return i.body.innerHTML = t, i.body.childNodes
}
function m(t) {
"loading" !== o.readyState ? t() : o.addEventListener("DOMContentLoaded", t)
}
function g(t, e) {
if (!t) return this;
if (t.cash && t !== a) return t;
var i, n = t,
s = 0;
if (d(t)) n = l.test(t) ? o.getElementById(t.slice(1)) : c.test(t) ? f(t) : v(t, e);
else if (h(t)) return m(t), this;
if (!n) return this;
if (n.nodeType || n === a) this[0] = n, this.length = 1;
else
for (i = this.length = n.length; s < i; s++) this[s] = n[s];
return this
}
function _(t, e) {
return new g(t, e)
}
var y = _.fn = _.prototype = g.prototype = {
cash: !0,
length: 0,
push: s,
splice: t.splice,
map: t.map,
init: g
};
function k(t, e) {
for (var i = t.length, n = 0; n < i && !1 !== e.call(t[n], t[n], n, t); n++);
}
function b(t, e) {
var i = t && (t.matches || t.webkitMatchesSelector || t.mozMatchesSelector || t.msMatchesSelector || t.oMatchesSelector);
return !!i && i.call(t, e)
}
function w(e) {
return d(e) ? b : e.cash ? function(t) {
return e.is(t)
} : function(t, e) {
return t === e
}
}
function C(t) {
return _(r.call(t).filter(function(t, e, i) {
return i.indexOf(t) === e
}))
}
Object.defineProperty(y, "constructor", {
value: _
}), _.parseHTML = f, _.noop = e, _.isFunction = h, _.isString = d, _.extend = y.extend = function(t) {
t = t || {};
var e = r.call(arguments),
i = e.length,
n = 1;
for (1 === e.length && (t = this, n = 0); n < i; n++)
if (e[n])
for (var s in e[n]) e[n].hasOwnProperty(s) && (t[s] = e[n][s]);
return t
}, _.extend({
merge: function(t, e) {
for (var i = +e.length, n = t.length, s = 0; s < i; n++, s++) t[n] = e[s];
return t.length = n, t
},
each: k,
matches: b,
unique: C,
isArray: Array.isArray,
isNumeric: function(t) {
return !isNaN(parseFloat(t)) && isFinite(t)
}
});
var E = _.uid = "_cash" + Date.now();
function M(t) {
return t[E] = t[E] || {}
}
function O(t, e, i) {
return M(t)[e] = i
}
function x(t, e) {
var i = M(t);
return void 0 === i[e] && (i[e] = t.dataset ? t.dataset[e] : _(t).attr("data-" + e)), i[e]
}
y.extend({
data: function(e, i) {
if (d(e)) return void 0 === i ? x(this[0], e) : this.each(function(t) {
return O(t, e, i)
});
for (var t in e) this.data(t, e[t]);
return this
},
removeData: function(s) {
return this.each(function(t) {
return i = s, void((n = M(e = t)) ? delete n[i] : e.dataset ? delete e.dataset[i] : _(e).removeAttr("data-" + name));
var e, i, n
})
}
});
var L = /\S+/g;
function T(t) {
return d(t) && t.match(L)
}
function $(t, e) {
return t.classList ? t.classList.contains(e) : new RegExp("(^| )" + e + "( |$)", "gi").test(t.className)
}
function B(t, e, i) {
t.classList ? t.classList.add(e) : i.indexOf(" " + e + " ") && (t.className += " " + e)
}
function D(t, e) {
t.classList ? t.classList.remove(e) : t.className = t.className.replace(e, "")
}
y.extend({
addClass: function(t) {
var n = T(t);
return n ? this.each(function(e) {
var i = " " + e.className + " ";
k(n, function(t) {
B(e, t, i)
})
}) : this
},
attr: function(e, i) {
if (e) {
if (d(e)) return void 0 === i ? this[0] ? this[0].getAttribute ? this[0].getAttribute(e) : this[0][e] : void 0 : this.each(function(t) {
t.setAttribute ? t.setAttribute(e, i) : t[e] = i
});
for (var t in e) this.attr(t, e[t]);
return this
}
},
hasClass: function(t) {
var e = !1,
i = T(t);
return i && i.length && this.each(function(t) {
return !(e = $(t, i[0]))
}), e
},
prop: function(e, i) {
if (d(e)) return void 0 === i ? this[0][e] : this.each(function(t) {
t[e] = i
});
for (var t in e) this.prop(t, e[t]);
return this
},
removeAttr: function(e) {
return this.each(function(t) {
t.removeAttribute ? t.removeAttribute(e) : delete t[e]
})
},
removeClass: function(t) {
if (!arguments.length) return this.attr("class", "");
var i = T(t);
return i ? this.each(function(e) {
k(i, function(t) {
D(e, t)
})
}) : this
},
removeProp: function(e) {
return this.each(function(t) {
delete t[e]
})
},
toggleClass: function(t, e) {
if (void 0 !== e) return this[e ? "addClass" : "removeClass"](t);
var n = T(t);
return n ? this.each(function(e) {
var i = " " + e.className + " ";
k(n, function(t) {
$(e, t) ? D(e, t) : B(e, t, i)
})
}) : this
}
}), y.extend({
add: function(t, e) {
return C(_.merge(this, _(t, e)))
},
each: function(t) {
return k(this, t), this
},
eq: function(t) {
return _(this.get(t))
},
filter: function(e) {
if (!e) return this;
var i = h(e) ? e : w(e);
return _(n.call(this, function(t) {
return i(t, e)
}))
},
first: function() {
return this.eq(0)
},
get: function(t) {
return void 0 === t ? r.call(this) : t < 0 ? this[t + this.length] : this[t]
},
index: function(t) {
var e = t ? _(t)[0] : this[0],
i = t ? this : _(e).parent().children();
return r.call(i).indexOf(e)
},
last: function() {
return this.eq(-1)
}
});
var S, I, A, R, H, P, W = (H = /(?:^\w|[A-Z]|\b\w)/g, P = /[\s-_]+/g, function(t) {
return t.replace(H, function(t, e) {
return t[0 === e ? "toLowerCase" : "toUpperCase"]()
}).replace(P, "")
}),
j = (S = {}, I = document, A = I.createElement("div"), R = A.style, function(e) {
if (e = W(e), S[e]) return S[e];
var t = e.charAt(0).toUpperCase() + e.slice(1),
i = (e + " " + ["webkit", "moz", "ms", "o"].join(t + " ") + t).split(" ");
return k(i, function(t) {
if (t in R) return S[t] = e = S[e] = t, !1
}), S[e]
});
function F(t, e) {
return parseInt(a.getComputedStyle(t[0], null)[e], 10) || 0
}
function q(e, i, t) {
var n, s = x(e, "_cashEvents"),
o = s && s[i];
o && (t ? (e.removeEventListener(i, t), 0 <= (n = o.indexOf(t)) && o.splice(n, 1)) : (k(o, function(t) {
e.removeEventListener(i, t)
}), o = []))
}
function N(t, e) {
return "&" + encodeURIComponent(t) + "=" + encodeURIComponent(e).replace(/%20/g, "+")
}
function z(t) {
var e, i, n, s = t.type;
if (!s) return null;
switch (s.toLowerCase()) {
case "select-one":
return 0 <= (n = (i = t).selectedIndex) ? i.options[n].value : null;
case "select-multiple":
return e = [], k(t.options, function(t) {
t.selected && e.push(t.value)
}), e.length ? e : null;
case "radio":
case "checkbox":
return t.checked ? t.value : null;
default:
return t.value ? t.value : null
}
}
function V(e, i, n) {
var t = d(i);
t || !i.length ? k(e, t ? function(t) {
return t.insertAdjacentHTML(n ? "afterbegin" : "beforeend", i)
} : function(t, e) {
return function(t, e, i) {
if (i) {
var n = t.childNodes[0];
t.insertBefore(e, n)
} else t.appendChild(e)
}(t, 0 === e ? i : i.cloneNode(!0), n)
}) : k(i, function(t) {
return V(e, t, n)
})
}
_.prefixedProp = j, _.camelCase = W, y.extend({
css: function(e, i) {
if (d(e)) return e = j(e), 1 < arguments.length ? this.each(function(t) {
return t.style[e] = i
}) : a.getComputedStyle(this[0])[e];
for (var t in e) this.css(t, e[t]);
return this
}
}), k(["Width", "Height"], function(e) {
var t = e.toLowerCase();
y[t] = function() {
return this[0].getBoundingClientRect()[t]
}, y["inner" + e] = function() {
return this[0]["client" + e]
}, y["outer" + e] = function(t) {
return this[0]["offset" + e] + (t ? F(this, "margin" + ("Width" === e ? "Left" : "Top")) + F(this, "margin" + ("Width" === e ? "Right" : "Bottom")) : 0)
}
}), y.extend({
off: function(e, i) {
return this.each(function(t) {
return q(t, e, i)
})
},
on: function(a, i, r, l) {
var n;
if (!d(a)) {
for (var t in a) this.on(t, i, a[t]);
return this
}
return h(i) && (r = i, i = null), "ready" === a ? (m(r), this) : (i && (n = r, r = function(t) {
for (var e = t.target; !b(e, i);) {
if (e === this || null === e) return e = !1;
e = e.parentNode
}
e && n.call(e, t)
}), this.each(function(t) {
var e, i, n, s, o = r;
l && (o = function() {
r.apply(this, arguments), q(t, a, o)
}), i = a, n = o, (s = x(e = t, "_cashEvents") || O(e, "_cashEvents", {}))[i] = s[i] || [], s[i].push(n), e.addEventListener(i, n)
}))
},
one: function(t, e, i) {
return this.on(t, e, i, !0)
},
ready: m,
trigger: function(t, e) {
if (document.createEvent) {
var i = document.createEvent("HTMLEvents");
return i.initEvent(t, !0, !1), i = this.extend(i, e), this.each(function(t) {
return t.dispatchEvent(i)
})
}
}
}), y.extend({
serialize: function() {
var s = "";
return k(this[0].elements || this, function(t) {
if (!t.disabled && "FIELDSET" !== t.tagName) {
var e = t.name;
switch (t.type.toLowerCase()) {
case "file":
case "reset":
case "submit":
case "button":
break;
case "select-multiple":
var i = z(t);
null !== i && k(i, function(t) {
s += N(e, t)
});
break;
default:
var n = z(t);
null !== n && (s += N(e, n))
}
}
}), s.substr(1)
},
val: function(e) {
return void 0 === e ? z(this[0]) : this.each(function(t) {
return t.value = e
})
}
}), y.extend({
after: function(t) {
return _(t).insertAfter(this), this
},
append: function(t) {
return V(this, t), this
},
appendTo: function(t) {
return V(_(t), this), this
},
before: function(t) {
return _(t).insertBefore(this), this
},
clone: function() {
return _(this.map(function(t) {
return t.cloneNode(!0)
}))
},
empty: function() {
return this.html(""), this
},
html: function(t) {
if (void 0 === t) return this[0].innerHTML;
var e = t.nodeType ? t[0].outerHTML : t;
return this.each(function(t) {
return t.innerHTML = e
})
},
insertAfter: function(t) {
var s = this;
return _(t).each(function(t, e) {
var i = t.parentNode,
n = t.nextSibling;
s.each(function(t) {
i.insertBefore(0 === e ? t : t.cloneNode(!0), n)
})
}), this
},
insertBefore: function(t) {
var s = this;
return _(t).each(function(e, i) {
var n = e.parentNode;
s.each(function(t) {
n.insertBefore(0 === i ? t : t.cloneNode(!0), e)
})
}), this
},
prepend: function(t) {
return V(this, t, !0), this
},
prependTo: function(t) {
return V(_(t), this, !0), this
},
remove: function() {
return this.each(function(t) {
if (t.parentNode) return t.parentNode.removeChild(t)
})
},
text: function(e) {
return void 0 === e ? this[0].textContent : this.each(function(t) {
return t.textContent = e
})
}
});
var X = o.documentElement;
return y.extend({
position: function() {
var t = this[0];
return {
left: t.offsetLeft,
top: t.offsetTop
}
},
offset: function() {
var t = this[0].getBoundingClientRect();
return {
top: t.top + a.pageYOffset - X.clientTop,
left: t.left + a.pageXOffset - X.clientLeft
}
},
offsetParent: function() {
return _(this[0].offsetParent)
}
}), y.extend({
children: function(e) {
var i = [];
return this.each(function(t) {
s.apply(i, t.children)
}), i = C(i), e ? i.filter(function(t) {
return b(t, e)
}) : i
},
closest: function(t) {
return !t || this.length < 1 ? _() : this.is(t) ? this.filter(t) : this.parent().closest(t)
},
is: function(e) {
if (!e) return !1;
var i = !1,
n = w(e);
return this.each(function(t) {
return !(i = n(t, e))
}), i
},
find: function(e) {
if (!e || e.nodeType) return _(e && this.has(e).length ? e : null);
var i = [];
return this.each(function(t) {
s.apply(i, v(e, t))
}), C(i)
},
has: function(e) {
var t = d(e) ? function(t) {
return 0 !== v(e, t).length
} : function(t) {
return t.contains(e)
};
return this.filter(t)
},
next: function() {
return _(this[0].nextElementSibling)
},
not: function(e) {
if (!e) return this;
var i = w(e);
return this.filter(function(t) {
return !i(t, e)
})
},
parent: function() {
var e = [];
return this.each(function(t) {
t && t.parentNode && e.push(t.parentNode)
}), C(e)
},
parents: function(e) {
var i, n = [];
return this.each(function(t) {
for (i = t; i && i.parentNode && i !== o.body.parentNode;) i = i.parentNode, (!e || e && b(i, e)) && n.push(i)
}), C(n)
},
prev: function() {
return _(this[0].previousElementSibling)
},
siblings: function(t) {
var e = this.parent().children(t),
i = this[0];
return e.filter(function(t) {
return t !== i
})
}
}), _
}();
var Component = function() {
function s(t, e, i) {
_classCallCheck(this, s), e instanceof Element || console.error(Error(e + " is not an HTML Element"));
var n = t.getInstance(e);
n && n.destroy(), this.el = e, this.$el = cash(e)
}
return _createClass(s, null, [{
key: "init",
value: function(t, e, i) {
var n = null;
if (e instanceof Element) n = new t(e, i);
else if (e && (e.jquery || e.cash || e instanceof NodeList)) {
for (var s = [], o = 0; o < e.length; o++) s.push(new t(e[o], i));
n = s
}
return n
}
}]), s
}();
! function(t) {
t.Package ? M = {} : t.M = {}, M.jQueryLoaded = !!t.jQuery
}(window), "function" == typeof define && define.amd ? define("M", [], function() {
return M
}) : "undefined" == typeof exports || exports.nodeType || ("undefined" != typeof module && !module.nodeType && module.exports && (exports = module.exports = M), exports.default = M), M.version = "1.0.0", M.keys = {
TAB: 9,
ENTER: 13,
ESC: 27,
ARROW_UP: 38,
ARROW_DOWN: 40
}, M.tabPressed = !1, M.keyDown = !1;
var docHandleKeydown = function(t) {
M.keyDown = !0, t.which !== M.keys.TAB && t.which !== M.keys.ARROW_DOWN && t.which !== M.keys.ARROW_UP || (M.tabPressed = !0)
},
docHandleKeyup = function(t) {
M.keyDown = !1, t.which !== M.keys.TAB && t.which !== M.keys.ARROW_DOWN && t.which !== M.keys.ARROW_UP || (M.tabPressed = !1)
},
docHandleFocus = function(t) {
M.keyDown && document.body.classList.add("keyboard-focused")
},
docHandleBlur = function(t) {
document.body.classList.remove("keyboard-focused")
};
document.addEventListener("keydown", docHandleKeydown, !0), document.addEventListener("keyup", docHandleKeyup, !0), document.addEventListener("focus", docHandleFocus, !0), document.addEventListener("blur", docHandleBlur, !0), M.initializeJqueryWrapper = function(n, s, o) {
jQuery.fn[s] = function(e) {
if (n.prototype[e]) {
var i = Array.prototype.slice.call(arguments, 1);
if ("get" === e.slice(0, 3)) {
var t = this.first()[0][o];
return t[e].apply(t, i)
}
return this.each(function() {
var t = this[o];
t[e].apply(t, i)
})
}
if ("object" == typeof e || !e) return n.init(this, e), this;
jQuery.error("Method " + e + " does not exist on jQuery." + s)
}
}, M.AutoInit = function(t) {
var e = t || document.body,
i = {
Autocomplete: e.querySelectorAll(".autocomplete:not(.no-autoinit)"),
Carousel: e.querySelectorAll(".carousel:not(.no-autoinit)"),
Chips: e.querySelectorAll(".chips:not(.no-autoinit)"),
Collapsible: e.querySelectorAll(".collapsible:not(.no-autoinit)"),
Datepicker: e.querySelectorAll(".datepicker:not(.no-autoinit)"),
Dropdown: e.querySelectorAll(".dropdown-trigger:not(.no-autoinit)"),
Materialbox: e.querySelectorAll(".materialboxed:not(.no-autoinit)"),
Modal: e.querySelectorAll(".modal:not(.no-autoinit)"),
Parallax: e.querySelectorAll(".parallax:not(.no-autoinit)"),
Pushpin: e.querySelectorAll(".pushpin:not(.no-autoinit)"),
ScrollSpy: e.querySelectorAll(".scrollspy:not(.no-autoinit)"),
FormSelect: e.querySelectorAll("select:not(.no-autoinit)"),
Sidenav: e.querySelectorAll(".sidenav:not(.no-autoinit)"),
Tabs: e.querySelectorAll(".tabs:not(.no-autoinit)"),
TapTarget: e.querySelectorAll(".tap-target:not(.no-autoinit)"),
Timepicker: e.querySelectorAll(".timepicker:not(.no-autoinit)"),
Tooltip: e.querySelectorAll(".tooltipped:not(.no-autoinit)"),
FloatingActionButton: e.querySelectorAll(".fixed-action-btn:not(.no-autoinit)")
};
for (var n in i) {
M[n].init(i[n])
}
}, M.objectSelectorString = function(t) {
return ((t.prop("tagName") || "") + (t.attr("id") || "") + (t.attr("class") || "")).replace(/\s/g, "")
}, M.guid = function() {
function t() {
return Math.floor(65536 * (1 + Math.random())).toString(16).substring(1)
}
return function() {
return t() + t() + "-" + t() + "-" + t() + "-" + t() + "-" + t() + t() + t()
}
}(), M.escapeHash = function(t) {
return t.replace(/(:|\.|\[|\]|,|=|\/)/g, "\\$1")
}, M.elementOrParentIsFixed = function(t) {
var e = $(t),
i = e.add(e.parents()),
n = !1;
return i.each(function() {
if ("fixed" === $(this).css("position")) return !(n = !0)
}), n
}, M.checkWithinContainer = function(t, e, i) {
var n = {
top: !1,
right: !1,
bottom: !1,
left: !1
},
s = t.getBoundingClientRect(),
o = t === document.body ? Math.max(s.bottom, window.innerHeight) : s.bottom,
a = t.scrollLeft,
r = t.scrollTop,
l = e.left - a,
h = e.top - r;
return (l < s.left + i || l < i) && (n.left = !0), (l + e.width > s.right - i || l + e.width > window.innerWidth - i) && (n.right = !0), (h < s.top + i || h < i) && (n.top = !0), (h + e.height > o - i || h + e.height > window.innerHeight - i) && (n.bottom = !0), n
}, M.checkPossibleAlignments = function(t, e, i, n) {
var s = {
top: !0,
right: !0,
bottom: !0,
left: !0,
spaceOnTop: null,
spaceOnRight: null,
spaceOnBottom: null,
spaceOnLeft: null
},
o = "visible" === getComputedStyle(e).overflow,
a = e.getBoundingClientRect(),
r = Math.min(a.height, window.innerHeight),
l = Math.min(a.width, window.innerWidth),
h = t.getBoundingClientRect(),
d = e.scrollLeft,
u = e.scrollTop,
c = i.left - d,
p = i.top - u,
v = i.top + h.height - u;
return s.spaceOnRight = o ? window.innerWidth - (h.left + i.width) : l - (c + i.width), s.spaceOnRight < 0 && (s.left = !1), s.spaceOnLeft = o ? h.right - i.width : c - i.width + h.width, s.spaceOnLeft < 0 && (s.right = !1), s.spaceOnBottom = o ? window.innerHeight - (h.top + i.height + n) : r - (p + i.height + n), s.spaceOnBottom < 0 && (s.top = !1), s.spaceOnTop = o ? h.bottom - (i.height + n) : v - (i.height - n), s.spaceOnTop < 0 && (s.bottom = !1), s
}, M.getOverflowParent = function(t) {
return null == t ? null : t === document.body || "visible" !== getComputedStyle(t).overflow ? t : M.getOverflowParent(t.parentElement)
}, M.getIdFromTrigger = function(t) {
var e = t.getAttribute("data-target");
return e || (e = (e = t.getAttribute("href")) ? e.slice(1) : ""), e
}, M.getDocumentScrollTop = function() {
return window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0
}, M.getDocumentScrollLeft = function() {
return window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0
};
var getTime = Date.now || function() {
return (new Date).getTime()
};
M.throttle = function(i, n, s) {
var o = void 0,
a = void 0,
r = void 0,
l = null,
h = 0;
s || (s = {});
var d = function() {
h = !1 === s.leading ? 0 : getTime(), l = null, r = i.apply(o, a), o = a = null
};
return function() {
var t = getTime();
h || !1 !== s.leading || (h = t);
var e = n - (t - h);
return o = this, a = arguments, e <= 0 ? (clearTimeout(l), l = null, h = t, r = i.apply(o, a), o = a = null) : l || !1 === s.trailing || (l = setTimeout(d, e)), r
}
};
var $jscomp = {
scope: {}
};
$jscomp.defineProperty = "function" == typeof Object.defineProperties ? Object.defineProperty : function(t, e, i) {
if (i.get || i.set) throw new TypeError("ES3 does not support getters and setters.");
t != Array.prototype && t != Object.prototype && (t[e] = i.value)
}, $jscomp.getGlobal = function(t) {
return "undefined" != typeof window && window === t ? t : "undefined" != typeof global && null != global ? global : t
}, $jscomp.global = $jscomp.getGlobal(this), $jscomp.SYMBOL_PREFIX = "jscomp_symbol_", $jscomp.initSymbol = function() {
$jscomp.initSymbol = function() {}, $jscomp.global.Symbol || ($jscomp.global.Symbol = $jscomp.Symbol)
}, $jscomp.symbolCounter_ = 0, $jscomp.Symbol = function(t) {
return $jscomp.SYMBOL_PREFIX + (t || "") + $jscomp.symbolCounter_++
}, $jscomp.initSymbolIterator = function() {
$jscomp.initSymbol();
var t = $jscomp.global.Symbol.iterator;
t || (t = $jscomp.global.Symbol.iterator = $jscomp.global.Symbol("iterator")), "function" != typeof Array.prototype[t] && $jscomp.defineProperty(Array.prototype, t, {
configurable: !0,
writable: !0,
value: function() {
return $jscomp.arrayIterator(this)
}
}), $jscomp.initSymbolIterator = function() {}
}, $jscomp.arrayIterator = function(t) {
var e = 0;
return $jscomp.iteratorPrototype(function() {
return e < t.length ? {
done: !1,
value: t[e++]
} : {
done: !0
}
})
}, $jscomp.iteratorPrototype = function(t) {
return $jscomp.initSymbolIterator(), (t = {
next: t
})[$jscomp.global.Symbol.iterator] = function() {
return this
}, t
}, $jscomp.array = $jscomp.array || {}, $jscomp.iteratorFromArray = function(e, i) {
$jscomp.initSymbolIterator(), e instanceof String && (e += "");
var n = 0,
s = {
next: function() {
if (n < e.length) {
var t = n++;
return {
value: i(t, e[t]),
done: !1
}
}
return s.next = function() {
return {
done: !0,
value: void 0
}
}, s.next()
}
};
return s[Symbol.iterator] = function() {
return s
}, s
}, $jscomp.polyfill = function(t, e, i, n) {
if (e) {
for (i = $jscomp.global, t = t.split("."), n = 0; n < t.length - 1; n++) {
var s = t[n];
s in i || (i[s] = {}), i = i[s]
}(e = e(n = i[t = t[t.length - 1]])) != n && null != e && $jscomp.defineProperty(i, t, {
configurable: !0,
writable: !0,
value: e
})
}
}, $jscomp.polyfill("Array.prototype.keys", function(t) {
return t || function() {
return $jscomp.iteratorFromArray(this, function(t) {
return t
})
}
}, "es6-impl", "es3");
var $jscomp$this = this;
M.anime = function() {
function s(t) {
if (!B.col(t)) try {
return document.querySelectorAll(t)
} catch (t) {}
}
function b(t, e) {
for (var i = t.length, n = 2 <= arguments.length ? e : void 0, s = [], o = 0; o < i; o++)
if (o in t) {
var a = t[o];
e.call(n, a, o, t) && s.push(a)
} return s
}
function d(t) {
return t.reduce(function(t, e) {
return t.concat(B.arr(e) ? d(e) : e)
}, [])
}
function o(t) {
return B.arr(t) ? t : (B.str(t) && (t = s(t) || t), t instanceof NodeList || t instanceof HTMLCollection ? [].slice.call(t) : [t])
}
function a(t, e) {
return t.some(function(t) {
return t === e
})
}
function r(t) {
var e, i = {};
for (e in t) i[e] = t[e];
return i
}
function u(t, e) {
var i, n = r(t);
for (i in t) n[i] = e.hasOwnProperty(i) ? e[i] : t[i];
return n
}
function c(t, e) {
var i, n = r(t);
for (i in e) n[i] = B.und(t[i]) ? e[i] : t[i];
return n
}
function l(t) {
if (t = /([\+\-]?[0-9#\.]+)(%|px|pt|em|rem|in|cm|mm|ex|ch|pc|vw|vh|vmin|vmax|deg|rad|turn)?$/.exec(t)) return t[2]
}
function h(t, e) {
return B.fnc(t) ? t(e.target, e.id, e.total) : t
}
function w(t, e) {
if (e in t.style) return getComputedStyle(t).getPropertyValue(e.replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase()) || "0"
}
function p(t, e) {
return B.dom(t) && a($, e) ? "transform" : B.dom(t) && (t.getAttribute(e) || B.svg(t) && t[e]) ? "attribute" : B.dom(t) && "transform" !== e && w(t, e) ? "css" : null != t[e] ? "object" : void 0
}
function v(t, e) {
switch (p(t, e)) {
case "transform":
return function(t, i) {
var e, n = -1 < (e = i).indexOf("translate") || "perspective" === e ? "px" : -1 < e.indexOf("rotate") || -1 < e.indexOf("skew") ? "deg" : void 0,
n = -1 < i.indexOf("scale") ? 1 : 0 + n;
if (!(t = t.style.transform)) return n;
for (var s = [], o = [], a = [], r = /(\w+)\((.+?)\)/g; s = r.exec(t);) o.push(s[1]), a.push(s[2]);
return (t = b(a, function(t, e) {
return o[e] === i
})).length ? t[0] : n
}(t, e);
case "css":
return w(t, e);
case "attribute":
return t.getAttribute(e)
}
return t[e] || 0
}
function f(t, e) {
var i = /^(\*=|\+=|-=)/.exec(t);
if (!i) return t;
var n = l(t) || 0;
switch (e = parseFloat(e), t = parseFloat(t.replace(i[0], "")), i[0][0]) {
case "+":
return e + t + n;
case "-":
return e - t + n;
case "*":
return e * t + n
}
}
function m(t, e) {
return Math.sqrt(Math.pow(e.x - t.x, 2) + Math.pow(e.y - t.y, 2))
}
function i(t) {
t = t.points;
for (var e, i = 0, n = 0; n < t.numberOfItems; n++) {
var s = t.getItem(n);
0 < n && (i += m(e, s)), e = s
}
return i
}
function g(t) {
if (t.getTotalLength) return t.getTotalLength();
switch (t.tagName.toLowerCase()) {
case "circle":
return 2 * Math.PI * t.getAttribute("r");
case "rect":
return 2 * t.getAttribute("width") + 2 * t.getAttribute("height");
case "line":
return m({
x: t.getAttribute("x1"),
y: t.getAttribute("y1")
}, {
x: t.getAttribute("x2"),
y: t.getAttribute("y2")
});
case "polyline":
return i(t);
case "polygon":
var e = t.points;
return i(t) + m(e.getItem(e.numberOfItems - 1), e.getItem(0))
}
}
function C(e, i) {
function t(t) {
return t = void 0 === t ? 0 : t, e.el.getPointAtLength(1 <= i + t ? i + t : 0)
}
var n = t(),
s = t(-1),
o = t(1);
switch (e.property) {
case "x":
return n.x;
case "y":
return n.y;
case "angle":
return 180 * Math.atan2(o.y - s.y, o.x - s.x) / Math.PI
}
}
function _(t, e) {
var i, n = /-?\d*\.?\d+/g;
if (i = B.pth(t) ? t.totalLength : t, B.col(i))
if (B.rgb(i)) {
var s = /rgb\((\d+,\s*[\d]+,\s*[\d]+)\)/g.exec(i);
i = s ? "rgba(" + s[1] + ",1)" : i
} else i = B.hex(i) ? function(t) {
t = t.replace(/^#?([a-f\d])([a-f\d])([a-f\d])$/i, function(t, e, i, n) {
return e + e + i + i + n + n
});
var e = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(t);
t = parseInt(e[1], 16);
var i = parseInt(e[2], 16),
e = parseInt(e[3], 16);
return "rgba(" + t + "," + i + "," + e + ",1)"
}(i) : B.hsl(i) ? function(t) {
function e(t, e, i) {
return i < 0 && (i += 1), 1 < i && --i, i < 1 / 6 ? t + 6 * (e - t) * i : i < .5 ? e : i < 2 / 3 ? t + (e - t) * (2 / 3 - i) * 6 : t
}
var i = /hsl\((\d+),\s*([\d.]+)%,\s*([\d.]+)%\)/g.exec(t) || /hsla\((\d+),\s*([\d.]+)%,\s*([\d.]+)%,\s*([\d.]+)\)/g.exec(t);
t = parseInt(i[1]) / 360;
var n = parseInt(i[2]) / 100,
s = parseInt(i[3]) / 100,
i = i[4] || 1;
if (0 == n) s = n = t = s;
else {
var o = s < .5 ? s * (1 + n) : s + n - s * n,
a = 2 * s - o,
s = e(a, o, t + 1 / 3),
n = e(a, o, t);
t = e(a, o, t - 1 / 3)
}
return "rgba(" + 255 * s + "," + 255 * n + "," + 255 * t + "," + i + ")"
}(i) : void 0;
else s = (s = l(i)) ? i.substr(0, i.length - s.length) : i, i = e && !/\s/g.test(i) ? s + e : s;
return {
original: i += "",
numbers: i.match(n) ? i.match(n).map(Number) : [0],
strings: B.str(t) || e ? i.split(n) : []
}
}
function y(t) {
return b(t = t ? d(B.arr(t) ? t.map(o) : o(t)) : [], function(t, e, i) {
return i.indexOf(t) === e
})
}
function k(t, i) {
var e = r(i);
if (B.arr(t)) {
var n = t.length;
2 !== n || B.obj(t[0]) ? B.fnc(i.duration) || (e.duration = i.duration / n) : t = {
value: t
}
}
return o(t).map(function(t, e) {
return e = e ? 0 : i.delay, t = B.obj(t) && !B.pth(t) ? t : {
value: t
}, B.und(t.delay) && (t.delay = e), t
}).map(function(t) {
return c(t, e)
})
}
function E(o, a) {
var r;
return o.tweens.map(function(t) {
var e = (t = function(t, e) {
var i, n = {};
for (i in t) {
var s = h(t[i], e);
B.arr(s) && 1 === (s = s.map(function(t) {
return h(t, e)
})).length && (s = s[0]), n[i] = s
}
return n.duration = parseFloat(n.duration), n.delay = parseFloat(n.delay), n
}(t, a)).value,
i = v(a.target, o.name),
n = r ? r.to.original : i,
n = B.arr(e) ? e[0] : n,
s = f(B.arr(e) ? e[1] : e, n),
i = l(s) || l(n) || l(i);
return t.from = _(n, i), t.to = _(s, i), t.start = r ? r.end : o.offset, t.end = t.start + t.delay + t.duration, t.easing = function(t) {
return B.arr(t) ? D.apply(this, t) : S[t]
}(t.easing), t.elasticity = (1e3 - Math.min(Math.max(t.elasticity, 1), 999)) / 1e3, t.isPath = B.pth(e), t.isColor = B.col(t.from.original), t.isColor && (t.round = 1), r = t
})
}
function M(e, t, i, n) {
var s = "delay" === e;
return t.length ? (s ? Math.min : Math.max).apply(Math, t.map(function(t) {
return t[e]
})) : s ? n.delay : i.offset + n.delay + n.duration
}
function n(t) {
var e, i, n, s, o = u(L, t),
a = u(T, t),
r = (i = t.targets, (n = y(i)).map(function(t, e) {
return {
target: t,
id: e,
total: n.length
}
})),
l = [],
h = c(o, a);
for (e in t) h.hasOwnProperty(e) || "targets" === e || l.push({
name: e,
offset: h.offset,
tweens: k(t[e], a)
});
return s = l, t = b(d(r.map(function(n) {
return s.map(function(t) {
var e = p(n.target, t.name);
if (e) {
var i = E(t, n);
t = {
type: e,
property: t.name,
animatable: n,
tweens: i,
duration: i[i.length - 1].end,
delay: i[0].delay
}
} else t = void 0;
return t
})
})), function(t) {
return !B.und(t)
}), c(o, {
children: [],
animatables: r,
animations: t,
duration: M("duration", t, o, a),
delay: M("delay", t, o, a)
})
}
function O(t) {
function d() {
return window.Promise && new Promise(function(t) {
return _ = t
})
}
function u(t) {
return k.reversed ? k.duration - t : t
}
function c(e) {
for (var t = 0, i = {}, n = k.animations, s = n.length; t < s;) {
var o = n[t],
a = o.animatable,
r = o.tweens,
l = r.length - 1,
h = r[l];
l && (h = b(r, function(t) {
return e < t.end
})[0] || h);
for (var r = Math.min(Math.max(e - h.start - h.delay, 0), h.duration) / h.duration, d = isNaN(r) ? 1 : h.easing(r, h.elasticity), r = h.to.strings, u = h.round, l = [], c = void 0, c = h.to.numbers.length, p = 0; p < c; p++) {
var v = void 0,
v = h.to.numbers[p],
f = h.from.numbers[p],
v = h.isPath ? C(h.value, d * v) : f + d * (v - f);
u && (h.isColor && 2 < p || (v = Math.round(v * u) / u)), l.push(v)
}
if (h = r.length)
for (c = r[0], d = 0; d < h; d++) u = r[d + 1], p = l[d], isNaN(p) || (c = u ? c + (p + u) : c + (p + " "));
else c = l[0];
I[o.type](a.target, o.property, c, i, a.id), o.currentValue = c, t++
}
if (t = Object.keys(i).length)
for (n = 0; n < t; n++) x || (x = w(document.body, "transform") ? "transform" : "-webkit-transform"), k.animatables[n].target.style[x] = i[n].join(" ");
k.currentTime = e, k.progress = e / k.duration * 100
}
function p(t) {
k[t] && k[t](k)
}
function v() {
k.remaining && !0 !== k.remaining && k.remaining--
}
function e(t) {
var e = k.duration,
i = k.offset,
n = i + k.delay,
s = k.currentTime,
o = k.reversed,
a = u(t);
if (k.children.length) {
var r = k.children,
l = r.length;
if (a >= k.currentTime)
for (var h = 0; h < l; h++) r[h].seek(a);
else
for (; l--;) r[l].seek(a)
}(n <= a || !e) && (k.began || (k.began = !0, p("begin")), p("run")), i < a && a < e ? c(a) : (a <= i && 0 !== s && (c(0), o && v()), (e <= a && s !== e || !e) && (c(e), o || v())), p("update"), e <= t && (k.remaining ? (m = f, "alternate" === k.direction && (k.reversed = !k.reversed)) : (k.pause(), k.completed || (k.completed = !0, p("complete"), "Promise" in window && (_(), y = d()))), g = 0)
}
t = void 0 === t ? {} : t;
var f, m, g = 0,
_ = null,
y = d(),
k = n(t);
return k.reset = function() {
var t = k.direction,
e = k.loop;
for (k.currentTime = 0, k.progress = 0, k.paused = !0, k.began = !1, k.completed = !1, k.reversed = "reverse" === t, k.remaining = "alternate" === t && 1 === e ? 2 : e, c(0), t = k.children.length; t--;) k.children[t].reset()
}, k.tick = function(t) {
f = t, m || (m = f), e((g + f - m) * O.speed)
}, k.seek = function(t) {
e(u(t))
}, k.pause = function() {
var t = A.indexOf(k); - 1 < t && A.splice(t, 1), k.paused = !0
}, k.play = function() {
k.paused && (k.paused = !1, m = 0, g = u(k.currentTime), A.push(k), R || H())
}, k.reverse = function() {
k.reversed = !k.reversed, m = 0, g = u(k.currentTime)
}, k.restart = function() {
k.pause(), k.reset(), k.play()
}, k.finished = y, k.reset(), k.autoplay && k.play(), k
}
var x, L = {
update: void 0,
begin: void 0,
run: void 0,
complete: void 0,
loop: 1,
direction: "normal",
autoplay: !0,
offset: 0
},
T = {
duration: 1e3,
delay: 0,
easing: "easeOutElastic",
elasticity: 500,
round: 0
},
$ = "translateX translateY translateZ rotate rotateX rotateY rotateZ scale scaleX scaleY scaleZ skewX skewY perspective".split(" "),
B = {
arr: function(t) {
return Array.isArray(t)
},
obj: function(t) {
return -1 < Object.prototype.toString.call(t).indexOf("Object")
},
pth: function(t) {
return B.obj(t) && t.hasOwnProperty("totalLength")
},
svg: function(t) {
return t instanceof SVGElement
},
dom: function(t) {
return t.nodeType || B.svg(t)
},
str: function(t) {
return "string" == typeof t
},
fnc: function(t) {
return "function" == typeof t
},
und: function(t) {
return void 0 === t
},
hex: function(t) {
return /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(t)
},
rgb: function(t) {
return /^rgb/.test(t)
},
hsl: function(t) {
return /^hsl/.test(t)
},
col: function(t) {
return B.hex(t) || B.rgb(t) || B.hsl(t)
}
},
D = function() {
function u(t, e, i) {
return (((1 - 3 * i + 3 * e) * t + (3 * i - 6 * e)) * t + 3 * e) * t
}
return function(a, r, l, h) {
if (0 <= a && a <= 1 && 0 <= l && l <= 1) {
var d = new Float32Array(11);
if (a !== r || l !== h)
for (var t = 0; t < 11; ++t) d[t] = u(.1 * t, a, l);
return function(t) {
if (a === r && l === h) return t;
if (0 === t) return 0;
if (1 === t) return 1;
for (var e = 0, i = 1; 10 !== i && d[i] <= t; ++i) e += .1;
var i = e + (t - d[--i]) / (d[i + 1] - d[i]) * .1,
n = 3 * (1 - 3 * l + 3 * a) * i * i + 2 * (3 * l - 6 * a) * i + 3 * a;
if (.001 <= n) {
for (e = 0; e < 4 && 0 != (n = 3 * (1 - 3 * l + 3 * a) * i * i + 2 * (3 * l - 6 * a) * i + 3 * a); ++e) var s = u(i, a, l) - t,
i = i - s / n;
t = i
} else if (0 === n) t = i;
else {
for (var i = e, e = e + .1, o = 0; 0 < (n = u(s = i + (e - i) / 2, a, l) - t) ? e = s : i = s, 1e-7 < Math.abs(n) && ++o < 10;);
t = s
}
return u(t, r, h)
}
}
}
}(),
S = function() {
function i(t, e) {
return 0 === t || 1 === t ? t : -Math.pow(2, 10 * (t - 1)) * Math.sin(2 * (t - 1 - e / (2 * Math.PI) * Math.asin(1)) * Math.PI / e)
}
var t, n = "Quad Cubic Quart Quint Sine Expo Circ Back Elastic".split(" "),
e = {
In: [
[.55, .085, .68, .53],
[.55, .055, .675, .19],
[.895, .03, .685, .22],
[.755, .05, .855, .06],
[.47, 0, .745, .715],
[.95, .05, .795, .035],
[.6, .04, .98, .335],
[.6, -.28, .735, .045], i
],
Out: [
[.25, .46, .45, .94],
[.215, .61, .355, 1],
[.165, .84, .44, 1],
[.23, 1, .32, 1],
[.39, .575, .565, 1],
[.19, 1, .22, 1],
[.075, .82, .165, 1],
[.175, .885, .32, 1.275],
function(t, e) {
return 1 - i(1 - t, e)
}
],
InOut: [
[.455, .03, .515, .955],
[.645, .045, .355, 1],
[.77, 0, .175, 1],
[.86, 0, .07, 1],
[.445, .05, .55, .95],
[1, 0, 0, 1],
[.785, .135, .15, .86],
[.68, -.55, .265, 1.55],
function(t, e) {
return t < .5 ? i(2 * t, e) / 2 : 1 - i(-2 * t + 2, e) / 2
}
]
},
s = {
linear: D(.25, .25, .75, .75)
},
o = {};
for (t in e) o.type = t, e[o.type].forEach(function(i) {
return function(t, e) {
s["ease" + i.type + n[e]] = B.fnc(t) ? t : D.apply($jscomp$this, t)
}
}(o)), o = {
type: o.type
};
return s
}(),
I = {
css: function(t, e, i) {
return t.style[e] = i
},
attribute: function(t, e, i) {
return t.setAttribute(e, i)
},
object: function(t, e, i) {
return t[e] = i
},
transform: function(t, e, i, n, s) {
n[s] || (n[s] = []), n[s].push(e + "(" + i + ")")
}
},
A = [],
R = 0,
H = function() {
function n() {
R = requestAnimationFrame(t)
}
function t(t) {
var e = A.length;
if (e) {
for (var i = 0; i < e;) A[i] && A[i].tick(t), i++;
n()
} else cancelAnimationFrame(R), R = 0
}
return n
}();
return O.version = "2.2.0", O.speed = 1, O.running = A, O.remove = function(t) {
t = y(t);
for (var e = A.length; e--;)
for (var i = A[e], n = i.animations, s = n.length; s--;) a(t, n[s].animatable.target) && (n.splice(s, 1), n.length || i.pause())
}, O.getValue = v, O.path = function(t, e) {
var i = B.str(t) ? s(t)[0] : t,
n = e || 100;
return function(t) {
return {
el: i,
property: t,
totalLength: g(i) * (n / 100)
}
}
}, O.setDashoffset = function(t) {
var e = g(t);
return t.setAttribute("stroke-dasharray", e), e
}, O.bezier = D, O.easings = S, O.timeline = function(n) {
var s = O(n);
return s.pause(), s.duration = 0, s.add = function(t) {
return s.children.forEach(function(t) {
t.began = !0, t.completed = !0
}), o(t).forEach(function(t) {
var e = c(t, u(T, n || {}));
e.targets = e.targets || n.targets, t = s.duration;
var i = e.offset;
e.autoplay = !1, e.direction = s.direction, e.offset = B.und(i) ? t : f(i, t), s.began = !0, s.completed = !0, s.seek(e.offset), (e = O(e)).began = !0, e.completed = !0, e.duration > t && (s.duration = e.duration), s.children.push(e)
}), s.seek(0), s.reset(), s.autoplay && s.restart(), s
}, s
}, O.random = function(t, e) {
return Math.floor(Math.random() * (e - t + 1)) + t
}, O
}(),
function(r, l) {
"use strict";
var e = {
accordion: !0,
onOpenStart: void 0,
onOpenEnd: void 0,
onCloseStart: void 0,
onCloseEnd: void 0,
inDuration: 300,
outDuration: 300
},
t = function(t) {
function s(t, e) {
_classCallCheck(this, s);
var i = _possibleConstructorReturn(this, (s.__proto__ || Object.getPrototypeOf(s)).call(this, s, t, e));
(i.el.M_Collapsible = i).options = r.extend({}, s.defaults, e), i.$headers = i.$el.children("li").children(".collapsible-header"), i.$headers.attr("tabindex", 0), i._setupEventHandlers();
var n = i.$el.children("li.active").children(".collapsible-body");
return i.options.accordion ? n.first().css("display", "block") : n.css("display", "block"), i
}
return _inherits(s, Component), _createClass(s, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this.el.M_Collapsible = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
var e = this;
this._handleCollapsibleClickBound = this._handleCollapsibleClick.bind(this), this._handleCollapsibleKeydownBound = this._handleCollapsibleKeydown.bind(this), this.el.addEventListener("click", this._handleCollapsibleClickBound), this.$headers.each(function(t) {
t.addEventListener("keydown", e._handleCollapsibleKeydownBound)
})
}
}, {
key: "_removeEventHandlers",
value: function() {
var e = this;
this.el.removeEventListener("click", this._handleCollapsibleClickBound), this.$headers.each(function(t) {
t.removeEventListener("keydown", e._handleCollapsibleKeydownBound)
})
}
}, {
key: "_handleCollapsibleClick",
value: function(t) {
var e = r(t.target).closest(".collapsible-header");
if (t.target && e.length) {
var i = e.closest(".collapsible");
if (i[0] === this.el) {
var n = e.closest("li"),
s = i.children("li"),
o = n[0].classList.contains("active"),
a = s.index(n);
o ? this.close(a) : this.open(a)
}
}
}
}, {
key: "_handleCollapsibleKeydown",
value: function(t) {
13 === t.keyCode && this._handleCollapsibleClickBound(t)
}
}, {
key: "_animateIn",
value: function(t) {
var e = this,
i = this.$el.children("li").eq(t);
if (i.length) {
var n = i.children(".collapsible-body");
l.remove(n[0]), n.css({
display: "block",
overflow: "hidden",
height: 0,
paddingTop: "",
paddingBottom: ""
});
var s = n.css("padding-top"),
o = n.css("padding-bottom"),
a = n[0].scrollHeight;
n.css({
paddingTop: 0,
paddingBottom: 0
}), l({
targets: n[0],
height: a,
paddingTop: s,
paddingBottom: o,
duration: this.options.inDuration,
easing: "easeInOutCubic",
complete: function(t) {
n.css({
overflow: "",
paddingTop: "",
paddingBottom: "",
height: ""
}), "function" == typeof e.options.onOpenEnd && e.options.onOpenEnd.call(e, i[0])
}
})
}
}
}, {
key: "_animateOut",
value: function(t) {
var e = this,
i = this.$el.children("li").eq(t);
if (i.length) {
var n = i.children(".collapsible-body");
l.remove(n[0]), n.css("overflow", "hidden"), l({
targets: n[0],
height: 0,
paddingTop: 0,
paddingBottom: 0,
duration: this.options.outDuration,
easing: "easeInOutCubic",
complete: function() {
n.css({
height: "",
overflow: "",
padding: "",
display: ""
}), "function" == typeof e.options.onCloseEnd && e.options.onCloseEnd.call(e, i[0])
}
})
}
}
}, {
key: "open",
value: function(t) {
var i = this,
e = this.$el.children("li").eq(t);
if (e.length && !e[0].classList.contains("active")) {
if ("function" == typeof this.options.onOpenStart && this.options.onOpenStart.call(this, e[0]), this.options.accordion) {
var n = this.$el.children("li");
this.$el.children("li.active").each(function(t) {
var e = n.index(r(t));
i.close(e)
})
}
e[0].classList.add("active"), this._animateIn(t)
}
}
}, {
key: "close",
value: function(t) {
var e = this.$el.children("li").eq(t);
e.length && e[0].classList.contains("active") && ("function" == typeof this.options.onCloseStart && this.options.onCloseStart.call(this, e[0]), e[0].classList.remove("active"), this._animateOut(t))
}
}], [{
key: "init",
value: function(t, e) {
return _get(s.__proto__ || Object.getPrototypeOf(s), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Collapsible
}
}, {
key: "defaults",
get: function() {
return e
}
}]), s
}();
M.Collapsible = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "collapsible", "M_Collapsible")
}(cash, M.anime),
function(h, i) {
"use strict";
var e = {
alignment: "left",
autoFocus: !0,
constrainWidth: !0,
container: null,
coverTrigger: !0,
closeOnClick: !0,
hover: !1,
inDuration: 150,
outDuration: 250,
onOpenStart: null,
onOpenEnd: null,
onCloseStart: null,
onCloseEnd: null,
onItemClick: null
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return i.el.M_Dropdown = i, n._dropdowns.push(i), i.id = M.getIdFromTrigger(t), i.dropdownEl = document.getElementById(i.id), i.$dropdownEl = h(i.dropdownEl), i.options = h.extend({}, n.defaults, e), i.isOpen = !1, i.isScrollable = !1, i.isTouchMoving = !1, i.focusedIndex = -1, i.filterQuery = [], i.options.container ? h(i.options.container).append(i.dropdownEl) : i.$el.after(i.dropdownEl), i._makeDropdownFocusable(), i._resetFilterQueryBound = i._resetFilterQuery.bind(i), i._handleDocumentClickBound = i._handleDocumentClick.bind(i), i._handleDocumentTouchmoveBound = i._handleDocumentTouchmove.bind(i), i._handleDropdownClickBound = i._handleDropdownClick.bind(i), i._handleDropdownKeydownBound = i._handleDropdownKeydown.bind(i), i._handleTriggerKeydownBound = i._handleTriggerKeydown.bind(i), i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._resetDropdownStyles(), this._removeEventHandlers(), n._dropdowns.splice(n._dropdowns.indexOf(this), 1), this.el.M_Dropdown = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this.el.addEventListener("keydown", this._handleTriggerKeydownBound), this.dropdownEl.addEventListener("click", this._handleDropdownClickBound), this.options.hover ? (this._handleMouseEnterBound = this._handleMouseEnter.bind(this), this.el.addEventListener("mouseenter", this._handleMouseEnterBound), this._handleMouseLeaveBound = this._handleMouseLeave.bind(this), this.el.addEventListener("mouseleave", this._handleMouseLeaveBound), this.dropdownEl.addEventListener("mouseleave", this._handleMouseLeaveBound)) : (this._handleClickBound = this._handleClick.bind(this), this.el.addEventListener("click", this._handleClickBound))
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("keydown", this._handleTriggerKeydownBound), this.dropdownEl.removeEventListener("click", this._handleDropdownClickBound), this.options.hover ? (this.el.removeEventListener("mouseenter", this._handleMouseEnterBound), this.el.removeEventListener("mouseleave", this._handleMouseLeaveBound), this.dropdownEl.removeEventListener("mouseleave", this._handleMouseLeaveBound)) : this.el.removeEventListener("click", this._handleClickBound)
}
}, {
key: "_setupTemporaryEventHandlers",
value: function() {
document.body.addEventListener("click", this._handleDocumentClickBound, !0), document.body.addEventListener("touchend", this._handleDocumentClickBound), document.body.addEventListener("touchmove", this._handleDocumentTouchmoveBound), this.dropdownEl.addEventListener("keydown", this._handleDropdownKeydownBound)
}
}, {
key: "_removeTemporaryEventHandlers",
value: function() {
document.body.removeEventListener("click", this._handleDocumentClickBound, !0), document.body.removeEventListener("touchend", this._handleDocumentClickBound), document.body.removeEventListener("touchmove", this._handleDocumentTouchmoveBound), this.dropdownEl.removeEventListener("keydown", this._handleDropdownKeydownBound)
}
}, {
key: "_handleClick",
value: function(t) {
t.preventDefault(), this.open()
}
}, {
key: "_handleMouseEnter",
value: function() {
this.open()
}
}, {
key: "_handleMouseLeave",
value: function(t) {
var e = t.toElement || t.relatedTarget,
i = !!h(e).closest(".dropdown-content").length,
n = !1,
s = h(e).closest(".dropdown-trigger");
s.length && s[0].M_Dropdown && s[0].M_Dropdown.isOpen && (n = !0), n || i || this.close()
}
}, {
key: "_handleDocumentClick",
value: function(t) {
var e = this,
i = h(t.target);
this.options.closeOnClick && i.closest(".dropdown-content").length && !this.isTouchMoving ? setTimeout(function() {
e.close()
}, 0) : !i.closest(".dropdown-trigger").length && i.closest(".dropdown-content").length || setTimeout(function() {
e.close()
}, 0), this.isTouchMoving = !1
}
}, {
key: "_handleTriggerKeydown",
value: function(t) {
t.which !== M.keys.ARROW_DOWN && t.which !== M.keys.ENTER || this.isOpen || (t.preventDefault(), this.open())
}
}, {
key: "_handleDocumentTouchmove",
value: function(t) {
h(t.target).closest(".dropdown-content").length && (this.isTouchMoving = !0)
}
}, {
key: "_handleDropdownClick",
value: function(t) {
if ("function" == typeof this.options.onItemClick) {
var e = h(t.target).closest("li")[0];
this.options.onItemClick.call(this, e)
}
}
}, {
key: "_handleDropdownKeydown",
value: function(t) {
if (t.which === M.keys.TAB) t.preventDefault(), this.close();
else if (t.which !== M.keys.ARROW_DOWN && t.which !== M.keys.ARROW_UP || !this.isOpen)
if (t.which === M.keys.ENTER && this.isOpen) {
var e = this.dropdownEl.children[this.focusedIndex],
i = h(e).find("a, button").first();
i.length ? i[0].click() : e && e.click()
} else t.which === M.keys.ESC && this.isOpen && (t.preventDefault(), this.close());
else {
t.preventDefault();
var n = t.which === M.keys.ARROW_DOWN ? 1 : -1,
s = this.focusedIndex,
o = !1;
do {
if (s += n, this.dropdownEl.children[s] && -1 !== this.dropdownEl.children[s].tabIndex) {
o = !0;
break
}
} while (s < this.dropdownEl.children.length && 0 <= s);
o && (this.focusedIndex = s, this._focusFocusedItem())
}
var a = String.fromCharCode(t.which).toLowerCase();
if (a && -1 === [9, 13, 27, 38, 40].indexOf(t.which)) {
this.filterQuery.push(a);
var r = this.filterQuery.join(""),
l = h(this.dropdownEl).find("li").filter(function(t) {
return 0 === h(t).text().toLowerCase().indexOf(r)
})[0];
l && (this.focusedIndex = h(l).index(), this._focusFocusedItem())
}
this.filterTimeout = setTimeout(this._resetFilterQueryBound, 1e3)
}
}, {
key: "_resetFilterQuery",
value: function() {
this.filterQuery = []
}
}, {
key: "_resetDropdownStyles",
value: function() {
this.$dropdownEl.css({
display: "",
width: "",
height: "",
left: "",
top: "",
"transform-origin": "",
transform: "",
opacity: ""
})
}
}, {
key: "_makeDropdownFocusable",
value: function() {
this.dropdownEl.tabIndex = 0, h(this.dropdownEl).children().each(function(t) {
t.getAttribute("tabindex") || t.setAttribute("tabindex", 0)
})
}
}, {
key: "_focusFocusedItem",
value: function() {
0 <= this.focusedIndex && this.focusedIndex < this.dropdownEl.children.length && this.options.autoFocus && this.dropdownEl.children[this.focusedIndex].focus()
}
}, {
key: "_getDropdownPosition",
value: function() {
this.el.offsetParent.getBoundingClientRect();
var t = this.el.getBoundingClientRect(),
e = this.dropdownEl.getBoundingClientRect(),
i = e.height,
n = e.width,
s = t.left - e.left,
o = t.top - e.top,
a = {
left: s,
top: o,
height: i,
width: n
},
r = this.dropdownEl.offsetParent ? this.dropdownEl.offsetParent : this.dropdownEl.parentNode,
l = M.checkPossibleAlignments(this.el, r, a, this.options.coverTrigger ? 0 : t.height),
h = "top",
d = this.options.alignment;
if (o += this.options.coverTrigger ? 0 : t.height, this.isScrollable = !1, l.top || (l.bottom ? h = "bottom" : (this.isScrollable = !0, l.spaceOnTop > l.spaceOnBottom ? (h = "bottom", i += l.spaceOnTop, o -= l.spaceOnTop) : i += l.spaceOnBottom)), !l[d]) {
var u = "left" === d ? "right" : "left";
l[u] ? d = u : l.spaceOnLeft > l.spaceOnRight ? (d = "right", n += l.spaceOnLeft, s -= l.spaceOnLeft) : (d = "left", n += l.spaceOnRight)
}
return "bottom" === h && (o = o - e.height + (this.options.coverTrigger ? t.height : 0)), "right" === d && (s = s - e.width + t.width), {
x: s,
y: o,
verticalAlignment: h,
horizontalAlignment: d,
height: i,
width: n
}
}
}, {
key: "_animateIn",
value: function() {
var e = this;
i.remove(this.dropdownEl), i({
targets: this.dropdownEl,
opacity: {
value: [0, 1],
easing: "easeOutQuad"
},
scaleX: [.3, 1],
scaleY: [.3, 1],
duration: this.options.inDuration,
easing: "easeOutQuint",
complete: function(t) {
e.options.autoFocus && e.dropdownEl.focus(), "function" == typeof e.options.onOpenEnd && e.options.onOpenEnd.call(e, e.el)
}
})
}
}, {
key: "_animateOut",
value: function() {
var e = this;
i.remove(this.dropdownEl), i({
targets: this.dropdownEl,
opacity: {
value: 0,
easing: "easeOutQuint"
},
scaleX: .3,
scaleY: .3,
duration: this.options.outDuration,
easing: "easeOutQuint",
complete: function(t) {
e._resetDropdownStyles(), "function" == typeof e.options.onCloseEnd && e.options.onCloseEnd.call(e, e.el)
}
})
}
}, {
key: "_placeDropdown",
value: function() {
var t = this.options.constrainWidth ? this.el.getBoundingClientRect().width : this.dropdownEl.getBoundingClientRect().width;
this.dropdownEl.style.width = t + "px";
var e = this._getDropdownPosition();
this.dropdownEl.style.left = e.x + "px", this.dropdownEl.style.top = e.y + "px", this.dropdownEl.style.height = e.height + "px", this.dropdownEl.style.width = e.width + "px", this.dropdownEl.style.transformOrigin = ("left" === e.horizontalAlignment ? "0" : "100%") + " " + ("top" === e.verticalAlignment ? "0" : "100%")
}
}, {
key: "open",
value: function() {
this.isOpen || (this.isOpen = !0, "function" == typeof this.options.onOpenStart && this.options.onOpenStart.call(this, this.el), this._resetDropdownStyles(), this.dropdownEl.style.display = "block", this._placeDropdown(), this._animateIn(), this._setupTemporaryEventHandlers())
}
}, {
key: "close",
value: function() {
this.isOpen && (this.isOpen = !1, this.focusedIndex = -1, "function" == typeof this.options.onCloseStart && this.options.onCloseStart.call(this, this.el), this._animateOut(), this._removeTemporaryEventHandlers(), this.options.autoFocus && this.el.focus())
}
}, {
key: "recalculateDimensions",
value: function() {
this.isOpen && (this.$dropdownEl.css({
width: "",
height: "",
left: "",
top: "",
"transform-origin": ""
}), this._placeDropdown())
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Dropdown
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
t._dropdowns = [], M.Dropdown = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "dropdown", "M_Dropdown")
}(cash, M.anime),
function(s, i) {
"use strict";
var e = {
opacity: .5,
inDuration: 250,
outDuration: 250,
onOpenStart: null,
onOpenEnd: null,
onCloseStart: null,
onCloseEnd: null,
preventScrolling: !0,
dismissible: !0,
startingTop: "4%",
endingTop: "10%"
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Modal = i).options = s.extend({}, n.defaults, e), i.isOpen = !1, i.id = i.$el.attr("id"), i._openingTrigger = void 0, i.$overlay = s('<div class="modal-overlay"></div>'), i.el.tabIndex = 0, i._nthModalOpened = 0, n._count++, i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
n._count--, this._removeEventHandlers(), this.el.removeAttribute("style"), this.$overlay.remove(), this.el.M_Modal = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleOverlayClickBound = this._handleOverlayClick.bind(this), this._handleModalCloseClickBound = this._handleModalCloseClick.bind(this), 1 === n._count && document.body.addEventListener("click", this._handleTriggerClick), this.$overlay[0].addEventListener("click", this._handleOverlayClickBound), this.el.addEventListener("click", this._handleModalCloseClickBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
0 === n._count && document.body.removeEventListener("click", this._handleTriggerClick), this.$overlay[0].removeEventListener("click", this._handleOverlayClickBound), this.el.removeEventListener("click", this._handleModalCloseClickBound)
}
}, {
key: "_handleTriggerClick",
value: function(t) {
var e = s(t.target).closest(".modal-trigger");
if (e.length) {
var i = M.getIdFromTrigger(e[0]),
n = document.getElementById(i).M_Modal;
n && n.open(e), t.preventDefault()
}
}
}, {
key: "_handleOverlayClick",
value: function() {
this.options.dismissible && this.close()
}
}, {
key: "_handleModalCloseClick",
value: function(t) {
s(t.target).closest(".modal-close").length && this.close()
}
}, {
key: "_handleKeydown",
value: function(t) {
27 === t.keyCode && this.options.dismissible && this.close()
}
}, {
key: "_handleFocus",
value: function(t) {
this.el.contains(t.target) || this._nthModalOpened !== n._modalsOpen || this.el.focus()
}
}, {
key: "_animateIn",
value: function() {
var t = this;
s.extend(this.el.style, {
display: "block",
opacity: 0
}), s.extend(this.$overlay[0].style, {
display: "block",
opacity: 0
}), i({
targets: this.$overlay[0],
opacity: this.options.opacity,
duration: this.options.inDuration,
easing: "easeOutQuad"
});
var e = {
targets: this.el,
duration: this.options.inDuration,
easing: "easeOutCubic",
complete: function() {
"function" == typeof t.options.onOpenEnd && t.options.onOpenEnd.call(t, t.el, t._openingTrigger)
}
};
this.el.classList.contains("bottom-sheet") ? s.extend(e, {
bottom: 0,
opacity: 1
}) : s.extend(e, {
top: [this.options.startingTop, this.options.endingTop],
opacity: 1,
scaleX: [.8, 1],
scaleY: [.8, 1]
}), i(e)
}
}, {
key: "_animateOut",
value: function() {
var t = this;
i({
targets: this.$overlay[0],
opacity: 0,
duration: this.options.outDuration,
easing: "easeOutQuart"
});
var e = {
targets: this.el,
duration: this.options.outDuration,
easing: "easeOutCubic",
complete: function() {
t.el.style.display = "none", t.$overlay.remove(), "function" == typeof t.options.onCloseEnd && t.options.onCloseEnd.call(t, t.el)
}
};
this.el.classList.contains("bottom-sheet") ? s.extend(e, {
bottom: "-100%",
opacity: 0
}) : s.extend(e, {
top: [this.options.endingTop, this.options.startingTop],
opacity: 0,
scaleX: .8,
scaleY: .8
}), i(e)
}
}, {
key: "open",
value: function(t) {
if (!this.isOpen) return this.isOpen = !0, n._modalsOpen++, this._nthModalOpened = n._modalsOpen, this.$overlay[0].style.zIndex = 1e3 + 2 * n._modalsOpen, this.el.style.zIndex = 1e3 + 2 * n._modalsOpen + 1, this._openingTrigger = t ? t[0] : void 0, "function" == typeof this.options.onOpenStart && this.options.onOpenStart.call(this, this.el, this._openingTrigger), this.options.preventScrolling && (document.body.style.overflow = "hidden"), this.el.classList.add("open"), this.el.insertAdjacentElement("afterend", this.$overlay[0]), this.options.dismissible && (this._handleKeydownBound = this._handleKeydown.bind(this), this._handleFocusBound = this._handleFocus.bind(this), document.addEventListener("keydown", this._handleKeydownBound), document.addEventListener("focus", this._handleFocusBound, !0)), i.remove(this.el), i.remove(this.$overlay[0]), this._animateIn(), this.el.focus(), this
}
}, {
key: "close",
value: function() {
if (this.isOpen) return this.isOpen = !1, n._modalsOpen--, this._nthModalOpened = 0, "function" == typeof this.options.onCloseStart && this.options.onCloseStart.call(this, this.el), this.el.classList.remove("open"), 0 === n._modalsOpen && (document.body.style.overflow = ""), this.options.dismissible && (document.removeEventListener("keydown", this._handleKeydownBound), document.removeEventListener("focus", this._handleFocusBound, !0)), i.remove(this.el), i.remove(this.$overlay[0]), this._animateOut(), this
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Modal
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
t._modalsOpen = 0, t._count = 0, M.Modal = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "modal", "M_Modal")
}(cash, M.anime),
function(o, a) {
"use strict";
var e = {
inDuration: 275,
outDuration: 200,
onOpenStart: null,
onOpenEnd: null,
onCloseStart: null,
onCloseEnd: null
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Materialbox = i).options = o.extend({}, n.defaults, e), i.overlayActive = !1, i.doneAnimating = !0, i.placeholder = o("<div></div>").addClass("material-placeholder"), i.originalWidth = 0, i.originalHeight = 0, i.originInlineStyles = i.$el.attr("style"), i.caption = i.el.getAttribute("data-caption") || "", i.$el.before(i.placeholder), i.placeholder.append(i.$el), i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this.el.M_Materialbox = void 0, o(this.placeholder).after(this.el).remove(), this.$el.removeAttr("style")
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleMaterialboxClickBound = this._handleMaterialboxClick.bind(this), this.el.addEventListener("click", this._handleMaterialboxClickBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("click", this._handleMaterialboxClickBound)
}
}, {
key: "_handleMaterialboxClick",
value: function(t) {
!1 === this.doneAnimating || this.overlayActive && this.doneAnimating ? this.close() : this.open()
}
}, {
key: "_handleWindowScroll",
value: function() {
this.overlayActive && this.close()
}
}, {
key: "_handleWindowResize",
value: function() {
this.overlayActive && this.close()
}
}, {
key: "_handleWindowEscape",
value: function(t) {
27 === t.keyCode && this.doneAnimating && this.overlayActive && this.close()
}
}, {
key: "_makeAncestorsOverflowVisible",
value: function() {
this.ancestorsChanged = o();
for (var t = this.placeholder[0].parentNode; null !== t && !o(t).is(document);) {
var e = o(t);
"visible" !== e.css("overflow") && (e.css("overflow", "visible"), void 0 === this.ancestorsChanged ? this.ancestorsChanged = e : this.ancestorsChanged = this.ancestorsChanged.add(e)), t = t.parentNode
}
}
}, {
key: "_animateImageIn",
value: function() {
var t = this,
e = {
targets: this.el,
height: [this.originalHeight, this.newHeight],
width: [this.originalWidth, this.newWidth],
left: M.getDocumentScrollLeft() + this.windowWidth / 2 - this.placeholder.offset().left - this.newWidth / 2,
top: M.getDocumentScrollTop() + this.windowHeight / 2 - this.placeholder.offset().top - this.newHeight / 2,
duration: this.options.inDuration,
easing: "easeOutQuad",
complete: function() {
t.doneAnimating = !0, "function" == typeof t.options.onOpenEnd && t.options.onOpenEnd.call(t, t.el)
}
};
this.maxWidth = this.$el.css("max-width"), this.maxHeight = this.$el.css("max-height"), "none" !== this.maxWidth && (e.maxWidth = this.newWidth), "none" !== this.maxHeight && (e.maxHeight = this.newHeight), a(e)
}
}, {
key: "_animateImageOut",
value: function() {
var t = this,
e = {
targets: this.el,
width: this.originalWidth,
height: this.originalHeight,
left: 0,
top: 0,
duration: this.options.outDuration,
easing: "easeOutQuad",
complete: function() {
t.placeholder.css({
height: "",
width: "",
position: "",
top: "",
left: ""
}), t.attrWidth && t.$el.attr("width", t.attrWidth), t.attrHeight && t.$el.attr("height", t.attrHeight), t.$el.removeAttr("style"), t.originInlineStyles && t.$el.attr("style", t.originInlineStyles), t.$el.removeClass("active"), t.doneAnimating = !0, t.ancestorsChanged.length && t.ancestorsChanged.css("overflow", ""), "function" == typeof t.options.onCloseEnd && t.options.onCloseEnd.call(t, t.el)
}
};
a(e)
}
}, {
key: "_updateVars",
value: function() {
this.windowWidth = window.innerWidth, this.windowHeight = window.innerHeight, this.caption = this.el.getAttribute("data-caption") || ""
}
}, {
key: "open",
value: function() {
var t = this;
this._updateVars(), this.originalWidth = this.el.getBoundingClientRect().width, this.originalHeight = this.el.getBoundingClientRect().height, this.doneAnimating = !1, this.$el.addClass("active"), this.overlayActive = !0, "function" == typeof this.options.onOpenStart && this.options.onOpenStart.call(this, this.el), this.placeholder.css({
width: this.placeholder[0].getBoundingClientRect().width + "px",
height: this.placeholder[0].getBoundingClientRect().height + "px",
position: "relative",
top: 0,
left: 0
}), this._makeAncestorsOverflowVisible(), this.$el.css({
position: "absolute",
"z-index": 1e3,
"will-change": "left, top, width, height"
}), this.attrWidth = this.$el.attr("width"), this.attrHeight = this.$el.attr("height"), this.attrWidth && (this.$el.css("width", this.attrWidth + "px"), this.$el.removeAttr("width")), this.attrHeight && (this.$el.css("width", this.attrHeight + "px"), this.$el.removeAttr("height")), this.$overlay = o('<div id="materialbox-overlay"></div>').css({
opacity: 0
}).one("click", function() {
t.doneAnimating && t.close()
}), this.$el.before(this.$overlay);
var e = this.$overlay[0].getBoundingClientRect();
this.$overlay.css({
width: this.windowWidth + "px",
height: this.windowHeight + "px",
left: -1 * e.left + "px",
top: -1 * e.top + "px"
}), a.remove(this.el), a.remove(this.$overlay[0]), a({
targets: this.$overlay[0],
opacity: 1,
duration: this.options.inDuration,
easing: "easeOutQuad"
}), "" !== this.caption && (this.$photocaption && a.remove(this.$photoCaption[0]), this.$photoCaption = o('<div class="materialbox-caption"></div>'), this.$photoCaption.text(this.caption), o("body").append(this.$photoCaption), this.$photoCaption.css({
display: "inline"
}), a({
targets: this.$photoCaption[0],
opacity: 1,
duration: this.options.inDuration,
easing: "easeOutQuad"
}));
var i = 0,
n = this.originalWidth / this.windowWidth,
s = this.originalHeight / this.windowHeight;
this.newWidth = 0, this.newHeight = 0, s < n ? (i = this.originalHeight / this.originalWidth, this.newWidth = .9 * this.windowWidth, this.newHeight = .9 * this.windowWidth * i) : (i = this.originalWidth / this.originalHeight, this.newWidth = .9 * this.windowHeight * i, this.newHeight = .9 * this.windowHeight), this._animateImageIn(), this._handleWindowScrollBound = this._handleWindowScroll.bind(this), this._handleWindowResizeBound = this._handleWindowResize.bind(this), this._handleWindowEscapeBound = this._handleWindowEscape.bind(this), window.addEventListener("scroll", this._handleWindowScrollBound), window.addEventListener("resize", this._handleWindowResizeBound), window.addEventListener("keyup", this._handleWindowEscapeBound)
}
}, {
key: "close",
value: function() {
var t = this;
this._updateVars(), this.doneAnimating = !1, "function" == typeof this.options.onCloseStart && this.options.onCloseStart.call(this, this.el), a.remove(this.el), a.remove(this.$overlay[0]), "" !== this.caption && a.remove(this.$photoCaption[0]), window.removeEventListener("scroll", this._handleWindowScrollBound), window.removeEventListener("resize", this._handleWindowResizeBound), window.removeEventListener("keyup", this._handleWindowEscapeBound), a({
targets: this.$overlay[0],
opacity: 0,
duration: this.options.outDuration,
easing: "easeOutQuad",
complete: function() {
t.overlayActive = !1, t.$overlay.remove()
}
}), this._animateImageOut(), "" !== this.caption && a({
targets: this.$photoCaption[0],
opacity: 0,
duration: this.options.outDuration,
easing: "easeOutQuad",
complete: function() {
t.$photoCaption.remove()
}
})
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Materialbox
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
M.Materialbox = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "materialbox", "M_Materialbox")
}(cash, M.anime),
function(s) {
"use strict";
var e = {
responsiveThreshold: 0
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Parallax = i).options = s.extend({}, n.defaults, e), i._enabled = window.innerWidth > i.options.responsiveThreshold, i.$img = i.$el.find("img").first(), i.$img.each(function() {
this.complete && s(this).trigger("load")
}), i._updateParallax(), i._setupEventHandlers(), i._setupStyles(), n._parallaxes.push(i), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
n._parallaxes.splice(n._parallaxes.indexOf(this), 1), this.$img[0].style.transform = "", this._removeEventHandlers(), this.$el[0].M_Parallax = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleImageLoadBound = this._handleImageLoad.bind(this), this.$img[0].addEventListener("load", this._handleImageLoadBound), 0 === n._parallaxes.length && (n._handleScrollThrottled = M.throttle(n._handleScroll, 5), window.addEventListener("scroll", n._handleScrollThrottled), n._handleWindowResizeThrottled = M.throttle(n._handleWindowResize, 5), window.addEventListener("resize", n._handleWindowResizeThrottled))
}
}, {
key: "_removeEventHandlers",
value: function() {
this.$img[0].removeEventListener("load", this._handleImageLoadBound), 0 === n._parallaxes.length && (window.removeEventListener("scroll", n._handleScrollThrottled), window.removeEventListener("resize", n._handleWindowResizeThrottled))
}
}, {
key: "_setupStyles",
value: function() {
this.$img[0].style.opacity = 1
}
}, {
key: "_handleImageLoad",
value: function() {
this._updateParallax()
}
}, {
key: "_updateParallax",
value: function() {
var t = 0 < this.$el.height() ? this.el.parentNode.offsetHeight : 500,
e = this.$img[0].offsetHeight - t,
i = this.$el.offset().top + t,
n = this.$el.offset().top,
s = M.getDocumentScrollTop(),
o = window.innerHeight,
a = e * ((s + o - n) / (t + o));
this._enabled ? s < i && n < s + o && (this.$img[0].style.transform = "translate3D(-50%, " + a + "px, 0)") : this.$img[0].style.transform = ""
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Parallax
}
}, {
key: "_handleScroll",
value: function() {
for (var t = 0; t < n._parallaxes.length; t++) {
var e = n._parallaxes[t];
e._updateParallax.call(e)
}
}
}, {
key: "_handleWindowResize",
value: function() {
for (var t = 0; t < n._parallaxes.length; t++) {
var e = n._parallaxes[t];
e._enabled = window.innerWidth > e.options.responsiveThreshold
}
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
t._parallaxes = [], M.Parallax = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "parallax", "M_Parallax")
}(cash),
function(a, s) {
"use strict";
var e = {
duration: 300,
onShow: null,
swipeable: !1,
responsiveThreshold: 1 / 0
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Tabs = i).options = a.extend({}, n.defaults, e), i.$tabLinks = i.$el.children("li.tab").children("a"), i.index = 0, i._setupActiveTabLink(), i.options.swipeable ? i._setupSwipeableTabs() : i._setupNormalTabs(), i._setTabsAndTabWidth(), i._createIndicator(), i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this._indicator.parentNode.removeChild(this._indicator), this.options.swipeable ? this._teardownSwipeableTabs() : this._teardownNormalTabs(), this.$el[0].M_Tabs = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleWindowResizeBound = this._handleWindowResize.bind(this), window.addEventListener("resize", this._handleWindowResizeBound), this._handleTabClickBound = this._handleTabClick.bind(this), this.el.addEventListener("click", this._handleTabClickBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
window.removeEventListener("resize", this._handleWindowResizeBound), this.el.removeEventListener("click", this._handleTabClickBound)
}
}, {
key: "_handleWindowResize",
value: function() {
this._setTabsAndTabWidth(), 0 !== this.tabWidth && 0 !== this.tabsWidth && (this._indicator.style.left = this._calcLeftPos(this.$activeTabLink) + "px", this._indicator.style.right = this._calcRightPos(this.$activeTabLink) + "px")
}
}, {
key: "_handleTabClick",
value: function(t) {
var e = this,
i = a(t.target).closest("li.tab"),
n = a(t.target).closest("a");
if (n.length && n.parent().hasClass("tab"))
if (i.hasClass("disabled")) t.preventDefault();
else if (!n.attr("target")) {
this.$activeTabLink.removeClass("active");
var s = this.$content;
this.$activeTabLink = n, this.$content = a(M.escapeHash(n[0].hash)), this.$tabLinks = this.$el.children("li.tab").children("a"), this.$activeTabLink.addClass("active");
var o = this.index;
this.index = Math.max(this.$tabLinks.index(n), 0), this.options.swipeable ? this._tabsCarousel && this._tabsCarousel.set(this.index, function() {
"function" == typeof e.options.onShow && e.options.onShow.call(e, e.$content[0])
}) : this.$content.length && (this.$content[0].style.display = "block", this.$content.addClass("active"), "function" == typeof this.options.onShow && this.options.onShow.call(this, this.$content[0]), s.length && !s.is(this.$content) && (s[0].style.display = "none", s.removeClass("active"))), this._setTabsAndTabWidth(), this._animateIndicator(o), t.preventDefault()
}
}
}, {
key: "_createIndicator",
value: function() {
var t = this,
e = document.createElement("li");
e.classList.add("indicator"), this.el.appendChild(e), this._indicator = e, setTimeout(function() {
t._indicator.style.left = t._calcLeftPos(t.$activeTabLink) + "px", t._indicator.style.right = t._calcRightPos(t.$activeTabLink) + "px"
}, 0)
}
}, {
key: "_setupActiveTabLink",
value: function() {
this.$activeTabLink = a(this.$tabLinks.filter('[href="' + location.hash + '"]')), 0 === this.$activeTabLink.length && (this.$activeTabLink = this.$el.children("li.tab").children("a.active").first()), 0 === this.$activeTabLink.length && (this.$activeTabLink = this.$el.children("li.tab").children("a").first()), this.$tabLinks.removeClass("active"), this.$activeTabLink[0].classList.add("active"), this.index = Math.max(this.$tabLinks.index(this.$activeTabLink), 0), this.$activeTabLink.length && (this.$content = a(M.escapeHash(this.$activeTabLink[0].hash)), this.$content.addClass("active"))
}
}, {
key: "_setupSwipeableTabs",
value: function() {
var i = this;
window.innerWidth > this.options.responsiveThreshold && (this.options.swipeable = !1);
var n = a();
this.$tabLinks.each(function(t) {
var e = a(M.escapeHash(t.hash));
e.addClass("carousel-item"), n = n.add(e)
});
var t = a('<div class="tabs-content carousel carousel-slider"></div>');
n.first().before(t), t.append(n), n[0].style.display = "";
var e = this.$activeTabLink.closest(".tab").index();
this._tabsCarousel = M.Carousel.init(t[0], {
fullWidth: !0,
noWrap: !0,
onCycleTo: function(t) {
var e = i.index;
i.index = a(t).index(), i.$activeTabLink.removeClass("active"), i.$activeTabLink = i.$tabLinks.eq(i.index), i.$activeTabLink.addClass("active"), i._animateIndicator(e), "function" == typeof i.options.onShow && i.options.onShow.call(i, i.$content[0])
}
}), this._tabsCarousel.set(e)
}
}, {
key: "_teardownSwipeableTabs",
value: function() {
var t = this._tabsCarousel.$el;
this._tabsCarousel.destroy(), t.after(t.children()), t.remove()
}
}, {
key: "_setupNormalTabs",
value: function() {
this.$tabLinks.not(this.$activeTabLink).each(function(t) {
if (t.hash) {
var e = a(M.escapeHash(t.hash));
e.length && (e[0].style.display = "none")
}
})
}
}, {
key: "_teardownNormalTabs",
value: function() {
this.$tabLinks.each(function(t) {
if (t.hash) {
var e = a(M.escapeHash(t.hash));
e.length && (e[0].style.display = "")
}
})
}
}, {
key: "_setTabsAndTabWidth",
value: function() {
this.tabsWidth = this.$el.width(), this.tabWidth = Math.max(this.tabsWidth, this.el.scrollWidth) / this.$tabLinks.length
}
}, {
key: "_calcRightPos",
value: function(t) {
return Math.ceil(this.tabsWidth - t.position().left - t[0].getBoundingClientRect().width)
}
}, {
key: "_calcLeftPos",
value: function(t) {
return Math.floor(t.position().left)
}
}, {
key: "updateTabIndicator",
value: function() {
this._setTabsAndTabWidth(), this._animateIndicator(this.index)
}
}, {
key: "_animateIndicator",
value: function(t) {
var e = 0,
i = 0;
0 <= this.index - t ? e = 90 : i = 90;
var n = {
targets: this._indicator,
left: {
value: this._calcLeftPos(this.$activeTabLink),
delay: e
},
right: {
value: this._calcRightPos(this.$activeTabLink),
delay: i
},
duration: this.options.duration,
easing: "easeOutQuad"
};
s.remove(this._indicator), s(n)
}
}, {
key: "select",
value: function(t) {
var e = this.$tabLinks.filter('[href="#' + t + '"]');
e.length && e.trigger("click")
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Tabs
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
M.Tabs = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "tabs", "M_Tabs")
}(cash, M.anime),
function(d, e) {
"use strict";
var i = {
exitDelay: 200,
enterDelay: 0,
html: null,
margin: 5,
inDuration: 250,
outDuration: 200,
position: "bottom",
transitionMovement: 10
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Tooltip = i).options = d.extend({}, n.defaults, e), i.isOpen = !1, i.isHovered = !1, i.isFocused = !1, i._appendTooltipEl(), i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
d(this.tooltipEl).remove(), this._removeEventHandlers(), this.el.M_Tooltip = void 0
}
}, {
key: "_appendTooltipEl",
value: function() {
var t = document.createElement("div");
t.classList.add("material-tooltip"), this.tooltipEl = t;
var e = document.createElement("div");
e.classList.add("tooltip-content"), e.innerHTML = this.options.html, t.appendChild(e), document.body.appendChild(t)
}
}, {
key: "_updateTooltipContent",
value: function() {
this.tooltipEl.querySelector(".tooltip-content").innerHTML = this.options.html
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleMouseEnterBound = this._handleMouseEnter.bind(this), this._handleMouseLeaveBound = this._handleMouseLeave.bind(this), this._handleFocusBound = this._handleFocus.bind(this), this._handleBlurBound = this._handleBlur.bind(this), this.el.addEventListener("mouseenter", this._handleMouseEnterBound), this.el.addEventListener("mouseleave", this._handleMouseLeaveBound), this.el.addEventListener("focus", this._handleFocusBound, !0), this.el.addEventListener("blur", this._handleBlurBound, !0)
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("mouseenter", this._handleMouseEnterBound), this.el.removeEventListener("mouseleave", this._handleMouseLeaveBound), this.el.removeEventListener("focus", this._handleFocusBound, !0), this.el.removeEventListener("blur", this._handleBlurBound, !0)
}
}, {
key: "open",
value: function(t) {
this.isOpen || (t = void 0 === t || void 0, this.isOpen = !0, this.options = d.extend({}, this.options, this._getAttributeOptions()), this._updateTooltipContent(), this._setEnterDelayTimeout(t))
}
}, {
key: "close",
value: function() {
this.isOpen && (this.isHovered = !1, this.isFocused = !1, this.isOpen = !1, this._setExitDelayTimeout())
}
}, {
key: "_setExitDelayTimeout",
value: function() {
var t = this;
clearTimeout(this._exitDelayTimeout), this._exitDelayTimeout = setTimeout(function() {
t.isHovered || t.isFocused || t._animateOut()
}, this.options.exitDelay)
}
}, {
key: "_setEnterDelayTimeout",
value: function(t) {
var e = this;
clearTimeout(this._enterDelayTimeout), this._enterDelayTimeout = setTimeout(function() {
(e.isHovered || e.isFocused || t) && e._animateIn()
}, this.options.enterDelay)
}
}, {
key: "_positionTooltip",
value: function() {
var t, e = this.el,
i = this.tooltipEl,
n = e.offsetHeight,
s = e.offsetWidth,
o = i.offsetHeight,
a = i.offsetWidth,
r = this.options.margin,
l = void 0,
h = void 0;
this.xMovement = 0, this.yMovement = 0, l = e.getBoundingClientRect().top + M.getDocumentScrollTop(), h = e.getBoundingClientRect().left + M.getDocumentScrollLeft(), "top" === this.options.position ? (l += -o - r, h += s / 2 - a / 2, this.yMovement = -this.options.transitionMovement) : "right" === this.options.position ? (l += n / 2 - o / 2, h += s + r, this.xMovement = this.options.transitionMovement) : "left" === this.options.position ? (l += n / 2 - o / 2, h += -a - r, this.xMovement = -this.options.transitionMovement) : (l += n + r, h += s / 2 - a / 2, this.yMovement = this.options.transitionMovement), t = this._repositionWithinScreen(h, l, a, o), d(i).css({
top: t.y + "px",
left: t.x + "px"
})
}
}, {
key: "_repositionWithinScreen",
value: function(t, e, i, n) {
var s = M.getDocumentScrollLeft(),
o = M.getDocumentScrollTop(),
a = t - s,
r = e - o,
l = {
left: a,
top: r,
width: i,
height: n
},
h = this.options.margin + this.options.transitionMovement,
d = M.checkWithinContainer(document.body, l, h);
return d.left ? a = h : d.right && (a -= a + i - window.innerWidth), d.top ? r = h : d.bottom && (r -= r + n - window.innerHeight), {
x: a + s,
y: r + o
}
}
}, {
key: "_animateIn",
value: function() {
this._positionTooltip(), this.tooltipEl.style.visibility = "visible", e.remove(this.tooltipEl), e({
targets: this.tooltipEl,
opacity: 1,
translateX: this.xMovement,
translateY: this.yMovement,
duration: this.options.inDuration,
easing: "easeOutCubic"
})
}
}, {
key: "_animateOut",
value: function() {
e.remove(this.tooltipEl), e({
targets: this.tooltipEl,
opacity: 0,
translateX: 0,
translateY: 0,
duration: this.options.outDuration,
easing: "easeOutCubic"
})
}
}, {
key: "_handleMouseEnter",
value: function() {
this.isHovered = !0, this.isFocused = !1, this.open(!1)
}
}, {
key: "_handleMouseLeave",
value: function() {
this.isHovered = !1, this.isFocused = !1, this.close()
}
}, {
key: "_handleFocus",
value: function() {
M.tabPressed && (this.isFocused = !0, this.open(!1))
}
}, {
key: "_handleBlur",
value: function() {
this.isFocused = !1, this.close()
}
}, {
key: "_getAttributeOptions",
value: function() {
var t = {},
e = this.el.getAttribute("data-tooltip"),
i = this.el.getAttribute("data-position");
return e && (t.html = e), i && (t.position = i), t
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Tooltip
}
}, {
key: "defaults",
get: function() {
return i
}
}]), n
}();
M.Tooltip = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "tooltip", "M_Tooltip")
}(cash, M.anime),
function(i) {
"use strict";
var t = t || {},
e = document.querySelectorAll.bind(document);
function m(t) {
var e = "";
for (var i in t) t.hasOwnProperty(i) && (e += i + ":" + t[i] + ";");
return e
}
var g = {
duration: 750,
show: function(t, e) {
if (2 === t.button) return !1;
var i = e || this,
n = document.createElement("div");
n.className = "waves-ripple", i.appendChild(n);
var s, o, a, r, l, h, d, u = (h = {
top: 0,
left: 0
}, d = (s = i) && s.ownerDocument, o = d.documentElement, void 0 !== s.getBoundingClientRect && (h = s.getBoundingClientRect()), a = null !== (l = r = d) && l === l.window ? r : 9 === r.nodeType && r.defaultView, {
top: h.top + a.pageYOffset - o.clientTop,
left: h.left + a.pageXOffset - o.clientLeft
}),
c = t.pageY - u.top,
p = t.pageX - u.left,
v = "scale(" + i.clientWidth / 100 * 10 + ")";
"touches" in t && (c = t.touches[0].pageY - u.top, p = t.touches[0].pageX - u.left), n.setAttribute("data-hold", Date.now()), n.setAttribute("data-scale", v), n.setAttribute("data-x", p), n.setAttribute("data-y", c);
var f = {
top: c + "px",
left: p + "px"
};
n.className = n.className + " waves-notransition", n.setAttribute("style", m(f)), n.className = n.className.replace("waves-notransition", ""), f["-webkit-transform"] = v, f["-moz-transform"] = v, f["-ms-transform"] = v, f["-o-transform"] = v, f.transform = v, f.opacity = "1", f["-webkit-transition-duration"] = g.duration + "ms", f["-moz-transition-duration"] = g.duration + "ms", f["-o-transition-duration"] = g.duration + "ms", f["transition-duration"] = g.duration + "ms", f["-webkit-transition-timing-function"] = "cubic-bezier(0.250, 0.460, 0.450, 0.940)", f["-moz-transition-timing-function"] = "cubic-bezier(0.250, 0.460, 0.450, 0.940)", f["-o-transition-timing-function"] = "cubic-bezier(0.250, 0.460, 0.450, 0.940)", f["transition-timing-function"] = "cubic-bezier(0.250, 0.460, 0.450, 0.940)", n.setAttribute("style", m(f))
},
hide: function(t) {
l.touchup(t);
var e = this,
i = (e.clientWidth, null),
n = e.getElementsByClassName("waves-ripple");
if (!(0 < n.length)) return !1;
var s = (i = n[n.length - 1]).getAttribute("data-x"),
o = i.getAttribute("data-y"),
a = i.getAttribute("data-scale"),
r = 350 - (Date.now() - Number(i.getAttribute("data-hold")));
r < 0 && (r = 0), setTimeout(function() {
var t = {
top: o + "px",
left: s + "px",
opacity: "0",
"-webkit-transition-duration": g.duration + "ms",
"-moz-transition-duration": g.duration + "ms",
"-o-transition-duration": g.duration + "ms",
"transition-duration": g.duration + "ms",
"-webkit-transform": a,
"-moz-transform": a,
"-ms-transform": a,
"-o-transform": a,
transform: a
};
i.setAttribute("style", m(t)), setTimeout(function() {
try {
e.removeChild(i)
} catch (t) {
return !1
}
}, g.duration)
}, r)
},
wrapInput: function(t) {
for (var e = 0; e < t.length; e++) {
var i = t[e];
if ("input" === i.tagName.toLowerCase()) {
var n = i.parentNode;
if ("i" === n.tagName.toLowerCase() && -1 !== n.className.indexOf("waves-effect")) continue;
var s = document.createElement("i");
s.className = i.className + " waves-input-wrapper";
var o = i.getAttribute("style");
o || (o = ""), s.setAttribute("style", o), i.className = "waves-button-input", i.removeAttribute("style"), n.replaceChild(s, i), s.appendChild(i)
}
}
}
},
l = {
touches: 0,
allowEvent: function(t) {
var e = !0;
return "touchstart" === t.type ? l.touches += 1 : "touchend" === t.type || "touchcancel" === t.type ? setTimeout(function() {
0 < l.touches && (l.touches -= 1)
}, 500) : "mousedown" === t.type && 0 < l.touches && (e = !1), e
},
touchup: function(t) {
l.allowEvent(t)
}
};
function n(t) {
var e = function(t) {
if (!1 === l.allowEvent(t)) return null;
for (var e = null, i = t.target || t.srcElement; null !== i.parentNode;) {
if (!(i instanceof SVGElement) && -1 !== i.className.indexOf("waves-effect")) {
e = i;
break
}
i = i.parentNode
}
return e
}(t);
null !== e && (g.show(t, e), "ontouchstart" in i && (e.addEventListener("touchend", g.hide, !1), e.addEventListener("touchcancel", g.hide, !1)), e.addEventListener("mouseup", g.hide, !1), e.addEventListener("mouseleave", g.hide, !1), e.addEventListener("dragend", g.hide, !1))
}
t.displayEffect = function(t) {
"duration" in (t = t || {}) && (g.duration = t.duration), g.wrapInput(e(".waves-effect")), "ontouchstart" in i && document.body.addEventListener("touchstart", n, !1), document.body.addEventListener("mousedown", n, !1)
}, t.attach = function(t) {
"input" === t.tagName.toLowerCase() && (g.wrapInput([t]), t = t.parentNode), "ontouchstart" in i && t.addEventListener("touchstart", n, !1), t.addEventListener("mousedown", n, !1)
}, i.Waves = t, document.addEventListener("DOMContentLoaded", function() {
t.displayEffect()
}, !1)
}(window),
function(i, n) {
"use strict";
var t = {
html: "",
displayLength: 4e3,
inDuration: 300,
outDuration: 375,
classes: "",
completeCallback: null,
activationPercent: .8
},
e = function() {
function s(t) {
_classCallCheck(this, s), this.options = i.extend({}, s.defaults, t), this.message = this.options.html, this.panning = !1, this.timeRemaining = this.options.displayLength, 0 === s._toasts.length && s._createContainer(), s._toasts.push(this);
var e = this._createToast();
(e.M_Toast = this).el = e, this.$el = i(e), this._animateIn(), this._setTimer()
}
return _createClass(s, [{
key: "_createToast",
value: function() {
var t = document.createElement("div");
return t.classList.add("toast"), this.options.classes.length && i(t).addClass(this.options.classes), ("object" == typeof HTMLElement ? this.message instanceof HTMLElement : this.message && "object" == typeof this.message && null !== this.message && 1 === this.message.nodeType && "string" == typeof this.message.nodeName) ? t.appendChild(this.message) : this.message.jquery ? i(t).append(this.message[0]) : t.innerHTML = this.message, s._container.appendChild(t), t
}
}, {
key: "_animateIn",
value: function() {
n({
targets: this.el,
top: 0,
opacity: 1,
duration: this.options.inDuration,
easing: "easeOutCubic"
})
}
}, {
key: "_setTimer",
value: function() {
var t = this;
this.timeRemaining !== 1 / 0 && (this.counterInterval = setInterval(function() {
t.panning || (t.timeRemaining -= 20), t.timeRemaining <= 0 && t.dismiss()
}, 20))
}
}, {
key: "dismiss",
value: function() {
var t = this;
window.clearInterval(this.counterInterval);
var e = this.el.offsetWidth * this.options.activationPercent;
this.wasSwiped && (this.el.style.transition = "transform .05s, opacity .05s", this.el.style.transform = "translateX(" + e + "px)", this.el.style.opacity = 0), n({
targets: this.el,
opacity: 0,
marginTop: -40,
duration: this.options.outDuration,
easing: "easeOutExpo",
complete: function() {
"function" == typeof t.options.completeCallback && t.options.completeCallback(), t.$el.remove(), s._toasts.splice(s._toasts.indexOf(t), 1), 0 === s._toasts.length && s._removeContainer()
}
})
}
}], [{
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Toast
}
}, {
key: "_createContainer",
value: function() {
var t = document.createElement("div");
t.setAttribute("id", "toast-container"), t.addEventListener("touchstart", s._onDragStart), t.addEventListener("touchmove", s._onDragMove), t.addEventListener("touchend", s._onDragEnd), t.addEventListener("mousedown", s._onDragStart), document.addEventListener("mousemove", s._onDragMove), document.addEventListener("mouseup", s._onDragEnd), document.body.appendChild(t), s._container = t
}
}, {
key: "_removeContainer",
value: function() {
document.removeEventListener("mousemove", s._onDragMove), document.removeEventListener("mouseup", s._onDragEnd), i(s._container).remove(), s._container = null
}
}, {
key: "_onDragStart",
value: function(t) {
if (t.target && i(t.target).closest(".toast").length) {
var e = i(t.target).closest(".toast")[0].M_Toast;
e.panning = !0, (s._draggedToast = e).el.classList.add("panning"), e.el.style.transition = "", e.startingXPos = s._xPos(t), e.time = Date.now(), e.xPos = s._xPos(t)
}
}
}, {
key: "_onDragMove",
value: function(t) {
if (s._draggedToast) {
t.preventDefault();
var e = s._draggedToast;
e.deltaX = Math.abs(e.xPos - s._xPos(t)), e.xPos = s._xPos(t), e.velocityX = e.deltaX / (Date.now() - e.time), e.time = Date.now();
var i = e.xPos - e.startingXPos,
n = e.el.offsetWidth * e.options.activationPercent;
e.el.style.transform = "translateX(" + i + "px)", e.el.style.opacity = 1 - Math.abs(i / n)
}
}
}, {
key: "_onDragEnd",
value: function() {
if (s._draggedToast) {
var t = s._draggedToast;
t.panning = !1, t.el.classList.remove("panning");
var e = t.xPos - t.startingXPos,
i = t.el.offsetWidth * t.options.activationPercent;
Math.abs(e) > i || 1 < t.velocityX ? (t.wasSwiped = !0, t.dismiss()) : (t.el.style.transition = "transform .2s, opacity .2s", t.el.style.transform = "", t.el.style.opacity = ""), s._draggedToast = null
}
}
}, {
key: "_xPos",
value: function(t) {
return t.targetTouches && 1 <= t.targetTouches.length ? t.targetTouches[0].clientX : t.clientX
}
}, {
key: "dismissAll",
value: function() {
for (var t in s._toasts) s._toasts[t].dismiss()
}
}, {
key: "defaults",
get: function() {
return t
}
}]), s
}();
e._toasts = [], e._container = null, e._draggedToast = null, M.Toast = e, M.toast = function(t) {
return new e(t)
}
}(cash, M.anime),
function(s, o) {
"use strict";
var e = {
edge: "left",
draggable: !0,
inDuration: 250,
outDuration: 200,
onOpenStart: null,
onOpenEnd: null,
onCloseStart: null,
onCloseEnd: null,
preventScrolling: !0
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Sidenav = i).id = i.$el.attr("id"), i.options = s.extend({}, n.defaults, e), i.isOpen = !1, i.isFixed = i.el.classList.contains("sidenav-fixed"), i.isDragged = !1, i.lastWindowWidth = window.innerWidth, i.lastWindowHeight = window.innerHeight, i._createOverlay(), i._createDragTarget(), i._setupEventHandlers(), i._setupClasses(), i._setupFixed(), n._sidenavs.push(i), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this._enableBodyScrolling(), this._overlay.parentNode.removeChild(this._overlay), this.dragTarget.parentNode.removeChild(this.dragTarget), this.el.M_Sidenav = void 0, this.el.style.transform = "";
var t = n._sidenavs.indexOf(this);
0 <= t && n._sidenavs.splice(t, 1)
}
}, {
key: "_createOverlay",
value: function() {
var t = document.createElement("div");
this._closeBound = this.close.bind(this), t.classList.add("sidenav-overlay"), t.addEventListener("click", this._closeBound), document.body.appendChild(t), this._overlay = t
}
}, {
key: "_setupEventHandlers",
value: function() {
0 === n._sidenavs.length && document.body.addEventListener("click", this._handleTriggerClick), this._handleDragTargetDragBound = this._handleDragTargetDrag.bind(this), this._handleDragTargetReleaseBound = this._handleDragTargetRelease.bind(this), this._handleCloseDragBound = this._handleCloseDrag.bind(this), this._handleCloseReleaseBound = this._handleCloseRelease.bind(this), this._handleCloseTriggerClickBound = this._handleCloseTriggerClick.bind(this), this.dragTarget.addEventListener("touchmove", this._handleDragTargetDragBound), this.dragTarget.addEventListener("touchend", this._handleDragTargetReleaseBound), this._overlay.addEventListener("touchmove", this._handleCloseDragBound), this._overlay.addEventListener("touchend", this._handleCloseReleaseBound), this.el.addEventListener("touchmove", this._handleCloseDragBound), this.el.addEventListener("touchend", this._handleCloseReleaseBound), this.el.addEventListener("click", this._handleCloseTriggerClickBound), this.isFixed && (this._handleWindowResizeBound = this._handleWindowResize.bind(this), window.addEventListener("resize", this._handleWindowResizeBound))
}
}, {
key: "_removeEventHandlers",
value: function() {
1 === n._sidenavs.length && document.body.removeEventListener("click", this._handleTriggerClick), this.dragTarget.removeEventListener("touchmove", this._handleDragTargetDragBound), this.dragTarget.removeEventListener("touchend", this._handleDragTargetReleaseBound), this._overlay.removeEventListener("touchmove", this._handleCloseDragBound), this._overlay.removeEventListener("touchend", this._handleCloseReleaseBound), this.el.removeEventListener("touchmove", this._handleCloseDragBound), this.el.removeEventListener("touchend", this._handleCloseReleaseBound), this.el.removeEventListener("click", this._handleCloseTriggerClickBound), this.isFixed && window.removeEventListener("resize", this._handleWindowResizeBound)
}
}, {
key: "_handleTriggerClick",
value: function(t) {
var e = s(t.target).closest(".sidenav-trigger");
if (t.target && e.length) {
var i = M.getIdFromTrigger(e[0]),
n = document.getElementById(i).M_Sidenav;
n && n.open(e), t.preventDefault()
}
}
}, {
key: "_startDrag",
value: function(t) {
var e = t.targetTouches[0].clientX;
this.isDragged = !0, this._startingXpos = e, this._xPos = this._startingXpos, this._time = Date.now(), this._width = this.el.getBoundingClientRect().width, this._overlay.style.display = "block", this._initialScrollTop = this.isOpen ? this.el.scrollTop : M.getDocumentScrollTop(), this._verticallyScrolling = !1, o.remove(this.el), o.remove(this._overlay)
}
}, {
key: "_dragMoveUpdate",
value: function(t) {
var e = t.targetTouches[0].clientX,
i = this.isOpen ? this.el.scrollTop : M.getDocumentScrollTop();
this.deltaX = Math.abs(this._xPos - e), this._xPos = e, this.velocityX = this.deltaX / (Date.now() - this._time), this._time = Date.now(), this._initialScrollTop !== i && (this._verticallyScrolling = !0)
}
}, {
key: "_handleDragTargetDrag",
value: function(t) {
if (this.options.draggable && !this._isCurrentlyFixed() && !this._verticallyScrolling) {
this.isDragged || this._startDrag(t), this._dragMoveUpdate(t);
var e = this._xPos - this._startingXpos,
i = 0 < e ? "right" : "left";
e = Math.min(this._width, Math.abs(e)), this.options.edge === i && (e = 0);
var n = e,
s = "translateX(-100%)";
"right" === this.options.edge && (s = "translateX(100%)", n = -n), this.percentOpen = Math.min(1, e / this._width), this.el.style.transform = s + " translateX(" + n + "px)", this._overlay.style.opacity = this.percentOpen
}
}
}, {
key: "_handleDragTargetRelease",
value: function() {
this.isDragged && (.2 < this.percentOpen ? this.open() : this._animateOut(), this.isDragged = !1, this._verticallyScrolling = !1)
}
}, {
key: "_handleCloseDrag",
value: function(t) {
if (this.isOpen) {
if (!this.options.draggable || this._isCurrentlyFixed() || this._verticallyScrolling) return;
this.isDragged || this._startDrag(t), this._dragMoveUpdate(t);
var e = this._xPos - this._startingXpos,
i = 0 < e ? "right" : "left";
e = Math.min(this._width, Math.abs(e)), this.options.edge !== i && (e = 0);
var n = -e;
"right" === this.options.edge && (n = -n), this.percentOpen = Math.min(1, 1 - e / this._width), this.el.style.transform = "translateX(" + n + "px)", this._overlay.style.opacity = this.percentOpen
}
}
}, {
key: "_handleCloseRelease",
value: function() {
this.isOpen && this.isDragged && (.8 < this.percentOpen ? this._animateIn() : this.close(), this.isDragged = !1, this._verticallyScrolling = !1)
}
}, {
key: "_handleCloseTriggerClick",
value: function(t) {
s(t.target).closest(".sidenav-close").length && !this._isCurrentlyFixed() && this.close()
}
}, {
key: "_handleWindowResize",
value: function() {
this.lastWindowWidth !== window.innerWidth && (992 < window.innerWidth ? this.open() : this.close()), this.lastWindowWidth = window.innerWidth, this.lastWindowHeight = window.innerHeight
}
}, {
key: "_setupClasses",
value: function() {
"right" === this.options.edge && (this.el.classList.add("right-aligned"), this.dragTarget.classList.add("right-aligned"))
}
}, {
key: "_removeClasses",
value: function() {
this.el.classList.remove("right-aligned"), this.dragTarget.classList.remove("right-aligned")
}
}, {
key: "_setupFixed",
value: function() {
this._isCurrentlyFixed() && this.open()
}
}, {
key: "_isCurrentlyFixed",
value: function() {
return this.isFixed && 992 < window.innerWidth
}
}, {
key: "_createDragTarget",
value: function() {
var t = document.createElement("div");
t.classList.add("drag-target"), document.body.appendChild(t), this.dragTarget = t
}
}, {
key: "_preventBodyScrolling",
value: function() {
document.body.style.overflow = "hidden"
}
}, {
key: "_enableBodyScrolling",
value: function() {
document.body.style.overflow = ""
}
}, {
key: "open",
value: function() {
!0 !== this.isOpen && (this.isOpen = !0, "function" == typeof this.options.onOpenStart && this.options.onOpenStart.call(this, this.el), this._isCurrentlyFixed() ? (o.remove(this.el), o({
targets: this.el,
translateX: 0,
duration: 0,
easing: "easeOutQuad"
}), this._enableBodyScrolling(), this._overlay.style.display = "none") : (this.options.preventScrolling && this._preventBodyScrolling(), this.isDragged && 1 == this.percentOpen || this._animateIn()))
}
}, {
key: "close",
value: function() {
if (!1 !== this.isOpen)
if (this.isOpen = !1, "function" == typeof this.options.onCloseStart && this.options.onCloseStart.call(this, this.el), this._isCurrentlyFixed()) {
var t = "left" === this.options.edge ? "-105%" : "105%";
this.el.style.transform = "translateX(" + t + ")"
} else this._enableBodyScrolling(), this.isDragged && 0 == this.percentOpen ? this._overlay.style.display = "none" : this._animateOut()
}
}, {
key: "_animateIn",
value: function() {
this._animateSidenavIn(), this._animateOverlayIn()
}
}, {
key: "_animateSidenavIn",
value: function() {
var t = this,
e = "left" === this.options.edge ? -1 : 1;
this.isDragged && (e = "left" === this.options.edge ? e + this.percentOpen : e - this.percentOpen), o.remove(this.el), o({
targets: this.el,
translateX: [100 * e + "%", 0],
duration: this.options.inDuration,
easing: "easeOutQuad",
complete: function() {
"function" == typeof t.options.onOpenEnd && t.options.onOpenEnd.call(t, t.el)
}
})
}
}, {
key: "_animateOverlayIn",
value: function() {
var t = 0;
this.isDragged ? t = this.percentOpen : s(this._overlay).css({
display: "block"
}), o.remove(this._overlay), o({
targets: this._overlay,
opacity: [t, 1],
duration: this.options.inDuration,
easing: "easeOutQuad"
})
}
}, {
key: "_animateOut",
value: function() {
this._animateSidenavOut(), this._animateOverlayOut()
}
}, {
key: "_animateSidenavOut",
value: function() {
var t = this,
e = "left" === this.options.edge ? -1 : 1,
i = 0;
this.isDragged && (i = "left" === this.options.edge ? e + this.percentOpen : e - this.percentOpen), o.remove(this.el), o({
targets: this.el,
translateX: [100 * i + "%", 105 * e + "%"],
duration: this.options.outDuration,
easing: "easeOutQuad",
complete: function() {
"function" == typeof t.options.onCloseEnd && t.options.onCloseEnd.call(t, t.el)
}
})
}
}, {
key: "_animateOverlayOut",
value: function() {
var t = this;
o.remove(this._overlay), o({
targets: this._overlay,
opacity: 0,
duration: this.options.outDuration,
easing: "easeOutQuad",
complete: function() {
s(t._overlay).css("display", "none")
}
})
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Sidenav
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
t._sidenavs = [], M.Sidenav = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "sidenav", "M_Sidenav")
}(cash, M.anime),
function(o, a) {
"use strict";
var e = {
throttle: 100,
scrollOffset: 200,
activeClass: "active",
getActiveElement: function(t) {
return 'a[href="#' + t + '"]'
}
},
t = function(t) {
function c(t, e) {
_classCallCheck(this, c);
var i = _possibleConstructorReturn(this, (c.__proto__ || Object.getPrototypeOf(c)).call(this, c, t, e));
return (i.el.M_ScrollSpy = i).options = o.extend({}, c.defaults, e), c._elements.push(i), c._count++, c._increment++, i.tickId = -1, i.id = c._increment, i._setupEventHandlers(), i._handleWindowScroll(), i
}
return _inherits(c, Component), _createClass(c, [{
key: "destroy",
value: function() {
c._elements.splice(c._elements.indexOf(this), 1), c._elementsInView.splice(c._elementsInView.indexOf(this), 1), c._visibleElements.splice(c._visibleElements.indexOf(this.$el), 1), c._count--, this._removeEventHandlers(), o(this.options.getActiveElement(this.$el.attr("id"))).removeClass(this.options.activeClass), this.el.M_ScrollSpy = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
var t = M.throttle(this._handleWindowScroll, 200);
this._handleThrottledResizeBound = t.bind(this), this._handleWindowScrollBound = this._handleWindowScroll.bind(this), 1 === c._count && (window.addEventListener("scroll", this._handleWindowScrollBound), window.addEventListener("resize", this._handleThrottledResizeBound), document.body.addEventListener("click", this._handleTriggerClick))
}
}, {
key: "_removeEventHandlers",
value: function() {
0 === c._count && (window.removeEventListener("scroll", this._handleWindowScrollBound), window.removeEventListener("resize", this._handleThrottledResizeBound), document.body.removeEventListener("click", this._handleTriggerClick))
}
}, {
key: "_handleTriggerClick",
value: function(t) {
for (var e = o(t.target), i = c._elements.length - 1; 0 <= i; i--) {
var n = c._elements[i];
if (e.is('a[href="#' + n.$el.attr("id") + '"]')) {
t.preventDefault();
var s = n.$el.offset().top + 1;
a({
targets: [document.documentElement, document.body],
scrollTop: s - n.options.scrollOffset,
duration: 400,
easing: "easeOutCubic"
});
break
}
}
}
}, {
key: "_handleWindowScroll",
value: function() {
c._ticks++;
for (var t = M.getDocumentScrollTop(), e = M.getDocumentScrollLeft(), i = e + window.innerWidth, n = t + window.innerHeight, s = c._findElements(t, i, n, e), o = 0; o < s.length; o++) {
var a = s[o];
a.tickId < 0 && a._enter(), a.tickId = c._ticks
}
for (var r = 0; r < c._elementsInView.length; r++) {
var l = c._elementsInView[r],
h = l.tickId;
0 <= h && h !== c._ticks && (l._exit(), l.tickId = -1)
}
c._elementsInView = s
}
}, {
key: "_enter",
value: function() {
(c._visibleElements = c._visibleElements.filter(function(t) {
return 0 != t.height()
}))[0] ? (o(this.options.getActiveElement(c._visibleElements[0].attr("id"))).removeClass(this.options.activeClass), c._visibleElements[0][0].M_ScrollSpy && this.id < c._visibleElements[0][0].M_ScrollSpy.id ? c._visibleElements.unshift(this.$el) : c._visibleElements.push(this.$el)) : c._visibleElements.push(this.$el), o(this.options.getActiveElement(c._visibleElements[0].attr("id"))).addClass(this.options.activeClass)
}
}, {
key: "_exit",
value: function() {
var e = this;
(c._visibleElements = c._visibleElements.filter(function(t) {
return 0 != t.height()
}))[0] && (o(this.options.getActiveElement(c._visibleElements[0].attr("id"))).removeClass(this.options.activeClass), (c._visibleElements = c._visibleElements.filter(function(t) {
return t.attr("id") != e.$el.attr("id")
}))[0] && o(this.options.getActiveElement(c._visibleElements[0].attr("id"))).addClass(this.options.activeClass))
}
}], [{
key: "init",
value: function(t, e) {
return _get(c.__proto__ || Object.getPrototypeOf(c), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_ScrollSpy
}
}, {
key: "_findElements",
value: function(t, e, i, n) {
for (var s = [], o = 0; o < c._elements.length; o++) {
var a = c._elements[o],
r = t + a.options.scrollOffset || 200;
if (0 < a.$el.height()) {
var l = a.$el.offset().top,
h = a.$el.offset().left,
d = h + a.$el.width(),
u = l + a.$el.height();
!(e < h || d < n || i < l || u < r) && s.push(a)
}
}
return s
}
}, {
key: "defaults",
get: function() {
return e
}
}]), c
}();
t._elements = [], t._elementsInView = [], t._visibleElements = [], t._count = 0, t._increment = 0, t._ticks = 0, M.ScrollSpy = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "scrollSpy", "M_ScrollSpy")
}(cash, M.anime),
function(h) {
"use strict";
var e = {
data: {},
limit: 1 / 0,
onAutocomplete: null,
minLength: 1,
sortFunction: function(t, e, i) {
return t.indexOf(i) - e.indexOf(i)
}
},
t = function(t) {
function s(t, e) {
_classCallCheck(this, s);
var i = _possibleConstructorReturn(this, (s.__proto__ || Object.getPrototypeOf(s)).call(this, s, t, e));
return (i.el.M_Autocomplete = i).options = h.extend({}, s.defaults, e), i.isOpen = !1, i.count = 0, i.activeIndex = -1, i.oldVal, i.$inputField = i.$el.closest(".input-field"), i.$active = h(), i._mousedown = !1, i._setupDropdown(), i._setupEventHandlers(), i
}
return _inherits(s, Component), _createClass(s, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this._removeDropdown(), this.el.M_Autocomplete = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleInputBlurBound = this._handleInputBlur.bind(this), this._handleInputKeyupAndFocusBound = this._handleInputKeyupAndFocus.bind(this), this._handleInputKeydownBound = this._handleInputKeydown.bind(this), this._handleInputClickBound = this._handleInputClick.bind(this), this._handleContainerMousedownAndTouchstartBound = this._handleContainerMousedownAndTouchstart.bind(this), this._handleContainerMouseupAndTouchendBound = this._handleContainerMouseupAndTouchend.bind(this), this.el.addEventListener("blur", this._handleInputBlurBound), this.el.addEventListener("keyup", this._handleInputKeyupAndFocusBound), this.el.addEventListener("focus", this._handleInputKeyupAndFocusBound), this.el.addEventListener("keydown", this._handleInputKeydownBound), this.el.addEventListener("click", this._handleInputClickBound), this.container.addEventListener("mousedown", this._handleContainerMousedownAndTouchstartBound), this.container.addEventListener("mouseup", this._handleContainerMouseupAndTouchendBound), void 0 !== window.ontouchstart && (this.container.addEventListener("touchstart", this._handleContainerMousedownAndTouchstartBound), this.container.addEventListener("touchend", this._handleContainerMouseupAndTouchendBound))
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("blur", this._handleInputBlurBound), this.el.removeEventListener("keyup", this._handleInputKeyupAndFocusBound), this.el.removeEventListener("focus", this._handleInputKeyupAndFocusBound), this.el.removeEventListener("keydown", this._handleInputKeydownBound), this.el.removeEventListener("click", this._handleInputClickBound), this.container.removeEventListener("mousedown", this._handleContainerMousedownAndTouchstartBound), this.container.removeEventListener("mouseup", this._handleContainerMouseupAndTouchendBound), void 0 !== window.ontouchstart && (this.container.removeEventListener("touchstart", this._handleContainerMousedownAndTouchstartBound), this.container.removeEventListener("touchend", this._handleContainerMouseupAndTouchendBound))
}
}, {
key: "_setupDropdown",
value: function() {
var e = this;
this.container = document.createElement("ul"), this.container.id = "autocomplete-options-" + M.guid(), h(this.container).addClass("autocomplete-content dropdown-content"), this.$inputField.append(this.container), this.el.setAttribute("data-target", this.container.id), this.dropdown = M.Dropdown.init(this.el, {
autoFocus: !1,
closeOnClick: !1,
coverTrigger: !1,
onItemClick: function(t) {
e.selectOption(h(t))
}
}), this.el.removeEventListener("click", this.dropdown._handleClickBound)
}
}, {
key: "_removeDropdown",
value: function() {
this.container.parentNode.removeChild(this.container)
}
}, {
key: "_handleInputBlur",
value: function() {
this._mousedown || (this.close(), this._resetAutocomplete())
}
}, {
key: "_handleInputKeyupAndFocus",
value: function(t) {
"keyup" === t.type && (s._keydown = !1), this.count = 0;
var e = this.el.value.toLowerCase();
13 !== t.keyCode && 38 !== t.keyCode && 40 !== t.keyCode && (this.oldVal === e || !M.tabPressed && "focus" === t.type || this.open(), this.oldVal = e)
}
}, {
key: "_handleInputKeydown",
value: function(t) {
s._keydown = !0;
var e = t.keyCode,
i = void 0,
n = h(this.container).children("li").length;
e === M.keys.ENTER && 0 <= this.activeIndex ? (i = h(this.container).children("li").eq(this.activeIndex)).length && (this.selectOption(i), t.preventDefault()) : e !== M.keys.ARROW_UP && e !== M.keys.ARROW_DOWN || (t.preventDefault(), e === M.keys.ARROW_UP && 0 < this.activeIndex && this.activeIndex--, e === M.keys.ARROW_DOWN && this.activeIndex < n - 1 && this.activeIndex++, this.$active.removeClass("active"), 0 <= this.activeIndex && (this.$active = h(this.container).children("li").eq(this.activeIndex), this.$active.addClass("active")))
}
}, {
key: "_handleInputClick",
value: function(t) {
this.open()
}
}, {
key: "_handleContainerMousedownAndTouchstart",
value: function(t) {
this._mousedown = !0
}
}, {
key: "_handleContainerMouseupAndTouchend",
value: function(t) {
this._mousedown = !1
}
}, {
key: "_highlight",
value: function(t, e) {
var i = e.find("img"),
n = e.text().toLowerCase().indexOf("" + t.toLowerCase()),
s = n + t.length - 1,
o = e.text().slice(0, n),
a = e.text().slice(n, s + 1),
r = e.text().slice(s + 1);
e.html("<span>" + o + "<span class='highlight'>" + a + "</span>" + r + "</span>"), i.length && e.prepend(i)
}
}, {
key: "_resetCurrentElement",
value: function() {
this.activeIndex = -1, this.$active.removeClass("active")
}
}, {
key: "_resetAutocomplete",
value: function() {
h(this.container).empty(), this._resetCurrentElement(), this.oldVal = null, this.isOpen = !1, this._mousedown = !1
}
}, {
key: "selectOption",
value: function(t) {
var e = t.text().trim();
this.el.value = e, this.$el.trigger("change"), this._resetAutocomplete(), this.close(), "function" == typeof this.options.onAutocomplete && this.options.onAutocomplete.call(this, e)
}
}, {
key: "_renderDropdown",
value: function(t, i) {
var n = this;
this._resetAutocomplete();
var e = [];
for (var s in t)
if (t.hasOwnProperty(s) && -1 !== s.toLowerCase().indexOf(i)) {
if (this.count >= this.options.limit) break;
var o = {
data: t[s],
key: s
};
e.push(o), this.count++
} if (this.options.sortFunction) {
e.sort(function(t, e) {
return n.options.sortFunction(t.key.toLowerCase(), e.key.toLowerCase(), i.toLowerCase())
})
}
for (var a = 0; a < e.length; a++) {
var r = e[a],
l = h("<li></li>");
r.data ? l.append('<img src="' + r.data + '" class="right circle"><span>' + r.key + "</span>") : l.append("<span>" + r.key + "</span>"), h(this.container).append(l), this._highlight(i, l)
}
}
}, {
key: "open",
value: function() {
var t = this.el.value.toLowerCase();
this._resetAutocomplete(), t.length >= this.options.minLength && (this.isOpen = !0, this._renderDropdown(this.options.data, t)), this.dropdown.isOpen ? this.dropdown.recalculateDimensions() : this.dropdown.open()
}
}, {
key: "close",
value: function() {
this.dropdown.close()
}
}, {
key: "updateData",
value: function(t) {
var e = this.el.value.toLowerCase();
this.options.data = t, this.isOpen && this._renderDropdown(t, e)
}
}], [{
key: "init",
value: function(t, e) {
return _get(s.__proto__ || Object.getPrototypeOf(s), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Autocomplete
}
}, {
key: "defaults",
get: function() {
return e
}
}]), s
}();
t._keydown = !1, M.Autocomplete = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "autocomplete", "M_Autocomplete")
}(cash),
function(d) {
M.updateTextFields = function() {
d("input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea").each(function(t, e) {
var i = d(this);
0 < t.value.length || d(t).is(":focus") || t.autofocus || null !== i.attr("placeholder") ? i.siblings("label").addClass("active") : t.validity ? i.siblings("label").toggleClass("active", !0 === t.validity.badInput) : i.siblings("label").removeClass("active")
})
}, M.validate_field = function(t) {
var e = null !== t.attr("data-length"),
i = parseInt(t.attr("data-length")),
n = t[0].value.length;
0 !== n || !1 !== t[0].validity.badInput || t.is(":required") ? t.hasClass("validate") && (t.is(":valid") && e && n <= i || t.is(":valid") && !e ? (t.removeClass("invalid"), t.addClass("valid")) : (t.removeClass("valid"), t.addClass("invalid"))) : t.hasClass("validate") && (t.removeClass("valid"), t.removeClass("invalid"))
}, M.textareaAutoResize = function(t) {
if (t instanceof Element && (t = d(t)), t.length) {
var e = d(".hiddendiv").first();
e.length || (e = d('<div class="hiddendiv common"></div>'), d("body").append(e));
var i = t.css("font-family"),
n = t.css("font-size"),
s = t.css("line-height"),
o = t.css("padding-top"),
a = t.css("padding-right"),
r = t.css("padding-bottom"),
l = t.css("padding-left");
n && e.css("font-size", n), i && e.css("font-family", i), s && e.css("line-height", s), o && e.css("padding-top", o), a && e.css("padding-right", a), r && e.css("padding-bottom", r), l && e.css("padding-left", l), t.data("original-height") || t.data("original-height", t.height()), "off" === t.attr("wrap") && e.css("overflow-wrap", "normal").css("white-space", "pre"), e.text(t[0].value + "\n");
var h = e.html().replace(/\n/g, "<br>");
e.html(h), 0 < t[0].offsetWidth && 0 < t[0].offsetHeight ? e.css("width", t.width() + "px") : e.css("width", window.innerWidth / 2 + "px"), t.data("original-height") <= e.innerHeight() ? t.css("height", e.innerHeight() + "px") : t[0].value.length < t.data("previous-length") && t.css("height", t.data("original-height") + "px"), t.data("previous-length", t[0].value.length)
} else console.error("No textarea element found")
}, d(document).ready(function() {
var n = "input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea";
d(document).on("change", n, function() {
0 === this.value.length && null === d(this).attr("placeholder") || d(this).siblings("label").addClass("active"), M.validate_field(d(this))
}), d(document).ready(function() {
M.updateTextFields()
}), d(document).on("reset", function(t) {
var e = d(t.target);
e.is("form") && (e.find(n).removeClass("valid").removeClass("invalid"), e.find(n).each(function(t) {
this.value.length && d(this).siblings("label").removeClass("active")
}), setTimeout(function() {
e.find("select").each(function() {
this.M_FormSelect && d(this).trigger("change")
})
}, 0))
}), document.addEventListener("focus", function(t) {
d(t.target).is(n) && d(t.target).siblings("label, .prefix").addClass("active")
}, !0), document.addEventListener("blur", function(t) {
var e = d(t.target);
if (e.is(n)) {
var i = ".prefix";
0 === e[0].value.length && !0 !== e[0].validity.badInput && null === e.attr("placeholder") && (i += ", label"), e.siblings(i).removeClass("active"), M.validate_field(e)
}
}, !0);
d(document).on("keyup", "input[type=radio], input[type=checkbox]", function(t) {
if (t.which === M.keys.TAB) return d(this).addClass("tabbed"), void d(this).one("blur", function(t) {
d(this).removeClass("tabbed")
})
});
var t = ".materialize-textarea";
d(t).each(function() {
var t = d(this);
t.data("original-height", t.height()), t.data("previous-length", this.value.length), M.textareaAutoResize(t)
}), d(document).on("keyup", t, function() {
M.textareaAutoResize(d(this))
}), d(document).on("keydown", t, function() {
M.textareaAutoResize(d(this))
}), d(document).on("change", '.file-field input[type="file"]', function() {
for (var t = d(this).closest(".file-field").find("input.file-path"), e = d(this)[0].files, i = [], n = 0; n < e.length; n++) i.push(e[n].name);
t[0].value = i.join(", "), t.trigger("change")
})
})
}(cash),
function(s, o) {
"use strict";
var e = {
indicators: !0,
height: 400,
duration: 500,
interval: 6e3
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Slider = i).options = s.extend({}, n.defaults, e), i.$slider = i.$el.find(".slides"), i.$slides = i.$slider.children("li"), i.activeIndex = i.$slides.filter(function(t) {
return s(t).hasClass("active")
}).first().index(), -1 != i.activeIndex && (i.$active = i.$slides.eq(i.activeIndex)), i._setSliderHeight(), i.$slides.find(".caption").each(function(t) {
i._animateCaptionIn(t, 0)
}), i.$slides.find("img").each(function(t) {
var e = "";
s(t).attr("src") !== e && (s(t).css("background-image", 'url("' + s(t).attr("src") + '")'), s(t).attr("src", e))
}), i._setupIndicators(), i.$active ? i.$active.css("display", "block") : (i.$slides.first().addClass("active"), o({
targets: i.$slides.first()[0],
opacity: 1,
duration: i.options.duration,
easing: "easeOutQuad"
}), i.activeIndex = 0, i.$active = i.$slides.eq(i.activeIndex), i.options.indicators && i.$indicators.eq(i.activeIndex).addClass("active")), i.$active.find("img").each(function(t) {
o({
targets: i.$active.find(".caption")[0],
opacity: 1,
translateX: 0,
translateY: 0,
duration: i.options.duration,
easing: "easeOutQuad"
})
}), i._setupEventHandlers(), i.start(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this.pause(), this._removeIndicators(), this._removeEventHandlers(), this.el.M_Slider = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
var e = this;
this._handleIntervalBound = this._handleInterval.bind(this), this._handleIndicatorClickBound = this._handleIndicatorClick.bind(this), this.options.indicators && this.$indicators.each(function(t) {
t.addEventListener("click", e._handleIndicatorClickBound)
})
}
}, {
key: "_removeEventHandlers",
value: function() {
var e = this;
this.options.indicators && this.$indicators.each(function(t) {
t.removeEventListener("click", e._handleIndicatorClickBound)
})
}
}, {
key: "_handleIndicatorClick",
value: function(t) {
var e = s(t.target).index();
this.set(e)
}
}, {
key: "_handleInterval",
value: function() {
var t = this.$slider.find(".active").index();
this.$slides.length === t + 1 ? t = 0 : t += 1, this.set(t)
}
}, {
key: "_animateCaptionIn",
value: function(t, e) {
var i = {
targets: t,
opacity: 0,
duration: e,
easing: "easeOutQuad"
};
s(t).hasClass("center-align") ? i.translateY = -100 : s(t).hasClass("right-align") ? i.translateX = 100 : s(t).hasClass("left-align") && (i.translateX = -100), o(i)
}
}, {
key: "_setSliderHeight",
value: function() {
this.$el.hasClass("fullscreen") || (this.options.indicators ? this.$el.css("height", this.options.height + 40 + "px") : this.$el.css("height", this.options.height + "px"), this.$slider.css("height", this.options.height + "px"))
}
}, {
key: "_setupIndicators",
value: function() {
var n = this;
this.options.indicators && (this.$indicators = s('<ul class="indicators"></ul>'), this.$slides.each(function(t, e) {
var i = s('<li class="indicator-item"></li>');
n.$indicators.append(i[0])
}), this.$el.append(this.$indicators[0]), this.$indicators = this.$indicators.children("li.indicator-item"))
}
}, {
key: "_removeIndicators",
value: function() {
this.$el.find("ul.indicators").remove()
}
}, {
key: "set",
value: function(t) {
var e = this;
if (t >= this.$slides.length ? t = 0 : t < 0 && (t = this.$slides.length - 1), this.activeIndex != t) {
this.$active = this.$slides.eq(this.activeIndex);
var i = this.$active.find(".caption");
this.$active.removeClass("active"), o({
targets: this.$active[0],
opacity: 0,
duration: this.options.duration,
easing: "easeOutQuad",
complete: function() {
e.$slides.not(".active").each(function(t) {
o({
targets: t,
opacity: 0,
translateX: 0,
translateY: 0,
duration: 0,
easing: "easeOutQuad"
})
})
}
}), this._animateCaptionIn(i[0], this.options.duration), this.options.indicators && (this.$indicators.eq(this.activeIndex).removeClass("active"), this.$indicators.eq(t).addClass("active")), o({
targets: this.$slides.eq(t)[0],
opacity: 1,
duration: this.options.duration,
easing: "easeOutQuad"
}), o({
targets: this.$slides.eq(t).find(".caption")[0],
opacity: 1,
translateX: 0,
translateY: 0,
duration: this.options.duration,
delay: this.options.duration,
easing: "easeOutQuad"
}), this.$slides.eq(t).addClass("active"), this.activeIndex = t, this.start()
}
}
}, {
key: "pause",
value: function() {
clearInterval(this.interval)
}
}, {
key: "start",
value: function() {
clearInterval(this.interval), this.interval = setInterval(this._handleIntervalBound, this.options.duration + this.options.interval)
}
}, {
key: "next",
value: function() {
var t = this.activeIndex + 1;
t >= this.$slides.length ? t = 0 : t < 0 && (t = this.$slides.length - 1), this.set(t)
}
}, {
key: "prev",
value: function() {
var t = this.activeIndex - 1;
t >= this.$slides.length ? t = 0 : t < 0 && (t = this.$slides.length - 1), this.set(t)
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Slider
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
M.Slider = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "slider", "M_Slider")
}(cash, M.anime),
function(n, s) {
n(document).on("click", ".card", function(t) {
if (n(this).children(".card-reveal").length) {
var i = n(t.target).closest(".card");
void 0 === i.data("initialOverflow") && i.data("initialOverflow", void 0 === i.css("overflow") ? "" : i.css("overflow"));
var e = n(this).find(".card-reveal");
n(t.target).is(n(".card-reveal .card-title")) || n(t.target).is(n(".card-reveal .card-title i")) ? s({
targets: e[0],
translateY: 0,
duration: 225,
easing: "easeInOutQuad",
complete: function(t) {
var e = t.animatables[0].target;
n(e).css({
display: "none"
}), i.css("overflow", i.data("initialOverflow"))
}
}) : (n(t.target).is(n(".card .activator")) || n(t.target).is(n(".card .activator i"))) && (i.css("overflow", "hidden"), e.css({
display: "block"
}), s({
targets: e[0],
translateY: "-100%",
duration: 300,
easing: "easeInOutQuad"
}))
}
})
}(cash, M.anime),
function(h) {
"use strict";
var e = {
data: [],
placeholder: "",
secondaryPlaceholder: "",
autocompleteOptions: {},
limit: 1 / 0,
onChipAdd: null,
onChipSelect: null,
onChipDelete: null
},
t = function(t) {
function l(t, e) {
_classCallCheck(this, l);
var i = _possibleConstructorReturn(this, (l.__proto__ || Object.getPrototypeOf(l)).call(this, l, t, e));
return (i.el.M_Chips = i).options = h.extend({}, l.defaults, e), i.$el.addClass("chips input-field"), i.chipsData = [], i.$chips = h(), i._setupInput(), i.hasAutocomplete = 0 < Object.keys(i.options.autocompleteOptions).length, i.$input.attr("id") || i.$input.attr("id", M.guid()), i.options.data.length && (i.chipsData = i.options.data, i._renderChips(i.chipsData)), i.hasAutocomplete && i._setupAutocomplete(), i._setPlaceholder(), i._setupLabel(), i._setupEventHandlers(), i
}
return _inherits(l, Component), _createClass(l, [{
key: "getData",
value: function() {
return this.chipsData
}
}, {
key: "destroy",
value: function() {
this._removeEventHandlers(), this.$chips.remove(), this.el.M_Chips = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleChipClickBound = this._handleChipClick.bind(this), this._handleInputKeydownBound = this._handleInputKeydown.bind(this), this._handleInputFocusBound = this._handleInputFocus.bind(this), this._handleInputBlurBound = this._handleInputBlur.bind(this), this.el.addEventListener("click", this._handleChipClickBound), document.addEventListener("keydown", l._handleChipsKeydown), document.addEventListener("keyup", l._handleChipsKeyup), this.el.addEventListener("blur", l._handleChipsBlur, !0), this.$input[0].addEventListener("focus", this._handleInputFocusBound), this.$input[0].addEventListener("blur", this._handleInputBlurBound), this.$input[0].addEventListener("keydown", this._handleInputKeydownBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("click", this._handleChipClickBound), document.removeEventListener("keydown", l._handleChipsKeydown), document.removeEventListener("keyup", l._handleChipsKeyup), this.el.removeEventListener("blur", l._handleChipsBlur, !0), this.$input[0].removeEventListener("focus", this._handleInputFocusBound), this.$input[0].removeEventListener("blur", this._handleInputBlurBound), this.$input[0].removeEventListener("keydown", this._handleInputKeydownBound)
}
}, {
key: "_handleChipClick",
value: function(t) {
var e = h(t.target).closest(".chip"),
i = h(t.target).is(".close");
if (e.length) {
var n = e.index();
i ? (this.deleteChip(n), this.$input[0].focus()) : this.selectChip(n)
} else this.$input[0].focus()
}
}, {
key: "_handleInputFocus",
value: function() {
this.$el.addClass("focus")
}
}, {
key: "_handleInputBlur",
value: function() {
this.$el.removeClass("focus")
}
}, {
key: "_handleInputKeydown",
value: function(t) {
if (l._keydown = !0, 13 === t.keyCode) {
if (this.hasAutocomplete && this.autocomplete && this.autocomplete.isOpen) return;
t.preventDefault(), this.addChip({
tag: this.$input[0].value
}), this.$input[0].value = ""
} else 8 !== t.keyCode && 37 !== t.keyCode || "" !== this.$input[0].value || !this.chipsData.length || (t.preventDefault(), this.selectChip(this.chipsData.length - 1))
}
}, {
key: "_renderChip",
value: function(t) {
if (t.tag) {
var e = document.createElement("div"),
i = document.createElement("i");
if (e.classList.add("chip"), e.textContent = t.tag, e.setAttribute("tabindex", 0), h(i).addClass("material-icons close"), i.textContent = "close", t.image) {
var n = document.createElement("img");
n.setAttribute("src", t.image), e.insertBefore(n, e.firstChild)
}
return e.appendChild(i), e
}
}
}, {
key: "_renderChips",
value: function() {
this.$chips.remove();
for (var t = 0; t < this.chipsData.length; t++) {
var e = this._renderChip(this.chipsData[t]);
this.$el.append(e), this.$chips.add(e)
}
this.$el.append(this.$input[0])
}
}, {
key: "_setupAutocomplete",
value: function() {
var e = this;
this.options.autocompleteOptions.onAutocomplete = function(t) {
e.addChip({
tag: t
}), e.$input[0].value = "", e.$input[0].focus()
}, this.autocomplete = M.Autocomplete.init(this.$input[0], this.options.autocompleteOptions)
}
}, {
key: "_setupInput",
value: function() {
this.$input = this.$el.find("input"), this.$input.length || (this.$input = h("<input></input>"), this.$el.append(this.$input)), this.$input.addClass("input")
}
}, {
key: "_setupLabel",
value: function() {
this.$label = this.$el.find("label"), this.$label.length && this.$label.setAttribute("for", this.$input.attr("id"))
}
}, {
key: "_setPlaceholder",
value: function() {
void 0 !== this.chipsData && !this.chipsData.length && this.options.placeholder ? h(this.$input).prop("placeholder", this.options.placeholder) : (void 0 === this.chipsData || this.chipsData.length) && this.options.secondaryPlaceholder && h(this.$input).prop("placeholder", this.options.secondaryPlaceholder)
}
}, {
key: "_isValid",
value: function(t) {
if (t.hasOwnProperty("tag") && "" !== t.tag) {
for (var e = !1, i = 0; i < this.chipsData.length; i++)
if (this.chipsData[i].tag === t.tag) {
e = !0;
break
} return !e
}
return !1
}
}, {
key: "addChip",
value: function(t) {
if (this._isValid(t) && !(this.chipsData.length >= this.options.limit)) {
var e = this._renderChip(t);
this.$chips.add(e), this.chipsData.push(t), h(this.$input).before(e), this._setPlaceholder(), "function" == typeof this.options.onChipAdd && this.options.onChipAdd.call(this, this.$el, e)
}
}
}, {
key: "deleteChip",
value: function(t) {
var e = this.$chips.eq(t);
this.$chips.eq(t).remove(), this.$chips = this.$chips.filter(function(t) {
return 0 <= h(t).index()
}), this.chipsData.splice(t, 1), this._setPlaceholder(), "function" == typeof this.options.onChipDelete && this.options.onChipDelete.call(this, this.$el, e[0])
}
}, {
key: "selectChip",
value: function(t) {
var e = this.$chips.eq(t);
(this._selectedChip = e)[0].focus(), "function" == typeof this.options.onChipSelect && this.options.onChipSelect.call(this, this.$el, e[0])
}
}], [{
key: "init",
value: function(t, e) {
return _get(l.__proto__ || Object.getPrototypeOf(l), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Chips
}
}, {
key: "_handleChipsKeydown",
value: function(t) {
l._keydown = !0;
var e = h(t.target).closest(".chips"),
i = t.target && e.length;
if (!h(t.target).is("input, textarea") && i) {
var n = e[0].M_Chips;
if (8 === t.keyCode || 46 === t.keyCode) {
t.preventDefault();
var s = n.chipsData.length;
if (n._selectedChip) {
var o = n._selectedChip.index();
n.deleteChip(o), n._selectedChip = null, s = Math.max(o - 1, 0)
}
n.chipsData.length && n.selectChip(s)
} else if (37 === t.keyCode) {
if (n._selectedChip) {
var a = n._selectedChip.index() - 1;
if (a < 0) return;
n.selectChip(a)
}
} else if (39 === t.keyCode && n._selectedChip) {
var r = n._selectedChip.index() + 1;
r >= n.chipsData.length ? n.$input[0].focus() : n.selectChip(r)
}
}
}
}, {
key: "_handleChipsKeyup",
value: function(t) {
l._keydown = !1
}
}, {
key: "_handleChipsBlur",
value: function(t) {
l._keydown || (h(t.target).closest(".chips")[0].M_Chips._selectedChip = null)
}
}, {
key: "defaults",
get: function() {
return e
}
}]), l
}();
t._keydown = !1, M.Chips = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "chips", "M_Chips"), h(document).ready(function() {
h(document.body).on("click", ".chip .close", function() {
var t = h(this).closest(".chips");
t.length && t[0].M_Chips || h(this).closest(".chip").remove()
})
})
}(cash),
function(s) {
"use strict";
var e = {
top: 0,
bottom: 1 / 0,
offset: 0,
onPositionChange: null
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Pushpin = i).options = s.extend({}, n.defaults, e), i.originalOffset = i.el.offsetTop, n._pushpins.push(i), i._setupEventHandlers(), i._updatePosition(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this.el.style.top = null, this._removePinClasses(), this._removeEventHandlers();
var t = n._pushpins.indexOf(this);
n._pushpins.splice(t, 1)
}
}, {
key: "_setupEventHandlers",
value: function() {
document.addEventListener("scroll", n._updateElements)
}
}, {
key: "_removeEventHandlers",
value: function() {
document.removeEventListener("scroll", n._updateElements)
}
}, {
key: "_updatePosition",
value: function() {
var t = M.getDocumentScrollTop() + this.options.offset;
this.options.top <= t && this.options.bottom >= t && !this.el.classList.contains("pinned") && (this._removePinClasses(), this.el.style.top = this.options.offset + "px", this.el.classList.add("pinned"), "function" == typeof this.options.onPositionChange && this.options.onPositionChange.call(this, "pinned")), t < this.options.top && !this.el.classList.contains("pin-top") && (this._removePinClasses(), this.el.style.top = 0, this.el.classList.add("pin-top"), "function" == typeof this.options.onPositionChange && this.options.onPositionChange.call(this, "pin-top")), t > this.options.bottom && !this.el.classList.contains("pin-bottom") && (this._removePinClasses(), this.el.classList.add("pin-bottom"), this.el.style.top = this.options.bottom - this.originalOffset + "px", "function" == typeof this.options.onPositionChange && this.options.onPositionChange.call(this, "pin-bottom"))
}
}, {
key: "_removePinClasses",
value: function() {
this.el.classList.remove("pin-top"), this.el.classList.remove("pinned"), this.el.classList.remove("pin-bottom")
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Pushpin
}
}, {
key: "_updateElements",
value: function() {
for (var t in n._pushpins) {
n._pushpins[t]._updatePosition()
}
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
t._pushpins = [], M.Pushpin = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "pushpin", "M_Pushpin")
}(cash),
function(r, s) {
"use strict";
var e = {
direction: "top",
hoverEnabled: !0,
toolbarEnabled: !1
};
r.fn.reverse = [].reverse;
var t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_FloatingActionButton = i).options = r.extend({}, n.defaults, e), i.isOpen = !1, i.$anchor = i.$el.children("a").first(), i.$menu = i.$el.children("ul").first(), i.$floatingBtns = i.$el.find("ul .btn-floating"), i.$floatingBtnsReverse = i.$el.find("ul .btn-floating").reverse(), i.offsetY = 0, i.offsetX = 0, i.$el.addClass("direction-" + i.options.direction), "top" === i.options.direction ? i.offsetY = 40 : "right" === i.options.direction ? i.offsetX = -40 : "bottom" === i.options.direction ? i.offsetY = -40 : i.offsetX = 40, i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this.el.M_FloatingActionButton = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleFABClickBound = this._handleFABClick.bind(this), this._handleOpenBound = this.open.bind(this), this._handleCloseBound = this.close.bind(this), this.options.hoverEnabled && !this.options.toolbarEnabled ? (this.el.addEventListener("mouseenter", this._handleOpenBound), this.el.addEventListener("mouseleave", this._handleCloseBound)) : this.el.addEventListener("click", this._handleFABClickBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
this.options.hoverEnabled && !this.options.toolbarEnabled ? (this.el.removeEventListener("mouseenter", this._handleOpenBound), this.el.removeEventListener("mouseleave", this._handleCloseBound)) : this.el.removeEventListener("click", this._handleFABClickBound)
}
}, {
key: "_handleFABClick",
value: function() {
this.isOpen ? this.close() : this.open()
}
}, {
key: "_handleDocumentClick",
value: function(t) {
r(t.target).closest(this.$menu).length || this.close()
}
}, {
key: "open",
value: function() {
this.isOpen || (this.options.toolbarEnabled ? this._animateInToolbar() : this._animateInFAB(), this.isOpen = !0)
}
}, {
key: "close",
value: function() {
this.isOpen && (this.options.toolbarEnabled ? (window.removeEventListener("scroll", this._handleCloseBound, !0), document.body.removeEventListener("click", this._handleDocumentClickBound, !0), this._animateOutToolbar()) : this._animateOutFAB(), this.isOpen = !1)
}
}, {
key: "_animateInFAB",
value: function() {
var e = this;
this.$el.addClass("active");
var i = 0;
this.$floatingBtnsReverse.each(function(t) {
s({
targets: t,
opacity: 1,
scale: [.4, 1],
translateY: [e.offsetY, 0],
translateX: [e.offsetX, 0],
duration: 275,
delay: i,
easing: "easeInOutQuad"
}), i += 40
})
}
}, {
key: "_animateOutFAB",
value: function() {
var e = this;
this.$floatingBtnsReverse.each(function(t) {
s.remove(t), s({
targets: t,
opacity: 0,
scale: .4,
translateY: e.offsetY,
translateX: e.offsetX,
duration: 175,
easing: "easeOutQuad",
complete: function() {
e.$el.removeClass("active")
}
})
})
}
}, {
key: "_animateInToolbar",
value: function() {
var t, e = this,
i = window.innerWidth,
n = window.innerHeight,
s = this.el.getBoundingClientRect(),
o = r('<div class="fab-backdrop"></div>'),
a = this.$anchor.css("background-color");
this.$anchor.append(o), this.offsetX = s.left - i / 2 + s.width / 2, this.offsetY = n - s.bottom, t = i / o[0].clientWidth, this.btnBottom = s.bottom, this.btnLeft = s.left, this.btnWidth = s.width, this.$el.addClass("active"), this.$el.css({
"text-align": "center",
width: "100%",
bottom: 0,
left: 0,
transform: "translateX(" + this.offsetX + "px)",
transition: "none"
}), this.$anchor.css({
transform: "translateY(" + -this.offsetY + "px)",
transition: "none"
}), o.css({
"background-color": a
}), setTimeout(function() {
e.$el.css({
transform: "",
transition: "transform .2s cubic-bezier(0.550, 0.085, 0.680, 0.530), background-color 0s linear .2s"
}), e.$anchor.css({
overflow: "visible",
transform: "",
transition: "transform .2s"
}), setTimeout(function() {
e.$el.css({
overflow: "hidden",
"background-color": a
}), o.css({
transform: "scale(" + t + ")",
transition: "transform .2s cubic-bezier(0.550, 0.055, 0.675, 0.190)"
}), e.$menu.children("li").children("a").css({
opacity: 1
}), e._handleDocumentClickBound = e._handleDocumentClick.bind(e), window.addEventListener("scroll", e._handleCloseBound, !0), document.body.addEventListener("click", e._handleDocumentClickBound, !0)
}, 100)
}, 0)
}
}, {
key: "_animateOutToolbar",
value: function() {
var t = this,
e = window.innerWidth,
i = window.innerHeight,
n = this.$el.find(".fab-backdrop"),
s = this.$anchor.css("background-color");
this.offsetX = this.btnLeft - e / 2 + this.btnWidth / 2, this.offsetY = i - this.btnBottom, this.$el.removeClass("active"), this.$el.css({
"background-color": "transparent",
transition: "none"
}), this.$anchor.css({
transition: "none"
}), n.css({
transform: "scale(0)",
"background-color": s
}), this.$menu.children("li").children("a").css({
opacity: ""
}), setTimeout(function() {
n.remove(), t.$el.css({
"text-align": "",
width: "",
bottom: "",
left: "",
overflow: "",
"background-color": "",
transform: "translate3d(" + -t.offsetX + "px,0,0)"
}), t.$anchor.css({
overflow: "",
transform: "translate3d(0," + t.offsetY + "px,0)"
}), setTimeout(function() {
t.$el.css({
transform: "translate3d(0,0,0)",
transition: "transform .2s"
}), t.$anchor.css({
transform: "translate3d(0,0,0)",
transition: "transform .2s cubic-bezier(0.550, 0.055, 0.675, 0.190)"
})
}, 20)
}, 200)
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_FloatingActionButton
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
M.FloatingActionButton = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "floatingActionButton", "M_FloatingActionButton")
}(cash, M.anime),
function(g) {
"use strict";
var e = {
autoClose: !1,
format: "mmm dd, yyyy",
parse: null,
defaultDate: null,
setDefaultDate: !1,
disableWeekends: !1,
disableDayFn: null,
firstDay: 0,
minDate: null,
maxDate: null,
yearRange: 10,
minYear: 0,
maxYear: 9999,
minMonth: void 0,
maxMonth: void 0,
startRange: null,
endRange: null,
isRTL: !1,
showMonthAfterYear: !1,
showDaysInNextAndPreviousMonths: !1,
container: null,
showClearBtn: !1,
i18n: {
cancel: "Cancel",
clear: "Clear",
done: "Ok",
previousMonth: "",
nextMonth: "",
months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
monthsShort: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
weekdays: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],
weekdaysShort: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
weekdaysAbbrev: ["S", "M", "T", "W", "T", "F", "S"]
},
events: [],
onSelect: null,
onOpen: null,
onClose: null,
onDraw: null
},
t = function(t) {
function B(t, e) {
_classCallCheck(this, B);
var i = _possibleConstructorReturn(this, (B.__proto__ || Object.getPrototypeOf(B)).call(this, B, t, e));
(i.el.M_Datepicker = i).options = g.extend({}, B.defaults, e), e && e.hasOwnProperty("i18n") && "object" == typeof e.i18n && (i.options.i18n = g.extend({}, B.defaults.i18n, e.i18n)), i.options.minDate && i.options.minDate.setHours(0, 0, 0, 0), i.options.maxDate && i.options.maxDate.setHours(0, 0, 0, 0), i.id = M.guid(), i._setupVariables(), i._insertHTMLIntoDOM(), i._setupModal(), i._setupEventHandlers(), i.options.defaultDate || (i.options.defaultDate = new Date(Date.parse(i.el.value)));
var n = i.options.defaultDate;
return B._isDate(n) ? i.options.setDefaultDate ? (i.setDate(n, !0), i.setInputValue()) : i.gotoDate(n) : i.gotoDate(new Date), i.isOpen = !1, i
}
return _inherits(B, Component), _createClass(B, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this.modal.destroy(), g(this.modalEl).remove(), this.destroySelects(), this.el.M_Datepicker = void 0
}
}, {
key: "destroySelects",
value: function() {
var t = this.calendarEl.querySelector(".orig-select-year");
t && M.FormSelect.getInstance(t).destroy();
var e = this.calendarEl.querySelector(".orig-select-month");
e && M.FormSelect.getInstance(e).destroy()
}
}, {
key: "_insertHTMLIntoDOM",
value: function() {
this.options.showClearBtn && (g(this.clearBtn).css({
visibility: ""
}), this.clearBtn.innerHTML = this.options.i18n.clear), this.doneBtn.innerHTML = this.options.i18n.done, this.cancelBtn.innerHTML = this.options.i18n.cancel, this.options.container ? this.$modalEl.appendTo(this.options.container) : this.$modalEl.insertBefore(this.el)
}
}, {
key: "_setupModal",
value: function() {
var t = this;
this.modalEl.id = "modal-" + this.id, this.modal = M.Modal.init(this.modalEl, {
onCloseEnd: function() {
t.isOpen = !1
}
})
}
}, {
key: "toString",
value: function(t) {
var e = this;
return t = t || this.options.format, B._isDate(this.date) ? t.split(/(d{1,4}|m{1,4}|y{4}|yy|!.)/g).map(function(t) {
return e.formats[t] ? e.formats[t]() : t
}).join("") : ""
}
}, {
key: "setDate",
value: function(t, e) {
if (!t) return this.date = null, this._renderDateDisplay(), this.draw();
if ("string" == typeof t && (t = new Date(Date.parse(t))), B._isDate(t)) {
var i = this.options.minDate,
n = this.options.maxDate;
B._isDate(i) && t < i ? t = i : B._isDate(n) && n < t && (t = n), this.date = new Date(t.getTime()), this._renderDateDisplay(), B._setToStartOfDay(this.date), this.gotoDate(this.date), e || "function" != typeof this.options.onSelect || this.options.onSelect.call(this, this.date)
}
}
}, {
key: "setInputValue",
value: function() {
this.el.value = this.toString(), this.$el.trigger("change", {
firedBy: this
})
}
}, {
key: "_renderDateDisplay",
value: function() {
var t = B._isDate(this.date) ? this.date : new Date,
e = this.options.i18n,
i = e.weekdaysShort[t.getDay()],
n = e.monthsShort[t.getMonth()],
s = t.getDate();
this.yearTextEl.innerHTML = t.getFullYear(), this.dateTextEl.innerHTML = i + ", " + n + " " + s
}
}, {
key: "gotoDate",
value: function(t) {
var e = !0;
if (B._isDate(t)) {
if (this.calendars) {
var i = new Date(this.calendars[0].year, this.calendars[0].month, 1),
n = new Date(this.calendars[this.calendars.length - 1].year, this.calendars[this.calendars.length - 1].month, 1),
s = t.getTime();
n.setMonth(n.getMonth() + 1), n.setDate(n.getDate() - 1), e = s < i.getTime() || n.getTime() < s
}
e && (this.calendars = [{
month: t.getMonth(),
year: t.getFullYear()
}]), this.adjustCalendars()
}
}
}, {
key: "adjustCalendars",
value: function() {
this.calendars[0] = this.adjustCalendar(this.calendars[0]), this.draw()
}
}, {
key: "adjustCalendar",
value: function(t) {
return t.month < 0 && (t.year -= Math.ceil(Math.abs(t.month) / 12), t.month += 12), 11 < t.month && (t.year += Math.floor(Math.abs(t.month) / 12), t.month -= 12), t
}
}, {
key: "nextMonth",
value: function() {
this.calendars[0].month++, this.adjustCalendars()
}
}, {
key: "prevMonth",
value: function() {
this.calendars[0].month--, this.adjustCalendars()
}
}, {
key: "render",
value: function(t, e, i) {
var n = this.options,
s = new Date,
o = B._getDaysInMonth(t, e),
a = new Date(t, e, 1).getDay(),
r = [],
l = [];
B._setToStartOfDay(s), 0 < n.firstDay && (a -= n.firstDay) < 0 && (a += 7);
for (var h = 0 === e ? 11 : e - 1, d = 11 === e ? 0 : e + 1, u = 0 === e ? t - 1 : t, c = 11 === e ? t + 1 : t, p = B._getDaysInMonth(u, h), v = o + a, f = v; 7 < f;) f -= 7;
v += 7 - f;
for (var m = !1, g = 0, _ = 0; g < v; g++) {
var y = new Date(t, e, g - a + 1),
k = !!B._isDate(this.date) && B._compareDates(y, this.date),
b = B._compareDates(y, s),
w = -1 !== n.events.indexOf(y.toDateString()),
C = g < a || o + a <= g,
E = g - a + 1,
M = e,
O = t,
x = n.startRange && B._compareDates(n.startRange, y),
L = n.endRange && B._compareDates(n.endRange, y),
T = n.startRange && n.endRange && n.startRange < y && y < n.endRange;
C && (g < a ? (E = p + E, M = h, O = u) : (E -= o, M = d, O = c));
var $ = {
day: E,
month: M,
year: O,
hasEvent: w,
isSelected: k,
isToday: b,
isDisabled: n.minDate && y < n.minDate || n.maxDate && y > n.maxDate || n.disableWeekends && B._isWeekend(y) || n.disableDayFn && n.disableDayFn(y),
isEmpty: C,
isStartRange: x,
isEndRange: L,
isInRange: T,
showDaysInNextAndPreviousMonths: n.showDaysInNextAndPreviousMonths
};
l.push(this.renderDay($)), 7 == ++_ && (r.push(this.renderRow(l, n.isRTL, m)), _ = 0, m = !(l = []))
}
return this.renderTable(n, r, i)
}
}, {
key: "renderDay",
value: function(t) {
var e = [],
i = "false";
if (t.isEmpty) {
if (!t.showDaysInNextAndPreviousMonths) return '<td class="is-empty"></td>';
e.push("is-outside-current-month"), e.push("is-selection-disabled")
}
return t.isDisabled && e.push("is-disabled"), t.isToday && e.push("is-today"), t.isSelected && (e.push("is-selected"), i = "true"), t.hasEvent && e.push("has-event"), t.isInRange && e.push("is-inrange"), t.isStartRange && e.push("is-startrange"), t.isEndRange && e.push("is-endrange"), '<td data-day="' + t.day + '" class="' + e.join(" ") + '" aria-selected="' + i + '"><button class="datepicker-day-button" type="button" data-year="' + t.year + '" data-month="' + t.month + '" data-day="' + t.day + '">' + t.day + "</button></td>"
}
}, {
key: "renderRow",
value: function(t, e, i) {
return '<tr class="datepicker-row' + (i ? " is-selected" : "") + '">' + (e ? t.reverse() : t).join("") + "</tr>"
}
}, {
key: "renderTable",
value: function(t, e, i) {
return '<div class="datepicker-table-wrapper"><table cellpadding="0" cellspacing="0" class="datepicker-table" role="grid" aria-labelledby="' + i + '">' + this.renderHead(t) + this.renderBody(e) + "</table></div>"
}
}, {
key: "renderHead",
value: function(t) {
var e = void 0,
i = [];
for (e = 0; e < 7; e++) i.push('<th scope="col"><abbr title="' + this.renderDayName(t, e) + '">' + this.renderDayName(t, e, !0) + "</abbr></th>");
return "<thead><tr>" + (t.isRTL ? i.reverse() : i).join("") + "</tr></thead>"
}
}, {
key: "renderBody",
value: function(t) {
return "<tbody>" + t.join("") + "</tbody>"
}
}, {
key: "renderTitle",
value: function(t, e, i, n, s, o) {
var a, r, l = void 0,
h = void 0,
d = void 0,
u = this.options,
c = i === u.minYear,
p = i === u.maxYear,
v = '<div id="' + o + '" class="datepicker-controls" role="heading" aria-live="assertive">',
f = !0,
m = !0;
for (d = [], l = 0; l < 12; l++) d.push('<option value="' + (i === s ? l - e : 12 + l - e) + '"' + (l === n ? ' selected="selected"' : "") + (c && l < u.minMonth || p && l > u.maxMonth ? 'disabled="disabled"' : "") + ">" + u.i18n.months[l] + "</option>");
for (a = '<select class="datepicker-select orig-select-month" tabindex="-1">' + d.join("") + "</select>", g.isArray(u.yearRange) ? (l = u.yearRange[0], h = u.yearRange[1] + 1) : (l = i - u.yearRange, h = 1 + i + u.yearRange), d = []; l < h && l <= u.maxYear; l++) l >= u.minYear && d.push('<option value="' + l + '" ' + (l === i ? 'selected="selected"' : "") + ">" + l + "</option>");
r = '<select class="datepicker-select orig-select-year" tabindex="-1">' + d.join("") + "</select>";
v += '<button class="month-prev' + (f ? "" : " is-disabled") + '" type="button"><svg fill="#000000" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z"/><path d="M0-.5h24v24H0z" fill="none"/></svg></button>', v += '<div class="selects-container">', u.showMonthAfterYear ? v += r + a : v += a + r, v += "</div>", c && (0 === n || u.minMonth >= n) && (f = !1), p && (11 === n || u.maxMonth <= n) && (m = !1);
return (v += '<button class="month-next' + (m ? "" : " is-disabled") + '" type="button"><svg fill="#000000" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z"/><path d="M0-.25h24v24H0z" fill="none"/></svg></button>') + "</div>"
}
}, {
key: "draw",
value: function(t) {
if (this.isOpen || t) {
var e, i = this.options,
n = i.minYear,
s = i.maxYear,
o = i.minMonth,
a = i.maxMonth,
r = "";
this._y <= n && (this._y = n, !isNaN(o) && this._m < o && (this._m = o)), this._y >= s && (this._y = s, !isNaN(a) && this._m > a && (this._m = a)), e = "datepicker-title-" + Math.random().toString(36).replace(/[^a-z]+/g, "").substr(0, 2);
for (var l = 0; l < 1; l++) this._renderDateDisplay(), r += this.renderTitle(this, l, this.calendars[l].year, this.calendars[l].month, this.calendars[0].year, e) + this.render(this.calendars[l].year, this.calendars[l].month, e);
this.destroySelects(), this.calendarEl.innerHTML = r;
var h = this.calendarEl.querySelector(".orig-select-year"),
d = this.calendarEl.querySelector(".orig-select-month");
M.FormSelect.init(h, {
classes: "select-year",
dropdownOptions: {
container: document.body,
constrainWidth: !1
}
}), M.FormSelect.init(d, {
classes: "select-month",
dropdownOptions: {
container: document.body,
constrainWidth: !1
}
}), h.addEventListener("change", this._handleYearChange.bind(this)), d.addEventListener("change", this._handleMonthChange.bind(this)), "function" == typeof this.options.onDraw && this.options.onDraw(this)
}
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleInputKeydownBound = this._handleInputKeydown.bind(this), this._handleInputClickBound = this._handleInputClick.bind(this), this._handleInputChangeBound = this._handleInputChange.bind(this), this._handleCalendarClickBound = this._handleCalendarClick.bind(this), this._finishSelectionBound = this._finishSelection.bind(this), this._handleMonthChange = this._handleMonthChange.bind(this), this._closeBound = this.close.bind(this), this.el.addEventListener("click", this._handleInputClickBound), this.el.addEventListener("keydown", this._handleInputKeydownBound), this.el.addEventListener("change", this._handleInputChangeBound), this.calendarEl.addEventListener("click", this._handleCalendarClickBound), this.doneBtn.addEventListener("click", this._finishSelectionBound), this.cancelBtn.addEventListener("click", this._closeBound), this.options.showClearBtn && (this._handleClearClickBound = this._handleClearClick.bind(this), this.clearBtn.addEventListener("click", this._handleClearClickBound))
}
}, {
key: "_setupVariables",
value: function() {
var e = this;
this.$modalEl = g(B._template), this.modalEl = this.$modalEl[0], this.calendarEl = this.modalEl.querySelector(".datepicker-calendar"), this.yearTextEl = this.modalEl.querySelector(".year-text"), this.dateTextEl = this.modalEl.querySelector(".date-text"), this.options.showClearBtn && (this.clearBtn = this.modalEl.querySelector(".datepicker-clear")), this.doneBtn = this.modalEl.querySelector(".datepicker-done"), this.cancelBtn = this.modalEl.querySelector(".datepicker-cancel"), this.formats = {
d: function() {
return e.date.getDate()
},
dd: function() {
var t = e.date.getDate();
return (t < 10 ? "0" : "") + t
},
ddd: function() {
return e.options.i18n.weekdaysShort[e.date.getDay()]
},
dddd: function() {
return e.options.i18n.weekdays[e.date.getDay()]
},
m: function() {
return e.date.getMonth() + 1
},
mm: function() {
var t = e.date.getMonth() + 1;
return (t < 10 ? "0" : "") + t
},
mmm: function() {
return e.options.i18n.monthsShort[e.date.getMonth()]
},
mmmm: function() {
return e.options.i18n.months[e.date.getMonth()]
},
yy: function() {
return ("" + e.date.getFullYear()).slice(2)
},
yyyy: function() {
return e.date.getFullYear()
}
}
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("click", this._handleInputClickBound), this.el.removeEventListener("keydown", this._handleInputKeydownBound), this.el.removeEventListener("change", this._handleInputChangeBound), this.calendarEl.removeEventListener("click", this._handleCalendarClickBound)
}
}, {
key: "_handleInputClick",
value: function() {
this.open()
}
}, {
key: "_handleInputKeydown",
value: function(t) {
t.which === M.keys.ENTER && (t.preventDefault(), this.open())
}
}, {
key: "_handleCalendarClick",
value: function(t) {
if (this.isOpen) {
var e = g(t.target);
e.hasClass("is-disabled") || (!e.hasClass("datepicker-day-button") || e.hasClass("is-empty") || e.parent().hasClass("is-disabled") ? e.closest(".month-prev").length ? this.prevMonth() : e.closest(".month-next").length && this.nextMonth() : (this.setDate(new Date(t.target.getAttribute("data-year"), t.target.getAttribute("data-month"), t.target.getAttribute("data-day"))), this.options.autoClose && this._finishSelection()))
}
}
}, {
key: "_handleClearClick",
value: function() {
this.date = null, this.setInputValue(), this.close()
}
}, {
key: "_handleMonthChange",
value: function(t) {
this.gotoMonth(t.target.value)
}
}, {
key: "_handleYearChange",
value: function(t) {
this.gotoYear(t.target.value)
}
}, {
key: "gotoMonth",
value: function(t) {
isNaN(t) || (this.calendars[0].month = parseInt(t, 10), this.adjustCalendars())
}
}, {
key: "gotoYear",
value: function(t) {
isNaN(t) || (this.calendars[0].year = parseInt(t, 10), this.adjustCalendars())
}
}, {
key: "_handleInputChange",
value: function(t) {
var e = void 0;
t.firedBy !== this && (e = this.options.parse ? this.options.parse(this.el.value, this.options.format) : new Date(Date.parse(this.el.value)), B._isDate(e) && this.setDate(e))
}
}, {
key: "renderDayName",
value: function(t, e, i) {
for (e += t.firstDay; 7 <= e;) e -= 7;
return i ? t.i18n.weekdaysAbbrev[e] : t.i18n.weekdays[e]
}
}, {
key: "_finishSelection",
value: function() {
this.setInputValue(), this.close()
}
}, {
key: "open",
value: function() {
if (!this.isOpen) return this.isOpen = !0, "function" == typeof this.options.onOpen && this.options.onOpen.call(this), this.draw(), this.modal.open(), this
}
}, {
key: "close",
value: function() {
if (this.isOpen) return this.isOpen = !1, "function" == typeof this.options.onClose && this.options.onClose.call(this), this.modal.close(), this
}
}], [{
key: "init",
value: function(t, e) {
return _get(B.__proto__ || Object.getPrototypeOf(B), "init", this).call(this, this, t, e)
}
}, {
key: "_isDate",
value: function(t) {
return /Date/.test(Object.prototype.toString.call(t)) && !isNaN(t.getTime())
}
}, {
key: "_isWeekend",
value: function(t) {
var e = t.getDay();
return 0 === e || 6 === e
}
}, {
key: "_setToStartOfDay",
value: function(t) {
B._isDate(t) && t.setHours(0, 0, 0, 0)
}
}, {
key: "_getDaysInMonth",
value: function(t, e) {
return [31, B._isLeapYear(t) ? 29 : 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][e]
}
}, {
key: "_isLeapYear",
value: function(t) {
return t % 4 == 0 && t % 100 != 0 || t % 400 == 0
}
}, {
key: "_compareDates",
value: function(t, e) {
return t.getTime() === e.getTime()
}
}, {
key: "_setToStartOfDay",
value: function(t) {
B._isDate(t) && t.setHours(0, 0, 0, 0)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Datepicker
}
}, {
key: "defaults",
get: function() {
return e
}
}]), B
}();
t._template = ['<div class= "modal datepicker-modal">', '<div class="modal-content datepicker-container">', '<div class="datepicker-date-display">', '<span class="year-text"></span>', '<span class="date-text"></span>', "</div>", '<div class="datepicker-calendar-container">', '<div class="datepicker-calendar"></div>', '<div class="datepicker-footer">', '<button class="btn-flat datepicker-clear waves-effect" style="visibility: hidden;" type="button"></button>', '<div class="confirmation-btns">', '<button class="btn-flat datepicker-cancel waves-effect" type="button"></button>', '<button class="btn-flat datepicker-done waves-effect" type="button"></button>', "</div>", "</div>", "</div>", "</div>", "</div>"].join(""), M.Datepicker = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "datepicker", "M_Datepicker")
}(cash),
function(h) {
"use strict";
var e = {
dialRadius: 135,
outerRadius: 105,
innerRadius: 70,
tickRadius: 20,
duration: 350,
container: null,
defaultTime: "now",
fromNow: 0,
showClearBtn: !1,
i18n: {
cancel: "Cancel",
clear: "Clear",
done: "Ok"
},
autoClose: !1,
twelveHour: !0,
vibrate: !0,
onOpenStart: null,
onOpenEnd: null,
onCloseStart: null,
onCloseEnd: null,
onSelect: null
},
t = function(t) {
function f(t, e) {
_classCallCheck(this, f);
var i = _possibleConstructorReturn(this, (f.__proto__ || Object.getPrototypeOf(f)).call(this, f, t, e));
return (i.el.M_Timepicker = i).options = h.extend({}, f.defaults, e), i.id = M.guid(), i._insertHTMLIntoDOM(), i._setupModal(), i._setupVariables(), i._setupEventHandlers(), i._clockSetup(), i._pickerSetup(), i
}
return _inherits(f, Component), _createClass(f, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this.modal.destroy(), h(this.modalEl).remove(), this.el.M_Timepicker = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleInputKeydownBound = this._handleInputKeydown.bind(this), this._handleInputClickBound = this._handleInputClick.bind(this), this._handleClockClickStartBound = this._handleClockClickStart.bind(this), this._handleDocumentClickMoveBound = this._handleDocumentClickMove.bind(this), this._handleDocumentClickEndBound = this._handleDocumentClickEnd.bind(this), this.el.addEventListener("click", this._handleInputClickBound), this.el.addEventListener("keydown", this._handleInputKeydownBound), this.plate.addEventListener("mousedown", this._handleClockClickStartBound), this.plate.addEventListener("touchstart", this._handleClockClickStartBound), h(this.spanHours).on("click", this.showView.bind(this, "hours")), h(this.spanMinutes).on("click", this.showView.bind(this, "minutes"))
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("click", this._handleInputClickBound), this.el.removeEventListener("keydown", this._handleInputKeydownBound)
}
}, {
key: "_handleInputClick",
value: function() {
this.open()
}
}, {
key: "_handleInputKeydown",
value: function(t) {
t.which === M.keys.ENTER && (t.preventDefault(), this.open())
}
}, {
key: "_handleClockClickStart",
value: function(t) {
t.preventDefault();
var e = this.plate.getBoundingClientRect(),
i = e.left,
n = e.top;
this.x0 = i + this.options.dialRadius, this.y0 = n + this.options.dialRadius, this.moved = !1;
var s = f._Pos(t);
this.dx = s.x - this.x0, this.dy = s.y - this.y0, this.setHand(this.dx, this.dy, !1), document.addEventListener("mousemove", this._handleDocumentClickMoveBound), document.addEventListener("touchmove", this._handleDocumentClickMoveBound), document.addEventListener("mouseup", this._handleDocumentClickEndBound), document.addEventListener("touchend", this._handleDocumentClickEndBound)
}
}, {
key: "_handleDocumentClickMove",
value: function(t) {
t.preventDefault();
var e = f._Pos(t),
i = e.x - this.x0,
n = e.y - this.y0;
this.moved = !0, this.setHand(i, n, !1, !0)
}
}, {
key: "_handleDocumentClickEnd",
value: function(t) {
var e = this;
t.preventDefault(), document.removeEventListener("mouseup", this._handleDocumentClickEndBound), document.removeEventListener("touchend", this._handleDocumentClickEndBound);
var i = f._Pos(t),
n = i.x - this.x0,
s = i.y - this.y0;
this.moved && n === this.dx && s === this.dy && this.setHand(n, s), "hours" === this.currentView ? this.showView("minutes", this.options.duration / 2) : this.options.autoClose && (h(this.minutesView).addClass("timepicker-dial-out"), setTimeout(function() {
e.done()
}, this.options.duration / 2)), "function" == typeof this.options.onSelect && this.options.onSelect.call(this, this.hours, this.minutes), document.removeEventListener("mousemove", this._handleDocumentClickMoveBound), document.removeEventListener("touchmove", this._handleDocumentClickMoveBound)
}
}, {
key: "_insertHTMLIntoDOM",
value: function() {
this.$modalEl = h(f._template), this.modalEl = this.$modalEl[0], this.modalEl.id = "modal-" + this.id;
var t = document.querySelector(this.options.container);
this.options.container && t ? this.$modalEl.appendTo(t) : this.$modalEl.insertBefore(this.el)
}
}, {
key: "_setupModal",
value: function() {
var t = this;
this.modal = M.Modal.init(this.modalEl, {
onOpenStart: this.options.onOpenStart,
onOpenEnd: this.options.onOpenEnd,
onCloseStart: this.options.onCloseStart,
onCloseEnd: function() {
"function" == typeof t.options.onCloseEnd && t.options.onCloseEnd.call(t), t.isOpen = !1
}
})
}
}, {
key: "_setupVariables",
value: function() {
this.currentView = "hours", this.vibrate = navigator.vibrate ? "vibrate" : navigator.webkitVibrate ? "webkitVibrate" : null, this._canvas = this.modalEl.querySelector(".timepicker-canvas"), this.plate = this.modalEl.querySelector(".timepicker-plate"), this.hoursView = this.modalEl.querySelector(".timepicker-hours"), this.minutesView = this.modalEl.querySelector(".timepicker-minutes"), this.spanHours = this.modalEl.querySelector(".timepicker-span-hours"), this.spanMinutes = this.modalEl.querySelector(".timepicker-span-minutes"), this.spanAmPm = this.modalEl.querySelector(".timepicker-span-am-pm"), this.footer = this.modalEl.querySelector(".timepicker-footer"), this.amOrPm = "PM"
}
}, {
key: "_pickerSetup",
value: function() {
var t = h('<button class="btn-flat timepicker-clear waves-effect" style="visibility: hidden;" type="button" tabindex="' + (this.options.twelveHour ? "3" : "1") + '">' + this.options.i18n.clear + "</button>").appendTo(this.footer).on("click", this.clear.bind(this));
this.options.showClearBtn && t.css({
visibility: ""
});
var e = h('<div class="confirmation-btns"></div>');
h('<button class="btn-flat timepicker-close waves-effect" type="button" tabindex="' + (this.options.twelveHour ? "3" : "1") + '">' + this.options.i18n.cancel + "</button>").appendTo(e).on("click", this.close.bind(this)), h('<button class="btn-flat timepicker-close waves-effect" type="button" tabindex="' + (this.options.twelveHour ? "3" : "1") + '">' + this.options.i18n.done + "</button>").appendTo(e).on("click", this.done.bind(this)), e.appendTo(this.footer)
}
}, {
key: "_clockSetup",
value: function() {
this.options.twelveHour && (this.$amBtn = h('<div class="am-btn">AM</div>'), this.$pmBtn = h('<div class="pm-btn">PM</div>'), this.$amBtn.on("click", this._handleAmPmClick.bind(this)).appendTo(this.spanAmPm), this.$pmBtn.on("click", this._handleAmPmClick.bind(this)).appendTo(this.spanAmPm)), this._buildHoursView(), this._buildMinutesView(), this._buildSVGClock()
}
}, {
key: "_buildSVGClock",
value: function() {
var t = this.options.dialRadius,
e = this.options.tickRadius,
i = 2 * t,
n = f._createSVGEl("svg");
n.setAttribute("class", "timepicker-svg"), n.setAttribute("width", i), n.setAttribute("height", i);
var s = f._createSVGEl("g");
s.setAttribute("transform", "translate(" + t + "," + t + ")");
var o = f._createSVGEl("circle");
o.setAttribute("class", "timepicker-canvas-bearing"), o.setAttribute("cx", 0), o.setAttribute("cy", 0), o.setAttribute("r", 4);
var a = f._createSVGEl("line");
a.setAttribute("x1", 0), a.setAttribute("y1", 0);
var r = f._createSVGEl("circle");
r.setAttribute("class", "timepicker-canvas-bg"), r.setAttribute("r", e), s.appendChild(a), s.appendChild(r), s.appendChild(o), n.appendChild(s), this._canvas.appendChild(n), this.hand = a, this.bg = r, this.bearing = o, this.g = s
}
}, {
key: "_buildHoursView",
value: function() {
var t = h('<div class="timepicker-tick"></div>');
if (this.options.twelveHour)
for (var e = 1; e < 13; e += 1) {
var i = t.clone(),
n = e / 6 * Math.PI,
s = this.options.outerRadius;
i.css({
left: this.options.dialRadius + Math.sin(n) * s - this.options.tickRadius + "px",
top: this.options.dialRadius - Math.cos(n) * s - this.options.tickRadius + "px"
}), i.html(0 === e ? "00" : e), this.hoursView.appendChild(i[0])
} else
for (var o = 0; o < 24; o += 1) {
var a = t.clone(),
r = o / 6 * Math.PI,
l = 0 < o && o < 13 ? this.options.innerRadius : this.options.outerRadius;
a.css({
left: this.options.dialRadius + Math.sin(r) * l - this.options.tickRadius + "px",
top: this.options.dialRadius - Math.cos(r) * l - this.options.tickRadius + "px"
}), a.html(0 === o ? "00" : o), this.hoursView.appendChild(a[0])
}
}
}, {
key: "_buildMinutesView",
value: function() {
for (var t = h('<div class="timepicker-tick"></div>'), e = 0; e < 60; e += 5) {
var i = t.clone(),
n = e / 30 * Math.PI;
i.css({
left: this.options.dialRadius + Math.sin(n) * this.options.outerRadius - this.options.tickRadius + "px",
top: this.options.dialRadius - Math.cos(n) * this.options.outerRadius - this.options.tickRadius + "px"
}), i.html(f._addLeadingZero(e)), this.minutesView.appendChild(i[0])
}
}
}, {
key: "_handleAmPmClick",
value: function(t) {
var e = h(t.target);
this.amOrPm = e.hasClass("am-btn") ? "AM" : "PM", this._updateAmPmView()
}
}, {
key: "_updateAmPmView",
value: function() {
this.options.twelveHour && (this.$amBtn.toggleClass("text-primary", "AM" === this.amOrPm), this.$pmBtn.toggleClass("text-primary", "PM" === this.amOrPm))
}
}, {
key: "_updateTimeFromInput",
value: function() {
var t = ((this.el.value || this.options.defaultTime || "") + "").split(":");
if (this.options.twelveHour && void 0 !== t[1] && (0 < t[1].toUpperCase().indexOf("AM") ? this.amOrPm = "AM" : this.amOrPm = "PM", t[1] = t[1].replace("AM", "").replace("PM", "")), "now" === t[0]) {
var e = new Date(+new Date + this.options.fromNow);
t = [e.getHours(), e.getMinutes()], this.options.twelveHour && (this.amOrPm = 12 <= t[0] && t[0] < 24 ? "PM" : "AM")
}
this.hours = +t[0] || 0, this.minutes = +t[1] || 0, this.spanHours.innerHTML = this.hours, this.spanMinutes.innerHTML = f._addLeadingZero(this.minutes), this._updateAmPmView()
}
}, {
key: "showView",
value: function(t, e) {
"minutes" === t && h(this.hoursView).css("visibility");
var i = "hours" === t,
n = i ? this.hoursView : this.minutesView,
s = i ? this.minutesView : this.hoursView;
this.currentView = t, h(this.spanHours).toggleClass("text-primary", i), h(this.spanMinutes).toggleClass("text-primary", !i), s.classList.add("timepicker-dial-out"), h(n).css("visibility", "visible").removeClass("timepicker-dial-out"), this.resetClock(e), clearTimeout(this.toggleViewTimer), this.toggleViewTimer = setTimeout(function() {
h(s).css("visibility", "hidden")
}, this.options.duration)
}
}, {
key: "resetClock",
value: function(t) {
var e = this.currentView,
i = this[e],
n = "hours" === e,
s = i * (Math.PI / (n ? 6 : 30)),
o = n && 0 < i && i < 13 ? this.options.innerRadius : this.options.outerRadius,
a = Math.sin(s) * o,
r = -Math.cos(s) * o,
l = this;
t ? (h(this.canvas).addClass("timepicker-canvas-out"), setTimeout(function() {
h(l.canvas).removeClass("timepicker-canvas-out"), l.setHand(a, r)
}, t)) : this.setHand(a, r)
}
}, {
key: "setHand",
value: function(t, e, i) {
var n = this,
s = Math.atan2(t, -e),
o = "hours" === this.currentView,
a = Math.PI / (o || i ? 6 : 30),
r = Math.sqrt(t * t + e * e),
l = o && r < (this.options.outerRadius + this.options.innerRadius) / 2,
h = l ? this.options.innerRadius : this.options.outerRadius;
this.options.twelveHour && (h = this.options.outerRadius), s < 0 && (s = 2 * Math.PI + s);
var d = Math.round(s / a);
s = d * a, this.options.twelveHour ? o ? 0 === d && (d = 12) : (i && (d *= 5), 60 === d && (d = 0)) : o ? (12 === d && (d = 0), d = l ? 0 === d ? 12 : d : 0 === d ? 0 : d + 12) : (i && (d *= 5), 60 === d && (d = 0)), this[this.currentView] !== d && this.vibrate && this.options.vibrate && (this.vibrateTimer || (navigator[this.vibrate](10), this.vibrateTimer = setTimeout(function() {
n.vibrateTimer = null
}, 100))), this[this.currentView] = d, o ? this.spanHours.innerHTML = d : this.spanMinutes.innerHTML = f._addLeadingZero(d);
var u = Math.sin(s) * (h - this.options.tickRadius),
c = -Math.cos(s) * (h - this.options.tickRadius),
p = Math.sin(s) * h,
v = -Math.cos(s) * h;
this.hand.setAttribute("x2", u), this.hand.setAttribute("y2", c), this.bg.setAttribute("cx", p), this.bg.setAttribute("cy", v)
}
}, {
key: "open",
value: function() {
this.isOpen || (this.isOpen = !0, this._updateTimeFromInput(), this.showView("hours"), this.modal.open())
}
}, {
key: "close",
value: function() {
this.isOpen && (this.isOpen = !1, this.modal.close())
}
}, {
key: "done",
value: function(t, e) {
var i = this.el.value,
n = e ? "" : f._addLeadingZero(this.hours) + ":" + f._addLeadingZero(this.minutes);
this.time = n, !e && this.options.twelveHour && (n = n + " " + this.amOrPm), (this.el.value = n) !== i && this.$el.trigger("change"), this.close(), this.el.focus()
}
}, {
key: "clear",
value: function() {
this.done(null, !0)
}
}], [{
key: "init",
value: function(t, e) {
return _get(f.__proto__ || Object.getPrototypeOf(f), "init", this).call(this, this, t, e)
}
}, {
key: "_addLeadingZero",
value: function(t) {
return (t < 10 ? "0" : "") + t
}
}, {
key: "_createSVGEl",
value: function(t) {
return document.createElementNS("http://www.w3.org/2000/svg", t)
}
}, {
key: "_Pos",
value: function(t) {
return t.targetTouches && 1 <= t.targetTouches.length ? {
x: t.targetTouches[0].clientX,
y: t.targetTouches[0].clientY
} : {
x: t.clientX,
y: t.clientY
}
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Timepicker
}
}, {
key: "defaults",
get: function() {
return e
}
}]), f
}();
t._template = ['<div class= "modal timepicker-modal">', '<div class="modal-content timepicker-container">', '<div class="timepicker-digital-display">', '<div class="timepicker-text-container">', '<div class="timepicker-display-column">', '<span class="timepicker-span-hours text-primary"></span>', ":", '<span class="timepicker-span-minutes"></span>', "</div>", '<div class="timepicker-display-column timepicker-display-am-pm">', '<div class="timepicker-span-am-pm"></div>', "</div>", "</div>", "</div>", '<div class="timepicker-analog-display">', '<div class="timepicker-plate">', '<div class="timepicker-canvas"></div>', '<div class="timepicker-dial timepicker-hours"></div>', '<div class="timepicker-dial timepicker-minutes timepicker-dial-out"></div>', "</div>", '<div class="timepicker-footer"></div>', "</div>", "</div>", "</div>"].join(""), M.Timepicker = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "timepicker", "M_Timepicker")
}(cash),
function(s) {
"use strict";
var e = {},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_CharacterCounter = i).options = s.extend({}, n.defaults, e), i.isInvalid = !1, i.isValidLength = !1, i._setupCounter(), i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this.el.CharacterCounter = void 0, this._removeCounter()
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleUpdateCounterBound = this.updateCounter.bind(this), this.el.addEventListener("focus", this._handleUpdateCounterBound, !0), this.el.addEventListener("input", this._handleUpdateCounterBound, !0)
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("focus", this._handleUpdateCounterBound, !0), this.el.removeEventListener("input", this._handleUpdateCounterBound, !0)
}
}, {
key: "_setupCounter",
value: function() {
this.counterEl = document.createElement("span"), s(this.counterEl).addClass("character-counter").css({
float: "right",
"font-size": "12px",
height: 1
}), this.$el.parent().append(this.counterEl)
}
}, {
key: "_removeCounter",
value: function() {
s(this.counterEl).remove()
}
}, {
key: "updateCounter",
value: function() {
var t = +this.$el.attr("data-length"),
e = this.el.value.length;
this.isValidLength = e <= t;
var i = e;
t && (i += "/" + t, this._validateInput()), s(this.counterEl).html(i)
}
}, {
key: "_validateInput",
value: function() {
this.isValidLength && this.isInvalid ? (this.isInvalid = !1, this.$el.removeClass("invalid")) : this.isValidLength || this.isInvalid || (this.isInvalid = !0, this.$el.removeClass("valid"), this.$el.addClass("invalid"))
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_CharacterCounter
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
M.CharacterCounter = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "characterCounter", "M_CharacterCounter")
}(cash),
function(b) {
"use strict";
var e = {
duration: 200,
dist: -100,
shift: 0,
padding: 0,
numVisible: 5,
fullWidth: !1,
indicators: !1,
noWrap: !1,
onCycleTo: null
},
t = function(t) {
function i(t, e) {
_classCallCheck(this, i);
var n = _possibleConstructorReturn(this, (i.__proto__ || Object.getPrototypeOf(i)).call(this, i, t, e));
return (n.el.M_Carousel = n).options = b.extend({}, i.defaults, e), n.hasMultipleSlides = 1 < n.$el.find(".carousel-item").length, n.showIndicators = n.options.indicators && n.hasMultipleSlides, n.noWrap = n.options.noWrap || !n.hasMultipleSlides, n.pressed = !1, n.dragged = !1, n.offset = n.target = 0, n.images = [], n.itemWidth = n.$el.find(".carousel-item").first().innerWidth(), n.itemHeight = n.$el.find(".carousel-item").first().innerHeight(), n.dim = 2 * n.itemWidth + n.options.padding || 1, n._autoScrollBound = n._autoScroll.bind(n), n._trackBound = n._track.bind(n), n.options.fullWidth && (n.options.dist = 0, n._setCarouselHeight(), n.showIndicators && n.$el.find(".carousel-fixed-item").addClass("with-indicators")), n.$indicators = b('<ul class="indicators"></ul>'), n.$el.find(".carousel-item").each(function(t, e) {
if (n.images.push(t), n.showIndicators) {
var i = b('<li class="indicator-item"></li>');
0 === e && i[0].classList.add("active"), n.$indicators.append(i)
}
}), n.showIndicators && n.$el.append(n.$indicators), n.count = n.images.length, n.options.numVisible = Math.min(n.count, n.options.numVisible), n.xform = "transform", ["webkit", "Moz", "O", "ms"].every(function(t) {
var e = t + "Transform";
return void 0 === document.body.style[e] || (n.xform = e, !1)
}), n._setupEventHandlers(), n._scroll(n.offset), n
}
return _inherits(i, Component), _createClass(i, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this.el.M_Carousel = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
var i = this;
this._handleCarouselTapBound = this._handleCarouselTap.bind(this), this._handleCarouselDragBound = this._handleCarouselDrag.bind(this), this._handleCarouselReleaseBound = this._handleCarouselRelease.bind(this), this._handleCarouselClickBound = this._handleCarouselClick.bind(this), void 0 !== window.ontouchstart && (this.el.addEventListener("touchstart", this._handleCarouselTapBound), this.el.addEventListener("touchmove", this._handleCarouselDragBound), this.el.addEventListener("touchend", this._handleCarouselReleaseBound)), this.el.addEventListener("mousedown", this._handleCarouselTapBound), this.el.addEventListener("mousemove", this._handleCarouselDragBound), this.el.addEventListener("mouseup", this._handleCarouselReleaseBound), this.el.addEventListener("mouseleave", this._handleCarouselReleaseBound), this.el.addEventListener("click", this._handleCarouselClickBound), this.showIndicators && this.$indicators && (this._handleIndicatorClickBound = this._handleIndicatorClick.bind(this), this.$indicators.find(".indicator-item").each(function(t, e) {
t.addEventListener("click", i._handleIndicatorClickBound)
}));
var t = M.throttle(this._handleResize, 200);
this._handleThrottledResizeBound = t.bind(this), window.addEventListener("resize", this._handleThrottledResizeBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
var i = this;
void 0 !== window.ontouchstart && (this.el.removeEventListener("touchstart", this._handleCarouselTapBound), this.el.removeEventListener("touchmove", this._handleCarouselDragBound), this.el.removeEventListener("touchend", this._handleCarouselReleaseBound)), this.el.removeEventListener("mousedown", this._handleCarouselTapBound), this.el.removeEventListener("mousemove", this._handleCarouselDragBound), this.el.removeEventListener("mouseup", this._handleCarouselReleaseBound), this.el.removeEventListener("mouseleave", this._handleCarouselReleaseBound), this.el.removeEventListener("click", this._handleCarouselClickBound), this.showIndicators && this.$indicators && this.$indicators.find(".indicator-item").each(function(t, e) {
t.removeEventListener("click", i._handleIndicatorClickBound)
}), window.removeEventListener("resize", this._handleThrottledResizeBound)
}
}, {
key: "_handleCarouselTap",
value: function(t) {
"mousedown" === t.type && b(t.target).is("img") && t.preventDefault(), this.pressed = !0, this.dragged = !1, this.verticalDragged = !1, this.reference = this._xpos(t), this.referenceY = this._ypos(t), this.velocity = this.amplitude = 0, this.frame = this.offset, this.timestamp = Date.now(), clearInterval(this.ticker), this.ticker = setInterval(this._trackBound, 100)
}
}, {
key: "_handleCarouselDrag",
value: function(t) {
var e = void 0,
i = void 0,
n = void 0;
if (this.pressed)
if (e = this._xpos(t), i = this._ypos(t), n = this.reference - e, Math.abs(this.referenceY - i) < 30 && !this.verticalDragged)(2 < n || n < -2) && (this.dragged = !0, this.reference = e, this._scroll(this.offset + n));
else {
if (this.dragged) return t.preventDefault(), t.stopPropagation(), !1;
this.verticalDragged = !0
} if (this.dragged) return t.preventDefault(), t.stopPropagation(), !1
}
}, {
key: "_handleCarouselRelease",
value: function(t) {
if (this.pressed) return this.pressed = !1, clearInterval(this.ticker), this.target = this.offset, (10 < this.velocity || this.velocity < -10) && (this.amplitude = .9 * this.velocity, this.target = this.offset + this.amplitude), this.target = Math.round(this.target / this.dim) * this.dim, this.noWrap && (this.target >= this.dim * (this.count - 1) ? this.target = this.dim * (this.count - 1) : this.target < 0 && (this.target = 0)), this.amplitude = this.target - this.offset, this.timestamp = Date.now(), requestAnimationFrame(this._autoScrollBound), this.dragged && (t.preventDefault(), t.stopPropagation()), !1
}
}, {
key: "_handleCarouselClick",
value: function(t) {
if (this.dragged) return t.preventDefault(), t.stopPropagation(), !1;
if (!this.options.fullWidth) {
var e = b(t.target).closest(".carousel-item").index();
0 !== this._wrap(this.center) - e && (t.preventDefault(), t.stopPropagation()), this._cycleTo(e)
}
}
}, {
key: "_handleIndicatorClick",
value: function(t) {
t.stopPropagation();
var e = b(t.target).closest(".indicator-item");
e.length && this._cycleTo(e.index())
}
}, {
key: "_handleResize",
value: function(t) {
this.options.fullWidth ? (this.itemWidth = this.$el.find(".carousel-item").first().innerWidth(), this.imageHeight = this.$el.find(".carousel-item.active").height(), this.dim = 2 * this.itemWidth + this.options.padding, this.offset = 2 * this.center * this.itemWidth, this.target = this.offset, this._setCarouselHeight(!0)) : this._scroll()
}
}, {
key: "_setCarouselHeight",
value: function(t) {
var i = this,
e = this.$el.find(".carousel-item.active").length ? this.$el.find(".carousel-item.active").first() : this.$el.find(".carousel-item").first(),
n = e.find("img").first();
if (n.length)
if (n[0].complete) {
var s = n.height();
if (0 < s) this.$el.css("height", s + "px");
else {
var o = n[0].naturalWidth,
a = n[0].naturalHeight,
r = this.$el.width() / o * a;
this.$el.css("height", r + "px")
}
} else n.one("load", function(t, e) {
i.$el.css("height", t.offsetHeight + "px")
});
else if (!t) {
var l = e.height();
this.$el.css("height", l + "px")
}
}
}, {
key: "_xpos",
value: function(t) {
return t.targetTouches && 1 <= t.targetTouches.length ? t.targetTouches[0].clientX : t.clientX
}
}, {
key: "_ypos",
value: function(t) {
return t.targetTouches && 1 <= t.targetTouches.length ? t.targetTouches[0].clientY : t.clientY
}
}, {
key: "_wrap",
value: function(t) {
return t >= this.count ? t % this.count : t < 0 ? this._wrap(this.count + t % this.count) : t
}
}, {
key: "_track",
value: function() {
var t, e, i, n;
e = (t = Date.now()) - this.timestamp, this.timestamp = t, i = this.offset - this.frame, this.frame = this.offset, n = 1e3 * i / (1 + e), this.velocity = .8 * n + .2 * this.velocity
}
}, {
key: "_autoScroll",
value: function() {
var t = void 0,
e = void 0;
this.amplitude && (t = Date.now() - this.timestamp, 2 < (e = this.amplitude * Math.exp(-t / this.options.duration)) || e < -2 ? (this._scroll(this.target - e), requestAnimationFrame(this._autoScrollBound)) : this._scroll(this.target))
}
}, {
key: "_scroll",
value: function(t) {
var e = this;
this.$el.hasClass("scrolling") || this.el.classList.add("scrolling"), null != this.scrollingTimeout && window.clearTimeout(this.scrollingTimeout), this.scrollingTimeout = window.setTimeout(function() {
e.$el.removeClass("scrolling")
}, this.options.duration);
var i, n, s, o, a = void 0,
r = void 0,
l = void 0,
h = void 0,
d = void 0,
u = void 0,
c = this.center,
p = 1 / this.options.numVisible;
if (this.offset = "number" == typeof t ? t : this.offset, this.center = Math.floor((this.offset + this.dim / 2) / this.dim), o = -(s = (n = this.offset - this.center * this.dim) < 0 ? 1 : -1) * n * 2 / this.dim, i = this.count >> 1, this.options.fullWidth ? (l = "translateX(0)", u = 1) : (l = "translateX(" + (this.el.clientWidth - this.itemWidth) / 2 + "px) ", l += "translateY(" + (this.el.clientHeight - this.itemHeight) / 2 + "px)", u = 1 - p * o), this.showIndicators) {
var v = this.center % this.count,
f = this.$indicators.find(".indicator-item.active");
f.index() !== v && (f.removeClass("active"), this.$indicators.find(".indicator-item").eq(v)[0].classList.add("active"))
}
if (!this.noWrap || 0 <= this.center && this.center < this.count) {
r = this.images[this._wrap(this.center)], b(r).hasClass("active") || (this.$el.find(".carousel-item").removeClass("active"), r.classList.add("active"));
var m = l + " translateX(" + -n / 2 + "px) translateX(" + s * this.options.shift * o * a + "px) translateZ(" + this.options.dist * o + "px)";
this._updateItemStyle(r, u, 0, m)
}
for (a = 1; a <= i; ++a) {
if (this.options.fullWidth ? (h = this.options.dist, d = a === i && n < 0 ? 1 - o : 1) : (h = this.options.dist * (2 * a + o * s), d = 1 - p * (2 * a + o * s)), !this.noWrap || this.center + a < this.count) {
r = this.images[this._wrap(this.center + a)];
var g = l + " translateX(" + (this.options.shift + (this.dim * a - n) / 2) + "px) translateZ(" + h + "px)";
this._updateItemStyle(r, d, -a, g)
}
if (this.options.fullWidth ? (h = this.options.dist, d = a === i && 0 < n ? 1 - o : 1) : (h = this.options.dist * (2 * a - o * s), d = 1 - p * (2 * a - o * s)), !this.noWrap || 0 <= this.center - a) {
r = this.images[this._wrap(this.center - a)];
var _ = l + " translateX(" + (-this.options.shift + (-this.dim * a - n) / 2) + "px) translateZ(" + h + "px)";
this._updateItemStyle(r, d, -a, _)
}
}
if (!this.noWrap || 0 <= this.center && this.center < this.count) {
r = this.images[this._wrap(this.center)];
var y = l + " translateX(" + -n / 2 + "px) translateX(" + s * this.options.shift * o + "px) translateZ(" + this.options.dist * o + "px)";
this._updateItemStyle(r, u, 0, y)
}
var k = this.$el.find(".carousel-item").eq(this._wrap(this.center));
c !== this.center && "function" == typeof this.options.onCycleTo && this.options.onCycleTo.call(this, k[0], this.dragged), "function" == typeof this.oneTimeCallback && (this.oneTimeCallback.call(this, k[0], this.dragged), this.oneTimeCallback = null)
}
}, {
key: "_updateItemStyle",
value: function(t, e, i, n) {
t.style[this.xform] = n, t.style.zIndex = i, t.style.opacity = e, t.style.visibility = "visible"
}
}, {
key: "_cycleTo",
value: function(t, e) {
var i = this.center % this.count - t;
this.noWrap || (i < 0 ? Math.abs(i + this.count) < Math.abs(i) && (i += this.count) : 0 < i && Math.abs(i - this.count) < i && (i -= this.count)), this.target = this.dim * Math.round(this.offset / this.dim), i < 0 ? this.target += this.dim * Math.abs(i) : 0 < i && (this.target -= this.dim * i), "function" == typeof e && (this.oneTimeCallback = e), this.offset !== this.target && (this.amplitude = this.target - this.offset, this.timestamp = Date.now(), requestAnimationFrame(this._autoScrollBound))
}
}, {
key: "next",
value: function(t) {
(void 0 === t || isNaN(t)) && (t = 1);
var e = this.center + t;
if (e >= this.count || e < 0) {
if (this.noWrap) return;
e = this._wrap(e)
}
this._cycleTo(e)
}
}, {
key: "prev",
value: function(t) {
(void 0 === t || isNaN(t)) && (t = 1);
var e = this.center - t;
if (e >= this.count || e < 0) {
if (this.noWrap) return;
e = this._wrap(e)
}
this._cycleTo(e)
}
}, {
key: "set",
value: function(t, e) {
if ((void 0 === t || isNaN(t)) && (t = 0), t > this.count || t < 0) {
if (this.noWrap) return;
t = this._wrap(t)
}
this._cycleTo(t, e)
}
}], [{
key: "init",
value: function(t, e) {
return _get(i.__proto__ || Object.getPrototypeOf(i), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Carousel
}
}, {
key: "defaults",
get: function() {
return e
}
}]), i
}();
M.Carousel = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "carousel", "M_Carousel")
}(cash),
function(S) {
"use strict";
var e = {
onOpen: void 0,
onClose: void 0
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_TapTarget = i).options = S.extend({}, n.defaults, e), i.isOpen = !1, i.$origin = S("#" + i.$el.attr("data-target")), i._setup(), i._calculatePositioning(), i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this.el.TapTarget = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleDocumentClickBound = this._handleDocumentClick.bind(this), this._handleTargetClickBound = this._handleTargetClick.bind(this), this._handleOriginClickBound = this._handleOriginClick.bind(this), this.el.addEventListener("click", this._handleTargetClickBound), this.originEl.addEventListener("click", this._handleOriginClickBound);
var t = M.throttle(this._handleResize, 200);
this._handleThrottledResizeBound = t.bind(this), window.addEventListener("resize", this._handleThrottledResizeBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("click", this._handleTargetClickBound), this.originEl.removeEventListener("click", this._handleOriginClickBound), window.removeEventListener("resize", this._handleThrottledResizeBound)
}
}, {
key: "_handleTargetClick",
value: function(t) {
this.open()
}
}, {
key: "_handleOriginClick",
value: function(t) {
this.close()
}
}, {
key: "_handleResize",
value: function(t) {
this._calculatePositioning()
}
}, {
key: "_handleDocumentClick",
value: function(t) {
S(t.target).closest(".tap-target-wrapper").length || (this.close(), t.preventDefault(), t.stopPropagation())
}
}, {
key: "_setup",
value: function() {
this.wrapper = this.$el.parent()[0], this.waveEl = S(this.wrapper).find(".tap-target-wave")[0], this.originEl = S(this.wrapper).find(".tap-target-origin")[0], this.contentEl = this.$el.find(".tap-target-content")[0], S(this.wrapper).hasClass(".tap-target-wrapper") || (this.wrapper = document.createElement("div"), this.wrapper.classList.add("tap-target-wrapper"), this.$el.before(S(this.wrapper)), this.wrapper.append(this.el)), this.contentEl || (this.contentEl = document.createElement("div"), this.contentEl.classList.add("tap-target-content"), this.$el.append(this.contentEl)), this.waveEl || (this.waveEl = document.createElement("div"), this.waveEl.classList.add("tap-target-wave"), this.originEl || (this.originEl = this.$origin.clone(!0, !0), this.originEl.addClass("tap-target-origin"), this.originEl.removeAttr("id"), this.originEl.removeAttr("style"), this.originEl = this.originEl[0], this.waveEl.append(this.originEl)), this.wrapper.append(this.waveEl))
}
}, {
key: "_calculatePositioning",
value: function() {
var t = "fixed" === this.$origin.css("position");
if (!t)
for (var e = this.$origin.parents(), i = 0; i < e.length && !(t = "fixed" == S(e[i]).css("position")); i++);
var n = this.$origin.outerWidth(),
s = this.$origin.outerHeight(),
o = t ? this.$origin.offset().top - M.getDocumentScrollTop() : this.$origin.offset().top,
a = t ? this.$origin.offset().left - M.getDocumentScrollLeft() : this.$origin.offset().left,
r = window.innerWidth,
l = window.innerHeight,
h = r / 2,
d = l / 2,
u = a <= h,
c = h < a,
p = o <= d,
v = d < o,
f = .25 * r <= a && a <= .75 * r,
m = this.$el.outerWidth(),
g = this.$el.outerHeight(),
_ = o + s / 2 - g / 2,
y = a + n / 2 - m / 2,
k = t ? "fixed" : "absolute",
b = f ? m : m / 2 + n,
w = g / 2,
C = p ? g / 2 : 0,
E = u && !f ? m / 2 - n : 0,
O = n,
x = v ? "bottom" : "top",
L = 2 * n,
T = L,
$ = g / 2 - T / 2,
B = m / 2 - L / 2,
D = {};
D.top = p ? _ + "px" : "", D.right = c ? r - y - m + "px" : "", D.bottom = v ? l - _ - g + "px" : "", D.left = u ? y + "px" : "", D.position = k, S(this.wrapper).css(D), S(this.contentEl).css({
width: b + "px",
height: w + "px",
top: C + "px",
right: "0px",
bottom: "0px",
left: E + "px",
padding: O + "px",
verticalAlign: x
}), S(this.waveEl).css({
top: $ + "px",
left: B + "px",
width: L + "px",
height: T + "px"
})
}
}, {
key: "open",
value: function() {
this.isOpen || ("function" == typeof this.options.onOpen && this.options.onOpen.call(this, this.$origin[0]), this.isOpen = !0, this.wrapper.classList.add("open"), document.body.addEventListener("click", this._handleDocumentClickBound, !0), document.body.addEventListener("touchend", this._handleDocumentClickBound))
}
}, {
key: "close",
value: function() {
this.isOpen && ("function" == typeof this.options.onClose && this.options.onClose.call(this, this.$origin[0]), this.isOpen = !1, this.wrapper.classList.remove("open"), document.body.removeEventListener("click", this._handleDocumentClickBound, !0), document.body.removeEventListener("touchend", this._handleDocumentClickBound))
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_TapTarget
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
M.TapTarget = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "tapTarget", "M_TapTarget")
}(cash),
function(d) {
"use strict";
var e = {
classes: "",
dropdownOptions: {}
},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return i.$el.hasClass("browser-default") ? _possibleConstructorReturn(i) : ((i.el.M_FormSelect = i).options = d.extend({}, n.defaults, e), i.isMultiple = i.$el.prop("multiple"), i.el.tabIndex = -1, i._keysSelected = {}, i._valueDict = {}, i._setupDropdown(), i._setupEventHandlers(), i)
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this._removeDropdown(), this.el.M_FormSelect = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
var e = this;
this._handleSelectChangeBound = this._handleSelectChange.bind(this), this._handleOptionClickBound = this._handleOptionClick.bind(this), this._handleInputClickBound = this._handleInputClick.bind(this), d(this.dropdownOptions).find("li:not(.optgroup)").each(function(t) {
t.addEventListener("click", e._handleOptionClickBound)
}), this.el.addEventListener("change", this._handleSelectChangeBound), this.input.addEventListener("click", this._handleInputClickBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
var e = this;
d(this.dropdownOptions).find("li:not(.optgroup)").each(function(t) {
t.removeEventListener("click", e._handleOptionClickBound)
}), this.el.removeEventListener("change", this._handleSelectChangeBound), this.input.removeEventListener("click", this._handleInputClickBound)
}
}, {
key: "_handleSelectChange",
value: function(t) {
this._setValueToInput()
}
}, {
key: "_handleOptionClick",
value: function(t) {
t.preventDefault();
var e = d(t.target).closest("li")[0],
i = e.id;
if (!d(e).hasClass("disabled") && !d(e).hasClass("optgroup") && i.length) {
var n = !0;
if (this.isMultiple) {
var s = d(this.dropdownOptions).find("li.disabled.selected");
s.length && (s.removeClass("selected"), s.find('input[type="checkbox"]').prop("checked", !1), this._toggleEntryFromArray(s[0].id)), n = this._toggleEntryFromArray(i)
} else d(this.dropdownOptions).find("li").removeClass("selected"), d(e).toggleClass("selected", n);
d(this._valueDict[i].el).prop("selected") !== n && (d(this._valueDict[i].el).prop("selected", n), this.$el.trigger("change"))
}
t.stopPropagation()
}
}, {
key: "_handleInputClick",
value: function() {
this.dropdown && this.dropdown.isOpen && (this._setValueToInput(), this._setSelectedStates())
}
}, {
key: "_setupDropdown",
value: function() {
var n = this;
this.wrapper = document.createElement("div"), d(this.wrapper).addClass("select-wrapper " + this.options.classes), this.$el.before(d(this.wrapper)), this.wrapper.appendChild(this.el), this.el.disabled && this.wrapper.classList.add("disabled"), this.$selectOptions = this.$el.children("option, optgroup"), this.dropdownOptions = document.createElement("ul"), this.dropdownOptions.id = "select-options-" + M.guid(), d(this.dropdownOptions).addClass("dropdown-content select-dropdown " + (this.isMultiple ? "multiple-select-dropdown" : "")), this.$selectOptions.length && this.$selectOptions.each(function(t) {
if (d(t).is("option")) {
var e = void 0;
e = n.isMultiple ? n._appendOptionWithIcon(n.$el, t, "multiple") : n._appendOptionWithIcon(n.$el, t), n._addOptionToValueDict(t, e)
} else if (d(t).is("optgroup")) {
var i = d(t).children("option");
d(n.dropdownOptions).append(d('<li class="optgroup"><span>' + t.getAttribute("label") + "</span></li>")[0]), i.each(function(t) {
var e = n._appendOptionWithIcon(n.$el, t, "optgroup-option");
n._addOptionToValueDict(t, e)
})
}
}), this.$el.after(this.dropdownOptions), this.input = document.createElement("input"), d(this.input).addClass("select-dropdown dropdown-trigger").addStyle("display:none"), this.input.setAttribute("type", "text"), this.input.setAttribute("readonly", "true"), this.input.setAttribute("data-target", this.dropdownOptions.id), this.el.disabled && d(this.input).prop("disabled", "true"), this.$el.before(this.input), this._setValueToInput();
var t = d('<svg class="caret" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M7 10l5 5 5-5z"/><path d="M0 0h24v24H0z" fill="none"/></svg>');
if (this.$el.before(t[0]), !this.el.disabled) {
var e = d.extend({}, this.options.dropdownOptions);
e.onOpenEnd = function(t) {
var e = d(n.dropdownOptions).find(".selected").first();
if (e.length && (M.keyDown = !0, n.dropdown.focusedIndex = e.index(), n.dropdown._focusFocusedItem(), M.keyDown = !1, n.dropdown.isScrollable)) {
var i = e[0].getBoundingClientRect().top - n.dropdownOptions.getBoundingClientRect().top;
i -= n.dropdownOptions.clientHeight / 2, n.dropdownOptions.scrollTop = i
}
}, this.isMultiple && (e.closeOnClick = !1), this.dropdown = M.Dropdown.init(this.input, e)
}
this._setSelectedStates()
}
}, {
key: "_addOptionToValueDict",
value: function(t, e) {
var i = Object.keys(this._valueDict).length,
n = this.dropdownOptions.id + i,
s = {};
e.id = n, s.el = t, s.optionEl = e, this._valueDict[n] = s
}
}, {
key: "_removeDropdown",
value: function() {
d(this.wrapper).find(".caret").remove(), d(this.input).remove(), d(this.dropdownOptions).remove(), d(this.wrapper).before(this.$el), d(this.wrapper).remove()
}
}, {
key: "_appendOptionWithIcon",
value: function(t, e, i) {
var n = e.disabled ? "disabled " : "",
s = "optgroup-option" === i ? "optgroup-option " : "",
o = this.isMultiple ? '<label><input type="checkbox"' + n + '"/><span>' + e.innerHTML + "</span></label>" : e.innerHTML,
a = d("<li></li>"),
r = d("<span></span>");
r.html(o), a.addClass(n + " " + s), a.append(r);
var l = e.getAttribute("data-icon");
if (l) {
var h = d('<img alt="" src="' + l + '">');
a.prepend(h)
}
return d(this.dropdownOptions).append(a[0]), a[0]
}
}, {
key: "_toggleEntryFromArray",
value: function(t) {
var e = !this._keysSelected.hasOwnProperty(t),
i = d(this._valueDict[t].optionEl);
return e ? this._keysSelected[t] = !0 : delete this._keysSelected[t], i.toggleClass("selected", e), i.find('input[type="checkbox"]').prop("checked", e), i.prop("selected", e), e
}
}, {
key: "_setValueToInput",
value: function() {
var i = [];
if (this.$el.find("option").each(function(t) {
if (d(t).prop("selected")) {
var e = d(t).text();
i.push(e)
}
}), !i.length) {
var t = this.$el.find("option:disabled").eq(0);
t.length && "" === t[0].value && i.push(t.text())
}
this.input.value = i.join(", ")
}
}, {
key: "_setSelectedStates",
value: function() {
for (var t in this._keysSelected = {}, this._valueDict) {
var e = this._valueDict[t],
i = d(e.el).prop("selected");
d(e.optionEl).find('input[type="checkbox"]').prop("checked", i), i ? (this._activateOption(d(this.dropdownOptions), d(e.optionEl)), this._keysSelected[t] = !0) : d(e.optionEl).removeClass("selected")
}
}
}, {
key: "_activateOption",
value: function(t, e) {
e && (this.isMultiple || t.find("li.selected").removeClass("selected"), d(e).addClass("selected"))
}
}, {
key: "getSelectedValues",
value: function() {
var t = [];
for (var e in this._keysSelected) t.push(this._valueDict[e].el.value);
return t
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_FormSelect
}
}, {
key: "defaults",
get: function() {
return e
}
}]), n
}();
M.FormSelect = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "formSelect", "M_FormSelect")
}(cash),
function(s, e) {
"use strict";
var i = {},
t = function(t) {
function n(t, e) {
_classCallCheck(this, n);
var i = _possibleConstructorReturn(this, (n.__proto__ || Object.getPrototypeOf(n)).call(this, n, t, e));
return (i.el.M_Range = i).options = s.extend({}, n.defaults, e), i._mousedown = !1, i._setupThumb(), i._setupEventHandlers(), i
}
return _inherits(n, Component), _createClass(n, [{
key: "destroy",
value: function() {
this._removeEventHandlers(), this._removeThumb(), this.el.M_Range = void 0
}
}, {
key: "_setupEventHandlers",
value: function() {
this._handleRangeChangeBound = this._handleRangeChange.bind(this), this._handleRangeMousedownTouchstartBound = this._handleRangeMousedownTouchstart.bind(this), this._handleRangeInputMousemoveTouchmoveBound = this._handleRangeInputMousemoveTouchmove.bind(this), this._handleRangeMouseupTouchendBound = this._handleRangeMouseupTouchend.bind(this), this._handleRangeBlurMouseoutTouchleaveBound = this._handleRangeBlurMouseoutTouchleave.bind(this), this.el.addEventListener("change", this._handleRangeChangeBound), this.el.addEventListener("mousedown", this._handleRangeMousedownTouchstartBound), this.el.addEventListener("touchstart", this._handleRangeMousedownTouchstartBound), this.el.addEventListener("input", this._handleRangeInputMousemoveTouchmoveBound), this.el.addEventListener("mousemove", this._handleRangeInputMousemoveTouchmoveBound), this.el.addEventListener("touchmove", this._handleRangeInputMousemoveTouchmoveBound), this.el.addEventListener("mouseup", this._handleRangeMouseupTouchendBound), this.el.addEventListener("touchend", this._handleRangeMouseupTouchendBound), this.el.addEventListener("blur", this._handleRangeBlurMouseoutTouchleaveBound), this.el.addEventListener("mouseout", this._handleRangeBlurMouseoutTouchleaveBound), this.el.addEventListener("touchleave", this._handleRangeBlurMouseoutTouchleaveBound)
}
}, {
key: "_removeEventHandlers",
value: function() {
this.el.removeEventListener("change", this._handleRangeChangeBound), this.el.removeEventListener("mousedown", this._handleRangeMousedownTouchstartBound), this.el.removeEventListener("touchstart", this._handleRangeMousedownTouchstartBound), this.el.removeEventListener("input", this._handleRangeInputMousemoveTouchmoveBound), this.el.removeEventListener("mousemove", this._handleRangeInputMousemoveTouchmoveBound), this.el.removeEventListener("touchmove", this._handleRangeInputMousemoveTouchmoveBound), this.el.removeEventListener("mouseup", this._handleRangeMouseupTouchendBound), this.el.removeEventListener("touchend", this._handleRangeMouseupTouchendBound), this.el.removeEventListener("blur", this._handleRangeBlurMouseoutTouchleaveBound), this.el.removeEventListener("mouseout", this._handleRangeBlurMouseoutTouchleaveBound), this.el.removeEventListener("touchleave", this._handleRangeBlurMouseoutTouchleaveBound)
}
}, {
key: "_handleRangeChange",
value: function() {
s(this.value).html(this.$el.val()), s(this.thumb).hasClass("active") || this._showRangeBubble();
var t = this._calcRangeOffset();
s(this.thumb).addClass("active").css("left", t + "px")
}
}, {
key: "_handleRangeMousedownTouchstart",
value: function(t) {
if (s(this.value).html(this.$el.val()), this._mousedown = !0, this.$el.addClass("active"), s(this.thumb).hasClass("active") || this._showRangeBubble(), "input" !== t.type) {
var e = this._calcRangeOffset();
s(this.thumb).addClass("active").css("left", e + "px")
}
}
}, {
key: "_handleRangeInputMousemoveTouchmove",
value: function() {
if (this._mousedown) {
s(this.thumb).hasClass("active") || this._showRangeBubble();
var t = this._calcRangeOffset();
s(this.thumb).addClass("active").css("left", t + "px"), s(this.value).html(this.$el.val())
}
}
}, {
key: "_handleRangeMouseupTouchend",
value: function() {
this._mousedown = !1, this.$el.removeClass("active")
}
}, {
key: "_handleRangeBlurMouseoutTouchleave",
value: function() {
if (!this._mousedown) {
var t = 7 + parseInt(this.$el.css("padding-left")) + "px";
s(this.thumb).hasClass("active") && (e.remove(this.thumb), e({
targets: this.thumb,
height: 0,
width: 0,
top: 10,
easing: "easeOutQuad",
marginLeft: t,
duration: 100
})), s(this.thumb).removeClass("active")
}
}
}, {
key: "_setupThumb",
value: function() {
this.thumb = document.createElement("span"), this.value = document.createElement("span"), s(this.thumb).addClass("thumb"), s(this.value).addClass("value"), s(this.thumb).append(this.value), this.$el.after(this.thumb)
}
}, {
key: "_removeThumb",
value: function() {
s(this.thumb).remove()
}
}, {
key: "_showRangeBubble",
value: function() {
var t = -7 + parseInt(s(this.thumb).parent().css("padding-left")) + "px";
e.remove(this.thumb), e({
targets: this.thumb,
height: 30,
width: 30,
top: -30,
marginLeft: t,
duration: 300,
easing: "easeOutQuint"
})
}
}, {
key: "_calcRangeOffset",
value: function() {
var t = this.$el.width() - 15,
e = parseFloat(this.$el.attr("max")) || 100,
i = parseFloat(this.$el.attr("min")) || 0;
return (parseFloat(this.$el.val()) - i) / (e - i) * t
}
}], [{
key: "init",
value: function(t, e) {
return _get(n.__proto__ || Object.getPrototypeOf(n), "init", this).call(this, this, t, e)
}
}, {
key: "getInstance",
value: function(t) {
return (t.jquery ? t[0] : t).M_Range
}
}, {
key: "defaults",
get: function() {
return i
}
}]), n
}();
M.Range = t, M.jQueryLoaded && M.initializeJqueryWrapper(t, "range", "M_Range"), t.init(s("input[type=range]"))
}(cash, M.anime);