-
-
Save koblas/3136961 to your computer and use it in GitHub Desktop.
Puma.com source code
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
(function (E, B) { | |
function ka(a, b, d) { | |
if (d === B && a.nodeType === 1) { | |
d = a.getAttribute("data-" + b); | |
if (typeof d === "string") { | |
try { | |
d = d === "true" ? true : d === "false" ? false : d === "null" ? null : !c.isNaN(d) ? parseFloat(d) : Ja.test(d) ? c.parseJSON(d) : d | |
} catch (e) {} | |
c.data(a, b, d) | |
} else d = B | |
} | |
return d | |
} | |
function U() { | |
return false | |
} | |
function ca() { | |
return true | |
} | |
function la(a, b, d) { | |
d[0].type = a; | |
return c.event.handle.apply(b, d) | |
} | |
function Ka(a) { | |
var b, d, e, f, h, l, k, o, x, r, A, C = []; | |
f = []; | |
h = c.data(this, this.nodeType ? "events" : "__events__"); | |
if (typeof h === "function") h = h.events; | |
if (!(a.liveFired === this || !h || !h.live || a.button && a.type === "click")) { | |
if (a.namespace) A = RegExp("(^|\\.)" + a.namespace.split(".").join("\\.(?:.*\\.)?") + "(\\.|$)"); | |
a.liveFired = this; | |
var J = h.live.slice(0); | |
for (k = 0; k < J.length; k++) { | |
h = J[k]; | |
h.origType.replace(X, "") === a.type ? f.push(h.selector) : J.splice(k--, 1) | |
} | |
f = c(a.target).closest(f, a.currentTarget); | |
o = 0; | |
for (x = f.length; o < x; o++) { | |
r = f[o]; | |
for (k = 0; k < J.length; k++) { | |
h = J[k]; | |
if (r.selector === h.selector && (!A || A.test(h.namespace))) { | |
l = r.elem; | |
e = null; | |
if (h.preType === "mouseenter" || h.preType === "mouseleave") { | |
a.type = h.preType; | |
e = c(a.relatedTarget).closest(h.selector)[0] | |
} | |
if (!e || e !== l) C.push({ | |
elem: l, | |
handleObj: h, | |
level: r.level | |
}) | |
} | |
} | |
} | |
o = 0; | |
for (x = C.length; o < x; o++) { | |
f = C[o]; | |
if (d && f.level > d) break; | |
a.currentTarget = f.elem; | |
a.data = f.handleObj.data; | |
a.handleObj = f.handleObj; | |
A = f.handleObj.origHandler.apply(f.elem, arguments); | |
if (A === false || a.isPropagationStopped()) { | |
d = f.level; | |
if (A === false) b = false; | |
if (a.isImmediatePropagationStopped()) break | |
} | |
} | |
return b | |
} | |
} | |
function Y(a, b) { | |
return (a && a !== "*" ? a + "." : "") + b.replace(La, "`").replace(Ma, "&") | |
} | |
function ma(a, b, d) { | |
if (c.isFunction(b)) return c.grep(a, function (f, h) { | |
return !!b.call(f, h, f) === d | |
}); | |
else if (b.nodeType) return c.grep(a, function (f) { | |
return f === b === d | |
}); | |
else if (typeof b === "string") { | |
var e = c.grep(a, function (f) { | |
return f.nodeType === 1 | |
}); | |
if (Na.test(b)) return c.filter(b, e, !d); | |
else b = c.filter(b, e) | |
} | |
return c.grep(a, function (f) { | |
return c.inArray(f, b) >= 0 === d | |
}) | |
} | |
function na(a, b) { | |
var d = 0; | |
b.each(function () { | |
if (this.nodeName === (a[d] && a[d].nodeName)) { | |
var e = c.data(a[d++]), | |
f = c.data(this, e); | |
if (e = e && e.events) { | |
delete f.handle; | |
f.events = {}; | |
for (var h in e) for (var l in e[h]) c.event.add(this, h, e[h][l], e[h][l].data) | |
} | |
} | |
}) | |
} | |
function Oa(a, b) { | |
b.src ? c.ajax({ | |
url: b.src, | |
async: false, | |
dataType: "script" | |
}) : c.globalEval(b.text || b.textContent || b.innerHTML || ""); | |
b.parentNode && b.parentNode.removeChild(b) | |
} | |
function oa(a, b, d) { | |
var e = b === "width" ? a.offsetWidth : a.offsetHeight; | |
if (d === "border") return e; | |
c.each(b === "width" ? Pa : Qa, function () { | |
d || (e -= parseFloat(c.css(a, "padding" + this)) || 0); | |
if (d === "margin") e += parseFloat(c.css(a, "margin" + this)) || 0; | |
else e -= parseFloat(c.css(a, "border" + this + "Width")) || 0 | |
}); | |
return e | |
} | |
function da(a, b, d, e) { | |
if (c.isArray(b) && b.length) c.each(b, function (f, h) { | |
d || Ra.test(a) ? e(a, h) : da(a + "[" + (typeof h === "object" || c.isArray(h) ? f : "") + "]", h, d, e) | |
}); | |
else if (!d && b != null && typeof b === "object") c.isEmptyObject(b) ? e(a, "") : c.each(b, function (f, h) { | |
da(a + "[" + f + "]", h, d, e) | |
}); | |
else e(a, b) | |
} | |
function S(a, b) { | |
var d = {}; | |
c.each(pa.concat.apply([], pa.slice(0, b)), function () { | |
d[this] = a | |
}); | |
return d | |
} | |
function qa(a) { | |
if (!ea[a]) { | |
var b = c("<" + a + ">").appendTo("body"), | |
d = b.css("display"); | |
b.remove(); | |
if (d === "none" || d === "") d = "block"; | |
ea[a] = d | |
} | |
return ea[a] | |
} | |
function fa(a) { | |
return c.isWindow(a) ? a : a.nodeType === 9 ? a.defaultView || a.parentWindow : false | |
} | |
var t = E.document, | |
c = function () { | |
function a() { | |
if (!b.isReady) { | |
try { | |
t.documentElement.doScroll("left") | |
} catch (j) { | |
setTimeout(a, 1); | |
return | |
} | |
b.ready() | |
} | |
} | |
var b = function (j, s) { | |
return new b.fn.init(j, s) | |
}, | |
d = E.jQuery, | |
e = E.$, | |
f, h = /^(?:[^<]*(<[\w\W]+>)[^>]*$|#([\w\-]+)$)/, | |
l = /\S/, | |
k = /^\s+/, | |
o = /\s+$/, | |
x = /\W/, | |
r = /\d/, | |
A = /^<(\w+)\s*\/?>(?:<\/\1>)?$/, | |
C = /^[\],:{}\s]*$/, | |
J = /\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, | |
w = /"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, | |
I = /(?:^|:|,)(?:\s*\[)+/g, | |
L = /(webkit)[ \/]([\w.]+)/, | |
g = /(opera)(?:.*version)?[ \/]([\w.]+)/, | |
i = /(msie) ([\w.]+)/, | |
n = /(mozilla)(?:.*? rv:([\w.]+))?/, | |
m = navigator.userAgent, | |
p = false, | |
q = [], | |
u, y = Object.prototype.toString, | |
F = Object.prototype.hasOwnProperty, | |
M = Array.prototype.push, | |
N = Array.prototype.slice, | |
O = String.prototype.trim, | |
D = Array.prototype.indexOf, | |
R = {}; | |
b.fn = b.prototype = { | |
init: function (j, s) { | |
var v, z, H; | |
if (!j) return this; | |
if (j.nodeType) { | |
this.context = this[0] = j; | |
this.length = 1; | |
return this | |
} | |
if (j === "body" && !s && t.body) { | |
this.context = t; | |
this[0] = t.body; | |
this.selector = "body"; | |
this.length = 1; | |
return this | |
} | |
if (typeof j === "string") if ((v = h.exec(j)) && (v[1] || !s)) if (v[1]) { | |
H = s ? s.ownerDocument || s : t; | |
if (z = A.exec(j)) if (b.isPlainObject(s)) { | |
j = [t.createElement(z[1])]; | |
b.fn.attr.call(j, s, true) | |
} else j = [H.createElement(z[1])]; | |
else { | |
z = b.buildFragment([v[1]], [H]); | |
j = (z.cacheable ? z.fragment.cloneNode(true) : z.fragment).childNodes | |
} | |
return b.merge(this, j) | |
} else { | |
if ((z = t.getElementById(v[2])) && z.parentNode) { | |
if (z.id !== v[2]) return f.find(j); | |
this.length = 1; | |
this[0] = z | |
} | |
this.context = t; | |
this.selector = j; | |
return this | |
} else if (!s && !x.test(j)) { | |
this.selector = j; | |
this.context = t; | |
j = t.getElementsByTagName(j); | |
return b.merge(this, j) | |
} else return !s || s.jquery ? (s || f).find(j) : b(s).find(j); | |
else if (b.isFunction(j)) return f.ready(j); | |
if (j.selector !== B) { | |
this.selector = j.selector; | |
this.context = j.context | |
} | |
return b.makeArray(j, this) | |
}, | |
selector: "", | |
jquery: "1.4.4", | |
length: 0, | |
size: function () { | |
return this.length | |
}, | |
toArray: function () { | |
return N.call(this, 0) | |
}, | |
get: function (j) { | |
return j == null ? this.toArray() : j < 0 ? this.slice(j)[0] : this[j] | |
}, | |
pushStack: function (j, s, v) { | |
var z = b(); | |
b.isArray(j) ? M.apply(z, j) : b.merge(z, j); | |
z.prevObject = this; | |
z.context = this.context; | |
if (s === "find") z.selector = this.selector + (this.selector ? " " : "") + v; | |
else if (s) z.selector = this.selector + "." + s + "(" + v + ")"; | |
return z | |
}, | |
each: function (j, s) { | |
return b.each(this, j, s) | |
}, | |
ready: function (j) { | |
b.bindReady(); | |
if (b.isReady) j.call(t, b); | |
else q && q.push(j); | |
return this | |
}, | |
eq: function (j) { | |
return j === -1 ? this.slice(j) : this.slice(j, + j + 1) | |
}, | |
first: function () { | |
return this.eq(0) | |
}, | |
last: function () { | |
return this.eq(-1) | |
}, | |
slice: function () { | |
return this.pushStack(N.apply(this, arguments), "slice", N.call(arguments).join(",")) | |
}, | |
map: function (j) { | |
return this.pushStack(b.map(this, function (s, v) { | |
return j.call(s, v, s) | |
})) | |
}, | |
end: function () { | |
return this.prevObject || b(null) | |
}, | |
push: M, | |
sort: [].sort, | |
splice: [].splice | |
}; | |
b.fn.init.prototype = b.fn; | |
b.extend = b.fn.extend = function () { | |
var j, s, v, z, H, G = arguments[0] || {}, | |
K = 1, | |
Q = arguments.length, | |
ga = false; | |
if (typeof G === "boolean") { | |
ga = G; | |
G = arguments[1] || {}; | |
K = 2 | |
} | |
if (typeof G !== "object" && !b.isFunction(G)) G = {}; | |
if (Q === K) { | |
G = this; | |
--K | |
} | |
for (; K < Q; K++) if ((j = arguments[K]) != null) for (s in j) { | |
v = G[s]; | |
z = j[s]; | |
if (G !== z) if (ga && z && (b.isPlainObject(z) || (H = b.isArray(z)))) { | |
if (H) { | |
H = false; | |
v = v && b.isArray(v) ? v : [] | |
} else v = v && b.isPlainObject(v) ? v : {}; | |
G[s] = b.extend(ga, v, z) | |
} else if (z !== B) G[s] = z | |
} | |
return G | |
}; | |
b.extend({ | |
noConflict: function (j) { | |
E.$ = e; | |
if (j) E.jQuery = d; | |
return b | |
}, | |
isReady: false, | |
readyWait: 1, | |
ready: function (j) { | |
j === true && b.readyWait--; | |
if (!b.readyWait || j !== true && !b.isReady) { | |
if (!t.body) return setTimeout(b.ready, 1); | |
b.isReady = true; | |
if (!(j !== true && --b.readyWait > 0)) if (q) { | |
var s = 0, | |
v = q; | |
for (q = null; j = v[s++];) j.call(t, b); | |
b.fn.trigger && b(t).trigger("ready").unbind("ready") | |
} | |
} | |
}, | |
bindReady: function () { | |
if (!p) { | |
p = true; | |
if (t.readyState === "complete") return setTimeout(b.ready, 1); | |
if (t.addEventListener) { | |
t.addEventListener("DOMContentLoaded", u, false); | |
E.addEventListener("load", b.ready, false) | |
} else if (t.attachEvent) { | |
t.attachEvent("onreadystatechange", u); | |
E.attachEvent("onload", b.ready); | |
var j = false; | |
try { | |
j = E.frameElement == null | |
} catch (s) {} | |
t.documentElement.doScroll && j && a() | |
} | |
} | |
}, | |
isFunction: function (j) { | |
return b.type(j) === "function" | |
}, | |
isArray: Array.isArray || function (j) { | |
return b.type(j) === "array" | |
}, | |
isWindow: function (j) { | |
return j && typeof j === "object" && "setInterval" in j | |
}, | |
isNaN: function (j) { | |
return j == null || !r.test(j) || isNaN(j) | |
}, | |
type: function (j) { | |
return j == null ? String(j) : R[y.call(j)] || "object" | |
}, | |
isPlainObject: function (j) { | |
if (!j || b.type(j) !== "object" || j.nodeType || b.isWindow(j)) return false; | |
if (j.constructor && !F.call(j, "constructor") && !F.call(j.constructor.prototype, "isPrototypeOf")) return false; | |
for (var s in j); | |
return s === B || F.call(j, s) | |
}, | |
isEmptyObject: function (j) { | |
for (var s in j) return false; | |
return true | |
}, | |
error: function (j) { | |
throw j; | |
}, | |
parseJSON: function (j) { | |
if (typeof j !== "string" || !j) return null; | |
j = b.trim(j); | |
if (C.test(j.replace(J, "@").replace(w, "]").replace(I, ""))) return E.JSON && E.JSON.parse ? E.JSON.parse(j) : (new Function("return " + j))(); | |
else b.error("Invalid JSON: " + j) | |
}, | |
noop: function () {}, | |
globalEval: function (j) { | |
if (j && l.test(j)) { | |
var s = t.getElementsByTagName("head")[0] || t.documentElement, | |
v = t.createElement("script"); | |
v.type = "text/javascript"; | |
if (b.support.scriptEval) v.appendChild(t.createTextNode(j)); | |
else v.text = j; | |
s.insertBefore(v, s.firstChild); | |
s.removeChild(v) | |
} | |
}, | |
nodeName: function (j, s) { | |
return j.nodeName && j.nodeName.toUpperCase() === s.toUpperCase() | |
}, | |
each: function (j, s, v) { | |
var z, H = 0, | |
G = j.length, | |
K = G === B || b.isFunction(j); | |
if (v) if (K) for (z in j) { | |
if (s.apply(j[z], v) === false) break | |
} else for (; H < G;) { | |
if (s.apply(j[H++], v) === false) break | |
} else if (K) for (z in j) { | |
if (s.call(j[z], z, j[z]) === false) break | |
} else for (v = j[0]; H < G && s.call(v, H, v) !== false; v = j[++H]); | |
return j | |
}, | |
trim: O ? function (j) { | |
return j == null ? "" : O.call(j) | |
} : function (j) { | |
return j == null ? "" : j.toString().replace(k, "").replace(o, "") | |
}, | |
makeArray: function (j, s) { | |
var v = s || []; | |
if (j != null) { | |
var z = b.type(j); | |
j.length == null || z === "string" || z === "function" || z === "regexp" || b.isWindow(j) ? M.call(v, j) : b.merge(v, j) | |
} | |
return v | |
}, | |
inArray: function (j, s) { | |
if (s.indexOf) return s.indexOf(j); | |
for (var v = 0, z = s.length; v < z; v++) if (s[v] === j) return v; | |
return -1 | |
}, | |
merge: function (j, s) { | |
var v = j.length, | |
z = 0; | |
if (typeof s.length === "number") for (var H = s.length; z < H; z++) j[v++] = s[z]; | |
else for (; s[z] !== B;) j[v++] = s[z++]; | |
j.length = v; | |
return j | |
}, | |
grep: function (j, s, v) { | |
var z = [], | |
H; | |
v = !! v; | |
for (var G = 0, K = j.length; G < K; G++) { | |
H = !! s(j[G], G); | |
v !== H && z.push(j[G]) | |
} | |
return z | |
}, | |
map: function (j, s, v) { | |
for (var z = [], H, G = 0, K = j.length; G < K; G++) { | |
H = s(j[G], G, v); | |
if (H != null) z[z.length] = H | |
} | |
return z.concat.apply([], z) | |
}, | |
guid: 1, | |
proxy: function (j, s, v) { | |
if (arguments.length === 2) if (typeof s === "string") { | |
v = j; | |
j = v[s]; | |
s = B | |
} else if (s && !b.isFunction(s)) { | |
v = s; | |
s = B | |
} | |
if (!s && j) s = function () { | |
return j.apply(v || this, arguments) | |
}; | |
if (j) s.guid = j.guid = j.guid || s.guid || b.guid++; | |
return s | |
}, | |
access: function (j, s, v, z, H, G) { | |
var K = j.length; | |
if (typeof s === "object") { | |
for (var Q in s) b.access(j, Q, s[Q], z, H, v); | |
return j | |
} | |
if (v !== B) { | |
z = !G && z && b.isFunction(v); | |
for (Q = 0; Q < K; Q++) H(j[Q], s, z ? v.call(j[Q], Q, H(j[Q], s)) : v, G); | |
return j | |
} | |
return K ? H(j[0], s) : B | |
}, | |
now: function () { | |
return (new Date).getTime() | |
}, | |
uaMatch: function (j) { | |
j = j.toLowerCase(); | |
j = L.exec(j) || g.exec(j) || i.exec(j) || j.indexOf("compatible") < 0 && n.exec(j) || []; | |
return { | |
browser: j[1] || "", | |
version: j[2] || "0" | |
} | |
}, | |
browser: {} | |
}); | |
b.each("Boolean Number String Function Array Date RegExp Object".split(" "), function (j, s) { | |
R["[object " + s + "]"] = s.toLowerCase() | |
}); | |
m = b.uaMatch(m); | |
if (m.browser) { | |
b.browser[m.browser] = true; | |
b.browser.version = m.version | |
} | |
if (b.browser.webkit) b.browser.safari = true; | |
if (D) b.inArray = function (j, s) { | |
return D.call(s, j) | |
}; | |
if (!/\s/.test("\u00a0")) { | |
k = /^[\s\xA0]+/; | |
o = /[\s\xA0]+$/ | |
} | |
f = b(t); | |
if (t.addEventListener) u = function () { | |
t.removeEventListener("DOMContentLoaded", u, false); | |
b.ready() | |
}; | |
else if (t.attachEvent) u = function () { | |
if (t.readyState === "complete") { | |
t.detachEvent("onreadystatechange", u); | |
b.ready() | |
} | |
}; | |
return E.jQuery = E.$ = b | |
}(); | |
(function () { | |
c.support = {}; | |
var a = t.documentElement, | |
b = t.createElement("script"), | |
d = t.createElement("div"), | |
e = "script" + c.now(); | |
d.style.display = "none"; | |
d.innerHTML = " <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>"; | |
var f = d.getElementsByTagName("*"), | |
h = d.getElementsByTagName("a")[0], | |
l = t.createElement("select"), | |
k = l.appendChild(t.createElement("option")); | |
if (!(!f || !f.length || !h)) { | |
c.support = { | |
leadingWhitespace: d.firstChild.nodeType === 3, | |
tbody: !d.getElementsByTagName("tbody").length, | |
htmlSerialize: !! d.getElementsByTagName("link").length, | |
style: /red/.test(h.getAttribute("style")), | |
hrefNormalized: h.getAttribute("href") === "/a", | |
opacity: /^0.55$/.test(h.style.opacity), | |
cssFloat: !! h.style.cssFloat, | |
checkOn: d.getElementsByTagName("input")[0].value === "on", | |
optSelected: k.selected, | |
deleteExpando: true, | |
optDisabled: false, | |
checkClone: false, | |
scriptEval: false, | |
noCloneEvent: true, | |
boxModel: null, | |
inlineBlockNeedsLayout: false, | |
shrinkWrapBlocks: false, | |
reliableHiddenOffsets: true | |
}; | |
l.disabled = true; | |
c.support.optDisabled = !k.disabled; | |
b.type = "text/javascript"; | |
try { | |
b.appendChild(t.createTextNode("window." + e + "=1;")) | |
} catch (o) {} | |
a.insertBefore(b, a.firstChild); | |
if (E[e]) { | |
c.support.scriptEval = true; | |
delete E[e] | |
} | |
try { | |
delete b.test | |
} catch (x) { | |
c.support.deleteExpando = false | |
} | |
a.removeChild(b); | |
if (d.attachEvent && d.fireEvent) { | |
d.attachEvent("onclick", function r() { | |
c.support.noCloneEvent = false; | |
d.detachEvent("onclick", r) | |
}); | |
d.cloneNode(true).fireEvent("onclick") | |
} | |
d = t.createElement("div"); | |
d.innerHTML = "<input type='radio' name='radiotest' checked='checked'/>"; | |
a = t.createDocumentFragment(); | |
a.appendChild(d.firstChild); | |
c.support.checkClone = a.cloneNode(true).cloneNode(true).lastChild.checked; | |
c(function () { | |
var r = t.createElement("div"); | |
r.style.width = r.style.paddingLeft = "1px"; | |
t.body.appendChild(r); | |
c.boxModel = c.support.boxModel = r.offsetWidth === 2; | |
if ("zoom" in r.style) { | |
r.style.display = "inline"; | |
r.style.zoom = 1; | |
c.support.inlineBlockNeedsLayout = r.offsetWidth === 2; | |
r.style.display = ""; | |
r.innerHTML = "<div style='width:4px;'></div>"; | |
c.support.shrinkWrapBlocks = r.offsetWidth !== 2 | |
} | |
r.innerHTML = "<table><tr><td style='padding:0;display:none'></td><td>t</td></tr></table>"; | |
var A = r.getElementsByTagName("td"); | |
c.support.reliableHiddenOffsets = A[0].offsetHeight === 0; | |
A[0].style.display = ""; | |
A[1].style.display = "none"; | |
c.support.reliableHiddenOffsets = c.support.reliableHiddenOffsets && A[0].offsetHeight === 0; | |
r.innerHTML = ""; | |
t.body.removeChild(r).style.display = "none" | |
}); | |
a = function (r) { | |
var A = t.createElement("div"); | |
r = "on" + r; | |
var C = r in A; | |
if (!C) { | |
A.setAttribute(r, "return;"); | |
C = typeof A[r] === "function" | |
} | |
return C | |
}; | |
c.support.submitBubbles = a("submit"); | |
c.support.changeBubbles = a("change"); | |
a = b = d = f = h = null | |
} | |
})(); | |
var ra = {}, | |
Ja = /^(?:\{.*\}|\[.*\])$/; | |
c.extend({ | |
cache: {}, | |
uuid: 0, | |
expando: "jQuery" + c.now(), | |
noData: { | |
embed: true, | |
object: "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000", | |
applet: true | |
}, | |
data: function (a, b, d) { | |
if (c.acceptData(a)) { | |
a = a == E ? ra : a; | |
var e = a.nodeType, | |
f = e ? a[c.expando] : null, | |
h = c.cache; | |
if (!(e && !f && typeof b === "string" && d === B)) { | |
if (e) f || (a[c.expando] = f = ++c.uuid); | |
else h = a; | |
if (typeof b === "object") if (e) h[f] = c.extend(h[f], b); | |
else c.extend(h, b); | |
else if (e && !h[f]) h[f] = {}; | |
a = e ? h[f] : h; | |
if (d !== B) a[b] = d; | |
return typeof b === "string" ? a[b] : a | |
} | |
} | |
}, | |
removeData: function (a, b) { | |
if (c.acceptData(a)) { | |
a = a == E ? ra : a; | |
var d = a.nodeType, | |
e = d ? a[c.expando] : a, | |
f = c.cache, | |
h = d ? f[e] : e; | |
if (b) { | |
if (h) { | |
delete h[b]; | |
d && c.isEmptyObject(h) && c.removeData(a) | |
} | |
} else if (d && c.support.deleteExpando) delete a[c.expando]; | |
else if (a.removeAttribute) a.removeAttribute(c.expando); | |
else if (d) delete f[e]; | |
else for (var l in a) delete a[l] | |
} | |
}, | |
acceptData: function (a) { | |
if (a.nodeName) { | |
var b = c.noData[a.nodeName.toLowerCase()]; | |
if (b) return !(b === true || a.getAttribute("classid") !== b) | |
} | |
return true | |
} | |
}); | |
c.fn.extend({ | |
data: function (a, b) { | |
var d = null; | |
if (typeof a === "undefined") { | |
if (this.length) { | |
var e = this[0].attributes, | |
f; | |
d = c.data(this[0]); | |
for (var h = 0, l = e.length; h < l; h++) { | |
f = e[h].name; | |
if (f.indexOf("data-") === 0) { | |
f = f.substr(5); | |
ka(this[0], f, d[f]) | |
} | |
} | |
} | |
return d | |
} else if (typeof a === "object") return this.each(function () { | |
c.data(this, a) | |
}); | |
var k = a.split("."); | |
k[1] = k[1] ? "." + k[1] : ""; | |
if (b === B) { | |
d = this.triggerHandler("getData" + k[1] + "!", [k[0]]); | |
if (d === B && this.length) { | |
d = c.data(this[0], a); | |
d = ka(this[0], a, d) | |
} | |
return d === B && k[1] ? this.data(k[0]) : d | |
} else return this.each(function () { | |
var o = c(this), | |
x = [k[0], b]; | |
o.triggerHandler("setData" + k[1] + "!", x); | |
c.data(this, a, b); | |
o.triggerHandler("changeData" + k[1] + "!", x) | |
}) | |
}, | |
removeData: function (a) { | |
return this.each(function () { | |
c.removeData(this, a) | |
}) | |
} | |
}); | |
c.extend({ | |
queue: function (a, b, d) { | |
if (a) { | |
b = (b || "fx") + "queue"; | |
var e = c.data(a, b); | |
if (!d) return e || []; | |
if (!e || c.isArray(d)) e = c.data(a, b, c.makeArray(d)); | |
else e.push(d); | |
return e | |
} | |
}, | |
dequeue: function (a, b) { | |
b = b || "fx"; | |
var d = c.queue(a, b), | |
e = d.shift(); | |
if (e === "inprogress") e = d.shift(); | |
if (e) { | |
b === "fx" && d.unshift("inprogress"); | |
e.call(a, function () { | |
c.dequeue(a, b) | |
}) | |
} | |
} | |
}); | |
c.fn.extend({ | |
queue: function (a, b) { | |
if (typeof a !== "string") { | |
b = a; | |
a = "fx" | |
} | |
if (b === B) return c.queue(this[0], a); | |
return this.each(function () { | |
var d = c.queue(this, a, b); | |
a === "fx" && d[0] !== "inprogress" && c.dequeue(this, a) | |
}) | |
}, | |
dequeue: function (a) { | |
return this.each(function () { | |
c.dequeue(this, a) | |
}) | |
}, | |
delay: function (a, b) { | |
a = c.fx ? c.fx.speeds[a] || a : a; | |
b = b || "fx"; | |
return this.queue(b, function () { | |
var d = this; | |
setTimeout(function () { | |
c.dequeue(d, b) | |
}, a) | |
}) | |
}, | |
clearQueue: function (a) { | |
return this.queue(a || "fx", []) | |
} | |
}); | |
var sa = /[\n\t]/g, | |
ha = /\s+/, | |
Sa = /\r/g, | |
Ta = /^(?:href|src|style)$/, | |
Ua = /^(?:button|input)$/i, | |
Va = /^(?:button|input|object|select|textarea)$/i, | |
Wa = /^a(?:rea)?$/i, | |
ta = /^(?:radio|checkbox)$/i; | |
c.props = { | |
"for": "htmlFor", | |
"class": "className", | |
readonly: "readOnly", | |
maxlength: "maxLength", | |
cellspacing: "cellSpacing", | |
rowspan: "rowSpan", | |
colspan: "colSpan", | |
tabindex: "tabIndex", | |
usemap: "useMap", | |
frameborder: "frameBorder" | |
}; | |
c.fn.extend({ | |
attr: function (a, b) { | |
return c.access(this, a, b, true, c.attr) | |
}, | |
removeAttr: function (a) { | |
return this.each(function () { | |
c.attr(this, a, ""); | |
this.nodeType === 1 && this.removeAttribute(a) | |
}) | |
}, | |
addClass: function (a) { | |
if (c.isFunction(a)) return this.each(function (x) { | |
var r = c(this); | |
r.addClass(a.call(this, x, r.attr("class"))) | |
}); | |
if (a && typeof a === "string") for (var b = (a || "").split(ha), d = 0, e = this.length; d < e; d++) { | |
var f = this[d]; | |
if (f.nodeType === 1) if (f.className) { | |
for (var h = " " + f.className + " ", l = f.className, k = 0, o = b.length; k < o; k++) if (h.indexOf(" " + b[k] + " ") < 0) l += " " + b[k]; | |
f.className = c.trim(l) | |
} else f.className = a | |
} | |
return this | |
}, | |
removeClass: function (a) { | |
if (c.isFunction(a)) return this.each(function (o) { | |
var x = c(this); | |
x.removeClass(a.call(this, o, x.attr("class"))) | |
}); | |
if (a && typeof a === "string" || a === B) for (var b = (a || "").split(ha), d = 0, e = this.length; d < e; d++) { | |
var f = this[d]; | |
if (f.nodeType === 1 && f.className) if (a) { | |
for (var h = (" " + f.className + " ").replace(sa, " "), l = 0, k = b.length; l < k; l++) h = h.replace(" " + b[l] + " ", " "); | |
f.className = c.trim(h) | |
} else f.className = "" | |
} | |
return this | |
}, | |
toggleClass: function (a, b) { | |
var d = typeof a, | |
e = typeof b === "boolean"; | |
if (c.isFunction(a)) return this.each(function (f) { | |
var h = c(this); | |
h.toggleClass(a.call(this, f, h.attr("class"), b), b) | |
}); | |
return this.each(function () { | |
if (d === "string") for (var f, h = 0, l = c(this), k = b, o = a.split(ha); f = o[h++];) { | |
k = e ? k : !l.hasClass(f); | |
l[k ? "addClass" : "removeClass"](f) | |
} else if (d === "undefined" || d === "boolean") { | |
this.className && c.data(this, "__className__", this.className); | |
this.className = this.className || a === false ? "" : c.data(this, "__className__") || "" | |
} | |
}) | |
}, | |
hasClass: function (a) { | |
a = " " + a + " "; | |
for (var b = 0, d = this.length; b < d; b++) if ((" " + this[b].className + " ").replace(sa, " ").indexOf(a) > -1) return true; | |
return false | |
}, | |
val: function (a) { | |
if (!arguments.length) { | |
var b = this[0]; | |
if (b) { | |
if (c.nodeName(b, "option")) { | |
var d = b.attributes.value; | |
return !d || d.specified ? b.value : b.text | |
} | |
if (c.nodeName(b, "select")) { | |
var e = b.selectedIndex; | |
d = []; | |
var f = b.options; | |
b = b.type === "select-one"; | |
if (e < 0) return null; | |
var h = b ? e : 0; | |
for (e = b ? e + 1 : f.length; h < e; h++) { | |
var l = f[h]; | |
if (l.selected && (c.support.optDisabled ? !l.disabled : l.getAttribute("disabled") === null) && (!l.parentNode.disabled || !c.nodeName(l.parentNode, "optgroup"))) { | |
a = c(l).val(); | |
if (b) return a; | |
d.push(a) | |
} | |
} | |
return d | |
} | |
if (ta.test(b.type) && !c.support.checkOn) return b.getAttribute("value") === null ? "on" : b.value; | |
return (b.value || "").replace(Sa, "") | |
} | |
return B | |
} | |
var k = c.isFunction(a); | |
return this.each(function (o) { | |
var x = c(this), | |
r = a; | |
if (this.nodeType === 1) { | |
if (k) r = a.call(this, o, x.val()); | |
if (r == null) r = ""; | |
else if (typeof r === "number") r += ""; | |
else if (c.isArray(r)) r = c.map(r, function (C) { | |
return C == null ? "" : C + "" | |
}); | |
if (c.isArray(r) && ta.test(this.type)) this.checked = c.inArray(x.val(), r) >= 0; | |
else if (c.nodeName(this, "select")) { | |
var A = c.makeArray(r); | |
c("option", this).each(function () { | |
this.selected = c.inArray(c(this).val(), A) >= 0 | |
}); | |
if (!A.length) this.selectedIndex = -1 | |
} else this.value = r | |
} | |
}) | |
} | |
}); | |
c.extend({ | |
attrFn: { | |
val: true, | |
css: true, | |
html: true, | |
text: true, | |
data: true, | |
width: true, | |
height: true, | |
offset: true | |
}, | |
attr: function (a, b, d, e) { | |
if (!a || a.nodeType === 3 || a.nodeType === 8) return B; | |
if (e && b in c.attrFn) return c(a)[b](d); | |
e = a.nodeType !== 1 || !c.isXMLDoc(a); | |
var f = d !== B; | |
b = e && c.props[b] || b; | |
var h = Ta.test(b); | |
if ((b in a || a[b] !== B) && e && !h) { | |
if (f) { | |
b === "type" && Ua.test(a.nodeName) && a.parentNode && c.error("type property can't be changed"); | |
if (d === null) a.nodeType === 1 && a.removeAttribute(b); | |
else a[b] = d | |
} | |
if (c.nodeName(a, "form") && a.getAttributeNode(b)) return a.getAttributeNode(b).nodeValue; | |
if (b === "tabIndex") return (b = a.getAttributeNode("tabIndex")) && b.specified ? b.value : Va.test(a.nodeName) || Wa.test(a.nodeName) && a.href ? 0 : B; | |
return a[b] | |
} | |
if (!c.support.style && e && b === "style") { | |
if (f) a.style.cssText = "" + d; | |
return a.style.cssText | |
} | |
f && a.setAttribute(b, "" + d); | |
if (!a.attributes[b] && a.hasAttribute && !a.hasAttribute(b)) return B; | |
a = !c.support.hrefNormalized && e && h ? a.getAttribute(b, 2) : a.getAttribute(b); | |
return a === null ? B : a | |
} | |
}); | |
var X = /\.(.*)$/, | |
ia = /^(?:textarea|input|select)$/i, | |
La = /\./g, | |
Ma = / /g, | |
Xa = /[^\w\s.|`]/g, | |
Ya = function (a) { | |
return a.replace(Xa, "\\$&") | |
}, | |
ua = { | |
focusin: 0, | |
focusout: 0 | |
}; | |
c.event = { | |
add: function (a, b, d, e) { | |
if (!(a.nodeType === 3 || a.nodeType === 8)) { | |
if (c.isWindow(a) && a !== E && !a.frameElement) a = E; | |
if (d === false) d = U; | |
else if (!d) return; | |
var f, h; | |
if (d.handler) { | |
f = d; | |
d = f.handler | |
} | |
if (!d.guid) d.guid = c.guid++; | |
if (h = c.data(a)) { | |
var l = a.nodeType ? "events" : "__events__", | |
k = h[l], | |
o = h.handle; | |
if (typeof k === "function") { | |
o = k.handle; | |
k = k.events | |
} else if (!k) { | |
a.nodeType || (h[l] = h = function () {}); | |
h.events = k = {} | |
} | |
if (!o) h.handle = o = function () { | |
return typeof c !== "undefined" && !c.event.triggered ? c.event.handle.apply(o.elem, arguments) : B | |
}; | |
o.elem = a; | |
b = b.split(" "); | |
for (var x = 0, r; l = b[x++];) { | |
h = f ? c.extend({}, f) : { | |
handler: d, | |
data: e | |
}; | |
if (l.indexOf(".") > -1) { | |
r = l.split("."); | |
l = r.shift(); | |
h.namespace = r.slice(0).sort().join(".") | |
} else { | |
r = []; | |
h.namespace = "" | |
} | |
h.type = l; | |
if (!h.guid) h.guid = d.guid; | |
var A = k[l], | |
C = c.event.special[l] || {}; | |
if (!A) { | |
A = k[l] = []; | |
if (!C.setup || C.setup.call(a, e, r, o) === false) if (a.addEventListener) a.addEventListener(l, o, false); | |
else a.attachEvent && a.attachEvent("on" + l, o) | |
} | |
if (C.add) { | |
C.add.call(a, h); | |
if (!h.handler.guid) h.handler.guid = d.guid | |
} | |
A.push(h); | |
c.event.global[l] = true | |
} | |
a = null | |
} | |
} | |
}, | |
global: {}, | |
remove: function (a, b, d, e) { | |
if (!(a.nodeType === 3 || a.nodeType === 8)) { | |
if (d === false) d = U; | |
var f, h, l = 0, | |
k, o, x, r, A, C, J = a.nodeType ? "events" : "__events__", | |
w = c.data(a), | |
I = w && w[J]; | |
if (w && I) { | |
if (typeof I === "function") { | |
w = I; | |
I = I.events | |
} | |
if (b && b.type) { | |
d = b.handler; | |
b = b.type | |
} | |
if (!b || typeof b === "string" && b.charAt(0) === ".") { | |
b = b || ""; | |
for (f in I) c.event.remove(a, f + b) | |
} else { | |
for (b = b.split(" "); f = b[l++];) { | |
r = f; | |
k = f.indexOf(".") < 0; | |
o = []; | |
if (!k) { | |
o = f.split("."); | |
f = o.shift(); | |
x = RegExp("(^|\\.)" + c.map(o.slice(0).sort(), Ya).join("\\.(?:.*\\.)?") + "(\\.|$)") | |
} | |
if (A = I[f]) if (d) { | |
r = c.event.special[f] || {}; | |
for (h = e || 0; h < A.length; h++) { | |
C = A[h]; | |
if (d.guid === C.guid) { | |
if (k || x.test(C.namespace)) { | |
e == null && A.splice(h--, 1); | |
r.remove && r.remove.call(a, C) | |
} | |
if (e != null) break | |
} | |
} | |
if (A.length === 0 || e != null && A.length === 1) { | |
if (!r.teardown || r.teardown.call(a, o) === false) c.removeEvent(a, f, w.handle); | |
delete I[f] | |
} | |
} else for (h = 0; h < A.length; h++) { | |
C = A[h]; | |
if (k || x.test(C.namespace)) { | |
c.event.remove(a, r, C.handler, h); | |
A.splice(h--, 1) | |
} | |
} | |
} | |
if (c.isEmptyObject(I)) { | |
if (b = w.handle) b.elem = null; | |
delete w.events; | |
delete w.handle; | |
if (typeof w === "function") c.removeData(a, J); | |
else c.isEmptyObject(w) && c.removeData(a) | |
} | |
} | |
} | |
} | |
}, | |
trigger: function (a, b, d, e) { | |
var f = a.type || a; | |
if (!e) { | |
a = typeof a === "object" ? a[c.expando] ? a : c.extend(c.Event(f), a) : c.Event(f); | |
if (f.indexOf("!") >= 0) { | |
a.type = f = f.slice(0, - 1); | |
a.exclusive = true | |
} | |
if (!d) { | |
a.stopPropagation(); | |
c.event.global[f] && c.each(c.cache, function () { | |
this.events && this.events[f] && c.event.trigger(a, b, this.handle.elem) | |
}) | |
} | |
if (!d || d.nodeType === 3 || d.nodeType === 8) return B; | |
a.result = B; | |
a.target = d; | |
b = c.makeArray(b); | |
b.unshift(a) | |
} | |
a.currentTarget = d; | |
(e = d.nodeType ? c.data(d, "handle") : (c.data(d, "__events__") || {}).handle) && e.apply(d, b); | |
e = d.parentNode || d.ownerDocument; | |
try { | |
if (!(d && d.nodeName && c.noData[d.nodeName.toLowerCase()])) if (d["on" + f] && d["on" + f].apply(d, b) === false) { | |
a.result = false; | |
a.preventDefault() | |
} | |
} catch (h) {} | |
if (!a.isPropagationStopped() && e) c.event.trigger(a, b, e, true); | |
else if (!a.isDefaultPrevented()) { | |
var l; | |
e = a.target; | |
var k = f.replace(X, ""), | |
o = c.nodeName(e, "a") && k === "click", | |
x = c.event.special[k] || {}; | |
if ((!x._default || x._default.call(d, a) === false) && !o && !(e && e.nodeName && c.noData[e.nodeName.toLowerCase()])) { | |
try { | |
if (e[k]) { | |
if (l = e["on" + k]) e["on" + k] = null; | |
c.event.triggered = true; | |
e[k]() | |
} | |
} catch (r) {} | |
if (l) e["on" + k] = l; | |
c.event.triggered = false | |
} | |
} | |
}, | |
handle: function (a) { | |
var b, d, e, f; | |
d = []; | |
var h = c.makeArray(arguments); | |
a = h[0] = c.event.fix(a || E.event); | |
a.currentTarget = this; | |
b = a.type.indexOf(".") < 0 && !a.exclusive; | |
if (!b) { | |
e = a.type.split("."); | |
a.type = e.shift(); | |
d = e.slice(0).sort(); | |
e = RegExp("(^|\\.)" + d.join("\\.(?:.*\\.)?") + "(\\.|$)") | |
} | |
a.namespace = a.namespace || d.join("."); | |
f = c.data(this, this.nodeType ? "events" : "__events__"); | |
if (typeof f === "function") f = f.events; | |
d = (f || {})[a.type]; | |
if (f && d) { | |
d = d.slice(0); | |
f = 0; | |
for (var l = d.length; f < l; f++) { | |
var k = d[f]; | |
if (b || e.test(k.namespace)) { | |
a.handler = k.handler; | |
a.data = k.data; | |
a.handleObj = k; | |
k = k.handler.apply(this, h); | |
if (k !== B) { | |
a.result = k; | |
if (k === false) { | |
a.preventDefault(); | |
a.stopPropagation() | |
} | |
} | |
if (a.isImmediatePropagationStopped()) break | |
} | |
} | |
} | |
return a.result | |
}, | |
props: "altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "), | |
fix: function (a) { | |
if (a[c.expando]) return a; | |
var b = a; | |
a = c.Event(b); | |
for (var d = this.props.length, e; d;) { | |
e = this.props[--d]; | |
a[e] = b[e] | |
} | |
if (!a.target) a.target = a.srcElement || t; | |
if (a.target.nodeType === 3) a.target = a.target.parentNode; | |
if (!a.relatedTarget && a.fromElement) a.relatedTarget = a.fromElement === a.target ? a.toElement : a.fromElement; | |
if (a.pageX == null && a.clientX != null) { | |
b = t.documentElement; | |
d = t.body; | |
a.pageX = a.clientX + (b && b.scrollLeft || d && d.scrollLeft || 0) - (b && b.clientLeft || d && d.clientLeft || 0); | |
a.pageY = a.clientY + (b && b.scrollTop || d && d.scrollTop || 0) - (b && b.clientTop || d && d.clientTop || 0) | |
} | |
if (a.which == null && (a.charCode != null || a.keyCode != null)) a.which = a.charCode != null ? a.charCode : a.keyCode; | |
if (!a.metaKey && a.ctrlKey) a.metaKey = a.ctrlKey; | |
if (!a.which && a.button !== B) a.which = a.button & 1 ? 1 : a.button & 2 ? 3 : a.button & 4 ? 2 : 0; | |
return a | |
}, | |
guid: 1E8, | |
proxy: c.proxy, | |
special: { | |
ready: { | |
setup: c.bindReady, | |
teardown: c.noop | |
}, | |
live: { | |
add: function (a) { | |
c.event.add(this, Y(a.origType, a.selector), c.extend({}, a, { | |
handler: Ka, | |
guid: a.handler.guid | |
})) | |
}, | |
remove: function (a) { | |
c.event.remove(this, Y(a.origType, a.selector), a) | |
} | |
}, | |
beforeunload: { | |
setup: function (a, b, d) { | |
if (c.isWindow(this)) this.onbeforeunload = d | |
}, | |
teardown: function (a, b) { | |
if (this.onbeforeunload === b) this.onbeforeunload = null | |
} | |
} | |
} | |
}; | |
c.removeEvent = t.removeEventListener ? function (a, b, d) { | |
a.removeEventListener && a.removeEventListener(b, d, false) | |
} : function (a, b, d) { | |
a.detachEvent && a.detachEvent("on" + b, d) | |
}; | |
c.Event = function (a) { | |
if (!this.preventDefault) return new c.Event(a); | |
if (a && a.type) { | |
this.originalEvent = a; | |
this.type = a.type | |
} else this.type = a; | |
this.timeStamp = c.now(); | |
this[c.expando] = true | |
}; | |
c.Event.prototype = { | |
preventDefault: function () { | |
this.isDefaultPrevented = ca; | |
var a = this.originalEvent; | |
if (a) if (a.preventDefault) a.preventDefault(); | |
else a.returnValue = false | |
}, | |
stopPropagation: function () { | |
this.isPropagationStopped = ca; | |
var a = this.originalEvent; | |
if (a) { | |
a.stopPropagation && a.stopPropagation(); | |
a.cancelBubble = true | |
} | |
}, | |
stopImmediatePropagation: function () { | |
this.isImmediatePropagationStopped = ca; | |
this.stopPropagation() | |
}, | |
isDefaultPrevented: U, | |
isPropagationStopped: U, | |
isImmediatePropagationStopped: U | |
}; | |
var va = function (a) { | |
var b = a.relatedTarget; | |
try { | |
for (; b && b !== this;) b = b.parentNode; | |
if (b !== this) { | |
a.type = a.data; | |
c.event.handle.apply(this, arguments) | |
} | |
} catch (d) {} | |
}, | |
wa = function (a) { | |
a.type = a.data; | |
c.event.handle.apply(this, arguments) | |
}; | |
c.each({ | |
mouseenter: "mouseover", | |
mouseleave: "mouseout" | |
}, function (a, b) { | |
c.event.special[a] = { | |
setup: function (d) { | |
c.event.add(this, b, d && d.selector ? wa : va, a) | |
}, | |
teardown: function (d) { | |
c.event.remove(this, b, d && d.selector ? wa : va) | |
} | |
} | |
}); | |
if (!c.support.submitBubbles) c.event.special.submit = { | |
setup: function () { | |
if (this.nodeName.toLowerCase() !== "form") { | |
c.event.add(this, "click.specialSubmit", function (a) { | |
var b = a.target, | |
d = b.type; | |
if ((d === "submit" || d === "image") && c(b).closest("form").length) { | |
a.liveFired = B; | |
return la("submit", this, arguments) | |
} | |
}); | |
c.event.add(this, "keypress.specialSubmit", function (a) { | |
var b = a.target, | |
d = b.type; | |
if ((d === "text" || d === "password") && c(b).closest("form").length && a.keyCode === 13) { | |
a.liveFired = B; | |
return la("submit", this, arguments) | |
} | |
}) | |
} else return false | |
}, | |
teardown: function () { | |
c.event.remove(this, ".specialSubmit") | |
} | |
}; | |
if (!c.support.changeBubbles) { | |
var V, xa = function (a) { | |
var b = a.type, | |
d = a.value; | |
if (b === "radio" || b === "checkbox") d = a.checked; | |
else if (b === "select-multiple") d = a.selectedIndex > -1 ? c.map(a.options, function (e) { | |
return e.selected | |
}).join("-") : ""; | |
else if (a.nodeName.toLowerCase() === "select") d = a.selectedIndex; | |
return d | |
}, | |
Z = function (a, b) { | |
var d = a.target, | |
e, f; | |
if (!(!ia.test(d.nodeName) || d.readOnly)) { | |
e = c.data(d, "_change_data"); | |
f = xa(d); | |
if (a.type !== "focusout" || d.type !== "radio") c.data(d, "_change_data", f); | |
if (!(e === B || f === e)) if (e != null || f) { | |
a.type = "change"; | |
a.liveFired = B; | |
return c.event.trigger(a, b, d) | |
} | |
} | |
}; | |
c.event.special.change = { | |
filters: { | |
focusout: Z, | |
beforedeactivate: Z, | |
click: function (a) { | |
var b = a.target, | |
d = b.type; | |
if (d === "radio" || d === "checkbox" || b.nodeName.toLowerCase() === "select") return Z.call(this, a) | |
}, | |
keydown: function (a) { | |
var b = a.target, | |
d = b.type; | |
if (a.keyCode === 13 && b.nodeName.toLowerCase() !== "textarea" || a.keyCode === 32 && (d === "checkbox" || d === "radio") || d === "select-multiple") return Z.call(this, a) | |
}, | |
beforeactivate: function (a) { | |
a = a.target; | |
c.data(a, "_change_data", xa(a)) | |
} | |
}, | |
setup: function () { | |
if (this.type === "file") return false; | |
for (var a in V) c.event.add(this, a + ".specialChange", V[a]); | |
return ia.test(this.nodeName) | |
}, | |
teardown: function () { | |
c.event.remove(this, ".specialChange"); | |
return ia.test(this.nodeName) | |
} | |
}; | |
V = c.event.special.change.filters; | |
V.focus = V.beforeactivate | |
} | |
t.addEventListener && c.each({ | |
focus: "focusin", | |
blur: "focusout" | |
}, function (a, b) { | |
function d(e) { | |
e = c.event.fix(e); | |
e.type = b; | |
return c.event.trigger(e, null, e.target) | |
} | |
c.event.special[b] = { | |
setup: function () { | |
ua[b]++ === 0 && t.addEventListener(a, d, true) | |
}, | |
teardown: function () { | |
--ua[b] === 0 && t.removeEventListener(a, d, true) | |
} | |
} | |
}); | |
c.each(["bind", "one"], function (a, b) { | |
c.fn[b] = function (d, e, f) { | |
if (typeof d === "object") { | |
for (var h in d) this[b](h, e, d[h], f); | |
return this | |
} | |
if (c.isFunction(e) || e === false) { | |
f = e; | |
e = B | |
} | |
var l = b === "one" ? c.proxy(f, function (o) { | |
c(this).unbind(o, l); | |
return f.apply(this, arguments) | |
}) : f; | |
if (d === "unload" && b !== "one") this.one(d, e, f); | |
else { | |
h = 0; | |
for (var k = this.length; h < k; h++) c.event.add(this[h], d, l, e) | |
} | |
return this | |
} | |
}); | |
c.fn.extend({ | |
unbind: function (a, b) { | |
if (typeof a === "object" && !a.preventDefault) for (var d in a) this.unbind(d, a[d]); | |
else { | |
d = 0; | |
for (var e = this.length; d < e; d++) c.event.remove(this[d], a, b) | |
} | |
return this | |
}, | |
delegate: function (a, b, d, e) { | |
return this.live(b, d, e, a) | |
}, | |
undelegate: function (a, b, d) { | |
return arguments.length === 0 ? this.unbind("live") : this.die(b, null, d, a) | |
}, | |
trigger: function (a, b) { | |
return this.each(function () { | |
c.event.trigger(a, b, this) | |
}) | |
}, | |
triggerHandler: function (a, b) { | |
if (this[0]) { | |
var d = c.Event(a); | |
d.preventDefault(); | |
d.stopPropagation(); | |
c.event.trigger(d, b, this[0]); | |
return d.result | |
} | |
}, | |
toggle: function (a) { | |
for (var b = arguments, d = 1; d < b.length;) c.proxy(a, b[d++]); | |
return this.click(c.proxy(a, function (e) { | |
var f = (c.data(this, "lastToggle" + a.guid) || 0) % d; | |
c.data(this, "lastToggle" + a.guid, f + 1); | |
e.preventDefault(); | |
return b[f].apply(this, arguments) || false | |
})) | |
}, | |
hover: function (a, b) { | |
return this.mouseenter(a).mouseleave(b || a) | |
} | |
}); | |
var ya = { | |
focus: "focusin", | |
blur: "focusout", | |
mouseenter: "mouseover", | |
mouseleave: "mouseout" | |
}; | |
c.each(["live", "die"], function (a, b) { | |
c.fn[b] = function (d, e, f, h) { | |
var l, k = 0, | |
o, x, r = h || this.selector; | |
h = h ? this : c(this.context); | |
if (typeof d === "object" && !d.preventDefault) { | |
for (l in d) h[b](l, e, d[l], r); | |
return this | |
} | |
if (c.isFunction(e)) { | |
f = e; | |
e = B | |
} | |
for (d = (d || "").split(" "); | |
(l = d[k++]) != null;) { | |
o = X.exec(l); | |
x = ""; | |
if (o) { | |
x = o[0]; | |
l = l.replace(X, "") | |
} | |
if (l === "hover") d.push("mouseenter" + x, "mouseleave" + x); | |
else { | |
o = l; | |
if (l === "focus" || l === "blur") { | |
d.push(ya[l] + x); | |
l += x | |
} else l = (ya[l] || l) + x; | |
if (b === "live") { | |
x = 0; | |
for (var A = h.length; x < A; x++) c.event.add(h[x], "live." + Y(l, r), { | |
data: e, | |
selector: r, | |
handler: f, | |
origType: l, | |
origHandler: f, | |
preType: o | |
}) | |
} else h.unbind("live." + Y(l, r), f) | |
} | |
} | |
return this | |
} | |
}); | |
c.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error".split(" "), function (a, b) { | |
c.fn[b] = function (d, e) { | |
if (e == null) { | |
e = d; | |
d = null | |
} | |
return arguments.length > 0 ? this.bind(b, d, e) : this.trigger(b) | |
}; | |
if (c.attrFn) c.attrFn[b] = true | |
}); | |
E.attachEvent && !E.addEventListener && c(E).bind("unload", function () { | |
for (var a in c.cache) if (c.cache[a].handle) try { | |
c.event.remove(c.cache[a].handle.elem) | |
} catch (b) {} | |
}); | |
(function () { | |
function a(g, i, n, m, p, q) { | |
p = 0; | |
for (var u = m.length; p < u; p++) { | |
var y = m[p]; | |
if (y) { | |
var F = false; | |
for (y = y[g]; y;) { | |
if (y.sizcache === n) { | |
F = m[y.sizset]; | |
break | |
} | |
if (y.nodeType === 1 && !q) { | |
y.sizcache = n; | |
y.sizset = p | |
} | |
if (y.nodeName.toLowerCase() === i) { | |
F = y; | |
break | |
} | |
y = y[g] | |
} | |
m[p] = F | |
} | |
} | |
} | |
function b(g, i, n, m, p, q) { | |
p = 0; | |
for (var u = m.length; p < u; p++) { | |
var y = m[p]; | |
if (y) { | |
var F = false; | |
for (y = y[g]; y;) { | |
if (y.sizcache === n) { | |
F = m[y.sizset]; | |
break | |
} | |
if (y.nodeType === 1) { | |
if (!q) { | |
y.sizcache = n; | |
y.sizset = p | |
} | |
if (typeof i !== "string") { | |
if (y === i) { | |
F = true; | |
break | |
} | |
} else if (k.filter(i, [y]).length > 0) { | |
F = y; | |
break | |
} | |
} | |
y = y[g] | |
} | |
m[p] = F | |
} | |
} | |
} | |
var d = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^\[\]]*\]|['"][^'"]*['"]|[^\[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g, | |
e = 0, | |
f = Object.prototype.toString, | |
h = false, | |
l = true; | |
[0, 0].sort(function () { | |
l = false; | |
return 0 | |
}); | |
var k = function (g, i, n, m) { | |
n = n || []; | |
var p = i = i || t; | |
if (i.nodeType !== 1 && i.nodeType !== 9) return []; | |
if (!g || typeof g !== "string") return n; | |
var q, u, y, F, M, N = true, | |
O = k.isXML(i), | |
D = [], | |
R = g; | |
do { | |
d.exec(""); | |
if (q = d.exec(R)) { | |
R = q[3]; | |
D.push(q[1]); | |
if (q[2]) { | |
F = q[3]; | |
break | |
} | |
} | |
} while (q); | |
if (D.length > 1 && x.exec(g)) if (D.length === 2 && o.relative[D[0]]) u = L(D[0] + D[1], i); | |
else for (u = o.relative[D[0]] ? [i] : k(D.shift(), i); D.length;) { | |
g = D.shift(); | |
if (o.relative[g]) g += D.shift(); | |
u = L(g, u) | |
} else { | |
if (!m && D.length > 1 && i.nodeType === 9 && !O && o.match.ID.test(D[0]) && !o.match.ID.test(D[D.length - 1])) { | |
q = k.find(D.shift(), i, O); | |
i = q.expr ? k.filter(q.expr, q.set)[0] : q.set[0] | |
} | |
if (i) { | |
q = m ? { | |
expr: D.pop(), | |
set: C(m) | |
} : k.find(D.pop(), D.length === 1 && (D[0] === "~" || D[0] === "+") && i.parentNode ? i.parentNode : i, O); | |
u = q.expr ? k.filter(q.expr, q.set) : q.set; | |
if (D.length > 0) y = C(u); | |
else N = false; | |
for (; D.length;) { | |
q = M = D.pop(); | |
if (o.relative[M]) q = D.pop(); | |
else M = ""; | |
if (q == null) q = i; | |
o.relative[M](y, q, O) | |
} | |
} else y = [] | |
} | |
y || (y = u); | |
y || k.error(M || g); | |
if (f.call(y) === "[object Array]") if (N) if (i && i.nodeType === 1) for (g = 0; y[g] != null; g++) { | |
if (y[g] && (y[g] === true || y[g].nodeType === 1 && k.contains(i, y[g]))) n.push(u[g]) | |
} else for (g = 0; y[g] != null; g++) y[g] && y[g].nodeType === 1 && n.push(u[g]); | |
else n.push.apply(n, y); | |
else C(y, n); | |
if (F) { | |
k(F, p, n, m); | |
k.uniqueSort(n) | |
} | |
return n | |
}; | |
k.uniqueSort = function (g) { | |
if (w) { | |
h = l; | |
g.sort(w); | |
if (h) for (var i = 1; i < g.length; i++) g[i] === g[i - 1] && g.splice(i--, 1) | |
} | |
return g | |
}; | |
k.matches = function (g, i) { | |
return k(g, null, null, i) | |
}; | |
k.matchesSelector = function (g, i) { | |
return k(i, null, null, [g]).length > 0 | |
}; | |
k.find = function (g, i, n) { | |
var m; | |
if (!g) return []; | |
for (var p = 0, q = o.order.length; p < q; p++) { | |
var u, y = o.order[p]; | |
if (u = o.leftMatch[y].exec(g)) { | |
var F = u[1]; | |
u.splice(1, 1); | |
if (F.substr(F.length - 1) !== "\\") { | |
u[1] = (u[1] || "").replace(/\\/g, ""); | |
m = o.find[y](u, i, n); | |
if (m != null) { | |
g = g.replace(o.match[y], ""); | |
break | |
} | |
} | |
} | |
} | |
m || (m = i.getElementsByTagName("*")); | |
return { | |
set: m, | |
expr: g | |
} | |
}; | |
k.filter = function (g, i, n, m) { | |
for (var p, q, u = g, y = [], F = i, M = i && i[0] && k.isXML(i[0]); g && i.length;) { | |
for (var N in o.filter) if ((p = o.leftMatch[N].exec(g)) != null && p[2]) { | |
var O, D, R = o.filter[N]; | |
D = p[1]; | |
q = false; | |
p.splice(1, 1); | |
if (D.substr(D.length - 1) !== "\\") { | |
if (F === y) y = []; | |
if (o.preFilter[N]) if (p = o.preFilter[N](p, F, n, y, m, M)) { | |
if (p === true) continue | |
} else q = O = true; | |
if (p) for (var j = 0; | |
(D = F[j]) != null; j++) if (D) { | |
O = R(D, p, j, F); | |
var s = m ^ !! O; | |
if (n && O != null) if (s) q = true; | |
else F[j] = false; | |
else if (s) { | |
y.push(D); | |
q = true | |
} | |
} | |
if (O !== B) { | |
n || (F = y); | |
g = g.replace(o.match[N], ""); | |
if (!q) return []; | |
break | |
} | |
} | |
} | |
if (g === u) if (q == null) k.error(g); | |
else break; | |
u = g | |
} | |
return F | |
}; | |
k.error = function (g) { | |
throw "Syntax error, unrecognized expression: " + g; | |
}; | |
var o = k.selectors = { | |
order: ["ID", "NAME", "TAG"], | |
match: { | |
ID: /#((?:[\w\u00c0-\uFFFF\-]|\\.)+)/, | |
CLASS: /\.((?:[\w\u00c0-\uFFFF\-]|\\.)+)/, | |
NAME: /\[name=['"]*((?:[\w\u00c0-\uFFFF\-]|\\.)+)['"]*\]/, | |
ATTR: /\[\s*((?:[\w\u00c0-\uFFFF\-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/, | |
TAG: /^((?:[\w\u00c0-\uFFFF\*\-]|\\.)+)/, | |
CHILD: /:(only|nth|last|first)-child(?:\((even|odd|[\dn+\-]*)\))?/, | |
POS: /:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^\-]|$)/, | |
PSEUDO: /:((?:[\w\u00c0-\uFFFF\-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/ | |
}, | |
leftMatch: {}, | |
attrMap: { | |
"class": "className", | |
"for": "htmlFor" | |
}, | |
attrHandle: { | |
href: function (g) { | |
return g.getAttribute("href") | |
} | |
}, | |
relative: { | |
"+": function (g, i) { | |
var n = typeof i === "string", | |
m = n && !/\W/.test(i); | |
n = n && !m; | |
if (m) i = i.toLowerCase(); | |
m = 0; | |
for (var p = g.length, q; m < p; m++) if (q = g[m]) { | |
for (; | |
(q = q.previousSibling) && q.nodeType !== 1;); | |
g[m] = n || q && q.nodeName.toLowerCase() === i ? q || false : q === i | |
} | |
n && k.filter(i, g, true) | |
}, | |
">": function (g, i) { | |
var n, m = typeof i === "string", | |
p = 0, | |
q = g.length; | |
if (m && !/\W/.test(i)) for (i = i.toLowerCase(); p < q; p++) { | |
if (n = g[p]) { | |
n = n.parentNode; | |
g[p] = n.nodeName.toLowerCase() === i ? n : false | |
} | |
} else { | |
for (; p < q; p++) if (n = g[p]) g[p] = m ? n.parentNode : n.parentNode === i; | |
m && k.filter(i, g, true) | |
} | |
}, | |
"": function (g, i, n) { | |
var m, p = e++, | |
q = b; | |
if (typeof i === "string" && !/\W/.test(i)) { | |
m = i = i.toLowerCase(); | |
q = a | |
} | |
q("parentNode", i, p, g, m, n) | |
}, | |
"~": function (g, i, n) { | |
var m, p = e++, | |
q = b; | |
if (typeof i === "string" && !/\W/.test(i)) { | |
m = i = i.toLowerCase(); | |
q = a | |
} | |
q("previousSibling", i, p, g, m, n) | |
} | |
}, | |
find: { | |
ID: function (g, i, n) { | |
if (typeof i.getElementById !== "undefined" && !n) return (g = i.getElementById(g[1])) && g.parentNode ? [g] : [] | |
}, | |
NAME: function (g, i) { | |
if (typeof i.getElementsByName !== "undefined") { | |
for (var n = [], m = i.getElementsByName(g[1]), p = 0, q = m.length; p < q; p++) m[p].getAttribute("name") === g[1] && n.push(m[p]); | |
return n.length === 0 ? null : n | |
} | |
}, | |
TAG: function (g, i) { | |
return i.getElementsByTagName(g[1]) | |
} | |
}, | |
preFilter: { | |
CLASS: function (g, i, n, m, p, q) { | |
g = " " + g[1].replace(/\\/g, "") + " "; | |
if (q) return g; | |
q = 0; | |
for (var u; | |
(u = i[q]) != null; q++) if (u) if (p ^ (u.className && (" " + u.className + " ").replace(/[\t\n]/g, " ").indexOf(g) >= 0)) n || m.push(u); | |
else if (n) i[q] = false; | |
return false | |
}, | |
ID: function (g) { | |
return g[1].replace(/\\/g, "") | |
}, | |
TAG: function (g) { | |
return g[1].toLowerCase() | |
}, | |
CHILD: function (g) { | |
if (g[1] === "nth") { | |
var i = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2] === "even" && "2n" || g[2] === "odd" && "2n+1" || !/\D/.test(g[2]) && "0n+" + g[2] || g[2]); | |
g[2] = i[1] + (i[2] || 1) - 0; | |
g[3] = i[3] - 0 | |
} | |
g[0] = e++; | |
return g | |
}, | |
ATTR: function (g, i, n, m, p, q) { | |
i = g[1].replace(/\\/g, ""); | |
if (!q && o.attrMap[i]) g[1] = o.attrMap[i]; | |
if (g[2] === "~=") g[4] = " " + g[4] + " "; | |
return g | |
}, | |
PSEUDO: function (g, i, n, m, p) { | |
if (g[1] === "not") if ((d.exec(g[3]) || "").length > 1 || /^\w/.test(g[3])) g[3] = k(g[3], null, null, i); | |
else { | |
g = k.filter(g[3], i, n, true ^ p); | |
n || m.push.apply(m, g); | |
return false | |
} else if (o.match.POS.test(g[0]) || o.match.CHILD.test(g[0])) return true; | |
return g | |
}, | |
POS: function (g) { | |
g.unshift(true); | |
return g | |
} | |
}, | |
filters: { | |
enabled: function (g) { | |
return g.disabled === false && g.type !== "hidden" | |
}, | |
disabled: function (g) { | |
return g.disabled === true | |
}, | |
checked: function (g) { | |
return g.checked === true | |
}, | |
selected: function (g) { | |
return g.selected === true | |
}, | |
parent: function (g) { | |
return !!g.firstChild | |
}, | |
empty: function (g) { | |
return !g.firstChild | |
}, | |
has: function (g, i, n) { | |
return !!k(n[3], g).length | |
}, | |
header: function (g) { | |
return /h\d/i.test(g.nodeName) | |
}, | |
text: function (g) { | |
return "text" === g.type | |
}, | |
radio: function (g) { | |
return "radio" === g.type | |
}, | |
checkbox: function (g) { | |
return "checkbox" === g.type | |
}, | |
file: function (g) { | |
return "file" === g.type | |
}, | |
password: function (g) { | |
return "password" === g.type | |
}, | |
submit: function (g) { | |
return "submit" === g.type | |
}, | |
image: function (g) { | |
return "image" === g.type | |
}, | |
reset: function (g) { | |
return "reset" === g.type | |
}, | |
button: function (g) { | |
return "button" === g.type || g.nodeName.toLowerCase() === "button" | |
}, | |
input: function (g) { | |
return /input|select|textarea|button/i.test(g.nodeName) | |
} | |
}, | |
setFilters: { | |
first: function (g, i) { | |
return i === 0 | |
}, | |
last: function (g, i, n, m) { | |
return i === m.length - 1 | |
}, | |
even: function (g, i) { | |
return i % 2 === 0 | |
}, | |
odd: function (g, i) { | |
return i % 2 === 1 | |
}, | |
lt: function (g, i, n) { | |
return i < n[3] - 0 | |
}, | |
gt: function (g, i, n) { | |
return i > n[3] - 0 | |
}, | |
nth: function (g, i, n) { | |
return n[3] - 0 === i | |
}, | |
eq: function (g, i, n) { | |
return n[3] - 0 === i | |
} | |
}, | |
filter: { | |
PSEUDO: function (g, i, n, m) { | |
var p = i[1], | |
q = o.filters[p]; | |
if (q) return q(g, n, i, m); | |
else if (p === "contains") return (g.textContent || g.innerText || k.getText([g]) || "").indexOf(i[3]) >= 0; | |
else if (p === "not") { | |
i = i[3]; | |
n = 0; | |
for (m = i.length; n < m; n++) if (i[n] === g) return false; | |
return true | |
} else k.error("Syntax error, unrecognized expression: " + p) | |
}, | |
CHILD: function (g, i) { | |
var n = i[1], | |
m = g; | |
switch (n) { | |
case "only": | |
case "first": | |
for (; m = m.previousSibling;) if (m.nodeType === 1) return false; | |
if (n === "first") return true; | |
m = g; | |
case "last": | |
for (; m = m.nextSibling;) if (m.nodeType === 1) return false; | |
return true; | |
case "nth": | |
n = i[2]; | |
var p = i[3]; | |
if (n === 1 && p === 0) return true; | |
var q = i[0], | |
u = g.parentNode; | |
if (u && (u.sizcache !== q || !g.nodeIndex)) { | |
var y = 0; | |
for (m = u.firstChild; m; m = m.nextSibling) if (m.nodeType === 1) m.nodeIndex = ++y; | |
u.sizcache = q | |
} | |
m = g.nodeIndex - p; | |
return n === 0 ? m === 0 : m % n === 0 && m / n >= 0 | |
} | |
}, | |
ID: function (g, i) { | |
return g.nodeType === 1 && g.getAttribute("id") === i | |
}, | |
TAG: function (g, i) { | |
return i === "*" && g.nodeType === 1 || g.nodeName.toLowerCase() === i | |
}, | |
CLASS: function (g, i) { | |
return (" " + (g.className || g.getAttribute("class")) + " ").indexOf(i) > -1 | |
}, | |
ATTR: function (g, i) { | |
var n = i[1]; | |
n = o.attrHandle[n] ? o.attrHandle[n](g) : g[n] != null ? g[n] : g.getAttribute(n); | |
var m = n + "", | |
p = i[2], | |
q = i[4]; | |
return n == null ? p === "!=" : p === "=" ? m === q : p === "*=" ? m.indexOf(q) >= 0 : p === "~=" ? (" " + m + " ").indexOf(q) >= 0 : !q ? m && n !== false : p === "!=" ? m !== q : p === "^=" ? m.indexOf(q) === 0 : p === "$=" ? m.substr(m.length - q.length) === q : p === "|=" ? m === q || m.substr(0, q.length + 1) === q + "-" : false | |
}, | |
POS: function (g, i, n, m) { | |
var p = o.setFilters[i[2]]; | |
if (p) return p(g, n, i, m) | |
} | |
} | |
}, | |
x = o.match.POS, | |
r = function (g, i) { | |
return "\\" + (i - 0 + 1) | |
}, | |
A; | |
for (A in o.match) { | |
o.match[A] = RegExp(o.match[A].source + /(?![^\[]*\])(?![^\(]*\))/.source); | |
o.leftMatch[A] = RegExp(/(^(?:.|\r|\n)*?)/.source + o.match[A].source.replace(/\\(\d+)/g, r)) | |
} | |
var C = function (g, i) { | |
g = Array.prototype.slice.call(g, 0); | |
if (i) { | |
i.push.apply(i, g); | |
return i | |
} | |
return g | |
}; | |
try { | |
Array.prototype.slice.call(t.documentElement.childNodes, 0) | |
} catch (J) { | |
C = function (g, i) { | |
var n = 0, | |
m = i || []; | |
if (f.call(g) === "[object Array]") Array.prototype.push.apply(m, g); | |
else if (typeof g.length === "number") for (var p = g.length; n < p; n++) m.push(g[n]); | |
else for (; g[n]; n++) m.push(g[n]); | |
return m | |
} | |
} | |
var w, I; | |
if (t.documentElement.compareDocumentPosition) w = function (g, i) { | |
if (g === i) { | |
h = true; | |
return 0 | |
} | |
if (!g.compareDocumentPosition || !i.compareDocumentPosition) return g.compareDocumentPosition ? -1 : 1; | |
return g.compareDocumentPosition(i) & 4 ? -1 : 1 | |
}; | |
else { | |
w = function (g, i) { | |
var n, m, p = [], | |
q = []; | |
n = g.parentNode; | |
m = i.parentNode; | |
var u = n; | |
if (g === i) { | |
h = true; | |
return 0 | |
} else if (n === m) return I(g, i); | |
else if (n) { | |
if (!m) return 1 | |
} else return -1; | |
for (; u;) { | |
p.unshift(u); | |
u = u.parentNode | |
} | |
for (u = m; u;) { | |
q.unshift(u); | |
u = u.parentNode | |
} | |
n = p.length; | |
m = q.length; | |
for (u = 0; u < n && u < m; u++) if (p[u] !== q[u]) return I(p[u], q[u]); | |
return u === n ? I(g, q[u], - 1) : I(p[u], i, 1) | |
}; | |
I = function (g, i, n) { | |
if (g === i) return n; | |
for (g = g.nextSibling; g;) { | |
if (g === i) return -1; | |
g = g.nextSibling | |
} | |
return 1 | |
} | |
} | |
k.getText = function (g) { | |
for (var i = "", n, m = 0; g[m]; m++) { | |
n = g[m]; | |
if (n.nodeType === 3 || n.nodeType === 4) i += n.nodeValue; | |
else if (n.nodeType !== 8) i += k.getText(n.childNodes) | |
} | |
return i | |
}; | |
(function () { | |
var g = t.createElement("div"), | |
i = "script" + (new Date).getTime(), | |
n = t.documentElement; | |
g.innerHTML = "<a name='" + i + "'/>"; | |
n.insertBefore(g, n.firstChild); | |
if (t.getElementById(i)) { | |
o.find.ID = function (m, p, q) { | |
if (typeof p.getElementById !== "undefined" && !q) return (p = p.getElementById(m[1])) ? p.id === m[1] || typeof p.getAttributeNode !== "undefined" && p.getAttributeNode("id").nodeValue === m[1] ? [p] : B : [] | |
}; | |
o.filter.ID = function (m, p) { | |
var q = typeof m.getAttributeNode !== "undefined" && m.getAttributeNode("id"); | |
return m.nodeType === 1 && q && q.nodeValue === p | |
} | |
} | |
n.removeChild(g); | |
n = g = null | |
})(); | |
(function () { | |
var g = t.createElement("div"); | |
g.appendChild(t.createComment("")); | |
if (g.getElementsByTagName("*").length > 0) o.find.TAG = function (i, n) { | |
var m = n.getElementsByTagName(i[1]); | |
if (i[1] === "*") { | |
for (var p = [], q = 0; m[q]; q++) m[q].nodeType === 1 && p.push(m[q]); | |
m = p | |
} | |
return m | |
}; | |
g.innerHTML = "<a href='#'></a>"; | |
if (g.firstChild && typeof g.firstChild.getAttribute !== "undefined" && g.firstChild.getAttribute("href") !== "#") o.attrHandle.href = function (i) { | |
return i.getAttribute("href", 2) | |
}; | |
g = null | |
})(); | |
t.querySelectorAll && function () { | |
var g = k, | |
i = t.createElement("div"); | |
i.innerHTML = "<p class='TEST'></p>"; | |
if (!(i.querySelectorAll && i.querySelectorAll(".TEST").length === 0)) { | |
k = function (m, p, q, u) { | |
p = p || t; | |
m = m.replace(/\=\s*([^'"\]]*)\s*\]/g, "='$1']"); | |
if (!u && !k.isXML(p)) if (p.nodeType === 9) try { | |
return C(p.querySelectorAll(m), q) | |
} catch (y) {} else if (p.nodeType === 1 && p.nodeName.toLowerCase() !== "object") { | |
var F = p.getAttribute("id"), | |
M = F || "__sizzle__"; | |
F || p.setAttribute("id", M); | |
try { | |
return C(p.querySelectorAll("#" + M + " " + m), q) | |
} catch (N) {} finally { | |
F || p.removeAttribute("id") | |
} | |
} | |
return g(m, p, q, u) | |
}; | |
for (var n in g) k[n] = g[n]; | |
i = null | |
} | |
}(); | |
(function () { | |
var g = t.documentElement, | |
i = g.matchesSelector || g.mozMatchesSelector || g.webkitMatchesSelector || g.msMatchesSelector, | |
n = false; | |
try { | |
i.call(t.documentElement, "[test!='']:sizzle") | |
} catch (m) { | |
n = true | |
} | |
if (i) k.matchesSelector = function (p, q) { | |
q = q.replace(/\=\s*([^'"\]]*)\s*\]/g, "='$1']"); | |
if (!k.isXML(p)) try { | |
if (n || !o.match.PSEUDO.test(q) && !/!=/.test(q)) return i.call(p, q) | |
} catch (u) {} | |
return k(q, null, null, [p]).length > 0 | |
} | |
})(); | |
(function () { | |
var g = t.createElement("div"); | |
g.innerHTML = "<div class='test e'></div><div class='test'></div>"; | |
if (!(!g.getElementsByClassName || g.getElementsByClassName("e").length === 0)) { | |
g.lastChild.className = "e"; | |
if (g.getElementsByClassName("e").length !== 1) { | |
o.order.splice(1, 0, "CLASS"); | |
o.find.CLASS = function (i, n, m) { | |
if (typeof n.getElementsByClassName !== "undefined" && !m) return n.getElementsByClassName(i[1]) | |
}; | |
g = null | |
} | |
} | |
})(); | |
k.contains = t.documentElement.contains ? function (g, i) { | |
return g !== i && (g.contains ? g.contains(i) : true) | |
} : t.documentElement.compareDocumentPosition ? function (g, i) { | |
return !!(g.compareDocumentPosition(i) & 16) | |
} : function () { | |
return false | |
}; | |
k.isXML = function (g) { | |
return (g = (g ? g.ownerDocument || g : 0).documentElement) ? g.nodeName !== "HTML" : false | |
}; | |
var L = function (g, i) { | |
for (var n, m = [], p = "", q = i.nodeType ? [i] : i; n = o.match.PSEUDO.exec(g);) { | |
p += n[0]; | |
g = g.replace(o.match.PSEUDO, "") | |
} | |
g = o.relative[g] ? g + "*" : g; | |
n = 0; | |
for (var u = q.length; n < u; n++) k(g, q[n], m); | |
return k.filter(p, m) | |
}; | |
c.find = k; | |
c.expr = k.selectors; | |
c.expr[":"] = c.expr.filters; | |
c.unique = k.uniqueSort; | |
c.text = k.getText; | |
c.isXMLDoc = k.isXML; | |
c.contains = k.contains | |
})(); | |
var Za = /Until$/, | |
$a = /^(?:parents|prevUntil|prevAll)/, | |
ab = /,/, | |
Na = /^.[^:#\[\.,]*$/, | |
bb = Array.prototype.slice, | |
cb = c.expr.match.POS; | |
c.fn.extend({ | |
find: function (a) { | |
for (var b = this.pushStack("", "find", a), d = 0, e = 0, f = this.length; e < f; e++) { | |
d = b.length; | |
c.find(a, this[e], b); | |
if (e > 0) for (var h = d; h < b.length; h++) for (var l = 0; l < d; l++) if (b[l] === b[h]) { | |
b.splice(h--, 1); | |
break | |
} | |
} | |
return b | |
}, | |
has: function (a) { | |
var b = c(a); | |
return this.filter(function () { | |
for (var d = 0, e = b.length; d < e; d++) if (c.contains(this, b[d])) return true | |
}) | |
}, | |
not: function (a) { | |
return this.pushStack(ma(this, a, false), "not", a) | |
}, | |
filter: function (a) { | |
return this.pushStack(ma(this, a, true), "filter", a) | |
}, | |
is: function (a) { | |
return !!a && c.filter(a, this).length > 0 | |
}, | |
closest: function (a, b) { | |
var d = [], | |
e, f, h = this[0]; | |
if (c.isArray(a)) { | |
var l, k = {}, | |
o = 1; | |
if (h && a.length) { | |
e = 0; | |
for (f = a.length; e < f; e++) { | |
l = a[e]; | |
k[l] || (k[l] = c.expr.match.POS.test(l) ? c(l, b || this.context) : l) | |
} | |
for (; h && h.ownerDocument && h !== b;) { | |
for (l in k) { | |
e = k[l]; | |
if (e.jquery ? e.index(h) > -1 : c(h).is(e)) d.push({ | |
selector: l, | |
elem: h, | |
level: o | |
}) | |
} | |
h = h.parentNode; | |
o++ | |
} | |
} | |
return d | |
} | |
l = cb.test(a) ? c(a, b || this.context) : null; | |
e = 0; | |
for (f = this.length; e < f; e++) for (h = this[e]; h;) if (l ? l.index(h) > -1 : c.find.matchesSelector(h, a)) { | |
d.push(h); | |
break | |
} else { | |
h = h.parentNode; | |
if (!h || !h.ownerDocument || h === b) break | |
} | |
d = d.length > 1 ? c.unique(d) : d; | |
return this.pushStack(d, "closest", a) | |
}, | |
index: function (a) { | |
if (!a || typeof a === "string") return c.inArray(this[0], a ? c(a) : this.parent().children()); | |
return c.inArray(a.jquery ? a[0] : a, this) | |
}, | |
add: function (a, b) { | |
var d = typeof a === "string" ? c(a, b || this.context) : c.makeArray(a), | |
e = c.merge(this.get(), d); | |
return this.pushStack(!d[0] || !d[0].parentNode || d[0].parentNode.nodeType === 11 || !e[0] || !e[0].parentNode || e[0].parentNode.nodeType === 11 ? e : c.unique(e)) | |
}, | |
andSelf: function () { | |
return this.add(this.prevObject) | |
} | |
}); | |
c.each({ | |
parent: function (a) { | |
return (a = a.parentNode) && a.nodeType !== 11 ? a : null | |
}, | |
parents: function (a) { | |
return c.dir(a, "parentNode") | |
}, | |
parentsUntil: function (a, b, d) { | |
return c.dir(a, "parentNode", d) | |
}, | |
next: function (a) { | |
return c.nth(a, 2, "nextSibling") | |
}, | |
prev: function (a) { | |
return c.nth(a, 2, "previousSibling") | |
}, | |
nextAll: function (a) { | |
return c.dir(a, "nextSibling") | |
}, | |
prevAll: function (a) { | |
return c.dir(a, "previousSibling") | |
}, | |
nextUntil: function (a, b, d) { | |
return c.dir(a, "nextSibling", d) | |
}, | |
prevUntil: function (a, b, d) { | |
return c.dir(a, "previousSibling", d) | |
}, | |
siblings: function (a) { | |
return c.sibling(a.parentNode.firstChild, a) | |
}, | |
children: function (a) { | |
return c.sibling(a.firstChild) | |
}, | |
contents: function (a) { | |
return c.nodeName(a, "iframe") ? a.contentDocument || a.contentWindow.document : c.makeArray(a.childNodes) | |
} | |
}, function (a, b) { | |
c.fn[a] = function (d, e) { | |
var f = c.map(this, b, d); | |
Za.test(a) || (e = d); | |
if (e && typeof e === "string") f = c.filter(e, f); | |
f = this.length > 1 ? c.unique(f) : f; | |
if ((this.length > 1 || ab.test(e)) && $a.test(a)) f = f.reverse(); | |
return this.pushStack(f, a, bb.call(arguments).join(",")) | |
} | |
}); | |
c.extend({ | |
filter: function (a, b, d) { | |
if (d) a = ":not(" + a + ")"; | |
return b.length === 1 ? c.find.matchesSelector(b[0], a) ? [b[0]] : [] : c.find.matches(a, b) | |
}, | |
dir: function (a, b, d) { | |
var e = []; | |
for (a = a[b]; a && a.nodeType !== 9 && (d === B || a.nodeType !== 1 || !c(a).is(d));) { | |
a.nodeType === 1 && e.push(a); | |
a = a[b] | |
} | |
return e | |
}, | |
nth: function (a, b, d) { | |
b = b || 1; | |
for (var e = 0; a; a = a[d]) if (a.nodeType === 1 && ++e === b) break; | |
return a | |
}, | |
sibling: function (a, b) { | |
for (var d = []; a; a = a.nextSibling) a.nodeType === 1 && a !== b && d.push(a); | |
return d | |
} | |
}); | |
var za = / jQuery\d+="(?:\d+|null)"/g, | |
$ = /^\s+/, | |
Aa = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig, | |
Ba = /<([\w:]+)/, | |
db = /<tbody/i, | |
eb = /<|&#?\w+;/, | |
Ca = /<(?:script|object|embed|option|style)/i, | |
Da = /checked\s*(?:[^=]|=\s*.checked.)/i, | |
fb = /\=([^="'>\s]+\/)>/g, | |
P = { | |
option: [1, "<select multiple='multiple'>", "</select>"], | |
legend: [1, "<fieldset>", "</fieldset>"], | |
thead: [1, "<table>", "</table>"], | |
tr: [2, "<table><tbody>", "</tbody></table>"], | |
td: [3, "<table><tbody><tr>", "</tr></tbody></table>"], | |
col: [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"], | |
area: [1, "<map>", "</map>"], | |
_default: [0, "", ""] | |
}; | |
P.optgroup = P.option; | |
P.tbody = P.tfoot = P.colgroup = P.caption = P.thead; | |
P.th = P.td; | |
if (!c.support.htmlSerialize) P._default = [1, "div<div>", "</div>"]; | |
c.fn.extend({ | |
text: function (a) { | |
if (c.isFunction(a)) return this.each(function (b) { | |
var d = c(this); | |
d.text(a.call(this, b, d.text())) | |
}); | |
if (typeof a !== "object" && a !== B) return this.empty().append((this[0] && this[0].ownerDocument || t).createTextNode(a)); | |
return c.text(this) | |
}, | |
wrapAll: function (a) { | |
if (c.isFunction(a)) return this.each(function (d) { | |
c(this).wrapAll(a.call(this, d)) | |
}); | |
if (this[0]) { | |
var b = c(a, this[0].ownerDocument).eq(0).clone(true); | |
this[0].parentNode && b.insertBefore(this[0]); | |
b.map(function () { | |
for (var d = this; d.firstChild && d.firstChild.nodeType === 1;) d = d.firstChild; | |
return d | |
}).append(this) | |
} | |
return this | |
}, | |
wrapInner: function (a) { | |
if (c.isFunction(a)) return this.each(function (b) { | |
c(this).wrapInner(a.call(this, b)) | |
}); | |
return this.each(function () { | |
var b = c(this), | |
d = b.contents(); | |
d.length ? d.wrapAll(a) : b.append(a) | |
}) | |
}, | |
wrap: function (a) { | |
return this.each(function () { | |
c(this).wrapAll(a) | |
}) | |
}, | |
unwrap: function () { | |
return this.parent().each(function () { | |
c.nodeName(this, "body") || c(this).replaceWith(this.childNodes) | |
}).end() | |
}, | |
append: function () { | |
return this.domManip(arguments, true, function (a) { | |
this.nodeType === 1 && this.appendChild(a) | |
}) | |
}, | |
prepend: function () { | |
return this.domManip(arguments, true, function (a) { | |
this.nodeType === 1 && this.insertBefore(a, this.firstChild) | |
}) | |
}, | |
before: function () { | |
if (this[0] && this[0].parentNode) return this.domManip(arguments, false, function (b) { | |
this.parentNode.insertBefore(b, this) | |
}); | |
else if (arguments.length) { | |
var a = c(arguments[0]); | |
a.push.apply(a, this.toArray()); | |
return this.pushStack(a, "before", arguments) | |
} | |
}, | |
after: function () { | |
if (this[0] && this[0].parentNode) return this.domManip(arguments, false, function (b) { | |
this.parentNode.insertBefore(b, this.nextSibling) | |
}); | |
else if (arguments.length) { | |
var a = this.pushStack(this, "after", arguments); | |
a.push.apply(a, c(arguments[0]).toArray()); | |
return a | |
} | |
}, | |
remove: function (a, b) { | |
for (var d = 0, e; | |
(e = this[d]) != null; d++) if (!a || c.filter(a, [e]).length) { | |
if (!b && e.nodeType === 1) { | |
c.cleanData(e.getElementsByTagName("*")); | |
c.cleanData([e]) | |
} | |
e.parentNode && e.parentNode.removeChild(e) | |
} | |
return this | |
}, | |
empty: function () { | |
for (var a = 0, b; | |
(b = this[a]) != null; a++) for (b.nodeType === 1 && c.cleanData(b.getElementsByTagName("*")); b.firstChild;) b.removeChild(b.firstChild); | |
return this | |
}, | |
clone: function (a) { | |
var b = this.map(function () { | |
if (!c.support.noCloneEvent && !c.isXMLDoc(this)) { | |
var d = this.outerHTML, | |
e = this.ownerDocument; | |
if (!d) { | |
d = e.createElement("div"); | |
d.appendChild(this.cloneNode(true)); | |
d = d.innerHTML | |
} | |
return c.clean([d.replace(za, "").replace(fb, '="$1">').replace($, "")], e)[0] | |
} else return this.cloneNode(true) | |
}); | |
if (a === true) { | |
na(this, b); | |
na(this.find("*"), b.find("*")) | |
} | |
return b | |
}, | |
html: function (a) { | |
if (a === B) return this[0] && this[0].nodeType === 1 ? this[0].innerHTML.replace(za, "") : null; | |
else if (typeof a === "string" && !Ca.test(a) && (c.support.leadingWhitespace || !$.test(a)) && !P[(Ba.exec(a) || ["", ""])[1].toLowerCase()]) { | |
a = a.replace(Aa, "<$1></$2>"); | |
try { | |
for (var b = 0, d = this.length; b < d; b++) if (this[b].nodeType === 1) { | |
c.cleanData(this[b].getElementsByTagName("*")); | |
this[b].innerHTML = a | |
} | |
} catch (e) { | |
this.empty().append(a) | |
} | |
} else c.isFunction(a) ? this.each(function (f) { | |
var h = c(this); | |
h.html(a.call(this, f, h.html())) | |
}) : this.empty().append(a); | |
return this | |
}, | |
replaceWith: function (a) { | |
if (this[0] && this[0].parentNode) { | |
if (c.isFunction(a)) return this.each(function (b) { | |
var d = c(this), | |
e = d.html(); | |
d.replaceWith(a.call(this, b, e)) | |
}); | |
if (typeof a !== "string") a = c(a).detach(); | |
return this.each(function () { | |
var b = this.nextSibling, | |
d = this.parentNode; | |
c(this).remove(); | |
b ? c(b).before(a) : c(d).append(a) | |
}) | |
} else return this.pushStack(c(c.isFunction(a) ? a() : a), "replaceWith", a) | |
}, | |
detach: function (a) { | |
return this.remove(a, true) | |
}, | |
domManip: function (a, b, d) { | |
var e, f, h, l = a[0], | |
k = []; | |
if (!c.support.checkClone && arguments.length === 3 && typeof l === "string" && Da.test(l)) return this.each(function () { | |
c(this).domManip(a, b, d, true) | |
}); | |
if (c.isFunction(l)) return this.each(function (x) { | |
var r = c(this); | |
a[0] = l.call(this, x, b ? r.html() : B); | |
r.domManip(a, b, d) | |
}); | |
if (this[0]) { | |
e = l && l.parentNode; | |
e = c.support.parentNode && e && e.nodeType === 11 && e.childNodes.length === this.length ? { | |
fragment: e | |
} : c.buildFragment(a, this, k); | |
h = e.fragment; | |
if (f = h.childNodes.length === 1 ? h = h.firstChild : h.firstChild) { | |
b = b && c.nodeName(f, "tr"); | |
f = 0; | |
for (var o = this.length; f < o; f++) d.call(b ? c.nodeName(this[f], "table") ? this[f].getElementsByTagName("tbody")[0] || this[f].appendChild(this[f].ownerDocument.createElement("tbody")) : this[f] : this[f], f > 0 || e.cacheable || this.length > 1 ? h.cloneNode(true) : h) | |
} | |
k.length && c.each(k, Oa) | |
} | |
return this | |
} | |
}); | |
c.buildFragment = function (a, b, d) { | |
var e, f, h; | |
b = b && b[0] ? b[0].ownerDocument || b[0] : t; | |
if (a.length === 1 && typeof a[0] === "string" && a[0].length < 512 && b === t && !Ca.test(a[0]) && (c.support.checkClone || !Da.test(a[0]))) { | |
f = true; | |
if (h = c.fragments[a[0]]) if (h !== 1) e = h | |
} | |
if (!e) { | |
e = b.createDocumentFragment(); | |
c.clean(a, b, e, d) | |
} | |
if (f) c.fragments[a[0]] = h ? e : 1; | |
return { | |
fragment: e, | |
cacheable: f | |
} | |
}; | |
c.fragments = {}; | |
c.each({ | |
appendTo: "append", | |
prependTo: "prepend", | |
insertBefore: "before", | |
insertAfter: "after", | |
replaceAll: "replaceWith" | |
}, function (a, b) { | |
c.fn[a] = function (d) { | |
var e = []; | |
d = c(d); | |
var f = this.length === 1 && this[0].parentNode; | |
if (f && f.nodeType === 11 && f.childNodes.length === 1 && d.length === 1) { | |
d[b](this[0]); | |
return this | |
} else { | |
f = 0; | |
for (var h = d.length; f < h; f++) { | |
var l = (f > 0 ? this.clone(true) : this).get(); | |
c(d[f])[b](l); | |
e = e.concat(l) | |
} | |
return this.pushStack(e, a, d.selector) | |
} | |
} | |
}); | |
c.extend({ | |
clean: function (a, b, d, e) { | |
b = b || t; | |
if (typeof b.createElement === "undefined") b = b.ownerDocument || b[0] && b[0].ownerDocument || t; | |
for (var f = [], h = 0, l; | |
(l = a[h]) != null; h++) { | |
if (typeof l === "number") l += ""; | |
if (l) { | |
if (typeof l === "string" && !eb.test(l)) l = b.createTextNode(l); | |
else if (typeof l === "string") { | |
l = l.replace(Aa, "<$1></$2>"); | |
var k = (Ba.exec(l) || ["", ""])[1].toLowerCase(), | |
o = P[k] || P._default, | |
x = o[0], | |
r = b.createElement("div"); | |
for (r.innerHTML = o[1] + l + o[2]; x--;) r = r.lastChild; | |
if (!c.support.tbody) { | |
x = db.test(l); | |
k = k === "table" && !x ? r.firstChild && r.firstChild.childNodes : o[1] === "<table>" && !x ? r.childNodes : []; | |
for (o = k.length - 1; o >= 0; --o) c.nodeName(k[o], "tbody") && !k[o].childNodes.length && k[o].parentNode.removeChild(k[o]) | |
}!c.support.leadingWhitespace && $.test(l) && r.insertBefore(b.createTextNode($.exec(l)[0]), r.firstChild); | |
l = r.childNodes | |
} | |
if (l.nodeType) f.push(l); | |
else f = c.merge(f, l) | |
} | |
} | |
if (d) for (h = 0; f[h]; h++) if (e && c.nodeName(f[h], "script") && (!f[h].type || f[h].type.toLowerCase() === "text/javascript")) e.push(f[h].parentNode ? f[h].parentNode.removeChild(f[h]) : f[h]); | |
else { | |
f[h].nodeType === 1 && f.splice.apply(f, [h + 1, 0].concat(c.makeArray(f[h].getElementsByTagName("script")))); | |
d.appendChild(f[h]) | |
} | |
return f | |
}, | |
cleanData: function (a) { | |
for (var b, d, e = c.cache, f = c.event.special, h = c.support.deleteExpando, l = 0, k; | |
(k = a[l]) != null; l++) if (!(k.nodeName && c.noData[k.nodeName.toLowerCase()])) if (d = k[c.expando]) { | |
if ((b = e[d]) && b.events) for (var o in b.events) f[o] ? c.event.remove(k, o) : c.removeEvent(k, o, b.handle); | |
if (h) delete k[c.expando]; | |
else k.removeAttribute && k.removeAttribute(c.expando); | |
delete e[d] | |
} | |
} | |
}); | |
var Ea = /alpha\([^)]*\)/i, | |
gb = /opacity=([^)]*)/, | |
hb = /-([a-z])/ig, | |
ib = /([A-Z])/g, | |
Fa = /^-?\d+(?:px)?$/i, | |
jb = /^-?\d/, | |
kb = { | |
position: "absolute", | |
visibility: "hidden", | |
display: "block" | |
}, | |
Pa = ["Left", "Right"], | |
Qa = ["Top", "Bottom"], | |
W, Ga, aa, lb = function (a, b) { | |
return b.toUpperCase() | |
}; | |
c.fn.css = function (a, b) { | |
if (arguments.length === 2 && b === B) return this; | |
return c.access(this, a, b, true, function (d, e, f) { | |
return f !== B ? c.style(d, e, f) : c.css(d, e) | |
}) | |
}; | |
c.extend({ | |
cssHooks: { | |
opacity: { | |
get: function (a, b) { | |
if (b) { | |
var d = W(a, "opacity", "opacity"); | |
return d === "" ? "1" : d | |
} else return a.style.opacity | |
} | |
} | |
}, | |
cssNumber: { | |
zIndex: true, | |
fontWeight: true, | |
opacity: true, | |
zoom: true, | |
lineHeight: true | |
}, | |
cssProps: { | |
"float": c.support.cssFloat ? "cssFloat" : "styleFloat" | |
}, | |
style: function (a, b, d, e) { | |
if (!(!a || a.nodeType === 3 || a.nodeType === 8 || !a.style)) { | |
var f, h = c.camelCase(b), | |
l = a.style, | |
k = c.cssHooks[h]; | |
b = c.cssProps[h] || h; | |
if (d !== B) { | |
if (!(typeof d === "number" && isNaN(d) || d == null)) { | |
if (typeof d === "number" && !c.cssNumber[h]) d += "px"; | |
if (!k || !("set" in k) || (d = k.set(a, d)) !== B) try { | |
l[b] = d | |
} catch (o) {} | |
} | |
} else { | |
if (k && "get" in k && (f = k.get(a, false, e)) !== B) return f; | |
return l[b] | |
} | |
} | |
}, | |
css: function (a, b, d) { | |
var e, f = c.camelCase(b), | |
h = c.cssHooks[f]; | |
b = c.cssProps[f] || f; | |
if (h && "get" in h && (e = h.get(a, true, d)) !== B) return e; | |
else if (W) return W(a, b, f) | |
}, | |
swap: function (a, b, d) { | |
var e = {}, | |
f; | |
for (f in b) { | |
e[f] = a.style[f]; | |
a.style[f] = b[f] | |
} | |
d.call(a); | |
for (f in b) a.style[f] = e[f] | |
}, | |
camelCase: function (a) { | |
return a.replace(hb, lb) | |
} | |
}); | |
c.curCSS = c.css; | |
c.each(["height", "width"], function (a, b) { | |
c.cssHooks[b] = { | |
get: function (d, e, f) { | |
var h; | |
if (e) { | |
if (d.offsetWidth !== 0) h = oa(d, b, f); | |
else c.swap(d, kb, function () { | |
h = oa(d, b, f) | |
}); | |
if (h <= 0) { | |
h = W(d, b, b); | |
if (h === "0px" && aa) h = aa(d, b, b); | |
if (h != null) return h === "" || h === "auto" ? "0px" : h | |
} | |
if (h < 0 || h == null) { | |
h = d.style[b]; | |
return h === "" || h === "auto" ? "0px" : h | |
} | |
return typeof h === "string" ? h : h + "px" | |
} | |
}, | |
set: function (d, e) { | |
if (Fa.test(e)) { | |
e = parseFloat(e); | |
if (e >= 0) return e + "px" | |
} else return e | |
} | |
} | |
}); | |
if (!c.support.opacity) c.cssHooks.opacity = { | |
get: function (a, b) { | |
return gb.test((b && a.currentStyle ? a.currentStyle.filter : a.style.filter) || "") ? parseFloat(RegExp.$1) / 100 + "" : b ? "1" : "" | |
}, | |
set: function (a, b) { | |
var d = a.style; | |
d.zoom = 1; | |
var e = c.isNaN(b) ? "" : "alpha(opacity=" + b * 100 + ")", | |
f = d.filter || ""; | |
d.filter = Ea.test(f) ? f.replace(Ea, e) : d.filter + " " + e | |
} | |
}; | |
if (t.defaultView && t.defaultView.getComputedStyle) Ga = function (a, b, d) { | |
var e; | |
d = d.replace(ib, "-$1").toLowerCase(); | |
if (!(b = a.ownerDocument.defaultView)) return B; | |
if (b = b.getComputedStyle(a, null)) { | |
e = b.getPropertyValue(d); | |
if (e === "" && !c.contains(a.ownerDocument.documentElement, a)) e = c.style(a, d) | |
} | |
return e | |
}; | |
if (t.documentElement.currentStyle) aa = function (a, b) { | |
var d, e, f = a.currentStyle && a.currentStyle[b], | |
h = a.style; | |
if (!Fa.test(f) && jb.test(f)) { | |
d = h.left; | |
e = a.runtimeStyle.left; | |
a.runtimeStyle.left = a.currentStyle.left; | |
h.left = b === "fontSize" ? "1em" : f || 0; | |
f = h.pixelLeft + "px"; | |
h.left = d; | |
a.runtimeStyle.left = e | |
} | |
return f === "" ? "auto" : f | |
}; | |
W = Ga || aa; | |
if (c.expr && c.expr.filters) { | |
c.expr.filters.hidden = function (a) { | |
var b = a.offsetHeight; | |
return a.offsetWidth === 0 && b === 0 || !c.support.reliableHiddenOffsets && (a.style.display || c.css(a, "display")) === "none" | |
}; | |
c.expr.filters.visible = function (a) { | |
return !c.expr.filters.hidden(a) | |
} | |
} | |
var mb = c.now(), | |
nb = /<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi, | |
ob = /^(?:select|textarea)/i, | |
pb = /^(?:color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i, | |
qb = /^(?:GET|HEAD)$/, | |
Ra = /\[\]$/, | |
T = /\=\?(&|$)/, | |
ja = /\?/, | |
rb = /([?&])_=[^&]*/, | |
sb = /^(\w+:)?\/\/([^\/?#]+)/, | |
tb = /%20/g, | |
ub = /#.*$/, | |
Ha = c.fn.load; | |
c.fn.extend({ | |
load: function (a, b, d) { | |
if (typeof a !== "string" && Ha) return Ha.apply(this, arguments); | |
else if (!this.length) return this; | |
var e = a.indexOf(" "); | |
if (e >= 0) { | |
var f = a.slice(e, a.length); | |
a = a.slice(0, e) | |
} | |
e = "GET"; | |
if (b) if (c.isFunction(b)) { | |
d = b; | |
b = null | |
} else if (typeof b === "object") { | |
b = c.param(b, c.ajaxSettings.traditional); | |
e = "POST" | |
} | |
var h = this; | |
c.ajax({ | |
url: a, | |
type: e, | |
dataType: "html", | |
data: b, | |
complete: function (l, k) { | |
if (k === "success" || k === "notmodified") h.html(f ? c("<div>").append(l.responseText.replace(nb, "")).find(f) : l.responseText); | |
d && h.each(d, [l.responseText, k, l]) | |
} | |
}); | |
return this | |
}, | |
serialize: function () { | |
return c.param(this.serializeArray()) | |
}, | |
serializeArray: function () { | |
return this.map(function () { | |
return this.elements ? c.makeArray(this.elements) : this | |
}).filter(function () { | |
return this.name && !this.disabled && (this.checked || ob.test(this.nodeName) || pb.test(this.type)) | |
}).map(function (a, b) { | |
var d = c(this).val(); | |
return d == null ? null : c.isArray(d) ? c.map(d, function (e) { | |
return { | |
name: b.name, | |
value: e | |
} | |
}) : { | |
name: b.name, | |
value: d | |
} | |
}).get() | |
} | |
}); | |
c.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "), function (a, b) { | |
c.fn[b] = function (d) { | |
return this.bind(b, d) | |
} | |
}); | |
c.extend({ | |
get: function (a, b, d, e) { | |
if (c.isFunction(b)) { | |
e = e || d; | |
d = b; | |
b = null | |
} | |
return c.ajax({ | |
type: "GET", | |
url: a, | |
data: b, | |
success: d, | |
dataType: e | |
}) | |
}, | |
getScript: function (a, b) { | |
return c.get(a, null, b, "script") | |
}, | |
getJSON: function (a, b, d) { | |
return c.get(a, b, d, "json") | |
}, | |
post: function (a, b, d, e) { | |
if (c.isFunction(b)) { | |
e = e || d; | |
d = b; | |
b = {} | |
} | |
return c.ajax({ | |
type: "POST", | |
url: a, | |
data: b, | |
success: d, | |
dataType: e | |
}) | |
}, | |
ajaxSetup: function (a) { | |
c.extend(c.ajaxSettings, a) | |
}, | |
ajaxSettings: { | |
url: location.href, | |
global: true, | |
type: "GET", | |
contentType: "application/x-www-form-urlencoded", | |
processData: true, | |
async: true, | |
xhr: function () { | |
return new E.XMLHttpRequest | |
}, | |
accepts: { | |
xml: "application/xml, text/xml", | |
html: "text/html", | |
script: "text/javascript, application/javascript", | |
json: "application/json, text/javascript", | |
text: "text/plain", | |
_default: "*/*" | |
} | |
}, | |
ajax: function (a) { | |
var b = c.extend(true, {}, c.ajaxSettings, a), | |
d, e, f, h = b.type.toUpperCase(), | |
l = qb.test(h); | |
b.url = b.url.replace(ub, ""); | |
b.context = a && a.context != null ? a.context : b; | |
if (b.data && b.processData && typeof b.data !== "string") b.data = c.param(b.data, b.traditional); | |
if (b.dataType === "jsonp") { | |
if (h === "GET") T.test(b.url) || (b.url += (ja.test(b.url) ? "&" : "?") + (b.jsonp || "callback") + "=?"); | |
else if (!b.data || !T.test(b.data)) b.data = (b.data ? b.data + "&" : "") + (b.jsonp || "callback") + "=?"; | |
b.dataType = "json" | |
} | |
if (b.dataType === "json" && (b.data && T.test(b.data) || T.test(b.url))) { | |
d = b.jsonpCallback || "jsonp" + mb++; | |
if (b.data) b.data = (b.data + "").replace(T, "=" + d + "$1"); | |
b.url = b.url.replace(T, "=" + d + "$1"); | |
b.dataType = "script"; | |
var k = E[d]; | |
E[d] = function (m) { | |
if (c.isFunction(k)) k(m); | |
else { | |
E[d] = B; | |
try { | |
delete E[d] | |
} catch (p) {} | |
} | |
f = m; | |
c.handleSuccess(b, w, e, f); | |
c.handleComplete(b, w, e, f); | |
r && r.removeChild(A) | |
} | |
} | |
if (b.dataType === "script" && b.cache === null) b.cache = false; | |
if (b.cache === false && l) { | |
var o = c.now(), | |
x = b.url.replace(rb, "$1_=" + o); | |
b.url = x + (x === b.url ? (ja.test(b.url) ? "&" : "?") + "_=" + o : "") | |
} | |
if (b.data && l) b.url += (ja.test(b.url) ? "&" : "?") + b.data; | |
b.global && c.active++ === 0 && c.event.trigger("ajaxStart"); | |
o = (o = sb.exec(b.url)) && (o[1] && o[1].toLowerCase() !== location.protocol || o[2].toLowerCase() !== location.host); | |
if (b.dataType === "script" && h === "GET" && o) { | |
var r = t.getElementsByTagName("head")[0] || t.documentElement, | |
A = t.createElement("script"); | |
if (b.scriptCharset) A.charset = b.scriptCharset; | |
A.src = b.url; | |
if (!d) { | |
var C = false; | |
A.onload = A.onreadystatechange = function () { | |
if (!C && (!this.readyState || this.readyState === "loaded" || this.readyState === "complete")) { | |
C = true; | |
c.handleSuccess(b, w, e, f); | |
c.handleComplete(b, w, e, f); | |
A.onload = A.onreadystatechange = null; | |
r && A.parentNode && r.removeChild(A) | |
} | |
} | |
} | |
r.insertBefore(A, r.firstChild); | |
return B | |
} | |
var J = false, | |
w = b.xhr(); | |
if (w) { | |
b.username ? w.open(h, b.url, b.async, b.username, b.password) : w.open(h, b.url, b.async); | |
try { | |
if (b.data != null && !l || a && a.contentType) w.setRequestHeader("Content-Type", b.contentType); | |
if (b.ifModified) { | |
c.lastModified[b.url] && w.setRequestHeader("If-Modified-Since", c.lastModified[b.url]); | |
c.etag[b.url] && w.setRequestHeader("If-None-Match", c.etag[b.url]) | |
} | |
o || w.setRequestHeader("X-Requested-With", "XMLHttpRequest"); | |
w.setRequestHeader("Accept", b.dataType && b.accepts[b.dataType] ? b.accepts[b.dataType] + ", */*; q=0.01" : b.accepts._default) | |
} catch (I) {} | |
if (b.beforeSend && b.beforeSend.call(b.context, w, b) === false) { | |
b.global && c.active-- === 1 && c.event.trigger("ajaxStop"); | |
w.abort(); | |
return false | |
} | |
b.global && c.triggerGlobal(b, "ajaxSend", [w, b]); | |
var L = w.onreadystatechange = function (m) { | |
if (!w || w.readyState === 0 || m === "abort") { | |
J || c.handleComplete(b, w, e, f); | |
J = true; | |
if (w) w.onreadystatechange = c.noop | |
} else if (!J && w && (w.readyState === 4 || m === "timeout")) { | |
J = true; | |
w.onreadystatechange = c.noop; | |
e = m === "timeout" ? "timeout" : !c.httpSuccess(w) ? "error" : b.ifModified && c.httpNotModified(w, b.url) ? "notmodified" : "success"; | |
var p; | |
if (e === "success") try { | |
f = c.httpData(w, b.dataType, b) | |
} catch (q) { | |
e = "parsererror"; | |
p = q | |
} | |
if (e === "success" || e === "notmodified") d || c.handleSuccess(b, w, e, f); | |
else c.handleError(b, w, e, p); | |
d || c.handleComplete(b, w, e, f); | |
m === "timeout" && w.abort(); | |
if (b.async) w = null | |
} | |
}; | |
try { | |
var g = w.abort; | |
w.abort = function () { | |
w && Function.prototype.call.call(g, w); | |
L("abort") | |
} | |
} catch (i) {} | |
b.async && b.timeout > 0 && setTimeout(function () { | |
w && !J && L("timeout") | |
}, b.timeout); | |
try { | |
w.send(l || b.data == null ? null : b.data) | |
} catch (n) { | |
c.handleError(b, w, null, n); | |
c.handleComplete(b, w, e, f) | |
} | |
b.async || L(); | |
return w | |
} | |
}, | |
param: function (a, b) { | |
var d = [], | |
e = function (h, l) { | |
l = c.isFunction(l) ? l() : l; | |
d[d.length] = encodeURIComponent(h) + "=" + encodeURIComponent(l) | |
}; | |
if (b === B) b = c.ajaxSettings.traditional; | |
if (c.isArray(a) || a.jquery) c.each(a, function () { | |
e(this.name, this.value) | |
}); | |
else for (var f in a) da(f, a[f], b, e); | |
return d.join("&").replace(tb, "+") | |
} | |
}); | |
c.extend({ | |
active: 0, | |
lastModified: {}, | |
etag: {}, | |
handleError: function (a, b, d, e) { | |
a.error && a.error.call(a.context, b, d, e); | |
a.global && c.triggerGlobal(a, "ajaxError", [b, a, e]) | |
}, | |
handleSuccess: function (a, b, d, e) { | |
a.success && a.success.call(a.context, e, d, b); | |
a.global && c.triggerGlobal(a, "ajaxSuccess", [b, a]) | |
}, | |
handleComplete: function (a, b, d) { | |
a.complete && a.complete.call(a.context, b, d); | |
a.global && c.triggerGlobal(a, "ajaxComplete", [b, a]); | |
a.global && c.active-- === 1 && c.event.trigger("ajaxStop") | |
}, | |
triggerGlobal: function (a, b, d) { | |
(a.context && a.context.url == null ? c(a.context) : c.event).trigger(b, d) | |
}, | |
httpSuccess: function (a) { | |
try { | |
return !a.status && location.protocol === "file:" || a.status >= 200 && a.status < 300 || a.status === 304 || a.status === 1223 | |
} catch (b) {} | |
return false | |
}, | |
httpNotModified: function (a, b) { | |
var d = a.getResponseHeader("Last-Modified"), | |
e = a.getResponseHeader("Etag"); | |
if (d) c.lastModified[b] = d; | |
if (e) c.etag[b] = e; | |
return a.status === 304 | |
}, | |
httpData: function (a, b, d) { | |
var e = a.getResponseHeader("content-type") || "", | |
f = b === "xml" || !b && e.indexOf("xml") >= 0; | |
a = f ? a.responseXML : a.responseText; | |
f && a.documentElement.nodeName === "parsererror" && c.error("parsererror"); | |
if (d && d.dataFilter) a = d.dataFilter(a, b); | |
if (typeof a === "string") if (b === "json" || !b && e.indexOf("json") >= 0) a = c.parseJSON(a); | |
else if (b === "script" || !b && e.indexOf("javascript") >= 0) c.globalEval(a); | |
return a | |
} | |
}); | |
if (E.ActiveXObject) c.ajaxSettings.xhr = function () { | |
if (E.location.protocol !== "file:") try { | |
return new E.XMLHttpRequest | |
} catch (a) {} | |
try { | |
return new E.ActiveXObject("Microsoft.XMLHTTP") | |
} catch (b) {} | |
}; | |
c.support.ajax = !! c.ajaxSettings.xhr(); | |
var ea = {}, | |
vb = /^(?:toggle|show|hide)$/, | |
wb = /^([+\-]=)?([\d+.\-]+)(.*)$/, | |
ba, pa = [ | |
["height", "marginTop", "marginBottom", "paddingTop", "paddingBottom"], | |
["width", "marginLeft", "marginRight", "paddingLeft", "paddingRight"], | |
["opacity"] | |
]; | |
c.fn.extend({ | |
show: function (a, b, d) { | |
if (a || a === 0) return this.animate(S("show", 3), a, b, d); | |
else { | |
d = 0; | |
for (var e = this.length; d < e; d++) { | |
a = this[d]; | |
b = a.style.display; | |
if (!c.data(a, "olddisplay") && b === "none") b = a.style.display = ""; | |
b === "" && c.css(a, "display") === "none" && c.data(a, "olddisplay", qa(a.nodeName)) | |
} | |
for (d = 0; d < e; d++) { | |
a = this[d]; | |
b = a.style.display; | |
if (b === "" || b === "none") a.style.display = c.data(a, "olddisplay") || "" | |
} | |
return this | |
} | |
}, | |
hide: function (a, b, d) { | |
if (a || a === 0) return this.animate(S("hide", 3), a, b, d); | |
else { | |
a = 0; | |
for (b = this.length; a < b; a++) { | |
d = c.css(this[a], "display"); | |
d !== "none" && c.data(this[a], "olddisplay", d) | |
} | |
for (a = 0; a < b; a++) this[a].style.display = "none"; | |
return this | |
} | |
}, | |
_toggle: c.fn.toggle, | |
toggle: function (a, b, d) { | |
var e = typeof a === "boolean"; | |
if (c.isFunction(a) && c.isFunction(b)) this._toggle.apply(this, arguments); | |
else a == null || e ? this.each(function () { | |
var f = e ? a : c(this).is(":hidden"); | |
c(this)[f ? "show" : "hide"]() | |
}) : this.animate(S("toggle", 3), a, b, d); | |
return this | |
}, | |
fadeTo: function (a, b, d, e) { | |
return this.filter(":hidden").css("opacity", 0).show().end().animate({ | |
opacity: b | |
}, a, d, e) | |
}, | |
animate: function (a, b, d, e) { | |
var f = c.speed(b, d, e); | |
if (c.isEmptyObject(a)) return this.each(f.complete); | |
return this[f.queue === false ? "each" : "queue"](function () { | |
var h = c.extend({}, f), | |
l, k = this.nodeType === 1, | |
o = k && c(this).is(":hidden"), | |
x = this; | |
for (l in a) { | |
var r = c.camelCase(l); | |
if (l !== r) { | |
a[r] = a[l]; | |
delete a[l]; | |
l = r | |
} | |
if (a[l] === "hide" && o || a[l] === "show" && !o) return h.complete.call(this); | |
if (k && (l === "height" || l === "width")) { | |
h.overflow = [this.style.overflow, this.style.overflowX, this.style.overflowY]; | |
if (c.css(this, "display") === "inline" && c.css(this, "float") === "none") if (c.support.inlineBlockNeedsLayout) if (qa(this.nodeName) === "inline") this.style.display = "inline-block"; | |
else { | |
this.style.display = "inline"; | |
this.style.zoom = 1 | |
} else this.style.display = "inline-block" | |
} | |
if (c.isArray(a[l])) { | |
(h.specialEasing = h.specialEasing || {})[l] = a[l][1]; | |
a[l] = a[l][0] | |
} | |
} | |
if (h.overflow != null) this.style.overflow = "hidden"; | |
h.curAnim = c.extend({}, a); | |
c.each(a, function (A, C) { | |
var J = new c.fx(x, h, A); | |
if (vb.test(C)) J[C === "toggle" ? o ? "show" : "hide" : C](a); | |
else { | |
var w = wb.exec(C), | |
I = J.cur() || 0; | |
if (w) { | |
var L = parseFloat(w[2]), | |
g = w[3] || "px"; | |
if (g !== "px") { | |
c.style(x, A, (L || 1) + g); | |
I = (L || 1) / J.cur() * I; | |
c.style(x, A, I + g) | |
} | |
if (w[1]) L = (w[1] === "-=" ? -1 : 1) * L + I; | |
J.custom(I, L, g) | |
} else J.custom(I, C, "") | |
} | |
}); | |
return true | |
}) | |
}, | |
stop: function (a, b) { | |
var d = c.timers; | |
a && this.queue([]); | |
this.each(function () { | |
for (var e = d.length - 1; e >= 0; e--) if (d[e].elem === this) { | |
b && d[e](true); | |
d.splice(e, 1) | |
} | |
}); | |
b || this.dequeue(); | |
return this | |
} | |
}); | |
c.each({ | |
slideDown: S("show", 1), | |
slideUp: S("hide", 1), | |
slideToggle: S("toggle", 1), | |
fadeIn: { | |
opacity: "show" | |
}, | |
fadeOut: { | |
opacity: "hide" | |
}, | |
fadeToggle: { | |
opacity: "toggle" | |
} | |
}, function (a, b) { | |
c.fn[a] = function (d, e, f) { | |
return this.animate(b, d, e, f) | |
} | |
}); | |
c.extend({ | |
speed: function (a, b, d) { | |
var e = a && typeof a === "object" ? c.extend({}, a) : { | |
complete: d || !d && b || c.isFunction(a) && a, | |
duration: a, | |
easing: d && b || b && !c.isFunction(b) && b | |
}; | |
e.duration = c.fx.off ? 0 : typeof e.duration === "number" ? e.duration : e.duration in c.fx.speeds ? c.fx.speeds[e.duration] : c.fx.speeds._default; | |
e.old = e.complete; | |
e.complete = function () { | |
e.queue !== false && c(this).dequeue(); | |
c.isFunction(e.old) && e.old.call(this) | |
}; | |
return e | |
}, | |
easing: { | |
linear: function (a, b, d, e) { | |
return d + e * a | |
}, | |
swing: function (a, b, d, e) { | |
return (-Math.cos(a * Math.PI) / 2 + 0.5) * e + d | |
} | |
}, | |
timers: [], | |
fx: function (a, b, d) { | |
this.options = b; | |
this.elem = a; | |
this.prop = d; | |
if (!b.orig) b.orig = {} | |
} | |
}); | |
c.fx.prototype = { | |
update: function () { | |
this.options.step && this.options.step.call(this.elem, this.now, this); | |
(c.fx.step[this.prop] || c.fx.step._default)(this) | |
}, | |
cur: function () { | |
if (this.elem[this.prop] != null && (!this.elem.style || this.elem.style[this.prop] == null)) return this.elem[this.prop]; | |
var a = parseFloat(c.css(this.elem, this.prop)); | |
return a && a > -1E4 ? a : 0 | |
}, | |
custom: function (a, b, d) { | |
function e(l) { | |
return f.step(l) | |
} | |
var f = this, | |
h = c.fx; | |
this.startTime = c.now(); | |
this.start = a; | |
this.end = b; | |
this.unit = d || this.unit || "px"; | |
this.now = this.start; | |
this.pos = this.state = 0; | |
e.elem = this.elem; | |
if (e() && c.timers.push(e) && !ba) ba = setInterval(h.tick, h.interval) | |
}, | |
show: function () { | |
this.options.orig[this.prop] = c.style(this.elem, this.prop); | |
this.options.show = true; | |
this.custom(this.prop === "width" || this.prop === "height" ? 1 : 0, this.cur()); | |
c(this.elem).show() | |
}, | |
hide: function () { | |
this.options.orig[this.prop] = c.style(this.elem, this.prop); | |
this.options.hide = true; | |
this.custom(this.cur(), 0) | |
}, | |
step: function (a) { | |
var b = c.now(), | |
d = true; | |
if (a || b >= this.options.duration + this.startTime) { | |
this.now = this.end; | |
this.pos = this.state = 1; | |
this.update(); | |
this.options.curAnim[this.prop] = true; | |
for (var e in this.options.curAnim) if (this.options.curAnim[e] !== true) d = false; | |
if (d) { | |
if (this.options.overflow != null && !c.support.shrinkWrapBlocks) { | |
var f = this.elem, | |
h = this.options; | |
c.each(["", "X", "Y"], function (k, o) { | |
f.style["overflow" + o] = h.overflow[k] | |
}) | |
} | |
this.options.hide && c(this.elem).hide(); | |
if (this.options.hide || this.options.show) for (var l in this.options.curAnim) c.style(this.elem, l, this.options.orig[l]); | |
this.options.complete.call(this.elem) | |
} | |
return false | |
} else { | |
a = b - this.startTime; | |
this.state = a / this.options.duration; | |
b = this.options.easing || (c.easing.swing ? "swing" : "linear"); | |
this.pos = c.easing[this.options.specialEasing && this.options.specialEasing[this.prop] || b](this.state, a, 0, 1, this.options.duration); | |
this.now = this.start + (this.end - this.start) * this.pos; | |
this.update() | |
} | |
return true | |
} | |
}; | |
c.extend(c.fx, { | |
tick: function () { | |
for (var a = c.timers, b = 0; b < a.length; b++) a[b]() || a.splice(b--, 1); | |
a.length || c.fx.stop() | |
}, | |
interval: 13, | |
stop: function () { | |
clearInterval(ba); | |
ba = null | |
}, | |
speeds: { | |
slow: 600, | |
fast: 200, | |
_default: 400 | |
}, | |
step: { | |
opacity: function (a) { | |
c.style(a.elem, "opacity", a.now) | |
}, | |
_default: function (a) { | |
if (a.elem.style && a.elem.style[a.prop] != null) a.elem.style[a.prop] = (a.prop === "width" || a.prop === "height" ? Math.max(0, a.now) : a.now) + a.unit; | |
else a.elem[a.prop] = a.now | |
} | |
} | |
}); | |
if (c.expr && c.expr.filters) c.expr.filters.animated = function (a) { | |
return c.grep(c.timers, function (b) { | |
return a === b.elem | |
}).length | |
}; | |
var xb = /^t(?:able|d|h)$/i, | |
Ia = /^(?:body|html)$/i; | |
c.fn.offset = "getBoundingClientRect" in t.documentElement ? function (a) { | |
var b = this[0], | |
d; | |
if (a) return this.each(function (l) { | |
c.offset.setOffset(this, a, l) | |
}); | |
if (!b || !b.ownerDocument) return null; | |
if (b === b.ownerDocument.body) return c.offset.bodyOffset(b); | |
try { | |
d = b.getBoundingClientRect() | |
} catch (e) {} | |
var f = b.ownerDocument, | |
h = f.documentElement; | |
if (!d || !c.contains(h, b)) return d || { | |
top: 0, | |
left: 0 | |
}; | |
b = f.body; | |
f = fa(f); | |
return { | |
top: d.top + (f.pageYOffset || c.support.boxModel && h.scrollTop || b.scrollTop) - (h.clientTop || b.clientTop || 0), | |
left: d.left + (f.pageXOffset || c.support.boxModel && h.scrollLeft || b.scrollLeft) - (h.clientLeft || b.clientLeft || 0) | |
} | |
} : function (a) { | |
var b = this[0]; | |
if (a) return this.each(function (x) { | |
c.offset.setOffset(this, a, x) | |
}); | |
if (!b || !b.ownerDocument) return null; | |
if (b === b.ownerDocument.body) return c.offset.bodyOffset(b); | |
c.offset.initialize(); | |
var d, e = b.offsetParent, | |
f = b.ownerDocument, | |
h = f.documentElement, | |
l = f.body; | |
d = (f = f.defaultView) ? f.getComputedStyle(b, null) : b.currentStyle; | |
for (var k = b.offsetTop, o = b.offsetLeft; | |
(b = b.parentNode) && b !== l && b !== h;) { | |
if (c.offset.supportsFixedPosition && d.position === "fixed") break; | |
d = f ? f.getComputedStyle(b, null) : b.currentStyle; | |
k -= b.scrollTop; | |
o -= b.scrollLeft; | |
if (b === e) { | |
k += b.offsetTop; | |
o += b.offsetLeft; | |
if (c.offset.doesNotAddBorder && !(c.offset.doesAddBorderForTableAndCells && xb.test(b.nodeName))) { | |
k += parseFloat(d.borderTopWidth) || 0; | |
o += parseFloat(d.borderLeftWidth) || 0 | |
} | |
e = b.offsetParent | |
} | |
if (c.offset.subtractsBorderForOverflowNotVisible && d.overflow !== "visible") { | |
k += parseFloat(d.borderTopWidth) || 0; | |
o += parseFloat(d.borderLeftWidth) || 0 | |
} | |
d = d | |
} | |
if (d.position === "relative" || d.position === "static") { | |
k += l.offsetTop; | |
o += l.offsetLeft | |
} | |
if (c.offset.supportsFixedPosition && d.position === "fixed") { | |
k += Math.max(h.scrollTop, l.scrollTop); | |
o += Math.max(h.scrollLeft, l.scrollLeft) | |
} | |
return { | |
top: k, | |
left: o | |
} | |
}; | |
c.offset = { | |
initialize: function () { | |
var a = t.body, | |
b = t.createElement("div"), | |
d, e, f, h = parseFloat(c.css(a, "marginTop")) || 0; | |
c.extend(b.style, { | |
position: "absolute", | |
top: 0, | |
left: 0, | |
margin: 0, | |
border: 0, | |
width: "1px", | |
height: "1px", | |
visibility: "hidden" | |
}); | |
b.innerHTML = "<div style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;'><div></div></div><table style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;' cellpadding='0' cellspacing='0'><tr><td></td></tr></table>"; | |
a.insertBefore(b, a.firstChild); | |
d = b.firstChild; | |
e = d.firstChild; | |
f = d.nextSibling.firstChild.firstChild; | |
this.doesNotAddBorder = e.offsetTop !== 5; | |
this.doesAddBorderForTableAndCells = f.offsetTop === 5; | |
e.style.position = "fixed"; | |
e.style.top = "20px"; | |
this.supportsFixedPosition = e.offsetTop === 20 || e.offsetTop === 15; | |
e.style.position = e.style.top = ""; | |
d.style.overflow = "hidden"; | |
d.style.position = "relative"; | |
this.subtractsBorderForOverflowNotVisible = e.offsetTop === -5; | |
this.doesNotIncludeMarginInBodyOffset = a.offsetTop !== h; | |
a.removeChild(b); | |
c.offset.initialize = c.noop | |
}, | |
bodyOffset: function (a) { | |
var b = a.offsetTop, | |
d = a.offsetLeft; | |
c.offset.initialize(); | |
if (c.offset.doesNotIncludeMarginInBodyOffset) { | |
b += parseFloat(c.css(a, "marginTop")) || 0; | |
d += parseFloat(c.css(a, "marginLeft")) || 0 | |
} | |
return { | |
top: b, | |
left: d | |
} | |
}, | |
setOffset: function (a, b, d) { | |
var e = c.css(a, "position"); | |
if (e === "static") a.style.position = "relative"; | |
var f = c(a), | |
h = f.offset(), | |
l = c.css(a, "top"), | |
k = c.css(a, "left"), | |
o = e === "absolute" && c.inArray("auto", [l, k]) > -1; | |
e = {}; | |
var x = {}; | |
if (o) x = f.position(); | |
l = o ? x.top : parseInt(l, 10) || 0; | |
k = o ? x.left : parseInt(k, 10) || 0; | |
if (c.isFunction(b)) b = b.call(a, d, h); | |
if (b.top != null) e.top = b.top - h.top + l; | |
if (b.left != null) e.left = b.left - h.left + k; | |
"using" in b ? b.using.call(a, e) : f.css(e) | |
} | |
}; | |
c.fn.extend({ | |
position: function () { | |
if (!this[0]) return null; | |
var a = this[0], | |
b = this.offsetParent(), | |
d = this.offset(), | |
e = Ia.test(b[0].nodeName) ? { | |
top: 0, | |
left: 0 | |
} : b.offset(); | |
d.top -= parseFloat(c.css(a, "marginTop")) || 0; | |
d.left -= parseFloat(c.css(a, "marginLeft")) || 0; | |
e.top += parseFloat(c.css(b[0], "borderTopWidth")) || 0; | |
e.left += parseFloat(c.css(b[0], "borderLeftWidth")) || 0; | |
return { | |
top: d.top - e.top, | |
left: d.left - e.left | |
} | |
}, | |
offsetParent: function () { | |
return this.map(function () { | |
for (var a = this.offsetParent || t.body; a && !Ia.test(a.nodeName) && c.css(a, "position") === "static";) a = a.offsetParent; | |
return a | |
}) | |
} | |
}); | |
c.each(["Left", "Top"], function (a, b) { | |
var d = "scroll" + b; | |
c.fn[d] = function (e) { | |
var f = this[0], | |
h; | |
if (!f) return null; | |
if (e !== B) return this.each(function () { | |
if (h = fa(this)) h.scrollTo(!a ? e : c(h).scrollLeft(), a ? e : c(h).scrollTop()); | |
else this[d] = e | |
}); | |
else return (h = fa(f)) ? "pageXOffset" in h ? h[a ? "pageYOffset" : "pageXOffset"] : c.support.boxModel && h.document.documentElement[d] || h.document.body[d] : f[d] | |
} | |
}); | |
c.each(["Height", "Width"], function (a, b) { | |
var d = b.toLowerCase(); | |
c.fn["inner" + b] = function () { | |
return this[0] ? parseFloat(c.css(this[0], d, "padding")) : null | |
}; | |
c.fn["outer" + b] = function (e) { | |
return this[0] ? parseFloat(c.css(this[0], d, e ? "margin" : "border")) : null | |
}; | |
c.fn[d] = function (e) { | |
var f = this[0]; | |
if (!f) return e == null ? null : this; | |
if (c.isFunction(e)) return this.each(function (l) { | |
var k = c(this); | |
k[d](e.call(this, l, k[d]())) | |
}); | |
if (c.isWindow(f)) return f.document.compatMode === "CSS1Compat" && f.document.documentElement["client" + b] || f.document.body["client" + b]; | |
else if (f.nodeType === 9) return Math.max(f.documentElement["client" + b], f.body["scroll" + b], f.documentElement["scroll" + b], f.body["offset" + b], f.documentElement["offset" + b]); | |
else if (e === B) { | |
f = c.css(f, d); | |
var h = parseFloat(f); | |
return c.isNaN(h) ? f : h | |
} else return this.css(d, typeof e === "string" ? e : e + "px") | |
} | |
}) | |
})(window); | |
jQuery.cookie = function (name, value, options) { | |
if (typeof value != 'undefined') { | |
options = options || {}; | |
if (value === null) { | |
value = ''; | |
options.expires = -1; | |
} | |
var expires = ''; | |
if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) { | |
var date; | |
if (typeof options.expires == 'number') { | |
date = new Date(); | |
date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000)); | |
} else { | |
date = options.expires; | |
} | |
expires = '; expires=' + date.toUTCString(); | |
} | |
var path = options.path ? '; path=' + (options.path) : ''; | |
var domain = options.domain ? '; domain=' + (options.domain) : ''; | |
var secure = options.secure ? '; secure' : ''; | |
document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join(''); | |
} else { | |
var cookieValue = null; | |
if (document.cookie && document.cookie != '') { | |
var cookies = document.cookie.split(';'); | |
for (var i = 0; i < cookies.length; i++) { | |
var cookie = jQuery.trim(cookies[i]); | |
if (cookie.substring(0, name.length + 1) == (name + '=')) { | |
cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); | |
break; | |
} | |
} | |
} | |
return cookieValue; | |
} | |
};; | |
(function ($) { | |
$.fn.equalHeight = function (options) { | |
var opts = $.extend({}, $.fn.equalHeight.defaults, options); | |
return this.each(function () { | |
var $this = $(this), | |
o = $.meta ? $.extend({}, opts, $this.data()) : opts, | |
maxHeight = 0; | |
$this.find(o.find).each(function () { | |
var elemHeight = $(this).height(); | |
maxHeight = (elemHeight > maxHeight) ? elemHeight : maxHeight; | |
}).height(maxHeight); | |
}); | |
}; | |
$.fn.equalHeight.defaults = { | |
find: 'li' | |
}; | |
})(jQuery); | |
(function ($) { | |
$.InFieldLabels = function (label, field, options) { | |
var base = this; | |
base.$label = $(label); | |
base.$field = $(field); | |
base.$label.data("InFieldLabels", base); | |
base.showing = true; | |
base.init = function () { | |
base.options = $.extend({}, $.InFieldLabels.defaultOptions, options); | |
base.$label.css('position', 'absolute'); | |
base.fieldPosition = base.$field.position(); | |
base.$label.css({ | |
'left': base.fieldPosition.left, | |
'top': (base.fieldPosition.top < 0) ? 0 : base.fieldPosition.top | |
}).addClass(base.options.labelClass); | |
if (base.$field.val() != "") { | |
base.$label.hide(); | |
base.showing = false; | |
}; | |
base.$field.focus(function () { | |
base.fadeOnFocus(); | |
}).blur(function () { | |
base.checkForEmpty(true); | |
}).bind('keydown.infieldlabel', function (e) { | |
base.hideOnChange(e); | |
}).change(function (e) { | |
base.checkForEmpty(); | |
}).bind('onPropertyChange', function () { | |
base.checkForEmpty(); | |
}); | |
}; | |
base.fadeOnFocus = function () { | |
if (base.showing) { | |
base.setOpacity(base.options.fadeOpacity); | |
}; | |
}; | |
base.setOpacity = function (opacity) { | |
base.$label.stop().animate({ | |
opacity: opacity | |
}, base.options.fadeDuration); | |
base.showing = (opacity > 0.0); | |
}; | |
base.checkForEmpty = function (blur) { | |
if (base.$field.val() == "") { | |
base.prepForShow(); | |
base.setOpacity(blur ? 1.0 : base.options.fadeOpacity); | |
} else { | |
base.setOpacity(0.0); | |
}; | |
}; | |
base.prepForShow = function (e) { | |
if (!base.showing) { | |
base.$label.css({ | |
opacity: 0.0 | |
}).show(); | |
base.$field.bind('keydown.infieldlabel', function (e) { | |
base.hideOnChange(e); | |
}); | |
}; | |
}; | |
base.hideOnChange = function (e) { | |
if ((e.keyCode == 16) || (e.keyCode == 9)) return; | |
if (base.showing) { | |
base.$label.hide(); | |
base.showing = false; | |
}; | |
base.$field.unbind('keydown.infieldlabel'); | |
}; | |
base.init(); | |
}; | |
$.InFieldLabels.defaultOptions = { | |
fadeOpacity: 0.5, | |
fadeDuration: 300, | |
labelClass: 'infield' | |
}; | |
$.fn.inFieldLabels = function (options) { | |
return this.each(function () { | |
var for_attr = $(this).attr('for'); | |
if (!for_attr) return; | |
var $field = $("input#" + for_attr + "[type='text']," + "input#" + for_attr + "[type='password']," + "textarea#" + for_attr); | |
if ($field.length == 0) return; | |
(new $.InFieldLabels(this, $field[0], options)); | |
}); | |
}; | |
})(jQuery); | |
(function ($) { | |
$.jScrollPane = { | |
active: [] | |
}; | |
$.fn.jScrollPane = function (settings) { | |
settings = $.extend({}, $.fn.jScrollPane.defaults, settings); | |
var rf = function () { | |
return false; | |
}; | |
return this.each(function () { | |
var $this = $(this); | |
var paneEle = this; | |
var currentScrollPosition = 0; | |
var paneWidth; | |
var paneHeight; | |
var trackHeight; | |
var trackOffset = settings.topCapHeight; | |
var $container; | |
if ($(this).parent().is('.jScrollPaneContainer')) { | |
$container = $(this).parent(); | |
currentScrollPosition = settings.maintainPosition ? $this.position().top : 0; | |
var $c = $(this).parent(); | |
paneWidth = $c.innerWidth(); | |
paneHeight = $c.outerHeight(); | |
$('>.jScrollPaneTrack, >.jScrollArrowUp, >.jScrollArrowDown, >.jScrollCap', $c).remove(); | |
$this.css({ | |
'top': 0 | |
}); | |
} else { | |
$this.data('originalStyleTag', $this.attr('style')); | |
$this.css('overflow', 'hidden'); | |
this.originalPadding = $this.css('paddingTop') + ' ' + $this.css('paddingRight') + ' ' + $this.css('paddingBottom') + ' ' + $this.css('paddingLeft'); | |
this.originalSidePaddingTotal = (parseInt($this.css('paddingLeft')) || 0) + (parseInt($this.css('paddingRight')) || 0); | |
paneWidth = $this.innerWidth(); | |
paneHeight = $this.innerHeight(); | |
$container = $('<div></div>').attr({ | |
'className': 'jScrollPaneContainer' | |
}).css({ | |
'height': paneHeight + 'px', | |
'width': paneWidth + 'px' | |
}); | |
if (settings.enableKeyboardNavigation) { | |
$container.attr('tabindex', settings.tabIndex); | |
} | |
$this.wrap($container); | |
$container = $this.parent(); | |
$(document).bind('emchange', function (e, cur, prev) { | |
$this.jScrollPane(settings); | |
}); | |
} | |
trackHeight = paneHeight; | |
if (settings.reinitialiseOnImageLoad) { | |
var $imagesToLoad = $.data(paneEle, 'jScrollPaneImagesToLoad') || $('img', $this); | |
var loadedImages = []; | |
if ($imagesToLoad.length) { | |
$imagesToLoad.each(function (i, val) { | |
$(this).bind('load readystatechange', function () { | |
if ($.inArray(i, loadedImages) == -1) { | |
loadedImages.push(val); | |
$imagesToLoad = $.grep($imagesToLoad, function (n, i) { | |
return n != val; | |
}); | |
$.data(paneEle, 'jScrollPaneImagesToLoad', $imagesToLoad); | |
var s2 = $.extend(settings, { | |
reinitialiseOnImageLoad: false | |
}); | |
$this.jScrollPane(s2); | |
} | |
}).each(function (i, val) { | |
if (this.complete || this.complete === undefined) { | |
this.src = this.src; | |
} | |
}); | |
}); | |
}; | |
} | |
var p = this.originalSidePaddingTotal; | |
var realPaneWidth = paneWidth - settings.scrollbarWidth - settings.scrollbarMargin - p; | |
var cssToApply = { | |
'height': 'auto', | |
'width': realPaneWidth + 'px' | |
} | |
if (settings.scrollbarOnLeft) { | |
cssToApply.paddingLeft = settings.scrollbarMargin + settings.scrollbarWidth + 'px'; | |
} else { | |
cssToApply.paddingRight = settings.scrollbarMargin + 'px'; | |
} | |
$this.css(cssToApply); | |
var contentHeight = $this.outerHeight(); | |
var percentInView = paneHeight / contentHeight; | |
var isScrollable = percentInView < .99; | |
$container[isScrollable ? 'addClass' : 'removeClass']('jScrollPaneScrollable'); | |
if (isScrollable) { | |
$container.append($('<div></div>').addClass('jScrollCap jScrollCapTop').css({ | |
height: settings.topCapHeight | |
}), $('<div></div>').attr({ | |
'className': 'jScrollPaneTrack' | |
}).css({ | |
'width': settings.scrollbarWidth + 'px' | |
}).append($('<div></div>').attr({ | |
'className': 'jScrollPaneDrag' | |
}).css({ | |
'width': settings.scrollbarWidth + 'px' | |
}).append($('<div></div>').attr({ | |
'className': 'jScrollPaneDragTop' | |
}).css({ | |
'width': settings.scrollbarWidth + 'px' | |
}), $('<div></div>').attr({ | |
'className': 'jScrollPaneDragBottom' | |
}).css({ | |
'width': settings.scrollbarWidth + 'px' | |
}))), $('<div></div>').addClass('jScrollCap jScrollCapBottom').css({ | |
height: settings.bottomCapHeight | |
})); | |
var $track = $('>.jScrollPaneTrack', $container); | |
var $drag = $('>.jScrollPaneTrack .jScrollPaneDrag', $container); | |
var currentArrowDirection; | |
var currentArrowTimerArr = []; | |
var currentArrowInc; | |
var whileArrowButtonDown = function () { | |
if (currentArrowInc > 4 || currentArrowInc % 4 == 0) { | |
positionDrag(dragPosition + currentArrowDirection * mouseWheelMultiplier); | |
} | |
currentArrowInc++; | |
}; | |
if (settings.enableKeyboardNavigation) { | |
$container.bind('keydown.jscrollpane', function (e) { | |
switch (e.keyCode) { | |
case 38: | |
currentArrowDirection = -1; | |
currentArrowInc = 0; | |
whileArrowButtonDown(); | |
currentArrowTimerArr[currentArrowTimerArr.length] = setInterval(whileArrowButtonDown, 100); | |
return false; | |
case 40: | |
currentArrowDirection = 1; | |
currentArrowInc = 0; | |
whileArrowButtonDown(); | |
currentArrowTimerArr[currentArrowTimerArr.length] = setInterval(whileArrowButtonDown, 100); | |
return false; | |
case 33: | |
case 34: | |
return false; | |
default: | |
} | |
}).bind('keyup.jscrollpane', function (e) { | |
if (e.keyCode == 38 || e.keyCode == 40) { | |
for (var i = 0; i < currentArrowTimerArr.length; i++) { | |
clearInterval(currentArrowTimerArr[i]); | |
} | |
return false; | |
} | |
}); | |
} | |
if (settings.showArrows) { | |
var currentArrowButton; | |
var currentArrowInterval; | |
var onArrowMouseUp = function (event) { | |
$('html').unbind('mouseup', onArrowMouseUp); | |
currentArrowButton.removeClass('jScrollActiveArrowButton'); | |
clearInterval(currentArrowInterval); | |
}; | |
var onArrowMouseDown = function () { | |
$('html').bind('mouseup', onArrowMouseUp); | |
currentArrowButton.addClass('jScrollActiveArrowButton'); | |
currentArrowInc = 0; | |
whileArrowButtonDown(); | |
currentArrowInterval = setInterval(whileArrowButtonDown, 100); | |
}; | |
$container.append($('<a></a>').attr({ | |
'href': 'javascript:;', | |
'className': 'jScrollArrowUp', | |
'tabindex': -1 | |
}).css({ | |
'width': settings.scrollbarWidth + 'px', | |
'top': settings.topCapHeight + 'px' | |
}).html('Scroll up').bind('mousedown', function () { | |
currentArrowButton = $(this); | |
currentArrowDirection = -1; | |
onArrowMouseDown(); | |
this.blur(); | |
return false; | |
}).bind('click', rf), $('<a></a>').attr({ | |
'href': 'javascript:;', | |
'className': 'jScrollArrowDown', | |
'tabindex': -1 | |
}).css({ | |
'width': settings.scrollbarWidth + 'px', | |
'bottom': settings.bottomCapHeight + 'px' | |
}).html('Scroll down').bind('mousedown', function () { | |
currentArrowButton = $(this); | |
currentArrowDirection = 1; | |
onArrowMouseDown(); | |
this.blur(); | |
return false; | |
}).bind('click', rf)); | |
var $upArrow = $('>.jScrollArrowUp', $container); | |
var $downArrow = $('>.jScrollArrowDown', $container); | |
} | |
if (settings.arrowSize) { | |
trackHeight = paneHeight - settings.arrowSize - settings.arrowSize; | |
trackOffset += settings.arrowSize; | |
} else if ($upArrow) { | |
var topArrowHeight = $upArrow.height(); | |
settings.arrowSize = topArrowHeight; | |
trackHeight = paneHeight - topArrowHeight - $downArrow.height(); | |
trackOffset += topArrowHeight; | |
} | |
trackHeight -= settings.topCapHeight + settings.bottomCapHeight; | |
$track.css({ | |
'height': trackHeight + 'px', | |
top: trackOffset + 'px' | |
}) | |
var $pane = $(this).css({ | |
'position': 'absolute', | |
'overflow': 'visible' | |
}); | |
var currentOffset; | |
var maxY; | |
var mouseWheelMultiplier; | |
var dragPosition = 0; | |
var dragMiddle = percentInView * paneHeight / 2; | |
var getPos = function (event, c) { | |
var p = c == 'X' ? 'Left' : 'Top'; | |
return event['page' + c] || (event['client' + c] + (document.documentElement['scroll' + p] || document.body['scroll' + p])) || 0; | |
}; | |
var ignoreNativeDrag = function () { | |
return false; | |
}; | |
var initDrag = function () { | |
ceaseAnimation(); | |
currentOffset = $drag.offset(false); | |
currentOffset.top -= dragPosition; | |
maxY = trackHeight - $drag[0].offsetHeight; | |
mouseWheelMultiplier = 2 * settings.wheelSpeed * maxY / contentHeight; | |
}; | |
var onStartDrag = function (event) { | |
initDrag(); | |
dragMiddle = getPos(event, 'Y') - dragPosition - currentOffset.top; | |
$('html').bind('mouseup', onStopDrag).bind('mousemove', updateScroll); | |
if ($.browser.msie) { | |
$('html').bind('dragstart', ignoreNativeDrag).bind('selectstart', ignoreNativeDrag); | |
} | |
return false; | |
}; | |
var onStopDrag = function () { | |
$('html').unbind('mouseup', onStopDrag).unbind('mousemove', updateScroll); | |
dragMiddle = percentInView * paneHeight / 2; | |
if ($.browser.msie) { | |
$('html').unbind('dragstart', ignoreNativeDrag).unbind('selectstart', ignoreNativeDrag); | |
} | |
}; | |
var positionDrag = function (destY) { | |
$container.scrollTop(0); | |
destY = destY < 0 ? 0 : (destY > maxY ? maxY : destY); | |
dragPosition = destY; | |
$drag.css({ | |
'top': destY + 'px' | |
}); | |
var p = destY / maxY; | |
$this.data('jScrollPanePosition', (paneHeight - contentHeight) * -p); | |
$pane.css({ | |
'top': ((paneHeight - contentHeight) * p) + 'px' | |
}); | |
$this.trigger('scroll'); | |
if (settings.showArrows) { | |
$upArrow[destY == 0 ? 'addClass' : 'removeClass']('disabled'); | |
$downArrow[destY == maxY ? 'addClass' : 'removeClass']('disabled'); | |
} | |
}; | |
var updateScroll = function (e) { | |
positionDrag(getPos(e, 'Y') - currentOffset.top - dragMiddle); | |
}; | |
var dragH = Math.max(Math.min(percentInView * (paneHeight - settings.arrowSize * 2), settings.dragMaxHeight), settings.dragMinHeight); | |
$drag.css({ | |
'height': dragH + 'px' | |
}).bind('mousedown', onStartDrag); | |
var trackScrollInterval; | |
var trackScrollInc; | |
var trackScrollMousePos; | |
var doTrackScroll = function () { | |
if (trackScrollInc > 8 || trackScrollInc % 4 == 0) { | |
positionDrag((dragPosition - ((dragPosition - trackScrollMousePos) / 2))); | |
} | |
trackScrollInc++; | |
}; | |
var onStopTrackClick = function () { | |
clearInterval(trackScrollInterval); | |
$('html').unbind('mouseup', onStopTrackClick).unbind('mousemove', onTrackMouseMove); | |
}; | |
var onTrackMouseMove = function (event) { | |
trackScrollMousePos = getPos(event, 'Y') - currentOffset.top - dragMiddle; | |
}; | |
var onTrackClick = function (event) { | |
initDrag(); | |
onTrackMouseMove(event); | |
trackScrollInc = 0; | |
$('html').bind('mouseup', onStopTrackClick).bind('mousemove', onTrackMouseMove); | |
trackScrollInterval = setInterval(doTrackScroll, 100); | |
doTrackScroll(); | |
return false; | |
}; | |
$track.bind('mousedown', onTrackClick); | |
$container.bind('mousewheel', function (event, delta) { | |
delta = delta || (event.wheelDelta ? event.wheelDelta / 120 : (event.detail) ? -event.detail / 3 : 0); | |
initDrag(); | |
ceaseAnimation(); | |
var d = dragPosition; | |
positionDrag(dragPosition - delta * mouseWheelMultiplier); | |
var dragOccured = d != dragPosition; | |
return !dragOccured; | |
}); | |
var _animateToPosition; | |
var _animateToInterval; | |
function animateToPosition() { | |
var diff = (_animateToPosition - dragPosition) / settings.animateStep; | |
if (diff > 1 || diff < -1) { | |
positionDrag(dragPosition + diff); | |
} else { | |
positionDrag(_animateToPosition); | |
ceaseAnimation(); | |
} | |
} | |
var ceaseAnimation = function () { | |
if (_animateToInterval) { | |
clearInterval(_animateToInterval); | |
delete _animateToPosition; | |
} | |
}; | |
var scrollTo = function (pos, preventAni) { | |
if (typeof pos == "string") { | |
try { | |
$e = $(pos, $this); | |
} catch (err) { | |
return; | |
} | |
if (!$e.length) return; | |
pos = $e.offset().top - $this.offset().top; | |
} | |
ceaseAnimation(); | |
var maxScroll = contentHeight - paneHeight; | |
pos = pos > maxScroll ? maxScroll : pos; | |
$this.data('jScrollPaneMaxScroll', maxScroll); | |
var destDragPosition = pos / maxScroll * maxY; | |
if (preventAni || !settings.animateTo) { | |
positionDrag(destDragPosition); | |
} else { | |
$container.scrollTop(0); | |
_animateToPosition = destDragPosition; | |
_animateToInterval = setInterval(animateToPosition, settings.animateInterval); | |
} | |
}; | |
$this[0].scrollTo = scrollTo; | |
$this[0].scrollBy = function (delta) { | |
var currentPos = -parseInt($pane.css('top')) || 0; | |
scrollTo(currentPos + delta); | |
}; | |
initDrag(); | |
scrollTo(-currentScrollPosition, true); | |
$('*', this).bind('focus', function (event) { | |
var $e = $(this); | |
var eleTop = 0; | |
while ($e[0] != $this[0]) { | |
eleTop += $e.position().top; | |
$e = $e.offsetParent(); | |
} | |
var viewportTop = -parseInt($pane.css('top')) || 0; | |
var maxVisibleEleTop = viewportTop + paneHeight; | |
var eleInView = eleTop > viewportTop && eleTop < maxVisibleEleTop; | |
if (!eleInView) { | |
var destPos = eleTop - settings.scrollbarMargin; | |
if (eleTop > viewportTop) { | |
destPos += $(this).height() + 15 + settings.scrollbarMargin - paneHeight; | |
} | |
scrollTo(destPos); | |
} | |
}) | |
if (settings.observeHash) { | |
if (location.hash && location.hash.length > 1) { | |
setTimeout(function () { | |
scrollTo(location.hash); | |
}, $.browser.safari ? 100 : 0); | |
} | |
$(document).bind('click', function (e) { | |
$target = $(e.target); | |
if ($target.is('a')) { | |
var h = $target.attr('href'); | |
if (h && h.substr(0, 1) == '#' && h.length > 1) { | |
setTimeout(function () { | |
scrollTo(h, !settings.animateToInternalLinks); | |
}, $.browser.safari ? 100 : 0); | |
} | |
} | |
}); | |
} | |
function onSelectScrollMouseDown(e) { | |
$(document).bind('mousemove.jScrollPaneDragging', onTextSelectionScrollMouseMove); | |
$(document).bind('mouseup.jScrollPaneDragging', onSelectScrollMouseUp); | |
} | |
var textDragDistanceAway; | |
var textSelectionInterval; | |
function onTextSelectionInterval() { | |
direction = textDragDistanceAway < 0 ? -1 : 1; | |
$this[0].scrollBy(textDragDistanceAway / 2); | |
} | |
function clearTextSelectionInterval() { | |
if (textSelectionInterval) { | |
clearInterval(textSelectionInterval); | |
textSelectionInterval = undefined; | |
} | |
} | |
function onTextSelectionScrollMouseMove(e) { | |
var offset = $this.parent().offset().top; | |
var maxOffset = offset + paneHeight; | |
var mouseOffset = getPos(e, 'Y'); | |
textDragDistanceAway = mouseOffset < offset ? mouseOffset - offset : (mouseOffset > maxOffset ? mouseOffset - maxOffset : 0); | |
if (textDragDistanceAway == 0) { | |
clearTextSelectionInterval(); | |
} else { | |
if (!textSelectionInterval) { | |
textSelectionInterval = setInterval(onTextSelectionInterval, 100); | |
} | |
} | |
} | |
function onSelectScrollMouseUp(e) { | |
$(document).unbind('mousemove.jScrollPaneDragging').unbind('mouseup.jScrollPaneDragging'); | |
clearTextSelectionInterval(); | |
} | |
$container.bind('mousedown.jScrollPane', onSelectScrollMouseDown); | |
$.jScrollPane.active.push($this[0]); | |
} else { | |
$this.css({ | |
'height': paneHeight + 'px', | |
'width': paneWidth - this.originalSidePaddingTotal + 'px', | |
'padding': this.originalPadding | |
}); | |
$this[0].scrollTo = $this[0].scrollBy = function () {}; | |
$this.parent().unbind('mousewheel').unbind('mousedown.jScrollPane').unbind('keydown.jscrollpane').unbind('keyup.jscrollpane'); | |
} | |
}) | |
}; | |
$.fn.jScrollPaneRemove = function () { | |
$(this).each(function () { | |
$this = $(this); | |
var $c = $this.parent(); | |
if ($c.is('.jScrollPaneContainer')) { | |
$this.css({ | |
'top': '', | |
'height': '', | |
'width': '', | |
'padding': '', | |
'overflow': '', | |
'position': '' | |
}); | |
$this.attr('style', $this.data('originalStyleTag')); | |
$c.after($this).remove(); | |
} | |
}); | |
} | |
$.fn.jScrollPane.defaults = { | |
scrollbarWidth: 10, | |
scrollbarMargin: 5, | |
wheelSpeed: 18, | |
showArrows: false, | |
arrowSize: 0, | |
animateTo: false, | |
dragMinHeight: 1, | |
dragMaxHeight: 99999, | |
animateInterval: 100, | |
animateStep: 3, | |
maintainPosition: true, | |
scrollbarOnLeft: false, | |
reinitialiseOnImageLoad: false, | |
tabIndex: 0, | |
enableKeyboardNavigation: true, | |
animateToInternalLinks: false, | |
topCapHeight: 0, | |
bottomCapHeight: 0, | |
observeHash: true | |
}; | |
$(window).bind('unload', function () { | |
var els = $.jScrollPane.active; | |
for (var i = 0; i < els.length; i++) { | |
els[i].scrollTo = els[i].scrollBy = null; | |
} | |
}); | |
})(jQuery); | |
(function ($) { | |
$.fn.scroller = function () { | |
$(this).each(function () { | |
var $this = $(this), | |
$scrollNav = $this.parents('.section').filter(':first').find('.nav-scroller'), | |
$pagerNav = $this.parents('.section').filter(':first').find('.nav-pager'), | |
scrollOffset = 0, | |
containerAddWidth = 0, | |
containerDimension, containerWidth, itemDimension, itemWidth, numItems, numPerRow, numToShow, frames; | |
if ($this.attr('data-scroll-offset')) { | |
scrollOffset = parseInt($this.attr('data-scroll-offset'), 10); | |
} | |
if ($this.attr('data-container-addwidth')) { | |
containerAddWidth = parseInt($this.attr('data-container-addwidth'), 10); | |
} | |
if ($this.hasClass('vertical')) { | |
containerDimension = $this.parent().height() + scrollOffset; | |
containerWidth = $this.parent().width(); | |
itemDimension = $this.children().outerHeight(); | |
itemWidth = $this.children().outerWidth(); | |
numItems = $this.children().length; | |
numPerRow = Math.floor(containerWidth / itemWidth); | |
numToShow = (Math.floor(containerDimension / itemDimension) * numPerRow) || 1; | |
frames = Math.ceil(numItems / numToShow); | |
$this.height((itemDimension * numItems / numPerRow)); | |
} else { | |
containerDimension = $this.parent().width() + scrollOffset; | |
itemDimension = $this.children().outerWidth(); | |
numItems = $this.children().length; | |
numToShow = Math.floor(containerDimension / itemDimension) || 1; | |
frames = Math.ceil(numItems / numToShow); | |
if ((scrollOffset !== 0) && ((numItems - (Math.floor(numItems / numToShow) * numToShow)) === 1)) { | |
frames = frames - 1; | |
} | |
$this.width((containerDimension * frames) + containerAddWidth); | |
} | |
if ($scrollNav.children('.current').length > 0) { | |
$scrollNav.children('.current').text($this.children('li:eq(' + count + ')').attr('title')); | |
} | |
$this.data('count', 0); | |
$scrollNav.find('a').click(function (e) { | |
var $link = $(this), | |
count = $this.data('count'); | |
$link.addClass('no-outline'); | |
var action = $link.parent().attr('class'); | |
if (action === 'prev') { | |
if (count > 0) { | |
count--; | |
} else { | |
count = frames - 1; | |
} | |
} else if (action === 'next') { | |
if (count < (frames - 1)) { | |
count++; | |
} else { | |
count = 0; | |
} | |
} | |
$this.data('count', count); | |
var moveTo = containerDimension * count; | |
if ($this.hasClass('vertical')) { | |
$this.animate({ | |
top: '-' + moveTo | |
}, 600, function () { | |
$link.trigger("animation-finished"); | |
}); | |
} else { | |
$this.animate({ | |
left: '-' + moveTo | |
}, 600, function () { | |
$link.trigger("animation-finished"); | |
}); | |
} | |
if ($pagerNav.length > 0) { | |
$pagerNav.children('.current').removeClass('current'); | |
$pagerNav.children('li:eq(' + count + ')').addClass('current'); | |
} | |
if ($scrollNav.children('.current').length > 0) { | |
if ($this.children('li:eq(' + count + ')').attr('title') !== "") { | |
$scrollNav.children('.current').text($this.children('li:eq(' + count + ')').attr('title')); | |
} | |
} | |
e.preventDefault(); | |
}); | |
if ($pagerNav.length > 0) { | |
$pagerNav.children().children('a').click(function (e) { | |
var $link = $(this); | |
$link.addClass('no-outline'); | |
var $pagerParent = $(this).parent(); | |
if (!$pagerParent.hasClass('current')) { | |
count = $pagerParent.prevAll().length; | |
var moveTo = containerDimension * count; | |
if ($this.hasClass('vertical')) { | |
$this.animate({ | |
top: '-' + moveTo | |
}, 600, function () { | |
$link.trigger("animation-finished"); | |
}); | |
} else { | |
$this.animate({ | |
left: '-' + moveTo | |
}, 600, function () { | |
$link.trigger("animation-finished"); | |
}); | |
} | |
$pagerNav.children('.current').removeClass('current'); | |
$pagerParent.addClass('current'); | |
$this.data('count', count); | |
} | |
e.preventDefault(); | |
}); | |
} | |
}); | |
return $(this); | |
}; | |
})(jQuery); | |
(function ($) { | |
$.fn.tabs = function (options) { | |
var opts = $.extend({ | |
callback: '' | |
}, options); | |
$(this).each(function () { | |
var $this = $(this), | |
$current = $this.children('.current'), | |
indicatorPos = getIndicatorPos($current), | |
$tabs = $this.closest('.section').find('.tabs:first'), | |
startIndex = $this.find('.current').prevAll().length; | |
$tabs.find('.tab').eq(startIndex).addClass('current').siblings().removeClass('current').addClass('hide'); | |
$this.after('<span class="indicator" style="left:' + indicatorPos + 'px;"></span>'); | |
$this.children().children('a').click(function (e) { | |
var $link = $(this), | |
$par = $link.parent(); | |
$link.addClass('no-outline'); | |
if (!$par.hasClass('current')) { | |
var $tabNav = $par.parent(), | |
$indicator = $tabNav.siblings('.indicator'), | |
indicatorPos = getIndicatorPos($par), | |
newIndex = $par.prevAll().length; | |
$tabNav.children('.current').removeClass('current'); | |
$par.addClass('current'); | |
$tabs.find('div.current').eq(0).removeClass('current').fadeOut(250, function () { | |
$tabs.find('div.tab:eq(' + newIndex + ')').eq(0).fadeIn(250, function () { | |
$(this).addClass('current'); | |
if (opts.callback != '') { | |
opts.callback(); | |
} | |
}); | |
}); | |
$indicator.animate({ | |
left: indicatorPos | |
}, 500, 'easeOutExpo', function () { | |
$link.trigger("animation-finished"); | |
}); | |
} | |
e.preventDefault(); | |
}); | |
}); | |
return $(this); | |
}; | |
})(jQuery);; | |
(function ($) { | |
$.fn.popup = function (options) { | |
var opts = $.extend({}, $.fn.popup.defaults, options); | |
return this.each(function () { | |
var $this = $(this), | |
o = $.meta ? $.extend({}, opts, $this.data()) : opts, | |
urlParts = $this.attr('href').split('#'), | |
popupElem = (urlParts[1]) ? '#' + urlParts[1] : urlParts[0], | |
$overlay = $('#popup-overlay'), | |
windowHeight = $(document).height(), | |
internalLink = (urlParts[1]) ? true : false; | |
$this.bind('click', function (e) { | |
if (!$overlay.length) { | |
$('<div/>', { | |
css: { | |
display: 'none', | |
height: windowHeight, | |
left: 0, | |
opacity: o.overlayOpacity, | |
position: 'absolute', | |
top: 0, | |
width: '100%' | |
}, | |
id: 'popup-overlay', | |
click: function () { | |
close(); | |
} | |
}).appendTo('body'); | |
} | |
$('<div/>', { | |
id: 'popup' | |
}).appendTo('body'); | |
$('<a/>', { | |
id: 'popup-close', | |
click: function (e) { | |
close(); | |
e.preventDefault(); | |
}, | |
href: '#', | |
text: 'Close' | |
}).prependTo('#popup'); | |
if (internalLink) { | |
$(popupElem).clone(true).appendTo('#popup'); | |
$('#popup').find(popupElem).show(); | |
$('#popup-overlay').fadeIn(500); | |
$('#popup').css('top', $(document).scrollTop() + 40).fadeIn(); | |
} else { | |
$('#popup-overlay').fadeIn(500); | |
$('#popup').load(popupElem, function () { | |
$('#popup').css('top', $(document).scrollTop() + 40).fadeIn(); | |
}); | |
} | |
if (o.open) { | |
o.open(); | |
} | |
e.preventDefault(); | |
}); | |
var close = function () { | |
$('#popup, #popup-overlay').fadeOut(500); | |
$('#popup').remove(); | |
if (o.close) { | |
o.close(); | |
} | |
}; | |
}); | |
}; | |
$.fn.popup.defaults = { | |
overlayOpacity: '0.8', | |
open: '', | |
close: '' | |
}; | |
})(jQuery); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _self = PUMA.ga = { | |
init: function () { | |
_self.$base = $('body'); | |
_self.bindEvents(); | |
}, | |
bindEvents: function () { | |
_self.$base.delegate('a[data-track-event], button[data-track-event], li[data-track-event], input[data-track-event], label[data-track-event], div[data-track-event], span[data-track-event], dt[data-track-event]', 'click', _self.basicTrack); | |
_self.$base.delegate('select[data-track-event]', 'change', _self.basicTrack); | |
_self.$base.delegate('form[data-track-event]', 'submit', _self.basicTrack); | |
_self.$base.delegate('a[data-track-delay]', 'click', _self.trackDelay); | |
_self.$base.delegate('form[data-track-delay]', 'submit', _self.formTrackDelay); | |
_self.$base.delegate('a[data-track-social]', 'click', _self.trackSocial); | |
}, | |
basicTrack: function () { | |
var track_array = $(this).attr('data-track-event').split(','); | |
_self.trackEvent(track_array); | |
}, | |
formTrackDelay: function (e) { | |
e.preventDefault(); | |
var $this = $(this), | |
track_array = $this.attr('data-track-delay').split(','); | |
_self.trackEvent(track_array); | |
setTimeout(function () { | |
_self.$base.undelegate('form[data-track-delay]', 'submit'); | |
$this.trigger('submit'); | |
}, 100); | |
}, | |
push: function (eventArray) { | |
if (typeof (_gaq) !== 'undefined') { | |
_gaq.push(eventArray); | |
} | |
}, | |
reset_utmb: function () { | |
_self.utmb = $.cookie("__utmb"); | |
if (_self.utmb) { | |
_self.utmb = _self.utmb.match(/(\d+\.\d+\.)\d+(.*)/); | |
$.cookie("__utmb", _self.utmb[1] + "10" + _self.utmb[2], { | |
domain: ".puma.com" | |
}); | |
} | |
}, | |
stripDomain: function (url) { | |
return url.split("/").slice(3).join("/"); | |
}, | |
trackDelay: function (e) { | |
e.preventDefault(); | |
var $this = $(this), | |
track_array = $this.attr('data-track-delay').split(','), | |
redirectTo = $this.attr('href'); | |
_self.trackEvent(track_array); | |
setTimeout(function () { | |
document.location = redirectTo; | |
}, 100); | |
}, | |
trackEvent: function (track_array) { | |
var opt_int_value = track_array[3] === '' || track_array[3] === undefined ? 0 : parseInt(track_array[3], 10); | |
_self.push(['_trackEvent', track_array[0], track_array[1], track_array[2], opt_int_value]); | |
_self.push(['t2._trackEvent', track_array[0], track_array[1], track_array[2], opt_int_value]); | |
_self.reset_utmb(); | |
}, | |
trackSocial: function (track_array) { | |
track_array = track_array || $(this).attr('data-track-social').split(','); | |
_self.push(['_trackSocial', track_array[0], track_array[1], track_array[2]]); | |
_self.push(['t2._trackSocial', track_array[0], track_array[1], track_array[2]]); | |
}, | |
facebook: { | |
like: function (targetUrl) { | |
_self.push(['_trackSocial', 'Facebook', 'Like', _self.stripDomain(targetUrl)]); | |
_self.push(['t2._trackSocial', 'Facebook', 'Like', _self.stripDomain(targetUrl)]); | |
var activityTitle = window.modalTitle ? window.modalTitle : document.title, | |
activityURL = window.modalURL ? window.modalURL : window.location.href; | |
$.post('/social/activities', { | |
title: activityTitle, | |
service: "facebook-like-button", | |
url: activityURL | |
}); | |
}, | |
unlike: function (targetUrl) { | |
_self.push(['_trackSocial', 'Facebook', 'Unlike', _self.stripDomain(targetUrl)]); | |
_self.push(['t2._trackSocial', 'Facebook', 'Unlike', _self.stripDomain(targetUrl)]); | |
} | |
} | |
}; | |
_self.init(); | |
})(); | |
var PUMA = PUMA || {}; | |
(function (d) { | |
var js, id = 'facebook-jssdk', | |
ref = d.getElementsByTagName('script')[0]; | |
if (d.getElementById(id)) { | |
return; | |
} | |
js = d.createElement('script'); | |
js.id = id; | |
js.async = true; | |
js.src = "//connect.facebook.net/en_US/all.js"; | |
ref.parentNode.insertBefore(js, ref); | |
}(document)); | |
PUMA.facebookInit = function () { | |
var channelUrl = 'http://' + window.location.host + '/fb-channel'; | |
FB.init({ | |
appId: '112969085424441', | |
channelUrl: channelUrl, | |
status: true, | |
cookie: true, | |
xfbml: true | |
}); | |
FB.Event.subscribe('edge.create', PUMA.ga.facebook.like); | |
FB.Event.subscribe('edge.remove', PUMA.ga.facebook.unlike); | |
}; | |
window.fbAsyncInit = function () { | |
PUMA.facebookInit(); | |
}; | |
var PUMA = PUMA || {}; | |
PUMA.nav = { | |
init: function () { | |
$('#puma-global-header-nav').find('li:not(.no-sub)').hover(PUMA.nav.hoverIn, PUMA.nav.hoverOut); | |
}, | |
hoverIn: function (e) { | |
$(this).addClass('active').children('.nav-sub').fadeIn(150); | |
}, | |
hoverOut: function (e) { | |
$(this).removeClass('active').children('.nav-sub').fadeOut(150); | |
} | |
}; | |
var PUMA = PUMA || {}; | |
var setCryptData = function (data) { | |
cryptData = data.crypto_key; | |
}; | |
PUMA.globalNav = function (upbUrl, callback) { | |
var activateGlobalNav = function () { | |
var $globalNav = $('#puma-global-upb'), | |
$signIn = $globalNav.find('div.sign-in'), | |
$signInHelp = $globalNav.find('div.sign-in-help'), | |
$createAccount = $globalNav.find('div.create-account'), | |
createAccountHeight = $createAccount.find('.columns').height(), | |
signInHeight = $signIn.find('.columns').height(); | |
$globalNav.find('div.off-screen').removeClass('off-screen').hide(); | |
$globalNav.find('a.control').die("click").live("click", function (e) { | |
var $link = $(this); | |
$link.addClass('no-outline'); | |
if ($link.hasClass('current')) { | |
$link.siblings('.global-sub').slideUp(350); | |
$link.removeClass('current'); | |
} else { | |
if ($globalNav.find('.nav > li > .current').length > 0) { | |
$globalNav.find('.nav > li > .current').removeClass('current'); | |
$globalNav.find('.global-sub').slideUp(350); | |
} | |
$link.addClass('current'); | |
$link.siblings('.global-sub').slideDown(250, function () { | |
$link.trigger("animation-finished"); | |
}); | |
} | |
e.preventDefault(); | |
}); | |
$('#main-wrapper').click(function () { | |
$globalNav.find('.global-sub').slideUp(350); | |
$globalNav.find('.nav > li > .current').removeClass('current'); | |
}); | |
var insertUserMenu = function (src) { | |
var userMenu = $(src); | |
userMenu.find("a.control").addClass('current'); | |
userMenu.find(".global-sub").css({ | |
bottom: '100%', | |
visibility: 'visible' | |
}); | |
$globalNav.find('.nav > li > .current').removeClass('current'); | |
$globalNav.find('li.nav-users').replaceWith(userMenu); | |
setupTabs(); | |
setupAccountArticles(); | |
}; | |
var submitFormWithCrypto = function (form, callback) { | |
$.getScript('/profiles/crypto_key?callback=setCryptData', function () { | |
var queryData = { | |
key_id: cryptData.id, | |
encrypted: teaEncrypt($(form).serialize(), cryptData.key) | |
}; | |
$.post(form.action.replace(/^https:/, window.location.protocol), $.param(queryData), callback, "json"); | |
}); | |
}; | |
$('form#global-login-form').submit(function (e) { | |
e.preventDefault(); | |
submitFormWithCrypto(this, function (response) { | |
if (response.errors) { | |
$globalNav.find('div.sign-in div.alert-row').html(response.errors.join(" ")).slideDown(250); | |
} else { | |
insertUserMenu(response.menu); | |
$.publish("user-info-available", response.user); | |
} | |
}); | |
}); | |
$('form#global-signup-form').submit(function (e) { | |
e.preventDefault(); | |
var $form = $(this); | |
submitFormWithCrypto(this, function (response) { | |
if (response.errors) { | |
$form.unbind("submit").submit(); | |
} else { | |
insertUserMenu(response.menu); | |
$.publish("user-info-available", response.user); | |
} | |
}); | |
}); | |
$('form#global-password-reset-form').submit(function (e) { | |
e.preventDefault(); | |
submitFormWithCrypto(this, function (response) { | |
if (response.error) { | |
$globalNav.find('div.sign-in-help div.alert-row').html(response.error).slideDown(250); | |
} else { | |
$globalNav.find('div.sign-in-help div.alert-row').html(response.message).slideDown(250); | |
} | |
}); | |
}); | |
$('form#upb_new_email_signup label:not(.not-infield)').inFieldLabels(); | |
$('form#upb_new_email_signup').bind('submit', function () { | |
var $this = $(this), | |
formData = $this.serialize(); | |
$.ajax({ | |
data: formData, | |
dataType: 'json', | |
type: 'post', | |
url: $this.attr('action'), | |
success: function (data) { | |
$globalNav.find('div.sign-in div.alert-row').html(data.message).slideDown(250); | |
}, | |
error: function () { | |
$globalNav.find('div.sign-in div.alert-row').html("Sorry, there was a problem. Please try again.").slideDown(250); | |
} | |
}); | |
return false; | |
}); | |
$globalNav.find('a.trouble-sign-in').click(function (e) { | |
$signInHelp.slideDown(350, 'swing'); | |
return false; | |
}); | |
$signInHelp.find('a.go-back').click(function (e) { | |
$signInHelp.slideUp(350, 'swing'); | |
return false; | |
}); | |
$globalNav.find('a.btn-create-account').click(function (e) { | |
$createAccount.slideDown(350, 'swing'); | |
return false; | |
}); | |
$globalNav.find('a.sign-in-link').click(function (e) { | |
$createAccount.slideUp(350, 'swing'); | |
return false; | |
}); | |
var setupAccountArticles = function () { | |
$globalNav.find('.articles ul').jScrollPane({ | |
'scrollbarMargin': 0 | |
}); | |
$globalNav.find('.articles a').click(function () { | |
e.preventDefault(); | |
activateArticle($(this)); | |
}); | |
}; | |
var activateArticle = function ($this) { | |
var $secondaryColumn = $globalNav.find('.nav-my-account .secondary-section'); | |
$this.parents('.articles').find('li.active, li.previous').removeClass('active previous'); | |
$this.parent().addClass('active').prev().addClass('previous'); | |
$secondaryColumn.html(''); | |
$this.siblings('.item').clone().appendTo($secondaryColumn); | |
$secondaryColumn.find('div.content').jScrollPane(); | |
}; | |
var $firstArticle = $globalNav.find('.articles:first a:first'); | |
setupAccountArticles(); | |
activateArticle($firstArticle); | |
$globalNav.find('label:not(.not-infield)').inFieldLabels(); | |
$globalNav.find('#global-location').bind({ | |
'focus': function () { | |
$('#global-city-start-search').find('.store-search-wrapper').addClass('focused'); | |
}, | |
'blur': function () { | |
$('#global-city-start-search').find('.store-search-wrapper').removeClass('focused'); | |
} | |
}); | |
$globalNav.find('.scroller').scroller(); | |
var setupTabs = function () { | |
$globalNav.find('.nav-tabs').tabs({ | |
callback: function () { | |
var $globalArticles = $('#puma-global-upb').find('.current .articles ul'); | |
$globalArticles.jScrollPaneRemove(); | |
$globalArticles.jScrollPane({ | |
'scrollbarMargin': 0 | |
}); | |
$globalArticles.find('a:first').click(); | |
} | |
}); | |
}; | |
setupTabs(); | |
var hideGlobalNav = function () { | |
$globalNav.find('.global-sub').addClass('hide').css({ | |
bottom: '100%', | |
visibility: 'visible' | |
}); | |
}; | |
hideGlobalNav(); | |
var popups = function () { | |
$('.popup').popup({ | |
open: function () { | |
$('.custom-scrollbars').jScrollPane(); | |
}, | |
close: function () { | |
$('.custom-scrollbars').jScrollPaneRemove(); | |
} | |
}); | |
}; | |
popups(); | |
if (typeof SHOW_SIGNUP !== "undefined") { | |
$globalNav.find("li.nav-users > a").click(); | |
$globalNav.find("a.btn-create-account").click(); | |
}; | |
if (callback) { | |
callback(); | |
} | |
}; | |
$.get(upbUrl, function (src) { | |
$("body").append(src); | |
activateGlobalNav(); | |
}); | |
}; | |
var PUMA = PUMA || {}; | |
PUMA.base = { | |
init: function () { | |
PUMA.globalNav('/upb', function () { | |
PUMA.base.omni(); | |
PUMA.base.pointMPLinksToCurrentURL(); | |
}); | |
PUMA.nav.init(); | |
$('#puma-global-footer').equalHeight({ | |
find: '.section' | |
}); | |
PUMA.base.finished(); | |
}, | |
initializeCaptchas: function () { | |
$('.captcha').each(function () { | |
var apiKey = $(this).data('api-key'); | |
Recaptcha.create(apiKey, this, { | |
theme: 'white' | |
}); | |
}); | |
}, | |
finished: function () { | |
$('.preload').addClass('loaded').removeClass('preload'); | |
$('.visibility-hide').addClass('hide').removeClass('visibility-hide'); | |
}, | |
omni: function (context) { | |
var modifyUrl = function (tag, attr) { | |
$(tag, context).each(function () { | |
var $this = $(this), | |
url = $this.attr(attr), | |
ga_cookie = $.cookie('__utmz'), | |
utmccn; | |
if (url && (url.match(/shop(-eu)?\.puma/) || url.match(/puma.com\/store(\?|\/?$)/))) { | |
url += (url.indexOf("?") != -1) ? "&" : "?"; | |
url += "source=marketing_PUMA_" + SITE_NAME + '_' + COUNTRY_CODE; | |
switch ($this.closest('[data-page-section]').data('page-section')) { | |
case 'catnav': | |
url += '_CatNav_' + $this.text().replace(/\s+/, '-'); | |
break; | |
case 'topnav': | |
url += '_topnav_' + $this.text().replace(/\s+/, '-'); | |
break; | |
case 'upb-left': | |
url += '_upbleft'; | |
break; | |
case 'upb-right': | |
url += '_upbright'; | |
break; | |
case 'footer': | |
url += '_footer'; | |
break; | |
case 'hot-products': | |
url += '_products'; | |
break; | |
case 'buy-online': | |
url += '_buyonline'; | |
break; | |
case 'subpanel': | |
url += '_subpanel'; | |
break; | |
case 'main-panel': | |
if ($this.data('campaign')) { | |
url += '_mainpanel_' + $this.data('campaign'); | |
} else { | |
url += '_mainpanel'; | |
} | |
break; | |
case 'bottom-ads': | |
url += '_bottompanel'; | |
break; | |
case 'splash': | |
if ($this.data('splash-location')) { | |
url += '_splashtest_' + $('#splash-page-modal').data('splash-page-id') + '_' + $this.data('splash-location'); | |
} else { | |
url += '_splashtest_' + $('#splash-page-modal').data('splash-page-id'); | |
} | |
break; | |
case 'producthub': | |
url += '_producthub'; | |
break; | |
case 'callout': | |
url += '_callout'; | |
break; | |
case 'nostocklink': | |
url += '_nostocklink'; | |
break; | |
default: | |
break; | |
} | |
if (ga_cookie && ga_cookie.match(/utmcsr=\(?media\)?/)) { | |
url += '_media'; | |
utmccn = ga_cookie.match(/utmccn=([^\|]+)/); | |
if (utmccn) { | |
url += '_' + utmccn[1]; | |
} | |
} | |
$this.attr(attr, url); | |
} | |
}); | |
}; | |
modifyUrl("a", "href"); | |
modifyUrl("a", "data-baseurl"); | |
modifyUrl("form", "action"); | |
}, | |
pointMPLinksToCurrentURL: function () { | |
var search = window.location.search; | |
$("li.nav-language li a").each(function () { | |
var url_parts = this.href.split("/?"), | |
domain = url_parts[0], | |
lang_param = url_parts[1], | |
query_string = search; | |
if (query_string.match(/lang=\w*/)) { | |
query_string = query_string.replace(/lang=\w*/, lang_param); | |
} else if (query_string === '') { | |
query_string += '?' + lang_param; | |
} else { | |
query_string += '&' + lang_param; | |
} | |
$(this).attr("href", [domain, window.location.pathname, query_string].join("")); | |
}); | |
} | |
}; | |
$(document).ready(PUMA.base.init); | |
Array.prototype.clean = function (deleteValue) { | |
for (var i = 0; i < this.length; i++) { | |
if (this[i] == deleteValue) { | |
this.splice(i, 1); | |
i--; | |
} | |
} | |
return this; | |
}; | |
(function () { | |
var lastTime = 0; | |
var vendors = ['ms', 'moz', 'webkit', 'o']; | |
for (var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) { | |
window.requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame']; | |
window.cancelAnimationFrame = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame']; | |
} | |
if (!window.requestAnimationFrame) window.requestAnimationFrame = function (callback, element) { | |
var currTime = new Date().getTime(); | |
var timeToCall = Math.max(0, 16 - (currTime - lastTime)); | |
var id = window.setTimeout(function () { | |
callback(currTime + timeToCall); | |
}, timeToCall); | |
lastTime = currTime + timeToCall; | |
return id; | |
}; | |
if (!window.cancelAnimationFrame) window.cancelAnimationFrame = function (id) { | |
clearTimeout(id); | |
}; | |
}()); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit = { | |
init: function () { | |
if (Modernizr.canvas) { | |
_8bit.drawCanvas(); | |
_8bit.initVars(); | |
_8bit.createGameObjects(); | |
_8bit.bindEvents(); | |
_8bit.updateScale(); | |
_8bit.scene = _8bit.scenes['start']; | |
_8bit.scene.init(); | |
_8bit.gameLoop(); | |
} | |
}, | |
initVars: function () { | |
_8bit.musicIsEnabled = true; | |
_8bit.soundIsEnabled = true; | |
_8bit.debug = false; | |
_8bit.isTouchDevice = _8bit.checkForTouchDevice(); | |
if (_8bit.isTouchDevice) { | |
_8bit.soundIsEnabled = false; | |
} | |
_8bit.modifier = 0; | |
_8bit.then = Date.now(); | |
_8bit.layers = []; | |
_8bit.keysDown = []; | |
_8bit.touchButtonsDown = []; | |
_8bit.clickables = []; | |
_8bit.$prerenderCanvas = $(_8bit.prerenderCanvas); | |
_8bit.$canvas = $(_8bit.canvas); | |
_8bit.$window = $(window); | |
_8bit.points = { | |
medal: 0, | |
time: 0, | |
total: 0, | |
highScore: 0, | |
speed: 0 | |
}; | |
_8bit.medals = 0; | |
_8bit.heartsLeft = 6; | |
}, | |
bindEvents: function () { | |
$('button#start').click(this.startGame); | |
$('button#reset').click(this.resetGame); | |
$('button#pause').click(this.togglePause); | |
$('button#debug').click(function () { | |
_8bit.debug = _8bit.debug ? false : true; | |
}); | |
_8bit.$window.bind({ | |
'resize.globalEvents': this.updateScale, | |
'blur.globalEvents': this.pause, | |
'focus.globalEvents': this.unpause | |
}); | |
if (!_8bit.isTouchDevice) { | |
_8bit.$window.bind({ | |
'keydown.globalEvents': this.keyDown, | |
'keyup.globalEvents': this.keyUp | |
}); | |
} | |
if (_8bit.isTouchDevice) { | |
_8bit.touches = {}; | |
_8bit.$canvas.bind('touchstart.globalEvents', function (e) { | |
_8bit.touches.pageX = e.originalEvent.changedTouches[0].pageX; | |
_8bit.touches.pageY = e.originalEvent.changedTouches[0].pageY; | |
}); | |
} | |
}, | |
checkForTouchDevice: function () { | |
return !!(('ontouchstart' in window) || window.DocumentTouch && document instanceof DocumentTouch); | |
}, | |
createGameObjects: function () { | |
_8bit.spriteSheets = { | |
backgrounds: new _8bit.SpriteSheet('/images/run_puma_run/background-sprites.png'), | |
gameScreens: new _8bit.SpriteSheet('/images/run_puma_run/gameScreen-sprites.png'), | |
players: new _8bit.SpriteSheet('/images/run_puma_run/player-sprites.png'), | |
obstacles: new _8bit.SpriteSheet('/images/run_puma_run/obstacle-sprites.png') | |
}; | |
_8bit.backgrounds = { | |
city: new _8bit.BackgroundGenerator({ | |
name: 'city', | |
spriteLocation: { | |
x: 0, | |
y: 248 | |
}, | |
width: 965, | |
height: 155, | |
x: 0, | |
y: 431, | |
speed: 0.05, | |
repeatLength: 965 | |
}), | |
cloud1: new _8bit.BackgroundGenerator({ | |
name: 'cloud1', | |
spriteLocation: { | |
x: 536, | |
y: 0 | |
}, | |
width: 171, | |
height: 92, | |
x: 0, | |
y: 160, | |
speed: 0.04, | |
repeatLength: 700 | |
}), | |
track: new _8bit.BackgroundGenerator({ | |
name: 'track', | |
spriteLocation: { | |
x: 0, | |
y: 0 | |
}, | |
width: 536, | |
height: 238, | |
x: 0, | |
y: 617, | |
speed: 1, | |
repeatLength: 536 | |
}), | |
fence: new _8bit.BackgroundGenerator({ | |
name: 'fence', | |
spriteLocation: { | |
x: 672, | |
y: 108 | |
}, | |
width: 250, | |
height: 56, | |
x: 0, | |
y: 561, | |
speed: 0.5, | |
repeatLength: 250 | |
}) | |
}; | |
_8bit.buttons = { | |
start: new _8bit.Button({ | |
name: 'start', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 1902 | |
}, | |
x: 607, | |
y: 552, | |
width: 184, | |
height: 52, | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 0.75, | |
sequence: [0, 3], | |
loops: true | |
}, | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [2] | |
} | |
}, | |
animation: 'up' | |
}), | |
letsRace: new _8bit.Button({ | |
name: 'letsRace', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 2013 | |
}, | |
x: 565, | |
y: 490, | |
width: 294, | |
height: 52, | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 2, | |
sequence: [0] | |
}, | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [2] | |
} | |
}, | |
animation: 'up' | |
}), | |
continueBtn: new _8bit.Button({ | |
name: 'continueBtn', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 1958 | |
}, | |
x: 561, | |
y: 533, | |
width: 294, | |
height: 52, | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 2, | |
sequence: [0] | |
}, | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [2] | |
} | |
}, | |
animation: 'up' | |
}), | |
facebook: new _8bit.Button({ | |
name: 'facebook', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 2186 | |
}, | |
x: 363, | |
y: 410, | |
width: 224, | |
height: 61, | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 2, | |
sequence: [0] | |
}, | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [2] | |
} | |
}, | |
animation: 'up' | |
}), | |
twitter: new _8bit.Button({ | |
name: 'twitter', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 2251 | |
}, | |
x: 363, | |
y: 471, | |
width: 224, | |
height: 61, | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 2, | |
sequence: [0] | |
}, | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [2] | |
} | |
}, | |
animation: 'up' | |
}), | |
raceAgain: new _8bit.Button({ | |
name: 'raceAgain', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 2069 | |
}, | |
x: 598, | |
y: 419, | |
width: 202, | |
height: 113, | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 2, | |
sequence: [0] | |
}, | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [2] | |
} | |
}, | |
animation: 'up' | |
}), | |
up: new _8bit.Button({ | |
name: 'up', | |
layer: 10, | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 740, | |
y: 2074 | |
}, | |
x: 20, | |
y: 605, | |
width: 68, | |
height: 96, | |
hitAreas: [{ | |
width: 200, | |
height: 196, | |
offsetX: -20, | |
offsetY: -100 | |
}], | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 2, | |
sequence: [0] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
} | |
}, | |
animation: 'up' | |
}), | |
down: new _8bit.Button({ | |
name: 'down', | |
layer: 10, | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 740, | |
y: 2170 | |
}, | |
x: 20, | |
y: 701, | |
width: 68, | |
height: 96, | |
hitAreas: [{ | |
width: 200, | |
height: 196, | |
offsetX: -20, | |
offsetY: 0 | |
}], | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 2, | |
sequence: [0] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
} | |
}, | |
animation: 'up' | |
}), | |
jump: new _8bit.Button({ | |
name: 'jump', | |
layer: 10, | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 460, | |
y: 1826 | |
}, | |
x: 1242, | |
y: 655, | |
width: 138, | |
height: 72, | |
hitAreas: [{ | |
width: 258, | |
height: 320, | |
offsetX: -100, | |
offsetY: -115 | |
}], | |
animations: { | |
up: { | |
timer: 0, | |
i: 0, | |
spf: 2, | |
sequence: [0] | |
}, | |
down: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1] | |
} | |
}, | |
animation: 'up' | |
}) | |
}; | |
_8bit.text = { | |
gameTime: new _8bit.Text({ | |
name: 'gameTime', | |
color: 'rgb(250, 250, 250)', | |
fontSize: 40, | |
text: '0:00', | |
x: 260, | |
y: 120 | |
}), | |
pace: new _8bit.Text({ | |
name: 'pace', | |
color: 'rgb(250, 250, 250)', | |
fontSize: 40, | |
text: 'Relaxed', | |
x: 418, | |
y: 120 | |
}), | |
medals: new _8bit.Text({ | |
name: 'medals', | |
color: 'rgb(250, 250, 250)', | |
fontSize: 40, | |
text: '0000', | |
x: 971, | |
y: 120 | |
}) | |
}; | |
_8bit.levelItems = { | |
startLine: { | |
name: 'startLine', | |
spriteSheet: _8bit.spriteSheets.backgrounds, | |
spriteLocation: { | |
x: 571, | |
y: 102 | |
}, | |
y: 648, | |
layer: 1, | |
width: 97, | |
height: 92 | |
}, | |
medal: { | |
name: 'medal', | |
spriteLocation: { | |
x: 0, | |
y: 967 | |
}, | |
width: 64, | |
height: 157, | |
hitAreas: [{ | |
width: 64, | |
height: 100, | |
offsetX: 0, | |
offsetY: 10 | |
}], | |
offset: -8, | |
animations: { | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0.25, | |
sequence: [0, 1, 2, 1], | |
loops: true | |
} | |
}, | |
animation: 'hover' | |
}, | |
heart: { | |
name: 'heart', | |
spriteLocation: { | |
x: 0, | |
y: 1128 | |
}, | |
width: 36, | |
height: 53, | |
hitAreas: [{ | |
width: 36, | |
height: 53, | |
offsetX: 0, | |
offsetY: 0 | |
}], | |
offset: -8, | |
animations: { | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0.25, | |
sequence: [0, 1, 2, 3, 2, 1], | |
loops: true | |
} | |
}, | |
animation: 'hover' | |
}, | |
cone: { | |
name: 'cone', | |
spriteLocation: { | |
x: 0, | |
y: 0 | |
}, | |
width: 73, | |
height: 73, | |
hitAreas: [{ | |
width: 22, | |
height: 50, | |
offsetX: 20, | |
offsetY: 23 | |
}] | |
}, | |
water: { | |
name: 'water', | |
spriteLocation: { | |
x: 0, | |
y: 306 | |
}, | |
width: 152, | |
height: 83, | |
hitAreas: [{ | |
width: 152, | |
height: 35, | |
offsetX: 0, | |
offsetY: 48 | |
}], | |
offset: 4 | |
}, | |
rock: { | |
name: 'rock', | |
spriteLocation: { | |
x: 0, | |
y: 389 | |
}, | |
width: 112, | |
height: 97, | |
hitAreas: [{ | |
width: 50, | |
height: 40, | |
offsetX: 12, | |
offsetY: 52 | |
}] | |
}, | |
hurdle_s: { | |
name: 'hurdle - small', | |
spriteLocation: { | |
x: 0, | |
y: 486 | |
}, | |
width: 128, | |
height: 100, | |
hitAreas: [{ | |
width: 20, | |
height: 75, | |
offsetX: 52, | |
offsetY: 20 | |
}] | |
}, | |
hurdle_m: { | |
name: 'hurdle - medium', | |
span: 2, | |
spriteLocation: { | |
x: 0, | |
y: 586 | |
}, | |
width: 184, | |
height: 118, | |
hitAreas: [{ | |
width: 10, | |
height: 80, | |
offsetX: 60, | |
offsetY: 35 | |
}, { | |
width: 10, | |
height: 80, | |
offsetX: 80, | |
offsetY: 10 | |
}] | |
}, | |
hurdle_l: { | |
name: 'hurdle - large', | |
span: 3, | |
spriteLocation: { | |
x: 0, | |
y: 704 | |
}, | |
width: 184, | |
height: 150, | |
hitAreas: [{ | |
width: 10, | |
height: 80, | |
offsetX: 67, | |
offsetY: 60 | |
}, { | |
width: 10, | |
height: 80, | |
offsetX: 90, | |
offsetY: 40 | |
}, { | |
width: 10, | |
height: 80, | |
offsetX: 112, | |
offsetY: 20 | |
}] | |
}, | |
fire: { | |
name: 'fire', | |
span: 3, | |
spriteLocation: { | |
x: 0, | |
y: 854 | |
}, | |
width: 267, | |
height: 113, | |
hitAreas: [{ | |
width: 145, | |
height: 25, | |
offsetX: 32, | |
offsetY: 83 | |
}, { | |
width: 145, | |
height: 25, | |
offsetX: 60, | |
offsetY: 50 | |
}, { | |
width: 145, | |
height: 25, | |
offsetX: 90, | |
offsetY: 15 | |
}], | |
animations: { | |
loop: { | |
timer: 0, | |
i: 0, | |
spf: 0.10, | |
sequence: [0, 1], | |
loops: true | |
} | |
}, | |
animation: 'loop', | |
offset: 10 | |
}, | |
bird: { | |
name: 'bird', | |
spriteLocation: { | |
x: 0, | |
y: 76 | |
}, | |
width: 109, | |
height: 114, | |
hitAreas: [{ | |
width: 80, | |
height: 45, | |
offsetX: 14, | |
offsetY: 28 | |
}], | |
animations: { | |
hover: { | |
timer: 0, | |
i: 0, | |
spf: 0.25, | |
sequence: [0, 1, 2, 1], | |
loops: true | |
} | |
}, | |
animation: 'hover' | |
}, | |
brick: { | |
name: 'brick', | |
spriteLocation: { | |
x: 0, | |
y: 190 | |
}, | |
width: 109, | |
height: 116, | |
hitAreas: [{ | |
width: 109, | |
height: 86, | |
offsetX: 7, | |
offsetY: 30 | |
}] | |
}, | |
crowd: { | |
name: 'crowd', | |
spriteSheet: _8bit.spriteSheets.backgrounds, | |
spriteLocation: { | |
x: 0, | |
y: 403 | |
}, | |
width: 472, | |
repeatOffset: -54, | |
y: 378, | |
height: 235, | |
speed: 0.5, | |
animations: { | |
loop: { | |
timer: 0, | |
i: 0, | |
spf: 0.25, | |
sequence: [0, 1], | |
loops: true | |
} | |
}, | |
animation: 'loop' | |
} | |
}; | |
_8bit.levelEngine = new _8bit.LevelEngine(); | |
_8bit.players = { | |
bolt: new _8bit.Player({ | |
name: 'bolt', | |
title: 'RUNNER', | |
spriteLocation: { | |
x: 0, | |
y: 0 | |
} | |
}), | |
rickie: new _8bit.Player({ | |
name: 'rickie', | |
title: 'GOLFER', | |
spriteLocation: { | |
x: 0, | |
y: 240 | |
} | |
}), | |
alonso: new _8bit.Player({ | |
name: 'alonso', | |
title: 'DRIVER', | |
spriteLocation: { | |
x: 0, | |
y: 720 | |
} | |
}), | |
aguero: new _8bit.Player({ | |
name: 'aguero', | |
title: 'FOOTBALLER', | |
spriteLocation: { | |
x: 0, | |
y: 480 | |
} | |
}), | |
yuvi: new _8bit.Player({ | |
name: 'yuvi', | |
title: 'CRICKETER', | |
spriteLocation: { | |
x: 0, | |
y: 960 | |
} | |
}) | |
}; | |
_8bit.player = _8bit.players.bolt; | |
_8bit.shapes = { | |
playerSelectBg: new _8bit.Shape({ | |
name: 'playerSelectBg', | |
color: 'rgba(28, 21, 21, 0.5)', | |
height: '371', | |
width: '116' | |
}), | |
touchButton_up: new _8bit.Shape({ | |
name: 'touchButton_up', | |
color: 'rgba(0, 0, 255, 0.1)', | |
height: '200', | |
width: '500', | |
x: 0, | |
y: 490 | |
}), | |
touchButton_down: new _8bit.Shape({ | |
name: 'touchButton_down', | |
color: 'rgba(0, 0, 255, 0.1)', | |
height: '200', | |
width: '500', | |
x: 0, | |
y: 690 | |
}), | |
touchButton_jump: new _8bit.Shape({ | |
name: 'touchButton_jump', | |
color: 'rgba(0, 0, 255, 0.1)', | |
height: '400', | |
width: '500', | |
x: 900, | |
y: 490, | |
layer: 10 | |
}) | |
}, _8bit.sounds = { | |
button: new _8bit.Sound('/audio/run_puma_run/button'), | |
pause: new _8bit.Sound('/audio/run_puma_run/pause'), | |
countDown: new _8bit.Sound('/audio/run_puma_run/countDown'), | |
die: new _8bit.Sound('/audio/run_puma_run/die'), | |
heart: new _8bit.Sound('/audio/run_puma_run/heart'), | |
gameOver: new _8bit.Sound('/audio/run_puma_run/gameOver'), | |
jump: new _8bit.Sound('/audio/run_puma_run/jump'), | |
medal: new _8bit.Sound('/audio/run_puma_run/medal'), | |
music: new _8bit.Sound('/audio/run_puma_run/bg-track', true), | |
points: new _8bit.Sound('/audio/run_puma_run/points'), | |
pointsEnd: new _8bit.Sound('/audio/run_puma_run/pointsEnd'), | |
swish: new _8bit.Sound('/audio/run_puma_run/swish'), | |
trip: new _8bit.Sound('/audio/run_puma_run/trip') | |
}; | |
_8bit.sounds.swish.sound.volume = 0.65; | |
_8bit.sprites = { | |
hearts: new _8bit.Sprite({ | |
name: 'hearts', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 693, | |
y: 1267 | |
}, | |
x: 1075, | |
y: 128, | |
width: 104, | |
height: 28 | |
}), | |
title: new _8bit.Sprite({ | |
name: 'title', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 1533 | |
}, | |
x: 510, | |
y: 160, | |
width: 368, | |
height: 365 | |
}), | |
playerBoard: new _8bit.Sprite({ | |
name: 'playerBoard', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 417 | |
}, | |
x: 290, | |
y: 160, | |
width: 821, | |
height: 427 | |
}), | |
howToPlayBoard: new _8bit.Sprite({ | |
name: 'howToPlayBoard', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 0 | |
}, | |
x: 302, | |
y: 171, | |
width: 797, | |
height: 415 | |
}), | |
howToPlayBoard_touch: new _8bit.Sprite({ | |
name: 'howToPlayBoard_touch', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 2317 | |
}, | |
x: 302, | |
y: 171, | |
width: 797, | |
height: 415 | |
}), | |
endScreenBoard: new _8bit.Sprite({ | |
name: 'endScreenBoard', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 849 | |
}, | |
x: 302, | |
y: 171, | |
width: 797, | |
height: 415 | |
}), | |
playerSelectArrow: new _8bit.Sprite({ | |
name: 'playerSelectArrow', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 773, | |
y: 1682 | |
}, | |
width: 28, | |
height: 28 | |
}), | |
medalCount: new _8bit.Sprite({ | |
name: 'medalCount', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 773, | |
y: 1533 | |
}, | |
width: 48, | |
height: 28, | |
x: 916, | |
y: 128 | |
}), | |
stopwatch: new _8bit.Sprite({ | |
name: 'stopwatch', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 773, | |
y: 1565 | |
}, | |
width: 32, | |
height: 28, | |
x: 221, | |
y: 128 | |
}), | |
speedLabel: new _8bit.Sprite({ | |
name: 'speedLabel', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 773, | |
y: 1615 | |
}, | |
width: 38, | |
height: 10, | |
x: 368, | |
y: 146 | |
}), | |
speedBars: new _8bit.Sprite({ | |
name: 'speedBars', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 774, | |
y: 1597 | |
}, | |
width: 36, | |
height: 15, | |
x: 369, | |
y: 128 | |
}), | |
lilDivider_1: new _8bit.Sprite({ | |
name: 'lilDivider_1', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 774, | |
y: 1630 | |
}, | |
width: 4, | |
height: 28, | |
x: 349, | |
y: 128 | |
}), | |
lilDivider_2: new _8bit.Sprite({ | |
name: 'lilDivider_2', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 774, | |
y: 1630 | |
}, | |
width: 4, | |
height: 28, | |
x: 1057, | |
y: 128 | |
}), | |
countDown: new _8bit.Sprite({ | |
name: 'countDown', | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 0, | |
y: 1266 | |
}, | |
width: 216, | |
height: 264, | |
layer: 10, | |
x: 587, | |
y: 230, | |
animations: { | |
one: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [0], | |
loops: false | |
}, | |
two: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [1], | |
loops: false | |
}, | |
three: { | |
timer: 0, | |
i: 0, | |
spf: 0, | |
sequence: [2], | |
loops: false | |
} | |
}, | |
animation: 'three' | |
}), | |
gameOver: new _8bit.Sprite({ | |
name: 'gameOver', | |
layer: 10, | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 372, | |
y: 1533 | |
}, | |
width: 383, | |
height: 246, | |
x: 508, | |
y: 250 | |
}) | |
}; | |
_8bit.scenes = { | |
start: new _8bit.Scene({ | |
init: function () { | |
this.enterWasPressed = false; | |
this.name = 'start'; | |
this.bind(); | |
this.setProperties(); | |
_8bit.player.jumpButtonIsDown = false; | |
_8bit.player.isGrounded = true; | |
this.update(); | |
_8bit.sounds.music.shouldResume = false; | |
}, | |
bind: function () { | |
_8bit.clickables = [_8bit.buttons.start]; | |
if (_8bit.isTouchDevice) { | |
_8bit.clickables.push(_8bit.buttons.jump, _8bit.buttons.down, _8bit.buttons.up); | |
_8bit.buttons.start.events = { | |
touchend: function (e) { | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('howToPlay'); | |
} | |
}; | |
_8bit.buttons.jump.events = { | |
touchstart: function (e) { | |
_8bit.buttons.jump.animation = 'down'; | |
_8bit.touchButtonsDown['jump'] = true; | |
_8bit.player.jump(); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.jump.animation = 'up'; | |
delete _8bit.touchButtonsDown['jump']; | |
} | |
}; | |
_8bit.buttons.up.events = { | |
touchstart: function (e) { | |
_8bit.buttons.up.animation = 'down'; | |
_8bit.touchButtonsDown['up'] = true; | |
_8bit.player.changeLane(1); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.up.animation = 'up'; | |
delete _8bit.touchButtonsDown['up']; | |
} | |
}; | |
_8bit.buttons.down.events = { | |
touchstart: function (e) { | |
_8bit.buttons.down.animation = 'down'; | |
_8bit.touchButtonsDown['down'] = true; | |
_8bit.player.changeLane(-1); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.down.animation = 'up'; | |
delete _8bit.touchButtonsDown['down']; | |
} | |
}; | |
_8bit.$canvas.bind({ | |
'touchstart.sceneEvents': _8bit.mouseEvents.touchstart, | |
'touchend.sceneEvents': _8bit.mouseEvents.touchend | |
}); | |
} else { | |
_8bit.buttons.start.events = { | |
mouseup: function (e) { | |
_8bit.sounds.button.play(); | |
_8bit.buttons.start.animation = 'up'; | |
_8bit.changeScene('howToPlay'); | |
}, | |
mousedown: function (e) { | |
_8bit.buttons.start.animation = 'down'; | |
}, | |
mouseenter: function (e) { | |
_8bit.buttons.start.animation = 'hover'; | |
}, | |
mouseleave: function (e) { | |
_8bit.buttons.start.animation = 'up'; | |
} | |
}; | |
_8bit.$window.bind({ | |
'keydown.sceneEvents': _8bit.keyDown, | |
'keyup.sceneEvents': _8bit.keyUp | |
}); | |
_8bit.$canvas.bind({ | |
'mousedown.sceneEvents': _8bit.mouseEvents.mousedown, | |
'mouseup.sceneEvents': _8bit.mouseEvents.mouseup, | |
'mousemove.sceneEvents': _8bit.mouseEvents.hoverCheck | |
}); | |
} | |
}, | |
checkKeys: function () { | |
var upKeyIsDown = 38 in _8bit.keysDown || 'up' in _8bit.touchButtonsDown; | |
var downKeyIsDown = 40 in _8bit.keysDown || 'down' in _8bit.touchButtonsDown; | |
var spacebarIsDown = 32 in _8bit.keysDown || 'jump' in _8bit.touchButtonsDown; | |
var enterIsDown = 13 in _8bit.keysDown; | |
var enterReleased = _8bit.enterWasDown && !enterIsDown; | |
if (enterIsDown) { | |
_8bit.enterWasDown = true; | |
_8bit.buttons.start.animation = 'down'; | |
} else if (enterReleased) { | |
_8bit.buttons.start.animation = 'up'; | |
_8bit.enterWasDown = false; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('howToPlay'); | |
} | |
if (spacebarIsDown) { | |
_8bit.player.jumpButtonIsDown = true; | |
} else { | |
_8bit.player.jumpButtonIsDown = false; | |
if (_8bit.player.isGrounded) { | |
_8bit.player.jumpButtonReleased = true; | |
} | |
} | |
if (upKeyIsDown) { | |
_8bit.player.changeLane(1); | |
} else if (downKeyIsDown) { | |
_8bit.player.changeLane(-1); | |
} else { | |
_8bit.player.laneChanged = false; | |
} | |
}, | |
setProperties: function () { | |
if (!_8bit.player) { | |
_8bit.player = _8bit.players.bolt; | |
} | |
_8bit.scene = _8bit.scenes.start; | |
_8bit.baseSpeed = 400; | |
_8bit.raceTime = 0; | |
_8bit.player.setPlayerData(); | |
_8bit.heartsLeft = 6; | |
_8bit.medals = 0; | |
_8bit.points = { | |
medal: 0, | |
time: 0, | |
total: 0, | |
highScore: 0, | |
speed: 0 | |
}; | |
_8bit.sprites.hearts.spriteLocation.y = _8bit.sprites.hearts.spriteLocation.startY; | |
}, | |
update: function () { | |
_8bit.groups.background.update(); | |
_8bit.groups.hud.update(); | |
_8bit.sprites.title.update(); | |
_8bit.buttons.start.update(); | |
_8bit.player.update(); | |
} | |
}), | |
howToPlay: new _8bit.Scene({ | |
init: function () { | |
PUMA.ga.trackEvent(['Game', 'Start', 'Start']); | |
this.bind(); | |
this.enterWasPressed = false; | |
if (_8bit.musicIsEnabled && !_8bit.sounds.music.isPlaying) { | |
_8bit.sounds.music.play(); | |
_8bit.sounds.music.shouldResume = true; | |
_8bit.sounds.music.sound.volume = 0.9; | |
_8bit.sounds.music.isPlaying = true; | |
} | |
}, | |
bind: function () { | |
_8bit.clickables = [_8bit.buttons.continueBtn]; | |
if (_8bit.isTouchDevice) { | |
_8bit.clickables.push(_8bit.buttons.jump, _8bit.buttons.up, _8bit.buttons.down); | |
_8bit.buttons.jump.events = { | |
touchstart: function (e) { | |
_8bit.buttons.jump.animation = 'down'; | |
_8bit.touchButtonsDown['jump'] = true; | |
_8bit.player.jump(); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.jump.animation = 'up'; | |
delete _8bit.touchButtonsDown['jump']; | |
} | |
}; | |
_8bit.buttons.up.events = { | |
touchstart: function (e) { | |
_8bit.buttons.up.animation = 'down'; | |
_8bit.touchButtonsDown['up'] = true; | |
_8bit.player.changeLane(1); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.up.animation = 'up'; | |
delete _8bit.touchButtonsDown['up']; | |
} | |
}; | |
_8bit.buttons.down.events = { | |
touchstart: function (e) { | |
_8bit.buttons.down.animation = 'down'; | |
_8bit.touchButtonsDown['down'] = true; | |
_8bit.player.changeLane(-1); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.down.animation = 'up'; | |
delete _8bit.touchButtonsDown['down']; | |
} | |
}; | |
_8bit.buttons.continueBtn.events = { | |
touchstart: function (e) { | |
_8bit.buttons.continueBtn.animation = 'down'; | |
}, | |
touchend: function (e) { | |
_8bit.buttons.continueBtn.animation = 'up'; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('playerSelect'); | |
} | |
}; | |
_8bit.$canvas.bind({ | |
'touchstart.sceneEvents': _8bit.mouseEvents.touchstart, | |
'touchend.sceneEvents': _8bit.mouseEvents.touchend | |
}); | |
} else { | |
_8bit.buttons.continueBtn.events = { | |
mouseup: function (e) { | |
_8bit.buttons.continueBtn.animation = 'up'; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('playerSelect'); | |
}, | |
mousedown: function (e) { | |
_8bit.buttons.continueBtn.animation = 'down'; | |
}, | |
mouseenter: function (e) { | |
_8bit.buttons.continueBtn.animation = 'hover'; | |
}, | |
mouseleave: function (e) { | |
_8bit.buttons.continueBtn.animation = 'up'; | |
} | |
}; | |
_8bit.$canvas.bind({ | |
'mousedown.sceneEvents': _8bit.mouseEvents.mousedown, | |
'mouseup.sceneEvents': _8bit.mouseEvents.mouseup, | |
'mousemove.sceneEvents': _8bit.mouseEvents.hoverCheck | |
}); | |
_8bit.$window.bind({ | |
'keydown.sceneEvents': _8bit.keyDown, | |
'keyup.sceneEvents': _8bit.keyUp | |
}); | |
} | |
}, | |
checkKeys: function () { | |
var upKeyIsDown; | |
var downKeyIsDown; | |
var spacebarIsDown; | |
var enterIsDown = 13 in _8bit.keysDown; | |
var enterReleased = _8bit.enterWasDown && !enterIsDown; | |
if (enterIsDown) { | |
_8bit.buttons.continueBtn.animation = 'down'; | |
_8bit.enterWasDown = true; | |
} else if (enterReleased) { | |
_8bit.buttons.continueBtn.animation = 'up'; | |
_8bit.enterWasDown = false; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('playerSelect'); | |
} | |
if (_8bit.isTouchDevice) { | |
upKeyIsDown = 'up' in _8bit.touchButtonsDown; | |
downKeyIsDown = 'down' in _8bit.touchButtonsDown; | |
spacebarIsDown = 'jump' in _8bit.touchButtonsDown; | |
} else { | |
upKeyIsDown = 38 in _8bit.keysDown; | |
downKeyIsDown = 40 in _8bit.keysDown; | |
spacebarIsDown = 32 in _8bit.keysDown; | |
} | |
if (upKeyIsDown) { | |
_8bit.player.changeLane(1); | |
} else if (downKeyIsDown) { | |
_8bit.player.changeLane(-1); | |
} else { | |
_8bit.player.laneChanged = false; | |
} | |
if (spacebarIsDown) { | |
_8bit.player.jumpButtonIsDown = true; | |
} else { | |
_8bit.player.jumpButtonIsDown = false; | |
if (_8bit.player.isGrounded) { | |
_8bit.player.jumpButtonReleased = true; | |
} | |
} | |
}, | |
update: function () { | |
_8bit.groups.background.update(); | |
if (_8bit.isTouchDevice) { | |
_8bit.sprites.howToPlayBoard_touch.update(); | |
_8bit.buttons.up.update(); | |
_8bit.buttons.down.update(); | |
_8bit.buttons.jump.update(); | |
} else { | |
_8bit.sprites.howToPlayBoard.update(); | |
} | |
_8bit.buttons.continueBtn.update(); | |
_8bit.groups.hud.update(); | |
_8bit.player.update(); | |
} | |
}), | |
playerSelect: new _8bit.Scene({ | |
init: function () { | |
PUMA.ga.trackEvent(['Game', 'Continue', 'Continue']); | |
_8bit.scenes.playerSelect.initSelectComplete = false; | |
this.name = 'playerSelect'; | |
this.createPlayerTitles(); | |
this.setProperties(); | |
this.bind(); | |
this.deselectPlayers(); | |
this.selectPlayer({ | |
target: _8bit.players.bolt | |
}); | |
}, | |
bind: function () { | |
var _this = this; | |
_8bit.clickables = [_8bit.players.bolt, _8bit.players.rickie, _8bit.players.aguero, _8bit.players.alonso, _8bit.players.yuvi, _8bit.buttons.letsRace]; | |
if (_8bit.isTouchDevice) { | |
_8bit.buttons.letsRace.events = { | |
touchstart: function (e) { | |
_8bit.buttons.letsRace.animation = 'down'; | |
}, | |
touchend: function (e) { | |
_8bit.buttons.letsRace.animation = 'up'; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('countDown'); | |
} | |
}; | |
for (var playerName in _8bit.players) { | |
_8bit.players[playerName].events = { | |
touchstart: _this.hoverPlayer, | |
touchend: _this.selectPlayer | |
}; | |
} | |
_8bit.buttons.jump.events = { | |
touchstart: function (e) { | |
_8bit.buttons.jump.animation = 'down'; | |
_8bit.touchButtonsDown['jump'] = true; | |
_8bit.player.jump(); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.jump.animation = 'up'; | |
delete _8bit.touchButtonsDown['jump']; | |
} | |
}; | |
_8bit.buttons.up.events = { | |
touchstart: function (e) { | |
_8bit.buttons.up.animation = 'down'; | |
_8bit.touchButtonsDown['up'] = true; | |
_8bit.player.changeLane(1); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.up.animation = 'up'; | |
delete _8bit.touchButtonsDown['up']; | |
} | |
}; | |
_8bit.buttons.down.events = { | |
touchstart: function (e) { | |
_8bit.buttons.down.animation = 'down'; | |
_8bit.touchButtonsDown['down'] = true; | |
_8bit.player.changeLane(-1); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.down.animation = 'up'; | |
delete _8bit.touchButtonsDown['down']; | |
} | |
}; | |
_8bit.$canvas.bind({ | |
'touchstart.sceneEvents': _8bit.mouseEvents.touchstart, | |
'touchend.sceneEvents': _8bit.mouseEvents.touchend | |
}); | |
_8bit.$window.bind({ | |
'keydown.sceneEvents': _8bit.keyDown, | |
'keyup.sceneEvents': _8bit.keyUp | |
}); | |
} else { | |
_8bit.buttons.letsRace.events = { | |
mouseup: function () { | |
_8bit.buttons.letsRace.animation = 'up'; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('countDown'); | |
}, | |
mousedown: function () { | |
_8bit.buttons.letsRace.animation = 'down'; | |
}, | |
mouseenter: function () { | |
_8bit.buttons.letsRace.animation = 'hover'; | |
}, | |
mouseleave: function () { | |
_8bit.buttons.letsRace.animation = 'up'; | |
} | |
}; | |
for (var playerName in _8bit.players) { | |
_8bit.players[playerName].events = { | |
mousedown: _this.selectPlayer, | |
mouseenter: _this.hoverPlayer | |
}; | |
} | |
_8bit.players.bolt.events = { | |
mousedown: _this.selectPlayer, | |
mouseenter: _this.hoverPlayer | |
}; | |
_8bit.$canvas.bind({ | |
'mousedown.sceneEvents': _8bit.mouseEvents.mousedown, | |
'mouseup.sceneEvents': _8bit.mouseEvents.mouseup, | |
'mousemove.sceneEvents': _8bit.mouseEvents.hoverCheck | |
}); | |
_8bit.$window.bind({ | |
'keydown.sceneEvents': _8bit.keyDown, | |
'keyup.sceneEvents': _8bit.keyUp | |
}); | |
} | |
}, | |
update: function () { | |
_8bit.groups.background.update(); | |
_8bit.sprites.playerBoard.update(); | |
_8bit.shapes.playerSelectBg.update(); | |
_8bit.players.aguero.update(); | |
_8bit.text.aguero.update(); | |
_8bit.players.alonso.update(); | |
_8bit.text.alonso.update(); | |
_8bit.players.bolt.update(); | |
_8bit.text.bolt.update(); | |
_8bit.players.rickie.update(); | |
_8bit.text.rickie.update(); | |
_8bit.players.yuvi.update(); | |
_8bit.text.yuvi.update(); | |
_8bit.buttons.letsRace.update(); | |
_8bit.sprites.playerSelectArrow.update(); | |
}, | |
checkKeys: function () { | |
var enterIsDown = 13 in _8bit.keysDown; | |
var leftIsDown = 37 in _8bit.keysDown; | |
var rightIsDown = 39 in _8bit.keysDown; | |
var upIsDown = 38 in _8bit.keysDown; | |
var downIsDown = 40 in _8bit.keysDown; | |
var spacebarIsDown = 32 in _8bit.keysDown; | |
var enterReleased = _8bit.enterWasDown && !enterIsDown; | |
if (enterIsDown) { | |
_8bit.enterWasDown = true; | |
_8bit.buttons.letsRace.animation = 'down'; | |
} else if (enterReleased) { | |
_8bit.buttons.letsRace.animation = 'up'; | |
_8bit.enterWasDown = false; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('countDown'); | |
} | |
if (leftIsDown || downIsDown) { | |
if (!this.playerSelectChanged) { | |
this.selectPlayer({ | |
target: _8bit.clickables[this.previousIndex] | |
}); | |
this.playerSelectChanged = true; | |
} | |
} else if (rightIsDown || upIsDown) { | |
if (!this.playerSelectChanged) { | |
this.selectPlayer({ | |
target: _8bit.clickables[this.nextIndex] | |
}); | |
this.playerSelectChanged = true; | |
} | |
} else { | |
this.playerSelectChanged = false; | |
} | |
}, | |
createPlayerTitles: function () { | |
var playerTitleData = function (player, title) { | |
var titleData = { | |
name: player + ' text', | |
color: '#9e877b', | |
fontSize: 22, | |
maxWidth: 140, | |
parent: _8bit.players[player], | |
text: ['THE', title], | |
textAlign: 'center', | |
x: 70, | |
y: 260 | |
}; | |
return titleData; | |
}; | |
_8bit.text.bolt = new _8bit.Text(playerTitleData('bolt', 'RUNNER')); | |
_8bit.text.rickie = new _8bit.Text(playerTitleData('rickie', 'GOLFER')); | |
_8bit.text.aguero = new _8bit.Text(playerTitleData('aguero', 'FOOTBALLER')); | |
_8bit.text.alonso = new _8bit.Text(playerTitleData('alonso', 'DRIVER')); | |
_8bit.text.yuvi = new _8bit.Text(playerTitleData('yuvi', 'CRICKETER')); | |
}, | |
hoverPlayer: function (e) { | |
var player = e.target; | |
_8bit.sprites.playerSelectArrow.x = _8bit.players[player.name].x + 61; | |
}, | |
selectPlayer: function (e) { | |
_8bit.scenes.playerSelect.deselectPlayers(); | |
if (_8bit.scenes.playerSelect.initSelectComplete) { | |
_8bit.sounds.swish.play(); | |
} | |
_8bit.scenes.playerSelect.initSelectComplete = true; | |
var player = e.target; | |
var _this = _8bit.scenes.playerSelect; | |
_8bit.player = _8bit.players[player.name]; | |
_8bit.player.animation = 'run'; | |
_8bit.sprites.playerSelectArrow.x = _8bit.player.x + 61; | |
_8bit.shapes.playerSelectBg.x = _8bit.players[player.name].x + 12; | |
_this.selectedIndex = _8bit.clickables.indexOf(_8bit.player); | |
_this.nextIndex = _this.selectedIndex + 1 < 5 ? _this.selectedIndex + 1 : 0; | |
_this.previousIndex = _this.selectedIndex - 1 > -1 ? _this.selectedIndex - 1 : 4; | |
}, | |
setProperties: function () { | |
_8bit.baseSpeed = 300; | |
_8bit.player.isGrounded = true; | |
_8bit.buttons.letsRace.parent = _8bit.sprites.playerBoard; | |
_8bit.buttons.letsRace.x = 275; | |
_8bit.buttons.letsRace.y = 387; | |
_8bit.players.bolt.parent = _8bit.sprites.playerBoard; | |
_8bit.players.bolt.x = 57 + (140 * 0); | |
_8bit.players.bolt.y = 88; | |
_8bit.players.rickie.parent = _8bit.sprites.playerBoard; | |
_8bit.players.rickie.x = 57 + (140 * 1); | |
_8bit.players.rickie.y = 88; | |
_8bit.players.aguero.parent = _8bit.sprites.playerBoard; | |
_8bit.players.aguero.x = 57 + (140 * 2); | |
_8bit.players.aguero.y = 88; | |
_8bit.players.alonso.parent = _8bit.sprites.playerBoard; | |
_8bit.players.alonso.x = 57 + (140 * 3); | |
_8bit.players.alonso.y = 88; | |
_8bit.players.yuvi.parent = _8bit.sprites.playerBoard; | |
_8bit.players.yuvi.x = 57 + (140 * 4); | |
_8bit.players.yuvi.y = 88; | |
_8bit.sprites.playerSelectArrow.parent = _8bit.sprites.playerBoard; | |
_8bit.sprites.playerSelectArrow.x = 50; | |
_8bit.sprites.playerSelectArrow.y = 60; | |
_8bit.shapes.playerSelectBg.parent = _8bit.sprites.playerBoard; | |
_8bit.shapes.playerSelectBg.x = _8bit.player.x + 12; | |
_8bit.shapes.playerSelectBg.y = 32; | |
}, | |
deselectPlayers: function () { | |
for (var playerName in _8bit.players) { | |
var player = _8bit.players[playerName]; | |
player.animation = 'stand'; | |
} | |
} | |
}), | |
countDown: new _8bit.Scene({ | |
init: function () { | |
PUMA.ga.trackEvent(['Game', 'Lets Race', _8bit.player.name]); | |
_8bit.sounds.music.stop(); | |
_8bit.sounds.music.hasPlayed = false; | |
_8bit.baseSpeed = 0; | |
_8bit.player.animation = 'stand'; | |
_8bit.player.lane = 2; | |
_8bit.player.laneIndex = 1; | |
_8bit.player.layer = 2; | |
_8bit.player.x = _8bit.player.lanes.x[_8bit.player.laneIndex]; | |
_8bit.player.y = _8bit.player.lanes.y[_8bit.player.laneIndex] - _8bit.player.height; | |
_8bit.player.groundY = _8bit.player.y; | |
_8bit.player.parent = false; | |
_8bit.sounds.countDown.hasPlayed = false; | |
_8bit.scenes.countDown.elapsedTime = 0; | |
_8bit.levelEngine.loadLevel(_8bit.levels.level_1); | |
this.update(); | |
}, | |
countDown: function () { | |
this.elapsedTime += _8bit.modifier; | |
if (this.elapsedTime > 1) { | |
if (!_8bit.sounds.countDown.hasPlayed) { | |
_8bit.sounds.countDown.play(); | |
_8bit.sounds.countDown.hasPlayed = true; | |
} | |
if (this.elapsedTime < 2) { | |
_8bit.sprites.countDown.animation = 'three'; | |
} else if (this.elapsedTime < 3) { | |
_8bit.sprites.countDown.animation = 'two'; | |
} else if (this.elapsedTime < 4) { | |
_8bit.sprites.countDown.animation = 'one'; | |
} else if (this.elapsedTime >= 4) { | |
if (!_8bit.sounds.music.hasPlayed) { | |
_8bit.sounds.music.play(); | |
_8bit.sounds.music.hasPlayed = true; | |
} | |
_8bit.changeScene('level_1'); | |
} | |
_8bit.sprites.countDown.update(); | |
} | |
}, | |
update: function () { | |
_8bit.levelEngine.update(); | |
_8bit.groups.background.update(); | |
_8bit.groups.hud.update(); | |
this.countDown(); | |
_8bit.player.update(); | |
if (_8bit.isTouchDevice) { | |
_8bit.buttons.up.update(); | |
_8bit.buttons.down.update(); | |
_8bit.buttons.jump.update(); | |
} | |
} | |
}), | |
level_1: new _8bit.Scene({ | |
init: function () { | |
this.name = 'level_1'; | |
this.setVars(); | |
this.bind(); | |
}, | |
bind: function () { | |
_8bit.clickables = [_8bit.buttons.jump, _8bit.buttons.down, _8bit.buttons.up]; | |
_8bit.buttons.jump.events = { | |
touchstart: function (e) { | |
_8bit.buttons.jump.animation = 'down'; | |
_8bit.touchButtonsDown['jump'] = true; | |
_8bit.player.jump(); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.jump.animation = 'up'; | |
delete _8bit.touchButtonsDown['jump']; | |
} | |
}; | |
_8bit.buttons.up.events = { | |
touchstart: function (e) { | |
_8bit.buttons.up.animation = 'down'; | |
_8bit.touchButtonsDown['up'] = true; | |
_8bit.player.changeLane(1); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.up.animation = 'up'; | |
delete _8bit.touchButtonsDown['up']; | |
} | |
}; | |
_8bit.buttons.down.events = { | |
touchstart: function (e) { | |
_8bit.buttons.down.animation = 'down'; | |
_8bit.touchButtonsDown['down'] = true; | |
_8bit.player.changeLane(-1); | |
}, | |
touchend: function (e) { | |
_8bit.buttons.down.animation = 'up'; | |
delete _8bit.touchButtonsDown['down']; | |
} | |
}; | |
_8bit.$canvas.bind({ | |
'touchstart.sceneEvents': _8bit.mouseEvents.touchstart, | |
'touchend.sceneEvents': _8bit.mouseEvents.touchend | |
}); | |
_8bit.$window.bind({ | |
'keydown.sceneEvents': _8bit.keyDown, | |
'keyup.sceneEvents': _8bit.keyUp | |
}); | |
}, | |
checkKeys: function () { | |
var upKeyIsDown = 38 in _8bit.keysDown || 'up' in _8bit.touchButtonsDown; | |
var downKeyIsDown = 40 in _8bit.keysDown || 'down' in _8bit.touchButtonsDown; | |
var spacebarIsDown = 32 in _8bit.keysDown || 'jump' in _8bit.touchButtonsDown; | |
if (upKeyIsDown) { | |
_8bit.player.changeLane(1); | |
} else if (downKeyIsDown) { | |
_8bit.player.changeLane(-1); | |
} else { | |
_8bit.player.laneChanged = false; | |
} | |
if (spacebarIsDown) { | |
_8bit.player.jumpButtonIsDown = true; | |
} else { | |
_8bit.player.jumpButtonIsDown = false; | |
if (_8bit.player.isGrounded) { | |
_8bit.player.jumpButtonReleased = true; | |
} | |
} | |
}, | |
setVars: function () { | |
_8bit.baseSpeed = 500; | |
_8bit.acceleration = 5.25; | |
_8bit.raceTime = 0; | |
_8bit.player.animation = 'run'; | |
}, | |
update: function () { | |
_8bit.baseSpeed = _8bit.baseSpeed + (_8bit.acceleration * _8bit.modifier); | |
_8bit.raceTime += _8bit.modifier; | |
_8bit.groups.background.update(); | |
_8bit.groups.hud.update(); | |
_8bit.levelEngine.update(); | |
_8bit.player.update(); | |
if (_8bit.isTouchDevice) { | |
_8bit.buttons.jump.update(); | |
_8bit.buttons.up.update(); | |
_8bit.buttons.down.update(); | |
} | |
} | |
}), | |
die: new _8bit.Scene({ | |
init: function () { | |
PUMA.ga.trackEvent(['Game', 'Game Over', 'Game Over']); | |
this.timer = 0; | |
_8bit.sounds.music.stop(); | |
_8bit.sounds.music.shouldResume = false; | |
_8bit.sounds.die.play(); | |
_8bit.sounds.gameOver.hasPlayed = false; | |
}, | |
update: function () { | |
this.timer += _8bit.modifier; | |
_8bit.groups.background.update(); | |
_8bit.groups.hud.update(); | |
_8bit.levelEngine.update(); | |
if (_8bit.player.isDead) { | |
if (!_8bit.sounds.gameOver.hasPlayed) { | |
_8bit.sounds.gameOver.play(); | |
_8bit.sounds.gameOver.hasPlayed = true; | |
} | |
_8bit.sprites.gameOver.update(); | |
if (this.timer > 5) { | |
_8bit.changeScene('endScreen'); | |
} | |
} else { | |
_8bit.baseSpeed = 0; | |
_8bit.player.update(); | |
_8bit.player.kill(); | |
} | |
} | |
}), | |
endScreen: new _8bit.Scene({ | |
init: function () { | |
this.timer = 0; | |
this.name = 'endScreen'; | |
this.createObjects(); | |
this.setProperties(); | |
this.bind(); | |
this.calculateScore(); | |
PUMA.ga.trackEvent(['Game', 'Stats', 'Time', (_8bit.raceTime | 0)]); | |
PUMA.ga.trackEvent(['Game', 'Stats', 'Medals', _8bit.medals]); | |
PUMA.ga.trackEvent(['Game', 'Stats', 'Total Points', _8bit.points.total]); | |
}, | |
bind: function () { | |
var _this = this; | |
var shopUrl = 'http://shop.puma.com/?source=marketing_PUMA_' + SITE_NAME + '_' + COUNTRY_CODE + '_game'; | |
_8bit.clickables = [_8bit.buttons.facebook, _8bit.buttons.raceAgain, _8bit.buttons.twitter, _8bit.shapes.shopPumaButton]; | |
_8bit.$window.bind({ | |
'keydown.sceneEvents': _8bit.keyDown, | |
'keyup.sceneEvents': _8bit.keyUp | |
}); | |
if (_8bit.isTouchDevice) { | |
_8bit.buttons.facebook.events = { | |
touchstart: function (e) { | |
_8bit.buttons.facebook.animation = 'down'; | |
}, | |
touchend: function (e) { | |
_8bit.buttons.facebook.animation = 'up'; | |
_this.fbShare(); | |
} | |
}; | |
_8bit.buttons.twitter.events = { | |
touchstart: function (e) { | |
_8bit.buttons.twitter.animation = 'down'; | |
}, | |
touchend: function (e) { | |
_8bit.buttons.twitter.animation = 'up'; | |
_this.tweet(); | |
} | |
}; | |
_8bit.buttons.raceAgain.events = { | |
touchstart: function (e) { | |
_8bit.buttons.raceAgain.animation = 'down'; | |
}, | |
touchend: function (e) { | |
_8bit.sounds.button.play(); | |
_8bit.buttons.raceAgain.animation = 'up'; | |
_8bit.changeScene('start'); | |
PUMA.ga.trackEvent(['Game', 'Race Again', 'Race Again']); | |
} | |
}; | |
_8bit.shapes.shopPumaButton.events = { | |
touchstart: function (e) { | |
_8bit.text.shopPuma.isHovered = true; | |
}, | |
touchend: function (e) { | |
PUMA.ga.trackEvent(['Game', 'Shop PUMA', shopUrl]); | |
_8bit.text.shopPuma.isHovered = false; | |
window.open(shopUrl); | |
} | |
}, _8bit.$canvas.bind({ | |
'touchstart.sceneEvents': _8bit.mouseEvents.touchstart, | |
'touchend.sceneEvents': _8bit.mouseEvents.touchend | |
}); | |
} else { | |
_8bit.buttons.raceAgain.events = { | |
mouseup: function (e) { | |
_8bit.buttons.raceAgain.animation = 'up'; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('start'); | |
PUMA.ga.trackEvent(['Game', 'Race Again', 'Race Again']); | |
}, | |
mousedown: function (e) { | |
_8bit.buttons.raceAgain.animation = 'down'; | |
}, | |
mouseenter: function (e) { | |
_8bit.buttons.raceAgain.animation = 'hover'; | |
}, | |
mouseleave: function (e) { | |
_8bit.buttons.raceAgain.animation = 'up'; | |
} | |
}; | |
_8bit.buttons.facebook.events = { | |
mouseup: function (e) { | |
_8bit.buttons.facebook.animation = 'up'; | |
_8bit.sounds.button.play(); | |
_this.fbShare(); | |
}, | |
mousedown: function (e) { | |
_8bit.buttons.facebook.animation = 'down'; | |
}, | |
mouseenter: function (e) { | |
_8bit.buttons.facebook.animation = 'hover'; | |
}, | |
mouseleave: function (e) { | |
_8bit.buttons.facebook.animation = 'up'; | |
} | |
}; | |
_8bit.buttons.twitter.events = { | |
mouseup: function (e) { | |
_8bit.buttons.twitter.animation = 'up'; | |
_8bit.sounds.button.play(); | |
_this.tweet(); | |
}, | |
mousedown: function (e) { | |
_8bit.buttons.twitter.animation = 'down'; | |
}, | |
mouseenter: function (e) { | |
_8bit.buttons.twitter.animation = 'hover'; | |
}, | |
mouseleave: function (e) { | |
_8bit.buttons.twitter.animation = 'up'; | |
} | |
}; | |
_8bit.shapes.shopPumaButton.events = { | |
mouseenter: function (e) { | |
_8bit.text.shopPuma.isHovered = true; | |
}, | |
mouseleave: function (e) { | |
_8bit.text.shopPuma.isHovered = false; | |
}, | |
mouseup: function (e) { | |
PUMA.ga.trackEvent(['Game', 'Shop PUMA', shopUrl]); | |
window.open(shopUrl); | |
} | |
}, _8bit.$canvas.bind({ | |
'mousedown.sceneEvents': _8bit.mouseEvents.mousedown, | |
'mouseup.sceneEvents': _8bit.mouseEvents.mouseup, | |
'mousemove.sceneEvents': _8bit.mouseEvents.hoverCheck | |
}); | |
} | |
}, | |
calculateScore: function () { | |
this.points = { | |
medal: 0, | |
time: 0, | |
total: 0 | |
}; | |
_8bit.points.medal = 500 * _8bit.medals; | |
_8bit.points.time = 150 * (_8bit.raceTime | 0); | |
_8bit.points.total = _8bit.points.medal + _8bit.points.time; | |
if (_8bit.points.total > _8bit.points.highScore) { | |
_8bit.points.highScore = _8bit.totalScore; | |
} | |
}, | |
checkKeys: function () { | |
var enterIsDown = 13 in _8bit.keysDown; | |
var enterReleased = _8bit.enterWasDown && !enterIsDown; | |
if (enterIsDown) { | |
_8bit.buttons.raceAgain.animation = 'down'; | |
_8bit.enterWasDown = true; | |
} else if (enterReleased) { | |
_8bit.buttons.raceAgain.animation = 'up'; | |
_8bit.enterWasDown = false; | |
_8bit.sounds.button.play(); | |
_8bit.changeScene('start'); | |
} | |
}, | |
createObjects: function () { | |
_8bit.text.timeLabel = new _8bit.Text({ | |
name: 'timeLabel', | |
color: '#fff', | |
fontSize: 33, | |
maxWidth: 100, | |
parent: _8bit.sprites.endScreenBoard, | |
text: ['TIME', 'MEDALS', ' ', 'TOTAL:'], | |
x: 62, | |
y: 100 | |
}); | |
_8bit.text.finalTime = new _8bit.Text({ | |
name: 'timeLabel', | |
color: '#fbe707', | |
fontSize: 33, | |
maxWidth: 100, | |
parent: _8bit.sprites.endScreenBoard, | |
text: _8bit.timeString, | |
x: 160, | |
y: 67 | |
}); | |
_8bit.text.medalTotal = new _8bit.Text({ | |
name: 'medalTotal', | |
color: '#fbe707', | |
fontSize: 33, | |
maxWidth: 100, | |
parent: _8bit.sprites.endScreenBoard, | |
text: 0, | |
x: 160, | |
y: 100 | |
}); | |
_8bit.text.medalScore = new _8bit.Text({ | |
name: 'medalScore', | |
color: '#fff', | |
fontSize: 39, | |
maxWidth: 100, | |
parent: _8bit.sprites.endScreenBoard, | |
text: 0, | |
textAlign: 'right', | |
x: 500, | |
y: 95 | |
}); | |
_8bit.text.timeScore = new _8bit.Text({ | |
name: 'timeScore', | |
color: '#fff', | |
fontSize: 39, | |
maxWidth: 260, | |
parent: _8bit.sprites.endScreenBoard, | |
text: '0', | |
textAlign: 'right', | |
x: 500, | |
y: 62 | |
}); | |
_8bit.text.totalScore = new _8bit.Text({ | |
name: 'totalScore', | |
color: '#38b5f3', | |
fontSize: 72, | |
maxWidth: 350, | |
parent: _8bit.sprites.endScreenBoard, | |
text: 0, | |
textAlign: 'right', | |
x: 500, | |
y: 155 | |
}); | |
_8bit.text.shopPuma = new _8bit.Text({ | |
name: 'shopPuma', | |
color: { | |
base: '#eee4e4', | |
hover: '#fbe707' | |
}, | |
fontSize: 30, | |
maxWidth: 130, | |
parent: _8bit.sprites.endScreenBoard, | |
text: 'SHOP PUMA', | |
textAlign: 'center', | |
x: 655, | |
y: 269 | |
}); | |
_8bit.sprites.shopPumaArrow = new _8bit.Sprite({ | |
name: 'shopPumaArrow', | |
parent: _8bit.sprites.endScreenBoard, | |
spriteSheet: _8bit.spriteSheets.gameScreens, | |
spriteLocation: { | |
x: 773, | |
y: 1660 | |
}, | |
height: 20, | |
width: 24, | |
x: 643, | |
y: 308 | |
}); | |
_8bit.shapes.shopPumaButton = new _8bit.Shape({ | |
name: 'shopPumaButton', | |
color: 'rgba(0, 0, 255, 0.0)', | |
parent: _8bit.sprites.endScreenBoard, | |
height: 60, | |
width: 130, | |
x: 590, | |
y: 270 - 35 | |
}); | |
}, | |
animateScore: function () { | |
this.timer += _8bit.modifier; | |
if (this.timer > 0.5) { | |
if (this.points.time < _8bit.points.time) { | |
this.points.time += 9000 * _8bit.modifier; | |
if (!_8bit.sounds.points.hasPlayed) { | |
_8bit.sounds.points.play(); | |
_8bit.sounds.points.hasPlayed = true; | |
} | |
} else { | |
if (!_8bit.sounds.pointsEnd.hasPlayed) { | |
_8bit.sounds.points.stop(); | |
_8bit.sounds.pointsEnd.play(); | |
_8bit.sounds.pointsEnd.hasPlayed = true; | |
} | |
this.points.time = _8bit.points.time; | |
if (this.points.medal < _8bit.points.medal) { | |
this.points.medal += 9000 * _8bit.modifier; | |
if (!_8bit.sounds.points.hasPlayed2) { | |
_8bit.sounds.points.play(); | |
_8bit.sounds.points.hasPlayed2 = true; | |
} | |
} else { | |
this.points.medal = _8bit.points.medal; | |
_8bit.sounds.points.sound.loop = false; | |
if (this.points.total < _8bit.points.total) { | |
this.points.total += 1234; | |
if (!_8bit.sounds.pointsEnd.hasPlayed2) { | |
_8bit.sounds.points.stop(); | |
_8bit.sounds.pointsEnd.play(); | |
_8bit.sounds.pointsEnd.hasPlayed2 = true; | |
} | |
} else { | |
this.points.total = _8bit.points.total; | |
} | |
} | |
} | |
} | |
_8bit.text.medalScore.text = this.points.medal | 0; | |
_8bit.text.totalScore.text = (this.points.time + this.points.medal) | 0; | |
_8bit.text.timeScore.text = this.points.time | 0; | |
}, | |
setProperties: function () { | |
_8bit.player.x = 885; | |
_8bit.player.y = 203; | |
_8bit.text.medalTotal.text = _8bit.medals; | |
_8bit.player.animation = 'cheer'; | |
_8bit.sounds.pointsEnd.hasPlayed = false; | |
_8bit.sounds.pointsEnd.hasPlayed2 = false; | |
_8bit.sounds.points.hasPlayed = false; | |
_8bit.sounds.points.hasPlayed2 = false; | |
}, | |
fbShare: function () { | |
var title = 'Run Puma Run'; | |
var url = 'http://puma.com/runpumarun'; | |
var summary = 'I just scored ' + _8bit.points.total + ' points playing RUN PUMA RUN as THE ' + _8bit.player.title + '. Think you can out-run me? Go ahead and try, champ.'; | |
var image = 'http://www.puma.com/images/run_puma_run/runpumarun-facebook-profilepic.jpg'; | |
PUMA.ga.trackSocial(['Facebook', 'Share', 'PUMA Game']); | |
window.open('http://www.facebook.com/sharer/sharer.php?s=100&p[title]=' + encodeURIComponent(title) + '&p[summary]=' + encodeURIComponent(summary) + '&p[url]=' + encodeURIComponent(url) + '&p[images][0]=' + encodeURIComponent(image)); | |
}, | |
tweet: function () { | |
PUMA.ga.trackSocial(['Twitter', 'Tweet', 'PUMA Game']); | |
var tweet = { | |
url: 'http://puma.com/runpumarun', | |
counturl: 'http://puma.com/runpumarun', | |
text: 'I just scored ' + _8bit.points.total + ' points playing RUN PUMA RUN as THE ' + _8bit.player.title + '. Think you can out-run me?', | |
hashtags: 'runpumarun' | |
}; | |
var queryString = _8bit.buildQueryString(tweet); | |
var tweetUrl = 'https://twitter.com/share?' + queryString; | |
window.open(tweetUrl); | |
}, | |
update: function () { | |
this.animateScore(); | |
_8bit.groups.background.update(); | |
_8bit.sprites.endScreenBoard.update(); | |
_8bit.text.finalTime.update(); | |
_8bit.text.timeLabel.update(); | |
_8bit.text.timeScore.update(); | |
_8bit.text.totalScore.update(); | |
_8bit.text.medalTotal.update(); | |
_8bit.text.medalScore.update(); | |
_8bit.buttons.twitter.update(); | |
_8bit.buttons.facebook.update(); | |
_8bit.buttons.raceAgain.update(); | |
_8bit.player.update(); | |
_8bit.groups.hud.update(); | |
_8bit.text.shopPuma.update(); | |
_8bit.sprites.shopPumaArrow.update(); | |
_8bit.shapes.shopPumaButton.update(); | |
} | |
}) | |
}; | |
_8bit.groups = { | |
background: new _8bit.Group({ | |
name: 'background', | |
layer: 0, | |
render: function () { | |
_8bit.prerenderCtx.fillStyle = '#38b5f3'; | |
_8bit.prerenderCtx.fillRect(0, 0, _8bit.prerenderCanvas.width, 587); | |
_8bit.prerenderCtx.fillStyle = '#63c4f4'; | |
_8bit.prerenderCtx.fillRect(0, 586, _8bit.prerenderCanvas.width, 32); | |
_8bit.prerenderCtx.fillStyle = '#67b03f'; | |
_8bit.prerenderCtx.fillRect(0, 617, _8bit.prerenderCanvas.width, 248); | |
_8bit.backgrounds.city.render(); | |
_8bit.backgrounds.cloud1.render(); | |
_8bit.backgrounds.fence.render(); | |
_8bit.backgrounds.track.render(); | |
} | |
}), | |
hud: new _8bit.Group({ | |
name: 'hud', | |
layer: 5, | |
render: function () { | |
var medals = _8bit.medals; | |
if (medals < 10) { | |
medals = '000' + medals; | |
} else if (medals < 100) { | |
medals = '00' + medals; | |
} else if (medals < 1000) { | |
medals = '0' + medals; | |
} | |
_8bit.text.medals.text = medals; | |
var time = { | |
minutes: (_8bit.raceTime / 60) | 0, | |
seconds: ((_8bit.raceTime / 60 % 1) * 60) | 0 | |
}; | |
if (time.seconds < 10) { | |
time.seconds = '0' + time.seconds; | |
} | |
_8bit.timeString = time.minutes + ':' + time.seconds; | |
_8bit.text.gameTime.text = _8bit.timeString; | |
var speedClass; | |
_8bit.points.speed = _8bit.baseSpeed > _8bit.points.speed ? _8bit.baseSpeed : _8bit.points.speed; | |
var speedLevelIncrement = 125; | |
var baseline = 500; | |
if (_8bit.points.speed < baseline + (speedLevelIncrement * 1)) { | |
speedClass = "MOLASSES"; | |
} else if (_8bit.points.speed < baseline + (speedLevelIncrement * 2)) { | |
speedClass = "NAKED IN A BAD DREAM"; | |
} else if (_8bit.points.speed < baseline + (speedLevelIncrement * 3)) { | |
speedClass = "BUSINESS CASUAL"; | |
} else if (_8bit.points.speed < baseline + (speedLevelIncrement * 4)) { | |
speedClass = "FREIGHT TRAIN"; | |
} else if (_8bit.points.speed < baseline + (speedLevelIncrement * 5)) { | |
speedClass = "DUELING BANJO"; | |
} else if (_8bit.points.speed < baseline + (speedLevelIncrement * 6)) { | |
speedClass = "PTERODACTYL"; | |
} else if (_8bit.points.speed < baseline + (speedLevelIncrement * 7)) { | |
speedClass = "LIGHTNING LEGS"; | |
} else if (_8bit.points.speed < baseline + (speedLevelIncrement * 8)) { | |
speedClass = "RIDICUPACE"; | |
} else if (_8bit.points.speed < baseline + (speedLevelIncrement * 9)) { | |
speedClass = "LUDICROUS SPEED"; | |
} else { | |
speedClass = "MUST BE CHEATIN'"; | |
} | |
_8bit.text.pace.text = speedClass; | |
_8bit.text.medals.render(); | |
_8bit.text.gameTime.render(); | |
_8bit.text.pace.render(); | |
_8bit.sprites.hearts.render(); | |
_8bit.sprites.stopwatch.render(); | |
_8bit.sprites.medalCount.render(); | |
_8bit.sprites.speedBars.render(); | |
_8bit.sprites.speedLabel.render(); | |
_8bit.sprites.lilDivider_1.render(); | |
_8bit.sprites.lilDivider_2.render(); | |
} | |
}), | |
scoreScreen: new _8bit.Group({ | |
name: 'scoreScreen', | |
layer: 5, | |
render: function () { | |
_8bit.prerenderCtx.fillStyle = "rgb(250, 250, 250)"; | |
_8bit.prerenderCtx.font = "80px VT323"; | |
_8bit.prerenderCtx.textAlign = "left"; | |
_8bit.prerenderCtx.textBaseline = "top"; | |
_8bit.prerenderCtx.fillText("Total Score: " + _8bit.score, 400, 300); | |
} | |
}) | |
}; | |
}, | |
drawCanvas: function () { | |
_8bit.prerenderCanvas = document.createElement("canvas"); | |
_8bit.prerenderCtx = _8bit.prerenderCanvas.getContext("2d"); | |
_8bit.prerenderCanvas.width = 1400; | |
_8bit.prerenderCanvas.height = 830; | |
_8bit.canvas = document.createElement("canvas"); | |
_8bit.ctx = _8bit.canvas.getContext("2d"); | |
_8bit.canvas.width = 1400; | |
_8bit.canvas.height = 830; | |
$('.canvas').html(_8bit.canvas); | |
$('.pre-render-canvas').html(_8bit.prerenderCanvas); | |
}, | |
startGame: function () { | |
_8bit.changeScene('playerSelect'); | |
}, | |
resetGame: function () { | |
_8bit.changeScene('start'); | |
}, | |
pause: function (e) { | |
if (!_8bit.isPaused) { | |
window.cancelAnimationFrame(_8bit.requestAnimationFrame); | |
_8bit.sounds.music.pause(); | |
_8bit.sounds.pause.play(); | |
_8bit.isPaused = true; | |
} | |
}, | |
unpause: function (e) { | |
if (_8bit.isPaused) { | |
_8bit.then = Date.now(); | |
_8bit.isPaused = false; | |
if (_8bit.sounds.music.shouldResume) { | |
_8bit.sounds.music.resume(); | |
} | |
_8bit.gameLoop(); | |
} | |
}, | |
togglePause: function (e) { | |
if (_8bit.isPaused) { | |
_8bit.unpause(); | |
} else { | |
_8bit.pause(); | |
} | |
}, | |
buildQueryString: function (object) { | |
var queryStringParts = []; | |
for (var key in object) { | |
var option = object[key]; | |
queryStringParts.push(key + '=' + encodeURIComponent(option)); | |
} | |
return '?' + queryStringParts.join('&'); | |
}, | |
mouseEvents: { | |
hoverCheck: function (e) { | |
_8bit.cursor = _8bit.getCursorPosition(e); | |
var objectList = _8bit.clickables; | |
var mouseEntered = false; | |
var collisions = []; | |
var hoveredLayer = -1; | |
var i = 0; | |
var hoveredObject = false; | |
trueCallback = 'onMouseenter'; | |
falseCallback = 'onMouseleave'; | |
for (i = objectList.length; i--;) { | |
var object = objectList[i]; | |
var objectIsHovered = _8bit.collision(_8bit.cursor.hitArea, object.hitAreas[0]); | |
if (objectIsHovered) { | |
hoveredObject = object; | |
if (!object.mouseEntered) { | |
object.mouseEntered = true; | |
if (object.events && object.events.mouseenter) { | |
e.target = object; | |
object.events.mouseenter(e); | |
} | |
} | |
} else if (object.mouseEntered) { | |
object.mouseEntered = false; | |
if (object.events && object.events.mouseleave) { | |
e.target = object; | |
object.events.mouseleave(e); | |
} | |
} | |
} | |
return hoveredObject; | |
}, | |
collisionCheck: function (e) { | |
_8bit.cursor = _8bit.getCursorPosition(e); | |
var objectList = _8bit.clickables; | |
var clickedObject = false; | |
var collisions = []; | |
var clickedLayer = -1; | |
var i = 0; | |
for (i = objectList.length; i--;) { | |
var object = objectList[i]; | |
var objectsAreTouching = _8bit.collision(_8bit.cursor.hitArea, object.hitAreas[0]); | |
if (objectsAreTouching) { | |
clickedObject = object; | |
} | |
} | |
if (clickedObject) { | |
for (i = collisions.length; i--;) { | |
var thisClickedObject = collisions[i]; | |
if (thisClickedObject.layer > clickedLayer) { | |
clickedLayer = thisClickedObject.layer; | |
clickedObject = thisClickedObject; | |
} | |
} | |
} | |
return clickedObject; | |
}, | |
clickCheck: function (e) { | |
var clickedObject = _8bit.mouseEvents.collisionCheck(e); | |
if (clickedObject) { | |
e.preventDefault(); | |
if (clickedObject.events && clickedObject.events.click) { | |
e.target = clickedObject; | |
clickedObject.events.click(e); | |
} | |
} | |
}, | |
mousedown: function (e) { | |
touchedObject = _8bit.mouseEvents.collisionCheck(e); | |
if (touchedObject) { | |
e.preventDefault(); | |
if (!touchedObject.isDown) { | |
e.target = touchedObject; | |
touchedObject.isDown = true; | |
_8bit.downObject = touchedObject; | |
if (touchedObject.events && touchedObject.events.mousedown) { | |
touchedObject.events.mousedown(e); | |
} | |
} | |
} else { | |
_8bit.downObject = false; | |
_8bit.downObject.isDown = false; | |
} | |
}, | |
mouseup: function (e) { | |
var releasedObject = _8bit.mouseEvents.collisionCheck(e); | |
if (releasedObject) { | |
e.preventDefault(); | |
if (releasedObject.events && releasedObject.events.mouseup && releasedObject.isDown) { | |
e.target = releasedObject; | |
releasedObject.events.mouseup(e); | |
releasedObject.isDown = false; | |
} | |
} | |
_8bit.downObject.isDown = false; | |
_8bit.downObject = false; | |
}, | |
touchstart: function (e) { | |
_8bit.touchedObject = _8bit.mouseEvents.collisionCheck(e); | |
if (_8bit.touchedObject) { | |
if (_8bit.touchedObject.events && _8bit.touchedObject.events.touchstart) { | |
e.target = _8bit.touchedObject; | |
_8bit.touchedObject.events.touchstart(e); | |
} | |
e.preventDefault(); | |
} | |
_8bit.scene.checkKeys && _8bit.scene.checkKeys(); | |
}, | |
touchend: function (e) { | |
if (_8bit.touchedObject) { | |
if (_8bit.touchedObject.events && _8bit.touchedObject.events.touchend) { | |
e.target = _8bit.touchedObject; | |
_8bit.touchedObject.events.touchend(e); | |
} | |
e.preventDefault(); | |
} | |
_8bit.scene.checkKeys && _8bit.scene.checkKeys(); | |
} | |
}, | |
collision: function (a, b) { | |
return a.x <= (b.x + b.width) && b.x <= (a.x + a.width) && a.y <= (b.y + b.height) && b.y <= (a.y + a.height); | |
}, | |
getCursorPosition: function (e) { | |
var cursor = {}; | |
if (e.offsetX || e.offsetY) { | |
cursor.x = e.offsetX; | |
cursor.y = e.offsetY; | |
} else if (e.layerX || e.layerY) { | |
if (_8bit.isTouchDevice) { | |
cursor.x = _8bit.touches.pageX - _8bit.canvas.offsetLeft; | |
cursor.y = _8bit.touches.pageY - _8bit.canvas.offsetTop; | |
} else { | |
cursor.x = e.layerX - _8bit.canvas.offsetLeft; | |
cursor.y = e.layerY - _8bit.canvas.offsetTop; | |
} | |
} else if (_8bit.isTouchDevice && e.originalEvent) { | |
var touch = e.originalEvent.touches[0]; | |
cursor.x = touch.pageX - _8bit.canvas.offsetLeft; | |
cursor.y = touch.pageY - _8bit.canvas.offsetTop; | |
} else { | |
cursor.x = e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft - _8bit.canvas.offsetLeft; | |
cursor.y = e.clientY + document.body.scrollTop + document.documentElement.scrollTop - _8bit.canvas.offsetTop; | |
} | |
cursor.hitArea = { | |
x: cursor.x * _8bit.scale, | |
y: cursor.y * _8bit.scale, | |
height: 1, | |
width: 1 | |
}; | |
return cursor; | |
}, | |
keyDown: function (e) { | |
_8bit.keysDown[e.keyCode] = true; | |
if (e.keyCode === 13 || e.keyCode === 32 || e.keyCode === 37 || e.keyCode === 38 || e.keyCode === 39 || e.keyCode === 40) { | |
_8bit.scene.checkKeys && _8bit.scene.checkKeys(); | |
e.preventDefault(); | |
} | |
}, | |
keyUp: function (e) { | |
if (e.keyCode === 13 || e.keyCode === 32 || e.keyCode === 37 || e.keyCode === 38 || e.keyCode === 39 || e.keyCode === 40) { | |
e.preventDefault(); | |
_8bit.scene.checkKeys && _8bit.scene.checkKeys(); | |
delete _8bit.keysDown[e.keyCode]; | |
} | |
}, | |
updateScale: function () { | |
_8bit.scale = _8bit.canvas.width / _8bit.canvas.offsetWidth; | |
var scaleOffset_x = (_8bit.scale - 1) * 520; | |
var scaleOffset_y = (_8bit.scale - 1) * 100; | |
var aspectRatio = _8bit.canvas.height / _8bit.canvas.width; | |
var currentWidth = _8bit.$canvas.outerWidth(); | |
var relativeHeight = (0.5 + (currentWidth * aspectRatio)) | 0; | |
_8bit.$canvas.css({ | |
'height': relativeHeight, | |
'margin-top': scaleOffset_y | |
}); | |
_8bit.sprites.stopwatch.x = _8bit.sprites.stopwatch.initial_x - scaleOffset_x; | |
_8bit.text.gameTime.x = _8bit.text.gameTime.initial_x - scaleOffset_x; | |
_8bit.sprites.lilDivider_1.x = _8bit.sprites.lilDivider_1.initial_x - scaleOffset_x; | |
_8bit.sprites.speedBars.x = _8bit.sprites.speedBars.initial_x - scaleOffset_x; | |
_8bit.sprites.speedLabel.x = _8bit.sprites.speedLabel.initial_x - scaleOffset_x; | |
_8bit.text.pace.x = _8bit.text.pace.initial_x - scaleOffset_x; | |
_8bit.text.medals.x = _8bit.text.medals.initial_x + scaleOffset_x; | |
_8bit.sprites.hearts.x = _8bit.sprites.hearts.initial_x + scaleOffset_x; | |
_8bit.sprites.medalCount.x = _8bit.sprites.medalCount.initial_x + scaleOffset_x; | |
_8bit.sprites.lilDivider_2.x = _8bit.sprites.lilDivider_2.initial_x + scaleOffset_x; | |
}, | |
pushToLayer: function (object) { | |
var layer = object.layer || 0; | |
_8bit.layers[layer] = _8bit.layers[layer] || []; | |
_8bit.layers[layer].push(object); | |
}, | |
changeScene: function (scene) { | |
_8bit.scene.destroy(); | |
_8bit.scene = _8bit.scenes[scene]; | |
_8bit.scene.init(); | |
}, | |
render: function () { | |
_8bit.layers.clean(undefined); | |
var len = _8bit.layers.length; | |
for (var i = 0; i < len; i++) { | |
var layer = _8bit.layers[i]; | |
var len2 = layer.length; | |
for (var ii = 0; ii < len2; ii++) { | |
var sprite = layer[ii]; | |
sprite.render(); | |
} | |
} | |
_8bit.layers = []; | |
if (_8bit.debug) { | |
_8bit.prerenderCtx.fillText('FPS: ' + (1000 / _8bit.delta | 0), 700, 120); | |
} | |
_8bit.ctx.drawImage(_8bit.prerenderCanvas, 0, 0); | |
}, | |
gameLoop: function () { | |
_8bit.requestAnimationFrame = window.requestAnimationFrame(function () { | |
_8bit.now = Date.now(); | |
_8bit.delta = _8bit.now - _8bit.then; | |
_8bit.modifier = _8bit.delta / 1000; | |
_8bit.scene.update(); | |
_8bit.render(); | |
_8bit.then = _8bit.now; | |
_8bit.gameLoop(); | |
}); | |
} | |
}; | |
$(document).ready(_8bit.init); | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.BaseObject = function (data) { | |
if (data) { | |
this.setData(data); | |
} | |
}; | |
_8bit.BaseObject.prototype = { | |
setData: function (data) { | |
$.extend(true, this, data); | |
if (this.spriteLocation) { | |
this.spriteLocation.startX = this.spriteLocation.x; | |
this.spriteLocation.startY = this.spriteLocation.y; | |
} | |
this.x = this.x || 0; | |
this.y = this.y || 0; | |
this.initial_x = this.x; | |
this.initial_y = this.y; | |
}, | |
setDefaults: function () { | |
this.name = this.name || 'untitled'; | |
this.x = this.x || 0; | |
this.y = this.y || 0; | |
if (this.parent) { | |
this.absolute_x = this.x + this.parent.absolute_x; | |
this.absolute_y = this.y + this.parent.absolute_y; | |
} else { | |
this.absolute_x = this.x; | |
this.absolute_y = this.y; | |
} | |
this.height = this.height || 1; | |
this.width = this.width || 1; | |
}, | |
update: function () { | |
_8bit.pushToLayer(this); | |
} | |
}; | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.Scene = function (data) { | |
this.setData(data); | |
}; | |
_8bit.Scene.prototype = new _8bit.BaseObject(); | |
$.extend(_8bit.Scene.prototype, { | |
destroy: function () { | |
_8bit.$canvas.unbind('.sceneEvents'); | |
$(window).unbind('.sceneEvents'); | |
_8bit.layers = []; | |
} | |
}); | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.SpriteSheet = function (src) { | |
this.loadImage(src); | |
this.x = 0, this.y = 0; | |
}; | |
_8bit.SpriteSheet.prototype = { | |
loadImage: function (src) { | |
var _this = this; | |
_this.ready = false; | |
_this.image = new Image(); | |
_this.image.src = src; | |
_this.image.onload = function () { | |
_this.ready = true; | |
}; | |
}, | |
render: function () { | |
if (this.ready) { | |
_8bit.prerenderCtx.drawImage(this.image, this.x, this.y); | |
} | |
} | |
}; | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.Sprite = function (data) { | |
if (data) { | |
this.setData(data); | |
} | |
}; | |
_8bit.Sprite.prototype = new _8bit.BaseObject(); | |
$.extend(_8bit.Sprite.prototype, { | |
animate: function () { | |
var animation = this.animations[this.animation]; | |
var animationJustChanged = animation !== this.lastAnimation; | |
this.animations[this.animation].timer += _8bit.modifier; | |
if (animation.sequence.length === 1 || animationJustChanged) { | |
this.spriteLocation.x = this.spriteLocation.startX + (this.width * animation.sequence[animation.i]); | |
} else if (animation.timer >= animation.spf) { | |
if (animation.i < (animation.sequence.length - 1)) { | |
animation.i++; | |
} else if (animation.loops) { | |
animation.i = 0; | |
} | |
this.spriteLocation.x = this.width * animation.sequence[animation.i]; | |
animation.timer = 0; | |
} | |
this.lastAnimation = animation; | |
}, | |
drawHitAreas: function () { | |
_8bit.prerenderCtx.fillStyle = 'rgba(0,255,255, 0.5)'; | |
for (var i = this.hitAreas.length; i--;) { | |
var hitArea = this.hitAreas[i]; | |
_8bit.prerenderCtx.fillRect(hitArea.x, hitArea.y, hitArea.width, hitArea.height); | |
} | |
}, | |
updateHitArea: function () { | |
for (var i = this.hitAreas.length; i--;) { | |
var hitArea = this.hitAreas[i], | |
offsetX = hitArea.offsetX || 0, | |
offsetY = hitArea.offsetY || 0; | |
hitArea.x = this.absolute_x + offsetX; | |
hitArea.y = this.absolute_y + offsetY - 35; | |
} | |
}, | |
render: function () { | |
if (this.parent) { | |
this.absolute_x = this.x + this.parent.absolute_x; | |
this.absolute_y = this.y + this.parent.absolute_y; | |
} else { | |
this.absolute_x = this.x; | |
this.absolute_y = this.y; | |
} | |
this.absolute_x = (0.5 + this.absolute_x) | 0; | |
this.absolute_y = (0.5 + this.absolute_y) | 0; | |
if (this.hitAreas) { | |
this.updateHitArea(); | |
} | |
if (this.spriteSheet.ready) { | |
_8bit.prerenderCtx.drawImage(this.spriteSheet.image, this.spriteLocation.x, this.spriteLocation.y, this.width, this.height, this.absolute_x, this.absolute_y - 35, this.width, this.height); | |
if (_8bit.debug === true && this.hitAreas) { | |
this.drawHitAreas(); | |
} | |
} | |
}, | |
update: function () { | |
if (this.animation) { | |
this.animate(); | |
} | |
_8bit.pushToLayer(this); | |
} | |
}); | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.Group = function (data) { | |
this.setData(data); | |
}; | |
_8bit.Group.prototype = new _8bit.BaseObject(); | |
$.extend(_8bit.Group.prototype, { | |
update: function () { | |
_8bit.pushToLayer(this); | |
} | |
}); | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.Button = function (data) { | |
this.setData(data); | |
this.type = 'Button'; | |
this.hitAreas = this.hitAreas || [{ | |
width: this.width, | |
height: this.height, | |
x: this.x, | |
y: this.y | |
}]; | |
}; | |
_8bit.Button.prototype = new _8bit.Sprite(); | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.Text = function (data) { | |
this.type = 'Text'; | |
if (data) { | |
this.setData(data); | |
} | |
this.setDefaults(); | |
}; | |
_8bit.Text.prototype = new _8bit.BaseObject(); | |
$.extend(_8bit.Text.prototype, { | |
setDefaults: function () { | |
this.name = this.name || 'untitled'; | |
this.layer = this.layer || 10; | |
this.color = this.color || '#000000'; | |
this.fontFamily = this.fontFamily || 'VT323'; | |
this.fontSize = this.fontSize || 14; | |
this.lineHeight = this.lineHeight || this.fontSize; | |
this.parent = this.parent || false; | |
this.isHovered = false; | |
this.x = this.x || 0; | |
this.y = this.y || 0; | |
this.initial_x = this.x; | |
this.initial_y = this.y; | |
this.text = this.text || ''; | |
this.textBaseline = this.textBaseline || 'top'; | |
this.firstLine = this.text instanceof Array ? this.text[0] : this.text; | |
this.maxWidth = this.maxWidth || false; | |
this.width = this.maxWidth || _8bit.prerenderCtx.measureText(this.firstLine); | |
this.textAlign = this.textAlign || 'left'; | |
if (this.parent) { | |
this.absolute_x = this.parent.absolute_x + this.x; | |
this.absolute_y = this.parent.absolute_y + this.y; | |
} else { | |
this.absolute_x = this.x; | |
this.absolute_y = this.y; | |
} | |
}, | |
render: function () { | |
var color; | |
if (typeof this.color === 'string') { | |
color = this.color; | |
} else if (this.isHovered && this.color.hover) { | |
color = this.color.hover; | |
} else if (this.color.base) { | |
color = this.color.base; | |
} | |
_8bit.prerenderCtx.fillStyle = this.isHovered && this.color.hover ? this.color.hover : this.color; | |
_8bit.prerenderCtx.font = this.fontSize + 'px ' + this.fontFamily; | |
_8bit.prerenderCtx.textAlign = this.textAlign; | |
_8bit.prerenderCtx.textBaseline = this.textBaseline; | |
if (this.parent) { | |
this.absolute_x = this.parent.absolute_x + this.x; | |
this.absolute_y = this.parent.absolute_y + this.y; | |
} else { | |
this.absolute_x = this.x; | |
this.absolute_y = this.y; | |
} | |
if (this.text instanceof Array) { | |
var len = this.text.length; | |
for (var i = 0; i < len; i++) { | |
var lineText = this.text[i]; | |
var line_y = this.absolute_y + (this.lineHeight * [i - 1]); | |
if (this.maxWidth) { | |
_8bit.prerenderCtx.fillText(lineText, this.absolute_x, line_y - 35, this.maxWidth); | |
} else { | |
_8bit.prerenderCtx.fillText(lineText, this.absolute_x, line_y - 35); | |
} | |
} | |
} else { | |
if (this.maxWidth) { | |
_8bit.prerenderCtx.fillText(this.text, this.absolute_x, this.absolute_y - 35, this.maxWidth); | |
} else { | |
_8bit.prerenderCtx.fillText(this.text, this.absolute_x, this.absolute_y - 35); | |
} | |
} | |
if (_8bit.debug === true && this.hitAreas) { | |
this.drawHitAreas(); | |
} | |
}, | |
update: function () { | |
_8bit.pushToLayer(this); | |
} | |
}); | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.Shape = function (data) { | |
this.type = 'Shape'; | |
this.setData(data); | |
this.setDefaults(); | |
}; | |
_8bit.Shape.prototype = new _8bit.BaseObject(); | |
$.extend(_8bit.Shape.prototype, { | |
setData: function (data) { | |
for (var key in data) { | |
this[key] = data[key]; | |
} | |
}, | |
setDefaults: function () { | |
this.name = this.name || 'untitled'; | |
this.color = this.color || 'transparent'; | |
this.parent = this.parent || false; | |
this.x = this.x || 0; | |
this.y = this.y || 0; | |
this.height = this.height || 20; | |
this.width = this.width || 20; | |
this.hitAreas = this.hitAreas || [{ | |
width: this.width, | |
height: this.height, | |
x: this.x, | |
y: this.y | |
}]; | |
if (this.parent) { | |
this.absolute_x = this.parent.absolute_x + this.x; | |
this.absolute_y = this.parent.absolute_y + this.y; | |
} else { | |
this.absolute_x = this.x; | |
this.absolute_y = this.y; | |
} | |
}, | |
drawHitAreas: function () { | |
_8bit.prerenderCtx.fillStyle = 'rgba(0,255,255, 0.5)'; | |
for (var i = this.hitAreas.length; i--;) { | |
var hitArea = this.hitAreas[i]; | |
_8bit.prerenderCtx.fillRect(hitArea.x, hitArea.y, hitArea.width, hitArea.height); | |
} | |
}, | |
updateHitArea: function () { | |
for (var i = this.hitAreas.length; i--;) { | |
var hitArea = this.hitAreas[i], | |
offsetX = hitArea.offsetX || 0, | |
offsetY = hitArea.offsetY || 0; | |
hitArea.x = this.absolute_x + offsetX; | |
hitArea.y = this.absolute_y + offsetY; | |
} | |
}, | |
render: function () { | |
if (this.hitAreas) { | |
this.updateHitArea(); | |
} | |
if (this.parent) { | |
this.absolute_x = this.parent.absolute_x + this.x; | |
this.absolute_y = this.parent.absolute_y + this.y; | |
} | |
if (this.color !== 'transparent') { | |
_8bit.prerenderCtx.fillStyle = this.color; | |
_8bit.prerenderCtx.fillRect(this.absolute_x, this.absolute_y - 35, this.width, this.height); | |
} | |
if (_8bit.debug === true && this.hitAreas) { | |
this.drawHitAreas(); | |
} | |
} | |
}); | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.Sound = function (src, loop) { | |
this.createElements(); | |
this.sound.preload = 'auto'; | |
this.mp3.src = src + '.mp3'; | |
this.ogg.src = src + '.ogg'; | |
if (loop) { | |
this.sound.loop = true; | |
} | |
}; | |
_8bit.Sound.prototype = { | |
play: function () { | |
if (_8bit.soundIsEnabled) { | |
var _this = this; | |
clearTimeout(_this.playTimeout); | |
this.isPlaying = true; | |
if (this.sound.readyState > 1) { | |
this.sound.currentTime = 0; | |
this.sound.play(); | |
} else { | |
this.playTimeout = setTimeout(function () { | |
_this.play(); | |
}, 20); | |
} | |
} | |
}, | |
pause: function () { | |
if (_8bit.soundIsEnabled) { | |
this.sound.pause(); | |
this.isPlaying = false; | |
} | |
}, | |
resume: function () { | |
if (_8bit.soundIsEnabled) { | |
this.sound.play(); | |
} | |
}, | |
stop: function () { | |
if (_8bit.soundIsEnabled && this.sound.readyState > 1) { | |
this.sound.pause(); | |
this.sound.currentTime = 0; | |
this.isPlaying = false; | |
} | |
}, | |
createElements: function () { | |
this.sound = document.createElement("audio"); | |
this.mp3 = document.createElement('source'); | |
this.ogg = document.createElement('source'); | |
this.sound.appendChild(this.mp3); | |
this.sound.appendChild(this.ogg); | |
} | |
}; | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
var temp; | |
_8bit.Player = function (data) { | |
this.setData(data); | |
this.setPlayerData(); | |
this.updateHitArea(); | |
this.setDefaults(); | |
}; | |
_8bit.Player.prototype = new _8bit.Sprite(); | |
$.extend(_8bit.Player.prototype, { | |
setPlayerData: function () { | |
this.type = 'Player'; | |
this.name = this.name || 'Untitled Player'; | |
this.spriteLocation = this.spriteLocation || { | |
x: 0, | |
y: 0 | |
}; | |
this.spriteSheet = this.spriteSheet || _8bit.spriteSheets.players; | |
this.lane = 2; | |
this.laneIndex = 1; | |
this.layer = 2; | |
this.lanes = { | |
x: [330, 300, 270], | |
y: [685, 715, 745] | |
}; | |
this.hitAreas = [{ | |
width: 57, | |
height: 200, | |
offsetX: 40, | |
offsetY: 20 | |
}]; | |
this.x = 300; | |
this.y = 690; | |
this.width = 140; | |
this.height = 240; | |
this.y = this.lanes.y[this.laneIndex] - this.height; | |
this.isDead = false; | |
this.isDying = false; | |
this.jumpButtonIsDown = false; | |
this.isGrounded = true; | |
this.laneChanged = false; | |
this.groundY = this.y; | |
this.jump_velocity = this.jump_velocity || 1500; | |
this.gravity = this.gravity || 3500; | |
this.y_velocity = this.jump_velocity; | |
this.animations = { | |
die: { | |
i: 0, | |
sequence: [10], | |
spf: 0.1, | |
timer: 0, | |
loops: false | |
}, | |
stand: { | |
i: 0, | |
sequence: [0], | |
spf: 0.1, | |
timer: 0, | |
loops: false | |
}, | |
run: { | |
i: 0, | |
sequence: [1, 2, 3, 4, 5, 6], | |
spf: 0.1, | |
timer: 0, | |
loops: true | |
}, | |
trip: { | |
i: 0, | |
sequence: [8, 8, 9, 9], | |
spf: 0.1, | |
timer: 0, | |
loops: true | |
}, | |
jump: { | |
i: 0, | |
sequence: [7], | |
spf: 0.1, | |
timer: 0, | |
loops: false | |
}, | |
cheer: { | |
i: 0, | |
sequence: [12, 13], | |
spf: 0.6, | |
timer: 0, | |
loops: true | |
} | |
}; | |
this.animation = 'run'; | |
}, | |
changeLane: function (direction) { | |
if ((!this.laneChanged && this.isGrounded) || ( !! this.changeLaneWhenGrounded && this.isGrounded)) { | |
this.lane -= direction; | |
if (this.lane > 3) { | |
this.lane = 3; | |
} else if (this.lane < 1) { | |
this.lane = 1; | |
} else { | |
_8bit.sounds.swish.play(); | |
} | |
this.laneIndex = this.lane - 1; | |
this.layer = this.lane; | |
this.x = this.lanes.x[this.laneIndex]; | |
this.y = this.lanes.y[this.laneIndex] - this.height; | |
this.groundY = this.y; | |
this.laneChanged = true; | |
if ( !! this.changeLaneWhenGrounded) { | |
this.laneChanged = false; | |
this.changeLaneWhenGrounded = false; | |
} | |
} else if (!this.isGrounded) { | |
this.changeLaneWhenGrounded = direction; | |
} | |
}, | |
increaseHearts: function (heart) { | |
heart.y = -1000; | |
heart.collected = true; | |
_8bit.sounds.heart.play(); | |
var maxHearts = 6; | |
_8bit.heartsLeft = _8bit.heartsLeft + 2; | |
_8bit.sprites.hearts.spriteLocation.y -= 64; | |
if (_8bit.heartsLeft > 6) { | |
_8bit.heartsLeft = 6; | |
_8bit.sprites.hearts.spriteLocation.y = 1267; | |
} | |
if (_8bit.heartsLeft === 0) { | |
_8bit.changeScene('die'); | |
return; | |
} | |
}, | |
kill: function () { | |
this.tripIsAnimating = false; | |
var frame_velocity = this.y_velocity * _8bit.modifier, | |
frame_increment = this.gravity * _8bit.modifier; | |
if (!this.isDying) { | |
this.layer = 10; | |
this.y_velocity = 1500; | |
this.animation = 'die'; | |
this.isDying = true; | |
} else if (!this.isDead && this.y < 2500) { | |
this.y_velocity = this.y_velocity - frame_increment; | |
this.y = this.y - frame_velocity; | |
} else { | |
this.layer = this.lane; | |
this.isDead = true; | |
} | |
}, | |
jump: function () { | |
var frame_velocity = this.y_velocity * _8bit.modifier, | |
frame_increment = this.gravity * _8bit.modifier; | |
if (this.jumpButtonIsDown && this.isGrounded && !this.isDying && !this.tripIsAnimating) { | |
_8bit.sounds.jump.currentTime = 0; | |
_8bit.sounds.jump.play(); | |
this.y = this.y - frame_velocity; | |
this.y_velocity = this.y_velocity - frame_increment; | |
this.isGrounded = false; | |
if (!this.tripIsAnimating && !this.isDying) { | |
this.animation = 'jump'; | |
} | |
} else if (!this.isGrounded) { | |
if (!this.jumpButtonIsDown && this.y_velocity > 0) { | |
this.y_velocity = this.y_velocity / 1.5; | |
} | |
this.y = this.y - frame_velocity; | |
this.y_velocity = this.y_velocity - frame_increment; | |
if (this.y >= this.groundY) { | |
this.y = this.groundY; | |
this.y_velocity = this.jump_velocity; | |
this.isGrounded = true; | |
if (!this.tripIsAnimating && !this.isDying) { | |
this.animation = _8bit.baseSpeed === 0 ? 'stand' : 'run'; | |
} | |
this.gravity = this.gravity; | |
if (this.changeLaneWhenGrounded) { | |
this.changeLane(this.changeLaneWhenGrounded); | |
} | |
} | |
} | |
if (this.y < 120) { | |
this.y = 120; | |
this.y_velocity = 0; | |
} | |
}, | |
collectMedal: function (medal) { | |
medal.y = -1000; | |
medal.collected = true; | |
_8bit.sounds.medal.play(); | |
_8bit.medals++; | |
}, | |
trip: function () { | |
if (!this.isDying) { | |
var _this = this; | |
this.tripIsAnimating = true; | |
_8bit.sounds.trip.play(); | |
_8bit.heartsLeft -= 1; | |
_8bit.sprites.hearts.spriteLocation.y += 32; | |
if (_8bit.heartsLeft === 0) { | |
_8bit.changeScene('die'); | |
return; | |
} | |
this.animation = 'trip'; | |
clearTimeout(_this.tripAnimationTimeout); | |
_this.tripAnimationTimeout = setTimeout(function () { | |
if (!_this.isDying) { | |
_this.animation = _this.isGrounded ? 'run' : 'jump'; | |
} | |
}, 1000); | |
} | |
}, | |
animateTrip: function () { | |
var frame_velocity = this.y_velocity * _8bit.modifier / 2, | |
frame_increment = this.gravity * _8bit.modifier * 3; | |
this.y = this.y - frame_velocity; | |
this.y_velocity = this.y_velocity - frame_increment; | |
if (this.y >= this.groundY) { | |
this.y = this.groundY; | |
this.y_velocity = this.jump_velocity; | |
this.tripIsAnimating = false; | |
} | |
}, | |
update: function () { | |
if (this.animation === 'run') { | |
this.animations[this.animation].spf = 45 / _8bit.baseSpeed; | |
} | |
if (this.jumpButtonIsDown || !this.isGrounded) { | |
this.jump(); | |
} | |
if (this.tripIsAnimating) { | |
this.animateTrip(); | |
} | |
this.animate(); | |
_8bit.pushToLayer(this); | |
} | |
}); | |
})(); | |
(function () { | |
var crowd = 'crowd', | |
startLine = 'startLine'; | |
var medal = 'medal'; | |
var bird = 'bird', | |
brick = 'brick', | |
cone = 'cone', | |
fire = 'fire', | |
hurdle_l = 'hurdle_l', | |
hurdle_m = 'hurdle_m', | |
hurdle_s = 'hurdle_s', | |
rock = 'rock', | |
heart = 'heart', | |
water = 'water'; | |
PUMA.eightBit.levels = { | |
level_1: [ | |
[, , , startLine], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[cone, , cone, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[cone, rock, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[cone, , , ], | |
[water, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, rock, , ], | |
[, , , ], | |
[medal, , cone, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, , ], | |
[, , cone, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , 'crowd_x2'], | |
[hurdle_l, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, heart, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[cone, cone, cone, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_m, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_m, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_m, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_m, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_m, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_m, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , brick, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , water, ], | |
[rock, , , ], | |
[, , , ], | |
[, , rock, ], | |
[, , rock, ], | |
[, , , ], | |
[water, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, rock, , ], | |
[, , , ], | |
[, , , ], | |
[, , rock, ], | |
[, , , ], | |
[, , , ], | |
[water, , , ], | |
[, , , ], | |
[, water, , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[rock, , water, ], | |
[, rock, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, rock, , ], | |
[, , rock, ], | |
[, , water, ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[cone, , , ], | |
[, rock, heart, ], | |
[, water, , ], | |
[, , , ], | |
[, , , ], | |
[, , bird, ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[water, rock, , ], | |
[, rock, , ], | |
[medal, , , ], | |
[, , , ], | |
[, , water, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , water, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, bird, , ], | |
[, , , ], | |
[, , , ], | |
[rock, , , ], | |
[water, , , ], | |
[, , , ], | |
[, , , ], | |
[, , rock, ], | |
[medal, , water, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, water, , ], | |
[, , , ], | |
[, cone, , ], | |
[, , cone, ], | |
[, , water, ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[cone, , , ], | |
[water, , , 'crowd_x4'], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_s, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_s, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_s, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_s, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[rock, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , water, ], | |
[, , , ], | |
[heart, , , ], | |
[, , , ], | |
[, , , ], | |
[rock, , , ], | |
[, , , ], | |
[, hurdle_m, ], | |
[, , , ], | |
[rock, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[cone, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , water, ], | |
[, rock, , ], | |
[, , brick, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , rock, ], | |
[, , cone, ], | |
[brick, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[cone, , , ], | |
[, , , ], | |
[, cone, , ], | |
[, , , ], | |
[medal, , cone, ], | |
[, , , ], | |
[, cone, , ], | |
[, , , ], | |
[cone, , , ], | |
[, , rock, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[brick, brick, brick, ], | |
[, , water, ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_s, , , ], | |
[water, , , ], | |
[, , bird, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, brick, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , heart, ], | |
[, , , ], | |
[hurdle_m, , ], | |
[, , , ], | |
[, , , ], | |
[, , brick, ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, rock, , ], | |
[, , , ], | |
[cone, , , ], | |
[brick, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, bird, , ], | |
[, , , 'crowd_x5'], | |
[, , , ], | |
[, , , ], | |
[, , bird, ], | |
[hurdle_s, , , ], | |
[water, , , ], | |
[, , rock, ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[fire], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[fire], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[fire], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[fire], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, heart, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , rock, ], | |
[, , bird, ], | |
[, , , ], | |
[bird, , , ], | |
[water, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[bird, , , ], | |
[, bird, , ], | |
[bird, , , ], | |
[, rock, , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, bird, water, ], | |
[, , , ], | |
[, bird, bird, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[bird, , , ], | |
[, , , ], | |
[rock, , medal, ], | |
[, , , ], | |
[, bird, , ], | |
[, , , ], | |
[, , , ], | |
[, cone, , ], | |
[, , bird, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[bird, , , ], | |
[water, , , ], | |
[, , , ], | |
[, , rock, ], | |
[, , bird, ], | |
[, bird, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, bird, , ], | |
[, , bird, ], | |
[bird, , , ], | |
[, heart, , ], | |
[, , , ], | |
[, bird, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[bird, , , ], | |
[water, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , 'crowd_x5'], | |
[, , , ], | |
[, , , ], | |
[, hurdle_m, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , ], | |
[rock, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_m, ], | |
[, , , ], | |
[, , ], | |
[, , , ], | |
[, , ], | |
[, , , ], | |
[cone, medal, ], | |
[, , , ], | |
[, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_m, ], | |
[, , , ], | |
[, , , ], | |
[rock, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[heart, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[water, hurdle_s, , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , water, ], | |
[, hurdle_s, , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_s, , ], | |
[bird, , , ], | |
[, , water, ], | |
[, , , ], | |
[, , rock, ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_s, , ], | |
[cone, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_s, water, ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_s, , ], | |
[rock, , , ], | |
[cone, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, hurdle_m, ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[, , water, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , brick, ], | |
[, , brick, ], | |
[, , , ], | |
[, , , ], | |
[water, , medal, ], | |
[, , , ], | |
[, , , ], | |
[, , brick, ], | |
[, , brick, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, , , ], | |
[brick, , , ], | |
[rock, , medal, ], | |
[brick, , , ], | |
[rock, , , ], | |
[, , medal, ], | |
[rock, , , ], | |
[brick, , , ], | |
[, , medal, ], | |
[brick, , , ], | |
[rock, , , ], | |
[brick, , , ], | |
[rock, , , ], | |
[brick, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[bird, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[medal, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[medal, brick, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[brick, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, , , ], | |
[, , , ], | |
[medal, , , ], | |
[, , , ], | |
[, , , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, cone, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[, brick, , ], | |
[bird, brick, , ], | |
[, , heart, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, water, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[brick, , brick, ], | |
[cone, cone, cone, ], | |
[brick, , brick, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[brick, , brick, ], | |
[cone, cone, cone, ], | |
[brick, , brick, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[brick, , brick, ], | |
[cone, cone, cone, ], | |
[brick, , brick, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[brick, , brick, ], | |
[cone, cone, cone, 'crowd_x6'], | |
[brick, , brick, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , bird, ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[water, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , medal, ], | |
[, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[medal, cone, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , bird, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, heart, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , 'crowd_x39'], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[bird, , bird, ], | |
[, medal, , ], | |
[bird, , bird, ], | |
[, medal, , ], | |
[bird, , bird, ], | |
[, medal, , ], | |
[bird, , bird, ], | |
[, medal, , ], | |
[bird, , bird, ], | |
[, medal, , ], | |
[bird, , bird, ], | |
[, medal, , ], | |
[bird, , bird, ], | |
[, medal, , ], | |
[bird, , bird, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[bird, , bird, ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[hurdle_l, ], | |
[fire, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, medal, , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[heart, heart, heart, ], | |
[heart, heart, heart, ], | |
[heart, heart, heart, ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, , , ], | |
[, ] | |
] | |
}; | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.LevelEngine = function (level) { | |
if (level) { | |
this.loadLevel(level); | |
} | |
}; | |
_8bit.LevelEngine.prototype = { | |
loadLevel: function (level) { | |
this.level = level; | |
this.rowGap = 100; | |
this.timer = 0; | |
this.i = 0; | |
this.currentRow = { | |
data: [false, false, false, false], | |
contents: [], | |
x: 300 | |
}; | |
this.laneOffset = 32; | |
this.lanes = { | |
lane_0: [], | |
lane_1: [], | |
lane_2: [], | |
lane_3: [] | |
}; | |
this.items = []; | |
this.loadNextRowIfReady(true); | |
}, | |
checkCollisions: function () { | |
var playerLane = 'lane_' + _8bit.player.lane; | |
var itemsInLane = this.lanes[playerLane]; | |
var hitObject = false; | |
for (var i = itemsInLane.length; i--;) { | |
var collision = false; | |
var item = itemsInLane[i]; | |
if (item.hitAreas) { | |
for (var ii = item.hitAreas.length; ii--;) { | |
var hitArea = item.hitAreas[ii]; | |
collision = _8bit.collision(hitArea, _8bit.player.hitAreas[0]); | |
if (collision) { | |
hitObject = item; | |
break; | |
} | |
} | |
} | |
if (hitObject) { | |
if (hitObject.name === 'medal' && !hitObject.collected) { | |
_8bit.player.collectMedal(hitObject); | |
} else if (hitObject.name === 'heart' && !hitObject.collected) { | |
_8bit.player.increaseHearts(hitObject); | |
} else if (!hitObject.collected && hitObject !== _8bit.player.lastTrippedObject) { | |
_8bit.player.trip(); | |
_8bit.player.lastTrippedObject = hitObject; | |
} | |
break; | |
} | |
} | |
}, | |
loadNextRow: function () { | |
this.currentRow = { | |
data: this.level[this.i], | |
x: this.currentRow.x + this.rowGap | |
}; | |
if (this.currentRow.x < 1400 && this.screenFilled) { | |
this.currentRow.x = 1400; | |
} | |
this.generateLaneItems(); | |
this.i = this.i < this.level.length - 1 ? this.i + 1 : 0; | |
}, | |
generateLaneItems: function () { | |
var _this = this; | |
var lane = 3; | |
var len = this.currentRow.data.length; | |
for (var i = 0; i < len; i++) { | |
var itemName = this.currentRow.data[i]; | |
if (itemName) { | |
var item = _this.generateItem(itemName, lane); | |
if (item.span) { | |
lane = lane - (item.span - 1); | |
} | |
} | |
lane--; | |
} | |
}, | |
generateItem: function (itemName, lane) { | |
var repeatNumber = false; | |
if (lane === 0 && itemName.indexOf('_x') >= 0) { | |
repeatNumber = itemName.split('_x')[1]; | |
itemName = itemName.split('_x')[0]; | |
} | |
var item = new _8bit.Sprite(_8bit.levelItems[itemName]); | |
var i = 0; | |
item.name = itemName; | |
item.spriteSheet = item.spriteSheet || _8bit.spriteSheets.obstacles; | |
item.offset = item.offset || 0; | |
item.speed = item.speed || 1; | |
item.repeat = repeatNumber || false; | |
item.repeatOffset = item.repeatOffset || 0; | |
item.lanes = [lane]; | |
if (item.span) { | |
for (i = 0; i < item.span - 1; i++) { | |
lane--; | |
item.lanes.push(lane); | |
} | |
} | |
this.setLaneData(item); | |
this.setItemPosition(item); | |
this.items.push(item); | |
for (i = item.lanes.length; i--;) { | |
var thisLane = 'lane_' + item.lanes[i]; | |
this.lanes[thisLane].push(item); | |
} | |
if (item.repeat) { | |
this.repeatItem(item); | |
} | |
return item; | |
}, | |
repeatItem: function (item) { | |
for (var i = 1; i < item.repeat; i++) { | |
var clone = $.extend(true, {}, item); | |
clone.x = clone.x + (item.repeatOffset * i) + (clone.width * i); | |
this.items.push(clone); | |
} | |
}, | |
loadNextRowIfReady: function (autofill) { | |
var timeToGenerate = this.currentRow.x < 3000; | |
if (timeToGenerate) { | |
this.loadNextRow(); | |
if (autofill) { | |
this.loadNextRowIfReady(autofill); | |
} else { | |
this.screenFilled = true; | |
} | |
} | |
}, | |
moveItem: function (item) { | |
var offset = _8bit.baseSpeed * _8bit.modifier * item.speed; | |
item.x -= offset; | |
}, | |
setLaneData: function (item) { | |
var notLaneItem = item.lanes[0] === 0; | |
var lane_1 = item.lanes.indexOf(1) >= 0 || false; | |
var lane_2 = item.lanes.indexOf(2) >= 0 || false; | |
var lane_3 = item.lanes.indexOf(3) >= 0 || false; | |
var layer; | |
if (lane_1 && lane_2 && lane_3) { | |
item.laneIndex = 3; | |
layer = 1; | |
} else if (lane_1 && lane_2) { | |
item.laneIndex = 2; | |
layer = 2; | |
} else if (lane_2 && lane_3) { | |
item.laneIndex = 3; | |
layer = 3; | |
} else if (notLaneItem) { | |
item.laneIndex = 0; | |
layer = 1; | |
} else { | |
item.laneIndex = item.lanes[0]; | |
layer = item.laneIndex; | |
} | |
item.layer = item.hasOwnProperty('layer') ? item.layer : layer; | |
}, | |
setItemPosition: function (item) { | |
var isometricOffset = 0; | |
var isLaneItem = item.lanes[0] !== 0; | |
if (item.lanes[0] === 1) { | |
isometricOffset = 64; | |
} else if (item.lanes[0] === 2) { | |
isometricOffset = 32; | |
} | |
item.x = this.currentRow.x + isometricOffset; | |
if (isLaneItem) { | |
item.y = 738 - isometricOffset - item.height + item.offset; | |
} | |
}, | |
update: function () { | |
this.updateItems(); | |
this.checkCollisions(); | |
this.loadNextRowIfReady(); | |
}, | |
updateItems: function () { | |
var anyOffScreen = false; | |
var item; | |
var thisIsOffScreen = false; | |
this.currentRow.x -= _8bit.baseSpeed * _8bit.modifier; | |
var len = this.items.length; | |
for (i = 0; i < len; i++) { | |
item = this.items[i]; | |
this.moveItem(item); | |
if (item.animation) { | |
item.animate(); | |
} | |
thisIsOffScreen = item.x < -item.width; | |
if (thisIsOffScreen) { | |
anyOffScreen = true; | |
delete this.items[i]; | |
} else { | |
_8bit.pushToLayer(item); | |
} | |
} | |
if (anyOffScreen) { | |
for (var laneKey in this.lanes) { | |
var lane = this.lanes[laneKey]; | |
for (var i = lane.length; i--;) { | |
item = lane[i]; | |
thisIsOffScreen = item.x < -item.width; | |
if (thisIsOffScreen) { | |
anyOffScreen = true; | |
delete lane[i]; | |
} | |
} | |
lane.clean(undefined); | |
} | |
this.items.clean(undefined); | |
anyOffScreen = false; | |
} | |
} | |
}; | |
})(); | |
var PUMA = PUMA || {}; | |
(function () { | |
var _8bit = PUMA.eightBit; | |
_8bit.BackgroundGenerator = function (data) { | |
this.selectBackground(data); | |
this.initializeSpritesArray(); | |
this.createSprites(); | |
}; | |
_8bit.BackgroundGenerator.prototype = { | |
createSprites: function () { | |
var _this = this, | |
tilesToSpanCanvas = _8bit.prerenderCanvas.width / this.repeatLength, | |
tilesRequiredToLoop = ((0.999 + tilesToSpanCanvas) | 0) + 1; | |
for (var i = 0; i < tilesRequiredToLoop; i++) { | |
_this.generate(); | |
} | |
}, | |
initializeSpritesArray: function () { | |
this.sprites = []; | |
this.generate(); | |
this.sprites[0].x = this.spriteData.x; | |
}, | |
selectBackground: function (data) { | |
this.spriteData = data; | |
this.name = data.name; | |
this.repeatLength = data.repeatLength; | |
this.speed = data.speed; | |
}, | |
render: function () { | |
var _this = this; | |
_this.update(); | |
var len = _this.sprites.length; | |
for (i = 0; i < len; i++) { | |
var sprite = _this.sprites[i]; | |
if (sprite.animation) { | |
sprite.animate(); | |
} | |
sprite.render(); | |
} | |
}, | |
update: function () { | |
var _this = this, | |
first_x = 0, | |
anyOffscreen = false; | |
this.deletedSprites = 0; | |
var len = _this.sprites.length; | |
for (i = 0; i < len; i++) { | |
var sprite = _this.sprites[i], | |
offset = (this.speed * _8bit.baseSpeed) * _8bit.modifier; | |
if (i === 0) { | |
sprite.x = sprite.x - offset; | |
first_x = sprite.x; | |
} else { | |
sprite.x = first_x + (this.repeatLength * i); | |
} | |
if (sprite.x < -sprite.width) { | |
anyOffscreen = true; | |
delete _this.sprites[i]; | |
this.deletedSprites++; | |
} | |
} | |
if (anyOffscreen) { | |
_this.sprites.clean(undefined); | |
this.replaceRemovedSprites(); | |
} | |
}, | |
generate: function () { | |
var sprite = new _8bit.Sprite(this.spriteData); | |
sprite.spriteSheet = _8bit.spriteSheets.backgrounds; | |
sprite.x = 1400; | |
sprite.y = this.spriteData.y; | |
this.sprites.push(sprite); | |
}, | |
replaceRemovedSprites: function () { | |
var _this = this; | |
for (i = 0; i < this.deletedSprites; i++) { | |
_this.generate(); | |
} | |
} | |
}; | |
})(); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment