Skip to content

Instantly share code, notes, and snippets.

@zmaril
Created July 18, 2012 14:24
Show Gist options
  • Save zmaril/3136483 to your computer and use it in GitHub Desktop.
Save zmaril/3136483 to your computer and use it in GitHub Desktop.
Puma.com source code
(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