Created
May 23, 2016 01:26
-
-
Save nfq/72244dfca8f8ee9efaebfc5844471208 to your computer and use it in GitHub Desktop.
This file has been truncated, but you can view the full file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
AngularJS v1.2.5 | |
(c) 2010-2014 Google, Inc. http://angularjs.org | |
License: MIT | |
*/ | |
(function(W, N, r) { | |
'use strict'; | |
function G(b) { | |
return function() { | |
var a = arguments[0], c, a = "[" + (b ? b + ":" : "") + a + "] http://errors.angularjs.org/1.2.5/" + (b ? b + "/" : "") + a; | |
for (c = 1; c < arguments.length; c++) | |
a = a + (1 == c ? "?" : "&") + "p" + (c - 1) + "=" + encodeURIComponent("function" == typeof arguments[c] ? arguments[c].toString().replace(/ \{[\s\S]*$/, "") : "undefined" == typeof arguments[c] ? "undefined" : "string" != typeof arguments[c] ? JSON.stringify(arguments[c]) : arguments[c]); | |
return Error(a) | |
} | |
} | |
function pb(b) { | |
if (null == b || Aa(b)) | |
return !1; | |
var a = | |
b.length; | |
return 1 === b.nodeType && a?!0 : D(b) || L(b) || 0 === a || "number" === typeof a && 0 < a && a - 1 in b | |
} | |
function q(b, a, c) { | |
var d; | |
if (b) | |
if (A(b)) | |
for (d in b) | |
"prototype" != d && ("length" != d && "name" != d && b.hasOwnProperty(d)) && a.call(c, b[d], d); | |
else if (b.forEach && b.forEach !== q) | |
b.forEach(a, c); | |
else if (pb(b)) | |
for (d = 0; d < b.length; d++) | |
a.call(c, b[d], d); | |
else | |
for (d in b) | |
b.hasOwnProperty(d) && a.call(c, b[d], d); | |
return b | |
} | |
function Ob(b) { | |
var a = [], c; | |
for (c in b) | |
b.hasOwnProperty(c) && a.push(c); | |
return a.sort() | |
} | |
function Nc(b, a, c) { | |
for (var d = Ob(b), | |
e = 0; e < d.length; e++) | |
a.call(c, b[d[e]], d[e]); | |
return d | |
} | |
function Pb(b) { | |
return function(a, c) { | |
b(c, a) | |
} | |
} | |
function Za() { | |
for (var b = ja.length, a; b;) { | |
b--; | |
a = ja[b].charCodeAt(0); | |
if (57 == a) | |
return ja[b] = "A", ja.join(""); | |
if (90 == a) | |
ja[b] = "0"; | |
else | |
return ja[b] = String.fromCharCode(a + 1), ja.join("") | |
} | |
ja.unshift("0"); | |
return ja.join("") | |
} | |
function Qb(b, a) { | |
a ? b.$$hashKey = a : delete b.$$hashKey | |
} | |
function w(b) { | |
var a = b.$$hashKey; | |
q(arguments, function(a) { | |
a !== b && q(a, function(a, c) { | |
b[c] = a | |
}) | |
}); | |
Qb(b, a); | |
return b | |
} | |
function R(b) { | |
return parseInt(b, | |
10) | |
} | |
function Rb(b, a) { | |
return w(new (w(function() {}, { | |
prototype: b | |
})), a) | |
} | |
function s() {} | |
function Ba(b) { | |
return b | |
} | |
function ca(b) { | |
return function() { | |
return b | |
} | |
} | |
function H(b) { | |
return "undefined" === typeof b | |
} | |
function z(b) { | |
return "undefined" !== typeof b | |
} | |
function U(b) { | |
return null != b && "object" === typeof b | |
} | |
function D(b) { | |
return "string" === typeof b | |
} | |
function qb(b) { | |
return "number" === typeof b | |
} | |
function La(b) { | |
return "[object Date]" === $a.call(b) | |
} | |
function L(b) { | |
return "[object Array]" === $a.call(b) | |
} | |
function A(b) { | |
return "function" === typeof b | |
} | |
function ab(b) { | |
return "[object RegExp]" === $a.call(b) | |
} | |
function Aa(b) { | |
return b && b.document && b.location && b.alert && b.setInterval | |
} | |
function Oc(b) { | |
return !(!b ||!(b.nodeName || b.on && b.find)) | |
} | |
function Pc(b, a, c) { | |
var d = []; | |
q(b, function(b, g, f) { | |
d.push(a.call(c, b, g, f)) | |
}); | |
return d | |
} | |
function bb(b, a) { | |
if (b.indexOf) | |
return b.indexOf(a); | |
for (var c = 0; c < b.length; c++) | |
if (a === b[c]) | |
return c; | |
return - 1 | |
} | |
function Ma(b, a) { | |
var c = bb(b, a); | |
0 <= c && b.splice(c, 1); | |
return a | |
} | |
function ga(b, a) { | |
if (Aa(b) || b && b.$evalAsync && b.$watch) | |
throw Na("cpws"); | |
if (a) { | |
if (b === | |
a) | |
throw Na("cpi"); | |
if (L(b)) | |
for (var c = a.length = 0; c < b.length; c++) | |
a.push(ga(b[c])); | |
else { | |
c = a.$$hashKey; | |
q(a, function(b, c) { | |
delete a[c] | |
}); | |
for (var d in b) | |
a[d] = ga(b[d]); | |
Qb(a, c) | |
} | |
} else (a = b) | |
&& (L(b) ? a = ga(b, []) : La(b) ? a = new Date(b.getTime()) : ab(b) ? a = RegExp(b.source) : U(b) && (a = ga(b, {}))); | |
return a | |
} | |
function Qc(b, a) { | |
a = a || {}; | |
for (var c in b) | |
b.hasOwnProperty(c) && "$$" !== c.substr(0, 2) && (a[c] = b[c]); | |
return a | |
} | |
function ta(b, a) { | |
if (b === a) | |
return !0; | |
if (null === b || null === a) | |
return !1; | |
if (b !== b && a !== a) | |
return !0; | |
var c = typeof b, d; | |
if (c == typeof a && | |
"object" == c) | |
if (L(b)) { | |
if (!L(a)) | |
return !1; | |
if ((c = b.length) == a.length) { | |
for (d = 0; d < c; d++) | |
if (!ta(b[d], a[d])) | |
return !1; | |
return !0 | |
} | |
} else { | |
if (La(b)) | |
return La(a) && b.getTime() == a.getTime(); | |
if (ab(b) && ab(a)) | |
return b.toString() == a.toString(); | |
if (b && b.$evalAsync && b.$watch || a && a.$evalAsync && a.$watch || Aa(b) || Aa(a) || L(a)) | |
return !1; | |
c = {}; | |
for (d in b) | |
if ("$" !== d.charAt(0)&&!A(b[d])) { | |
if (!ta(b[d], a[d])) | |
return !1; | |
c[d]=!0 | |
} | |
for (d in a) | |
if (!c.hasOwnProperty(d) && "$" !== d.charAt(0) && a[d] !== r&&!A(a[d])) | |
return !1; | |
return !0 | |
} | |
return !1 | |
} | |
function Sb() { | |
return N.securityPolicy && | |
N.securityPolicy.isActive || N.querySelector&&!(!N.querySelector("[ng-csp]")&&!N.querySelector("[data-ng-csp]")) | |
} | |
function rb(b, a) { | |
var c = 2 < arguments.length ? ua.call(arguments, 2): []; | |
return !A(a) || a instanceof RegExp ? a : c.length ? function() { | |
return arguments.length ? a.apply(b, c.concat(ua.call(arguments, 0))) : a.apply(b, c) | |
} : function() { | |
return arguments.length ? a.apply(b, arguments) : a.call(b) | |
} | |
} | |
function Rc(b, a) { | |
var c = a; | |
"string" === typeof b && "$" === b.charAt(0) ? c = r : Aa(a) ? c = "$WINDOW" : a && N === a ? c = "$DOCUMENT" : a && (a.$evalAsync && | |
a.$watch) && (c = "$SCOPE"); | |
return c | |
} | |
function oa(b, a) { | |
return "undefined" === typeof b ? r : JSON.stringify(b, Rc, a ? " " : null) | |
} | |
function Tb(b) { | |
return D(b) ? JSON.parse(b) : b | |
} | |
function Oa(b) { | |
b && 0 !== b.length ? (b = v("" + b), b=!("f" == b || "0" == b || "false" == b || "no" == b || "n" == b || "[]" == b)) : b=!1; | |
return b | |
} | |
function ha(b) { | |
b = x(b).clone(); | |
try { | |
b.empty() | |
} catch (a) {} | |
var c = x("<div>").append(b).html(); | |
try { | |
return 3 === b[0].nodeType ? v(c) : c.match(/^(<[^>]+>)/)[1].replace(/^<([\w\-]+)/, function(a, b) { | |
return "<" + v(b) | |
}) | |
} catch (d) { | |
return v(c) | |
} | |
} | |
function Ub(b) { | |
try { | |
return decodeURIComponent(b) | |
} catch (a) {} | |
} | |
function Vb(b) { | |
var a = {}, c, d; | |
q((b || "").split("&"), function(b) { | |
b && (c = b.split("="), d = Ub(c[0]), z(d) && (b = z(c[1]) ? Ub(c[1]) : !0, a[d] ? L(a[d]) ? a[d].push(b) : a[d] = [a[d], b] : a[d] = b)) | |
}); | |
return a | |
} | |
function Wb(b) { | |
var a = []; | |
q(b, function(b, d) { | |
L(b) ? q(b, function(b) { | |
a.push(va(d, !0) + (!0 === b ? "" : "=" + va(b, !0))) | |
}) : a.push(va(d, !0) + (!0 === b ? "" : "=" + va(b, !0))) | |
}); | |
return a.length ? a.join("&") : "" | |
} | |
function sb(b) { | |
return va(b, !0).replace(/%26/gi, "&").replace(/%3D/gi, "=").replace(/%2B/gi, "+") | |
} | |
function va(b, a) { | |
return encodeURIComponent(b).replace(/%40/gi, | |
"@").replace(/%3A/gi, ":").replace(/%24/g, "$").replace(/%2C/gi, ",").replace(/%20/g, a ? "%20" : "+") | |
} | |
function Sc(b, a) { | |
function c(a) { | |
a && d.push(a) | |
} | |
var d = [b], e, g, f = ["ng:app", "ng-app", "x-ng-app", "data-ng-app"], h = /\sng[:\-]app(:\s*([\w\d_]+);?)?\s/; | |
q(f, function(a) { | |
f[a]=!0; | |
c(N.getElementById(a)); | |
a = a.replace(":", "\\:"); | |
b.querySelectorAll && (q(b.querySelectorAll("." + a), c), q(b.querySelectorAll("." + a + "\\:"), c), q(b.querySelectorAll("[" + a + "]"), c)) | |
}); | |
q(d, function(a) { | |
if (!e) { | |
var b = h.exec(" " + a.className + " "); | |
b ? (e = a, g = | |
(b[2] || "").replace(/\s+/g, ",")) : q(a.attributes, function(b) { | |
!e && f[b.name] && (e = a, g = b.value) | |
}) | |
} | |
}); | |
e && a(e, g ? [g] : []) | |
} | |
function Xb(b, a) { | |
var c = function() { | |
b = x(b); | |
if (b.injector()) { | |
var c = b[0] === N ? "document": ha(b); | |
throw Na("btstrpd", c); | |
} | |
a = a || []; | |
a.unshift(["$provide", function(a) { | |
a.value("$rootElement", b) | |
} | |
]); | |
a.unshift("ng"); | |
c = Yb(a); | |
c.invoke(["$rootScope", "$rootElement", "$compile", "$injector", "$animate", function(a, b, c, d, e) { | |
a.$apply(function() { | |
b.data("$injector", d); | |
c(b)(a) | |
}) | |
} | |
]); | |
return c | |
}, d = /^NG_DEFER_BOOTSTRAP!/; | |
if (W&&!d.test(W.name)) | |
return c(); | |
W.name = W.name.replace(d, ""); | |
Pa.resumeBootstrap = function(b) { | |
q(b, function(b) { | |
a.push(b) | |
}); | |
c() | |
} | |
} | |
function cb(b, a) { | |
a = a || "_"; | |
return b.replace(Tc, function(b, d) { | |
return (d ? a : "") + b.toLowerCase() | |
}) | |
} | |
function tb(b, a, c) { | |
if (!b) | |
throw Na("areq", a || "?", c || "required"); | |
return b | |
} | |
function Qa(b, a, c) { | |
c && L(b) && (b = b[b.length - 1]); | |
tb(A(b), a, "not a function, got " + (b && "object" == typeof b ? b.constructor.name || "Object" : typeof b)); | |
return b | |
} | |
function wa(b, a) { | |
if ("hasOwnProperty" === b) | |
throw Na("badname", | |
a); | |
} | |
function ub(b, a, c) { | |
if (!a) | |
return b; | |
a = a.split("."); | |
for (var d, e = b, g = a.length, f = 0; f < g; f++) | |
d = a[f], b && (b = (e = b)[d]); | |
return !c && A(b) ? rb(e, b) : b | |
} | |
function vb(b) { | |
var a = b[0]; | |
b = b[b.length - 1]; | |
if (a === b) | |
return x(a); | |
var c = [a]; | |
do { | |
a = a.nextSibling; | |
if (!a) | |
break; | |
c.push(a) | |
} | |
while (a !== b); | |
return x(c) | |
} | |
function Uc(b) { | |
var a = G("$injector"), c = G("ng"); | |
b = b.angular || (b.angular = {}); | |
b.$$minErr = b.$$minErr || G; | |
return b.module || (b.module = function() { | |
var b = {}; | |
return function(e, g, f) { | |
if ("hasOwnProperty" === e) | |
throw c("badname", "module"); | |
g && | |
b.hasOwnProperty(e) && (b[e] = null); | |
return b[e] || (b[e] = function() { | |
function b(a, d, e) { | |
return function() { | |
c[e || "push"]([a, d, arguments]); | |
return n | |
} | |
} | |
if (!g) | |
throw a("nomod", e); | |
var c = [], d = [], m = b("$injector", "invoke"), n = { | |
_invokeQueue: c, | |
_runBlocks: d, | |
requires: g, | |
name: e, | |
provider: b("$provide", "provider"), | |
factory: b("$provide", "factory"), | |
service: b("$provide", "service"), | |
value: b("$provide", "value"), | |
constant: b("$provide", "constant", "unshift"), | |
animation: b("$animateProvider", "register"), | |
filter: b("$filterProvider", "register"), | |
controller: b("$controllerProvider", "register"), | |
directive: b("$compileProvider", "directive"), | |
config: m, | |
run: function(a) { | |
d.push(a); | |
return this | |
} | |
}; | |
f && m(f); | |
return n | |
}()) | |
} | |
}()) | |
} | |
function Ra(b) { | |
return b.replace(Vc, function(a, b, d, e) { | |
return e ? d.toUpperCase() : d | |
}).replace(Wc, "Moz$1") | |
} | |
function wb(b, a, c, d) { | |
function e(b) { | |
var e = c && b ? [this.filter(b)]: [this], l = a, k, m, n, p, t, C; | |
if (!d || null != b) | |
for (; e.length;) | |
for (k = e.shift(), m = 0, n = k.length; m < n; m++) | |
for (p = x(k[m]), l ? p.triggerHandler("$destroy") : l=!l, t = 0, p = (C = p.children()).length; t < | |
p; t++) | |
e.push(Ca(C[t])); | |
return g.apply(this, arguments) | |
} | |
var g = Ca.fn[b], g = g.$original || g; | |
e.$original = g; | |
Ca.fn[b] = e | |
} | |
function I(b) { | |
if (b instanceof I) | |
return b; | |
if (!(this instanceof I)) { | |
if (D(b) && "<" != b.charAt(0)) | |
throw xb("nosel"); | |
return new I(b) | |
} | |
if (D(b)) { | |
var a = N.createElement("div"); | |
a.innerHTML = "<div> </div>" + b; | |
a.removeChild(a.firstChild); | |
yb(this, a.childNodes); | |
x(N.createDocumentFragment()).append(this) | |
} else | |
yb(this, b) | |
} | |
function zb(b) { | |
return b.cloneNode(!0) | |
} | |
function Da(b) { | |
Zb(b); | |
var a = 0; | |
for (b = b.childNodes || | |
[]; a < b.length; a++) | |
Da(b[a]) | |
} | |
function $b(b, a, c, d) { | |
if (z(d)) | |
throw xb("offargs"); | |
var e = ka(b, "events"); | |
ka(b, "handle") && (H(a) ? q(e, function(a, c) { | |
Ab(b, c, a); | |
delete e[c] | |
}) : q(a.split(" "), function(a) { | |
H(c) ? (Ab(b, a, e[a]), delete e[a]) : Ma(e[a] || [], c) | |
})) | |
} | |
function Zb(b, a) { | |
var c = b[db], d = Sa[c]; | |
d && (a ? delete Sa[c].data[a] : (d.handle && (d.events.$destroy && d.handle({}, "$destroy"), $b(b)), delete Sa[c], b[db] = r)) | |
} | |
function ka(b, a, c) { | |
var d = b[db], d = Sa[d||-1]; | |
if (z(c)) | |
d || (b[db] = d=++Xc, d = Sa[d] = {}), d[a] = c; | |
else | |
return d && d[a] | |
} | |
function ac(b, | |
a, c) { | |
var d = ka(b, "data"), e = z(c), g=!e && z(a), f = g&&!U(a); | |
d || f || ka(b, "data", d = {}); | |
if (e) | |
d[a] = c; | |
else if (g) { | |
if (f) | |
return d && d[a]; | |
w(d, a) | |
} else | |
return d | |
} | |
function Bb(b, a) { | |
return b.getAttribute?-1 < (" " + (b.getAttribute("class") || "") + " ").replace(/[\n\t]/g, " ").indexOf(" " + a + " ") : !1 | |
} | |
function Cb(b, a) { | |
a && b.setAttribute && q(a.split(" "), function(a) { | |
b.setAttribute("class", aa((" " + (b.getAttribute("class") || "") + " ").replace(/[\n\t]/g, " ").replace(" " + aa(a) + " ", " "))) | |
}) | |
} | |
function Db(b, a) { | |
if (a && b.setAttribute) { | |
var c = (" " + | |
(b.getAttribute("class") || "") + " ").replace(/[\n\t]/g, " "); | |
q(a.split(" "), function(a) { | |
a = aa(a); | |
- 1 === c.indexOf(" " + a + " ") && (c += a + " ") | |
}); | |
b.setAttribute("class", aa(c)) | |
} | |
} | |
function yb(b, a) { | |
if (a) { | |
a = a.nodeName ||!z(a.length) || Aa(a) ? [a] : a; | |
for (var c = 0; c < a.length; c++) | |
b.push(a[c]) | |
} | |
} | |
function bc(b, a) { | |
return eb(b, "$" + (a || "ngController") + "Controller") | |
} | |
function eb(b, a, c) { | |
b = x(b); | |
9 == b[0].nodeType && (b = b.find("html")); | |
for (a = L(a) ? a : [a]; b.length;) { | |
for (var d = 0, e = a.length; d < e; d++) | |
if ((c = b.data(a[d])) !== r) | |
return c; | |
b = b.parent() | |
} | |
} | |
function cc(b) { | |
for (var a = 0, c = b.childNodes; a < c.length; a++) | |
Da(c[a]); | |
for (; b.firstChild;) | |
b.removeChild(b.firstChild) | |
} | |
function dc(b, a) { | |
var c = fb[a.toLowerCase()]; | |
return c && ec[b.nodeName] && c | |
} | |
function Yc(b, a) { | |
var c = function(c, e) { | |
c.preventDefault || (c.preventDefault = function() { | |
c.returnValue=!1 | |
}); | |
c.stopPropagation || (c.stopPropagation = function() { | |
c.cancelBubble=!0 | |
}); | |
c.target || (c.target = c.srcElement || N); | |
if (H(c.defaultPrevented)) { | |
var g = c.preventDefault; | |
c.preventDefault = function() { | |
c.defaultPrevented=!0; | |
g.call(c) | |
}; | |
c.defaultPrevented=!1 | |
} | |
c.isDefaultPrevented = function() { | |
return c.defaultPrevented ||!1 === c.returnValue | |
}; | |
q(a[e || c.type], function(a) { | |
a.call(b, c) | |
}); | |
8 >= E ? (c.preventDefault = null, c.stopPropagation = null, c.isDefaultPrevented = null) : (delete c.preventDefault, delete c.stopPropagation, delete c.isDefaultPrevented) | |
}; | |
c.elem = b; | |
return c | |
} | |
function Ea(b) { | |
var a = typeof b, c; | |
"object" == a && null !== b ? "function" == typeof(c = b.$$hashKey) ? c = b.$$hashKey() : c === r && (c = b.$$hashKey = Za()) : c = b; | |
return a + ":" + c | |
} | |
function Ta(b) { | |
q(b, this.put, this) | |
} | |
function fc(b) { | |
var a, c; | |
"function" == typeof b ? (a = b.$inject) || (a = [], b.length && (c = b.toString().replace(Zc, ""), c = c.match($c), q(c[1].split(ad), function(b) { | |
b.replace(bd, function(b, c, d) { | |
a.push(d) | |
}) | |
})), b.$inject = a) : L(b) ? (c = b.length - 1, Qa(b[c], "fn"), a = b.slice(0, c)) : Qa(b, "fn", !0); | |
return a | |
} | |
function Yb(b) { | |
function a(a) { | |
return function(b, c) { | |
if (U(b)) | |
q(b, Pb(a)); | |
else | |
return a(b, c) | |
} | |
} | |
function c(a, b) { | |
wa(a, "service"); | |
if (A(b) || L(b)) | |
b = n.instantiate(b); | |
if (!b.$get) | |
throw Ua("pget", a); | |
return m[a + h] = b | |
} | |
function d(a, b) { | |
return c(a, | |
{ | |
$get: b | |
}) | |
} | |
function e(a) { | |
var b = [], c, d, h, g; | |
q(a, function(a) { | |
if (!k.get(a)) { | |
k.put(a, !0); | |
try { | |
if (D(a)) | |
for (c = Va(a), b = b.concat(e(c.requires)).concat(c._runBlocks), d = c._invokeQueue, h = 0, g = d.length; h < g; h++) { | |
var f = d[h], l = n.get(f[0]); | |
l[f[1]].apply(l, f[2]) | |
} else | |
A(a) ? b.push(n.invoke(a)) : L(a) ? b.push(n.invoke(a)) : Qa(a, "module") | |
} catch (m) { | |
throw L(a) && (a = a[a.length - 1]), m.message && (m.stack&&-1 == m.stack.indexOf(m.message)) && (m = m.message + "\n" + m.stack), Ua("modulerr", a, m.stack || m.message || m); | |
} | |
} | |
}); | |
return b | |
} | |
function g(a, b) { | |
function c(d) { | |
if (a.hasOwnProperty(d)) { | |
if (a[d] === | |
f) | |
throw Ua("cdep", l.join(" <- ")); | |
return a[d] | |
} | |
try { | |
return l.unshift(d), a[d] = f, a[d] = b(d) | |
} finally { | |
l.shift() | |
} | |
} | |
function d(a, b, e) { | |
var h = [], g = fc(a), f, k, l; | |
k = 0; | |
for (f = g.length; k < f; k++) { | |
l = g[k]; | |
if ("string" !== typeof l) | |
throw Ua("itkn", l); | |
h.push(e && e.hasOwnProperty(l) ? e[l] : c(l)) | |
} | |
a.$inject || (a = a[f]); | |
return a.apply(b, h) | |
} | |
return { | |
invoke: d, | |
instantiate: function(a, b) { | |
var c = function() {}, e; | |
c.prototype = (L(a) ? a[a.length - 1] : a).prototype; | |
c = new c; | |
e = d(a, c, b); | |
return U(e) || A(e) ? e : c | |
}, | |
get: c, | |
annotate: fc, | |
has: function(b) { | |
return m.hasOwnProperty(b + | |
h) || a.hasOwnProperty(b) | |
} | |
} | |
} | |
var f = {}, h = "Provider", l = [], k = new Ta, m = { | |
$provide: { | |
provider: a(c), | |
factory: a(d), | |
service: a(function(a, b) { | |
return d(a, ["$injector", function(a) { | |
return a.instantiate(b) | |
} | |
]) | |
}), | |
value: a(function(a, b) { | |
return d(a, ca(b)) | |
}), | |
constant: a(function(a, b) { | |
wa(a, "constant"); | |
m[a] = b; | |
p[a] = b | |
}), | |
decorator: function(a, b) { | |
var c = n.get(a + h), d = c.$get; | |
c.$get = function() { | |
var a = t.invoke(d, c); | |
return t.invoke(b, null, { | |
$delegate: a | |
}) | |
} | |
} | |
} | |
}, n = m.$injector = g(m, function() { | |
throw Ua("unpr", l.join(" <- ")); | |
}), p = {}, t = p.$injector = | |
g(p, function(a) { | |
a = n.get(a + h); | |
return t.invoke(a.$get, a) | |
}); | |
q(e(b), function(a) { | |
t.invoke(a || s) | |
}); | |
return t | |
} | |
function cd() { | |
var b=!0; | |
this.disableAutoScrolling = function() { | |
b=!1 | |
}; | |
this.$get = ["$window", "$location", "$rootScope", function(a, c, d) { | |
function e(a) { | |
var b = null; | |
q(a, function(a) { | |
b || "a" !== v(a.nodeName) || (b = a) | |
}); | |
return b | |
} | |
function g() { | |
var b = c.hash(), d; | |
b ? (d = f.getElementById(b)) ? d.scrollIntoView() : (d = e(f.getElementsByName(b))) ? d.scrollIntoView() : "top" === b && a.scrollTo(0, 0) : a.scrollTo(0, 0) | |
} | |
var f = a.document; | |
b && d.$watch(function() { | |
return c.hash() | |
}, | |
function() { | |
d.$evalAsync(g) | |
}); | |
return g | |
} | |
] | |
} | |
function dd(b, a, c, d) { | |
function e(a) { | |
try { | |
a.apply(null, ua.call(arguments, 1)) | |
} finally { | |
if (C--, 0 === C) | |
for (; B.length;) | |
try { | |
B.pop()() | |
} catch (b) { | |
c.error(b) | |
} | |
} | |
} | |
function g(a, b) { | |
(function la() { | |
q(K, function(a) { | |
a() | |
}); | |
u = b(la, a) | |
})() | |
} | |
function f() { | |
y = null; | |
P != h.url() && (P = h.url(), q(ba, function(a) { | |
a(h.url()) | |
})) | |
} | |
var h = this, l = a[0], k = b.location, m = b.history, n = b.setTimeout, p = b.clearTimeout, t = {}; | |
h.isMock=!1; | |
var C = 0, B = []; | |
h.$$completeOutstandingRequest = e; | |
h.$$incOutstandingRequestCount = function() { | |
C++ | |
}; | |
h.notifyWhenNoOutstandingRequests = function(a) { | |
q(K, function(a) { | |
a() | |
}); | |
0 === C ? a() : B.push(a) | |
}; | |
var K = [], u; | |
h.addPollFn = function(a) { | |
H(u) && g(100, n); | |
K.push(a); | |
return a | |
}; | |
var P = k.href, Z = a.find("base"), y = null; | |
h.url = function(a, c) { | |
k !== b.location && (k = b.location); | |
if (a) { | |
if (P != a) | |
return P = a, d.history ? c ? m.replaceState(null, "", a) : (m.pushState(null, "", a), Z.attr("href", Z.attr("href"))) : (y = a, c ? k.replace(a) : k.href = a), h | |
} else | |
return y || k.href.replace(/%27/g, "'") | |
}; | |
var ba = [], Q=!1; | |
h.onUrlChange = function(a) { | |
if (!Q) { | |
if (d.history) | |
x(b).on("popstate", | |
f); | |
if (d.hashchange) | |
x(b).on("hashchange", f); | |
else | |
h.addPollFn(f); | |
Q=!0 | |
} | |
ba.push(a); | |
return a | |
}; | |
h.baseHref = function() { | |
var a = Z.attr("href"); | |
return a ? a.replace(/^https?\:\/\/[^\/]*/, "") : "" | |
}; | |
var Y = {}, X = "", $ = h.baseHref(); | |
h.cookies = function(a, b) { | |
var d, e, g, h; | |
if (a) | |
b === r ? l.cookie = escape(a) + "=;path=" + $ + ";expires=Thu, 01 Jan 1970 00:00:00 GMT" : D(b) && (d = (l.cookie = escape(a) + "=" + escape(b) + ";path=" + $).length + 1, 4096 < d && c.warn("Cookie '" + a + "' possibly not set or overflowed because it was too large (" + d + " > 4096 bytes)!")); | |
else { | |
if (l.cookie !== X) | |
for (X = l.cookie, d = X.split("; "), Y = {}, g = 0; g < d.length; g++) | |
e = d[g], h = e.indexOf("="), 0 < h && (a = unescape(e.substring(0, h)), Y[a] === r && (Y[a] = unescape(e.substring(h + 1)))); | |
return Y | |
} | |
}; | |
h.defer = function(a, b) { | |
var c; | |
C++; | |
c = n(function() { | |
delete t[c]; | |
e(a) | |
}, b || 0); | |
t[c]=!0; | |
return c | |
}; | |
h.defer.cancel = function(a) { | |
return t[a] ? (delete t[a], p(a), e(s), !0) : !1 | |
} | |
} | |
function ed() { | |
this.$get = ["$window", "$log", "$sniffer", "$document", function(b, a, c, d) { | |
return new dd(b, d, a, c) | |
} | |
] | |
} | |
function fd() { | |
this.$get = function() { | |
function b(b, | |
d) { | |
function e(a) { | |
a != n && (p ? p == a && (p = a.n) : p = a, g(a.n, a.p), g(a, n), n = a, n.n = null) | |
} | |
function g(a, b) { | |
a != b && (a && (a.p = b), b && (b.n = a)) | |
} | |
if (b in a) | |
throw G("$cacheFactory")("iid", b); | |
var f = 0, h = w({}, d, { | |
id: b | |
}), l = {}, k = d && d.capacity || Number.MAX_VALUE, m = {}, n = null, p = null; | |
return a[b] = { | |
put: function(a, b) { | |
var c = m[a] || (m[a] = { | |
key: a | |
}); | |
e(c); | |
if (!H(b)) | |
return a in l || f++, l[a] = b, f > k && this.remove(p.key), b | |
}, | |
get: function(a) { | |
var b = m[a]; | |
if (b) | |
return e(b), l[a] | |
}, | |
remove: function(a) { | |
var b = m[a]; | |
b && (b == n && (n = b.p), b == p && (p = b.n), g(b.n, b.p), delete m[a], | |
delete l[a], f--) | |
}, | |
removeAll: function() { | |
l = {}; | |
f = 0; | |
m = {}; | |
n = p = null | |
}, | |
destroy: function() { | |
m = h = l = null; | |
delete a[b] | |
}, | |
info: function() { | |
return w({}, h, { | |
size: f | |
}) | |
} | |
} | |
} | |
var a = {}; | |
b.info = function() { | |
var b = {}; | |
q(a, function(a, e) { | |
b[e] = a.info() | |
}); | |
return b | |
}; | |
b.get = function(b) { | |
return a[b] | |
}; | |
return b | |
} | |
} | |
function gd() { | |
this.$get = ["$cacheFactory", function(b) { | |
return b("templates") | |
} | |
] | |
} | |
function hc(b, a) { | |
var c = {}, d = "Directive", e = /^\s*directive\:\s*([\d\w\-_]+)\s+(.*)$/, g = /(([\d\w\-_]+)(?:\:([^;]+))?;?)/, f = /^(on[a-z]+|formaction)$/; | |
this.directive = | |
function l(a, e) { | |
wa(a, "directive"); | |
D(a) ? (tb(e, "directiveFactory"), c.hasOwnProperty(a) || (c[a] = [], b.factory(a + d, ["$injector", "$exceptionHandler", function(b, d) { | |
var e = []; | |
q(c[a], function(c, g) { | |
try { | |
var f = b.invoke(c); | |
A(f) ? f = { | |
compile: ca(f) | |
} : !f.compile && f.link && (f.compile = ca(f.link)); | |
f.priority = f.priority || 0; | |
f.index = g; | |
f.name = f.name || a; | |
f.require = f.require || f.controller && f.name; | |
f.restrict = f.restrict || "A"; | |
e.push(f) | |
} catch (l) { | |
d(l) | |
} | |
}); | |
return e | |
} | |
])), c[a].push(e)) : q(a, Pb(l)); | |
return this | |
}; | |
this.aHrefSanitizationWhitelist = | |
function(b) { | |
return z(b) ? (a.aHrefSanitizationWhitelist(b), this) : a.aHrefSanitizationWhitelist() | |
}; | |
this.imgSrcSanitizationWhitelist = function(b) { | |
return z(b) ? (a.imgSrcSanitizationWhitelist(b), this) : a.imgSrcSanitizationWhitelist() | |
}; | |
this.$get = ["$injector", "$interpolate", "$exceptionHandler", "$http", "$templateCache", "$parse", "$controller", "$rootScope", "$document", "$sce", "$animate", "$$sanitizeUri", function(a, b, m, n, p, t, C, B, K, u, P, Z) { | |
function y(a, b, c, d, e) { | |
a instanceof x || (a = x(a)); | |
q(a, function(b, c) { | |
3 == b.nodeType && | |
b.nodeValue.match(/\S+/) && (a[c] = x(b).wrap("<span></span>").parent()[0]) | |
}); | |
var g = Q(a, b, a, c, d, e); | |
return function(b, c, d) { | |
tb(b, "scope"); | |
var e = c ? Fa.clone.call(a): a; | |
q(d, function(a, b) { | |
e.data("$" + b + "Controller", a) | |
}); | |
d = 0; | |
for (var f = e.length; d < f; d++) { | |
var k = e[d]; | |
1 != k.nodeType && 9 != k.nodeType || e.eq(d).data("$scope", b) | |
} | |
ba(e, "ng-scope"); | |
c && c(e, b); | |
g && g(b, e, e); | |
return e | |
} | |
} | |
function ba(a, b) { | |
try { | |
a.addClass(b) | |
} catch (c) {} | |
} | |
function Q(a, b, c, d, e, g) { | |
function f(a, c, d, e) { | |
var g, l, m, p, n, t, C, da = []; | |
n = 0; | |
for (t = c.length; n < t; n++) | |
da.push(c[n]); | |
C = n = 0; | |
for (t = k.length; n < t; C++) | |
l = da[C], c = k[n++], g = k[n++], m = x(l), c ? (c.scope ? (p = a.$new(), m.data("$scope", p), ba(m, "ng-scope")) : p = a, (m = c.transclude) ||!e && b ? c(g, p, l, d, Y(a, m || b)) : c(g, p, l, d, e)) : g && g(a, l.childNodes, r, e) | |
} | |
for (var k = [], l, m, p, n = 0; n < a.length; n++) | |
m = new Eb, l = X(a[n], [], m, 0 === n ? d : r, e), l = (g = l.length ? M(l, a[n], m, b, c, null, [], [], g) : null) && g.terminal ||!a[n].childNodes ||!a[n].childNodes.length ? null : Q(a[n].childNodes, g ? g.transclude : b), k.push(g), k.push(l), p = p || g || l, g = null; | |
return p ? f : null | |
} | |
function Y(a, b) { | |
return function(c, | |
d, e) { | |
var g=!1; | |
c || (c = a.$new(), g = c.$$transcluded=!0); | |
d = b(c, d, e); | |
if (g) | |
d.on("$destroy", rb(c, c.$destroy)); | |
return d | |
} | |
} | |
function X(a, b, c, d, f) { | |
var k = c.$attr, l; | |
switch (a.nodeType) { | |
case 1: | |
la(b, ma(Ga(a).toLowerCase()), "E", d, f); | |
var m, p, n; | |
l = a.attributes; | |
for (var t = 0, C = l && l.length; t < C; t++) { | |
var B=!1, y=!1; | |
m = l[t]; | |
if (!E || 8 <= E || m.specified) { | |
p = m.name; | |
n = ma(p); | |
xa.test(n) && (p = cb(n.substr(6), "-")); | |
var P = n.replace(/(Start|End)$/, ""); | |
n === P + "Start" && (B = p, y = p.substr(0, p.length - 5) + "end", p = p.substr(0, p.length - 6)); | |
n = ma(p.toLowerCase()); | |
k[n] = p; | |
c[n] = m = aa(E && "href" == p ? decodeURIComponent(a.getAttribute(p, 2)) : m.value); | |
dc(a, n) && (c[n]=!0); | |
I(a, b, m, n); | |
la(b, n, "A", d, f, B, y) | |
} | |
} | |
a = a.className; | |
if (D(a) && "" !== a) | |
for (; l = g.exec(a);) | |
n = ma(l[2]), la(b, n, "C", d, f) && (c[n] = aa(l[3])), a = a.substr(l.index + l[0].length); | |
break; | |
case 3: | |
v(b, a.nodeValue); | |
break; | |
case 8: | |
try { | |
if (l = e.exec(a.nodeValue)) | |
n = ma(l[1]), la(b, n, "M", d, f) && (c[n] = aa(l[2])) | |
} catch (K) {} | |
} | |
b.sort(s); | |
return b | |
} | |
function $(a, b, c) { | |
var d = [], e = 0; | |
if (b && a.hasAttribute && a.hasAttribute(b)) { | |
do { | |
if (!a) | |
throw ia("uterdir", b, | |
c); | |
1 == a.nodeType && (a.hasAttribute(b) && e++, a.hasAttribute(c) && e--); | |
d.push(a); | |
a = a.nextSibling | |
} | |
while (0 < e) | |
} else | |
d.push(a); | |
return x(d) | |
} | |
function O(a, b, c) { | |
return function(d, e, g, f, k) { | |
e = $(e[0], b, c); | |
return a(d, e, g, f, k) | |
} | |
} | |
function M(a, c, d, e, g, f, l, p, n) { | |
function B(a, b, c, d) { | |
if (a) { | |
c && (a = O(a, c, d)); | |
a.require = F.require; | |
if (Q === F || F.$$isolateScope) | |
a = T(a, { | |
isolateScope: !0 | |
}); | |
l.push(a) | |
} | |
if (b) { | |
c && (b = O(b, c, d)); | |
b.require = F.require; | |
if (Q === F || F.$$isolateScope) | |
b = T(b, { | |
isolateScope: !0 | |
}); | |
p.push(b) | |
} | |
} | |
function P(a, b, c) { | |
var d, e = "data", | |
g=!1; | |
if (D(a)) { | |
for (; "^" == (d = a.charAt(0)) || "?" == d;) | |
a = a.substr(1), "^" == d && (e = "inheritedData"), g = g || "?" == d; | |
d = null; | |
c && "data" === e && (d = c[a]); | |
d = d || b[e]("$" + a + "Controller"); | |
if (!d&&!g) | |
throw ia("ctreq", a, ea); | |
} else | |
L(a) && (d = [], q(a, function(a) { | |
d.push(P(a, b, c)) | |
})); | |
return d | |
} | |
function K(a, e, g, f, n) { | |
function B(a, b) { | |
var c; | |
2 > arguments.length && (b = a, a = r); | |
Ha && (c = O); | |
return n(a, b, c) | |
} | |
var y, da, Y, u, $, J, O = {}, X; | |
y = c === g ? d : Qc(d, new Eb(x(g), d.$attr)); | |
da = y.$$element; | |
if (Q) { | |
var S = /^\s*([@=&])(\??)\s*(\w*)\s*$/; | |
f = x(g); | |
J = e.$new(!0); | |
M && | |
M === Q.$$originalDirective ? f.data("$isolateScope", J) : f.data("$isolateScopeNoTemplate", J); | |
ba(f, "ng-isolate-scope"); | |
q(Q.scope, function(a, c) { | |
var d = a.match(S) || [], g = d[3] || c, f = "?" == d[2], d = d[1], l, m, n, p; | |
J.$$isolateBindings[c] = d + g; | |
switch (d) { | |
case "@": | |
y.$observe(g, function(a) { | |
J[c] = a | |
}); | |
y.$$observers[g].$$scope = e; | |
y[g] && (J[c] = b(y[g])(e)); | |
break; | |
case "=": | |
if (f&&!y[g]) | |
break; | |
m = t(y[g]); | |
p = m.literal ? ta : function(a, b) { | |
return a === b | |
}; | |
n = m.assign || function() { | |
l = J[c] = m(e); | |
throw ia("nonassign", y[g], Q.name); | |
}; | |
l = J[c] = m(e); | |
J.$watch(function() { | |
var a = | |
m(e); | |
p(a, J[c]) || (p(a, l) ? n(e, a = J[c]) : J[c] = a); | |
return l = a | |
}, null, m.literal); | |
break; | |
case "&": | |
m = t(y[g]); | |
J[c] = function(a) { | |
return m(e, a) | |
}; | |
break; | |
default: | |
throw ia("iscp", Q.name, c, a); | |
} | |
}) | |
} | |
X = n && B; | |
Z && q(Z, function(a) { | |
var b = { | |
$scope: a === Q || a.$$isolateScope ? J: e, | |
$element: da, | |
$attrs: y, | |
$transclude: X | |
}, c; | |
$ = a.controller; | |
"@" == $ && ($ = y[a.name]); | |
c = C($, b); | |
O[a.name] = c; | |
Ha || da.data("$" + a.name + "Controller", c); | |
a.controllerAs && (b.$scope[a.controllerAs] = c) | |
}); | |
f = 0; | |
for (Y = l.length; f < Y; f++) | |
try { | |
u = l[f], u(u.isolateScope ? J : e, da, y, u.require && P(u.require, | |
da, O), X) | |
} catch (v) { | |
m(v, ha(da)) | |
} | |
f = e; | |
Q && (Q.template || null === Q.templateUrl) && (f = J); | |
a && a(f, g.childNodes, r, n); | |
for (f = p.length - 1; 0 <= f; f--) | |
try { | |
u = p[f], u(u.isolateScope ? J : e, da, y, u.require && P(u.require, da, O), X) | |
} catch (hd) { | |
m(hd, ha(da)) | |
} | |
} | |
n = n || {}; | |
var Y =- Number.MAX_VALUE, u, Z = n.controllerDirectives, Q = n.newIsolateScopeDirective, M = n.templateDirective; | |
n = n.nonTlbTranscludeDirective; | |
for (var la=!1, Ha=!1, s = d.$$element = x(c), F, ea, v, w = e, G, I = 0, E = a.length; I < E; I++) { | |
F = a[I]; | |
var xa = F.$$start, gb = F.$$end; | |
xa && (s = $(c, xa, gb)); | |
v = r; | |
if (Y > | |
F.priority) | |
break; | |
if (v = F.scope) | |
u = u || F, F.templateUrl || (H("new/isolated scope", Q, F, s), U(v) && (Q = F)); | |
ea = F.name; | |
!F.templateUrl && F.controller && (v = F.controller, Z = Z || {}, H("'" + ea + "' controller", Z[ea], F, s), Z[ea] = F); | |
if (v = F.transclude) | |
la=!0, F.$$tlb || (H("transclusion", n, F, s), n = F), "element" == v ? (Ha=!0, Y = F.priority, v = $(c, xa, gb), s = d.$$element = x(N.createComment(" " + ea + ": " + d[ea] + " ")), c = s[0], R(g, x(ua.call(v, 0)), c), w = y(v, e, Y, f && f.name, { | |
nonTlbTranscludeDirective: n | |
})) : (v = x(zb(c)).contents(), s.empty(), w = y(v, e)); | |
if (F.template) | |
if (H("template", | |
M, F, s), M = F, v = A(F.template) ? F.template(s, d) : F.template, v = ic(v), F.replace) { | |
f = F; | |
v = x("<div>" + aa(v) + "</div>").contents(); | |
c = v[0]; | |
if (1 != v.length || 1 !== c.nodeType) | |
throw ia("tplrt", ea, ""); | |
R(g, s, c); | |
E = { | |
$attr: {} | |
}; | |
v = X(c, [], E); | |
var V = a.splice(I + 1, a.length - (I + 1)); | |
Q && S(v); | |
a = a.concat(v).concat(V); | |
gc(d, E); | |
E = a.length | |
} else | |
s.html(v); | |
if (F.templateUrl) | |
H("template", M, F, s), M = F, F.replace && (f = F), K = z(a.splice(I, a.length - I), s, d, g, w, l, p, { | |
controllerDirectives: Z, | |
newIsolateScopeDirective: Q, | |
templateDirective: M, | |
nonTlbTranscludeDirective: n | |
}), | |
E = a.length; | |
else if (F.compile) | |
try { | |
G = F.compile(s, d, w), A(G) ? B(null, G, xa, gb) : G && B(G.pre, G.post, xa, gb) | |
} catch (W) { | |
m(W, ha(s)) | |
} | |
F.terminal && (K.terminal=!0, Y = Math.max(Y, F.priority)) | |
} | |
K.scope = u&&!0 === u.scope; | |
K.transclude = la && w; | |
return K | |
} | |
function S(a) { | |
for (var b = 0, c = a.length; b < c; b++) | |
a[b] = Rb(a[b], { | |
$$isolateScope: !0 | |
}) | |
} | |
function la(b, e, g, f, k, n, p) { | |
if (e === k) | |
return null; | |
k = null; | |
if (c.hasOwnProperty(e)) { | |
var t; | |
e = a.get(e + d); | |
for (var C = 0, B = e.length; C < B; C++) | |
try { | |
t = e[C], (f === r || f > t.priority)&&-1 != t.restrict.indexOf(g) && (n && (t = Rb(t, | |
{ | |
$$start: n, | |
$$end: p | |
})), b.push(t), k = t) | |
} catch (y) { | |
m(y) | |
} | |
} | |
return k | |
} | |
function gc(a, b) { | |
var c = b.$attr, d = a.$attr, e = a.$$element; | |
q(a, function(d, e) { | |
"$" != e.charAt(0) && (b[e] && (d += ("style" === e ? ";" : " ") + b[e]), a.$set(e, d, !0, c[e])) | |
}); | |
q(b, function(b, g) { | |
"class" == g ? (ba(e, b), a["class"] = (a["class"] ? a["class"] + " " : "") + b) : "style" == g ? (e.attr("style", e.attr("style") + ";" + b), a.style = (a.style ? a.style + ";" : "") + b) : "$" == g.charAt(0) || a.hasOwnProperty(g) || (a[g] = b, d[g] = c[g]) | |
}) | |
} | |
function z(a, b, c, d, e, g, f, k) { | |
var l = [], m, t, C = b[0], B = a.shift(), | |
y = w({}, B, { | |
templateUrl: null, | |
transclude: null, | |
replace: null, | |
$$originalDirective: B | |
}), P = A(B.templateUrl) ? B.templateUrl(b, c): B.templateUrl; | |
b.empty(); | |
n.get(u.getTrustedResourceUrl(P), { | |
cache: p | |
}).success(function(n) { | |
var p, K; | |
n = ic(n); | |
if (B.replace) { | |
n = x("<div>" + aa(n) + "</div>").contents(); | |
p = n[0]; | |
if (1 != n.length || 1 !== p.nodeType) | |
throw ia("tplrt", B.name, P); | |
n = { | |
$attr: {} | |
}; | |
R(d, b, p); | |
var u = X(p, [], n); | |
U(B.scope) && S(u); | |
a = u.concat(a); | |
gc(c, n) | |
} else | |
p = C, b.html(n); | |
a.unshift(y); | |
m = M(a, p, c, e, b, B, g, f, k); | |
q(d, function(a, c) { | |
a == p && (d[c] = | |
b[0]) | |
}); | |
for (t = Q(b[0].childNodes, e); l.length;) { | |
n = l.shift(); | |
K = l.shift(); | |
var ba = l.shift(), Z = l.shift(), u = b[0]; | |
K !== C && (u = zb(p), R(ba, x(K), u)); | |
K = m.transclude ? Y(n, m.transclude) : Z; | |
m(t, n, u, d, K) | |
} | |
l = null | |
}).error(function(a, b, c, d) { | |
throw ia("tpload", d.url); | |
}); | |
return function(a, b, c, d, e) { | |
l ? (l.push(b), l.push(c), l.push(d), l.push(e)) : m(t, b, c, d, e) | |
} | |
} | |
function s(a, b) { | |
var c = b.priority - a.priority; | |
return 0 !== c ? c : a.name !== b.name ? a.name < b.name?-1 : 1 : a.index - b.index | |
} | |
function H(a, b, c, d) { | |
if (b) | |
throw ia("multidir", b.name, c.name, a, | |
ha(d)); | |
} | |
function v(a, c) { | |
var d = b(c, !0); | |
d && a.push({ | |
priority: 0, | |
compile: ca(function(a, b) { | |
var c = b.parent(), e = c.data("$binding") || []; | |
e.push(d); | |
ba(c.data("$binding", e), "ng-binding"); | |
a.$watch(d, function(a) { | |
b[0].nodeValue = a | |
}) | |
}) | |
}) | |
} | |
function G(a, b) { | |
if ("srcdoc" == b) | |
return u.HTML; | |
var c = Ga(a); | |
if ("xlinkHref" == b || "FORM" == c && "action" == b || "IMG" != c && ("src" == b || "ngSrc" == b)) | |
return u.RESOURCE_URL | |
} | |
function I(a, c, d, e) { | |
var g = b(d, !0); | |
if (g) { | |
if ("multiple" === e && "SELECT" === Ga(a)) | |
throw ia("selmulti", ha(a)); | |
c.push({ | |
priority: 100, | |
compile: function() { | |
return { | |
pre: function(c, | |
d, l) { | |
d = l.$$observers || (l.$$observers = {}); | |
if (f.test(e)) | |
throw ia("nodomevents"); | |
if (g = b(l[e], !0, G(a, e))) | |
l[e] = g(c), (d[e] || (d[e] = [])).$$inter=!0, (l.$$observers && l.$$observers[e].$$scope || c).$watch(g, function(a, b) { | |
"class" === e && a != b ? l.$updateClass(a, b) : l.$set(e, a) | |
}) | |
} | |
} | |
} | |
}) | |
} | |
} | |
function R(a, b, c) { | |
var d = b[0], e = b.length, g = d.parentNode, f, l; | |
if (a) | |
for (f = 0, l = a.length; f < l; f++) | |
if (a[f] == d) { | |
a[f++] = c; | |
l = f + e - 1; | |
for (var k = a.length; f < k; f++, l++) | |
l < k ? a[f] = a[l] : delete a[f]; | |
a.length -= e - 1; | |
break | |
} | |
g && g.replaceChild(c, d); | |
a = N.createDocumentFragment(); | |
a.appendChild(d); | |
c[x.expando] = d[x.expando]; | |
d = 1; | |
for (e = b.length; d < e; d++) | |
g = b[d], x(g).remove(), a.appendChild(g), delete b[d]; | |
b[0] = c; | |
b.length = 1 | |
} | |
function T(a, b) { | |
return w(function() { | |
return a.apply(null, arguments) | |
}, a, b) | |
} | |
var Eb = function(a, b) { | |
this.$$element = a; | |
this.$attr = b || {} | |
}; | |
Eb.prototype = { | |
$normalize: ma, | |
$addClass: function(a) { | |
a && 0 < a.length && P.addClass(this.$$element, a) | |
}, | |
$removeClass: function(a) { | |
a && 0 < a.length && P.removeClass(this.$$element, a) | |
}, | |
$updateClass: function(a, b) { | |
this.$removeClass(jc(b, a)); | |
this.$addClass(jc(a, | |
b)) | |
}, | |
$set: function(a, b, c, d) { | |
var e = dc(this.$$element[0], a); | |
e && (this.$$element.prop(a, b), d = e); | |
this[a] = b; | |
d ? this.$attr[a] = d : (d = this.$attr[a]) || (this.$attr[a] = d = cb(a, "-")); | |
e = Ga(this.$$element); | |
if ("A" === e && "href" === a || "IMG" === e && "src" === a) | |
this[a] = b = Z(b, "src" === a); | |
!1 !== c && (null === b || b === r ? this.$$element.removeAttr(d) : this.$$element.attr(d, b)); | |
(c = this.$$observers) && q(c[a], function(a) { | |
try { | |
a(b) | |
} catch (c) { | |
m(c) | |
} | |
}) | |
}, | |
$observe: function(a, b) { | |
var c = this, d = c.$$observers || (c.$$observers = {}), e = d[a] || (d[a] = []); | |
e.push(b); | |
B.$evalAsync(function() { | |
e.$$inter || b(c[a]) | |
}); | |
return b | |
} | |
}; | |
var ea = b.startSymbol(), Ha = b.endSymbol(), ic = "{{" == ea || "}}" == Ha ? Ba: function(a) { | |
return a.replace(/\{\{/g, ea).replace(/}}/g, Ha) | |
}, xa = /^ngAttr[A-Z]/; | |
return y | |
} | |
] | |
} | |
function ma(b) { | |
return Ra(b.replace(id, "")) | |
} | |
function jc(b, a) { | |
var c = "", d = b.split(/\s+/), e = a.split(/\s+/), g = 0; | |
a: for (; | |
g < d.length; | |
g++) { | |
for (var f = d[g], h = 0; | |
h < e.length; | |
h++)if (f == e[h]) | |
continue a; | |
c += (0 < c.length ? " " : "") + f | |
} | |
return c | |
} | |
function jd() { | |
var b = {}, a = /^(\S+)(\s+as\s+(\w+))?$/; | |
this.register = function(a, | |
d) { | |
wa(a, "controller"); | |
U(a) ? w(b, a) : b[a] = d | |
}; | |
this.$get = ["$injector", "$window", function(c, d) { | |
return function(e, g) { | |
var f, h, l; | |
D(e) && (f = e.match(a), h = f[1], l = f[3], e = b.hasOwnProperty(h) ? b[h] : ub(g.$scope, h, !0) || ub(d, h, !0), Qa(e, h, !0)); | |
f = c.instantiate(e, g); | |
if (l) { | |
if (!g || "object" != typeof g.$scope) | |
throw G("$controller")("noscp", h || e.name, l); | |
g.$scope[l] = f | |
} | |
return f | |
} | |
} | |
] | |
} | |
function kd() { | |
this.$get = ["$window", function(b) { | |
return x(b.document) | |
} | |
] | |
} | |
function ld() { | |
this.$get = ["$log", function(b) { | |
return function(a, c) { | |
b.error.apply(b, | |
arguments) | |
} | |
} | |
] | |
} | |
function kc(b) { | |
var a = {}, c, d, e; | |
if (!b) | |
return a; | |
q(b.split("\n"), function(b) { | |
e = b.indexOf(":"); | |
c = v(aa(b.substr(0, e))); | |
d = aa(b.substr(e + 1)); | |
c && (a[c] = a[c] ? a[c] + (", " + d) : d) | |
}); | |
return a | |
} | |
function lc(b) { | |
var a = U(b) ? b: r; | |
return function(c) { | |
a || (a = kc(b)); | |
return c ? a[v(c)] || null : a | |
} | |
} | |
function mc(b, a, c) { | |
if (A(c)) | |
return c(b, a); | |
q(c, function(c) { | |
b = c(b, a) | |
}); | |
return b | |
} | |
function md() { | |
var b = /^\s*(\[|\{[^\{])/, a = /[\}\]]\s*$/, c = /^\)\]\}',?\n/, d = { | |
"Content-Type": "application/json;charset=utf-8" | |
}, e = this.defaults = { | |
transformResponse: [function(d) { | |
D(d) && | |
(d = d.replace(c, ""), b.test(d) && a.test(d) && (d = Tb(d))); | |
return d | |
} | |
], | |
transformRequest: [function(a) { | |
return U(a) && "[object File]" !== $a.call(a) ? oa(a) : a | |
} | |
], | |
headers: { | |
common: { | |
Accept: "application/json, text/plain, */*" | |
}, | |
post: d, | |
put: d, | |
patch: d | |
}, | |
xsrfCookieName: "XSRF-TOKEN", | |
xsrfHeaderName: "X-XSRF-TOKEN" | |
}, g = this.interceptors = [], f = this.responseInterceptors = []; | |
this.$get = ["$httpBackend", "$browser", "$cacheFactory", "$rootScope", "$q", "$injector", function(a, b, c, d, n, p) { | |
function t(a) { | |
function c(a) { | |
var b = w({}, a, { | |
data: mc(a.data, | |
a.headers, d.transformResponse) | |
}); | |
return 200 <= a.status && 300 > a.status ? b : n.reject(b) | |
} | |
var d = { | |
transformRequest: e.transformRequest, | |
transformResponse: e.transformResponse | |
}, g = function(a) { | |
function b(a) { | |
var c; | |
q(a, function(b, d) { | |
A(b) && (c = b(), null != c ? a[d] = c : delete a[d]) | |
}) | |
} | |
var c = e.headers, d = w({}, a.headers), g, f, c = w({}, c.common, c[v(a.method)]); | |
b(c); | |
b(d); | |
a: for (g in c) { | |
a = v(g); | |
for (f in d) | |
if (v(f) === a) | |
continue a; | |
d[g] = c[g] | |
} | |
return d | |
}(a); | |
w(d, a); | |
d.headers = g; | |
d.method = Ia(d.method); | |
(a = Fb(d.url) ? b.cookies()[d.xsrfCookieName || | |
e.xsrfCookieName] : r) && (g[d.xsrfHeaderName || e.xsrfHeaderName] = a); | |
var f = [function(a) { | |
g = a.headers; | |
var b = mc(a.data, lc(g), a.transformRequest); | |
H(a.data) && q(g, function(a, b) { | |
"content-type" === v(b) && delete g[b] | |
}); | |
H(a.withCredentials)&&!H(e.withCredentials) && (a.withCredentials = e.withCredentials); | |
return C(a, b, g).then(c, c) | |
}, r], h = n.when(d); | |
for (q(u, function(a) { | |
(a.request || a.requestError) && f.unshift(a.request, a.requestError); | |
(a.response || a.responseError) && f.push(a.response, a.responseError) | |
}); | |
f.length; | |
) { | |
a = f.shift(); | |
var k = f.shift(), h = h.then(a, k) | |
} | |
h.success = function(a) { | |
h.then(function(b) { | |
a(b.data, b.status, b.headers, d) | |
}); | |
return h | |
}; | |
h.error = function(a) { | |
h.then(null, function(b) { | |
a(b.data, b.status, b.headers, d) | |
}); | |
return h | |
}; | |
return h | |
} | |
function C(b, c, g) { | |
function f(a, b, c) { | |
u && (200 <= a && 300 > a ? u.put(r, [a, b, kc(c)]) : u.remove(r)); | |
l(b, a, c); | |
d.$$phase || d.$apply() | |
} | |
function l(a, c, d) { | |
c = Math.max(c, 0); | |
(200 <= c && 300 > c ? p.resolve : p.reject)({ | |
data: a, | |
status: c, | |
headers: lc(d), | |
config: b | |
}) | |
} | |
function k() { | |
var a = bb(t.pendingRequests, b); | |
- 1 !== a && t.pendingRequests.splice(a, | |
1) | |
} | |
var p = n.defer(), C = p.promise, u, q, r = B(b.url, b.params); | |
t.pendingRequests.push(b); | |
C.then(k, k); | |
(b.cache || e.cache) && (!1 !== b.cache && "GET" == b.method) && (u = U(b.cache) ? b.cache : U(e.cache) ? e.cache : K); | |
if (u) | |
if (q = u.get(r), z(q)) { | |
if (q.then) | |
return q.then(k, k), q; | |
L(q) ? l(q[1], q[0], ga(q[2])) : l(q, 200, {}) | |
} else | |
u.put(r, C); | |
H(q) && a(b.method, r, c, f, g, b.timeout, b.withCredentials, b.responseType); | |
return C | |
} | |
function B(a, b) { | |
if (!b) | |
return a; | |
var c = []; | |
Nc(b, function(a, b) { | |
null === a || H(a) || (L(a) || (a = [a]), q(a, function(a) { | |
U(a) && (a = oa(a)); | |
c.push(va(b) + "=" + va(a)) | |
})) | |
}); | |
return a + ( - 1 == a.indexOf("?") ? "?" : "&") + c.join("&") | |
} | |
var K = c("$http"), u = []; | |
q(g, function(a) { | |
u.unshift(D(a) ? p.get(a) : p.invoke(a)) | |
}); | |
q(f, function(a, b) { | |
var c = D(a) ? p.get(a): p.invoke(a); | |
u.splice(b, 0, { | |
response: function(a) { | |
return c(n.when(a)) | |
}, | |
responseError: function(a) { | |
return c(n.reject(a)) | |
} | |
}) | |
}); | |
t.pendingRequests = []; | |
(function(a) { | |
q(arguments, function(a) { | |
t[a] = function(b, c) { | |
return t(w(c || {}, { | |
method: a, | |
url: b | |
})) | |
} | |
}) | |
})("get", "delete", "head", "jsonp"); | |
(function(a) { | |
q(arguments, function(a) { | |
t[a] = | |
function(b, c, d) { | |
return t(w(d || {}, { | |
method: a, | |
url: b, | |
data: c | |
})) | |
} | |
}) | |
})("post", "put"); | |
t.defaults = e; | |
return t | |
} | |
] | |
} | |
function nd() { | |
this.$get = ["$browser", "$window", "$document", function(b, a, c) { | |
return od(b, pd, b.defer, a.angular.callbacks, c[0]) | |
} | |
] | |
} | |
function od(b, a, c, d, e) { | |
function g(a, b) { | |
var c = e.createElement("script"), d = function() { | |
c.onreadystatechange = c.onload = c.onerror = null; | |
e.body.removeChild(c); | |
b && b() | |
}; | |
c.type = "text/javascript"; | |
c.src = a; | |
E && 8 >= E ? c.onreadystatechange = function() { | |
/loaded|complete/.test(c.readyState) && d() | |
} : | |
c.onload = c.onerror = function() { | |
d() | |
}; | |
e.body.appendChild(c); | |
return d | |
} | |
var f =- 1; | |
return function(e, l, k, m, n, p, t, C) { | |
function B() { | |
u = f; | |
r && r(); | |
y && y.abort() | |
} | |
function K(a, d, e, g) { | |
var f = ya(l).protocol; | |
ba && c.cancel(ba); | |
r = y = null; | |
d = "file" == f && 0 === d ? e ? 200 : 404 : d; | |
a(1223 == d ? 204 : d, e, g); | |
b.$$completeOutstandingRequest(s) | |
} | |
var u; | |
b.$$incOutstandingRequestCount(); | |
l = l || b.url(); | |
if ("jsonp" == v(e)) { | |
var P = "_" + (d.counter++).toString(36); | |
d[P] = function(a) { | |
d[P].data = a | |
}; | |
var r = g(l.replace("JSON_CALLBACK", "angular.callbacks." + P), function() { | |
d[P].data ? | |
K(m, 200, d[P].data) : K(m, u||-2); | |
delete d[P] | |
}) | |
} else { | |
var y = new a; | |
y.open(e, l, !0); | |
q(n, function(a, b) { | |
z(a) && y.setRequestHeader(b, a) | |
}); | |
y.onreadystatechange = function() { | |
if (4 == y.readyState) { | |
var a = null, b = null; | |
u !== f && (a = y.getAllResponseHeaders(), b = y.responseType ? y.response : y.responseText); | |
K(m, u || y.status, b, a) | |
} | |
}; | |
t && (y.withCredentials=!0); | |
C && (y.responseType = C); | |
y.send(k || null) | |
} | |
if (0 < p) | |
var ba = c(B, p); | |
else | |
p && p.then && p.then(B) | |
} | |
} | |
function qd() { | |
var b = "{{", a = "}}"; | |
this.startSymbol = function(a) { | |
return a ? (b = a, this) : b | |
}; | |
this.endSymbol = | |
function(b) { | |
return b ? (a = b, this) : a | |
}; | |
this.$get = ["$parse", "$exceptionHandler", "$sce", function(c, d, e) { | |
function g(g, k, m) { | |
for (var n, p, t = 0, C = [], B = g.length, K=!1, u = []; t < B;) | |
- 1 != (n = g.indexOf(b, t))&&-1 != (p = g.indexOf(a, n + f)) ? (t != n && C.push(g.substring(t, n)), C.push(t = c(K = g.substring(n + f, p))), t.exp = K, t = p + h, K=!0) : (t != B && C.push(g.substring(t)), t = B); | |
(B = C.length) || (C.push(""), B = 1); | |
if (m && 1 < C.length) | |
throw nc("noconcat", g); | |
if (!k || K) | |
return u.length = B, t = function(a) { | |
try { | |
for (var b = 0, c = B, f; b < c; b++) | |
"function" == typeof(f = C[b]) && | |
(f = f(a), f = m ? e.getTrusted(m, f) : e.valueOf(f), null === f || H(f) ? f = "" : "string" != typeof f && (f = oa(f))), u[b] = f; | |
return u.join("") | |
} catch (h) { | |
a = nc("interr", g, h.toString()), d(a) | |
} | |
}, t.exp = g, t.parts = C, t | |
} | |
var f = b.length, h = a.length; | |
g.startSymbol = function() { | |
return b | |
}; | |
g.endSymbol = function() { | |
return a | |
}; | |
return g | |
} | |
] | |
} | |
function rd() { | |
this.$get = ["$rootScope", "$window", "$q", function(b, a, c) { | |
function d(d, f, h, l) { | |
var k = a.setInterval, m = a.clearInterval, n = c.defer(), p = n.promise, t = 0, C = z(l)&&!l; | |
h = z(h) ? h : 0; | |
p.then(null, null, d); | |
p.$$intervalId = | |
k(function() { | |
n.notify(t++); | |
0 < h && t >= h && (n.resolve(t), m(p.$$intervalId), delete e[p.$$intervalId]); | |
C || b.$apply() | |
}, f); | |
e[p.$$intervalId] = n; | |
return p | |
} | |
var e = {}; | |
d.cancel = function(a) { | |
return a && a.$$intervalId in e ? (e[a.$$intervalId].reject("canceled"), clearInterval(a.$$intervalId), delete e[a.$$intervalId], !0) : !1 | |
}; | |
return d | |
} | |
] | |
} | |
function sd() { | |
this.$get = function() { | |
return { | |
id: "en-us", | |
NUMBER_FORMATS: { | |
DECIMAL_SEP: ".", | |
GROUP_SEP: ",", | |
PATTERNS: [{ | |
minInt: 1, | |
minFrac: 0, | |
maxFrac: 3, | |
posPre: "", | |
posSuf: "", | |
negPre: "-", | |
negSuf: "", | |
gSize: 3, | |
lgSize: 3 | |
}, { | |
minInt: 1, | |
minFrac: 2, | |
maxFrac: 2, | |
posPre: "\u00a4", | |
posSuf: "", | |
negPre: "(\u00a4", | |
negSuf: ")", | |
gSize: 3, | |
lgSize: 3 | |
} | |
], | |
CURRENCY_SYM: "$" | |
}, | |
DATETIME_FORMATS: { | |
MONTH: "January February March April May June July August September October November December".split(" "), | |
SHORTMONTH: "Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec".split(" "), | |
DAY: "Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "), | |
SHORTDAY: "Sun Mon Tue Wed Thu Fri Sat".split(" "), | |
AMPMS: ["AM", "PM"], | |
medium: "MMM d, y h:mm:ss a", | |
"short": "M/d/yy h:mm a", | |
fullDate: "EEEE, MMMM d, y", | |
longDate: "MMMM d, y", | |
mediumDate: "MMM d, y", | |
shortDate: "M/d/yy", | |
mediumTime: "h:mm:ss a", | |
shortTime: "h:mm a" | |
}, | |
pluralCat: function(b) { | |
return 1 === b ? "one" : "other" | |
} | |
} | |
} | |
} | |
function oc(b) { | |
b = b.split("/"); | |
for (var a = b.length; a--;) | |
b[a] = sb(b[a]); | |
return b.join("/") | |
} | |
function pc(b, a, c) { | |
b = ya(b, c); | |
a.$$protocol = b.protocol; | |
a.$$host = b.hostname; | |
a.$$port = R(b.port) || td[b.protocol] || null | |
} | |
function qc(b, a, c) { | |
var d = "/" !== b.charAt(0); | |
d && (b = "/" + b); | |
b = ya(b, c); | |
a.$$path = decodeURIComponent(d && "/" === b.pathname.charAt(0) ? | |
b.pathname.substring(1) : b.pathname); | |
a.$$search = Vb(b.search); | |
a.$$hash = decodeURIComponent(b.hash); | |
a.$$path && "/" != a.$$path.charAt(0) && (a.$$path = "/" + a.$$path) | |
} | |
function na(b, a) { | |
if (0 === a.indexOf(b)) | |
return a.substr(b.length) | |
} | |
function Wa(b) { | |
var a = b.indexOf("#"); | |
return - 1 == a ? b : b.substr(0, a) | |
} | |
function Gb(b) { | |
return b.substr(0, Wa(b).lastIndexOf("/") + 1) | |
} | |
function rc(b, a) { | |
this.$$html5=!0; | |
a = a || ""; | |
var c = Gb(b); | |
pc(b, this, b); | |
this.$$parse = function(a) { | |
var e = na(c, a); | |
if (!D(e)) | |
throw Hb("ipthprfx", a, c); | |
qc(e, this, b); | |
this.$$path || | |
(this.$$path = "/"); | |
this.$$compose() | |
}; | |
this.$$compose = function() { | |
var a = Wb(this.$$search), b = this.$$hash ? "#" + sb(this.$$hash): ""; | |
this.$$url = oc(this.$$path) + (a ? "?" + a : "") + b; | |
this.$$absUrl = c + this.$$url.substr(1) | |
}; | |
this.$$rewrite = function(d) { | |
var e; | |
if ((e = na(b, d)) !== r) | |
return d = e, (e = na(a, e)) !== r ? c + (na("/", e) || e) : b + d; | |
if ((e = na(c, d)) !== r) | |
return c + e; | |
if (c == d + "/") | |
return c | |
} | |
} | |
function Ib(b, a) { | |
var c = Gb(b); | |
pc(b, this, b); | |
this.$$parse = function(d) { | |
var e = na(b, d) || na(c, d), e = "#" == e.charAt(0) ? na(a, e): this.$$html5 ? e: ""; | |
if (!D(e)) | |
throw Hb("ihshprfx", | |
d, a); | |
qc(e, this, b); | |
d = this.$$path; | |
var g = /^\/?.*?:(\/.*)/; | |
0 === e.indexOf(b) && (e = e.replace(b, "")); | |
g.exec(e) || (d = (e = g.exec(d)) ? e[1] : d); | |
this.$$path = d; | |
this.$$compose() | |
}; | |
this.$$compose = function() { | |
var c = Wb(this.$$search), e = this.$$hash ? "#" + sb(this.$$hash): ""; | |
this.$$url = oc(this.$$path) + (c ? "?" + c : "") + e; | |
this.$$absUrl = b + (this.$$url ? a + this.$$url : "") | |
}; | |
this.$$rewrite = function(a) { | |
if (Wa(b) == Wa(a)) | |
return a | |
} | |
} | |
function sc(b, a) { | |
this.$$html5=!0; | |
Ib.apply(this, arguments); | |
var c = Gb(b); | |
this.$$rewrite = function(d) { | |
var e; | |
if (b == Wa(d)) | |
return d; | |
if (e = na(c, d)) | |
return b + a + e; | |
if (c === d + "/") | |
return c | |
} | |
} | |
function hb(b) { | |
return function() { | |
return this[b] | |
} | |
} | |
function tc(b, a) { | |
return function(c) { | |
if (H(c)) | |
return this[b]; | |
this[b] = a(c); | |
this.$$compose(); | |
return this | |
} | |
} | |
function ud() { | |
var b = "", a=!1; | |
this.hashPrefix = function(a) { | |
return z(a) ? (b = a, this) : b | |
}; | |
this.html5Mode = function(b) { | |
return z(b) ? (a = b, this) : a | |
}; | |
this.$get = ["$rootScope", "$browser", "$sniffer", "$rootElement", function(c, d, e, g) { | |
function f(a) { | |
c.$broadcast("$locationChangeSuccess", h.absUrl(), a) | |
} | |
var h, l = d.baseHref(), | |
k = d.url(); | |
a ? (l = k.substring(0, k.indexOf("/", k.indexOf("//") + 2)) + (l || "/"), e = e.history ? rc : sc) : (l = Wa(k), e = Ib); | |
h = new e(l, "#" + b); | |
h.$$parse(h.$$rewrite(k)); | |
g.on("click", function(a) { | |
if (!a.ctrlKey&&!a.metaKey && 2 != a.which) { | |
for (var b = x(a.target); "a" !== v(b[0].nodeName);) | |
if (b[0] === g[0] ||!(b = b.parent())[0]) | |
return; | |
var e = b.prop("href"), f = h.$$rewrite(e); | |
e && (!b.attr("target") && f&&!a.isDefaultPrevented()) && (a.preventDefault(), f != d.url() && (h.$$parse(f), c.$apply(), W.angular["ff-684208-preventDefault"]=!0)) | |
} | |
}); | |
h.absUrl() != | |
k && d.url(h.absUrl(), !0); | |
d.onUrlChange(function(a) { | |
h.absUrl() != a && (c.$broadcast("$locationChangeStart", a, h.absUrl()).defaultPrevented ? d.url(h.absUrl()) : (c.$evalAsync(function() { | |
var b = h.absUrl(); | |
h.$$parse(a); | |
f(b) | |
}), c.$$phase || c.$digest())) | |
}); | |
var m = 0; | |
c.$watch(function() { | |
var a = d.url(), b = h.$$replace; | |
m && a == h.absUrl() || (m++, c.$evalAsync(function() { | |
c.$broadcast("$locationChangeStart", h.absUrl(), a).defaultPrevented ? h.$$parse(a) : (d.url(h.absUrl(), b), f(a)) | |
})); | |
h.$$replace=!1; | |
return m | |
}); | |
return h | |
} | |
] | |
} | |
function vd() { | |
var b = | |
!0, a = this; | |
this.debugEnabled = function(a) { | |
return z(a) ? (b = a, this) : b | |
}; | |
this.$get = ["$window", function(c) { | |
function d(a) { | |
a instanceof Error && (a.stack ? a = a.message&&-1 === a.stack.indexOf(a.message) ? "Error: " + a.message + "\n" + a.stack : a.stack : a.sourceURL && (a = a.message + "\n" + a.sourceURL + ":" + a.line)); | |
return a | |
} | |
function e(a) { | |
var b = c.console || {}, e = b[a] || b.log || s; | |
return e.apply ? function() { | |
var a = []; | |
q(arguments, function(b) { | |
a.push(d(b)) | |
}); | |
return e.apply(b, a) | |
} : function(a, b) { | |
e(a, null == b ? "" : b) | |
} | |
} | |
return { | |
log: e("log"), | |
info: e("info"), | |
warn: e("warn"), | |
error: e("error"), | |
debug: function() { | |
var c = e("debug"); | |
return function() { | |
b && c.apply(a, arguments) | |
} | |
}() | |
} | |
} | |
] | |
} | |
function pa(b, a) { | |
if ("constructor" === b) | |
throw za("isecfld", a); | |
return b | |
} | |
function Xa(b, a) { | |
if (b) { | |
if (b.constructor === b) | |
throw za("isecfn", a); | |
if (b.document && b.location && b.alert && b.setInterval) | |
throw za("isecwindow", a); | |
if (b.children && (b.nodeName || b.on && b.find)) | |
throw za("isecdom", a); | |
} | |
return b | |
} | |
function ib(b, a, c, d, e) { | |
e = e || {}; | |
a = a.split("."); | |
for (var g, f = 0; 1 < a.length; f++) { | |
g = pa(a.shift(), d); | |
var h = b[g]; | |
h || (h = {}, b[g] = h); | |
b = h; | |
b.then && e.unwrapPromises && (qa(d), "$$v"in b || function(a) { | |
a.then(function(b) { | |
a.$$v = b | |
}) | |
}(b), b.$$v === r && (b.$$v = {}), b = b.$$v) | |
} | |
g = pa(a.shift(), d); | |
return b[g] = c | |
} | |
function uc(b, a, c, d, e, g, f) { | |
pa(b, g); | |
pa(a, g); | |
pa(c, g); | |
pa(d, g); | |
pa(e, g); | |
return f.unwrapPromises ? function(f, l) { | |
var k = l && l.hasOwnProperty(b) ? l: f, m; | |
if (null === k || k === r) | |
return k; | |
(k = k[b]) && k.then && (qa(g), "$$v"in k || (m = k, m.$$v = r, m.then(function(a) { | |
m.$$v = a | |
})), k = k.$$v); | |
if (!a || null === k || k === r) | |
return k; | |
(k = k[a]) && k.then && (qa(g), "$$v"in k || (m = k, | |
m.$$v = r, m.then(function(a) { | |
m.$$v = a | |
})), k = k.$$v); | |
if (!c || null === k || k === r) | |
return k; | |
(k = k[c]) && k.then && (qa(g), "$$v"in k || (m = k, m.$$v = r, m.then(function(a) { | |
m.$$v = a | |
})), k = k.$$v); | |
if (!d || null === k || k === r) | |
return k; | |
(k = k[d]) && k.then && (qa(g), "$$v"in k || (m = k, m.$$v = r, m.then(function(a) { | |
m.$$v = a | |
})), k = k.$$v); | |
if (!e || null === k || k === r) | |
return k; | |
(k = k[e]) && k.then && (qa(g), "$$v"in k || (m = k, m.$$v = r, m.then(function(a) { | |
m.$$v = a | |
})), k = k.$$v); | |
return k | |
} : function(g, f) { | |
var k = f && f.hasOwnProperty(b) ? f: g; | |
if (null === k || k === r) | |
return k; | |
k = k[b]; | |
if (!a || | |
null === k || k === r) | |
return k; | |
k = k[a]; | |
if (!c || null === k || k === r) | |
return k; | |
k = k[c]; | |
if (!d || null === k || k === r) | |
return k; | |
k = k[d]; | |
return e && null !== k && k !== r ? k = k[e] : k | |
} | |
} | |
function vc(b, a, c) { | |
if (Jb.hasOwnProperty(b)) | |
return Jb[b]; | |
var d = b.split("."), e = d.length, g; | |
if (a.csp) | |
g = 6 > e ? uc(d[0], d[1], d[2], d[3], d[4], c, a) : function(b, g) { | |
var f = 0, h; | |
do | |
h = uc(d[f++], d[f++], d[f++], d[f++], d[f++], c, a)(b, g), g = r, b = h; | |
while (f < e); | |
return h | |
}; | |
else { | |
var f = "var l, fn, p;\n"; | |
q(d, function(b, d) { | |
pa(b, c); | |
f += "if(s === null || s === undefined) return s;\nl=s;\ns=" + | |
(d ? "s" : '((k&&k.hasOwnProperty("' + b + '"))?k:s)') + '["' + b + '"];\n' + (a.unwrapPromises ? 'if (s && s.then) {\n pw("' + c.replace(/(["\r\n])/g, "\\$1") + '");\n if (!("$$v" in s)) {\n p=s;\n p.$$v = undefined;\n p.then(function(v) {p.$$v=v;});\n}\n s=s.$$v\n}\n' : "") | |
}); | |
var f = f + "return s;", h = new Function("s", "k", "pw", f); | |
h.toString = function() { | |
return f | |
}; | |
g = function(a, b) { | |
return h(a, b, qa) | |
} | |
} | |
"hasOwnProperty" !== b && (Jb[b] = g); | |
return g | |
} | |
function wd() { | |
var b = {}, a = { | |
csp: !1, | |
unwrapPromises: !1, | |
logPromiseWarnings: !0 | |
}; | |
this.unwrapPromises = | |
function(b) { | |
return z(b) ? (a.unwrapPromises=!!b, this) : a.unwrapPromises | |
}; | |
this.logPromiseWarnings = function(b) { | |
return z(b) ? (a.logPromiseWarnings = b, this) : a.logPromiseWarnings | |
}; | |
this.$get = ["$filter", "$sniffer", "$log", function(c, d, e) { | |
a.csp = d.csp; | |
qa = function(b) { | |
a.logPromiseWarnings&&!wc.hasOwnProperty(b) && (wc[b]=!0, e.warn("[$parse] Promise found in the expression `" + b + "`. Automatic unwrapping of promises in Angular expressions is deprecated.")) | |
}; | |
return function(d) { | |
var e; | |
switch (typeof d) { | |
case "string": | |
if (b.hasOwnProperty(d)) | |
return b[d]; | |
e = new Kb(a); | |
e = (new Ya(e, c, a)).parse(d, !1); | |
"hasOwnProperty" !== d && (b[d] = e); | |
return e; | |
case "function": | |
return d; | |
default: | |
return s | |
} | |
} | |
} | |
] | |
} | |
function xd() { | |
this.$get = ["$rootScope", "$exceptionHandler", function(b, a) { | |
return yd(function(a) { | |
b.$evalAsync(a) | |
}, a) | |
} | |
] | |
} | |
function yd(b, a) { | |
function c(a) { | |
return a | |
} | |
function d(a) { | |
return f(a) | |
} | |
var e = function() { | |
var h = [], l, k; | |
return k = { | |
resolve: function(a) { | |
if (h) { | |
var c = h; | |
h = r; | |
l = g(a); | |
c.length && b(function() { | |
for (var a, b = 0, d = c.length; b < d; b++) | |
a = c[b], l.then(a[0], a[1], a[2]) | |
}) | |
} | |
}, | |
reject: function(a) { | |
k.resolve(f(a)) | |
}, | |
notify: function(a) { | |
if (h) { | |
var c = h; | |
h.length && b(function() { | |
for (var b, d = 0, e = c.length; d < e; d++) | |
b = c[d], b[2](a) | |
}) | |
} | |
}, | |
promise: { | |
then: function(b, f, g) { | |
var k = e(), C = function(d) { | |
try { | |
k.resolve((A(b) ? b : c)(d)) | |
} catch (e) { | |
k.reject(e), a(e) | |
} | |
}, B = function(b) { | |
try { | |
k.resolve((A(f) ? f : d)(b)) | |
} catch (c) { | |
k.reject(c), a(c) | |
} | |
}, K = function(b) { | |
try { | |
k.notify((A(g) ? g : c)(b)) | |
} catch (d) { | |
a(d) | |
} | |
}; | |
h ? h.push([C, B, K]) : l.then(C, B, K); | |
return k.promise | |
}, | |
"catch": function(a) { | |
return this.then(null, a) | |
}, | |
"finally": function(a) { | |
function b(a, c) { | |
var d = e(); | |
c ? d.resolve(a) : | |
d.reject(a); | |
return d.promise | |
} | |
function d(e, f) { | |
var g = null; | |
try { | |
g = (a || c)() | |
} catch (h) { | |
return b(h, !1) | |
} | |
return g && A(g.then) ? g.then(function() { | |
return b(e, f) | |
}, function(a) { | |
return b(a, !1) | |
}) : b(e, f) | |
} | |
return this.then(function(a) { | |
return d(a, !0) | |
}, function(a) { | |
return d(a, !1) | |
}) | |
} | |
} | |
} | |
}, g = function(a) { | |
return a && A(a.then) ? a : { | |
then: function(c) { | |
var d = e(); | |
b(function() { | |
d.resolve(c(a)) | |
}); | |
return d.promise | |
} | |
} | |
}, f = function(c) { | |
return { | |
then: function(f, g) { | |
var m = e(); | |
b(function() { | |
try { | |
m.resolve((A(g) ? g : d)(c)) | |
} catch (b) { | |
m.reject(b), a(b) | |
} | |
}); | |
return m.promise | |
} | |
} | |
}; | |
return { | |
defer: e, | |
reject: f, | |
when: function(h, l, k, m) { | |
var n = e(), p, t = function(b) { | |
try { | |
return (A(l) ? l : c)(b) | |
} catch (d) { | |
return a(d), f(d) | |
} | |
}, C = function(b) { | |
try { | |
return (A(k) ? k : d)(b) | |
} catch (c) { | |
return a(c), f(c) | |
} | |
}, B = function(b) { | |
try { | |
return (A(m) ? m : c)(b) | |
} catch (d) { | |
a(d) | |
} | |
}; | |
b(function() { | |
g(h).then(function(a) { | |
p || (p=!0, n.resolve(g(a).then(t, C, B))) | |
}, function(a) { | |
p || (p=!0, n.resolve(C(a))) | |
}, function(a) { | |
p || n.notify(B(a)) | |
}) | |
}); | |
return n.promise | |
}, | |
all: function(a) { | |
var b = e(), c = 0, d = L(a) ? []: {}; | |
q(a, function(a, e) { | |
c++; | |
g(a).then(function(a) { | |
d.hasOwnProperty(e) || | |
(d[e] = a, --c || b.resolve(d)) | |
}, function(a) { | |
d.hasOwnProperty(e) || b.reject(a) | |
}) | |
}); | |
0 === c && b.resolve(d); | |
return b.promise | |
} | |
} | |
} | |
function zd() { | |
var b = 10, a = G("$rootScope"), c = null; | |
this.digestTtl = function(a) { | |
arguments.length && (b = a); | |
return b | |
}; | |
this.$get = ["$injector", "$exceptionHandler", "$parse", "$browser", function(d, e, g, f) { | |
function h() { | |
this.$id = Za(); | |
this.$$phase = this.$parent = this.$$watchers = this.$$nextSibling = this.$$prevSibling = this.$$childHead = this.$$childTail = null; | |
this["this"] = this.$root = this; | |
this.$$destroyed=!1; | |
this.$$asyncQueue = []; | |
this.$$postDigestQueue = []; | |
this.$$listeners = {}; | |
this.$$isolateBindings = {} | |
} | |
function l(b) { | |
if (n.$$phase) | |
throw a("inprog", n.$$phase); | |
n.$$phase = b | |
} | |
function k(a, b) { | |
var c = g(a); | |
Qa(c, b); | |
return c | |
} | |
function m() {} | |
h.prototype = { | |
constructor: h, | |
$new: function(a) { | |
a ? (a = new h, a.$root = this.$root, a.$$asyncQueue = this.$$asyncQueue, a.$$postDigestQueue = this.$$postDigestQueue) : (a = function() {}, a.prototype = this, a = new a, a.$id = Za()); | |
a["this"] = a; | |
a.$$listeners = {}; | |
a.$parent = this; | |
a.$$watchers = a.$$nextSibling = a.$$childHead = | |
a.$$childTail = null; | |
a.$$prevSibling = this.$$childTail; | |
this.$$childHead ? this.$$childTail = this.$$childTail.$$nextSibling = a : this.$$childHead = this.$$childTail = a; | |
return a | |
}, | |
$watch: function(a, b, d) { | |
var e = k(a, "watch"), g = this.$$watchers, f = { | |
fn: b, | |
last: m, | |
get: e, | |
exp: a, | |
eq: !!d | |
}; | |
c = null; | |
if (!A(b)) { | |
var h = k(b || s, "listener"); | |
f.fn = function(a, b, c) { | |
h(c) | |
} | |
} | |
if ("string" == typeof a && e.constant) { | |
var l = f.fn; | |
f.fn = function(a, b, c) { | |
l.call(this, a, b, c); | |
Ma(g, f) | |
} | |
} | |
g || (g = this.$$watchers = []); | |
g.unshift(f); | |
return function() { | |
Ma(g, f) | |
} | |
}, | |
$watchCollection: function(a, | |
b) { | |
var c = this, d, e, f = 0, h = g(a), l = [], k = {}, m = 0; | |
return this.$watch(function() { | |
e = h(c); | |
var a, b; | |
if (U(e)) | |
if (pb(e)) | |
for (d !== l && (d = l, m = d.length = 0, f++), a = e.length, m !== a && (f++, d.length = m = a), b = 0; b < a; b++) | |
d[b] !== e[b] && (f++, d[b] = e[b]); | |
else { | |
d !== k && (d = k = {}, m = 0, f++); | |
a = 0; | |
for (b in e) | |
e.hasOwnProperty(b) && (a++, d.hasOwnProperty(b) ? d[b] !== e[b] && (f++, d[b] = e[b]) : (m++, d[b] = e[b], f++)); | |
if (m > a) | |
for (b in f++, d) | |
d.hasOwnProperty(b)&&!e.hasOwnProperty(b) && (m--, delete d[b]) | |
} else | |
d !== e && (d = e, f++); | |
return f | |
}, function() { | |
b(e, d, c) | |
}) | |
}, | |
$digest: function() { | |
var d, | |
f, g, h, k = this.$$asyncQueue, q = this.$$postDigestQueue, r, v, y = b, s, x = [], z, X, $; | |
l("$digest"); | |
c = null; | |
do { | |
v=!1; | |
for (s = this; k.length;) { | |
try { | |
$ = k.shift(), $.scope.$eval($.expression) | |
} catch (O) { | |
n.$$phase = null, e(O) | |
} | |
c = null | |
} | |
a: | |
do { | |
if (h = s.$$watchers) | |
for (r = h.length; r--;) | |
try { | |
if (d = h[r]) | |
if ((f = d.get(s)) !== (g = d.last)&&!(d.eq ? ta(f, g) : "number" == typeof f && "number" == typeof g && isNaN(f) && isNaN(g))) | |
v=!0, c = d, d.last = d.eq ? ga(f) : f, d.fn(f, g === m ? f : g, s), 5 > y && (z = 4 - y, x[z] || (x[z] = []), X = A(d.exp) ? "fn: " + (d.exp.name || d.exp.toString()) : d.exp, X += "; newVal: " + | |
oa(f) + "; oldVal: " + oa(g), x[z].push(X)); | |
else if (d === c) { | |
v=!1; | |
break a | |
} | |
} catch (M) { | |
n.$$phase = null, e(M) | |
} | |
if (!(h = s.$$childHead || s !== this && s.$$nextSibling)) | |
for (; s !== this&&!(h = s.$$nextSibling);) | |
s = s.$parent | |
} | |
while (s = h); | |
if (v&&!y--) | |
throw n.$$phase = null, a("infdig", b, oa(x)); | |
} | |
while (v || k.length); | |
for (n.$$phase = null; q.length;) | |
try { | |
q.shift()() | |
} catch (S) { | |
e(S) | |
} | |
}, | |
$destroy: function() { | |
if (!this.$$destroyed) { | |
var a = this.$parent; | |
this.$broadcast("$destroy"); | |
this.$$destroyed=!0; | |
this !== n && (a.$$childHead == this && (a.$$childHead = this.$$nextSibling), | |
a.$$childTail == this && (a.$$childTail = this.$$prevSibling), this.$$prevSibling && (this.$$prevSibling.$$nextSibling = this.$$nextSibling), this.$$nextSibling && (this.$$nextSibling.$$prevSibling = this.$$prevSibling), this.$parent = this.$$nextSibling = this.$$prevSibling = this.$$childHead = this.$$childTail = null) | |
} | |
}, | |
$eval: function(a, b) { | |
return g(a)(this, b) | |
}, | |
$evalAsync: function(a) { | |
n.$$phase || n.$$asyncQueue.length || f.defer(function() { | |
n.$$asyncQueue.length && n.$digest() | |
}); | |
this.$$asyncQueue.push({ | |
scope: this, | |
expression: a | |
}) | |
}, | |
$$postDigest: function(a) { | |
this.$$postDigestQueue.push(a) | |
}, | |
$apply: function(a) { | |
try { | |
return l("$apply"), this.$eval(a) | |
} catch (b) { | |
e(b) | |
} finally { | |
n.$$phase = null; | |
try { | |
n.$digest() | |
} catch (c) { | |
throw e(c), c; | |
} | |
} | |
}, | |
$on: function(a, b) { | |
var c = this.$$listeners[a]; | |
c || (this.$$listeners[a] = c = []); | |
c.push(b); | |
return function() { | |
c[bb(c, b)] = null | |
} | |
}, | |
$emit: function(a, b) { | |
var c = [], d, f = this, g=!1, h = { | |
name: a, | |
targetScope: f, | |
stopPropagation: function() { | |
g=!0 | |
}, | |
preventDefault: function() { | |
h.defaultPrevented=!0 | |
}, | |
defaultPrevented: !1 | |
}, l = [h].concat(ua.call(arguments, | |
1)), k, m; | |
do { | |
d = f.$$listeners[a] || c; | |
h.currentScope = f; | |
k = 0; | |
for (m = d.length; k < m; k++) | |
if (d[k]) | |
try { | |
d[k].apply(null, l) | |
} catch (n) { | |
e(n) | |
} else | |
d.splice(k, 1), k--, m--; | |
if (g) | |
break; | |
f = f.$parent | |
} | |
while (f); | |
return h | |
}, | |
$broadcast: function(a, b) { | |
var c = this, d = this, f = { | |
name: a, | |
targetScope: this, | |
preventDefault: function() { | |
f.defaultPrevented=!0 | |
}, | |
defaultPrevented: !1 | |
}, g = [f].concat(ua.call(arguments, 1)), h, k; | |
do { | |
c = d; | |
f.currentScope = c; | |
d = c.$$listeners[a] || []; | |
h = 0; | |
for (k = d.length; h < k; h++) | |
if (d[h]) | |
try { | |
d[h].apply(null, g) | |
} catch (l) { | |
e(l) | |
} else | |
d.splice(h, | |
1), h--, k--; | |
if (!(d = c.$$childHead || c !== this && c.$$nextSibling)) | |
for (; c !== this&&!(d = c.$$nextSibling);) | |
c = c.$parent | |
} | |
while (c = d); | |
return f | |
} | |
}; | |
var n = new h; | |
return n | |
} | |
] | |
} | |
function Ad() { | |
var b = /^\s*(https?|ftp|mailto|tel|file):/, a = /^\s*(https?|ftp|file):|data:image\//; | |
this.aHrefSanitizationWhitelist = function(a) { | |
return z(a) ? (b = a, this) : b | |
}; | |
this.imgSrcSanitizationWhitelist = function(b) { | |
return z(b) ? (a = b, this) : a | |
}; | |
this.$get = function() { | |
return function(c, d) { | |
var e = d ? a: b, g; | |
if (!E || 8 <= E) | |
if (g = ya(c).href, "" !== g&&!g.match(e)) | |
return "unsafe:" + | |
g; | |
return c | |
} | |
} | |
} | |
function Bd(b) { | |
if ("self" === b) | |
return b; | |
if (D(b)) { | |
if ( - 1 < b.indexOf("***")) | |
throw ra("iwcard", b); | |
b = b.replace(/([-()\[\]{}+?*.$\^|,:#<!\\])/g, "\\$1").replace(/\x08/g, "\\x08").replace("\\*\\*", ".*").replace("\\*", "[^:/.?&;]*"); | |
return RegExp("^" + b + "$") | |
} | |
if (ab(b)) | |
return RegExp("^" + b.source + "$"); | |
throw ra("imatcher"); | |
} | |
function xc(b) { | |
var a = []; | |
z(b) && q(b, function(b) { | |
a.push(Bd(b)) | |
}); | |
return a | |
} | |
function Cd() { | |
this.SCE_CONTEXTS = fa; | |
var b = ["self"], a = []; | |
this.resourceUrlWhitelist = function(a) { | |
arguments.length && | |
(b = xc(a)); | |
return b | |
}; | |
this.resourceUrlBlacklist = function(b) { | |
arguments.length && (a = xc(b)); | |
return a | |
}; | |
this.$get = ["$injector", function(c) { | |
function d(a) { | |
var b = function(a) { | |
this.$$unwrapTrustedValue = function() { | |
return a | |
} | |
}; | |
a && (b.prototype = new a); | |
b.prototype.valueOf = function() { | |
return this.$$unwrapTrustedValue() | |
}; | |
b.prototype.toString = function() { | |
return this.$$unwrapTrustedValue().toString() | |
}; | |
return b | |
} | |
var e = function(a) { | |
throw ra("unsafe"); | |
}; | |
c.has("$sanitize") && (e = c.get("$sanitize")); | |
var g = d(), f = {}; | |
f[fa.HTML] = d(g); | |
f[fa.CSS] = d(g); | |
f[fa.URL] = d(g); | |
f[fa.JS] = d(g); | |
f[fa.RESOURCE_URL] = d(f[fa.URL]); | |
return { | |
trustAs: function(a, b) { | |
var c = f.hasOwnProperty(a) ? f[a]: null; | |
if (!c) | |
throw ra("icontext", a, b); | |
if (null === b || b === r || "" === b) | |
return b; | |
if ("string" !== typeof b) | |
throw ra("itype", a); | |
return new c(b) | |
}, | |
getTrusted: function(c, d) { | |
if (null === d || d === r || "" === d) | |
return d; | |
var g = f.hasOwnProperty(c) ? f[c]: null; | |
if (g && d instanceof g) | |
return d.$$unwrapTrustedValue(); | |
if (c === fa.RESOURCE_URL) { | |
var g = ya(d.toString()), m, n, p=!1; | |
m = 0; | |
for (n = b.length; m < n; m++) | |
if ("self" === | |
b[m] ? Fb(g) : b[m].exec(g.href)) { | |
p=!0; | |
break | |
} | |
if (p) | |
for (m = 0, n = a.length; m < n; m++) | |
if ("self" === a[m] ? Fb(g) : a[m].exec(g.href)) { | |
p=!1; | |
break | |
} | |
if (p) | |
return d; | |
throw ra("insecurl", d.toString()); | |
} | |
if (c === fa.HTML) | |
return e(d); | |
throw ra("unsafe"); | |
}, | |
valueOf: function(a) { | |
return a instanceof g ? a.$$unwrapTrustedValue() : a | |
} | |
} | |
} | |
] | |
} | |
function Dd() { | |
var b=!0; | |
this.enabled = function(a) { | |
arguments.length && (b=!!a); | |
return b | |
}; | |
this.$get = ["$parse", "$sniffer", "$sceDelegate", function(a, c, d) { | |
if (b && c.msie && 8 > c.msieDocumentMode) | |
throw ra("iequirks"); | |
var e = | |
ga(fa); | |
e.isEnabled = function() { | |
return b | |
}; | |
e.trustAs = d.trustAs; | |
e.getTrusted = d.getTrusted; | |
e.valueOf = d.valueOf; | |
b || (e.trustAs = e.getTrusted = function(a, b) { | |
return b | |
}, e.valueOf = Ba); | |
e.parseAs = function(b, c) { | |
var d = a(c); | |
return d.literal && d.constant ? d : function(a, c) { | |
return e.getTrusted(b, d(a, c)) | |
} | |
}; | |
var g = e.parseAs, f = e.getTrusted, h = e.trustAs; | |
q(fa, function(a, b) { | |
var c = v(b); | |
e[Ra("parse_as_" + c)] = function(b) { | |
return g(a, b) | |
}; | |
e[Ra("get_trusted_" + c)] = function(b) { | |
return f(a, b) | |
}; | |
e[Ra("trust_as_" + c)] = function(b) { | |
return h(a, b) | |
} | |
}); | |
return e | |
} | |
] | |
} | |
function Ed() { | |
this.$get = ["$window", "$document", function(b, a) { | |
var c = {}, d = R((/android (\d+)/.exec(v((b.navigator || {}).userAgent)) || [])[1]), e = /Boxee/i.test((b.navigator || {}).userAgent), g = a[0] || {}, f = g.documentMode, h, l = /^(Moz|webkit|O|ms)(?=[A-Z])/, k = g.body && g.body.style, m=!1, n=!1; | |
if (k) { | |
for (var p in k) | |
if (m = l.exec(p)) { | |
h = m[0]; | |
h = h.substr(0, 1).toUpperCase() + h.substr(1); | |
break | |
} | |
h || (h = "WebkitOpacity"in k && "webkit"); | |
m=!!("transition"in k || h + "Transition"in k); | |
n=!!("animation"in k || h + "Animation"in k); | |
!d || m && n || (m = D(g.body.style.webkitTransition), n = D(g.body.style.webkitAnimation)) | |
} | |
return { | |
history: !(!b.history ||!b.history.pushState || 4 > d || e), | |
hashchange: "onhashchange"in b && (!f || 7 < f), | |
hasEvent: function(a) { | |
if ("input" == a && 9 == E) | |
return !1; | |
if (H(c[a])) { | |
var b = g.createElement("div"); | |
c[a] = "on" + a in b | |
} | |
return c[a] | |
}, | |
csp: Sb(), | |
vendorPrefix: h, | |
transitions: m, | |
animations: n, | |
msie: E, | |
msieDocumentMode: f | |
} | |
} | |
] | |
} | |
function Fd() { | |
this.$get = ["$rootScope", "$browser", "$q", "$exceptionHandler", function(b, a, c, d) { | |
function e(e, h, l) { | |
var k = c.defer(), | |
m = k.promise, n = z(l)&&!l; | |
h = a.defer(function() { | |
try { | |
k.resolve(e()) | |
} catch (a) { | |
k.reject(a), d(a) | |
} finally { | |
delete g[m.$$timeoutId] | |
} | |
n || b.$apply() | |
}, h); | |
m.$$timeoutId = h; | |
g[h] = k; | |
return m | |
} | |
var g = {}; | |
e.cancel = function(b) { | |
return b && b.$$timeoutId in g ? (g[b.$$timeoutId].reject("canceled"), delete g[b.$$timeoutId], a.defer.cancel(b.$$timeoutId)) : !1 | |
}; | |
return e | |
} | |
] | |
} | |
function ya(b, a) { | |
var c = b; | |
E && (T.setAttribute("href", c), c = T.href); | |
T.setAttribute("href", c); | |
return { | |
href: T.href, | |
protocol: T.protocol ? T.protocol.replace(/:$/, ""): "", | |
host: T.host, | |
search: T.search ? T.search.replace(/^\?/, ""): "", | |
hash: T.hash ? T.hash.replace(/^#/, ""): "", | |
hostname: T.hostname, | |
port: T.port, | |
pathname: "/" === T.pathname.charAt(0) ? T.pathname: "/" + T.pathname | |
} | |
} | |
function Fb(b) { | |
b = D(b) ? ya(b) : b; | |
return b.protocol === yc.protocol && b.host === yc.host | |
} | |
function Gd() { | |
this.$get = ca(W) | |
} | |
function zc(b) { | |
function a(d, e) { | |
if (U(d)) { | |
var g = {}; | |
q(d, function(b, c) { | |
g[c] = a(c, b) | |
}); | |
return g | |
} | |
return b.factory(d + c, e) | |
} | |
var c = "Filter"; | |
this.register = a; | |
this.$get = ["$injector", function(a) { | |
return function(b) { | |
return a.get(b + | |
c) | |
} | |
} | |
]; | |
a("currency", Ac); | |
a("date", Bc); | |
a("filter", Hd); | |
a("json", Id); | |
a("limitTo", Jd); | |
a("lowercase", Kd); | |
a("number", Cc); | |
a("orderBy", Dc); | |
a("uppercase", Ld) | |
} | |
function Hd() { | |
return function(b, a, c) { | |
if (!L(b)) | |
return b; | |
var d = typeof c, e = []; | |
e.check = function(a) { | |
for (var b = 0; b < e.length; b++) | |
if (!e[b](a)) | |
return !1; | |
return !0 | |
}; | |
"function" !== d && (c = "boolean" === d && c ? function(a, b) { | |
return Pa.equals(a, b) | |
} : function(a, b) { | |
b = ("" + b).toLowerCase(); | |
return - 1 < ("" + a).toLowerCase().indexOf(b) | |
}); | |
var g = function(a, b) { | |
if ("string" == typeof b && "!" === | |
b.charAt(0)) | |
return !g(a, b.substr(1)); | |
switch (typeof a) { | |
case "boolean": | |
case "number": | |
case "string": | |
return c(a, b); | |
case "object": | |
switch (typeof b) { | |
case "object": | |
return c(a, b); | |
default: | |
for (var d in a) | |
if ("$" !== d.charAt(0) && g(a[d], b)) | |
return !0 | |
} | |
return !1; | |
case "array": | |
for (d = 0; d < a.length; d++) | |
if (g(a[d], b)) | |
return !0; | |
return !1; | |
default: | |
return !1 | |
} | |
}; | |
switch (typeof a) { | |
case "boolean": | |
case "number": | |
case "string": | |
a = { | |
$: a | |
}; | |
case "object": | |
for (var f in a) | |
"$" == f ? function() { | |
if (a[f]) { | |
var b = f; | |
e.push(function(c) { | |
return g(c, a[b]) | |
}) | |
} | |
}() : | |
function() { | |
if ("undefined" != typeof a[f]) { | |
var b = f; | |
e.push(function(c) { | |
return g(ub(c, b), a[b]) | |
}) | |
} | |
}(); | |
break; | |
case "function": | |
e.push(a); | |
break; | |
default: | |
return b | |
} | |
for (var d = [], h = 0; h < b.length; h++) { | |
var l = b[h]; | |
e.check(l) && d.push(l) | |
} | |
return d | |
} | |
} | |
function Ac(b) { | |
var a = b.NUMBER_FORMATS; | |
return function(b, d) { | |
H(d) && (d = a.CURRENCY_SYM); | |
return Ec(b, a.PATTERNS[1], a.GROUP_SEP, a.DECIMAL_SEP, 2).replace(/\u00A4/g, d) | |
} | |
} | |
function Cc(b) { | |
var a = b.NUMBER_FORMATS; | |
return function(b, d) { | |
return Ec(b, a.PATTERNS[0], a.GROUP_SEP, a.DECIMAL_SEP, d) | |
} | |
} | |
function Ec(b, a, c, d, e) { | |
if (isNaN(b) ||!isFinite(b)) | |
return ""; | |
var g = 0 > b; | |
b = Math.abs(b); | |
var f = b + "", h = "", l = [], k=!1; | |
if ( - 1 !== f.indexOf("e")) { | |
var m = f.match(/([\d\.]+)e(-?)(\d+)/); | |
m && "-" == m[2] && m[3] > e + 1 ? f = "0" : (h = f, k=!0) | |
} | |
if (k) | |
0 < e && ( - 1 < b && 1 > b) && (h = b.toFixed(e)); | |
else { | |
f = (f.split(Fc)[1] || "").length; | |
H(e) && (e = Math.min(Math.max(a.minFrac, f), a.maxFrac)); | |
f = Math.pow(10, e); | |
b = Math.round(b * f) / f; | |
b = ("" + b).split(Fc); | |
f = b[0]; | |
b = b[1] || ""; | |
var m = 0, n = a.lgSize, p = a.gSize; | |
if (f.length >= n + p) | |
for (m = f.length - n, k = 0; k < m; k++) | |
0 === (m - k)%p && 0 !== | |
k && (h += c), h += f.charAt(k); | |
for (k = m; k < f.length; k++) | |
0 === (f.length - k)%n && 0 !== k && (h += c), h += f.charAt(k); | |
for (; b.length < e;) | |
b += "0"; | |
e && "0" !== e && (h += d + b.substr(0, e)) | |
} | |
l.push(g ? a.negPre : a.posPre); | |
l.push(h); | |
l.push(g ? a.negSuf : a.posSuf); | |
return l.join("") | |
} | |
function Lb(b, a, c) { | |
var d = ""; | |
0 > b && (d = "-", b =- b); | |
for (b = "" + b; b.length < a;) | |
b = "0" + b; | |
c && (b = b.substr(b.length - a)); | |
return d + b | |
} | |
function V(b, a, c, d) { | |
c = c || 0; | |
return function(e) { | |
e = e["get" + b](); | |
if (0 < c || e>-c) | |
e += c; | |
0 === e&&-12 == c && (e = 12); | |
return Lb(e, a, d) | |
} | |
} | |
function jb(b, a) { | |
return function(c, | |
d) { | |
var e = c["get" + b](), g = Ia(a ? "SHORT" + b : b); | |
return d[g][e] | |
} | |
} | |
function Bc(b) { | |
function a(a) { | |
var b; | |
if (b = a.match(c)) { | |
a = new Date(0); | |
var g = 0, f = 0, h = b[8] ? a.setUTCFullYear: a.setFullYear, l = b[8] ? a.setUTCHours: a.setHours; | |
b[9] && (g = R(b[9] + b[10]), f = R(b[9] + b[11])); | |
h.call(a, R(b[1]), R(b[2]) - 1, R(b[3])); | |
g = R(b[4] || 0) - g; | |
f = R(b[5] || 0) - f; | |
h = R(b[6] || 0); | |
b = Math.round(1E3 * parseFloat("0." + (b[7] || 0))); | |
l.call(a, g, f, h, b) | |
} | |
return a | |
} | |
var c = /^(\d{4})-?(\d\d)-?(\d\d)(?:T(\d\d)(?::?(\d\d)(?::?(\d\d)(?:\.(\d+))?)?)?(Z|([+-])(\d\d):?(\d\d))?)?$/; | |
return function(c, e) { | |
var g = "", f = [], h, l; | |
e = e || "mediumDate"; | |
e = b.DATETIME_FORMATS[e] || e; | |
D(c) && (c = Md.test(c) ? R(c) : a(c)); | |
qb(c) && (c = new Date(c)); | |
if (!La(c)) | |
return c; | |
for (; e;)(l = Nd.exec(e) | |
) ? (f = f.concat(ua.call(l, 1)), e = f.pop()) : (f.push(e), e = null); | |
q(f, function(a) { | |
h = Od[a]; | |
g += h ? h(c, b.DATETIME_FORMATS) : a.replace(/(^'|'$)/g, "").replace(/''/g, "'") | |
}); | |
return g | |
} | |
} | |
function Id() { | |
return function(b) { | |
return oa(b, !0) | |
} | |
} | |
function Jd() { | |
return function(b, a) { | |
if (!L(b)&&!D(b)) | |
return b; | |
a = R(a); | |
if (D(b)) | |
return a ? 0 <= a ? b.slice(0, a) : b.slice(a, | |
b.length) : ""; | |
var c = [], d, e; | |
a > b.length ? a = b.length : a<-b.length && (a =- b.length); | |
0 < a ? (d = 0, e = a) : (d = b.length + a, e = b.length); | |
for (; d < e; d++) | |
c.push(b[d]); | |
return c | |
} | |
} | |
function Dc(b) { | |
return function(a, c, d) { | |
function e(a, b) { | |
return Oa(b) ? function(b, c) { | |
return a(c, b) | |
} : a | |
} | |
if (!L(a) ||!c) | |
return a; | |
c = L(c) ? c : [c]; | |
c = Pc(c, function(a) { | |
var c=!1, d = a || Ba; | |
if (D(a)) { | |
if ("+" == a.charAt(0) || "-" == a.charAt(0)) | |
c = "-" == a.charAt(0), a = a.substring(1); | |
d = b(a) | |
} | |
return e(function(a, b) { | |
var c; | |
c = d(a); | |
var e = d(b), f = typeof c, g = typeof e; | |
f == g ? ("string" == f && (c = | |
c.toLowerCase(), e = e.toLowerCase()), c = c === e ? 0 : c < e?-1 : 1) : c = f < g?-1 : 1; | |
return c | |
}, c) | |
}); | |
for (var g = [], f = 0; f < a.length; f++) | |
g.push(a[f]); | |
return g.sort(e(function(a, b) { | |
for (var d = 0; d < c.length; d++) { | |
var e = c[d](a, b); | |
if (0 !== e) | |
return e | |
} | |
return 0 | |
}, d)) | |
} | |
} | |
function sa(b) { | |
A(b) && (b = { | |
link: b | |
}); | |
b.restrict = b.restrict || "AC"; | |
return ca(b) | |
} | |
function Gc(b, a) { | |
function c(a, c) { | |
c = c ? "-" + cb(c, "-") : ""; | |
b.removeClass((a ? kb : lb) + c).addClass((a ? lb : kb) + c) | |
} | |
var d = this, e = b.parent().controller("form") || mb, g = 0, f = d.$error = {}, h = []; | |
d.$name = a.name || a.ngForm; | |
d.$dirty=!1; | |
d.$pristine=!0; | |
d.$valid=!0; | |
d.$invalid=!1; | |
e.$addControl(d); | |
b.addClass(Ja); | |
c(!0); | |
d.$addControl = function(a) { | |
wa(a.$name, "input"); | |
h.push(a); | |
a.$name && (d[a.$name] = a) | |
}; | |
d.$removeControl = function(a) { | |
a.$name && d[a.$name] === a && delete d[a.$name]; | |
q(f, function(b, c) { | |
d.$setValidity(c, !0, a) | |
}); | |
Ma(h, a) | |
}; | |
d.$setValidity = function(a, b, h) { | |
var n = f[a]; | |
if (b) | |
n && (Ma(n, h), n.length || (g--, g || (c(b), d.$valid=!0, d.$invalid=!1), f[a]=!1, c(!0, a), e.$setValidity(a, !0, d))); | |
else { | |
g || c(b); | |
if (n) { | |
if ( - 1 != bb(n, h)) | |
return | |
} else | |
f[a] = n = [], | |
g++, c(!1, a), e.$setValidity(a, !1, d); | |
n.push(h); | |
d.$valid=!1; | |
d.$invalid=!0 | |
} | |
}; | |
d.$setDirty = function() { | |
b.removeClass(Ja).addClass(nb); | |
d.$dirty=!0; | |
d.$pristine=!1; | |
e.$setDirty() | |
}; | |
d.$setPristine = function() { | |
b.removeClass(nb).addClass(Ja); | |
d.$dirty=!1; | |
d.$pristine=!0; | |
q(h, function(a) { | |
a.$setPristine() | |
}) | |
} | |
} | |
function ob(b, a, c, d, e, g) { | |
var f=!1; | |
a.on("compositionstart", function() { | |
f=!0 | |
}); | |
a.on("compositionend", function() { | |
f=!1 | |
}); | |
var h = function() { | |
if (!f) { | |
var e = a.val(); | |
Oa(c.ngTrim || "T") && (e = aa(e)); | |
d.$viewValue !== e && b.$apply(function() { | |
d.$setViewValue(e) | |
}) | |
} | |
}; | |
if (e.hasEvent("input")) | |
a.on("input", h); | |
else { | |
var l, k = function() { | |
l || (l = g.defer(function() { | |
h(); | |
l = null | |
})) | |
}; | |
a.on("keydown", function(a) { | |
a = a.keyCode; | |
91 === a || (15 < a && 19 > a || 37 <= a && 40 >= a) || k() | |
}); | |
if (e.hasEvent("paste")) | |
a.on("paste cut", k) | |
} | |
a.on("change", h); | |
d.$render = function() { | |
a.val(d.$isEmpty(d.$viewValue) ? "" : d.$viewValue) | |
}; | |
var m = c.ngPattern, n = function(a, b) { | |
if (d.$isEmpty(b) || a.test(b)) | |
return d.$setValidity("pattern", !0), b; | |
d.$setValidity("pattern", !1); | |
return r | |
}; | |
m && ((e = m.match(/^\/(.*)\/([gim]*)$/)) ? (m = RegExp(e[1], | |
e[2]), e = function(a) { | |
return n(m, a) | |
}) : e = function(c) { | |
var d = b.$eval(m); | |
if (!d ||!d.test) | |
throw G("ngPattern")("noregexp", m, d, ha(a)); | |
return n(d, c) | |
}, d.$formatters.push(e), d.$parsers.push(e)); | |
if (c.ngMinlength) { | |
var p = R(c.ngMinlength); | |
e = function(a) { | |
if (!d.$isEmpty(a) && a.length < p) | |
return d.$setValidity("minlength", !1), r; | |
d.$setValidity("minlength", !0); | |
return a | |
}; | |
d.$parsers.push(e); | |
d.$formatters.push(e) | |
} | |
if (c.ngMaxlength) { | |
var t = R(c.ngMaxlength); | |
e = function(a) { | |
if (!d.$isEmpty(a) && a.length > t) | |
return d.$setValidity("maxlength", | |
!1), r; | |
d.$setValidity("maxlength", !0); | |
return a | |
}; | |
d.$parsers.push(e); | |
d.$formatters.push(e) | |
} | |
} | |
function Mb(b, a) { | |
b = "ngClass" + b; | |
return function() { | |
return { | |
restrict: "AC", | |
link: function(c, d, e) { | |
function g(b) { | |
if (!0 === a || c.$index%2 === a) { | |
var d = f(b || ""); | |
h ? ta(b, h) || e.$updateClass(d, f(h)) : e.$addClass(d) | |
} | |
h = ga(b) | |
} | |
function f(a) { | |
if (L(a)) | |
return a.join(" "); | |
if (U(a)) { | |
var b = []; | |
q(a, function(a, c) { | |
a && b.push(c) | |
}); | |
return b.join(" ") | |
} | |
return a | |
} | |
var h; | |
c.$watch(e[b], g, !0); | |
e.$observe("class", function(a) { | |
g(c.$eval(e[b])) | |
}); | |
"ngClass" !== | |
b && c.$watch("$index", function(d, g) { | |
var h = d & 1; | |
if (h !== g & 1) { | |
var n = f(c.$eval(e[b])); | |
h === a ? e.$addClass(n) : e.$removeClass(n) | |
} | |
}) | |
} | |
} | |
} | |
} | |
var v = function(b) { | |
return D(b) ? b.toLowerCase() : b | |
}, Ia = function(b) { | |
return D(b) ? b.toUpperCase() : b | |
}, E, x, Ca, ua = [].slice, Pd = [].push, $a = Object.prototype.toString, Na = G("ng"), Pa = W.angular || (W.angular = {}), Va, Ga, ja = ["0", "0", "0"]; | |
E = R((/msie (\d+)/.exec(v(navigator.userAgent)) || [])[1]); | |
isNaN(E) && (E = R((/trident\/.*; rv:(\d+)/.exec(v(navigator.userAgent)) || [])[1])); | |
s.$inject = []; | |
Ba.$inject = | |
[]; | |
var aa = function() { | |
return String.prototype.trim ? function(b) { | |
return D(b) ? b.trim() : b | |
} : function(b) { | |
return D(b) ? b.replace(/^\s\s*/, "").replace(/\s\s*$/, "") : b | |
} | |
}(); | |
Ga = 9 > E ? function(b) { | |
b = b.nodeName ? b : b[0]; | |
return b.scopeName && "HTML" != b.scopeName ? Ia(b.scopeName + ":" + b.nodeName) : b.nodeName | |
} : function(b) { | |
return b.nodeName ? b.nodeName : b[0].nodeName | |
}; | |
var Tc = /[A-Z]/g, Qd = { | |
full: "1.2.5", | |
major: 1, | |
minor: 2, | |
dot: 5, | |
codeName: "singularity-expansion" | |
}, Sa = I.cache = {}, db = I.expando = "ng-" + (new Date).getTime(), Xc = 1, Hc = W.document.addEventListener ? | |
function(b, a, c) { | |
b.addEventListener(a, c, !1) | |
} | |
: function(b, a, c) { | |
b.attachEvent("on" + a, c) | |
}, Ab = W.document.removeEventListener ? function(b, a, c) { | |
b.removeEventListener(a, c, !1) | |
} | |
: function(b, a, c) { | |
b.detachEvent("on" + a, c) | |
}, Vc = /([\:\-\_]+(.))/g, Wc = /^moz([A-Z])/, xb = G("jqLite"), Fa = I.prototype = { | |
ready: function(b) { | |
function a() { | |
c || (c=!0, b()) | |
} | |
var c=!1; | |
"complete" === N.readyState ? setTimeout(a) : (this.on("DOMContentLoaded", a), I(W).on("load", a)) | |
}, | |
toString: function() { | |
var b = []; | |
q(this, function(a) { | |
b.push("" + a) | |
}); | |
return "[" + b.join(", ") + | |
"]" | |
}, | |
eq: function(b) { | |
return 0 <= b ? x(this[b]) : x(this[this.length + b]) | |
}, | |
length: 0, | |
push: Pd, | |
sort: [].sort, | |
splice: [].splice | |
}, fb = {}; | |
q("multiple selected checked disabled readOnly required open".split(" "), function(b) { | |
fb[v(b)] = b | |
}); | |
var ec = {}; | |
q("input select option textarea button form details".split(" "), function(b) { | |
ec[Ia(b)]=!0 | |
}); | |
q({ | |
data: ac, | |
inheritedData: eb, | |
scope: function(b) { | |
return x(b).data("$scope") || eb(b.parentNode || b, ["$isolateScope", "$scope"]) | |
}, | |
isolateScope: function(b) { | |
return x(b).data("$isolateScope") || | |
x(b).data("$isolateScopeNoTemplate") | |
}, | |
controller: bc, | |
injector: function(b) { | |
return eb(b, "$injector") | |
}, | |
removeAttr: function(b, a) { | |
b.removeAttribute(a) | |
}, | |
hasClass: Bb, | |
css: function(b, a, c) { | |
a = Ra(a); | |
if (z(c)) | |
b.style[a] = c; | |
else { | |
var d; | |
8 >= E && (d = b.currentStyle && b.currentStyle[a], "" === d && (d = "auto")); | |
d = d || b.style[a]; | |
8 >= E && (d = "" === d ? r : d); | |
return d | |
} | |
}, | |
attr: function(b, a, c) { | |
var d = v(a); | |
if (fb[d]) | |
if (z(c)) | |
c ? (b[a]=!0, b.setAttribute(a, d)) : (b[a]=!1, b.removeAttribute(d)); | |
else | |
return b[a] || (b.attributes.getNamedItem(a) || s).specified ? | |
d : r; | |
else if (z(c)) | |
b.setAttribute(a, c); | |
else if (b.getAttribute) | |
return b = b.getAttribute(a, 2), null === b ? r : b | |
}, | |
prop: function(b, a, c) { | |
if (z(c)) | |
b[a] = c; | |
else | |
return b[a] | |
}, | |
text: function() { | |
function b(b, d) { | |
var e = a[b.nodeType]; | |
if (H(d)) | |
return e ? b[e] : ""; | |
b[e] = d | |
} | |
var a = []; | |
9 > E ? (a[1] = "innerText", a[3] = "nodeValue") : a[1] = a[3] = "textContent"; | |
b.$dv = ""; | |
return b | |
}(), | |
val: function(b, a) { | |
if (H(a)) { | |
if ("SELECT" === Ga(b) && b.multiple) { | |
var c = []; | |
q(b.options, function(a) { | |
a.selected && c.push(a.value || a.text) | |
}); | |
return 0 === c.length ? null : c | |
} | |
return b.value | |
} | |
b.value = | |
a | |
}, | |
html: function(b, a) { | |
if (H(a)) | |
return b.innerHTML; | |
for (var c = 0, d = b.childNodes; c < d.length; c++) | |
Da(d[c]); | |
b.innerHTML = a | |
}, | |
empty: cc | |
}, function(b, a) { | |
I.prototype[a] = function(a, d) { | |
var e, g; | |
if (b !== cc && (2 == b.length && b !== Bb && b !== bc ? a : d) === r) { | |
if (U(a)) { | |
for (e = 0; e < this.length; e++) | |
if (b === ac) | |
b(this[e], a); | |
else | |
for (g in a) | |
b(this[e], g, a[g]); | |
return this | |
} | |
e = b.$dv; | |
g = e === r ? Math.min(this.length, 1) : this.length; | |
for (var f = 0; f < g; f++) { | |
var h = b(this[f], a, d); | |
e = e ? e + h : h | |
} | |
return e | |
} | |
for (e = 0; e < this.length; e++) | |
b(this[e], a, d); | |
return this | |
} | |
}); | |
q({ | |
removeData: Zb, | |
dealoc: Da, | |
on: function a(c, d, e, g) { | |
if (z(g)) | |
throw xb("onargs"); | |
var f = ka(c, "events"), h = ka(c, "handle"); | |
f || ka(c, "events", f = {}); | |
h || ka(c, "handle", h = Yc(c, f)); | |
q(d.split(" "), function(d) { | |
var g = f[d]; | |
if (!g) { | |
if ("mouseenter" == d || "mouseleave" == d) { | |
var m = N.body.contains || N.body.compareDocumentPosition ? function(a, c) { | |
var d = 9 === a.nodeType ? a.documentElement: a, e = c && c.parentNode; | |
return a === e||!!(e && 1 === e.nodeType && (d.contains ? d.contains(e) : a.compareDocumentPosition && a.compareDocumentPosition(e) & 16)) | |
} | |
: function(a, c) { | |
if (c) | |
for (; c = | |
c.parentNode;) | |
if (c === a) | |
return !0; | |
return !1 | |
}; | |
f[d] = []; | |
a(c, { | |
mouseleave: "mouseout", | |
mouseenter: "mouseover" | |
} | |
[d], function(a) { | |
var c = a.relatedTarget; | |
c && (c === this || m(this, c)) || h(a, d) | |
}) | |
} else | |
Hc(c, d, h), f[d] = []; | |
g = f[d] | |
} | |
g.push(e) | |
}) | |
}, | |
off: $b, | |
replaceWith: function(a, c) { | |
var d, e = a.parentNode; | |
Da(a); | |
q(new I(c), function(c) { | |
d ? e.insertBefore(c, d.nextSibling) : e.replaceChild(c, a); | |
d = c | |
}) | |
}, | |
children: function(a) { | |
var c = []; | |
q(a.childNodes, function(a) { | |
1 === a.nodeType && c.push(a) | |
}); | |
return c | |
}, | |
contents: function(a) { | |
return a.childNodes || [] | |
}, | |
append: function(a, c) { | |
q(new I(c), function(c) { | |
1 !== a.nodeType && 11 !== a.nodeType || a.appendChild(c) | |
}) | |
}, | |
prepend: function(a, c) { | |
if (1 === a.nodeType) { | |
var d = a.firstChild; | |
q(new I(c), function(c) { | |
a.insertBefore(c, d) | |
}) | |
} | |
}, | |
wrap: function(a, c) { | |
c = x(c)[0]; | |
var d = a.parentNode; | |
d && d.replaceChild(c, a); | |
c.appendChild(a) | |
}, | |
remove: function(a) { | |
Da(a); | |
var c = a.parentNode; | |
c && c.removeChild(a) | |
}, | |
after: function(a, c) { | |
var d = a, e = a.parentNode; | |
q(new I(c), function(a) { | |
e.insertBefore(a, d.nextSibling); | |
d = a | |
}) | |
}, | |
addClass: Db, | |
removeClass: Cb, | |
toggleClass: function(a, | |
c, d) { | |
H(d) && (d=!Bb(a, c)); | |
(d ? Db : Cb)(a, c) | |
}, | |
parent: function(a) { | |
return (a = a.parentNode) && 11 !== a.nodeType ? a : null | |
}, | |
next: function(a) { | |
if (a.nextElementSibling) | |
return a.nextElementSibling; | |
for (a = a.nextSibling; null != a && 1 !== a.nodeType;) | |
a = a.nextSibling; | |
return a | |
}, | |
find: function(a, c) { | |
return a.getElementsByTagName ? a.getElementsByTagName(c) : [] | |
}, | |
clone: zb, | |
triggerHandler: function(a, c, d) { | |
c = (ka(a, "events") || {})[c]; | |
d = d || []; | |
var e = [{ | |
preventDefault: s, | |
stopPropagation: s | |
} | |
]; | |
q(c, function(c) { | |
c.apply(a, e.concat(d)) | |
}) | |
} | |
}, function(a, c) { | |
I.prototype[c] = | |
function(c, e, g) { | |
for (var f, h = 0; h < this.length; h++) | |
H(f) ? (f = a(this[h], c, e, g), z(f) && (f = x(f))) : yb(f, a(this[h], c, e, g)); | |
return z(f) ? f : this | |
}; | |
I.prototype.bind = I.prototype.on; | |
I.prototype.unbind = I.prototype.off | |
}); | |
Ta.prototype = { | |
put: function(a, c) { | |
this[Ea(a)] = c | |
}, | |
get: function(a) { | |
return this[Ea(a)] | |
}, | |
remove: function(a) { | |
var c = this[a = Ea(a)]; | |
delete this[a]; | |
return c | |
} | |
}; | |
var $c = /^function\s*[^\(]*\(\s*([^\)]*)\)/m, ad = /,/, bd = /^\s*(_?)(\S+?)\1\s*$/, Zc = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg, Ua = G("$injector"), Rd = G("$animate"), Sd = | |
["$provide", function(a) { | |
this.$$selectors = {}; | |
this.register = function(c, d) { | |
var e = c + "-animation"; | |
if (c && "." != c.charAt(0)) | |
throw Rd("notcsel", c); | |
this.$$selectors[c.substr(1)] = e; | |
a.factory(e, d) | |
}; | |
this.$get = ["$timeout", function(a) { | |
return { | |
enter: function(d, e, g, f) { | |
g ? g.after(d) : (e && e[0] || (e = g.parent()), e.append(d)); | |
f && a(f, 0, !1) | |
}, | |
leave: function(d, e) { | |
d.remove(); | |
e && a(e, 0, !1) | |
}, | |
move: function(a, c, g, f) { | |
this.enter(a, c, g, f) | |
}, | |
addClass: function(d, e, g) { | |
e = D(e) ? e : L(e) ? e.join(" ") : ""; | |
q(d, function(a) { | |
Db(a, e) | |
}); | |
g && a(g, 0, !1) | |
}, | |
removeClass: function(d, | |
e, g) { | |
e = D(e) ? e : L(e) ? e.join(" ") : ""; | |
q(d, function(a) { | |
Cb(a, e) | |
}); | |
g && a(g, 0, !1) | |
}, | |
enabled: s | |
} | |
} | |
] | |
} | |
], ia = G("$compile"); | |
hc.$inject = ["$provide", "$$sanitizeUriProvider"]; | |
var id = /^(x[\:\-_]|data[\:\-_])/i, pd = W.XMLHttpRequest || function() { | |
try { | |
return new ActiveXObject("Msxml2.XMLHTTP.6.0") | |
} catch (a) {} | |
try { | |
return new ActiveXObject("Msxml2.XMLHTTP.3.0") | |
} catch (c) {} | |
try { | |
return new ActiveXObject("Msxml2.XMLHTTP") | |
} catch (d) {} | |
throw G("$httpBackend")("noxhr"); | |
}, nc = G("$interpolate"), Td = /^([^\?#]*)(\?([^#]*))?(#(.*))?$/, td = { | |
http: 80, | |
https: 443, | |
ftp: 21 | |
}, Hb = G("$location"); | |
sc.prototype = Ib.prototype = rc.prototype = { | |
$$html5: !1, | |
$$replace: !1, | |
absUrl: hb("$$absUrl"), | |
url: function(a, c) { | |
if (H(a)) | |
return this.$$url; | |
var d = Td.exec(a); | |
d[1] && this.path(decodeURIComponent(d[1])); | |
(d[2] || d[1]) && this.search(d[3] || ""); | |
this.hash(d[5] || "", c); | |
return this | |
}, | |
protocol: hb("$$protocol"), | |
host: hb("$$host"), | |
port: hb("$$port"), | |
path: tc("$$path", function(a) { | |
return "/" == a.charAt(0) ? a : "/" + a | |
}), | |
search: function(a, c) { | |
switch (arguments.length) { | |
case 0: | |
return this.$$search; | |
case 1: | |
if (D(a)) | |
this.$$search = | |
Vb(a); | |
else if (U(a)) | |
this.$$search = a; | |
else | |
throw Hb("isrcharg"); | |
break; | |
default: | |
H(c) || null === c ? delete this.$$search[a] : this.$$search[a] = c | |
} | |
this.$$compose(); | |
return this | |
}, | |
hash: tc("$$hash", Ba), | |
replace: function() { | |
this.$$replace=!0; | |
return this | |
} | |
}; | |
var za = G("$parse"), wc = {}, qa, Ka = { | |
"null": function() { | |
return null | |
}, | |
"true": function() { | |
return !0 | |
}, | |
"false": function() { | |
return !1 | |
}, | |
undefined: s, | |
"+": function(a, c, d, e) { | |
d = d(a, c); | |
e = e(a, c); | |
return z(d) ? z(e) ? d + e : d : z(e) ? e : r | |
}, | |
"-": function(a, c, d, e) { | |
d = d(a, c); | |
e = e(a, c); | |
return (z(d) ? d : 0) - (z(e) ? | |
e : 0) | |
}, | |
"*": function(a, c, d, e) { | |
return d(a, c) * e(a, c) | |
}, | |
"/": function(a, c, d, e) { | |
return d(a, c) / e(a, c) | |
}, | |
"%": function(a, c, d, e) { | |
return d(a, c)%e(a, c) | |
}, | |
"^": function(a, c, d, e) { | |
return d(a, c)^e(a, c) | |
}, | |
"=": s, | |
"===": function(a, c, d, e) { | |
return d(a, c) === e(a, c) | |
}, | |
"!==": function(a, c, d, e) { | |
return d(a, c) !== e(a, c) | |
}, | |
"==": function(a, c, d, e) { | |
return d(a, c) == e(a, c) | |
}, | |
"!=": function(a, c, d, e) { | |
return d(a, c) != e(a, c) | |
}, | |
"<": function(a, c, d, e) { | |
return d(a, c) < e(a, c) | |
}, | |
">": function(a, c, d, e) { | |
return d(a, c) > e(a, c) | |
}, | |
"<=": function(a, c, d, e) { | |
return d(a, c) <= | |
e(a, c) | |
}, | |
">=": function(a, c, d, e) { | |
return d(a, c) >= e(a, c) | |
}, | |
"&&": function(a, c, d, e) { | |
return d(a, c) && e(a, c) | |
}, | |
"||": function(a, c, d, e) { | |
return d(a, c) || e(a, c) | |
}, | |
"&": function(a, c, d, e) { | |
return d(a, c) & e(a, c) | |
}, | |
"|": function(a, c, d, e) { | |
return e(a, c)(a, c, d(a, c)) | |
}, | |
"!": function(a, c, d) { | |
return !d(a, c) | |
} | |
}, Ud = { | |
n: "\n", | |
f: "\f", | |
r: "\r", | |
t: "\t", | |
v: "\v", | |
"'": "'", | |
'"': '"' | |
}, Kb = function(a) { | |
this.options = a | |
}; | |
Kb.prototype = { | |
constructor: Kb, | |
lex: function(a) { | |
this.text = a; | |
this.index = 0; | |
this.ch = r; | |
this.lastCh = ":"; | |
this.tokens = []; | |
var c; | |
for (a = []; this.index < this.text.length;) { | |
this.ch = | |
this.text.charAt(this.index); | |
if (this.is("\"'")) | |
this.readString(this.ch); | |
else if (this.isNumber(this.ch) || this.is(".") && this.isNumber(this.peek())) | |
this.readNumber(); | |
else if (this.isIdent(this.ch)) | |
this.readIdent(), this.was("{,") && ("{" === a[0] && (c = this.tokens[this.tokens.length - 1])) && (c.json =- 1 === c.text.indexOf(".")); | |
else if (this.is("(){}[].,;:?")) | |
this.tokens.push({ | |
index: this.index, | |
text: this.ch, | |
json: this.was(":[,") && this.is("{[") || this.is("}]:,") | |
}), this.is("{[") && a.unshift(this.ch), this.is("}]") && a.shift(), | |
this.index++; | |
else if (this.isWhitespace(this.ch)) { | |
this.index++; | |
continue | |
} else { | |
var d = this.ch + this.peek(), e = d + this.peek(2), g = Ka[this.ch], f = Ka[d], h = Ka[e]; | |
h ? (this.tokens.push({ | |
index: this.index, | |
text: e, | |
fn: h | |
}), this.index += 3) : f ? (this.tokens.push({ | |
index: this.index, | |
text: d, | |
fn: f | |
}), this.index += 2) : g ? (this.tokens.push({ | |
index: this.index, | |
text: this.ch, | |
fn: g, | |
json: this.was("[,:") && this.is("+-") | |
}), this.index += 1) : this.throwError("Unexpected next character ", this.index, this.index + 1) | |
} | |
this.lastCh = this.ch | |
} | |
return this.tokens | |
}, | |
is: function(a) { | |
return - 1 !== a.indexOf(this.ch) | |
}, | |
was: function(a) { | |
return - 1 !== a.indexOf(this.lastCh) | |
}, | |
peek: function(a) { | |
a = a || 1; | |
return this.index + a < this.text.length ? this.text.charAt(this.index + a) : !1 | |
}, | |
isNumber: function(a) { | |
return "0" <= a && "9" >= a | |
}, | |
isWhitespace: function(a) { | |
return " " === a || "\r" === a || "\t" === a || "\n" === a || "\v" === a || "\u00a0" === a | |
}, | |
isIdent: function(a) { | |
return "a" <= a && "z" >= a || "A" <= a && "Z" >= a || "_" === a || "$" === a | |
}, | |
isExpOperator: function(a) { | |
return "-" === a || "+" === a || this.isNumber(a) | |
}, | |
throwError: function(a, c, d) { | |
d = | |
d || this.index; | |
c = z(c) ? "s " + c + "-" + this.index + " [" + this.text.substring(c, d) + "]" : " " + d; | |
throw za("lexerr", a, c, this.text); | |
}, | |
readNumber: function() { | |
for (var a = "", c = this.index; this.index < this.text.length;) { | |
var d = v(this.text.charAt(this.index)); | |
if ("." == d || this.isNumber(d)) | |
a += d; | |
else { | |
var e = this.peek(); | |
if ("e" == d && this.isExpOperator(e)) | |
a += d; | |
else if (this.isExpOperator(d) && e && this.isNumber(e) && "e" == a.charAt(a.length - 1)) | |
a += d; | |
else if (!this.isExpOperator(d) || e && this.isNumber(e) || "e" != a.charAt(a.length - 1)) | |
break; | |
else | |
this.throwError("Invalid exponent") | |
} | |
this.index++ | |
} | |
a*= | |
1; | |
this.tokens.push({ | |
index: c, | |
text: a, | |
json: !0, | |
fn: function() { | |
return a | |
} | |
}) | |
}, | |
readIdent: function() { | |
for (var a = this, c = "", d = this.index, e, g, f, h; this.index < this.text.length;) { | |
h = this.text.charAt(this.index); | |
if ("." === h || this.isIdent(h) || this.isNumber(h)) | |
"." === h && (e = this.index), c += h; | |
else | |
break; | |
this.index++ | |
} | |
if (e) | |
for (g = this.index; g < this.text.length;) { | |
h = this.text.charAt(g); | |
if ("(" === h) { | |
f = c.substr(e - d + 1); | |
c = c.substr(0, e - d); | |
this.index = g; | |
break | |
} | |
if (this.isWhitespace(h)) | |
g++; | |
else | |
break | |
} | |
d = { | |
index: d, | |
text: c | |
}; | |
if (Ka.hasOwnProperty(c)) | |
d.fn = | |
Ka[c], d.json = Ka[c]; | |
else { | |
var l = vc(c, this.options, this.text); | |
d.fn = w(function(a, c) { | |
return l(a, c) | |
}, { | |
assign: function(d, e) { | |
return ib(d, c, e, a.text, a.options) | |
} | |
}) | |
} | |
this.tokens.push(d); | |
f && (this.tokens.push({ | |
index: e, | |
text: ".", | |
json: !1 | |
}), this.tokens.push({ | |
index: e + 1, | |
text: f, | |
json: !1 | |
})) | |
}, | |
readString: function(a) { | |
var c = this.index; | |
this.index++; | |
for (var d = "", e = a, g=!1; this.index < this.text.length;) { | |
var f = this.text.charAt(this.index), e = e + f; | |
if (g) | |
"u" === f ? (f = this.text.substring(this.index + 1, this.index + 5), f.match(/[\da-f]{4}/i) || | |
this.throwError("Invalid unicode escape [\\u" + f + "]"), this.index += 4, d += String.fromCharCode(parseInt(f, 16))) : d = (g = Ud[f]) ? d + g : d + f, g=!1; | |
else if ("\\" === f) | |
g=!0; | |
else { | |
if (f === a) { | |
this.index++; | |
this.tokens.push({ | |
index: c, | |
text: e, | |
string: d, | |
json: !0, | |
fn: function() { | |
return d | |
} | |
}); | |
return | |
} | |
d += f | |
} | |
this.index++ | |
} | |
this.throwError("Unterminated quote", c) | |
} | |
}; | |
var Ya = function(a, c, d) { | |
this.lexer = a; | |
this.$filter = c; | |
this.options = d | |
}; | |
Ya.ZERO = function() { | |
return 0 | |
}; | |
Ya.prototype = { | |
constructor: Ya, | |
parse: function(a, c) { | |
this.text = a; | |
this.json = c; | |
this.tokens = | |
this.lexer.lex(a); | |
c && (this.assignment = this.logicalOR, this.functionCall = this.fieldAccess = this.objectIndex = this.filterChain = function() { | |
this.throwError("is not valid json", { | |
text: a, | |
index: 0 | |
}) | |
}); | |
var d = c ? this.primary(): this.statements(); | |
0 !== this.tokens.length && this.throwError("is an unexpected token", this.tokens[0]); | |
d.literal=!!d.literal; | |
d.constant=!!d.constant; | |
return d | |
}, | |
primary: function() { | |
var a; | |
if (this.expect("(")) | |
a = this.filterChain(), this.consume(")"); | |
else if (this.expect("[")) | |
a = this.arrayDeclaration(); | |
else if (this.expect("{")) | |
a = this.object(); | |
else { | |
var c = this.expect(); | |
(a = c.fn) || this.throwError("not a primary expression", c); | |
c.json && (a.constant=!0, a.literal=!0) | |
} | |
for (var d; c = this.expect("(", "[", ".");) | |
"(" === c.text ? (a = this.functionCall(a, d), d = null) : "[" === c.text ? (d = a, a = this.objectIndex(a)) : "." === c.text ? (d = a, a = this.fieldAccess(a)) : this.throwError("IMPOSSIBLE"); | |
return a | |
}, | |
throwError: function(a, c) { | |
throw za("syntax", c.text, a, c.index + 1, this.text, this.text.substring(c.index)); | |
}, | |
peekToken: function() { | |
if (0 === this.tokens.length) | |
throw za("ueoe", | |
this.text); | |
return this.tokens[0] | |
}, | |
peek: function(a, c, d, e) { | |
if (0 < this.tokens.length) { | |
var g = this.tokens[0], f = g.text; | |
if (f === a || f === c || f === d || f === e ||!(a || c || d || e)) | |
return g | |
} | |
return !1 | |
}, | |
expect: function(a, c, d, e) { | |
return (a = this.peek(a, c, d, e)) ? (this.json&&!a.json && this.throwError("is not valid json", a), this.tokens.shift(), a) : !1 | |
}, | |
consume: function(a) { | |
this.expect(a) || this.throwError("is unexpected, expecting [" + a + "]", this.peek()) | |
}, | |
unaryFn: function(a, c) { | |
return w(function(d, e) { | |
return a(d, e, c) | |
}, { | |
constant: c.constant | |
}) | |
}, | |
ternaryFn: function(a, c, d) { | |
return w(function(e, g) { | |
return a(e, g) ? c(e, g) : d(e, g) | |
}, { | |
constant: a.constant && c.constant && d.constant | |
}) | |
}, | |
binaryFn: function(a, c, d) { | |
return w(function(e, g) { | |
return c(e, g, a, d) | |
}, { | |
constant: a.constant && d.constant | |
}) | |
}, | |
statements: function() { | |
for (var a = []; ;) | |
if (0 < this.tokens.length&&!this.peek("}", ")", ";", "]") && a.push(this.filterChain()), !this.expect(";")) | |
return 1 === a.length ? a[0] : function(c, d) { | |
for (var e, g = 0; g < a.length; g++) { | |
var f = a[g]; | |
f && (e = f(c, d)) | |
} | |
return e | |
} | |
}, | |
filterChain: function() { | |
for (var a = | |
this.expression(), c; ;) | |
if (c = this.expect("|")) | |
a = this.binaryFn(a, c.fn, this.filter()); | |
else | |
return a | |
}, | |
filter: function() { | |
for (var a = this.expect(), c = this.$filter(a.text), d = []; ;) | |
if (a = this.expect(":")) | |
d.push(this.expression()); | |
else { | |
var e = function(a, e, h) { | |
h = [h]; | |
for (var l = 0; l < d.length; l++) | |
h.push(d[l](a, e)); | |
return c.apply(a, h) | |
}; | |
return function() { | |
return e | |
} | |
} | |
}, | |
expression: function() { | |
return this.assignment() | |
}, | |
assignment: function() { | |
var a = this.ternary(), c, d; | |
return (d = this.expect("=")) ? (a.assign || this.throwError("implies assignment but [" + | |
this.text.substring(0, d.index) + "] can not be assigned to", d), c = this.ternary(), function(d, g) { | |
return a.assign(d, c(d, g), g) | |
}) : a | |
}, | |
ternary: function() { | |
var a = this.logicalOR(), c, d; | |
if (this.expect("?")) { | |
c = this.ternary(); | |
if (d = this.expect(":")) | |
return this.ternaryFn(a, c, this.ternary()); | |
this.throwError("expected :", d) | |
} else | |
return a | |
}, | |
logicalOR: function() { | |
for (var a = this.logicalAND(), c; ;) | |
if (c = this.expect("||")) | |
a = this.binaryFn(a, c.fn, this.logicalAND()); | |
else | |
return a | |
}, | |
logicalAND: function() { | |
var a = this.equality(), c; | |
if (c = | |
this.expect("&&")) | |
a = this.binaryFn(a, c.fn, this.logicalAND()); | |
return a | |
}, | |
equality: function() { | |
var a = this.relational(), c; | |
if (c = this.expect("==", "!=", "===", "!==")) | |
a = this.binaryFn(a, c.fn, this.equality()); | |
return a | |
}, | |
relational: function() { | |
var a = this.additive(), c; | |
if (c = this.expect("<", ">", "<=", ">=")) | |
a = this.binaryFn(a, c.fn, this.relational()); | |
return a | |
}, | |
additive: function() { | |
for (var a = this.multiplicative(), c; c = this.expect("+", "-");) | |
a = this.binaryFn(a, c.fn, this.multiplicative()); | |
return a | |
}, | |
multiplicative: function() { | |
for (var a = | |
this.unary(), c; c = this.expect("*", "/", "%");) | |
a = this.binaryFn(a, c.fn, this.unary()); | |
return a | |
}, | |
unary: function() { | |
var a; | |
return this.expect("+") ? this.primary() : (a = this.expect("-")) ? this.binaryFn(Ya.ZERO, a.fn, this.unary()) : (a = this.expect("!")) ? this.unaryFn(a.fn, this.unary()) : this.primary() | |
}, | |
fieldAccess: function(a) { | |
var c = this, d = this.expect().text, e = vc(d, this.options, this.text); | |
return w(function(c, d, h) { | |
return e(h || a(c, d), d) | |
}, { | |
assign: function(e, f, h) { | |
return ib(a(e, h), d, f, c.text, c.options) | |
} | |
}) | |
}, | |
objectIndex: function(a) { | |
var c = | |
this, d = this.expression(); | |
this.consume("]"); | |
return w(function(e, g) { | |
var f = a(e, g), h = d(e, g), l; | |
if (!f) | |
return r; | |
(f = Xa(f[h], c.text)) && (f.then && c.options.unwrapPromises) && (l = f, "$$v"in f || (l.$$v = r, l.then(function(a) { | |
l.$$v = a | |
})), f = f.$$v); | |
return f | |
}, { | |
assign: function(e, g, f) { | |
var h = d(e, f); | |
return Xa(a(e, f), c.text)[h] = g | |
} | |
}) | |
}, | |
functionCall: function(a, c) { | |
var d = []; | |
if (")" !== this.peekToken().text) { | |
do | |
d.push(this.expression()); | |
while (this.expect(",")) | |
} | |
this.consume(")"); | |
var e = this; | |
return function(g, f) { | |
for (var h = [], l = c ? c(g, f) : | |
g, k = 0; k < d.length; k++) | |
h.push(d[k](g, f)); | |
k = a(g, f, l) || s; | |
Xa(l, e.text); | |
Xa(k, e.text); | |
h = k.apply ? k.apply(l, h) : k(h[0], h[1], h[2], h[3], h[4]); | |
return Xa(h, e.text) | |
} | |
}, arrayDeclaration: function() { | |
var a = [], c=!0; | |
if ("]" !== this.peekToken().text) { | |
do { | |
var d = this.expression(); | |
a.push(d); | |
d.constant || (c=!1) | |
} | |
while (this.expect(",")) | |
} | |
this.consume("]"); | |
return w(function(c, d) { | |
for (var f = [], h = 0; h < a.length; h++) | |
f.push(a[h](c, d)); | |
return f | |
}, { | |
literal: !0, | |
constant: c | |
}) | |
}, object: function() { | |
var a = [], c=!0; | |
if ("}" !== this.peekToken().text) { | |
do { | |
var d = | |
this.expect(), d = d.string || d.text; | |
this.consume(":"); | |
var e = this.expression(); | |
a.push({ | |
key: d, | |
value: e | |
}); | |
e.constant || (c=!1) | |
} | |
while (this.expect(",")) | |
} | |
this.consume("}"); | |
return w(function(c, d) { | |
for (var e = {}, l = 0; l < a.length; l++) { | |
var k = a[l]; | |
e[k.key] = k.value(c, d) | |
} | |
return e | |
}, { | |
literal: !0, | |
constant: c | |
}) | |
} | |
}; | |
var Jb = {}, ra = G("$sce"), fa = { | |
HTML: "html", | |
CSS: "css", | |
URL: "url", | |
RESOURCE_URL: "resourceUrl", | |
JS: "js" | |
}, T = N.createElement("a"), yc = ya(W.location.href, !0); | |
zc.$inject = ["$provide"]; | |
Ac.$inject = ["$locale"]; | |
Cc.$inject = ["$locale"]; | |
var Fc = | |
".", Od = { | |
yyyy: V("FullYear", 4), | |
yy: V("FullYear", 2, 0, !0), | |
y: V("FullYear", 1), | |
MMMM: jb("Month"), | |
MMM: jb("Month", !0), | |
MM: V("Month", 2, 1), | |
M: V("Month", 1, 1), | |
dd: V("Date", 2), | |
d: V("Date", 1), | |
HH: V("Hours", 2), | |
H: V("Hours", 1), | |
hh: V("Hours", 2, - 12), | |
h: V("Hours", 1, - 12), | |
mm: V("Minutes", 2), | |
m: V("Minutes", 1), | |
ss: V("Seconds", 2), | |
s: V("Seconds", 1), | |
sss: V("Milliseconds", 3), | |
EEEE: jb("Day"), | |
EEE: jb("Day", !0), | |
a: function(a, c) { | |
return 12 > a.getHours() ? c.AMPMS[0] : c.AMPMS[1] | |
}, | |
Z: function(a) { | |
a =- 1 * a.getTimezoneOffset(); | |
return a = (0 <= a ? "+" : "") + (Lb(Math[0 < | |
a ? "floor": "ceil"](a / 60), 2) + Lb(Math.abs(a%60), 2)) | |
} | |
}, Nd = /((?:[^yMdHhmsaZE']+)|(?:'(?:[^']|'')*')|(?:E+|y+|M+|d+|H+|h+|m+|s+|a|Z))(.*)/, Md = /^\-?\d+$/; | |
Bc.$inject = ["$locale"]; | |
var Kd = ca(v), Ld = ca(Ia); | |
Dc.$inject = ["$parse"]; | |
var Vd = ca({ | |
restrict: "E", | |
compile: function(a, c) { | |
8 >= E && (c.href || c.name || c.$set("href", ""), a.append(N.createComment("IE fix"))); | |
if (!c.href&&!c.name) | |
return function(a, c) { | |
c.on("click", function(a) { | |
c.attr("href") || a.preventDefault() | |
}) | |
} | |
} | |
}), Nb = {}; | |
q(fb, function(a, c) { | |
if ("multiple" != a) { | |
var d = ma("ng-" + | |
c); | |
Nb[d] = function() { | |
return { | |
priority: 100, | |
compile: function() { | |
return function(a, g, f) { | |
a.$watch(f[d], function(a) { | |
f.$set(c, !!a) | |
}) | |
} | |
} | |
} | |
} | |
} | |
}); | |
q(["src", "srcset", "href"], function(a) { | |
var c = ma("ng-" + a); | |
Nb[c] = function() { | |
return { | |
priority: 99, | |
link: function(d, e, g) { | |
g.$observe(c, function(c) { | |
c && (g.$set(a, c), E && e.prop(a, g[a])) | |
}) | |
} | |
} | |
} | |
}); | |
var mb = { | |
$addControl: s, | |
$removeControl: s, | |
$setValidity: s, | |
$setDirty: s, | |
$setPristine: s | |
}; | |
Gc.$inject = ["$element", "$attrs", "$scope"]; | |
var Ic = function(a) { | |
return ["$timeout", function(c) { | |
return { | |
name: "form", | |
restrict: a ? "EAC": "E", | |
controller: Gc, | |
compile: function() { | |
return { | |
pre: function(a, e, g, f) { | |
if (!g.action) { | |
var h = function(a) { | |
a.preventDefault ? a.preventDefault() : a.returnValue=!1 | |
}; | |
Hc(e[0], "submit", h); | |
e.on("$destroy", function() { | |
c(function() { | |
Ab(e[0], "submit", h) | |
}, 0, !1) | |
}) | |
} | |
var l = e.parent().controller("form"), k = g.name || g.ngForm; | |
k && ib(a, k, f, k); | |
if (l) | |
e.on("$destroy", function() { | |
l.$removeControl(f); | |
k && ib(a, k, r, k); | |
w(f, mb) | |
}) | |
} | |
} | |
} | |
} | |
} | |
] | |
}, Wd = Ic(), Xd = Ic(!0), Yd = /^(ftp|http|https):\/\/(\w+:{0,1}\w*@)?(\S+)(:[0-9]+)?(\/|\/([\w#!:.?+=&%@!\-\/]))?$/, | |
Zd = /^[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,6}$/, $d = /^\s*(\-|\+)?(\d+|(\d*(\.\d*)))\s*$/, Jc = { | |
text: ob, | |
number: function(a, c, d, e, g, f) { | |
ob(a, c, d, e, g, f); | |
e.$parsers.push(function(a) { | |
var c = e.$isEmpty(a); | |
if (c || $d.test(a)) | |
return e.$setValidity("number", !0), "" === a ? null : c ? a : parseFloat(a); | |
e.$setValidity("number", !1); | |
return r | |
}); | |
e.$formatters.push(function(a) { | |
return e.$isEmpty(a) ? "" : "" + a | |
}); | |
d.min && (a = function(a) { | |
var c = parseFloat(d.min); | |
if (!e.$isEmpty(a) && a < c) | |
return e.$setValidity("min", !1), r; | |
e.$setValidity("min", | |
!0); | |
return a | |
}, e.$parsers.push(a), e.$formatters.push(a)); | |
d.max && (a = function(a) { | |
var c = parseFloat(d.max); | |
if (!e.$isEmpty(a) && a > c) | |
return e.$setValidity("max", !1), r; | |
e.$setValidity("max", !0); | |
return a | |
}, e.$parsers.push(a), e.$formatters.push(a)); | |
e.$formatters.push(function(a) { | |
if (e.$isEmpty(a) || qb(a)) | |
return e.$setValidity("number", !0), a; | |
e.$setValidity("number", !1); | |
return r | |
}) | |
}, | |
url: function(a, c, d, e, g, f) { | |
ob(a, c, d, e, g, f); | |
a = function(a) { | |
if (e.$isEmpty(a) || Yd.test(a)) | |
return e.$setValidity("url", !0), a; | |
e.$setValidity("url", | |
!1); | |
return r | |
}; | |
e.$formatters.push(a); | |
e.$parsers.push(a) | |
}, | |
email: function(a, c, d, e, g, f) { | |
ob(a, c, d, e, g, f); | |
a = function(a) { | |
if (e.$isEmpty(a) || Zd.test(a)) | |
return e.$setValidity("email", !0), a; | |
e.$setValidity("email", !1); | |
return r | |
}; | |
e.$formatters.push(a); | |
e.$parsers.push(a) | |
}, | |
radio: function(a, c, d, e) { | |
H(d.name) && c.attr("name", Za()); | |
c.on("click", function() { | |
c[0].checked && a.$apply(function() { | |
e.$setViewValue(d.value) | |
}) | |
}); | |
e.$render = function() { | |
c[0].checked = d.value == e.$viewValue | |
}; | |
d.$observe("value", e.$render) | |
}, | |
checkbox: function(a, | |
c, d, e) { | |
var g = d.ngTrueValue, f = d.ngFalseValue; | |
D(g) || (g=!0); | |
D(f) || (f=!1); | |
c.on("click", function() { | |
a.$apply(function() { | |
e.$setViewValue(c[0].checked) | |
}) | |
}); | |
e.$render = function() { | |
c[0].checked = e.$viewValue | |
}; | |
e.$isEmpty = function(a) { | |
return a !== g | |
}; | |
e.$formatters.push(function(a) { | |
return a === g | |
}); | |
e.$parsers.push(function(a) { | |
return a ? g : f | |
}) | |
}, | |
hidden: s, | |
button: s, | |
submit: s, | |
reset: s | |
}, Kc = ["$browser", "$sniffer", function(a, c) { | |
return { | |
restrict: "E", | |
require: "?ngModel", | |
link: function(d, e, g, f) { | |
f && (Jc[v(g.type)] || Jc.text)(d, e, g, f, c, a) | |
} | |
} | |
} | |
], | |
lb = "ng-valid", kb = "ng-invalid", Ja = "ng-pristine", nb = "ng-dirty", ae = ["$scope", "$exceptionHandler", "$attrs", "$element", "$parse", function(a, c, d, e, g) { | |
function f(a, c) { | |
c = c ? "-" + cb(c, "-") : ""; | |
e.removeClass((a ? kb : lb) + c).addClass((a ? lb : kb) + c) | |
} | |
this.$modelValue = this.$viewValue = Number.NaN; | |
this.$parsers = []; | |
this.$formatters = []; | |
this.$viewChangeListeners = []; | |
this.$pristine=!0; | |
this.$dirty=!1; | |
this.$valid=!0; | |
this.$invalid=!1; | |
this.$name = d.name; | |
var h = g(d.ngModel), l = h.assign; | |
if (!l) | |
throw G("ngModel")("nonassign", d.ngModel, ha(e)); | |
this.$render = s; | |
this.$isEmpty = function(a) { | |
return H(a) || "" === a || null === a || a !== a | |
}; | |
var k = e.inheritedData("$formController") || mb, m = 0, n = this.$error = {}; | |
e.addClass(Ja); | |
f(!0); | |
this.$setValidity = function(a, c) { | |
n[a]!==!c && (c ? (n[a] && m--, m || (f(!0), this.$valid=!0, this.$invalid=!1)) : (f(!1), this.$invalid=!0, this.$valid=!1, m++), n[a]=!c, f(c, a), k.$setValidity(a, c, this)) | |
}; | |
this.$setPristine = function() { | |
this.$dirty=!1; | |
this.$pristine=!0; | |
e.removeClass(nb).addClass(Ja) | |
}; | |
this.$setViewValue = function(d) { | |
this.$viewValue = d; | |
this.$pristine && | |
(this.$dirty=!0, this.$pristine=!1, e.removeClass(Ja).addClass(nb), k.$setDirty()); | |
q(this.$parsers, function(a) { | |
d = a(d) | |
}); | |
this.$modelValue !== d && (this.$modelValue = d, l(a, d), q(this.$viewChangeListeners, function(a) { | |
try { | |
a() | |
} catch (d) { | |
c(d) | |
} | |
})) | |
}; | |
var p = this; | |
a.$watch(function() { | |
var c = h(a); | |
if (p.$modelValue !== c) { | |
var d = p.$formatters, e = d.length; | |
for (p.$modelValue = c; e--;) | |
c = d[e](c); | |
p.$viewValue !== c && (p.$viewValue = c, p.$render()) | |
} | |
return c | |
}) | |
} | |
], be = function() { | |
return { | |
require: ["ngModel", "^?form"], | |
controller: ae, | |
link: function(a, | |
c, d, e) { | |
var g = e[0], f = e[1] || mb; | |
f.$addControl(g); | |
a.$on("$destroy", function() { | |
f.$removeControl(g) | |
}) | |
} | |
} | |
}, ce = ca({ | |
require: "ngModel", | |
link: function(a, c, d, e) { | |
e.$viewChangeListeners.push(function() { | |
a.$eval(d.ngChange) | |
}) | |
} | |
}), Lc = function() { | |
return { | |
require: "?ngModel", | |
link: function(a, c, d, e) { | |
if (e) { | |
d.required=!0; | |
var g = function(a) { | |
if (d.required && e.$isEmpty(a)) | |
e.$setValidity("required", !1); | |
else | |
return e.$setValidity("required", !0), a | |
}; | |
e.$formatters.push(g); | |
e.$parsers.unshift(g); | |
d.$observe("required", function() { | |
g(e.$viewValue) | |
}) | |
} | |
} | |
} | |
}, | |
de = function() { | |
return { | |
require: "ngModel", | |
link: function(a, c, d, e) { | |
var g = (a = /\/(.*)\//.exec(d.ngList)) && RegExp(a[1]) || d.ngList || ","; | |
e.$parsers.push(function(a) { | |
if (!H(a)) { | |
var c = []; | |
a && q(a.split(g), function(a) { | |
a && c.push(aa(a)) | |
}); | |
return c | |
} | |
}); | |
e.$formatters.push(function(a) { | |
return L(a) ? a.join(", ") : r | |
}); | |
e.$isEmpty = function(a) { | |
return !a ||!a.length | |
} | |
} | |
} | |
}, ee = /^(true|false|\d+)$/, fe = function() { | |
return { | |
priority: 100, | |
compile: function(a, c) { | |
return ee.test(c.ngValue) ? function(a, c, g) { | |
g.$set("value", a.$eval(g.ngValue)) | |
} : function(a, | |
c, g) { | |
a.$watch(g.ngValue, function(a) { | |
g.$set("value", a) | |
}) | |
} | |
} | |
} | |
}, ge = sa(function(a, c, d) { | |
c.addClass("ng-binding").data("$binding", d.ngBind); | |
a.$watch(d.ngBind, function(a) { | |
c.text(a == r ? "" : a) | |
}) | |
}), he = ["$interpolate", function(a) { | |
return function(c, d, e) { | |
c = a(d.attr(e.$attr.ngBindTemplate)); | |
d.addClass("ng-binding").data("$binding", c); | |
e.$observe("ngBindTemplate", function(a) { | |
d.text(a) | |
}) | |
} | |
} | |
], ie = ["$sce", "$parse", function(a, c) { | |
return function(d, e, g) { | |
e.addClass("ng-binding").data("$binding", g.ngBindHtml); | |
var f = c(g.ngBindHtml); | |
d.$watch(function() { | |
return (f(d) || "").toString() | |
}, function(c) { | |
e.html(a.getTrustedHtml(f(d)) || "") | |
}) | |
} | |
} | |
], je = Mb("", !0), ke = Mb("Odd", 0), le = Mb("Even", 1), me = sa({ | |
compile: function(a, c) { | |
c.$set("ngCloak", r); | |
a.removeClass("ng-cloak") | |
} | |
}), ne = [function() { | |
return { | |
scope: !0, | |
controller: "@", | |
priority: 500 | |
} | |
} | |
], Mc = {}; | |
q("click dblclick mousedown mouseup mouseover mouseout mousemove mouseenter mouseleave keydown keyup keypress submit focus blur copy cut paste".split(" "), function(a) { | |
var c = ma("ng-" + a); | |
Mc[c] = ["$parse", function(d) { | |
return { | |
compile: function(e, | |
g) { | |
var f = d(g[c]); | |
return function(c, d, e) { | |
d.on(v(a), function(a) { | |
c.$apply(function() { | |
f(c, { | |
$event: a | |
}) | |
}) | |
}) | |
} | |
} | |
} | |
} | |
] | |
}); | |
var oe = ["$animate", function(a) { | |
return { | |
transclude: "element", | |
priority: 600, | |
terminal: !0, | |
restrict: "A", | |
$$tlb: !0, | |
link: function(c, d, e, g, f) { | |
var h, l; | |
c.$watch(e.ngIf, function(g) { | |
Oa(g) ? l || (l = c.$new(), f(l, function(c) { | |
c[c.length++] = N.createComment(" end ngIf: " + e.ngIf + " "); | |
h = { | |
clone: c | |
}; | |
a.enter(c, d.parent(), d) | |
})) : (l && (l.$destroy(), l = null), h && (a.leave(vb(h.clone)), h = null)) | |
}) | |
} | |
} | |
} | |
], pe = ["$http", "$templateCache", | |
"$anchorScroll", "$animate", "$sce", function(a, c, d, e, g) { | |
return { | |
restrict: "ECA", | |
priority: 400, | |
terminal: !0, | |
transclude: "element", | |
controller: Pa.noop, | |
compile: function(f, h) { | |
var l = h.ngInclude || h.src, k = h.onload || "", m = h.autoscroll; | |
return function(f, h, q, r, B) { | |
var s = 0, u, v, x = function() { | |
u && (u.$destroy(), u = null); | |
v && (e.leave(v), v = null) | |
}; | |
f.$watch(g.parseAsResourceUrl(l), function(g) { | |
var l = function() { | |
!z(m) || m&&!f.$eval(m) || d() | |
}, q=++s; | |
g ? (a.get(g, { | |
cache: c | |
}).success(function(a) { | |
if (q === s) { | |
var c = f.$new(); | |
r.template = a; | |
a = B(c, | |
function(a) { | |
x(); | |
e.enter(a, null, h, l) | |
}); | |
u = c; | |
v = a; | |
u.$emit("$includeContentLoaded"); | |
f.$eval(k) | |
} | |
}).error(function() { | |
q === s && x() | |
}), f.$emit("$includeContentRequested")) : (x(), r.template = null) | |
}) | |
} | |
} | |
} | |
} | |
], qe = ["$compile", function(a) { | |
return { | |
restrict: "ECA", | |
priority: - 400, | |
require: "ngInclude", | |
link: function(c, d, e, g) { | |
d.html(g.template); | |
a(d.contents())(c) | |
} | |
} | |
} | |
], re = sa({ | |
priority: 450, | |
compile: function() { | |
return { | |
pre: function(a, c, d) { | |
a.$eval(d.ngInit) | |
} | |
} | |
} | |
}), se = sa({ | |
terminal: !0, | |
priority: 1E3 | |
}), te = ["$locale", "$interpolate", function(a, c) { | |
var d = | |
/{}/g; | |
return { | |
restrict: "EA", | |
link: function(e, g, f) { | |
var h = f.count, l = f.$attr.when && g.attr(f.$attr.when), k = f.offset || 0, m = e.$eval(l) || {}, n = {}, p = c.startSymbol(), t = c.endSymbol(), r = /^when(Minus)?(.+)$/; | |
q(f, function(a, c) { | |
r.test(c) && (m[v(c.replace("when", "").replace("Minus", "-"))] = g.attr(f.$attr[c])) | |
}); | |
q(m, function(a, e) { | |
n[e] = c(a.replace(d, p + h + "-" + k + t)) | |
}); | |
e.$watch(function() { | |
var c = parseFloat(e.$eval(h)); | |
if (isNaN(c)) | |
return ""; | |
c in m || (c = a.pluralCat(c - k)); | |
return n[c](e, g, !0) | |
}, function(a) { | |
g.text(a) | |
}) | |
} | |
} | |
} | |
], ue = ["$parse", | |
"$animate", function(a, c) { | |
var d = G("ngRepeat"); | |
return { | |
transclude: "element", | |
priority: 1E3, | |
terminal: !0, | |
$$tlb: !0, | |
link: function(e, g, f, h, l) { | |
var k = f.ngRepeat, m = k.match(/^\s*(.+)\s+in\s+(.*?)\s*(\s+track\s+by\s+(.+)\s*)?$/), n, p, t, r, s, v, u = { | |
$id: Ea | |
}; | |
if (!m) | |
throw d("iexp", k); | |
f = m[1]; | |
h = m[2]; | |
(m = m[4]) ? (n = a(m), p = function(a, c, d) { | |
v && (u[v] = a); | |
u[s] = c; | |
u.$index = d; | |
return n(e, u) | |
}) : (t = function(a, c) { | |
return Ea(c) | |
}, r = function(a) { | |
return a | |
}); | |
m = f.match(/^(?:([\$\w]+)|\(([\$\w]+)\s*,\s*([\$\w]+)\))$/); | |
if (!m) | |
throw d("iidexp", f); | |
s = m[3] || | |
m[1]; | |
v = m[2]; | |
var z = {}; | |
e.$watchCollection(h, function(a) { | |
var f, h, m = g[0], n, u = {}, H, O, M, S, D, w, G = []; | |
if (pb(a)) | |
D = a, n = p || t; | |
else { | |
n = p || r; | |
D = []; | |
for (M in a) | |
a.hasOwnProperty(M) && "$" != M.charAt(0) && D.push(M); | |
D.sort() | |
} | |
H = D.length; | |
h = G.length = D.length; | |
for (f = 0; f < h; f++) | |
if (M = a === D ? f : D[f], S = a[M], S = n(M, S, f), wa(S, "`track by` id"), z.hasOwnProperty(S)) | |
w = z[S], delete z[S], u[S] = w, G[f] = w; | |
else { | |
if (u.hasOwnProperty(S)) | |
throw q(G, function(a) { | |
a && a.scope && (z[a.id] = a) | |
}), d("dupes", k, S); | |
G[f] = { | |
id: S | |
}; | |
u[S]=!1 | |
} | |
for (M in z) | |
z.hasOwnProperty(M) && (w = | |
z[M], f = vb(w.clone), c.leave(f), q(f, function(a) { | |
a.$$NG_REMOVED=!0 | |
}), w.scope.$destroy()); | |
f = 0; | |
for (h = D.length; f < h; f++) { | |
M = a === D ? f : D[f]; | |
S = a[M]; | |
w = G[f]; | |
G[f - 1] && (m = G[f - 1].clone[G[f - 1].clone.length - 1]); | |
if (w.scope) { | |
O = w.scope; | |
n = m; | |
do | |
n = n.nextSibling; | |
while (n && n.$$NG_REMOVED); | |
w.clone[0] != n && c.move(vb(w.clone), null, x(m)); | |
m = w.clone[w.clone.length - 1] | |
} else | |
O = e.$new(); | |
O[s] = S; | |
v && (O[v] = M); | |
O.$index = f; | |
O.$first = 0 === f; | |
O.$last = f === H - 1; | |
O.$middle=!(O.$first || O.$last); | |
O.$odd=!(O.$even = 0 === (f & 1)); | |
w.scope || l(O, function(a) { | |
a[a.length++] = | |
N.createComment(" end ngRepeat: " + k + " "); | |
c.enter(a, null, x(m)); | |
m = a; | |
w.scope = O; | |
w.clone = a; | |
u[w.id] = w | |
}) | |
} | |
z = u | |
}) | |
} | |
} | |
} | |
], ve = ["$animate", function(a) { | |
return function(c, d, e) { | |
c.$watch(e.ngShow, function(c) { | |
a[Oa(c) ? "removeClass": "addClass"](d, "ng-hide") | |
}) | |
} | |
} | |
], we = ["$animate", function(a) { | |
return function(c, d, e) { | |
c.$watch(e.ngHide, function(c) { | |
a[Oa(c) ? "addClass": "removeClass"](d, "ng-hide") | |
}) | |
} | |
} | |
], xe = sa(function(a, c, d) { | |
a.$watch(d.ngStyle, function(a, d) { | |
d && a !== d && q(d, function(a, d) { | |
c.css(d, "") | |
}); | |
a && c.css(a) | |
}, !0) | |
}), ye = ["$animate", | |
function(a) { | |
return { | |
restrict: "EA", | |
require: "ngSwitch", | |
controller: ["$scope", function() { | |
this.cases = {} | |
} | |
], | |
link: function(c, d, e, g) { | |
var f, h, l = []; | |
c.$watch(e.ngSwitch || e.on, function(d) { | |
for (var m = 0, n = l.length; m < n; m++) | |
l[m].$destroy(), a.leave(h[m]); | |
h = []; | |
l = []; | |
if (f = g.cases["!" + d] || g.cases["?"]) | |
c.$eval(e.change), q(f, function(d) { | |
var e = c.$new(); | |
l.push(e); | |
d.transclude(e, function(c) { | |
var e = d.element; | |
h.push(c); | |
a.enter(c, e.parent(), e) | |
}) | |
}) | |
}) | |
} | |
} | |
} | |
], ze = sa({ | |
transclude: "element", | |
priority: 800, | |
require: "^ngSwitch", | |
compile: function(a, | |
c) { | |
return function(a, e, g, f, h) { | |
f.cases["!" + c.ngSwitchWhen] = f.cases["!" + c.ngSwitchWhen] || []; | |
f.cases["!" + c.ngSwitchWhen].push({ | |
transclude: h, | |
element: e | |
}) | |
} | |
} | |
}), Ae = sa({ | |
transclude: "element", | |
priority: 800, | |
require: "^ngSwitch", | |
link: function(a, c, d, e, g) { | |
e.cases["?"] = e.cases["?"] || []; | |
e.cases["?"].push({ | |
transclude: g, | |
element: c | |
}) | |
} | |
}), Be = sa({ | |
controller: ["$element", "$transclude", function(a, c) { | |
if (!c) | |
throw G("ngTransclude")("orphan", ha(a)); | |
this.$transclude = c | |
} | |
], | |
link: function(a, c, d, e) { | |
e.$transclude(function(a) { | |
c.empty(); | |
c.append(a) | |
}) | |
} | |
}), | |
Ce = ["$templateCache", function(a) { | |
return { | |
restrict: "E", | |
terminal: !0, | |
compile: function(c, d) { | |
"text/ng-template" == d.type && a.put(d.id, c[0].text) | |
} | |
} | |
} | |
], De = G("ngOptions"), Ee = ca({ | |
terminal: !0 | |
}), Fe = ["$compile", "$parse", function(a, c) { | |
var d = /^\s*(.*?)(?:\s+as\s+(.*?))?(?:\s+group\s+by\s+(.*))?\s+for\s+(?:([\$\w][\$\w]*)|(?:\(\s*([\$\w][\$\w]*)\s*,\s*([\$\w][\$\w]*)\s*\)))\s+in\s+(.*?)(?:\s+track\s+by\s+(.*?))?$/, e = { | |
$setViewValue: s | |
}; | |
return { | |
restrict: "E", | |
require: ["select", "?ngModel"], | |
controller: ["$element", "$scope", | |
"$attrs", function(a, c, d) { | |
var l = this, k = {}, m = e, n; | |
l.databound = d.ngModel; | |
l.init = function(a, c, d) { | |
m = a; | |
n = d | |
}; | |
l.addOption = function(c) { | |
wa(c, '"option value"'); | |
k[c]=!0; | |
m.$viewValue == c && (a.val(c), n.parent() && n.remove()) | |
}; | |
l.removeOption = function(a) { | |
this.hasOption(a) && (delete k[a], m.$viewValue == a && this.renderUnknownOption(a)) | |
}; | |
l.renderUnknownOption = function(c) { | |
c = "? " + Ea(c) + " ?"; | |
n.val(c); | |
a.prepend(n); | |
a.val(c); | |
n.prop("selected", !0) | |
}; | |
l.hasOption = function(a) { | |
return k.hasOwnProperty(a) | |
}; | |
c.$on("$destroy", function() { | |
l.renderUnknownOption = | |
s | |
}) | |
} | |
], | |
link: function(e, f, h, l) { | |
function k(a, c, d, e) { | |
d.$render = function() { | |
var a = d.$viewValue; | |
e.hasOption(a) ? (y.parent() && y.remove(), c.val(a), "" === a && u.prop("selected", !0)) : H(a) && u ? c.val("") : e.renderUnknownOption(a) | |
}; | |
c.on("change", function() { | |
a.$apply(function() { | |
y.parent() && y.remove(); | |
d.$setViewValue(c.val()) | |
}) | |
}) | |
} | |
function m(a, c, d) { | |
var e; | |
d.$render = function() { | |
var a = new Ta(d.$viewValue); | |
q(c.find("option"), function(c) { | |
c.selected = z(a.get(c.value)) | |
}) | |
}; | |
a.$watch(function() { | |
ta(e, d.$viewValue) || (e = ga(d.$viewValue), | |
d.$render()) | |
}); | |
c.on("change", function() { | |
a.$apply(function() { | |
var a = []; | |
q(c.find("option"), function(c) { | |
c.selected && a.push(c.value) | |
}); | |
d.$setViewValue(a) | |
}) | |
}) | |
} | |
function n(e, f, g) { | |
function h() { | |
var a = { | |
"": [] | |
}, c = [""], d, k, r, s, x; | |
s = g.$modelValue; | |
x = t(e) || []; | |
var B = n ? Ob(x): x, H, A, J; | |
A = {}; | |
r=!1; | |
var E, I; | |
if (v) | |
if (u && L(s)) | |
for (r = new Ta([]), J = 0; J < s.length; J++) | |
A[m] = s[J], r.put(u(e, A), s[J]); | |
else | |
r = new Ta(s); | |
for (J = 0; H = B.length, J < H; J++) { | |
k = J; | |
if (n) { | |
k = B[J]; | |
if ("$" === k.charAt(0)) | |
continue; | |
A[n] = k | |
} | |
A[m] = x[k]; | |
d = p(e, A) || ""; | |
(k = a[d]) || (k = a[d] = | |
[], c.push(d)); | |
v ? d = z(r.remove(u ? u(e, A) : q(e, A))) : (u ? (d = {}, d[m] = s, d = u(e, d) === u(e, A)) : d = s === q(e, A), r = r || d); | |
E = l(e, A); | |
E = z(E) ? E : ""; | |
k.push({ | |
id: u ? u(e, A): n ? B[J]: J, | |
label: E, | |
selected: d | |
}) | |
} | |
v || (w || null === s ? a[""].unshift({ | |
id: "", | |
label: "", | |
selected: !r | |
}) : r || a[""].unshift({ | |
id: "?", | |
label: "", | |
selected: !0 | |
})); | |
A = 0; | |
for (B = c.length; A < B; A++) { | |
d = c[A]; | |
k = a[d]; | |
y.length <= A ? (s = { | |
element: G.clone().attr("label", d), | |
label: k.label | |
}, x = [s], y.push(x), f.append(s.element)) : (x = y[A], s = x[0], s.label != d && s.element.attr("label", s.label = d)); | |
E = null; | |
J = 0; | |
for (H = | |
k.length; J < H; J++) | |
r = k[J], (d = x[J + 1]) ? (E = d.element, d.label !== r.label && E.text(d.label = r.label), d.id !== r.id && E.val(d.id = r.id), E[0].selected !== r.selected && E.prop("selected", d.selected = r.selected)) : ("" === r.id && w ? I = w : (I = D.clone()).val(r.id).attr("selected", r.selected).text(r.label), x.push({ | |
element: I, | |
label: r.label, | |
id: r.id, | |
selected: r.selected | |
}), E ? E.after(I) : s.element.append(I), E = I); | |
for (J++; x.length > J;) | |
x.pop().element.remove() | |
} | |
for (; y.length > A;) | |
y.pop()[0].element.remove() | |
} | |
var k; | |
if (!(k = s.match(d))) | |
throw De("iexp", | |
s, ha(f)); | |
var l = c(k[2] || k[1]), m = k[4] || k[6], n = k[5], p = c(k[3] || ""), q = c(k[2] ? k[1] : m), t = c(k[7]), u = k[8] ? c(k[8]): null, y = [[{ | |
element: f, | |
label: "" | |
} | |
]]; | |
w && (a(w)(e), w.removeClass("ng-scope"), w.remove()); | |
f.empty(); | |
f.on("change", function() { | |
e.$apply(function() { | |
var a, c = t(e) || [], d = {}, h, k, l, p, s, x, w; | |
if (v) | |
for (k = [], p = 0, x = y.length; p < x; p++) | |
for (a = y[p], l = 1, s = a.length; l < s; l++) { | |
if ((h = a[l].element)[0].selected) { | |
h = h.val(); | |
n && (d[n] = h); | |
if (u) | |
for (w = 0; w < c.length && (d[m] = c[w], u(e, d) != h); w++); | |
else | |
d[m] = c[h]; | |
k.push(q(e, d)) | |
} | |
} else if (h = f.val(), | |
"?" == h) | |
k = r; | |
else if ("" === h) | |
k = null; | |
else if (u) | |
for (w = 0; w < c.length; w++) { | |
if (d[m] = c[w], u(e, d) == h) { | |
k = q(e, d); | |
break | |
} | |
} else | |
d[m] = c[h], n && (d[n] = h), k = q(e, d); | |
g.$setViewValue(k) | |
}) | |
}); | |
g.$render = h; | |
e.$watch(h) | |
} | |
if (l[1]) { | |
var p = l[0], t = l[1], v = h.multiple, s = h.ngOptions, w=!1, u, D = x(N.createElement("option")), G = x(N.createElement("optgroup")), y = D.clone(); | |
l = 0; | |
for (var A = f.children(), I = A.length; l < I; l++) | |
if ("" === A[l].value) { | |
u = w = A.eq(l); | |
break | |
} | |
p.init(t, w, y); | |
if (v && (h.required || h.ngRequired)) { | |
var E = function(a) { | |
t.$setValidity("required", | |
!h.required || a && a.length); | |
return a | |
}; | |
t.$parsers.push(E); | |
t.$formatters.unshift(E); | |
h.$observe("required", function() { | |
E(t.$viewValue) | |
}) | |
} | |
s ? n(e, f, t) : v ? m(e, f, t) : k(e, f, t, p) | |
} | |
} | |
} | |
} | |
], Ge = ["$interpolate", function(a) { | |
var c = { | |
addOption: s, | |
removeOption: s | |
}; | |
return { | |
restrict: "E", | |
priority: 100, | |
compile: function(d, e) { | |
if (H(e.value)) { | |
var g = a(d.text(), !0); | |
g || e.$set("value", d.text()) | |
} | |
return function(a, d, e) { | |
var k = d.parent(), m = k.data("$selectController") || k.parent().data("$selectController"); | |
m && m.databound ? d.prop("selected", !1) : m = | |
c; | |
g ? a.$watch(g, function(a, c) { | |
e.$set("value", a); | |
a !== c && m.removeOption(c); | |
m.addOption(a) | |
}) : m.addOption(e.value); | |
d.on("$destroy", function() { | |
m.removeOption(e.value) | |
}) | |
} | |
} | |
} | |
} | |
], He = ca({ | |
restrict: "E", | |
terminal: !0 | |
}); | |
(Ca = W.jQuery) ? (x = Ca, w(Ca.fn, { | |
scope: Fa.scope, | |
isolateScope: Fa.isolateScope, | |
controller: Fa.controller, | |
injector: Fa.injector, | |
inheritedData: Fa.inheritedData | |
}), wb("remove", !0, !0, !1), wb("empty", !1, !1, !1), wb("html", !1, !1, !0)) : x = I; | |
Pa.element = x; | |
(function(a) { | |
w(a, { | |
bootstrap: Xb, | |
copy: ga, | |
extend: w, | |
equals: ta, | |
element: x, | |
forEach: q, | |
injector: Yb, | |
noop: s, | |
bind: rb, | |
toJson: oa, | |
fromJson: Tb, | |
identity: Ba, | |
isUndefined: H, | |
isDefined: z, | |
isString: D, | |
isFunction: A, | |
isObject: U, | |
isNumber: qb, | |
isElement: Oc, | |
isArray: L, | |
version: Qd, | |
isDate: La, | |
lowercase: v, | |
uppercase: Ia, | |
callbacks: { | |
counter: 0 | |
}, | |
$$minErr: G, | |
$$csp: Sb | |
}); | |
Va = Uc(W); | |
try { | |
Va("ngLocale") | |
} catch (c) { | |
Va("ngLocale", []).provider("$locale", sd) | |
} | |
Va("ng", ["ngLocale"], ["$provide", function(a) { | |
a.provider({ | |
$$sanitizeUri: Ad | |
}); | |
a.provider("$compile", hc).directive({ | |
a: Vd, | |
input: Kc, | |
textarea: Kc, | |
form: Wd, | |
script: Ce, | |
select: Fe, | |
style: He, | |
option: Ge, | |
ngBind: ge, | |
ngBindHtml: ie, | |
ngBindTemplate: he, | |
ngClass: je, | |
ngClassEven: le, | |
ngClassOdd: ke, | |
ngCloak: me, | |
ngController: ne, | |
ngForm: Xd, | |
ngHide: we, | |
ngIf: oe, | |
ngInclude: pe, | |
ngInit: re, | |
ngNonBindable: se, | |
ngPluralize: te, | |
ngRepeat: ue, | |
ngShow: ve, | |
ngStyle: xe, | |
ngSwitch: ye, | |
ngSwitchWhen: ze, | |
ngSwitchDefault: Ae, | |
ngOptions: Ee, | |
ngTransclude: Be, | |
ngModel: be, | |
ngList: de, | |
ngChange: ce, | |
required: Lc, | |
ngRequired: Lc, | |
ngValue: fe | |
}).directive({ | |
ngInclude: qe | |
}).directive(Nb).directive(Mc); | |
a.provider({ | |
$anchorScroll: cd, | |
$animate: Sd, | |
$browser: ed, | |
$cacheFactory: fd, | |
$controller: jd, | |
$document: kd, | |
$exceptionHandler: ld, | |
$filter: zc, | |
$interpolate: qd, | |
$interval: rd, | |
$http: md, | |
$httpBackend: nd, | |
$location: ud, | |
$log: vd, | |
$parse: wd, | |
$rootScope: zd, | |
$q: xd, | |
$sce: Dd, | |
$sceDelegate: Cd, | |
$sniffer: Ed, | |
$templateCache: gd, | |
$timeout: Fd, | |
$window: Gd | |
}) | |
} | |
]) | |
})(Pa); | |
x(N).ready(function() { | |
Sc(N, Xb) | |
}) | |
})(window, document); | |
!angular.$$csp() && angular.element(document).find("head").prepend('<style type="text/css">@charset "UTF-8";[ng\\:cloak],[ng-cloak],[data-ng-cloak],[x-ng-cloak],.ng-cloak,.x-ng-cloak,.ng-hide{display:none !important;}ng\\:form{display:block;}.ng-animate-start{border-spacing:1px 1px;-ms-zoom:1.0001;}.ng-animate-active{border-spacing:0px 0px;-ms-zoom:1;}</style>'); | |
//# sourceMappingURL=angular.min.js.map | |
/* | |
AngularJS v1.2.5 | |
(c) 2010-2014 Google, Inc. http://angularjs.org | |
License: MIT | |
*/ | |
(function(h, e, A) { | |
'use strict'; | |
function u(w, q, k) { | |
return { | |
restrict: "ECA", | |
terminal: !0, | |
priority: 400, | |
transclude: "element", | |
link: function(a, c, b, f, n) { | |
function y() { | |
l && (l.$destroy(), l = null); | |
g && (k.leave(g), g = null) | |
} | |
function v() { | |
var b = w.current && w.current.locals; | |
if (b && b.$template) { | |
var b = a.$new(), f = w.current; | |
g = n(b, function(d) { | |
k.enter(d, null, g || c, function() { | |
!e.isDefined(t) || t&&!a.$eval(t) || q() | |
}); | |
y() | |
}); | |
l = f.scope = b; | |
l.$emit("$viewContentLoaded"); | |
l.$eval(h) | |
} else | |
y() | |
} | |
var l, g, t = b.autoscroll, h = b.onload || ""; | |
a.$on("$routeChangeSuccess", | |
v); | |
v() | |
} | |
} | |
} | |
function z(e, h, k) { | |
return { | |
restrict: "ECA", | |
priority: - 400, | |
link: function(a, c) { | |
var b = k.current, f = b.locals; | |
c.html(f.$template); | |
var n = e(c.contents()); | |
b.controller && (f.$scope = a, f = h(b.controller, f), b.controllerAs && (a[b.controllerAs] = f), c.data("$ngControllerController", f), c.children().data("$ngControllerController", f)); | |
n(a) | |
} | |
} | |
} | |
h = e.module("ngRoute", ["ng"]).provider("$route", function() { | |
function h(a, c) { | |
return e.extend(new (e.extend(function() {}, { | |
prototype: a | |
})), c) | |
} | |
function q(a, e) { | |
var b = e.caseInsensitiveMatch, | |
f = { | |
originalPath: a, | |
regexp: a | |
}, h = f.keys = []; | |
a = a.replace(/([().])/g, "\\$1").replace(/(\/)?:(\w+)([\?|\*])?/g, function(a, e, b, c) { | |
a = "?" === c ? c : null; | |
c = "*" === c ? c : null; | |
h.push({ | |
name: b, | |
optional: !!a | |
}); | |
e = e || ""; | |
return "" + (a ? "" : e) + "(?:" + (a ? e : "") + (c && "(.+?)" || "([^/]+)") + (a || "") + ")" + (a || "") | |
}).replace(/([\/$\*])/g, "\\$1"); | |
f.regexp = RegExp("^" + a + "$", b ? "i" : ""); | |
return f | |
} | |
var k = {}; | |
this.when = function(a, c) { | |
k[a] = e.extend({ | |
reloadOnSearch: !0 | |
}, c, a && q(a, c)); | |
if (a) { | |
var b = "/" == a[a.length - 1] ? a.substr(0, a.length - 1): a + "/"; | |
k[b] = e.extend({ | |
redirectTo: a | |
}, | |
q(b, c)) | |
} | |
return this | |
}; | |
this.otherwise = function(a) { | |
this.when(null, a); | |
return this | |
}; | |
this.$get = ["$rootScope", "$location", "$routeParams", "$q", "$injector", "$http", "$templateCache", "$sce", function(a, c, b, f, n, q, v, l) { | |
function g() { | |
var d = t(), m = r.current; | |
if (d && m && d.$$route === m.$$route && e.equals(d.pathParams, m.pathParams)&&!d.reloadOnSearch&&!x) | |
m.params = d.params, e.copy(m.params, b), a.$broadcast("$routeUpdate", m); | |
else if (d || m) | |
x=!1, a.$broadcast("$routeChangeStart", d, m), (r.current = d) && d.redirectTo && (e.isString(d.redirectTo) ? | |
c.path(u(d.redirectTo, d.params)).search(d.params).replace() : c.url(d.redirectTo(d.pathParams, c.path(), c.search())).replace()), f.when(d).then(function() { | |
if (d) { | |
var a = e.extend({}, d.resolve), c, b; | |
e.forEach(a, function(d, c) { | |
a[c] = e.isString(d) ? n.get(d) : n.invoke(d) | |
}); | |
e.isDefined(c = d.template) ? e.isFunction(c) && (c = c(d.params)) : e.isDefined(b = d.templateUrl) && (e.isFunction(b) && (b = b(d.params)), b = l.getTrustedResourceUrl(b), e.isDefined(b) && (d.loadedTemplateUrl = b, c = q.get(b, { | |
cache: v | |
}).then(function(a) { | |
return a.data | |
}))); | |
e.isDefined(c) && (a.$template = c); | |
return f.all(a) | |
} | |
}).then(function(c) { | |
d == r.current && (d && (d.locals = c, e.copy(d.params, b)), a.$broadcast("$routeChangeSuccess", d, m)) | |
}, function(c) { | |
d == r.current && a.$broadcast("$routeChangeError", d, m, c) | |
}) | |
} | |
function t() { | |
var a, b; | |
e.forEach(k, function(f, k) { | |
var p; | |
if (p=!b) { | |
var s = c.path(); | |
p = f.keys; | |
var l = {}; | |
if (f.regexp) | |
if (s = f.regexp.exec(s)) { | |
for (var g = 1, q = s.length; g < q; ++g) { | |
var n = p[g - 1], r = "string" == typeof s[g] ? decodeURIComponent(s[g]): s[g]; | |
n && r && (l[n.name] = r) | |
} | |
p = l | |
} else | |
p = null; | |
else | |
p = null; | |
p = a = p | |
} | |
p && (b = h(f, { | |
params: e.extend({}, c.search(), a), | |
pathParams: a | |
}), b.$$route = f) | |
}); | |
return b || k[null] && h(k[null], { | |
params: {}, | |
pathParams: {} | |
}) | |
} | |
function u(a, c) { | |
var b = []; | |
e.forEach((a || "").split(":"), function(a, d) { | |
if (0 === d) | |
b.push(a); | |
else { | |
var e = a.match(/(\w+)(.*)/), f = e[1]; | |
b.push(c[f]); | |
b.push(e[2] || ""); | |
delete c[f] | |
} | |
}); | |
return b.join("") | |
} | |
var x=!1, r = { | |
routes: k, | |
reload: function() { | |
x=!0; | |
a.$evalAsync(g) | |
} | |
}; | |
a.$on("$locationChangeSuccess", g); | |
return r | |
} | |
] | |
}); | |
h.provider("$routeParams", function() { | |
this.$get = function() { | |
return {} | |
} | |
}); | |
h.directive("ngView", u); | |
h.directive("ngView", z); | |
u.$inject = ["$route", "$anchorScroll", "$animate"]; | |
z.$inject = ["$compile", "$controller", "$route"] | |
})(window, window.angular); | |
//# sourceMappingURL=angular-route.min.js.map | |
/* | |
AngularJS v1.2.5 | |
(c) 2010-2014 Google, Inc. http://angularjs.org | |
License: MIT | |
*/ | |
(function(C, k, F) { | |
'use strict'; | |
k.module("ngAnimate", ["ng"]).config(["$provide", "$animateProvider", function(M, G) { | |
function l(l) { | |
for (var h = 0; h < l.length; h++) { | |
var m = l[h]; | |
if (m.nodeType == T) | |
return m | |
} | |
} | |
var s = k.noop, m = k.forEach, N = G.$$selectors, T = 1, h = "$$ngAnimateState", J = "ng-animate", g = { | |
running: !0 | |
}; | |
M.decorator("$animate", ["$delegate", "$injector", "$sniffer", "$rootElement", "$timeout", "$rootScope", "$document", function(H, C, I, n, t, q, F) { | |
function O(a) { | |
if (a) { | |
var c = [], e = {}; | |
a = a.substr(1).split("."); | |
(I.transitions || I.animations) && | |
a.push(""); | |
for (var f = 0; f < a.length; f++) { | |
var b = a[f], l = N[b]; | |
l&&!e[b] && (c.push(C.get(l)), e[b]=!0) | |
} | |
return c | |
} | |
} | |
function p(a, c, e, f, b, g, q) { | |
function x(a) { | |
v(); | |
if (!0 === a) | |
w(); | |
else { | |
if (a = e.data(h)) | |
a.done = w, e.data(h, a); | |
p(y, "after", w) | |
} | |
} | |
function p(f, b, l) { | |
var h = b + "End"; | |
m(f, function(m, g) { | |
var d = function() { | |
a: { | |
var d = b + "Complete", a = f[g]; | |
a[d]=!0; | |
(a[h] || s)(); | |
for (a = 0; a < f.length; a++) | |
if (!f[a][d]) | |
break a; | |
l() | |
} | |
}; | |
"before" != b || "enter" != a && "move" != a ? m[b] ? m[h] = z ? m[b](e, c, d) : m[b](e, d) : d() : d() | |
}) | |
} | |
function n() { | |
q && t(q, 0, !1) | |
} | |
function v() { | |
v.hasBeenRun || | |
(v.hasBeenRun=!0, g()) | |
} | |
function w() { | |
if (!w.hasBeenRun) { | |
w.hasBeenRun=!0; | |
var a = e.data(h); | |
a && (z ? A(e) : (a.closeAnimationTimeout = t(function() { | |
A(e) | |
}, 0, !1), e.data(h, a))); | |
n() | |
} | |
} | |
var u = l(e); | |
if (u) { | |
var u = u.className, k = (" " + (u + " " + c)).replace(/\s+/g, "."); | |
f || (f = b ? b.parent() : e.parent()); | |
var k = O(k), z = "addClass" == a || "removeClass" == a; | |
b = e.data(h) || {}; | |
if (K(e, f) || 0 === k.length) | |
v(), w(); | |
else { | |
var y = []; | |
b.running && z && b.structural || m(k, function(b) { | |
if (!b.allowCancel || b.allowCancel(e, a, c)) { | |
var f = b[a]; | |
"leave" == a ? (b = f, f = null) : b = b["before" + | |
a.charAt(0).toUpperCase() + a.substr(1)]; | |
y.push({ | |
before: b, | |
after: f | |
}) | |
} | |
}); | |
0 === y.length ? (v(), n()) : (f = " " + u + " ", b.running && (t.cancel(b.closeAnimationTimeout), A(e), L(b.animations), b.beforeComplete ? (b.done || s)(!0) : z&&!b.structural && (f = "removeClass" == b.event ? f.replace(b.className, "") : f + b.className + " ")), u = " " + c + " ", "addClass" == a && 0 <= f.indexOf(u) || "removeClass" == a&&-1 == f.indexOf(u) ? (v(), n()) : (e.addClass(J), e.data(h, { | |
running: !0, | |
event: a, | |
className: c, | |
structural: !z, | |
animations: y, | |
done: x | |
}), p(y, "before", x))) | |
} | |
} else | |
v(), | |
w() | |
} | |
function E(a) { | |
a = l(a); | |
m(a.querySelectorAll("." + J), function(a) { | |
a = k.element(a); | |
var e = a.data(h); | |
e && (L(e.animations), A(a)) | |
}) | |
} | |
function L(a) { | |
m(a, function(c) { | |
a.beforeComplete || (c.beforeEnd || s)(!0); | |
a.afterComplete || (c.afterEnd || s)(!0) | |
}) | |
} | |
function A(a) { | |
l(a) == l(n) ? g.disabled || (g.running=!1, g.structural=!1) : (a.removeClass(J), a.removeData(h)) | |
} | |
function K(a, c) { | |
if (g.disabled) | |
return !0; | |
if (l(a) == l(n)) | |
return g.disabled || g.running; | |
do { | |
if (0 === c.length) | |
break; | |
var e = l(c) == l(n), f = e ? g: c.data(h), f = f && (!!f.disabled||!!f.running); | |
if (e || f) | |
return f; | |
if (e) | |
break | |
} | |
while (c = c.parent()); | |
return !0 | |
} | |
n.data(h, g); | |
q.$$postDigest(function() { | |
q.$$postDigest(function() { | |
g.running=!1 | |
}) | |
}); | |
return { | |
enter: function(a, c, e, f) { | |
this.enabled(!1, a); | |
H.enter(a, c, e); | |
q.$$postDigest(function() { | |
p("enter", "ng-enter", a, c, e, s, f) | |
}) | |
}, | |
leave: function(a, c) { | |
E(a); | |
this.enabled(!1, a); | |
q.$$postDigest(function() { | |
p("leave", "ng-leave", a, null, null, function() { | |
H.leave(a) | |
}, c) | |
}) | |
}, | |
move: function(a, c, e, f) { | |
E(a); | |
this.enabled(!1, a); | |
H.move(a, c, e); | |
q.$$postDigest(function() { | |
p("move", "ng-move", | |
a, c, e, s, f) | |
}) | |
}, | |
addClass: function(a, c, e) { | |
p("addClass", c, a, null, null, function() { | |
H.addClass(a, c) | |
}, e) | |
}, | |
removeClass: function(a, c, e) { | |
p("removeClass", c, a, null, null, function() { | |
H.removeClass(a, c) | |
}, e) | |
}, | |
enabled: function(a, c) { | |
switch (arguments.length) { | |
case 2: | |
if (a) | |
A(c); | |
else { | |
var e = c.data(h) || {}; | |
e.disabled=!0; | |
c.data(h, e) | |
} | |
break; | |
case 1: | |
g.disabled=!a; | |
break; | |
default: | |
a=!g.disabled | |
} | |
return !!a | |
} | |
} | |
} | |
]); | |
G.register("", ["$window", "$sniffer", "$timeout", function(h, g, I) { | |
function n(d) { | |
R.push(d); | |
I.cancel(S); | |
S = I(function() { | |
m(R, function(d) { | |
d() | |
}); | |
R = []; | |
S = null; | |
D = {} | |
}, 10, !1) | |
} | |
function t(d, a) { | |
var b = a ? D[a]: null; | |
if (!b) { | |
var e = 0, c = 0, f = 0, l = 0, g, k, n, p; | |
m(d, function(d) { | |
if (d.nodeType == T) { | |
d = h.getComputedStyle(d) || {}; | |
n = d[B + G]; | |
e = Math.max(q(n), e); | |
p = d[B + v]; | |
g = d[B + w]; | |
c = Math.max(q(g), c); | |
k = d[x + w]; | |
l = Math.max(q(k), l); | |
var a = q(d[x + G]); | |
0 < a && (a*=parseInt(d[x + u], 10) || 1); | |
f = Math.max(a, f) | |
} | |
}); | |
b = { | |
total: 0, | |
transitionPropertyStyle: p, | |
transitionDurationStyle: n, | |
transitionDelayStyle: g, | |
transitionDelay: c, | |
transitionDuration: e, | |
animationDelayStyle: k, | |
animationDelay: l, | |
animationDuration: f | |
}; | |
a && (D[a] = b) | |
} | |
return b | |
} | |
function q(d) { | |
var a = 0; | |
d = k.isString(d) ? d.split(/\s*,\s*/) : []; | |
m(d, function(d) { | |
a = Math.max(parseFloat(d) || 0, a) | |
}); | |
return a | |
} | |
function J(d) { | |
var a = d.parent(), b = a.data(V); | |
b || (a.data(V, ++U), b = U); | |
return b + "-" + l(d).className | |
} | |
function O(d, a) { | |
var b = J(d), e = b + " " + a, c = {}, f = D[e]?++D[e].total : 0; | |
if (0 < f) { | |
var h = a + "-stagger", c = b + " " + h; | |
(b=!D[c]) && d.addClass(h); | |
c = t(d, c); | |
b && d.removeClass(h) | |
} | |
d.addClass(a); | |
e = t(d, e); | |
h = Math.max(e.transitionDuration, e.animationDuration); | |
if (0 === h) | |
return d.removeClass(a), !1; | |
var g = | |
""; | |
0 < e.transitionDuration ? (d.addClass(y), g += M + " ", l(d).style[B + v] = "none") : l(d).style[x] = "none 0s"; | |
m(a.split(" "), function(d, a) { | |
g += (0 < a ? " " : "") + d + "-active" | |
}); | |
d.data(z, { | |
className: a, | |
activeClassName: g, | |
maxDuration: h, | |
classes: a + " " + g, | |
timings: e, | |
stagger: c, | |
ii: f | |
}); | |
return !0 | |
} | |
function p(d) { | |
var a = B + v; | |
d = l(d); | |
d.style[a] && 0 < d.style[a].length && (d.style[a] = "") | |
} | |
function E(d) { | |
var a = x; | |
d = l(d); | |
d.style[a] && 0 < d.style[a].length && (d.style[a] = "") | |
} | |
function L(a, c, f) { | |
function h(a) { | |
a.stopPropagation(); | |
var d = a.originalEvent || a; | |
a = d.$manualTimeStamp || | |
d.timeStamp || Date.now(); | |
d = parseFloat(d.elapsedTime.toFixed(N)); | |
Math.max(a - x, 0) >= v && d >= p && f() | |
} | |
var r = a.data(z), m = l(a); | |
if ( - 1 != m.className.indexOf(c) && r) { | |
var k = r.timings, n = r.stagger, p = r.maxDuration, q = r.activeClassName, v = 1E3 * Math.max(k.transitionDelay, k.animationDelay), x = Date.now(), w = Q + " " + P, u = r.ii, y, r = "", s = []; | |
if (0 < k.transitionDuration) { | |
var t = k.transitionPropertyStyle; | |
- 1 == t.indexOf("all") && (y=!0, r += b + "transition-property: " + t + ", " + (g.msie ? "-ms-zoom" : "border-spacing") + "; ", r += b + "transition-duration: " + | |
k.transitionDurationStyle + ", " + k.transitionDuration + "s; ", s.push(b + "transition-property"), s.push(b + "transition-duration")) | |
} | |
0 < u && (0 < n.transitionDelay && 0 === n.transitionDuration && (t = k.transitionDelayStyle, y && (t += ", " + k.transitionDelay + "s"), r += b + "transition-delay: " + A(t, n.transitionDelay, u) + "; ", s.push(b + "transition-delay")), 0 < n.animationDelay && 0 === n.animationDuration && (r += b + "animation-delay: " + A(k.animationDelayStyle, n.animationDelay, u) + "; ", s.push(b + "animation-delay"))); | |
0 < s.length && (k = m.getAttribute("style") || | |
"", m.setAttribute("style", k + " " + r)); | |
a.on(w, h); | |
a.addClass(q); | |
return function(b) { | |
a.off(w, h); | |
a.removeClass(q); | |
e(a, c); | |
b = l(a); | |
for (var f in s) | |
b.style.removeProperty(s[f]) | |
} | |
} | |
f() | |
} | |
function A(a, b, e) { | |
var c = ""; | |
m(a.split(","), function(a, d) { | |
c += (0 < d ? "," : "") + (e * b + parseInt(a, 10)) + "s" | |
}); | |
return c | |
} | |
function K(a, b) { | |
if (O(a, b)) | |
return function(c) { | |
c && e(a, b) | |
} | |
} | |
function a(a, b, c) { | |
if (a.data(z)) | |
return L(a, b, c); | |
e(a, b); | |
c() | |
} | |
function c(d, b, c) { | |
var e = K(d, b); | |
if (e) { | |
var f = e; | |
n(function() { | |
p(d); | |
E(d); | |
f = a(d, b, c) | |
}); | |
return function(a) { | |
(f || s)(a) | |
} | |
} | |
c() | |
} | |
function e(a, b) { | |
a.removeClass(b); | |
a.removeClass(y); | |
a.removeData(z) | |
} | |
function f(a, b) { | |
var c = ""; | |
a = k.isArray(a) ? a : a.split(/\s+/); | |
m(a, function(a, d) { | |
a && 0 < a.length && (c += (0 < d ? " " : "") + a + b) | |
}); | |
return c | |
} | |
var b = "", B, P, x, Q; | |
C.ontransitionend === F && C.onwebkittransitionend !== F ? (b = "-webkit-", B = "WebkitTransition", P = "webkitTransitionEnd transitionend") : (B = "transition", P = "transitionend"); | |
C.onanimationend === F && C.onwebkitanimationend !== F ? (b = "-webkit-", x = "WebkitAnimation", Q = "webkitAnimationEnd animationend") : (x = "animation", | |
Q = "animationend"); | |
var G = "Duration", v = "Property", w = "Delay", u = "IterationCount", V = "$$ngAnimateKey", z = "$$ngAnimateCSS3Data", y = "ng-animate-start", M = "ng-animate-active", N = 3, D = {}, U = 0, R = [], S; | |
return { | |
allowCancel: function(a, b, c) { | |
var e = (a.data(z) || {}).classes; | |
if (!e || 0 <= ["enter", "leave", "move"].indexOf(b)) | |
return !0; | |
var h = a.parent(), g = k.element(l(a).cloneNode()); | |
g.attr("style", "position:absolute; top:-9999px; left:-9999px"); | |
g.removeAttr("id"); | |
g.empty(); | |
m(e.split(" "), function(a) { | |
g.removeClass(a) | |
}); | |
g.addClass(f(c, | |
"addClass" == b ? "-add" : "-remove")); | |
h.append(g); | |
a = t(g); | |
g.remove(); | |
return 0 < Math.max(a.transitionDuration, a.animationDuration) | |
}, | |
enter: function(a, b) { | |
return c(a, "ng-enter", b) | |
}, | |
leave: function(a, b) { | |
return c(a, "ng-leave", b) | |
}, | |
move: function(a, b) { | |
return c(a, "ng-move", b) | |
}, | |
beforeAddClass: function(a, b, c) { | |
if (b = K(a, f(b, "-add"))) | |
return n(function() { | |
p(a); | |
E(a); | |
c() | |
}), b; | |
c() | |
}, | |
addClass: function(b, c, e) { | |
return a(b, f(c, "-add"), e) | |
}, | |
beforeRemoveClass: function(a, b, c) { | |
if (b = K(a, f(b, "-remove"))) | |
return n(function() { | |
p(a); | |
E(a); | |
c() | |
}), | |
b; | |
c() | |
}, | |
removeClass: function(b, c, e) { | |
return a(b, f(c, "-remove"), e) | |
} | |
} | |
} | |
]) | |
} | |
]) | |
})(window, window.angular); | |
//# sourceMappingURL=angular-animate.min.js.map | |
/* | |
AngularJS v1.2.11 | |
(c) 2010-2014 Google, Inc. http://angularjs.org | |
License: MIT | |
*/ | |
(function(H, a, A) { | |
'use strict'; | |
function D(p, g) { | |
g = g || {}; | |
a.forEach(g, function(a, c) { | |
delete g[c] | |
}); | |
for (var c in p) | |
p.hasOwnProperty(c) && ("$" !== c.charAt(0) && "$" !== c.charAt(1)) && (g[c] = p[c]); | |
return g | |
} | |
var v = a.$$minErr("$resource"), C = /^(\.[a-zA-Z_$][0-9a-zA-Z_$]*)+$/; | |
a.module("ngResource", ["ng"]).factory("$resource", ["$http", "$q", function(p, g) { | |
function c(a, c) { | |
this.template = a; | |
this.defaults = c || {}; | |
this.urlParams = {} | |
} | |
function t(n, w, l) { | |
function r(h, d) { | |
var e = {}; | |
d = x({}, w, d); | |
s(d, function(b, d) { | |
u(b) && (b = b()); | |
var k; | |
if (b && | |
b.charAt && "@" == b.charAt(0)) { | |
k = h; | |
var a = b.substr(1); | |
if (null == a || "" === a || "hasOwnProperty" === a ||!C.test("." + a)) | |
throw v("badmember", a); | |
for (var a = a.split("."), f = 0, c = a.length; f < c && k !== A; f++) { | |
var g = a[f]; | |
k = null !== k ? k[g] : A | |
} | |
} else | |
k = b; | |
e[d] = k | |
}); | |
return e | |
} | |
function e(a) { | |
return a.resource | |
} | |
function f(a) { | |
D(a || {}, this) | |
} | |
var F = new c(n); | |
l = x({}, B, l); | |
s(l, function(h, d) { | |
var c = /^(POST|PUT|PATCH)$/i.test(h.method); | |
f[d] = function(b, d, k, w) { | |
var q = {}, n, l, y; | |
switch (arguments.length) { | |
case 4: | |
y = w, l = k; | |
case 3: | |
case 2: | |
if (u(d)) { | |
if (u(b)) { | |
l = | |
b; | |
y = d; | |
break | |
} | |
l = d; | |
y = k | |
} else { | |
q = b; | |
n = d; | |
l = k; | |
break | |
} | |
case 1: | |
u(b) ? l = b : c ? n = b : q = b; | |
break; | |
case 0: | |
break; | |
default: | |
throw v("badargs", arguments.length); | |
} | |
var t = this instanceof f, m = t ? n: h.isArray ? []: new f(n), z = {}, B = h.interceptor && h.interceptor.response || e, C = h.interceptor && h.interceptor.responseError || A; | |
s(h, function(a, b) { | |
"params" != b && ("isArray" != b && "interceptor" != b) && (z[b] = G(a)) | |
}); | |
c && (z.data = n); | |
F.setUrlParams(z, x({}, r(n, h.params || {}), q), h.url); | |
q = p(z).then(function(b) { | |
var d = b.data, k = m.$promise; | |
if (d) { | |
if (a.isArray(d)!==!!h.isArray) | |
throw v("badcfg", | |
h.isArray ? "array" : "object", a.isArray(d) ? "array" : "object"); | |
h.isArray ? (m.length = 0, s(d, function(b) { | |
m.push(new f(b)) | |
})) : (D(d, m), m.$promise = k) | |
} | |
m.$resolved=!0; | |
b.resource = m; | |
return b | |
}, function(b) { | |
m.$resolved=!0; | |
(y || E)(b); | |
return g.reject(b) | |
}); | |
q = q.then(function(b) { | |
var a = B(b); | |
(l || E)(a, b.headers); | |
return a | |
}, C); | |
return t ? q : (m.$promise = q, m.$resolved=!1, m) | |
}; | |
f.prototype["$" + d] = function(b, a, k) { | |
u(b) && (k = a, a = b, b = {}); | |
b = f[d].call(this, b, this, a, k); | |
return b.$promise || b | |
} | |
}); | |
f.bind = function(a) { | |
return t(n, x({}, w, a), l) | |
}; | |
return f | |
} | |
var B = { | |
get: { | |
method: "GET" | |
}, | |
save: { | |
method: "POST" | |
}, | |
query: { | |
method: "GET", | |
isArray: !0 | |
}, | |
remove: { | |
method: "DELETE" | |
}, | |
"delete": { | |
method: "DELETE" | |
} | |
}, E = a.noop, s = a.forEach, x = a.extend, G = a.copy, u = a.isFunction; | |
c.prototype = { | |
setUrlParams: function(c, g, l) { | |
var r = this, e = l || r.template, f, p, h = r.urlParams = {}; | |
s(e.split(/\W/), function(a) { | |
if ("hasOwnProperty" === a) | |
throw v("badname"); | |
!/^\d+$/.test(a) && (a && RegExp("(^|[^\\\\]):" + a + "(\\W|$)").test(e)) && (h[a]=!0) | |
}); | |
e = e.replace(/\\:/g, ":"); | |
g = g || {}; | |
s(r.urlParams, function(d, c) { | |
f = g.hasOwnProperty(c) ? | |
g[c] : r.defaults[c]; | |
a.isDefined(f) && null !== f ? (p = encodeURIComponent(f).replace(/%40/gi, "@").replace(/%3A/gi, ":").replace(/%24/g, "$").replace(/%2C/gi, ",").replace(/%20/g, "%20").replace(/%26/gi, "&").replace(/%3D/gi, "=").replace(/%2B/gi, "+"), e = e.replace(RegExp(":" + c + "(\\W|$)", "g"), function(a, c) { | |
return p + c | |
})) : e = e.replace(RegExp("(/?):" + c + "(\\W|$)", "g"), function(a, c, d) { | |
return "/" == d.charAt(0) ? d : c + d | |
}) | |
}); | |
e = e.replace(/\/+$/, "") || "/"; | |
e = e.replace(/\/\.(?=\w+($|\?))/, "."); | |
c.url = e.replace(/\/\\\./, "/."); | |
s(g, function(a, | |
e) { | |
r.urlParams[e] || (c.params = c.params || {}, c.params[e] = a) | |
}) | |
} | |
}; | |
return t | |
} | |
]) | |
})(window, window.angular); | |
//# sourceMappingURL=angular-resource.min.js.map | |
/* | |
AngularJS v1.2.11 | |
(c) 2010-2014 Google, Inc. http://angularjs.org | |
License: MIT | |
*/ | |
(function(p, h, q) { | |
'use strict'; | |
function E(a) { | |
var e = []; | |
s(e, h.noop).chars(a); | |
return e.join("") | |
} | |
function k(a) { | |
var e = {}; | |
a = a.split(","); | |
var d; | |
for (d = 0; d < a.length; d++) | |
e[a[d]]=!0; | |
return e | |
} | |
function F(a, e) { | |
function d(a, b, d, g) { | |
b = h.lowercase(b); | |
if (t[b]) | |
for (; f.last() && u[f.last()];) | |
c("", f.last()); | |
v[b] && f.last() == b && c("", b); | |
(g = w[b]||!!g) || f.push(b); | |
var l = {}; | |
d.replace(G, function(a, b, e, c, d) { | |
l[b] = r(e || c || d || "") | |
}); | |
e.start && e.start(b, l, g) | |
} | |
function c(a, b) { | |
var c = 0, d; | |
if (b = h.lowercase(b)) | |
for (c = f.length - 1; 0 <= c && f[c] != b; c--); | |
if (0 <= c) { | |
for (d = f.length - 1; d >= c; d--) | |
e.end && e.end(f[d]); | |
f.length = c | |
} | |
} | |
var b, g, f = [], l = a; | |
for (f.last = function() { | |
return f[f.length - 1] | |
}; a;) { | |
g=!0; | |
if (f.last() && x[f.last()]) | |
a = a.replace(RegExp("(.*)<\\s*\\/\\s*" + f.last() + "[^>]*>", "i"), function(b, a) { | |
a = a.replace(H, "$1").replace(I, "$1"); | |
e.chars && e.chars(r(a)); | |
return "" | |
}), c("", f.last()); | |
else { | |
if (0 === a.indexOf("\x3c!--")) | |
b = a.indexOf("--", 4), 0 <= b && a.lastIndexOf("--\x3e", b) === b && (e.comment && e.comment(a.substring(4, b)), a = a.substring(b + 3), g=!1); | |
else if (y.test(a)) { | |
if (b = a.match(y)) | |
a = | |
a.replace(b[0], ""), g=!1 | |
} else if (J.test(a)) { | |
if (b = a.match(z)) | |
a = a.substring(b[0].length), b[0].replace(z, c), g=!1 | |
} else | |
K.test(a) && (b = a.match(A)) && (a = a.substring(b[0].length), b[0].replace(A, d), g=!1); | |
g && (b = a.indexOf("<"), g = 0 > b ? a : a.substring(0, b), a = 0 > b ? "" : a.substring(b), e.chars && e.chars(r(g))) | |
} | |
if (a == l) | |
throw L("badparse", a); | |
l = a | |
} | |
c() | |
} | |
function r(a) { | |
if (!a) | |
return ""; | |
var e = M.exec(a); | |
a = e[1]; | |
var d = e[3]; | |
if (e = e[2]) | |
n.innerHTML = e.replace(/</g, "<"), e = "textContent"in n ? n.textContent : n.innerText; | |
return a + e + d | |
} | |
function B(a) { | |
return a.replace(/&/g, | |
"&").replace(N, function(a) { | |
return "&#" + a.charCodeAt(0) + ";" | |
}).replace(/</g, "<").replace(/>/g, ">") | |
} | |
function s(a, e) { | |
var d=!1, c = h.bind(a, a.push); | |
return { | |
start: function(a, g, f) { | |
a = h.lowercase(a); | |
!d && x[a] && (d = a); | |
d ||!0 !== C[a] || (c("<"), c(a), h.forEach(g, function(d, f) { | |
var g = h.lowercase(f), k = "img" === a && "src" === g || "background" === g; | |
!0 !== O[g] ||!0 === D[g]&&!e(d, k) || (c(" "), c(f), c('="'), c(B(d)), c('"')) | |
}), c(f ? "/>" : ">")) | |
}, | |
end: function(a) { | |
a = h.lowercase(a); | |
d ||!0 !== C[a] || (c("</"), c(a), c(">")); | |
a == d && (d=!1) | |
}, | |
chars: function(a) { | |
d || | |
c(B(a)) | |
} | |
} | |
} | |
var L = h.$$minErr("$sanitize"), A = /^<\s*([\w:-]+)((?:\s+[\w:-]+(?:\s*=\s*(?:(?:"[^"]*")|(?:'[^']*')|[^>\s]+))?)*)\s*(\/?)\s*>/, z = /^<\s*\/\s*([\w:-]+)[^>]*>/, G = /([\w:-]+)(?:\s*=\s*(?:(?:"((?:[^"])*)")|(?:'((?:[^'])*)')|([^>\s]+)))?/g, K = /^</, J = /^<\s*\//, H = /\x3c!--(.*?)--\x3e/g, y = /<!DOCTYPE([^>]*?)>/i, I = /<!\[CDATA\[(.*?)]]\x3e/g, N = /([^\#-~| |!])/g, w = k("area,br,col,hr,img,wbr"); | |
p = k("colgroup,dd,dt,li,p,tbody,td,tfoot,th,thead,tr"); | |
q = k("rp,rt"); | |
var v = h.extend({}, q, p), t = h.extend({}, p, k("address,article,aside,blockquote,caption,center,del,dir,div,dl,figure,figcaption,footer,h1,h2,h3,h4,h5,h6,header,hgroup,hr,ins,map,menu,nav,ol,pre,script,section,table,ul")), | |
u = h.extend({}, q, k("a,abbr,acronym,b,bdi,bdo,big,br,cite,code,del,dfn,em,font,i,img,ins,kbd,label,map,mark,q,ruby,rp,rt,s,samp,small,span,strike,strong,sub,sup,time,tt,u,var")), x = k("script,style"), C = h.extend({}, w, t, u, v), D = k("background,cite,href,longdesc,src,usemap"), O = h.extend({}, D, k("abbr,align,alt,axis,bgcolor,border,cellpadding,cellspacing,class,clear,color,cols,colspan,compact,coords,dir,face,headers,height,hreflang,hspace,ismap,lang,language,nohref,nowrap,rel,rev,rows,rowspan,rules,scope,scrolling,shape,size,span,start,summary,target,title,type,valign,value,vspace,width")), | |
n = document.createElement("pre"), M = /^(\s*)([\s\S]*?)(\s*)$/; | |
h.module("ngSanitize", []).provider("$sanitize", function() { | |
this.$get = ["$$sanitizeUri", function(a) { | |
return function(e) { | |
var d = []; | |
F(e, s(d, function(c, b) { | |
return !/^unsafe/.test(a(c, b)) | |
})); | |
return d.join("") | |
} | |
} | |
] | |
}); | |
h.module("ngSanitize").filter("linky", ["$sanitize", function(a) { | |
var e = /((ftp|https?):\/\/|(mailto:)?[A-Za-z0-9._%+-]+@)\S*[^\s.;,(){}<>]/, d = /^mailto:/; | |
return function(c, b) { | |
function g(a) { | |
a && m.push(E(a)) | |
} | |
function f(a, c) { | |
m.push("<a "); | |
h.isDefined(b) && | |
(m.push('target="'), m.push(b), m.push('" ')); | |
m.push('href="'); | |
m.push(a); | |
m.push('">'); | |
g(c); | |
m.push("</a>") | |
} | |
if (!c) | |
return c; | |
for (var l, k = c, m = [], n, p; l = k.match(e);) | |
n = l[0], l[2] == l[3] && (n = "mailto:" + n), p = l.index, g(k.substr(0, p)), f(n, l[0].replace(d, "")), k = k.substring(p + l[0].length); | |
g(k); | |
return a(m.join("")) | |
} | |
} | |
]) | |
})(window, window.angular); | |
//# sourceMappingURL=angular-sanitize.min.js.map | |
/** | |
* @license Angulartics v0.17.2 | |
* (c) 2013 Luis Farzati http://luisfarzati.github.io/angulartics | |
* License: MIT | |
*/ | |
!function(a) { | |
"use strict"; | |
var b = window.angulartics || (window.angulartics = {}); | |
b.waitForVendorCount = 0, b.waitForVendorApi = function(a, c, d, e, f) { | |
f || b.waitForVendorCount++, e || (e = d, d = void 0), !Object.prototype.hasOwnProperty.call(window, a) || void 0 !== d && void 0 === window[a][d] ? setTimeout(function() { | |
b.waitForVendorApi(a, c, d, e, !0) | |
}, c) : (b.waitForVendorCount--, e(window[a])) | |
}, a.module("angulartics", []).provider("$analytics", function() { | |
var c = { | |
pageTracking: { | |
autoTrackFirstPage: !0, | |
autoTrackVirtualPages: !0, | |
trackRelativePath: !1, | |
autoBasePath: !1, | |
basePath: "" | |
}, | |
eventTracking: {}, | |
bufferFlushDelay: 1e3, | |
developerMode: !1 | |
}, d = ["pageTrack", "eventTrack", "setAlias", "setUsername", "setAlias", "setUserProperties", "setUserPropertiesOnce", "setSuperProperties", "setSuperPropertiesOnce"], e = {}, f = {}, g = function(a) { | |
return function() { | |
b.waitForVendorCount && (e[a] || (e[a] = []), e[a].push(arguments)) | |
} | |
}, h = function(b, c) { | |
return f[b] || (f[b] = []), f[b].push(c), function() { | |
var c = arguments; | |
a.forEach(f[b], function(a) { | |
a.apply(this, c) | |
}, this) | |
} | |
}, i = { | |
settings: c | |
}, j = function(a, b) { | |
b ? setTimeout(a, b) : a() | |
}, k = { | |
$get: function() { | |
return i | |
}, | |
api: i, | |
settings: c, | |
virtualPageviews: function(a) { | |
this.settings.pageTracking.autoTrackVirtualPages = a | |
}, | |
firstPageview: function(a) { | |
this.settings.pageTracking.autoTrackFirstPage = a | |
}, | |
withBase: function(b) { | |
this.settings.pageTracking.basePath = b ? a.element("base").attr("href").slice(0, - 1) : "" | |
}, | |
withAutoBase: function(a) { | |
this.settings.pageTracking.autoBasePath = a | |
}, | |
developerMode: function(a) { | |
this.settings.developerMode = a | |
} | |
}, l = function(b, d) { | |
i[b] = h(b, d); | |
var f = c[b], g = f ? f.bufferFlushDelay: null, k = null !== g ? g: c.bufferFlushDelay; | |
a.forEach(e[b], function(a, b) { | |
j(function() { | |
d.apply(this, a) | |
}, b * k) | |
}) | |
}, m = function(a) { | |
return a.replace(/^./, function(a) { | |
return a.toUpperCase() | |
}) | |
}, n = function(a) { | |
var b = "register" + m(a); | |
k[b] = function(b) { | |
l(a, b) | |
}, i[a] = h(a, g(a)) | |
}; | |
return a.forEach(d, n), k | |
}).run(["$rootScope", "$window", "$analytics", "$injector", function(b, c, d, e) { | |
d.settings.pageTracking.autoTrackFirstPage && e.invoke(["$location", function(a) { | |
var b=!0; | |
if (e.has("$route")) { | |
var f = e.get("$route"); | |
for (var g in f.routes) { | |
b=!1; | |
break | |
} | |
} else if (e.has("$state")) { | |
var h = e.get("$state"); | |
for (var i in h.get()) { | |
b=!1; | |
break | |
} | |
} | |
if (b) | |
if (d.settings.pageTracking.autoBasePath && (d.settings.pageTracking.basePath = c.location.pathname), d.settings.trackRelativePath) { | |
var j = d.settings.pageTracking.basePath + a.url(); | |
d.pageTrack(j, a) | |
} else | |
d.pageTrack(a.absUrl(), a) | |
} | |
]), d.settings.pageTracking.autoTrackVirtualPages && e.invoke(["$location", function(a) { | |
d.settings.pageTracking.autoBasePath && (d.settings.pageTracking.basePath = c.location.pathname + "#"), e.has("$route") && b.$on("$routeChangeSuccess", function(b, c) { | |
if (!c ||!(c.$$route || c).redirectTo) { | |
var e = d.settings.pageTracking.basePath + a.url(); | |
d.pageTrack(e, a) | |
} | |
}), e.has("$state") && b.$on("$stateChangeSuccess", function() { | |
var b = d.settings.pageTracking.basePath + a.url(); | |
d.pageTrack(b, a) | |
}) | |
} | |
]), d.settings.developerMode && a.forEach(d, function(a, b) { | |
"function" == typeof a && (d[b] = function() {}) | |
}) | |
} | |
]).directive("analyticsOn", ["$analytics", function(b) { | |
function c(a) { | |
return ["a:", "button:", "button:button", "button:submit", "input:button", "input:submit"].indexOf(a.tagName.toLowerCase() + ":" + (a.type || "")) >= 0 | |
} | |
function d(a) { | |
return c(a) ? "click" : "click" | |
} | |
function e(a) { | |
return c(a) ? a.innerText || a.value : a.id || a.name || a.tagName | |
} | |
function f(a) { | |
return "analytics" === a.substr(0, 9)&&-1 === ["On", "Event", "If", "Properties", "EventType"].indexOf(a.substr(9)) | |
} | |
function g(a) { | |
var b = a.slice(9); | |
return "undefined" != typeof b && null !== b && b.length > 0 ? b.substring(0, 1).toLowerCase() + b.substring(1) : b | |
} | |
return { | |
restrict: "A", | |
link: function(c, h, i) { | |
var j = i.analyticsOn || d(h[0]), k = {}; | |
a.forEach(i.$attr, function(a, b) { | |
f(b) && (k[g(b)] = i[b], i.$observe(b, function(a) { | |
k[g(b)] = a | |
})) | |
}), a.element(h[0]).bind(j, function(d) { | |
var f = i.analyticsEvent || e(h[0]); | |
k.eventType = d.type, (!i.analyticsIf || c.$eval(i.analyticsIf)) && (i.analyticsProperties && a.extend(k, c.$eval(i.analyticsProperties)), b.eventTrack(f, k)) | |
}) | |
} | |
} | |
} | |
]) | |
}(angular); | |
/** | |
* @license Angulartics v0.17.2 | |
* (c) 2013 Luis Farzati http://luisfarzati.github.io/angulartics | |
* Google Tag Manager Plugin Contributed by http://github.com/danrowe49 | |
* License: MIT | |
*/ | |
!function(a) { | |
"use strict"; | |
a.module("angulartics.google.tagmanager", ["angulartics"]).config(["$analyticsProvider", function(a) { | |
a.registerPageTrack(function(a) { | |
var b = window.dataLayer = window.dataLayer || []; | |
b.push({ | |
event: "content-view", | |
"content-name": a | |
}) | |
}), a.registerEventTrack(function(a, b) { | |
var c = window.dataLayer = window.dataLayer || []; | |
c.push({ | |
event: "interaction", | |
target: b.category, | |
action: a, | |
"target-properties": b.label, | |
value: b.value, | |
"interaction-type": b.noninteraction | |
}) | |
}) | |
} | |
]) | |
}(angular); | |
/** | |
* PRPL ANIMATOR is series of animation tools that rely on whether the | |
* element is within the viewport or not | |
* | |
* @author: Parker Hutchinson | |
* | |
*/ | |
(function(window, angular, undefined) { | |
'use strict'; | |
var ngPrplAnimator = angular.module('prplAnimator', []); | |
/** | |
* directive gets current element to add class 'inviewtop' | |
* or 'inviewmiddle' or 'inviewbottom' to itself when container is either visible or | |
* at least the elements' middle or bottom are visible. class is only removed | |
* if element is below window viewport not above it. | |
* | |
* @author: Parker Hutchinson | |
* @attr: offset = integer | |
*/ | |
ngPrplAnimator.directive('prplInview', function() { | |
var link = function(scope, element, attrs) { | |
// debounce(http://davidwalsh.name/javascript-debounce-function), because duh. | |
// Returns a function, that, as long as it continues to be invoked, will not | |
// be triggered. The function will be called after it stops being called for | |
// N milliseconds. If `immediate` is passed, trigger the function on the | |
// leading edge, instead of the trailing. | |
function debounce(func, wait, immediate) { | |
var timeout; | |
return function() { | |
var context = this, args = arguments; | |
clearTimeout(timeout); | |
timeout = setTimeout(function() { | |
timeout = null; | |
if (!immediate) | |
func.apply(context, args); | |
}, wait); | |
if (immediate && !timeout) | |
func.apply(context, args); | |
}; | |
}; | |
var inViewFun = debounce(function() { | |
var winTop = $(window).scrollTop(), | |
elementTop = $(element).offset().top - $(window).height(), | |
elementBottom = elementTop + $(element).outerHeight(), | |
elementMiddle = elementTop + $(element).outerHeight() / 2; | |
// only removes class if element is below | |
// window height | |
// only add class if element top is in view | |
if (winTop >= elementTop) { | |
$(element).addClass('inviewtop'); | |
} else { | |
$(element).removeClass('inviewtop'); | |
}; | |
// only add class if element is visible && if | |
// middle of element can be seen | |
if (winTop >= elementMiddle) { | |
$(element).addClass('inviewmiddle'); | |
} else { | |
$(element).removeClass('inviewmiddle'); | |
}; | |
// only add class if element bottom is in view | |
if (winTop >= elementBottom) { | |
$(element).addClass('inviewbottom'); | |
} else { | |
$(element).removeClass('inviewbottom'); | |
}; | |
// only add class if element top is in view plus | |
// custom offset | |
if (winTop >= (elementTop + parseInt(attrs.inviewOffset))) { | |
$(element).addClass('inviewcustom'); | |
} else { | |
$(element).removeClass('inviewcustom'); | |
}; | |
}, 20); | |
// on init | |
$(window).load(inViewFun); | |
// on scroll | |
$(window).on('scroll', inViewFun); | |
}; | |
return { | |
restrict: 'A', | |
link: link | |
}; | |
}); | |
/** | |
* directive to listen for when the blue icons on fleetgistics | |
* are visible via the inviewbottom class. if they are, then set the | |
* cols to active one at a time until finished | |
* | |
* @author: Parker Hutchinson | |
* @requires: prplInview | |
* @attr: stepperDalay = integer | |
*/ | |
ngPrplAnimator.directive('prplStepper', function() { | |
var link = function(scope, element, attrs) { | |
var listener, | |
sequence, | |
unlistener, | |
delay = parseInt(attrs.stepperDelay) || 300, | |
inviewClass = attrs.stepperClass || "inviewbottom"; | |
// listening for 'inviewbottom' class to be applied | |
var listenerAddClass = function() { | |
listener = window.setInterval(function() { | |
if ($(element).hasClass(inviewClass)) { | |
// run seqeuncer | |
// console.log('running?') | |
sequencer(); | |
listenerRemoveClass(); | |
clearInterval(listener); | |
}; | |
}, 20); | |
}; | |
// init this function on load | |
listenerAddClass(); | |
// listen for when inviewbottom is not applied | |
// removes / resets the 'active' class / animation | |
// restarts the inviewbottom listener | |
var listenerRemoveClass = function() { | |
unlistener = window.setInterval(function() { | |
if (!$(element).hasClass(inviewClass)) { | |
listenerAddClass(); | |
$(element).find('.step').removeClass('step-active'); | |
clearInterval(unlistener); | |
// iterupt sequencer so it can reset properly | |
clearInterval(sequence); | |
} | |
}, 20); | |
}; | |
var sequencer = function() { | |
var count = 0; | |
// sequentially add 'active' class to elements | |
$(element).find('.step:eq(' + count + ')').addClass('step-active'); | |
sequence = window.setInterval(function() { | |
count++; | |
$(element).find('.step:eq(' + count + ')').addClass('step-active'); | |
if (count == ($(element).find('.step').length - 1)) { | |
clearInterval(sequence); | |
}; | |
}, delay); | |
}; | |
}; | |
return { | |
restrict: 'A', | |
link: link | |
}; | |
}); | |
/** | |
* | |
* A custom animation queing directive looks for class 'prplKey' | |
* data from that element 'keytime' at what point the | |
* animation needs to fire. | |
* | |
* @author: Parker Hutchinson | |
* @requires: prplInview | |
* @attr: delay = integer | |
* | |
*/ | |
// TODO: write comments! | |
ngPrplAnimator.directive('prplKeyframer', function() { | |
var link = function(scope, element, attrs) { | |
var keyframe = $(element).find('.keyframe'), | |
listener, | |
unlistener, | |
keyTimer = [], | |
inviewClass = attrs.inviewClass || "inviewbottom"; | |
var startKeyframes = function() { | |
listener = window.setInterval(function() { | |
if ($(element).hasClass(inviewClass)) { | |
playKeyFrames(); | |
resetkeyFrames(); | |
clearInterval(listener); | |
} | |
}, 20); | |
}; | |
// init | |
startKeyframes(); | |
var resetkeyFrames = function() { | |
unlistener = window.setInterval(function() { | |
if (!$(element).hasClass(inviewClass)) { | |
clearInterval(unlistener); | |
for (var i = 0; i < keyTimer.length; i++) { | |
clearTimeout(keyTimer[i]); | |
} | |
$(keyframe).removeClass('play-keyframe'); | |
startKeyframes(); | |
} | |
}, 20); | |
}; | |
var playKeyFrames = function() { | |
// play first keyframe immediatley | |
$(keyframe).each(function(i) { | |
var keyFrameTime = $(this).attr('data-keytime') || 500; | |
// push all timers to | |
keyTimer.push(setTimeout(function() { | |
// console.log($(keyframe[animationIndex])); | |
$(keyframe[i]).addClass('play-keyframe'); | |
}, keyFrameTime)); | |
}); | |
}; | |
}; | |
return { | |
restrict: 'A', | |
link: link | |
}; | |
}); | |
})(window, window.angular); | |
/* | |
* angular-disqus 1.1.0 | |
* http://github.com/kirstein/angular-disqus | |
* | |
* Licensed under the MIT license | |
*/ | |
!function(a, b) { | |
"use strict"; | |
var c = a.module("ngDisqus", []); | |
c.provider("$disqus", function() { | |
function c() { | |
return document.getElementsByTagName("head")[0] || document.getElementsByTagName("body")[0] | |
} | |
function d() { | |
return l || b.disqus_shortname | |
} | |
function e(a, b) { | |
return "//" + a + ".disqus.com/" + b | |
} | |
function f(a) { | |
var b = document.createElement("script"); | |
return b.type = "text/javascript", b.async=!0, b.src = a, b | |
} | |
function g(a, b) { | |
var c, d, e = a.getElementsByTagName("script"); | |
for (d = 0; d < e.length; d += 1) | |
if (c = e[d], ~c.src.indexOf(b)) | |
return !0; | |
return !1 | |
} | |
function h(a, c, d) { | |
b.disqus_identifier = a, b.disqus_url = c, b.disqus_shortname = d | |
} | |
function i() { | |
var c = b.DISQUSWIDGETS; | |
c && a.isFunction(c.getCount) && c.getCount() | |
} | |
function j(a, c) { | |
b.DISQUS.reset({ | |
reload: !0, | |
config: function() { | |
this.page.identifier = c, this.page.url = a.absUrl() | |
} | |
}) | |
} | |
function k(a, b) { | |
var d = c(), h = e(a, b); | |
g(d, h) || d.appendChild(f(h)) | |
} | |
var l, m = "embed.js", n = "count.js"; | |
this.setShortname = function(a) { | |
l = a | |
}, this.$get = ["$location", function(c) { | |
function e(e) { | |
var f = d(); | |
if (!a.isDefined(f)) | |
throw new Error("No disqus shortname defined"); | |
if (!a.isDefined(e)) | |
throw new Error("No disqus thread id defined"); | |
a.isDefined(b.DISQUS) ? j(c, e) : (h(e, c.absUrl(), f), k(f, m)) | |
} | |
function f(a) { | |
h(a, c.absUrl(), l), k(d(), m), k(d(), n), i() | |
} | |
return { | |
commit: e, | |
getShortname: d, | |
loadCount: f | |
} | |
} | |
] | |
}), c.directive("disqus", ["$disqus", function(b) { | |
return { | |
restrict: "AC", | |
replace: !0, | |
scope: { | |
id: "=disqus" | |
}, | |
template: '<div id="disqus_thread"></div>', | |
link: function(c) { | |
c.$watch("id", function(c) { | |
a.isDefined(c) && b.commit(c) | |
}) | |
} | |
} | |
} | |
]), c.directive("disqusIdentifier", ["$disqus", function(a) { | |
return { | |
restrict: "A", | |
link: function(b, c, d) { | |
a.loadCount(d.disqusIdentifier) | |
} | |
} | |
} | |
]) | |
}(angular, this); | |
/*! | |
* imagesLoaded PACKAGED v3.1.5 | |
* JavaScript is all like "You images are done yet or what?" | |
* MIT License | |
*/ | |
/*! | |
* EventEmitter v4.2.6 - git.io/ee | |
* Oliver Caldwell | |
* MIT license | |
* @preserve | |
*/ | |
(function () { | |
/** | |
* Class for managing events. | |
* Can be extended to provide event functionality in other classes. | |
* | |
* @class EventEmitter Manages event registering and emitting. | |
*/ | |
function EventEmitter() {} | |
// Shortcuts to improve speed and size | |
var proto = EventEmitter.prototype; | |
var exports = this; | |
var originalGlobalValue = exports.EventEmitter; | |
/** | |
* Finds the index of the listener for the event in it's storage array. | |
* | |
* @param {Function[]} listeners Array of listeners to search through. | |
* @param {Function} listener Method to look for. | |
* @return {Number} Index of the specified listener, -1 if not found | |
* @api private | |
*/ | |
function indexOfListener(listeners, listener) { | |
var i = listeners.length; | |
while (i--) { | |
if (listeners[i].listener === listener) { | |
return i; | |
} | |
} | |
return - 1; | |
} | |
/** | |
* Alias a method while keeping the context correct, to allow for overwriting of target method. | |
* | |
* @param {String} name The name of the target method. | |
* @return {Function} The aliased method | |
* @api private | |
*/ | |
function alias(name) { | |
return function aliasClosure() { | |
return this[name].apply(this, arguments); | |
}; | |
} | |
/** | |
* Returns the listener array for the specified event. | |
* Will initialise the event object and listener arrays if required. | |
* Will return an object if you use a regex search. The object contains keys for each matched event. So /ba[rz]/ might return an object containing bar and baz. But only if you have either defined them with defineEvent or added some listeners to them. | |
* Each property in the object response is an array of listener functions. | |
* | |
* @param {String|RegExp} evt Name of the event to return the listeners from. | |
* @return {Function[]|Object} All listener functions for the event. | |
*/ | |
proto.getListeners = function getListeners(evt) { | |
var events = this._getEvents(); | |
var response; | |
var key; | |
// Return a concatenated array of all matching events if | |
// the selector is a regular expression. | |
if (typeof evt === 'object') { | |
response = {}; | |
for (key in events) { | |
if (events.hasOwnProperty(key) && evt.test(key)) { | |
response[key] = events[key]; | |
} | |
} | |
} else { | |
response = events[evt] || (events[evt] = []); | |
} | |
return response; | |
}; | |
/** | |
* Takes a list of listener objects and flattens it into a list of listener functions. | |
* | |
* @param {Object[]} listeners Raw listener objects. | |
* @return {Function[]} Just the listener functions. | |
*/ | |
proto.flattenListeners = function flattenListeners(listeners) { | |
var flatListeners = []; | |
var i; | |
for (i = 0; i < listeners.length; i += 1) { | |
flatListeners.push(listeners[i].listener); | |
} | |
return flatListeners; | |
}; | |
/** | |
* Fetches the requested listeners via getListeners but will always return the results inside an object. This is mainly for internal use but others may find it useful. | |
* | |
* @param {String|RegExp} evt Name of the event to return the listeners from. | |
* @return {Object} All listener functions for an event in an object. | |
*/ | |
proto.getListenersAsObject = function getListenersAsObject(evt) { | |
var listeners = this.getListeners(evt); | |
var response; | |
if (listeners instanceof Array) { | |
response = {}; | |
response[evt] = listeners; | |
} | |
return response || listeners; | |
}; | |
/** | |
* Adds a listener function to the specified event. | |
* The listener will not be added if it is a duplicate. | |
* If the listener returns true then it will be removed after it is called. | |
* If you pass a regular expression as the event name then the listener will be added to all events that match it. | |
* | |
* @param {String|RegExp} evt Name of the event to attach the listener to. | |
* @param {Function} listener Method to be called when the event is emitted. If the function returns true then it will be removed after calling. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.addListener = function addListener(evt, listener) { | |
var listeners = this.getListenersAsObject(evt); | |
var listenerIsWrapped = typeof listener === 'object'; | |
var key; | |
for (key in listeners) { | |
if (listeners.hasOwnProperty(key) && indexOfListener(listeners[key], listener) === - 1) { | |
listeners[key].push(listenerIsWrapped ? listener : { | |
listener: listener, | |
once: false | |
}); | |
} | |
} | |
return this; | |
}; | |
/** | |
* Alias of addListener | |
*/ | |
proto.on = alias('addListener'); | |
/** | |
* Semi-alias of addListener. It will add a listener that will be | |
* automatically removed after it's first execution. | |
* | |
* @param {String|RegExp} evt Name of the event to attach the listener to. | |
* @param {Function} listener Method to be called when the event is emitted. If the function returns true then it will be removed after calling. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.addOnceListener = function addOnceListener(evt, listener) { | |
return this.addListener(evt, { | |
listener: listener, | |
once: true | |
}); | |
}; | |
/** | |
* Alias of addOnceListener. | |
*/ | |
proto.once = alias('addOnceListener'); | |
/** | |
* Defines an event name. This is required if you want to use a regex to add a listener to multiple events at once. If you don't do this then how do you expect it to know what event to add to? Should it just add to every possible match for a regex? No. That is scary and bad. | |
* You need to tell it what event names should be matched by a regex. | |
* | |
* @param {String} evt Name of the event to create. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.defineEvent = function defineEvent(evt) { | |
this.getListeners(evt); | |
return this; | |
}; | |
/** | |
* Uses defineEvent to define multiple events. | |
* | |
* @param {String[]} evts An array of event names to define. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.defineEvents = function defineEvents(evts) { | |
for (var i = 0; i < evts.length; i += 1) { | |
this.defineEvent(evts[i]); | |
} | |
return this; | |
}; | |
/** | |
* Removes a listener function from the specified event. | |
* When passed a regular expression as the event name, it will remove the listener from all events that match it. | |
* | |
* @param {String|RegExp} evt Name of the event to remove the listener from. | |
* @param {Function} listener Method to remove from the event. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.removeListener = function removeListener(evt, listener) { | |
var listeners = this.getListenersAsObject(evt); | |
var index; | |
var key; | |
for (key in listeners) { | |
if (listeners.hasOwnProperty(key)) { | |
index = indexOfListener(listeners[key], listener); | |
if (index !== - 1) { | |
listeners[key].splice(index, 1); | |
} | |
} | |
} | |
return this; | |
}; | |
/** | |
* Alias of removeListener | |
*/ | |
proto.off = alias('removeListener'); | |
/** | |
* Adds listeners in bulk using the manipulateListeners method. | |
* If you pass an object as the second argument you can add to multiple events at once. The object should contain key value pairs of events and listeners or listener arrays. You can also pass it an event name and an array of listeners to be added. | |
* You can also pass it a regular expression to add the array of listeners to all events that match it. | |
* Yeah, this function does quite a bit. That's probably a bad thing. | |
* | |
* @param {String|Object|RegExp} evt An event name if you will pass an array of listeners next. An object if you wish to add to multiple events at once. | |
* @param {Function[]} [listeners] An optional array of listener functions to add. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.addListeners = function addListeners(evt, listeners) { | |
// Pass through to manipulateListeners | |
return this.manipulateListeners(false, evt, listeners); | |
}; | |
/** | |
* Removes listeners in bulk using the manipulateListeners method. | |
* If you pass an object as the second argument you can remove from multiple events at once. The object should contain key value pairs of events and listeners or listener arrays. | |
* You can also pass it an event name and an array of listeners to be removed. | |
* You can also pass it a regular expression to remove the listeners from all events that match it. | |
* | |
* @param {String|Object|RegExp} evt An event name if you will pass an array of listeners next. An object if you wish to remove from multiple events at once. | |
* @param {Function[]} [listeners] An optional array of listener functions to remove. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.removeListeners = function removeListeners(evt, listeners) { | |
// Pass through to manipulateListeners | |
return this.manipulateListeners(true, evt, listeners); | |
}; | |
/** | |
* Edits listeners in bulk. The addListeners and removeListeners methods both use this to do their job. You should really use those instead, this is a little lower level. | |
* The first argument will determine if the listeners are removed (true) or added (false). | |
* If you pass an object as the second argument you can add/remove from multiple events at once. The object should contain key value pairs of events and listeners or listener arrays. | |
* You can also pass it an event name and an array of listeners to be added/removed. | |
* You can also pass it a regular expression to manipulate the listeners of all events that match it. | |
* | |
* @param {Boolean} remove True if you want to remove listeners, false if you want to add. | |
* @param {String|Object|RegExp} evt An event name if you will pass an array of listeners next. An object if you wish to add/remove from multiple events at once. | |
* @param {Function[]} [listeners] An optional array of listener functions to add/remove. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.manipulateListeners = function manipulateListeners(remove, evt, listeners) { | |
var i; | |
var value; | |
var single = remove ? this.removeListener : this.addListener; | |
var multiple = remove ? this.removeListeners : this.addListeners; | |
// If evt is an object then pass each of it's properties to this method | |
if (typeof evt === 'object' && !(evt instanceof RegExp)) { | |
for (i in evt) { | |
if (evt.hasOwnProperty(i) && (value = evt[i])) { | |
// Pass the single listener straight through to the singular method | |
if (typeof value === 'function') { | |
single.call(this, i, value); | |
} else { | |
// Otherwise pass back to the multiple function | |
multiple.call(this, i, value); | |
} | |
} | |
} | |
} else { | |
// So evt must be a string | |
// And listeners must be an array of listeners | |
// Loop over it and pass each one to the multiple method | |
i = listeners.length; | |
while (i--) { | |
single.call(this, evt, listeners[i]); | |
} | |
} | |
return this; | |
}; | |
/** | |
* Removes all listeners from a specified event. | |
* If you do not specify an event then all listeners will be removed. | |
* That means every event will be emptied. | |
* You can also pass a regex to remove all events that match it. | |
* | |
* @param {String|RegExp} [evt] Optional name of the event to remove all listeners for. Will remove from every event if not passed. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.removeEvent = function removeEvent(evt) { | |
var type = typeof evt; | |
var events = this._getEvents(); | |
var key; | |
// Remove different things depending on the state of evt | |
if (type === 'string') { | |
// Remove all listeners for the specified event | |
delete events[evt]; | |
} else if (type === 'object') { | |
// Remove all events matching the regex. | |
for (key in events) { | |
if (events.hasOwnProperty(key) && evt.test(key)) { | |
delete events[key]; | |
} | |
} | |
} else { | |
// Remove all listeners in all events | |
delete this._events; | |
} | |
return this; | |
}; | |
/** | |
* Alias of removeEvent. | |
* | |
* Added to mirror the node API. | |
*/ | |
proto.removeAllListeners = alias('removeEvent'); | |
/** | |
* Emits an event of your choice. | |
* When emitted, every listener attached to that event will be executed. | |
* If you pass the optional argument array then those arguments will be passed to every listener upon execution. | |
* Because it uses `apply`, your array of arguments will be passed as if you wrote them out separately. | |
* So they will not arrive within the array on the other side, they will be separate. | |
* You can also pass a regular expression to emit to all events that match it. | |
* | |
* @param {String|RegExp} evt Name of the event to emit and execute listeners for. | |
* @param {Array} [args] Optional array of arguments to be passed to each listener. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.emitEvent = function emitEvent(evt, args) { | |
var listeners = this.getListenersAsObject(evt); | |
var listener; | |
var i; | |
var key; | |
var response; | |
for (key in listeners) { | |
if (listeners.hasOwnProperty(key)) { | |
i = listeners[key].length; | |
while (i--) { | |
// If the listener returns true then it shall be removed from the event | |
// The function is executed either with a basic call or an apply if there is an args array | |
listener = listeners[key][i]; | |
if (listener.once === true) { | |
this.removeListener(evt, listener.listener); | |
} | |
response = listener.listener.apply(this, args || []); | |
if (response === this._getOnceReturnValue()) { | |
this.removeListener(evt, listener.listener); | |
} | |
} | |
} | |
} | |
return this; | |
}; | |
/** | |
* Alias of emitEvent | |
*/ | |
proto.trigger = alias('emitEvent'); | |
/** | |
* Subtly different from emitEvent in that it will pass its arguments on to the listeners, as opposed to taking a single array of arguments to pass on. | |
* As with emitEvent, you can pass a regex in place of the event name to emit to all events that match it. | |
* | |
* @param {String|RegExp} evt Name of the event to emit and execute listeners for. | |
* @param {...*} Optional additional arguments to be passed to each listener. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.emit = function emit(evt) { | |
var args = Array.prototype.slice.call(arguments, 1); | |
return this.emitEvent(evt, args); | |
}; | |
/** | |
* Sets the current value to check against when executing listeners. If a | |
* listeners return value matches the one set here then it will be removed | |
* after execution. This value defaults to true. | |
* | |
* @param {*} value The new value to check for when executing listeners. | |
* @return {Object} Current instance of EventEmitter for chaining. | |
*/ | |
proto.setOnceReturnValue = function setOnceReturnValue(value) { | |
this._onceReturnValue = value; | |
return this; | |
}; | |
/** | |
* Fetches the current value to check against when executing listeners. If | |
* the listeners return value matches this one then it should be removed | |
* automatically. It will return true by default. | |
* | |
* @return {*|Boolean} The current value to check for or the default, true. | |
* @api private | |
*/ | |
proto._getOnceReturnValue = function _getOnceReturnValue() { | |
if (this.hasOwnProperty('_onceReturnValue')) { | |
return this._onceReturnValue; | |
} else { | |
return true; | |
} | |
}; | |
/** | |
* Fetches the events object and creates one if required. | |
* | |
* @return {Object} The events storage object. | |
* @api private | |
*/ | |
proto._getEvents = function _getEvents() { | |
return this._events || (this._events = {}); | |
}; | |
/** | |
* Reverts the global {@link EventEmitter} to its previous value and returns a reference to this version. | |
* | |
* @return {Function} Non conflicting EventEmitter class. | |
*/ | |
EventEmitter.noConflict = function noConflict() { | |
exports.EventEmitter = originalGlobalValue; | |
return EventEmitter; | |
}; | |
// Expose the class either via AMD, CommonJS or the global object | |
if (typeof define === 'function' && define.amd) { | |
define('eventEmitter/EventEmitter', [], function () { | |
return EventEmitter; | |
}); | |
} else if (typeof module === 'object' && module.exports) { | |
module.exports = EventEmitter; | |
} else { | |
this.EventEmitter = EventEmitter; | |
} | |
}.call(this)); | |
/*! | |
* eventie v1.0.4 | |
* event binding helper | |
* eventie.bind( elem, 'click', myFn ) | |
* eventie.unbind( elem, 'click', myFn ) | |
*/ | |
/*jshint browser: true, undef: true, unused: true */ | |
/*global define: false */ | |
( function( window ) { | |
var docElem = document.documentElement; | |
var bind = function() {}; | |
function getIEEvent( obj ) { | |
var event = window.event; | |
// add event.target | |
event.target = event.target || event.srcElement || obj; | |
return event; | |
} | |
if ( docElem.addEventListener ) { | |
bind = function( obj, type, fn ) { | |
obj.addEventListener( type, fn, false ); | |
}; | |
} else if ( docElem.attachEvent ) { | |
bind = function( obj, type, fn ) { | |
obj[ type + fn ] = fn.handleEvent ? | |
function() { | |
var event = getIEEvent( obj ); | |
fn.handleEvent.call( fn, event ); | |
} : | |
function() { | |
var event = getIEEvent( obj ); | |
fn.call( obj, event ); | |
}; | |
obj.attachEvent( "on" + type, obj[ type + fn ] ); | |
}; | |
} | |
var unbind = function() {}; | |
if ( docElem.removeEventListener ) { | |
unbind = function( obj, type, fn ) { | |
obj.removeEventListener( type, fn, false ); | |
}; | |
} else if ( docElem.detachEvent ) { | |
unbind = function( obj, type, fn ) { | |
obj.detachEvent( "on" + type, obj[ type + fn ] ); | |
try { | |
delete obj[ type + fn ]; | |
} catch ( err ) { | |
// can't delete window object properties | |
obj[ type + fn ] = undefined; | |
} | |
}; | |
} | |
var eventie = { | |
bind: bind, | |
unbind: unbind | |
}; | |
// transport | |
if ( typeof define === 'function' && define.amd ) { | |
// AMD | |
define( 'eventie/eventie', eventie ); | |
} else { | |
// browser global | |
window.eventie = eventie; | |
} | |
})( this ); | |
/*! | |
* imagesLoaded v3.1.5 | |
* JavaScript is all like "You images are done yet or what?" | |
* MIT License | |
*/ | |
( function( window, factory ) { | |
// universal module definition | |
/*global define: false, module: false, require: false */ | |
if ( typeof define === 'function' && define.amd ) { | |
// AMD | |
define( [ | |
'eventEmitter/EventEmitter', | |
'eventie/eventie' | |
], function( EventEmitter, eventie ) { | |
return factory( window, EventEmitter, eventie ); | |
}); | |
} else if ( typeof exports === 'object' ) { | |
// CommonJS | |
module.exports = factory( | |
window, | |
require('eventEmitter'), | |
require('eventie') | |
); | |
} else { | |
// browser global | |
window.imagesLoaded = factory( | |
window, | |
window.EventEmitter, | |
window.eventie | |
); | |
} | |
})( this, | |
// -------------------------- factory -------------------------- // | |
function factory( window, EventEmitter, eventie ) { | |
var $ = window.jQuery; | |
var console = window.console; | |
var hasConsole = typeof console !== 'undefined'; | |
// -------------------------- helpers -------------------------- // | |
// extend objects | |
function extend( a, b ) { | |
for ( var prop in b ) { | |
a[ prop ] = b[ prop ]; | |
} | |
return a; | |
} | |
var objToString = Object.prototype.toString; | |
function isArray( obj ) { | |
return objToString.call( obj ) === '[object Array]'; | |
} | |
// turn element or nodeList into an array | |
function makeArray( obj ) { | |
var ary = []; | |
if ( isArray( obj ) ) { | |
// use object if already an array | |
ary = obj; | |
} else if ( typeof obj.length === 'number' ) { | |
// convert nodeList to array | |
for ( var i = 0, len = obj.length; i < len; i++ ) { | |
ary.push( obj[i] ); | |
} | |
} else { | |
// array of single index | |
ary.push( obj ); | |
} | |
return ary; | |
} | |
// -------------------------- imagesLoaded -------------------------- // | |
/** | |
* @param {Array, Element, NodeList, String} elem | |
* @param {Object or Function} options - if function, use as callback | |
* @param {Function} onAlways - callback function | |
*/ | |
function ImagesLoaded( elem, options, onAlways ) { | |
// coerce ImagesLoaded() without new, to be new ImagesLoaded() | |
if ( !( this instanceof ImagesLoaded ) ) { | |
return new ImagesLoaded( elem, options ); | |
} | |
// use elem as selector string | |
if ( typeof elem === 'string' ) { | |
elem = document.querySelectorAll( elem ); | |
} | |
this.elements = makeArray( elem ); | |
this.options = extend( {}, this.options ); | |
if ( typeof options === 'function' ) { | |
onAlways = options; | |
} else { | |
extend( this.options, options ); | |
} | |
if ( onAlways ) { | |
this.on( 'always', onAlways ); | |
} | |
this.getImages(); | |
if ( $ ) { | |
// add jQuery Deferred object | |
this.jqDeferred = new $.Deferred(); | |
} | |
// HACK check async to allow time to bind listeners | |
var _this = this; | |
setTimeout( function() { | |
_this.check(); | |
}); | |
} | |
ImagesLoaded.prototype = new EventEmitter(); | |
ImagesLoaded.prototype.options = {}; | |
ImagesLoaded.prototype.getImages = function() { | |
this.images = []; | |
// filter & find items if we have an item selector | |
for ( var i = 0, len = this.elements.length; i < len; i++ ) { | |
var elem = this.elements[i]; | |
// filter siblings | |
if ( elem.nodeName === 'IMG' ) { | |
this.addImage( elem ); | |
} | |
// find children | |
// no non-element nodes, #143 | |
if ( !elem.nodeType || !( elem.nodeType === 1 || elem.nodeType === 9 ) ) { | |
continue; | |
} | |
var childElems = elem.querySelectorAll('img'); | |
// concat childElems to filterFound array | |
for ( var j = 0, jLen = childElems.length; j < jLen; j++ ) { | |
var img = childElems[j]; | |
this.addImage( img ); | |
} | |
} | |
}; | |
/** | |
* @param {Image} img | |
*/ | |
ImagesLoaded.prototype.addImage = function( img ) { | |
var loadingImage = new LoadingImage( img ); | |
this.images.push( loadingImage ); | |
}; | |
ImagesLoaded.prototype.check = function() { | |
var _this = this; | |
var checkedCount = 0; | |
var length = this.images.length; | |
this.hasAnyBroken = false; | |
// complete if no images | |
if ( !length ) { | |
this.complete(); | |
return; | |
} | |
function onConfirm( image, message ) { | |
if ( _this.options.debug && hasConsole ) { | |
console.log( 'confirm', image, message ); | |
} | |
_this.progress( image ); | |
checkedCount++; | |
if ( checkedCount === length ) { | |
_this.complete(); | |
} | |
return true; // bind once | |
} | |
for ( var i = 0; i < length; i++ ) { | |
var loadingImage = this.images[i]; | |
loadingImage.on( 'confirm', onConfirm ); | |
loadingImage.check(); | |
} | |
}; | |
ImagesLoaded.prototype.progress = function( image ) { | |
this.hasAnyBroken = this.hasAnyBroken || !image.isLoaded; | |
// HACK - Chrome triggers event before object properties have changed. #83 | |
var _this = this; | |
setTimeout( function() { | |
_this.emit( 'progress', _this, image ); | |
if ( _this.jqDeferred && _this.jqDeferred.notify ) { | |
_this.jqDeferred.notify( _this, image ); | |
} | |
}); | |
}; | |
ImagesLoaded.prototype.complete = function() { | |
var eventName = this.hasAnyBroken ? 'fail' : 'done'; | |
this.isComplete = true; | |
var _this = this; | |
// HACK - another setTimeout so that confirm happens after progress | |
setTimeout( function() { | |
_this.emit( eventName, _this ); | |
_this.emit( 'always', _this ); | |
if ( _this.jqDeferred ) { | |
var jqMethod = _this.hasAnyBroken ? 'reject' : 'resolve'; | |
_this.jqDeferred[ jqMethod ]( _this ); | |
} | |
}); | |
}; | |
// -------------------------- jquery -------------------------- // | |
if ( $ ) { | |
$.fn.imagesLoaded = function( options, callback ) { | |
var instance = new ImagesLoaded( this, options, callback ); | |
return instance.jqDeferred.promise( $(this) ); | |
}; | |
} | |
// -------------------------- -------------------------- // | |
function LoadingImage( img ) { | |
this.img = img; | |
} | |
LoadingImage.prototype = new EventEmitter(); | |
LoadingImage.prototype.check = function() { | |
// first check cached any previous images that have same src | |
var resource = cache[ this.img.src ] || new Resource( this.img.src ); | |
if ( resource.isConfirmed ) { | |
this.confirm( resource.isLoaded, 'cached was confirmed' ); | |
return; | |
} | |
// If complete is true and browser supports natural sizes, | |
// try to check for image status manually. | |
if ( this.img.complete && this.img.naturalWidth !== undefined ) { | |
// report based on naturalWidth | |
this.confirm( this.img.naturalWidth !== 0, 'naturalWidth' ); | |
return; | |
} | |
// If none of the checks above matched, simulate loading on detached element. | |
var _this = this; | |
resource.on( 'confirm', function( resrc, message ) { | |
_this.confirm( resrc.isLoaded, message ); | |
return true; | |
}); | |
resource.check(); | |
}; | |
LoadingImage.prototype.confirm = function( isLoaded, message ) { | |
this.isLoaded = isLoaded; | |
this.emit( 'confirm', this, message ); | |
}; | |
// -------------------------- Resource -------------------------- // | |
// Resource checks each src, only once | |
// separate class from LoadingImage to prevent memory leaks. See #115 | |
var cache = {}; | |
function Resource( src ) { | |
this.src = src; | |
// add to cache | |
cache[ src ] = this; | |
} | |
Resource.prototype = new EventEmitter(); | |
Resource.prototype.check = function() { | |
// only trigger checking once | |
if ( this.isChecked ) { | |
return; | |
} | |
// simulate loading on detached element | |
var proxyImage = new Image(); | |
eventie.bind( proxyImage, 'load', this ); | |
eventie.bind( proxyImage, 'error', this ); | |
proxyImage.src = this.src; | |
// set flag | |
this.isChecked = true; | |
}; | |
// ----- events ----- // | |
// trigger specified handler for event type | |
Resource.prototype.handleEvent = function( event ) { | |
var method = 'on' + event.type; | |
if ( this[ method ] ) { | |
this[ method ]( event ); | |
} | |
}; | |
Resource.prototype.onload = function( event ) { | |
this.confirm( true, 'onload' ); | |
this.unbindProxyEvents( event ); | |
}; | |
Resource.prototype.onerror = function( event ) { | |
this.confirm( false, 'onerror' ); | |
this.unbindProxyEvents( event ); | |
}; | |
// ----- confirm ----- // | |
Resource.prototype.confirm = function( isLoaded, message ) { | |
this.isConfirmed = true; | |
this.isLoaded = isLoaded; | |
this.emit( 'confirm', this, message ); | |
}; | |
Resource.prototype.unbindProxyEvents = function( event ) { | |
eventie.unbind( event.target, 'load', this ); | |
eventie.unbind( event.target, 'error', this ); | |
}; | |
// ----- ----- // | |
return ImagesLoaded; | |
}); | |
/* | |
* iosSlider - http://iosscripts.com/iosslider/ | |
* | |
* Touch Enabled, Responsive jQuery Horizontal Content Slider/Carousel/Image Gallery Plugin | |
* | |
* A jQuery plugin which allows you to integrate a customizable, cross-browser | |
* content slider into your web presence. Designed for use as a content slider, carousel, | |
* scrolling website banner, or image gallery. | |
* | |
* Copyright (c) 2013 Marc Whitbread | |
* | |
* Version: v1.3.16 (09/24/2013) | |
* Minimum requirements: jQuery v1.4+ | |
* | |
* Advanced requirements: | |
* 1) jQuery bind() click event override on slide requires jQuery v1.6+ | |
* | |
* Terms of use: | |
* | |
* 1) iosSlider is licensed under the Creative Commons – Attribution-NonCommercial 3.0 License. | |
* 2) You may use iosSlider free for personal or non-profit purposes, without restriction. | |
* Attribution is not required but always appreciated. For commercial projects, you | |
* must purchase a license. You may download and play with the script before deciding to | |
* fully implement it in your project. Making sure you are satisfied, and knowing iosSlider | |
* is the right script for your project is paramount. | |
* 3) You are not permitted to make the resources found on iosscripts.com available for | |
* distribution elsewhere "as is" without prior consent. If you would like to feature | |
* iosSlider on your site, please do not link directly to the resource zip files. Please | |
* link to the appropriate page on iosscripts.com where users can find the download. | |
* | |
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY | |
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | |
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE | |
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | |
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE | |
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED | |
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | |
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED | |
* OF THE POSSIBILITY OF SUCH DAMAGE. | |
*/ | |
(function(b) { | |
var na = 0, W = 0, da = 0, T = 0, za = "ontouchstart"in window, Ba = "onorientationchange"in window, ea=!1, aa=!1, X=!1, oa=!1, ha=!1, ia = "pointer", sa = "pointer", ja = [], J = [], ta = [], $ = [], z = [], ba = [], B = [], m = [], s = [], ua = [], fa = [], e = { | |
showScrollbar: function(a, e) { | |
a.scrollbarHide && b("." + e).css({ | |
opacity: a.scrollbarOpacity, | |
filter: "alpha(opacity:" + 100 * a.scrollbarOpacity + ")" | |
}) | |
}, | |
hideScrollbar: function(b, g, c, f, h, d, m, s, B, z) { | |
if (b.scrollbar && b.scrollbarHide) | |
for (var t = c; t < c + 25; t++) | |
g[g.length] = e.hideScrollbarIntervalTimer(10 * t, f[c], (c + 24 - t) / 24, h, d, m, s, B, z, b) | |
}, | |
hideScrollbarInterval: function(a, g, c, f, h, d, m, B, z) { | |
T =- 1 * a / s[B] * (h - d - m - f); | |
e.setSliderOffset("." + c, T); | |
b("." + c).css({ | |
opacity: z.scrollbarOpacity * g, | |
filter: "alpha(opacity:" + 100 * z.scrollbarOpacity * g + ")" | |
}) | |
}, | |
slowScrollHorizontalInterval: function(a, g, c, f, h, d, N, O, L, K, t, w, x, y, v, q, G, p, n) { | |
if (n.infiniteSlider) { | |
if (c<=-1 * s[q]) { | |
var r = b(a).width(); | |
if (c<=-1 * ua[q]) { | |
var u =- 1 * t[0]; | |
b(g).each(function(c) { | |
e.setSliderOffset(b(g)[c], u + G); | |
c < w.length && (w[c] =- 1 * u); | |
u += v[c] | |
}); | |
c +=- 1 * w[0]; | |
m[q] =- 1 * w[0] + G; | |
s[q] = m[q] + r - d; | |
B[q] = 0 | |
} else { | |
var k = 0, D = e.getSliderOffset(b(g[0]), "x"); | |
b(g).each(function(b) { | |
e.getSliderOffset(this, "x") < D && (D = e.getSliderOffset(this, "x"), k = b) | |
}); | |
x = m[q] + r; | |
e.setSliderOffset(b(g)[k], x); | |
m[q] =- 1 * w[1] + G; | |
s[q] = m[q] + r - d; | |
w.splice(0, 1); | |
w.splice(w.length, 0, - 1 * x + G); | |
B[q]++ | |
} | |
} | |
if (c>=-1 * m[q] || 0 <= c) { | |
r = b(a).width(); | |
if (0 <= c) | |
for (u =- 1 * t[0], b(g).each(function(c) { | |
e.setSliderOffset(b(g)[c], u + G); | |
c < w.length && (w[c] =- 1 * u); | |
u += v[c] | |
}), c-=-1 * w[0], m[q] =- 1 * w[0] + G, s[q] = m[q] + r - d, B[q] = y; 0<-1 * w[0] - r + G;) { | |
var A = 0, I = e.getSliderOffset(b(g[0]), "x"); | |
b(g).each(function(c) { | |
e.getSliderOffset(this, "x") > I && (I = e.getSliderOffset(this, "x"), A = c) | |
}); | |
x = m[q] - v[A]; | |
e.setSliderOffset(b(g)[A], x); | |
w.splice(0, 0, - 1 * x + G); | |
w.splice(w.length - 1, 1); | |
m[q] =- 1 * w[0] + G; | |
s[q] = m[q] + r - d; | |
B[q]--; | |
z[q]++ | |
} | |
0 > c && (A = 0, I = e.getSliderOffset(b(g[0]), "x"), b(g).each(function(c) { | |
e.getSliderOffset(this, "x") > I && (I = e.getSliderOffset(this, "x"), A = c) | |
}), x = m[q] - v[A], e.setSliderOffset(b(g)[A], x), w.splice(0, 0, - 1 * x + G), w.splice(w.length - 1, 1), m[q] =- 1 * w[0] + G, s[q] = m[q] + r - d, B[q]--) | |
} | |
} | |
t=!1; | |
d = e.calcActiveOffset(n, c, w, d, B[q], y, K, q); | |
x = (d + B[q] + y)%y; | |
n.infiniteSlider ? x != ba[q] && (t=!0) : d != z[q] && (t=!0); | |
if (t && (y = new e.args("change", n, a, b(a).children(":eq(" + x + ")"), x, p), b(a).parent().data("args", y), "" != n.onSlideChange)) | |
n.onSlideChange(y); | |
z[q] = d; | |
ba[q] = x; | |
c = Math.floor(c); | |
e.setSliderOffset(a, c); | |
n.scrollbar && (T = Math.floor(( - 1 * c - m[q] + G) / (s[q] - m[q] + G) * (N - O - h)), a = h - L, c>=-1 * m[q] + G ? (a = h - L - - 1 * T, e.setSliderOffset(b("." + f), 0)) : (c<=-1 * s[q] + 1 && (a = N - O - L - T), e.setSliderOffset(b("." + f), T)), b("." + f).css({ | |
width: a + "px" | |
})) | |
}, | |
slowScrollHorizontal: function(a, g, c, f, h, d, N, O, L, K, t, w, x, y, v, q, G, p, n, r, u) { | |
var k = e.getSliderOffset(a, "x"); | |
d = []; | |
var D = 0, A = 25 / 1024 * O; | |
frictionCoefficient = u.frictionCoefficient; | |
elasticFrictionCoefficient = u.elasticFrictionCoefficient; | |
snapFrictionCoefficient = u.snapFrictionCoefficient; | |
h > u.snapVelocityThreshold && u.snapToChildren&&!n ? D = 1 : h<-1 * u.snapVelocityThreshold && u.snapToChildren&&!n && (D =- 1); | |
h<-1 * A ? h =- 1 * A : h > A && (h = A); | |
b(a)[0] !== b(p)[0] && (D*=-1, h*=-2); | |
p = B[v]; | |
if (u.infiniteSlider) | |
var I = m[v], l = s[v]; | |
n = []; | |
for (var A = [], E = 0; E < x.length; E++) | |
n[E] = x[E], E < g.length && (A[E] = e.getSliderOffset(b(g[E]), "x")); | |
for (; 1 < h||-1 > h;) { | |
h*=frictionCoefficient; | |
k += h; | |
(k>-1 * m[v] || k<-1 * s[v])&&!u.infiniteSlider && (h*=elasticFrictionCoefficient, k += h); | |
if (u.infiniteSlider) { | |
if (k<=-1 * l) { | |
for (var l = b(a).width(), J = 0, P = A[0], E = 0; E < A.length; E++) | |
A[E] < P && (P = A[E], J = E); | |
E = I + l; | |
A[J] = E; | |
I =- 1 * n[1] + r; | |
l = I + l - O; | |
n.splice(0, 1); | |
n.splice(n.length, 0, - 1 * E + r); | |
p++ | |
} | |
if (k>=-1 * I) { | |
l = b(a).width(); | |
J = 0; | |
P = A[0]; | |
for (E = 0; E < A.length; E++) | |
A[E] > P && (P = A[E], J = E); | |
E = I - y[J]; | |
A[J] = E; | |
n.splice(0, 0, - 1 * E + r); | |
n.splice(n.length - 1, 1); | |
I =- 1 * n[0] + r; | |
l = I + l - O; | |
p-- | |
} | |
} | |
d[d.length] = k | |
} | |
A=!1; | |
h = e.calcActiveOffset(u, k, n, O, p, G, z[v], v); | |
I = (h + p + G)%G; | |
u.snapToChildren && (u.infiniteSlider ? I != ba[v] && (A=!0) : h != z[v] && (A=!0), 0 > D&&!A ? (h++, h >= x.length&&!u.infiniteSlider && (h = x.length - 1)) : 0 < D&&!A && (h--, 0 > h&&!u.infiniteSlider && (h = 0))); | |
if (u.snapToChildren || (k>-1 * m[v] || k<-1 * s[v])&&!u.infiniteSlider) { | |
(k>-1 * m[v] || k<-1 * s[v])&&!u.infiniteSlider ? d.splice(0, d.length) : (d.splice(0.1 * d.length, d.length), k = 0 < d.length ? d[d.length - 1] : k); | |
for (; k < n[h] - 0.5 || k > n[h] + 0.5;) | |
k = (k - n[h]) * snapFrictionCoefficient + n[h], d[d.length] = k; | |
d[d.length] = n[h] | |
} | |
D = 1; | |
0 != d.length%2 && (D = 0); | |
for (k = 0; k < c.length; k++) | |
clearTimeout(c[k]); | |
p = (h + p + G)%G; | |
I = 0; | |
for (k = D; k < d.length; k += 2) | |
if (k == D || 1 < Math.abs(d[k] - I) || k >= d.length - 2) | |
I = d[k], c[c.length] = e.slowScrollHorizontalIntervalTimer(10 * k, a, g, d[k], f, N, O, L, K, t, h, w, x, q, G, y, v, r, p, u); | |
I = (h + B[v] + G)%G; | |
"" != u.onSlideComplete && 1 < d.length && (c[c.length] = e.onSlideCompleteTimer(10 * (k + 1), u, a, b(a).children(":eq(" + I + ")"), p, v)); | |
$[v] = c; | |
e.hideScrollbar(u, c, k, d, f, N, O, K, t, v) | |
}, | |
onSlideComplete: function(a, g, c, f, h) { | |
c = new e.args("complete", a, b(g), c, f, f); | |
b(g).parent().data("args", c); | |
if ("" != a.onSlideComplete) | |
a.onSlideComplete(c) | |
}, | |
getSliderOffset: function(a, e) { | |
var c = 0; | |
e = "x" == e ? 4 : 5; | |
if (!ea || aa || X) | |
c = parseInt(b(a).css("left"), 10); | |
else { | |
for (var c = ["-webkit-transform", "-moz-transform", "transform"], f, h = 0; h < c.length; h++) | |
if (void 0 != b(a).css(c[h]) && 0 < b(a).css(c[h]).length) { | |
f = b(a).css(c[h]).split(","); | |
break | |
} | |
c = void 0 == f[e] ? 0 : parseInt(f[e], 10) | |
} | |
return c | |
}, | |
setSliderOffset: function(a, e) { | |
e = parseInt(e, 10); | |
!ea || aa || X ? b(a).css({ | |
left: e + "px" | |
}) : b(a).css({ | |
webkitTransform: "matrix(1,0,0,1," + e + ",0)", | |
MozTransform: "matrix(1,0,0,1," + e + ",0)", | |
transform: "matrix(1,0,0,1," + e + ",0)" | |
}) | |
}, | |
setBrowserInfo: function() { | |
null != navigator.userAgent.match("WebKit") ? (ia = "-webkit-grab", sa = "-webkit-grabbing") : null != navigator.userAgent.match("Gecko") ? (ha=!0, ia = "move", sa = "-moz-grabbing") : null != navigator.userAgent.match("MSIE 7") ? oa = aa=!0 : null != navigator.userAgent.match("MSIE 8") ? oa = X=!0 : null != navigator.userAgent.match("MSIE 9") && (oa=!0) | |
}, | |
has3DTransform: function() { | |
var a = !1, e = b("<div />").css({ | |
webkitTransform: "matrix(1,1,1,1,1,1)", | |
MozTransform: "matrix(1,1,1,1,1,1)", | |
transform: "matrix(1,1,1,1,1,1)" | |
}); | |
"" == e.attr("style") ? a=!1 : ha&&!za && 21 <= parseInt(navigator.userAgent.split("/")[3], 10) ? a=!1 : void 0 != e.attr("style") && (a=!0); | |
return a | |
}, | |
getSlideNumber: function(b, e, c) { | |
return (b - B[e] + c)%c | |
}, | |
calcActiveOffset: function(b, e, c, f, h, d, m, s) { | |
h=!1; | |
b = []; | |
var z; | |
e > c[0] && (z = 0); | |
e < c[c.length - 1] && (z = d - 1); | |
for (d = 0; d < c.length; d++) | |
c[d] <= e && c[d] > e - f && (h || c[d] == e || (b[b.length] = c[d - 1]), b[b.length] = c[d], h=!0); | |
0 == b.length && (b[0] = c[c.length - 1]); | |
for (d = h = 0; d < b.length; d++) | |
m = Math.abs(e - b[d]), m < f && (h = b[d], f = m); | |
for (d = 0; d < c.length; d++) | |
h == c[d] && (z = d); | |
return z | |
}, | |
changeSlide: function(a, g, c, f, h, d, m, s, L, K, t, w, x, y, v, q, G, p) { | |
e.autoSlidePause(y); | |
for (var n = 0; n < f.length; n++) | |
clearTimeout(f[n]); | |
var r = Math.ceil(p.autoSlideTransTimer / 10) + 1, u = e.getSliderOffset(g, "x"), k = w[a], D = k - u; | |
if (p.infiniteSlider) | |
for (a = (a - B[y] + 2 * q)%q, n=!1, 0 == a && 2 == q && (a = q, w[a] = w[a - 1] - b(c).eq(0).outerWidth(!0), n=!0), k = w[a], D = k - u, k = [w[a] - b(g).width(), w[a] + b(g).width()], n && w.splice(w.length - 1, 1), n = 0; n < k.length; n++) | |
Math.abs(k[n] - u) < Math.abs(D) && (D = k[n] - u); | |
var k = [], A; | |
e.showScrollbar(p, h); | |
for (n = 0; n <= r; n++) | |
A = n, A/=r, A--, A = u + D * (Math.pow(A, 5) + 1), k[k.length] = A; | |
r = (a + B[y] + q)%q; | |
for (n = u = 0; n < k.length; n++) { | |
if (0 == n || 1 < Math.abs(k[n] - u) || n >= k.length - 2) | |
u = k[n], f[n] = e.slowScrollHorizontalIntervalTimer(10 * (n + 1), g, c, k[n], h, d, m, s, L, K, a, t, w, v, q, x, y, G, r, p); | |
0 == n && "" != p.onSlideStart && (D = (z[y] + B[y] + q)%q, p.onSlideStart(new e.args("start", p, g, b(g).children(":eq(" + D + ")"), D, a))) | |
} | |
u = !1; | |
p.infiniteSlider ? r != ba[y] && (u=!0) : a != z[y] && (u=!0); | |
u && "" != p.onSlideComplete && (f[f.length] = e.onSlideCompleteTimer(10 * (n + 1), p, g, b(g).children(":eq(" + r + ")"), r, y)); | |
$[y] = f; | |
e.hideScrollbar(p, f, n, k, h, d, m, L, K, y); | |
e.autoSlide(g, c, f, h, d, m, s, L, K, t, w, x, y, v, q, G, p) | |
}, | |
autoSlide: function(b, g, c, f, h, d, m, s, L, K, t, w, x, y, v, q, G) { | |
if (!J[x].autoSlide) | |
return !1; | |
e.autoSlidePause(x); | |
ja[x] = setTimeout(function() { | |
!G.infiniteSlider && z[x] > t.length - 1 && (z[x] -= v); | |
e.changeSlide((z[x] + B[x] + t.length + 1)%t.length, b, g, c, f, h, d, m, s, L, K, t, w, x, y, v, q, G); | |
e.autoSlide(b, g, c, f, h, d, m, s, L, K, t, w, x, y, v, q, G) | |
}, G.autoSlideTimer + G.autoSlideTransTimer) | |
}, | |
autoSlidePause: function(b) { | |
clearTimeout(ja[b]) | |
}, | |
isUnselectable: function(a, e) { | |
return "" != e.unselectableSelector && 1 == b(a).closest(e.unselectableSelector).length?!0 : !1 | |
}, | |
slowScrollHorizontalIntervalTimer: function(b, g, c, f, h, d, m, s, z, B, t, w, x, y, v, q, G, p, n, r) { | |
return setTimeout(function() { | |
e.slowScrollHorizontalInterval(g, c, f, h, d, m, s, z, B, t, w, x, y, v, q, G, p, n, r) | |
}, b) | |
}, | |
onSlideCompleteTimer: function(b, g, c, f, h, d) { | |
return setTimeout(function() { | |
e.onSlideComplete(g, c, f, h, d) | |
}, b) | |
}, | |
hideScrollbarIntervalTimer: function(b, g, c, f, h, d, m, s, z, B) { | |
return setTimeout(function() { | |
e.hideScrollbarInterval(g, c, f, h, d, m, s, z, B) | |
}, b) | |
}, | |
args: function(a, g, c, f, h, d) { | |
this.prevSlideNumber = void 0 == b(c).parent().data("args") ? void 0 : b(c).parent().data("args").prevSlideNumber; | |
this.prevSlideObject = void 0 == b(c).parent().data("args") ? void 0 : b(c).parent().data("args").prevSlideObject; | |
this.targetSlideNumber = d + 1; | |
this.targetSlideObject = b(c).children(":eq(" + d + ")"); | |
this.slideChanged=!1; | |
"load" == a ? this.targetSlideObject = this.targetSlideNumber = void 0 : "start" == a ? this.targetSlideObject = this.targetSlideNumber = void 0 : "change" == a ? (this.slideChanged=!0, this.prevSlideNumber = void 0 == b(c).parent().data("args") ? g.startAtSlide : b(c).parent().data("args").currentSlideNumber, this.prevSlideObject = b(c).children(":eq(" + this.prevSlideNumber + ")")) : "complete" == a && (this.slideChanged = b(c).parent().data("args").slideChanged); | |
this.settings = g; | |
this.data = b(c).parent().data("iosslider"); | |
this.sliderObject = c; | |
this.sliderContainerObject = b(c).parent(); | |
this.currentSlideObject = f; | |
this.currentSlideNumber = h + 1; | |
this.currentSliderOffset =- 1 * e.getSliderOffset(c, "x") | |
}, | |
preventDrag: function(b) { | |
b.preventDefault() | |
}, | |
preventClick: function(b) { | |
b.stopImmediatePropagation(); | |
return !1 | |
}, | |
enableClick: function() { | |
return !0 | |
} | |
}; | |
e.setBrowserInfo(); | |
var V = { | |
init: function(a, g) { | |
ea = e.has3DTransform(); | |
var c = b.extend(!0, { | |
elasticPullResistance: 0.6, | |
frictionCoefficient: 0.92, | |
elasticFrictionCoefficient: 0.6, | |
snapFrictionCoefficient: 0.92, | |
snapToChildren: !1, | |
snapSlideCenter: !1, | |
startAtSlide: 1, | |
scrollbar: !1, | |
scrollbarDrag: !1, | |
scrollbarHide: !0, | |
scrollbarLocation: "top", | |
scrollbarContainer: "", | |
scrollbarOpacity: 0.4, | |
scrollbarHeight: "4px", | |
scrollbarBorder: "0", | |
scrollbarMargin: "5px", | |
scrollbarBackground: "#000", | |
scrollbarBorderRadius: "100px", | |
scrollbarShadow: "0 0 0 #000", | |
scrollbarElasticPullResistance: 0.9, | |
desktopClickDrag: !1, | |
keyboardControls: !1, | |
tabToAdvance: !1, | |
responsiveSlideContainer: !0, | |
responsiveSlides: !0, | |
navSlideSelector: "", | |
navPrevSelector: "", | |
navNextSelector: "", | |
autoSlideToggleSelector: "", | |
autoSlide: !1, | |
autoSlideTimer: 5E3, | |
autoSlideTransTimer: 750, | |
autoSlideHoverPause: !0, | |
infiniteSlider: !1, | |
snapVelocityThreshold: 5, | |
slideStartVelocityThreshold: 0, | |
horizontalSlideLockThreshold: 5, | |
verticalSlideLockThreshold: 3, | |
stageCSS: { | |
position: "relative", | |
top: "0", | |
left: "0", | |
overflow: "hidden", | |
zIndex: 1 | |
}, | |
unselectableSelector: "", | |
onSliderLoaded: "", | |
onSliderUpdate: "", | |
onSliderResize: "", | |
onSlideStart: "", | |
onSlideChange: "", | |
onSlideComplete: "" | |
}, a); | |
void 0 == g && (g = this); | |
return b(g).each(function(a) { | |
function g() { | |
e.autoSlidePause(d); | |
va = b(F).find("a"); | |
ja = b(F).find("[onclick]"); | |
pa = b(F).find("*"); | |
b(n).css("width", ""); | |
b(n).css("height", ""); | |
b(F).css("width", ""); | |
C = b(F).children().not("script").get(); | |
ga = []; | |
M = []; | |
c.responsiveSlides && b(C).css("width", ""); | |
s[d] = 0; | |
l = []; | |
q = b(n).parent().width(); | |
r = b(n).outerWidth(!0); | |
c.responsiveSlideContainer && (r = b(n).outerWidth(!0) > q ? q : b(n).width()); | |
b(n).css({ | |
position: c.stageCSS.position, | |
top: c.stageCSS.top, | |
left: c.stageCSS.left, | |
overflow: c.stageCSS.overflow, | |
zIndex: c.stageCSS.zIndex, | |
webkitPerspective: 1E3, | |
webkitBackfaceVisibility: "hidden", | |
msTouchAction: "pan-y", | |
width: r | |
}); | |
b(c.unselectableSelector).css({ | |
cursor: "default" | |
}); | |
for (var a = 0; a < C.length; a++) { | |
ga[a] = b(C[a]).width(); | |
M[a] = b(C[a]).outerWidth(!0); | |
var h = M[a]; | |
c.responsiveSlides && (M[a] > r ? (h = r +- 1 * (M[a] - ga[a]), ga[a] = h, M[a] = r) : h = ga[a], b(C[a]).css({ | |
width: h | |
})); | |
b(C[a]).css({ | |
webkitBackfaceVisibility: "hidden", | |
overflow: "hidden", | |
position: "absolute" | |
}); | |
l[a] =- 1 * s[d]; | |
s[d] = s[d] + h + (M[a] - ga[a]) | |
} | |
c.snapSlideCenter && (p = 0.5 * (r - M[0]), c.responsiveSlides && M[0] > r && (p = 0)); | |
ua[d] = 2 * s[d]; | |
for (a = 0; a < C.length; a++) | |
e.setSliderOffset(b(C[a]), - 1 * l[a] + s[d] + p), l[a] -= s[d]; | |
if (!c.infiniteSlider&&!c.snapSlideCenter) { | |
for (a = 0; a < l.length&&!(l[a]<=-1 * (2 * s[d] - r)); a++) | |
ha = a; | |
l.splice(ha + 1, l.length); | |
l[l.length] =- 1 * (2 * s[d] - r) | |
} | |
for (a = 0; a < l.length; a++) | |
E[a] = l[a]; | |
I && (J[d].startAtSlide = J[d].startAtSlide > l.length ? l.length : J[d].startAtSlide, c.infiniteSlider ? (J[d].startAtSlide = (J[d].startAtSlide - 1 + H)%H, z[d] = J[d].startAtSlide) : (J[d].startAtSlide = 0 > J[d].startAtSlide - 1 ? l.length - 1 : J[d].startAtSlide, z[d] = J[d].startAtSlide - 1), ba[d] = z[d]); | |
m[d] = s[d] + p; | |
b(F).css({ | |
position: "relative", | |
cursor: ia, | |
webkitPerspective: "0", | |
webkitBackfaceVisibility: "hidden", | |
width: s[d] + "px" | |
}); | |
R = s[d]; | |
s[d] = 2 * s[d] - r + 2 * p; | |
(Y = R < r || 0 == r?!0 : !1) && b(F).css({ | |
cursor: "default" | |
}); | |
G = b(n).parent().outerHeight(!0); | |
u = b(n).height(); | |
c.responsiveSlideContainer && (u = u > G ? G : u); | |
b(n).css({ | |
height: u | |
}); | |
e.setSliderOffset(F, l[z[d]]); | |
if (c.infiniteSlider&&!Y) { | |
a = e.getSliderOffset(b(F), "x"); | |
for (h =- 1 * ((B[d] + H)%H); 0 > h;) { | |
var f = 0, A = e.getSliderOffset(b(C[0]), "x"); | |
b(C).each(function(b) { | |
e.getSliderOffset(this, "x") < A && (A = e.getSliderOffset(this, "x"), f = b) | |
}); | |
var L = m[d] + R; | |
e.setSliderOffset(b(C)[f], L); | |
m[d] =- 1 * l[1] + p; | |
s[d] = m[d] + R - r; | |
l.splice(0, 1); | |
l.splice(l.length, 0, - 1 * L + p); | |
h++ | |
} | |
for (; 0<-1 * l[0] - R + p && c.snapSlideCenter && I;) { | |
var O = 0, P = e.getSliderOffset(b(C[0]), "x"); | |
b(C).each(function(b) { | |
e.getSliderOffset(this, "x") > P && (P = e.getSliderOffset(this, "x"), O = b) | |
}); | |
L = m[d] - M[O]; | |
e.setSliderOffset(b(C)[O], L); | |
l.splice(0, 0, - 1 * L + p); | |
l.splice(l.length - 1, 1); | |
m[d] =- 1 * l[0] + p; | |
s[d] = m[d] + R - r; | |
B[d]--; | |
z[d]++ | |
} | |
for (; a<=-1 * s[d];) | |
f = 0, A = e.getSliderOffset(b(C[0]), "x"), b(C).each(function(b) { | |
e.getSliderOffset(this, "x") < A && (A = e.getSliderOffset(this, "x"), f = b) | |
}), L = m[d] + R, e.setSliderOffset(b(C)[f], L), m[d] =- 1 * l[1] + p, s[d] = m[d] + R - r, l.splice(0, 1), l.splice(l.length, 0, - 1 * L + p), B[d]++, z[d]-- | |
} | |
e.setSliderOffset(F, l[z[d]]); | |
c.desktopClickDrag || b(F).css({ | |
cursor: "default" | |
}); | |
c.scrollbar && (b("." + K).css({ | |
margin: c.scrollbarMargin, | |
overflow: "hidden", | |
display: "none" | |
}), b("." + K + " ." + t).css({ | |
border: c.scrollbarBorder | |
}), k = parseInt(b("." + K).css("marginLeft")) + parseInt(b("." + K).css("marginRight")), D = parseInt(b("." + K + " ." + t).css("borderLeftWidth"), 10) + parseInt(b("." + K + " ." + t).css("borderRightWidth"), 10), y = "" != c.scrollbarContainer ? b(c.scrollbarContainer).width() : r, v = r / R * (y - k), c.scrollbarHide || (V = c.scrollbarOpacity), b("." + K).css({ | |
position: "absolute", | |
left: 0, | |
width: y - k + "px", | |
margin: c.scrollbarMargin | |
}), "top" == c.scrollbarLocation ? b("." + K).css("top", "0") : b("." + K).css("bottom", "0"), b("." + K + " ." + t).css({ | |
borderRadius: c.scrollbarBorderRadius, | |
background: c.scrollbarBackground, | |
height: c.scrollbarHeight, | |
width: v - D + "px", | |
minWidth: c.scrollbarHeight, | |
border: c.scrollbarBorder, | |
webkitPerspective: 1E3, | |
webkitBackfaceVisibility: "hidden", | |
position: "relative", | |
opacity: V, | |
filter: "alpha(opacity:" + 100 * V + ")", | |
boxShadow: c.scrollbarShadow | |
}), e.setSliderOffset(b("." + K + " ." + t), Math.floor(( - 1 * l[z[d]] - m[d] + p) / (s[d] - m[d] + p) * (y - k - v))), b("." + K).css({ | |
display: "block" | |
}), w = b("." + K + " ." + t), x = b("." + K)); | |
c.scrollbarDrag&&!Y && b("." + K + " ." + t).css({ | |
cursor: ia | |
}); | |
c.infiniteSlider && (S = (s[d] + r) / 3); | |
"" != c.navSlideSelector && b(c.navSlideSelector).each(function(a) { | |
b(this).css({ | |
cursor: "pointer" | |
}); | |
b(this).unbind(Q).bind(Q, function(g) { | |
"touchstart" == g.type ? b(this).unbind("click.iosSliderEvent") : b(this).unbind("touchstart.iosSliderEvent"); | |
Q = g.type + ".iosSliderEvent"; | |
e.changeSlide(a, F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c) | |
}) | |
}); | |
"" != c.navPrevSelector && (b(c.navPrevSelector).css({ | |
cursor: "pointer" | |
}), b(c.navPrevSelector).unbind(Q).bind(Q, function(a) { | |
"touchstart" == a.type ? b(this).unbind("click.iosSliderEvent") : b(this).unbind("touchstart.iosSliderEvent"); | |
Q = a.type + ".iosSliderEvent"; | |
a = (z[d] + B[d] + H)%H; | |
(0 < a || c.infiniteSlider) && e.changeSlide(a - 1, F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c) | |
})); | |
"" != c.navNextSelector && (b(c.navNextSelector).css({ | |
cursor: "pointer" | |
}), b(c.navNextSelector).unbind(Q).bind(Q, function(a) { | |
"touchstart" == a.type ? b(this).unbind("click.iosSliderEvent") : b(this).unbind("touchstart.iosSliderEvent"); | |
Q = a.type + ".iosSliderEvent"; | |
a = (z[d] + B[d] + H)%H; | |
(a < l.length - 1 || c.infiniteSlider) && e.changeSlide(a + 1, F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c) | |
})); | |
c.autoSlide&&!Y && "" != c.autoSlideToggleSelector && (b(c.autoSlideToggleSelector).css({ | |
cursor: "pointer" | |
}), b(c.autoSlideToggleSelector).unbind(Q).bind(Q, function(a) { | |
"touchstart" == a.type ? b(this).unbind("click.iosSliderEvent") : b(this).unbind("touchstart.iosSliderEvent"); | |
Q = a.type + ".iosSliderEvent"; | |
wa ? (e.autoSlide(F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c), wa=!1, b(c.autoSlideToggleSelector).removeClass("on")) : (e.autoSlidePause(d), wa=!0, b(c.autoSlideToggleSelector).addClass("on")) | |
})); | |
e.autoSlide(F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c); | |
b(n).bind("mouseleave.iosSliderEvent", function() { | |
e.autoSlide(F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c) | |
}); | |
b(n).bind("touchend.iosSliderEvent", function() { | |
e.autoSlide(F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c) | |
}); | |
c.autoSlideHoverPause && b(n).bind("mouseenter.iosSliderEvent", function() { | |
e.autoSlidePause(d) | |
}); | |
b(n).data("iosslider", { | |
obj: Aa, | |
settings: c, | |
scrollerNode: F, | |
slideNodes: C, | |
numberOfSlides: H, | |
centeredSlideOffset: p, | |
sliderNumber: d, | |
originalOffsets: E, | |
childrenOffsets: l, | |
sliderMax: s[d], | |
scrollbarClass: t, | |
scrollbarWidth: v, | |
scrollbarStageWidth: y, | |
stageWidth: r, | |
scrollMargin: k, | |
scrollBorder: D, | |
infiniteSliderOffset: B[d], | |
infiniteSliderWidth: S, | |
slideNodeOuterWidths: M | |
}); | |
I = !1; | |
return !0 | |
} | |
na++; | |
var d = na, N = []; | |
J[d] = b.extend({}, c); | |
m[d] = 0; | |
s[d] = 0; | |
var O = [0, 0], L = [0, 0], K = "scrollbarBlock" + na, t = "scrollbar" + na, w, x, y, v, q, G, p = 0, n = b(this), r, u, k, D, A, I=!0; | |
a =- 1; | |
var l, E = [], V = 0, P = 0, ea = 0, F = b(this).children(":first-child"), C, ga, M, H = b(F).children().not("script").length, U=!1, ha = 0, xa=!1, qa = void 0, S; | |
B[d] = 0; | |
var Y=!1, wa=!1; | |
ta[d]=!1; | |
var Z, ra=!1, ka=!1, Q = "touchstart.iosSliderEvent click.iosSliderEvent", R, va, ja, pa; | |
fa[d]=!1; | |
$[d] = []; | |
c.scrollbarDrag && (c.scrollbar=!0, c.scrollbarHide=!1); | |
var Aa = b(this); | |
if (void 0 != Aa.data("iosslider") | |
)return !0; | |
b(this).find("img").bind("dragstart.iosSliderEvent", function(b) { | |
b.preventDefault() | |
}); | |
c.infiniteSlider && (c.scrollbar=!1); | |
c.infiniteSlider && 1 == H && (c.infiniteSlider=!1); | |
c.scrollbar && ("" != c.scrollbarContainer ? b(c.scrollbarContainer).append("<div class = '" + K + "'><div class = '" + t + "'></div></div>") : b(F).parent().append("<div class = '" + K + "'><div class = '" + t + "'></div></div>")); | |
if (!g()) | |
return !0; | |
b(this).find("a").bind("mousedown", e.preventDrag); | |
b(this).find("[onclick]").bind("click", e.preventDrag).each(function() { | |
b(this).data("onclick", this.onclick) | |
}); | |
a = e.calcActiveOffset(c, e.getSliderOffset(b(F), "x"), l, r, B[d], H, void 0, d); | |
a = (a + B[d] + H)%H; | |
a = new e.args("load", c, F, b(F).children(":eq(" + a + ")"), a, a); | |
b(n).data("args", a); | |
if ("" != c.onSliderLoaded) | |
c.onSliderLoaded(a); | |
if (J[d].responsiveSlides || J[d].responsiveSlideContainer) | |
a = Ba ? "orientationchange" : "resize", b(window).bind(a + ".iosSliderEvent-" + d, function() { | |
if (!g()) | |
return !0; | |
var a = b(n).data("args"); | |
if ("" != c.onSliderResize) | |
c.onSliderResize(a) | |
}); | |
!c.keyboardControls&&!c.tabToAdvance || Y || b(document).bind("keydown.iosSliderEvent", function(b) { | |
aa || X || (b = b.originalEvent); | |
if (37 == b.keyCode && c.keyboardControls) | |
b.preventDefault(), b = (z[d] + B[d] + H)%H, (0 < b || c.infiniteSlider) && e.changeSlide(b - 1, F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c); | |
else if (39 == b.keyCode && c.keyboardControls || 9 == b.keyCode && c.tabToAdvance) | |
b.preventDefault(), b = (z[d] + B[d] + H)%H, (b < l.length - 1 || c.infiniteSlider) && e.changeSlide(b + 1, F, C, N, t, v, r, y, k, D, E, l, M, d, S, H, p, c) | |
}); | |
if (za || c.desktopClickDrag) { | |
var ca = !1, la = b(F), ma = b(F), ya=!1; | |
c.scrollbarDrag && (la = la.add(w), ma = ma.add(x)); | |
b(la).bind("mousedown.iosSliderEvent touchstart.iosSliderEvent", function(a) { | |
if (ca) | |
return !0; | |
ca=!0; | |
"touchstart" == a.type ? b(ma).unbind("mousedown.iosSliderEvent") : b(ma).unbind("touchstart.iosSliderEvent"); | |
if (fa[d] || Y || (ya = e.isUnselectable(a.target, c))) | |
return U = ca=!1, !0; | |
Z = b(this)[0] === b(w)[0] ? w : F; | |
aa || X || (a = a.originalEvent); | |
e.autoSlidePause(d); | |
pa.unbind(".disableClick"); | |
if ("touchstart" == a.type) | |
eventX = a.touches[0].pageX, eventY = a.touches[0].pageY; | |
else { | |
if (window.getSelection) | |
window.getSelection().empty ? window.getSelection().empty() : window.getSelection().removeAllRanges && window.getSelection().removeAllRanges(); | |
else if (document.selection) | |
if (X) | |
try { | |
document.selection.empty() | |
} catch (g) {} else | |
document.selection.empty(); | |
eventX = a.pageX; | |
eventY = a.pageY; | |
xa=!0; | |
qa = F; | |
b(this).css({ | |
cursor: sa | |
}) | |
} | |
O = [0, 0]; | |
L = [0, 0]; | |
W = 0; | |
U=!1; | |
for (a = 0; a < N.length; a++) | |
clearTimeout(N[a]); | |
a = e.getSliderOffset(F, "x"); | |
a>-1 * m[d] + p + R ? (a =- 1 * m[d] + p + R, e.setSliderOffset(b("." + t), a), b("." + t).css({ | |
width: v - D + "px" | |
})) : a<-1 * s[d] && (e.setSliderOffset(b("." + t), y - k - v), b("." + t).css({ | |
width: v - D + "px" | |
})); | |
a = b(this)[0] === b(w)[0] ? m[d] : 0; | |
P =- 1 * (e.getSliderOffset(this, "x") - eventX - a); | |
e.getSliderOffset(this, "y"); | |
O[1] = eventX; | |
L[1] = eventY; | |
ka=!1 | |
}); | |
b(ma).bind("touchmove.iosSliderEvent mousemove.iosSliderEvent", function(a) { | |
aa || X || (a = a.originalEvent); | |
if (fa[d] || Y || ya) | |
return !0; | |
var g = 0; | |
if ("touchmove" == a.type) | |
eventX = a.touches[0].pageX, eventY = a.touches[0].pageY; | |
else { | |
if (window.getSelection) | |
window.getSelection().empty || window.getSelection().removeAllRanges && window.getSelection().removeAllRanges(); | |
else if (document.selection) | |
if (X) | |
try { | |
document.selection.empty() | |
} catch (h) {} else | |
document.selection.empty(); | |
eventX = a.pageX; | |
eventY = a.pageY; | |
if (!xa ||!oa && ("undefined" != typeof a.webkitMovementX || "undefined" != typeof a.webkitMovementY) && 0 === a.webkitMovementY && 0 === a.webkitMovementX) | |
return !0 | |
} | |
O[0] = O[1]; | |
O[1] = eventX; | |
W = (O[1] - O[0]) / 2; | |
L[0] = L[1]; | |
L[1] = eventY; | |
da = (L[1] - L[0]) / 2; | |
if (!U) { | |
var f = (z[d] + B[d] + H)%H, f = new e.args("start", c, F, b(F).children(":eq(" + f + ")"), f, void 0); | |
b(n).data("args", f); | |
if ("" != c.onSlideStart) | |
c.onSlideStart(f) | |
}(da > c.verticalSlideLockThreshold || da<-1 * c.verticalSlideLockThreshold) && "touchmove" == a.type&&!U && (ra=!0); | |
(W > c.horizontalSlideLockThreshold || W<-1 * c.horizontalSlideLockThreshold) && "touchmove" == a.type && a.preventDefault(); | |
if (W > c.slideStartVelocityThreshold || W<-1 * c.slideStartVelocityThreshold) | |
U=!0; | |
if (U&&!ra) { | |
var f = e.getSliderOffset(F, "x"), q = b(Z)[0] === b(w)[0] ? m[d]: p, u = b(Z)[0] === b(w)[0] ? (m[d] - s[d] - p) / (y - k - v): 1, x = b(Z)[0] === b(w)[0] ? c.scrollbarElasticPullResistance: c.elasticPullResistance, G = c.snapSlideCenter && b(Z)[0] === b(w)[0] ? 0: p, K = c.snapSlideCenter && b(Z)[0] === b(w)[0] ? p: 0; | |
"touchmove" == a.type && (ea != a.touches.length && (P =- 1 * f + eventX), ea = a.touches.length); | |
if (c.infiniteSlider) { | |
if (f<=-1 * s[d]) { | |
var I = b(F).width(); | |
if (f<=-1 * ua[d]) { | |
var J =- 1 * E[0]; | |
b(C).each(function(a) { | |
e.setSliderOffset(b(C)[a], J + p); | |
a < l.length && (l[a] =- 1 * J); | |
J += M[a] | |
}); | |
P-=-1 * l[0]; | |
m[d] =- 1 * l[0] + p; | |
s[d] = m[d] + I - r; | |
B[d] = 0 | |
} else { | |
var N = 0, S = e.getSliderOffset(b(C[0]), "x"); | |
b(C).each(function(b) { | |
e.getSliderOffset(this, "x") < S && (S = e.getSliderOffset(this, "x"), N = b) | |
}); | |
x = m[d] + I; | |
e.setSliderOffset(b(C)[N], x); | |
m[d] =- 1 * l[1] + p; | |
s[d] = m[d] + I - r; | |
l.splice(0, 1); | |
l.splice(l.length, 0, - 1 * x + p); | |
B[d]++ | |
} | |
} | |
if (f>=-1 * m[d] || 0 <= f) | |
if (I = b(F).width(), 0 <= f) | |
for (J =- 1 * E[0], b(C).each(function(a) { | |
e.setSliderOffset(b(C)[a], J + p); | |
a < l.length && (l[a] =- 1 * J); | |
J += M[a] | |
}), P +=- 1 * l[0], m[d] =- 1 * l[0] + p, s[d] = m[d] + I - r, B[d] = H; 0<-1 * l[0] - I + p;) { | |
var Q = 0, R = e.getSliderOffset(b(C[0]), "x"); | |
b(C).each(function(b) { | |
e.getSliderOffset(this, "x") > R && (R = e.getSliderOffset(this, "x"), Q = b) | |
}); | |
x = m[d] - M[Q]; | |
e.setSliderOffset(b(C)[Q], x); | |
l.splice(0, 0, - 1 * x + p); | |
l.splice(l.length - 1, 1); | |
m[d] =- 1 * l[0] + p; | |
s[d] = m[d] + I - r; | |
B[d]--; | |
z[d]++ | |
} else | |
Q = 0, R = e.getSliderOffset(b(C[0]), "x"), b(C).each(function(b) { | |
e.getSliderOffset(this, "x") > R && (R = e.getSliderOffset(this, "x"), Q = b) | |
}), x = m[d] - M[Q], e.setSliderOffset(b(C)[Q], x), l.splice(0, 0, - 1 * x + p), l.splice(l.length - 1, 1), m[d] =- 1 * l[0] + p, s[d] = m[d] + I - r, B[d]-- | |
} else | |
I = b(F).width(), f>-1 * m[d] + p && (g =- 1 * (m[d] +- 1 * (P - q - eventX + G) * u - q) * x / u), f<-1 * s[d] && (g =- 1 * (s[d] + K +- 1 * (P - q - eventX) * u - q) * x / u); | |
e.setSliderOffset(F, - 1 * (P - q - eventX - g) * u - q + K); | |
c.scrollbar && (e.showScrollbar(c, t), T = Math.floor((P - eventX - g - m[d] + G) / (s[d] - m[d] + p) * (y - k - v) * u), f = v, 0 >= T ? (f = v - D - - 1 * T, e.setSliderOffset(b("." + t), 0), b("." + t).css({ | |
width: f + "px" | |
})) : T >= y - k - D - v ? (f = y - k - D - T, e.setSliderOffset(b("." + t), T), b("." + t).css({ | |
width: f + "px" | |
})) : e.setSliderOffset(b("." + t), T)); | |
"touchmove" == a.type && (A = a.touches[0].pageX); | |
a=!1; | |
g = e.calcActiveOffset(c, - 1 * (P - eventX - g), l, r, B[d], H, void 0, d); | |
f = (g + B[d] + H)%H; | |
c.infiniteSlider ? f != ba[d] && (a=!0) : g != z[d] && (a=!0); | |
if (a && (z[d] = g, ba[d] = f, ka=!0, f = new e.args("change", c, F, b(F).children(":eq(" + f + ")"), f, f), b(n).data("args", f), "" != c.onSlideChange)) | |
c.onSlideChange(f) | |
} | |
ca=!1 | |
}); | |
a = b(window); | |
if (X || aa) | |
a = b(document); | |
b(la).bind("touchend.iosSliderEvent", function(b) { | |
b = b.originalEvent; | |
if (fa[d] || Y || ya) | |
return !0; | |
if (0 != b.touches.length) | |
for (var a = 0; a < b.touches.length; a++) | |
b.touches[a].pageX == A && e.slowScrollHorizontal(F, C, N, t, W, da, v, r, y, k, D, E, l, M, d, S, H, Z, ka, p, c); | |
else | |
e.slowScrollHorizontal(F, C, N, t, W, da, v, r, y, k, D, E, l, M, d, S, H, Z, ka, p, c); | |
ca = ra=!1 | |
}); | |
b(a).bind("mouseup.iosSliderEvent-" + d, function(a) { | |
U ? va.unbind("click.disableClick").bind("click.disableClick", e.preventClick) : va.unbind("click.disableClick").bind("click.disableClick", e.enableClick); | |
ja.each(function() { | |
this.onclick = function(a) { | |
if (U) | |
return !1; | |
b(this).data("onclick").call(this, a || window.event) | |
}; | |
this.onclick = b(this).data("onclick") | |
}); | |
1.8 <= parseFloat(b().jquery) ? pa.each(function() { | |
var a = b._data(this, "events"); | |
if (void 0 != a && void 0 != a.click && "iosSliderEvent" != a.click[0].namespace) { | |
if (!U) | |
return !1; | |
b(this).one("click.disableClick", e.preventClick); | |
var a = b._data(this, "events").click, c = a.pop(); | |
a.splice(0, 0, c) | |
} | |
}) : 1.6 <= parseFloat(b().jquery) && pa.each(function() { | |
var a = b(this).data("events"); | |
if (void 0 != a && void 0 != a.click && "iosSliderEvent" != a.click[0].namespace) { | |
if (!U) | |
return !1; | |
b(this).one("click.disableClick", e.preventClick); | |
var a = b(this).data("events").click, c = a.pop(); | |
a.splice(0, 0, c) | |
} | |
}); | |
if (!ta[d]) { | |
if (Y) | |
return !0; | |
b(la).css({ | |
cursor: ia | |
}); | |
xa=!1; | |
if (void 0 == qa) | |
return !0; | |
e.slowScrollHorizontal(qa, C, N, t, W, da, v, r, y, k, D, E, l, M, d, S, H, Z, ka, p, c); | |
qa = void 0 | |
} | |
ca = ra=!1 | |
}) | |
} | |
}) | |
}, | |
destroy: function(a, g) { | |
void 0 == g && (g = this); | |
return b(g).each(function() { | |
var c = b(this), f = c.data("iosslider"); | |
if (void 0 == f) | |
return !1; | |
void 0 == a && (a=!0); | |
e.autoSlidePause(f.sliderNumber); | |
ta[f.sliderNumber]=!0; | |
b(window).unbind(".iosSliderEvent-" + f.sliderNumber); | |
b(document).unbind(".iosSliderEvent-" + f.sliderNumber); | |
b(document).unbind("keydown.iosSliderEvent"); | |
b(this).unbind(".iosSliderEvent"); | |
b(this).children(":first-child").unbind(".iosSliderEvent"); | |
b(this).children(":first-child").children().unbind(".iosSliderEvent"); | |
a && (b(this).attr("style", ""), b(this).children(":first-child").attr("style", ""), b(this).children(":first-child").children().attr("style", ""), b(f.settings.navSlideSelector).attr("style", ""), b(f.settings.navPrevSelector).attr("style", ""), b(f.settings.navNextSelector).attr("style", ""), b(f.settings.autoSlideToggleSelector).attr("style", ""), b(f.settings.unselectableSelector).attr("style", "")); | |
f.settings.scrollbar && b(".scrollbarBlock" + f.sliderNumber).remove(); | |
for (var f = $[f.sliderNumber], g = 0; g < f.length; g++) | |
clearTimeout(f[g]); | |
c.removeData("iosslider"); | |
c.removeData("args") | |
}) | |
}, | |
update: function(a) { | |
void 0 == a && (a = this); | |
return b(a).each(function() { | |
var a = b(this), c = a.data("iosslider"); | |
if (void 0 == c) | |
return !1; | |
c.settings.startAtSlide = a.data("args").currentSlideNumber; | |
V.destroy(!1, this); | |
1 != c.numberOfSlides && c.settings.infiniteSlider && (c.settings.startAtSlide = (z[c.sliderNumber] + 1 + B[c.sliderNumber] + c.numberOfSlides)%c.numberOfSlides); | |
V.init(c.settings, this); | |
a = new e.args("update", c.settings, c.scrollerNode, b(c.scrollerNode).children(":eq(" + (c.settings.startAtSlide - 1) + ")"), c.settings.startAtSlide - 1, c.settings.startAtSlide - 1); | |
b(c.stageNode).data("args", a); | |
if ("" != c.settings.onSliderUpdate) | |
c.settings.onSliderUpdate(a) | |
}) | |
}, | |
addSlide: function(a, e) { | |
return this.each(function() { | |
var c = b(this), f = c.data("iosslider"); | |
if (void 0 == f) | |
return !1; | |
0 == b(f.scrollerNode).children().length ? (b(f.scrollerNode).append(a), c.data("args").currentSlideNumber = 1) : f.settings.infiniteSlider ? (1 == e ? b(f.scrollerNode).children(":eq(0)").before(a) : b(f.scrollerNode).children(":eq(" + (e - 2) + ")").after(a), - 1 > B[f.sliderNumber] && z[f.sliderNumber]--, c.data("args").currentSlideNumber >= e && z[f.sliderNumber]++) : (e <= f.numberOfSlides ? b(f.scrollerNode).children(":eq(" + (e - 1) + ")").before(a) : b(f.scrollerNode).children(":eq(" + (e - 2) + ")").after(a), c.data("args").currentSlideNumber >= e && c.data("args").currentSlideNumber++); | |
c.data("iosslider").numberOfSlides++; | |
V.update(this) | |
}) | |
}, | |
removeSlide: function(a) { | |
return this.each(function() { | |
var e = b(this).data("iosslider"); | |
if (void 0 == e) | |
return !1; | |
b(e.scrollerNode).children(":eq(" + (a - 1) + ")").remove(); | |
z[e.sliderNumber] > a - 1 && z[e.sliderNumber]--; | |
V.update(this) | |
}) | |
}, | |
goToSlide: function(a, g) { | |
void 0 == g && (g = this); | |
return b(g).each(function() { | |
var c = b(this).data("iosslider"); | |
if (void 0 == c) | |
return !1; | |
a = a > c.childrenOffsets.length ? c.childrenOffsets.length - 1 : a - 1; | |
e.changeSlide(a, b(c.scrollerNode), b(c.slideNodes), $[c.sliderNumber], c.scrollbarClass, c.scrollbarWidth, c.stageWidth, c.scrollbarStageWidth, c.scrollMargin, c.scrollBorder, c.originalOffsets, c.childrenOffsets, c.slideNodeOuterWidths, c.sliderNumber, c.infiniteSliderWidth, c.numberOfSlides, c.centeredSlideOffset, c.settings) | |
}) | |
}, | |
prevSlide: function() { | |
return this.each(function() { | |
var a = b(this).data("iosslider"); | |
if (void 0 == a) | |
return !1; | |
var g = (z[a.sliderNumber] + B[a.sliderNumber] + a.numberOfSlides)%a.numberOfSlides; | |
(0 < g || a.settings.infiniteSlider) && e.changeSlide(g - 1, b(a.scrollerNode), b(a.slideNodes), $[a.sliderNumber], a.scrollbarClass, a.scrollbarWidth, a.stageWidth, a.scrollbarStageWidth, a.scrollMargin, a.scrollBorder, a.originalOffsets, a.childrenOffsets, a.slideNodeOuterWidths, a.sliderNumber, a.infiniteSliderWidth, a.numberOfSlides, a.centeredSlideOffset, a.settings); | |
z[a.sliderNumber] = g | |
}) | |
}, | |
nextSlide: function() { | |
return this.each(function() { | |
var a = b(this).data("iosslider"); | |
if (void 0 == a) | |
return !1; | |
var g = (z[a.sliderNumber] + B[a.sliderNumber] + a.numberOfSlides)%a.numberOfSlides; | |
(g < a.childrenOffsets.length - 1 || a.settings.infiniteSlider) && e.changeSlide(g + 1, b(a.scrollerNode), b(a.slideNodes), $[a.sliderNumber], a.scrollbarClass, a.scrollbarWidth, a.stageWidth, a.scrollbarStageWidth, a.scrollMargin, a.scrollBorder, a.originalOffsets, a.childrenOffsets, a.slideNodeOuterWidths, a.sliderNumber, a.infiniteSliderWidth, a.numberOfSlides, a.centeredSlideOffset, a.settings); | |
z[a.sliderNumber] = g | |
}) | |
}, | |
lock: function() { | |
return this.each(function() { | |
var a = b(this).data("iosslider"); | |
if (void 0 == a) | |
return !1; | |
fa[a.sliderNumber]=!0 | |
}) | |
}, | |
unlock: function() { | |
return this.each(function() { | |
var a = b(this).data("iosslider"); | |
if (void 0 == a) | |
return !1; | |
fa[a.sliderNumber] = !1 | |
}) | |
}, | |
getData: function() { | |
return this.each(function() { | |
var a = b(this).data("iosslider"); | |
return void 0 == a?!1 : a | |
}) | |
}, | |
autoSlidePause: function() { | |
return this.each(function() { | |
var a = b(this).data("iosslider"); | |
if (void 0 == a) | |
return !1; | |
J[a.sliderNumber].autoSlide=!1; | |
e.autoSlidePause(a.sliderNumber); | |
return a | |
}) | |
}, | |
autoSlidePlay: function() { | |
return this.each(function() { | |
var a = b(this).data("iosslider"); | |
if (void 0 == a) | |
return !1; | |
J[a.sliderNumber].autoSlide=!0; | |
e.autoSlide(b(a.scrollerNode), b(a.slideNodes), $[a.sliderNumber], a.scrollbarClass, a.scrollbarWidth, a.stageWidth, a.scrollbarStageWidth, a.scrollMargin, a.scrollBorder, a.originalOffsets, a.childrenOffsets, a.slideNodeOuterWidths, a.sliderNumber, a.infiniteSliderWidth, a.numberOfSlides, a.centeredSlideOffset, a.settings); | |
return a | |
}) | |
} | |
}; | |
b.fn.iosSlider = function(a) { | |
if (V[a]) | |
return V[a].apply(this, Array.prototype.slice.call(arguments, 1)); | |
if ("object" !== typeof a && a) | |
b.error("invalid method call!"); | |
else | |
return V.init.apply(this, arguments) | |
} | |
})(jQuery); | |
// jQuery Plugins | |
// Remove whitespace | |
(function(a) { | |
a.fn.removeWhitespace = function() { | |
this.contents().filter(function() { | |
return this.nodeType == 3&&!/\S/.test(this.nodeValue) | |
}).remove(); | |
return this | |
} | |
})(jQuery) | |
/*! | |
* | |
* jQuery collagePlus Plugin v0.3.3 | |
* https://github.com/ed-lea/jquery-collagePlus | |
* | |
* Copyright 2012, Ed Lea twitter.com/ed_lea | |
* | |
* built for http://qiip.me | |
* | |
* Dual licensed under the MIT or GPL Version 2 licenses. | |
* http://www.opensource.org/licenses/mit-license.php | |
* http://www.opensource.org/licenses/GPL-2.0 | |
* | |
*/ | |
; | |
(function(e) { | |
e.fn.collagePlus = function(t) { | |
function n(t, n, i, s) { | |
var o = i.padding * (t.length - 1) + t.length * t[0][3], u = i.albumWidth - o, a = u / (n - o), f = o, l = n < i.albumWidth ? true: false; | |
for (var c = 0; c < t.length; c++) { | |
var h = e(t[c][0]), p = Math.floor(t[c][1] * a), d = Math.floor(t[c][2] * a), v=!!(c < t.length - 1); | |
if (i.allowPartialLastRow === true && l === true) { | |
p = t[c][1]; | |
d = t[c][2] | |
} | |
f += p; | |
if (!v && f < i.albumWidth) { | |
if (i.allowPartialLastRow === true && l === true) { | |
p = p | |
} else { | |
p = p + (i.albumWidth - f) | |
} | |
} | |
p--; | |
var m = h.is("img") ? h: h.find("img"); | |
m.width(p); | |
if (!h.is("img")) { | |
h.width(p + t[c][3]) | |
} | |
m.height(d); | |
if (!h.is("img")) { | |
h.height(d + t[c][4]) | |
} | |
r(h, v, i); | |
m.one("load", function(e) { | |
return function() { | |
if (i.effect == "default") { | |
e.animate({ | |
opacity: "1" | |
}, { | |
duration: i.fadeSpeed | |
}) | |
} else { | |
if (i.direction == "vertical") { | |
var t = s <= 10 ? s: 10 | |
} else { | |
var t = c <= 9 ? c + 1: 10 | |
} | |
e.removeClass(function(e, t) { | |
return (t.match(/\beffect-\S+/g) || []).join(" ") | |
}); | |
e.addClass(i.effect); | |
e.addClass("effect-duration-" + t) | |
} | |
} | |
}(h)).each(function() { | |
if (this.complete) | |
e(this).trigger("load") | |
}) | |
} | |
} | |
function r(e, t, n) { | |
var r = { | |
"margin-bottom": n.padding + "px", | |
"margin-right": t ? n.padding + "px": "0px", | |
display: n.display, | |
"vertical-align": "bottom", | |
overflow: "hidden" | |
}; | |
return e.css(r) | |
} | |
function i(t) { | |
$img = e(t); | |
var n = new Array; | |
n["w"] = parseFloat($img.css("border-left-width")) + parseFloat($img.css("border-right-width")); | |
n["h"] = parseFloat($img.css("border-top-width")) + parseFloat($img.css("border-bottom-width")); | |
return n | |
} | |
return this.each(function() { | |
var r = 0, s = [], o = 1, u = e(this); | |
e.fn.collagePlus.defaults.albumWidth = u.width(); | |
e.fn.collagePlus.defaults.padding = parseFloat(u.css("padding-left")); | |
e.fn.collagePlus.defaults.images = u.children(); | |
var a = e.extend({}, e.fn.collagePlus.defaults, t); | |
a.images.each(function(t) { | |
var u = e(this), f = u.is("img") ? u: e(this).find("img"); | |
var l = typeof f.data("width") != "undefined" ? f.data("width"): f.width(), c = typeof f.data("height") != "undefined" ? f.data("height"): f.height(); | |
var h = i(f); | |
f.data("width", l); | |
f.data("height", c); | |
var p = Math.ceil(l / c * a.targetHeight), d = Math.ceil(a.targetHeight); | |
s.push([this, p, d, h["w"], h["h"]]); | |
r += p + h["w"] + a.padding; | |
if (r > a.albumWidth && s.length != 0) { | |
n(s, r - a.padding, a, o); | |
delete r; | |
delete s; | |
r = 0; | |
s = []; | |
o += 1 | |
} | |
if (a.images.length - 1 == t && s.length != 0) { | |
n(s, r, a, o); | |
delete r; | |
delete s; | |
r = 0; | |
s = []; | |
o += 1 | |
} | |
}) | |
}) | |
}; | |
e.fn.collagePlus.defaults = { | |
targetHeight: 400, | |
fadeSpeed: "fast", | |
display: "inline-block", | |
effect: "default", | |
direction: "vertical", | |
allowPartialLastRow: false | |
} | |
})(jQuery); | |
/** | |
* photoset-grid - v1.0.1 | |
* 2014-04-08 | |
* jQuery plugin to arrange images into a flexible grid | |
* http://stylehatch.github.com/photoset-grid/ | |
* | |
* Copyright 2014 Jonathan Moore - Style Hatch | |
*/ | |
!function(a, b, c, d) { | |
"use strict"; | |
function e(b, c) { | |
this.element = b, this.options = a.extend({}, g, c), this._defaults = g, this._name = f, this.init() | |
} | |
var f = "photosetGrid", g = { | |
width: "100%", | |
gutter: "0px", | |
highresLinks: !1, | |
lowresWidth: 500, | |
rel: "", | |
onInit: function() {}, | |
onComplete: function() {} | |
}; | |
e.prototype = { | |
init: function() { | |
this.options.onInit(), this._setupRows(this.element, this.options), this._setupColumns(this.element, this.options) | |
}, | |
_callback: function(a) { | |
this.options.onComplete(a) | |
}, | |
_setupRows: function(b, c) { | |
if (c.layout) | |
this.layout = c.layout; | |
else if (a(b).attr("data-layout")) | |
this.layout = a(b).attr("data-layout"); | |
else { | |
for (var d = "", e = 1, f = 0; f < a(b).find("img").length; f++) | |
d += e.toString(); | |
this.layout = d | |
} | |
this.rows = this.layout.split(""); | |
for (var g in this.rows) | |
this.rows[g] = parseInt(this.rows[g], 10); | |
var h = a(b).find("img"), i = 0; | |
a.each(this.rows, function(a, b) { | |
var c = i, d = i + b; | |
h.slice(c, d).wrapAll('<div class="photoset-row cols-' + b + '"></div>'), i = d | |
}), a(b).find(".photoset-row:not(:last-child)").css({ | |
"margin-bottom": c.gutter | |
}) | |
}, | |
_setupColumns: function(c, d) { | |
var e = this, f = function(e) { | |
function f() { | |
var b = a(c).width().toString(); | |
b !== a(c).attr("data-width") && (g.each(function() { | |
var b = a(this).find("img:eq(0)"); | |
a(this).find("img").each(function() { | |
var c = a(this); | |
c.attr("height") < b.attr("height") && (b = a(this)), parseInt(c.css("width"), 10) > d.lowresWidth && c.attr("data-highres") && c.attr("src", c.attr("data-highres")) | |
}); | |
var c = b.attr("height") * parseInt(b.css("width"), 10) / b.attr("width"), e = Math.floor(.025 * c); | |
a(this).height(c - e), a(this).find("img").each(function() { | |
var b = a(this).attr("height") * parseInt(a(this).css("width"), 10) / a(this).attr("width"), d = .5 * (c - b) + "px"; | |
a(this).css({ | |
"margin-top": d | |
}) | |
}) | |
}), a(c).attr("data-width", b)) | |
} | |
var g = a(c).find(".photoset-row"), h = a(c).find("img"); | |
d.highresLinks ? (h.each(function() { | |
var b; | |
b = a(this).attr(a(this).attr("data-highres") ? "data-highres" : "src"), a(this).wrapAll('<a href="' + b + '" class="photoset-cell highres-link" />') | |
}), d.rel && h.parent().attr("rel", d.rel)) : h.each(function() { | |
a(this).wrapAll('<div class="photoset-cell" />') | |
}); | |
var i = a(c).find(".photoset-cell"), j = a(c).find(".cols-1 .photoset-cell"), k = a(c).find(".cols-2 .photoset-cell"), l = a(c).find(".cols-3 .photoset-cell"), m = a(c).find(".cols-4 .photoset-cell"), n = a(c).find(".cols-5 .photoset-cell"); | |
a(c).css({ | |
width: d.width | |
}), g.css({ | |
clear: "left", | |
display: "block", | |
overflow: "hidden" | |
}), i.css({ | |
"float": "left", | |
display: "block", | |
"line-height": "0", | |
"-webkit-box-sizing": "border-box", | |
"-moz-box-sizing": "border-box", | |
"box-sizing": "border-box" | |
}), h.css({ | |
width: "100%", | |
height: "auto" | |
}), e && h.each(function() { | |
a(this).attr("height", a(this).height()), a(this).attr("width", a(this).width()) | |
}), j.css({ | |
width: "100%" | |
}), k.css({ | |
width: "50%" | |
}), l.css({ | |
width: "33.3%" | |
}), m.css({ | |
width: "25%" | |
}), n.css({ | |
width: "20%" | |
}); | |
var o = parseInt(d.gutter, 10); | |
a(c).find(".photoset-cell:not(:last-child)").css({ | |
"padding-right": o / 2 + "px" | |
}), a(c).find(".photoset-cell:not(:first-child)").css({ | |
"padding-left": o / 2 + "px" | |
}), f(), a(b).on("resize", function() { | |
f() | |
}) | |
}, g=!0, h=!0; | |
a(c).find("img").each(function() { | |
h&=!!a(this).attr("height")&!!a(this).attr("width") | |
}), g=!h, g ? a(c).imagesLoaded(function() { | |
f(g), e._callback(c) | |
}) : (f(g), e._callback(c)) | |
} | |
}, a.fn[f] = function(b) { | |
return this.each(function() { | |
a.data(this, "plugin_" + f) || a.data(this, "plugin_" + f, new e(this, b)) | |
}) | |
}; | |
var h = ""; | |
a.fn.imagesLoaded = function(b) { | |
function c() { | |
var c = a(m), d = a(n); | |
i && (n.length ? i.reject(k, c, d) : i.resolve(k)), a.isFunction(b) && b.call(g, k, c, d) | |
} | |
function e(a) { | |
f(a.target, "error" === a.type) | |
} | |
function f(b, d) { | |
b.src !== h&&-1 === a.inArray(b, l) && (l.push(b), d ? n.push(b) : m.push(b), a.data(b, "imagesLoaded", { | |
isBroken: d, | |
src: b.src | |
}), j && i.notifyWith(a(b), [d, k, a(m), a(n)]), k.length === l.length && (setTimeout(c), k.unbind(".imagesLoaded", e))) | |
} | |
var g = this, i = a.isFunction(a.Deferred) ? a.Deferred(): 0, j = a.isFunction(i.notify), k = g.find("img").add(g.filter("img")), l = [], m = [], n = []; | |
return a.isPlainObject(b) && a.each(b, function(a, c) { | |
"callback" === a ? b = c : i && i[a](c) | |
}), k.length ? k.bind("load.imagesLoaded error.imagesLoaded", e).each(function(b, c) { | |
var e = c.src, g = a.data(c, "imagesLoaded"); | |
return g && g.src === e ? void f(c, g.isBroken) : c.complete && c.naturalWidth !== d ? void f(c, 0 === c.naturalWidth || 0 === c.naturalHeight) : void((c.readyState || c.complete) && (c.src = h, c.src = e)) | |
}) : c(), i ? i.promise(g) : g | |
}; | |
var i, j, k, l = a.event, m = { | |
_: 0 | |
}, n = 0; | |
i = l.special.throttledresize = { | |
setup: function() { | |
a(this).on("resize", i.handler) | |
}, | |
teardown: function() { | |
a(this).off("resize", i.handler) | |
}, | |
handler: function(b, c) { | |
var d = this, e = arguments; | |
j=!0, k || (setInterval(function() { | |
n++, (n > i.threshold && j || c) && (b.type = "throttledresize", l.dispatch.apply(d, e), j=!1, n = 0), n > 9 && (a(m).stop(), k=!1, n = 0) | |
}, 30), k=!0) | |
}, | |
threshold: 0 | |
} | |
}(jQuery, window, document); | |
/* | |
* jQuery throttle / debounce - v1.1 - 3/7/2010 | |
* http://benalman.com/projects/jquery-throttle-debounce-plugin/ | |
* | |
* Copyright (c) 2010 "Cowboy" Ben Alman | |
* Dual licensed under the MIT and GPL licenses. | |
* http://benalman.com/about/license/ | |
*/ | |
(function(b, c) { | |
var $ = b.jQuery || b.Cowboy || (b.Cowboy = {}), a; | |
$.throttle = a = function(e, f, j, i) { | |
var h, d = 0; | |
if (typeof f !== "boolean") { | |
i = j; | |
j = f; | |
f = c | |
} | |
function g() { | |
var o = this, m =+ new Date() - d, n = arguments; | |
function l() { | |
d =+ new Date(); | |
j.apply(o, n) | |
} | |
function k() { | |
h = c | |
} | |
if (i&&!h) { | |
l() | |
} | |
h && clearTimeout(h); | |
if (i === c && m > e) { | |
l() | |
} else { | |
if (f !== true) { | |
h = setTimeout(i ? k : l, i === c ? e - m : e) | |
} | |
} | |
} | |
if ($.guid) { | |
g.guid = j.guid = j.guid || $.guid++ | |
} | |
return g | |
}; | |
$.debounce = function(d, e, f) { | |
return f === c ? a(d, e, false) : a(d, f, e !== false) | |
} | |
})(this); | |
var Plugins; | |
(function (Plugins) { | |
var AutosizeInput = (function () { | |
function AutosizeInput(input, options) { | |
var _this = this; | |
this._input = $(input); | |
this._options = options; | |
this._mirror = $('<span style="position:absolute; top:-999px; left:0; white-space:pre;"/>'); | |
$.each(['fontFamily', 'fontSize', 'fontWeight', 'fontStyle', 'letterSpacing', 'textTransform', 'wordSpacing', 'textIndent'], function (i, val) { | |
_this._mirror[0].style[val] = _this._input.css(val); | |
}); | |
$("body").append(this._mirror); | |
this._input.on("keydown keyup input propertychange change", function (e) { | |
_this.update(); | |
}); | |
(function () { | |
_this.update(); | |
})(); | |
} | |
Object.defineProperty(AutosizeInput.prototype, "options", { | |
get: function () { | |
return this._options; | |
}, | |
enumerable: true, | |
configurable: true | |
}); | |
Object.defineProperty(AutosizeInput, "instanceKey", { | |
get: function () { | |
return "autosizeInputInstance"; | |
}, | |
enumerable: true, | |
configurable: true | |
}); | |
AutosizeInput.prototype.update = function () { | |
var value = this._input.val(); | |
if (!value) { | |
value = this._input.attr("placeholder") || ""; | |
} | |
if (value === this._mirror.text()) { | |
return; | |
} | |
this._mirror.text(value); | |
var newWidth = this._mirror.width() + this._options.space; | |
this._input.width(newWidth); | |
}; | |
return AutosizeInput; | |
})(); | |
Plugins.AutosizeInput = AutosizeInput; | |
var AutosizeInputOptions = (function () { | |
function AutosizeInputOptions(space) { | |
if (typeof space === "undefined") { | |
space = 30; | |
} | |
this._space = space; | |
} | |
Object.defineProperty(AutosizeInputOptions.prototype, "space", { | |
get: function () { | |
return this._space; | |
}, | |
set: function (value) { | |
this._space = value; | |
}, | |
enumerable: true, | |
configurable: true | |
}); | |
return AutosizeInputOptions; | |
})(); | |
Plugins.AutosizeInputOptions = AutosizeInputOptions; | |
(function ($) { | |
var pluginDataAttributeName = "autosize-input"; | |
var validTypes = ["text", "password", "search", "url", "tel", "email"]; | |
$.fn.autosizeInput = function (options) { | |
return this.each(function () { | |
if (!(this.tagName == "INPUT" && $.inArray(this.type, validTypes) > - 1)) { | |
return; | |
} | |
var $this = $(this); | |
if (!$this.data(Plugins.AutosizeInput.instanceKey)) { | |
if (options == undefined) { | |
var options = $this.data(pluginDataAttributeName); | |
if (!(options && typeof options == 'object')) { | |
options = new AutosizeInputOptions(); | |
} | |
} | |
$this.data(Plugins.AutosizeInput.instanceKey, new Plugins.AutosizeInput(this, options)); | |
} | |
}); | |
}; | |
$(function () { | |
$("input[data-" + pluginDataAttributeName + "]").autosizeInput(); | |
}); | |
})(jQuery); | |
})(Plugins || (Plugins = {})); | |
// Generated by CoffeeScript 1.6.2 | |
/* | |
jQuery Waypoints - v2.0.4 | |
Copyright (c) 2011-2014 Caleb Troughton | |
Dual licensed under the MIT license and GPL license. | |
https://github.com/imakewebthings/jquery-waypoints/blob/master/licenses.txt | |
*/ | |
(function() { | |
var t = [].indexOf || function(t) { | |
for (var e = 0, n = this.length; e < n; e++) { | |
if (e in this && this[e] === t) | |
return e | |
} | |
return - 1 | |
}, e = [].slice; | |
(function(t, e) { | |
if (typeof define === "function" && define.amd) { | |
return define("waypoints", ["jquery"], function(n) { | |
return e(n, t) | |
}) | |
} else { | |
return e(t.jQuery, t) | |
} | |
})(this, function(n, r) { | |
var i, o, l, s, f, u, c, a, h, d, p, y, v, w, g, m; | |
i = n(r); | |
a = t.call(r, "ontouchstart") >= 0; | |
s = { | |
horizontal: {}, | |
vertical: {} | |
}; | |
f = 1; | |
c = {}; | |
u = "waypoints-context-id"; | |
p = "resize.waypoints"; | |
y = "scroll.waypoints"; | |
v = 1; | |
w = "waypoints-waypoint-ids"; | |
g = "waypoint"; | |
m = "waypoints"; | |
o = function() { | |
function t(t) { | |
var e = this; | |
this.$element = t; | |
this.element = t[0]; | |
this.didResize = false; | |
this.didScroll = false; | |
this.id = "context" + f++; | |
this.oldScroll = { | |
x: t.scrollLeft(), | |
y: t.scrollTop() | |
}; | |
this.waypoints = { | |
horizontal: {}, | |
vertical: {} | |
}; | |
this.element[u] = this.id; | |
c[this.id] = this; | |
t.bind(y, function() { | |
var t; | |
if (!(e.didScroll || a)) { | |
e.didScroll = true; | |
t = function() { | |
e.doScroll(); | |
return e.didScroll = false | |
}; | |
return r.setTimeout(t, n[m].settings.scrollThrottle) | |
} | |
}); | |
t.bind(p, function() { | |
var t; | |
if (!e.didResize) { | |
e.didResize = true; | |
t = function() { | |
n[m]("refresh"); | |
return e.didResize = false | |
}; | |
return r.setTimeout(t, n[m].settings.resizeThrottle) | |
} | |
}) | |
} | |
t.prototype.doScroll = function() { | |
var t, e = this; | |
t = { | |
horizontal: { | |
newScroll: this.$element.scrollLeft(), | |
oldScroll: this.oldScroll.x, | |
forward: "right", | |
backward: "left" | |
}, | |
vertical: { | |
newScroll: this.$element.scrollTop(), | |
oldScroll: this.oldScroll.y, | |
forward: "down", | |
backward: "up" | |
} | |
}; | |
if (a && (!t.vertical.oldScroll ||!t.vertical.newScroll)) { | |
n[m]("refresh") | |
} | |
n.each(t, function(t, r) { | |
var i, o, l; | |
l = []; | |
o = r.newScroll > r.oldScroll; | |
i = o ? r.forward : r.backward; | |
n.each(e.waypoints[t], function(t, e) { | |
var n, i; | |
if (r.oldScroll < (n = e.offset) && n <= r.newScroll) { | |
return l.push(e) | |
} else if (r.newScroll < (i = e.offset) && i <= r.oldScroll) { | |
return l.push(e) | |
} | |
}); | |
l.sort(function(t, e) { | |
return t.offset - e.offset | |
}); | |
if (!o) { | |
l.reverse() | |
} | |
return n.each(l, function(t, e) { | |
if (e.options.continuous || t === l.length - 1) { | |
return e.trigger([i]) | |
} | |
}) | |
}); | |
return this.oldScroll = { | |
x: t.horizontal.newScroll, | |
y: t.vertical.newScroll | |
} | |
}; | |
t.prototype.refresh = function() { | |
var t, e, r, i = this; | |
r = n.isWindow(this.element); | |
e = this.$element.offset(); | |
this.doScroll(); | |
t = { | |
horizontal: { | |
contextOffset: r ? 0: e.left, | |
contextScroll: r ? 0: this.oldScroll.x, | |
contextDimension: this.$element.width(), | |
oldScroll: this.oldScroll.x, | |
forward: "right", | |
backward: "left", | |
offsetProp: "left" | |
}, | |
vertical: { | |
contextOffset: r ? 0: e.top, | |
contextScroll: r ? 0: this.oldScroll.y, | |
contextDimension: r ? n[m]("viewportHeight"): this.$element.height(), | |
oldScroll: this.oldScroll.y, | |
forward: "down", | |
backward: "up", | |
offsetProp: "top" | |
} | |
}; | |
return n.each(t, function(t, e) { | |
return n.each(i.waypoints[t], function(t, r) { | |
var i, o, l, s, f; | |
i = r.options.offset; | |
l = r.offset; | |
o = n.isWindow(r.element) ? 0 : r.$element.offset()[e.offsetProp]; | |
if (n.isFunction(i)) { | |
i = i.apply(r.element) | |
} else if (typeof i === "string") { | |
i = parseFloat(i); | |
if (r.options.offset.indexOf("%")>-1) { | |
i = Math.ceil(e.contextDimension * i / 100) | |
} | |
} | |
r.offset = o - e.contextOffset + e.contextScroll - i; | |
if (r.options.onlyOnScroll && l != null ||!r.enabled) { | |
return | |
} | |
if (l !== null && l < (s = e.oldScroll) && s <= r.offset) { | |
return r.trigger([e.backward]) | |
} else if (l !== null && l > (f = e.oldScroll) && f >= r.offset) { | |
return r.trigger([e.forward]) | |
} else if (l === null && e.oldScroll >= r.offset) { | |
return r.trigger([e.forward]) | |
} | |
}) | |
}) | |
}; | |
t.prototype.checkEmpty = function() { | |
if (n.isEmptyObject(this.waypoints.horizontal) && n.isEmptyObject(this.waypoints.vertical)) { | |
this.$element.unbind([p, y].join(" ")); | |
return delete c[this.id] | |
} | |
}; | |
return t | |
}(); | |
l = function() { | |
function t(t, e, r) { | |
var i, o; | |
r = n.extend({}, n.fn[g].defaults, r); | |
if (r.offset === "bottom-in-view") { | |
r.offset = function() { | |
var t; | |
t = n[m]("viewportHeight"); | |
if (!n.isWindow(e.element)) { | |
t = e.$element.height() | |
} | |
return t - n(this).outerHeight() | |
} | |
} | |
this.$element = t; | |
this.element = t[0]; | |
this.axis = r.horizontal ? "horizontal" : "vertical"; | |
this.callback = r.handler; | |
this.context = e; | |
this.enabled = r.enabled; | |
this.id = "waypoints" + v++; | |
this.offset = null; | |
this.options = r; | |
e.waypoints[this.axis][this.id] = this; | |
s[this.axis][this.id] = this; | |
i = (o = this.element[w]) != null ? o : []; | |
i.push(this.id); | |
this.element[w] = i | |
} | |
t.prototype.trigger = function(t) { | |
if (!this.enabled) { | |
return | |
} | |
if (this.callback != null) { | |
this.callback.apply(this.element, t) | |
} | |
if (this.options.triggerOnce) { | |
return this.destroy() | |
} | |
}; | |
t.prototype.disable = function() { | |
return this.enabled = false | |
}; | |
t.prototype.enable = function() { | |
this.context.refresh(); | |
return this.enabled = true | |
}; | |
t.prototype.destroy = function() { | |
delete s[this.axis][this.id]; | |
delete this.context.waypoints[this.axis][this.id]; | |
return this.context.checkEmpty() | |
}; | |
t.getWaypointsByElement = function(t) { | |
var e, r; | |
r = t[w]; | |
if (!r) { | |
return [] | |
} | |
e = n.extend({}, s.horizontal, s.vertical); | |
return n.map(r, function(t) { | |
return e[t] | |
}) | |
}; | |
return t | |
}(); | |
d = { | |
init: function(t, e) { | |
var r; | |
if (e == null) { | |
e = {} | |
} | |
if ((r = e.handler) == null) { | |
e.handler = t | |
} | |
this.each(function() { | |
var t, r, i, s; | |
t = n(this); | |
i = (s = e.context) != null ? s : n.fn[g].defaults.context; | |
if (!n.isWindow(i)) { | |
i = t.closest(i) | |
} | |
i = n(i); | |
r = c[i[0][u]]; | |
if (!r) { | |
r = new o(i) | |
} | |
return new l(t, r, e) | |
}); | |
n[m]("refresh"); | |
return this | |
}, | |
disable: function() { | |
return d._invoke.call(this, "disable") | |
}, | |
enable: function() { | |
return d._invoke.call(this, "enable") | |
}, | |
destroy: function() { | |
return d._invoke.call(this, "destroy") | |
}, | |
prev: function(t, e) { | |
return d._traverse.call(this, t, e, function(t, e, n) { | |
if (e > 0) { | |
return t.push(n[e - 1]) | |
} | |
}) | |
}, | |
next: function(t, e) { | |
return d._traverse.call(this, t, e, function(t, e, n) { | |
if (e < n.length - 1) { | |
return t.push(n[e + 1]) | |
} | |
}) | |
}, | |
_traverse: function(t, e, i) { | |
var o, l; | |
if (t == null) { | |
t = "vertical" | |
} | |
if (e == null) { | |
e = r | |
} | |
l = h.aggregate(e); | |
o = []; | |
this.each(function() { | |
var e; | |
e = n.inArray(this, l[t]); | |
return i(o, e, l[t]) | |
}); | |
return this.pushStack(o) | |
}, | |
_invoke: function(t) { | |
this.each(function() { | |
var e; | |
e = l.getWaypointsByElement(this); | |
return n.each(e, function(e, n) { | |
n[t](); | |
return true | |
}) | |
}); | |
return this | |
} | |
}; | |
n.fn[g] = function() { | |
var t, r; | |
r = arguments[0], t = 2 <= arguments.length ? e.call(arguments, 1) : []; | |
if (d[r]) { | |
return d[r].apply(this, t) | |
} else if (n.isFunction(r)) { | |
return d.init.apply(this, arguments) | |
} else if (n.isPlainObject(r)) { | |
return d.init.apply(this, [null, r]) | |
} else if (!r) { | |
return n.error("jQuery Waypoints needs a callback function or handler option.") | |
} else { | |
return n.error("The " + r + " method does not exist in jQuery Waypoints.") | |
} | |
}; | |
n.fn[g].defaults = { | |
context: r, | |
continuous: true, | |
enabled: true, | |
horizontal: false, | |
offset: 0, | |
triggerOnce: false | |
}; | |
h = { | |
refresh: function() { | |
return n.each(c, function(t, e) { | |
return e.refresh() | |
}) | |
}, | |
viewportHeight: function() { | |
var t; | |
return (t = r.innerHeight) != null ? t : i.height() | |
}, | |
aggregate: function(t) { | |
var e, r, i; | |
e = s; | |
if (t) { | |
e = (i = c[n(t)[0][u]]) != null ? i.waypoints : void 0 | |
} | |
if (!e) { | |
return [] | |
} | |
r = { | |
horizontal: [], | |
vertical: [] | |
}; | |
n.each(r, function(t, i) { | |
n.each(e[t], function(t, e) { | |
return i.push(e) | |
}); | |
i.sort(function(t, e) { | |
return t.offset - e.offset | |
}); | |
r[t] = n.map(i, function(t) { | |
return t.element | |
}); | |
return r[t] = n.unique(r[t]) | |
}); | |
return r | |
}, | |
above: function(t) { | |
if (t == null) { | |
t = r | |
} | |
return h._filter(t, "vertical", function(t, e) { | |
return e.offset <= t.oldScroll.y | |
}) | |
}, | |
below: function(t) { | |
if (t == null) { | |
t = r | |
} | |
return h._filter(t, "vertical", function(t, e) { | |
return e.offset > t.oldScroll.y | |
}) | |
}, | |
left: function(t) { | |
if (t == null) { | |
t = r | |
} | |
return h._filter(t, "horizontal", function(t, e) { | |
return e.offset <= t.oldScroll.x | |
}) | |
}, | |
right: function(t) { | |
if (t == null) { | |
t = r | |
} | |
return h._filter(t, "horizontal", function(t, e) { | |
return e.offset > t.oldScroll.x | |
}) | |
}, | |
enable: function() { | |
return h._invoke("enable") | |
}, | |
disable: function() { | |
return h._invoke("disable") | |
}, | |
destroy: function() { | |
return h._invoke("destroy") | |
}, | |
extendFn: function(t, e) { | |
return d[t] = e | |
}, | |
_invoke: function(t) { | |
var e; | |
e = n.extend({}, s.vertical, s.horizontal); | |
return n.each(e, function(e, n) { | |
n[t](); | |
return true | |
}) | |
}, | |
_filter: function(t, e, r) { | |
var i, o; | |
i = c[n(t)[0][u]]; | |
if (!i) { | |
return [] | |
} | |
o = []; | |
n.each(i.waypoints[e], function(t, e) { | |
if (r(i, e)) { | |
return o.push(e) | |
} | |
}); | |
o.sort(function(t, e) { | |
return t.offset - e.offset | |
}); | |
return n.map(o, function(t) { | |
return t.element | |
}) | |
} | |
}; | |
n[m] = function() { | |
var t, n; | |
n = arguments[0], t = 2 <= arguments.length ? e.call(arguments, 1) : []; | |
if (h[n]) { | |
return h[n].apply(null, t) | |
} else { | |
return h.aggregate.call(null, n) | |
} | |
}; | |
n[m].settings = { | |
resizeThrottle: 100, | |
scrollThrottle: 30 | |
}; | |
return i.load(function() { | |
return n[m]("refresh") | |
}) | |
}) | |
}).call(this); | |
/** | |
* Copyright (c) 2007-2014 Ariel Flesler - aflesler<a>gmail<d>com | http://flesler.blogspot.com | |
* Licensed under MIT | |
* @author Ariel Flesler | |
* @version 1.4.11 | |
*/ | |
; | |
(function(a) { | |
if (typeof define === 'function' && define.amd) { | |
define(['jquery'], a) | |
} else { | |
a(jQuery) | |
} | |
}(function($) { | |
var j = $.scrollTo = function(a, b, c) { | |
return $(window).scrollTo(a, b, c) | |
}; | |
j.defaults = { | |
axis: 'xy', | |
duration: parseFloat($.fn.jquery) >= 1.3 ? 0: 1, | |
limit: true | |
}; | |
j.window = function(a) { | |
return $(window)._scrollable() | |
}; | |
$.fn._scrollable = function() { | |
return this.map(function() { | |
var a = this, isWin=!a.nodeName || $.inArray(a.nodeName.toLowerCase(), ['iframe', '#document', 'html', 'body'])!=-1; | |
if (!isWin) | |
return a; | |
var b = (a.contentWindow || a).document || a.ownerDocument || a; | |
return /webkit/i.test(navigator.userAgent) || b.compatMode == 'BackCompat' ? b.body : b.documentElement | |
}) | |
}; | |
$.fn.scrollTo = function(f, g, h) { | |
if (typeof g == 'object') { | |
h = g; | |
g = 0 | |
} | |
if (typeof h == 'function') | |
h = { | |
onAfter: h | |
}; | |
if (f == 'max') | |
f = 9e9; | |
h = $.extend({}, j.defaults, h); | |
g = g || h.duration; | |
h.queue = h.queue && h.axis.length > 1; | |
if (h.queue) | |
g/=2; | |
h.offset = both(h.offset); | |
h.over = both(h.over); | |
return this._scrollable().each(function() { | |
if (f == null) | |
return; | |
var d = this, $elem = $(d), targ = f, toff, attr = {}, win = $elem.is('html,body'); | |
switch (typeof targ) { | |
case'number': | |
case'string': | |
if (/^([+-]=?)?\d+(\.\d+)?(px|%)?$/.test(targ)) { | |
targ = both(targ); | |
break | |
} | |
targ = $(targ, this); | |
if (!targ.length) | |
return; | |
case'object': | |
if (targ.is || targ.style) | |
toff = (targ = $(targ)).offset() | |
} | |
var e = $.isFunction(h.offset) && h.offset(d, targ) || h.offset; | |
$.each(h.axis.split(''), function(i, a) { | |
var b = a == 'x' ? 'Left': 'Top', pos = b.toLowerCase(), key = 'scroll' + b, old = d[key], max = j.max(d, a); | |
if (toff) { | |
attr[key] = toff[pos] + (win ? 0 : old - $elem.offset()[pos]); | |
if (h.margin) { | |
attr[key] -= parseInt(targ.css('margin' + b)) || 0; | |
attr[key] -= parseInt(targ.css('border' + b + 'Width')) || 0 | |
} | |
attr[key] += e[pos] || 0; | |
if (h.over[pos]) | |
attr[key] += targ[a == 'x' ? 'width': 'height']() * h.over[pos] | |
} else { | |
var c = targ[pos]; | |
attr[key] = c.slice && c.slice( - 1) == '%' ? parseFloat(c) / 100 * max : c | |
} | |
if (h.limit && /^\d+$/.test(attr[key])) | |
attr[key] = attr[key] <= 0 ? 0 : Math.min(attr[key], max); | |
if (!i && h.queue) { | |
if (old != attr[key]) | |
animate(h.onAfterFirst); | |
delete attr[key] | |
} | |
}); | |
animate(h.onAfter); | |
function animate(a) { | |
$elem.animate(attr, g, h.easing, a && function() { | |
a.call(this, targ, h) | |
}) | |
} | |
}).end() | |
}; | |
j.max = function(a, b) { | |
var c = b == 'x' ? 'Width': 'Height', scroll = 'scroll' + c; | |
if (!$(a).is('html,body')) | |
return a[scroll] - $(a)[c.toLowerCase()](); | |
var d = 'client' + c, html = a.ownerDocument.documentElement, body = a.ownerDocument.body; | |
return Math.max(html[scroll], body[scroll]) - Math.min(html[d], body[d]) | |
}; | |
function both(a) { | |
return $.isFunction(a) || typeof a == 'object' ? a : { | |
top: a, | |
left: a | |
} | |
}; | |
return j | |
})); | |
/* | |
* jQuery Easing v1.3 - http://gsgd.co.uk/sandbox/jquery/easing/ | |
* | |
* Uses the built in easing capabilities added In jQuery 1.1 | |
* to offer multiple easing options | |
* | |
* TERMS OF USE - jQuery Easing | |
* | |
* Open source under the BSD License. | |
* | |
* Copyright © 2008 George McGinley Smith | |
* All rights reserved. | |
* | |
* Redistribution and use in source and binary forms, with or without modification, | |
* are permitted provided that the following conditions are met: | |
* | |
* Redistributions of source code must retain the above copyright notice, this list of | |
* conditions and the following disclaimer. | |
* Redistributions in binary form must reproduce the above copyright notice, this list | |
* of conditions and the following disclaimer in the documentation and/or other materials | |
* provided with the distribution. | |
* | |
* Neither the name of the author nor the names of contributors may be used to endorse | |
* or promote products derived from this software without specific prior written permission. | |
* | |
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY | |
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | |
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE | |
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | |
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE | |
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED | |
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | |
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED | |
* OF THE POSSIBILITY OF SUCH DAMAGE. | |
* | |
*/ | |
// t: current time, b: begInnIng value, c: change In value, d: duration | |
jQuery.easing['jswing'] = jQuery.easing['swing']; | |
jQuery.extend( jQuery.easing, | |
{ | |
def: 'easeOutQuad', | |
swing: function (x, t, b, c, d) { | |
//alert(jQuery.easing.default); | |
return jQuery.easing[jQuery.easing.def](x, t, b, c, d); | |
}, | |
easeInQuad: function (x, t, b, c, d) { | |
return c * (t/=d) * t + b; | |
}, | |
easeOutQuad: function (x, t, b, c, d) { | |
return - c * (t/=d) * (t - 2) + b; | |
}, | |
easeInOutQuad: function (x, t, b, c, d) { | |
if ((t/=d / 2) < 1) | |
return c / 2 * t * t + b; | |
return - c / 2 * ((--t) * (t - 2) - 1) + b; | |
}, | |
easeInCubic: function (x, t, b, c, d) { | |
return c * (t/=d) * t * t + b; | |
}, | |
easeOutCubic: function (x, t, b, c, d) { | |
return c * ((t = t / d - 1) * t * t + 1) + b; | |
}, | |
easeInOutCubic: function (x, t, b, c, d) { | |
if ((t/=d / 2) < 1) | |
return c / 2 * t * t * t + b; | |
return c / 2 * ((t -= 2) * t * t + 2) + b; | |
}, | |
easeInQuart: function (x, t, b, c, d) { | |
return c * (t/=d) * t * t * t + b; | |
}, | |
easeOutQuart: function (x, t, b, c, d) { | |
return - c * ((t = t / d - 1) * t * t * t - 1) + b; | |
}, | |
easeInOutQuart: function (x, t, b, c, d) { | |
if ((t/=d / 2) < 1) | |
return c / 2 * t * t * t * t + b; | |
return - c / 2 * ((t -= 2) * t * t * t - 2) + b; | |
}, | |
easeInQuint: function (x, t, b, c, d) { | |
return c * (t/=d) * t * t * t * t + b; | |
}, | |
easeOutQuint: function (x, t, b, c, d) { | |
return c * ((t = t / d - 1) * t * t * t * t + 1) + b; | |
}, | |
easeInOutQuint: function (x, t, b, c, d) { | |
if ((t/=d / 2) < 1) | |
return c / 2 * t * t * t * t * t + b; | |
return c / 2 * ((t -= 2) * t * t * t * t + 2) + b; | |
}, | |
easeInSine: function (x, t, b, c, d) { | |
return - c * Math.cos(t / d * (Math.PI / 2)) + c + b; | |
}, | |
easeOutSine: function (x, t, b, c, d) { | |
return c * Math.sin(t / d * (Math.PI / 2)) + b; | |
}, | |
easeInOutSine: function (x, t, b, c, d) { | |
return - c / 2 * (Math.cos(Math.PI * t / d) - 1) + b; | |
}, | |
easeInExpo: function (x, t, b, c, d) { | |
return (t == 0) ? b : c * Math.pow(2, 10 * (t / d - 1)) + b; | |
}, | |
easeOutExpo: function (x, t, b, c, d) { | |
return (t == d) ? b + c : c * ( - Math.pow(2, - 10 * t / d) + 1) + b; | |
}, | |
easeInOutExpo: function (x, t, b, c, d) { | |
if (t == 0) | |
return b; | |
if (t == d) | |
return b + c; | |
if ((t/=d / 2) < 1) | |
return c / 2 * Math.pow(2, 10 * (t - 1)) + b; | |
return c / 2 * ( - Math.pow(2, - 10 * --t) + 2) + b; | |
}, | |
easeInCirc: function (x, t, b, c, d) { | |
return - c * (Math.sqrt(1 - (t/=d) * t) - 1) + b; | |
}, | |
easeOutCirc: function (x, t, b, c, d) { | |
return c * Math.sqrt(1 - (t = t / d - 1) * t) + b; | |
}, | |
easeInOutCirc: function (x, t, b, c, d) { | |
if ((t/=d / 2) < 1) | |
return - c / 2 * (Math.sqrt(1 - t * t) - 1) + b; | |
return c / 2 * (Math.sqrt(1 - (t -= 2) * t) + 1) + b; | |
}, | |
easeInElastic: function (x, t, b, c, d) { | |
var s = 1.70158; | |
var p = 0; | |
var a = c; | |
if (t == 0) | |
return b; | |
if ((t/=d) == 1) | |
return b + c; | |
if (!p) | |
p = d * .3; | |
if (a < Math.abs(c)) { | |
a = c; | |
var s = p / 4; | |
} else | |
var s = p / (2 * Math.PI) * Math.asin (c / a); | |
return - (a * Math.pow(2, 10 * (t -= 1)) * Math.sin( (t * d - s) * (2 * Math.PI) / p )) + b; | |
}, | |
easeOutElastic: function (x, t, b, c, d) { | |
var s = 1.70158; | |
var p = 0; | |
var a = c; | |
if (t == 0) | |
return b; | |
if ((t/=d) == 1) | |
return b + c; | |
if (!p) | |
p = d * .3; | |
if (a < Math.abs(c)) { | |
a = c; | |
var s = p / 4; | |
} else | |
var s = p / (2 * Math.PI) * Math.asin (c / a); | |
return a * Math.pow(2, - 10 * t) * Math.sin( (t * d - s) * (2 * Math.PI) / p ) + c + b; | |
}, | |
easeInOutElastic: function (x, t, b, c, d) { | |
var s = 1.70158; | |
var p = 0; | |
var a = c; | |
if (t == 0) | |
return b; | |
if ((t/=d / 2) == 2) | |
return b + c; | |
if (!p) | |
p = d * (.3 * 1.5); | |
if (a < Math.abs(c)) { | |
a = c; | |
var s = p / 4; | |
} else | |
var s = p / (2 * Math.PI) * Math.asin (c / a); | |
if (t < 1) | |
return - .5 * (a * Math.pow(2, 10 * (t -= 1)) * Math.sin( (t * d - s) * (2 * Math.PI) / p )) + b; | |
return a * Math.pow(2, - 10 * (t -= 1)) * Math.sin( (t * d - s) * (2 * Math.PI) / p ) * .5 + c + b; | |
}, | |
easeInBack: function (x, t, b, c, d, s) { | |
if (s == undefined) | |
s = 1.70158; | |
return c * (t/=d) * t * ((s + 1) * t - s) + b; | |
}, | |
easeOutBack: function (x, t, b, c, d, s) { | |
if (s == undefined) | |
s = 1.70158; | |
return c * ((t = t / d - 1) * t * ((s + 1) * t + s) + 1) + b; | |
}, | |
easeInOutBack: function (x, t, b, c, d, s) { | |
if (s == undefined) | |
s = 1.70158; | |
if ((t/=d / 2) < 1) | |
return c / 2 * (t * t * (((s*=(1.525)) + 1) * t - s)) + b; | |
return c / 2 * ((t -= 2) * t * (((s*=(1.525)) + 1) * t + s) + 2) + b; | |
}, | |
easeInBounce: function (x, t, b, c, d) { | |
return c - jQuery.easing.easeOutBounce (x, d - t, 0, c, d) + b; | |
}, | |
easeOutBounce: function (x, t, b, c, d) { | |
if ((t/=d) < (1 / 2.75)) { | |
return c * (7.5625 * t * t) + b; | |
} else if (t < (2 / 2.75)) { | |
return c * (7.5625 * (t -= (1.5 / 2.75)) * t + .75) + b; | |
} else if (t < (2.5 / 2.75)) { | |
return c * (7.5625 * (t -= (2.25 / 2.75)) * t + .9375) + b; | |
} else { | |
return c * (7.5625 * (t -= (2.625 / 2.75)) * t + .984375) + b; | |
} | |
}, | |
easeInOutBounce: function (x, t, b, c, d) { | |
if (t < d / 2) | |
return jQuery.easing.easeInBounce (x, t * 2, 0, c, d) * .5 + b; | |
return jQuery.easing.easeOutBounce (x, t * 2 - d, 0, c, d) * .5 + c * .5 + b; | |
} | |
}); | |
/* | |
* | |
* TERMS OF USE - EASING EQUATIONS | |
* | |
* Open source under the BSD License. | |
* | |
* Copyright © 2001 Robert Penner | |
* All rights reserved. | |
* | |
* Redistribution and use in source and binary forms, with or without modification, | |
* are permitted provided that the following conditions are met: | |
* | |
* Redistributions of source code must retain the above copyright notice, this list of | |
* conditions and the following disclaimer. | |
* Redistributions in binary form must reproduce the above copyright notice, this list | |
* of conditions and the following disclaimer in the documentation and/or other materials | |
* provided with the distribution. | |
* | |
* Neither the name of the author nor the names of contributors may be used to endorse | |
* or promote products derived from this software without specific prior written permission. | |
* | |
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY | |
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | |
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE | |
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | |
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE | |
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED | |
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | |
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED | |
* OF THE POSSIBILITY OF SUCH DAMAGE. | |
* | |
*/ | |
/* | |
Copyright 2012 Igor Vaynberg | |
Version: 3.4.5 Timestamp: Mon Nov 4 08:22:42 PST 2013 | |
This software is licensed under the Apache License, Version 2.0 (the "Apache License") or the GNU | |
General Public License version 2 (the "GPL License"). You may choose either license to govern your | |
use of this software only upon the condition that you accept all of the terms of either the Apache | |
License or the GPL License. | |
You may obtain a copy of the Apache License and the GPL License at: | |
http://www.apache.org/licenses/LICENSE-2.0 | |
http://www.gnu.org/licenses/gpl-2.0.html | |
Unless required by applicable law or agreed to in writing, software distributed under the Apache License | |
or the GPL Licesnse is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, | |
either express or implied. See the Apache License and the GPL License for the specific language governing | |
permissions and limitations under the Apache License and the GPL License. | |
*/ | |
!function(a) { | |
"undefined" == typeof a.fn.each2 && a.extend(a.fn, { | |
each2: function(b) { | |
for (var c = a([0]), d =- 1, e = this.length; ++d < e && (c.context = c[0] = this[d]) && b.call(c[0], d, c)!==!1;); | |
return this | |
} | |
}) | |
}(jQuery), function(a, b) { | |
"use strict"; | |
function n(a) { | |
var b, c, d, e; | |
if (!a || a.length < 1) | |
return a; | |
for (b = "", c = 0, d = a.length; d > c; c++) | |
e = a.charAt(c), b += m[e] || e; | |
return b | |
} | |
function o(a, b) { | |
for (var c = 0, d = b.length; d > c; c += 1) | |
if (q(a, b[c])) | |
return c; | |
return - 1 | |
} | |
function p() { | |
var b = a(l); | |
b.appendTo("body"); | |
var c = { | |
width: b.width() - b[0].clientWidth, | |
height: b.height() - b[0].clientHeight | |
}; | |
return b.remove(), c | |
} | |
function q(a, c) { | |
return a === c?!0 : a === b || c === b?!1 : null === a || null === c?!1 : a.constructor === String ? a + "" == c + "" : c.constructor === String ? c + "" == a + "" : !1 | |
} | |
function r(b, c) { | |
var d, e, f; | |
if (null === b || b.length < 1) | |
return []; | |
for (d = b.split(c), e = 0, f = d.length; f > e; e += 1) | |
d[e] = a.trim(d[e]); | |
return d | |
} | |
function s(a) { | |
return a.outerWidth(!1) - a.width() | |
} | |
function t(c) { | |
var d = "keyup-change-value"; | |
c.on("keydown", function() { | |
a.data(c, d) === b && a.data(c, d, c.val()) | |
}), c.on("keyup", function() { | |
var e = a.data(c, d); | |
e !== b && c.val() !== e && (a.removeData(c, d), c.trigger("keyup-change")) | |
}) | |
} | |
function u(c) { | |
c.on("mousemove", function(c) { | |
var d = i; | |
(d === b || d.x !== c.pageX || d.y !== c.pageY) && a(c.target).trigger("mousemove-filtered", c) | |
}) | |
} | |
function v(a, c, d) { | |
d = d || b; | |
var e; | |
return function() { | |
var b = arguments; | |
window.clearTimeout(e), e = window.setTimeout(function() { | |
c.apply(d, b) | |
}, a) | |
} | |
} | |
function w(a) { | |
var c, b=!1; | |
return function() { | |
return b===!1 && (c = a(), b=!0), c | |
} | |
} | |
function x(a, b) { | |
var c = v(a, function(a) { | |
b.trigger("scroll-debounced", a) | |
}); | |
b.on("scroll", function(a) { | |
o(a.target, b.get()) >= 0 && c(a) | |
}) | |
} | |
function y(a) { | |
a[0] !== document.activeElement && window.setTimeout(function() { | |
var d, b = a[0], c = a.val().length; | |
a.focus(), a.is(":visible") && b === document.activeElement && (b.setSelectionRange ? b.setSelectionRange(c, c) : b.createTextRange && (d = b.createTextRange(), d.collapse(!1), d.select())) | |
}, 0) | |
} | |
function z(b) { | |
b = a(b)[0]; | |
var c = 0, d = 0; | |
if ("selectionStart"in b) | |
c = b.selectionStart, d = b.selectionEnd - c; | |
else if ("selection"in document) { | |
b.focus(); | |
var e = document.selection.createRange(); | |
d = document.selection.createRange().text.length, e.moveStart("character", - b.value.length), c = e.text.length - d | |
} | |
return { | |
offset: c, | |
length: d | |
} | |
} | |
function A(a) { | |
a.preventDefault(), a.stopPropagation() | |
} | |
function B(a) { | |
a.preventDefault(), a.stopImmediatePropagation() | |
} | |
function C(b) { | |
if (!h) { | |
var c = b[0].currentStyle || window.getComputedStyle(b[0], null); | |
h = a(document.createElement("div")).css({ | |
position: "absolute", | |
left: "-10000px", | |
top: "-10000px", | |
display: "none", | |
fontSize: c.fontSize, | |
fontFamily: c.fontFamily, | |
fontStyle: c.fontStyle, | |
fontWeight: c.fontWeight, | |
letterSpacing: c.letterSpacing, | |
textTransform: c.textTransform, | |
whiteSpace: "nowrap" | |
}), h.attr("class", "select2-sizer"), a("body").append(h) | |
} | |
return h.text(b.val()), h.width() | |
} | |
function D(b, c, d) { | |
var e, g, f = []; | |
e = b.attr("class"), e && (e = "" + e, a(e.split(" ")).each2(function() { | |
0 === this.indexOf("select2-") && f.push(this) | |
})), e = c.attr("class"), e && (e = "" + e, a(e.split(" ")).each2(function() { | |
0 !== this.indexOf("select2-") && (g = d(this), g && f.push(g)) | |
})), b.attr("class", f.join(" ")) | |
} | |
function E(a, b, c, d) { | |
var e = n(a.toUpperCase()).indexOf(n(b.toUpperCase())), f = b.length; | |
return 0 > e ? (c.push(d(a)), void 0) : (c.push(d(a.substring(0, e))), c.push("<span class='select2-match'>"), c.push(d(a.substring(e, e + f))), c.push("</span>"), c.push(d(a.substring(e + f, a.length))), void 0) | |
} | |
function F(a) { | |
var b = { | |
"\\": "\", | |
"&": "&", | |
"<": "<", | |
">": ">", | |
'"': """, | |
"'": "'", | |
"/": "/" | |
}; | |
return String(a).replace(/[&<>"'\/\\]/g, function(a) { | |
return b[a] | |
}) | |
} | |
function G(c) { | |
var d, e = null, f = c.quietMillis || 100, g = c.url, h = this; | |
return function(i) { | |
window.clearTimeout(d), d = window.setTimeout(function() { | |
var d = c.data, f = g, j = c.transport || a.fn.select2.ajaxDefaults.transport, k = { | |
type: c.type || "GET", | |
cache: c.cache ||!1, | |
jsonpCallback: c.jsonpCallback || b, | |
dataType: c.dataType || "json" | |
}, l = a.extend({}, a.fn.select2.ajaxDefaults.params, k); | |
d = d ? d.call(h, i.term, i.page, i.context) : null, f = "function" == typeof f ? f.call(h, i.term, i.page, i.context) : f, e && e.abort(), c.params && (a.isFunction(c.params) ? a.extend(l, c.params.call(h)) : a.extend(l, c.params)), a.extend(l, { | |
url: f, | |
dataType: c.dataType, | |
data: d, | |
success: function(a) { | |
var b = c.results(a, i.page); | |
i.callback(b) | |
} | |
}), e = j.call(h, l) | |
}, f) | |
} | |
} | |
function H(b) { | |
var d, e, c = b, f = function(a) { | |
return "" + a.text | |
}; | |
a.isArray(c) && (e = c, c = { | |
results: e | |
}), a.isFunction(c)===!1 && (e = c, c = function() { | |
return e | |
}); | |
var g = c(); | |
return g.text && (f = g.text, a.isFunction(f) || (d = g.text, f = function(a) { | |
return a[d] | |
})), function(b) { | |
var g, d = b.term, e = { | |
results: [] | |
}; | |
return "" === d ? (b.callback(c()), void 0) : (g = function(c, e) { | |
var h, i; | |
if (c = c[0], c.children) { | |
h = {}; | |
for (i in c) | |
c.hasOwnProperty(i) && (h[i] = c[i]); | |
h.children = [], a(c.children).each2(function(a, b) { | |
g(b, h.children) | |
}), (h.children.length || b.matcher(d, f(h), c)) && e.push(h) | |
} else | |
b.matcher(d, f(c), c) && e.push(c) | |
}, a(c().results).each2(function(a, b) { | |
g(b, e.results) | |
}), b.callback(e), void 0) | |
} | |
} | |
function I(c) { | |
var d = a.isFunction(c); | |
return function(e) { | |
var f = e.term, g = { | |
results: [] | |
}; | |
a(d ? c() : c).each(function() { | |
var a = this.text !== b, c = a ? this.text: this; | |
("" === f || e.matcher(f, c)) && g.results.push(a ? this : { | |
id: this, | |
text: this | |
}) | |
}), e.callback(g) | |
} | |
} | |
function J(b, c) { | |
if (a.isFunction(b)) | |
return !0; | |
if (!b) | |
return !1; | |
throw new Error(c + " must be a function or a falsy value") | |
} | |
function K(b) { | |
return a.isFunction(b) ? b() : b | |
} | |
function L(b) { | |
var c = 0; | |
return a.each(b, function(a, b) { | |
b.children ? c += L(b.children) : c++ | |
}), c | |
} | |
function M(a, c, d, e) { | |
var h, i, j, k, l, f = a, g=!1; | |
if (!e.createSearchChoice ||!e.tokenSeparators || e.tokenSeparators.length < 1) | |
return b; | |
for (; ;) { | |
for (i =- 1, j = 0, k = e.tokenSeparators.length; k > j && (l = e.tokenSeparators[j], i = a.indexOf(l), !(i >= 0)); j++); | |
if (0 > i) | |
break; | |
if (h = a.substring(0, i), a = a.substring(i + l.length), h.length > 0 && (h = e.createSearchChoice.call(this, h, c), h !== b && null !== h && e.id(h) !== b && null !== e.id(h))) { | |
for (g=!1, j = 0, k = c.length; k > j; j++) | |
if (q(e.id(h), e.id(c[j]))) { | |
g=!0; | |
break | |
} | |
g || d(h) | |
} | |
} | |
return f !== a ? a : void 0 | |
} | |
function N(b, c) { | |
var d = function() {}; | |
return d.prototype = new b, d.prototype.constructor = d, d.prototype.parent = b.prototype, d.prototype = a.extend(d.prototype, c), d | |
} | |
if (window.Select2 === b) { | |
var c, d, e, f, g, h, j, k, i = { | |
x: 0, | |
y: 0 | |
}, c = { | |
TAB: 9, | |
ENTER: 13, | |
ESC: 27, | |
SPACE: 32, | |
LEFT: 37, | |
UP: 38, | |
RIGHT: 39, | |
DOWN: 40, | |
SHIFT: 16, | |
CTRL: 17, | |
ALT: 18, | |
PAGE_UP: 33, | |
PAGE_DOWN: 34, | |
HOME: 36, | |
END: 35, | |
BACKSPACE: 8, | |
DELETE: 46, | |
isArrow: function(a) { | |
switch (a = a.which ? a.which : a) { | |
case c.LEFT: | |
case c.RIGHT: | |
case c.UP: | |
case c.DOWN: | |
return !0 | |
} | |
return !1 | |
}, | |
isControl: function(a) { | |
var b = a.which; | |
switch (b) { | |
case c.SHIFT: | |
case c.CTRL: | |
case c.ALT: | |
return !0 | |
} | |
return a.metaKey?!0 : !1 | |
}, | |
isFunctionKey: function(a) { | |
return a = a.which ? a.which : a, a >= 112 && 123 >= a | |
} | |
}, l = "<div class='select2-measure-scrollbar'></div>", m = { | |
"\u24b6": "A", | |
"\uff21": "A", | |
"\xc0": "A", | |
"\xc1": "A", | |
"\xc2": "A", | |
"\u1ea6": "A", | |
"\u1ea4": "A", | |
"\u1eaa": "A", | |
"\u1ea8": "A", | |
"\xc3": "A", | |
"\u0100": "A", | |
"\u0102": "A", | |
"\u1eb0": "A", | |
"\u1eae": "A", | |
"\u1eb4": "A", | |
"\u1eb2": "A", | |
"\u0226": "A", | |
"\u01e0": "A", | |
"\xc4": "A", | |
"\u01de": "A", | |
"\u1ea2": "A", | |
"\xc5": "A", | |
"\u01fa": "A", | |
"\u01cd": "A", | |
"\u0200": "A", | |
"\u0202": "A", | |
"\u1ea0": "A", | |
"\u1eac": "A", | |
"\u1eb6": "A", | |
"\u1e00": "A", | |
"\u0104": "A", | |
"\u023a": "A", | |
"\u2c6f": "A", | |
"\ua732": "AA", | |
"\xc6": "AE", | |
"\u01fc": "AE", | |
"\u01e2": "AE", | |
"\ua734": "AO", | |
"\ua736": "AU", | |
"\ua738": "AV", | |
"\ua73a": "AV", | |
"\ua73c": "AY", | |
"\u24b7": "B", | |
"\uff22": "B", | |
"\u1e02": "B", | |
"\u1e04": "B", | |
"\u1e06": "B", | |
"\u0243": "B", | |
"\u0182": "B", | |
"\u0181": "B", | |
"\u24b8": "C", | |
"\uff23": "C", | |
"\u0106": "C", | |
"\u0108": "C", | |
"\u010a": "C", | |
"\u010c": "C", | |
"\xc7": "C", | |
"\u1e08": "C", | |
"\u0187": "C", | |
"\u023b": "C", | |
"\ua73e": "C", | |
"\u24b9": "D", | |
"\uff24": "D", | |
"\u1e0a": "D", | |
"\u010e": "D", | |
"\u1e0c": "D", | |
"\u1e10": "D", | |
"\u1e12": "D", | |
"\u1e0e": "D", | |
"\u0110": "D", | |
"\u018b": "D", | |
"\u018a": "D", | |
"\u0189": "D", | |
"\ua779": "D", | |
"\u01f1": "DZ", | |
"\u01c4": "DZ", | |
"\u01f2": "Dz", | |
"\u01c5": "Dz", | |
"\u24ba": "E", | |
"\uff25": "E", | |
"\xc8": "E", | |
"\xc9": "E", | |
"\xca": "E", | |
"\u1ec0": "E", | |
"\u1ebe": "E", | |
"\u1ec4": "E", | |
"\u1ec2": "E", | |
"\u1ebc": "E", | |
"\u0112": "E", | |
"\u1e14": "E", | |
"\u1e16": "E", | |
"\u0114": "E", | |
"\u0116": "E", | |
"\xcb": "E", | |
"\u1eba": "E", | |
"\u011a": "E", | |
"\u0204": "E", | |
"\u0206": "E", | |
"\u1eb8": "E", | |
"\u1ec6": "E", | |
"\u0228": "E", | |
"\u1e1c": "E", | |
"\u0118": "E", | |
"\u1e18": "E", | |
"\u1e1a": "E", | |
"\u0190": "E", | |
"\u018e": "E", | |
"\u24bb": "F", | |
"\uff26": "F", | |
"\u1e1e": "F", | |
"\u0191": "F", | |
"\ua77b": "F", | |
"\u24bc": "G", | |
"\uff27": "G", | |
"\u01f4": "G", | |
"\u011c": "G", | |
"\u1e20": "G", | |
"\u011e": "G", | |
"\u0120": "G", | |
"\u01e6": "G", | |
"\u0122": "G", | |
"\u01e4": "G", | |
"\u0193": "G", | |
"\ua7a0": "G", | |
"\ua77d": "G", | |
"\ua77e": "G", | |
"\u24bd": "H", | |
"\uff28": "H", | |
"\u0124": "H", | |
"\u1e22": "H", | |
"\u1e26": "H", | |
"\u021e": "H", | |
"\u1e24": "H", | |
"\u1e28": "H", | |
"\u1e2a": "H", | |
"\u0126": "H", | |
"\u2c67": "H", | |
"\u2c75": "H", | |
"\ua78d": "H", | |
"\u24be": "I", | |
"\uff29": "I", | |
"\xcc": "I", | |
"\xcd": "I", | |
"\xce": "I", | |
"\u0128": "I", | |
"\u012a": "I", | |
"\u012c": "I", | |
"\u0130": "I", | |
"\xcf": "I", | |
"\u1e2e": "I", | |
"\u1ec8": "I", | |
"\u01cf": "I", | |
"\u0208": "I", | |
"\u020a": "I", | |
"\u1eca": "I", | |
"\u012e": "I", | |
"\u1e2c": "I", | |
"\u0197": "I", | |
"\u24bf": "J", | |
"\uff2a": "J", | |
"\u0134": "J", | |
"\u0248": "J", | |
"\u24c0": "K", | |
"\uff2b": "K", | |
"\u1e30": "K", | |
"\u01e8": "K", | |
"\u1e32": "K", | |
"\u0136": "K", | |
"\u1e34": "K", | |
"\u0198": "K", | |
"\u2c69": "K", | |
"\ua740": "K", | |
"\ua742": "K", | |
"\ua744": "K", | |
"\ua7a2": "K", | |
"\u24c1": "L", | |
"\uff2c": "L", | |
"\u013f": "L", | |
"\u0139": "L", | |
"\u013d": "L", | |
"\u1e36": "L", | |
"\u1e38": "L", | |
"\u013b": "L", | |
"\u1e3c": "L", | |
"\u1e3a": "L", | |
"\u0141": "L", | |
"\u023d": "L", | |
"\u2c62": "L", | |
"\u2c60": "L", | |
"\ua748": "L", | |
"\ua746": "L", | |
"\ua780": "L", | |
"\u01c7": "LJ", | |
"\u01c8": "Lj", | |
"\u24c2": "M", | |
"\uff2d": "M", | |
"\u1e3e": "M", | |
"\u1e40": "M", | |
"\u1e42": "M", | |
"\u2c6e": "M", | |
"\u019c": "M", | |
"\u24c3": "N", | |
"\uff2e": "N", | |
"\u01f8": "N", | |
"\u0143": "N", | |
"\xd1": "N", | |
"\u1e44": "N", | |
"\u0147": "N", | |
"\u1e46": "N", | |
"\u0145": "N", | |
"\u1e4a": "N", | |
"\u1e48": "N", | |
"\u0220": "N", | |
"\u019d": "N", | |
"\ua790": "N", | |
"\ua7a4": "N", | |
"\u01ca": "NJ", | |
"\u01cb": "Nj", | |
"\u24c4": "O", | |
"\uff2f": "O", | |
"\xd2": "O", | |
"\xd3": "O", | |
"\xd4": "O", | |
"\u1ed2": "O", | |
"\u1ed0": "O", | |
"\u1ed6": "O", | |
"\u1ed4": "O", | |
"\xd5": "O", | |
"\u1e4c": "O", | |
"\u022c": "O", | |
"\u1e4e": "O", | |
"\u014c": "O", | |
"\u1e50": "O", | |
"\u1e52": "O", | |
"\u014e": "O", | |
"\u022e": "O", | |
"\u0230": "O", | |
"\xd6": "O", | |
"\u022a": "O", | |
"\u1ece": "O", | |
"\u0150": "O", | |
"\u01d1": "O", | |
"\u020c": "O", | |
"\u020e": "O", | |
"\u01a0": "O", | |
"\u1edc": "O", | |
"\u1eda": "O", | |
"\u1ee0": "O", | |
"\u1ede": "O", | |
"\u1ee2": "O", | |
"\u1ecc": "O", | |
"\u1ed8": "O", | |
"\u01ea": "O", | |
"\u01ec": "O", | |
"\xd8": "O", | |
"\u01fe": "O", | |
"\u0186": "O", | |
"\u019f": "O", | |
"\ua74a": "O", | |
"\ua74c": "O", | |
"\u01a2": "OI", | |
"\ua74e": "OO", | |
"\u0222": "OU", | |
"\u24c5": "P", | |
"\uff30": "P", | |
"\u1e54": "P", | |
"\u1e56": "P", | |
"\u01a4": "P", | |
"\u2c63": "P", | |
"\ua750": "P", | |
"\ua752": "P", | |
"\ua754": "P", | |
"\u24c6": "Q", | |
"\uff31": "Q", | |
"\ua756": "Q", | |
"\ua758": "Q", | |
"\u024a": "Q", | |
"\u24c7": "R", | |
"\uff32": "R", | |
"\u0154": "R", | |
"\u1e58": "R", | |
"\u0158": "R", | |
"\u0210": "R", | |
"\u0212": "R", | |
"\u1e5a": "R", | |
"\u1e5c": "R", | |
"\u0156": "R", | |
"\u1e5e": "R", | |
"\u024c": "R", | |
"\u2c64": "R", | |
"\ua75a": "R", | |
"\ua7a6": "R", | |
"\ua782": "R", | |
"\u24c8": "S", | |
"\uff33": "S", | |
"\u1e9e": "S", | |
"\u015a": "S", | |
"\u1e64": "S", | |
"\u015c": "S", | |
"\u1e60": "S", | |
"\u0160": "S", | |
"\u1e66": "S", | |
"\u1e62": "S", | |
"\u1e68": "S", | |
"\u0218": "S", | |
"\u015e": "S", | |
"\u2c7e": "S", | |
"\ua7a8": "S", | |
"\ua784": "S", | |
"\u24c9": "T", | |
"\uff34": "T", | |
"\u1e6a": "T", | |
"\u0164": "T", | |
"\u1e6c": "T", | |
"\u021a": "T", | |
"\u0162": "T", | |
"\u1e70": "T", | |
"\u1e6e": "T", | |
"\u0166": "T", | |
"\u01ac": "T", | |
"\u01ae": "T", | |
"\u023e": "T", | |
"\ua786": "T", | |
"\ua728": "TZ", | |
"\u24ca": "U", | |
"\uff35": "U", | |
"\xd9": "U", | |
"\xda": "U", | |
"\xdb": "U", | |
"\u0168": "U", | |
"\u1e78": "U", | |
"\u016a": "U", | |
"\u1e7a": "U", | |
"\u016c": "U", | |
"\xdc": "U", | |
"\u01db": "U", | |
"\u01d7": "U", | |
"\u01d5": "U", | |
"\u01d9": "U", | |
"\u1ee6": "U", | |
"\u016e": "U", | |
"\u0170": "U", | |
"\u01d3": "U", | |
"\u0214": "U", | |
"\u0216": "U", | |
"\u01af": "U", | |
"\u1eea": "U", | |
"\u1ee8": "U", | |
"\u1eee": "U", | |
"\u1eec": "U", | |
"\u1ef0": "U", | |
"\u1ee4": "U", | |
"\u1e72": "U", | |
"\u0172": "U", | |
"\u1e76": "U", | |
"\u1e74": "U", | |
"\u0244": "U", | |
"\u24cb": "V", | |
"\uff36": "V", | |
"\u1e7c": "V", | |
"\u1e7e": "V", | |
"\u01b2": "V", | |
"\ua75e": "V", | |
"\u0245": "V", | |
"\ua760": "VY", | |
"\u24cc": "W", | |
"\uff37": "W", | |
"\u1e80": "W", | |
"\u1e82": "W", | |
"\u0174": "W", | |
"\u1e86": "W", | |
"\u1e84": "W", | |
"\u1e88": "W", | |
"\u2c72": "W", | |
"\u24cd": "X", | |
"\uff38": "X", | |
"\u1e8a": "X", | |
"\u1e8c": "X", | |
"\u24ce": "Y", | |
"\uff39": "Y", | |
"\u1ef2": "Y", | |
"\xdd": "Y", | |
"\u0176": "Y", | |
"\u1ef8": "Y", | |
"\u0232": "Y", | |
"\u1e8e": "Y", | |
"\u0178": "Y", | |
"\u1ef6": "Y", | |
"\u1ef4": "Y", | |
"\u01b3": "Y", | |
"\u024e": "Y", | |
"\u1efe": "Y", | |
"\u24cf": "Z", | |
"\uff3a": "Z", | |
"\u0179": "Z", | |
"\u1e90": "Z", | |
"\u017b": "Z", | |
"\u017d": "Z", | |
"\u1e92": "Z", | |
"\u1e94": "Z", | |
"\u01b5": "Z", | |
"\u0224": "Z", | |
"\u2c7f": "Z", | |
"\u2c6b": "Z", | |
"\ua762": "Z", | |
"\u24d0": "a", | |
"\uff41": "a", | |
"\u1e9a": "a", | |
"\xe0": "a", | |
"\xe1": "a", | |
"\xe2": "a", | |
"\u1ea7": "a", | |
"\u1ea5": "a", | |
"\u1eab": "a", | |
"\u1ea9": "a", | |
"\xe3": "a", | |
"\u0101": "a", | |
"\u0103": "a", | |
"\u1eb1": "a", | |
"\u1eaf": "a", | |
"\u1eb5": "a", | |
"\u1eb3": "a", | |
"\u0227": "a", | |
"\u01e1": "a", | |
"\xe4": "a", | |
"\u01df": "a", | |
"\u1ea3": "a", | |
"\xe5": "a", | |
"\u01fb": "a", | |
"\u01ce": "a", | |
"\u0201": "a", | |
"\u0203": "a", | |
"\u1ea1": "a", | |
"\u1ead": "a", | |
"\u1eb7": "a", | |
"\u1e01": "a", | |
"\u0105": "a", | |
"\u2c65": "a", | |
"\u0250": "a", | |
"\ua733": "aa", | |
"\xe6": "ae", | |
"\u01fd": "ae", | |
"\u01e3": "ae", | |
"\ua735": "ao", | |
"\ua737": "au", | |
"\ua739": "av", | |
"\ua73b": "av", | |
"\ua73d": "ay", | |
"\u24d1": "b", | |
"\uff42": "b", | |
"\u1e03": "b", | |
"\u1e05": "b", | |
"\u1e07": "b", | |
"\u0180": "b", | |
"\u0183": "b", | |
"\u0253": "b", | |
"\u24d2": "c", | |
"\uff43": "c", | |
"\u0107": "c", | |
"\u0109": "c", | |
"\u010b": "c", | |
"\u010d": "c", | |
"\xe7": "c", | |
"\u1e09": "c", | |
"\u0188": "c", | |
"\u023c": "c", | |
"\ua73f": "c", | |
"\u2184": "c", | |
"\u24d3": "d", | |
"\uff44": "d", | |
"\u1e0b": "d", | |
"\u010f": "d", | |
"\u1e0d": "d", | |
"\u1e11": "d", | |
"\u1e13": "d", | |
"\u1e0f": "d", | |
"\u0111": "d", | |
"\u018c": "d", | |
"\u0256": "d", | |
"\u0257": "d", | |
"\ua77a": "d", | |
"\u01f3": "dz", | |
"\u01c6": "dz", | |
"\u24d4": "e", | |
"\uff45": "e", | |
"\xe8": "e", | |
"\xe9": "e", | |
"\xea": "e", | |
"\u1ec1": "e", | |
"\u1ebf": "e", | |
"\u1ec5": "e", | |
"\u1ec3": "e", | |
"\u1ebd": "e", | |
"\u0113": "e", | |
"\u1e15": "e", | |
"\u1e17": "e", | |
"\u0115": "e", | |
"\u0117": "e", | |
"\xeb": "e", | |
"\u1ebb": "e", | |
"\u011b": "e", | |
"\u0205": "e", | |
"\u0207": "e", | |
"\u1eb9": "e", | |
"\u1ec7": "e", | |
"\u0229": "e", | |
"\u1e1d": "e", | |
"\u0119": "e", | |
"\u1e19": "e", | |
"\u1e1b": "e", | |
"\u0247": "e", | |
"\u025b": "e", | |
"\u01dd": "e", | |
"\u24d5": "f", | |
"\uff46": "f", | |
"\u1e1f": "f", | |
"\u0192": "f", | |
"\ua77c": "f", | |
"\u24d6": "g", | |
"\uff47": "g", | |
"\u01f5": "g", | |
"\u011d": "g", | |
"\u1e21": "g", | |
"\u011f": "g", | |
"\u0121": "g", | |
"\u01e7": "g", | |
"\u0123": "g", | |
"\u01e5": "g", | |
"\u0260": "g", | |
"\ua7a1": "g", | |
"\u1d79": "g", | |
"\ua77f": "g", | |
"\u24d7": "h", | |
"\uff48": "h", | |
"\u0125": "h", | |
"\u1e23": "h", | |
"\u1e27": "h", | |
"\u021f": "h", | |
"\u1e25": "h", | |
"\u1e29": "h", | |
"\u1e2b": "h", | |
"\u1e96": "h", | |
"\u0127": "h", | |
"\u2c68": "h", | |
"\u2c76": "h", | |
"\u0265": "h", | |
"\u0195": "hv", | |
"\u24d8": "i", | |
"\uff49": "i", | |
"\xec": "i", | |
"\xed": "i", | |
"\xee": "i", | |
"\u0129": "i", | |
"\u012b": "i", | |
"\u012d": "i", | |
"\xef": "i", | |
"\u1e2f": "i", | |
"\u1ec9": "i", | |
"\u01d0": "i", | |
"\u0209": "i", | |
"\u020b": "i", | |
"\u1ecb": "i", | |
"\u012f": "i", | |
"\u1e2d": "i", | |
"\u0268": "i", | |
"\u0131": "i", | |
"\u24d9": "j", | |
"\uff4a": "j", | |
"\u0135": "j", | |
"\u01f0": "j", | |
"\u0249": "j", | |
"\u24da": "k", | |
"\uff4b": "k", | |
"\u1e31": "k", | |
"\u01e9": "k", | |
"\u1e33": "k", | |
"\u0137": "k", | |
"\u1e35": "k", | |
"\u0199": "k", | |
"\u2c6a": "k", | |
"\ua741": "k", | |
"\ua743": "k", | |
"\ua745": "k", | |
"\ua7a3": "k", | |
"\u24db": "l", | |
"\uff4c": "l", | |
"\u0140": "l", | |
"\u013a": "l", | |
"\u013e": "l", | |
"\u1e37": "l", | |
"\u1e39": "l", | |
"\u013c": "l", | |
"\u1e3d": "l", | |
"\u1e3b": "l", | |
"\u017f": "l", | |
"\u0142": "l", | |
"\u019a": "l", | |
"\u026b": "l", | |
"\u2c61": "l", | |
"\ua749": "l", | |
"\ua781": "l", | |
"\ua747": "l", | |
"\u01c9": "lj", | |
"\u24dc": "m", | |
"\uff4d": "m", | |
"\u1e3f": "m", | |
"\u1e41": "m", | |
"\u1e43": "m", | |
"\u0271": "m", | |
"\u026f": "m", | |
"\u24dd": "n", | |
"\uff4e": "n", | |
"\u01f9": "n", | |
"\u0144": "n", | |
"\xf1": "n", | |
"\u1e45": "n", | |
"\u0148": "n", | |
"\u1e47": "n", | |
"\u0146": "n", | |
"\u1e4b": "n", | |
"\u1e49": "n", | |
"\u019e": "n", | |
"\u0272": "n", | |
"\u0149": "n", | |
"\ua791": "n", | |
"\ua7a5": "n", | |
"\u01cc": "nj", | |
"\u24de": "o", | |
"\uff4f": "o", | |
"\xf2": "o", | |
"\xf3": "o", | |
"\xf4": "o", | |
"\u1ed3": "o", | |
"\u1ed1": "o", | |
"\u1ed7": "o", | |
"\u1ed5": "o", | |
"\xf5": "o", | |
"\u1e4d": "o", | |
"\u022d": "o", | |
"\u1e4f": "o", | |
"\u014d": "o", | |
"\u1e51": "o", | |
"\u1e53": "o", | |
"\u014f": "o", | |
"\u022f": "o", | |
"\u0231": "o", | |
"\xf6": "o", | |
"\u022b": "o", | |
"\u1ecf": "o", | |
"\u0151": "o", | |
"\u01d2": "o", | |
"\u020d": "o", | |
"\u020f": "o", | |
"\u01a1": "o", | |
"\u1edd": "o", | |
"\u1edb": "o", | |
"\u1ee1": "o", | |
"\u1edf": "o", | |
"\u1ee3": "o", | |
"\u1ecd": "o", | |
"\u1ed9": "o", | |
"\u01eb": "o", | |
"\u01ed": "o", | |
"\xf8": "o", | |
"\u01ff": "o", | |
"\u0254": "o", | |
"\ua74b": "o", | |
"\ua74d": "o", | |
"\u0275": "o", | |
"\u01a3": "oi", | |
"\u0223": "ou", | |
"\ua74f": "oo", | |
"\u24df": "p", | |
"\uff50": "p", | |
"\u1e55": "p", | |
"\u1e57": "p", | |
"\u01a5": "p", | |
"\u1d7d": "p", | |
"\ua751": "p", | |
"\ua753": "p", | |
"\ua755": "p", | |
"\u24e0": "q", | |
"\uff51": "q", | |
"\u024b": "q", | |
"\ua757": "q", | |
"\ua759": "q", | |
"\u24e1": "r", | |
"\uff52": "r", | |
"\u0155": "r", | |
"\u1e59": "r", | |
"\u0159": "r", | |
"\u0211": "r", | |
"\u0213": "r", | |
"\u1e5b": "r", | |
"\u1e5d": "r", | |
"\u0157": "r", | |
"\u1e5f": "r", | |
"\u024d": "r", | |
"\u027d": "r", | |
"\ua75b": "r", | |
"\ua7a7": "r", | |
"\ua783": "r", | |
"\u24e2": "s", | |
"\uff53": "s", | |
"\xdf": "s", | |
"\u015b": "s", | |
"\u1e65": "s", | |
"\u015d": "s", | |
"\u1e61": "s", | |
"\u0161": "s", | |
"\u1e67": "s", | |
"\u1e63": "s", | |
"\u1e69": "s", | |
"\u0219": "s", | |
"\u015f": "s", | |
"\u023f": "s", | |
"\ua7a9": "s", | |
"\ua785": "s", | |
"\u1e9b": "s", | |
"\u24e3": "t", | |
"\uff54": "t", | |
"\u1e6b": "t", | |
"\u1e97": "t", | |
"\u0165": "t", | |
"\u1e6d": "t", | |
"\u021b": "t", | |
"\u0163": "t", | |
"\u1e71": "t", | |
"\u1e6f": "t", | |
"\u0167": "t", | |
"\u01ad": "t", | |
"\u0288": "t", | |
"\u2c66": "t", | |
"\ua787": "t", | |
"\ua729": "tz", | |
"\u24e4": "u", | |
"\uff55": "u", | |
"\xf9": "u", | |
"\xfa": "u", | |
"\xfb": "u", | |
"\u0169": "u", | |
"\u1e79": "u", | |
"\u016b": "u", | |
"\u1e7b": "u", | |
"\u016d": "u", | |
"\xfc": "u", | |
"\u01dc": "u", | |
"\u01d8": "u", | |
"\u01d6": "u", | |
"\u01da": "u", | |
"\u1ee7": "u", | |
"\u016f": "u", | |
"\u0171": "u", | |
"\u01d4": "u", | |
"\u0215": "u", | |
"\u0217": "u", | |
"\u01b0": "u", | |
"\u1eeb": "u", | |
"\u1ee9": "u", | |
"\u1eef": "u", | |
"\u1eed": "u", | |
"\u1ef1": "u", | |
"\u1ee5": "u", | |
"\u1e73": "u", | |
"\u0173": "u", | |
"\u1e77": "u", | |
"\u1e75": "u", | |
"\u0289": "u", | |
"\u24e5": "v", | |
"\uff56": "v", | |
"\u1e7d": "v", | |
"\u1e7f": "v", | |
"\u028b": "v", | |
"\ua75f": "v", | |
"\u028c": "v", | |
"\ua761": "vy", | |
"\u24e6": "w", | |
"\uff57": "w", | |
"\u1e81": "w", | |
"\u1e83": "w", | |
"\u0175": "w", | |
"\u1e87": "w", | |
"\u1e85": "w", | |
"\u1e98": "w", | |
"\u1e89": "w", | |
"\u2c73": "w", | |
"\u24e7": "x", | |
"\uff58": "x", | |
"\u1e8b": "x", | |
"\u1e8d": "x", | |
"\u24e8": "y", | |
"\uff59": "y", | |
"\u1ef3": "y", | |
"\xfd": "y", | |
"\u0177": "y", | |
"\u1ef9": "y", | |
"\u0233": "y", | |
"\u1e8f": "y", | |
"\xff": "y", | |
"\u1ef7": "y", | |
"\u1e99": "y", | |
"\u1ef5": "y", | |
"\u01b4": "y", | |
"\u024f": "y", | |
"\u1eff": "y", | |
"\u24e9": "z", | |
"\uff5a": "z", | |
"\u017a": "z", | |
"\u1e91": "z", | |
"\u017c": "z", | |
"\u017e": "z", | |
"\u1e93": "z", | |
"\u1e95": "z", | |
"\u01b6": "z", | |
"\u0225": "z", | |
"\u0240": "z", | |
"\u2c6c": "z", | |
"\ua763": "z" | |
}; | |
j = a(document), g = function() { | |
var a = 1; | |
return function() { | |
return a++ | |
} | |
}(), j.on("mousemove", function(a) { | |
i.x = a.pageX, i.y = a.pageY | |
}), d = N(Object, { | |
bind: function(a) { | |
var b = this; | |
return function() { | |
a.apply(b, arguments) | |
} | |
}, | |
init: function(c) { | |
var d, e, f = ".select2-results"; | |
this.opts = c = this.prepareOpts(c), this.id = c.id, c.element.data("select2") !== b && null !== c.element.data("select2") && c.element.data("select2").destroy(), this.container = this.createContainer(), this.containerId = "s2id_" + (c.element.attr("id") || "autogen" + g()), this.containerSelector = "#" + this.containerId.replace(/([;&,\.\+\*\~':"\!\^#$%@\[\]\(\)=>\|])/g, "\\$1"), this.container.attr("id", this.containerId), this.body = w(function() { | |
return c.element.closest("body") | |
}), D(this.container, this.opts.element, this.opts.adaptContainerCssClass), this.container.attr("style", c.element.attr("style")), this.container.css(K(c.containerCss)), this.container.addClass(K(c.containerCssClass)), this.elementTabIndex = this.opts.element.attr("tabindex"), this.opts.element.data("select2", this).attr("tabindex", "-1").before(this.container).on("click.select2", A), this.container.data("select2", this), this.dropdown = this.container.find(".select2-drop"), D(this.dropdown, this.opts.element, this.opts.adaptDropdownCssClass), this.dropdown.addClass(K(c.dropdownCssClass)), this.dropdown.data("select2", this), this.dropdown.on("click", A), this.results = d = this.container.find(f), this.search = e = this.container.find("input.select2-input"), this.queryCount = 0, this.resultsPage = 0, this.context = null, this.initContainer(), this.container.on("click", A), u(this.results), this.dropdown.on("mousemove-filtered touchstart touchmove touchend", f, this.bind(this.highlightUnderEvent)), x(80, this.results), this.dropdown.on("scroll-debounced", f, this.bind(this.loadMoreIfNeeded)), a(this.container).on("change", ".select2-input", function(a) { | |
a.stopPropagation() | |
}), a(this.dropdown).on("change", ".select2-input", function(a) { | |
a.stopPropagation() | |
}), a.fn.mousewheel && d.mousewheel(function(a, b, c, e) { | |
var f = d.scrollTop(); | |
e > 0 && 0 >= f - e ? (d.scrollTop(0), A(a)) : 0 > e && d.get(0).scrollHeight - d.scrollTop() + e <= d.height() && (d.scrollTop(d.get(0).scrollHeight - d.height()), A(a)) | |
}), t(e), e.on("keyup-change input paste", this.bind(this.updateResults)), e.on("focus", function() { | |
e.addClass("select2-focused") | |
}), e.on("blur", function() { | |
e.removeClass("select2-focused") | |
}), this.dropdown.on("mouseup", f, this.bind(function(b) { | |
a(b.target).closest(".select2-result-selectable").length > 0 && (this.highlightUnderEvent(b), this.selectHighlighted(b)) | |
})), this.dropdown.on("click mouseup mousedown", function(a) { | |
a.stopPropagation() | |
}), a.isFunction(this.opts.initSelection) && (this.initSelection(), this.monitorSource()), null !== c.maximumInputLength && this.search.attr("maxlength", c.maximumInputLength); | |
var h = c.element.prop("disabled"); | |
h === b && (h=!1), this.enable(!h); | |
var i = c.element.prop("readonly"); | |
i === b && (i=!1), this.readonly(i), k = k || p(), this.autofocus = c.element.prop("autofocus"), c.element.prop("autofocus", !1), this.autofocus && this.focus(), this.nextSearchTerm = b | |
}, | |
destroy: function() { | |
var a = this.opts.element, c = a.data("select2"); | |
this.close(), this.propertyObserver && (delete this.propertyObserver, this.propertyObserver = null), c !== b && (c.container.remove(), c.dropdown.remove(), a.removeClass("select2-offscreen").removeData("select2").off(".select2").prop("autofocus", this.autofocus ||!1), this.elementTabIndex ? a.attr({ | |
tabindex: this.elementTabIndex | |
}) : a.removeAttr("tabindex"), a.show()) | |
}, | |
optionToData: function(a) { | |
return a.is("option") ? { | |
id: a.prop("value"), | |
text: a.text(), | |
element: a.get(), | |
css: a.attr("class"), | |
disabled: a.prop("disabled"), | |
locked: q(a.attr("locked"), "locked") || q(a.data("locked"), !0) | |
} : a.is("optgroup") ? { | |
text: a.attr("label"), | |
children: [], | |
element: a.get(), | |
css: a.attr("class") | |
} : void 0 | |
}, | |
prepareOpts: function(c) { | |
var d, e, f, g, h = this; | |
if (d = c.element, "select" === d.get(0).tagName.toLowerCase() && (this.select = e = c.element), e && a.each(["id", "multiple", "ajax", "query", "createSearchChoice", "initSelection", "data", "tags"], function() { | |
if (this in c) | |
throw new Error("Option '" + this + "' is not allowed for Select2 when attached to a <select> element.") | |
}), c = a.extend({}, { | |
populateResults: function(d, e, f) { | |
var g, i = this.opts.id; | |
g = function(d, e, j) { | |
var k, l, m, n, o, p, q, r, s, t; | |
for (d = c.sortResults(d, e, f), k = 0, l = d.length; l > k; k += 1) | |
m = d[k], o = m.disabled===!0, n=!o && i(m) !== b, p = m.children && m.children.length > 0, q = a("<li></li>"), q.addClass("select2-results-dept-" + j), q.addClass("select2-result"), q.addClass(n ? "select2-result-selectable" : "select2-result-unselectable"), o && q.addClass("select2-disabled"), p && q.addClass("select2-result-with-children"), q.addClass(h.opts.formatResultCssClass(m)), r = a(document.createElement("div")), r.addClass("select2-result-label"), t = c.formatResult(m, r, f, h.opts.escapeMarkup), t !== b && r.html(t), q.append(r), p && (s = a("<ul></ul>"), s.addClass("select2-result-sub"), g(m.children, s, j + 1), q.append(s)), q.data("select2-data", m), e.append(q) | |
}, g(e, d, 0) | |
} | |
}, a.fn.select2.defaults, c), "function" != typeof c.id && (f = c.id, c.id = function(a) { | |
return a[f] | |
}), a.isArray(c.element.data("select2Tags"))) { | |
if ("tags"in c) | |
throw "tags specified as both an attribute 'data-select2-tags' and in options of Select2 " + c.element.attr("id"); | |
c.tags = c.element.data("select2Tags") | |
} | |
if (e ? (c.query = this.bind(function(a) { | |
var f, g, i, c = { | |
results: [], | |
more: !1 | |
}, e = a.term; | |
i = function(b, c) { | |
var d; | |
b.is("option") ? a.matcher(e, b.text(), b) && c.push(h.optionToData(b)) : b.is("optgroup") && (d = h.optionToData(b), b.children().each2(function(a, b) { | |
i(b, d.children) | |
}), d.children.length > 0 && c.push(d)) | |
}, f = d.children(), this.getPlaceholder() !== b && f.length > 0 && (g = this.getPlaceholderOption(), g && (f = f.not(g))), f.each2(function(a, b) { | |
i(b, c.results) | |
}), a.callback(c) | |
}), c.id = function(a) { | |
return a.id | |
}, c.formatResultCssClass = function(a) { | |
return a.css | |
}) : "query"in c || ("ajax"in c ? (g = c.element.data("ajax-url"), g && g.length > 0 && (c.ajax.url = g), c.query = G.call(c.element, c.ajax)) : "data"in c ? c.query = H(c.data) : "tags"in c && (c.query = I(c.tags), c.createSearchChoice === b && (c.createSearchChoice = function(b) { | |
return { | |
id: a.trim(b), | |
text: a.trim(b) | |
} | |
}), c.initSelection === b && (c.initSelection = function(b, d) { | |
var e = []; | |
a(r(b.val(), c.separator)).each(function() { | |
var b = { | |
id: this, | |
text: this | |
}, d = c.tags; | |
a.isFunction(d) && (d = d()), a(d).each(function() { | |
return q(this.id, b.id) ? (b = this, !1) : void 0 | |
}), e.push(b) | |
}), d(e) | |
}))), "function" != typeof c.query) | |
throw "query function not defined for Select2 " + c.element.attr("id"); | |
return c | |
}, | |
monitorSource: function() { | |
var c, d, a = this.opts.element; | |
a.on("change.select2", this.bind(function() { | |
this.opts.element.data("select2-change-triggered")!==!0 && this.initSelection() | |
})), c = this.bind(function() { | |
var c = a.prop("disabled"); | |
c === b && (c=!1), this.enable(!c); | |
var d = a.prop("readonly"); | |
d === b && (d=!1), this.readonly(d), D(this.container, this.opts.element, this.opts.adaptContainerCssClass), this.container.addClass(K(this.opts.containerCssClass)), D(this.dropdown, this.opts.element, this.opts.adaptDropdownCssClass), this.dropdown.addClass(K(this.opts.dropdownCssClass)) | |
}), a.on("propertychange.select2", c), this.mutationCallback === b && (this.mutationCallback = function(a) { | |
a.forEach(c) | |
}), d = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver, d !== b && (this.propertyObserver && (delete this.propertyObserver, this.propertyObserver = null), this.propertyObserver = new d(this.mutationCallback), this.propertyObserver.observe(a.get(0), { | |
attributes: !0, | |
subtree: !1 | |
})) | |
}, | |
triggerSelect: function(b) { | |
var c = a.Event("select2-selecting", { | |
val: this.id(b), | |
object: b | |
}); | |
return this.opts.element.trigger(c), !c.isDefaultPrevented() | |
}, | |
triggerChange: function(b) { | |
b = b || {}, b = a.extend({}, b, { | |
type: "change", | |
val: this.val() | |
}), this.opts.element.data("select2-change-triggered", !0), this.opts.element.trigger(b), this.opts.element.data("select2-change-triggered", !1), this.opts.element.click(), this.opts.blurOnChange && this.opts.element.blur() | |
}, | |
isInterfaceEnabled: function() { | |
return this.enabledInterface===!0 | |
}, | |
enableInterface: function() { | |
var a = this._enabled&&!this._readonly, b=!a; | |
return a === this.enabledInterface?!1 : (this.container.toggleClass("select2-container-disabled", b), this.close(), this.enabledInterface = a, !0) | |
}, | |
enable: function(a) { | |
a === b && (a=!0), this._enabled !== a && (this._enabled = a, this.opts.element.prop("disabled", !a), this.enableInterface()) | |
}, | |
disable: function() { | |
this.enable(!1) | |
}, | |
readonly: function(a) { | |
return a === b && (a=!1), this._readonly === a?!1 : (this._readonly = a, this.opts.element.prop("readonly", a), this.enableInterface(), !0) | |
}, | |
opened: function() { | |
return this.container.hasClass("select2-dropdown-open") | |
}, | |
positionDropdown: function() { | |
var t, u, v, w, x, b = this.dropdown, c = this.container.offset(), d = this.container.outerHeight(!1), e = this.container.outerWidth(!1), f = b.outerHeight(!1), g = a(window), h = g.width(), i = g.height(), j = g.scrollLeft() + h, l = g.scrollTop() + i, m = c.top + d, n = c.left, o = l >= m + f, p = c.top - f >= this.body().scrollTop(), q = b.outerWidth(!1), r = j >= n + q, s = b.hasClass("select2-drop-above"); | |
s ? (u=!0, !p && o && (v=!0, u=!1)) : (u=!1, !o && p && (v=!0, u=!0)), v && (b.hide(), c = this.container.offset(), d = this.container.outerHeight(!1), e = this.container.outerWidth(!1), f = b.outerHeight(!1), j = g.scrollLeft() + h, l = g.scrollTop() + i, m = c.top + d, n = c.left, q = b.outerWidth(!1), r = j >= n + q, b.show()), this.opts.dropdownAutoWidth ? (x = a(".select2-results", b)[0], b.addClass("select2-drop-auto-width"), b.css("width", ""), q = b.outerWidth(!1) + (x.scrollHeight === x.clientHeight ? 0 : k.width), q > e ? e = q : q = e, r = j >= n + q) : this.container.removeClass("select2-drop-auto-width"), "static" !== this.body().css("position") && (t = this.body().offset(), m -= t.top, n -= t.left), r || (n = c.left + e - q), w = { | |
left: n, | |
width: e | |
}, u ? (w.bottom = i - c.top, w.top = "auto", this.container.addClass("select2-drop-above"), b.addClass("select2-drop-above")) : (w.top = m, w.bottom = "auto", this.container.removeClass("select2-drop-above"), b.removeClass("select2-drop-above")), w = a.extend(w, K(this.opts.dropdownCss)), b.css(w) | |
}, | |
shouldOpen: function() { | |
var b; | |
return this.opened()?!1 : this._enabled===!1 || this._readonly===!0?!1 : (b = a.Event("select2-opening"), this.opts.element.trigger(b), !b.isDefaultPrevented()) | |
}, | |
clearDropdownAlignmentPreference: function() { | |
this.container.removeClass("select2-drop-above"), this.dropdown.removeClass("select2-drop-above") | |
}, | |
open: function() { | |
return this.shouldOpen() ? (this.opening(), !0) : !1 | |
}, | |
opening: function() { | |
var f, b = this.containerId, c = "scroll." + b, d = "resize." + b, e = "orientationchange." + b; | |
this.container.addClass("select2-dropdown-open").addClass("select2-container-active"), this.clearDropdownAlignmentPreference(), this.dropdown[0] !== this.body().children().last()[0] && this.dropdown.detach().appendTo(this.body()), f = a("#select2-drop-mask"), 0 == f.length && (f = a(document.createElement("div")), f.attr("id", "select2-drop-mask").attr("class", "select2-drop-mask"), f.hide(), f.appendTo(this.body()), f.on("mousedown touchstart click", function(b) { | |
var d, c = a("#select2-drop"); | |
c.length > 0 && (d = c.data("select2"), d.opts.selectOnBlur && d.selectHighlighted({ | |
noFocus: !0 | |
}), d.close({ | |
focus: !0 | |
}), b.preventDefault(), b.stopPropagation()) | |
})), this.dropdown.prev()[0] !== f[0] && this.dropdown.before(f), a("#select2-drop").removeAttr("id"), this.dropdown.attr("id", "select2-drop"), f.show(), this.positionDropdown(), this.dropdown.show(), this.positionDropdown(), this.dropdown.addClass("select2-drop-active"); | |
var g = this; | |
this.container.parents().add(window).each(function() { | |
a(this).on(d + " " + c + " " + e, function() { | |
g.positionDropdown() | |
}) | |
}) | |
}, | |
close: function() { | |
if (this.opened()) { | |
var b = this.containerId, c = "scroll." + b, d = "resize." + b, e = "orientationchange." + b; | |
this.container.parents().add(window).each(function() { | |
a(this).off(c).off(d).off(e) | |
}), this.clearDropdownAlignmentPreference(), a("#select2-drop-mask").hide(), this.dropdown.removeAttr("id"), this.dropdown.hide(), this.container.removeClass("select2-dropdown-open").removeClass("select2-container-active"), this.results.empty(), this.clearSearch(), this.search.removeClass("select2-active"), this.opts.element.trigger(a.Event("select2-close")) | |
} | |
}, | |
externalSearch: function(a) { | |
this.open(), this.search.val(a), this.updateResults(!1) | |
}, | |
clearSearch: function() {}, | |
getMaximumSelectionSize: function() { | |
return K(this.opts.maximumSelectionSize) | |
}, | |
ensureHighlightVisible: function() { | |
var c, d, e, f, g, h, i, b = this.results; | |
if (d = this.highlight(), !(0 > d)) { | |
if (0 == d) | |
return b.scrollTop(0), void 0; | |
c = this.findHighlightableChoices().find(".select2-result-label"), e = a(c[d]), f = e.offset().top + e.outerHeight(!0), d === c.length - 1 && (i = b.find("li.select2-more-results"), i.length > 0 && (f = i.offset().top + i.outerHeight(!0))), g = b.offset().top + b.outerHeight(!0), f > g && b.scrollTop(b.scrollTop() + (f - g)), h = e.offset().top - b.offset().top, 0 > h && "none" != e.css("display") && b.scrollTop(b.scrollTop() + h) | |
} | |
}, | |
findHighlightableChoices: function() { | |
return this.results.find(".select2-result-selectable:not(.select2-disabled, .select2-selected)") | |
}, | |
moveHighlight: function(b) { | |
for (var c = this.findHighlightableChoices(), d = this.highlight(); d>-1 && d < c.length;) { | |
d += b; | |
var e = a(c[d]); | |
if (e.hasClass("select2-result-selectable")&&!e.hasClass("select2-disabled")&&!e.hasClass("select2-selected")) { | |
this.highlight(d); | |
break | |
} | |
} | |
}, | |
highlight: function(b) { | |
var d, e, c = this.findHighlightableChoices(); | |
return 0 === arguments.length ? o(c.filter(".select2-highlighted")[0], c.get()) : (b >= c.length && (b = c.length - 1), 0 > b && (b = 0), this.removeHighlight(), d = a(c[b]), d.addClass("select2-highlighted"), this.ensureHighlightVisible(), e = d.data("select2-data"), e && this.opts.element.trigger({ | |
type: "select2-highlight", | |
val: this.id(e), | |
choice: e | |
}), void 0) | |
}, | |
removeHighlight: function() { | |
this.results.find(".select2-highlighted").removeClass("select2-highlighted") | |
}, | |
countSelectableResults: function() { | |
return this.findHighlightableChoices().length | |
}, | |
highlightUnderEvent: function(b) { | |
var c = a(b.target).closest(".select2-result-selectable"); | |
if (c.length > 0&&!c.is(".select2-highlighted")) { | |
var d = this.findHighlightableChoices(); | |
this.highlight(d.index(c)) | |
} else | |
0 == c.length && this.removeHighlight() | |
}, | |
loadMoreIfNeeded: function() { | |
var c, a = this.results, b = a.find("li.select2-more-results"), d = this.resultsPage + 1, e = this, f = this.search.val(), g = this.context; | |
0 !== b.length && (c = b.offset().top - a.offset().top - a.height(), c <= this.opts.loadMorePadding && (b.addClass("select2-active"), this.opts.query({ | |
element: this.opts.element, | |
term: f, | |
page: d, | |
context: g, | |
matcher: this.opts.matcher, | |
callback: this.bind(function(c) { | |
e.opened() && (e.opts.populateResults.call(this, a, c.results, { | |
term: f, | |
page: d, | |
context: g | |
}), e.postprocessResults(c, !1, !1), c.more===!0 ? (b.detach().appendTo(a).text(e.opts.formatLoadMore(d + 1)), window.setTimeout(function() { | |
e.loadMoreIfNeeded() | |
}, 10)) : b.remove(), e.positionDropdown(), e.resultsPage = d, e.context = c.context, this.opts.element.trigger({ | |
type: "select2-loaded", | |
items: c | |
})) | |
}) | |
}))) | |
}, | |
tokenize: function() {}, | |
updateResults: function(c) { | |
function m() { | |
d.removeClass("select2-active"), h.positionDropdown() | |
} | |
function n(a) { | |
e.html(a), m() | |
} | |
var g, i, l, d = this.search, e = this.results, f = this.opts, h = this, j = d.val(), k = a.data(this.container, "select2-last-term"); | |
if ((c===!0 ||!k ||!q(j, k)) && (a.data(this.container, "select2-last-term", j), c===!0 || this.showSearchInput!==!1 && this.opened())) { | |
l=++this.queryCount; | |
var o = this.getMaximumSelectionSize(); | |
if (o >= 1 && (g = this.data(), a.isArray(g) && g.length >= o && J(f.formatSelectionTooBig, "formatSelectionTooBig"))) | |
return n("<li class='select2-selection-limit'>" + f.formatSelectionTooBig(o) + "</li>"), void 0; | |
if (d.val().length < f.minimumInputLength) | |
return J(f.formatInputTooShort, "formatInputTooShort") ? n("<li class='select2-no-results'>" + f.formatInputTooShort(d.val(), f.minimumInputLength) + "</li>") : n(""), c && this.showSearch && this.showSearch(!0), void 0; | |
if (f.maximumInputLength && d.val().length > f.maximumInputLength) | |
return J(f.formatInputTooLong, "formatInputTooLong") ? n("<li class='select2-no-results'>" + f.formatInputTooLong(d.val(), f.maximumInputLength) + "</li>") : n(""), void 0; | |
f.formatSearching && 0 === this.findHighlightableChoices().length && n("<li class='select2-searching'>" + f.formatSearching() + "</li>"), d.addClass("select2-active"), this.removeHighlight(), i = this.tokenize(), i != b && null != i && d.val(i), this.resultsPage = 1, f.query({ | |
element: f.element, | |
term: d.val(), | |
page: this.resultsPage, | |
context: null, | |
matcher: f.matcher, | |
callback: this.bind(function(g) { | |
var i; | |
if (l == this.queryCount) { | |
if (!this.opened()) | |
return this.search.removeClass("select2-active"), void 0; | |
if (this.context = g.context === b ? null : g.context, this.opts.createSearchChoice && "" !== d.val() && (i = this.opts.createSearchChoice.call(h, d.val(), g.results), i !== b && null !== i && h.id(i) !== b && null !== h.id(i) && 0 === a(g.results).filter(function() { | |
return q(h.id(this), h.id(i)) | |
}).length && g.results.unshift(i)), 0 === g.results.length && J(f.formatNoMatches, "formatNoMatches")) | |
return n("<li class='select2-no-results'>" + f.formatNoMatches(d.val()) + "</li>"), void 0; | |
e.empty(), h.opts.populateResults.call(this, e, g.results, { | |
term: d.val(), | |
page: this.resultsPage, | |
context: null | |
}), g.more===!0 && J(f.formatLoadMore, "formatLoadMore") && (e.append("<li class='select2-more-results'>" + h.opts.escapeMarkup(f.formatLoadMore(this.resultsPage)) + "</li>"), window.setTimeout(function() { | |
h.loadMoreIfNeeded() | |
}, 10)), this.postprocessResults(g, c), m(), this.opts.element.trigger({ | |
type: "select2-loaded", | |
items: g | |
}) | |
} | |
}) | |
}) | |
} | |
}, | |
cancel: function() { | |
this.close() | |
}, | |
blur: function() { | |
this.opts.selectOnBlur && this.selectHighlighted({ | |
noFocus: !0 | |
}), this.close(), this.container.removeClass("select2-container-active"), this.search[0] === document.activeElement && this.search.blur(), this.clearSearch(), this.selection.find(".select2-search-choice-focus").removeClass("select2-search-choice-focus") | |
}, | |
focusSearch: function() { | |
y(this.search) | |
}, | |
selectHighlighted: function(a) { | |
var b = this.highlight(), c = this.results.find(".select2-highlighted"), d = c.closest(".select2-result").data("select2-data"); | |
d ? (this.highlight(b), this.onSelect(d, a)) : a && a.noFocus && this.close() | |
}, | |
getPlaceholder: function() { | |
var a; | |
return this.opts.element.attr("placeholder") || this.opts.element.attr("data-placeholder") || this.opts.element.data("placeholder") || this.opts.placeholder || ((a = this.getPlaceholderOption()) !== b ? a.text() : b) | |
}, | |
getPlaceholderOption: function() { | |
if (this.select) { | |
var a = this.select.children("option").first(); | |
if (this.opts.placeholderOption !== b) | |
return "first" === this.opts.placeholderOption && a || "function" == typeof this.opts.placeholderOption && this.opts.placeholderOption(this.select); | |
if ("" === a.text() && "" === a.val()) | |
return a | |
} | |
}, | |
initContainerWidth: function() { | |
function c() { | |
var c, d, e, f, g, h; | |
if ("off" === this.opts.width) | |
return null; | |
if ("element" === this.opts.width) | |
return 0 === this.opts.element.outerWidth(!1) ? "auto" : this.opts.element.outerWidth(!1) + "px"; | |
if ("copy" === this.opts.width || "resolve" === this.opts.width) { | |
if (c = this.opts.element.attr("style"), c !== b) | |
for (d = c.split(";"), f = 0, g = d.length; g > f; f += 1) | |
if (h = d[f].replace(/\s/g, ""), e = h.match(/^width:(([-+]?([0-9]*\.)?[0-9]+)(px|em|ex|%|in|cm|mm|pt|pc))/i), null !== e && e.length >= 1) | |
return e[1]; | |
return "resolve" === this.opts.width ? (c = this.opts.element.css("width"), c.indexOf("%") > 0 ? c : 0 === this.opts.element.outerWidth(!1) ? "auto" : this.opts.element.outerWidth(!1) + "px") : null | |
} | |
return a.isFunction(this.opts.width) ? this.opts.width() : this.opts.width | |
} | |
var d = c.call(this); | |
null !== d && this.container.css("width", d) | |
} | |
}), e = N(d, { | |
createContainer: function() { | |
var b = a(document.createElement("div")).attr({ | |
"class": "select2-container" | |
}).html(["<a href='javascript:void(0)' onclick='return false;' class='select2-choice' tabindex='-1'>", " <span class='select2-chosen'> </span><abbr class='select2-search-choice-close'></abbr>", " <span class='select2-arrow'><b></b></span>", "</a>", "<input class='select2-focusser select2-offscreen' type='text'/>", "<div class='select2-drop select2-display-none'>", " <div class='select2-search'>", " <input type='text' autocomplete='off' autocorrect='off' autocapitalize='off' spellcheck='false' class='select2-input'/>", " </div>", " <ul class='select2-results'>", " </ul>", "</div>"].join("")); | |
return b | |
}, | |
enableInterface: function() { | |
this.parent.enableInterface.apply(this, arguments) && this.focusser.prop("disabled", !this.isInterfaceEnabled()) | |
}, | |
opening: function() { | |
var c, d, e; | |
this.opts.minimumResultsForSearch >= 0 && this.showSearch(!0), this.parent.opening.apply(this, arguments), this.showSearchInput!==!1 && this.search.val(this.focusser.val()), this.search.focus(), c = this.search.get(0), c.createTextRange ? (d = c.createTextRange(), d.collapse(!1), d.select()) : c.setSelectionRange && (e = this.search.val().length, c.setSelectionRange(e, e)), "" === this.search.val() && this.nextSearchTerm != b && (this.search.val(this.nextSearchTerm), this.search.select()), this.focusser.prop("disabled", !0).val(""), this.updateResults(!0), this.opts.element.trigger(a.Event("select2-open")) | |
}, | |
close: function(a) { | |
this.opened() && (this.parent.close.apply(this, arguments), a = a || { | |
focus: !0 | |
}, this.focusser.removeAttr("disabled"), a.focus && this.focusser.focus()) | |
}, | |
focus: function() { | |
this.opened() ? this.close() : (this.focusser.removeAttr("disabled"), this.focusser.focus()) | |
}, | |
isFocused: function() { | |
return this.container.hasClass("select2-container-active") | |
}, | |
cancel: function() { | |
this.parent.cancel.apply(this, arguments), this.focusser.removeAttr("disabled"), this.focusser.focus() | |
}, | |
destroy: function() { | |
a("label[for='" + this.focusser.attr("id") + "']").attr("for", this.opts.element.attr("id")), this.parent.destroy.apply(this, arguments) | |
}, | |
initContainer: function() { | |
var b, d = this.container, e = this.dropdown; | |
this.opts.minimumResultsForSearch < 0 ? this.showSearch(!1) : this.showSearch(!0), this.selection = b = d.find(".select2-choice"), this.focusser = d.find(".select2-focusser"), this.focusser.attr("id", "s2id_autogen" + g()), a("label[for='" + this.opts.element.attr("id") + "']").attr("for", this.focusser.attr("id")), this.focusser.attr("tabindex", this.elementTabIndex), this.search.on("keydown", this.bind(function(a) { | |
if (this.isInterfaceEnabled()) { | |
if (a.which === c.PAGE_UP || a.which === c.PAGE_DOWN) | |
return A(a), void 0; | |
switch (a.which) { | |
case c.UP: | |
case c.DOWN: | |
return this.moveHighlight(a.which === c.UP?-1 : 1), A(a), void 0; | |
case c.ENTER: | |
return this.selectHighlighted(), A(a), void 0; | |
case c.TAB: | |
return this.selectHighlighted({ | |
noFocus: !0 | |
}), void 0; | |
case c.ESC: | |
return this.cancel(a), A(a), void 0 | |
} | |
} | |
})), this.search.on("blur", this.bind(function() { | |
document.activeElement === this.body().get(0) && window.setTimeout(this.bind(function() { | |
this.search.focus() | |
}), 0) | |
})), this.focusser.on("keydown", this.bind(function(a) { | |
if (this.isInterfaceEnabled() && a.which !== c.TAB&&!c.isControl(a)&&!c.isFunctionKey(a) && a.which !== c.ESC) { | |
if (this.opts.openOnEnter===!1 && a.which === c.ENTER) | |
return A(a), void 0; | |
if (a.which == c.DOWN || a.which == c.UP || a.which == c.ENTER && this.opts.openOnEnter) { | |
if (a.altKey || a.ctrlKey || a.shiftKey || a.metaKey) | |
return; | |
return this.open(), A(a), void 0 | |
} | |
return a.which == c.DELETE || a.which == c.BACKSPACE ? (this.opts.allowClear && this.clear(), A(a), void 0) : void 0 | |
} | |
})), t(this.focusser), this.focusser.on("keyup-change input", this.bind(function(a) { | |
if (this.opts.minimumResultsForSearch >= 0) { | |
if (a.stopPropagation(), this.opened()) | |
return; | |
this.open() | |
} | |
})), b.on("mousedown", "abbr", this.bind(function(a) { | |
this.isInterfaceEnabled() && (this.clear(), B(a), this.close(), this.selection.focus()) | |
})), b.on("mousedown", this.bind(function(b) { | |
this.container.hasClass("select2-container-active") || this.opts.element.trigger(a.Event("select2-focus")), this.opened() ? this.close() : this.isInterfaceEnabled() && this.open(), A(b) | |
})), e.on("mousedown", this.bind(function() { | |
this.search.focus() | |
})), b.on("focus", this.bind(function(a) { | |
A(a) | |
})), this.focusser.on("focus", this.bind(function() { | |
this.container.hasClass("select2-container-active") || this.opts.element.trigger(a.Event("select2-focus")), this.container.addClass("select2-container-active") | |
})).on("blur", this.bind(function() { | |
this.opened() || (this.container.removeClass("select2-container-active"), this.opts.element.trigger(a.Event("select2-blur"))) | |
})), this.search.on("focus", this.bind(function() { | |
this.container.hasClass("select2-container-active") || this.opts.element.trigger(a.Event("select2-focus")), this.container.addClass("select2-container-active") | |
})), this.initContainerWidth(), this.opts.element.addClass("select2-offscreen"), this.setPlaceholder() | |
}, | |
clear: function(b) { | |
var c = this.selection.data("select2-data"); | |
if (c) { | |
var d = a.Event("select2-clearing"); | |
if (this.opts.element.trigger(d), d.isDefaultPrevented()) | |
return; | |
var e = this.getPlaceholderOption(); | |
this.opts.element.val(e ? e.val() : ""), this.selection.find(".select2-chosen").empty(), this.selection.removeData("select2-data"), this.setPlaceholder(), b!==!1 && (this.opts.element.trigger({ | |
type: "select2-removed", | |
val: this.id(c), | |
choice: c | |
}), this.triggerChange({ | |
removed: c | |
})) | |
} | |
}, | |
initSelection: function() { | |
if (this.isPlaceholderOptionSelected()) | |
this.updateSelection(null), this.close(), this.setPlaceholder(); | |
else { | |
var c = this; | |
this.opts.initSelection.call(null, this.opts.element, function(a) { | |
a !== b && null !== a && (c.updateSelection(a), c.close(), c.setPlaceholder()) | |
}) | |
} | |
}, | |
isPlaceholderOptionSelected: function() { | |
var a; | |
return this.getPlaceholder() ? (a = this.getPlaceholderOption()) !== b && a.prop("selected") || "" === this.opts.element.val() || this.opts.element.val() === b || null === this.opts.element.val() : !1 | |
}, | |
prepareOpts: function() { | |
var b = this.parent.prepareOpts.apply(this, arguments), c = this; | |
return "select" === b.element.get(0).tagName.toLowerCase() ? b.initSelection = function(a, b) { | |
var d = a.find("option").filter(function() { | |
return this.selected | |
}); | |
b(c.optionToData(d)) | |
} : "data"in b && (b.initSelection = b.initSelection || function(c, d) { | |
var e = c.val(), f = null; | |
b.query({ | |
matcher: function(a, c, d) { | |
var g = q(e, b.id(d)); | |
return g && (f = d), g | |
}, | |
callback: a.isFunction(d) ? function() { | |
d(f) | |
} | |
: a.noop | |
}) | |
}), b | |
}, | |
getPlaceholder: function() { | |
return this.select && this.getPlaceholderOption() === b ? b : this.parent.getPlaceholder.apply(this, arguments) | |
}, | |
setPlaceholder: function() { | |
var a = this.getPlaceholder(); | |
if (this.isPlaceholderOptionSelected() && a !== b) { | |
if (this.select && this.getPlaceholderOption() === b) | |
return; | |
this.selection.find(".select2-chosen").html(this.opts.escapeMarkup(a)), this.selection.addClass("select2-default"), this.container.removeClass("select2-allowclear") | |
} | |
}, | |
postprocessResults: function(a, b, c) { | |
var d = 0, e = this; | |
if (this.findHighlightableChoices().each2(function(a, b) { | |
return q(e.id(b.data("select2-data")), e.opts.element.val()) ? (d = a, !1) : void 0 | |
}), c!==!1 && (b===!0 && d >= 0 ? this.highlight(d) : this.highlight(0)), b===!0) { | |
var g = this.opts.minimumResultsForSearch; | |
g >= 0 && this.showSearch(L(a.results) >= g) | |
} | |
}, | |
showSearch: function(b) { | |
this.showSearchInput !== b && (this.showSearchInput = b, this.dropdown.find(".select2-search").toggleClass("select2-search-hidden", !b), this.dropdown.find(".select2-search").toggleClass("select2-offscreen", !b), a(this.dropdown, this.container).toggleClass("select2-with-searchbox", b)) | |
}, | |
onSelect: function(a, b) { | |
if (this.triggerSelect(a)) { | |
var c = this.opts.element.val(), d = this.data(); | |
this.opts.element.val(this.id(a)), this.updateSelection(a), this.opts.element.trigger({ | |
type: "select2-selected", | |
val: this.id(a), | |
choice: a | |
}), this.nextSearchTerm = this.opts.nextSearchTerm(a, this.search.val()), this.close(), b && b.noFocus || this.focusser.focus(), q(c, this.id(a)) || this.triggerChange({ | |
added: a, | |
removed: d | |
}) | |
} | |
}, | |
updateSelection: function(a) { | |
var d, e, c = this.selection.find(".select2-chosen"); | |
this.selection.data("select2-data", a), c.empty(), null !== a && (d = this.opts.formatSelection(a, c, this.opts.escapeMarkup)), d !== b && c.append(d), e = this.opts.formatSelectionCssClass(a, c), e !== b && c.addClass(e), this.selection.removeClass("select2-default"), this.opts.allowClear && this.getPlaceholder() !== b && this.container.addClass("select2-allowclear") | |
}, | |
val: function() { | |
var a, c=!1, d = null, e = this, f = this.data(); | |
if (0 === arguments.length) | |
return this.opts.element.val(); | |
if (a = arguments[0], arguments.length > 1 && (c = arguments[1]), this.select) | |
this.select.val(a).find("option").filter(function() { | |
return this.selected | |
}).each2(function(a, b) { | |
return d = e.optionToData(b), !1 | |
}), this.updateSelection(d), this.setPlaceholder(), c && this.triggerChange({ | |
added: d, | |
removed: f | |
}); | |
else { | |
if (!a && 0 !== a) | |
return this.clear(c), void 0; | |
if (this.opts.initSelection === b) | |
throw new Error("cannot call val() if initSelection() is not defined"); | |
this.opts.element.val(a), this.opts.initSelection(this.opts.element, function(a) { | |
e.opts.element.val(a ? e.id(a) : ""), e.updateSelection(a), e.setPlaceholder(), c && e.triggerChange({ | |
added: a, | |
removed: f | |
}) | |
}) | |
} | |
}, | |
clearSearch: function() { | |
this.search.val(""), this.focusser.val("") | |
}, | |
data: function(a) { | |
var c, d=!1; | |
return 0 === arguments.length ? (c = this.selection.data("select2-data"), c == b && (c = null), c) : (arguments.length > 1 && (d = arguments[1]), a ? (c = this.data(), this.opts.element.val(a ? this.id(a) : ""), this.updateSelection(a), d && this.triggerChange({ | |
added: a, | |
removed: c | |
})) : this.clear(d), void 0) | |
} | |
}), f = N(d, { | |
createContainer: function() { | |
var b = a(document.createElement("div")).attr({ | |
"class": "select2-container select2-container-multi" | |
}).html(["<ul class='select2-choices'>", " <li class='select2-search-field'>", " <input type='text' autocomplete='off' autocorrect='off' autocapitalize='off' spellcheck='false' class='select2-input'>", " </li>", "</ul>", "<div class='select2-drop select2-drop-multi select2-display-none'>", " <ul class='select2-results'>", " </ul>", "</div>"].join("")); | |
return b | |
}, | |
prepareOpts: function() { | |
var b = this.parent.prepareOpts.apply(this, arguments), c = this; | |
return "select" === b.element.get(0).tagName.toLowerCase() ? b.initSelection = function(a, b) { | |
var d = []; | |
a.find("option").filter(function() { | |
return this.selected | |
}).each2(function(a, b) { | |
d.push(c.optionToData(b)) | |
}), b(d) | |
} : "data"in b && (b.initSelection = b.initSelection || function(c, d) { | |
var e = r(c.val(), b.separator), f = []; | |
b.query({ | |
matcher: function(c, d, g) { | |
var h = a.grep(e, function(a) { | |
return q(a, b.id(g)) | |
}).length; | |
return h && f.push(g), h | |
}, | |
callback: a.isFunction(d) ? function() { | |
for (var a = [], c = 0; c < e.length; c++) | |
for (var g = e[c], h = 0; h < f.length; h++) { | |
var i = f[h]; | |
if (q(g, b.id(i))) { | |
a.push(i), f.splice(h, 1); | |
break | |
} | |
} | |
d(a) | |
} | |
: a.noop | |
}) | |
}), b | |
}, | |
selectChoice: function(a) { | |
var b = this.container.find(".select2-search-choice-focus"); | |
b.length && a && a[0] == b[0] || (b.length && this.opts.element.trigger("choice-deselected", b), b.removeClass("select2-search-choice-focus"), a && a.length && (this.close(), a.addClass("select2-search-choice-focus"), this.opts.element.trigger("choice-selected", a))) | |
}, | |
destroy: function() { | |
a("label[for='" + this.search.attr("id") + "']").attr("for", this.opts.element.attr("id")), this.parent.destroy.apply(this, arguments) | |
}, | |
initContainer: function() { | |
var d, b = ".select2-choices"; | |
this.searchContainer = this.container.find(".select2-search-field"), this.selection = d = this.container.find(b); | |
var e = this; | |
this.selection.on("click", ".select2-search-choice:not(.select2-locked)", function() { | |
e.search[0].focus(), e.selectChoice(a(this)) | |
}), this.search.attr("id", "s2id_autogen" + g()), a("label[for='" + this.opts.element.attr("id") + "']").attr("for", this.search.attr("id")), this.search.on("input paste", this.bind(function() { | |
this.isInterfaceEnabled() && (this.opened() || this.open()) | |
})), this.search.attr("tabindex", this.elementTabIndex), this.keydowns = 0, this.search.on("keydown", this.bind(function(a) { | |
if (this.isInterfaceEnabled()) { | |
++this.keydowns; | |
var b = d.find(".select2-search-choice-focus"), e = b.prev(".select2-search-choice:not(.select2-locked)"), f = b.next(".select2-search-choice:not(.select2-locked)"), g = z(this.search); | |
if (b.length && (a.which == c.LEFT || a.which == c.RIGHT || a.which == c.BACKSPACE || a.which == c.DELETE || a.which == c.ENTER)) { | |
var h = b; | |
return a.which == c.LEFT && e.length ? h = e : a.which == c.RIGHT ? h = f.length ? f : null : a.which === c.BACKSPACE ? (this.unselect(b.first()), this.search.width(10), h = e.length ? e : f) : a.which == c.DELETE ? (this.unselect(b.first()), this.search.width(10), h = f.length ? f : null) : a.which == c.ENTER && (h = null), this.selectChoice(h), A(a), h && h.length || this.open(), void 0 | |
} | |
if ((a.which === c.BACKSPACE && 1 == this.keydowns || a.which == c.LEFT) && 0 == g.offset&&!g.length) | |
return this.selectChoice(d.find(".select2-search-choice:not(.select2-locked)").last()), A(a), void 0; | |
if (this.selectChoice(null), this.opened()) | |
switch (a.which) { | |
case c.UP: | |
case c.DOWN: | |
return this.moveHighlight(a.which === c.UP?-1 : 1), A(a), void 0; | |
case c.ENTER: | |
return this.selectHighlighted(), A(a), void 0; | |
case c.TAB: | |
return this.selectHighlighted({ | |
noFocus: !0 | |
}), this.close(), void 0; | |
case c.ESC: | |
return this.cancel(a), A(a), void 0 | |
} | |
if (a.which !== c.TAB&&!c.isControl(a)&&!c.isFunctionKey(a) && a.which !== c.BACKSPACE && a.which !== c.ESC) { | |
if (a.which === c.ENTER) { | |
if (this.opts.openOnEnter===!1) | |
return; | |
if (a.altKey || a.ctrlKey || a.shiftKey || a.metaKey) | |
return | |
} | |
this.open(), (a.which === c.PAGE_UP || a.which === c.PAGE_DOWN) && A(a), a.which === c.ENTER && A(a) | |
} | |
} | |
})), this.search.on("keyup", this.bind(function() { | |
this.keydowns = 0, this.resizeSearch() | |
})), this.search.on("blur", this.bind(function(b) { | |
this.container.removeClass("select2-container-active"), this.search.removeClass("select2-focused"), this.selectChoice(null), this.opened() || this.clearSearch(), b.stopImmediatePropagation(), this.opts.element.trigger(a.Event("select2-blur")) | |
})), this.container.on("click", b, this.bind(function(b) { | |
this.isInterfaceEnabled() && (a(b.target).closest(".select2-search-choice").length > 0 || (this.selectChoice(null), this.clearPlaceholder(), this.container.hasClass("select2-container-active") || this.opts.element.trigger(a.Event("select2-focus")), this.open(), this.focusSearch(), b.preventDefault())) | |
})), this.container.on("focus", b, this.bind(function() { | |
this.isInterfaceEnabled() && (this.container.hasClass("select2-container-active") || this.opts.element.trigger(a.Event("select2-focus")), this.container.addClass("select2-container-active"), this.dropdown.addClass("select2-drop-active"), this.clearPlaceholder()) | |
})), this.initContainerWidth(), this.opts.element.addClass("select2-offscreen"), this.clearSearch() | |
}, | |
enableInterface: function() { | |
this.parent.enableInterface.apply(this, arguments) && this.search.prop("disabled", !this.isInterfaceEnabled()) | |
}, | |
initSelection: function() { | |
if ("" === this.opts.element.val() && "" === this.opts.element.text() && (this.updateSelection([]), this.close(), this.clearSearch()), this.select || "" !== this.opts.element.val()) { | |
var c = this; | |
this.opts.initSelection.call(null, this.opts.element, function(a) { | |
a !== b && null !== a && (c.updateSelection(a), c.close(), c.clearSearch()) | |
}) | |
} | |
}, | |
clearSearch: function() { | |
var a = this.getPlaceholder(), c = this.getMaxSearchWidth(); | |
a !== b && 0 === this.getVal().length && this.search.hasClass("select2-focused")===!1 ? (this.search.val(a).addClass("select2-default"), this.search.width(c > 0 ? c : this.container.css("width"))) : this.search.val("").width(10) | |
}, | |
clearPlaceholder: function() { | |
this.search.hasClass("select2-default") && this.search.val("").removeClass("select2-default") | |
}, | |
opening: function() { | |
this.clearPlaceholder(), this.resizeSearch(), this.parent.opening.apply(this, arguments), this.focusSearch(), this.updateResults(!0), this.search.focus(), this.opts.element.trigger(a.Event("select2-open")) | |
}, | |
close: function() { | |
this.opened() && this.parent.close.apply(this, arguments) | |
}, | |
focus: function() { | |
this.close(), this.search.focus() | |
}, | |
isFocused: function() { | |
return this.search.hasClass("select2-focused") | |
}, | |
updateSelection: function(b) { | |
var c = [], d = [], e = this; | |
a(b).each(function() { | |
o(e.id(this), c) < 0 && (c.push(e.id(this)), d.push(this)) | |
}), b = d, this.selection.find(".select2-search-choice").remove(), a(b).each(function() { | |
e.addSelectedChoice(this) | |
}), e.postprocessResults() | |
}, | |
tokenize: function() { | |
var a = this.search.val(); | |
a = this.opts.tokenizer.call(this, a, this.data(), this.bind(this.onSelect), this.opts), null != a && a != b && (this.search.val(a), a.length > 0 && this.open()) | |
}, | |
onSelect: function(a, b) { | |
this.triggerSelect(a) && (this.addSelectedChoice(a), this.opts.element.trigger({ | |
type: "selected", | |
val: this.id(a), | |
choice: a | |
}), (this.select ||!this.opts.closeOnSelect) && this.postprocessResults(a, !1, this.opts.closeOnSelect===!0), this.opts.closeOnSelect ? (this.close(), this.search.width(10)) : this.countSelectableResults() > 0 ? (this.search.width(10), this.resizeSearch(), this.getMaximumSelectionSize() > 0 && this.val().length >= this.getMaximumSelectionSize() && this.updateResults(!0), this.positionDropdown()) : (this.close(), this.search.width(10)), this.triggerChange({ | |
added: a | |
}), b && b.noFocus || this.focusSearch()) | |
}, | |
cancel: function() { | |
this.close(), this.focusSearch() | |
}, | |
addSelectedChoice: function(c) { | |
var j, k, d=!c.locked, e = a("<li class='select2-search-choice'> <div></div> <a href='#' onclick='return false;' class='select2-search-choice-close' tabindex='-1'></a></li>"), f = a("<li class='select2-search-choice select2-locked'><div></div></li>"), g = d ? e : f, h = this.id(c), i = this.getVal(); | |
j = this.opts.formatSelection(c, g.find("div"), this.opts.escapeMarkup), j != b && g.find("div").replaceWith("<div>" + j + "</div>"), k = this.opts.formatSelectionCssClass(c, g.find("div")), k != b && g.addClass(k), d && g.find(".select2-search-choice-close").on("mousedown", A).on("click dblclick", this.bind(function(b) { | |
this.isInterfaceEnabled() && (a(b.target).closest(".select2-search-choice").fadeOut("fast", this.bind(function() { | |
this.unselect(a(b.target)), this.selection.find(".select2-search-choice-focus").removeClass("select2-search-choice-focus"), this.close(), this.focusSearch() | |
})).dequeue(), A(b)) | |
})).on("focus", this.bind(function() { | |
this.isInterfaceEnabled() && (this.container.addClass("select2-container-active"), this.dropdown.addClass("select2-drop-active")) | |
})), g.data("select2-data", c), g.insertBefore(this.searchContainer), i.push(h), this.setVal(i) | |
}, | |
unselect: function(b) { | |
var d, e, c = this.getVal(); | |
if (b = b.closest(".select2-search-choice"), 0 === b.length) | |
throw "Invalid argument: " + b + ". Must be .select2-search-choice"; | |
if (d = b.data("select2-data")) { | |
for (; (e = o(this.id(d), c)) >= 0;) | |
c.splice(e, 1), this.setVal(c), this.select && this.postprocessResults(); | |
var f = a.Event("select2-removing"); | |
f.val = this.id(d), f.choice = d, this.opts.element.trigger(f), f.isDefaultPrevented() || (b.remove(), this.opts.element.trigger({ | |
type: "select2-removed", | |
val: this.id(d), | |
choice: d | |
}), this.triggerChange({ | |
removed: d | |
})) | |
} | |
}, | |
postprocessResults: function(a, b, c) { | |
var d = this.getVal(), e = this.results.find(".select2-result"), f = this.results.find(".select2-result-with-children"), g = this; | |
e.each2(function(a, b) { | |
var c = g.id(b.data("select2-data")); | |
o(c, d) >= 0 && (b.addClass("select2-selected"), b.find(".select2-result-selectable").addClass("select2-selected")) | |
}), f.each2(function(a, b) { | |
b.is(".select2-result-selectable") || 0 !== b.find(".select2-result-selectable:not(.select2-selected)").length || b.addClass("select2-selected") | |
}), - 1 == this.highlight() && c!==!1 && g.highlight(0), !this.opts.createSearchChoice&&!e.filter(".select2-result:not(.select2-selected)").length > 0 && (!a || a&&!a.more && 0 === this.results.find(".select2-no-results").length) && J(g.opts.formatNoMatches, "formatNoMatches") && this.results.append("<li class='select2-no-results'>" + g.opts.formatNoMatches(g.search.val()) + "</li>") | |
}, | |
getMaxSearchWidth: function() { | |
return this.selection.width() - s(this.search) | |
}, | |
resizeSearch: function() { | |
var a, b, c, d, e, f = s(this.search); | |
a = C(this.search) + 10, b = this.search.offset().left, c = this.selection.width(), d = this.selection.offset().left, e = c - (b - d) - f, a > e && (e = c - f), 40 > e && (e = c - f), 0 >= e && (e = a), this.search.width(Math.floor(e)) | |
}, | |
getVal: function() { | |
var a; | |
return this.select ? (a = this.select.val(), null === a ? [] : a) : (a = this.opts.element.val(), r(a, this.opts.separator)) | |
}, | |
setVal: function(b) { | |
var c; | |
this.select ? this.select.val(b) : (c = [], a(b).each(function() { | |
o(this, c) < 0 && c.push(this) | |
}), this.opts.element.val(0 === c.length ? "" : c.join(this.opts.separator))) | |
}, | |
buildChangeDetails: function(a, b) { | |
for (var b = b.slice(0), a = a.slice(0), c = 0; c < b.length; c++) | |
for (var d = 0; d < a.length; d++) | |
q(this.opts.id(b[c]), this.opts.id(a[d])) && (b.splice(c, 1), c > 0 && c--, a.splice(d, 1), d--); | |
return { | |
added: b, | |
removed: a | |
} | |
}, | |
val: function(c, d) { | |
var e, f = this; | |
if (0 === arguments.length) | |
return this.getVal(); | |
if (e = this.data(), e.length || (e = []), !c && 0 !== c) | |
return this.opts.element.val(""), this.updateSelection([]), this.clearSearch(), d && this.triggerChange({ | |
added: this.data(), | |
removed: e | |
}), void 0; | |
if (this.setVal(c), this.select) | |
this.opts.initSelection(this.select, this.bind(this.updateSelection)), d && this.triggerChange(this.buildChangeDetails(e, this.data())); | |
else { | |
if (this.opts.initSelection === b) | |
throw new Error("val() cannot be called if initSelection() is not defined"); | |
this.opts.initSelection(this.opts.element, function(b) { | |
var c = a.map(b, f.id); | |
f.setVal(c), f.updateSelection(b), f.clearSearch(), d && f.triggerChange(f.buildChangeDetails(e, f.data())) | |
}) | |
} | |
this.clearSearch() | |
}, | |
onSortStart: function() { | |
if (this.select) | |
throw new Error("Sorting of elements is not supported when attached to <select>. Attach to <input type='hidden'/> instead."); | |
this.search.width(0), this.searchContainer.hide() | |
}, | |
onSortEnd: function() { | |
var b = [], c = this; | |
this.searchContainer.show(), this.searchContainer.appendTo(this.searchContainer.parent()), this.resizeSearch(), this.selection.find(".select2-search-choice").each(function() { | |
b.push(c.opts.id(a(this).data("select2-data"))) | |
}), this.setVal(b), this.triggerChange() | |
}, | |
data: function(b, c) { | |
var e, f, d = this; | |
return 0 === arguments.length ? this.selection.find(".select2-search-choice").map(function() { | |
return a(this).data("select2-data") | |
}).get() : (f = this.data(), b || (b = []), e = a.map(b, function(a) { | |
return d.opts.id(a) | |
}), this.setVal(e), this.updateSelection(b), this.clearSearch(), c && this.triggerChange(this.buildChangeDetails(f, this.data())), void 0) | |
} | |
}), a.fn.select2 = function() { | |
var d, g, h, i, j, c = Array.prototype.slice.call(arguments, 0), k = ["val", "destroy", "opened", "open", "close", "focus", "isFocused", "container", "dropdown", "onSortStart", "onSortEnd", "enable", "disable", "readonly", "positionDropdown", "data", "search"], l = ["opened", "isFocused", "container", "dropdown"], m = ["val", "data"], n = { | |
search: "externalSearch" | |
}; | |
return this.each(function() { | |
if (0 === c.length || "object" == typeof c[0]) | |
d = 0 === c.length ? {} : a.extend({}, c[0]), d.element = a(this), "select" === d.element.get(0).tagName.toLowerCase() ? j = d.element.prop("multiple") : (j = d.multiple ||!1, "tags"in d && (d.multiple = j=!0)), g = j ? new f : new e, g.init(d); | |
else { | |
if ("string" != typeof c[0]) | |
throw "Invalid arguments to select2 plugin: " + c; | |
if (o(c[0], k) < 0) | |
throw "Unknown method: " + c[0]; | |
if (i = b, g = a(this).data("select2"), g === b) | |
return; | |
if (h = c[0], "container" === h ? i = g.container : "dropdown" === h ? i = g.dropdown : (n[h] && (h = n[h]), i = g[h].apply(g, c.slice(1))), o(c[0], l) >= 0 || o(c[0], m) && 1 == c.length) | |
return !1 | |
} | |
}), i === b ? this : i | |
}, a.fn.select2.defaults = { | |
width: "copy", | |
loadMorePadding: 0, | |
closeOnSelect: !0, | |
openOnEnter: !0, | |
containerCss: {}, | |
dropdownCss: {}, | |
containerCssClass: "", | |
dropdownCssClass: "", | |
formatResult: function(a, b, c, d) { | |
var e = []; | |
return E(a.text, c.term, e, d), e.join("") | |
}, | |
formatSelection: function(a, c, d) { | |
return a ? d(a.text) : b | |
}, | |
sortResults: function(a) { | |
return a | |
}, | |
formatResultCssClass: function() { | |
return b | |
}, | |
formatSelectionCssClass: function() { | |
return b | |
}, | |
formatNoMatches: function() { | |
return "No matches found" | |
}, | |
formatInputTooShort: function(a, b) { | |
var c = b - a.length; | |
return "Please enter " + c + " more character" + (1 == c ? "" : "s") | |
}, | |
formatInputTooLong: function(a, b) { | |
var c = a.length - b; | |
return "Please delete " + c + " character" + (1 == c ? "" : "s") | |
}, | |
formatSelectionTooBig: function(a) { | |
return "You can only select " + a + " item" + (1 == a ? "" : "s") | |
}, | |
formatLoadMore: function() { | |
return "Loading more results..." | |
}, | |
formatSearching: function() { | |
return "Searching..." | |
}, | |
minimumResultsForSearch: 0, | |
minimumInputLength: 0, | |
maximumInputLength: null, | |
maximumSelectionSize: 0, | |
id: function(a) { | |
return a.id | |
}, | |
matcher: function(a, b) { | |
return n("" + b).toUpperCase().indexOf(n("" + a).toUpperCase()) >= 0 | |
}, | |
separator: ",", | |
tokenSeparators: [], | |
tokenizer: M, | |
escapeMarkup: F, | |
blurOnChange: !1, | |
selectOnBlur: !1, | |
adaptContainerCssClass: function(a) { | |
return a | |
}, | |
adaptDropdownCssClass: function() { | |
return null | |
}, | |
nextSearchTerm: function() { | |
return b | |
} | |
}, a.fn.select2.ajaxDefaults = { | |
transport: a.ajax, | |
params: { | |
type: "GET", | |
cache: !1, | |
dataType: "json" | |
} | |
}, window.Select2 = { | |
query: { | |
ajax: G, | |
local: H, | |
tags: I | |
}, | |
util: { | |
debounce: v, | |
markMatch: E, | |
escapeMarkup: F, | |
stripDiacritics: n | |
}, | |
"class": { | |
"abstract": d, | |
single: e, | |
multi: f | |
} | |
} | |
} | |
}(jQuery); | |
/*! | |
* Velocity.js: Accelerated JavaScript animation. | |
* @version 0.0.0 | |
* @requires jQuery.js | |
* @docs VelocityJS.org | |
* @license Copyright 2014 Julian Shapiro. MIT License: http://en.wikipedia.org/wiki/MIT_License | |
*/ | |
!function(e, t, a, r) { | |
function o(e) { | |
for (var t =- 1, a = e ? e.length : 0, r = []; ++t < a;) { | |
var o = e[t]; | |
o && r.push(o) | |
} | |
return r | |
} | |
function l(e) { | |
return "[object Function]" === Object.prototype.toString.call(e) | |
} | |
function i(t) { | |
if (t) | |
for (var a = (new Date).getTime(), o = 0, l = e.velocity.State.calls.length; l > o; o++) | |
if (e.velocity.State.calls[o]) { | |
var s = e.velocity.State.calls[o], g = s[0], d = s[2], f = s[3]; | |
f || (f = e.velocity.State.calls[o][3] = a - 16); | |
for (var y = Math.min((a - f) / d.duration, 1), m = 0, h = g.length; h > m; m++) { | |
var v = g[m], P = v.element; | |
if (e.data(P, c)) { | |
var x=!1; | |
d.display && "none" !== d.display && (p.setPropertyValue(P, "display", d.display), e.velocity.State.calls[o][2].display=!1); | |
for (var b in v) | |
if ("element" !== b) { | |
var V = v[b], S = V.currentValue, w; | |
if (w = 1 === y ? V.endValue : V.startValue + (V.endValue - V.startValue) * e.easing[V.easing](y), V.currentValue = w, p.Hooks.registered[b]) { | |
var k = p.Hooks.getRoot(b), C = e.data(P, c).rootPropertyValueCache[k]; | |
C && (V.rootPropertyValue = C) | |
} | |
var T = p.setPropertyValue(P, b, V.currentValue + ("auto" === w ? "" : V.unitType), V.rootPropertyValue, V.scrollContainer); | |
p.Hooks.registered[b] && (e.data(P, c).rootPropertyValueCache[k] = p.Normalizations.registered[k] ? p.Normalizations.registered[k]("extract", null, T[1]) : T[1]), "transform" === T[0] && (x=!0) | |
} | |
d.mobileHA && (e.data(P, c).transformCache.translate3d === r ? (e.data(P, c).transformCache.translate3d = "(0, 0, 0)", x=!0) : 1 === y && (delete e.data(P, c).transformCache.translate3d, x=!0)), x && p.flushTransformCache(P) | |
} | |
} | |
1 === y && n(o) | |
} | |
e.velocity.State.isTicking && u(i) | |
} | |
function n(t) { | |
for (var a = e.velocity.State.calls[t][0], o = e.velocity.State.calls[t][1], l = e.velocity.State.calls[t][2], i=!1, n = 0, s = a.length; s > n; n++) { | |
var u = a[n].element; | |
"none" === l.display && l.loop===!1 && p.setPropertyValue(u, "display", l.display), e.queue(u)[1] !== r && /\$\.velocity\.queueEntryFlag/i.test(e.queue(u)[1]) || e.data(u, c) && (e.data(u, c).isAnimating=!1, e.data(u, c).rootPropertyValueCache = {}), n === s - 1 && l.complete && l.complete.call(o, o), e.dequeue(u) | |
} | |
e.velocity.State.calls[t]=!1; | |
for (var g = 0, d = e.velocity.State.calls.length; d > g; g++) | |
if (e.velocity.State.calls[g]!==!1) { | |
i=!0; | |
break | |
} | |
i===!1 && (e.velocity.State.isTicking=!1, delete e.velocity.State.calls, e.velocity.State.calls = []) | |
} | |
var s = function() { | |
if (a.documentMode) | |
return a.documentMode; | |
for (var e = 7; e > 4; e--) { | |
var t = a.createElement("div"); | |
if (t.innerHTML = "<!--[if IE " + e + "]><span></span><![endif]-->", t.getElementsByTagName("span").length) | |
return t = null, e | |
} | |
return r | |
}(), u = t.requestAnimationFrame || function() { | |
var e = 0; | |
return t.webkitRequestAnimationFrame || t.mozRequestAnimationFrame || function(t) { | |
var a = (new Date).getTime(), r; | |
return r = Math.max(0, 16 - (a - e)), e = a + r, setTimeout(function() { | |
t(a + r) | |
}, r) | |
} | |
}(); | |
if (7 >= s) | |
return void(e.fn.velocity = e.fn.animate); | |
if (e.velocity !== r || e.fn.velocity !== r) | |
return void console.log("Velocity is already loaded or its namespace is occupied."); | |
!function() { | |
var t = {}; | |
e.each(["Quad", "Cubic", "Quart", "Quint", "Expo"], function(e, a) { | |
t[a] = function(t) { | |
return Math.pow(t, e + 2) | |
} | |
}), e.extend(t, { | |
Sine: function(e) { | |
return 1 - Math.cos(e * Math.PI / 2) | |
}, | |
Circ: function(e) { | |
return 1 - Math.sqrt(1 - e * e) | |
}, | |
Elastic: function(e) { | |
return 0 === e || 1 === e ? e : - Math.pow(2, 8 * (e - 1)) * Math.sin((80 * (e - 1) - 7.5) * Math.PI / 15) | |
}, | |
Back: function(e) { | |
return e * e * (3 * e - 2) | |
}, | |
Bounce: function(e) { | |
for (var t, a = 4; e < ((t = Math.pow(2, --a)) - 1) / 11;); | |
return 1 / Math.pow(4, 3 - a) - 7.5625 * Math.pow((3 * t - 2) / 22 - e, 2) | |
} | |
}), e.each(t, function(t, a) { | |
e.easing["easeIn" + t] = a, e.easing["easeOut" + t] = function(e) { | |
return 1 - a(1 - e) | |
}, e.easing["easeInOut" + t] = function(e) { | |
return .5 > e ? a(2 * e) / 2 : 1 - a( - 2 * e + 2) / 2 | |
} | |
}), e.easing.spring = function(e) { | |
return 1 - Math.cos(4.5 * e * Math.PI) * Math.exp(6*-e) | |
} | |
}(); | |
var c = "velocity"; | |
e.velocity = { | |
State: { | |
isMobile: /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent), | |
prefixElement: a.createElement("div"), | |
prefixMatches: {}, | |
scrollAnchor: null, | |
scrollProperty: null, | |
isTicking: !1, | |
calls: [] | |
}, | |
CSS: {}, | |
Sequences: {}, | |
animate: function() {}, | |
debug: !1 | |
}, t.pageYOffset !== r ? (e.velocity.State.scrollAnchor = t, e.velocity.State.scrollProperty = "pageYOffset") : (e.velocity.State.scrollAnchor = a.documentElement || a.body.parentNode || a.body, e.velocity.State.scrollProperty = "scrollTop"); | |
var p = e.velocity.CSS = { | |
RegEx: { | |
valueUnwrap: /^[A-z]+\((.*)\)$/i, | |
wrappedValueAlreadyExtracted: /[0-9.]+ [0-9.]+ [0-9.]+( [0-9.]+)?/, | |
valueSplit: /([A-z]+\(.+\))|(([A-z0-9#-.]+?)(?=\s|$))/gi | |
}, | |
Hooks: { | |
templates: { | |
color: ["Red Green Blue Alpha", "255 255 255 1"], | |
backgroundColor: ["Red Green Blue Alpha", "255 255 255 1"], | |
borderColor: ["Red Green Blue Alpha", "255 255 255 1"], | |
outlineColor: ["Red Green Blue Alpha", "255 255 255 1"], | |
textShadow: ["Color X Y Blur", "black 0px 0px 0px"], | |
boxShadow: ["Color X Y Blur Spread", "black 0px 0px 0px 0px"], | |
clip: ["Top Right Bottom Left", "0px 0px 0px 0px"], | |
backgroundPosition: ["X Y", "0% 0%"], | |
transformOrigin: ["X Y Z", "50% 50% 0%"], | |
perspectiveOrigin: ["X Y", "50% 50%"] | |
}, | |
registered: {}, | |
register: function() { | |
var e, t, a; | |
if (s) | |
for (e in p.Hooks.templates) { | |
t = p.Hooks.templates[e], a = t[0].split(" "); | |
var r = t[1].match(p.RegEx.valueSplit); | |
"Color" === a[0] && (a.push(a.shift()), r.push(r.shift()), p.Hooks.templates[e] = [a.join(" "), r.join(" ")]) | |
} | |
for (e in p.Hooks.templates) { | |
t = p.Hooks.templates[e], a = t[0].split(" "); | |
for (var o in a) { | |
var l = e + a[o], i = o; | |
p.Hooks.registered[l] = [e, i] | |
} | |
} | |
}, | |
getRoot: function(e) { | |
var t = p.Hooks.registered[e]; | |
return t ? t[0] : e | |
}, | |
cleanRootPropertyValue: function(e, t) { | |
return p.RegEx.valueUnwrap.test(t) && (t = t.match(p.Hooks.RegEx.valueUnwrap)[1]), p.Values.isCSSNullValue(t) && (t = p.Hooks.templates[e][1]), t | |
}, | |
extractValue: function(e, t) { | |
var a = p.Hooks.registered[e]; | |
if (a) { | |
var r = a[0], o = a[1]; | |
return t = p.Hooks.cleanRootPropertyValue(r, t), t.toString().match(p.RegEx.valueSplit)[o] | |
} | |
return t | |
}, | |
injectValue: function(e, t, a) { | |
var r = p.Hooks.registered[e]; | |
if (r) { | |
var o = r[0], l = r[1], i, n; | |
return a = p.Hooks.cleanRootPropertyValue(o, a), i = a.toString().match(p.RegEx.valueSplit), i[l] = t, n = i.join(" ") | |
} | |
return a | |
} | |
}, | |
Normalizations: { | |
registered: { | |
clip: function(e, t, a) { | |
switch (e) { | |
case"name": | |
return "clip"; | |
case"extract": | |
var r; | |
return p.RegEx.wrappedValueAlreadyExtracted.test(a) ? r = a : (r = a.toString().match(p.RegEx.valueUnwrap), r && (r = r[1].replace(/,(\s+)?/g, " "))), r; | |
case"inject": | |
return "rect(" + a + ")" | |
} | |
}, | |
opacity: function(e, t, a) { | |
if (8 >= s) | |
switch (e) { | |
case"name": | |
return "filter"; | |
case"extract": | |
var r = a.toString().match(/alpha\(opacity=(.*)\)/i); | |
return a = r ? r[1] / 100 : 1; | |
case"inject": | |
return t.style.zoom = 1, "alpha(opacity=" + parseInt(100 * a) + ")" | |
} else | |
switch (e) { | |
case"name": | |
return "opacity"; | |
case"extract": | |
return a; | |
case"inject": | |
return a | |
} | |
} | |
}, | |
register: function() { | |
function t(e) { | |
var t = /^#?([a-f\d])([a-f\d])([a-f\d])$/i, a = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i, r; | |
return e = e.replace(t, function(e, t, a, r) { | |
return t + t + a + a + r + r | |
}), r = a.exec(e), r ? "rgb(" + (parseInt(r[1], 16) + " " + parseInt(r[2], 16) + " " + parseInt(r[3], 16)) + ")" : "rgb(0 0 0)" | |
} | |
var a = ["translateX", "translateY", "scale", "scaleX", "scaleY", "skewX", "skewY", "rotateZ"]; | |
9 >= s || (a = a.concat(["transformPerspective", "translateZ", "scaleZ", "rotateX", "rotateY"])); | |
for (var o = 0, l = a.length; l > o; o++) | |
!function() { | |
var t = a[o]; | |
p.Normalizations.registered[t] = function(a, o, l) { | |
switch (a) { | |
case"name": | |
return "transform"; | |
case"extract": | |
return e.data(o, c).transformCache[t] === r ? /^scale/i.test(t) ? 1 : 0 : e.data(o, c).transformCache[t].replace(/[()]/g, ""); | |
case"inject": | |
var i=!1; | |
switch (t.substr(0, t.length - 1)) { | |
case"translate": | |
i=!/(%|px|em|rem|\d)$/i.test(l); | |
break; | |
case"scale": | |
i=!/(\d)$/i.test(l); | |
break; | |
case"skew": | |
i=!/(deg|\d)$/i.test(l); | |
break; | |
case"rotate": | |
i=!/(deg|\d)$/i.test(l) | |
} | |
return i || (e.data(o, c).transformCache[t] = "(" + l + ")"), e.data(o, c).transformCache[t] | |
} | |
} | |
}(); | |
for (var i = ["color", "backgroundColor", "borderColor", "outlineColor"], o = 0, n = i.length; n > o; o++) | |
!function() { | |
var e = i[o]; | |
p.Normalizations.registered[e] = function(a, o, l) { | |
switch (a) { | |
case"name": | |
return e; | |
case"extract": | |
var i; | |
if (p.RegEx.wrappedValueAlreadyExtracted.test(l)) | |
i = l; | |
else { | |
var n, u = { | |
aqua: "rgb(0, 255, 255);", | |
black: "rgb(0, 0, 0)", | |
blue: "rgb(0, 0, 255)", | |
fuchsia: "rgb(255, 0, 255)", | |
gray: "rgb(128, 128, 128)", | |
green: "rgb(0, 128, 0)", | |
lime: "rgb(0, 255, 0)", | |
maroon: "rgb(128, 0, 0)", | |
navy: "rgb(0, 0, 128)", | |
olive: "rgb(128, 128, 0)", | |
purple: "rgb(128, 0, 128)", | |
red: "rgb(255, 0, 0)", | |
silver: "rgb(192, 192, 192)", | |
teal: "rgb(0, 128, 128)", | |
white: "rgb(255, 255, 255)", | |
yellow: "rgb(255, 255, 0)" | |
}; | |
/^[A-z]+$/i.test(l) ? n = u[l] !== r ? u[l] : u.black : /^#([A-f\d]{3}){1,2}$/i.test(l) ? n = t(l) : /^rgba?\(/i.test(l) || (n = u.black), i = (n || l).toString().match(p.RegEx.valueUnwrap)[1].replace(/,(\s+)?/g, " ") | |
} | |
return 8 >= s || 3 !== i.split(" ").length || (i += " 1"), i; | |
case"inject": | |
return 8 >= s ? 4 === l.split(" ").length && (l = l.split(/\s+/).slice(0, 3).join(" ")) : 3 === l.split(" ").length && (l += " 1"), (8 >= s ? "rgb" : "rgba") + "(" + l.replace(/\s+/g, ",").replace(/\.(\d)+(?=,)/g, "") + ")" | |
} | |
} | |
}() | |
} | |
}, | |
Names: { | |
camelCase: function(e) { | |
return e.replace(/-(\w)/g, function(e, t) { | |
return t.toUpperCase() | |
}) | |
}, | |
prefixCheck: function(t) { | |
if (e.velocity.State.prefixMatches[t]) | |
return [e.velocity.State.prefixMatches[t], !0]; | |
for (var a = ["", "Webkit", "Moz", "ms", "O"], r = 0, o = a.length; o > r; r++) { | |
var l; | |
if (l = 0 === r ? t : a[r] + t.replace(/^\w/, function(e) { | |
return e.toUpperCase() | |
}), "string" == typeof e.velocity.State.prefixElement.style[l]) | |
return e.velocity.State.prefixMatches[t] = l, [l, !0] | |
} | |
return [t, !1] | |
} | |
}, | |
Values: { | |
isCSSNullValue: function(e) { | |
return 0 == e || /^(none|auto|transparent|(rgba\(0, ?0, ?0, ?0\)))$/i.test(e) | |
}, | |
getUnitType: function(e) { | |
return /^(rotate|skew)/i.test(e) ? "deg" : /(^(scale|scaleX|scaleY|scaleZ|opacity|alpha|fillOpacity|flexGrow|flexHeight|zIndex|fontWeight)$)|color/i.test(e) ? "" : "px" | |
} | |
}, | |
getPropertyValue: function(a, o, l, i) { | |
function n(a, o) { | |
if (!i) { | |
if ("height" === o && "border-box" !== p.getPropertyValue(a, "boxSizing").toLowerCase()) | |
return a.offsetHeight - (parseFloat(p.getPropertyValue(a, "borderTopWidth")) || 0) - (parseFloat(p.getPropertyValue(a, "borderBottomWidth")) || 0) - (parseFloat(p.getPropertyValue(a, "paddingTop")) || 0) - (parseFloat(p.getPropertyValue(a, "paddingBottom")) || 0); | |
if ("width" === o && "border-box" !== p.getPropertyValue(a, "boxSizing").toLowerCase()) | |
return a.offsetWidth - (parseFloat(p.getPropertyValue(a, "borderLeftWidth")) || 0) - (parseFloat(p.getPropertyValue(a, "borderRightWidth")) || 0) - (parseFloat(p.getPropertyValue(a, "paddingLeft")) || 0) - (parseFloat(p.getPropertyValue(a, "paddingRight")) || 0) | |
} | |
var l = 0; | |
if (8 >= s) | |
l = e.css(a, o); | |
else { | |
var u; | |
u = e.data(a, c) === r ? t.getComputedStyle(a, null) : e.data(a, c).computedStyle ? e.data(a, c).computedStyle : e.data(a, c).computedStyle = t.getComputedStyle(a, null), s && "borderColor" === o && (o = "borderTopColor"), l = 9 === s && "filter" === o ? u.getPropertyValue(o) : u[o], "" === l && (l = a.style[o]) | |
} | |
if ("auto" === l && /^(top|right|bottom|left)$/i.test(o)) { | |
var g = n(a, "position"); | |
("fixed" === g || "absolute" === g && /top|left/i.test(o)) && (l = e(a).position()[o] + "px") | |
} | |
return l | |
} | |
var u; | |
if (p.Hooks.registered[o]) { | |
var g = o, d = p.Hooks.getRoot(g); | |
l === r && (l = p.getPropertyValue(a, p.Names.prefixCheck(d)[0])), p.Normalizations.registered[d] && (l = p.Normalizations.registered[d]("extract", a, l)), u = p.Hooks.extractValue(g, l) | |
} else if (p.Normalizations.registered[o]) { | |
var f, y; | |
f = p.Normalizations.registered[o]("name", a), "transform" !== f && (y = n(a, p.Names.prefixCheck(f)[0]), p.Values.isCSSNullValue(y) && p.Hooks.templates[o] && (y = p.Hooks.templates[o][1])), u = p.Normalizations.registered[o]("extract", a, y) | |
} | |
return /^[\d-]/.test(u) || (u = n(a, p.Names.prefixCheck(o)[0])), p.Values.isCSSNullValue(u) && (u = 0), e.velocity.debug >= 2 && console.log("Get " + o + ": " + u), u | |
}, | |
setPropertyValue: function(a, r, o, l, i) { | |
var n = r; | |
if ("scroll" === r) | |
i ? i.scrollTop = o : t.scrollTo(null, o); | |
else if (p.Normalizations.registered[r] && "transform" === p.Normalizations.registered[r]("name", a)) | |
p.Normalizations.registered[r]("inject", a, o), n = "transform", o = e.data(a, c).transformCache[r]; | |
else { | |
if (p.Hooks.registered[r]) { | |
var u = r, g = p.Hooks.getRoot(r); | |
l = l || p.getPropertyValue(a, g), o = p.Hooks.injectValue(u, o, l), r = g | |
} | |
if (p.Normalizations.registered[r] && (o = p.Normalizations.registered[r]("inject", a, o), r = p.Normalizations.registered[r]("name", a)), n = p.Names.prefixCheck(r)[0], 8 >= s) | |
try { | |
a.style[n] = o | |
} catch (d) { | |
console.log("Error setting [" + n + "] to [" + o + "]") | |
} else | |
a.style[n] = o; | |
e.velocity.debug >= 2 && console.log("Set " + r + " (" + n + "): " + o) | |
} | |
return [n, o] | |
}, | |
flushTransformCache: function(t) { | |
var a = "", r, o, l; | |
for (r in e.data(t, c).transformCache) | |
o = e.data(t, c).transformCache[r], "transformPerspective" !== r ? (9 === s && "rotateZ" === r && (r = "rotate"), a += r + o + " ") : l = o; | |
l && (a = "perspective" + l + " " + a), p.setPropertyValue(t, "transform", a) | |
} | |
}; | |
p.Hooks.register(), p.Normalizations.register(), e.fn.velocity = e.velocity.animate = function() { | |
function t() { | |
var t = this, n = e.extend({}, e.fn.velocity.defaults, g), y = {}; | |
if ("stop" === h) | |
return e.queue(t, "string" == typeof g ? g : "", []), !0; | |
switch (e.data(t, c) === r && e.data(t, c, { | |
isAnimating: !1, | |
computedStyle: null, | |
tweensContainer: null, | |
rootPropertyValueCache: {}, | |
transformCache: {} | |
}), n.duration.toString().toLowerCase()) { | |
case"fast": | |
n.duration = 200; | |
break; | |
case"normal": | |
n.duration = 400; | |
break; | |
case"slow": | |
n.duration = 600; | |
break; | |
default: | |
n.duration = parseFloat(n.duration) || parseFloat(e.fn.velocity.defaults.duration) || 400 | |
} | |
e.easing[n.easing] || (n.easing = e.easing[e.fn.velocity.defaults.easing] ? e.fn.velocity.defaults.easing : "swing"), /^\d/.test(n.delay) && e.queue(t, n.queue, function(t) { | |
e.velocity.queueEntryFlag=!0, setTimeout(t, parseFloat(n.delay)) | |
}), n.display && (n.display = n.display.toLowerCase()), n.mobileHA = n.mobileHA && e.velocity.State.isMobile, e.queue(t, n.queue, function(m) { | |
function x(a) { | |
var o = r, i = r, s = r; | |
return "[object Array]" === Object.prototype.toString.call(a) ? (o = a[0], /^[\d-]/.test(a[1]) || l(a[1]) ? s = a[1] : "string" == typeof a[1] && (e.easing[a[1]] !== r && (i = a[1]), a[2] && (s = a[2]))) : o = a, i = i || n.easing, l(o) && (o = o.call(t, f, d)), l(s) && (s = s.call(t, f, d)), [o || 0, i, s] | |
} | |
function b(e, t) { | |
var a, r; | |
return r = (t || 0).toString().toLowerCase().replace(/[%A-z]+$/, function(e) { | |
return a = e, "" | |
}), a || (a = p.Values.getUnitType(e)), [r, a] | |
} | |
function V() { | |
var r = { | |
parent: t.parentNode, | |
position: p.getPropertyValue(t, "position"), | |
fontSize: p.getPropertyValue(t, "fontSize") | |
}, o = r.position === v.lastPosition && r.parent === v.lastParent, l = r.fontSize === v.lastFontSize; | |
v.lastParent = r.parent, v.lastPosition = r.position, v.lastFontSize = r.fontSize, null === v.remToPxRatio && (v.remToPxRatio = parseFloat(p.getPropertyValue(a.body, "fontSize")) || 16); | |
var i = { | |
overflowX: null, | |
overflowY: null, | |
boxSizing: null, | |
width: null, | |
minWidth: null, | |
maxWidth: null, | |
height: null, | |
minHeight: null, | |
maxHeight: null, | |
paddingLeft: null | |
}, n = {}, s = 10; | |
n.remToPxRatio = v.remToPxRatio, i.overflowX = p.getPropertyValue(t, "overflowX"), i.overflowY = p.getPropertyValue(t, "overflowY"), i.boxSizing = p.getPropertyValue(t, "boxSizing"), i.width = p.getPropertyValue(t, "width", null, !0), i.minWidth = p.getPropertyValue(t, "minWidth"), i.maxWidth = p.getPropertyValue(t, "maxWidth") || "none", i.height = p.getPropertyValue(t, "height", null, !0), i.minHeight = p.getPropertyValue(t, "minHeight"), i.maxHeight = p.getPropertyValue(t, "maxHeight") || "none", i.paddingLeft = p.getPropertyValue(t, "paddingLeft"), o ? (n.percentToPxRatioWidth = v.lastPercentToPxWidth, n.percentToPxRatioHeight = v.lastPercentToPxHeight) : (p.setPropertyValue(t, "overflowX", "hidden"), p.setPropertyValue(t, "overflowY", "hidden"), p.setPropertyValue(t, "boxSizing", "content-box"), p.setPropertyValue(t, "width", s + "%"), p.setPropertyValue(t, "minWidth", s + "%"), p.setPropertyValue(t, "maxWidth", s + "%"), p.setPropertyValue(t, "height", s + "%"), p.setPropertyValue(t, "minHeight", s + "%"), p.setPropertyValue(t, "maxHeight", s + "%")), l ? n.emToPxRatio = v.lastEmToPx : p.setPropertyValue(t, "paddingLeft", s + "em"), o || (n.percentToPxRatioWidth = v.lastPercentToPxWidth = (parseFloat(p.getPropertyValue(t, "width", null, !0)) || 1) / s, n.percentToPxRatioHeight = v.lastPercentToPxHeight = (parseFloat(p.getPropertyValue(t, "height", null, !0)) || 1) / s), l || (n.emToPxRatio = v.lastEmToPx = (parseFloat(p.getPropertyValue(t, "paddingLeft")) || 1) / s); | |
for (var u in i) | |
p.setPropertyValue(t, u, i[u]); | |
return e.velocity.debug >= 1 && console.log("Unit ratios: " + JSON.stringify(n), t), n | |
} | |
if (e.velocity.queueEntryFlag=!0, 0 === f && g && l(g.begin) && g.begin.call(s, s), "scroll" === h) { | |
var S = parseFloat(n.offset) || 0, w, k; | |
n.container ? n.container.jquery || n.container.nodeType ? (n.container = n.container[0] || n.container, w = n.container.scrollTop, k = w + e(t).position().top + S) : n.container = null : (w = e.velocity.State.scrollAnchor[e.velocity.State.scrollProperty], k = e(t).offset().top + S), y = { | |
scroll: { | |
rootPropertyValue: !1, | |
startValue: w, | |
currentValue: w, | |
endValue: k, | |
unitType: "", | |
easing: n.easing, | |
scrollContainer: n.container | |
}, | |
element: t | |
} | |
} else if ("reverse" === h) { | |
if (!e.data(t, c).tweensContainer) | |
return void e.dequeue(t, n.queue); | |
"none" === e.data(t, c).opts.display && (e.data(t, c).opts.display = "block"), e.data(t, c).opts.loop=!1, n = e.extend({}, e.data(t, c).opts, g); | |
var C = e.extend(!0, {}, e.data(t, c).tweensContainer); | |
for (var T in C) | |
if ("element" !== T) { | |
var H = C[T].startValue; | |
C[T].startValue = C[T].currentValue = C[T].endValue, C[T].endValue = H, g && (C[T].easing = n.easing) | |
} | |
y = C | |
} else if ("start" === h) { | |
var C; | |
e.data(t, c).tweensContainer && e.data(t, c).isAnimating===!0 && (C = e.data(t, c).tweensContainer); | |
for (var R in u) { | |
var z = x(u[R]), q = z[0], N = z[1], j = z[2]; | |
R = p.Names.camelCase(R); | |
var A = p.Hooks.getRoot(R), E=!1; | |
if (p.Names.prefixCheck(A)[1]!==!1 || p.Normalizations.registered[A] !== r) { | |
n.display && "none" !== n.display && /opacity|filter/.test(R)&&!j && 0 !== q && (j = 0), n._cacheValues && C && C[R] ? (j === r && (j = C[R].endValue + C[R].unitType), E = e.data(t, c).rootPropertyValueCache[A]) : p.Hooks.registered[R] ? j === r ? (E = p.getPropertyValue(t, A), j = p.getPropertyValue(t, R, E)) : E = p.Hooks.templates[A][1] : j === r && (j = p.getPropertyValue(t, R)); | |
var F, M, Y, B; | |
F = b(R, j), j = F[0], Y = F[1], F = b(R, q), q = F[0].replace(/^([+-\/*])=/, function(e, t) { | |
return B = t, "" | |
}), M = F[1], j = parseFloat(j) || 0, q = parseFloat(q) || 0; | |
var W; | |
if ("%" === M && (/^(fontSize|lineHeight)$/.test(R) ? (q/=100, M = "em") : /^scale/.test(R) ? (q/=100, M = "") : /(Red|Green|Blue)$/i.test(R) && (q = q / 100 * 255, M = "")), /[\/*]/.test(B)) | |
M = Y; | |
else if (Y !== M && 0 !== j) | |
if (0 === q) | |
M = Y; | |
else { | |
W = W || V(); | |
var $ = /margin|padding|left|right|width|text|word|letter/i.test(R) || /X$/.test(R) ? "x": "y"; | |
switch (Y) { | |
case"%": | |
j*="x" === $ ? W.percentToPxRatioWidth : W.percentToPxRatioHeight; | |
break; | |
case"em": | |
j*=W.emToPxRatio; | |
break; | |
case"rem": | |
j*=W.remToPxRatio; | |
break; | |
case"px": | |
} | |
switch (M) { | |
case"%": | |
j*=1 / ("x" === $ ? W.percentToPxRatioWidth : W.percentToPxRatioHeight); | |
break; | |
case"em": | |
j*=1 / W.emToPxRatio; | |
break; | |
case"rem": | |
j*=1 / W.remToPxRatio; | |
break; | |
case"px": | |
} | |
} | |
switch (B) { | |
case"+": | |
q = j + q; | |
break; | |
case"-": | |
q = j - q; | |
break; | |
case"*": | |
q = j * q; | |
break; | |
case"/": | |
q = j / q | |
} | |
y[R] = { | |
rootPropertyValue: E, | |
startValue: j, | |
currentValue: j, | |
endValue: q, | |
unitType: M, | |
easing: N | |
}, e.velocity.debug && console.log("tweensContainer (" + R + "): " + JSON.stringify(y[R]), t) | |
} else | |
e.velocity.debug && console.log("Skipping [" + A + "] due to a lack of browser support.") | |
} | |
y.element = t | |
} | |
y.element && (P.push(y), e.data(t, c).tweensContainer = y, e.data(t, c).opts = n, e.data(t, c).isAnimating=!0, f === d - 1 ? (e.velocity.State.calls.length > 1e4 && (e.velocity.State.calls = o(e.velocity.State.calls)), e.velocity.State.calls.push([P, s, n]), e.velocity.State.isTicking===!1 && (e.velocity.State.isTicking=!0, i())) : f++), "" !== n.queue && "fx" !== n.queue && setTimeout(m, n.duration + n.delay) | |
}), (n.queue===!1 || ("" === n.queue || "fx" === n.queue) && "inprogress" !== e.queue(t)[0]) && e.dequeue(t) | |
} | |
var n, s, u, g; | |
this.jquery ? (n=!0, s = this, u = arguments[0], g = arguments[1]) : (n=!1, s = arguments[0].jquery ? arguments[0].get() : arguments[0], u = arguments[1], g = arguments[2]); | |
var d = s.length || 1, f = 0; | |
if ("stop" !== u && "object" != typeof g) { | |
var y = n ? 1: 2; | |
g = {}; | |
for (var m = y; m < arguments.length; m++) | |
/^\d / .test(arguments[m]) ? g.duration = parseFloat(arguments[m]) : "string" == typeof arguments[m] ? g.easing = arguments[m].replace(/^\s+|\s+$/g, "") : l(arguments[m]) && (g.complete = arguments[m]) | |
} | |
var h; | |
switch (u) { | |
case"scroll": | |
h = "scroll"; | |
break; | |
case"reverse": | |
h = "reverse"; | |
break; | |
case"stop": | |
h = "stop"; | |
break; | |
default: | |
if (!e.isPlainObject(u) || e.isEmptyObject(u)) | |
return "string" == typeof u && e.velocity.Sequences[u] ? (e.each(s, function(t, a) { | |
e.velocity.Sequences[u].call(a, a, g || {}, t, d) | |
}), s) : (e.velocity.debug && console.log("First argument was not a property map, a known action, or a registered sequence. Aborting."), s); | |
h = "start" | |
} | |
var v = { | |
lastParent: null, | |
lastPosition: null, | |
lastFontSize: null, | |
lastPercentToPxWidth: null, | |
lastPercentToPxHeight: null, | |
lastEmToPx: null, | |
remToPxRatio: null | |
}, P = []; | |
if (g&&!l(g.complete) && (g.complete = null), n) | |
s.each(t); | |
else if (s.nodeType) | |
t.call(s); | |
else if (s[0] && s[0].nodeType) | |
for (var x in s) | |
t.call(s[x]); | |
var b = e.extend({}, e.fn.velocity.defaults, g); | |
if (b.loop = parseInt(b.loop), b.loop) | |
for (var V = 0; V < 2 * b.loop - 1; V++) | |
n ? s.velocity("reverse", { | |
delay: b.delay | |
}) : e.velocity.animate(s, "reverse", { | |
delay: b.delay | |
}); | |
return s | |
} | |
}(jQuery, window, document), jQuery.fn.velocity.defaults = { | |
queue: "", | |
duration: 400, | |
easing: "swing", | |
complete: null, | |
display: null, | |
loop: !1, | |
delay: !1, | |
mobileHA: !0, | |
_cacheValues: !0 | |
}, jQuery.velocity.Sequences.slideDown = function(e, t) { | |
var a = { | |
height: null, | |
marginTop: null, | |
marginBottom: null, | |
paddingTop: null, | |
paddingBottom: null | |
}, r = { | |
overflow: null, | |
overflowY: null | |
}, o = t.complete; | |
t.delay = t.delay || 1, t.begin = function() { | |
r.overflow = jQuery.velocity.CSS.getPropertyValue(e, "overflow"), r.overflowY = jQuery.velocity.CSS.getPropertyValue(e, "overflowY"), this.style.overflow = "hidden", this.style.overflowY = "hidden", e.style.height = "auto", e.style.display = "block"; | |
for (var t in a) | |
a[t] = [jQuery.velocity.CSS.getPropertyValue(e, t), 0] | |
}, t.complete = function() { | |
o && o.call(this, this), this.style.overflow = r.overflow, this.style.overflowY = r.overflowY | |
}, jQuery.velocity.animate(e, a, t) | |
}, jQuery.velocity.Sequences.slideUp = function(e, t) { | |
var a = { | |
height: null, | |
marginTop: null, | |
marginBottom: null, | |
paddingTop: null, | |
paddingBottom: null, | |
overflow: null, | |
overflowY: null | |
}, r = t.complete; | |
t.display = t.display || "none", t._cacheValues=!1, t.begin = function() { | |
for (var t in a) | |
a[t] = jQuery.velocity.CSS.getPropertyValue(e, t); | |
this.style.overflow = "hidden", this.style.overflowY = "hidden" | |
}, t.complete = function() { | |
r && r.call(this, this); | |
for (var e in a) | |
this.style[e] = a[e] | |
}, jQuery.velocity.animate(e, { | |
height: [0, a.height], | |
marginTop: [0, a.marginTop], | |
marginBottom: [0, a.marginBottom], | |
paddingTop: [0, a.paddingTop], | |
paddingBottom: [0, a.paddingBottom] | |
}, t) | |
}; | |
// simple debounce plugin | |
function debounce(a, b, c) { | |
var d; | |
return function() { | |
var e = this, f = arguments; | |
clearTimeout(d), d = setTimeout(function() { | |
d = null, c || a.apply(e, f) | |
}, b), c&&!d && a.apply(e, f) | |
} | |
} | |
(function(d) { | |
var p = {}, e, a, h = document, i = window, f = h.documentElement, j = d.expando; | |
d.event.special.inview = { | |
add: function(a) { | |
p[a.guid + "-" + this[j]] = { | |
data: a, | |
$element: d(this) | |
} | |
}, | |
remove: function(a) { | |
try { | |
delete p[a.guid + "-" + this[j]] | |
} catch (d) {} | |
} | |
}; | |
d(i).bind("scroll resize", function() { | |
e = a = null | |
}); | |
!f.addEventListener && f.attachEvent && f.attachEvent("onfocusin", function() { | |
a = null | |
}); | |
setInterval(function() { | |
var k = d(), j, n = 0; | |
d.each(p, function(a, b) { | |
var c = b.data.selector, d = b.$element; | |
k = k.add(c ? d.find(c) : d) | |
}); | |
if (j = k.length) { | |
var b; | |
if (!(b = e)) { | |
var g = { | |
height: i.innerHeight, | |
width: i.innerWidth | |
}; | |
if (!g.height && ((b = h.compatMode) ||!d.support.boxModel)) | |
b = "CSS1Compat" === b ? f : h.body, g = { | |
height: b.clientHeight, | |
width: b.clientWidth | |
}; | |
b = g | |
} | |
e = b; | |
for (a = a || { | |
top: i.pageYOffset || f.scrollTop || h.body.scrollTop, | |
left: i.pageXOffset || f.scrollLeft || h.body.scrollLeft | |
}; n < j; n++) | |
if (d.contains(f, k[n])) { | |
b = d(k[n]); | |
var l = b.height(), m = b.width(), c = b.offset(), g = b.data("inview"); | |
if (!a ||!e) | |
break; | |
c.top + l > a.top && c.top < a.top + e.height && c.left + m > a.left && c.left < a.left + e.width ? | |
(m = a.left > c.left ? "right" : a.left + e.width < c.left + m ? "left" : "both", l = a.top > c.top ? "bottom" : a.top + e.height < c.top + l ? "top" : "both", c = m + "-" + l, (!g || g !== c) && b.data("inview", c).trigger("inview", [!0, m, l])) : g && b.data("inview", !1).trigger("inview", [!1]) | |
} | |
} | |
}, 250) | |
})(jQuery); | |
// count up plugin https://github.com/inorganik/countUp.js | |
function countUp(a, b, c, d, e, f) { | |
for (var g = 0, h = ["webkit", "moz", "ms"], i = 0; i < h.length&&!window.requestAnimationFrame; ++i) | |
window.requestAnimationFrame = window[h[i] + "RequestAnimationFrame"], window.cancelAnimationFrame = window[h[i] + "CancelAnimationFrame"] || window[h[i] + "CancelRequestAnimationFrame"]; | |
window.requestAnimationFrame || (window.requestAnimationFrame = function(a) { | |
var c = (new Date).getTime(), d = Math.max(0, 16 - (c - g)), e = window.setTimeout(function() { | |
a(c + d) | |
}, d); | |
return g = c + d, e | |
}), window.cancelAnimationFrame || (window.cancelAnimationFrame = function(a) { | |
clearTimeout(a) | |
}), this.options = f || { | |
useEasing: !0, | |
useGrouping: !0, | |
separator: ",", | |
decimal: "." | |
}, "" == this.options.separator && (this.options.useGrouping=!1); | |
var j = this; | |
this.d = "string" == typeof a ? document.getElementById(a) : a, this.startVal = Number(b), this.endVal = Number(c), this.countDown = this.startVal > this.endVal?!0 : !1, this.startTime = null, this.timestamp = null, this.remaining = null, this.frameVal = this.startVal, this.rAF = null, this.decimals = Math.max(0, d || 0), this.dec = Math.pow(10, this.decimals), this.duration = 1e3 * e || 2e3, this.version = function() { | |
return "1.1.1" | |
}, this.easeOutExpo = function(a, b, c, d) { | |
return 1024 * c * ( - Math.pow(2, - 10 * a / d) + 1) / 1023 + b | |
}, this.count = function(a) { | |
null === j.startTime && (j.startTime = a), j.timestamp = a; | |
var b = a - j.startTime; | |
if (j.remaining = j.duration - b, j.options.useEasing) | |
if (j.countDown) { | |
var c = j.easeOutExpo(b, 0, j.startVal - j.endVal, j.duration); | |
j.frameVal = j.startVal - c | |
} else | |
j.frameVal = j.easeOutExpo(b, j.startVal, j.endVal - j.startVal, j.duration); | |
else if (j.countDown) { | |
var c = (j.startVal - j.endVal) * (b / j.duration); | |
j.frameVal = j.startVal - c | |
} else | |
j.frameVal = j.startVal + (j.endVal - j.startVal) * (b / j.duration); | |
j.frameVal = Math.round(j.frameVal * j.dec) / j.dec, j.frameVal = j.countDown ? j.frameVal < j.endVal ? j.endVal : j.frameVal : j.frameVal > j.endVal ? j.endVal : j.frameVal, j.d.innerHTML = j.formatNumber(j.frameVal.toFixed(j.decimals)), b < j.duration ? j.rAF = requestAnimationFrame(j.count) : null != j.callback && j.callback() | |
}, this.start = function(a) { | |
return j.callback = a, isNaN(j.endVal) || isNaN(j.startVal) ? (console.log("countUp error: startVal or endVal is not a number"), j.d.innerHTML = "--") : j.rAF = requestAnimationFrame(j.count), !1 | |
}, this.stop = function() { | |
cancelAnimationFrame(j.rAF) | |
}, this.reset = function() { | |
j.startTime = null, cancelAnimationFrame(j.rAF), j.d.innerHTML = j.formatNumber(j.startVal.toFixed(j.decimals)) | |
}, this.resume = function() { | |
j.startTime = null, j.duration = j.remaining, j.startVal = j.frameVal, requestAnimationFrame(j.count) | |
}, this.formatNumber = function(a) { | |
a += ""; | |
var b, c, d, e; | |
if (b = a.split("."), c = b[0], d = b.length > 1 ? j.options.decimal + b[1] : "", e = /(\d+)(\d{3})/, j.options.useGrouping) | |
for (; e.test(c);) | |
c = c.replace(e, "$1" + j.options.separator + "$2"); | |
return c + d | |
}, j.d.innerHTML = j.formatNumber(j.startVal.toFixed(j.decimals)) | |
} | |
/*! JSON v3.3.0 | http://bestiejs.github.io/json3 | Copyright 2012-2014, Kit Cambridge | http://kit.mit-license.org */ | |
(function(n) { | |
function K(p, q) { | |
function s(a) { | |
if (s[a] !== v) | |
return s[a]; | |
var c; | |
if ("bug-string-char-index" == a) | |
c = "a" != "a"[0]; | |
else if ("json" == a) | |
c = s("json-stringify") && s("json-parse"); | |
else { | |
var e; | |
if ("json-stringify" == a) { | |
c = q.stringify; | |
var b = "function" == typeof c && r; | |
if (b) { | |
(e = function() { | |
return 1 | |
}).toJSON = e; | |
try { | |
b = "0" === c(0) && "0" === c(new A) && '""' == c(new B) && c(t) === v && c(v) === v && c() === v && "1" === c(e) && "[1]" == c([e]) && "[null]" == c([v]) && "null" == c(null) && "[null,null,null]" == c([v, t, null]) && '{"a":[1,true,false,null,"\\u0000\\b\\n\\f\\r\\t"]}' == | |
c({ | |
a: [e, !0, !1, null, "\x00\b\n\f\r\t"] | |
}) && "1" === c(null, e) && "[\n 1,\n 2\n]" == c([1, 2], null, 1) && '"-271821-04-20T00:00:00.000Z"' == c(new D( - 864E13)) && '"+275760-09-13T00:00:00.000Z"' == c(new D(864E13)) && '"-000001-01-01T00:00:00.000Z"' == c(new D( - 621987552E5)) && '"1969-12-31T23:59:59.999Z"' == c(new D( - 1)) | |
} catch (f) { | |
b=!1 | |
} | |
} | |
c = b | |
} | |
if ("json-parse" == a) { | |
c = q.parse; | |
if ("function" == typeof c) | |
try { | |
if (0 === c("0")&&!c(!1)) { | |
e = c('{"a":[1,true,false,null,"\\u0000\\b\\n\\f\\r\\t"]}'); | |
var l = 5 == e.a.length && 1 === e.a[0]; | |
if (l) { | |
try { | |
l=!c('"\t"') | |
} catch (d) {} | |
if (l) | |
try { | |
l = | |
1 !== c("01") | |
} catch (h) {} | |
if (l) | |
try { | |
l = 1 !== c("1.") | |
} catch (m) {} | |
} | |
} | |
} catch (X) { | |
l=!1 | |
} | |
c = l | |
} | |
} | |
return s[a]=!!c | |
} | |
p || (p = n.Object()); | |
q || (q = n.Object()); | |
var A = p.Number || n.Number, B = p.String || n.String, G = p.Object || n.Object, D = p.Date || n.Date, J = p.SyntaxError || n.SyntaxError, N = p.TypeError || n.TypeError, R = p.Math || n.Math, H = p.JSON || n.JSON; | |
"object" == typeof H && H && (q.stringify = H.stringify, q.parse = H.parse); | |
var G = G.prototype, t = G.toString, u, C, v, r = new D( - 0xc782b5b800cec); | |
try { | |
r =- 109252 == r.getUTCFullYear() && 0 === r.getUTCMonth() && 1 === r.getUTCDate() && | |
10 == r.getUTCHours() && 37 == r.getUTCMinutes() && 6 == r.getUTCSeconds() && 708 == r.getUTCMilliseconds() | |
} catch (Y) {} | |
if (!s("json")) { | |
var E = s("bug-string-char-index"); | |
if (!r) | |
var w = R.floor, S = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334], F = function(a, c) { | |
return S[c] + 365 * (a - 1970) + w((a - 1969 + (c =+ (1 < c))) / 4) - w((a - 1901 + c) / 100) + w((a - 1601 + c) / 400) | |
}; | |
(u = G.hasOwnProperty) || (u = function(a) { | |
var c = {}, e; | |
(c.__proto__ = null, c.__proto__ = { | |
toString: 1 | |
}, c).toString != t ? u = function(a) { | |
var c = this.__proto__; | |
a = a in (this.__proto__ = null, this); | |
this.__proto__ = | |
c; | |
return a | |
} : (e = c.constructor, u = function(a) { | |
var c = (this.constructor || e).prototype; | |
return a in this&&!(a in c && this[a] === c[a]) | |
}); | |
c = null; | |
return u.call(this, a) | |
}); | |
var T = { | |
"boolean": 1, | |
number: 1, | |
string: 1, | |
undefined: 1 | |
}; | |
C = function(a, c) { | |
var e = 0, b, f, l; | |
(b = function() { | |
this.valueOf = 0 | |
}).prototype.valueOf = 0; | |
f = new b; | |
for (l in f) | |
u.call(f, l) && e++; | |
b = f = null; | |
e ? C = 2 == e ? function(a, c) { | |
var e = {}, b = "[object Function]" == t.call(a), f; | |
for (f in a) | |
b && "prototype" == f || u.call(e, f) ||!(e[f] = 1) ||!u.call(a, f) || c(f) | |
} : function(a, c) { | |
var e = "[object Function]" == | |
t.call(a), b, f; | |
for (b in a) | |
e && "prototype" == b ||!u.call(a, b) || (f = "constructor" === b) || c(b); | |
(f || u.call(a, b = "constructor")) && c(b) | |
} : (f = "valueOf toString toLocaleString propertyIsEnumerable isPrototypeOf hasOwnProperty constructor".split(" "), C = function(a, c) { | |
var e = "[object Function]" == t.call(a), b, g; | |
if (g=!e) | |
if (g = "function" != typeof a.constructor) | |
g = typeof a.hasOwnProperty, g = "object" == g?!!a.hasOwnProperty : !T[g]; | |
g = g ? a.hasOwnProperty : u; | |
for (b in a) | |
e && "prototype" == b ||!g.call(a, b) || c(b); | |
for (e = f.length; b = f[--e]; g.call(a, | |
b) | |
&& c(b)); | |
}); | |
return C(a, c) | |
}; | |
if (!s("json-stringify")) { | |
var U = { | |
92: "\\\\", | |
34: '\\"', | |
8: "\\b", | |
12: "\\f", | |
10: "\\n", | |
13: "\\r", | |
9: "\\t" | |
}, x = function(a, c) { | |
return ("000000" + (c || 0)).slice( - a) | |
}, O = function(a) { | |
for (var c = '"', b = 0, g = a.length, f=!E || 10 < g, l = f && (E ? a.split("") : a); b < g; b++) { | |
var d = a.charCodeAt(b); | |
switch (d) { | |
case 8: | |
case 9: | |
case 10: | |
case 12: | |
case 13: | |
case 34: | |
case 92: | |
c += U[d]; | |
break; | |
default: | |
if (32 > d) { | |
c += "\\u00" + x(2, d.toString(16)); | |
break | |
} | |
c += f ? l[b] : a.charAt(b) | |
} | |
} | |
return c + '"' | |
}, L = function(a, c, b, g, f, l, d) { | |
var h, m, k, n, p, q, r, s, y; | |
try { | |
h = | |
c[a] | |
} catch (z) {} | |
if ("object" == typeof h && h) | |
if (m = t.call(h), "[object Date]" != m || u.call(h, "toJSON")) | |
"function" == typeof h.toJSON && ("[object Number]" != m && "[object String]" != m && "[object Array]" != m || u.call(h, "toJSON")) && (h = h.toJSON(a)); | |
else if (h>-1 / 0 && h < 1 / 0) { | |
if (F) { | |
n = w(h / 864E5); | |
for (m = w(n / 365.2425) + 1970 - 1; F(m + 1, 0) <= n; m++); | |
for (k = w((n - F(m, 0)) / 30.42); F(m, k + 1) <= n; k++); | |
n = 1 + n - F(m, k); | |
p = (h%864E5 + 864E5)%864E5; | |
q = w(p / 36E5)%24; | |
r = w(p / 6E4)%60; | |
s = w(p / 1E3)%60; | |
p%=1E3 | |
} else | |
m = h.getUTCFullYear(), k = h.getUTCMonth(), n = h.getUTCDate(), | |
q = h.getUTCHours(), r = h.getUTCMinutes(), s = h.getUTCSeconds(), p = h.getUTCMilliseconds(); | |
h = (0 >= m || 1E4 <= m ? (0 > m ? "-" : "+") + x(6, 0 > m?-m : m) : x(4, m)) + "-" + x(2, k + 1) + "-" + x(2, n) + "T" + x(2, q) + ":" + x(2, r) + ":" + x(2, s) + "." + x(3, p) + "Z" | |
} else | |
h = null; | |
b && (h = b.call(c, a, h)); | |
if (null === h) | |
return "null"; | |
m = t.call(h); | |
if ("[object Boolean]" == m) | |
return "" + h; | |
if ("[object Number]" == m) | |
return h>-1 / 0 && h < 1 / 0 ? "" + h : "null"; | |
if ("[object String]" == m) | |
return O("" + h); | |
if ("object" == typeof h) { | |
for (a = d.length; a--;) | |
if (d[a] === h) | |
throw N(); | |
d.push(h); | |
y = []; | |
c = l; | |
l += f; | |
if ("[object Array]" == | |
m) { | |
k = 0; | |
for (a = h.length; k < a; k++) | |
m = L(k, h, b, g, f, l, d), y.push(m === v ? "null" : m); | |
a = y.length ? f ? "[\n" + l + y.join(",\n" + l) + "\n" + c + "]" : "[" + y.join(",") + "]" : "[]" | |
} else | |
C(g || h, function(a) { | |
var c = L(a, h, b, g, f, l, d); | |
c !== v && y.push(O(a) + ":" + (f ? " " : "") + c) | |
}), a = y.length ? f ? "{\n" + l + y.join(",\n" + l) + "\n" + c + "}" : "{" + y.join(",") + "}" : "{}"; | |
d.pop(); | |
return a | |
} | |
}; | |
q.stringify = function(a, c, b) { | |
var g, f, l, d; | |
if ("function" == typeof c || "object" == typeof c && c) | |
if ("[object Function]" == (d = t.call(c))) | |
f = c; | |
else if ("[object Array]" == d) { | |
l = {}; | |
for (var h = 0, m = c.length, | |
k; h < m; k = c[h++], (d = t.call(k), "[object String]" == d || "[object Number]" == d) && (l[k] = 1)); | |
} | |
if (b) | |
if ("[object Number]" == (d = t.call(b))) { | |
if (0 < (b -= b%1)) | |
for (g = "", 10 < b && (b = 10); g.length < b; g += " "); | |
} else | |
"[object String]" == d && (g = 10 >= b.length ? b : b.slice(0, 10)); | |
return L("", (k = {}, k[""] = a, k), f, l, g, "", []) | |
} | |
} | |
if (!s("json-parse")) { | |
var V = B.fromCharCode, W = { | |
92: "\\", | |
34: '"', | |
47: "/", | |
98: "\b", | |
116: "\t", | |
110: "\n", | |
102: "\f", | |
114: "\r" | |
}, b, I, k = function() { | |
b = I = null; | |
throw J(); | |
}, z = function() { | |
for (var a = I, c = a.length, e, g, f, l, d; b < c;) | |
switch (d = a.charCodeAt(b), | |
d) { | |
case 9: | |
case 10: | |
case 13: | |
case 32: | |
b++; | |
break; | |
case 123: | |
case 125: | |
case 91: | |
case 93: | |
case 58: | |
case 44: | |
return e = E ? a.charAt(b) : a[b], b++, e; | |
case 34: | |
e = "@"; | |
for (b++; b < c;) | |
if (d = a.charCodeAt(b), 32 > d) | |
k(); | |
else if (92 == d) | |
switch (d = a.charCodeAt(++b), d) { | |
case 92: | |
case 34: | |
case 47: | |
case 98: | |
case 116: | |
case 110: | |
case 102: | |
case 114: | |
e += W[d]; | |
b++; | |
break; | |
case 117: | |
g=++b; | |
for (f = b + 4; b < f; b++) | |
d = a.charCodeAt(b), 48 <= d && 57 >= d || 97 <= d && 102 >= d || 65 <= d && 70 >= d || k(); | |
e += V("0x" + a.slice(g, b)); | |
break; | |
default: | |
k() | |
} else { | |
if (34 == d) | |
break; | |
d = a.charCodeAt(b); | |
for (g = b; 32 <= | |
d && 92 != d && 34 != d;) | |
d = a.charCodeAt(++b); | |
e += a.slice(g, b) | |
} | |
if (34 == a.charCodeAt(b)) | |
return b++, e; | |
k(); | |
default: | |
g = b; | |
45 == d && (l=!0, d = a.charCodeAt(++b)); | |
if (48 <= d && 57 >= d) { | |
for (48 == d && (d = a.charCodeAt(b + 1), 48 <= d && 57 >= d) && k(); b < c && (d = a.charCodeAt(b), 48 <= d && 57 >= d); b++); | |
if (46 == a.charCodeAt(b)) { | |
for (f=++b; f < c && (d = a.charCodeAt(f), 48 <= d && 57 >= d); f++); | |
f == b && k(); | |
b = f | |
} | |
d = a.charCodeAt(b); | |
if (101 == d || 69 == d) { | |
d = a.charCodeAt(++b); | |
43 != d && 45 != d || b++; | |
for (f = b; f < c && (d = a.charCodeAt(f), 48 <= d && 57 >= d); f++); | |
f == b && k(); | |
b = f | |
} | |
return + a.slice(g, b) | |
} | |
l && | |
k(); | |
if ("true" == a.slice(b, b + 4)) | |
return b += 4, !0; | |
if ("false" == a.slice(b, b + 5)) | |
return b += 5, !1; | |
if ("null" == a.slice(b, b + 4)) | |
return b += 4, null; | |
k() | |
} | |
return "$" | |
}, M = function(a) { | |
var c, b; | |
"$" == a && k(); | |
if ("string" == typeof a) { | |
if ("@" == (E ? a.charAt(0) : a[0])) | |
return a.slice(1); | |
if ("[" == a) { | |
for (c = []; ; b || (b=!0) | |
) { | |
a = z(); | |
if ("]" == a) | |
break; | |
b && ("," == a ? (a = z(), "]" == a && k()) : k()); | |
"," == a && k(); | |
c.push(M(a)) | |
} | |
return c | |
} | |
if ("{" == a) { | |
for (c = {}; ; b || (b=!0) | |
) { | |
a = z(); | |
if ("}" == a) | |
break; | |
b && ("," == a ? (a = z(), "}" == a && k()) : k()); | |
"," != a && "string" == typeof a && "@" == (E ? a.charAt(0) : | |
a[0]) && ":" == z() || k(); | |
c[a.slice(1)] = M(z()) | |
} | |
return c | |
} | |
k() | |
} | |
return a | |
}, Q = function(a, b, e) { | |
e = P(a, b, e); | |
e === v ? delete a[b] : a[b] = e | |
}, P = function(a, b, e) { | |
var g = a[b], f; | |
if ("object" == typeof g && g) | |
if ("[object Array]" == t.call(g)) | |
for (f = g.length; f--;) | |
Q(g, f, e); | |
else | |
C(g, function(a) { | |
Q(g, a, e) | |
}); | |
return e.call(a, b, g) | |
}; | |
q.parse = function(a, c) { | |
var e, g; | |
b = 0; | |
I = "" + a; | |
e = M(z()); | |
"$" != z() && k(); | |
b = I = null; | |
return c && "[object Function]" == t.call(c) ? P((g = {}, g[""] = e, g), "", c) : e | |
} | |
} | |
} | |
q.runInContext = K; | |
return q | |
} | |
var J = typeof define === "function" && define.amd, | |
A = "object" == typeof global && global; | |
!A || A.global !== A && A.window !== A || (n = A); | |
if ("object" != typeof exports ||!exports || exports.nodeType || J) { | |
var N = n.JSON, B = K(n, n.JSON3 = { | |
noConflict: function() { | |
n.JSON = N; | |
return B | |
} | |
}); | |
n.JSON = { | |
parse: B.parse, | |
stringify: B.stringify | |
} | |
} else | |
K(n, exports); | |
J && define(function() { | |
return B | |
}) | |
})(this); | |
var kkeys = [], konami = "38,38,40,40,37,39,37,39,66,65"; | |
$(document).keydown(function(e) { | |
kkeys.push( e.keyCode ); | |
if ( kkeys.toString().indexOf( konami ) >= 0 ) { | |
$(document).unbind('keydown', arguments.callee); | |
// do something awesome | |
$("html").addClass("konami"); | |
$(window).trigger('KONAMI_CODE'); | |
} | |
}); | |
var modAnalytics = angular.module('PRPLAnalytics', []); | |
modAnalytics.factory('$prplAnalytics', function() { | |
var self = this; | |
// self.cacheTTL = '0h:0m:2s'; // dev | |
return { | |
pageview: function(url) { | |
ga('send', 'pageview'); | |
// console.log('pageview url', url); | |
// _gaq.push(['_trackPageview', url]); | |
}, | |
send: function(obj) { | |
if (typeof obj === 'undefined') { | |
return false; | |
} else { | |
var type = (typeof obj.type === 'undefined') ? "Default" : obj.type, | |
action = (typeof obj.action === 'undefined') ? "click" : obj.action, | |
value = (typeof obj.value === 'undefined') ? "Default" : obj.value; | |
ga('send', 'event', type, action, value); | |
// console.info("PRPLAnalyticz: ga('send', 'event', '" + type + "', '" + action + "', '" + value + "');") | |
} | |
}, | |
gtm: { | |
pageview: function(url) { | |
GTMDataLayer.push({ | |
'event': 'ngPageview', | |
'ngPageviewURL': url | |
}); | |
} | |
} | |
}; | |
}); | |
modAnalytics.directive('prplAnalytics', ['$prplAnalytics', function($prplAnalytics) { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
var aVal = 'Default'; | |
if (typeof attrs.analyticsVal !== 'undefined' && attrs.analyticsVal !== '') { | |
aVal = attrs.analyticsVal; | |
} | |
if (attrs.analytics !== '') { | |
if (attrs.analytics === 'click') { | |
element.on({ | |
click: function() { | |
$prplAnalytics.send({ | |
action: 'click', | |
value: aVal | |
}); | |
} | |
}); | |
} | |
} | |
} | |
} | |
} | |
]); | |
//! moment.js | |
//! version : 2.5.1 | |
//! authors : Tim Wood, Iskren Chernev, Moment.js contributors | |
//! license : MIT | |
//! momentjs.com | |
(function(a) { | |
function b() { | |
return { | |
empty: !1, | |
unusedTokens: [], | |
unusedInput: [], | |
overflow: - 2, | |
charsLeftOver: 0, | |
nullInput: !1, | |
invalidMonth: null, | |
invalidFormat: !1, | |
userInvalidated: !1, | |
iso: !1 | |
} | |
} | |
function c(a, b) { | |
return function(c) { | |
return k(a.call(this, c), b) | |
} | |
} | |
function d(a, b) { | |
return function(c) { | |
return this.lang().ordinal(a.call(this, c), b) | |
} | |
} | |
function e() {} | |
function f(a) { | |
w(a), h(this, a) | |
} | |
function g(a) { | |
var b = q(a), c = b.year || 0, d = b.month || 0, e = b.week || 0, f = b.day || 0, g = b.hour || 0, h = b.minute || 0, i = b.second || 0, j = b.millisecond || 0; | |
this._milliseconds =+ j + 1e3 * i + 6e4 * h + 36e5 * g, this._days =+ f + 7 * e, this._months =+ d + 12 * c, this._data = {}, this._bubble() | |
} | |
function h(a, b) { | |
for (var c in b) | |
b.hasOwnProperty(c) && (a[c] = b[c]); | |
return b.hasOwnProperty("toString") && (a.toString = b.toString), b.hasOwnProperty("valueOf") && (a.valueOf = b.valueOf), a | |
} | |
function i(a) { | |
var b, c = {}; | |
for (b in a) | |
a.hasOwnProperty(b) && qb.hasOwnProperty(b) && (c[b] = a[b]); | |
return c | |
} | |
function j(a) { | |
return 0 > a ? Math.ceil(a) : Math.floor(a) | |
} | |
function k(a, b, c) { | |
for (var d = "" + Math.abs(a), e = a >= 0; d.length < b;) | |
d = "0" + d; | |
return (e ? c ? "+" : "" : "-") + d | |
} | |
function l(a, b, c, d) { | |
var e, f, g = b._milliseconds, h = b._days, i = b._months; | |
g && a._d.setTime( + a._d + g * c), (h || i) && (e = a.minute(), f = a.hour()), h && a.date(a.date() + h * c), i && a.month(a.month() + i * c), g&&!d && db.updateOffset(a), (h || i) && (a.minute(e), a.hour(f)) | |
} | |
function m(a) { | |
return "[object Array]" === Object.prototype.toString.call(a) | |
} | |
function n(a) { | |
return "[object Date]" === Object.prototype.toString.call(a) || a instanceof Date | |
} | |
function o(a, b, c) { | |
var d, e = Math.min(a.length, b.length), f = Math.abs(a.length - b.length), g = 0; | |
for (d = 0; e > d; d++)(c && a[d] !== b[d] ||!c && s(a[d]) !== s(b[d]) | |
) && g++; | |
return g + f | |
} | |
function p(a) { | |
if (a) { | |
var b = a.toLowerCase().replace(/(.)s$/, "$1"); | |
a = Tb[a] || Ub[b] || b | |
} | |
return a | |
} | |
function q(a) { | |
var b, c, d = {}; | |
for (c in a) | |
a.hasOwnProperty(c) && (b = p(c), b && (d[b] = a[c])); | |
return d | |
} | |
function r(b) { | |
var c, d; | |
if (0 === b.indexOf("week")) | |
c = 7, d = "day"; | |
else { | |
if (0 !== b.indexOf("month")) | |
return; | |
c = 12, d = "month" | |
} | |
db[b] = function(e, f) { | |
var g, h, i = db.fn._lang[b], j = []; | |
if ("number" == typeof e && (f = e, e = a), h = function(a) { | |
var b = db().utc().set(d, a); | |
return i.call(db.fn._lang, b, e || "") | |
}, null != f) | |
return h(f); | |
for (g = 0; c > g; g++) | |
j.push(h(g)); | |
return j | |
} | |
} | |
function s(a) { | |
var b =+ a, c = 0; | |
return 0 !== b && isFinite(b) && (c = b >= 0 ? Math.floor(b) : Math.ceil(b)), c | |
} | |
function t(a, b) { | |
return new Date(Date.UTC(a, b + 1, 0)).getUTCDate() | |
} | |
function u(a) { | |
return v(a) ? 366 : 365 | |
} | |
function v(a) { | |
return a%4 === 0 && a%100 !== 0 || a%400 === 0 | |
} | |
function w(a) { | |
var b; | |
a._a&&-2 === a._pf.overflow && (b = a._a[jb] < 0 || a._a[jb] > 11 ? jb : a._a[kb] < 1 || a._a[kb] > t(a._a[ib], a._a[jb]) ? kb : a._a[lb] < 0 || a._a[lb] > 23 ? lb : a._a[mb] < 0 || a._a[mb] > 59 ? mb : a._a[nb] < 0 || a._a[nb] > 59 ? nb : a._a[ob] < 0 || a._a[ob] > 999 ? ob : - 1, a._pf._overflowDayOfYear && (ib > b || b > kb) && (b = kb), a._pf.overflow = b) | |
} | |
function x(a) { | |
return null == a._isValid && (a._isValid=!isNaN(a._d.getTime()) && a._pf.overflow < 0&&!a._pf.empty&&!a._pf.invalidMonth&&!a._pf.nullInput&&!a._pf.invalidFormat&&!a._pf.userInvalidated, a._strict && (a._isValid = a._isValid && 0 === a._pf.charsLeftOver && 0 === a._pf.unusedTokens.length)), a._isValid | |
} | |
function y(a) { | |
return a ? a.toLowerCase().replace("_", "-") : a | |
} | |
function z(a, b) { | |
return b._isUTC ? db(a).zone(b._offset || 0) : db(a).local() | |
} | |
function A(a, b) { | |
return b.abbr = a, pb[a] || (pb[a] = new e), pb[a].set(b), pb[a] | |
} | |
function B(a) { | |
delete pb[a] | |
} | |
function C(a) { | |
var b, c, d, e, f = 0, g = function(a) { | |
if (!pb[a] && rb) | |
try { | |
require("./lang/" + a) | |
} catch (b) {} | |
return pb[a] | |
}; | |
if (!a) | |
return db.fn._lang; | |
if (!m(a)) { | |
if (c = g(a)) | |
return c; | |
a = [a] | |
} | |
for (; f < a.length;) { | |
for (e = y(a[f]).split("-"), b = e.length, d = y(a[f + 1]), d = d ? d.split("-") : null; b > 0;) { | |
if (c = g(e.slice(0, b).join("-"))) | |
return c; | |
if (d && d.length >= b && o(e, d, !0) >= b - 1) | |
break; | |
b-- | |
} | |
f++ | |
} | |
return db.fn._lang | |
} | |
function D(a) { | |
return a.match(/\[[\s\S]/) ? a.replace(/^\[|\]$/g, "") : a.replace(/\\/g, "") | |
} | |
function E(a) { | |
var b, c, d = a.match(vb); | |
for (b = 0, c = d.length; c > b; b++) | |
d[b] = Yb[d[b]] ? Yb[d[b]] : D(d[b]); | |
return function(e) { | |
var f = ""; | |
for (b = 0; c > b; b++) | |
f += d[b]instanceof Function ? d[b].call(e, a) : d[b]; | |
return f | |
} | |
} | |
function F(a, b) { | |
return a.isValid() ? (b = G(b, a.lang()), Vb[b] || (Vb[b] = E(b)), Vb[b](a)) : a.lang().invalidDate() | |
} | |
function G(a, b) { | |
function c(a) { | |
return b.longDateFormat(a) || a | |
} | |
var d = 5; | |
for (wb.lastIndex = 0; d >= 0 && wb.test(a);) | |
a = a.replace(wb, c), wb.lastIndex = 0, d -= 1; | |
return a | |
} | |
function H(a, b) { | |
var c, d = b._strict; | |
switch (a) { | |
case"DDDD": | |
return Ib; | |
case"YYYY": | |
case"GGGG": | |
case"gggg": | |
return d ? Jb : zb; | |
case"Y": | |
case"G": | |
case"g": | |
return Lb; | |
case"YYYYYY": | |
case"YYYYY": | |
case"GGGGG": | |
case"ggggg": | |
return d ? Kb : Ab; | |
case"S": | |
if (d) | |
return Gb; | |
case"SS": | |
if (d) | |
return Hb; | |
case"SSS": | |
if (d) | |
return Ib; | |
case"DDD": | |
return yb; | |
case"MMM": | |
case"MMMM": | |
case"dd": | |
case"ddd": | |
case"dddd": | |
return Cb; | |
case"a": | |
case"A": | |
return C(b._l)._meridiemParse; | |
case"X": | |
return Fb; | |
case"Z": | |
case"ZZ": | |
return Db; | |
case"T": | |
return Eb; | |
case"SSSS": | |
return Bb; | |
case"MM": | |
case"DD": | |
case"YY": | |
case"GG": | |
case"gg": | |
case"HH": | |
case"hh": | |
case"mm": | |
case"ss": | |
case"ww": | |
case"WW": | |
return d ? Hb : xb; | |
case"M": | |
case"D": | |
case"d": | |
case"H": | |
case"h": | |
case"m": | |
case"s": | |
case"w": | |
case"W": | |
case"e": | |
case"E": | |
return xb; | |
default: | |
return c = new RegExp(P(O(a.replace("\\", "")), "i")) | |
} | |
} | |
function I(a) { | |
a = a || ""; | |
var b = a.match(Db) || [], c = b[b.length - 1] || [], d = (c + "").match(Qb) || ["-", 0, 0], e =+ (60 * d[1]) + s(d[2]); | |
return "+" === d[0]?-e : e | |
} | |
function J(a, b, c) { | |
var d, e = c._a; | |
switch (a) { | |
case"M": | |
case"MM": | |
null != b && (e[jb] = s(b) - 1); | |
break; | |
case"MMM": | |
case"MMMM": | |
d = C(c._l).monthsParse(b), null != d ? e[jb] = d : c._pf.invalidMonth = b; | |
break; | |
case"D": | |
case"DD": | |
null != b && (e[kb] = s(b)); | |
break; | |
case"DDD": | |
case"DDDD": | |
null != b && (c._dayOfYear = s(b)); | |
break; | |
case"YY": | |
e[ib] = s(b) + (s(b) > 68 ? 1900 : 2e3); | |
break; | |
case"YYYY": | |
case"YYYYY": | |
case"YYYYYY": | |
e[ib] = s(b); | |
break; | |
case"a": | |
case"A": | |
c._isPm = C(c._l).isPM(b); | |
break; | |
case"H": | |
case"HH": | |
case"h": | |
case"hh": | |
e[lb] = s(b); | |
break; | |
case"m": | |
case"mm": | |
e[mb] = s(b); | |
break; | |
case"s": | |
case"ss": | |
e[nb] = s(b); | |
break; | |
case"S": | |
case"SS": | |
case"SSS": | |
case"SSSS": | |
e[ob] = s(1e3 * ("0." + b)); | |
break; | |
case"X": | |
c._d = new Date(1e3 * parseFloat(b)); | |
break; | |
case"Z": | |
case"ZZ": | |
c._useUTC=!0, c._tzm = I(b); | |
break; | |
case"w": | |
case"ww": | |
case"W": | |
case"WW": | |
case"d": | |
case"dd": | |
case"ddd": | |
case"dddd": | |
case"e": | |
case"E": | |
a = a.substr(0, 1); | |
case"gg": | |
case"gggg": | |
case"GG": | |
case"GGGG": | |
case"GGGGG": | |
a = a.substr(0, 2), b && (c._w = c._w || {}, c._w[a] = b) | |
} | |
} | |
function K(a) { | |
var b, c, d, e, f, g, h, i, j, k, l = []; | |
if (!a._d) { | |
for (d = M(a), a._w && null == a._a[kb] && null == a._a[jb] && (f = function(b) { | |
var c = parseInt(b, 10); | |
return b ? b.length < 3 ? c > 68 ? 1900 + c : 2e3 + c : c : null == a._a[ib] ? db().weekYear() : a._a[ib] | |
}, g = a._w, null != g.GG || null != g.W || null != g.E ? h = Z(f(g.GG), g.W || 1, g.E, 4, 1) : (i = C(a._l), j = null != g.d ? V(g.d, i) : null != g.e ? parseInt(g.e, 10) + i._week.dow : 0, k = parseInt(g.w, 10) || 1, null != g.d && j < i._week.dow && k++, h = Z(f(g.gg), k, j, i._week.doy, i._week.dow)), a._a[ib] = h.year, a._dayOfYear = h.dayOfYear), a._dayOfYear && (e = null == a._a[ib] ? d[ib] : a._a[ib], a._dayOfYear > u(e) && (a._pf._overflowDayOfYear=!0), c = U(e, 0, a._dayOfYear), a._a[jb] = c.getUTCMonth(), a._a[kb] = c.getUTCDate()), b = 0; 3 > b && null == a._a[b]; ++b) | |
a._a[b] = l[b] = d[b]; | |
for (; 7 > b; b++) | |
a._a[b] = l[b] = null == a._a[b] ? 2 === b ? 1 : 0 : a._a[b]; | |
l[lb] += s((a._tzm || 0) / 60), l[mb] += s((a._tzm || 0)%60), a._d = (a._useUTC ? U : T).apply(null, l) | |
} | |
} | |
function L(a) { | |
var b; | |
a._d || (b = q(a._i), a._a = [b.year, b.month, b.day, b.hour, b.minute, b.second, b.millisecond], K(a)) | |
} | |
function M(a) { | |
var b = new Date; | |
return a._useUTC ? [b.getUTCFullYear(), b.getUTCMonth(), b.getUTCDate()] : [b.getFullYear(), b.getMonth(), b.getDate()] | |
} | |
function N(a) { | |
a._a = [], a._pf.empty=!0; | |
var b, c, d, e, f, g = C(a._l), h = "" + a._i, i = h.length, j = 0; | |
for (d = G(a._f, g).match(vb) || [], b = 0; b < d.length; b++) | |
e = d[b], c = (h.match(H(e, a)) || [])[0], c && (f = h.substr(0, h.indexOf(c)), f.length > 0 && a._pf.unusedInput.push(f), h = h.slice(h.indexOf(c) + c.length), j += c.length), Yb[e] ? (c ? a._pf.empty=!1 : a._pf.unusedTokens.push(e), J(e, c, a)) : a._strict&&!c && a._pf.unusedTokens.push(e); | |
a._pf.charsLeftOver = i - j, h.length > 0 && a._pf.unusedInput.push(h), a._isPm && a._a[lb] < 12 && (a._a[lb] += 12), a._isPm===!1 && 12 === a._a[lb] && (a._a[lb] = 0), K(a), w(a) | |
} | |
function O(a) { | |
return a.replace(/\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g, function(a, b, c, d, e) { | |
return b || c || d || e | |
}) | |
} | |
function P(a) { | |
return a.replace(/[-\/\\^$*+?.()|[\]{}]/g, "\\$&") | |
} | |
function Q(a) { | |
var c, d, e, f, g; | |
if (0 === a._f.length) | |
return a._pf.invalidFormat=!0, a._d = new Date(0 / 0), void 0; | |
for (f = 0; f < a._f.length; f++) | |
g = 0, c = h({}, a), c._pf = b(), c._f = a._f[f], N(c), x(c) && (g += c._pf.charsLeftOver, g += 10 * c._pf.unusedTokens.length, c._pf.score = g, (null == e || e > g) && (e = g, d = c)); | |
h(a, d || c) | |
} | |
function R(a) { | |
var b, c, d = a._i, e = Mb.exec(d); | |
if (e) { | |
for (a._pf.iso=!0, b = 0, c = Ob.length; c > b; b++) | |
if (Ob[b][1].exec(d)) { | |
a._f = Ob[b][0] + (e[6] || " "); | |
break | |
} | |
for (b = 0, c = Pb.length; c > b; b++) | |
if (Pb[b][1].exec(d)) { | |
a._f += Pb[b][0]; | |
break | |
} | |
d.match(Db) && (a._f += "Z"), N(a) | |
} else | |
a._d = new Date(d) | |
} | |
function S(b) { | |
var c = b._i, d = sb.exec(c); | |
c === a ? b._d = new Date : d ? b._d = new Date( + d[1]) : "string" == typeof c ? R(b) : m(c) ? (b._a = c.slice(0), K(b)) : n(c) ? b._d = new Date( + c) : "object" == typeof c ? L(b) : b._d = new Date(c) | |
} | |
function T(a, b, c, d, e, f, g) { | |
var h = new Date(a, b, c, d, e, f, g); | |
return 1970 > a && h.setFullYear(a), h | |
} | |
function U(a) { | |
var b = new Date(Date.UTC.apply(null, arguments)); | |
return 1970 > a && b.setUTCFullYear(a), b | |
} | |
function V(a, b) { | |
if ("string" == typeof a) | |
if (isNaN(a)) { | |
if (a = b.weekdaysParse(a), "number" != typeof a) | |
return null | |
} else | |
a = parseInt(a, 10); | |
return a | |
} | |
function W(a, b, c, d, e) { | |
return e.relativeTime(b || 1, !!c, a, d) | |
} | |
function X(a, b, c) { | |
var d = hb(Math.abs(a) / 1e3), e = hb(d / 60), f = hb(e / 60), g = hb(f / 24), h = hb(g / 365), i = 45 > d && ["s", d] || 1 === e && ["m"] || 45 > e && ["mm", e] || 1 === f && ["h"] || 22 > f && ["hh", f] || 1 === g && ["d"] || 25 >= g && ["dd", g] || 45 >= g && ["M"] || 345 > g && ["MM", hb(g / 30)] || 1 === h && ["y"] || ["yy", h]; | |
return i[2] = b, i[3] = a > 0, i[4] = c, W.apply({}, i) | |
} | |
function Y(a, b, c) { | |
var d, e = c - b, f = c - a.day(); | |
return f > e && (f -= 7), e - 7 > f && (f += 7), d = db(a).add("d", f), { | |
week: Math.ceil(d.dayOfYear() / 7), | |
year: d.year() | |
} | |
} | |
function Z(a, b, c, d, e) { | |
var f, g, h = U(a, 0, 1).getUTCDay(); | |
return c = null != c ? c : e, f = e - h + (h > d ? 7 : 0) - (e > h ? 7 : 0), g = 7 * (b - 1) + (c - e) + f + 1, { | |
year: g > 0 ? a: a - 1, | |
dayOfYear: g > 0 ? g: u(a - 1) + g | |
} | |
} | |
function $(a) { | |
var b = a._i, c = a._f; | |
return null === b ? db.invalid({ | |
nullInput: !0 | |
}) : ("string" == typeof b && (a._i = b = C().preparse(b)), db.isMoment(b) ? (a = i(b), a._d = new Date( + b._d)) : c ? m(c) ? Q(a) : N(a) : S(a), new f(a)) | |
} | |
function _(a, b) { | |
db.fn[a] = db.fn[a + "s"] = function(a) { | |
var c = this._isUTC ? "UTC": ""; | |
return null != a ? (this._d["set" + c + b](a), db.updateOffset(this), this) : this._d["get" + c + b]() | |
} | |
} | |
function ab(a) { | |
db.duration.fn[a] = function() { | |
return this._data[a] | |
} | |
} | |
function bb(a, b) { | |
db.duration.fn["as" + a] = function() { | |
return + this / b | |
} | |
} | |
function cb(a) { | |
var b=!1, c = db; | |
"undefined" == typeof ender && (a ? (gb.moment = function() { | |
return !b && console && console.warn && (b=!0, console.warn("Accessing Moment through the global scope is deprecated, and will be removed in an upcoming release.")), c.apply(null, arguments) | |
}, h(gb.moment, c)) : gb.moment = db) | |
} | |
for (var db, eb, fb = "2.5.1", gb = this, hb = Math.round, ib = 0, jb = 1, kb = 2, lb = 3, mb = 4, nb = 5, ob = 6, pb = {}, qb = { | |
_isAMomentObject: null, | |
_i: null, | |
_f: null, | |
_l: null, | |
_strict: null, | |
_isUTC: null, | |
_offset: null, | |
_pf: null, | |
_lang: null | |
}, rb = "undefined" != typeof module && module.exports && "undefined" != typeof require, sb = /^\/?Date\((\-?\d+)/i, tb = /(\-)?(?:(\d*)\.)?(\d+)\:(\d+)(?:\:(\d+)\.?(\d{3})?)?/, ub = /^(-)?P(?:(?:([0-9,.]*)Y)?(?:([0-9,.]*)M)?(?:([0-9,.]*)D)?(?:T(?:([0-9,.]*)H)?(?:([0-9,.]*)M)?(?:([0-9,.]*)S)?)?|([0-9,.]*)W)$/, vb = /(\[[^\[]*\])|(\\)?(Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|YYYYYY|YYYYY|YYYY|YY|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|mm?|ss?|S{1,4}|X|zz?|ZZ?|.)/g, wb = /(\[[^\[]*\])|(\\)?(LT|LL?L?L?|l{1,4})/g, xb = /\d\d?/, yb = /\d{1,3}/, zb = /\d{1,4}/, Ab = /[+\-]?\d{1,6}/, Bb = /\d+/, Cb = /[0-9]*['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+|[\u0600-\u06FF\/]+(\s*?[\u0600-\u06FF]+){1,2}/i, Db = /Z|[\+\-]\d\d:?\d\d/gi, Eb = /T/i, Fb = /[\+\-]?\d+(\.\d{1,3})?/, Gb = /\d/, Hb = /\d\d/, Ib = /\d{3}/, Jb = /\d{4}/, Kb = /[+-]?\d{6}/, Lb = /[+-]?\d+/, Mb = /^\s*(?:[+-]\d{6}|\d{4})-(?:(\d\d-\d\d)|(W\d\d$)|(W\d\d-\d)|(\d\d\d))((T| )(\d\d(:\d\d(:\d\d(\.\d+)?)?)?)?([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?$/, Nb = "YYYY-MM-DDTHH:mm:ssZ", Ob = [["YYYYYY-MM-DD", /[+-]\d{6}-\d{2}-\d{2}/], ["YYYY-MM-DD", /\d{4}-\d{2}-\d{2}/], ["GGGG-[W]WW-E", /\d{4}-W\d{2}-\d/], ["GGGG-[W]WW", /\d{4}-W\d{2}/], ["YYYY-DDD", /\d{4}-\d{3}/]], Pb = [["HH:mm:ss.SSSS", /(T| )\d\d:\d\d:\d\d\.\d{1,3}/], ["HH:mm:ss", /(T| )\d\d:\d\d:\d\d/], ["HH:mm", /(T| )\d\d:\d\d/], ["HH", /(T| )\d\d/]], Qb = /([\+\-]|\d\d)/gi, Rb = "Date|Hours|Minutes|Seconds|Milliseconds".split("|") | |
, Sb = { | |
Milliseconds: 1, | |
Seconds: 1e3, | |
Minutes: 6e4, | |
Hours: 36e5, | |
Days: 864e5, | |
Months: 2592e6, | |
Years: 31536e6 | |
}, Tb = { | |
ms: "millisecond", | |
s: "second", | |
m: "minute", | |
h: "hour", | |
d: "day", | |
D: "date", | |
w: "week", | |
W: "isoWeek", | |
M: "month", | |
y: "year", | |
DDD: "dayOfYear", | |
e: "weekday", | |
E: "isoWeekday", | |
gg: "weekYear", | |
GG: "isoWeekYear" | |
}, Ub = { | |
dayofyear: "dayOfYear", | |
isoweekday: "isoWeekday", | |
isoweek: "isoWeek", | |
weekyear: "weekYear", | |
isoweekyear: "isoWeekYear" | |
}, Vb = {}, Wb = "DDD w W M D d".split(" "), Xb = "M D H h m s w W".split(" "), Yb = { | |
M: function() { | |
return this.month() + 1 | |
}, | |
MMM: function(a) { | |
return this.lang().monthsShort(this, a) | |
}, | |
MMMM: function(a) { | |
return this.lang().months(this, a) | |
}, | |
D: function() { | |
return this.date() | |
}, | |
DDD: function() { | |
return this.dayOfYear() | |
}, | |
d: function() { | |
return this.day() | |
}, | |
dd: function(a) { | |
return this.lang().weekdaysMin(this, a) | |
}, | |
ddd: function(a) { | |
return this.lang().weekdaysShort(this, a) | |
}, | |
dddd: function(a) { | |
return this.lang().weekdays(this, a) | |
}, | |
w: function() { | |
return this.week() | |
}, | |
W: function() { | |
return this.isoWeek() | |
}, | |
YY: function() { | |
return k(this.year()%100, 2) | |
}, | |
YYYY: function() { | |
return k(this.year(), 4) | |
}, | |
YYYYY: function() { | |
return k(this.year(), 5) | |
}, | |
YYYYYY: function() { | |
var a = this.year(), b = a >= 0 ? "+": "-"; | |
return b + k(Math.abs(a), 6) | |
}, | |
gg: function() { | |
return k(this.weekYear()%100, 2) | |
}, | |
gggg: function() { | |
return k(this.weekYear(), 4) | |
}, | |
ggggg: function() { | |
return k(this.weekYear(), 5) | |
}, | |
GG: function() { | |
return k(this.isoWeekYear()%100, 2) | |
}, | |
GGGG: function() { | |
return k(this.isoWeekYear(), 4) | |
}, | |
GGGGG: function() { | |
return k(this.isoWeekYear(), 5) | |
}, | |
e: function() { | |
return this.weekday() | |
}, | |
E: function() { | |
return this.isoWeekday() | |
}, | |
a: function() { | |
return this.lang().meridiem(this.hours(), this.minutes(), !0) | |
}, | |
A: function() { | |
return this.lang().meridiem(this.hours(), this.minutes(), !1) | |
}, | |
H: function() { | |
return this.hours() | |
}, | |
h: function() { | |
return this.hours()%12 || 12 | |
}, | |
m: function() { | |
return this.minutes() | |
}, | |
s: function() { | |
return this.seconds() | |
}, | |
S: function() { | |
return s(this.milliseconds() / 100) | |
}, | |
SS: function() { | |
return k(s(this.milliseconds() / 10), 2) | |
}, | |
SSS: function() { | |
return k(this.milliseconds(), 3) | |
}, | |
SSSS: function() { | |
return k(this.milliseconds(), 3) | |
}, | |
Z: function() { | |
var a =- this.zone(), b = "+"; | |
return 0 > a && (a =- a, b = "-"), b + k(s(a / 60), 2) + ":" + k(s(a)%60, 2) | |
}, | |
ZZ: function() { | |
var a =- this.zone(), b = "+"; | |
return 0 > a && (a =- a, b = "-"), b + k(s(a / 60), 2) + k(s(a)%60, 2) | |
}, | |
z: function() { | |
return this.zoneAbbr() | |
}, | |
zz: function() { | |
return this.zoneName() | |
}, | |
X: function() { | |
return this.unix() | |
}, | |
Q: function() { | |
return this.quarter() | |
} | |
}, Zb = ["months", "monthsShort", "weekdays", "weekdaysShort", "weekdaysMin"]; | |
Wb.length; | |
)eb = Wb.pop(), Yb[eb + "o"] = d(Yb[eb], eb); | |
for (; Xb.length;) | |
eb = Xb.pop(), Yb[eb + eb] = c(Yb[eb], 2); | |
for (Yb.DDDD = c(Yb.DDD, 3), h(e.prototype, { | |
set: function(a) { | |
var b, c; | |
for (c in a) | |
b = a[c], "function" == typeof b ? this[c] = b : this["_" + c] = b | |
}, | |
_months: "January_February_March_April_May_June_July_August_September_October_November_December".split("_"), | |
months: function(a) { | |
return this._months[a.month()] | |
}, | |
_monthsShort: "Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec".split("_"), | |
monthsShort: function(a) { | |
return this._monthsShort[a.month()] | |
}, | |
monthsParse: function(a) { | |
var b, c, d; | |
for (this._monthsParse || (this._monthsParse = []), b = 0; 12 > b; b++) | |
if (this._monthsParse[b] || (c = db.utc([2e3, b]), d = "^" + this.months(c, "") + "|^" + this.monthsShort(c, ""), this._monthsParse[b] = new RegExp(d.replace(".", ""), "i")), this._monthsParse[b].test(a)) | |
return b | |
}, | |
_weekdays: "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), | |
weekdays: function(a) { | |
return this._weekdays[a.day()] | |
}, | |
_weekdaysShort: "Sun_Mon_Tue_Wed_Thu_Fri_Sat".split("_"), | |
weekdaysShort: function(a) { | |
return this._weekdaysShort[a.day()] | |
}, | |
_weekdaysMin: "Su_Mo_Tu_We_Th_Fr_Sa".split("_"), | |
weekdaysMin: function(a) { | |
return this._weekdaysMin[a.day()] | |
}, | |
weekdaysParse: function(a) { | |
var b, c, d; | |
for (this._weekdaysParse || (this._weekdaysParse = []), b = 0; 7 > b; b++) | |
if (this._weekdaysParse[b] || (c = db([2e3, 1]).day(b), d = "^" + this.weekdays(c, "") + "|^" + this.weekdaysShort(c, "") + "|^" + this.weekdaysMin(c, ""), this._weekdaysParse[b] = new RegExp(d.replace(".", ""), "i")), this._weekdaysParse[b].test(a)) | |
return b | |
}, | |
_longDateFormat: { | |
LT: "h:mm A", | |
L: "MM/DD/YYYY", | |
LL: "MMMM D YYYY", | |
LLL: "MMMM D YYYY LT", | |
LLLL: "dddd, MMMM D YYYY LT" | |
}, | |
longDateFormat: function(a) { | |
var b = this._longDateFormat[a]; | |
return !b && this._longDateFormat[a.toUpperCase()] && (b = this._longDateFormat[a.toUpperCase()].replace(/MMMM|MM|DD|dddd/g, function(a) { | |
return a.slice(1) | |
}), this._longDateFormat[a] = b), b | |
}, | |
isPM: function(a) { | |
return "p" === (a + "").toLowerCase().charAt(0) | |
}, | |
_meridiemParse: /[ap]\.?m?\.?/i, | |
meridiem: function(a, b, c) { | |
return a > 11 ? c ? "pm" : "PM" : c ? "am" : "AM" | |
}, | |
_calendar: { | |
sameDay: "[Today at] LT", | |
nextDay: "[Tomorrow at] LT", | |
nextWeek: "dddd [at] LT", | |
lastDay: "[Yesterday at] LT", | |
lastWeek: "[Last] dddd [at] LT", | |
sameElse: "L" | |
}, | |
calendar: function(a, b) { | |
var c = this._calendar[a]; | |
return "function" == typeof c ? c.apply(b) : c | |
}, | |
_relativeTime: { | |
future: "in %s", | |
past: "%s ago", | |
s: "a few seconds", | |
m: "a minute", | |
mm: "%d minutes", | |
h: "an hour", | |
hh: "%d hours", | |
d: "a day", | |
dd: "%d days", | |
M: "a month", | |
MM: "%d months", | |
y: "a year", | |
yy: "%d years" | |
}, | |
relativeTime: function(a, b, c, d) { | |
var e = this._relativeTime[c]; | |
return "function" == typeof e ? e(a, b, c, d) : e.replace(/%d/i, a) | |
}, | |
pastFuture: function(a, b) { | |
var c = this._relativeTime[a > 0 ? "future": "past"]; | |
return "function" == typeof c ? c(b) : c.replace(/%s/i, b) | |
}, | |
ordinal: function(a) { | |
return this._ordinal.replace("%d", a) | |
}, | |
_ordinal: "%d", | |
preparse: function(a) { | |
return a | |
}, | |
postformat: function(a) { | |
return a | |
}, | |
week: function(a) { | |
return Y(a, this._week.dow, this._week.doy).week | |
}, | |
_week: { | |
dow: 0, | |
doy: 6 | |
}, | |
_invalidDate: "Invalid date", | |
invalidDate: function() { | |
return this._invalidDate | |
} | |
}), db = function(c, d, e, f) { | |
var g; | |
return "boolean" == typeof e && (f = e, e = a), g = {}, g._isAMomentObject=!0, g._i = c, g._f = d, g._l = e, g._strict = f, g._isUTC=!1, g._pf = b(), $(g) | |
}, db.utc = function(c, d, e, f) { | |
var g; | |
return "boolean" == typeof e && (f = e, e = a), g = {}, g._isAMomentObject=!0, g._useUTC=!0, g._isUTC=!0, g._l = e, g._i = c, g._f = d, g._strict = f, g._pf = b(), $(g).utc() | |
}, db.unix = function(a) { | |
return db(1e3 * a) | |
}, db.duration = function(a, b) { | |
var c, d, e, f = a, h = null; | |
return db.isDuration(a) ? f = { | |
ms: a._milliseconds, | |
d: a._days, | |
M: a._months | |
} : "number" == typeof a ? (f = {}, b ? f[b] = a : f.milliseconds = a) : (h = tb.exec(a)) ? (c = "-" === h[1]?-1 : 1, f = { | |
y : 0, d : s(h[kb]) * c, h : s(h[lb]) * c, m : s(h[mb]) * c, s : s(h[nb]) * c, ms : s(h[ob]) * c | |
}) | |
: (h = ub.exec(a)) && (c = "-" === h[1]?-1 : 1, e = function(a) { | |
var b = a && parseFloat(a.replace(",", ".")); | |
return (isNaN(b) ? 0 : b) * c | |
}, f = { | |
y: e(h[2]), | |
M: e(h[3]), | |
d: e(h[4]), | |
h: e(h[5]), | |
m: e(h[6]), | |
s: e(h[7]), | |
w: e(h[8]) | |
}), d = new g(f), db.isDuration(a) && a.hasOwnProperty("_lang") && (d._lang = a._lang), d | |
}, db.version = fb, db.defaultFormat = Nb, db.updateOffset = function() {}, db.lang = function(a, b) { | |
var c; | |
return a ? (b ? A(y(a), b) : null === b ? (B(a), a = "en") : pb[a] || C(a), c = db.duration.fn._lang = db.fn._lang = C(a), c._abbr) : db.fn._lang._abbr | |
}, db.langData = function(a) { | |
return a && a._lang && a._lang._abbr && (a = a._lang._abbr), C(a) | |
}, db.isMoment = function(a) { | |
return a instanceof f || null != a && a.hasOwnProperty("_isAMomentObject") | |
}, db.isDuration = function(a) { | |
return a instanceof g | |
}, eb = Zb.length - 1; eb >= 0; --eb)r(Zb[eb]); | |
for (db.normalizeUnits = function(a) { | |
return p(a) | |
}, db.invalid = function(a) { | |
var b = db.utc(0 / 0); | |
return null != a ? h(b._pf, a) : b._pf.userInvalidated=!0, b | |
}, db.parseZone = function(a) { | |
return db(a).parseZone() | |
}, h(db.fn = f.prototype, { | |
clone: function() { | |
return db(this) | |
}, | |
valueOf: function() { | |
return + this._d + 6e4 * (this._offset || 0) | |
}, | |
unix: function() { | |
return Math.floor( + this / 1e3) | |
}, | |
toString: function() { | |
return this.clone().lang("en").format("ddd MMM DD YYYY HH:mm:ss [GMT]ZZ") | |
}, | |
toDate: function() { | |
return this._offset ? new Date( + this) : this._d | |
}, | |
toISOString: function() { | |
var a = db(this).utc(); | |
return 0 < a.year() && a.year() <= 9999 ? F(a, "YYYY-MM-DD[T]HH:mm:ss.SSS[Z]") : F(a, "YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]") | |
}, | |
toArray: function() { | |
var a = this; | |
return [a.year(), a.month(), a.date(), a.hours(), a.minutes(), a.seconds(), a.milliseconds()] | |
}, | |
isValid: function() { | |
return x(this) | |
}, | |
isDSTShifted: function() { | |
return this._a ? this.isValid() && o(this._a, (this._isUTC ? db.utc(this._a) : db(this._a)).toArray()) > 0 : !1 | |
}, | |
parsingFlags: function() { | |
return h({}, this._pf) | |
}, | |
invalidAt: function() { | |
return this._pf.overflow | |
}, | |
utc: function() { | |
return this.zone(0) | |
}, | |
local: function() { | |
return this.zone(0), this._isUTC=!1, this | |
}, | |
format: function(a) { | |
var b = F(this, a || db.defaultFormat); | |
return this.lang().postformat(b) | |
}, | |
add: function(a, b) { | |
var c; | |
return c = "string" == typeof a ? db.duration( + b, a) : db.duration(a, b), l(this, c, 1), this | |
}, | |
subtract: function(a, b) { | |
var c; | |
return c = "string" == typeof a ? db.duration( + b, a) : db.duration(a, b), l(this, c, - 1), this | |
}, | |
diff: function(a, b, c) { | |
var d, e, f = z(a, this), g = 6e4 * (this.zone() - f.zone()); | |
return b = p(b), "year" === b || "month" === b ? (d = 432e5 * (this.daysInMonth() + f.daysInMonth()), e = 12 * (this.year() - f.year()) + (this.month() - f.month()), e += (this - db(this).startOf("month") - (f - db(f).startOf("month"))) / d, e -= 6e4 * (this.zone() - db(this).startOf("month").zone() - (f.zone() - db(f).startOf("month").zone())) / d, "year" === b && (e/=12)) : (d = this - f, e = "second" === b ? d / 1e3 : "minute" === b ? d / 6e4 : "hour" === b ? d / 36e5 : "day" === b ? (d - g) / 864e5 : "week" === b ? (d - g) / 6048e5 : d), c ? e : j(e) | |
}, | |
from: function(a, b) { | |
return db.duration(this.diff(a)).lang(this.lang()._abbr).humanize(!b) | |
}, | |
fromNow: function(a) { | |
return this.from(db(), a) | |
}, | |
calendar: function() { | |
var a = z(db(), this).startOf("day"), b = this.diff(a, "days", !0), c =- 6 > b ? "sameElse" : - 1 > b ? "lastWeek" : 0 > b ? "lastDay" : 1 > b ? "sameDay" : 2 > b ? "nextDay" : 7 > b ? "nextWeek" : "sameElse"; | |
return this.format(this.lang().calendar(c, this)) | |
}, | |
isLeapYear: function() { | |
return v(this.year()) | |
}, | |
isDST: function() { | |
return this.zone() < this.clone().month(0).zone() || this.zone() < this.clone().month(5).zone() | |
}, | |
day: function(a) { | |
var b = this._isUTC ? this._d.getUTCDay(): this._d.getDay(); | |
return null != a ? (a = V(a, this.lang()), this.add({ | |
d: a - b | |
})) : b | |
}, | |
month: function(a) { | |
var b, c = this._isUTC ? "UTC": ""; | |
return null != a ? "string" == typeof a && (a = this.lang().monthsParse(a), "number" != typeof a) ? this : (b = this.date(), this.date(1), this._d["set" + c + "Month"](a), this.date(Math.min(b, this.daysInMonth())), db.updateOffset(this), this) : this._d["get" + c + "Month"]() | |
}, | |
startOf: function(a) { | |
switch (a = p(a)) { | |
case"year": | |
this.month(0); | |
case"month": | |
this.date(1); | |
case"week": | |
case"isoWeek": | |
case"day": | |
this.hours(0); | |
case"hour": | |
this.minutes(0); | |
case"minute": | |
this.seconds(0); | |
case"second": | |
this.milliseconds(0) | |
} | |
return "week" === a ? this.weekday(0) : "isoWeek" === a && this.isoWeekday(1), this | |
}, | |
endOf: function(a) { | |
return a = p(a), this.startOf(a).add("isoWeek" === a ? "week" : a, 1).subtract("ms", 1) | |
}, | |
isAfter: function(a, b) { | |
return b = "undefined" != typeof b ? b : "millisecond", + this.clone().startOf(b)>+db(a).startOf(b) | |
}, | |
isBefore: function(a, b) { | |
return b = "undefined" != typeof b ? b : "millisecond", + this.clone().startOf(b)<+db(a).startOf(b) | |
}, | |
isSame: function(a, b) { | |
return b = b || "ms", + this.clone().startOf(b) ===+ z(a, this).startOf(b) | |
}, | |
min: function(a) { | |
return a = db.apply(null, arguments), this > a ? this : a | |
}, | |
max: function(a) { | |
return a = db.apply(null, arguments), a > this ? this : a | |
}, | |
zone: function(a) { | |
var b = this._offset || 0; | |
return null == a ? this._isUTC ? b : this._d.getTimezoneOffset() : ("string" == typeof a && (a = I(a)), Math.abs(a) < 16 && (a = 60 * a), this._offset = a, this._isUTC=!0, b !== a && l(this, db.duration(b - a, "m"), 1, !0), this) | |
}, | |
zoneAbbr: function() { | |
return this._isUTC ? "UTC" : "" | |
}, | |
zoneName: function() { | |
return this._isUTC ? "Coordinated Universal Time" : "" | |
}, | |
parseZone: function() { | |
return this._tzm ? this.zone(this._tzm) : "string" == typeof this._i && this.zone(this._i), this | |
}, | |
hasAlignedHourOffset: function(a) { | |
return a = a ? db(a).zone() : 0, (this.zone() - a)%60 === 0 | |
}, | |
daysInMonth: function() { | |
return t(this.year(), this.month()) | |
}, | |
dayOfYear: function(a) { | |
var b = hb((db(this).startOf("day") - db(this).startOf("year")) / 864e5) + 1; | |
return null == a ? b : this.add("d", a - b) | |
}, | |
quarter: function() { | |
return Math.ceil((this.month() + 1) / 3) | |
}, | |
weekYear: function(a) { | |
var b = Y(this, this.lang()._week.dow, this.lang()._week.doy).year; | |
return null == a ? b : this.add("y", a - b) | |
}, | |
isoWeekYear: function(a) { | |
var b = Y(this, 1, 4).year; | |
return null == a ? b : this.add("y", a - b) | |
}, | |
week: function(a) { | |
var b = this.lang().week(this); | |
return null == a ? b : this.add("d", 7 * (a - b)) | |
}, | |
isoWeek: function(a) { | |
var b = Y(this, 1, 4).week; | |
return null == a ? b : this.add("d", 7 * (a - b)) | |
}, | |
weekday: function(a) { | |
var b = (this.day() + 7 - this.lang()._week.dow)%7; | |
return null == a ? b : this.add("d", a - b) | |
}, | |
isoWeekday: function(a) { | |
return null == a ? this.day() || 7 : this.day(this.day()%7 ? a : a - 7) | |
}, | |
get: function(a) { | |
return a = p(a), this[a]() | |
}, | |
set: function(a, b) { | |
return a = p(a), "function" == typeof this[a] && this[a](b), this | |
}, | |
lang: function(b) { | |
return b === a ? this._lang : (this._lang = C(b), this) | |
} | |
}), eb = 0; eb < Rb.length; eb++) | |
_(Rb[eb].toLowerCase().replace(/s$/, ""), Rb[eb]); | |
_("year", "FullYear"), db.fn.days = db.fn.day, db.fn.months = db.fn.month, db.fn.weeks = db.fn.week, db.fn.isoWeeks = db.fn.isoWeek, db.fn.toJSON = db.fn.toISOString, h(db.duration.fn = g.prototype, { | |
_bubble: function() { | |
var a, b, c, d, e = this._milliseconds, f = this._days, g = this._months, h = this._data; | |
h.milliseconds = e%1e3, a = j(e / 1e3), h.seconds = a%60, b = j(a / 60), h.minutes = b%60, c = j(b / 60), h.hours = c%24, f += j(c / 24), h.days = f%30, g += j(f / 30), h.months = g%12, d = j(g / 12), h.years = d | |
}, | |
weeks: function() { | |
return j(this.days() / 7) | |
}, | |
valueOf: function() { | |
return this._milliseconds + 864e5 * this._days + this._months%12 * 2592e6 + 31536e6 * s(this._months / 12) | |
}, | |
humanize: function(a) { | |
var b =+ this, c = X(b, !a, this.lang()); | |
return a && (c = this.lang().pastFuture(b, c)), this.lang().postformat(c) | |
}, | |
add: function(a, b) { | |
var c = db.duration(a, b); | |
return this._milliseconds += c._milliseconds, this._days += c._days, this._months += c._months, this._bubble(), this | |
}, | |
subtract: function(a, b) { | |
var c = db.duration(a, b); | |
return this._milliseconds -= c._milliseconds, this._days -= c._days, this._months -= c._months, this._bubble(), this | |
}, | |
get: function(a) { | |
return a = p(a), this[a.toLowerCase() + "s"]() | |
}, | |
as: function(a) { | |
return a = p(a), this["as" + a.charAt(0).toUpperCase() + a.slice(1) + "s"]() | |
}, | |
lang: db.fn.lang, | |
toIsoString: function() { | |
var a = Math.abs(this.years()), b = Math.abs(this.months()), c = Math.abs(this.days()), d = Math.abs(this.hours()), e = Math.abs(this.minutes()), f = Math.abs(this.seconds() + this.milliseconds() / 1e3); | |
return this.asSeconds() ? (this.asSeconds() < 0 ? "-" : "") + "P" + (a ? a + "Y" : "") + (b ? b + "M" : "") + (c ? c + "D" : "") + (d || e || f ? "T" : "") + (d ? d + "H" : "") + (e ? e + "M" : "") + (f ? f + "S" : "") : "P0D" | |
} | |
}); | |
for (eb in Sb) | |
Sb.hasOwnProperty(eb) && (bb(eb, Sb[eb]), ab(eb.toLowerCase())); | |
bb("Weeks", 6048e5), db.duration.fn.asMonths = function() { | |
return ( + this - 31536e6 * this.years()) / 2592e6 + 12 * this.years() | |
}, db.lang("en", { | |
ordinal: function(a) { | |
var b = a%10, c = 1 === s(a%100 / 10) ? "th": 1 === b ? "st": 2 === b ? "nd": 3 === b ? "rd": "th"; | |
return a + c | |
} | |
}), rb ? (module.exports = db, cb(!0)) : "function" == typeof define && define.amd ? define("moment", function(b, c, d) { | |
return d.config && d.config() && d.config().noGlobal!==!0 && cb(d.config().noGlobal === a), db | |
}) : cb() | |
}).call(this); | |
/* ================ | |
* | |
* Videoz | |
* | |
* =============== */ | |
var PRPLVideo = function (customization) { | |
var custom = customization; | |
// generated html example | |
// <video id="" class="" preload="preload" poster="" autoplay="true" loop="true" muted="true"> | |
// <source src="skin/frontend/videri/default/videos/Home_2.mp4" type="video/mp4; codecs="avc1.42E01E, mp4a.40.2""> | |
// <source src="skin/frontend/videri/default/videos/Home_2.webmhd.webm" type="video/webm;"> | |
// </video> | |
var $videos = $('[data-video="true"]'); | |
// console.log($videos) | |
if ($videos.length > 0) { | |
for (var i = $videos.length - 1; | |
i >= 0; | |
i--) { | |
//get data | |
var $video = $($videos[i]); | |
var $videoParent = $video.parent(); //appendTo later; | |
var videoData = (typeof $video.data() !== 'undefined') ? $video.data() : false;; | |
var videoID = (typeof $video.attr('id') !== 'undefined') ? $video.attr('id') : 'video' + i; //generated id fallback | |
var videoClasses = (typeof $video.attr('class') !== 'undefined') ? $video.attr('class') : ''; //add default html classes? | |
//use supplied or defaults | |
var v = {}; | |
v.autoplay = (typeof videoData.videoAutoplay !== 'undefined') ? videoData.videoAutoplay : true; | |
v.loop = (typeof videoData.videoLoop !== 'undefined') ? videoData.videoLoop : false; | |
v.muted = (typeof videoData.videoMuted !== 'undefined') ? videoData.videoMuted : false; | |
v.poster = (typeof videoData.videoPoster !== 'undefined') ? videoData.videoPoster : ''; | |
v.preload = (typeof videoData.videoPreload !== 'undefined') ? videoData.videoPreload : false; | |
// defaults set above | |
v.htmlClasses = videoClasses; | |
v.htmlID = videoID; | |
// build html | |
var el = ''; | |
if (!Modernizr.touch) { | |
// video element | |
el += '<video id="' + v.htmlID + '" class="' + v.htmlClasses + '" '; | |
// autoplay="' + v.autoplay + '" loop="' + v.loop + '" muted="' + v.muted + '" poster="' + v.poster + '" preload="' + v.preload + '">'; | |
if (v.autoplay !== false) { | |
el += 'autoplay="' + v.autoplay + '" '; | |
} | |
if (v.loop !== false) { | |
el += 'loop="' + v.loop + '" '; | |
} | |
if (v.muted !== false) { | |
el += 'muted="' + v.muted + '" '; | |
} | |
if (v.poster !== false && v.poster !== '') { | |
el += 'poster="' + v.poster + '" '; | |
} | |
if (v.preload !== false) { | |
el += 'preload="' + v.preload + '" '; | |
} | |
el += '>'; | |
// video sources | |
var $sources = $($videos[i]).find('[data-video-source]'); | |
for (var j = $sources.length - 1; j >= 0; j--) { | |
var sourceData = $($sources[j]).data(); | |
// console.log('Video Source Data: ', sourceData); | |
if (typeof sourceData !== 'undefined') { | |
var s = {}; | |
s.src = (typeof sourceData.videoSource !== 'undefined') ? sourceData.videoSource : ''; | |
s.type = (typeof sourceData.videoType !== 'undefined') ? sourceData.videoType : ''; | |
el += '<source src="' + s.src + '" type="' + s.type + '" />'; | |
} | |
}; | |
el += '</video>'; | |
} | |
// video css overlay | |
var $overlays = $($videos[i]).find('[data-video-overlay]'); | |
for (var k = $overlays.length - 1; k >= 0; k--) { | |
var overlayData = $($overlays[k]).data(); | |
if (typeof overlayData !== 'undefined') { | |
var o = {}; | |
o.color = (typeof overlayData.videoOverlayColor !== 'undefined') ? overlayData.videoOverlayColor : ''; | |
o.opacity = (typeof overlayData.videoOverlayOpacity !== 'undefined') ? overlayData.videoOverlayOpacity : 0.25; | |
el += '<div class="color-overlay ' + o.color + '" style="opacity:' + o.opacity + ';"></div>'; | |
} | |
}; | |
// add generated video tag, remove data divs | |
$videoParent.prepend(el); | |
$video.remove(); | |
}; | |
} | |
}; | |
var CoverVideo = function() { | |
var min_w = 320; // minimum video width allowed | |
var vid_w_orig; // original video dimensions | |
var vid_h_orig; | |
var jWin = $(window); | |
var jVidContainer = $('.cover-video'); | |
var jVideo = $('#homepageVideo'); | |
vid_w_orig = parseInt(jVideo.attr('width')); | |
vid_h_orig = parseInt(jVideo.attr('height')); | |
function resizeToCover() { | |
jWin = $(window); | |
// set the video viewport to the window size | |
jVidContainer.width(jWin.width()); | |
jVidContainer.height(jWin.height()); | |
// use largest scale factor of horizontal/vertical | |
var scale_h = jWin.width() / vid_w_orig; | |
var scale_v = jWin.height() / vid_h_orig; | |
var scale = scale_h > scale_v ? scale_h : scale_v; | |
// don't allow scaled width < minimum video width | |
if (scale * vid_w_orig < min_w) { | |
scale = min_w / vid_w_orig; | |
}; | |
// now scale the video | |
if ($('#hero').height() < scale * vid_h_orig) { | |
jVideo.width(scale * vid_w_orig); | |
jVideo.height(scale * vid_h_orig); | |
// and center it by scrolling the video viewport | |
jVidContainer.scrollLeft((jVideo.width() - jWin.width()) / 2); | |
jVidContainer.scrollTop((jVideo.height() - jWin.height()) / 2); | |
} | |
}; | |
jQuery(window).resize(function () { | |
resizeToCover(); | |
}); | |
jQuery(window).trigger('resize'); | |
} | |
/* Viewport Helper 2 [its there if you need it] | |
* | |
* viewport = { | |
* width: 'window window' | |
* height: 'window height' | |
* top: 'scrollTop value' | |
* } | |
* | |
* jquery and jquery throttle/debounce required see | |
* http://benalman.com/projects/jquery-throttle-debounce-plugin/ for more | |
* information, debounce included in scripts/lib/jquery.plugins.js | |
* | |
========================================= */ | |
var PRPLView = function( params ) { | |
self = this; | |
var jqWin = $(window); | |
var jsBody = $('body'); | |
var _construct = function() { | |
self.width = jqWin.width(); | |
self.height = jqWin.height(); | |
self.scrollTop = jqWin.scrollTop(); | |
jqWin.on({ | |
scroll: function(e) { | |
scrollHandler(e); | |
}, | |
resize: function(e) { | |
resizeHandler(e); | |
} | |
}) | |
} | |
var scrollHandler = function(e) { | |
self.scrollTop = $(e.currentTarget).scrollTop(); | |
trigger('vpScroll', self.scrollTop); | |
} | |
var resizeHandler = function(e) { | |
setWidth($(e.currentTarget).width()); | |
setHeight($(e.currentTarget).height()); | |
} | |
var setWidth = function(newWidth) { | |
if (typeof newWidth === 'undefined' || newWidth === self.width) { | |
return false; | |
} | |
self.width = newWidth; | |
trigger('vpWidth', self.width); | |
} | |
var setHeight = function(newHeight) { | |
if (typeof newHeight === 'undefined' || newHeight === self.height) { | |
return false; | |
} | |
self.height = newHeight; | |
trigger('vpHeight', self.height); | |
} | |
// trigger jq events | |
var trigger = function(what, data) { | |
if (typeof what === 'undefined') { | |
return false; | |
} | |
if (typeof data === 'undefined') { | |
$(self).trigger(what); | |
} else { | |
$(self).trigger(what, data); | |
} | |
return true; | |
}; | |
_construct(); | |
} | |
/* Viewport Helper [its there if you need it] | |
* | |
* viewport = { | |
* width: '...' | |
* height: 'window height' | |
* domheight: 'document height' | |
* breakpoint: 'active breakpoint' | |
* top: 'scrollTop value' | |
* params: 'user provided object' | |
* } | |
* | |
* jquery and jquery throttle/debounce required | |
* ^ see › http://benalman.com/projects/jquery-throttle-debounce-plugin/ | |
* | |
========================================= */ | |
var PRPLViewport = function(opts) { | |
var $ = jQuery; | |
if (typeof $ === 'undefined') { | |
console.log('jQuery required'); | |
return false; | |
} else {} | |
/* ================ | |
* | |
* Variables | |
* | |
* =============== */ | |
var _class = this; | |
//public vars | |
// _class.params = (opts) ? opts : false; | |
// _class.waypoints = (opts.waypoints !== undefined)) ? opts.waypoints : false; | |
_class.top = undefined; | |
_class.breakpoint = undefined; | |
_class.width = undefined; | |
_class.height = undefined; | |
_class.domheight = undefined; | |
//private vars | |
var devmode = true; | |
var scrollRefreshTimer; | |
var breakpoints = { | |
'xs': 300, | |
'sm': 540, | |
'md': 768, | |
'lg': 960, | |
'xl': 1280, | |
'xxl': 1440 | |
}; | |
//cached selectors | |
var $win = $(window); | |
var $wrap = $('.site-wrap'); | |
/* ================ | |
* | |
* Constructor | |
* | |
* =============== */ | |
var init = function() { | |
addWindowVars(); | |
addWindowEvents(); | |
setRemainingValues(); | |
// console.log('add get url slug fn from HP'); | |
return _class; | |
}; | |
/* ================ | |
* | |
* Public Methods | |
* | |
* =============== */ | |
_class.get = function() { | |
return { | |
width : _class.width, | |
height : _class.height, | |
top: _class.top, | |
breakpoint: _class.breakpoint, | |
domheight: _class.domheight, | |
params: _class.params | |
}; | |
}; | |
_class.getWindowSize = function() { | |
// $win = $(window); | |
return { | |
width : _class.width, | |
height : _class.height | |
}; | |
}; | |
_class.getHeight = function() { | |
return _class.height; | |
} | |
_class.getWidth = function() { | |
return _class.width; | |
} | |
_class.getScrollTop = function() { | |
return _class.top; | |
}; | |
_class.getBreakpoint = function() { | |
return _class.breakpoint; | |
}; | |
// _class.addWaypoints = function(arr){ | |
// if(typeof arr === 'undefined' || arr.length < 1){ return false; } | |
// var waypoints = arr; | |
// for (var i = waypoints.length - 1; i >= 0; i--) { | |
// console.log(waypoints[i]); | |
// }; | |
// } | |
/* ================ | |
* | |
* Private Fn's | |
* | |
* =============== */ | |
// dom height etc. | |
var setRemainingValues = function() { | |
_class.domheight = $wrap.height(); | |
}; | |
// set public window vars | |
var addWindowVars = function() { | |
_class.width = $win.width(); | |
_class.height = $win.height(); | |
}; | |
// add window events | |
var addWindowEvents = function() { | |
// defined in plugins.js | |
// deBouncer(jQuery,'smartresize', 'resize', 100); | |
// deBouncer(jQuery,'smartscroll', 'scroll', 100); | |
// throttled event handlers | |
// $win.smartresize(function(e){ onWindowSmartResize(e); }); | |
// $win.smartscroll(function(e){ onWindowSmartScroll(e); }); | |
$win.resize(function(e) { | |
onWindowResize(e); | |
}); | |
$win.scroll(function(e) { | |
onWindowScroll(e); | |
}); | |
// trigger an inital scroll and resize evt | |
$win.scroll(); | |
$win.resize(); | |
}; | |
var onWindowResize = function(e) { | |
if (typeof e === 'undefined') { | |
return false; | |
} | |
// console.log('rageresize'); | |
setHeight($win.height()); | |
var $e = $(e.currentTarget); | |
if ($e.height() !== _class.height) { | |
setHeight($e.height()) | |
}; | |
if ($e.width() !== _class.width) { | |
setWidth($e.width()) | |
}; | |
setBreakpoint($e.width()); | |
trigger('vp_resize', e); | |
}; | |
var previousScrollPos = 0; | |
var scrollDirection = 'down'; | |
var onWindowScroll = function(e) { | |
if (typeof e === 'undefined') { | |
return false; | |
} | |
// console.log('ragescroll'); | |
var $e = $(e.currentTarget)[0]; | |
var distanceTop = $e.scrollY; | |
// if(distanceTop > previousScrollPos){ | |
// scrollDirection = 'down'; | |
// }else{ | |
// scrollDirection = 'up'; | |
// } | |
previousScrollPos = distanceTop; | |
setScrollTop(distanceTop); | |
trigger('vp_scroll', e); | |
if (typeof _class.waypoints !== 'undefined' && $('body').hasClass('homepage')) { | |
if (_class.waypoints !== false && _class.waypoints.length > 0) { | |
// console.log(_class.waypoints); | |
var found = false; | |
var wps = _class.waypoints; | |
// if(scrollDirection === 'up'){ wps.reverse() } | |
for (var i = wps.length - 1; i >= 0; i--) { | |
var wp = wps[i]; | |
var waypointTop = $(wp.selector).offset().top - 40; | |
if (distanceTop >= waypointTop) { | |
if (!found) { | |
trigger('vp_waypoint', wp); | |
// trigger('vp_waypoint_'+wp.name, wp); | |
found = true; | |
} | |
} | |
}; | |
} | |
} | |
}; | |
var onWindowSmartResize = function(e) { | |
if (typeof e === 'undefined') { | |
return false; | |
} | |
// set _class.width after resize | |
var $e = $(e.currentTarget); | |
if ($e.height() !== _class.height) { | |
setHeight($e.height()) | |
}; | |
if ($e.width() !== _class.width) { | |
setWidth($e.width()) | |
}; | |
setBreakpoint($e.width()); | |
trigger('vp_smartresize', e); | |
}; | |
var onWindowSmartScroll = function(e) { | |
if (typeof e === 'undefined') { | |
return false; | |
} | |
// set _class.top after scrolling | |
var $e = $(e.currentTarget)[0]; | |
setScrollTop($e.scrollY); | |
// console.log($e.scrollY, $e.screenY, $e.pageYOffset); // test values | |
trigger('vp_smartscroll', e); | |
}; | |
// like it says on the tin | |
var setHeight = function(h) { | |
if (typeof h === 'undefined') { | |
return false; | |
} | |
_class.height = h; | |
trigger('vp_height', h); | |
return true; | |
}; | |
var setWidth = function(w) { | |
if (typeof w === 'undefined') { | |
return false; | |
} | |
_class.width = w; | |
trigger('vp_width', w); | |
return true; | |
}; | |
// set the scroll top value (on debounced scroll) | |
var setScrollTop = function(top) { | |
if (typeof top === 'number') { | |
if (top < 0) { | |
if (top < - 70) {} else if (top < - 20) { | |
// if(devmode){console.log('this would be a good place to implement a refresh timer');} | |
} else {} | |
} | |
_class.top = top; | |
trigger('vp_scrolltop', top); | |
return true; | |
} else { | |
return false; | |
} | |
}; | |
// set breakpoint (on debounced resize) | |
var setBreakpoint = function(width) { | |
if (typeof width === 'number' && width > 0) { | |
_class.width = width; | |
var prev = _class.breakpoint; | |
if (_class.width > 0 && _class.width <= breakpoints.xs) { | |
_class.breakpoint = 'xxs'; | |
} else if (_class.width > breakpoints.xs && _class.width <= breakpoints.sm) { | |
_class.breakpoint = 'xs'; | |
} else if (_class.width > breakpoints.sm && _class.width <= breakpoints.md) { | |
_class.breakpoint = 'sm'; | |
} else if (_class.width > breakpoints.md && _class.width <= breakpoints.lg) { | |
_class.breakpoint = 'md'; | |
} else if (_class.width > breakpoints.lg && _class.width <= breakpoints.xl) { | |
_class.breakpoint = 'lg'; | |
} else if (_class.width > breakpoints.xl && _class.width <= breakpoints.xxl) { | |
_class.breakpoint = 'xl'; | |
} else if (_class.width > breakpoints.xxl) { | |
_class.breakpoint = 'xxl'; | |
} | |
if (prev !== _class.breakpoint) { | |
trigger('vp_breakpoint', _class.breakpoint); | |
return true; | |
} else { | |
return false; | |
} | |
} else { | |
return false; | |
} | |
}; | |
// trigger jq events | |
var trigger = function(what, data) { | |
if (typeof what === 'undefined') { | |
return false; | |
} | |
if (typeof data === 'undefined') { | |
$(_class).trigger(what); | |
} else { | |
$(_class).trigger(what, data); | |
} | |
return true; | |
}; | |
//class hack | |
return init(); | |
}; | |
/** | |
* Copyright (C) 2013 by Matias Niemela | |
* | |
* Permission is hereby granted, free of charge, to any person obtaining a copy | |
* of this software and associated documentation files (the "Software"), to deal | |
* in the Software without restriction, including without limitation the rights | |
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | |
* copies of the Software, and to permit persons to whom the Software is | |
* furnished to do so, subject to the following conditions: | |
* | |
* The above copyright notice and this permission notice shall be included in | |
* all copies or substantial portions of the Software. | |
* | |
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | |
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | |
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | |
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | |
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | |
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | |
* THE SOFTWARE. | |
*/ | |
angular.module('Scope.onReady', []).run(['$rootScope', '$injector', function($rootScope, $injector) { | |
//this is the special key that tells the scope when it's ready | |
var successKey = '__scope_success__'; | |
var readyKey = '__scope_ready__'; | |
var qKey = '__q__'; | |
var deferKey = '__defer__'; | |
var promiseKey = '__promise__'; | |
//this is set as the default just incase you forget to call $scope.$prepareForReady() in your controller | |
$rootScope[successKey] = true; | |
$rootScope[readyKey] = true; | |
//this is just here for code reuse | |
var cleanUp = function($scope) { | |
$scope[qKey] = null; | |
$scope[deferKey] = null; | |
$scope[promiseKey] = null; | |
}; | |
//you will need to call this first at the top of the controller | |
$rootScope.$prepareForReady = function($q) { | |
cleanUp(this); | |
if ($q) { | |
this[qKey] = $q; | |
} | |
this[successKey] = null; | |
this[readyKey] = false; | |
} | |
//this is used within each directive | |
$rootScope.$whenReady = function(success, fail) { | |
fail = fail || function() {}; //just incase this is not set | |
if ((typeof success != 'function') || (typeof fail != 'function')) | |
return; | |
if (this.$isReady()) { | |
//this means it's already ready | |
this[successKey] ? success() : fail(); | |
} else { | |
//this means it needs to wait for the controller to complete it's job | |
if (!this[promiseKey]) { | |
if (!this[deferKey]) { | |
if (!this[qKey]) { | |
this[qKey] = $injector.get('$q'); | |
} | |
this[deferKey] = this[qKey].defer(); | |
} | |
this[promiseKey] = this[deferKey].promise; | |
} | |
var $q = this[qKey]; | |
this[promiseKey] = this[promiseKey].then( | |
success, | |
function(reason) { | |
fail(); | |
return $q.reject(reason); | |
}); | |
} | |
}; | |
//this will inform you if it is ready | |
$rootScope.$isReady = function() { | |
return this[readyKey] ? true : false; | |
}; | |
//this will inform you if there are any events set | |
$rootScope.$hasReadyEvents = function() { | |
return this[promiseKey] && this[deferKey] ? true : false; | |
}; | |
//this is called in your controller when all your data is ready | |
$rootScope.$onReady = function(args) { | |
var $scope = this; | |
if ($scope.$isReady()) | |
return; | |
var C = function() { | |
cleanUp($scope); | |
$scope[successKey] = true; | |
$scope[readyKey] = true; | |
}; | |
if ($scope.$hasReadyEvents()) { | |
var F = function() { | |
$scope[deferKey].resolve(args); | |
C(); | |
}; | |
$scope.$$phase ? F() : $scope.$apply(F); | |
} else { | |
C(); | |
} | |
}; | |
//this is called in your controller when there is a failure of somesort | |
$rootScope.$onFailure = function(args) { | |
var $scope = this; | |
if ($scope.$isReady()) | |
return; | |
var C = function() { | |
cleanUp($scope); | |
$scope[successKey] = false; | |
$scope[readyKey] = true; | |
}; | |
if ($scope.$hasReadyEvents()) { | |
var F = function() { | |
$scope[deferKey].reject(args); | |
C(); | |
}; | |
$scope.$$phase ? F() : $scope.$apply(F); | |
} else { | |
C(); | |
} | |
}; | |
} | |
]); | |
var Swiper = function(selector, params) { | |
if (document.body.__defineGetter__) { | |
if (HTMLElement) { | |
var element = HTMLElement.prototype; | |
if (element.__defineGetter__) { | |
element.__defineGetter__("outerHTML", function() { | |
return new XMLSerializer().serializeToString(this); | |
}); | |
} | |
} | |
} | |
if (!window.getComputedStyle) { | |
window.getComputedStyle = function(el, pseudo) { | |
this.el = el; | |
this.getPropertyValue = function(prop) { | |
var re = /(\-([a-z]){1})/g; | |
if (prop === 'float') | |
prop = 'styleFloat'; | |
if (re.test(prop)) { | |
prop = prop.replace(re, function() { | |
return arguments[2].toUpperCase(); | |
}); | |
} | |
return el.currentStyle[prop] ? el.currentStyle[prop] : null; | |
} | |
return this; | |
} | |
} | |
if (!Array.prototype.indexOf) { | |
Array.prototype.indexOf = function(obj, start) { | |
for (var i = (start || 0), j = this.length; i < j; i++) { | |
if (this[i] === obj) { | |
return i; | |
} | |
} | |
return - 1; | |
} | |
} | |
if (!document.querySelectorAll) { | |
if (!window.jQuery) | |
return; | |
} | |
function $$(selector, context) { | |
if (document.querySelectorAll) | |
return (context || document).querySelectorAll(selector); | |
else | |
return jQuery(selector, context); | |
} | |
if (typeof selector === 'undefined') | |
return; | |
if (!(selector.nodeType)) { | |
if ($$(selector).length === 0) | |
return; | |
} | |
var _this = this; | |
_this.touches = { | |
start: 0, | |
startX: 0, | |
startY: 0, | |
current: 0, | |
currentX: 0, | |
currentY: 0, | |
diff: 0, | |
abs: 0 | |
}; | |
_this.positions = { | |
start: 0, | |
abs: 0, | |
diff: 0, | |
current: 0 | |
}; | |
_this.times = { | |
start: 0, | |
end: 0 | |
}; | |
_this.id = (new Date()).getTime(); | |
_this.container = (selector.nodeType) ? selector : $$(selector)[0]; | |
_this.isTouched = false; | |
_this.isMoved = false; | |
_this.activeIndex = 0; | |
_this.centerIndex = 0; | |
_this.activeLoaderIndex = 0; | |
_this.activeLoopIndex = 0; | |
_this.previousIndex = null; | |
_this.velocity = 0; | |
_this.snapGrid = []; | |
_this.slidesGrid = []; | |
_this.imagesToLoad = []; | |
_this.imagesLoaded = 0; | |
_this.wrapperLeft = 0; | |
_this.wrapperRight = 0; | |
_this.wrapperTop = 0; | |
_this.wrapperBottom = 0; | |
var wrapper, slideSize, wrapperSize, direction, isScrolling, containerSize; | |
var defaults = { | |
mode: 'horizontal', | |
touchRatio: 1, | |
speed: 300, | |
freeMode: false, | |
freeModeFluid: false, | |
momentumRatio: 1, | |
momentumBounce: true, | |
momentumBounceRatio: 1, | |
slidesPerView: 1, | |
slidesPerGroup: 1, | |
simulateTouch: true, | |
followFinger: true, | |
shortSwipes: true, | |
moveStartThreshold: false, | |
onlyExternal: false, | |
createPagination: true, | |
pagination: false, | |
paginationElement: 'span', | |
paginationClickable: false, | |
paginationAsRange: true, | |
resistance: true, | |
scrollContainer: false, | |
preventLinks: true, | |
noSwiping: false, | |
noSwipingClass: 'swiper-no-swiping', | |
initialSlide: 0, | |
keyboardControl: false, | |
mousewheelControl: false, | |
useCSS3Transforms: true, | |
autoplay: false, | |
autoplayDisableOnInteraction: true, | |
loop: false, | |
loopAdditionalSlides: 0, | |
calculateHeight: false, | |
cssWidthAndHeight: false, | |
updateOnImagesReady: true, | |
releaseFormElements: true, | |
watchActiveIndex: false, | |
visibilityFullFit: false, | |
offsetPxBefore: 0, | |
offsetPxAfter: 0, | |
offsetSlidesBefore: 0, | |
offsetSlidesAfter: 0, | |
centeredSlides: false, | |
queueStartCallbacks: false, | |
queueEndCallbacks: false, | |
autoResize: true, | |
resizeReInit: false, | |
DOMAnimation: true, | |
loader: { | |
slides: [], | |
slidesHTMLType: 'inner', | |
surroundGroups: 1, | |
logic: 'reload', | |
loadAllSlides: false | |
}, | |
slideElement: 'div', | |
slideClass: 'swiper-slide', | |
slideActiveClass: 'swiper-slide-active', | |
slideVisibleClass: 'swiper-slide-visible', | |
wrapperClass: 'swiper-wrapper', | |
paginationElementClass: 'swiper-pagination-switch', | |
paginationActiveClass: 'swiper-active-switch', | |
paginationVisibleClass: 'swiper-visible-switch' | |
} | |
params = params || {}; | |
for (var prop in defaults) { | |
if (prop in params && typeof params[prop] === 'object') { | |
for (var subProp in defaults[prop]) { | |
if (!(subProp in params[prop])) { | |
params[prop][subProp] = defaults[prop][subProp]; | |
} | |
} | |
} else if (!(prop in params)) { | |
params[prop] = defaults[prop] | |
} | |
} | |
_this.params = params; | |
if (params.scrollContainer) { | |
params.freeMode = true; | |
params.freeModeFluid = true; | |
} | |
if (params.loop) { | |
params.resistance = '100%'; | |
} | |
var isH = params.mode === 'horizontal'; | |
_this.touchEvents = { | |
touchStart: _this.support.touch ||!params.simulateTouch ? 'touchstart': (_this.browser.ie10 ? 'MSPointerDown' : 'mousedown'), | |
touchMove: _this.support.touch ||!params.simulateTouch ? 'touchmove': (_this.browser.ie10 ? 'MSPointerMove' : 'mousemove'), | |
touchEnd: _this.support.touch ||!params.simulateTouch ? 'touchend': (_this.browser.ie10 ? 'MSPointerUp' : 'mouseup') | |
}; | |
for (var i = _this.container.childNodes.length - 1; i >= 0; i--) { | |
if (_this.container.childNodes[i].className) { | |
var _wrapperClasses = _this.container.childNodes[i].className.split(' ') | |
for (var j = 0; j < _wrapperClasses.length; j++) { | |
if (_wrapperClasses[j] === params.wrapperClass) { | |
wrapper = _this.container.childNodes[i]; | |
} | |
}; | |
} | |
}; | |
_this.wrapper = wrapper; | |
_this._extendSwiperSlide = function(el) { | |
el.append = function() { | |
if (params.loop) { | |
el.insertAfter(_this.slides.length - _this.loopedSlides); | |
_this.removeLoopedSlides(); | |
_this.calcSlides(); | |
_this.createLoop(); | |
} else { | |
_this.wrapper.appendChild(el); | |
} | |
_this.reInit(); | |
return el; | |
} | |
el.prepend = function() { | |
if (params.loop) { | |
_this.wrapper.insertBefore(el, _this.slides[_this.loopedSlides]); | |
_this.removeLoopedSlides(); | |
_this.calcSlides(); | |
_this.createLoop(); | |
} else { | |
_this.wrapper.insertBefore(el, _this.wrapper.firstChild); | |
} | |
_this.reInit(); | |
return el; | |
} | |
el.insertAfter = function(index) { | |
if (typeof index === 'undefined') | |
return false; | |
var beforeSlide; | |
if (params.loop) { | |
beforeSlide = _this.slides[index + 1 + _this.loopedSlides]; | |
_this.wrapper.insertBefore(el, beforeSlide); | |
_this.removeLoopedSlides(); | |
_this.calcSlides(); | |
_this.createLoop(); | |
} else { | |
beforeSlide = _this.slides[index + 1]; | |
_this.wrapper.insertBefore(el, beforeSlide) | |
} | |
_this.reInit(); | |
return el; | |
} | |
el.clone = function() { | |
return _this._extendSwiperSlide(el.cloneNode(true)) | |
} | |
el.remove = function() { | |
_this.wrapper.removeChild(el); | |
_this.reInit(); | |
} | |
el.html = function(html) { | |
if (typeof html === 'undefined') { | |
return el.innerHTML; | |
} else { | |
el.innerHTML = html; | |
return el; | |
} | |
} | |
el.index = function() { | |
var index; | |
for (var i = _this.slides.length - 1; i >= 0; i--) { | |
if (el === _this.slides[i]) | |
index = i; | |
} | |
return index; | |
} | |
el.isActive = function() { | |
if (el.index() === _this.activeIndex) | |
return true; | |
else | |
return false; | |
} | |
if (!el.swiperSlideDataStorage) | |
el.swiperSlideDataStorage = {}; | |
el.getData = function(name) { | |
return el.swiperSlideDataStorage[name]; | |
} | |
el.setData = function(name, value) { | |
el.swiperSlideDataStorage[name] = value; | |
return el; | |
} | |
el.data = function(name, value) { | |
if (!value) { | |
return el.getAttribute('data-' + name); | |
} else { | |
el.setAttribute('data-' + name, value); | |
return el; | |
} | |
} | |
el.getWidth = function(outer) { | |
return _this.h.getWidth(el, outer); | |
} | |
el.getHeight = function(outer) { | |
return _this.h.getHeight(el, outer); | |
} | |
el.getOffset = function() { | |
return _this.h.getOffset(el); | |
} | |
return el; | |
} | |
_this.calcSlides = function(forceCalcSlides) { | |
var oldNumber = _this.slides ? _this.slides.length: false; | |
_this.slides = []; | |
_this.displaySlides = []; | |
for (var i = 0; i < _this.wrapper.childNodes.length; i++) { | |
if (_this.wrapper.childNodes[i].className) { | |
var _className = _this.wrapper.childNodes[i].className; | |
var _slideClasses = _className.split(' '); | |
for (var j = 0; j < _slideClasses.length; j++) { | |
if (_slideClasses[j] === params.slideClass) { | |
_this.slides.push(_this.wrapper.childNodes[i]); | |
} | |
} | |
} | |
} | |
for (i = _this.slides.length - 1; i >= 0; i--) { | |
_this._extendSwiperSlide(_this.slides[i]); | |
} | |
if (oldNumber === false) | |
return; | |
if (oldNumber !== _this.slides.length || forceCalcSlides) { | |
removeSlideEvents(); | |
addSlideEvents(); | |
_this.updateActiveSlide(); | |
if (_this.params.pagination) | |
_this.createPagination(); | |
_this.callPlugins('numberOfSlidesChanged'); | |
} | |
} | |
_this.createSlide = function(html, slideClassList, el) { | |
var slideClassList = slideClassList || _this.params.slideClass; | |
var el = el || params.slideElement; | |
var newSlide = document.createElement(el); | |
newSlide.innerHTML = html || ''; | |
newSlide.className = slideClassList; | |
return _this._extendSwiperSlide(newSlide); | |
} | |
_this.appendSlide = function(html, slideClassList, el) { | |
if (!html) | |
return; | |
if (html.nodeType) { | |
return _this._extendSwiperSlide(html).append() | |
} else { | |
return _this.createSlide(html, slideClassList, el).append() | |
} | |
} | |
_this.prependSlide = function(html, slideClassList, el) { | |
if (!html) | |
return; | |
if (html.nodeType) { | |
return _this._extendSwiperSlide(html).prepend() | |
} else { | |
return _this.createSlide(html, slideClassList, el).prepend() | |
} | |
} | |
_this.insertSlideAfter = function(index, html, slideClassList, el) { | |
if (typeof index === 'undefined') | |
return false; | |
if (html.nodeType) { | |
return _this._extendSwiperSlide(html).insertAfter(index); | |
} else { | |
return _this.createSlide(html, slideClassList, el).insertAfter(index); | |
} | |
} | |
_this.removeSlide = function(index) { | |
if (_this.slides[index]) { | |
if (params.loop) { | |
if (!_this.slides[index + _this.loopedSlides]) | |
return false; | |
_this.slides[index + _this.loopedSlides].remove(); | |
_this.removeLoopedSlides(); | |
_this.calcSlides(); | |
_this.createLoop(); | |
} else | |
_this.slides[index].remove(); | |
return true; | |
} else | |
return false; | |
} | |
_this.removeLastSlide = function() { | |
if (_this.slides.length > 0) { | |
if (params.loop) { | |
_this.slides[_this.slides.length - 1 - _this.loopedSlides].remove(); | |
_this.removeLoopedSlides(); | |
_this.calcSlides(); | |
_this.createLoop(); | |
} else | |
_this.slides[(_this.slides.length - 1)].remove(); | |
return true; | |
} else { | |
return false; | |
} | |
} | |
_this.removeAllSlides = function() { | |
for (var i = _this.slides.length - 1; i >= 0; i--) { | |
_this.slides[i].remove() | |
} | |
} | |
_this.getSlide = function(index) { | |
return _this.slides[index] | |
} | |
_this.getLastSlide = function() { | |
return _this.slides[_this.slides.length - 1] | |
} | |
_this.getFirstSlide = function() { | |
return _this.slides[0] | |
} | |
_this.activeSlide = function() { | |
return _this.slides[_this.activeIndex] | |
} | |
var _plugins = []; | |
for (var plugin in _this.plugins) { | |
if (params[plugin]) { | |
var p = _this.plugins[plugin](_this, params[plugin]); | |
if (p) | |
_plugins.push(p); | |
} | |
} | |
_this.callPlugins = function(method, args) { | |
if (!args) | |
args = {} | |
for (var i = 0; i < _plugins.length; i++) { | |
if (method in _plugins[i]) { | |
_plugins[i][method](args); | |
} | |
} | |
} | |
_this.fireCallback = function() { | |
var callback = arguments[0]; | |
if (Object.prototype.toString.call(callback) === '[object Array]') { | |
for (var i = 0; i < callback.length; i++) { | |
if (typeof callback[i] === 'function') { | |
callback[i](arguments[1], arguments[2], arguments[3], arguments[4], arguments[5]) | |
} | |
} | |
} else { | |
callback(arguments[1], arguments[2], arguments[3], arguments[4], arguments[5]); | |
} | |
} | |
function isArray(obj) { | |
"use strict"; | |
if (Object.prototype.toString.apply(obj) === '[object Array]') | |
return true; | |
return false; | |
} | |
_this.addCallback = function(callback, func) { | |
"use strict"; | |
var _this = this, tempFunc; | |
if (_this.params['on' + callback]) { | |
if (isArray(this.params['on' + callback])) { | |
return this.params['on' + callback].push(func); | |
} else if (typeof this.params['on' + callback] === 'function') { | |
tempFunc = this.params['on' + callback]; | |
this.params['on' + callback] = []; | |
this.params['on' + callback].push(tempFunc); | |
return this.params['on' + callback].push(func); | |
} | |
} else { | |
this.params['on' + callback] = []; | |
return this.params['on' + callback].push(func); | |
} | |
} | |
_this.removeCallbacks = function(callback) { | |
if (_this.params['on' + callback]) { | |
return _this.params['on' + callback] = null; | |
} | |
} | |
if (_this.browser.ie10&&!params.onlyExternal) { | |
_this.wrapper.classList.add('swiper-wp8-' + (isH ? 'horizontal' : 'vertical')); | |
} | |
if (params.freeMode) { | |
_this.container.className += ' swiper-free-mode'; | |
} | |
_this.initialized = false; | |
_this.init = function(force, forceCalcSlides) { | |
var _width = _this.h.getWidth(_this.container); | |
var _height = _this.h.getHeight(_this.container); | |
if (_width === _this.width && _height === _this.height&&!force) | |
return; | |
_this.width = _width; | |
_this.height = _height; | |
containerSize = isH ? _width : _height; | |
var wrapper = _this.wrapper; | |
if (force) { | |
_this.calcSlides(forceCalcSlides); | |
} | |
if (params.slidesPerView === 'auto') { | |
var slidesWidth = 0; | |
var slidesHeight = 0; | |
if (params.slidesOffset > 0) { | |
wrapper.style.paddingLeft = ''; | |
wrapper.style.paddingRight = ''; | |
wrapper.style.paddingTop = ''; | |
wrapper.style.paddingBottom = ''; | |
} | |
wrapper.style.width = ''; | |
wrapper.style.height = ''; | |
if (params.offsetPxBefore > 0) { | |
if (isH) | |
_this.wrapperLeft = params.offsetPxBefore; | |
else | |
_this.wrapperTop = params.offsetPxBefore; | |
} | |
if (params.offsetPxAfter > 0) { | |
if (isH) | |
_this.wrapperRight = params.offsetPxAfter; | |
else | |
_this.wrapperBottom = params.offsetPxAfter; | |
} | |
if (params.centeredSlides) { | |
if (isH) { | |
_this.wrapperLeft = (containerSize - this.slides[0].getWidth(true)) / 2; | |
_this.wrapperRight = (containerSize - _this.slides[_this.slides.length - 1].getWidth(true)) / 2; | |
} else { | |
_this.wrapperTop = (containerSize - _this.slides[0].getHeight(true)) / 2; | |
_this.wrapperBottom = (containerSize - _this.slides[_this.slides.length - 1].getHeight(true)) / 2; | |
} | |
} | |
if (isH) { | |
if (_this.wrapperLeft >= 0) | |
wrapper.style.paddingLeft = _this.wrapperLeft + 'px'; | |
if (_this.wrapperRight >= 0) | |
wrapper.style.paddingRight = _this.wrapperRight + 'px'; | |
} else { | |
if (_this.wrapperTop >= 0) | |
wrapper.style.paddingTop = _this.wrapperTop + 'px'; | |
if (_this.wrapperBottom >= 0) | |
wrapper.style.paddingBottom = _this.wrapperBottom + 'px'; | |
} | |
var slideLeft = 0; | |
var centeredSlideLeft = 0; | |
_this.snapGrid = []; | |
_this.slidesGrid = []; | |
var slideMaxHeight = 0; | |
for (var i = 0; i < _this.slides.length; i++) { | |
var slideWidth = _this.slides[i].getWidth(true); | |
var slideHeight = _this.slides[i].getHeight(true); | |
if (params.calculateHeight) { | |
slideMaxHeight = Math.max(slideMaxHeight, slideHeight) | |
} | |
var _slideSize = isH ? slideWidth: slideHeight; | |
if (params.centeredSlides) { | |
var nextSlideWidth = i === _this.slides.length - 1 ? 0: _this.slides[i + 1].getWidth(true); | |
var nextSlideHeight = i === _this.slides.length - 1 ? 0: _this.slides[i + 1].getHeight(true); | |
var nextSlideSize = isH ? nextSlideWidth: nextSlideHeight; | |
if (_slideSize > containerSize) { | |
for (var j = 0; j <= Math.floor(_slideSize / (containerSize + _this.wrapperLeft)); j++) { | |
if (j === 0) | |
_this.snapGrid.push(slideLeft + _this.wrapperLeft); | |
else | |
_this.snapGrid.push(slideLeft + _this.wrapperLeft + containerSize * j); | |
} | |
_this.slidesGrid.push(slideLeft + _this.wrapperLeft); | |
} else { | |
_this.snapGrid.push(centeredSlideLeft); | |
_this.slidesGrid.push(centeredSlideLeft); | |
} | |
centeredSlideLeft += _slideSize / 2 + nextSlideSize / 2; | |
} else { | |
if (_slideSize > containerSize) { | |
for (var j = 0; j <= Math.floor(_slideSize / containerSize); j++) { | |
_this.snapGrid.push(slideLeft + containerSize * j); | |
} | |
} else { | |
_this.snapGrid.push(slideLeft); | |
} | |
_this.slidesGrid.push(slideLeft); | |
} | |
slideLeft += _slideSize; | |
slidesWidth += slideWidth; | |
slidesHeight += slideHeight; | |
} | |
if (params.calculateHeight) | |
_this.height = slideMaxHeight; | |
if (isH) { | |
wrapperSize = slidesWidth + _this.wrapperRight + _this.wrapperLeft; | |
wrapper.style.width = (slidesWidth) + 'px'; | |
wrapper.style.height = (_this.height) + 'px'; | |
} else { | |
wrapperSize = slidesHeight + _this.wrapperTop + _this.wrapperBottom; | |
wrapper.style.width = (_this.width) + 'px'; | |
wrapper.style.height = (slidesHeight) + 'px'; | |
} | |
} else if (params.scrollContainer) { | |
wrapper.style.width = ''; | |
wrapper.style.height = ''; | |
var wrapperWidth = _this.slides[0].getWidth(true); | |
var wrapperHeight = _this.slides[0].getHeight(true); | |
wrapperSize = isH ? wrapperWidth : wrapperHeight; | |
wrapper.style.width = wrapperWidth + 'px'; | |
wrapper.style.height = wrapperHeight + 'px'; | |
slideSize = isH ? wrapperWidth : wrapperHeight; | |
} else { | |
if (params.calculateHeight) { | |
var slideMaxHeight = 0; | |
var wrapperHeight = 0; | |
if (!isH) | |
_this.container.style.height = ''; | |
wrapper.style.height = ''; | |
for (var i = 0; i < _this.slides.length; i++) { | |
_this.slides[i].style.height = ''; | |
slideMaxHeight = Math.max(_this.slides[i].getHeight(true), slideMaxHeight); | |
if (!isH) | |
wrapperHeight += _this.slides[i].getHeight(true); | |
} | |
var slideHeight = slideMaxHeight; | |
_this.height = slideHeight; | |
if (isH) | |
wrapperHeight = slideHeight; | |
else | |
containerSize = slideHeight, _this.container.style.height = containerSize + 'px'; | |
} else { | |
var slideHeight = isH ? _this.height: _this.height / params.slidesPerView; | |
var wrapperHeight = isH ? _this.height: _this.slides.length * slideHeight; | |
} | |
var slideWidth = isH ? _this.width / params.slidesPerView: _this.width; | |
var wrapperWidth = isH ? _this.slides.length * slideWidth: _this.width; | |
slideSize = isH ? slideWidth : slideHeight; | |
if (params.offsetSlidesBefore > 0) { | |
if (isH) | |
_this.wrapperLeft = slideSize * params.offsetSlidesBefore; | |
else | |
_this.wrapperTop = slideSize * params.offsetSlidesBefore; | |
} | |
if (params.offsetSlidesAfter > 0) { | |
if (isH) | |
_this.wrapperRight = slideSize * params.offsetSlidesAfter; | |
else | |
_this.wrapperBottom = slideSize * params.offsetSlidesAfter; | |
} | |
if (params.offsetPxBefore > 0) { | |
if (isH) | |
_this.wrapperLeft = params.offsetPxBefore; | |
else | |
_this.wrapperTop = params.offsetPxBefore; | |
} | |
if (params.offsetPxAfter > 0) { | |
if (isH) | |
_this.wrapperRight = params.offsetPxAfter; | |
else | |
_this.wrapperBottom = params.offsetPxAfter; | |
} | |
if (params.centeredSlides) { | |
if (isH) { | |
_this.wrapperLeft = (containerSize - slideSize) / 2; | |
_this.wrapperRight = (containerSize - slideSize) / 2; | |
} else { | |
_this.wrapperTop = (containerSize - slideSize) / 2; | |
_this.wrapperBottom = (containerSize - slideSize) / 2; | |
} | |
} | |
if (isH) { | |
if (_this.wrapperLeft > 0) | |
wrapper.style.paddingLeft = _this.wrapperLeft + 'px'; | |
if (_this.wrapperRight > 0) | |
wrapper.style.paddingRight = _this.wrapperRight + 'px'; | |
} else { | |
if (_this.wrapperTop > 0) | |
wrapper.style.paddingTop = _this.wrapperTop + 'px'; | |
if (_this.wrapperBottom > 0) | |
wrapper.style.paddingBottom = _this.wrapperBottom + 'px'; | |
} | |
wrapperSize = isH ? wrapperWidth + _this.wrapperRight + _this.wrapperLeft : wrapperHeight + _this.wrapperTop + _this.wrapperBottom; | |
if (!params.cssWidthAndHeight) { | |
if (parseFloat(wrapperWidth) > 0) { | |
wrapper.style.width = wrapperWidth + 'px'; | |
} | |
if (parseFloat(wrapperHeight) > 0) { | |
wrapper.style.height = wrapperHeight + 'px'; | |
} | |
} | |
var slideLeft = 0; | |
_this.snapGrid = []; | |
_this.slidesGrid = []; | |
for (var i = 0; i < _this.slides.length; i++) { | |
_this.snapGrid.push(slideLeft); | |
_this.slidesGrid.push(slideLeft); | |
slideLeft += slideSize; | |
if (!params.cssWidthAndHeight) { | |
if (parseFloat(slideWidth) > 0) { | |
_this.slides[i].style.width = slideWidth + 'px'; | |
} | |
if (parseFloat(slideHeight) > 0) { | |
_this.slides[i].style.height = slideHeight + 'px'; | |
} | |
} | |
} | |
} | |
if (!_this.initialized) { | |
_this.callPlugins('onFirstInit'); | |
if (params.onFirstInit) | |
_this.fireCallback(params.onFirstInit, _this); | |
} else { | |
_this.callPlugins('onInit'); | |
if (params.onInit) | |
_this.fireCallback(params.onInit, _this); | |
} | |
_this.initialized = true; | |
} | |
_this.reInit = function(forceCalcSlides) { | |
_this.init(true, forceCalcSlides); | |
} | |
_this.resizeFix = function(reInit) { | |
_this.callPlugins('beforeResizeFix'); | |
_this.init(params.resizeReInit || reInit); | |
if (!params.freeMode) { | |
_this.swipeTo((params.loop ? _this.activeLoopIndex : _this.activeIndex), 0, false); | |
} else if (_this.getWrapperTranslate()<-maxWrapperPosition()) { | |
_this.setWrapperTransition(0); | |
_this.setWrapperTranslate( - maxWrapperPosition()); | |
} | |
_this.callPlugins('afterResizeFix'); | |
} | |
function maxWrapperPosition() { | |
var a = (wrapperSize - containerSize); | |
if (params.freeMode) { | |
a = wrapperSize - containerSize; | |
} | |
if (params.slidesPerView > _this.slides.length) | |
a = 0; | |
if (a < 0) | |
a = 0; | |
return a; | |
} | |
function minWrapperPosition() { | |
var a = 0; | |
return a; | |
} | |
function initEvents() { | |
var bind = _this.h.addEventListener; | |
if (!_this.browser.ie10) { | |
if (_this.support.touch) { | |
bind(_this.wrapper, 'touchstart', onTouchStart); | |
bind(_this.wrapper, 'touchmove', onTouchMove); | |
bind(_this.wrapper, 'touchend', onTouchEnd); | |
} | |
if (params.simulateTouch) { | |
bind(_this.wrapper, 'mousedown', onTouchStart); | |
bind(document, 'mousemove', onTouchMove); | |
bind(document, 'mouseup', onTouchEnd); | |
} | |
} else { | |
bind(_this.wrapper, _this.touchEvents.touchStart, onTouchStart); | |
bind(document, _this.touchEvents.touchMove, onTouchMove); | |
bind(document, _this.touchEvents.touchEnd, onTouchEnd); | |
} | |
if (params.autoResize) { | |
bind(window, 'resize', _this.resizeFix); | |
} | |
addSlideEvents(); | |
_this._wheelEvent = false; | |
if (params.mousewheelControl) { | |
if (document.onmousewheel !== undefined) { | |
_this._wheelEvent = "mousewheel"; | |
} | |
try { | |
WheelEvent("wheel"); | |
_this._wheelEvent = "wheel"; | |
} catch (e) {} | |
if (!_this._wheelEvent) { | |
_this._wheelEvent = "DOMMouseScroll"; | |
} | |
if (_this._wheelEvent) { | |
bind(_this.container, _this._wheelEvent, handleMousewheel); | |
} | |
} | |
if (params.keyboardControl) { | |
bind(document, 'keydown', handleKeyboardKeys); | |
} | |
if (params.updateOnImagesReady) { | |
_this.imagesToLoad = $$('img', _this.container); | |
for (var i = 0; i < _this.imagesToLoad.length; i++) { | |
_loadImage(_this.imagesToLoad[i].getAttribute('src')) | |
} | |
} | |
function _loadImage(src) { | |
var image = new Image(); | |
image.onload = function() { | |
_this.imagesLoaded++; | |
if (_this.imagesLoaded == _this.imagesToLoad.length) { | |
_this.reInit(); | |
if (params.onImagesReady) | |
_this.fireCallback(params.onImagesReady, _this); | |
} | |
} | |
image.src = src; | |
} | |
} | |
_this.destroy = function(removeResizeFix) { | |
var unbind = _this.h.removeEventListener; | |
if (!_this.browser.ie10) { | |
if (_this.support.touch) { | |
unbind(_this.wrapper, 'touchstart', onTouchStart); | |
unbind(_this.wrapper, 'touchmove', onTouchMove); | |
unbind(_this.wrapper, 'touchend', onTouchEnd); | |
} | |
if (params.simulateTouch) { | |
unbind(_this.wrapper, 'mousedown', onTouchStart); | |
unbind(document, 'mousemove', onTouchMove); | |
unbind(document, 'mouseup', onTouchEnd); | |
} | |
} else { | |
unbind(_this.wrapper, _this.touchEvents.touchStart, onTouchStart); | |
unbind(document, _this.touchEvents.touchMove, onTouchMove); | |
unbind(document, _this.touchEvents.touchEnd, onTouchEnd); | |
} | |
if (params.autoResize) { | |
unbind(window, 'resize', _this.resizeFix); | |
} | |
removeSlideEvents(); | |
if (params.paginationClickable) { | |
removePaginationEvents(); | |
} | |
if (params.mousewheelControl && _this._wheelEvent) { | |
unbind(_this.container, _this._wheelEvent, handleMousewheel); | |
} | |
if (params.keyboardControl) { | |
unbind(document, 'keydown', handleKeyboardKeys); | |
} | |
if (params.autoplay) { | |
_this.stopAutoplay(); | |
} | |
_this.callPlugins('onDestroy'); | |
_this = null; | |
} | |
function addSlideEvents() { | |
var bind = _this.h.addEventListener, i; | |
if (params.preventLinks) { | |
var links = $$('a', _this.container); | |
for (i = 0; i < links.length; i++) { | |
bind(links[i], 'click', preventClick); | |
} | |
} | |
if (params.releaseFormElements) { | |
var formElements = $$('input, textarea, select', _this.container); | |
for (i = 0; i < formElements.length; i++) { | |
bind(formElements[i], _this.touchEvents.touchStart, releaseForms, true); | |
} | |
} | |
if (params.onSlideClick) { | |
for (i = 0; i < _this.slides.length; i++) { | |
bind(_this.slides[i], 'click', slideClick); | |
} | |
} | |
if (params.onSlideTouch) { | |
for (i = 0; i < _this.slides.length; i++) { | |
bind(_this.slides[i], _this.touchEvents.touchStart, slideTouch); | |
} | |
} | |
} | |
function removeSlideEvents() { | |
var unbind = _this.h.removeEventListener, i; | |
if (params.onSlideClick) { | |
for (i = 0; i < _this.slides.length; i++) { | |
unbind(_this.slides[i], 'click', slideClick); | |
} | |
} | |
if (params.onSlideTouch) { | |
for (i = 0; i < _this.slides.length; i++) { | |
unbind(_this.slides[i], _this.touchEvents.touchStart, slideTouch); | |
} | |
} | |
if (params.releaseFormElements) { | |
var formElements = $$('input, textarea, select', _this.container); | |
for (i = 0; i < formElements.length; i++) { | |
unbind(formElements[i], _this.touchEvents.touchStart, releaseForms, true); | |
} | |
} | |
if (params.preventLinks) { | |
var links = $$('a', _this.container); | |
for (i = 0; i < links.length; i++) { | |
unbind(links[i], 'click', preventClick); | |
} | |
} | |
} | |
function handleKeyboardKeys(e) { | |
var kc = e.keyCode || e.charCode; | |
if (kc == 37 || kc == 39 || kc == 38 || kc == 40) { | |
var inView = false; | |
var swiperOffset = _this.h.getOffset(_this.container); | |
var scrollLeft = _this.h.windowScroll().left; | |
var scrollTop = _this.h.windowScroll().top; | |
var windowWidth = _this.h.windowWidth(); | |
var windowHeight = _this.h.windowHeight(); | |
var swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + _this.width, swiperOffset.top], [swiperOffset.left, swiperOffset.top + _this.height], [swiperOffset.left + _this.width, swiperOffset.top + _this.height]] | |
for (var i = 0; i < swiperCoord.length; i++) { | |
var point = swiperCoord[i]; | |
if (point[0] >= scrollLeft && point[0] <= scrollLeft + windowWidth && point[1] >= scrollTop && point[1] <= scrollTop + windowHeight) { | |
inView = true; | |
} | |
} | |
if (!inView) | |
return; | |
} | |
if (isH) { | |
if (kc == 37 || kc == 39) { | |
if (e.preventDefault) | |
e.preventDefault(); | |
else | |
e.returnValue = false; | |
} | |
if (kc == 39) | |
_this.swipeNext(); | |
if (kc == 37) | |
_this.swipePrev(); | |
} else { | |
if (kc == 38 || kc == 40) { | |
if (e.preventDefault) | |
e.preventDefault(); | |
else | |
e.returnValue = false; | |
} | |
if (kc == 40) | |
_this.swipeNext(); | |
if (kc == 38) | |
_this.swipePrev(); | |
} | |
} | |
var lastScrollTime = (new Date()).getTime(); | |
function handleMousewheel(e) { | |
var we = _this._wheelEvent; | |
var delta = 0; | |
if (e.detail) | |
delta =- e.detail; | |
else if (we == 'mousewheel') { | |
if (isH) { | |
if (Math.abs(e.wheelDeltaX) > Math.abs(e.wheelDeltaY)) | |
delta = e.wheelDeltaX; | |
else | |
return; | |
} else { | |
if (Math.abs(e.wheelDeltaY) > Math.abs(e.wheelDeltaX)) | |
delta = e.wheelDeltaY; | |
else | |
return; | |
} | |
} else if (we == 'DOMMouseScroll') | |
delta =- e.detail; | |
else if (we == 'wheel') { | |
if (isH) { | |
if (Math.abs(e.deltaX) > Math.abs(e.deltaY)) | |
delta =- e.deltaX; | |
else | |
return; | |
} else { | |
if (Math.abs(e.deltaY) > Math.abs(e.deltaX)) | |
delta =- e.deltaY; | |
else | |
return; | |
} | |
} | |
if (!params.freeMode) { | |
if ((new Date()).getTime() - lastScrollTime > 60) { | |
if (delta < 0) | |
_this.swipeNext(); | |
else | |
_this.swipePrev(); | |
} | |
lastScrollTime = (new Date()).getTime(); | |
} else { | |
var position = _this.getWrapperTranslate() + delta; | |
if (position > 0) | |
position = 0; | |
if (position<-maxWrapperPosition()) | |
position =- maxWrapperPosition(); | |
_this.setWrapperTransition(0); | |
_this.setWrapperTranslate(position); | |
_this.updateActiveSlide(position); | |
if (position == 0 || position==-maxWrapperPosition()) | |
return; | |
} | |
if (params.autoplay) | |
_this.stopAutoplay(true); | |
if (e.preventDefault) | |
e.preventDefault(); | |
else | |
e.returnValue = false; | |
return false; | |
} | |
if (params.grabCursor) { | |
var containerStyle = _this.container.style; | |
containerStyle.cursor = 'move'; | |
containerStyle.cursor = 'grab'; | |
containerStyle.cursor = '-moz-grab'; | |
containerStyle.cursor = '-webkit-grab'; | |
} | |
_this.allowSlideClick = true; | |
function slideClick(event) { | |
if (_this.allowSlideClick) { | |
setClickedSlide(event); | |
_this.fireCallback(params.onSlideClick, _this, event); | |
} | |
} | |
function slideTouch(event) { | |
setClickedSlide(event); | |
_this.fireCallback(params.onSlideTouch, _this, event); | |
} | |
function setClickedSlide(event) { | |
if (!event.currentTarget) { | |
var element = event.srcElement; | |
do { | |
if (element.className.indexOf(params.slideClass)>-1) { | |
break; | |
} | |
} | |
while (element = element.parentNode); | |
_this.clickedSlide = element; | |
} else { | |
_this.clickedSlide = event.currentTarget; | |
} | |
_this.clickedSlideIndex = _this.slides.indexOf(_this.clickedSlide); | |
_this.clickedSlideLoopIndex = _this.clickedSlideIndex - (_this.loopedSlides || 0); | |
} | |
_this.allowLinks = true; | |
function preventClick(e) { | |
if (!_this.allowLinks) { | |
if (e.preventDefault) | |
e.preventDefault(); | |
else | |
e.returnValue = false; | |
return false; | |
} | |
} | |
function releaseForms(e) { | |
if (e.stopPropagation) | |
e.stopPropagation(); | |
else | |
e.returnValue = false; | |
return false; | |
} | |
var isTouchEvent = false; | |
var allowThresholdMove; | |
var allowMomentumBounce = true; | |
function onTouchStart(event) { | |
if (params.preventLinks) | |
_this.allowLinks = true; | |
if (_this.isTouched || params.onlyExternal) { | |
return false; | |
} | |
if (params.noSwiping && (event.target || event.srcElement) && noSwipingSlide(event.target || event.srcElement)) | |
return false; | |
allowMomentumBounce = false; | |
_this.isTouched = true; | |
isTouchEvent = event.type == 'touchstart'; | |
if (!isTouchEvent || event.targetTouches.length == 1) { | |
_this.callPlugins('onTouchStartBegin'); | |
if (!isTouchEvent) { | |
if (event.preventDefault) | |
event.preventDefault(); | |
else | |
event.returnValue = false; | |
} | |
var pageX = isTouchEvent ? event.targetTouches[0].pageX: (event.pageX || event.clientX); | |
var pageY = isTouchEvent ? event.targetTouches[0].pageY: (event.pageY || event.clientY); | |
_this.touches.startX = _this.touches.currentX = pageX; | |
_this.touches.startY = _this.touches.currentY = pageY; | |
_this.touches.start = _this.touches.current = isH ? pageX : pageY; | |
_this.setWrapperTransition(0); | |
_this.positions.start = _this.positions.current = _this.getWrapperTranslate(); | |
_this.setWrapperTranslate(_this.positions.start); | |
_this.times.start = (new Date()).getTime(); | |
isScrolling = undefined; | |
if (params.moveStartThreshold > 0) | |
allowThresholdMove = false; | |
if (params.onTouchStart) | |
_this.fireCallback(params.onTouchStart, _this); | |
_this.callPlugins('onTouchStartEnd'); | |
} | |
} | |
var velocityPrevPosition, velocityPrevTime; | |
function onTouchMove(event) { | |
if (!_this.isTouched || params.onlyExternal) | |
return; | |
if (isTouchEvent && event.type == 'mousemove') | |
return; | |
var pageX = isTouchEvent ? event.targetTouches[0].pageX: (event.pageX || event.clientX); | |
var pageY = isTouchEvent ? event.targetTouches[0].pageY: (event.pageY || event.clientY); | |
if (typeof isScrolling === 'undefined' && isH) { | |
isScrolling=!!(isScrolling || Math.abs(pageY - _this.touches.startY) > Math.abs(pageX - _this.touches.startX)); | |
} | |
if (typeof isScrolling === 'undefined'&&!isH) { | |
isScrolling=!!(isScrolling || Math.abs(pageY - _this.touches.startY) < Math.abs(pageX - _this.touches.startX)); | |
} | |
if (isScrolling) { | |
_this.isTouched = false; | |
return; | |
} | |
if (event.assignedToSwiper) { | |
_this.isTouched = false; | |
return; | |
} | |
event.assignedToSwiper = true; | |
if (params.preventLinks) { | |
_this.allowLinks = false; | |
} | |
if (params.onSlideClick) { | |
_this.allowSlideClick = false; | |
} | |
if (params.autoplay) { | |
_this.stopAutoplay(true); | |
} | |
if (!isTouchEvent || event.touches.length == 1) { | |
if (!_this.isMoved) { | |
_this.callPlugins('onTouchMoveStart'); | |
if (params.loop) { | |
_this.fixLoop(); | |
_this.positions.start = _this.getWrapperTranslate(); | |
} | |
if (params.onTouchMoveStart) | |
_this.fireCallback(params.onTouchMoveStart, _this); | |
} | |
_this.isMoved = true; | |
if (event.preventDefault) | |
event.preventDefault(); | |
else | |
event.returnValue = false; | |
_this.touches.current = isH ? pageX : pageY; | |
_this.positions.current = (_this.touches.current - _this.touches.start) * params.touchRatio + _this.positions.start; | |
if (_this.positions.current > 0 && params.onResistanceBefore) { | |
_this.fireCallback(params.onResistanceBefore, _this, _this.positions.current); | |
} | |
if (_this.positions.current<-maxWrapperPosition() && params.onResistanceAfter) { | |
_this.fireCallback(params.onResistanceAfter, _this, Math.abs(_this.positions.current + maxWrapperPosition())); | |
} | |
if (params.resistance && params.resistance != '100%') { | |
if (_this.positions.current > 0) { | |
var resistance = 1 - _this.positions.current / containerSize / 2; | |
if (resistance < 0.5) | |
_this.positions.current = (containerSize / 2); | |
else | |
_this.positions.current = _this.positions.current * resistance; | |
} | |
if (_this.positions.current<-maxWrapperPosition()) { | |
var diff = (_this.touches.current - _this.touches.start) * params.touchRatio + (maxWrapperPosition() + _this.positions.start); | |
var resistance = (containerSize + diff) / (containerSize); | |
var newPos = _this.positions.current - diff * (1 - resistance) / 2; | |
var stopPos =- maxWrapperPosition() - containerSize / 2; | |
if (newPos < stopPos || resistance <= 0) | |
_this.positions.current = stopPos; | |
else | |
_this.positions.current = newPos; | |
} | |
} | |
if (params.resistance && params.resistance == '100%') { | |
if (_this.positions.current > 0&&!(params.freeMode&&!params.freeModeFluid)) { | |
_this.positions.current = 0; | |
} | |
if ((_this.positions.current)<-maxWrapperPosition()&&!(params.freeMode&&!params.freeModeFluid)) { | |
_this.positions.current =- maxWrapperPosition(); | |
} | |
} | |
if (!params.followFinger) | |
return; | |
if (!params.moveStartThreshold) { | |
_this.setWrapperTranslate(_this.positions.current); | |
} else { | |
if (Math.abs(_this.touches.current - _this.touches.start) > params.moveStartThreshold || allowThresholdMove) { | |
allowThresholdMove = true; | |
_this.setWrapperTranslate(_this.positions.current); | |
} else { | |
_this.positions.current = _this.positions.start; | |
} | |
} | |
if (params.freeMode || params.watchActiveIndex) { | |
_this.updateActiveSlide(_this.positions.current); | |
} | |
if (params.grabCursor) { | |
_this.container.style.cursor = 'move'; | |
_this.container.style.cursor = 'grabbing'; | |
_this.container.style.cursor = '-moz-grabbin'; | |
_this.container.style.cursor = '-webkit-grabbing'; | |
} | |
if (!velocityPrevPosition) | |
velocityPrevPosition = _this.touches.current; | |
if (!velocityPrevTime) | |
velocityPrevTime = (new Date).getTime(); | |
_this.velocity = (_this.touches.current - velocityPrevPosition) / ((new Date).getTime() - velocityPrevTime) / 2; | |
if (Math.abs(_this.touches.current - velocityPrevPosition) < 2) | |
_this.velocity = 0; | |
velocityPrevPosition = _this.touches.current; | |
velocityPrevTime = (new Date).getTime(); | |
_this.callPlugins('onTouchMoveEnd'); | |
if (params.onTouchMove) | |
_this.fireCallback(params.onTouchMove, _this); | |
return false; | |
} | |
} | |
function onTouchEnd(event) { | |
if (isScrolling) { | |
_this.swipeReset(); | |
} | |
if (params.onlyExternal ||!_this.isTouched) | |
return; | |
_this.isTouched = false | |
if (params.grabCursor) { | |
_this.container.style.cursor = 'move'; | |
_this.container.style.cursor = 'grab'; | |
_this.container.style.cursor = '-moz-grab'; | |
_this.container.style.cursor = '-webkit-grab'; | |
} | |
if (!_this.positions.current && _this.positions.current !== 0) { | |
_this.positions.current = _this.positions.start | |
} | |
if (params.followFinger) { | |
_this.setWrapperTranslate(_this.positions.current); | |
} | |
_this.times.end = (new Date()).getTime(); | |
_this.touches.diff = _this.touches.current - _this.touches.start | |
_this.touches.abs = Math.abs(_this.touches.diff) | |
_this.positions.diff = _this.positions.current - _this.positions.start | |
_this.positions.abs = Math.abs(_this.positions.diff) | |
var diff = _this.positions.diff; | |
var diffAbs = _this.positions.abs; | |
var timeDiff = _this.times.end - _this.times.start | |
if (diffAbs < 5 && (timeDiff) < 300 && _this.allowLinks == false) { | |
if (!params.freeMode && diffAbs != 0) | |
_this.swipeReset() | |
if (params.preventLinks) { | |
_this.allowLinks = true; | |
} | |
if (params.onSlideClick) { | |
_this.allowSlideClick = true; | |
} | |
} | |
setTimeout(function() { | |
if (params.preventLinks) { | |
_this.allowLinks = true; | |
} | |
if (params.onSlideClick) { | |
_this.allowSlideClick = true; | |
} | |
}, 100); | |
var maxPosition = maxWrapperPosition(); | |
if (!_this.isMoved && params.freeMode) { | |
_this.isMoved = false; | |
if (params.onTouchEnd) | |
_this.fireCallback(params.onTouchEnd, _this); | |
_this.callPlugins('onTouchEnd'); | |
return; | |
} | |
if (!_this.isMoved || _this.positions.current > 0 || _this.positions.current<-maxPosition) { | |
_this.swipeReset(); | |
if (params.onTouchEnd) | |
_this.fireCallback(params.onTouchEnd, _this); | |
_this.callPlugins('onTouchEnd'); | |
return; | |
} | |
_this.isMoved = false; | |
if (params.freeMode) { | |
if (params.freeModeFluid) { | |
var momentumDuration = 1000 * params.momentumRatio; | |
var momentumDistance = _this.velocity * momentumDuration; | |
var newPosition = _this.positions.current + momentumDistance | |
var doBounce = false; | |
var afterBouncePosition; | |
var bounceAmount = Math.abs(_this.velocity) * 20 * params.momentumBounceRatio; | |
if (newPosition<-maxPosition) { | |
if (params.momentumBounce && _this.support.transitions) { | |
if (newPosition + maxPosition<-bounceAmount) | |
newPosition =- maxPosition - bounceAmount; | |
afterBouncePosition =- maxPosition; | |
doBounce = true; | |
allowMomentumBounce = true; | |
} else | |
newPosition =- maxPosition; | |
} | |
if (newPosition > 0) { | |
if (params.momentumBounce && _this.support.transitions) { | |
if (newPosition > bounceAmount) | |
newPosition = bounceAmount; | |
afterBouncePosition = 0 | |
doBounce = true; | |
allowMomentumBounce = true; | |
} else | |
newPosition = 0; | |
} | |
if (_this.velocity != 0) | |
momentumDuration = Math.abs((newPosition - _this.positions.current) / _this.velocity) | |
_this.setWrapperTranslate(newPosition); | |
_this.setWrapperTransition(momentumDuration); | |
if (params.momentumBounce && doBounce) { | |
_this.wrapperTransitionEnd(function() { | |
if (!allowMomentumBounce) | |
return; | |
if (params.onMomentumBounce) | |
_this.fireCallback(params.onMomentumBounce, _this); | |
_this.callPlugins('onMomentumBounce'); | |
_this.setWrapperTranslate(afterBouncePosition); | |
_this.setWrapperTransition(300); | |
}) | |
} | |
_this.updateActiveSlide(newPosition) | |
} | |
if (!params.freeModeFluid || timeDiff >= 300) | |
_this.updateActiveSlide(_this.positions.current) | |
if (params.onTouchEnd) | |
_this.fireCallback(params.onTouchEnd, _this); | |
_this.callPlugins('onTouchEnd'); | |
return; | |
} | |
direction = diff < 0 ? "toNext" : "toPrev" | |
if (direction == "toNext" && (timeDiff <= 300)) { | |
if (diffAbs < 30 ||!params.shortSwipes) | |
_this.swipeReset() | |
else | |
_this.swipeNext(true); | |
} | |
if (direction == "toPrev" && (timeDiff <= 300)) { | |
if (diffAbs < 30 ||!params.shortSwipes) | |
_this.swipeReset() | |
else | |
_this.swipePrev(true); | |
} | |
var targetSlideSize = 0; | |
if (params.slidesPerView == 'auto') { | |
var currentPosition = Math.abs(_this.getWrapperTranslate()); | |
var slidesOffset = 0; | |
var _slideSize; | |
for (var i = 0; i < _this.slides.length; i++) { | |
_slideSize = isH ? _this.slides[i].getWidth(true) : _this.slides[i].getHeight(true); | |
slidesOffset += _slideSize; | |
if (slidesOffset > currentPosition) { | |
targetSlideSize = _slideSize; | |
break; | |
} | |
} | |
if (targetSlideSize > containerSize) | |
targetSlideSize = containerSize; | |
} else { | |
targetSlideSize = slideSize * params.slidesPerView; | |
} | |
if (direction == "toNext" && (timeDiff > 300)) { | |
if (diffAbs >= targetSlideSize * 0.5) { | |
_this.swipeNext(true) | |
} else { | |
_this.swipeReset() | |
} | |
} | |
if (direction == "toPrev" && (timeDiff > 300)) { | |
if (diffAbs >= targetSlideSize * 0.5) { | |
_this.swipePrev(true); | |
} else { | |
_this.swipeReset() | |
} | |
} | |
if (params.onTouchEnd) | |
params.onTouchEnd(_this) | |
_this.callPlugins('onTouchEnd'); | |
} | |
function noSwipingSlide(el) { | |
var noSwiping = false; | |
do { | |
if (el.className.indexOf(params.noSwipingClass)>-1) | |
{ | |
noSwiping = true; | |
} | |
el = el.parentElement; | |
} | |
while (!noSwiping && el.parentElement && el.className.indexOf(params.wrapperClass)==-1); | |
if (!noSwiping && el.className.indexOf(params.wrapperClass)>-1 && el.className.indexOf(params.noSwipingClass)>-1) | |
noSwiping = true; | |
return noSwiping; | |
} | |
_this.swipeNext = function(internal) { | |
if (!internal && params.loop) | |
_this.fixLoop(); | |
if (!internal && params.autoplay) | |
_this.stopAutoplay(true); | |
_this.callPlugins('onSwipeNext'); | |
var currentPosition = _this.getWrapperTranslate(); | |
var newPosition = currentPosition; | |
if (params.slidesPerView == 'auto') { | |
for (var i = 0; i < _this.snapGrid.length; i++) { | |
if ( - currentPosition >= _this.snapGrid[i]&&-currentPosition < _this.snapGrid[i + 1]) { | |
newPosition =- _this.snapGrid[i + 1] | |
break; | |
} | |
} | |
} else { | |
var groupSize = slideSize * params.slidesPerGroup; | |
newPosition =- (Math.floor(Math.abs(currentPosition) / Math.floor(groupSize)) * groupSize + groupSize); | |
} | |
if (newPosition<- maxWrapperPosition()) { | |
newPosition =- maxWrapperPosition() | |
}; | |
if (newPosition == currentPosition) | |
return false; | |
swipeToPosition(newPosition, 'next'); | |
return true | |
} | |
_this.swipePrev = function(internal) { | |
if (!internal && params.loop) | |
_this.fixLoop(); | |
if (!internal && params.autoplay) | |
_this.stopAutoplay(true); | |
_this.callPlugins('onSwipePrev'); | |
var currentPosition = Math.ceil(_this.getWrapperTranslate()); | |
var newPosition; | |
if (params.slidesPerView == 'auto') { | |
newPosition = 0; | |
for (var i = 1; i < _this.snapGrid.length; i++) { | |
if ( - currentPosition == _this.snapGrid[i]) { | |
newPosition =- _this.snapGrid[i - 1] | |
break; | |
} | |
if ( - currentPosition > _this.snapGrid[i]&&-currentPosition < _this.snapGrid[i + 1]) { | |
newPosition =- _this.snapGrid[i] | |
break; | |
} | |
} | |
} else { | |
var groupSize = slideSize * params.slidesPerGroup; | |
newPosition =- (Math.ceil( - currentPosition / groupSize) - 1) * groupSize; | |
} | |
if (newPosition > 0) | |
newPosition = 0; | |
if (newPosition == currentPosition) | |
return false; | |
swipeToPosition(newPosition, 'prev'); | |
return true; | |
} | |
_this.swipeReset = function() { | |
_this.callPlugins('onSwipeReset'); | |
var currentPosition = _this.getWrapperTranslate(); | |
var groupSize = slideSize * params.slidesPerGroup; | |
var newPosition; | |
var maxPosition =- maxWrapperPosition(); | |
if (params.slidesPerView == 'auto') { | |
newPosition = 0; | |
for (var i = 0; i < _this.snapGrid.length; i++) { | |
if ( - currentPosition === _this.snapGrid[i]) | |
return; | |
if ( - currentPosition >= _this.snapGrid[i]&&-currentPosition < _this.snapGrid[i + 1]) { | |
if (_this.positions.diff > 0) | |
newPosition =- _this.snapGrid[i + 1] | |
else | |
newPosition =- _this.snapGrid[i] | |
break; | |
} | |
} | |
if ( - currentPosition >= _this.snapGrid[_this.snapGrid.length - 1]) | |
newPosition =- _this.snapGrid[_this.snapGrid.length - 1]; | |
if (currentPosition<=-maxWrapperPosition()) | |
newPosition =- maxWrapperPosition() | |
} else { | |
newPosition = currentPosition < 0 ? Math.round(currentPosition / groupSize) * groupSize : 0 | |
} | |
if (params.scrollContainer) { | |
newPosition = currentPosition < 0 ? currentPosition : 0; | |
} | |
if (newPosition<-maxWrapperPosition()) { | |
newPosition =- maxWrapperPosition() | |
} | |
if (params.scrollContainer && (containerSize > slideSize)) { | |
newPosition = 0; | |
} | |
if (newPosition == currentPosition) | |
return false; | |
swipeToPosition(newPosition, 'reset'); | |
return true; | |
} | |
_this.swipeTo = function(index, speed, runCallbacks) { | |
index = parseInt(index, 10); | |
_this.callPlugins('onSwipeTo', { | |
index: index, | |
speed: speed | |
}); | |
if (params.loop) | |
index = index + _this.loopedSlides; | |
var currentPosition = _this.getWrapperTranslate(); | |
if (index > (_this.slides.length - 1) || index < 0) | |
return; | |
var newPosition | |
if (params.slidesPerView == 'auto') { | |
newPosition =- _this.slidesGrid[index]; | |
} else { | |
newPosition =- index * slideSize; | |
} | |
if (newPosition<- maxWrapperPosition()) { | |
newPosition =- maxWrapperPosition(); | |
}; | |
if (newPosition == currentPosition) | |
return false; | |
runCallbacks = runCallbacks === false ? false : true; | |
swipeToPosition(newPosition, 'to', { | |
index: index, | |
speed: speed, | |
runCallbacks: runCallbacks | |
}); | |
return true; | |
} | |
function swipeToPosition(newPosition, action, toOptions) { | |
var speed = (action == 'to' && toOptions.speed >= 0) ? toOptions.speed: params.speed; | |
if (_this.support.transitions ||!params.DOMAnimation) { | |
_this.setWrapperTranslate(newPosition); | |
_this.setWrapperTransition(speed); | |
} else { | |
var currentPosition = _this.getWrapperTranslate(); | |
var animationStep = Math.ceil((newPosition - currentPosition) / speed * (1000 / 60)); | |
var direction = currentPosition > newPosition ? 'toNext': 'toPrev'; | |
var condition = direction == 'toNext' ? currentPosition > newPosition: currentPosition < newPosition; | |
if (_this._DOMAnimating) | |
return; | |
anim(); | |
} | |
function anim() { | |
currentPosition += animationStep; | |
condition = direction == 'toNext' ? currentPosition > newPosition : currentPosition < newPosition; | |
if (condition) { | |
_this.setWrapperTranslate(Math.round(currentPosition)); | |
_this._DOMAnimating = true | |
window.setTimeout(function() { | |
anim() | |
}, 1000 / 60) | |
} else { | |
if (params.onSlideChangeEnd) | |
_this.fireCallback(params.onSlideChangeEnd, _this); | |
_this.setWrapperTranslate(newPosition); | |
_this._DOMAnimating = false; | |
} | |
} | |
_this.updateActiveSlide(newPosition); | |
if (params.onSlideNext && action == 'next') { | |
_this.fireCallback(params.onSlideNext, _this, newPosition); | |
} | |
if (params.onSlidePrev && action == 'prev') { | |
_this.fireCallback(params.onSlidePrev, _this, newPosition); | |
} | |
if (params.onSlideReset && action == 'reset') { | |
_this.fireCallback(params.onSlideReset, _this, newPosition); | |
} | |
if (action == 'next' || action == 'prev' || (action == 'to' && toOptions.runCallbacks == true)) | |
slideChangeCallbacks(action); | |
} | |
_this._queueStartCallbacks = false; | |
_this._queueEndCallbacks = false; | |
function slideChangeCallbacks(direction) { | |
_this.callPlugins('onSlideChangeStart'); | |
if (params.onSlideChangeStart) { | |
if (params.queueStartCallbacks && _this.support.transitions) { | |
if (_this._queueStartCallbacks) | |
return; | |
_this._queueStartCallbacks = true; | |
_this.fireCallback(params.onSlideChangeStart, _this, direction) | |
_this.wrapperTransitionEnd(function() { | |
_this._queueStartCallbacks = false; | |
}) | |
} else | |
_this.fireCallback(params.onSlideChangeStart, _this, direction) | |
} | |
if (params.onSlideChangeEnd) { | |
if (_this.support.transitions) { | |
if (params.queueEndCallbacks) { | |
if (_this._queueEndCallbacks) | |
return; | |
_this._queueEndCallbacks = true; | |
_this.wrapperTransitionEnd(function(swiper) { | |
_this.fireCallback(params.onSlideChangeEnd, swiper, direction) | |
}) | |
} else | |
_this.wrapperTransitionEnd(function(swiper) { | |
_this.fireCallback(params.onSlideChangeEnd, swiper, direction) | |
}) | |
} else { | |
if (!params.DOMAnimation) { | |
setTimeout(function() { | |
_this.fireCallback(params.onSlideChangeStart, _this, direction) | |
}, 10) | |
} | |
} | |
} | |
} | |
_this.updateActiveSlide = function(position) { | |
if (!_this.initialized) | |
return; | |
if (_this.slides.length == 0) | |
return; | |
_this.previousIndex = _this.activeIndex; | |
if (typeof position == 'undefined') | |
position = _this.getWrapperTranslate(); | |
if (position > 0) | |
position = 0; | |
if (params.slidesPerView == 'auto') { | |
var slidesOffset = 0; | |
_this.activeIndex = _this.slidesGrid.indexOf( - position); | |
if (_this.activeIndex < 0) { | |
for (var i = 0; i < _this.slidesGrid.length - 1; i++) { | |
if ( - position > _this.slidesGrid[i]&&-position < _this.slidesGrid[i + 1]) { | |
break; | |
} | |
} | |
var leftDistance = Math.abs(_this.slidesGrid[i] + position) | |
var rightDistance = Math.abs(_this.slidesGrid[i + 1] + position) | |
if (leftDistance <= rightDistance) | |
_this.activeIndex = i; | |
else | |
_this.activeIndex = i + 1; | |
} | |
} else { | |
_this.activeIndex = Math[params.visibilityFullFit ? 'ceil': 'round']( - position / slideSize); | |
} | |
if (_this.activeIndex == _this.slides.length) | |
_this.activeIndex = _this.slides.length - 1; | |
if (_this.activeIndex < 0) | |
_this.activeIndex = 0; | |
if (!_this.slides[_this.activeIndex]) | |
return; | |
_this.calcVisibleSlides(position); | |
var activeClassRegexp = new RegExp("\\s*" + params.slideActiveClass); | |
var inViewClassRegexp = new RegExp("\\s*" + params.slideVisibleClass); | |
for (var i = 0; i < _this.slides.length; i++) { | |
_this.slides[i].className = _this.slides[i].className.replace(activeClassRegexp, '').replace(inViewClassRegexp, ''); | |
if (_this.visibleSlides.indexOf(_this.slides[i]) >= 0) { | |
_this.slides[i].className += ' ' + params.slideVisibleClass; | |
} | |
} | |
_this.slides[_this.activeIndex].className += ' ' + params.slideActiveClass; | |
if (params.loop) { | |
var ls = _this.loopedSlides; | |
_this.activeLoopIndex = _this.activeIndex - ls; | |
if (_this.activeLoopIndex >= _this.slides.length - ls * 2) { | |
_this.activeLoopIndex = _this.slides.length - ls * 2 - _this.activeLoopIndex; | |
} | |
if (_this.activeLoopIndex < 0) { | |
_this.activeLoopIndex = _this.slides.length - ls * 2 + _this.activeLoopIndex; | |
} | |
} else { | |
_this.activeLoopIndex = _this.activeIndex; | |
} | |
if (params.pagination) { | |
_this.updatePagination(position); | |
} | |
} | |
_this.createPagination = function(firstInit) { | |
if (params.paginationClickable && _this.paginationButtons) { | |
removePaginationEvents(); | |
} | |
_this.paginationContainer = params.pagination.nodeType ? params.pagination : $$(params.pagination)[0]; | |
if (params.createPagination) { | |
var paginationHTML = ""; | |
var numOfSlides = _this.slides.length; | |
var numOfButtons = numOfSlides; | |
if (params.loop) | |
numOfButtons -= _this.loopedSlides * 2 | |
for (var i = 0; i < numOfButtons; i++) { | |
paginationHTML += '<' + params.paginationElement + ' class="' + params.paginationElementClass + '"></' + params.paginationElement + '>' | |
} | |
_this.paginationContainer.innerHTML = paginationHTML; | |
} | |
_this.paginationButtons = $$('.' + params.paginationElementClass, _this.paginationContainer); | |
if (!firstInit) | |
_this.updatePagination() | |
_this.callPlugins('onCreatePagination'); | |
if (params.paginationClickable) { | |
addPaginationEvents(); | |
} | |
} | |
function removePaginationEvents() { | |
var pagers = _this.paginationButtons; | |
for (var i = 0; i < pagers.length; i++) { | |
_this.h.removeEventListener(pagers[i], 'click', paginationClick); | |
} | |
} | |
function addPaginationEvents() { | |
var pagers = _this.paginationButtons; | |
for (var i = 0; i < pagers.length; i++) { | |
_this.h.addEventListener(pagers[i], 'click', paginationClick); | |
} | |
} | |
function paginationClick(e) { | |
var index; | |
var target = e.target || e.srcElement; | |
var pagers = _this.paginationButtons; | |
for (var i = 0; i < pagers.length; i++) { | |
if (target === pagers[i]) | |
index = i; | |
} | |
_this.swipeTo(index) | |
} | |
_this.updatePagination = function(position) { | |
if (!params.pagination) | |
return; | |
if (_this.slides.length < 1) | |
return; | |
var activePagers = $$('.' + params.paginationActiveClass, _this.paginationContainer); | |
if (!activePagers) | |
return; | |
var pagers = _this.paginationButtons; | |
if (pagers.length == 0) | |
return; | |
for (var i = 0; i < pagers.length; i++) { | |
pagers[i].className = params.paginationElementClass | |
} | |
var indexOffset = params.loop ? _this.loopedSlides: 0; | |
if (params.paginationAsRange) { | |
if (!_this.visibleSlides) | |
_this.calcVisibleSlides(position) | |
var visibleIndexes = []; | |
for (var i = 0; i < _this.visibleSlides.length; i++) { | |
var visIndex = _this.slides.indexOf(_this.visibleSlides[i]) - indexOffset | |
if (params.loop && visIndex < 0) { | |
visIndex = _this.slides.length - _this.loopedSlides * 2 + visIndex; | |
} | |
if (params.loop && visIndex >= _this.slides.length - _this.loopedSlides * 2) { | |
visIndex = _this.slides.length - _this.loopedSlides * 2 - visIndex; | |
visIndex = Math.abs(visIndex) | |
} | |
visibleIndexes.push(visIndex) | |
} | |
for (i = 0; i < visibleIndexes.length; i++) { | |
if (pagers[visibleIndexes[i]]) | |
pagers[visibleIndexes[i]].className += ' ' + params.paginationVisibleClass; | |
} | |
if (params.loop) { | |
pagers[_this.activeLoopIndex].className += ' ' + params.paginationActiveClass; | |
} else { | |
pagers[_this.activeIndex].className += ' ' + params.paginationActiveClass; | |
} | |
} else { | |
if (params.loop) { | |
pagers[_this.activeLoopIndex].className += ' ' + params.paginationActiveClass + ' ' + params.paginationVisibleClass; | |
} else { | |
pagers[_this.activeIndex].className += ' ' + params.paginationActiveClass + ' ' + params.paginationVisibleClass; | |
} | |
} | |
} | |
_this.calcVisibleSlides = function(position) { | |
var visibleSlides = []; | |
var _slideLeft = 0, _slideSize = 0, _slideRight = 0; | |
if (isH && _this.wrapperLeft > 0) | |
position = position + _this.wrapperLeft; | |
if (!isH && _this.wrapperTop > 0) | |
position = position + _this.wrapperTop; | |
for (var i = 0; i < _this.slides.length; i++) { | |
_slideLeft += _slideSize; | |
if (params.slidesPerView == 'auto') | |
_slideSize = isH ? _this.h.getWidth(_this.slides[i], true) : _this.h.getHeight(_this.slides[i], true); | |
else | |
_slideSize = slideSize; | |
_slideRight = _slideLeft + _slideSize; | |
var isVisibile = false; | |
if (params.visibilityFullFit) { | |
if (_slideLeft>=-position && _slideRight<=-position + containerSize) | |
isVisibile = true; | |
if (_slideLeft<=-position && _slideRight>=-position + containerSize) | |
isVisibile = true; | |
} else { | |
if (_slideRight>-position && _slideRight <= (( - position + containerSize))) | |
isVisibile = true; | |
if (_slideLeft>=-position && _slideLeft < (( - position + containerSize))) | |
isVisibile = true; | |
if (_slideLeft<-position && _slideRight > (( - position + containerSize))) | |
isVisibile = true; | |
} | |
if (isVisibile) | |
visibleSlides.push(_this.slides[i]) | |
} | |
if (visibleSlides.length == 0) | |
visibleSlides = [_this.slides[_this.activeIndex]] | |
_this.visibleSlides = visibleSlides; | |
} | |
var autoplayTimeoutId = undefined; | |
_this.startAutoplay = function() { | |
if (typeof autoplayTimeoutId !== 'undefined') | |
return false; | |
if (!params.autoplay) | |
return; | |
_this.callPlugins('onAutoplayStart'); | |
autoplay(); | |
} | |
_this.stopAutoplay = function(internal) { | |
if (autoplayTimeoutId) | |
clearTimeout(autoplayTimeoutId); | |
autoplayTimeoutId = undefined; | |
if (internal&&!params.autoplayDisableOnInteraction) { | |
_this.wrapperTransitionEnd(function() { | |
autoplay(); | |
}) | |
} | |
_this.callPlugins('onAutoplayStop'); | |
} | |
function autoplay() { | |
autoplayTimeoutId = setTimeout(function() { | |
if (params.loop) { | |
_this.fixLoop(); | |
_this.swipeNext(true); | |
} else if (!_this.swipeNext(true)) | |
_this.swipeTo(0); | |
_this.wrapperTransitionEnd(function() { | |
if (typeof autoplayTimeoutId !== 'undefined') | |
autoplay(); | |
}) | |
}, params.autoplay) | |
} | |
_this.loopCreated = false; | |
_this.removeLoopedSlides = function() { | |
if (_this.loopCreated) { | |
for (var i = 0; i < _this.slides.length; i++) { | |
if (_this.slides[i].getData('looped') === true) | |
_this.wrapper.removeChild(_this.slides[i]); | |
} | |
} | |
} | |
_this.createLoop = function() { | |
if (_this.slides.length == 0) | |
return; | |
if (params.slidesPerView == 'auto') { | |
_this.loopedSlides = params.loopedSlides || 1; | |
} else { | |
_this.loopedSlides = params.slidesPerView + params.loopAdditionalSlides; | |
} | |
if (_this.loopedSlides > _this.slides.length) { | |
_this.loopedSlides = _this.slides.length; | |
} | |
var slideFirstHTML = '', slideLastHTML = '', i; | |
var slidesSetFullHTML = ''; | |
var numSlides = _this.slides.length; | |
var fullSlideSets = Math.floor(_this.loopedSlides / numSlides); | |
var remainderSlides = _this.loopedSlides%numSlides; | |
for (i = 0; i < (fullSlideSets * numSlides); i++) { | |
var j = i; | |
if (i >= numSlides) { | |
var over = Math.floor(i / numSlides); | |
j = i - (numSlides * over); | |
} | |
slidesSetFullHTML += _this.slides[j].outerHTML; | |
} | |
for (i = 0; i < remainderSlides; i++) { | |
slideLastHTML += _this.slides[i].outerHTML; | |
} | |
for (i = numSlides - remainderSlides; i < numSlides; i++) { | |
slideFirstHTML += _this.slides[i].outerHTML; | |
} | |
var slides = slideFirstHTML + slidesSetFullHTML + wrapper.innerHTML + slidesSetFullHTML + slideLastHTML; | |
wrapper.innerHTML = slides; | |
_this.loopCreated = true; | |
_this.calcSlides(); | |
for (i = 0; i < _this.slides.length; i++) { | |
if (i < _this.loopedSlides || i >= _this.slides.length - _this.loopedSlides) | |
_this.slides[i].setData('looped', true); | |
} | |
_this.callPlugins('onCreateLoop'); | |
} | |
_this.fixLoop = function() { | |
var newIndex; | |
if (_this.activeIndex < _this.loopedSlides) { | |
newIndex = _this.slides.length - _this.loopedSlides * 3 + _this.activeIndex; | |
_this.swipeTo(newIndex, 0, false); | |
} else if (_this.activeIndex > _this.slides.length - params.slidesPerView * 2) { | |
newIndex =- _this.slides.length + _this.activeIndex + _this.loopedSlides | |
_this.swipeTo(newIndex, 0, false); | |
} | |
} | |
_this.loadSlides = function() { | |
var slidesHTML = ''; | |
_this.activeLoaderIndex = 0; | |
var slides = params.loader.slides; | |
var slidesToLoad = params.loader.loadAllSlides ? slides.length: params.slidesPerView * (1 + params.loader.surroundGroups); | |
for (var i = 0; i < slidesToLoad; i++) { | |
if (params.loader.slidesHTMLType == 'outer') | |
slidesHTML += slides[i]; | |
else { | |
slidesHTML += '<' + params.slideElement + ' class="' + params.slideClass + '" data-swiperindex="' + i + '">' + slides[i] + '</' + params.slideElement + '>'; | |
} | |
} | |
_this.wrapper.innerHTML = slidesHTML; | |
_this.calcSlides(true); | |
if (!params.loader.loadAllSlides) { | |
_this.wrapperTransitionEnd(_this.reloadSlides, true); | |
} | |
} | |
_this.reloadSlides = function() { | |
var slides = params.loader.slides; | |
var newActiveIndex = parseInt(_this.activeSlide().data('swiperindex'), 10) | |
if (newActiveIndex < 0 || newActiveIndex > slides.length - 1) | |
return | |
_this.activeLoaderIndex = newActiveIndex; | |
var firstIndex = Math.max(0, newActiveIndex - params.slidesPerView * params.loader.surroundGroups) | |
var lastIndex = Math.min(newActiveIndex + params.slidesPerView * (1 + params.loader.surroundGroups) - 1, slides.length - 1) | |
if (newActiveIndex > 0) { | |
var newTransform =- slideSize * (newActiveIndex - firstIndex) | |
_this.setWrapperTranslate(newTransform); | |
_this.setWrapperTransition(0); | |
} | |
if (params.loader.logic === 'reload') { | |
_this.wrapper.innerHTML = ''; | |
var slidesHTML = ''; | |
for (var i = firstIndex; i <= lastIndex; i++) { | |
slidesHTML += params.loader.slidesHTMLType == 'outer' ? slides[i] : '<' + params.slideElement + ' class="' + params.slideClass + '" data-swiperindex="' + i + '">' + slides[i] + '</' + params.slideElement + '>'; | |
} | |
_this.wrapper.innerHTML = slidesHTML; | |
} else { | |
var minExistIndex = 1000; | |
var maxExistIndex = 0; | |
for (var i = 0; i < _this.slides.length; i++) { | |
var index = _this.slides[i].data('swiperindex'); | |
if (index < firstIndex || index > lastIndex) { | |
_this.wrapper.removeChild(_this.slides[i]); | |
} else { | |
minExistIndex = Math.min(index, minExistIndex) | |
maxExistIndex = Math.max(index, maxExistIndex) | |
} | |
} | |
for (var i = firstIndex; i <= lastIndex; i++) { | |
if (i < minExistIndex) { | |
var newSlide = document.createElement(params.slideElement); | |
newSlide.className = params.slideClass; | |
newSlide.setAttribute('data-swiperindex', i); | |
newSlide.innerHTML = slides[i]; | |
_this.wrapper.insertBefore(newSlide, _this.wrapper.firstChild); | |
} | |
if (i > maxExistIndex) { | |
var newSlide = document.createElement(params.slideElement); | |
newSlide.className = params.slideClass; | |
newSlide.setAttribute('data-swiperindex', i); | |
newSlide.innerHTML = slides[i]; | |
_this.wrapper.appendChild(newSlide); | |
} | |
} | |
} | |
_this.reInit(true); | |
} | |
function makeSwiper() { | |
_this.calcSlides(); | |
if (params.loader.slides.length > 0 && _this.slides.length == 0) { | |
_this.loadSlides(); | |
} | |
if (params.loop) { | |
_this.createLoop(); | |
} | |
_this.init(); | |
initEvents(); | |
if (params.pagination) { | |
_this.createPagination(true); | |
} | |
if (params.loop || params.initialSlide > 0) { | |
_this.swipeTo(params.initialSlide, 0, false); | |
} else { | |
_this.updateActiveSlide(0); | |
} | |
if (params.autoplay) { | |
_this.startAutoplay(); | |
} | |
_this.centerIndex = _this.activeIndex; | |
if (params.onSwiperCreated) | |
_this.fireCallback(params.onSwiperCreated, _this); | |
_this.callPlugins('onSwiperCreated'); | |
} | |
makeSwiper(); | |
} | |
Swiper.prototype = { | |
plugins: {}, | |
wrapperTransitionEnd: function(callback, permanent) { | |
var a = this, el = a.wrapper, events = ['webkitTransitionEnd', 'transitionend', 'oTransitionEnd', 'MSTransitionEnd', 'msTransitionEnd'], i; | |
function fireCallBack() { | |
callback(a); | |
if (a.params.queueEndCallbacks) | |
a._queueEndCallbacks = false; | |
if (!permanent) { | |
for (i = 0; i < events.length; i++) { | |
a.h.removeEventListener(el, events[i], fireCallBack); | |
} | |
} | |
} | |
if (callback) { | |
for (i = 0; i < events.length; i++) { | |
a.h.addEventListener(el, events[i], fireCallBack); | |
} | |
} | |
}, | |
getWrapperTranslate: function(axis) { | |
var el = this.wrapper, matrix, curTransform, curStyle, transformMatrix; | |
if (typeof axis == 'undefined') { | |
axis = this.params.mode == 'horizontal' ? 'x' : 'y'; | |
} | |
if (this.support.transforms && this.params.useCSS3Transforms) { | |
curStyle = window.getComputedStyle(el, null); | |
if (window.WebKitCSSMatrix) { | |
transformMatrix = new WebKitCSSMatrix(curStyle.webkitTransform); | |
} else { | |
transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue("transform").replace("translate(", "matrix(1, 0, 0, 1,"); | |
matrix = transformMatrix.toString().split(','); | |
} | |
if (axis == 'x') { | |
if (window.WebKitCSSMatrix) | |
curTransform = transformMatrix.m41; | |
else if (matrix.length == 16) | |
curTransform = parseFloat(matrix[12]); | |
else | |
curTransform = parseFloat(matrix[4]); | |
} | |
if (axis == 'y') { | |
if (window.WebKitCSSMatrix) | |
curTransform = transformMatrix.m42; | |
else if (matrix.length == 16) | |
curTransform = parseFloat(matrix[13]); | |
else | |
curTransform = parseFloat(matrix[5]); | |
} | |
} else { | |
if (axis == 'x') | |
curTransform = parseFloat(el.style.left, 10) || 0; | |
if (axis == 'y') | |
curTransform = parseFloat(el.style.top, 10) || 0; | |
} | |
return curTransform || 0; | |
}, | |
setWrapperTranslate: function(x, y, z) { | |
var es = this.wrapper.style, coords = { | |
x: 0, | |
y: 0, | |
z: 0 | |
}, translate; | |
if (arguments.length == 3) { | |
coords.x = x; | |
coords.y = y; | |
coords.z = z; | |
} else { | |
if (typeof y == 'undefined') { | |
y = this.params.mode == 'horizontal' ? 'x' : 'y'; | |
} | |
coords[y] = x; | |
} | |
if (this.support.transforms && this.params.useCSS3Transforms) { | |
translate = this.support.transforms3d ? 'translate3d(' + coords.x + 'px, ' + coords.y + 'px, ' + coords.z + 'px)' : 'translate(' + coords.x + 'px, ' + coords.y + 'px)'; | |
es.webkitTransform = es.MsTransform = es.msTransform = es.MozTransform = es.OTransform = es.transform = translate; | |
} else { | |
es.left = coords.x + 'px'; | |
es.top = coords.y + 'px'; | |
} | |
this.callPlugins('onSetWrapperTransform', coords); | |
if (this.params.onSetWrapperTransform) | |
this.fireCallback(this.params.onSetWrapperTransform, this, coords); | |
}, | |
setWrapperTransition: function(duration) { | |
var es = this.wrapper.style; | |
es.webkitTransitionDuration = es.MsTransitionDuration = es.msTransitionDuration = es.MozTransitionDuration = es.OTransitionDuration = es.transitionDuration = (duration / 1000) + 's'; | |
this.callPlugins('onSetWrapperTransition', { | |
duration: duration | |
}); | |
if (this.params.onSetWrapperTransition) | |
this.fireCallback(this.params.onSetWrapperTransition, this, duration); | |
}, | |
h: { | |
getWidth: function(el, outer) { | |
var width = window.getComputedStyle(el, null).getPropertyValue('width') | |
var returnWidth = parseFloat(width); | |
if (isNaN(returnWidth) || width.indexOf('%') > 0) { | |
returnWidth = el.offsetWidth - parseFloat(window.getComputedStyle(el, null).getPropertyValue('padding-left')) - parseFloat(window.getComputedStyle(el, null).getPropertyValue('padding-right')); | |
} | |
if (outer) | |
returnWidth += parseFloat(window.getComputedStyle(el, null).getPropertyValue('padding-left')) + parseFloat(window.getComputedStyle(el, null).getPropertyValue('padding-right')) | |
return returnWidth; | |
}, | |
getHeight: function(el, outer) { | |
if (outer) | |
return el.offsetHeight; | |
var height = window.getComputedStyle(el, null).getPropertyValue('height') | |
var returnHeight = parseFloat(height); | |
if (isNaN(returnHeight) || height.indexOf('%') > 0) { | |
returnHeight = el.offsetHeight - parseFloat(window.getComputedStyle(el, null).getPropertyValue('padding-top')) - parseFloat(window.getComputedStyle(el, null).getPropertyValue('padding-bottom')); | |
} | |
if (outer) | |
returnHeight += parseFloat(window.getComputedStyle(el, null).getPropertyValue('padding-top')) + parseFloat(window.getComputedStyle(el, null).getPropertyValue('padding-bottom')) | |
return returnHeight; | |
}, | |
getOffset: function(el) { | |
var box = el.getBoundingClientRect(); | |
var body = document.body; | |
var clientTop = el.clientTop || body.clientTop || 0; | |
var clientLeft = el.clientLeft || body.clientLeft || 0; | |
var scrollTop = window.pageYOffset || el.scrollTop; | |
var scrollLeft = window.pageXOffset || el.scrollLeft; | |
if (document.documentElement&&!window.pageYOffset) { | |
scrollTop = document.documentElement.scrollTop; | |
scrollLeft = document.documentElement.scrollLeft; | |
} | |
return { | |
top: box.top + scrollTop - clientTop, | |
left: box.left + scrollLeft - clientLeft | |
}; | |
}, | |
windowWidth: function() { | |
if (window.innerWidth) | |
return window.innerWidth | |
else if (document.documentElement && document.documentElement.clientWidth) | |
return document.documentElement.clientWidth; | |
}, | |
windowHeight: function() { | |
if (window.innerHeight) | |
return window.innerHeight | |
else if (document.documentElement && document.documentElement.clientHeight) | |
return document.documentElement.clientHeight; | |
}, | |
windowScroll: function() { | |
var left = 0, top = 0; | |
if (typeof pageYOffset != 'undefined') { | |
return { | |
left: window.pageXOffset, | |
top: window.pageYOffset | |
} | |
} else if (document.documentElement) { | |
return { | |
left: document.documentElement.scrollLeft, | |
top: document.documentElement.scrollTop | |
} | |
} | |
}, | |
addEventListener: function(el, event, listener, useCapture) { | |
if (typeof useCapture == 'undefined') { | |
useCapture = false; | |
} | |
if (el.addEventListener) { | |
el.addEventListener(event, listener, useCapture); | |
} else if (el.attachEvent) { | |
el.attachEvent('on' + event, listener); | |
} | |
}, | |
removeEventListener: function(el, event, listener, useCapture) { | |
if (typeof useCapture == 'undefined') { | |
useCapture = false; | |
} | |
if (el.removeEventListener) { | |
el.removeEventListener(event, listener, useCapture); | |
} else if (el.detachEvent) { | |
el.detachEvent('on' + event, listener); | |
} | |
} | |
}, | |
setTransform: function(el, transform) { | |
var es = el.style | |
es.webkitTransform = es.MsTransform = es.msTransform = es.MozTransform = es.OTransform = es.transform = transform | |
}, | |
setTranslate: function(el, translate) { | |
var es = el.style | |
var pos = { | |
x: translate.x || 0, | |
y: translate.y || 0, | |
z: translate.z || 0 | |
}; | |
var transformString = this.support.transforms3d ? 'translate3d(' + (pos.x) + 'px,' + (pos.y) + 'px,' + (pos.z) + 'px)': 'translate(' + (pos.x) + 'px,' + (pos.y) + 'px)'; | |
es.webkitTransform = es.MsTransform = es.msTransform = es.MozTransform = es.OTransform = es.transform = transformString; | |
if (!this.support.transforms) { | |
es.left = pos.x + 'px' | |
es.top = pos.y + 'px' | |
} | |
}, | |
setTransition: function(el, duration) { | |
var es = el.style | |
es.webkitTransitionDuration = es.MsTransitionDuration = es.msTransitionDuration = es.MozTransitionDuration = es.OTransitionDuration = es.transitionDuration = duration + 'ms'; | |
}, | |
support: { | |
touch: (window.Modernizr && Modernizr.touch === true) || (function() { | |
return !!(("ontouchstart"in window) || window.DocumentTouch && document instanceof DocumentTouch); | |
})(), | |
transforms3d: (window.Modernizr && Modernizr.csstransforms3d === true) || (function() { | |
var div = document.createElement('div').style; | |
return ("webkitPerspective"in div || "MozPerspective"in div || "OPerspective"in div || "MsPerspective"in div || "perspective"in div); | |
})(), | |
transforms: (window.Modernizr && Modernizr.csstransforms === true) || (function() { | |
var div = document.createElement('div').style; | |
return ('transform'in div || 'WebkitTransform'in div || 'MozTransform'in div || 'msTransform'in div || 'MsTransform'in div || 'OTransform'in div); | |
})(), | |
transitions: (window.Modernizr && Modernizr.csstransitions === true) || (function() { | |
var div = document.createElement('div').style; | |
return ('transition'in div || 'WebkitTransition'in div || 'MozTransition'in div || 'msTransition'in div || 'MsTransition'in div || 'OTransition'in div); | |
})() | |
}, | |
browser: { | |
ie8: (function() { | |
var rv =- 1; | |
if (navigator.appName == 'Microsoft Internet Explorer') { | |
var ua = navigator.userAgent; | |
var re = new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})"); | |
if (re.exec(ua) != null) | |
rv = parseFloat(RegExp.$1); | |
} | |
return rv!=-1 && rv < 9; | |
})(), | |
ie10: window.navigator.msPointerEnabled | |
} | |
} | |
if (window.jQuery || window.Zepto) { | |
(function($) { | |
$.fn.swiper = function(params) { | |
var s = new Swiper($(this)[0], params) | |
$(this).data('swiper', s); | |
return s; | |
} | |
})(window.jQuery || window.Zepto) | |
} | |
if (typeof(module) !== 'undefined') | |
{ | |
module.exports = Swiper; | |
} | |
Swiper.prototype.plugins.scrollbar = function(swiper, params) { | |
var enabled = params && params.container; | |
if (!enabled) | |
return; | |
var defaults = { | |
hide: true, | |
draggable: true, | |
snapOnRelease: false | |
} | |
params = params || {}; | |
for (var prop in defaults) { | |
if (!(prop in params)) { | |
params[prop] = defaults[prop] | |
} | |
} | |
if (!document.querySelectorAll) { | |
if (!window.jQuery) | |
return; | |
} | |
function $$(s) { | |
if (document.querySelectorAll) | |
return document.querySelectorAll(s) | |
else | |
return jQuery(s) | |
} | |
if (!(params.container.nodeType)) { | |
if ($$(params.container).length == 0) | |
return; | |
} | |
var container = (params.container.nodeType) ? params.container: $$(params.container)[0]; | |
var isH = swiper.params.mode == 'horizontal', track = container, trackWidth, trackHeight, divider, moveDivider, dragWidth, dragHeight; | |
var drag = document.createElement('div') | |
drag.className = 'swiper-scrollbar-drag'; | |
if (params.draggable) | |
drag.className += ' swiper-scrollbar-cursor-drag'; | |
track.appendChild(drag); | |
if (params.hide) | |
track.style.opacity = 0; | |
var te = swiper.touchEvents | |
if (params.draggable) { | |
var isTouched = false; | |
function dragStart(e) { | |
isTouched = true; | |
if (e.preventDefault) | |
e.preventDefault(); | |
else | |
e.returnValue = false; | |
setDragPosition(e); | |
clearTimeout(timeout); | |
swiper.setTransition(track, 0) | |
track.style.opacity = 1; | |
swiper.setWrapperTransition(100); | |
swiper.setTransition(drag, 100) | |
if (params.onScrollbarDrag) { | |
params.onScrollbarDrag(swiper) | |
} | |
} | |
function dragMove(e) { | |
if (!isTouched) | |
return; | |
if (e.preventDefault) | |
e.preventDefault(); | |
else | |
e.returnValue = false; | |
setDragPosition(e); | |
swiper.setWrapperTransition(0); | |
swiper.setTransition(track, 0) | |
swiper.setTransition(drag, 0) | |
if (params.onScrollbarDrag) { | |
params.onScrollbarDrag(swiper) | |
} | |
} | |
function dragEnd(e) { | |
isTouched = false; | |
if (params.hide) { | |
clearTimeout(timeout) | |
timeout = setTimeout(function() { | |
track.style.opacity = 0; | |
swiper.setTransition(track, 400) | |
}, 1000) | |
} | |
if (params.snapOnRelease) { | |
swiper.swipeReset() | |
} | |
} | |
var lestenEl = swiper.support.touch ? track: document | |
swiper.h.addEventListener(track, te.touchStart, dragStart, false) | |
swiper.h.addEventListener(lestenEl, te.touchMove, dragMove, false) | |
swiper.h.addEventListener(lestenEl, te.touchEnd, dragEnd, false) | |
function setDragPosition(e) { | |
var x = y = 0; | |
var position; | |
if (isH) { | |
var pageX = (e.type == 'touchstart' || e.type == 'touchmove') ? e.targetTouches[0].pageX: e.pageX || e.clientX; | |
x = (pageX) - swiper.h.getOffset(track).left - dragWidth / 2 | |
if (x < 0) | |
x = 0; | |
else if ((x + dragWidth) > trackWidth) { | |
x = trackWidth - dragWidth; | |
} | |
} else { | |
var pageY = (e.type == 'touchstart' || e.type == 'touchmove') ? e.targetTouches[0].pageY: e.pageY || e.clientY; | |
y = (pageY) - swiper.h.getOffset(track).top - dragHeight / 2; | |
if (y < 0) | |
y = 0; | |
else if ((y + dragHeight) > trackHeight) { | |
y = trackHeight - dragHeight; | |
} | |
} | |
swiper.setTranslate(drag, { | |
x: x, | |
y: y | |
}) | |
var wrapX =- x / moveDivider; | |
var wrapY =- y / moveDivider; | |
swiper.setWrapperTranslate(wrapX, wrapY, 0) | |
swiper.updateActiveSlide(isH ? wrapX : wrapY); | |
} | |
} | |
function setScrollBars() { | |
drag.style.width = '' | |
drag.style.height = '' | |
if (isH) { | |
trackWidth = swiper.h.getWidth(track, true); | |
divider = swiper.width / (swiper.h.getWidth(swiper.wrapper) + swiper.wrapperLeft + swiper.wrapperRight); | |
moveDivider = divider * (trackWidth / swiper.width); | |
dragWidth = trackWidth * divider; | |
drag.style.width = dragWidth + 'px'; | |
} else { | |
trackHeight = swiper.h.getHeight(track, true); | |
divider = swiper.height / (swiper.h.getHeight(swiper.wrapper) + swiper.wrapperTop + swiper.wrapperBottom); | |
moveDivider = divider * (trackHeight / swiper.height); | |
dragHeight = trackHeight * divider; | |
if (dragHeight > trackHeight) | |
dragHeight = trackHeight | |
drag.style.height = dragHeight + 'px'; | |
} | |
if (divider >= 1) { | |
container.style.display = 'none' | |
} else { | |
container.style.display = '' | |
} | |
} | |
var timeout; | |
var hooks = { | |
onFirstInit: function(args) { | |
setScrollBars() | |
}, | |
onInit: function(args) { | |
setScrollBars() | |
}, | |
onTouchMoveEnd: function(args) { | |
if (params.hide) { | |
clearTimeout(timeout) | |
track.style.opacity = 1; | |
swiper.setTransition(track, 200) | |
} | |
}, | |
onTouchEnd: function(args) { | |
if (params.hide) { | |
clearTimeout(timeout) | |
timeout = setTimeout(function() { | |
track.style.opacity = 0; | |
swiper.setTransition(track, 400) | |
}, 1000) | |
} | |
}, | |
onSetWrapperTransform: function(pos) { | |
if (isH) { | |
var newLeft = pos.x * moveDivider; | |
var newWidth = dragWidth; | |
if (newLeft > 0) { | |
var diff = newLeft; | |
newLeft = 0; | |
newWidth = dragWidth - diff; | |
} else if (( - newLeft + dragWidth) > trackWidth) { | |
newWidth = trackWidth + newLeft; | |
} | |
swiper.setTranslate(drag, { | |
x: - newLeft | |
}) | |
drag.style.width = newWidth + 'px'; | |
} else { | |
var newTop = pos.y * moveDivider; | |
var newHeight = dragHeight; | |
if (newTop > 0) { | |
var diff = newTop; | |
newTop = 0; | |
newHeight = dragHeight - diff; | |
} else if (( - newTop + dragHeight) > trackHeight) { | |
newHeight = trackHeight + newTop; | |
} | |
swiper.setTranslate(drag, { | |
y: - newTop | |
}) | |
drag.style.height = newHeight + 'px'; | |
} | |
if (swiper.params.freeMode && params.hide) { | |
clearTimeout(timeout) | |
track.style.opacity = 1; | |
timeout = setTimeout(function() { | |
track.style.opacity = 0; | |
swiper.setTransition(track, 400) | |
}, 1000) | |
} | |
}, | |
onSetWrapperTransition: function(args) { | |
swiper.setTransition(drag, args.duration) | |
}, | |
onDestroy: function() { | |
var lestenEl = swiper.support.touch ? track: document | |
swiper.h.removeEventListener(track, te.touchStart, dragStart, false) | |
swiper.h.removeEventListener(lestenEl, te.touchMove, dragMove, false) | |
swiper.h.removeEventListener(lestenEl, te.touchEnd, dragEnd, false) | |
} | |
} | |
return hooks; | |
} | |
// Vars | |
var jqWin = $(window); | |
var jqHTML = $('html'); | |
var jqBody = $('body'); | |
var preloadTimer; | |
var appInfo = { | |
name: "PRPL.rs", | |
description: "PRPL.rs powered by Angular and the WordPress JSON API Plugin", | |
version: { | |
'name': 'X', | |
'number': '1.5' | |
} | |
}; | |
var glob = {} | |
glob.canAnimate = false; | |
/* Angular App Setup (ngPRPL) | |
************************************************************************ */ | |
var ngPRPL = angular.module('PRPL', | |
['ngRoute', 'ngAnimate', 'ngResource', 'ngSanitize', 'prplAnimator', 'angulartics', 'angulartics.google.tagmanager'] | |
); | |
ngPRPL.config([ | |
'$routeProvider', | |
'$locationProvider', | |
function($routeProvider, $locationProvider) { | |
// remove the hashbang from the URL | |
$locationProvider.html5Mode(true).hashPrefix('!'); | |
// set up routes and associated controllers | |
$routeProvider | |
.when('/', { | |
controller: 'HomeController', | |
templateUrl: '/views/main.html' | |
}) | |
.when('/about', { | |
controller: 'AboutController', | |
templateUrl: '/views/about.html' | |
}) | |
.when('/process', { | |
controller: 'ProcessController', | |
templateUrl: '/views/process.html' | |
}) | |
.when('/work', { | |
controller: 'CaseStudiesController', | |
templateUrl: '/views/case-studies.html' | |
}) | |
.when('/work/rmcad', { | |
controller: 'RMCADController', | |
templateUrl: '/views/case-studies/rmcad.html' | |
}) | |
.when('/work/videri', { | |
controller: 'VideriController', | |
templateUrl: '/views/case-studies/videri.html' | |
}) | |
.when('/work/4-rivers', { | |
controller: 'FourRiversController', | |
templateUrl: '/views/case-studies/4rivers.html' | |
}) | |
.when('/work/davidoff', { | |
controller: 'DavidoffController', | |
templateUrl: '/views/case-studies/davidoff.html' | |
}) | |
.when('/work/adu', { | |
controller: 'ADUController', | |
templateUrl: '/views/case-studies/adu.html' | |
}) | |
.when('/work/nasa', { | |
controller: 'NASAController', | |
templateUrl: '/views/case-studies/nasa.html' | |
}) | |
.when('/work/cisco', { | |
controller: 'CiscoController', | |
templateUrl: '/views/case-studies/cisco.html' | |
}) | |
.when('/work/fleetgistics', { | |
controller: 'FleetgisticsController', | |
templateUrl: '/views/case-studies/fleetgistics.html' | |
}) | |
.when('/work/ouc', { | |
controller: 'OUCController', | |
templateUrl: '/views/case-studies/ouc.html' | |
}) | |
.when('/careers', { | |
controller: 'CareersController', | |
templateUrl: '/views/careers.html', | |
reloadOnSearch: false | |
}) | |
.when('/careers/:slug', { | |
controller: 'CareersController', | |
templateUrl: '/views/careers.html' | |
}) | |
.when('/careers/:slug/:apply', { | |
controller: 'CareersController', | |
templateUrl: '/views/careers.html' | |
}) | |
.when('/contact', { | |
controller: 'ContactController', | |
templateUrl: '/views/contact.html' | |
}) | |
.when('/contact/:slug', { | |
controller: 'ContactController', | |
templateUrl: '/views/contact.html', | |
reloadOnSearch: false | |
}) | |
.when('/notes', { | |
controller: 'BlogListController', | |
templateUrl: '/views/notes.html' | |
}) | |
.when('/notes/:cat', { | |
controller: 'BlogListController', | |
templateUrl: '/views/notes.html' | |
}) | |
.when('/notes/:id/:slug', { | |
controller: 'BlogPostController', | |
templateUrl: '/views/note.html' | |
}) | |
.when('/privacy', { | |
controller: 'PrivacyPolicyController', | |
templateUrl: '/views/privacy.html' | |
}) | |
.when('/mutual-nda', { | |
controller: 'NonDisclosureAgreementController', | |
templateUrl: '/views/nda.html' | |
}) | |
.when('/master-agreement', { | |
controller: 'MasterAgreementController', | |
templateUrl: '/views/msa.html' | |
}) | |
.when('/fla', { | |
controller: 'FacilityLicenseAgreementController', | |
templateUrl: '/views/fla.html' | |
}) | |
.when('/facility-license-agreement', { | |
controller: 'FacilityLicenseAgreementController', | |
templateUrl: '/views/fla.html' | |
}) | |
.when('/facility-agreement', { | |
controller: 'FacilityLicenseAgreementController', | |
templateUrl: '/views/fla.html' | |
}) | |
.when('/csa', { | |
controller: 'ConsultingServicesAgreementController', | |
templateUrl: '/views/csa.html' | |
}) | |
.when('/consulting-services-agreement', { | |
controller: 'ConsultingServicesAgreementController', | |
templateUrl: '/views/csa.html' | |
}) | |
.when('/consulting-services', { | |
controller: 'ConsultingServicesAgreementController', | |
templateUrl: '/views/csa.html' | |
}) | |
.when('/404', { | |
controller: 'ErrorController', | |
templateUrl: '/views/404.html' | |
}) | |
.when('/x/:shortLink', { | |
controller: 'ShortLinkController', | |
templateUrl: '/views/link.html' | |
}) | |
.otherwise({ | |
redirectTo: '/404' | |
}); | |
} | |
]); | |
ngPRPL.run([ | |
'$rootScope', | |
'$location', | |
'$anchorScroll', | |
'$routeParams', | |
'$timeout', | |
function($rootScope, $location, $anchorScroll, $routeParams, $timeout) { | |
$rootScope.$on('$routeChangeSuccess', function(newRoute, oldRoute) { | |
// Manual Page Tracking | |
// console.log(oldRoute); | |
// force loader to remain on link page | |
if (oldRoute.loadedTemplateUrl !== "/views/link.html") { | |
setTimeout(function() { | |
$('body').removeClass('preloading').addClass('loaded'); | |
}, 1500); | |
} | |
// setup scrollTo param and force scroll to top, because for some reason thats not default behavior. | |
$timeout(function() { | |
$location.hash($routeParams.scrollTo); | |
$anchorScroll(); | |
$(window).resize(); | |
if ($('.ng-view-wrap').last().find('[data-prpl-poi]').length == 0) { | |
// $('#progress-indicator').addClass('none-found'); | |
$.waypoints('destroy') | |
$('.points-of-interest').removeClass('intro'); | |
} else { | |
// $.waypoints('refresh'); | |
// $('#progress-indicator').removeClass('none-found'); | |
}; | |
}, 50); | |
//blacklist for animations | |
var disallowUrl = { | |
notes: "notes", | |
careers: "careers", | |
about: "about", | |
process: "process" | |
}, | |
pathName = window.location.pathname.split("/"); | |
$timeout(function() { | |
// $('.prpl-bgv').on('canplay', function(){ | |
imagesLoaded('body', function() { | |
// console.log('images loaded') | |
// $('body').removeClass('preloading').addClass('loaded'); | |
}); | |
// }); | |
}, 1000); | |
}); | |
$rootScope.$on('$routeChangeStart', function(newRoute, oldRoute) { | |
// console.log('show loader'); | |
$.waypoints('destroy') | |
$('.points-of-interest').removeClass('intro'); | |
// $('#progress-indicator').addClass('none-found'); | |
// $('#progress-indicator .points-of-interest').removeClass('intro').html(''); | |
// $('body').addClass('preloading').removeClass('loaded'); | |
}); | |
} | |
]); | |
/* 404 Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('ErrorController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', | |
function ($scope, $sanitize, $routeParams, $location) { | |
var GIFcount = 44; | |
var random = Math.floor(Math.random() * (GIFcount - 1 + 1)) + 1; | |
var randomGIF = 'url(../assets/images/404/404_' + random + '.gif)'; | |
$('.hero-404').css('background-image', randomGIF); | |
var copyDest = $('.page-404 .copy'); | |
var copy404 = "Sorry, we can’t find whatever it is you think you want." | |
switch (random) { | |
case 35: | |
copy404 = "Blerg. Sorry, Charlie, this is really bumming us out."; | |
break; | |
case 2: | |
copy404 = "This page ain't ralph tho."; | |
break; | |
case 5: | |
copy404 = "NOOOOOOOOOOO THE PAGE IS GONEEEEEEE"; | |
break; | |
case 8: | |
copy404 = "Uhhhh no way pal, that link is broke." | |
break; | |
case 9: | |
copy404 = "Crap, this is way loose butthole." | |
break; | |
case 15: | |
copy404 = "Your request for this page has been overruled." | |
break; | |
case 30: | |
copy404 = "No way. Like, what are you looking for, again?"; | |
break; | |
case 28: | |
copy404 = "Mmm, no. The road to power is paved with hypocrisy and 404 errors."; | |
break; | |
case 9: | |
copy404 = "Sorry dude, you’re gonna have to get weird somewhere else."; | |
break; | |
case 17: | |
copy404 = "Pfffffft, I don't need no pages."; | |
break; | |
case 4: | |
copy404 = "Oh no honey boo boo child, there is no page here."; | |
break; | |
case 37: | |
copy404 = "Sorry dude, you’re gonna have to get weird somewhere else."; | |
break; | |
case 36: | |
copy404 = "Started from a link and now we're here."; | |
break; | |
case 27: | |
copy404 = "Man f@%! yo' page request, I'm Rick James!" | |
break; | |
case 22: | |
copy404 = "This just in — your page cannot be found."; | |
break; | |
case 38: | |
copy404 = "Therez no page here ya dingus" | |
break; | |
case 39: | |
copy404 = "Have you tried turning it off and on again?" | |
break; | |
case 44: | |
copy404 = "Sometimes you gotta work a little, so you can ball a lot." | |
break; | |
case 45: | |
copy404 = "If at first you don’t succeed then maybe you just suck."; | |
break; | |
default: | |
break; | |
} | |
copyDest.html(copy404); | |
$scope.$parent.navFlag = spacesToNBSP('Oh no, a 404!'); | |
$scope.$parent.seo = { | |
description: 'Purple Rock Scissors / A Digital Creative Agency', | |
keywords: 'Purple Rock Scissors, Design, Development', | |
title: '404 | PRPL.rs' | |
}; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
} | |
]); | |
/* About Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('AboutController', | |
['$scope', '$sanitize', '$resource', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $resource, $location, PRPLEmployee) { | |
// $scope.$parent.navFlag = spacesToNBSP("About"); | |
$scope.$parent.seo = { | |
title: 'About | Purple, Rock, Scissors', | |
description: 'Digital agency PRPL delivers best-in-class experiences and innovation at the forefront of technology. Learn who we are and what we value.', | |
keywords: 'PRPL, digital creative agency, agency think tank, digital agency, digital agency of record, innovation consulting, digital strategy, agency culture' | |
}; | |
$scope.$parent.social = { | |
title: 'PRPL | Purple, Rock, Scissors: A Digital Creative Agency in Orlando', | |
description: 'Digital agency PRPL delivers best-in-class experiences and innovation at the forefront of technology. Learn who we are and what we value.', | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs', | |
photo: 'http://purplerockscissors.com/assets/images/video-posters/final-hero-about.jpg' | |
}; | |
// PULL EMPLOYEE POSTS | |
PRPLEmployee.all(function (res) { | |
// console.info('whole result', res); | |
// var arr = res.result; | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
arr = shuffleArray(arr); | |
// console.info('team array', arr); | |
var gridArr = []; | |
if (arr.length > 0) { | |
var tmp = []; | |
for (var i = 0; i < arr.length; i++) { | |
var obj = {}; | |
obj.show = (exists(arr[i]['wpcf-is-employee']) && arr[i]['wpcf-is-employee'] != '0') ? true : false; | |
if (obj.show !== false) { | |
obj.fName = (exists(arr[i]['first_name'])) ? arr[i]['first_name'][0] : false; | |
obj.lName = (exists(arr[i]['last_name'])) ? arr[i]['last_name'][0] : false; | |
obj.title = (exists(arr[i]['wpcf-job-title'])) ? arr[i]['wpcf-job-title'][0] : false; | |
obj.gifn = (exists(arr[i]['wpcf-gifn'])) ? arr[i]['wpcf-gifn'][0] : false; | |
obj.gifn = (exists(arr[i]['wpcf-gifn'])) ? arr[i]['wpcf-gifn'][0] : false; | |
obj.gifnStatic = (exists(arr[i]['wpcf-gifn-colorized-single-frame'])) ? arr[i]['wpcf-gifn-colorized-single-frame'][0] : false; | |
obj.twitter = (exists(arr[i]['wpcf-twitter'])) ? arr[i]['wpcf-twitter'][0] : false; | |
obj.facebook = (exists(arr[i]['wpcf-facebook'])) ? arr[i]['wpcf-facebook'][0] : false; | |
obj.instagram = (exists(arr[i]['wpcf-instagram'])) ? arr[i]['wpcf-instagram'][0] : false; | |
obj.linkedin = (exists(arr[i]['wpcf-linkedin'])) ? arr[i]['wpcf-linkedin'][0] : false; | |
obj.github = (exists(arr[i]['wpcf-github'])) ? arr[i]['wpcf-github'][0] : false; | |
obj.dribbble = (exists(arr[i]['wpcf-dribbble'])) ? arr[i]['wpcf-dribbble'][0] : false; | |
tmp.push(obj); | |
} | |
}; | |
var arr2 = []; | |
for (var i = 0; i < tmp.length; i++) { | |
arr2.push(tmp[i]); | |
if (i % 3 === 2) { | |
gridArr.push(arr2); | |
arr2 = []; | |
} | |
// push grouping every 3 | |
else if (i === (tmp.length - 1)) { | |
gridArr.push(arr2); | |
} | |
// push partial grouping at end | |
}; | |
// make available to view | |
$scope.gridArray = gridArr; | |
var didHackReset = false; | |
var sliderSel = '.prpl-team-slider .iosslider'; | |
$(sliderSel).iosSlider({ | |
snapToChildren: true, | |
desktopClickDrag: true, | |
snapSlideCenter: true, | |
// responsiveSlides: true, | |
infiniteSlider: true, | |
keyboardControls: true | |
}); | |
PRERENDER_READY(); // utils.js | |
} | |
// makeTeamSwiper('.prpl-team .swiper-container'); | |
setTimeout(function () { | |
$(sliderSel).iosSlider('update').iosSlider('goToSlide', 1); | |
}, 500); | |
$('.prpl-team-slider .fade-to-red-left a').on({ | |
click: function (e) { | |
$(sliderSel).iosSlider('prevSlide'); | |
} | |
}); | |
$('.prpl-team-slider .fade-to-red-right a').on({ | |
click: function (e) { | |
$(sliderSel).iosSlider('nextSlide'); | |
} | |
}); | |
// removePreloader(250); | |
// $scope.htmlReady(); | |
}); | |
} | |
]); | |
/* Global Controller | |
************************************************************************ */ | |
ngPRPL.controller('AppController', | |
['$scope', '$location', '$cacheFactory', 'PRPLBlog', '$timeout', '$anchorScroll', 'PRPLCareers', 'PRPLEmployee', '$analytics', | |
function ($scope, $location, $cacheFactory, PRPLBlog, $timeout, $anchorScroll, PRPLCareers, PRPLEmployee, $analytics) { | |
$scope.activeMenu = false; | |
$scope.activeSpeechMenu = false; | |
$scope.seo = { | |
title: 'PRPL | Purple, Rock, Scissors: A Digital Creative Agency in Orlando', | |
description: 'Purple, Rock, Scissors, a digital creative agency in Orlando, FL, provides digital strategy consultation, innovation, and goal-driven design.', | |
keywords: 'digital agency, orlando agency, digital strategy agency, business intelligence services, digital agency of record, goal-driven design' | |
}; | |
var loc = window.location.href; | |
// console.log(loc); | |
$scope.social = { | |
title: 'PRPL | Purple, Rock, Scissors: A Digital Creative Agency in Orlando', | |
description: 'Purple, Rock, Scissors, a digital creative agency in Orlando, FL, provides digital strategy consultation, innovation, and goal-driven design.', | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs', | |
photo: 'http://purplerockscissors.com/assets/images/social.jpg' | |
}; | |
// failback | |
$timeout(function() { | |
$('#site-loader em').addClass('show'); | |
}, 8000); | |
// Globalise parze | |
Parse.initialize("03qVAe3sC1Gzxc6Llav7qTg2lr1X2IS1N2PaWXf7", "48fUyDNU35jSFbfombXs8tpDWc5T79S0Tt8TGpuW"); | |
// PRPLBlog.getPosts(); | |
// PRPLEmployee.all(); | |
// PRPLCareers.get(); | |
$scope.navFlag = false; | |
var speechEnabled = false; | |
if (!('webkitSpeechRecognition' in window) || !speechEnabled) { | |
$('.microphone').addClass('hidden'); | |
} else { | |
var create_email = false; | |
var final_transcript = ''; | |
var recognizing = false; | |
var ignore_onend; | |
var start_timestamp; | |
PRPLrecognition = new webkitSpeechRecognition(); | |
PRPLrecognition.continuous = false; | |
PRPLrecognition.interimResults = true; | |
PRPLrecognition.onstart = function () { | |
recognizing = true; | |
// console.log('info_speak_now'); | |
}; | |
PRPLrecognition.onerror = function (event) { | |
// console.log('err'); | |
if (event.error == 'no-speech') { | |
// console.log('info_no_speech'); | |
ignore_onend = true; | |
} | |
if (event.error == 'audio-capture') { | |
// console.log('info_no_microphone'); | |
ignore_onend = true; | |
} | |
if (event.error == 'not-allowed') { | |
if (event.timeStamp - start_timestamp < 100) { | |
// console.log('info_blocked'); | |
} else { | |
// console.log('info_denied'); | |
} | |
ignore_onend = true; | |
} | |
}; | |
PRPLrecognition.onend = function () { | |
PRPLrecognition.stop(); | |
PRPLrecognition.abort(); | |
recognizing = false; | |
// console.log(final_transcript); | |
if (ignore_onend) { | |
return; | |
} | |
if (!final_transcript) { | |
// console.log('info_start'); | |
return; | |
} | |
}; | |
PRPLrecognition.onresult = function (event) { | |
var interim_transcript = ''; | |
for (var i = event.resultIndex; i < event.results.length; ++i) { | |
if (event.results[i].isFinal) { | |
final_transcript += event.results[i][0].transcript; | |
} else { | |
interim_transcript += event.results[i][0].transcript; | |
} | |
} | |
var nospacetranscript = interim_transcript; | |
var caseStudyRoutes = ['work', 'designs', 'case study', 'something cool']; | |
var aboutRoutes = ['about', 'who', 'labs', 'what']; | |
var processRoutes = ['process', 'approach', 'structure', 'charts']; | |
var careersRoutes = ['jobs', 'careers', 'job', 'join the team', 'hire me', 'intern', 'internship']; | |
var notesRoutes = ['blog', 'notes', 'thoughts']; | |
var contactRoutes = ['contact', 'say hi', 'email', 'hello']; | |
var badRoutes = ['*', 'fuck', 'shit', 'cock', 'ass', 'fucker', 'fucking', 'motherfucker']; | |
caseStudyRoutes.forEach(function (caseStudyRoute) { | |
if (nospacetranscript.indexOf(caseStudyRoute) != - 1 && foundMatch == false) { | |
$('.the-links a').eq(2).click(); | |
PRPLrecognition.stop(); | |
recognizing = false; | |
foundMatch = true; | |
return false; | |
} | |
}) | |
aboutRoutes.forEach(function (aboutRoute) { | |
if (nospacetranscript.indexOf(aboutRoute) != - 1 && foundMatch == false) { | |
$('.the-links a').eq(0).click(); | |
PRPLrecognition.stop(); | |
recognizing = false; | |
foundMatch = true; | |
return false; | |
} | |
}) | |
processRoutes.forEach(function (processRoute) { | |
if (nospacetranscript.indexOf(processRoute) != - 1 && foundMatch == false) { | |
$('.the-links a').eq(1).click(); | |
PRPLrecognition.stop(); | |
recognizing = false; | |
foundMatch = true; | |
return false; | |
} | |
}) | |
careersRoutes.forEach(function (careersRoute) { | |
if (nospacetranscript.indexOf(careersRoute) != - 1 && foundMatch == false) { | |
$('.the-links a').eq(3).click(); | |
PRPLrecognition.stop(); | |
recognizing = false; | |
foundMatch = true; | |
return false; | |
} | |
}) | |
notesRoutes.forEach(function (notesRoute) { | |
if (nospacetranscript.indexOf(notesRoute) != - 1 && foundMatch == false) { | |
$('.the-links a').eq(4).click(); | |
PRPLrecognition.stop(); | |
recognizing = false; | |
foundMatch = true; | |
return false; | |
} | |
}) | |
processRoutes.forEach(function (processRoute) { | |
if (nospacetranscript.indexOf(processRoute) != - 1 && foundMatch == false) { | |
$('.the-links a').eq(1).click(); | |
PRPLrecognition.stop(); | |
recognizing = false; | |
foundMatch = true; | |
return false; | |
} | |
}) | |
contactRoutes.forEach(function (contactRoute) { | |
if (nospacetranscript.indexOf(contactRoute) != - 1 && foundMatch == false) { | |
$('.the-links a').eq(5).click(); | |
PRPLrecognition.stop(); | |
recognizing = false; | |
foundMatch = true; | |
return false; | |
} | |
}) | |
badRoutes.forEach(function (badRoute) { | |
if (nospacetranscript.indexOf(badRoute) != - 1 && foundMatch == false) { | |
$('html').addClass('konami'); | |
$('a.hamburger').click(); | |
PRPLrecognition.stop(); | |
recognizing = false; | |
foundMatch = true; | |
return false; | |
} | |
}) | |
final_transcript = capitalize(final_transcript); | |
// final_span.innerHTML = linebreak(final_transcript); | |
// interim_span.innerHTML = linebreak(interim_transcript); | |
// console.log(interim_transcript); | |
}; | |
var two_line = /\n\n/g; | |
var one_line = /\n/g; | |
function linebreak(s) { | |
return s.replace(two_line, '<p></p>').replace(one_line, '<br>'); | |
} | |
var first_char = /\S/; | |
function capitalize(s) { | |
return s.replace(first_char, function (m) { | |
return m.toUpperCase(); | |
}); | |
} | |
} | |
$scope.voiceMenu = function ($timeout) { | |
// console.log('click'); | |
// console.log(recognizing); | |
// console.log(PRPLrecognition); | |
if (recognizing) { | |
PRPLrecognition.abort(); | |
// return; | |
} | |
final_transcript = ''; | |
foundMatch = false; | |
// PRPLrecognition.abort(); | |
$timeout(function() { | |
PRPLrecognition.start(); | |
}, 500) | |
ignore_onend = false; | |
start_timestamp = event.timeStamp; | |
}; | |
$scope.pagepush = function(dest) { | |
// console.log(dest); | |
var doTrans = true; | |
if ($(window).width() > 770) { | |
var aboutProcess = { | |
paddingTop: 290, | |
height: 667 | |
} | |
var work = { | |
paddingTop: 290, | |
height: 607 | |
} | |
var careers = { | |
paddingTop: 290, | |
height: 672 | |
} | |
var notes = { | |
paddingTop: 290, | |
height: 672 | |
} | |
var transHeight = 0; | |
var transPadding = 0; | |
} else { | |
var aboutProcess = { | |
paddingTop: 125, | |
height: 428 | |
} | |
var work = { | |
paddingTop: 125, | |
height: 428 | |
} | |
var careers = { | |
paddingTop: 125, | |
height: 428 | |
} | |
var notes = { | |
paddingTop: 125, | |
height: 428 | |
} | |
var transHeight = 0; | |
var transPadding = 0; | |
} | |
switch (dest) { | |
case 'about': | |
case 'process': | |
// default: | |
transHeight = aboutProcess.height; | |
transPadding = aboutProcess.paddingTop; | |
break; | |
case 'work': | |
transHeight = work.height; | |
transPadding = work.paddingTop; | |
break; | |
case 'careers': | |
transHeight = careers.height; | |
transPadding = careers.paddingTop; | |
break; | |
case 'notes': | |
transHeight = notes.height; | |
transPadding = notes.paddingTop; | |
break; | |
default: | |
// console.warn('destination not programmed, falling back'); | |
doTrans = false; | |
break; | |
} | |
if (!doTrans) { | |
$location.path(dest); | |
return false; | |
} | |
var speed = 500; | |
var windowHeight = $(window).height(); | |
var windowWidth = $(window).width(); | |
// console.log(windowHeight, transHeight, transPadding); | |
$('#footerTeaser').addClass('push-now').velocity({ | |
paddingBottom: windowHeight - transHeight | |
}, speed); | |
$('#footerTeaser a').velocity({ | |
paddingTop: transPadding, | |
height: transHeight | |
}, speed) | |
$('.page').css({ | |
marginBottom: windowHeight | |
}); | |
$('.page').velocity({ | |
translateY: - (windowHeight - transPadding + 11) | |
}, speed); | |
// $("html, body").animate({ scrollTop: $(document).height()-$(window).height() }, speed); | |
$('.points-of-interest').removeClass('intro'); | |
$timeout(function() { | |
$location.path(dest); | |
// $timemout(function(){$anchorScroll();}, 500) | |
}, speed + 50); | |
}; | |
$timeout(function () { | |
centerFixedPRPLNav('#site-header'); | |
}, 300); | |
$(window).on({ | |
resize: function (e) { | |
centerFixedPRPLNav('#site-header'); | |
} | |
}); | |
$timeout(function () { | |
$(window).resize(); | |
}, 2000); | |
// $('body').addClass('viewloading').removeClass('loaded'); | |
} | |
]); | |
/* Blog Post List Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('BlogListController', | |
['$scope', '$sanitize', '$resource', '$location', '$routeParams', 'PRPLPosts', 'PRPLBlog', | |
function ($scope, $sanitize, $resource, $location, $routeParams, PRPLPosts, PRPLBlog) { | |
///////////// | |
// init(apiData), init is triggered in PRPLBlog callbacks | |
//////////// | |
// param handling | |
// if category is specified in url go that route | |
if (exists($routeParams.cat)) { | |
// check see if the category is valid then request those posts | |
var isValid = checkValidCategory($routeParams.cat); | |
if (isValid) { | |
$scope.blogFilter = $routeParams.cat; | |
PRPLBlog.getGroup($routeParams.cat, function (result) { | |
$.scrollTo('.hero .secondary-nav', 400, { | |
'easing': 'easeInOutExpo', | |
'offset': - 50 | |
}); | |
init(result); | |
}); | |
if ($routeParams.cat === 'projects') { | |
seo({ | |
'title': 'Projects | Notes | Purple, Rock, Scissors', | |
'description': 'Follow project updates, website launches, and campaigns from digital creative agency Purple, Rock, Scissors', | |
'keywords': '' | |
}); | |
activeSecondaryNav('.secondary-nav [data-cat-group="projects"]'); | |
} else if ($routeParams.cat === 'savvy') { | |
seo({ | |
'title': 'Savvy | Notes | Purple, Rock, Scissors', | |
'description': 'Digital creative agency Purple, Rock, Scissors dives into industry news and shares expertise.', | |
'keywords': '' | |
}); | |
activeSecondaryNav('.secondary-nav [data-cat-group="savvy"]'); | |
} else if ($routeParams.cat === 'culture') { | |
seo({ | |
'title': 'Culture | Notes | Purple, Rock, Scissors', | |
'description': "Follow updates on PRPL's digital agency culture, announcements, and digital industry events.", | |
'keywords': '' | |
}); | |
activeSecondaryNav('.secondary-nav [data-cat-group="culture"]'); | |
} | |
// invalid categories can f off to /404... or /notes? | |
} else { | |
$location.path('/notes'); | |
} | |
} else { | |
// load all if no category filter is specified | |
$scope.blogFilter = 'all'; | |
PRPLBlog.getPosts(function (result) { | |
init(result); | |
}); | |
seo({}); | |
} | |
function init(apiData) { | |
$scope.currentPage = 1; | |
$scope.totalPosts = apiData.count; //continues counting when paginating (see: loadPageData()) | |
$scope.blogPosts = apiData.posts; | |
$scope.totalPages = apiData.pages || 1; | |
// console.info(apiData); | |
createInfiniteScroll(); | |
// removePreloader(250); | |
setLoadingPosts(false); | |
PRERENDER_READY(); | |
} | |
function activeSecondaryNav(sel) { | |
$(sel).parent().find('a').removeClass('active'); | |
$(sel).addClass('active'); | |
} | |
///////////// | |
// Functions | |
//////////// | |
function createInfiniteScroll() { | |
$(window).on({ | |
scroll: function (e) { | |
var pageHeight = $(document).height(); | |
var scrollPos = e.currentTarget.scrollY + $(window).height(); | |
var predictiveOffset = 300; | |
var threshold = pageHeight - predictiveOffset; | |
if (scrollPos >= threshold && $('#pageNotes').length > 0) { | |
// manage triggering other evt as it makes API call, reset this in the api callback | |
if (getLoadingPosts() === false) { | |
setLoadingPosts(true); | |
$(window).trigger('PRPL_INFINITE_SCROLL'); | |
} | |
} | |
} | |
}); | |
$(window).off('PRPL_INFINITE_SCROLL').on({ | |
'PRPL_INFINITE_SCROLL': function (e, data) { | |
$scope.currentPage++; | |
// console.info('next, total', $scope.currentPage, $scope.totalPages); | |
if ($scope.currentPage > $scope.totalPages) { | |
removeInfiniteScroll(); | |
} else { | |
loadPageData($scope.currentPage); | |
} | |
} | |
}); | |
} | |
function removeInfiniteScroll() { | |
$(window).off('scroll PRPL_INFINITE_SCROLL'); | |
// console.log('thats all folks!, show everything loaded graphic or message'); | |
} | |
// $scope.loadingPosts (bool) | |
function getLoadingPosts() { | |
return $scope.loadingPosts; | |
} | |
function setLoadingPosts(bool) { | |
if (!exists(bool)) { | |
return false; | |
} | |
if (bool === true) { | |
$scope.loadingPosts = true; | |
} else if (bool === false) { | |
$scope.loadingPosts = false; | |
} | |
} | |
function loadPageData(num) { | |
var filter = $scope.blogFilter; // all, projects, savvy, culture etc. | |
PRPLBlog.nextPage(filter, num, function (result) { | |
// console.info('API CALLBACK', result); | |
$scope.blogPosts = $scope.blogPosts.concat(result.posts); | |
$scope.totalPosts = $scope.totalPosts + result.count; | |
// add these 10 posts to the array not replace****** | |
setLoadingPosts(false); | |
}); | |
} | |
function checkValidCategory(slug) { | |
var groups = ['projects', 'savvy', 'culture']; | |
var found = false; | |
for (var i = groups.length - 1; i >= 0; i--) { | |
if (slug === groups[i]) { | |
found = true; | |
} | |
}; | |
return found; | |
} | |
function seo(obj) { | |
var flagText, pageTitle, pageDescription, pageKeywords; | |
if (exists(obj)) { | |
// flagText = (exists(obj.flag)) ? obj.flag : 'Notes | Purple Rock Scissors'; | |
pageTitle = (exists(obj.title)) ? obj.title : 'Notes | Purple Rock Scissors'; | |
pageDescription = (exists(obj.description)) ? obj.description : "Follow PRPL's digital agency culture and expertise, with updates on digital industry news, awards, and more."; | |
pageKeywords = (exists(obj.keywords)) ? obj.keywords : ''; | |
} | |
$scope.$parent.seo = { | |
title: pageTitle, | |
description: pageDescription, | |
keywords: pageKeywords | |
}; | |
$scope.$parent.social = { | |
title: pageTitle, | |
description: pageDescription, | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
} | |
} | |
]); | |
/* Single Blog Post Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('BlogPostController', | |
['$scope', '$sanitize', '$routeParams', '$resource', '$location', 'PRPLAuthor', 'PRPLPost', 'PRPLBlog', '$sce', | |
function ($scope, $sanitize, $routeParams, $resource, $location, PRPLAuthor, PRPLPost, PRPLBlog, $sce) { | |
$scope.disqusReady = false; | |
PRPLBlog.getPost($routeParams.id, function(result) { | |
if (result.status === 'error') { | |
$location.path('/404'); | |
return false; | |
} | |
// SEO | |
var seoTitle = (exists( result.post.meta.seo.title ) && result.post.meta.seo.title !== "") ? result.post.meta.seo.title : 'PRPL Blog'; | |
var seoDescription = (exists( result.post.meta.seo.description ) && result.post.meta.seo.description !== "") ? $(result.post.meta.seo.description).text() : 'Purple Rock Scissors / A Digital Creative Agency'; | |
var seoKeywords = (exists( result.post.meta.seo.keywords ) && result.post.meta.seo.keywords !== "") ? $(result.post.meta.seo.keywords).text() : 'Purple Rock Scissors, Design, Development'; | |
//---------- Work in progress ------------- | |
var seoOriginal = (exists( result.post.meta.seo.original ) && result.post.meta.seo.original !== "") ? result.post.meta.seo.original : 'https://medium.com/purple-rock-scissors'; | |
var seoSyndication = (exists( result.post.meta.seo.syndication ) && result.post.meta.seo.syndication !== "") ? result.post.meta.seo.syndication : 'https://medium.com/purple-rock-scissors'; | |
$scope.$parent.seo = { | |
description: seoDescription, | |
keywords: seoKeywords, | |
title: seoTitle, | |
original: seoOriginal, | |
syndication: seoSyndication | |
}; | |
// THE POST | |
$scope.thePost = result.post; | |
// console.info($scope.thePost); | |
buildHeroHTML($scope.thePost.heroMedia); | |
$scope.postContent = $sce.trustAsHtml(result.post.contentHTML); | |
$scope.photoGridContent = $sce.trustAsHtml(result.post.photoGridHTML); | |
// THE AUTHOR | |
var authorPhoto = (exists(result.post.author.photo) && result.post.author.photo !== null) ? result.post.author.photo : '/assets/images/prpl-badge.jpg'; | |
var authorLink = (exists(result.post.author.link) && result.post.author.link !== null) ? result.post.author.link : 'http://twitter.com/prplrckscssrs'; | |
var authorFName = (exists(result.post.author.first) && result.post.author.first !== "") ? result.post.author.first : 'PRPL'; | |
var authorLName = (exists(result.post.author.last) && result.post.author.last !== "") ? result.post.author.last : ''; | |
var authorNickname = (exists(result.post.author.nickname) && result.post.author.nickname !== "") ? result.post.author.nickname : 'PRPL'; | |
$scope.authorName = authorFName + ' ' + authorLName; | |
$scope.authorGIFNStatic = authorPhoto; | |
$scope.authorURL = authorLink; | |
// THE FOOTER TEASER | |
var footerImg = (exists(result.post.previous.hero)) ? result.post.previous.hero : false; | |
var footerTitle = (exists(result.post.previous.title)) ? result.post.previous.title : false; | |
var footerURL = '/notes/' + result.post.previous.id + '/' + result.post.previous.sanitized; | |
$scope.thePrevPost = { | |
'img': footerImg, | |
'title': footerTitle, | |
'url': footerURL | |
}; | |
// INIT PHOTO GRID | |
$(window).on({ | |
load: function(e) { | |
$('.PhotoCollage').removeWhitespace().collagePlus().css('opacity', 1); | |
$(window).on({ | |
resize: function(e) { | |
$('.PhotoCollage').removeWhitespace().css('opacity', 0).collagePlus().css('opacity', 1); | |
} | |
}); | |
} | |
}); | |
// SOCIAL | |
var socialTitle = seoTitle; | |
var socialDescription = seoDescription; | |
var socialKeywords = seoKeywords; | |
$scope.$parent.social = { | |
title: socialTitle, | |
description: socialDescription, | |
url: defragz(window.location.href), | |
author: authorNickname, | |
photo: result.post.heroURL | |
}; | |
addSocialShares(); | |
// remove loader | |
// removePreloader(250); | |
$scope.disqusReady = true; | |
PRERENDER_READY(); | |
// $scope.$apply(); | |
console.info('THAT RESULT THO', result); | |
}); | |
function addSocialShares() { | |
// console.info('adding socialz', $scope.social); | |
$('.inner-author-share .share-link').on({ | |
click: function (e) { | |
$(e.currentTarget).closest('.author-share').addClass('is-sharing'); | |
} | |
}); | |
$('.author-share .share-close').on({ | |
click: function (e) { | |
$(e.currentTarget).closest('.author-share').removeClass('is-sharing'); | |
} | |
}); | |
$(".share-area .auto-copy-clipboard").on({ | |
click: function (e) { | |
$(this).select(); | |
} | |
}); | |
} | |
function buildHeroHTML(heroObj) { | |
// console.info(heroObj); | |
var isVideo = false; | |
var hasFallback = false; | |
if (heroObj.vimtube !== '' || heroObj.html5 !== '') { | |
isVideo = true; | |
} | |
if (heroObj.image !== '') { | |
hasFallback = true; | |
} | |
// console.info('isVideo:', isVideo, 'hasFallback:', hasFallback); | |
// if(!hasFallback){ console.warn('No fallback found set to default?', hasFallback); } | |
if (isVideo) { | |
var isVimtube = (heroObj.vimtube !== '') ? heroObj.vimtube : false; | |
var isHTML5 = (heroObj.html5 !== '') ? heroObj.html5 : false; | |
// console.log(isVimtube, isHTML5); | |
if (isHTML5) { | |
if ($('html').hasClass('touch')) { | |
buildFallbackHTML(heroObj.image); | |
} else { | |
buildHTML5HTML(isHTML5); | |
} | |
} else if (isVimtube) { | |
if (isVimtube.indexOf('vimeo.com') > - 1) { | |
buildVimeoHTML(isVimtube); | |
} else if (isVimtube.indexOf('youtube.com') > - 1) { | |
buildYoutubeHTML(isVimtube); | |
} else { | |
buildFallbackHTML(heroObj.image); | |
} | |
} else { | |
buildFallbackHTML(heroObj.image); | |
} | |
} else { | |
// console.log('isnt video, use image hero'); | |
buildFallbackHTML(heroObj.image); | |
} | |
} | |
function buildVimeoHTML(url) { | |
var el = ''; | |
var arr = url.split('vimeo.com/'); | |
var vimeo_id = arr[arr.length - 1]; | |
// console.info(vimeo_id); | |
el += '<iframe src="//player.vimeo.com/video/' + vimeo_id + '?title=0&byline=0&portrait=0&color=f26f70" width="800" height="450" frameborder="0" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>'; | |
$('#pageNote .the-note .the-hero').html(el); | |
} | |
function buildYoutubeHTML(url) { | |
var el = ''; | |
var arr = url.split('youtube.com/watch?v='); | |
var yt_id = arr[arr.length - 1]; | |
el += '<iframe width="800" height="450" src="//www.youtube.com/embed/' + yt_id + '" frameborder="0" allowfullscreen></iframe>'; | |
$('#pageNote .the-note .the-hero').html(el); | |
} | |
function buildHTML5HTML(url) { | |
var el = ''; | |
el += '<video class="note-hero-h5v" id="bgvNoteHero" preload="metadata" loop="true" muted="true" autoplay="true">'; | |
el += '<source src="' + url + '.webmhd.webm" type="video/webm">'; | |
el += '<source src="' + url + '.mp4" type="video/mp4; codecs="avc1.42E01E, mp4a.40.2"">'; | |
el += '</video>'; | |
$('#pageNote .the-note .the-hero').html(el); | |
} | |
function buildFallbackHTML(url) { | |
var el = ''; | |
el = "<img src=" + $scope.thePost.heroURL + " alt=" + $scope.thePost.title + " />"; | |
$('#pageNote .the-note .the-hero').html(el); | |
} | |
} | |
]); | |
/* Careers Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('CareersController', | |
[ '$scope', '$sanitize', '$resource', '$location', '$routeParams', 'PRPLCareers', '$analytics', | |
function ($scope, $sanitize, $resource, $location, $routeParams, PRPLCareers, $analytics) { | |
$scope.formDebug = false; | |
// $scope.activeDepartment = false; | |
// $scope.formState = 'default'; | |
$scope.formValid = false; | |
$scope.formComplete = false; | |
var _form = {}; | |
var _dataAPI = false; | |
var _dataJob = false; | |
var _activeDeptSlug = false; | |
var _activeDeptIndex = false; | |
// var submissionRef = new Firebase("https://prpl-careers.firebaseio.com/submissions"); | |
// var _formSubs = $firebase(submissionRef); | |
var stageOne = { | |
// Variables (w/ getters & setters) | |
_complete: false, | |
getComplete: function() { | |
return stageOne._complete; | |
}, | |
setComplete: function(val) { | |
stageOne._complete = val; | |
}, | |
_active: false, | |
getActive: function() { | |
return stageOne._active; | |
}, | |
setActive: function(val) { | |
stageOne._active = val; | |
}, | |
_depts: false, | |
getDepartments: function() { | |
return stageOne._depts; | |
}, | |
setDepartments: function(val) { | |
stageOne._depts = val; | |
}, | |
init : function(leggo) { | |
// Some sort of sanitization | |
if (leggo.length < 1) { | |
// console.error('we got an API-shaped problem'); | |
return false; | |
} | |
// Leg'go | |
var allDepts = leggo | |
var deptsHiring = stageOne.filterHiring(allDepts); | |
stageOne.setDepartments(deptsHiring); | |
// console.info($routeParams); | |
if (exists($routeParams.job)) { | |
if (exists($routeParams.slug) && $routeParams.slug === 'thanks-for-applying') { | |
utils.showThankYouMessage(); | |
// path dependednt scope html ready (thankyou message) | |
// $scope.htmlReady(); | |
} else { | |
stageOne.preSelectedJob($routeParams.job); | |
} | |
} else { | |
utils.seo('page-defaults'); | |
// path dependednt scope html ready (default) | |
// $scope.htmlReady(); | |
} | |
stageOne.listDepartments(); | |
// Now HTML is added enable the goal of stage one | |
stageOne.addListEvents(); | |
stageOne.setActive(true); | |
PRERENDER_READY(); // utils.js | |
}, | |
reset : function() { | |
stageOne.setComplete(false); | |
stageOne.setActive(false); | |
}, | |
// Methods | |
addListEvents : function() { | |
$('.form-options .massive-li').off('click').on({ | |
click : function(e) { | |
var selectedDepartment = stageOne.nextStage($(e.currentTarget).text()); | |
if (selectedDepartment !== false) { | |
stageOne.setComplete(true); | |
stageTwo.init(selectedDepartment); | |
$analytics.eventTrack( selectedDepartment.name, { | |
category: 'Careers CTA', | |
label: 'Selected Department' | |
}); | |
} | |
} | |
}); | |
}, | |
filterHiring : function(data) { | |
// Filter by departments that are hiring | |
var depts = []; | |
for (var i = 0; i < data.length; i++) { | |
if (data[i].hiring !== false) { | |
depts.push(data[i]); | |
} | |
}; | |
return (depts); | |
}, | |
htmlListEntry: function(entry) { | |
// Make some massive LI's | |
var el = ''; | |
el += '<li class="massive-li">'; | |
el += '<a href="javascript:;" data-slug="' + entry.name + '">' + entry.name + '</a>'; | |
el += '</li>'; | |
return el; | |
}, | |
listDepartments: function() { | |
var data = stageOne.getDepartments(); | |
var el = ''; | |
for (var i = 0; i < data.length; i++) { | |
el += stageOne.htmlListEntry(data[i]); | |
}; | |
$('.form-options.massive-ul').html(el); | |
return el; | |
}, | |
nextStage : function(cat) { | |
var depts = stageOne.getDepartments(); | |
var found = false; | |
for (var i = depts.length - 1; i >= 0; i--) { | |
if (depts[i].name === cat) { | |
found = depts[i]; | |
} | |
}; | |
return found; | |
}, | |
preSelectedJob : function(jobSlug) { | |
// console.info(jobSlug); | |
var data = stageOne.getDepartments(); | |
var found = false; | |
for (var i = 0; i < data.length; i++) { | |
var jobz = data[i].jobs; | |
for (var j = 0; j < jobz.length; j++) { | |
var sluggish = slugify(jobz[j]['post_title']); | |
if (jobSlug === sluggish) { | |
found = data[i]; | |
found.preselect = jobSlug; | |
// console.info(jobSlug, sluggish, data[i]); | |
} | |
} | |
}; | |
if (found !== false) { | |
stageTwo.init(found); | |
} | |
} | |
}; | |
// console.log(stageOne); | |
var stageTwo = { | |
// Variables, getters/setters | |
_complete: false, | |
getComplete: function() { | |
return stageTwo._complete; | |
}, | |
setComplete: function(val) { | |
stageTwo._complete = val; | |
}, | |
_active: false, | |
getActive: function() { | |
return stageTwo._active; | |
}, | |
setActive: function(val) { | |
stageTwo._active = val; | |
}, | |
_dept: false, | |
getDepartment: function() { | |
return stageTwo._dept; | |
}, | |
setDepartment: function(val) { | |
stageTwo._dept = val; | |
}, | |
_jobs: false, | |
getJobs: function() { | |
return stageTwo._jobs; | |
}, | |
setJobs: function(val) { | |
stageTwo._jobs = val; | |
}, | |
_job: false, | |
getJob: function() { | |
return stageTwo._job; | |
}, | |
setJob: function(val) { | |
stageTwo._job = val; | |
}, | |
init: function(deptObj) { | |
stageTwo.setDepartment(deptObj); | |
stageTwo.setJobs(deptObj.jobs); | |
stageTwo.hideDepartmentList(); | |
stageTwo.addFormFocusedToPage(); | |
stageTwo.addDescriptions(); | |
stageTwo.addTitleTabEvents(); | |
if (exists(deptObj.preselect)) { | |
stageTwo.showSpecificDescription(deptObj.preselect); | |
// path dependednt scope html ready (pre selected job) | |
// $scope.htmlReady(); | |
} else { | |
stageTwo.showFirstDescriptionByDefault(); | |
} | |
// stageTwo.addApplyNowEvents(); | |
utils.addCloseButton(); | |
utils.addDepartmentNav(); | |
}, | |
// Methods | |
addApplyNowEvents : function() { | |
$('.form-area-careers .apply-bar .btn-form-submission').off('click').on({ | |
click: function(e) { | |
stageTwo.nextStage(); | |
} | |
}); | |
}, | |
addDescriptions : function() { | |
var dept = stageTwo.getDepartment(); | |
// HTML NEEDS | |
// - Department name | |
var HTMLTitle = stageTwo.titleHTML(dept); | |
// - Tagline | |
var HTMLTagline = stageTwo.taglineHTML(dept); | |
// - H3/A Job Titles | |
var HTMLJobTabs = stageTwo.jobTabsHTML(dept.jobs); | |
// - Job Descriptions (for each) | |
var HTMLJobDescriptions = stageTwo.jobDescriptionsHTML(dept.jobs); | |
// - Responsibilities Area | |
// - Sidebar Area | |
// - Qualifications | |
// - Bonus Points | |
// console.info(HTMLTitle, HTMLTagline, HTMLJobTabs, HTMLJobDescriptions); | |
$('.form-area-careers .detail-buttons .department-name').html(dept.name); | |
$('.form-area-careers .single-description .title-tabs').html(HTMLTagline + HTMLJobTabs); | |
$('.form-area-careers .job-details .job-descriptions').html(HTMLJobDescriptions); | |
$('.form-area-careers .detail-buttons').show(); | |
$('.form-area-careers .job-details').show(); | |
}, | |
addFormFocusedToPage : function() { | |
$('.page-careers').addClass('form-area-focused'); | |
}, | |
addTitleTabEvents : function() { | |
$('.form-area-careers .single-description .title-tabs a').on({ | |
click: function(e) { | |
var data = $(e.currentTarget).data(); | |
var dIndex = data.descriptionIndex; | |
var sanitized = data.urlSlug; | |
var jobj = stageTwo.getJobjectBySlug(sanitized); | |
stageTwo.setButtonURL(jobj.fields["bamboo-link"]); | |
stageTwo.setJob(jobj); | |
utils.seo(sanitized); | |
$('.form-area-careers .title-tabs [data-description-index]').removeClass('active'); | |
$('.form-area-careers .single-description [data-tab-index]').removeClass('active'); | |
$('.form-area-careers .title-tabs [data-description-index="' + dIndex + '"]').addClass('active'); | |
$('.form-area-careers .single-description [data-tab-index="' + dIndex + '"]').addClass('active'); | |
stageTwo.updateURL(sanitized); | |
} | |
}) | |
}, | |
getJobjectBySlug: function(mollusk) { | |
var jobs = stageTwo.getJobs(); | |
var job = false; | |
for (var i = jobs.length - 1; i >= 0; i--) { | |
var sluggish = slugify(jobs[i]['post_title']); | |
if (sluggish === mollusk) { | |
job = jobs[i]; | |
} | |
}; | |
return job; | |
}, | |
hideDepartmentList : function() { | |
$('.form-area-careers .massive-ul').hide(); | |
}, | |
jobDescriptionsHTML : function(jobs) { | |
var el = ''; | |
for (var i = 0; i < jobs.length; i++) { | |
el += '<div class="job-description" data-tab-index="' + i + '">'; | |
el += '<div class="job-resp">'; | |
el += '<div>' + jobs[i].fields.responsibilties + '</div>'; | |
el += '</div>'; | |
el += '<div class="sidebar">'; | |
el += '<aside class="job-qualifications">'; | |
el += '<h4>Qualifications</h4>'; | |
el += '<div>' + jobs[i].fields.qualifications + '</div>'; | |
el += '</aside>'; | |
el += '<aside class="job-bonus-points">'; | |
el += '<h4>Bonus Points</h4>'; | |
el += '<div>' + jobs[i].fields['bonus-points'] + '</div>'; | |
el += '</aside>'; | |
el += '</div>'; | |
el += '</div>'; | |
}; | |
return el; | |
}, | |
jobSlugToIndex: function(nomme) { | |
var bangbang = false; | |
var jobs = stageTwo.getJobs(); | |
for (var i = 0; i < jobs.length; i++) { | |
var gEazy = slugify(jobs[i]['post_title']); | |
if (nomme === gEazy) { | |
bangbang = i; | |
} | |
} | |
return bangbang; | |
}, | |
jobTabsHTML : function(jobs) { | |
var el = ''; | |
for (var i = 0; i < jobs.length; i++) { | |
var purel = slugify(jobs[i]['post_title']); | |
el += '<h3 class="job-title">'; | |
el += '<a href="javascript:;" data-url-slug="' + purel + '" data-description-index="' + i + '">' + jobs[i]['post_title'] + '</a>'; | |
el += '</h3>'; | |
}; | |
return el; | |
}, | |
nextStage : function() { | |
var jobj = stageTwo.getJob(); | |
//console.info('next job › ', jobj); | |
stageTwo.unload(); | |
stageThree.init(jobj); | |
}, | |
showSpecificDescription : function(jobSlug) { | |
var LILDURK = stageTwo.jobSlugToIndex(jobSlug); | |
$('.form-area-careers .title-tabs [data-description-index="' + LILDURK + '"]').addClass('active'); | |
$('.form-area-careers .single-description [data-tab-index="' + LILDURK + '"]').addClass('active'); | |
$.scrollTo('h1.department-name', 400, { | |
'easing': 'easeInOutExpo', | |
'offset': 0 | |
}); | |
utils.seo(jobSlug); | |
var jobj = stageTwo.getJobjectBySlug(jobSlug); | |
stageTwo.setButtonURL(jobj.fields["bamboo-link"]); | |
stageTwo.setJob(jobj); | |
}, | |
showFirstDescriptionByDefault : function() { | |
var sluggish = $('.form-area-careers .title-tabs [data-description-index="0"]').data().urlSlug; | |
stageTwo.updateURL(sluggish); | |
var jobj = stageTwo.getJobjectBySlug(sluggish); | |
stageTwo.setButtonURL(jobj.fields["bamboo-link"]); | |
stageTwo.setJob(jobj); | |
$('.form-area-careers .title-tabs [data-description-index="0"]').click(); | |
// $('.form-area-careers .title-tabs [data-description-index="0"]').addClass('active'); | |
// $('.form-area-careers .single-description [data-tab-index="0"]').addClass('active'); | |
$.scrollTo('h1.department-name', 400, { | |
'easing': 'easeInOutExpo', | |
'offset': 0 | |
}); | |
// utils.seo(sluggish); | |
}, | |
setButtonURL : function(url) { | |
url = url || "https://prpl.bamboohr.com/jobs/"; | |
$('.form-area-careers .apply-bar .btn-form-submission').attr('href', url); | |
}, | |
taglineHTML : function(dept) { | |
var el = '<h2 class="tagline">' + dept.tagline + '</h2>'; | |
return el; | |
}, | |
titleHTML : function(dept) { | |
var el = '<h1 class="department-name">' + dept.name + '</h1>'; | |
return el; | |
}, | |
updateURL: function(str) { | |
$location.search('job', str); | |
$scope.$apply(); | |
}, | |
unload: function() { | |
$('.job-details').hide(); | |
}, | |
validateURL : function(params) { | |
// console.info(params); | |
} | |
}; | |
// console.log(stageTwo); | |
var stageThree = { | |
// Variables (w/ getters & irish setters) | |
_complete: false, | |
getComplete: function() { | |
return stageThree._complete; | |
}, | |
setComplete: function(val) { | |
stageThree._complete = val; | |
}, | |
_active: false, | |
getActive: function() { | |
return stageThree._active; | |
}, | |
setActive: function(val) { | |
stageThree._active = val; | |
}, | |
_dept: false, | |
getDepartment: function() { | |
return stageThree._dept; | |
}, | |
setDepartment: function(val) { | |
stageThree._dept = val; | |
}, | |
_job: false, | |
getJob: function() { | |
return stageThree._job; | |
}, | |
setJob: function(val) { | |
stageThree._job = val; | |
}, | |
_valid: false, | |
getValid: function() { | |
return stageThree._valid; | |
}, | |
setValid: function(val) { | |
stageThree._valid = val; | |
}, | |
init : function(jobject) { | |
stageThree.setJob(jobject); | |
stageThree.showForm(); | |
stageThree.addSubmitEvents(); | |
stageThree.addBackButton(); | |
utils.linkedInButton(jobject); | |
$scope.theJobName = jobject['post_title']; | |
}, | |
// Methods | |
addBackButton : function() { | |
$('.form-area-careers .back-to-description').off('click').on({ | |
click: function(e) { | |
stageThree.backToStageTwo(); | |
} | |
}) | |
}, | |
addSubmitEvents: function() { | |
$('form[name="jobForm"]').off('submit').on({ | |
submit: function (e) { | |
if ($(e.currentTarget).hasClass('ng-valid')) { | |
// var passesHoneyPotValidation = $('.verifyName', emailForm).val(); | |
// passesHoneyPotValidation = (passesHoneyPotValidation.length === 0) ? true : false; | |
// console.info(passesHoneyPotValidation); | |
if (true) { | |
// FPO Honeypot Validation | |
// var postUrl = '/cm-message-form.php'; | |
// var cmListID = '630fe8f9871cf8412a9de87c682792d6'; | |
// var recipient = '[email protected]'; | |
// var subject = 'Job Application: ' + $scope.theJobName; | |
// var postData = $(e.currentTarget).serialize(); | |
// var siteReferrer = $('#prplSiteReferrer').val(); | |
// postData += '&cmid=' + cmListID + '&recipient=' + recipient + '&subject=' + subject + '&hidden_link_referrer=' + siteReferrer; | |
// utils.addDataToFirebase($scope.theJobName); | |
// // console.warn(postData); | |
// $.ajax({ | |
// type: 'POST', | |
// url: postUrl, | |
// data: postData, | |
// success: function (msg) { | |
// // console.info(msg); | |
// var nurl = '/careers/thanks-for-applying?job=' + utils.getJobNameParam() + '&type=default'; | |
// $location.url(nurl); | |
// $scope.$apply(); | |
// }, | |
// error: function (msg) { | |
// // console.info(msg); | |
// } | |
// }); | |
tmp = {}; | |
tmp.job = $scope.theJobName, | |
tmp.name = $('.form-area-careers form [name="name"]').val(); | |
tmp.email = $('.form-area-careers form [name="email"]').val(); | |
tmp.phone = $('.form-area-careers form [name="phone"]').val(); | |
tmp.portfolio = $('.form-area-careers form [name="portfolio"]').val(); | |
tmp.twitter = $('.form-area-careers form [name="twitter"]').val(); | |
tmp.music = $('.form-area-careers form [name="music"]').val(); | |
tmp.linkedin = $('.form-area-careers form [name="application_linkedin"]').val(); | |
tmp.video = $('.form-area-careers form [name="application_video"]').val(); | |
tmp.message = $('.form-area-careers form [name="application_message"]').val(); | |
tmp.music = $('.form-area-careers form [name="music"]').val(); | |
tmp.referrer = $('#prplSiteReferrer').val(); | |
var ParseClass = Parse.Object.extend("CareerSubmission"); | |
var parseClass = new ParseClass(); | |
parseClass.save( tmp , { | |
success: function(object) { | |
// console.info('dongs', object); | |
var nurl = '/careers/thanks-for-applying?job=' + utils.getJobNameParam() + '&type=default'; | |
$location.url(nurl); | |
$scope.$apply(); | |
}, | |
error: function(model, error) { | |
console.error(model, error); | |
} | |
}); | |
} else { | |
return false; | |
} | |
} else { | |
// console.warn('form contains errors!'); | |
stageThree.showFormErrors(); | |
} | |
return false; | |
} | |
}); | |
}, | |
backToStageTwo: function() { | |
$('.form-area-careers .the-form').hide(); | |
$('.job-details').show(); | |
$.scrollTo('h1.department-name', 400, { | |
'easing': 'easeInOutExpo', | |
'offset': 0 | |
}); | |
}, | |
showForm: function() { | |
$('.form-area-careers .the-form').show(); | |
$.scrollTo('h1.department-name', 400, { | |
'easing': 'easeInOutExpo', | |
'offset': 0 | |
}); | |
}, | |
showFormErrors: function() { | |
$('.form-area-careers .the-form .ng-invalid').addClass('form-errors'); | |
}, | |
validateURL : function(params) { | |
// console.info(params); | |
} | |
}; | |
// console.log(stageThree); | |
var utils = { | |
reset: function() { | |
$location.url($location.path()); | |
$location.path('/careers'); | |
utils.seo('page-defaults'); | |
$('.page-careers').removeClass('form-area-focused'); | |
$('.form-area-careers .detail-buttons').hide(); | |
$('.form-area-careers .job-details').hide(); | |
$('.form-area-careers .the-form').hide(); | |
$('.form-area-careers .massive-ul').show(); | |
$scope.$apply(); | |
}, | |
addCloseButton : function() { | |
$('.form-area-careers .detail-buttons .btn-close').off('click').on({ | |
click: function(e) { | |
utils.reset(); | |
} | |
}); | |
}, | |
addDepartmentNav : function() { | |
$('.form-area-careers .detail-buttons .btn-prev').off('click').on({ | |
click: function(e) { | |
utils.previousDepartment(); | |
} | |
}); | |
$('.form-area-careers .detail-buttons .btn-next').off('click').on({ | |
click: function(e) { | |
utils.nextDepartment(); | |
} | |
}); | |
}, | |
linkedInButton : function(jobData) { | |
// console.info(jobData); | |
// <script src="//platform.linkedin.com/in.js" type="text/javascript">api_key: 77s2y2wb75hodu</script> | |
// <script type="IN/Apply" data-companyid="215915" data-jobtitle="Architect" data-joblocation="Orlando, FL" data-themecolor="#f26f70" data-phone="required" data-email="[email protected]" data-showtext='false'></script> | |
//$('.linked-btn').html(''); | |
//var el = '<script class="theLinkedScriptButton" type="IN/Apply" data-companyid="215915" data-jobtitle="' + jobData['post_title'] + '" data-joblocation="Orlando, FL" data-themecolor="#f26f70" data-phone="required" data-email="[email protected]" data-showtext="false" data-size="medium"></script><script src="//platform.linkedin.com/in.js" type="text/javascript">api_key: 77s2y2wb75hodu</script>'; | |
//$('.linked-btn').html(el); | |
var script = $('<script>') | |
// add attributes | |
.attr('type', 'IN/Apply') // make it an Apply with LinkedIn button | |
.attr('data-jobTitle', jobData['post_title']) | |
.attr('data-companyid', '215915') | |
.attr('data-email', '[email protected]') | |
// .attr('data-joblocation', 'Orlando, FL') | |
.attr('data-phone', 'required') | |
.attr('data-showtext', 'false') | |
.attr('data-size', 'medium') | |
.attr('data-onsuccess', 'linkedInApplySuccessCallback') | |
.attr('data-coverLetter', 'required') | |
.attr('data-themecolor', '#f26f70'); | |
$('#linkedInTop').html(script); | |
// check if IN.parse exists, if so, call it | |
if (IN.parse) { | |
IN.parse(); | |
} | |
// otherwise, we will register it to fire on the systemReady event | |
// this is just precaution, but can avoid a special race condition | |
else { | |
IN.Event.on(IN, "systemReady", IN.parse); | |
} | |
$(window).off("LINKEDIN_APPLY_SUCCESS").one({ | |
LINKEDIN_APPLY_SUCCESS: function(e, data) { | |
if (data.event === 'success') { | |
// alert(utils.getJobNameParam()); | |
var nurl = '/careers/thanks-for-applying?job=' + utils.getJobNameParam() + '&type=linkedin'; | |
$location.url(nurl); | |
$scope.$apply(); | |
} | |
} | |
}); | |
}, | |
nextDepartment: function() { | |
// console.info('next department'); | |
}, | |
previousDepartment: function() { | |
// console.info('prev department'); | |
}, | |
seo : function(slug) { | |
var flagText, pageTitle, pageDescription, pageKeywords; | |
var obj = stageTwo.getJobjectBySlug(slug); | |
if (obj !== false) { | |
pageTitle = (exists(obj.fields['seo-title']) && obj.fields['seo-title'] !== '') ? obj.fields['seo-title'] : 'Careers | Purple, Rock, Scissors'; | |
pageDescription = (exists(obj.fields['seo-description']) && obj.fields['seo-description'] !== '') ? obj.fields['seo-description'] : "Interested in a job at PRPL? See what careers are available in digital marketing, web design, ux design, production, and client strategy."; | |
pageKeywords = (exists(obj.fields['seo-keywords']) && obj.fields['seo-keywords'] !== '') ? obj.fields['seo-keywords'] : 'prpl careers, prpl jobs, digital marketing job, ux jobs, digital marketing careers, digital design jobs, digital design careers, ux design jobs'; | |
// console.info(slug, pageTitle, pageDescription, pageKeywords); | |
$scope.$parent.seo = { | |
title: pageTitle, | |
description: pageDescription, | |
keywords: pageKeywords | |
}; | |
$scope.$parent.social = { | |
title: pageTitle, | |
description: pageDescription, | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
// $scope.$apply(); | |
} else { | |
$scope.$parent.seo = { | |
title: 'Careers | Purple, Rock, Scissors', | |
description: 'Interested in a job at PRPL? See what careers are available in digital marketing, web design, ux design, production, and client strategy.', | |
keywords: 'prpl careers, prpl jobs, digital marketing job, ux jobs, digital marketing careers, digital design jobs, digital design careers, ux design jobs' | |
}; | |
$scope.$parent.social = { | |
title: 'Careers | Purple, Rock, Scissors', | |
description: 'Interested in a job at PRPL? See what careers are available in digital marketing, web design, ux design, production, and client strategy.', | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
} | |
}, | |
showThankYouMessage : function() { | |
$('.form-area-careers .thankyou-message').show(); | |
$.scrollTo('.form-area-careers .thankyou-message', 400, { | |
'easing': 'easeInOutExpo', | |
'offset': 0 | |
}); | |
if (exists($routeParams.type)) { | |
var submissionType = $routeParams.type; | |
var defaultCode = '6015206741101'; | |
var linkedinCode = '6015206783301'; | |
if (submissionType === 'default') { | |
utils.addFBPixelCode(defaultCode); | |
} else if (submissionType === 'linkedin') { | |
utils.addFBPixelCode(linkedinCode); | |
} | |
} | |
$('.form-area-careers .thankyou-message .little-red-header-link').off('click').on({ | |
click: function() { | |
$location.url($location.path()); | |
$location.path('/careers'); | |
$scope.$apply(); | |
} | |
}) | |
}, | |
getJobNameParam: function() { | |
// console.log($routeParams); | |
if (exists($routeParams.job)) { | |
return $routeParams.job | |
} else { | |
return false; | |
} | |
}, | |
addFBPixelCode: function(theID) { | |
var el = ''; | |
el += '<div id="fbCareersSubmissionPixel">'; | |
el += '<script type="text/javascript">'; | |
el += '(function() {'; | |
el += '\nvar _fbq = window._fbq || (window._fbq = []);'; | |
el += '\nif (!_fbq.loaded) {'; | |
el += "\n\tvar fbds = document.createElement('script');"; | |
el += "\n\tfbds.async = true;"; | |
el += "\n\tfbds.src = '//connect.facebook.net/en_US/fbds.js';"; | |
el += "\n\tvar s = document.getElementsByTagName('script')[0];"; | |
el += "\n\ts.parentNode.insertBefore(fbds, s);"; | |
el += "\n\t_fbq.loaded = true;"; | |
el += "\n}"; | |
el += "\n})();"; | |
el += "\nwindow._fbq = window._fbq || [];"; | |
el += "\nwindow._fbq.push(['track', " + theID + ", {'value':'0.00','currency':'USD'}]);"; | |
el += "</script>"; | |
el += '<noscript><img height="1" width="1" alt="" style="display:none" src="https://www.facebook.com/tr?ev=' + theID + '&cd[value]=0&cd[currency]=USD&noscript=1" /></noscript>'; | |
el += "</div>"; | |
if ($('#fbCareersSubmissionPixel').length > 0) { | |
$('#fbCareersSubmissionPixel').remove(); | |
} | |
$('body').append(el); | |
// console.log('add fb code', theID, el, $('#fbCareersSubmissionPixel')); | |
}, | |
addDataToFirebase: function(jobSlug) { | |
// _formSubs.$add({ | |
// 'job': jobSlug, | |
// 'name': $('.form-area-careers form [name="name"]').val(), | |
// 'email': $('.form-area-careers form [name="email"]').val(), | |
// 'phone': $('.form-area-careers form [name="phone"]').val(), | |
// 'porftolio': $('.form-area-careers form [name="porftolio"]').val(), | |
// 'twitter': $('.form-area-careers form [name="twitter"]').val(), | |
// 'music': $('.form-area-careers form [name="music"]').val(), | |
// 'application_linkedin': $('.form-area-careers form [name="application_linkedin"]').val(), | |
// 'application_video': $('.form-area-careers form [name="application_video"]').val(), | |
// 'application_message': $('.form-area-careers form [name="application_message"]').val(), | |
// 'music': $('.form-area-careers form [name="music"]').val(), | |
// 'referrer': $('#prplSiteReferrer').val() | |
// }); | |
console.log('discontinued') | |
} | |
}; | |
// GET DATA AND HANDLE PARAMS | |
PRPLCareers.get(function (res) { | |
// console.info('API Result:', res); | |
$scope.careersData = res.result; | |
_dataAPI = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.linkedinJobTitle = 'FPO'; | |
$scope.theJobName = 'unknown'; | |
// var deptsHiring = stageOne.filterHiring(_dataAPI); | |
// stageOne.listDepartments(deptsHiring); | |
stageOne.init(_dataAPI); | |
// Param Handling | |
if (exists($routeParams.slug)) { | |
// $scope.activeDepartment = strSanitize($routeParams.slug); | |
// var res = getJobData($routeParams.slug); | |
// $scope.activeData = res; | |
if (exists($routeParams.position)) { | |
var tmp = findJobByName($routeParams.position); | |
// if (tmp !== false) { | |
// setTimeout(function () { | |
// showJobDescriptionByIndex(tmp.index); | |
// }, 100); | |
// $scope.activeJob = strSanitize($routeParams.position); | |
// } | |
if (exists($routeParams.apply)) { | |
setFormState('applying'); | |
} else { | |
setFormState('description'); | |
} | |
} else { | |
if ($scope.activeDepartment === 'thanks-for-applying') { | |
// alert('thankyou!'); | |
} else { | |
// var tmp = findJobByIndex(0); | |
// if (tmp !== false) { | |
// var purel = urlSanitize(tmp.data['post_title']); | |
// updateURL($scope.activeDepartment + '/' + purel); | |
// } | |
} | |
} | |
} else { | |
setFormState('default'); | |
} | |
// removePreloader(0); | |
}); | |
function setFormState(state, activeDept) { | |
if (typeof state === 'undefined') { | |
return false; | |
} | |
if (state === 'default') { | |
$scope.activeDepartment = false; | |
$scope.activeJob = false; | |
$scope.formState = 'default'; | |
// console.warn('removed update form path', state); | |
} else if (state === 'description') { | |
$scope.formState = 'description'; | |
if (exists(activeDept)) { | |
if (activeDept === 'NEXT') { | |
// console.info('next category', $scope.activeDepartment); | |
} else if (activeDept === 'PREV') { | |
// console.info('previous category', $scope.activeDepartment); | |
} else { | |
$scope.activeDepartment = activeDept; | |
// updateURL(activeDept); | |
// console.warn('removed update form path', state); | |
} | |
} | |
} else if (state === 'applying') { | |
// updateURL('apply'); | |
// console.warn('removed update form path', state); | |
$scope.formState = 'applying'; | |
addSubmitButton(); | |
buildLinkedInButton(); | |
} else if (state === 'thanks') { | |
// updateURL('thanks'); | |
// console.warn('removed update form path', state); | |
$scope.formState = 'thanks'; | |
} | |
} | |
} | |
]); | |
/* Contact Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('ContactController', | |
[ '$scope', '$sanitize', '$location', '$routeParams', | |
function ($scope, $sanitize, $location, $routeParams) { | |
// Controller-wide varz | |
var _form = new Object(); | |
var _isTouchDevice = $('html').hasClass('touch'); | |
var autoAdvanceTimer; | |
// var submissionRef = new Firebase("https://prpl-contact.firebaseio.com/submissions"); | |
// var _formSubs = $firebase(submissionRef); | |
var paramFormState = handleRouteParams($routeParams); | |
if (paramFormState !== false) { | |
setFormState(paramFormState); | |
} | |
function handleRouteParams(params) { | |
if (!exists(params)) { | |
return false; | |
} | |
var response = false; | |
// True if there is a form slug in the url e.g. /careers/wonga | |
if (exists(params.slug)) { | |
var sanitized = urlSanitize(params.slug); | |
var isValid = checkValidSlug(sanitized); | |
if (isValid) { | |
// console.info(sanitized); | |
if (sanitized === 'talk-biz') { | |
seo({ | |
'title': 'Talk Biz | Contact | Purple, Rock, Scissors', | |
'description': 'Contact digital agency Purple, Rock, Scissors for new business opportunities in digital strategy, online marketing, web design and development.' | |
}); | |
} else if (sanitized === 'speaker-event') { | |
seo({ | |
'title': 'Event Speaker | Contact | Purple, Rock, Scissors', | |
'description': 'Book an event at Purple, Rock, Scissors or speaking engagement with a member of their digital agency team.' | |
}); | |
} else if (sanitized === 'say-hi') { | |
seo({ | |
'title': 'Say Hi | Contact | Purple, Rock, Scissors', | |
'description': 'Contact Purple, Rock, Scissors, a digital creative agency in Orlando, Florida' | |
}); | |
} | |
response = { | |
state: sanitized | |
}; | |
} else { | |
$location.path('/404'); | |
} | |
// console.info('form pre-selected by url', params.slug); | |
} else { | |
// if the url is /careers only | |
response = { | |
state: 'default' | |
} | |
seo({}); | |
} | |
// console.info(params); | |
return response; | |
} | |
function setFormState(state_name) { | |
if (!exists(state_name)) { | |
return false; | |
} | |
var s = (exists(state_name.state)) ? state_name.state : false; | |
if (!s) { | |
return false; | |
} | |
if (s === 'default') { | |
$scope.formState = 'default'; | |
} else if (s === 'say-hi' || s === 'speaker-event' || s === 'talk-biz') { | |
$scope.formState = s; | |
_form.slug = s; | |
$('input.auto-size').autosizeInput(); | |
$.scrollTo('.form-area-contact', 400, { | |
'easing': 'easeInOutExpo', | |
'offset': 0 | |
}); | |
// $('select.jq-select-box').select2(); | |
formHandler(s); | |
} else if (s === 'thanks-biz' || s === 'thanks-speaker' || s === 'thanks-for-saying-hi') { | |
var fbCode = false; | |
if (s === 'thanks-biz') { | |
fbCode = '6015045364901'; | |
$('.the-form-thanks .biz-nda').addClass('reveal'); | |
$('.the-form-thanks .non-biz').addClass('obfuscate'); | |
} else if (s === 'thanks-speaker') { | |
fbCode = '6015045399901'; | |
} else if (s === 'thanks-for-saying-hi') { | |
fbCode = '6015045403901'; | |
} | |
$scope.formState = 'thankyou-message'; | |
$.scrollTo('.the-form-thanks', 400, { | |
'easing': 'easeInOutExpo', | |
'offset': 0 | |
}); | |
addFormClose(); | |
if (fbCode !== false) { | |
addContactFBConversions(fbCode); | |
} | |
addGoogleConversionCode(); | |
} | |
PRERENDER_READY(); // utils.js | |
} | |
$scope.showForm = function (e) { | |
var eAttrs = e.currentTarget.attributes; | |
var slug = eAttrs['data-form-name'].value; | |
updateURL(slug); | |
} | |
$scope.submitForm = function (valid, e) { | |
//console.info(valid, e); | |
e.preventDefault(); | |
e.stopPropagation(); | |
// var passesHoneyPotValidation = $('.verifyName', emailForm).val(); | |
// passesHoneyPotValidation = (passesHoneyPotValidation.length === 0) ? true : false; | |
// console.info(passesHoneyPotValidation); | |
if (true) { | |
var diffs = submissionDifferences(e.currentTarget); | |
var formSelector = '.page-contact .the-form-say-hi '; | |
var siteReferrer = $('#prplSiteReferrer').val(); | |
// console.log(diffs); | |
var classType = false; | |
var tmp = {}; | |
var sfObj = {}; | |
var sel = ''; | |
var sf = { | |
url: "/sfpost.php", | |
oid: "00Do0000000I0Kp", | |
retUrl: "http://prpl.rs", | |
company: "company", | |
budget: "00No0000003BJSj", | |
message: "00No0000003AmaBEAS", | |
first_name: "first_name", | |
last_name: "last_name", | |
email: "email", | |
phone: "phone", | |
lead_source: "lead_source", | |
referrer: "00No0000003BJTD", | |
web_referrer: "00No0000003BJY3" | |
}; | |
if (diffs.formType === 'say-hi') { | |
classType = 'Contact_SayHi'; | |
sel = '.page-contact .the-form-say-hi '; // set relevant jq selecta | |
tmp.reason = $(sel + '[name="reason"]:checked').val(); | |
tmp.name = $(sel + '[name="name"]').val(); | |
tmp.message = $(sel + '[name="message"]').val(); | |
tmp.email = $(sel + '[name="email"]').val(); | |
tmp.phone = $(sel + '[name="phone"]').val(); | |
tmp.referrer = $('#prplSiteReferrer').val(); | |
} else if (diffs.formType === 'speaker-event') { | |
classType = 'Contact_SpeakerEvent'; | |
sel = '.page-contact .the-form-speaker-event '; | |
tmp.event = $(sel + '[name="event"]').val(); | |
tmp.name = $(sel + '[name="name"]').val(); | |
tmp.date = $(sel + '[name="evtDate"]').val(); | |
tmp.reason = $(sel + '[name="whatCanWeDo"]').val(); | |
tmp.email = $(sel + '[name="email"]').val(); | |
tmp.referrer = $('#prplSiteReferrer').val(); | |
} else if (diffs.formType === 'talk-biz') { | |
classType = 'Contact_Business'; | |
sel = '.page-contact .the-form-talk-biz '; | |
tmp.name = $(sel + '[name="name"]').val(), | |
tmp.company = $(sel + '[name="company"]').val(), | |
tmp.message = $(sel + '[name="message"]').val(), | |
tmp.budget = $(sel + '[name="budgetRange"]').val(), | |
tmp.email = $(sel + '[name="email"]').val(), | |
tmp.phone = $(sel + '[name="phone"]').val(), | |
tmp.stated_referrer = $(sel + '[name="stated_referrer"]').val(), | |
tmp.referrer = $('#prplSiteReferrer').val(); | |
splitname = tmp.name.split(" "); | |
sfObj['oid'] = sf.oid; | |
sfObj['retUrl'] = sf.retUrl; | |
sfObj[sf.first_name] = splitname[0]; | |
sfObj[sf.last_name] = splitname.length ? splitname[1] : ""; | |
sfObj[sf.company] = $(sel + '[name="company"]').val(), | |
sfObj[sf.message] = $(sel + '[name="message"]').val(), | |
sfObj[sf.budget] = $(sel + '[name="budgetRange"]').val(), | |
sfObj[sf.email] = $(sel + '[name="email"]').val(), | |
sfObj[sf.phone] = $(sel + '[name="phone"]').val(), | |
sfObj[sf.referrer] = $(sel + '[name="stated_referrer"]').val(), | |
sfObj[sf.web_referrer] = $('#prplSiteReferrer').val(); | |
sfObj[sf.lead_source] = "Web"; | |
//sfObj['debug'] = 1; | |
//sfObj['debugEmail'] = '[email protected]'; | |
// console.log("SF Object: ", sfObj); | |
//=========== AJAX to Pipedrive ========== | |
//Takes two Params | |
// 1.) Type of Request sne to pipedrive. Can be one of the following | |
// 'newDeal' | creates new Deal | |
// 'createNote' | creates new Note | |
// | |
// 2.) Data to be sent(must be object) | |
ajaxPipedrive( 'createOrg', tmp ); | |
} else { | |
console.error('not found, we\'re doomed!'); | |
return false; | |
} | |
//... | |
//;::::; | |
//;::::; :; | |
//;:::::' :; | |
//;:::::; ;. | |
//,:::::' ; OOO\ | |
//::::::; ; OOOOO\ | |
//;:::::; ; OOOOOOOO | |
//,;::::::; ;' / OOOOOOO | |
//;:::::::::`. ,,,;. / / DOOOOOO | |
//.';:::::::::::::::::;, / / DOOOO | |
//,::::::;::::::;;;;::::;, / / DOOO | |
//;`::::::`'::::::;;;::::: ,#/ / DOOO | |
//:`:::::::`;::::::;;::: ;::# / DOOO | |
//::`:::::::`;:::::::: ;::::# / DOO | |
//`:`:::::::`;:::::: ;::::::#/ DOO | |
//:::`:::::::`;; ;:::::::::## OO | |
//::::`:::::::`;::::::::;:::# OO | |
//`:::::`::::::::::::;'`:;::# O | |
//`:::::`::::::::;' / / `:# | |
//::::::`:::::;' / / `# | |
//@@@@@@@ @@@ @@@@@@@ @@@@@@@ @@@@@@ @@@@@@@ @@@@@@ @@@@@@@@ | |
//@@! @@@ @@! @@! @@@ @@! @@@ @@! @@@ @@! @@@ !@@ @@! | |
//@!@!!@! !!@ @!@@!@! @!@@!@! @!@!@!@! @!@!!@! !@@!! @!!!:! | |
//!!: :!! !!: !!: !!: !!: !!! !!: :!! !:! !!: | |
//: : : : : : : : : : : : ::.: : : :: ::: | |
var ParseClass = Parse.Object.extend(classType); | |
var parseClass = new ParseClass(); | |
parseClass.save( tmp , { | |
success: function(object) { | |
// console.info('dongs', object); | |
$location.path(diffs.tyURL).replace(); | |
$scope.$apply(); | |
}, | |
error: function(model, error) { | |
console.error(model, error); | |
} | |
}); | |
// AJAX out to be sent to Pipedrive | |
function ajaxPipedrive( requestType, sendData ) { | |
//Modifies data to conform to pipedrive values | |
//based on request type. If you have a better | |
//way of doing this, please do. please. please. | |
switch ( requestType ) { | |
case 'createDeal': | |
var request = { | |
'param': '/deals', | |
'value': sendData.budget, | |
'org_id': sendData.org_id, | |
'person_id': sendData.person_id, | |
'title': sendData.company + ' deal' | |
} | |
break; | |
case 'createNote': | |
var request = { | |
'param': '/notes', | |
'content': 'Initial Message: ' + sendData.message + '<br>_____<br>Refered by: ' + sendData.stated_referrer, | |
'deal_id' : sendData.deal_id | |
} | |
break; | |
case 'createOrg': | |
var request = { | |
'param': '/organizations', | |
'name': sendData.company | |
} | |
break; | |
case 'createPerson': | |
var request = { | |
'param': '/persons', | |
'name': sendData.name, | |
'org_id': sendData.org_id, | |
'email': sendData.email, | |
'phone': sendData.phone | |
} | |
break; | |
default: | |
return false; | |
} | |
$.ajax({ | |
url: '/submit.php', | |
type: 'POST', | |
dataType: 'json', | |
data: request, | |
success: function( response ) { | |
//Show success response | |
if (response.success) { | |
//This is some bull right here. Bull that works | |
if ( requestType == 'createOrg' ) { | |
tmp.org_id = response.data.id; | |
ajaxPipedrive( 'createPerson', tmp ); | |
} else if ( requestType == 'createPerson' ) { | |
tmp.person_id = response.data.id; | |
ajaxPipedrive( 'createDeal', tmp ); | |
} else if ( requestType == 'createDeal' ) { | |
tmp.deal_id = response.data.id; | |
ajaxPipedrive( 'createNote', tmp ); | |
} else if ( requestType == 'createNote' ) {} | |
} else { | |
// Response failure condition | |
console.log( "JSON sucess, return failed", response ); | |
} | |
}, | |
error: function( error, status, thrown ) { | |
//Show error response | |
console.log( 'AJAX error' ); | |
console.log( status ); | |
console.log( thrown ); | |
} | |
}); | |
} | |
} else { | |
return false; | |
} | |
return false; | |
} | |
function addGoogleConversionCode() { | |
// window.google_trackConversion({ | |
// google_conversion_id: 979906042, | |
// google_conversion_language: "en", | |
// google_conversion_format: "3", | |
// google_conversion_color: "ffffff", | |
// google_conversion_label: "fJicCP6k3AgQ-tug0wM", | |
// google_remarketing_only: true | |
// }); | |
var google_conversion_id = 979906042; | |
var google_conversion_language = "en"; | |
var google_conversion_format = "3"; | |
var google_conversion_color = "ffffff"; | |
var google_conversion_label = "fJicCP6k3AgQ-tug0wM"; | |
var google_conversion_value = 0; | |
$.getScript( "http://www.googleadservices.com/pagead/conversion.js" ); | |
// console.log('google conversion-ed'); | |
}; | |
function parseHello() { | |
console.warn('hello'); | |
} | |
function parseSpeaker() { | |
var formSelector = '.page-contact .the-form-speaker-event '; | |
var siteReferrer = $('#prplSiteReferrer').val(); | |
console.warn('speaker'); | |
} | |
function parseBiz() { | |
var formSelector = '.page-contact .the-form-talk-biz'; | |
var siteReferrer = $('#prplSiteReferrer').val(); | |
console.warn('biz'); | |
} | |
function parseIt(formType) { | |
// console.log(formType); | |
var tmp = {}; | |
var sel = ''; | |
} | |
function submissionDifferences(e_target) { | |
var bizFormClass = 'the-form-talk-biz'; | |
var bizFormSlug = 'talk-biz'; | |
var bizFormTY = "/contact/thanks-biz"; | |
var bizFormCMID = '27b4e06ae8133bff660a5cea2ae86b73'; | |
var bizFormRecipient = '[email protected]'; | |
var bizSubjectLine = 'PRPL Site: New Business'; | |
var bizFormFBConversionID = '6015045364901'; | |
var speakerFormClass = 'the-form-speaker-event'; | |
var speakerFormSlug = 'speaker-event'; | |
var speakerFormTY = "/contact/thanks-speaker"; | |
var speakerFormCMID = '801385cf4bd4d8c7b2572cd5f0b28e48'; | |
var speakerFormRecipient = '[email protected]'; | |
var speakerSubjectLine = 'PRPL Site: Speaking Inquiry'; | |
var speakerFBConversionID = '6015045399901'; | |
var hiFormClass = 'the-form-say-hi'; | |
var hiFormSlug = 'say-hi'; | |
var hiFormTY = "/contact/thanks-for-saying-hi"; | |
var hiFormCMID = '3779c1502913740363cae49644340f69'; | |
var hiFormRecipient = '[email protected]'; | |
var hiSubjectLine = 'PRPL Site: Saying Hi'; | |
var hiFBConversionID = '6015045403901'; | |
var fSlug = false; | |
var response = { | |
'cmID': false, | |
'tyURL': false, | |
'fbCode': false, | |
'recipient': '[email protected]', | |
'subject': 'PRPL Site Message From /Contact' | |
}; | |
// so which is it? | |
if ($(e_target).parent().hasClass(bizFormClass)) { | |
fSlug = bizFormSlug; | |
} else if ($(e_target).parent().hasClass(speakerFormClass)) { | |
fSlug = speakerFormSlug; | |
} else if ($(e_target).parent().hasClass(hiFormClass)) { | |
fSlug = hiFormSlug; | |
} | |
// prep response now we know where you're going | |
if (fSlug === false) { | |
response = false; | |
} else if (fSlug === bizFormSlug) { | |
response.cmID = bizFormCMID; | |
response.tyURL = bizFormTY; | |
response.recipient = bizFormRecipient; | |
response.subject = bizSubjectLine; | |
response.fbCode = bizFormFBConversionID; | |
response.formType = fSlug; | |
} else if (fSlug === speakerFormSlug) { | |
response.cmID = speakerFormCMID; | |
response.tyURL = speakerFormTY; | |
response.recipient = speakerFormRecipient; | |
response.subject = speakerSubjectLine; | |
response.fbCode = speakerFBConversionID; | |
response.formType = fSlug; | |
} else if (fSlug === hiFormSlug) { | |
response.cmID = hiFormCMID; | |
response.tyURL = hiFormTY; | |
response.recipient = hiFormRecipient; | |
response.subject = hiSubjectLine; | |
response.fbCode = hiFBConversionID; | |
response.formType = fSlug; | |
} else { | |
response = false; | |
} | |
return response; | |
} | |
function formHandler(which_str) { | |
var activeForm = (exists(which_str)) ? which_str : false; | |
if (!activeForm) { | |
return false; | |
} | |
_form.active = activeForm; | |
_form.formSelector = '.form-area-contact .the-form-' + activeForm; | |
_form.panelSelector = _form.formSelector + ' .form-panel'; | |
var jqFormPanels = $(_form.panelSelector); | |
// _form.totalPanels = $(_form.panelSelector).length; | |
_form.currentPanel = 0; | |
if (jqFormPanels.length < 1) { | |
return false; | |
} | |
// no panels found, clearly something went wrong | |
addFormClose(); | |
addFormNext(); | |
addFormPrev(); | |
addInputEvents(_form.formSelector); | |
// focus first field unelss touch | |
if (_isTouchDevice === false) { | |
setTimeout(function() { | |
$(_form.formSelector + ' .form-panel.active').find('input.auto-size').first().focus(); | |
}, 500); | |
} | |
} | |
function panelHandler(intent, newVal) { | |
if (!exists(intent)) { | |
return false; | |
} | |
var change = false; | |
if (intent === 'NEXT') { | |
_form.currentPanel++; | |
if ((_form.currentPanel + 1) >= _form.totalPanels) { | |
toggleFormNext(false); | |
$(_form.formSelector + ' > form').submit(); | |
} | |
change = true; | |
} else if (intent === 'PREV') { | |
_form.currentPanel--; | |
change = true; | |
} else if (intent === 'RESET') { | |
_form.currentPanel = 0; | |
change = true; | |
} else if (intent === 'GOTO' && exists(newVal)) { | |
_form.currentPanel = newVal; | |
change = true; | |
} else { | |
return false; | |
} | |
if (change === true) { | |
changePanel(_form.currentPanel); | |
} | |
} | |
function changePanel(toWhat) { | |
if (!exists(toWhat)) { | |
return false; | |
} | |
if (toWhat > 0) { | |
toggleFormPrev(true); | |
} else if (toWhat < 1) { | |
toggleFormPrev(false); | |
} | |
cheekyTrack(toWhat); | |
var sel = _form.panelSelector + ':eq(' + toWhat + ')'; | |
$(_form.panelSelector).removeClass('active'); | |
$(sel).addClass('active'); | |
clearTimeout(autoAdvanceTimer); | |
var isTimed = $(sel).hasClass('form-panel-auto-advance'); | |
if (isTimed) { | |
var dur = $(sel).data().advanceDuration; | |
startAutoAdvanceTimer(dur); | |
} else { | |
var tmpSel = sel + ' input, ' + sel + ' textarea'; | |
// console.log('is touch dvice?', _isTouchDevice); | |
if (_isTouchDevice === false) { | |
$(tmpSel).first().focus(); | |
} | |
validateField(tmpSel); | |
} | |
// start hack on page load it sometimes shows the length doubled, no idea why? a DOM hangover? | |
_form.totalPanels = $(_form.panelSelector).length; | |
// end hack | |
showSubmitIfNecessary(); | |
updateProgress(); | |
} | |
function startAutoAdvanceTimer(dur) { | |
// console.info('advance timer: ', dur); | |
if (!exists(dur)) { | |
dur = 5000; | |
} | |
autoAdvanceTimer = setTimeout(function () { | |
// console.info('timer complete'); | |
panelHandler('NEXT'); | |
}, dur); | |
} | |
function stopAutoAdvanceTimer() { | |
// console.info('timer cancelled'); | |
//clearTimeout(autoAdvanceTimer); | |
} | |
function addInputEvents(form_sel) { | |
// var inputSelector = form_sel + ' .form-panel input, ' + form_sel + ' .form-panel textarea, ' + form_sel + ' .form-panel select'; | |
var inputSelector = form_sel + ' .form-panel input[type="text"], ' + form_sel + ' .form-panel input[type="email"], ' + form_sel + ' .form-panel input[type="tel"]'; | |
var textareaSelector = form_sel + ' .form-panel textarea'; | |
var radioSelector = form_sel + ' .form-panel input[type="radio"]'; | |
var selectSelector = form_sel + ' .form-panel .custom-select select'; | |
var jqInputs = $(inputSelector); | |
var jqTextAreas = $(textareaSelector); | |
var jqRadios = $(radioSelector); | |
var jqSelects = $(selectSelector); | |
var inputTimer; | |
jqInputs.off('keyup').on({ | |
keyup: function (e) { | |
var kPressed = e.keyCode ? e.keyCode : e.charCode; | |
var enterCode = 13; | |
if (kPressed === enterCode) { | |
var validated = validateField(e.currentTarget); | |
if (validated.isValid) { | |
panelHandler('NEXT'); | |
$(e.currentTarget).blur(); | |
} | |
} else { | |
clearTimeout(inputTimer); | |
inputTimer = setTimeout(function () { | |
var validated = validateField(e.currentTarget); | |
clearTimeout(inputTimer); | |
}, 300); | |
} | |
} | |
}); | |
jqTextAreas.off('keyup').on({ | |
keyup: function (e) { | |
clearTimeout(inputTimer); | |
inputTimer = setTimeout(function () { | |
var validated = validateField(e.currentTarget); | |
clearTimeout(inputTimer); | |
}, 300); | |
} | |
}); | |
jqRadios.off('change').on({ | |
change: function (e) { | |
var jqTarg = $(e.currentTarget).parent().find('input'); | |
setTimeout(function () { | |
validateField(jqTarg[0]); | |
// if(validated.isValid){ panelHandler('NEXT'); } | |
}, 500); | |
} | |
}); | |
$scope.budgetRange = 0; | |
jqSelects.off('change').on({ | |
change: function (e) { | |
var jqTarg = $(e.currentTarget); | |
validateField(jqTarg[0]); | |
// setTimeout(function () { | |
// validateField(jqTarg[0]); | |
// if(validated.isValid){ panelHandler('NEXT'); } | |
// }, 500); | |
} | |
}); | |
} | |
function validateField(c_target) { | |
var response = {}; | |
var validField = $(c_target).hasClass('ng-valid'); | |
var fieldName = $(c_target).attr('name'); | |
if (fieldName === 'budgetRange') { | |
// console.info('triggered by budgie', $(c_target).val(), fieldName, validField); | |
if ($(c_target).val() === "0") { | |
validField = false; | |
} else { | |
validField = true; | |
} | |
} | |
if (validField === true) { | |
toggleFormNext(true); | |
response.isValid = true; | |
} else { | |
toggleFormNext(false); | |
response.isValid = false; | |
} | |
response.name = fieldName; | |
return response; | |
} | |
function addFormClose() { | |
$('.form-area-contact .btn-close').off('click').on({ | |
click: function (e) { | |
updateURL('RESET'); | |
} | |
}); | |
} | |
function addFormNext() { | |
$('.form-area-contact .btn-next').off('click').on({ | |
click: function (e) { | |
if ($(e.currentTarget).hasClass('disabled')) { | |
return false; | |
} | |
panelHandler('NEXT'); | |
} | |
}); | |
} | |
function addFormPrev() { | |
$('.form-area-contact .btn-prev').off('click').on({ | |
click: function (e) { | |
if ($(e.currentTarget).hasClass('disabled')) { | |
return false; | |
} | |
panelHandler('PREV'); | |
} | |
}); | |
} | |
function toggleFormNext(enabled) { | |
if (enabled) { | |
$('.form-area-contact .btn-next').removeClass('disabled'); | |
} else { | |
$('.form-area-contact .btn-next').addClass('disabled'); | |
} | |
} | |
function toggleFormPrev(enabled) { | |
if (enabled) { | |
$('.form-area-contact .btn-prev').removeClass('disabled'); | |
} else { | |
$('.form-area-contact .btn-prev').addClass('disabled'); | |
} | |
} | |
function updateProgress() { | |
// currentPanel is by index so add one to compensate for non-index based totalPanels | |
var prog = (100 / _form.totalPanels) * (_form.currentPanel + 1); | |
$('.form-area-contact .form-progress .bar').css({ | |
'width': prog + '%' | |
}); | |
// console.info(prog, _form); | |
} | |
function updateURL(str) { | |
var purel; | |
if (exists(str)) { | |
if (str === 'RESET') { | |
// http://stackoverflow.com/questions/17376416/angularjs-how-to-clear-query-parameters-in-the-url | |
$location.search('step', null); | |
// or $location.url($location.path()); | |
$location.path('/contact'); | |
$scope.$apply(); | |
} else { | |
purel = urlSanitize(str); | |
$location.path('/contact/' + purel); | |
} | |
} else { | |
return false; | |
} | |
} | |
function checkValidSlug(slugStr) { | |
if (!exists(slugStr)) { | |
return false; | |
} | |
var arr = [ | |
'talk-biz', 'speaker-event', 'say-hi', | |
'thanks-biz', 'thanks-speaker', 'thanks-for-saying-hi' | |
]; | |
var response = false; | |
for (var i = arr.length - 1; i >= 0; i--) { | |
if (arr[i] === slugStr) { | |
response = true; | |
} | |
}; | |
return response; | |
} | |
function seo(obj) { | |
var flagText, pageTitle, pageDescription, pageKeywords; | |
if (exists(obj)) { | |
pageTitle = (exists(obj.title)) ? obj.title : 'Contact | Purple, Rock, Scissors'; | |
pageDescription = (exists(obj.description)) ? obj.description : "Contact digital agency Purple, Rock, Scissors for new business, career opportunities, or booking an event speaker."; | |
pageKeywords = (exists(obj.keywords)) ? obj.keywords : ''; | |
} | |
// console.info(pageTitle, pageDescription, pageKeywords, window.location.href); | |
$scope.$parent.seo = { | |
title: pageTitle, | |
description: pageDescription, | |
keywords: pageKeywords | |
}; | |
$scope.$parent.social = { | |
title: pageTitle, | |
description: pageDescription, | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
} | |
function addContactFBConversions(theID) { | |
var el = ''; | |
el += '<div id="fbContactSubmissionPixel">'; | |
el += '<script type="text/javascript">'; | |
el += 'var fb_param = {};'; | |
el += '\nfb_param.pixel_id = ' + theID + ';'; | |
el += '\nfb_param.value = "0.00";'; | |
el += '\nfb_param.currency = "USD";'; | |
el += '\n(function(){'; | |
el += "\n\tvar fpw = document.createElement('script');"; | |
el += "\n\tfpw.async = true;"; | |
el += "\n\tfpw.src = '//connect.facebook.net/en_US/fp.js';"; | |
el += "\n\tvar ref = document.getElementsByTagName('script')[0];"; | |
el += "\n\tref.parentNode.insertBefore(fpw, ref);"; | |
el += '\n})();'; | |
el += "</script>"; | |
el += '<noscript><img height="1" width="1" alt="" style="display:none" src="https://www.facebook.com/offsite_event.php?id=' + theID + '&value=0&currency=USD" /></noscript>'; | |
el += "</div>"; | |
if ($('#fbContactSubmissionPixel').length > 0) { | |
$('#fbContactSubmissionPixel').remove(); | |
} | |
$('body').append(el); | |
} | |
function cheekyTrack(indy) { | |
$location.search('step', indy + 1); | |
$scope.$apply(); | |
} | |
function showSubmitIfNecessary() { | |
// smh, look at this conditional hahah | |
if ((_form.currentPanel + 1) == (_form.totalPanels - 1)) { | |
showSubmitButton(); | |
} else { | |
hideSubmitButton(); | |
} | |
} | |
function showSubmitButton() { | |
$('.shared-form-nav .form-steps .btn-next').addClass('pre-submission'); | |
} | |
function hideSubmitButton() { | |
$('.shared-form-nav .form-steps .btn-next').removeClass('pre-submission'); | |
} | |
// removePreloader(); | |
} | |
]); | |
/* CSA ( Consulting Services Agreement ) Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('ConsultingServicesAgreementController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', | |
function ($scope, $sanitize, $routeParams, $location) { | |
PRERENDER_READY(); // utils.js | |
} | |
]); | |
/* FLA ( Facility License Agreement ) Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('FacilityLicenseAgreementController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', | |
function ($scope, $sanitize, $routeParams, $location) { | |
// console.info('master agreement controller'); | |
PRERENDER_READY(); // utils.js | |
} | |
]); | |
/* Home Controller | |
************************************************************************ */ | |
ngPRPL.controller('HomeController', | |
['$scope', '$sanitize', '$resource', 'PRPLPosts', 'PRPLInstagram', '$location', | |
function ($scope, $sanitize, $resource, PRPLPosts, PRPLInstagram, $location) { | |
// $scope.$parent.navFlag = false; | |
$scope.$parent.seo = { | |
description: 'Purple, Rock, Scissors, a digital creative agency in Orlando, FL, provides digital strategy consultation, innovation, and goal-driven design.', | |
keywords: 'digital agency, orlando agency, digital strategy agency, business intelligence services, digital agency of record, goal-driven design', | |
title: 'PRPL | Purple, Rock, Scissors: A Digital Creative Agency in Orlando' | |
}; | |
$scope.$parent.social = { | |
title: 'PRPL | Purple, Rock, Scissors: A Digital Creative Agency in Orlando', | |
description: 'Purple, Rock, Scissors, a digital creative agency in Orlando, FL, provides digital strategy consultation, innovation, and goal-driven design.', | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs', | |
photo: 'http://purplerockscissors.com/assets/images/social.jpg' | |
}; | |
// RECENT POSTS | |
PRPLPosts.get(function(result) { | |
$scope.featuredPosts = result.posts; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
}); | |
// RECENT INSTAGRAMS | |
PRPLInstagram.get(function (result) { | |
$scope.instaPosts = result.data; | |
}); | |
} | |
]); | |
/* Short Linx Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('ShortLinkController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', | |
function ($scope, $sanitize, $routeParams, $location) { | |
var Short_Link = Parse.Object.extend("Short_Link"); | |
var query = new Parse.Query(Short_Link); | |
query.equalTo("short_url", $routeParams.shortLink); | |
query.first({ | |
success: function(result) { | |
// console.info(result); | |
if (typeof result !== 'undefined') { | |
result.increment("views"); | |
result.save(null, { | |
success: function(result) { | |
window.location.href = result.get("long_url"); | |
} | |
}); | |
} else { | |
$location.path('/404'); | |
} | |
}, | |
error: function(error) { | |
// console.info(result); | |
$location.path('/404'); | |
} | |
}); | |
} | |
]); | |
/* MSA (Master Service Agreement) Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('MasterAgreementController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', | |
function ($scope, $sanitize, $routeParams, $location) { | |
// console.info('master agreement controller'); | |
PRERENDER_READY(); // utils.js | |
} | |
]); | |
/* NDA (Non Disclosure Agreement) Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('NonDisclosureAgreementController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', | |
function ($scope, $sanitize, $routeParams, $location) { | |
// console.info('non disclosure controller'); | |
PRERENDER_READY(); // utils.js | |
} | |
]); | |
/* Privacy Policy Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('PrivacyPolicyController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', | |
function ($scope, $sanitize, $routeParams, $location) { | |
// console.info('privacy policy controller'); | |
PRERENDER_READY(); // utils.js | |
} | |
]); | |
/* Process Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('ProcessController', | |
['$scope', '$sanitize', '$location', | |
function ($scope, $sanitize, $location) { | |
// $scope.$parent.navFlag = spacesToNBSP('Approach'); | |
$scope.$parent.seo = { | |
title: 'Process | Purple, Rock, Scissors', | |
description: 'PRPL applies omnichannel strategy and business intelligence to design, development, enterprise integration, and marketing to engage tomorrow’s digital consumers.', | |
keywords: 'digital strategy, experience design, content strategy, data-driven marketing, social media services, video production, digital services, business consultation, business innovation' | |
}; | |
$scope.$parent.social = { | |
title: 'Process | Purple, Rock, Scissors', | |
description: 'PRPL applies omnichannel strategy and business intelligence to design, development, enterprise integration, and marketing to engage tomorrow’s digital consumers.', | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
} | |
]); | |
ngPRPL.controller('FourRiversController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
//social | |
$scope.$parent.seo = { | |
title: '4 Rivers | Work | Purple, Rock, Scissors', | |
description: "4 Rivers Smokehouse sought PRPL’s services to transform their mobile & e-commerce experiences, while conveying their true brand online.", | |
keywords: 'digital agency, mobile website development, e-commerce development, design agency, web design, 4 rivers website, 4 rivers smokehouse, 4rivers, best restaurant website, ecommerce website, ux design, user experience' | |
}; | |
$scope.$parent.social = { | |
title: '4 Rivers | Work | Purple, Rock, Scissors', | |
description: "4 Rivers Smokehouse sought PRPL’s services to transform their mobile & e-commerce experiences, while conveying their true brand online.", | |
photo: "http://purplerockscissors.com/assets/images/4r/hero.jpg", | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('4rivers', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
}); | |
var fourRiverVariables = {}; | |
fourRiverVariables.sliderExists = false; | |
fourRiverVariables.sliderSel = '.increased-sales .iosslider'; | |
var fourRiverFunctions = {}; | |
fourRiverFunctions.createGraphSlider = function() { | |
fourRiverVariables.sliderExists = true; | |
$(fourRiverVariables.sliderSel).iosSlider({ | |
snapToChildren: true, | |
desktopClickDrag: true, | |
snapSlideCenter: true, | |
responsiveSlides: true, | |
infiniteSlider: true, | |
keyboardControls: true, | |
onSlideChange: function(args) { | |
fourRiverFunctions.setActiveGraphSliderDot(args.currentSlideNumber); | |
} | |
}); | |
}; | |
fourRiverFunctions.removeGraphSlider = function() { | |
fourRiverVariables.sliderExists = false; | |
$(fourRiverVariables.sliderSel).iosSlider('destroy'); | |
}; | |
fourRiverFunctions.gotoGraphSlide = function(which) { | |
$(fourRiverVariables.sliderSel).iosSlider('goToSlide', which); | |
}; | |
fourRiverFunctions.setActiveGraphSliderDot = function(which) { | |
$(".increased-sales .pagination-dots [data-slide-ref]").removeClass('active'); | |
$(".increased-sales .pagination-dots [data-slide-ref=" + which + "]").addClass('active'); | |
} | |
$(".increased-sales .pagination-dots [data-slide-ref]").on({ | |
click: function(e) { | |
var eSlide = $(e.currentTarget).data().slideRef; | |
fourRiverFunctions.gotoGraphSlide(eSlide); | |
} | |
}) | |
if ($(window).width() < 1000) { | |
fourRiverFunctions.createGraphSlider(); | |
} else { | |
fourRiverFunctions.removeGraphSlider(); | |
} | |
$(window).on({ | |
resize: function () { | |
if ($(window).width() < 1000) { | |
fourRiverFunctions.createGraphSlider(); | |
} else { | |
fourRiverFunctions.removeGraphSlider(); | |
} | |
} | |
}); | |
} | |
]); | |
ngPRPL.controller('ADUController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
$scope.$parent.seo = { | |
title: 'Adventist University (ADU) | Work | Purple, Rock, Scissors', | |
description: 'Adventist University of Health Sciences partnered with PRPL to define and optimize student lead generation funnels and overhaul their digital experience.', | |
keywords: 'digital strategy, digital agency, lead generation, business intelligence, KPIs, ADU, adventist university, university websites, purple rock scissors, web development, web design' | |
}; | |
$scope.$parent.social = { | |
title: 'Adventist University (ADU) | Work | Purple, Rock, Scissors', | |
description: 'Adventist University of Health Sciences partnered with PRPL to define and optimize student lead generation funnels and overhaul their digital experience.', | |
photo: "http://purplerockscissors.com/assets/images/adu/hero.jpg", | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('adu', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
PRERENDER_READY(); // utils.js | |
}); | |
// case study variables | |
var aduVars = {}; | |
var aduFns = {}; | |
aduVars.$pageScope = $('.page-cs-adu'); | |
} | |
]); | |
ngPRPL.controller('CiscoController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
$scope.$parent.seo = { | |
title: 'Cisco | Work | Purple, Rock, Scissors', | |
description: 'Cisco partnered with PRPL to overhaul their online application for the Cisco International Internship Program (CIIP) in just 12 weeks', | |
keywords: 'digital agency, website development, design agency, web design, django development, ux design, user experience, digital strategy, cisco website, cisco international internship program, CIIP' | |
}; | |
$scope.$parent.social = { | |
title: 'Cisco | Work | Purple, Rock, Scissors', | |
description: 'Cisco partnered with PRPL to overhaul their online application for the Cisco International Internship Program (CIIP) in just 12 weeks', | |
photo: "http://purplerockscissors.com/assets/images/cisco/hero.jpg", | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('cisco', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
}); | |
} | |
]); | |
ngPRPL.controller('DavidoffController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
$scope.$parent.seo = { | |
title: 'Davidoff of Geneva Madison Avenue | Work | Purple, Rock, Scissors', | |
description: 'Our partnership with Davidoff of Geneva led us to end-to-end social media management and strategy for their flagship store in NYC, and to great results.', | |
keywords: 'digital agency, digital strategy, social media strategy, social media management, community management, social media agency, Davidoff Madison Avenue, tobacco advertising' | |
}; | |
$scope.$parent.social = { | |
title: 'Davidoff of Geneva Madison Avenue | Work | Purple, Rock, Scissors', | |
description: 'Our partnership with Davidoff of Geneva led us to end-to-end social media management and strategy for their flagship store in NYC, and to great results.', | |
photo: "http://purplerockscissors.com/assets/images/davidoff/hero.jpg", | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('davidoff-madison-ave', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
}); | |
// case study variables | |
var davidoffVars = {}; | |
var davidoffFns = {}; | |
davidoffVars.$pageScope = $('.page-cs-davidoff') | |
davidoffVars.$phoneSlider = $('.davidoff-social-platforms .iosslider', davidoffVars.$pageScope); | |
davidoffVars.phoneSliderCreated = false; | |
davidoffVars.$barGraphSlider = $('.davidoff-charts-area .graph-group-barz .iosslider', davidoffVars.$pageScope); | |
davidoffVars.$circleGraphSlider = $('.davidoff-charts-area .graph-group-circlez .iosslider', davidoffVars.$pageScope); | |
davidoffVars.graphSlidersCreated = false; | |
davidoffFns.createPhoneSlider = function() { | |
davidoffVars.phoneSliderCreated = true; | |
davidoffVars.$phoneSlider.iosSlider({ | |
snapToChildren: true, | |
desktopClickDrag: true, | |
snapSlideCenter: true, | |
responsiveSlides: true, | |
infiniteSlider: true, | |
keyboardControls: true, | |
autoSlide: true | |
}); | |
}; | |
davidoffFns.removePhoneSlider = function() { | |
davidoffVars.phoneSliderCreated = false; | |
davidoffVars.$phoneSlider.iosSlider('destroy'); | |
}; | |
davidoffFns.createGraphSliders = function() { | |
davidoffVars.graphSlidersCreated = true; | |
davidoffVars.$barGraphSlider.iosSlider({ | |
snapToChildren: true, | |
desktopClickDrag: true, | |
snapSlideCenter: true, | |
responsiveSlides: true, | |
infiniteSlider: true, | |
keyboardControls: true, | |
onSlideChange: function(args) { | |
davidoffFns.setActiveBarGraphSliderDot(args.currentSlideNumber); | |
} | |
}); | |
davidoffVars.$circleGraphSlider.iosSlider({ | |
snapToChildren: true, | |
desktopClickDrag: true, | |
snapSlideCenter: true, | |
responsiveSlides: true, | |
infiniteSlider: true, | |
keyboardControls: true, | |
onSlideChange: function(args) { | |
davidoffFns.setActiveCircleGraphSliderDot(args.currentSlideNumber); | |
} | |
}); | |
}; | |
davidoffFns.removeGraphSliders = function() { | |
davidoffVars.graphSlidersCreated = false; | |
davidoffVars.$barGraphSlider.iosSlider('destroy'); | |
davidoffVars.$circleGraphSlider.iosSlider('destroy'); | |
}; | |
davidoffFns.setActiveCircleGraphSliderDot = function(which) { | |
$(".graph-group-circlez .pagination-dots [data-slide-ref]").removeClass('active'); | |
$(".graph-group-circlez .pagination-dots [data-slide-ref=" + which + "]").addClass('active'); | |
}; | |
davidoffFns.setActiveBarGraphSliderDot = function(which) { | |
$(".graph-group-barz .pagination-dots [data-slide-ref]").removeClass('active'); | |
$(".graph-group-barz .pagination-dots [data-slide-ref=" + which + "]").addClass('active'); | |
}; | |
davidoffFns.gotoCircleGraphSlide = function(which) { | |
davidoffVars.$circleGraphSlider.iosSlider('goToSlide', which); | |
}; | |
davidoffFns.gotoBarGraphSlide = function(which) { | |
davidoffVars.$barGraphSlider.iosSlider('goToSlide', which); | |
}; | |
$(".graph-group-barz .pagination-dots [data-slide-ref]").on({ | |
click: function(e) { | |
var eSlide = $(e.currentTarget).data().slideRef; | |
davidoffFns.gotoBarGraphSlide(eSlide); | |
} | |
}); | |
$(".graph-group-circlez .pagination-dots [data-slide-ref]").on({ | |
click: function(e) { | |
var eSlide = $(e.currentTarget).data().slideRef; | |
davidoffFns.gotoCircleGraphSlide(eSlide); | |
} | |
}); | |
// always use phone slider so call it now, | |
// the mobile only ones are called below | |
davidoffFns.createPhoneSlider(); | |
$(window).on({ | |
resize: function () { | |
if ($(window).width() < 1280) { | |
davidoffFns.createGraphSliders(); | |
} else { | |
davidoffFns.removeGraphSliders(); | |
} | |
} | |
}).trigger('resize'); | |
} | |
]); | |
ngPRPL.controller('FleetgisticsController', | |
['$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
$scope.$parent.seo = { | |
title: 'Fleetgistics | Work | Purple, Rock, Scissors', | |
description: 'PRPL rebranded Fleetgistics with a new lead-generating website with motion graphics and geo-targeted landing pages, and implementing an email marketing campaign.', | |
keywords: 'fleetgistics, website for fleetgistics, fleetgistics website, conversion funnel, landing page, user experience, prpl' | |
}; | |
$scope.$parent.social = { | |
title: 'Fleetgistics | Work | Purple, Rock, Scissors', | |
description: 'PRPL rebranded Fleetgistics with a new lead-generating website with motion graphics and geo-targeted landing pages, and implementing an email marketing campaign.', | |
photo: "http://purplerockscissors.com/assets/images/fleetgists/bg-cityscape.png", | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('fleetgistics', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
}); | |
} | |
]); | |
ngPRPL.controller('NASAController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
$scope.$parent.seo = { | |
title: 'NASA IDEAS Case Study | Work | Purple, Rock, Scissors', | |
description: 'NASA partnered with PRPL on their new wearable technology, the Integrated Display and Environmental Awareness System (IDEAS), for the Early Career Initiative (ECI) pilot program.', | |
keywords: 'digital strategy, innovation digital agency, wearable technology, NASA, kennedy space center, NASA digital agency, technology, purple rock scissors' | |
}; | |
$scope.$parent.social = { | |
title: 'NASA | Work | Purple, Rock, Scissors', | |
description: 'NASA partnered with PRPL on their new wearable technology, the Integrated Display and Environmental Awareness System (IDEAS), for the Early Career Initiative (ECI) pilot program.', | |
photo: "http://purplerockscissors.com/assets/images/nasa/hero.jpg", | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('nasa', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
PRERENDER_READY(); // utils.js | |
}); | |
// case study variables | |
var _nasa = {}; | |
_nasa.$pageScope = $('.page-cs-nasa'); | |
_nasa.innit = function() { | |
$('.user-card', _nasa.$pageScope).on({ | |
"click" : function(e) { | |
$(e.currentTarget).toggleClass('is-active'); | |
return false; | |
} | |
}); | |
_nasa.$videos = $("[data-auto-video]", _nasa.$pageScope); | |
if ( _nasa.$videos ) | |
_nasa.initVideos(); | |
_nasa.$cardSlider = $("[data-card-slider]", _nasa.$pageScope); | |
if ( _nasa.$cardSlider ) | |
_nasa.initCardSlider(); | |
_nasa.$helmet = $("[data-nasa-helmet]", _nasa.$pageScope); | |
if ( _nasa.$helmet ) | |
_nasa.initHelmet(); | |
_nasa.$signalingServer = $('[data-nasa-signals]', _nasa.$pageScope); | |
if ( _nasa.$signalingServer ) | |
_nasa.signalDots(); | |
}; | |
_nasa.initVideos = function() { | |
_nasa.hoverRevealDuration = 3000; | |
_nasa.videoRevealTimer; | |
_nasa.$videos.find('a').on({ | |
click: function(e) { | |
clearTimeout( _nasa.videoRevealTimer ); | |
var targ = e.currentTarget; | |
$(targ).parent().addClass('reveal'); | |
$(targ).off('mouseenter mouseleave'); | |
setTimeout(function() { | |
$(targ).hide(); | |
var vid = $(targ).parent().find('video')[0]; | |
vid.play(); | |
}, 500); | |
}, | |
mouseenter: function(e) { | |
_nasa.videoRevealTimer = setTimeout(function() { | |
$(e.currentTarget).click(); | |
}, _nasa.hoverRevealDuration); | |
}, | |
mouseleave: function(e) { | |
clearTimeout( _nasa.videoRevealTimer ); | |
} | |
}); | |
}; | |
_nasa.signalDots = function() { | |
var type, $dot, timer, count = 0, animTo, animDur = 800; | |
timer = setInterval(function() { | |
if ( count === 12 ) { | |
return | |
} | |
type = (Math.round(Math.random())) ? 'top' : 'bottom'; | |
animTo = (type === 'top') ? 1080 : 400; | |
$dot = _nasa.makeSignalDot(type); | |
$("#TUBES .nasa-signals__tube--" + type).append( $dot ); | |
$( $dot ).animate({ | |
cx: animTo | |
}, animDur, function() { | |
$(this).remove(); | |
count--; | |
}) | |
count++; | |
}, (Math.random() * 400) + 300); | |
}; | |
_nasa.makeSignalDot = function(type) { | |
var yPos, xPos, fill = 'white'; | |
if (type === 'top') { | |
yPos = '541.8'; | |
xPos = '400'; | |
} else { | |
yPos = '573.2'; | |
xPos = '1080'; | |
} | |
var $c = document.createElementNS('http://www.w3.org/2000/svg', 'circle'); | |
$c.setAttribute('r', '2.5'); | |
$c.setAttribute('cx', xPos); | |
$c.setAttribute('cy', yPos); | |
$c.setAttribute('fill', fill); | |
return $c; | |
} | |
_nasa.initCardSlider = function() { | |
_nasa.cardsSwiper = new Swiper(_nasa.$cardSlider[0], { | |
slidesPerView: "auto" | |
}); | |
}; | |
_nasa.initHelmet = function() { | |
_nasa.$hotspots = _nasa.$helmet.find('[data-helmet-hotspot]'); | |
_nasa.$hotspotDescriptions = _nasa.$helmet.parent().find('[data-helmet-description]'); | |
_nasa.$hotspotNext = _nasa.$helmet.find('[data-helmet-next]'); | |
_nasa.$hotspotPrev = _nasa.$helmet.find('[data-helmet-prev]'); | |
_nasa.hotspotTotal = _nasa.$hotspots.length; | |
_nasa.hotspotActive = 1; | |
_nasa.$hotspots.on({ | |
click: function(e) { | |
var targ = $(e.currentTarget).attr('data-helmet-hotspot'); | |
_nasa.helmetAction('goto', targ); | |
} | |
}); | |
_nasa.$hotspotNext.on({ | |
click: function (e) { | |
_nasa.helmetAction('next'); | |
return false; | |
} | |
}); | |
_nasa.$hotspotPrev.on({ | |
click: function (e) { | |
_nasa.helmetAction('prev'); | |
return false; | |
} | |
}); | |
}; | |
_nasa.helmetAction = function(action, id) { | |
if (action === 'next') { | |
_nasa.helmetAction('goto', _nasa.getNextHelmetHotspot()); | |
} else if (action === 'prev') { | |
_nasa.helmetAction('goto', _nasa.getPrevHelmetHotspot()); | |
} else if (action === 'goto' && typeof id !== "undefined") { | |
_nasa.$hotspots.attr('class', 'hotspot'); | |
$('[data-helmet-hotspot="' + id + '"]').attr('class', 'hotspot is-active'); | |
_nasa.$hotspotDescriptions.removeClass('is-active'); | |
$('[data-helmet-description="' + id + '"]').addClass('is-active'); | |
_nasa.hotspotActive = Number(id); | |
} | |
}; | |
_nasa.getNextHelmetHotspot = function() { | |
var output = _nasa.hotspotActive + 1; | |
if (output > _nasa.hotspotTotal) | |
output = 1; | |
return output; | |
}; | |
_nasa.getPrevHelmetHotspot = function() { | |
var output = _nasa.hotspotActive - 1; | |
if (output < 1) | |
output = _nasa.hotspotTotal; | |
return output; | |
}; | |
_nasa.innit(); | |
} | |
]); | |
ngPRPL.controller('OUCController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
$scope.$parent.seo = { | |
title: 'OUC | Work | Purple, Rock, Scissors', | |
description: 'OUC enlisted PRPL to pioneer an innovative digital platform, so we took the downtown powerhouse to a new level with an enterprise solution and complete redesign.', | |
keywords: 'OUC, website for OUC, OUC website, Enterprise Service Bus, Orlando Utilities Commission, PRPL, MyOuc, Enterprise Solution' | |
}; | |
$scope.$parent.social = { | |
title: 'OUC | Work | Purple, Rock, Scissors', | |
description: 'OUC enlisted PRPL to pioneer an innovative digital platform, so we took the downtown powerhouse to a new level with an enterprise solution and complete redesign.', | |
photo: "http://purplerockscissors.com/assets/images/ouc/bg-header.jpg", | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('ouc', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
}); | |
} | |
]); | |
ngPRPL.controller('RMCADController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
$scope.$parent.seo = { | |
title: 'RMCAD | Work | Purple, Rock, Scissors', | |
description: "PRPL redesigned RMCAD's website with a fresh new look and a responsive design. RMCAD also kicked off a digital marketing campaign at site launch.", | |
keywords: 'rmcad, rmcad website, website for RMCAD, creative branding, responsive design, search engine marketing, display ads, prpl' | |
}; | |
$scope.$parent.social = { | |
title: 'RMCAD | Work | Purple, Rock, Scissors', | |
description: "PRPL redesigned RMCAD's website with a fresh new look and a responsive design. RMCAD also kicked off a digital marketing campaign at site launch.", | |
url: defragz(window.location.href), | |
photo: "http://purplerockscissors.com/assets/images/rmcad/hero.jpg", | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('rmcad', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
}); | |
} | |
]); | |
ngPRPL.controller('VideriController', | |
[ '$scope', '$sanitize', '$routeParams', '$location', 'PRPLEmployee', | |
function ($scope, $sanitize, $routeParams, $location, PRPLEmployee) { | |
$scope.$parent.seo = { | |
title: 'Videri | Work | Purple, Rock, Scissors', | |
description: 'Videri Chocolate Factory came to PRPL with the challenge of rendering the brand’s in-person feel online, and driving sales outside the factory setting.', | |
keywords: 'Videri Chocolate Factory, web design, marketing, hoefler & co, typography, PRPL' | |
}; | |
$scope.$parent.social = { | |
title: 'Videri | Work | Purple, Rock, Scissors', | |
description: 'Videri Chocolate Factory came to PRPL with the challenge of rendering the brand’s in-person feel online, and driving sales outside the factory setting.', | |
photo: "http://purplerockscissors.com/assets/images/videri/hero.jpg", | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
PRPLEmployee.casestudy('videri', function (res) { | |
var arr = $.map(res.result, function (value, key) { | |
return value; | |
}); | |
$scope.creditsArray = arr; | |
// removePreloader(); | |
PRERENDER_READY(); // utils.js | |
}); | |
} | |
]); | |
/* Case Studies List Controller | |
************************************************************************ */ | |
// | |
ngPRPL.controller('CaseStudiesController', | |
['$scope', '$sanitize', '$location', 'PRPLBlog', | |
function ($scope, $sanitize, $location, PRPLBlog) { | |
// $scope.$parent.navFlag = spacesToNBSP('Case Studies'); | |
$scope.$parent.seo = { | |
title: 'Work | Purple, Rock, Scissors', | |
description: 'View the PRPL case studies and ROI of our web design, web development, and digital marketing strategy services we provide to our clients', | |
keywords: 'prpl case studies, prpl clients, digital marketing, social engagement, web design, web development, seo strategy, ppc strategy, branding, digital strategy' | |
}; | |
$scope.$parent.social = { | |
title: 'Work | Purple, Rock, Scissors', | |
description: 'View the PRPL case studies and ROI of our web design, web development, and digital marketing strategy services we provide to our clients', | |
url: defragz(window.location.href), | |
author: '@prplrckscssrs' | |
}; | |
// PRPLBlog.workPageLinks('launches', function (response) { | |
// console.info('wonga sponsored results:', response); | |
// var data = response; | |
// var title = data.prev["post_title"]; | |
// var url = '/notes/' + data.prev["ID"] + '/' + data.prev["post_name"]; | |
// console.info(img, title, url); | |
// $scope.thePrevPost = { 'img': img, 'title': title, 'url': url }; | |
// var arr = data.posts; | |
// console.log(arr); | |
// for (var i = arr.length - 1; i >= 0; i--) { | |
// console.log(arr[i]["title"]); | |
// }; | |
// }); | |
// removePreloader(0); | |
PRERENDER_READY(); // utils.js | |
} | |
]); | |
/* Angular Directives | |
************************************************************************ */ | |
ngPRPL.directive('prplSeo', [function() { | |
return { | |
restrict: 'E', | |
link: function(scope, element, attrs) { | |
var target = element[0]; | |
var keywords = $('.keywords', target).text(); | |
var description = $('.description', target).text(); | |
var title = $('.title', target).html(); | |
var jqHead = $('html > head'); | |
$('meta[name="keywords"]', jqHead).attr('content', keywords); | |
$('meta[name="description"]', jqHead).attr('content', description); | |
$('title', jqHead).html(title); | |
$(target).remove(); | |
} | |
} | |
} | |
]); | |
// ngPRPL.directive('ngBindModel',function($compile){ | |
// return{ | |
// compile:function(tEl,tAtr){ | |
// tEl[0].removeAttribute('ng-bind-model') | |
// return function(scope){ | |
// tEl[0].setAttribute('ng-model',scope.$eval(tAtr.ngBindModel)) | |
// $compile(tEl[0])(scope) | |
// console.info('new compiled element:',tEl[0]) | |
// } | |
// } | |
// } | |
// }); | |
ngPRPL.directive('ngBindAttrs', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
scope.$watch(attrs.ngBindAttrs, function(value) { | |
angular.forEach(value, function(value, key) { | |
attrs.$set(key, value); | |
}); | |
}, true); | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('toggleAnimate', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
setInterval(function() { | |
$('.django-image').removeClass('animate-code'); | |
setTimeout(function() { | |
$('.django-image').addClass('animate-code'); | |
}, 50); | |
}, 3400); | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('mudChartStrategy', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
// var target = element[0]; | |
$('.chart-digital-strategy [data-toggle]').on({ | |
mouseover: function(e) { | |
$(e.currentTarget).trigger('click', e); | |
}, | |
click: function(e) { | |
$('.chart-digital-strategy .is-active').removeClass('is-active'); | |
var dat = $(e.currentTarget).addClass('is-active').data(); | |
var lolsvg = $('.chart-digital-strategy [data-line="' + dat.toggle + '"]')[0]; | |
lolsvg.classList.add('is-active'); | |
} | |
}); | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('mudChartScalability', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
$('.chart-scalability .c2-wrap .c2-circ').on({ | |
mouseover: function(e) { | |
var jqTarget = $(e.currentTarget); | |
var jqPointerCircle = $('.c2-wrap .c2-center'); | |
//jqTarget.addClass('focused'); | |
var data = jqTarget.data(); | |
var targetOrder = (typeof data.order !== 'undefined') ? data.order : 1; | |
var totalLength = 6; | |
var targetName = (typeof data.name !== 'undefined') ? data.name : 'strategist'; | |
// var rotation = ((360/totalLength) * (targetOrder-1)) - 90; // subtract 90 due to initial pointer rotation | |
var bgColor = jqTarget.find('.c2-label').css('color'); | |
// jqPointerCircle.find('svg').css({ '-webkit-transform': 'rotate(' + rotation + 'deg)'}); | |
jqPointerCircle.find('svg path, svg polygon').css({ | |
'fill': bgColor | |
}); | |
}, | |
click: function(e) { | |
$(e.currentTarget).trigger('mouseover'); | |
} | |
}); | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('prplSpinner', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
var el = ""; | |
el += '<div class="spinner">'; | |
el += '<div class="rect1"></div>'; | |
el += '<div class="rect2"></div>'; | |
el += '<div class="rect3"></div>'; | |
el += '<div class="rect4"></div>'; | |
el += '<div class="rect5"></div>'; | |
el += '</div>' | |
$(element).append(el) | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('prplCareersReasons', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
var jqContainer = $('.the-reasons'); | |
var jqPanels = $('.the-reasons .reason'); | |
var jqPanelContainer = $('.the-reasons .reason-container > .vertical-child'); | |
// var randomIndex = Math.floor(Math.random() * panelLength); | |
var currentIndex = 0; | |
var panelLength = jqPanels.length; | |
if (panelLength < 1) { | |
return false; | |
} | |
// jqPanels = shuffleArray(jqPanels); | |
// jqPanelContainer.html(jqPanels); | |
// jqPanelContainer.children().first().addClass('display'); | |
var vidSrc = $(jqPanels[0]).attr('data-slide-video-src'); | |
var posterSrc = $(jqPanels[0]).attr('data-slide-video-poster'); | |
$('.the-reasons .prpl-bgv').attr('poster', posterSrc); | |
$('.the-reasons .prpl-bgv .src-mp4').attr('src', vidSrc + '.mp4'); | |
$('.the-reasons .prpl-bgv .src-webm').attr('src', vidSrc + '.webmhd.webm'); | |
var vidRef = $('.the-reasons .prpl-bgv')[0]; | |
if (!$('html').hasClass('touch')) { | |
vidRef.load(); | |
} | |
$('.the-reasons .gimme-another').off('click').on({ | |
click: function(e) { | |
currentIndex++; | |
if (currentIndex === panelLength) { | |
currentIndex = 0; | |
} | |
jqContainer = $('.the-reasons'); | |
jqPanels = $('.the-reasons .reason'); | |
jqPanelContainer = $('.the-reasons .reason-container > .vertical-child'); | |
jqPanels.removeClass('display'); | |
// console.info(jqPanels[currentIndex]) | |
$(jqPanels[currentIndex]).addClass('display'); | |
vidSrc = $(jqPanels[currentIndex]).attr('data-slide-video-src'); | |
posterSrc = $(jqPanels[currentIndex]).attr('data-slide-video-poster'); | |
$('.the-reasons').css({ | |
'background-image': 'url(' + posterSrc + ')' | |
}); | |
$('.the-reasons .prpl-bgv').attr('poster', posterSrc); | |
$('.the-reasons .prpl-bgv .src-mp4').attr('src', vidSrc + '.mp4'); | |
$('.the-reasons .prpl-bgv .src-webm').attr('src', vidSrc + '.webmhd.webm').parent().addClass('intro'); | |
vidRef = $('.the-reasons .prpl-bgv')[0]; | |
if (!$('html').hasClass('touch')) { | |
vidRef.load(); | |
} | |
} | |
}); | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('prplScrollUp', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
// console.log('only show these elements when scrolling upwards, nav-tag as first') | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('prplDisplayRandom', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
var jqChildren = $(element).find('.random-option'); | |
var indexRange = jqChildren.length; | |
var rando = Math.floor(Math.random() * indexRange); | |
$(jqChildren[rando]).addClass('random-selected'); | |
$(element).addClass('intro'); | |
setInterval(function() { | |
var next, cur; | |
for (var i = jqChildren.length - 1; i >= 0; i--) { | |
if ( $(jqChildren[i]).hasClass('random-selected') ) { | |
next = i; | |
cur = i; | |
} | |
}; | |
next = (next === (jqChildren.length - 1)) ? 0 : next + 1; // reset or increment | |
$(jqChildren[cur]).parent().fadeOut(400, function() { | |
$( jqChildren[cur] ).removeClass('random-selected'); | |
$( jqChildren[next] ).addClass('random-selected').parent().fadeIn(200); | |
}); | |
}, 5000); | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('prplFormTooltip', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
// var jqWrap = $(element); | |
// var strTooltip = jqWrap.find('.tooltip-content').first().html(); | |
// var jqInput = jqWrap.find('input')[0]; | |
// console.info(strTooltip, jqInput); | |
// // build html | |
// var el = ''; | |
// el += '<div class="form-tooltip-wrap">'; | |
// // el += jqInput; | |
// el += ''; | |
// el += '</div>'; | |
// jqWrap.append(el); | |
var jqWrap = $(element); | |
var input = $('input, select, textarea', jqWrap); | |
var tooltip = $('.tooltip-content'); | |
// tooltip.on({ | |
// hover: function(e){ | |
// $('') | |
// } | |
// }) | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('externalLinkCursor', [function() { | |
var linkFn; | |
linkFn = function(scope, element, attrs) { | |
$(element).addClass('external-link').attr('target', '_blank'); | |
}; | |
return { | |
restrict: 'A', | |
link: linkFn | |
} | |
} | |
]); | |
ngPRPL.directive('onscreen', [function() { | |
var linkFn; | |
linkFn = function(scope, element, attrs) { | |
$(element).addClass('offscreen'); | |
$(element).waypoint(function(direction) { | |
// alert('waypoint', direction); | |
$(this).toggleClass('offscreen').toggleClass('onscreen'); | |
}); | |
}; | |
return { | |
restrict: 'A', | |
link: linkFn | |
} | |
} | |
]); | |
ngPRPL.directive('hopdown', [function() { | |
var linkFn; | |
linkFn = function(scope, element, attrs) { | |
$(element).css('cursor', 'pointer').on({ | |
click: function(e) { | |
$(element).velocity("scroll", { | |
duration: 750, | |
easing: "easeInOutCirc", | |
offset: - 100 | |
}) | |
} | |
}) | |
}; | |
return { | |
restrict: 'A', | |
link: linkFn | |
} | |
} | |
]); | |
/** | |
* directive for animating chocolate bars on a conveyor belt | |
* | |
* @author: Parker Hutchinson | |
* @requires: debounce | |
*/ | |
ngPRPL.directive('prplBars', [function() { | |
function link(scope, element, attrs) { | |
var $scope = scope, | |
glob = {}; | |
var init = function() { | |
var $container = $(element).find('ul'), | |
containerW = $(element).outerWidth(), | |
pageW = 1360, | |
leftA = Math.floor((pageW - containerW) / 2), | |
animateA = (640 + leftA) * - 1; | |
// setup the container | |
if (containerW < pageW) { | |
$container.css({ | |
'left': '-' + leftA + 'px' | |
}); | |
} else { | |
leftA = 280; | |
$container.css({ | |
'left': '-260px' | |
}); | |
} | |
var animateAfterResize = debounce(function() { | |
// reset timer after resize | |
window.clearInterval(glob.timer); | |
containerW = $(element).outerWidth(); | |
leftA = Math.floor((pageW - containerW) / 2) + 260; | |
// setup the container after resize | |
if (containerW < pageW) { | |
leftA = Math.floor((pageW - containerW) / 2) + 260; | |
animateA = (640 + leftA) * - 1; | |
$container.css({ | |
'left': '-' + leftA + 'px' | |
}); | |
} else { | |
animateA = (640 + 260) * - 1; | |
leftA = 260; | |
$container.css({ | |
'left': '-280px' | |
}); | |
} | |
// animate function | |
animateBars(animateA, element, leftA); | |
}, 250); | |
// debounce call | |
$(window).on('resize', animateAfterResize); | |
return; | |
} | |
var animateBars = function(animateA, element, leftA) { | |
var count = 0; | |
// slideshow loop | |
glob.timer = window.setInterval(function() { | |
$(element).find('ul').velocity({ | |
left: animateA | |
}, 1500, "easeInOutBack", function() { | |
// prepare next slide animation | |
animateA -= 640; | |
count++; | |
// reset the slider to make it appear infinite | |
if (count == 3) { | |
count = 0; | |
animateA = (640 + leftA) * - 1; | |
$(element).find('ul').css({ | |
"left": "-" + leftA + "px" | |
}); | |
} | |
}); | |
return; | |
}, 2500); | |
return; | |
} | |
//only init after view has loaded | |
$scope.$on('$viewContentLoaded', function() { | |
init(); | |
return; | |
}); | |
} | |
return { | |
restrict: 'A', | |
link: link | |
}; | |
} | |
]); | |
/** | |
* creates directive to attach to videri png chocolate bar sequence | |
* iteration occures on scroll. | |
* | |
* @author Parker Hutchinson | |
* | |
*/ | |
ngPRPL.directive('prplSequence', [function() { | |
var link = function(scope, element, attrs) { | |
var $scope = scope; | |
//main script for animating scroll and png sequence | |
var init = function() { | |
var totalImages = 116, | |
scrollInterval = Math.floor(($(window).height() - $(window).height() * .2) / totalImages), | |
viewport = $(window), | |
images = []; | |
// essentially caches the image location | |
// for easy access | |
for (i = 1; i <= 116; i++) { | |
images.push('http://ffc71bcab7b3b768044d-112878d1308f6723380931f33472aca6.r86.cf1.rackcdn.com/videri/videri_sequence-' + i + '.png'); | |
}; | |
$(images).each(function () { | |
$('<img />')[0].src = this; | |
}); | |
// onload intial | |
$(element).find('img').attr('src', images[1]); | |
setImage() | |
// perform image sequence on a tight scroll no debounce | |
viewport.on('scroll', function () { | |
setImage(); | |
return; | |
}); | |
function setImage() { | |
// animate image only if it is in its section | |
if ($(window).scrollTop() > $(element).offset().top - 600 && $(window).scrollTop() < ($(element).offset().top + $(element).height())) { | |
// prepare img | |
$(element).find('img').addClass("begin"); | |
// iterate over images based on container height | |
i = Math.floor(($(window).scrollTop() - ($(element).offset().top - 600)) / scrollInterval); | |
$(element).find('img').attr('src', images[i]); | |
// animate circles in | |
if (i > (images.length - 40)) { | |
$(element).find('.circle').addClass('active'); | |
} | |
} else { | |
// set img sequence to display none | |
// reset circle animation | |
$(element).find('img').removeClass("begin"); | |
$(element).find('.circle').removeClass('active'); | |
} | |
return; | |
} | |
} | |
//only init after view has loaded | |
$scope.$on('$viewContentLoaded', function() { | |
init(); | |
return; | |
}); | |
}; | |
return { | |
restrict: 'A', | |
link: link | |
}; | |
} | |
]); | |
/** | |
* just a directive wrapper for a plugin called counter.js | |
* looks for elements to count based on class 'count-value' | |
* can use attrs. | |
* | |
* @author: Parker Hutchinson | |
* @requires: prplInview | |
* @attr: counterStart = integer | |
* @attr: counterStop = integer | |
* | |
*/ | |
ngPRPL.directive('prplCounter', [function() { | |
var link = function(scope, element, attrs) { | |
var options = { | |
useEasing : true, | |
useGrouping : true, | |
separator : ',', | |
decimal : '.' | |
}, | |
listener, | |
unlistener, | |
startAt = parseInt(attrs.counterStart) || 0, | |
stopAt = parseInt(attrs.counterStop) || 100, | |
uid = Math.random().toString(36).substr(2, 9); | |
// do a quick id placement based on element scope id | |
$(element).find('.count-value').attr("id", "count" + uid); | |
// create new counter object based on recently created id | |
// start and stop values from attrs | |
var counter = new countUp("count" + uid, 0, stopAt, startAt, 2.8, options); | |
// element enter view listener | |
var countupListener = function() { | |
listener = window.setInterval(function() { | |
if ($(element).hasClass('inviewtop')) { | |
// run counter | |
counter.start(); | |
countupUnlistener(); | |
clearInterval(listener); | |
} | |
}, 20); | |
} | |
// init | |
countupListener(); | |
// reset | |
var countupUnlistener = function() { | |
unlistener = window.setInterval(function() { | |
if (!$(element).hasClass('inviewtop')) { | |
countupListener(); | |
counter.reset(); | |
clearInterval(unlistener); | |
} | |
}, 20); | |
} | |
return; | |
}; | |
return { | |
restrict: 'A', | |
link: link | |
}; | |
} | |
]); | |
/** | |
* custom adaptation of counter to be used with the footer | |
* stats on case studies | |
* | |
* @author: Parker Hutchinson | |
* @requires: prplInview | |
* @attr: startAt = integer | |
* @attr: stopAt = integer | |
* | |
*/ | |
ngPRPL.directive('prplCounterStats', [function() { | |
var link = function(scope, element, attrs) { | |
var options = { | |
useEasing : true, | |
useGrouping : true, | |
separator : ',', | |
decimal : '.' | |
}, | |
listener, | |
startAt = parseInt(attrs.counterStart) || 0, | |
stopAt = parseInt(attrs.counterStop) || 100, | |
uid = Math.random().toString(36).substr(2, 9), | |
unlistener; | |
// console.log(Math.random().toString(36).substr(2,9)); | |
// do a quick id placement based on element scope id | |
$(element).find('.count-value').attr("id", "count" + uid); | |
// create new counter object based on recently created id | |
// start and stop values from attrs | |
var counter = new countUp("count" + uid, 0, stopAt, startAt, 2.8, options); | |
// element enter view listener | |
var countupListener = function() { | |
listener = window.setInterval(function() { | |
if ($(element).hasClass('inviewbottom') && $(element).hasClass('step-active')) { | |
// run counter | |
counter.start(); | |
countupUnlistener(); | |
clearInterval(listener); | |
} | |
}, 20); | |
} | |
countupListener(); | |
var countupUnlistener = function() { | |
unlistener = window.setInterval(function() { | |
if (!$(element).hasClass('inviewbottom')) { | |
countupListener(); | |
counter.reset(); | |
clearInterval(unlistener); | |
} | |
}, 20); | |
} | |
return; | |
}; | |
return { | |
restrict: 'A', | |
link: link | |
}; | |
} | |
]); | |
ngPRPL.directive('prplFsVideo', [function() { | |
var linkFn; | |
linkFn = function(scope, element, attrs) { | |
$(element).on({ | |
click: function(e) { | |
$('body').toggleClass('unlocked').toggleClass('locked'); | |
// CREATION VARS | |
// var cursorURLClose = "/assets/images/video-cursor-close.png"; | |
var chapterCount = 1; | |
var el = ""; | |
var isPaused = false; | |
var fsvLoop; | |
var fsvLoopDelay = 200; | |
var fsvProgress = 0; | |
var fsvDuration = 0; | |
var fsvHover = false; | |
// MOBILE REDIRECT | |
if (jqHTML.hasClass('touch')) { | |
window.open(attrs.videoMp4); | |
return false; | |
} | |
var randomCacheBuster = '?' + Math.floor(Math.random() * (100 - 1) + 1); | |
// THE HTML | |
el += '<aside class="prpl-fsv-wrapper intro">'; | |
el += '<video id="prplFSV" class="prpl-fsv" preload="auto" poster="' + attrs.videoPoster + '" autoplay >'; | |
el += '<source src="' + attrs.videoWebm + randomCacheBuster + '" type="video/webm;">'; | |
el += '<source src="' + attrs.videoMp4 + randomCacheBuster + '" type="video/mp4; codecs="avc1.42E01E, mp4a.40.2"">'; | |
el += '</video>'; | |
el += '<div id="fsvVideoControls">'; | |
el += '<div id="fsvSeekBar" class="seek-bar">'; | |
el += '<div id="fsvInnerSeekBar" class="inner-bar">'; | |
el += '<div id="fsvPlayHead" class="play-head">'; | |
el += '<a id="fsvPlayPause" href="javascript:;" class="play-pause"><i class="icon-pause"></i></a>'; | |
el += '<span id="fsvElapsedTime" class="elapsed-time">0:00</span>'; | |
el += '</div>'; | |
el += '</div>'; | |
el += '<div id="fsvChapters" class="chapters">'; | |
el += '<a id="fsvChapter' + chapterCount++ + '" href="javascript:;" class="fsv-chapter chapter-1"></a>'; | |
el += '<a id="fsvChapter' + chapterCount++ + '" href="javascript:;" class="fsv-chapter chapter-2"></a>'; | |
el += '<a id="fsvChapter' + chapterCount++ + '" href="javascript:;" class="fsv-chapter chapter-3"></a>'; | |
el += '<a id="fsvChapter' + chapterCount++ + '" href="javascript:;" class="fsv-chapter chapter-4"></a>'; | |
el += '<a id="fsvChapter' + chapterCount++ + '" href="javascript:;" class="fsv-chapter chapter-5"></a>'; | |
el += '</div>'; | |
el += '</div>'; | |
el += '</div>'; | |
el += '<a id="fsvFullscreen"><i class="icon-popup"></i></a>'; | |
if (attrs.id == "process") { | |
el += '<div id="fsvTitle" style="display: none;"><span>Bobby Jones</span> <em>Founder & CEO</em></div>' | |
}; | |
el += '</aside>'; | |
// add to DOM | |
$(element).parent().append(el); | |
$('#site-header').addClass('go-away'); | |
// setTimeout(function(){ | |
// $('.prpl-fsv-wrapper').removeClass('intro'); | |
// }, 100) | |
// start interval loop | |
fsvEventLoop(); | |
// JS/JQ DOM SELECTORS | |
// var jqWin // mine is globes | |
var jqFSVWrapper = $('.prpl-fsv-wrapper'); | |
var jsFSVVideo = document.getElementById('prplFSV'); | |
jsFSVVideo.addEventListener('canplaythrough', function() { | |
setTimeout(function() { | |
// console.log('doge video logeded', jsFSVVideo.readyState); | |
// console.info(jsFSVVideo.videoWidth, jsFSVVideo.videoHeight); | |
jqWin.trigger('resize'); | |
$('.prpl-fsv-wrapper').removeClass('intro'); | |
}, 250); | |
}, false); | |
jsFSVVideo.addEventListener('ended', function() { | |
fsvExit(); | |
}, false); | |
// VIDEO EVENT LISTENERS | |
$('#prplFSV', jqFSVWrapper).on({ | |
click: function(e) { | |
fsvExit(); | |
} | |
}); | |
// WINDOW EVENT LISTENERS | |
jqWin.on({ | |
keyup: function(e) { | |
var keyCode = e.keyCode; | |
var esc = (keyCode === 27) ? true : false; | |
var enter = (keyCode === 13) ? true : false; | |
var space = (keyCode === 32) ? true : false; | |
if (esc) { | |
fsvExit(); | |
} | |
if (space) { | |
fsvTogglePause(); | |
} | |
}, | |
resize: function(e) { | |
fsvResizeHandler(e); | |
} | |
}); | |
var jqChild = $(jsFSVVideo); | |
var jqParent = jqFSVWrapper; | |
// CONTROLS EVENT LISTENERS | |
$('.seek-bar', jqFSVWrapper).on({ | |
click: function(e) { | |
// console.log(e.target); | |
var jqTarget = $(e.target); | |
if ( jqTarget.hasClass('seek-bar') || jqTarget.hasClass('inner-bar') ) { | |
fsvSeek(e); | |
} else { | |
fsvTogglePause(); | |
} | |
} | |
}); | |
$('#fsvFullscreen').on({ | |
click: function(e) { | |
fsvFullscreen(); | |
} | |
}) | |
function fsvTogglePause() { | |
if (isPaused) { | |
fsvPlay(); | |
} else { | |
fsvPause(); | |
} | |
} | |
function fsvPlay() { | |
jsFSVVideo.play(); | |
fsvUpdateCSS('playing'); | |
fsvSetIsPaused(false); | |
} | |
function fsvPause() { | |
jsFSVVideo.pause(); | |
fsvUpdateCSS('paused'); | |
fsvSetIsPaused(true); | |
} | |
function fsvStop() { | |
jsFSVVideo.pause(); | |
jsFSVVideo.currentTime = 0; | |
window.clearInterval(fsvLoop); | |
} | |
function fsvGoTo(perc) { | |
if (typeof perc === 'undefined') { | |
return false; | |
} | |
var target = ( fsvDuration / 100 ) * perc ; | |
fsvSetPlayhead(target); | |
fsvUpdateCSS('percent', perc); | |
} | |
function fsvSetPlayhead(toWhat) { | |
jsFSVVideo.currentTime = toWhat; | |
var clean = secondsToHms(toWhat); | |
$('.elapsed-time', jqFSVWrapper).html(clean); | |
} | |
function fsvExit() { | |
fsvStop(); | |
$('body').toggleClass('unlocked').toggleClass('locked'); | |
jqFSVWrapper.addClass('intro'); | |
setTimeout(function() { | |
jqFSVWrapper.remove(); | |
$('#site-header').removeClass('go-away'); | |
}, 200); | |
fsvUpdateCSS('exit'); | |
jqWin.off('keyup'); | |
$('#prplFSV', jqFSVWrapper).off('click'); | |
} | |
function fsvEventLoop() { | |
clearInterval(fsvLoop); | |
fsvLoop = setInterval(function() { | |
if (!isPaused) { | |
fsvUpdateDuration(); | |
if (fsvDuration > 0) { | |
if (attrs.id == "process") { | |
if (jsFSVVideo.currentTime > 7 && jsFSVVideo.currentTime < 14.5) { | |
$('#fsvTitle').css({ | |
bottom: '9%', | |
right: '4%', | |
display: 'block' | |
}) | |
} | |
if (jsFSVVideo.currentTime > 14.5 && jsFSVVideo.currentTime < 15.5) { | |
$('#fsvTitle').css({ | |
display: 'none' | |
}); | |
} | |
if (jsFSVVideo.currentTime > 32 && jsFSVVideo.currentTime < 35) { | |
$('#fsvTitle span').html('Michael Parler'); | |
$('#fsvTitle em').html('Vice President') | |
} | |
if (jsFSVVideo.currentTime > 35.5 && jsFSVVideo.currentTime < 44) { | |
$('#fsvTitle').css({ | |
bottom: '9%', | |
left: '4%', | |
display: 'block' | |
}) | |
} | |
if (jsFSVVideo.currentTime > 44.1 && jsFSVVideo.currentTime < 45) { | |
$('#fsvTitle').css({ | |
display: 'none' | |
}); | |
} | |
if (jsFSVVideo.currentTime > 50 && jsFSVVideo.currentTime < 51) { | |
$('#fsvTitle span').html('Erin Butler'); | |
$('#fsvTitle em').html('Brand & Content Strategist') | |
} | |
if (jsFSVVideo.currentTime > 52 && jsFSVVideo.currentTime < 55) { | |
$('#fsvTitle').css({ | |
bottom: '9%', | |
left: '4%', | |
display: 'block' | |
}) | |
} | |
if (jsFSVVideo.currentTime > 55.3 && jsFSVVideo.currentTime < 57) { | |
$('#fsvTitle').css({ | |
display: 'none' | |
}); | |
} | |
if (jsFSVVideo.currentTime > 72 && jsFSVVideo.currentTime < 73) { | |
$('#fsvTitle span').html('Jim Powell'); | |
$('#fsvTitle em').html('Director of Technology') | |
} | |
if (jsFSVVideo.currentTime > 73 && jsFSVVideo.currentTime < 77) { | |
$('#fsvTitle').css({ | |
bottom: '9%', | |
left: '4%', | |
display: 'block' | |
}) | |
} | |
if (jsFSVVideo.currentTime > 77.1 && jsFSVVideo.currentTime < 78) { | |
$('#fsvTitle').css({ | |
display: 'none' | |
}); | |
} | |
if (jsFSVVideo.currentTime > 91 && jsFSVVideo.currentTime < 93) { | |
$('#fsvTitle span').html('Kristina Doyle'); | |
$('#fsvTitle em').html('Director of Marketing') | |
} | |
if (jsFSVVideo.currentTime > 93 && jsFSVVideo.currentTime < 95) { | |
$('#fsvTitle').css({ | |
bottom: '9%', | |
left: '4%', | |
display: 'block' | |
}) | |
} | |
if (jsFSVVideo.currentTime > 95.4 && jsFSVVideo.currentTime < 97) { | |
$('#fsvTitle').css({ | |
display: 'none' | |
}); | |
} | |
} | |
fsvUpdateProgress(jsFSVVideo.currentTime); | |
} | |
} | |
}, fsvLoopDelay); | |
} | |
function fsvUpdateProgress(timeElapsed) { | |
if (typeof timeElapsed === 'undefined') { | |
return false; | |
} | |
if (fsvProgress !== timeElapsed) { | |
fsvProgress = timeElapsed; | |
fsvUpdateCSS('progress'); | |
var clean = secondsToHms(timeElapsed); | |
$('.elapsed-time', jqFSVWrapper).html(clean); | |
} | |
} | |
function fsvUpdateDuration() { | |
if (fsvDuration !== jsFSVVideo.duration) { | |
fsvDuration = jsFSVVideo.duration; | |
} | |
} | |
function fsvSetIsPaused(toWhat) { | |
if (typeof toWhat === 'undefined') { | |
return false; | |
} else { | |
isPaused = toWhat; | |
return true; | |
} | |
} | |
function fsvUpdateCSS(state, newVal) { | |
if (typeof state === 'undefined') { | |
return false; | |
} else if ( state === 'progress') { | |
var newHeight = (100 / fsvDuration) * fsvProgress; | |
newHeight = Math.round( newHeight * 10) / 10 | |
$('.inner-bar', jqFSVWrapper).css({ | |
height: newHeight + "%" | |
}); | |
} else if ( state === 'percent' && typeof newVal !== 'undefined') { | |
newVal = Math.floor(newVal); | |
$('.inner-bar', jqFSVWrapper).css({ | |
height: newVal + '%' | |
}); | |
} else if ( state === 'playing') { | |
$('.play-pause i', jqFSVWrapper).removeClass('icon-play').addClass('icon-pause'); | |
} else if ( state === 'paused') { | |
$('.play-pause i', jqFSVWrapper).removeClass('icon-pause').addClass('icon-play'); | |
} else if ( state === 'exit') { | |
jqBody.removeClass('view-no-scroll'); | |
} else if (state === 'height' && newVal !== 'undefined') { | |
newVal = Math.floor(newVal); | |
jqChild.css({ | |
'width': 'auto', | |
'height': '100%', | |
'margin-left': '-' + newVal / 2 + 'px', | |
'margin-top': 0 | |
}) | |
} else if (state === 'width' && newVal !== 'undefined') { | |
newVal = Math.floor(newVal); | |
jqChild.css({ | |
'width': '100%', | |
'height': 'auto', | |
'margin-top': '-' + newVal / 2 + 'px', | |
'margin-left': 0 | |
}); | |
} | |
} | |
function fsvSeek(e) { | |
if (typeof e === 'undefined') { | |
return false; | |
} | |
var winH = jqWin.height(); | |
var clickH = e.offsetY; | |
var killaBeez = (100 / winH) * clickH; | |
fsvGoTo(killaBeez); | |
// console.log(winH, clickH, killaBeez); | |
} | |
function fsvGoToChapter(num) { | |
// console.info('good luck haha', num, $('.fsv-chapter')); | |
} | |
function fsvResizeHandler(e) { | |
var cw = jqChild.width(); | |
var ch = jqChild.height(); | |
var pw = jqParent.width(); | |
var ph = jqParent.height(); | |
var cr = ch / cw; | |
var pr = ph / pw; | |
var diffw = cw - pw; | |
var diffh = ch - ph; | |
// console.log('video width', cw, 'video height', ch); | |
// console.log('container width', pw, 'container height', ph); | |
// console.log(cr, pr, diffw, diffh); | |
if (cr < pr) { | |
// console.info('heighttoo short'); | |
fsvUpdateCSS('height', diffw); | |
} else { | |
// console.info('width too short'); | |
// bgvUpdateCSS('reset'); | |
fsvUpdateCSS('width', diffh); | |
} | |
} | |
function fsvFullscreen() { | |
if (jsFSVVideo.requestFullScreen) { | |
jsFSVVideo.requestFullScreen(); | |
} else if (jsFSVVideo.webkitRequestFullScreen) { | |
jsFSVVideo.webkitRequestFullScreen(); | |
} else if (jsFSVVideo.mozRequestFullScreen) { | |
jsFSVVideo.mozRequestFullScreen(); | |
} | |
} | |
} | |
}) | |
}; | |
return { | |
restrict: 'A', | |
link: linkFn | |
} | |
} | |
]); | |
ngPRPL.directive('prplBgv', ['$timeout', function($timeout) { | |
return { | |
restrict: 'E', | |
link: function(scope, element, attrs) { | |
// DOM Referneces | |
var jqTarget = $(element); | |
var jqChildren = $(element).children(); //appended at the end | |
// HTML String | |
var el = ''; | |
// HTML Id for vanilla javascript load listener | |
var tmpID = 'bgv_'; | |
tmpID += randomString(6); | |
// Customization | |
var vidAttrs = { | |
htmlClass: (exists(attrs.class)) ? attrs.class : false, | |
id: (exists(attrs.id)) ? attrs.id : false, | |
poster: (exists(attrs.poster)) ? attrs.poster : false, | |
preload: (exists(attrs.preload)) ? attrs.preload : false, | |
loop: (exists(attrs.loop)) ? true : false, | |
muted: (exists(attrs.muted)) ? true : false, | |
autoplay: (exists(attrs.autoplay)) ? true : false, | |
overlay: (exists(attrs.overlay)) ? attrs.overlay : false, | |
overlayOpacity: (exists(attrs.overlayOpacity)) ? attrs.overlayOpacity : false, | |
viewportResize: (exists(attrs.viewportResize)) ? attrs.viewportResize : false, | |
viewportMin: (exists(attrs.viewportMin)) ? attrs.viewportMin : false | |
}; | |
// console.log(vidAttrs); | |
// Build customized HTML | |
el = '<div class="prpl-bgv-container intro"><video '; | |
// copied attributes | |
if (vidAttrs.htmlClass !== false) { | |
el += 'class="' + vidAttrs.htmlClass + ' prpl-bgv-generated" ' | |
} | |
// if(vidAttrs.id !== false){ el += 'id="' + vidAttrs.id + '" ' } | |
el += 'id="' + tmpID + '" ' | |
if (vidAttrs.poster !== false) { | |
el += 'poster="' + vidAttrs.poster + '" ' | |
} | |
if (vidAttrs.preload !== false) { | |
el += 'preload="' + vidAttrs.preload + '" ' | |
} | |
if (vidAttrs.loop !== false) { | |
el += 'loop="' + vidAttrs.loop + '" ' | |
} | |
if (vidAttrs.muted !== false) { | |
el += 'muted="' + vidAttrs.muted + '" ' | |
} | |
if (vidAttrs.autoplay !== false) { | |
el += 'autoplay' | |
} | |
el += '></video>'; | |
// color overlay if specified | |
if (vidAttrs.overlay !== false) { | |
if (vidAttrs.overlayOpacity == false) { | |
vidAttrs.overlayOpacity = 1; | |
} | |
el += '<div class="bgv-color-overlay ' + vidAttrs.overlay + '" style="opacity:' + vidAttrs.overlayOpacity + '"></div>'; | |
} | |
el += '</div>'; | |
// console.info(el); | |
// Add to <video> to DOM, remove <prpl-bgv> element | |
// Don't run on touch devices | |
if (jqHTML.hasClass('touch')) { | |
el = '<div class="prpl-bgv-container intro"><div class="prpl-bgv-generated prpl-bgv-mobile"></div></div>' | |
} | |
jqTarget.before(el).parent().find('.prpl-bgv-generated').html(jqChildren); | |
jqTarget.remove(); | |
// Updated DOM Refs with video tag added | |
var jqGenerated = $('.prpl-bgv-generated'); | |
jqGenerated.removeClass('prpl-bgv-generated'); | |
var jqChild = jqGenerated; | |
var jqParent = jqGenerated.parent(); | |
var jqCoverParent = jqParent.parent(); | |
var vidRef = jqChild[0]; | |
// vidRef.pause(); | |
// console.info(vidRef); | |
// cover video stuff | |
if (vidAttrs.viewportResize !== false) { | |
bgvUpdateCSS('viewport-height'); | |
} | |
// RESIZING | |
$(window).on({ | |
resize: function() { | |
if (vidAttrs.viewportResize !== false) { | |
bgvUpdateCSS('viewport-height'); | |
} | |
resizeHandler(); | |
} | |
}); | |
function resizeHandler(e) { | |
var cw = jqChild.width(); | |
var ch = jqChild.height(); | |
var pw = jqParent.width(); | |
var ph = jqParent.height(); | |
if ( ch === 0 || ph === 0) { | |
// console.log('handler still attached after navigating to another page, using .off(resize) breaks the careers page proper'); | |
return false; | |
} | |
// console.log(cw, ch, pw, ph); | |
var cr = ch / cw; | |
var pr = ph / pw; | |
var diffw = cw - pw; | |
var diffh = ch - ph; | |
if (cr < pr) { | |
bgvUpdateCSS('height', diffw); | |
} else { | |
bgvUpdateCSS('width', diffh); | |
} | |
// console.info('child ratio', cr, 'parent ratio', pr, 'diff w', diffw, 'diff h', diffh); | |
} | |
// Load handling | |
vidRef.addEventListener('durationchange', function() { | |
// vidRef.play(); | |
$timeout(function() { | |
jqParent.removeClass('intro'); | |
$('.the-reasons .prpl-bgv').removeClass('intro'); | |
}, 800); | |
// setTimeout(function(){ | |
// console.info('durationchange'); | |
// jqParent.css({ 'opacity': 1 }); | |
$(window).trigger('resize'); | |
// }, 1000) | |
}, false); | |
// Update CSS Settings (on resize only at this point) | |
function bgvUpdateCSS(state, offset) { | |
// console.info(state, offset); | |
if (typeof state === 'undefined') { | |
return false; | |
} | |
if (state === 'height' && offset !== 'undefined') { | |
jqChild.css({ | |
'width': 'auto', | |
'height': '100%', | |
'margin-left': '-' + offset / 2 + 'px', | |
'margin-top': 0 | |
}) | |
} else if (state === 'width' && offset !== 'undefined') { | |
jqChild.css({ | |
'width': '100%', | |
'height': 'auto', | |
'margin-top': '-' + offset / 2 + 'px', | |
'margin-left': 0 | |
}); | |
} else if (state === 'viewport-height') { | |
var winH = $(window).height(), | |
winW = $(window).width(); | |
if (winW < 770) { | |
jqCoverParent.css({ | |
'min-height': 'none' | |
}); | |
return false; | |
}; | |
if (vidAttrs.viewportMin !== false) { | |
if (vidAttrs.viewportMin >= winH) { | |
jqCoverParent.css({ | |
'min-height': vidAttrs.viewportMin + 'px' | |
}); | |
} else { | |
jqCoverParent.css({ | |
'min-height': $(window).height() + 'px' | |
}); | |
} | |
} else { | |
jqCoverParent.css({ | |
'min-height': $(window).height() + 'px' | |
}); | |
} | |
} else if (state === 'reset') { | |
jqChild.removeAttr('style'); | |
} | |
} | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('jqScrollTo', [function() { | |
return { | |
restrict: 'A', | |
link: function(scope, element, attrs) { | |
// console.warn('jqscrollto'); | |
var scrollSelector, scrollDuration, scrollEasing, scrollOffset; | |
if (typeof attrs.scrollSelector === 'undefined') { | |
return false; | |
} else { | |
scrollSelector = attrs.scrollSelector; | |
} | |
if (typeof attrs.scrollDuration === 'undefined') { | |
scrollDuration = 800; | |
} else { | |
scrollDuration = Number(attrs.scrollDuration); | |
} | |
if (typeof attrs.scrollEasing === 'undefined') { | |
scrollEasing = 'easeInOutExpo'; | |
} else { | |
scrollEasing = attrs.scrollEasing; | |
} | |
if (typeof attrs.scrollOffset === 'undefined') { | |
scrollOffset = 0; | |
} else { | |
scrollOffset = attrs.scrollOffset; | |
} | |
var $targets = $(element); | |
$targets.off('click').on({ | |
click: function(e) { | |
var $e = $(e.currentTarget); | |
// console.info(scrollSelector, scrollDuration, scrollEasing, scrollOffset); | |
// if(typeof $e.data().scrollTo === 'undefined'){ return false; } | |
$.scrollTo(scrollSelector, scrollDuration, { | |
'easing': scrollEasing, | |
'offset': scrollOffset | |
}); | |
return false; | |
} | |
}); | |
} | |
} | |
} | |
]); | |
ngPRPL.directive('prplFixedNav', [function() { | |
var linkFn; | |
linkFn = function(scope, element, attrs) { | |
// centerFixedPRPLNav(element); | |
// jqWin.on({ resize: function(e){ centerFixedPRPLNav(element); } }); | |
}; | |
return { | |
restrict: 'A', | |
link: linkFn | |
} | |
} | |
]); | |
ngPRPL.directive('navImageSwap', [function() { | |
var linkFn; | |
linkFn = function(scope, element, attrs) { | |
// console.info('iran', $(element).find('a')); | |
$(element).find('a').on({ | |
mouseover: function(e) { | |
var recentSlug = $(e.currentTarget).data().recentWork || false; | |
if (recentSlug === false) { | |
return false; | |
} | |
$(e.currentTarget).addClass('in-focus'); | |
$('.case-study-nav .recents ul').addClass('link-focus'); | |
$('.case-study-nav .images-to-swap [data-recent-work="' + recentSlug + '"]').addClass('hovered'); | |
}, | |
mouseout: function(e) { | |
$('.case-study-nav .recents .hover-nav').removeClass('in-focus'); | |
$('.case-study-nav .recents ul').removeClass('link-focus'); | |
$('.case-study-nav .images-to-swap [data-recent-work]').removeClass('hovered'); | |
} | |
}) | |
}; | |
return { | |
restrict: 'A', | |
link: linkFn | |
} | |
} | |
]); | |
ngPRPL.directive('hasProgIndicator', [ '$timeout', function($timeout) { | |
function updateProgBar(perc, dir) { | |
// console.info(perc, dir); | |
$("#progress-indicator .bar-highlight").css({ | |
'height': perc + '%' | |
}); | |
} | |
return { | |
restrict: 'A', | |
link: function() { | |
$timeout(function() { | |
var self = this; | |
self.html = ''; | |
self.customPOI = []; | |
var jqPOI = $('.ng-view-wrap').last().find('[data-prpl-poi]'); | |
// console.log(jqPOI) | |
if (jqPOI.length < 2) { | |
return false; | |
} | |
for (var i = 0; i < jqPOI.length; i++) { | |
var data = $(jqPOI[i]).data(); | |
var tmp = {}; | |
tmp.text = data.prplPoi; | |
tmp.tooltipText = spacesToNBSP(data.prplPoi); | |
tmp.selector = $(jqPOI[i]).attr('class'); | |
tmp.selectorAlt = "[data-prpl-poi='" + data.prplPoi + "']"; | |
self.customPOI.push(tmp); | |
}; | |
var poiLength = self.customPOI.length; | |
var segmentH = 40; | |
if (poiLength > 10) { | |
if (poiLength > 16) { | |
segmentH = 20; | |
} else { | |
segmentH = 30; | |
} | |
} | |
self.cssValues = { | |
'segmentHeight': segmentH, | |
'count': poiLength, | |
'totalHeight': segmentH * (poiLength - 1) | |
} | |
var elDefault, elHighlight, elHitbox; | |
elDefault = '<div class="bar-default">'; | |
elHighlight = '<div class="bar-highlight">'; | |
elHitbox = '<div class="prog-tooltips">'; | |
elDefault += '<span class="prog-bar"></span>'; | |
elHighlight += '<span class="prog-bar"></span>'; | |
elDefault += '<div class="prog-dots">'; | |
elHighlight += '<div class="prog-dots">'; | |
for (var i = 0; i < poiLength; i++) { | |
elDefault += '<span style="top:' + (self.cssValues.segmentHeight * i) + 'px;" class="prog-dot pd' + (i + 1) + '"></span>'; | |
elHighlight += '<span style="top:' + (self.cssValues.segmentHeight * i) + 'px;" class="prog-dot pd' + (i + 1) + '"></span>'; | |
elHitbox += '<a href="javascript:;" style="height:' + (self.cssValues.segmentHeight) + 'px;" class="hitbox" data-poi-index="' + i + '" data-poi-selector="' + self.customPOI[i].text + '">'; | |
elHitbox += '<span class="text-wrap"><span class="the-text">' + self.customPOI[i].tooltipText + '</span></span>' | |
elHitbox += '</a>'; | |
}; | |
elDefault += '</div>'; | |
elHighlight += '</div>'; | |
elDefault += '</div>'; | |
elHighlight += '</div>'; | |
elHitbox += '</div>'; | |
self.html = elDefault + elHighlight + elHitbox; | |
$('#progress-indicator .points-of-interest').html('').html(self.html); | |
$('#progress-indicator, #progress-indicator .points-of-interest').css({ | |
'height': self.cssValues.totalHeight + 'px' | |
}); | |
$('#progress-indicator .points-of-interest a.hitbox').off('click').on({ | |
click: function(e) { | |
var sSelector, sDuration, sEasing, sOffset; | |
sSelector = '[data-prpl-poi="' + $(e.currentTarget).attr('data-poi-selector') + '"]'; | |
sDuration = 800; | |
sEasing = 'easeInOutExpo'; | |
sOffset = 0; | |
// $.scrollTo(sSelector, sDuration, {'easing': sEasing, 'offset': sOffset}); | |
$(sSelector).velocity("scroll", { | |
duration: 750, | |
easing: "easeInOutCirc" | |
}) | |
}, | |
mouseover: function(e) { | |
$(e.currentTarget).addClass('hovered'); | |
}, | |
mouseout: function(e) { | |
$(e.currentTarget).removeClass('hovered'); | |
} | |
}); | |
for (var i = 0; i < self.customPOI.length; i++) { | |
$(self.customPOI[i].selectorAlt).waypoint('destroy'); | |
$(self.customPOI[i].selectorAlt).waypoint(function(direction) { | |
// alert('waypointin'); | |
// console.log(this, direction) | |
if (direction == 'up') { | |
var target = this; | |
var data = $(target).data(); | |
var sel = '[data-poi-selector="' + data.prplPoi + '"]'; | |
var selData = $(sel).data(); | |
// console.info(sel, selData); | |
if (exists(selData)) { | |
if (exists(selData.poiIndex)) { | |
var currentPOI = selData.poiIndex; | |
var totalPOIs = (self.cssValues.count - 1); | |
var progPercent = (100 / totalPOIs) * currentPOI; | |
// console.log(currentPOI, totalPOIs, progPercent); | |
//console.log('update!', this); | |
$timeout(function() { | |
updateProgBar(progPercent, direction); | |
}, 100) | |
} else { | |
return false; | |
} | |
} else { | |
return false; | |
} | |
} else if (direction == 'down') { | |
var target = this; | |
var data = $(target).data(); | |
var sel = '[data-poi-selector="' + data.prplPoi + '"]'; | |
var selData = $(sel).data(); | |
if (exists(selData)) { | |
if (exists(selData.poiIndex)) { | |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment