Created
May 31, 2011 08:11
-
-
Save patrickkettner/1000151 to your computer and use it in GitHub Desktop.
jquery translate party - javascript to coffescript and back again
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
jQuery source used | |
/*! | |
* jQuery JavaScript Library v1.4.2 | |
* http://jquery.com/ | |
* | |
* Copyright 2010, John Resig | |
* Dual licensed under the MIT or GPL Version 2 licenses. | |
* http://jquery.org/license | |
* | |
* Includes Sizzle.js | |
* http://sizzlejs.com/ | |
* Copyright 2010, The Dojo Foundation | |
* Released under the MIT, BSD, and GPL Licenses. | |
* | |
* Date: Sat Feb 13 22:33:48 2010 -0500 | |
*/ | |
(function(A, w) { | |
function ma() { | |
if (!c.isReady) { | |
try { | |
s.documentElement.doScroll("left") | |
} catch (a) { | |
setTimeout(ma, 1); | |
return | |
} | |
c.ready() | |
} | |
} | |
function Qa(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 X(a, b, d, f, e, j) { | |
var i = a.length; | |
if (typeof b === "object") { | |
for (var o in b) | |
X(a, o, b[o], f, e, d); | |
return a | |
} | |
if (d !== w) { | |
f = !j && f && c.isFunction(d); | |
for (o = 0; o < i; o++) | |
e(a[o], b, f ? d.call(a[o], o, e(a[o], b)) : d, j); | |
return a | |
} | |
return i ? | |
e(a[0], b) : w | |
} | |
function J() { | |
return (new Date).getTime() | |
} | |
function Y() { | |
return false | |
} | |
function Z() { | |
return true | |
} | |
function na(a, b, d) { | |
d[0].type = a; | |
return c.event.handle.apply(b, d) | |
} | |
function oa(a) { | |
var b, d = [], f = [], e = arguments, j, i, o, k, n, r; | |
i = c.data(this, "events"); | |
if (!(a.liveFired === this || !i || !i.live || a.button && a.type === "click")) { | |
a.liveFired = this; | |
var u = i.live.slice(0); | |
for (k = 0; k < u.length; k++) { | |
i = u[k]; | |
i.origType.replace(O, "") === a.type ? f.push(i.selector) : u.splice(k--, 1) | |
} | |
j = c(a.target).closest(f, a.currentTarget); | |
n = 0; | |
for (r = | |
j.length; n < r; n++) | |
for (k = 0; k < u.length; k++) { | |
i = u[k]; | |
if (j[n].selector === i.selector) { | |
o = j[n].elem; | |
f = null; | |
if (i.preType === "mouseenter" || i.preType === "mouseleave") | |
f = c(a.relatedTarget).closest(i.selector)[0]; | |
if (!f || f !== o) | |
d.push({elem: o,handleObj: i}) | |
} | |
} | |
n = 0; | |
for (r = d.length; n < r; n++) { | |
j = d[n]; | |
a.currentTarget = j.elem; | |
a.data = j.handleObj.data; | |
a.handleObj = j.handleObj; | |
if (j.handleObj.origHandler.apply(j.elem, e) === false) { | |
b = false; | |
break | |
} | |
} | |
return b | |
} | |
} | |
function pa(a, b) { | |
return "live." + (a && a !== "*" ? a + "." : "") + b.replace(/\./g, "`").replace(/ /g, | |
"&") | |
} | |
function qa(a) { | |
return !a || !a.parentNode || a.parentNode.nodeType === 11 | |
} | |
function ra(a, b) { | |
var d = 0; | |
b.each(function() { | |
if (this.nodeName === (a[d] && a[d].nodeName)) { | |
var f = c.data(a[d++]), e = c.data(this, f); | |
if (f = f && f.events) { | |
delete e.handle; | |
e.events = {}; | |
for (var j in f) | |
for (var i in f[j]) | |
c.event.add(this, j, f[j][i], f[j][i].data) | |
} | |
} | |
}) | |
} | |
function sa(a, b, d) { | |
var f, e, j; | |
b = b && b[0] ? b[0].ownerDocument || b[0] : s; | |
if (a.length === 1 && typeof a[0] === "string" && a[0].length < 512 && b === s && !ta.test(a[0]) && (c.support.checkClone || !ua.test(a[0]))) { | |
e = | |
true; | |
if (j = c.fragments[a[0]]) | |
if (j !== 1) | |
f = j | |
} | |
if (!f) { | |
f = b.createDocumentFragment(); | |
c.clean(a, b, f, d) | |
} | |
if (e) | |
c.fragments[a[0]] = j ? f : 1; | |
return {fragment: f,cacheable: e} | |
} | |
function K(a, b) { | |
var d = {}; | |
c.each(va.concat.apply([], va.slice(0, b)), function() { | |
d[this] = a | |
}); | |
return d | |
} | |
function wa(a) { | |
return "scrollTo" in a && a.document ? a : a.nodeType === 9 ? a.defaultView || a.parentWindow : false | |
} | |
var c = function(a, b) { | |
return new c.fn.init(a, b) | |
}, Ra = A.jQuery, Sa = A.$, s = A.document, T, Ta = /^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/, Ua = /^.[^:#\[\.,]*$/, Va = /\S/, | |
Wa = /^(\s|\u00A0)+|(\s|\u00A0)+$/g, Xa = /^<(\w+)\s*\/?>(?:<\/\1>)?$/, P = navigator.userAgent, xa = false, Q = [], L, $ = Object.prototype.toString, aa = Object.prototype.hasOwnProperty, ba = Array.prototype.push, R = Array.prototype.slice, ya = Array.prototype.indexOf; | |
c.fn = c.prototype = {init: function(a, b) { | |
var d, f; | |
if (!a) | |
return this; | |
if (a.nodeType) { | |
this.context = this[0] = a; | |
this.length = 1; | |
return this | |
} | |
if (a === "body" && !b) { | |
this.context = s; | |
this[0] = s.body; | |
this.selector = "body"; | |
this.length = 1; | |
return this | |
} | |
if (typeof a === "string") | |
if ((d = Ta.exec(a)) && | |
(d[1] || !b)) | |
if (d[1]) { | |
f = b ? b.ownerDocument || b : s; | |
if (a = Xa.exec(a)) | |
if (c.isPlainObject(b)) { | |
a = [s.createElement(a[1])]; | |
c.fn.attr.call(a, b, true) | |
} else | |
a = [f.createElement(a[1])]; | |
else { | |
a = sa([d[1]], [f]); | |
a = (a.cacheable ? a.fragment.cloneNode(true) : a.fragment).childNodes | |
} | |
return c.merge(this, a) | |
} else { | |
if (b = s.getElementById(d[2])) { | |
if (b.id !== d[2]) | |
return T.find(a); | |
this.length = 1; | |
this[0] = b | |
} | |
this.context = s; | |
this.selector = a; | |
return this | |
} | |
else if (!b && /^\w+$/.test(a)) { | |
this.selector = a; | |
this.context = s; | |
a = s.getElementsByTagName(a); | |
return c.merge(this, | |
a) | |
} else | |
return !b || b.jquery ? (b || T).find(a) : c(b).find(a); | |
else if (c.isFunction(a)) | |
return T.ready(a); | |
if (a.selector !== w) { | |
this.selector = a.selector; | |
this.context = a.context | |
} | |
return c.makeArray(a, this) | |
},selector: "",jquery: "1.4.2",length: 0,size: function() { | |
return this.length | |
},toArray: function() { | |
return R.call(this, 0) | |
},get: function(a) { | |
return a == null ? this.toArray() : a < 0 ? this.slice(a)[0] : this[a] | |
},pushStack: function(a, b, d) { | |
var f = c(); | |
c.isArray(a) ? ba.apply(f, a) : c.merge(f, a); | |
f.prevObject = this; | |
f.context = this.context; | |
if (b === | |
"find") | |
f.selector = this.selector + (this.selector ? " " : "") + d; | |
else if (b) | |
f.selector = this.selector + "." + b + "(" + d + ")"; | |
return f | |
},each: function(a, b) { | |
return c.each(this, a, b) | |
},ready: function(a) { | |
c.bindReady(); | |
if (c.isReady) | |
a.call(s, c); | |
else | |
Q && Q.push(a); | |
return this | |
},eq: function(a) { | |
return a === -1 ? this.slice(a) : this.slice(a, +a + 1) | |
},first: function() { | |
return this.eq(0) | |
},last: function() { | |
return this.eq(-1) | |
},slice: function() { | |
return this.pushStack(R.apply(this, arguments), "slice", R.call(arguments).join(",")) | |
},map: function(a) { | |
return this.pushStack(c.map(this, | |
function(b, d) { | |
return a.call(b, d, b) | |
})) | |
},end: function() { | |
return this.prevObject || c(null) | |
},push: ba,sort: [].sort,splice: [].splice}; | |
c.fn.init.prototype = c.fn; | |
c.extend = c.fn.extend = function() { | |
var a = arguments[0] || {}, b = 1, d = arguments.length, f = false, e, j, i, o; | |
if (typeof a === "boolean") { | |
f = a; | |
a = arguments[1] || {}; | |
b = 2 | |
} | |
if (typeof a !== "object" && !c.isFunction(a)) | |
a = {}; | |
if (d === b) { | |
a = this; | |
--b | |
} | |
for (; b < d; b++) | |
if ((e = arguments[b]) != null) | |
for (j in e) { | |
i = a[j]; | |
o = e[j]; | |
if (a !== o) | |
if (f && o && (c.isPlainObject(o) || c.isArray(o))) { | |
i = i && (c.isPlainObject(i) || | |
c.isArray(i)) ? i : c.isArray(o) ? [] : {}; | |
a[j] = c.extend(f, i, o) | |
} else if (o !== w) | |
a[j] = o | |
} | |
return a | |
}; | |
c.extend({noConflict: function(a) { | |
A.$ = Sa; | |
if (a) | |
A.jQuery = Ra; | |
return c | |
},isReady: false,ready: function() { | |
if (!c.isReady) { | |
if (!s.body) | |
return setTimeout(c.ready, 13); | |
c.isReady = true; | |
if (Q) { | |
for (var a, b = 0; a = Q[b++]; ) | |
a.call(s, c); | |
Q = null | |
} | |
c.fn.triggerHandler && c(s).triggerHandler("ready") | |
} | |
},bindReady: function() { | |
if (!xa) { | |
xa = true; | |
if (s.readyState === "complete") | |
return c.ready(); | |
if (s.addEventListener) { | |
s.addEventListener("DOMContentLoaded", | |
L, false); | |
A.addEventListener("load", c.ready, false) | |
} else if (s.attachEvent) { | |
s.attachEvent("onreadystatechange", L); | |
A.attachEvent("onload", c.ready); | |
var a = false; | |
try { | |
a = A.frameElement == null | |
} catch (b) { | |
} | |
s.documentElement.doScroll && a && ma() | |
} | |
} | |
},isFunction: function(a) { | |
return $.call(a) === "[object Function]" | |
},isArray: function(a) { | |
return $.call(a) === "[object Array]" | |
},isPlainObject: function(a) { | |
if (!a || $.call(a) !== "[object Object]" || a.nodeType || a.setInterval) | |
return false; | |
if (a.constructor && !aa.call(a, "constructor") && !aa.call(a.constructor.prototype, | |
"isPrototypeOf")) | |
return false; | |
var b; | |
for (b in a) | |
; | |
return b === w || aa.call(a, b) | |
},isEmptyObject: function(a) { | |
for (var b in a) | |
return false; | |
return true | |
},error: function(a) { | |
throw a; | |
},parseJSON: function(a) { | |
if (typeof a !== "string" || !a) | |
return null; | |
a = c.trim(a); | |
if (/^[\],:{}\s]*$/.test(a.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, "@").replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, "]").replace(/(?:^|:|,)(?:\s*\[)+/g, ""))) | |
return A.JSON && A.JSON.parse ? A.JSON.parse(a) : (new Function("return " + | |
a))(); | |
else | |
c.error("Invalid JSON: " + a) | |
},noop: function() { | |
},globalEval: function(a) { | |
if (a && Va.test(a)) { | |
var b = s.getElementsByTagName("head")[0] || s.documentElement, d = s.createElement("script"); | |
d.type = "text/javascript"; | |
if (c.support.scriptEval) | |
d.appendChild(s.createTextNode(a)); | |
else | |
d.text = a; | |
b.insertBefore(d, b.firstChild); | |
b.removeChild(d) | |
} | |
},nodeName: function(a, b) { | |
return a.nodeName && a.nodeName.toUpperCase() === b.toUpperCase() | |
},each: function(a, b, d) { | |
var f, e = 0, j = a.length, i = j === w || c.isFunction(a); | |
if (d) | |
if (i) | |
for (f in a) { | |
if (b.apply(a[f], | |
d) === false) | |
break | |
} | |
else | |
for (; e < j; ) { | |
if (b.apply(a[e++], d) === false) | |
break | |
} | |
else if (i) | |
for (f in a) { | |
if (b.call(a[f], f, a[f]) === false) | |
break | |
} | |
else | |
for (d = a[0]; e < j && b.call(d, e, d) !== false; d = a[++e]) | |
; | |
return a | |
},trim: function(a) { | |
return (a || "").replace(Wa, "") | |
},makeArray: function(a, b) { | |
b = b || []; | |
if (a != null) | |
a.length == null || typeof a === "string" || c.isFunction(a) || typeof a !== "function" && a.setInterval ? ba.call(b, a) : c.merge(b, a); | |
return b | |
},inArray: function(a, b) { | |
if (b.indexOf) | |
return b.indexOf(a); | |
for (var d = 0, f = b.length; d < f; d++) | |
if (b[d] === | |
a) | |
return d; | |
return -1 | |
},merge: function(a, b) { | |
var d = a.length, f = 0; | |
if (typeof b.length === "number") | |
for (var e = b.length; f < e; f++) | |
a[d++] = b[f]; | |
else | |
for (; b[f] !== w; ) | |
a[d++] = b[f++]; | |
a.length = d; | |
return a | |
},grep: function(a, b, d) { | |
for (var f = [], e = 0, j = a.length; e < j; e++) | |
!d !== !b(a[e], e) && f.push(a[e]); | |
return f | |
},map: function(a, b, d) { | |
for (var f = [], e, j = 0, i = a.length; j < i; j++) { | |
e = b(a[j], j, d); | |
if (e != null) | |
f[f.length] = e | |
} | |
return f.concat.apply([], f) | |
},guid: 1,proxy: function(a, b, d) { | |
if (arguments.length === 2) | |
if (typeof b === "string") { | |
d = a; | |
a = d[b]; | |
b = w | |
} else if (b && | |
!c.isFunction(b)) { | |
d = b; | |
b = w | |
} | |
if (!b && a) | |
b = function() { | |
return a.apply(d || this, arguments) | |
}; | |
if (a) | |
b.guid = a.guid = a.guid || b.guid || c.guid++; | |
return b | |
},uaMatch: function(a) { | |
a = a.toLowerCase(); | |
a = /(webkit)[ \/]([\w.]+)/.exec(a) || /(opera)(?:.*version)?[ \/]([\w.]+)/.exec(a) || /(msie) ([\w.]+)/.exec(a) || !/compatible/.test(a) && /(mozilla)(?:.*? rv:([\w.]+))?/.exec(a) || []; | |
return {browser: a[1] || "",version: a[2] || "0"} | |
},browser: {}}); | |
P = c.uaMatch(P); | |
if (P.browser) { | |
c.browser[P.browser] = true; | |
c.browser.version = P.version | |
} | |
if (c.browser.webkit) | |
c.browser.safari = | |
true; | |
if (ya) | |
c.inArray = function(a, b) { | |
return ya.call(b, a) | |
}; | |
T = c(s); | |
if (s.addEventListener) | |
L = function() { | |
s.removeEventListener("DOMContentLoaded", L, false); | |
c.ready() | |
}; | |
else if (s.attachEvent) | |
L = function() { | |
if (s.readyState === "complete") { | |
s.detachEvent("onreadystatechange", L); | |
c.ready() | |
} | |
}; | |
(function() { | |
c.support = {}; | |
var a = s.documentElement, b = s.createElement("script"), d = s.createElement("div"), f = "script" + J(); | |
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 e = d.getElementsByTagName("*"), j = d.getElementsByTagName("a")[0]; | |
if (!(!e || !e.length || !j)) { | |
c.support = {leadingWhitespace: d.firstChild.nodeType === 3,tbody: !d.getElementsByTagName("tbody").length,htmlSerialize: !!d.getElementsByTagName("link").length,style: /red/.test(j.getAttribute("style")),hrefNormalized: j.getAttribute("href") === "/a",opacity: /^0.55$/.test(j.style.opacity),cssFloat: !!j.style.cssFloat,checkOn: d.getElementsByTagName("input")[0].value === "on",optSelected: s.createElement("select").appendChild(s.createElement("option")).selected, | |
parentNode: d.removeChild(d.appendChild(s.createElement("div"))).parentNode === null,deleteExpando: true,checkClone: false,scriptEval: false,noCloneEvent: true,boxModel: null}; | |
b.type = "text/javascript"; | |
try { | |
b.appendChild(s.createTextNode("window." + f + "=1;")) | |
} catch (i) { | |
} | |
a.insertBefore(b, a.firstChild); | |
if (A[f]) { | |
c.support.scriptEval = true; | |
delete A[f] | |
} | |
try { | |
delete b.test | |
} catch (o) { | |
c.support.deleteExpando = false | |
} | |
a.removeChild(b); | |
if (d.attachEvent && d.fireEvent) { | |
d.attachEvent("onclick", function k() { | |
c.support.noCloneEvent = | |
false; | |
d.detachEvent("onclick", k) | |
}); | |
d.cloneNode(true).fireEvent("onclick") | |
} | |
d = s.createElement("div"); | |
d.innerHTML = "<input type='radio' name='radiotest' checked='checked'/>"; | |
a = s.createDocumentFragment(); | |
a.appendChild(d.firstChild); | |
c.support.checkClone = a.cloneNode(true).cloneNode(true).lastChild.checked; | |
c(function() { | |
var k = s.createElement("div"); | |
k.style.width = k.style.paddingLeft = "1px"; | |
s.body.appendChild(k); | |
c.boxModel = c.support.boxModel = k.offsetWidth === 2; | |
s.body.removeChild(k).style.display = "none" | |
}); | |
a = function(k) { | |
var n = | |
s.createElement("div"); | |
k = "on" + k; | |
var r = k in n; | |
if (!r) { | |
n.setAttribute(k, "return;"); | |
r = typeof n[k] === "function" | |
} | |
return r | |
}; | |
c.support.submitBubbles = a("submit"); | |
c.support.changeBubbles = a("change"); | |
a = b = d = e = j = null | |
} | |
})(); | |
c.props = {"for": "htmlFor","class": "className",readonly: "readOnly",maxlength: "maxLength",cellspacing: "cellSpacing",rowspan: "rowSpan",colspan: "colSpan",tabindex: "tabIndex",usemap: "useMap",frameborder: "frameBorder"}; | |
var G = "jQuery" + J(), Ya = 0, za = {}; | |
c.extend({cache: {},expando: G,noData: {embed: true,object: true, | |
applet: true},data: function(a, b, d) { | |
if (!(a.nodeName && c.noData[a.nodeName.toLowerCase()])) { | |
a = a == A ? za : a; | |
var f = a[G], e = c.cache; | |
if (!f && typeof b === "string" && d === w) | |
return null; | |
f || (f = ++Ya); | |
if (typeof b === "object") { | |
a[G] = f; | |
e[f] = c.extend(true, {}, b) | |
} else if (!e[f]) { | |
a[G] = f; | |
e[f] = {} | |
} | |
a = e[f]; | |
if (d !== w) | |
a[b] = d; | |
return typeof b === "string" ? a[b] : a | |
} | |
},removeData: function(a, b) { | |
if (!(a.nodeName && c.noData[a.nodeName.toLowerCase()])) { | |
a = a == A ? za : a; | |
var d = a[G], f = c.cache, e = f[d]; | |
if (b) { | |
if (e) { | |
delete e[b]; | |
c.isEmptyObject(e) && c.removeData(a) | |
} | |
} else { | |
if (c.support.deleteExpando) | |
delete a[c.expando]; | |
else | |
a.removeAttribute && a.removeAttribute(c.expando); | |
delete f[d] | |
} | |
} | |
}}); | |
c.fn.extend({data: function(a, b) { | |
if (typeof a === "undefined" && this.length) | |
return c.data(this[0]); | |
else if (typeof a === "object") | |
return this.each(function() { | |
c.data(this, a) | |
}); | |
var d = a.split("."); | |
d[1] = d[1] ? "." + d[1] : ""; | |
if (b === w) { | |
var f = this.triggerHandler("getData" + d[1] + "!", [d[0]]); | |
if (f === w && this.length) | |
f = c.data(this[0], a); | |
return f === w && d[1] ? this.data(d[0]) : f | |
} else | |
return this.trigger("setData" + d[1] + "!", [d[0], b]).each(function() { | |
c.data(this, | |
a, b) | |
}) | |
},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 f = c.data(a, b); | |
if (!d) | |
return f || []; | |
if (!f || c.isArray(d)) | |
f = c.data(a, b, c.makeArray(d)); | |
else | |
f.push(d); | |
return f | |
} | |
},dequeue: function(a, b) { | |
b = b || "fx"; | |
var d = c.queue(a, b), f = d.shift(); | |
if (f === "inprogress") | |
f = d.shift(); | |
if (f) { | |
b === "fx" && d.unshift("inprogress"); | |
f.call(a, function() { | |
c.dequeue(a, b) | |
}) | |
} | |
}}); | |
c.fn.extend({queue: function(a, b) { | |
if (typeof a !== "string") { | |
b = a; | |
a = "fx" | |
} | |
if (b === | |
w) | |
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 Aa = /[\n\t]/g, ca = /\s+/, Za = /\r/g, $a = /href|src|style/, ab = /(button|input)/i, bb = /(button|input|object|select|textarea)/i, | |
cb = /^(a|area)$/i, Ba = /radio|checkbox/; | |
c.fn.extend({attr: function(a, b) { | |
return X(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(n) { | |
var r = c(this); | |
r.addClass(a.call(this, n, r.attr("class"))) | |
}); | |
if (a && typeof a === "string") | |
for (var b = (a || "").split(ca), d = 0, f = this.length; d < f; d++) { | |
var e = this[d]; | |
if (e.nodeType === 1) | |
if (e.className) { | |
for (var j = " " + e.className + " ", | |
i = e.className, o = 0, k = b.length; o < k; o++) | |
if (j.indexOf(" " + b[o] + " ") < 0) | |
i += " " + b[o]; | |
e.className = c.trim(i) | |
} else | |
e.className = a | |
} | |
return this | |
},removeClass: function(a) { | |
if (c.isFunction(a)) | |
return this.each(function(k) { | |
var n = c(this); | |
n.removeClass(a.call(this, k, n.attr("class"))) | |
}); | |
if (a && typeof a === "string" || a === w) | |
for (var b = (a || "").split(ca), d = 0, f = this.length; d < f; d++) { | |
var e = this[d]; | |
if (e.nodeType === 1 && e.className) | |
if (a) { | |
for (var j = (" " + e.className + " ").replace(Aa, " "), i = 0, o = b.length; i < o; i++) | |
j = j.replace(" " + b[i] + " ", | |
" "); | |
e.className = c.trim(j) | |
} else | |
e.className = "" | |
} | |
return this | |
},toggleClass: function(a, b) { | |
var d = typeof a, f = typeof b === "boolean"; | |
if (c.isFunction(a)) | |
return this.each(function(e) { | |
var j = c(this); | |
j.toggleClass(a.call(this, e, j.attr("class"), b), b) | |
}); | |
return this.each(function() { | |
if (d === "string") | |
for (var e, j = 0, i = c(this), o = b, k = a.split(ca); e = k[j++]; ) { | |
o = f ? o : !i.hasClass(e); | |
i[o ? "addClass" : "removeClass"](e) | |
} | |
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(Aa, " ").indexOf(a) > -1) | |
return true; | |
return false | |
},val: function(a) { | |
if (a === w) { | |
var b = this[0]; | |
if (b) { | |
if (c.nodeName(b, "option")) | |
return (b.attributes.value || {}).specified ? b.value : b.text; | |
if (c.nodeName(b, "select")) { | |
var d = b.selectedIndex, f = [], e = b.options; | |
b = b.type === "select-one"; | |
if (d < 0) | |
return null; | |
var j = b ? d : 0; | |
for (d = b ? d + 1 : e.length; j < d; j++) { | |
var i = | |
e[j]; | |
if (i.selected) { | |
a = c(i).val(); | |
if (b) | |
return a; | |
f.push(a) | |
} | |
} | |
return f | |
} | |
if (Ba.test(b.type) && !c.support.checkOn) | |
return b.getAttribute("value") === null ? "on" : b.value; | |
return (b.value || "").replace(Za, "") | |
} | |
return w | |
} | |
var o = c.isFunction(a); | |
return this.each(function(k) { | |
var n = c(this), r = a; | |
if (this.nodeType === 1) { | |
if (o) | |
r = a.call(this, k, n.val()); | |
if (typeof r === "number") | |
r += ""; | |
if (c.isArray(r) && Ba.test(this.type)) | |
this.checked = c.inArray(n.val(), r) >= 0; | |
else if (c.nodeName(this, "select")) { | |
var u = c.makeArray(r); | |
c("option", this).each(function() { | |
this.selected = | |
c.inArray(c(this).val(), u) >= 0 | |
}); | |
if (!u.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, f) { | |
if (!a || a.nodeType === 3 || a.nodeType === 8) | |
return w; | |
if (f && b in c.attrFn) | |
return c(a)[b](d); | |
f = a.nodeType !== 1 || !c.isXMLDoc(a); | |
var e = d !== w; | |
b = f && c.props[b] || b; | |
if (a.nodeType === 1) { | |
var j = $a.test(b); | |
if (b in a && f && !j) { | |
if (e) { | |
b === "type" && ab.test(a.nodeName) && a.parentNode && c.error("type property can't be changed"); | |
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 : bb.test(a.nodeName) || cb.test(a.nodeName) && a.href ? 0 : w; | |
return a[b] | |
} | |
if (!c.support.style && f && b === "style") { | |
if (e) | |
a.style.cssText = "" + d; | |
return a.style.cssText | |
} | |
e && a.setAttribute(b, "" + d); | |
a = !c.support.hrefNormalized && f && j ? a.getAttribute(b, 2) : a.getAttribute(b); | |
return a === null ? w : a | |
} | |
return c.style(a, b, d) | |
}}); | |
var O = /\.(.*)$/, db = function(a) { | |
return a.replace(/[^\w\s\.\|`]/g, | |
function(b) { | |
return "\\" + b | |
}) | |
}; | |
c.event = {add: function(a, b, d, f) { | |
if (!(a.nodeType === 3 || a.nodeType === 8)) { | |
if (a.setInterval && a !== A && !a.frameElement) | |
a = A; | |
var e, j; | |
if (d.handler) { | |
e = d; | |
d = e.handler | |
} | |
if (!d.guid) | |
d.guid = c.guid++; | |
if (j = c.data(a)) { | |
var i = j.events = j.events || {}, o = j.handle; | |
if (!o) | |
j.handle = o = function() { | |
return typeof c !== "undefined" && !c.event.triggered ? c.event.handle.apply(o.elem, arguments) : w | |
}; | |
o.elem = a; | |
b = b.split(" "); | |
for (var k, n = 0, r; k = b[n++]; ) { | |
j = e ? c.extend({}, e) : {handler: d,data: f}; | |
if (k.indexOf(".") > -1) { | |
r = k.split("."); | |
k = r.shift(); | |
j.namespace = r.slice(0).sort().join(".") | |
} else { | |
r = []; | |
j.namespace = "" | |
} | |
j.type = k; | |
j.guid = d.guid; | |
var u = i[k], z = c.event.special[k] || {}; | |
if (!u) { | |
u = i[k] = []; | |
if (!z.setup || z.setup.call(a, f, r, o) === false) | |
if (a.addEventListener) | |
a.addEventListener(k, o, false); | |
else | |
a.attachEvent && a.attachEvent("on" + k, o) | |
} | |
if (z.add) { | |
z.add.call(a, j); | |
if (!j.handler.guid) | |
j.handler.guid = d.guid | |
} | |
u.push(j); | |
c.event.global[k] = true | |
} | |
a = null | |
} | |
} | |
},global: {},remove: function(a, b, d, f) { | |
if (!(a.nodeType === 3 || a.nodeType === 8)) { | |
var e, j = 0, i, o, k, n, r, u, z = c.data(a), | |
C = z && z.events; | |
if (z && C) { | |
if (b && b.type) { | |
d = b.handler; | |
b = b.type | |
} | |
if (!b || typeof b === "string" && b.charAt(0) === ".") { | |
b = b || ""; | |
for (e in C) | |
c.event.remove(a, e + b) | |
} else { | |
for (b = b.split(" "); e = b[j++]; ) { | |
n = e; | |
i = e.indexOf(".") < 0; | |
o = []; | |
if (!i) { | |
o = e.split("."); | |
e = o.shift(); | |
k = new RegExp("(^|\\.)" + c.map(o.slice(0).sort(), db).join("\\.(?:.*\\.)?") + "(\\.|$)") | |
} | |
if (r = C[e]) | |
if (d) { | |
n = c.event.special[e] || {}; | |
for (B = f || 0; B < r.length; B++) { | |
u = r[B]; | |
if (d.guid === u.guid) { | |
if (i || k.test(u.namespace)) { | |
f == null && r.splice(B--, 1); | |
n.remove && n.remove.call(a, u) | |
} | |
if (f != | |
null) | |
break | |
} | |
} | |
if (r.length === 0 || f != null && r.length === 1) { | |
if (!n.teardown || n.teardown.call(a, o) === false) | |
Ca(a, e, z.handle); | |
delete C[e] | |
} | |
} else | |
for (var B = 0; B < r.length; B++) { | |
u = r[B]; | |
if (i || k.test(u.namespace)) { | |
c.event.remove(a, n, u.handler, B); | |
r.splice(B--, 1) | |
} | |
} | |
} | |
if (c.isEmptyObject(C)) { | |
if (b = z.handle) | |
b.elem = null; | |
delete z.events; | |
delete z.handle; | |
c.isEmptyObject(z) && c.removeData(a) | |
} | |
} | |
} | |
} | |
},trigger: function(a, b, d, f) { | |
var e = a.type || a; | |
if (!f) { | |
a = typeof a === "object" ? a[G] ? a : c.extend(c.Event(e), a) : c.Event(e); | |
if (e.indexOf("!") >= 0) { | |
a.type = | |
e = e.slice(0, -1); | |
a.exclusive = true | |
} | |
if (!d) { | |
a.stopPropagation(); | |
c.event.global[e] && c.each(c.cache, function() { | |
this.events && this.events[e] && c.event.trigger(a, b, this.handle.elem) | |
}) | |
} | |
if (!d || d.nodeType === 3 || d.nodeType === 8) | |
return w; | |
a.result = w; | |
a.target = d; | |
b = c.makeArray(b); | |
b.unshift(a) | |
} | |
a.currentTarget = d; | |
(f = c.data(d, "handle")) && f.apply(d, b); | |
f = d.parentNode || d.ownerDocument; | |
try { | |
if (!(d && d.nodeName && c.noData[d.nodeName.toLowerCase()])) | |
if (d["on" + e] && d["on" + e].apply(d, b) === false) | |
a.result = false | |
} catch (j) { | |
} | |
if (!a.isPropagationStopped() && | |
f) | |
c.event.trigger(a, b, f, true); | |
else if (!a.isDefaultPrevented()) { | |
f = a.target; | |
var i, o = c.nodeName(f, "a") && e === "click", k = c.event.special[e] || {}; | |
if ((!k._default || k._default.call(d, a) === false) && !o && !(f && f.nodeName && c.noData[f.nodeName.toLowerCase()])) { | |
try { | |
if (f[e]) { | |
if (i = f["on" + e]) | |
f["on" + e] = null; | |
c.event.triggered = true; | |
f[e]() | |
} | |
} catch (n) { | |
} | |
if (i) | |
f["on" + e] = i; | |
c.event.triggered = false | |
} | |
} | |
},handle: function(a) { | |
var b, d, f, e; | |
a = arguments[0] = c.event.fix(a || A.event); | |
a.currentTarget = this; | |
b = a.type.indexOf(".") < 0 && !a.exclusive; | |
if (!b) { | |
d = a.type.split("."); | |
a.type = d.shift(); | |
f = new RegExp("(^|\\.)" + d.slice(0).sort().join("\\.(?:.*\\.)?") + "(\\.|$)") | |
} | |
e = c.data(this, "events"); | |
d = e[a.type]; | |
if (e && d) { | |
d = d.slice(0); | |
e = 0; | |
for (var j = d.length; e < j; e++) { | |
var i = d[e]; | |
if (b || f.test(i.namespace)) { | |
a.handler = i.handler; | |
a.data = i.data; | |
a.handleObj = i; | |
i = i.handler.apply(this, arguments); | |
if (i !== w) { | |
a.result = i; | |
if (i === 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 originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "), | |
fix: function(a) { | |
if (a[G]) | |
return a; | |
var b = a; | |
a = c.Event(b); | |
for (var d = this.props.length, f; d; ) { | |
f = this.props[--d]; | |
a[f] = b[f] | |
} | |
if (!a.target) | |
a.target = a.srcElement || s; | |
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 = s.documentElement; | |
d = s.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 && (a.charCode || a.charCode === 0 ? a.charCode : a.keyCode)) | |
a.which = a.charCode || a.keyCode; | |
if (!a.metaKey && a.ctrlKey) | |
a.metaKey = a.ctrlKey; | |
if (!a.which && a.button !== w) | |
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, a.origType, c.extend({}, a, {handler: oa})) | |
},remove: function(a) { | |
var b = true, d = a.origType.replace(O, ""); | |
c.each(c.data(this, | |
"events").live || [], function() { | |
if (d === this.origType.replace(O, "")) | |
return b = false | |
}); | |
b && c.event.remove(this, a.origType, oa) | |
}},beforeunload: {setup: function(a, b, d) { | |
if (this.setInterval) | |
this.onbeforeunload = d; | |
return false | |
},teardown: function(a, b) { | |
if (this.onbeforeunload === b) | |
this.onbeforeunload = null | |
}}}}; | |
var Ca = s.removeEventListener ? function(a, b, d) { | |
a.removeEventListener(b, d, false) | |
} : function(a, b, d) { | |
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 = J(); | |
this[G] = true | |
}; | |
c.Event.prototype = {preventDefault: function() { | |
this.isDefaultPrevented = Z; | |
var a = this.originalEvent; | |
if (a) { | |
a.preventDefault && a.preventDefault(); | |
a.returnValue = false | |
} | |
},stopPropagation: function() { | |
this.isPropagationStopped = Z; | |
var a = this.originalEvent; | |
if (a) { | |
a.stopPropagation && a.stopPropagation(); | |
a.cancelBubble = true | |
} | |
},stopImmediatePropagation: function() { | |
this.isImmediatePropagationStopped = Z; | |
this.stopPropagation() | |
},isDefaultPrevented: Y,isPropagationStopped: Y, | |
isImmediatePropagationStopped: Y}; | |
var Da = 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) { | |
} | |
}, Ea = 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 ? Ea : Da, a) | |
},teardown: function(d) { | |
c.event.remove(this, b, d && d.selector ? Ea : Da) | |
}} | |
}); | |
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) | |
return na("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) | |
return na("submit", this, arguments) | |
}) | |
} else | |
return false | |
},teardown: function() { | |
c.event.remove(this, ".specialSubmit") | |
}}; | |
if (!c.support.changeBubbles) { | |
var da = /textarea|input|select/i, ea, Fa = 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(f) { | |
return f.selected | |
}).join("-") : ""; | |
else if (a.nodeName.toLowerCase() === "select") | |
d = a.selectedIndex; | |
return d | |
}, fa = function(a, b) { | |
var d = a.target, f, e; | |
if (!(!da.test(d.nodeName) || d.readOnly)) { | |
f = c.data(d, "_change_data"); | |
e = Fa(d); | |
if (a.type !== "focusout" || d.type !== "radio") | |
c.data(d, "_change_data", | |
e); | |
if (!(f === w || e === f)) | |
if (f != null || e) { | |
a.type = "change"; | |
return c.event.trigger(a, b, d) | |
} | |
} | |
}; | |
c.event.special.change = {filters: {focusout: fa,click: function(a) { | |
var b = a.target, d = b.type; | |
if (d === "radio" || d === "checkbox" || b.nodeName.toLowerCase() === "select") | |
return fa.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 fa.call(this, a) | |
},beforeactivate: function(a) { | |
a = a.target; | |
c.data(a, | |
"_change_data", Fa(a)) | |
}},setup: function() { | |
if (this.type === "file") | |
return false; | |
for (var a in ea) | |
c.event.add(this, a + ".specialChange", ea[a]); | |
return da.test(this.nodeName) | |
},teardown: function() { | |
c.event.remove(this, ".specialChange"); | |
return da.test(this.nodeName) | |
}}; | |
ea = c.event.special.change.filters | |
} | |
s.addEventListener && c.each({focus: "focusin",blur: "focusout"}, function(a, b) { | |
function d(f) { | |
f = c.event.fix(f); | |
f.type = b; | |
return c.event.handle.call(this, f) | |
} | |
c.event.special[b] = {setup: function() { | |
this.addEventListener(a, | |
d, true) | |
},teardown: function() { | |
this.removeEventListener(a, d, true) | |
}} | |
}); | |
c.each(["bind", "one"], function(a, b) { | |
c.fn[b] = function(d, f, e) { | |
if (typeof d === "object") { | |
for (var j in d) | |
this[b](j, f, d[j], e); | |
return this | |
} | |
if (c.isFunction(f)) { | |
e = f; | |
f = w | |
} | |
var i = b === "one" ? c.proxy(e, function(k) { | |
c(this).unbind(k, i); | |
return e.apply(this, arguments) | |
}) : e; | |
if (d === "unload" && b !== "one") | |
this.one(d, f, e); | |
else { | |
j = 0; | |
for (var o = this.length; j < o; j++) | |
c.event.add(this[j], d, i, f) | |
} | |
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 f = this.length; d < f; d++) | |
c.event.remove(this[d], a, b) | |
} | |
return this | |
},delegate: function(a, b, d, f) { | |
return this.live(b, d, f, 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]) { | |
a = c.Event(a); | |
a.preventDefault(); | |
a.stopPropagation(); | |
c.event.trigger(a, b, this[0]); | |
return a.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(f) { | |
var e = (c.data(this, "lastToggle" + a.guid) || 0) % d; | |
c.data(this, "lastToggle" + a.guid, e + 1); | |
f.preventDefault(); | |
return b[e].apply(this, arguments) || false | |
})) | |
},hover: function(a, b) { | |
return this.mouseenter(a).mouseleave(b || a) | |
}}); | |
var Ga = {focus: "focusin",blur: "focusout",mouseenter: "mouseover",mouseleave: "mouseout"}; | |
c.each(["live", "die"], function(a, b) { | |
c.fn[b] = function(d, f, e, j) { | |
var i, o = 0, k, n, r = j || this.selector, | |
u = j ? this : c(this.context); | |
if (c.isFunction(f)) { | |
e = f; | |
f = w | |
} | |
for (d = (d || "").split(" "); (i = d[o++]) != null; ) { | |
j = O.exec(i); | |
k = ""; | |
if (j) { | |
k = j[0]; | |
i = i.replace(O, "") | |
} | |
if (i === "hover") | |
d.push("mouseenter" + k, "mouseleave" + k); | |
else { | |
n = i; | |
if (i === "focus" || i === "blur") { | |
d.push(Ga[i] + k); | |
i += k | |
} else | |
i = (Ga[i] || i) + k; | |
b === "live" ? u.each(function() { | |
c.event.add(this, pa(i, r), {data: f,selector: r,handler: e,origType: i,origHandler: e,preType: n}) | |
}) : u.unbind(pa(i, r), e) | |
} | |
} | |
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) { | |
return d ? this.bind(b, d) : this.trigger(b) | |
}; | |
if (c.attrFn) | |
c.attrFn[b] = true | |
}); | |
A.attachEvent && !A.addEventListener && A.attachEvent("onunload", 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) { | |
for (var h = "", l, m = 0; g[m]; m++) { | |
l = g[m]; | |
if (l.nodeType === 3 || l.nodeType === 4) | |
h += l.nodeValue; | |
else if (l.nodeType !== 8) | |
h += a(l.childNodes) | |
} | |
return h | |
} | |
function b(g, h, l, m, q, p) { | |
q = 0; | |
for (var v = m.length; q < v; q++) { | |
var t = m[q]; | |
if (t) { | |
t = t[g]; | |
for (var y = false; t; ) { | |
if (t.sizcache === l) { | |
y = m[t.sizset]; | |
break | |
} | |
if (t.nodeType === 1 && !p) { | |
t.sizcache = l; | |
t.sizset = q | |
} | |
if (t.nodeName.toLowerCase() === h) { | |
y = t; | |
break | |
} | |
t = t[g] | |
} | |
m[q] = y | |
} | |
} | |
} | |
function d(g, h, l, m, q, p) { | |
q = 0; | |
for (var v = m.length; q < v; q++) { | |
var t = m[q]; | |
if (t) { | |
t = t[g]; | |
for (var y = false; t; ) { | |
if (t.sizcache === l) { | |
y = m[t.sizset]; | |
break | |
} | |
if (t.nodeType === 1) { | |
if (!p) { | |
t.sizcache = l; | |
t.sizset = q | |
} | |
if (typeof h !== "string") { | |
if (t === h) { | |
y = true; | |
break | |
} | |
} else if (k.filter(h, [t]).length > 0) { | |
y = t; | |
break | |
} | |
} | |
t = t[g] | |
} | |
m[q] = y | |
} | |
} | |
} | |
var f = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g, | |
e = 0, j = Object.prototype.toString, i = false, o = true; | |
[0, 0].sort(function() { | |
o = false; | |
return 0 | |
}); | |
var k = function(g, h, l, m) { | |
l = l || []; | |
var q = h = h || s; | |
if (h.nodeType !== 1 && h.nodeType !== 9) | |
return []; | |
if (!g || typeof g !== "string") | |
return l; | |
for (var p = [], v, t, y, S, H = true, M = x(h), I = g; (f.exec(""), v = f.exec(I)) !== null; ) { | |
I = v[3]; | |
p.push(v[1]); | |
if (v[2]) { | |
S = v[3]; | |
break | |
} | |
} | |
if (p.length > 1 && r.exec(g)) | |
if (p.length === 2 && n.relative[p[0]]) | |
t = ga(p[0] + p[1], h); | |
else | |
for (t = n.relative[p[0]] ? [h] : k(p.shift(), h); p.length; ) { | |
g = p.shift(); | |
if (n.relative[g]) | |
g += p.shift(); | |
t = ga(g, t) | |
} | |
else { | |
if (!m && p.length > 1 && h.nodeType === 9 && !M && n.match.ID.test(p[0]) && !n.match.ID.test(p[p.length - 1])) { | |
v = k.find(p.shift(), h, M); | |
h = v.expr ? k.filter(v.expr, v.set)[0] : v.set[0] | |
} | |
if (h) { | |
v = m ? {expr: p.pop(),set: z(m)} : k.find(p.pop(), p.length === 1 && (p[0] === "~" || p[0] === "+") && h.parentNode ? h.parentNode : h, M); | |
t = v.expr ? k.filter(v.expr, v.set) : v.set; | |
if (p.length > 0) | |
y = z(t); | |
else | |
H = false; | |
for (; p.length; ) { | |
var D = p.pop(); | |
v = D; | |
if (n.relative[D]) | |
v = p.pop(); | |
else | |
D = ""; | |
if (v == null) | |
v = h; | |
n.relative[D](y, v, M) | |
} | |
} else | |
y = [] | |
} | |
y || (y = t); | |
y || k.error(D || | |
g); | |
if (j.call(y) === "[object Array]") | |
if (H) | |
if (h && h.nodeType === 1) | |
for (g = 0; y[g] != null; g++) { | |
if (y[g] && (y[g] === true || y[g].nodeType === 1 && E(h, y[g]))) | |
l.push(t[g]) | |
} | |
else | |
for (g = 0; y[g] != null; g++) | |
y[g] && y[g].nodeType === 1 && l.push(t[g]); | |
else | |
l.push.apply(l, y); | |
else | |
z(y, l); | |
if (S) { | |
k(S, q, l, m); | |
k.uniqueSort(l) | |
} | |
return l | |
}; | |
k.uniqueSort = function(g) { | |
if (B) { | |
i = o; | |
g.sort(B); | |
if (i) | |
for (var h = 1; h < g.length; h++) | |
g[h] === g[h - 1] && g.splice(h--, 1) | |
} | |
return g | |
}; | |
k.matches = function(g, h) { | |
return k(g, null, null, h) | |
}; | |
k.find = function(g, h, l) { | |
var m, q; | |
if (!g) | |
return []; | |
for (var p = 0, v = n.order.length; p < v; p++) { | |
var t = n.order[p]; | |
if (q = n.leftMatch[t].exec(g)) { | |
var y = q[1]; | |
q.splice(1, 1); | |
if (y.substr(y.length - 1) !== "\\") { | |
q[1] = (q[1] || "").replace(/\\/g, ""); | |
m = n.find[t](q, h, l); | |
if (m != null) { | |
g = g.replace(n.match[t], ""); | |
break | |
} | |
} | |
} | |
} | |
m || (m = h.getElementsByTagName("*")); | |
return {set: m,expr: g} | |
}; | |
k.filter = function(g, h, l, m) { | |
for (var q = g, p = [], v = h, t, y, S = h && h[0] && x(h[0]); g && h.length; ) { | |
for (var H in n.filter) | |
if ((t = n.leftMatch[H].exec(g)) != null && t[2]) { | |
var M = n.filter[H], I, D; | |
D = t[1]; | |
y = false; | |
t.splice(1, 1); | |
if (D.substr(D.length - | |
1) !== "\\") { | |
if (v === p) | |
p = []; | |
if (n.preFilter[H]) | |
if (t = n.preFilter[H](t, v, l, p, m, S)) { | |
if (t === true) | |
continue | |
} else | |
y = I = true; | |
if (t) | |
for (var U = 0; (D = v[U]) != null; U++) | |
if (D) { | |
I = M(D, t, U, v); | |
var Ha = m ^ !!I; | |
if (l && I != null) | |
if (Ha) | |
y = true; | |
else | |
v[U] = false; | |
else if (Ha) { | |
p.push(D); | |
y = true | |
} | |
} | |
if (I !== w) { | |
l || (v = p); | |
g = g.replace(n.match[H], ""); | |
if (!y) | |
return []; | |
break | |
} | |
} | |
} | |
if (g === q) | |
if (y == null) | |
k.error(g); | |
else | |
break; | |
q = g | |
} | |
return v | |
}; | |
k.error = function(g) { | |
throw "Syntax error, unrecognized expression: " + g; | |
}; | |
var n = 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, h) { | |
var l = typeof h === "string", m = l && !/\W/.test(h); | |
l = l && !m; | |
if (m) | |
h = h.toLowerCase(); | |
m = 0; | |
for (var q = g.length, p; m < q; m++) | |
if (p = g[m]) { | |
for (; (p = p.previousSibling) && p.nodeType !== 1; ) | |
; | |
g[m] = l || p && p.nodeName.toLowerCase() === h ? p || false : p === h | |
} | |
l && k.filter(h, g, true) | |
},">": function(g, h) { | |
var l = typeof h === "string"; | |
if (l && !/\W/.test(h)) { | |
h = h.toLowerCase(); | |
for (var m = 0, q = g.length; m < q; m++) { | |
var p = g[m]; | |
if (p) { | |
l = p.parentNode; | |
g[m] = l.nodeName.toLowerCase() === h ? l : false | |
} | |
} | |
} else { | |
m = 0; | |
for (q = g.length; m < q; m++) | |
if (p = g[m]) | |
g[m] = | |
l ? p.parentNode : p.parentNode === h; | |
l && k.filter(h, g, true) | |
} | |
},"": function(g, h, l) { | |
var m = e++, q = d; | |
if (typeof h === "string" && !/\W/.test(h)) { | |
var p = h = h.toLowerCase(); | |
q = b | |
} | |
q("parentNode", h, m, g, p, l) | |
},"~": function(g, h, l) { | |
var m = e++, q = d; | |
if (typeof h === "string" && !/\W/.test(h)) { | |
var p = h = h.toLowerCase(); | |
q = b | |
} | |
q("previousSibling", h, m, g, p, l) | |
}},find: {ID: function(g, h, l) { | |
if (typeof h.getElementById !== "undefined" && !l) | |
return (g = h.getElementById(g[1])) ? [g] : [] | |
},NAME: function(g, h) { | |
if (typeof h.getElementsByName !== "undefined") { | |
var l = []; | |
h = h.getElementsByName(g[1]); | |
for (var m = 0, q = h.length; m < q; m++) | |
h[m].getAttribute("name") === g[1] && l.push(h[m]); | |
return l.length === 0 ? null : l | |
} | |
},TAG: function(g, h) { | |
return h.getElementsByTagName(g[1]) | |
}},preFilter: {CLASS: function(g, h, l, m, q, p) { | |
g = " " + g[1].replace(/\\/g, "") + " "; | |
if (p) | |
return g; | |
p = 0; | |
for (var v; (v = h[p]) != null; p++) | |
if (v) | |
if (q ^ (v.className && (" " + v.className + " ").replace(/[\t\n]/g, " ").indexOf(g) >= 0)) | |
l || m.push(v); | |
else if (l) | |
h[p] = 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 h = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2] === "even" && "2n" || g[2] === "odd" && "2n+1" || !/\D/.test(g[2]) && "0n+" + g[2] || g[2]); | |
g[2] = h[1] + (h[2] || 1) - 0; | |
g[3] = h[3] - 0 | |
} | |
g[0] = e++; | |
return g | |
},ATTR: function(g, h, l, m, q, p) { | |
h = g[1].replace(/\\/g, ""); | |
if (!p && n.attrMap[h]) | |
g[1] = n.attrMap[h]; | |
if (g[2] === "~=") | |
g[4] = " " + g[4] + " "; | |
return g | |
},PSEUDO: function(g, h, l, m, q) { | |
if (g[1] === "not") | |
if ((f.exec(g[3]) || "").length > 1 || /^\w/.test(g[3])) | |
g[3] = k(g[3], null, null, h); | |
else { | |
g = k.filter(g[3], h, l, true ^ q); | |
l || m.push.apply(m, | |
g); | |
return false | |
} | |
else if (n.match.POS.test(g[0]) || n.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, h, l) { | |
return !!k(l[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, h) { | |
return h === 0 | |
},last: function(g, h, l, m) { | |
return h === m.length - 1 | |
},even: function(g, h) { | |
return h % 2 === 0 | |
},odd: function(g, h) { | |
return h % 2 === 1 | |
},lt: function(g, h, l) { | |
return h < l[3] - 0 | |
},gt: function(g, h, l) { | |
return h > l[3] - 0 | |
},nth: function(g, h, l) { | |
return l[3] - 0 === h | |
},eq: function(g, h, l) { | |
return l[3] - 0 === h | |
}},filter: {PSEUDO: function(g, h, l, m) { | |
var q = h[1], p = n.filters[q]; | |
if (p) | |
return p(g, l, h, m); | |
else if (q === "contains") | |
return (g.textContent || g.innerText || a([g]) || "").indexOf(h[3]) >= 0; | |
else if (q === "not") { | |
h = | |
h[3]; | |
l = 0; | |
for (m = h.length; l < m; l++) | |
if (h[l] === g) | |
return false; | |
return true | |
} else | |
k.error("Syntax error, unrecognized expression: " + q) | |
},CHILD: function(g, h) { | |
var l = h[1], m = g; | |
switch (l) { | |
case "only": | |
case "first": | |
for (; m = m.previousSibling; ) | |
if (m.nodeType === 1) | |
return false; | |
if (l === "first") | |
return true; | |
m = g; | |
case "last": | |
for (; m = m.nextSibling; ) | |
if (m.nodeType === 1) | |
return false; | |
return true; | |
case "nth": | |
l = h[2]; | |
var q = h[3]; | |
if (l === 1 && q === 0) | |
return true; | |
h = h[0]; | |
var p = g.parentNode; | |
if (p && (p.sizcache !== h || !g.nodeIndex)) { | |
var v = 0; | |
for (m = p.firstChild; m; m = | |
m.nextSibling) | |
if (m.nodeType === 1) | |
m.nodeIndex = ++v; | |
p.sizcache = h | |
} | |
g = g.nodeIndex - q; | |
return l === 0 ? g === 0 : g % l === 0 && g / l >= 0 | |
} | |
},ID: function(g, h) { | |
return g.nodeType === 1 && g.getAttribute("id") === h | |
},TAG: function(g, h) { | |
return h === "*" && g.nodeType === 1 || g.nodeName.toLowerCase() === h | |
},CLASS: function(g, h) { | |
return (" " + (g.className || g.getAttribute("class")) + " ").indexOf(h) > -1 | |
},ATTR: function(g, h) { | |
var l = h[1]; | |
g = n.attrHandle[l] ? n.attrHandle[l](g) : g[l] != null ? g[l] : g.getAttribute(l); | |
l = g + ""; | |
var m = h[2]; | |
h = h[4]; | |
return g == null ? m === "!=" : m === | |
"=" ? l === h : m === "*=" ? l.indexOf(h) >= 0 : m === "~=" ? (" " + l + " ").indexOf(h) >= 0 : !h ? l && g !== false : m === "!=" ? l !== h : m === "^=" ? l.indexOf(h) === 0 : m === "$=" ? l.substr(l.length - h.length) === h : m === "|=" ? l === h || l.substr(0, h.length + 1) === h + "-" : false | |
},POS: function(g, h, l, m) { | |
var q = n.setFilters[h[2]]; | |
if (q) | |
return q(g, l, h, m) | |
}}}, r = n.match.POS; | |
for (var u in n.match) { | |
n.match[u] = new RegExp(n.match[u].source + /(?![^\[]*\])(?![^\(]*\))/.source); | |
n.leftMatch[u] = new RegExp(/(^(?:.|\r|\n)*?)/.source + n.match[u].source.replace(/\\(\d+)/g, function(g, | |
h) { | |
return "\\" + (h - 0 + 1) | |
})) | |
} | |
var z = function(g, h) { | |
g = Array.prototype.slice.call(g, 0); | |
if (h) { | |
h.push.apply(h, g); | |
return h | |
} | |
return g | |
}; | |
try { | |
Array.prototype.slice.call(s.documentElement.childNodes, 0) | |
} catch (C) { | |
z = function(g, h) { | |
h = h || []; | |
if (j.call(g) === "[object Array]") | |
Array.prototype.push.apply(h, g); | |
else if (typeof g.length === "number") | |
for (var l = 0, m = g.length; l < m; l++) | |
h.push(g[l]); | |
else | |
for (l = 0; g[l]; l++) | |
h.push(g[l]); | |
return h | |
} | |
} | |
var B; | |
if (s.documentElement.compareDocumentPosition) | |
B = function(g, h) { | |
if (!g.compareDocumentPosition || | |
!h.compareDocumentPosition) { | |
if (g == h) | |
i = true; | |
return g.compareDocumentPosition ? -1 : 1 | |
} | |
g = g.compareDocumentPosition(h) & 4 ? -1 : g === h ? 0 : 1; | |
if (g === 0) | |
i = true; | |
return g | |
}; | |
else if ("sourceIndex" in s.documentElement) | |
B = function(g, h) { | |
if (!g.sourceIndex || !h.sourceIndex) { | |
if (g == h) | |
i = true; | |
return g.sourceIndex ? -1 : 1 | |
} | |
g = g.sourceIndex - h.sourceIndex; | |
if (g === 0) | |
i = true; | |
return g | |
}; | |
else if (s.createRange) | |
B = function(g, h) { | |
if (!g.ownerDocument || !h.ownerDocument) { | |
if (g == h) | |
i = true; | |
return g.ownerDocument ? -1 : 1 | |
} | |
var l = g.ownerDocument.createRange(), m = | |
h.ownerDocument.createRange(); | |
l.setStart(g, 0); | |
l.setEnd(g, 0); | |
m.setStart(h, 0); | |
m.setEnd(h, 0); | |
g = l.compareBoundaryPoints(Range.START_TO_END, m); | |
if (g === 0) | |
i = true; | |
return g | |
}; | |
(function() { | |
var g = s.createElement("div"), h = "script" + (new Date).getTime(); | |
g.innerHTML = "<a name='" + h + "'/>"; | |
var l = s.documentElement; | |
l.insertBefore(g, l.firstChild); | |
if (s.getElementById(h)) { | |
n.find.ID = function(m, q, p) { | |
if (typeof q.getElementById !== "undefined" && !p) | |
return (q = q.getElementById(m[1])) ? q.id === m[1] || typeof q.getAttributeNode !== "undefined" && | |
q.getAttributeNode("id").nodeValue === m[1] ? [q] : w : [] | |
}; | |
n.filter.ID = function(m, q) { | |
var p = typeof m.getAttributeNode !== "undefined" && m.getAttributeNode("id"); | |
return m.nodeType === 1 && p && p.nodeValue === q | |
} | |
} | |
l.removeChild(g); | |
l = g = null | |
})(); | |
(function() { | |
var g = s.createElement("div"); | |
g.appendChild(s.createComment("")); | |
if (g.getElementsByTagName("*").length > 0) | |
n.find.TAG = function(h, l) { | |
l = l.getElementsByTagName(h[1]); | |
if (h[1] === "*") { | |
h = []; | |
for (var m = 0; l[m]; m++) | |
l[m].nodeType === 1 && h.push(l[m]); | |
l = h | |
} | |
return l | |
}; | |
g.innerHTML = "<a href='#'></a>"; | |
if (g.firstChild && typeof g.firstChild.getAttribute !== "undefined" && g.firstChild.getAttribute("href") !== "#") | |
n.attrHandle.href = function(h) { | |
return h.getAttribute("href", 2) | |
}; | |
g = null | |
})(); | |
s.querySelectorAll && function() { | |
var g = k, h = s.createElement("div"); | |
h.innerHTML = "<p class='TEST'></p>"; | |
if (!(h.querySelectorAll && h.querySelectorAll(".TEST").length === 0)) { | |
k = function(m, q, p, v) { | |
q = q || s; | |
if (!v && q.nodeType === 9 && !x(q)) | |
try { | |
return z(q.querySelectorAll(m), p) | |
} catch (t) { | |
} | |
return g(m, q, p, v) | |
}; | |
for (var l in g) | |
k[l] = g[l]; | |
h = null | |
} | |
}(); | |
(function() { | |
var g = s.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) { | |
n.order.splice(1, 0, "CLASS"); | |
n.find.CLASS = function(h, l, m) { | |
if (typeof l.getElementsByClassName !== "undefined" && !m) | |
return l.getElementsByClassName(h[1]) | |
}; | |
g = null | |
} | |
} | |
})(); | |
var E = s.compareDocumentPosition ? function(g, h) { | |
return !!(g.compareDocumentPosition(h) & 16) | |
} : | |
function(g, h) { | |
return g !== h && (g.contains ? g.contains(h) : true) | |
}, x = function(g) { | |
return (g = (g ? g.ownerDocument || g : 0).documentElement) ? g.nodeName !== "HTML" : false | |
}, ga = function(g, h) { | |
var l = [], m = "", q; | |
for (h = h.nodeType ? [h] : h; q = n.match.PSEUDO.exec(g); ) { | |
m += q[0]; | |
g = g.replace(n.match.PSEUDO, "") | |
} | |
g = n.relative[g] ? g + "*" : g; | |
q = 0; | |
for (var p = h.length; q < p; q++) | |
k(g, h[q], l); | |
return k.filter(m, l) | |
}; | |
c.find = k; | |
c.expr = k.selectors; | |
c.expr[":"] = c.expr.filters; | |
c.unique = k.uniqueSort; | |
c.text = a; | |
c.isXMLDoc = x; | |
c.contains = E | |
})(); | |
var eb = /Until$/, fb = /^(?:parents|prevUntil|prevAll)/, | |
gb = /,/; | |
R = Array.prototype.slice; | |
var Ia = function(a, b, d) { | |
if (c.isFunction(b)) | |
return c.grep(a, function(e, j) { | |
return !!b.call(e, j, e) === d | |
}); | |
else if (b.nodeType) | |
return c.grep(a, function(e) { | |
return e === b === d | |
}); | |
else if (typeof b === "string") { | |
var f = c.grep(a, function(e) { | |
return e.nodeType === 1 | |
}); | |
if (Ua.test(b)) | |
return c.filter(b, f, !d); | |
else | |
b = c.filter(b, f) | |
} | |
return c.grep(a, function(e) { | |
return c.inArray(e, b) >= 0 === d | |
}) | |
}; | |
c.fn.extend({find: function(a) { | |
for (var b = this.pushStack("", "find", a), d = 0, f = 0, e = this.length; f < e; f++) { | |
d = b.length; | |
c.find(a, this[f], b); | |
if (f > 0) | |
for (var j = d; j < b.length; j++) | |
for (var i = 0; i < d; i++) | |
if (b[i] === b[j]) { | |
b.splice(j--, 1); | |
break | |
} | |
} | |
return b | |
},has: function(a) { | |
var b = c(a); | |
return this.filter(function() { | |
for (var d = 0, f = b.length; d < f; d++) | |
if (c.contains(this, b[d])) | |
return true | |
}) | |
},not: function(a) { | |
return this.pushStack(Ia(this, a, false), "not", a) | |
},filter: function(a) { | |
return this.pushStack(Ia(this, a, true), "filter", a) | |
},is: function(a) { | |
return !!a && c.filter(a, this).length > 0 | |
},closest: function(a, b) { | |
if (c.isArray(a)) { | |
var d = [], f = this[0], e, j = | |
{}, i; | |
if (f && a.length) { | |
e = 0; | |
for (var o = a.length; e < o; e++) { | |
i = a[e]; | |
j[i] || (j[i] = c.expr.match.POS.test(i) ? c(i, b || this.context) : i) | |
} | |
for (; f && f.ownerDocument && f !== b; ) { | |
for (i in j) { | |
e = j[i]; | |
if (e.jquery ? e.index(f) > -1 : c(f).is(e)) { | |
d.push({selector: i,elem: f}); | |
delete j[i] | |
} | |
} | |
f = f.parentNode | |
} | |
} | |
return d | |
} | |
var k = c.expr.match.POS.test(a) ? c(a, b || this.context) : null; | |
return this.map(function(n, r) { | |
for (; r && r.ownerDocument && r !== b; ) { | |
if (k ? k.index(r) > -1 : c(r).is(a)) | |
return r; | |
r = r.parentNode | |
} | |
return null | |
}) | |
},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) { | |
a = typeof a === "string" ? c(a, b || this.context) : c.makeArray(a); | |
b = c.merge(this.get(), a); | |
return this.pushStack(qa(a[0]) || qa(b[0]) ? b : c.unique(b)) | |
},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, f) { | |
var e = c.map(this, b, d); | |
eb.test(a) || (f = d); | |
if (f && typeof f === "string") | |
e = c.filter(f, e); | |
e = this.length > 1 ? c.unique(e) : e; | |
if ((this.length > 1 || gb.test(f)) && fb.test(a)) | |
e = e.reverse(); | |
return this.pushStack(e, a, R.call(arguments).join(",")) | |
} | |
}); | |
c.extend({filter: function(a, b, d) { | |
if (d) | |
a = ":not(" + a + ")"; | |
return c.find.matches(a, b) | |
},dir: function(a, b, d) { | |
var f = []; | |
for (a = a[b]; a && a.nodeType !== 9 && (d === w || a.nodeType !== 1 || !c(a).is(d)); ) { | |
a.nodeType === | |
1 && f.push(a); | |
a = a[b] | |
} | |
return f | |
},nth: function(a, b, d) { | |
b = b || 1; | |
for (var f = 0; a; a = a[d]) | |
if (a.nodeType === 1 && ++f === 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 Ja = / jQuery\d+="(?:\d+|null)"/g, V = /^\s+/, Ka = /(<([\w:]+)[^>]*?)\/>/g, hb = /^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i, La = /<([\w:]+)/, ib = /<tbody/i, jb = /<|&#?\w+;/, ta = /<script|<object|<embed|<option|<style/i, ua = /checked\s*(?:[^=]|=\s*.checked.)/i, Ma = function(a, b, d) { | |
return hb.test(d) ? | |
a : b + "></" + d + ">" | |
}, F = {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, "", ""]}; | |
F.optgroup = F.option; | |
F.tbody = F.tfoot = F.colgroup = F.caption = F.thead; | |
F.th = F.td; | |
if (!c.support.htmlSerialize) | |
F._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 !== w) | |
return this.empty().append((this[0] && this[0].ownerDocument || s).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, f; (f = this[d]) != null; d++) | |
if (!a || c.filter(a, [f]).length) { | |
if (!b && f.nodeType === 1) { | |
c.cleanData(f.getElementsByTagName("*")); | |
c.cleanData([f]) | |
} | |
f.parentNode && f.parentNode.removeChild(f) | |
} | |
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, f = this.ownerDocument; | |
if (!d) { | |
d = f.createElement("div"); | |
d.appendChild(this.cloneNode(true)); | |
d = d.innerHTML | |
} | |
return c.clean([d.replace(Ja, "").replace(/=([^="'>\s]+\/)>/g, '="$1">').replace(V, "")], f)[0] | |
} else | |
return this.cloneNode(true) | |
}); | |
if (a === true) { | |
ra(this, b); | |
ra(this.find("*"), b.find("*")) | |
} | |
return b | |
},html: function(a) { | |
if (a === w) | |
return this[0] && this[0].nodeType === 1 ? this[0].innerHTML.replace(Ja, | |
"") : null; | |
else if (typeof a === "string" && !ta.test(a) && (c.support.leadingWhitespace || !V.test(a)) && !F[(La.exec(a) || ["", ""])[1].toLowerCase()]) { | |
a = a.replace(Ka, Ma); | |
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 (f) { | |
this.empty().append(a) | |
} | |
} else | |
c.isFunction(a) ? this.each(function(e) { | |
var j = c(this), i = j.html(); | |
j.empty().append(function() { | |
return a.call(this, e, i) | |
}) | |
}) : 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), f = d.html(); | |
d.replaceWith(a.call(this, b, f)) | |
}); | |
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) { | |
function f(u) { | |
return c.nodeName(u, "table") ? u.getElementsByTagName("tbody")[0] || | |
u.appendChild(u.ownerDocument.createElement("tbody")) : u | |
} | |
var e, j, i = a[0], o = [], k; | |
if (!c.support.checkClone && arguments.length === 3 && typeof i === "string" && ua.test(i)) | |
return this.each(function() { | |
c(this).domManip(a, b, d, true) | |
}); | |
if (c.isFunction(i)) | |
return this.each(function(u) { | |
var z = c(this); | |
a[0] = i.call(this, u, b ? z.html() : w); | |
z.domManip(a, b, d) | |
}); | |
if (this[0]) { | |
e = i && i.parentNode; | |
e = c.support.parentNode && e && e.nodeType === 11 && e.childNodes.length === this.length ? {fragment: e} : sa(a, this, o); | |
k = e.fragment; | |
if (j = k.childNodes.length === | |
1 ? (k = k.firstChild) : k.firstChild) { | |
b = b && c.nodeName(j, "tr"); | |
for (var n = 0, r = this.length; n < r; n++) | |
d.call(b ? f(this[n], j) : this[n], n > 0 || e.cacheable || this.length > 1 ? k.cloneNode(true) : k) | |
} | |
o.length && c.each(o, Qa) | |
} | |
return this | |
}}); | |
c.fragments = {}; | |
c.each({appendTo: "append",prependTo: "prepend",insertBefore: "before",insertAfter: "after",replaceAll: "replaceWith"}, function(a, b) { | |
c.fn[a] = function(d) { | |
var f = []; | |
d = c(d); | |
var e = this.length === 1 && this[0].parentNode; | |
if (e && e.nodeType === 11 && e.childNodes.length === 1 && d.length === 1) { | |
d[b](this[0]); | |
return this | |
} else { | |
e = 0; | |
for (var j = d.length; e < j; e++) { | |
var i = (e > 0 ? this.clone(true) : this).get(); | |
c.fn[b].apply(c(d[e]), i); | |
f = f.concat(i) | |
} | |
return this.pushStack(f, a, d.selector) | |
} | |
} | |
}); | |
c.extend({clean: function(a, b, d, f) { | |
b = b || s; | |
if (typeof b.createElement === "undefined") | |
b = b.ownerDocument || b[0] && b[0].ownerDocument || s; | |
for (var e = [], j = 0, i; (i = a[j]) != null; j++) { | |
if (typeof i === "number") | |
i += ""; | |
if (i) { | |
if (typeof i === "string" && !jb.test(i)) | |
i = b.createTextNode(i); | |
else if (typeof i === "string") { | |
i = i.replace(Ka, Ma); | |
var o = (La.exec(i) || ["", | |
""])[1].toLowerCase(), k = F[o] || F._default, n = k[0], r = b.createElement("div"); | |
for (r.innerHTML = k[1] + i + k[2]; n--; ) | |
r = r.lastChild; | |
if (!c.support.tbody) { | |
n = ib.test(i); | |
o = o === "table" && !n ? r.firstChild && r.firstChild.childNodes : k[1] === "<table>" && !n ? r.childNodes : []; | |
for (k = o.length - 1; k >= 0; --k) | |
c.nodeName(o[k], "tbody") && !o[k].childNodes.length && o[k].parentNode.removeChild(o[k]) | |
} | |
!c.support.leadingWhitespace && V.test(i) && r.insertBefore(b.createTextNode(V.exec(i)[0]), r.firstChild); | |
i = r.childNodes | |
} | |
if (i.nodeType) | |
e.push(i); | |
else | |
e = | |
c.merge(e, i) | |
} | |
} | |
if (d) | |
for (j = 0; e[j]; j++) | |
if (f && c.nodeName(e[j], "script") && (!e[j].type || e[j].type.toLowerCase() === "text/javascript")) | |
f.push(e[j].parentNode ? e[j].parentNode.removeChild(e[j]) : e[j]); | |
else { | |
e[j].nodeType === 1 && e.splice.apply(e, [j + 1, 0].concat(c.makeArray(e[j].getElementsByTagName("script")))); | |
d.appendChild(e[j]) | |
} | |
return e | |
},cleanData: function(a) { | |
for (var b, d, f = c.cache, e = c.event.special, j = c.support.deleteExpando, i = 0, o; (o = a[i]) != null; i++) | |
if (d = o[c.expando]) { | |
b = f[d]; | |
if (b.events) | |
for (var k in b.events) | |
e[k] ? | |
c.event.remove(o, k) : Ca(o, k, b.handle); | |
if (j) | |
delete o[c.expando]; | |
else | |
o.removeAttribute && o.removeAttribute(c.expando); | |
delete f[d] | |
} | |
}}); | |
var kb = /z-?index|font-?weight|opacity|zoom|line-?height/i, Na = /alpha\([^)]*\)/, Oa = /opacity=([^)]*)/, ha = /float/i, ia = /-([a-z])/ig, lb = /([A-Z])/g, mb = /^-?\d+(?:px)?$/i, nb = /^-?\d/, ob = {position: "absolute",visibility: "hidden",display: "block"}, pb = ["Left", "Right"], qb = ["Top", "Bottom"], rb = s.defaultView && s.defaultView.getComputedStyle, Pa = c.support.cssFloat ? "cssFloat" : "styleFloat", ja = | |
function(a, b) { | |
return b.toUpperCase() | |
}; | |
c.fn.css = function(a, b) { | |
return X(this, a, b, true, function(d, f, e) { | |
if (e === w) | |
return c.curCSS(d, f); | |
if (typeof e === "number" && !kb.test(f)) | |
e += "px"; | |
c.style(d, f, e) | |
}) | |
}; | |
c.extend({style: function(a, b, d) { | |
if (!a || a.nodeType === 3 || a.nodeType === 8) | |
return w; | |
if ((b === "width" || b === "height") && parseFloat(d) < 0) | |
d = w; | |
var f = a.style || a, e = d !== w; | |
if (!c.support.opacity && b === "opacity") { | |
if (e) { | |
f.zoom = 1; | |
b = parseInt(d, 10) + "" === "NaN" ? "" : "alpha(opacity=" + d * 100 + ")"; | |
a = f.filter || c.curCSS(a, "filter") || ""; | |
f.filter = | |
Na.test(a) ? a.replace(Na, b) : b | |
} | |
return f.filter && f.filter.indexOf("opacity=") >= 0 ? parseFloat(Oa.exec(f.filter)[1]) / 100 + "" : "" | |
} | |
if (ha.test(b)) | |
b = Pa; | |
b = b.replace(ia, ja); | |
if (e) | |
f[b] = d; | |
return f[b] | |
},css: function(a, b, d, f) { | |
if (b === "width" || b === "height") { | |
var e, j = b === "width" ? pb : qb; | |
function i() { | |
e = b === "width" ? a.offsetWidth : a.offsetHeight; | |
f !== "border" && c.each(j, function() { | |
f || (e -= parseFloat(c.curCSS(a, "padding" + this, true)) || 0); | |
if (f === "margin") | |
e += parseFloat(c.curCSS(a, "margin" + this, true)) || 0; | |
else | |
e -= parseFloat(c.curCSS(a, | |
"border" + this + "Width", true)) || 0 | |
}) | |
} | |
a.offsetWidth !== 0 ? i() : c.swap(a, ob, i); | |
return Math.max(0, Math.round(e)) | |
} | |
return c.curCSS(a, b, d) | |
},curCSS: function(a, b, d) { | |
var f, e = a.style; | |
if (!c.support.opacity && b === "opacity" && a.currentStyle) { | |
f = Oa.test(a.currentStyle.filter || "") ? parseFloat(RegExp.$1) / 100 + "" : ""; | |
return f === "" ? "1" : f | |
} | |
if (ha.test(b)) | |
b = Pa; | |
if (!d && e && e[b]) | |
f = e[b]; | |
else if (rb) { | |
if (ha.test(b)) | |
b = "float"; | |
b = b.replace(lb, "-$1").toLowerCase(); | |
e = a.ownerDocument.defaultView; | |
if (!e) | |
return null; | |
if (a = e.getComputedStyle(a, null)) | |
f = | |
a.getPropertyValue(b); | |
if (b === "opacity" && f === "") | |
f = "1" | |
} else if (a.currentStyle) { | |
d = b.replace(ia, ja); | |
f = a.currentStyle[b] || a.currentStyle[d]; | |
if (!mb.test(f) && nb.test(f)) { | |
b = e.left; | |
var j = a.runtimeStyle.left; | |
a.runtimeStyle.left = a.currentStyle.left; | |
e.left = d === "fontSize" ? "1em" : f || 0; | |
f = e.pixelLeft + "px"; | |
e.left = b; | |
a.runtimeStyle.left = j | |
} | |
} | |
return f | |
},swap: function(a, b, d) { | |
var f = {}; | |
for (var e in b) { | |
f[e] = a.style[e]; | |
a.style[e] = b[e] | |
} | |
d.call(a); | |
for (e in b) | |
a.style[e] = f[e] | |
}}); | |
if (c.expr && c.expr.filters) { | |
c.expr.filters.hidden = function(a) { | |
var b = | |
a.offsetWidth, d = a.offsetHeight, f = a.nodeName.toLowerCase() === "tr"; | |
return b === 0 && d === 0 && !f ? true : b > 0 && d > 0 && !f ? false : c.curCSS(a, "display") === "none" | |
}; | |
c.expr.filters.visible = function(a) { | |
return !c.expr.filters.hidden(a) | |
} | |
} | |
var sb = J(), tb = /<script(.|\s)*?\/script>/gi, ub = /select|textarea/i, vb = /color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i, N = /=\?(&|$)/, ka = /\?/, wb = /(\?|&)_=.*?(&|$)/, xb = /^(\w+:)?\/\/([^\/?#]+)/, yb = /%20/g, zb = c.fn.load; | |
c.fn.extend({load: function(a, b, d) { | |
if (typeof a !== | |
"string") | |
return zb.call(this, a); | |
else if (!this.length) | |
return this; | |
var f = a.indexOf(" "); | |
if (f >= 0) { | |
var e = a.slice(f, a.length); | |
a = a.slice(0, f) | |
} | |
f = "GET"; | |
if (b) | |
if (c.isFunction(b)) { | |
d = b; | |
b = null | |
} else if (typeof b === "object") { | |
b = c.param(b, c.ajaxSettings.traditional); | |
f = "POST" | |
} | |
var j = this; | |
c.ajax({url: a,type: f,dataType: "html",data: b,complete: function(i, o) { | |
if (o === "success" || o === "notmodified") | |
j.html(e ? c("<div />").append(i.responseText.replace(tb, "")).find(e) : i.responseText); | |
d && j.each(d, [i.responseText, o, i]) | |
}}); | |
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 || ub.test(this.nodeName) || vb.test(this.type)) | |
}).map(function(a, b) { | |
a = c(this).val(); | |
return a == null ? null : c.isArray(a) ? c.map(a, function(d) { | |
return {name: b.name,value: d} | |
}) : {name: b.name,value: a} | |
}).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, f) { | |
if (c.isFunction(b)) { | |
f = f || d; | |
d = b; | |
b = null | |
} | |
return c.ajax({type: "GET",url: a,data: b,success: d,dataType: f}) | |
},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, f) { | |
if (c.isFunction(b)) { | |
f = f || d; | |
d = b; | |
b = {} | |
} | |
return c.ajax({type: "POST",url: a,data: b,success: d,dataType: f}) | |
},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: A.XMLHttpRequest && (A.location.protocol !== "file:" || !A.ActiveXObject) ? function() { | |
return new A.XMLHttpRequest | |
} : function() { | |
try { | |
return new A.ActiveXObject("Microsoft.XMLHTTP") | |
} catch (a) { | |
} | |
},accepts: {xml: "application/xml, text/xml",html: "text/html",script: "text/javascript, application/javascript",json: "application/json, text/javascript",text: "text/plain",_default: "*/*"}},lastModified: {},etag: {},ajax: function(a) { | |
function b() { | |
e.success && | |
e.success.call(k, o, i, x); | |
e.global && f("ajaxSuccess", [x, e]) | |
} | |
function d() { | |
e.complete && e.complete.call(k, x, i); | |
e.global && f("ajaxComplete", [x, e]); | |
e.global && !--c.active && c.event.trigger("ajaxStop") | |
} | |
function f(q, p) { | |
(e.context ? c(e.context) : c.event).trigger(q, p) | |
} | |
var e = c.extend(true, {}, c.ajaxSettings, a), j, i, o, k = a && a.context || e, n = e.type.toUpperCase(); | |
if (e.data && e.processData && typeof e.data !== "string") | |
e.data = c.param(e.data, e.traditional); | |
if (e.dataType === "jsonp") { | |
if (n === "GET") | |
N.test(e.url) || (e.url += (ka.test(e.url) ? | |
"&" : "?") + (e.jsonp || "callback") + "=?"); | |
else if (!e.data || !N.test(e.data)) | |
e.data = (e.data ? e.data + "&" : "") + (e.jsonp || "callback") + "=?"; | |
e.dataType = "json" | |
} | |
if (e.dataType === "json" && (e.data && N.test(e.data) || N.test(e.url))) { | |
j = e.jsonpCallback || "jsonp" + sb++; | |
if (e.data) | |
e.data = (e.data + "").replace(N, "=" + j + "$1"); | |
e.url = e.url.replace(N, "=" + j + "$1"); | |
e.dataType = "script"; | |
A[j] = A[j] || function(q) { | |
o = q; | |
b(); | |
d(); | |
A[j] = w; | |
try { | |
delete A[j] | |
} catch (p) { | |
} | |
z && z.removeChild(C) | |
} | |
} | |
if (e.dataType === "script" && e.cache === null) | |
e.cache = false; | |
if (e.cache === | |
false && n === "GET") { | |
var r = J(), u = e.url.replace(wb, "$1_=" + r + "$2"); | |
e.url = u + (u === e.url ? (ka.test(e.url) ? "&" : "?") + "_=" + r : "") | |
} | |
if (e.data && n === "GET") | |
e.url += (ka.test(e.url) ? "&" : "?") + e.data; | |
e.global && !c.active++ && c.event.trigger("ajaxStart"); | |
r = (r = xb.exec(e.url)) && (r[1] && r[1] !== location.protocol || r[2] !== location.host); | |
if (e.dataType === "script" && n === "GET" && r) { | |
var z = s.getElementsByTagName("head")[0] || s.documentElement, C = s.createElement("script"); | |
C.src = e.url; | |
if (e.scriptCharset) | |
C.charset = e.scriptCharset; | |
if (!j) { | |
var B = | |
false; | |
C.onload = C.onreadystatechange = function() { | |
if (!B && (!this.readyState || this.readyState === "loaded" || this.readyState === "complete")) { | |
B = true; | |
b(); | |
d(); | |
C.onload = C.onreadystatechange = null; | |
z && C.parentNode && z.removeChild(C) | |
} | |
} | |
} | |
z.insertBefore(C, z.firstChild); | |
return w | |
} | |
var E = false, x = e.xhr(); | |
if (x) { | |
e.username ? x.open(n, e.url, e.async, e.username, e.password) : x.open(n, e.url, e.async); | |
try { | |
if (e.data || a && a.contentType) | |
x.setRequestHeader("Content-Type", e.contentType); | |
if (e.ifModified) { | |
c.lastModified[e.url] && x.setRequestHeader("If-Modified-Since", | |
c.lastModified[e.url]); | |
c.etag[e.url] && x.setRequestHeader("If-None-Match", c.etag[e.url]) | |
} | |
r || x.setRequestHeader("X-Requested-With", "XMLHttpRequest"); | |
x.setRequestHeader("Accept", e.dataType && e.accepts[e.dataType] ? e.accepts[e.dataType] + ", */*" : e.accepts._default) | |
} catch (ga) { | |
} | |
if (e.beforeSend && e.beforeSend.call(k, x, e) === false) { | |
e.global && !--c.active && c.event.trigger("ajaxStop"); | |
x.abort(); | |
return false | |
} | |
e.global && f("ajaxSend", [x, e]); | |
var g = x.onreadystatechange = function(q) { | |
if (!x || x.readyState === 0 || q === "abort") { | |
E || | |
d(); | |
E = true; | |
if (x) | |
x.onreadystatechange = c.noop | |
} else if (!E && x && (x.readyState === 4 || q === "timeout")) { | |
E = true; | |
x.onreadystatechange = c.noop; | |
i = q === "timeout" ? "timeout" : !c.httpSuccess(x) ? "error" : e.ifModified && c.httpNotModified(x, e.url) ? "notmodified" : "success"; | |
var p; | |
if (i === "success") | |
try { | |
o = c.httpData(x, e.dataType, e) | |
} catch (v) { | |
i = "parsererror"; | |
p = v | |
} | |
if (i === "success" || i === "notmodified") | |
j || b(); | |
else | |
c.handleError(e, x, i, p); | |
d(); | |
q === "timeout" && x.abort(); | |
if (e.async) | |
x = null | |
} | |
}; | |
try { | |
var h = x.abort; | |
x.abort = function() { | |
x && h.call(x); | |
g("abort") | |
} | |
} catch (l) { | |
} | |
e.async && e.timeout > 0 && setTimeout(function() { | |
x && !E && g("timeout") | |
}, e.timeout); | |
try { | |
x.send(n === "POST" || n === "PUT" || n === "DELETE" ? e.data : null) | |
} catch (m) { | |
c.handleError(e, x, null, m); | |
d() | |
} | |
e.async || g(); | |
return x | |
} | |
},handleError: function(a, b, d, f) { | |
if (a.error) | |
a.error.call(a.context || a, b, d, f); | |
if (a.global) | |
(a.context ? c(a.context) : c.event).trigger("ajaxError", [b, a, f]) | |
},active: 0,httpSuccess: function(a) { | |
try { | |
return !a.status && location.protocol === "file:" || a.status >= 200 && a.status < 300 || a.status === 304 || a.status === | |
1223 || a.status === 0 | |
} catch (b) { | |
} | |
return false | |
},httpNotModified: function(a, b) { | |
var d = a.getResponseHeader("Last-Modified"), f = a.getResponseHeader("Etag"); | |
if (d) | |
c.lastModified[b] = d; | |
if (f) | |
c.etag[b] = f; | |
return a.status === 304 || a.status === 0 | |
},httpData: function(a, b, d) { | |
var f = a.getResponseHeader("content-type") || "", e = b === "xml" || !b && f.indexOf("xml") >= 0; | |
a = e ? a.responseXML : a.responseText; | |
e && a.documentElement.nodeName === "parsererror" && c.error("parsererror"); | |
if (d && d.dataFilter) | |
a = d.dataFilter(a, b); | |
if (typeof a === "string") | |
if (b === | |
"json" || !b && f.indexOf("json") >= 0) | |
a = c.parseJSON(a); | |
else if (b === "script" || !b && f.indexOf("javascript") >= 0) | |
c.globalEval(a); | |
return a | |
},param: function(a, b) { | |
function d(i, o) { | |
if (c.isArray(o)) | |
c.each(o, function(k, n) { | |
b || /\[\]$/.test(i) ? f(i, n) : d(i + "[" + (typeof n === "object" || c.isArray(n) ? k : "") + "]", n) | |
}); | |
else | |
!b && o != null && typeof o === "object" ? c.each(o, function(k, n) { | |
d(i + "[" + k + "]", n) | |
}) : f(i, o) | |
} | |
function f(i, o) { | |
o = c.isFunction(o) ? o() : o; | |
e[e.length] = encodeURIComponent(i) + "=" + encodeURIComponent(o) | |
} | |
var e = []; | |
if (b === w) | |
b = c.ajaxSettings.traditional; | |
if (c.isArray(a) || a.jquery) | |
c.each(a, function() { | |
f(this.name, this.value) | |
}); | |
else | |
for (var j in a) | |
d(j, a[j]); | |
return e.join("&").replace(yb, "+") | |
}}); | |
var la = {}, Ab = /toggle|show|hide/, Bb = /^([+-]=)?([\d+-.]+)(.*)$/, W, va = [["height", "marginTop", "marginBottom", "paddingTop", "paddingBottom"], ["width", "marginLeft", "marginRight", "paddingLeft", "paddingRight"], ["opacity"]]; | |
c.fn.extend({show: function(a, b) { | |
if (a || a === 0) | |
return this.animate(K("show", 3), a, b); | |
else { | |
a = 0; | |
for (b = this.length; a < b; a++) { | |
var d = c.data(this[a], "olddisplay"); | |
this[a].style.display = d || ""; | |
if (c.css(this[a], "display") === "none") { | |
d = this[a].nodeName; | |
var f; | |
if (la[d]) | |
f = la[d]; | |
else { | |
var e = c("<" + d + " />").appendTo("body"); | |
f = e.css("display"); | |
if (f === "none") | |
f = "block"; | |
e.remove(); | |
la[d] = f | |
} | |
c.data(this[a], "olddisplay", f) | |
} | |
} | |
a = 0; | |
for (b = this.length; a < b; a++) | |
this[a].style.display = c.data(this[a], "olddisplay") || ""; | |
return this | |
} | |
},hide: function(a, b) { | |
if (a || a === 0) | |
return this.animate(K("hide", 3), a, b); | |
else { | |
a = 0; | |
for (b = this.length; a < b; a++) { | |
var d = c.data(this[a], "olddisplay"); | |
!d && d !== "none" && c.data(this[a], | |
"olddisplay", c.css(this[a], "display")) | |
} | |
a = 0; | |
for (b = this.length; a < b; a++) | |
this[a].style.display = "none"; | |
return this | |
} | |
},_toggle: c.fn.toggle,toggle: function(a, b) { | |
var d = typeof a === "boolean"; | |
if (c.isFunction(a) && c.isFunction(b)) | |
this._toggle.apply(this, arguments); | |
else | |
a == null || d ? this.each(function() { | |
var f = d ? a : c(this).is(":hidden"); | |
c(this)[f ? "show" : "hide"]() | |
}) : this.animate(K("toggle", 3), a, b); | |
return this | |
},fadeTo: function(a, b, d) { | |
return this.filter(":hidden").css("opacity", 0).show().end().animate({opacity: b}, a, d) | |
}, | |
animate: function(a, b, d, f) { | |
var e = c.speed(b, d, f); | |
if (c.isEmptyObject(a)) | |
return this.each(e.complete); | |
return this[e.queue === false ? "each" : "queue"](function() { | |
var j = c.extend({}, e), i, o = this.nodeType === 1 && c(this).is(":hidden"), k = this; | |
for (i in a) { | |
var n = i.replace(ia, ja); | |
if (i !== n) { | |
a[n] = a[i]; | |
delete a[i]; | |
i = n | |
} | |
if (a[i] === "hide" && o || a[i] === "show" && !o) | |
return j.complete.call(this); | |
if ((i === "height" || i === "width") && this.style) { | |
j.display = c.css(this, "display"); | |
j.overflow = this.style.overflow | |
} | |
if (c.isArray(a[i])) { | |
(j.specialEasing = | |
j.specialEasing || {})[i] = a[i][1]; | |
a[i] = a[i][0] | |
} | |
} | |
if (j.overflow != null) | |
this.style.overflow = "hidden"; | |
j.curAnim = c.extend({}, a); | |
c.each(a, function(r, u) { | |
var z = new c.fx(k, j, r); | |
if (Ab.test(u)) | |
z[u === "toggle" ? o ? "show" : "hide" : u](a); | |
else { | |
var C = Bb.exec(u), B = z.cur(true) || 0; | |
if (C) { | |
u = parseFloat(C[2]); | |
var E = C[3] || "px"; | |
if (E !== "px") { | |
k.style[r] = (u || 1) + E; | |
B = (u || 1) / z.cur(true) * B; | |
k.style[r] = B + E | |
} | |
if (C[1]) | |
u = (C[1] === "-=" ? -1 : 1) * u + B; | |
z.custom(B, u, E) | |
} else | |
z.custom(B, u, "") | |
} | |
}); | |
return true | |
}) | |
},stop: function(a, b) { | |
var d = c.timers; | |
a && this.queue([]); | |
this.each(function() { | |
for (var f = d.length - 1; f >= 0; f--) | |
if (d[f].elem === this) { | |
b && d[f](true); | |
d.splice(f, 1) | |
} | |
}); | |
b || this.dequeue(); | |
return this | |
}}); | |
c.each({slideDown: K("show", 1),slideUp: K("hide", 1),slideToggle: K("toggle", 1),fadeIn: {opacity: "show"},fadeOut: {opacity: "hide"}}, function(a, b) { | |
c.fn[a] = function(d, f) { | |
return this.animate(b, d, f) | |
} | |
}); | |
c.extend({speed: function(a, b, d) { | |
var f = a && typeof a === "object" ? a : {complete: d || !d && b || c.isFunction(a) && a,duration: a,easing: d && b || b && !c.isFunction(b) && b}; | |
f.duration = c.fx.off ? 0 : typeof f.duration === | |
"number" ? f.duration : c.fx.speeds[f.duration] || c.fx.speeds._default; | |
f.old = f.complete; | |
f.complete = function() { | |
f.queue !== false && c(this).dequeue(); | |
c.isFunction(f.old) && f.old.call(this) | |
}; | |
return f | |
},easing: {linear: function(a, b, d, f) { | |
return d + f * a | |
},swing: function(a, b, d, f) { | |
return (-Math.cos(a * Math.PI) / 2 + 0.5) * f + 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); | |
if ((this.prop === "height" || this.prop === "width") && this.elem.style) | |
this.elem.style.display = "block" | |
},cur: function(a) { | |
if (this.elem[this.prop] != null && (!this.elem.style || this.elem.style[this.prop] == null)) | |
return this.elem[this.prop]; | |
return (a = parseFloat(c.css(this.elem, this.prop, a))) && a > -10000 ? a : parseFloat(c.curCSS(this.elem, this.prop)) || 0 | |
},custom: function(a, b, d) { | |
function f(j) { | |
return e.step(j) | |
} | |
this.startTime = J(); | |
this.start = a; | |
this.end = b; | |
this.unit = d || this.unit || "px"; | |
this.now = this.start; | |
this.pos = this.state = 0; | |
var e = this; | |
f.elem = this.elem; | |
if (f() && c.timers.push(f) && !W) | |
W = setInterval(c.fx.tick, 13) | |
},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 = J(), 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 f in this.options.curAnim) | |
if (this.options.curAnim[f] !== true) | |
d = false; | |
if (d) { | |
if (this.options.display != null) { | |
this.elem.style.overflow = this.options.overflow; | |
a = c.data(this.elem, "olddisplay"); | |
this.elem.style.display = a ? a : this.options.display; | |
if (c.css(this.elem, "display") === "none") | |
this.elem.style.display = "block" | |
} | |
this.options.hide && c(this.elem).hide(); | |
if (this.options.hide || this.options.show) | |
for (var e in this.options.curAnim) | |
c.style(this.elem, | |
e, this.options.orig[e]); | |
this.options.complete.call(this.elem) | |
} | |
return false | |
} else { | |
e = b - this.startTime; | |
this.state = e / this.options.duration; | |
a = this.options.easing || (c.easing.swing ? "swing" : "linear"); | |
this.pos = c.easing[this.options.specialEasing && this.options.specialEasing[this.prop] || a](this.state, e, 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() | |
},stop: function() { | |
clearInterval(W); | |
W = 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 | |
}; | |
c.fn.offset = "getBoundingClientRect" in s.documentElement ? | |
function(a) { | |
var b = this[0]; | |
if (a) | |
return this.each(function(e) { | |
c.offset.setOffset(this, a, e) | |
}); | |
if (!b || !b.ownerDocument) | |
return null; | |
if (b === b.ownerDocument.body) | |
return c.offset.bodyOffset(b); | |
var d = b.getBoundingClientRect(), f = b.ownerDocument; | |
b = f.body; | |
f = f.documentElement; | |
return {top: d.top + (self.pageYOffset || c.support.boxModel && f.scrollTop || b.scrollTop) - (f.clientTop || b.clientTop || 0),left: d.left + (self.pageXOffset || c.support.boxModel && f.scrollLeft || b.scrollLeft) - (f.clientLeft || b.clientLeft || 0)} | |
} : function(a) { | |
var b = | |
this[0]; | |
if (a) | |
return this.each(function(r) { | |
c.offset.setOffset(this, a, r) | |
}); | |
if (!b || !b.ownerDocument) | |
return null; | |
if (b === b.ownerDocument.body) | |
return c.offset.bodyOffset(b); | |
c.offset.initialize(); | |
var d = b.offsetParent, f = b, e = b.ownerDocument, j, i = e.documentElement, o = e.body; | |
f = (e = e.defaultView) ? e.getComputedStyle(b, null) : b.currentStyle; | |
for (var k = b.offsetTop, n = b.offsetLeft; (b = b.parentNode) && b !== o && b !== i; ) { | |
if (c.offset.supportsFixedPosition && f.position === "fixed") | |
break; | |
j = e ? e.getComputedStyle(b, null) : b.currentStyle; | |
k -= b.scrollTop; | |
n -= b.scrollLeft; | |
if (b === d) { | |
k += b.offsetTop; | |
n += b.offsetLeft; | |
if (c.offset.doesNotAddBorder && !(c.offset.doesAddBorderForTableAndCells && /^t(able|d|h)$/i.test(b.nodeName))) { | |
k += parseFloat(j.borderTopWidth) || 0; | |
n += parseFloat(j.borderLeftWidth) || 0 | |
} | |
f = d; | |
d = b.offsetParent | |
} | |
if (c.offset.subtractsBorderForOverflowNotVisible && j.overflow !== "visible") { | |
k += parseFloat(j.borderTopWidth) || 0; | |
n += parseFloat(j.borderLeftWidth) || 0 | |
} | |
f = j | |
} | |
if (f.position === "relative" || f.position === "static") { | |
k += o.offsetTop; | |
n += o.offsetLeft | |
} | |
if (c.offset.supportsFixedPosition && | |
f.position === "fixed") { | |
k += Math.max(i.scrollTop, o.scrollTop); | |
n += Math.max(i.scrollLeft, o.scrollLeft) | |
} | |
return {top: k,left: n} | |
}; | |
c.offset = {initialize: function() { | |
var a = s.body, b = s.createElement("div"), d, f, e, j = parseFloat(c.curCSS(a, "marginTop", true)) || 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; | |
f = d.firstChild; | |
e = d.nextSibling.firstChild.firstChild; | |
this.doesNotAddBorder = f.offsetTop !== 5; | |
this.doesAddBorderForTableAndCells = e.offsetTop === 5; | |
f.style.position = "fixed"; | |
f.style.top = "20px"; | |
this.supportsFixedPosition = f.offsetTop === 20 || f.offsetTop === 15; | |
f.style.position = f.style.top = ""; | |
d.style.overflow = "hidden"; | |
d.style.position = "relative"; | |
this.subtractsBorderForOverflowNotVisible = f.offsetTop === -5; | |
this.doesNotIncludeMarginInBodyOffset = a.offsetTop !== j; | |
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.curCSS(a, "marginTop", true)) || 0; | |
d += parseFloat(c.curCSS(a, "marginLeft", true)) || 0 | |
} | |
return {top: b,left: d} | |
},setOffset: function(a, b, d) { | |
if (/static/.test(c.curCSS(a, "position"))) | |
a.style.position = "relative"; | |
var f = c(a), e = f.offset(), j = parseInt(c.curCSS(a, "top", true), 10) || 0, i = parseInt(c.curCSS(a, "left", true), 10) || 0; | |
if (c.isFunction(b)) | |
b = b.call(a, | |
d, e); | |
d = {top: b.top - e.top + j,left: b.left - e.left + i}; | |
"using" in b ? b.using.call(a, d) : f.css(d) | |
}}; | |
c.fn.extend({position: function() { | |
if (!this[0]) | |
return null; | |
var a = this[0], b = this.offsetParent(), d = this.offset(), f = /^body|html$/i.test(b[0].nodeName) ? {top: 0,left: 0} : b.offset(); | |
d.top -= parseFloat(c.curCSS(a, "marginTop", true)) || 0; | |
d.left -= parseFloat(c.curCSS(a, "marginLeft", true)) || 0; | |
f.top += parseFloat(c.curCSS(b[0], "borderTopWidth", true)) || 0; | |
f.left += parseFloat(c.curCSS(b[0], "borderLeftWidth", true)) || 0; | |
return {top: d.top - | |
f.top,left: d.left - f.left} | |
},offsetParent: function() { | |
return this.map(function() { | |
for (var a = this.offsetParent || s.body; a && !/^body|html$/i.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(f) { | |
var e = this[0], j; | |
if (!e) | |
return null; | |
if (f !== w) | |
return this.each(function() { | |
if (j = wa(this)) | |
j.scrollTo(!a ? f : c(j).scrollLeft(), a ? f : c(j).scrollTop()); | |
else | |
this[d] = f | |
}); | |
else | |
return (j = wa(e)) ? "pageXOffset" in j ? j[a ? "pageYOffset" : | |
"pageXOffset"] : c.support.boxModel && j.document.documentElement[d] || j.document.body[d] : e[d] | |
} | |
}); | |
c.each(["Height", "Width"], function(a, b) { | |
var d = b.toLowerCase(); | |
c.fn["inner" + b] = function() { | |
return this[0] ? c.css(this[0], d, false, "padding") : null | |
}; | |
c.fn["outer" + b] = function(f) { | |
return this[0] ? c.css(this[0], d, false, f ? "margin" : "border") : null | |
}; | |
c.fn[d] = function(f) { | |
var e = this[0]; | |
if (!e) | |
return f == null ? null : this; | |
if (c.isFunction(f)) | |
return this.each(function(j) { | |
var i = c(this); | |
i[d](f.call(this, j, i[d]())) | |
}); | |
return "scrollTo" in | |
e && e.document ? e.document.compatMode === "CSS1Compat" && e.document.documentElement["client" + b] || e.document.body["client" + b] : e.nodeType === 9 ? Math.max(e.documentElement["client" + b], e.body["scroll" + b], e.documentElement["scroll" + b], e.body["offset" + b], e.documentElement["offset" + b]) : f === w ? c.css(e, d) : this.css(d, typeof f === "string" ? f : f + "px") | |
} | |
}); | |
A.jQuery = A.$ = c | |
})(window); | |
jQuery source converted to coffeescript via https://github.com/rstacruz/js2coffee | |
((A, w) -> | |
ma = -> | |
if not c.isReady | |
try | |
s.documentElement.doScroll 'left' | |
catch a | |
setTimeout ma, 1 | |
return | |
c.ready() | |
Qa = (a, b) -> | |
(if b.src then c.ajax( | |
url: b.src | |
async: false | |
dataType: 'script' | |
) else c.globalEval(b.text or b.textContent or b.innerHTML or '')) | |
b.parentNode and b.parentNode.removeChild(b) | |
X = (a, b, d, f, e, j) -> | |
i = a.length | |
if typeof(b) is 'object' | |
for o of b | |
X a, o, b[o], f, e, d | |
return a | |
if d isnt w | |
f = not j and f and c.isFunction(d) | |
o = 0 | |
while o < i | |
e a[o], b, (if f then d.call(a[o], o, e(a[o], b)) else d), j | |
o++ | |
return a | |
(if i then e(a[0], b) else w) | |
J = -> | |
(new Date).getTime() | |
Y = -> | |
false | |
Z = -> | |
true | |
na = (a, b, d) -> | |
d[0].type = a | |
c.event.handle.apply b, d | |
oa = (a) -> | |
d = [] | |
f = [] | |
e = arguments | |
i = c.data(this, 'events') | |
if not (a.liveFired is this or not i or not i.live or a.button and a.type is 'click') | |
a.liveFired = this | |
u = i.live.slice(0) | |
k = 0 | |
while k < u.length | |
i = u[k] | |
(if i.origType.replace(O, '') is a.type then f.push(i.selector) else u.splice(k--, 1)) | |
k++ | |
j = c(a.target).closest(f, a.currentTarget) | |
n = 0 | |
r = j.length | |
while n < r | |
k = 0 | |
while k < u.length | |
i = u[k] | |
if j[n].selector is i.selector | |
o = j[n].elem | |
f = null | |
f = c(a.relatedTarget).closest(i.selector)[0] if i.preType is 'mouseenter' or i.preType is 'mouseleave' | |
if not f or f isnt o | |
d.push | |
elem: o | |
handleObj: i | |
k++ | |
n++ | |
n = 0 | |
r = d.length | |
while n < r | |
j = d[n] | |
a.currentTarget = j.elem | |
a.data = j.handleObj.data | |
a.handleObj = j.handleObj | |
if j.handleObj.origHandler.apply(j.elem, e) is false | |
b = false | |
break | |
n++ | |
return b | |
pa = (a, b) -> | |
'live.' + ((if a and a isnt '*' then a + '.' else '')) + b.replace(/\./g, '`').replace(RegExp(' ', 'g'), '&') | |
qa = (a) -> | |
not a or not a.parentNode or a.parentNode.nodeType is 11 | |
ra = (a, b) -> | |
d = 0 | |
b.each -> | |
if @nodeName is (a[d] and a[d].nodeName) | |
f = c.data(a[d++]) | |
e = c.data(this, f) | |
if f = f and f.events | |
delete e.handle | |
e.events = {} | |
for j of f | |
for i of f[j] | |
c.event.add this, j, f[j][i], f[j][i].data | |
sa = (a, b, d) -> | |
b = (if b and b[0] then b[0].ownerDocument or b[0] else s) | |
if a.length is 1 and typeof(a[0]) is 'string' and a[0].length < 512 and b is s and not ta.test(a[0]) and (c.support.checkClone or not ua.test(a[0])) | |
e = true | |
f = j if j isnt 1 if j = c.fragments[a[0]] | |
if not f | |
f = b.createDocumentFragment() | |
c.clean a, b, f, d | |
c.fragments[a[0]] = (if j then f else 1) if e | |
{ | |
fragment: f | |
cacheable: e | |
} | |
K = (a, b) -> | |
d = {} | |
c.each va.concat.apply([], va.slice(0, b)), -> | |
d[this] = a | |
d | |
wa = (a) -> | |
(if 'scrollTo' in a and a.document then a else (if a.nodeType is 9 then a.defaultView or a.parentWindow else false)) | |
c = (a, b) -> | |
new c.fn.init(a, b) | |
Ra = A.jQuery | |
Sa = A.$ | |
s = A.document | |
Ta = /^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/ | |
Ua = /^.[^:#\[\.,]*$/ | |
Va = /\S/ | |
Wa = /^(\s|\u00A0)+|(\s|\u00A0)+$/g | |
Xa = /^<(\w+)\s*\/?>(?:<\/\1>)?$/ | |
P = navigator.userAgent | |
xa = false | |
Q = [] | |
$ = Object.prototype.toString | |
aa = Object.prototype.hasOwnProperty | |
ba = Array.prototype.push | |
R = Array.prototype.slice | |
ya = Array.prototype.indexOf | |
c.fn = c.prototype = | |
init: (a, b) -> | |
return this if not a | |
if a.nodeType | |
@context = this[0] = a | |
@length = 1 | |
return this | |
if a is 'body' and not b | |
@context = s | |
this[0] = s.body | |
@selector = 'body' | |
@length = 1 | |
return this | |
if typeof(a) is 'string' | |
if (d = Ta.exec(a)) and (d[1] or not b) | |
if d[1] | |
f = (if b then b.ownerDocument or b else s) | |
if a = Xa.exec(a) | |
if c.isPlainObject(b) | |
a = [s.createElement(a[1])] | |
c.fn.attr.call a, b, true | |
else a = [f.createElement(a[1])] | |
else a = sa([d[1]], [f]) | |
a = ((if a.cacheable then a.fragment.cloneNode(true) else a.fragment)).childNodes | |
return c.merge(this, a) | |
else if b = s.getElementById(d[2]) | |
return T.find(a) if b.id isnt d[2] | |
@length = 1 | |
this[0] = b | |
@context = s | |
@selector = a | |
return this | |
else if not b and /^\w+$/.test(a) | |
@selector = a | |
@context = s | |
a = s.getElementsByTagName(a) | |
return c.merge(this, a) | |
else return (if not b or b.jquery then (b or T).find(a) else c(b).find(a)) | |
else return T.ready(a) if c.isFunction(a) | |
if a.selector isnt w | |
@selector = a.selector | |
@context = a.context | |
c.makeArray a, this | |
selector: '' | |
jquery: '1.4.2' | |
length: 0 | |
size: -> | |
@length | |
toArray: -> | |
R.call this, 0 | |
get: (a) -> | |
(if a == null then @toArray() else (if a < 0 then @slice(a)[0] else this[a])) | |
pushStack: (a, b, d) -> | |
f = c() | |
(if c.isArray(a) then ba.apply(f, a) else c.merge(f, a)) | |
f.prevObject = this | |
f.context = @context | |
if b is 'find' | |
f.selector = @selector + ((if @selector then ' ' else '')) + d | |
else f.selector = @selector + '.' + b + '(' + d + ')' if b | |
f | |
each: (a, b) -> | |
c.each this, a, b | |
ready: (a) -> | |
c.bindReady() | |
if c.isReady | |
a.call s, c | |
else Q and Q.push(a) | |
this | |
eq: (a) -> | |
(if a is -1 then @slice(a) else @slice(a, +a + 1)) | |
first: -> | |
@eq 0 | |
last: -> | |
@eq -1 | |
slice: -> | |
@pushStack R.apply(this, arguments), 'slice', R.call(arguments).join(',') | |
map: (a) -> | |
@pushStack c.map(this, (b, d) -> | |
a.call b, d, b | |
) | |
end: -> | |
@prevObject or c(null) | |
push: ba | |
sort: [].sort | |
splice: [].splice | |
c.fn.init.prototype = c.fn | |
c.extend = c.fn.extend = -> | |
a = arguments[0] or {} | |
b = 1 | |
d = arguments.length | |
f = false | |
if typeof(a) is 'boolean' | |
f = a | |
a = arguments[1] or {} | |
b = 2 | |
a = {} if typeof(a) isnt 'object' and not c.isFunction(a) | |
if d is b | |
a = this | |
b-- | |
while b < d | |
if (e = arguments[b]) != null | |
for j of e | |
i = a[j] | |
o = e[j] | |
if a isnt o | |
if f and o and (c.isPlainObject(o) or c.isArray(o)) | |
i = (if i and (c.isPlainObject(i) or c.isArray(i)) then i else (if c.isArray(o) then [] else {})) | |
a[j] = c.extend(f, i, o) | |
else a[j] = o if o isnt w | |
b++ | |
a | |
c.extend | |
noConflict: (a) -> | |
A.$ = Sa | |
A.jQuery = Ra if a | |
c | |
isReady: false | |
ready: -> | |
if not c.isReady | |
return setTimeout(c.ready, 13) if not s.body | |
c.isReady = true | |
if Q | |
b = 0 | |
while a = Q[b++] | |
a.call s, c | |
Q = null | |
c.fn.triggerHandler and c(s).triggerHandler('ready') | |
bindReady: -> | |
if not xa | |
xa = true | |
return c.ready() if s.readyState is 'complete' | |
if s.addEventListener | |
s.addEventListener 'DOMContentLoaded', L, false | |
A.addEventListener 'load', c.ready, false | |
else if s.attachEvent | |
s.attachEvent 'onreadystatechange', L | |
A.attachEvent 'onload', c.ready | |
a = false | |
try | |
a = A.frameElement == null | |
catch b | |
s.documentElement.doScroll and a and ma() | |
isFunction: (a) -> | |
$.call(a) is '[object Function]' | |
isArray: (a) -> | |
$.call(a) is '[object Array]' | |
isPlainObject: (a) -> | |
return false if not a or $.call(a) isnt '[object Object]' or a.nodeType or a.setInterval | |
return false if a.constructor and not aa.call(a, 'constructor') and not aa.call(a.constructor.prototype, 'isPrototypeOf') | |
for b of a | |
0 | |
b is w or aa.call(a, b) | |
isEmptyObject: (a) -> | |
for b of a | |
return false | |
true | |
error: (a) -> | |
throw a | |
parseJSON: (a) -> | |
return null if typeof(a) isnt 'string' or not a | |
a = c.trim(a) | |
if /^[\],:{}\s]*$/.test(a.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, '@').replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']').replace(/(?:^|:|,)(?:\s*\[)+/g, '')) | |
return (if A.JSON and A.JSON.parse then A.JSON.parse(a) else (new Function('return ' + a))()) | |
else c.error 'Invalid JSON: ' + a | |
noop: -> | |
globalEval: (a) -> | |
if a and Va.test(a) | |
b = s.getElementsByTagName('head')[0] or s.documentElement | |
d = s.createElement('script') | |
d.type = 'text/javascript' | |
if c.support.scriptEval | |
d.appendChild s.createTextNode(a) | |
else d.text = a | |
b.insertBefore d, b.firstChild | |
b.removeChild d | |
nodeName: (a, b) -> | |
a.nodeName and a.nodeName.toUpperCase() is b.toUpperCase() | |
each: (a, b, d) -> | |
e = 0 | |
j = a.length | |
i = j is w or c.isFunction(a) | |
if d | |
if i | |
for f of a | |
break if b.apply(a[f], d) is false | |
else while e < j | |
break if b.apply(a[e++], d) is false | |
else if i | |
for f of a | |
break if b.call(a[f], f, a[f]) is false | |
else d = a[0] | |
while e < j and b.call(d, e, d) isnt false | |
d = a[e++] | |
a | |
trim: (a) -> | |
(a or '').replace Wa, '' | |
makeArray: (a, b) -> | |
b = b or [] | |
(if a.length == null or typeof(a) is 'string' or c.isFunction(a) or typeof(a) isnt 'function' and a.setInterval then ba.call(b, a) else c.merge(b, a)) if a != null | |
b | |
inArray: (a, b) -> | |
return b.indexOf(a) if b.indexOf | |
d = 0 | |
f = b.length | |
while d < f | |
return d if b[d] is a | |
d++ | |
-1 | |
merge: (a, b) -> | |
d = a.length | |
f = 0 | |
if typeof(b.length) is 'number' | |
e = b.length | |
while f < e | |
a[d++] = b[f] | |
f++ | |
else while b[f] isnt w | |
a[d++] = b[f++] | |
a.length = d | |
a | |
grep: (a, b, d) -> | |
f = [] | |
e = 0 | |
j = a.length | |
while e < j | |
not d isnt not b(a[e], e) and f.push(a[e]) | |
e++ | |
f | |
map: (a, b, d) -> | |
f = [] | |
j = 0 | |
i = a.length | |
while j < i | |
e = b(a[j], j, d) | |
f[f.length] = e if e != null | |
j++ | |
f.concat.apply [], f | |
guid: 1 | |
proxy: (a, b, d) -> | |
if arguments.length is 2 | |
if typeof(b) is 'string' | |
d = a | |
a = d[b] | |
b = w | |
else if b and not c.isFunction(b) | |
d = b | |
b = w | |
if not b and a | |
b = -> | |
a.apply d or this, arguments | |
b.guid = a.guid = a.guid or b.guid or c.guid++ if a | |
b | |
uaMatch: (a) -> | |
a = a.toLowerCase() | |
a = /(webkit)[ \/]([\w.]+)/.exec(a) or /(opera)(?:.*version)?[ \/]([\w.]+)/.exec(a) or /(msie) ([\w.]+)/.exec(a) or not /compatible/.test(a) and /(mozilla)(?:.*? rv:([\w.]+))?/.exec(a) or [] | |
{ | |
browser: a[1] or '' | |
version: a[2] or '0' | |
} | |
browser: {} | |
P = c.uaMatch(P) | |
if P.browser | |
c.browser[P.browser] = true | |
c.browser.version = P.version | |
c.browser.safari = true if c.browser.webkit | |
if ya | |
c.inArray = (a, b) -> | |
ya.call b, a | |
T = c(s) | |
if s.addEventListener | |
L = -> | |
s.removeEventListener 'DOMContentLoaded', L, false | |
c.ready() | |
else if s.attachEvent | |
L = -> | |
if s.readyState is 'complete' | |
s.detachEvent 'onreadystatechange', L | |
c.ready() | |
(-> | |
c.support = {} | |
a = s.documentElement | |
b = s.createElement('script') | |
d = s.createElement('div') | |
f = 'script' + J() | |
d.style.display = 'none' | |
d.innerHTML = " <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>" | |
e = d.getElementsByTagName('*') | |
j = d.getElementsByTagName('a')[0] | |
if not (not e or not e.length or not j) | |
c.support = | |
leadingWhitespace: d.firstChild.nodeType is 3 | |
tbody: not d.getElementsByTagName('tbody').length | |
htmlSerialize: not not d.getElementsByTagName('link').length | |
style: /red/.test(j.getAttribute('style')) | |
hrefNormalized: j.getAttribute('href') is '/a' | |
opacity: /^0.55$/.test(j.style.opacity) | |
cssFloat: not not j.style.cssFloat | |
checkOn: d.getElementsByTagName('input')[0].value is 'on' | |
optSelected: s.createElement('select').appendChild(s.createElement('option')).selected | |
parentNode: d.removeChild(d.appendChild(s.createElement('div'))).parentNode is null | |
deleteExpando: true | |
checkClone: false | |
scriptEval: false | |
noCloneEvent: true | |
boxModel: null | |
b.type = 'text/javascript' | |
try | |
b.appendChild s.createTextNode('window.' + f + '=1;') | |
catch i | |
a.insertBefore b, a.firstChild | |
if A[f] | |
c.support.scriptEval = true | |
delete A[f] | |
try | |
delete b.test | |
catch o | |
c.support.deleteExpando = false | |
a.removeChild b | |
if d.attachEvent and d.fireEvent | |
d.attachEvent 'onclick', k = -> | |
c.support.noCloneEvent = false | |
d.detachEvent 'onclick', k | |
d.cloneNode(true).fireEvent 'onclick' | |
d = s.createElement('div') | |
d.innerHTML = "<input type='radio' name='radiotest' checked='checked'/>" | |
a = s.createDocumentFragment() | |
a.appendChild d.firstChild | |
c.support.checkClone = a.cloneNode(true).cloneNode(true).lastChild.checked | |
c -> | |
k = s.createElement('div') | |
k.style.width = k.style.paddingLeft = '1px' | |
s.body.appendChild k | |
c.boxModel = c.support.boxModel = k.offsetWidth is 2 | |
s.body.removeChild(k).style.display = 'none' | |
a = (k) -> | |
n = s.createElement('div') | |
k = 'on' + k | |
r = k in n | |
if not r | |
n.setAttribute k, 'return;' | |
r = typeof(n[k]) is 'function' | |
r | |
c.support.submitBubbles = a('submit') | |
c.support.changeBubbles = a('change') | |
a = b = d = e = j = null | |
)() | |
c.props = | |
'for': 'htmlFor' | |
'class': 'className' | |
readonly: 'readOnly' | |
maxlength: 'maxLength' | |
cellspacing: 'cellSpacing' | |
rowspan: 'rowSpan' | |
colspan: 'colSpan' | |
tabindex: 'tabIndex' | |
usemap: 'useMap' | |
frameborder: 'frameBorder' | |
G = 'jQuery' + J() | |
Ya = 0 | |
za = {} | |
c.extend | |
cache: {} | |
expando: G | |
noData: { | |
embed: true | |
object: true | |
applet: true | |
} | |
data: (a, b, d) -> | |
if not (a.nodeName and c.noData[a.nodeName.toLowerCase()]) | |
a = (if a == A then za else a) | |
f = a[G] | |
e = c.cache | |
return null if not f and typeof(b) is 'string' and d is w | |
f or (f = Ya++) | |
if typeof(b) is 'object' | |
a[G] = f | |
e[f] = c.extend(true, {}, b) | |
else if not e[f] | |
a[G] = f | |
e[f] = {} | |
a = e[f] | |
a[b] = d if d isnt w | |
return (if typeof(b) is 'string' then a[b] else a) | |
removeData: (a, b) -> | |
if not (a.nodeName and c.noData[a.nodeName.toLowerCase()]) | |
a = (if a == A then za else a) | |
d = a[G] | |
f = c.cache | |
e = f[d] | |
if b | |
if e | |
delete e[b] | |
c.isEmptyObject(e) and c.removeData(a) | |
else if c.support.deleteExpando | |
delete a[c.expando] | |
else a.removeAttribute and a.removeAttribute(c.expando) | |
delete f[d] | |
c.fn.extend | |
data: (a, b) -> | |
if typeof(a) is 'undefined' and @length | |
return c.data(this[0]) | |
else if typeof(a) is 'object' | |
return @each(-> | |
c.data this, a | |
) | |
d = a.split('.') | |
d[1] = (if d[1] then '.' + d[1] else '') | |
if b is w | |
f = @triggerHandler('getData' + d[1] + '!', [d[0]]) | |
f = c.data(this[0], a) if f is w and @length | |
return (if f is w and d[1] then @data(d[0]) else f) | |
else return @trigger('setData' + d[1] + '!', [d[0], b]).each(-> | |
c.data this, a, b | |
) | |
removeData: (a) -> | |
@each -> | |
c.removeData this, a | |
c.extend | |
queue: (a, b, d) -> | |
if a | |
b = (b or 'fx') + 'queue' | |
f = c.data(a, b) | |
return f or [] if not d | |
if not f or c.isArray(d) | |
f = c.data(a, b, c.makeArray(d)) | |
else f.push d | |
return f | |
dequeue: (a, b) -> | |
b = b or 'fx' | |
d = c.queue(a, b) | |
f = d.shift() | |
f = d.shift() if f is 'inprogress' | |
if f | |
b is 'fx' and d.unshift('inprogress') | |
f.call a, -> | |
c.dequeue a, b | |
c.fn.extend | |
queue: (a, b) -> | |
if typeof(a) isnt 'string' | |
b = a | |
a = 'fx' | |
return c.queue(this[0], a) if b is w | |
@each -> | |
d = c.queue(this, a, b) | |
a is 'fx' and d[0] isnt 'inprogress' and c.dequeue(this, a) | |
dequeue: (a) -> | |
@each -> | |
c.dequeue this, a | |
delay: (a, b) -> | |
a = (if c.fx then c.fx.speeds[a] or a else a) | |
b = b or 'fx' | |
@queue b, -> | |
d = this | |
setTimeout -> | |
c.dequeue d, b | |
, a | |
clearQueue: (a) -> | |
@queue a or 'fx', [] | |
Aa = /[\n\t]/g | |
ca = /\s+/ | |
Za = /\r/g | |
$a = /href|src|style/ | |
ab = /(button|input)/i | |
bb = /(button|input|object|select|textarea)/i | |
cb = /^(a|area)$/i | |
Ba = /radio|checkbox/ | |
c.fn.extend | |
attr: (a, b) -> | |
X this, a, b, true, c.attr | |
removeAttr: (a) -> | |
@each -> | |
c.attr this, a, '' | |
@nodeType is 1 and @removeAttribute(a) | |
addClass: (a) -> | |
if c.isFunction(a) | |
return @each((n) -> | |
r = c(this) | |
r.addClass a.call(this, n, r.attr('class')) | |
) | |
if a and typeof(a) is 'string' | |
b = (a or '').split(ca) | |
d = 0 | |
f = @length | |
while d < f | |
e = this[d] | |
if e.nodeType is 1 | |
if e.className | |
j = ' ' + e.className + ' ' | |
i = e.className | |
o = 0 | |
k = b.length | |
while o < k | |
i = ' ' + b[o] if j.indexOf(' ' + b[o] + ' ') < 0 | |
o++ | |
e.className = c.trim(i) | |
else e.className = a | |
d++ | |
this | |
removeClass: (a) -> | |
if c.isFunction(a) | |
return @each((k) -> | |
n = c(this) | |
n.removeClass a.call(this, k, n.attr('class')) | |
) | |
if a and typeof(a) is 'string' or a is w | |
b = (a or '').split(ca) | |
d = 0 | |
f = @length | |
while d < f | |
e = this[d] | |
if e.nodeType is 1 and e.className | |
if a | |
j = (' ' + e.className + ' ').replace(Aa, ' ') | |
i = 0 | |
o = b.length | |
while i < o | |
j = j.replace(' ' + b[i] + ' ', ' ') | |
i++ | |
e.className = c.trim(j) | |
else e.className = '' | |
d++ | |
this | |
toggleClass: (a, b) -> | |
d = typeof(a) | |
f = typeof(b) is 'boolean' | |
if c.isFunction(a) | |
return @each((e) -> | |
j = c(this) | |
j.toggleClass a.call(this, e, j.attr('class'), b), b | |
) | |
@each -> | |
if d is 'string' | |
j = 0 | |
i = c(this) | |
o = b | |
k = a.split(ca) | |
while e = k[j++] | |
o = (if f then o else not i.hasClass(e)) | |
i[(if o then 'addClass' else 'removeClass')] e | |
else if d is 'undefined' or d is 'boolean' | |
@className and c.data(this, '__className__', @className) | |
@className = (if @className or a is false then '' else c.data(this, '__className__') or '') | |
hasClass: (a) -> | |
a = ' ' + a + ' ' | |
b = 0 | |
d = @length | |
while b < d | |
return true if (' ' + this[b].className + ' ').replace(Aa, ' ').indexOf(a) > -1 | |
b++ | |
false | |
val: (a) -> | |
if a is w | |
b = this[0] | |
if b | |
return (if (b.attributes.value or {}).specified then b.value else b.text) if c.nodeName(b, 'option') | |
if c.nodeName(b, 'select') | |
d = b.selectedIndex | |
f = [] | |
e = b.options | |
b = b.type is 'select-one' | |
return null if d < 0 | |
j = (if b then d else 0) | |
d = (if b then d + 1 else e.length) | |
while j < d | |
i = e[j] | |
if i.selected | |
a = c(i).val() | |
return a if b | |
f.push a | |
j++ | |
return f | |
return (if b.getAttribute('value') is null then 'on' else b.value) if Ba.test(b.type) and not c.support.checkOn | |
return (b.value or '').replace(Za, '') | |
return w | |
o = c.isFunction(a) | |
@each (k) -> | |
n = c(this) | |
r = a | |
if @nodeType is 1 | |
r = a.call(this, k, n.val()) if o | |
r = '' if typeof(r) is 'number' | |
if c.isArray(r) and Ba.test(@type) | |
@checked = c.inArray(n.val(), r) >= 0 | |
else if c.nodeName(this, 'select') | |
u = c.makeArray(r) | |
c('option', this).each -> | |
@selected = c.inArray(c(this).val(), u) >= 0 | |
@selectedIndex = -1 if not u.length | |
else @value = r | |
c.extend | |
attrFn: { | |
val: true | |
css: true | |
html: true | |
text: true | |
data: true | |
width: true | |
height: true | |
offset: true | |
} | |
attr: (a, b, d, f) -> | |
return w if not a or a.nodeType is 3 or a.nodeType is 8 | |
return c(a)[b](d) if f and b in c.attrFn | |
f = a.nodeType isnt 1 or not c.isXMLDoc(a) | |
e = d isnt w | |
b = f and c.props[b] or b | |
if a.nodeType is 1 | |
j = $a.test(b) | |
if b in a and f and not j | |
if e | |
b is 'type' and ab.test(a.nodeName) and a.parentNode and c.error("type property can't be changed") | |
a[b] = d | |
return a.getAttributeNode(b).nodeValue if c.nodeName(a, 'form') and a.getAttributeNode(b) | |
return (if (b = a.getAttributeNode('tabIndex')) and b.specified then b.value else (if bb.test(a.nodeName) or cb.test(a.nodeName) and a.href then 0 else w)) if b is 'tabIndex' | |
return a[b] | |
if not c.support.style and f and b is 'style' | |
a.style.cssText = '' + d if e | |
return a.style.cssText | |
e and a.setAttribute(b, '' + d) | |
a = (if not c.support.hrefNormalized and f and j then a.getAttribute(b, 2) else a.getAttribute(b)) | |
return (if a is null then w else a) | |
c.style a, b, d | |
O = /\.(.*)$/ | |
db = (a) -> | |
a.replace /[^\w\s\.\|`]/g, (b) -> | |
'\\' + b | |
c.event = | |
add: (a, b, d, f) -> | |
if not (a.nodeType is 3 or a.nodeType is 8) | |
a = A if a.setInterval and a isnt A and not a.frameElement | |
if d.handler | |
e = d | |
d = e.handler | |
d.guid = c.guid++ if not d.guid | |
if j = c.data(a) | |
i = j.events = j.events or {} | |
o = j.handle | |
if not o | |
j.handle = o = -> | |
(if typeof(c) isnt 'undefined' and not c.event.triggered then c.event.handle.apply(o.elem, arguments) else w) | |
o.elem = a | |
b = b.split(' ') | |
n = 0 | |
while k = b[n++] | |
j = (if e then c.extend({}, e) else { | |
handler: d | |
data: f | |
}) | |
if k.indexOf('.') > -1 | |
r = k.split('.') | |
k = r.shift() | |
j.namespace = r.slice(0).sort().join('.') | |
else r = [] | |
j.namespace = '' | |
j.type = k | |
j.guid = d.guid | |
u = i[k] | |
z = c.event.special[k] or {} | |
if not u | |
u = i[k] = [] | |
if not z.setup or z.setup.call(a, f, r, o) is false | |
if a.addEventListener | |
a.addEventListener k, o, false | |
else a.attachEvent and a.attachEvent('on' + k, o) | |
if z.add | |
z.add.call a, j | |
j.handler.guid = d.guid if not j.handler.guid | |
u.push j | |
c.event.global[k] = true | |
a = null | |
global: {} | |
remove: (a, b, d, f) -> | |
if not (a.nodeType is 3 or a.nodeType is 8) | |
j = 0 | |
z = c.data(a) | |
C = z and z.events | |
if z and C | |
if b and b.type | |
d = b.handler | |
b = b.type | |
if not b or typeof(b) is 'string' and b.charAt(0) is '.' | |
b = b or '' | |
for e of C | |
c.event.remove a, e + b | |
else b = b.split(' ') | |
while e = b[j++] | |
n = e | |
i = e.indexOf('.') < 0 | |
o = [] | |
if not i | |
o = e.split('.') | |
e = o.shift() | |
k = new RegExp('(^|\\.)' + c.map(o.slice(0).sort(), db).join('\\.(?:.*\\.)?') + '(\\.|$)') | |
if r = C[e] | |
if d | |
n = c.event.special[e] or {} | |
B = f or 0 | |
while B < r.length | |
u = r[B] | |
if d.guid is u.guid | |
if i or k.test(u.namespace) | |
f == null and r.splice(B--, 1) | |
n.remove and n.remove.call(a, u) | |
break if f != null | |
B++ | |
if r.length is 0 or f != null and r.length is 1 | |
Ca a, e, z.handle if not n.teardown or n.teardown.call(a, o) is false | |
delete C[e] | |
else B = 0 | |
while B < r.length | |
u = r[B] | |
if i or k.test(u.namespace) | |
c.event.remove a, n, u.handler, B | |
r.splice B--, 1 | |
B++ | |
if c.isEmptyObject(C) | |
b.elem = null if b = z.handle | |
delete z.events | |
delete z.handle | |
c.isEmptyObject(z) and c.removeData(a) | |
trigger: (a, b, d, f) -> | |
e = a.type or a | |
if not f | |
a = (if typeof(a) is 'object' then a[G] else (if a then c.extend(c.Event(e), a) else c.Event(e))) | |
if e.indexOf('!') >= 0 | |
a.type = e = e.slice(0, -1) | |
a.exclusive = true | |
if not d | |
a.stopPropagation() | |
c.event.global[e] and c.each(c.cache, -> | |
@events and @events[e] and c.event.trigger(a, b, @handle.elem) | |
) | |
return w if not d or d.nodeType is 3 or d.nodeType is 8 | |
a.result = w | |
a.target = d | |
b = c.makeArray(b) | |
b.unshift a | |
a.currentTarget = d | |
(f = c.data(d, 'handle')) and f.apply(d, b) | |
f = d.parentNode or d.ownerDocument | |
try | |
a.result = false if d['on' + e] and d['on' + e].apply(d, b) is false if not (d and d.nodeName and c.noData[d.nodeName.toLowerCase()]) | |
catch j | |
if not a.isPropagationStopped() and f | |
c.event.trigger a, b, f, true | |
else if not a.isDefaultPrevented() | |
f = a.target | |
o = c.nodeName(f, 'a') and e is 'click' | |
k = c.event.special[e] or {} | |
if (not k._default or k._default.call(d, a) is false) and not o and not (f and f.nodeName and c.noData[f.nodeName.toLowerCase()]) | |
try | |
if f[e] | |
f['on' + e] = null if i = f['on' + e] | |
c.event.triggered = true | |
f[e]() | |
catch n | |
f['on' + e] = i if i | |
c.event.triggered = false | |
handle: (a) -> | |
a = arguments[0] = c.event.fix(a or A.event) | |
a.currentTarget = this | |
b = a.type.indexOf('.') < 0 and not a.exclusive | |
if not b | |
d = a.type.split('.') | |
a.type = d.shift() | |
f = new RegExp('(^|\\.)' + d.slice(0).sort().join('\\.(?:.*\\.)?') + '(\\.|$)') | |
e = c.data(this, 'events') | |
d = e[a.type] | |
if e and d | |
d = d.slice(0) | |
e = 0 | |
j = d.length | |
while e < j | |
i = d[e] | |
if b or f.test(i.namespace) | |
a.handler = i.handler | |
a.data = i.data | |
a.handleObj = i | |
i = i.handler.apply(this, arguments) | |
if i isnt w | |
a.result = i | |
if i is false | |
a.preventDefault() | |
a.stopPropagation() | |
break if a.isImmediatePropagationStopped() | |
e++ | |
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 originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which'.split(' ') | |
fix: (a) -> | |
return a if a[G] | |
b = a | |
a = c.Event(b) | |
d = @props.length | |
while d | |
f = @props[d--] | |
a[f] = b[f] | |
a.target = a.srcElement or s if not a.target | |
a.target = a.target.parentNode if a.target.nodeType is 3 | |
a.relatedTarget = (if a.fromElement is a.target then a.toElement else a.fromElement) if not a.relatedTarget and a.fromElement | |
if a.pageX == null and a.clientX != null | |
b = s.documentElement | |
d = s.body | |
a.pageX = a.clientX + (b and b.scrollLeft or d and d.scrollLeft or 0) - (b and b.clientLeft or d and d.clientLeft or 0) | |
a.pageY = a.clientY + (b and b.scrollTop or d and d.scrollTop or 0) - (b and b.clientTop or d and d.clientTop or 0) | |
a.which = a.charCode or a.keyCode if not a.which and ((if a.charCode or a.charCode is 0 then a.charCode else a.keyCode)) | |
a.metaKey = a.ctrlKey if not a.metaKey and a.ctrlKey | |
a.which = (if a.button & 1 then 1 else (if a.button & 2 then 3 else (if a.button & 4 then 2 else 0))) if not a.which and a.button isnt w | |
a | |
guid: 100000000.0 | |
proxy: c.proxy | |
special: { | |
ready: { | |
setup: c.bindReady | |
teardown: c.noop | |
} | |
live: { | |
add: (a) -> | |
c.event.add this, a.origType, c.extend({}, a, {handler: oa}) | |
remove: (a) -> | |
b = true | |
d = a.origType.replace(O, '') | |
c.each c.data(this, 'events').live or [], -> | |
return b = false if d is @origType.replace(O, '') | |
b and c.event.remove(this, a.origType, oa) | |
} | |
beforeunload: { | |
setup: (a, b, d) -> | |
@onbeforeunload = d if @setInterval | |
false | |
teardown: (a, b) -> | |
@onbeforeunload = null if @onbeforeunload is b | |
} | |
} | |
Ca = (if s.removeEventListener then (a, b, d) -> | |
a.removeEventListener b, d, false | |
else (a, b, d) -> | |
a.detachEvent 'on' + b, d | |
) | |
c.Event = (a) -> | |
return new c.Event(a) if not @preventDefault | |
if a and a.type | |
@originalEvent = a | |
@type = a.type | |
else @type = a | |
@timeStamp = J() | |
this[G] = true | |
c.Event.prototype = | |
preventDefault: -> | |
@isDefaultPrevented = Z | |
a = @originalEvent | |
if a | |
a.preventDefault and a.preventDefault() | |
a.returnValue = false | |
stopPropagation: -> | |
@isPropagationStopped = Z | |
a = @originalEvent | |
if a | |
a.stopPropagation and a.stopPropagation() | |
a.cancelBubble = true | |
stopImmediatePropagation: -> | |
@isImmediatePropagationStopped = Z | |
@stopPropagation() | |
isDefaultPrevented: Y | |
isPropagationStopped: Y | |
isImmediatePropagationStopped: Y | |
Da = (a) -> | |
b = a.relatedTarget | |
try | |
while b and b isnt this | |
b = b.parentNode | |
if b isnt this | |
a.type = a.data | |
c.event.handle.apply this, arguments | |
catch d | |
Ea = (a) -> | |
a.type = a.data | |
c.event.handle.apply this, arguments | |
c.each | |
mouseenter: 'mouseover' | |
mouseleave: 'mouseout' | |
, (a, b) -> | |
c.event.special[a] = | |
setup: (d) -> | |
c.event.add this, b, (if d and d.selector then Ea else Da), a | |
teardown: (d) -> | |
c.event.remove this, b, (if d and d.selector then Ea else Da) | |
if not c.support.submitBubbles | |
c.event.special.submit = | |
setup: -> | |
if @nodeName.toLowerCase() isnt 'form' | |
c.event.add this, 'click.specialSubmit', (a) -> | |
b = a.target | |
d = b.type | |
return na('submit', this, arguments) if (d is 'submit' or d is 'image') and c(b).closest('form').length | |
c.event.add this, 'keypress.specialSubmit', (a) -> | |
b = a.target | |
d = b.type | |
return na('submit', this, arguments) if (d is 'text' or d is 'password') and c(b).closest('form').length and a.keyCode is 13 | |
else return false | |
teardown: -> | |
c.event.remove this, '.specialSubmit' | |
if not c.support.changeBubbles | |
da = /textarea|input|select/i | |
Fa = (a) -> | |
b = a.type | |
d = a.value | |
if b is 'radio' or b is 'checkbox' | |
d = a.checked | |
else if b is 'select-multiple' | |
d = (if a.selectedIndex > -1 then c.map(a.options, (f) -> | |
f.selected | |
).join('-') else '') | |
else d = a.selectedIndex if a.nodeName.toLowerCase() is 'select' | |
d | |
fa = (a, b) -> | |
d = a.target | |
if not (not da.test(d.nodeName) or d.readOnly) | |
f = c.data(d, '_change_data') | |
e = Fa(d) | |
c.data d, '_change_data', e if a.type isnt 'focusout' or d.type isnt 'radio' | |
if not (f is w or e is f) | |
if f != null or e | |
a.type = 'change' | |
return c.event.trigger(a, b, d) | |
c.event.special.change = | |
filters: { | |
focusout: fa | |
click: (a) -> | |
b = a.target | |
d = b.type | |
return fa.call(this, a) if d is 'radio' or d is 'checkbox' or b.nodeName.toLowerCase() is 'select' | |
keydown: (a) -> | |
b = a.target | |
d = b.type | |
return fa.call(this, a) if a.keyCode is 13 and b.nodeName.toLowerCase() isnt 'textarea' or a.keyCode is 32 and (d is 'checkbox' or d is 'radio') or d is 'select-multiple' | |
beforeactivate: (a) -> | |
a = a.target | |
c.data a, '_change_data', Fa(a) | |
} | |
setup: -> | |
return false if @type is 'file' | |
for a of ea | |
c.event.add this, a + '.specialChange', ea[a] | |
da.test @nodeName | |
teardown: -> | |
c.event.remove this, '.specialChange' | |
da.test @nodeName | |
ea = c.event.special.change.filters | |
s.addEventListener and c.each( | |
focus: 'focusin' | |
blur: 'focusout' | |
, (a, b) -> | |
d = (f) -> | |
f = c.event.fix(f) | |
f.type = b | |
c.event.handle.call this, f | |
c.event.special[b] = | |
setup: -> | |
@addEventListener a, d, true | |
teardown: -> | |
@removeEventListener a, d, true | |
) | |
c.each ['bind', 'one'], (a, b) -> | |
c.fn[b] = (d, f, e) -> | |
if typeof(d) is 'object' | |
for j of d | |
this[b] j, f, d[j], e | |
return this | |
if c.isFunction(f) | |
e = f | |
f = w | |
i = (if b is 'one' then c.proxy(e, (k) -> | |
c(this).unbind k, i | |
e.apply this, arguments | |
) else e) | |
if d is 'unload' and b isnt 'one' | |
@one d, f, e | |
else j = 0 | |
o = @length | |
while j < o | |
c.event.add this[j], d, i, f | |
j++ | |
this | |
c.fn.extend | |
unbind: (a, b) -> | |
if typeof(a) is 'object' and not a.preventDefault | |
for d of a | |
@unbind d, a[d] | |
else d = 0 | |
f = @length | |
while d < f | |
c.event.remove this[d], a, b | |
d++ | |
this | |
delegate: (a, b, d, f) -> | |
@live b, d, f, a | |
undelegate: (a, b, d) -> | |
(if arguments.length is 0 then @unbind('live') else @die(b, null, d, a)) | |
trigger: (a, b) -> | |
@each -> | |
c.event.trigger a, b, this | |
triggerHandler: (a, b) -> | |
if this[0] | |
a = c.Event(a) | |
a.preventDefault() | |
a.stopPropagation() | |
c.event.trigger a, b, this[0] | |
return a.result | |
toggle: (a) -> | |
b = arguments | |
d = 1 | |
while d < b.length | |
c.proxy a, b[d++] | |
@click c.proxy(a, (f) -> | |
e = (c.data(this, 'lastToggle' + a.guid) or 0) % d | |
c.data this, 'lastToggle' + a.guid, e + 1 | |
f.preventDefault() | |
b[e].apply(this, arguments) or false | |
) | |
hover: (a, b) -> | |
@mouseenter(a).mouseleave b or a | |
Ga = { | |
focus: 'focusin' | |
blur: 'focusout' | |
mouseenter: 'mouseover' | |
mouseleave: 'mouseout' | |
} | |
c.each ['live', 'die'], (a, b) -> | |
c.fn[b] = (d, f, e, j) -> | |
o = 0 | |
r = j or @selector | |
u = (if j then this else c(@context)) | |
if c.isFunction(f) | |
e = f | |
f = w | |
d = (d or '').split(' ') | |
while (i = d[o++]) != null | |
j = O.exec(i) | |
k = '' | |
if j | |
k = j[0] | |
i = i.replace(O, '') | |
if i is 'hover' | |
d.push 'mouseenter' + k, 'mouseleave' + k | |
else n = i | |
if i is 'focus' or i is 'blur' | |
d.push Ga[i] + k | |
i = k | |
else i = (Ga[i] or i) + k | |
(if b is 'live' then u.each(-> | |
c.event.add this, pa(i, r), | |
data: f | |
selector: r | |
handler: e | |
origType: i | |
origHandler: e | |
preType: n | |
) else u.unbind(pa(i, r), e)) | |
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(' '), (a, b) -> | |
c.fn[b] = (d) -> | |
(if d then @bind(b, d) else @trigger(b)) | |
c.attrFn[b] = true if c.attrFn | |
A.attachEvent and not A.addEventListener and A.attachEvent('onunload', -> | |
for a of c.cache | |
if c.cache[a].handle | |
try | |
c.event.remove c.cache[a].handle.elem | |
catch b | |
) | |
(-> | |
a = (g) -> | |
h = '' | |
m = 0 | |
while g[m] | |
l = g[m] | |
if l.nodeType is 3 or l.nodeType is 4 | |
h = l.nodeValue | |
else h = a(l.childNodes) if l.nodeType isnt 8 | |
m++ | |
h | |
b = (g, h, l, m, q, p) -> | |
q = 0 | |
v = m.length | |
while q < v | |
t = m[q] | |
if t | |
t = t[g] | |
y = false | |
while t | |
if t.sizcache is l | |
y = m[t.sizset] | |
break | |
if t.nodeType is 1 and not p | |
t.sizcache = l | |
t.sizset = q | |
if t.nodeName.toLowerCase() is h | |
y = t | |
break | |
t = t[g] | |
m[q] = y | |
q++ | |
d = (g, h, l, m, q, p) -> | |
q = 0 | |
v = m.length | |
while q < v | |
t = m[q] | |
if t | |
t = t[g] | |
y = false | |
while t | |
if t.sizcache is l | |
y = m[t.sizset] | |
break | |
if t.nodeType is 1 | |
if not p | |
t.sizcache = l | |
t.sizset = q | |
if typeof(h) isnt 'string' | |
if t is h | |
y = true | |
break | |
else if k.filter(h, [t]).length > 0 | |
y = t | |
break | |
t = t[g] | |
m[q] = y | |
q++ | |
f = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g | |
e = 0 | |
j = Object.prototype.toString | |
i = false | |
o = true | |
[0, 0].sort -> | |
o = false | |
0 | |
k = (g, h, l, m) -> | |
l = l or [] | |
q = h = h or s | |
return [] if h.nodeType isnt 1 and h.nodeType isnt 9 | |
return l if not g or typeof(g) isnt 'string' | |
p = [] | |
H = true | |
M = x(h) | |
I = g | |
while (f.exec('') | |
v = f.exec(I)) isnt null | |
I = v[3] | |
p.push v[1] | |
if v[2] | |
S = v[3] | |
break | |
if p.length > 1 and r.exec(g) | |
if p.length is 2 and n.relative[p[0]] | |
t = ga(p[0] + p[1], h) | |
else t = (if n.relative[p[0]] then [h] else k(p.shift(), h)) | |
while p.length | |
g = p.shift() | |
g = p.shift() if n.relative[g] | |
t = ga(g, t) | |
else if not m and p.length > 1 and h.nodeType is 9 and not M and n.match.ID.test(p[0]) and not n.match.ID.test(p[p.length - 1]) | |
v = k.find(p.shift(), h, M) | |
h = (if v.expr then k.filter(v.expr, v.set)[0] else v.set[0]) | |
if h | |
v = (if m then { | |
expr: p.pop() | |
set: z(m) | |
} else k.find(p.pop(), (if p.length is 1 and (p[0] is '~' or p[0] is '+') and h.parentNode then h.parentNode else h), M)) | |
t = (if v.expr then k.filter(v.expr, v.set) else v.set) | |
if p.length > 0 | |
y = z(t) | |
else H = false | |
while p.length | |
D = p.pop() | |
v = D | |
if n.relative[D] | |
v = p.pop() | |
else D = '' | |
v = h if v == null | |
n.relative[D] y, v, M | |
else y = [] | |
y or (y = t) | |
y or k.error(D or g) | |
if j.call(y) is '[object Array]' | |
if H | |
if h and h.nodeType is 1 | |
g = 0 | |
while y[g] != null | |
l.push t[g] if y[g] and (y[g] is true or y[g].nodeType is 1 and E(h, y[g])) | |
g++ | |
else g = 0 | |
while y[g] != null | |
y[g] and y[g].nodeType is 1 and l.push(t[g]) | |
g++ | |
else l.push.apply l, y | |
else z y, l | |
if S | |
k S, q, l, m | |
k.uniqueSort l | |
l | |
k.uniqueSort = (g) -> | |
if B | |
i = o | |
g.sort B | |
if i | |
h = 1 | |
while h < g.length | |
g[h] is g[h - 1] and g.splice(h--, 1) | |
h++ | |
g | |
k.matches = (g, h) -> | |
k g, null, null, h | |
k.find = (g, h, l) -> | |
return [] if not g | |
p = 0 | |
v = n.order.length | |
while p < v | |
t = n.order[p] | |
if q = n.leftMatch[t].exec(g) | |
y = q[1] | |
q.splice 1, 1 | |
if y.substr(y.length - 1) isnt '\\' | |
q[1] = (q[1] or '').replace(/\\/g, '') | |
m = n.find[t](q, h, l) | |
if m != null | |
g = g.replace(n.match[t], '') | |
break | |
p++ | |
m or (m = h.getElementsByTagName('*')) | |
{ | |
set: m | |
expr: g | |
} | |
k.filter = (g, h, l, m) -> | |
q = g | |
p = [] | |
v = h | |
S = h and h[0] and x(h[0]) | |
while g and h.length | |
for H of n.filter | |
if (t = n.leftMatch[H].exec(g)) != null and t[2] | |
M = n.filter[H] | |
D = t[1] | |
y = false | |
t.splice 1, 1 | |
if D.substr(D.length - 1) isnt '\\' | |
p = [] if v is p | |
if n.preFilter[H] | |
if t = n.preFilter[H](t, v, l, p, m, S) | |
continue if t is true | |
else y = I = true | |
if t | |
U = 0 | |
while (D = v[U]) != null | |
if D | |
I = M(D, t, U, v) | |
Ha = m ^ not not I | |
if l and I != null | |
if Ha | |
y = true | |
else v[U] = false | |
else if Ha | |
p.push D | |
y = true | |
U++ | |
if I isnt w | |
l or (v = p) | |
g = g.replace(n.match[H], '') | |
return [] if not y | |
break | |
if g is q | |
if y == null | |
k.error g | |
else break | |
q = g | |
v | |
k.error = (g) -> | |
throw 'Syntax error, unrecognized expression: ' + g | |
n = 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: (g) -> | |
g.getAttribute 'href' | |
} | |
relative: { | |
'+': (g, h) -> | |
l = typeof(h) is 'string' | |
m = l and not /\W/.test(h) | |
l = l and not m | |
h = h.toLowerCase() if m | |
m = 0 | |
q = g.length | |
while m < q | |
if p = g[m] | |
while (p = p.previousSibling) and p.nodeType isnt 1 | |
0 | |
g[m] = (if l or p and p.nodeName.toLowerCase() is h then p or false else p is h) | |
m++ | |
l and k.filter(h, g, true) | |
'>': (g, h) -> | |
l = typeof(h) is 'string' | |
if l and not /\W/.test(h) | |
h = h.toLowerCase() | |
m = 0 | |
q = g.length | |
while m < q | |
p = g[m] | |
if p | |
l = p.parentNode | |
g[m] = (if l.nodeName.toLowerCase() is h then l else false) | |
m++ | |
else m = 0 | |
q = g.length | |
while m < q | |
g[m] = (if l then p.parentNode else p.parentNode is h) if p = g[m] | |
m++ | |
l and k.filter(h, g, true) | |
'': (g, h, l) -> | |
m = e++ | |
q = d | |
if typeof(h) is 'string' and not /\W/.test(h) | |
p = h = h.toLowerCase() | |
q = b | |
q 'parentNode', h, m, g, p, l | |
'~': (g, h, l) -> | |
m = e++ | |
q = d | |
if typeof(h) is 'string' and not /\W/.test(h) | |
p = h = h.toLowerCase() | |
q = b | |
q 'previousSibling', h, m, g, p, l | |
} | |
find: { | |
ID: (g, h, l) -> | |
return (if (g = h.getElementById(g[1])) then [g] else []) if typeof(h.getElementById) isnt 'undefined' and not l | |
NAME: (g, h) -> | |
if typeof(h.getElementsByName) isnt 'undefined' | |
l = [] | |
h = h.getElementsByName(g[1]) | |
m = 0 | |
q = h.length | |
while m < q | |
h[m].getAttribute('name') is g[1] and l.push(h[m]) | |
m++ | |
return (if l.length is 0 then null else l) | |
TAG: (g, h) -> | |
h.getElementsByTagName g[1] | |
} | |
preFilter: { | |
CLASS: (g, h, l, m, q, p) -> | |
g = ' ' + g[1].replace(/\\/g, '') + ' ' | |
return g if p | |
p = 0 | |
while (v = h[p]) != null | |
if v | |
if q ^ (v.className and (' ' + v.className + ' ').replace(/[\t\n]/g, ' ').indexOf(g) >= 0) | |
l or m.push(v) | |
else h[p] = false if l | |
p++ | |
false | |
ID: (g) -> | |
g[1].replace /\\/g, '' | |
TAG: (g) -> | |
g[1].toLowerCase() | |
CHILD: (g) -> | |
if g[1] is 'nth' | |
h = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2] is 'even' and '2n' or g[2] is 'odd' and '2n+1' or not /\D/.test(g[2]) and '0n+' + g[2] or g[2]) | |
g[2] = h[1] + (h[2] or 1) - 0 | |
g[3] = h[3] - 0 | |
g[0] = e++ | |
g | |
ATTR: (g, h, l, m, q, p) -> | |
h = g[1].replace(/\\/g, '') | |
g[1] = n.attrMap[h] if not p and n.attrMap[h] | |
g[4] = ' ' + g[4] + ' ' if g[2] is '~=' | |
g | |
PSEUDO: (g, h, l, m, q) -> | |
if g[1] is 'not' | |
if (f.exec(g[3]) or '').length > 1 or /^\w/.test(g[3]) | |
g[3] = k(g[3], null, null, h) | |
else g = k.filter(g[3], h, l, true ^ q) | |
l or m.push.apply(m, g) | |
return false | |
else return true if n.match.POS.test(g[0]) or n.match.CHILD.test(g[0]) | |
g | |
POS: (g) -> | |
g.unshift true | |
g | |
} | |
filters: { | |
enabled: (g) -> | |
g.disabled is false and g.type isnt 'hidden' | |
disabled: (g) -> | |
g.disabled is true | |
checked: (g) -> | |
g.checked is true | |
selected: (g) -> | |
g.selected is true | |
parent: (g) -> | |
not not g.firstChild | |
empty: (g) -> | |
not g.firstChild | |
has: (g, h, l) -> | |
not not k(l[3], g).length | |
header: (g) -> | |
/h\d/i.test g.nodeName | |
text: (g) -> | |
'text' is g.type | |
radio: (g) -> | |
'radio' is g.type | |
checkbox: (g) -> | |
'checkbox' is g.type | |
file: (g) -> | |
'file' is g.type | |
password: (g) -> | |
'password' is g.type | |
submit: (g) -> | |
'submit' is g.type | |
image: (g) -> | |
'image' is g.type | |
reset: (g) -> | |
'reset' is g.type | |
button: (g) -> | |
'button' is g.type or g.nodeName.toLowerCase() is 'button' | |
input: (g) -> | |
/input|select|textarea|button/i.test g.nodeName | |
} | |
setFilters: { | |
first: (g, h) -> | |
h is 0 | |
last: (g, h, l, m) -> | |
h is m.length - 1 | |
even: (g, h) -> | |
h % 2 is 0 | |
odd: (g, h) -> | |
h % 2 is 1 | |
lt: (g, h, l) -> | |
h < l[3] - 0 | |
gt: (g, h, l) -> | |
h > l[3] - 0 | |
nth: (g, h, l) -> | |
l[3] - 0 is h | |
eq: (g, h, l) -> | |
l[3] - 0 is h | |
} | |
filter: { | |
PSEUDO: (g, h, l, m) -> | |
q = h[1] | |
p = n.filters[q] | |
if p | |
return p(g, l, h, m) | |
else if q is 'contains' | |
return (g.textContent or g.innerText or a([g]) or '').indexOf(h[3]) >= 0 | |
else if q is 'not' | |
h = h[3] | |
l = 0 | |
m = h.length | |
while l < m | |
return false if h[l] is g | |
l++ | |
return true | |
else k.error 'Syntax error, unrecognized expression: ' + q | |
CHILD: (g, h) -> | |
l = h[1] | |
m = g | |
if 'only' == l | |
else if 'first' == l | |
while m = m.previousSibling | |
return false if m.nodeType is 1 | |
return true if l is 'first' | |
m = g | |
else if 'last' == l | |
while m = m.nextSibling | |
return false if m.nodeType is 1 | |
return true | |
else if 'nth' == l | |
l = h[2] | |
q = h[3] | |
return true if l is 1 and q is 0 | |
h = h[0] | |
p = g.parentNode | |
if p and (p.sizcache isnt h or not g.nodeIndex) | |
v = 0 | |
m = p.firstChild | |
while m | |
m.nodeIndex = v++ if m.nodeType is 1 | |
m = m.nextSibling | |
p.sizcache = h | |
g = g.nodeIndex - q | |
return (if l is 0 then g is 0 else g % l is 0 and g / l >= 0) | |
ID: (g, h) -> | |
g.nodeType is 1 and g.getAttribute('id') is h | |
TAG: (g, h) -> | |
h is '*' and g.nodeType is 1 or g.nodeName.toLowerCase() is h | |
CLASS: (g, h) -> | |
(' ' + (g.className or g.getAttribute('class')) + ' ').indexOf(h) > -1 | |
ATTR: (g, h) -> | |
l = h[1] | |
g = (if n.attrHandle[l] then n.attrHandle[l](g) else (if g[l] != null then g[l] else g.getAttribute(l))) | |
l = g + '' | |
m = h[2] | |
h = h[4] | |
(if g == null then m is '!=' else (if m is '=' then l is h else (if m is '*=' then l.indexOf(h) >= 0 else (if m is '~=' then (' ' + l + ' ').indexOf(h) >= 0 else (if not h then l and g isnt false else (if m is '!=' then l isnt h else (if m is '^=' then l.indexOf(h) is 0 else (if m is '$=' then l.substr(l.length - h.length) is h else (if m is '|=' then l is h or l.substr(0, h.length + 1) is h + '-' else false))))))))) | |
POS: (g, h, l, m) -> | |
q = n.setFilters[h[2]] | |
return q(g, l, h, m) if q | |
} | |
r = n.match.POS | |
for u of n.match | |
n.match[u] = new RegExp(n.match[u].source + /(?![^\[]*\])(?![^\(]*\))/.source) | |
n.leftMatch[u] = new RegExp(/(^(?:.|\r|\n)*?)/.source + n.match[u].source.replace(/\\(\d+)/g, (g, h) -> | |
'\\' + (h - 0 + 1) | |
)) | |
z = (g, h) -> | |
g = Array.prototype.slice.call(g, 0) | |
if h | |
h.push.apply h, g | |
return h | |
g | |
try | |
Array.prototype.slice.call s.documentElement.childNodes, 0 | |
catch C | |
z = (g, h) -> | |
h = h or [] | |
if j.call(g) is '[object Array]' | |
Array.prototype.push.apply h, g | |
else if typeof(g.length) is 'number' | |
l = 0 | |
m = g.length | |
while l < m | |
h.push g[l] | |
l++ | |
else l = 0 | |
while g[l] | |
h.push g[l] | |
l++ | |
h | |
if s.documentElement.compareDocumentPosition | |
B = (g, h) -> | |
if not g.compareDocumentPosition or not h.compareDocumentPosition | |
i = true if g == h | |
return (if g.compareDocumentPosition then -1 else 1) | |
g = (if g.compareDocumentPosition(h) & 4 then -1 else (if g is h then 0 else 1)) | |
i = true if g is 0 | |
g | |
else if 'sourceIndex' in s.documentElement | |
B = (g, h) -> | |
if not g.sourceIndex or not h.sourceIndex | |
i = true if g == h | |
return (if g.sourceIndex then -1 else 1) | |
g = g.sourceIndex - h.sourceIndex | |
i = true if g is 0 | |
g | |
else if s.createRange | |
B = (g, h) -> | |
if not g.ownerDocument or not h.ownerDocument | |
i = true if g == h | |
return (if g.ownerDocument then -1 else 1) | |
l = g.ownerDocument.createRange() | |
m = h.ownerDocument.createRange() | |
l.setStart g, 0 | |
l.setEnd g, 0 | |
m.setStart h, 0 | |
m.setEnd h, 0 | |
g = l.compareBoundaryPoints(Range.START_TO_END, m) | |
i = true if g is 0 | |
g | |
(-> | |
g = s.createElement('div') | |
h = 'script' + (new Date).getTime() | |
g.innerHTML = "<a name='" + h + "'/>" | |
l = s.documentElement | |
l.insertBefore g, l.firstChild | |
if s.getElementById(h) | |
n.find.ID = (m, q, p) -> | |
return (if (q = q.getElementById(m[1])) then q.id is m[1] or typeof(q.getAttributeNode) isnt 'undefined' and q.getAttributeNode('id').nodeValue is m[1] else (if [q] then w else [])) if typeof(q.getElementById) isnt 'undefined' and not p | |
n.filter.ID = (m, q) -> | |
p = typeof(m.getAttributeNode) isnt 'undefined' and m.getAttributeNode('id') | |
m.nodeType is 1 and p and p.nodeValue is q | |
l.removeChild g | |
l = g = null | |
)() | |
(-> | |
g = s.createElement('div') | |
g.appendChild s.createComment('') | |
if g.getElementsByTagName('*').length > 0 | |
n.find.TAG = (h, l) -> | |
l = l.getElementsByTagName(h[1]) | |
if h[1] is '*' | |
h = [] | |
m = 0 | |
while l[m] | |
l[m].nodeType is 1 and h.push(l[m]) | |
m++ | |
l = h | |
l | |
g.innerHTML = "<a href='#'></a>" | |
if g.firstChild and typeof(g.firstChild.getAttribute) isnt 'undefined' and g.firstChild.getAttribute('href') isnt '#' | |
n.attrHandle.href = (h) -> | |
h.getAttribute 'href', 2 | |
g = null | |
)() | |
s.querySelectorAll and -> | |
g = k | |
h = s.createElement('div') | |
h.innerHTML = "<p class='TEST'></p>" | |
if not (h.querySelectorAll and h.querySelectorAll('.TEST').length is 0) | |
k = (m, q, p, v) -> | |
q = q or s | |
if not v and q.nodeType is 9 and not x(q) | |
try | |
return z(q.querySelectorAll(m), p) | |
catch t | |
g m, q, p, v | |
for l of g | |
k[l] = g[l] | |
h = null | |
(-> | |
g = s.createElement('div') | |
g.innerHTML = "<div class='test e'></div><div class='test'></div>" | |
if not (not g.getElementsByClassName or g.getElementsByClassName('e').length is 0) | |
g.lastChild.className = 'e' | |
if g.getElementsByClassName('e').length isnt 1 | |
n.order.splice 1, 0, 'CLASS' | |
n.find.CLASS = (h, l, m) -> | |
return l.getElementsByClassName(h[1]) if typeof(l.getElementsByClassName) isnt 'undefined' and not m | |
g = null | |
)() | |
E = (if s.compareDocumentPosition then (g, h) -> | |
not not (g.compareDocumentPosition(h) & 16) | |
else (g, h) -> | |
g isnt h and ((if g.contains then g.contains(h) else true)) | |
) | |
x = (g) -> | |
(if (g = ((if g then g.ownerDocument or g else 0)).documentElement) then g.nodeName isnt 'HTML' else false) | |
ga = (g, h) -> | |
l = [] | |
m = '' | |
h = (if h.nodeType then [h] else h) | |
while q = n.match.PSEUDO.exec(g) | |
m = q[0] | |
g = g.replace(n.match.PSEUDO, '') | |
g = (if n.relative[g] then g + '*' else g) | |
q = 0 | |
p = h.length | |
while q < p | |
k g, h[q], l | |
q++ | |
k.filter m, l | |
c.find = k | |
c.expr = k.selectors | |
c.expr[':'] = c.expr.filters | |
c.unique = k.uniqueSort | |
c.text = a | |
c.isXMLDoc = x | |
c.contains = E | |
)() | |
eb = /Until$/ | |
fb = /^(?:parents|prevUntil|prevAll)/ | |
gb = /,/ | |
R = Array.prototype.slice | |
Ia = (a, b, d) -> | |
if c.isFunction(b) | |
return c.grep(a, (e, j) -> | |
not not b.call(e, j, e) is d | |
) | |
else if b.nodeType | |
return c.grep(a, (e) -> | |
e is b is d | |
) | |
else if typeof(b) is 'string' | |
f = c.grep(a, (e) -> | |
e.nodeType is 1 | |
) | |
if Ua.test(b) | |
return c.filter(b, f, not d) | |
else b = c.filter(b, f) | |
c.grep a, (e) -> | |
c.inArray(e, b) >= 0 is d | |
c.fn.extend | |
find: (a) -> | |
b = @pushStack('', 'find', a) | |
d = 0 | |
f = 0 | |
e = @length | |
while f < e | |
d = b.length | |
c.find a, this[f], b | |
if f > 0 | |
j = d | |
while j < b.length | |
i = 0 | |
while i < d | |
if b[i] is b[j] | |
b.splice j--, 1 | |
break | |
i++ | |
j++ | |
f++ | |
b | |
has: (a) -> | |
b = c(a) | |
@filter -> | |
d = 0 | |
f = b.length | |
while d < f | |
return true if c.contains(this, b[d]) | |
d++ | |
not_: (a) -> | |
@pushStack Ia(this, a, false), 'not', a | |
filter: (a) -> | |
@pushStack Ia(this, a, true), 'filter', a | |
is: (a) -> | |
not not a and c.filter(a, this).length > 0 | |
closest: (a, b) -> | |
if c.isArray(a) | |
d = [] | |
f = this[0] | |
j = {} | |
if f and a.length | |
e = 0 | |
o = a.length | |
while e < o | |
i = a[e] | |
j[i] or (j[i] = (if c.expr.match.POS.test(i) then c(i, b or @context) else i)) | |
e++ | |
while f and f.ownerDocument and f isnt b | |
for i of j | |
e = j[i] | |
if (if e.jquery then e.index(f) > -1 else c(f).is(e)) | |
d.push | |
selector: i | |
elem: f | |
delete j[i] | |
f = f.parentNode | |
return d | |
k = (if c.expr.match.POS.test(a) then c(a, b or @context) else null) | |
@map (n, r) -> | |
while r and r.ownerDocument and r isnt b | |
return r if (if k then k.index(r) > -1 else c(r).is(a)) | |
r = r.parentNode | |
null | |
index: (a) -> | |
return c.inArray(this[0], (if a then c(a) else @parent().children())) if not a or typeof(a) is 'string' | |
c.inArray (if a.jquery then a[0] else a), this | |
add: (a, b) -> | |
a = (if typeof(a) is 'string' then c(a, b or @context) else c.makeArray(a)) | |
b = c.merge(@get(), a) | |
@pushStack (if qa(a[0]) or qa(b[0]) then b else c.unique(b)) | |
andSelf: -> | |
@add @prevObject | |
c.each | |
parent: (a) -> | |
(if (a = a.parentNode) and a.nodeType isnt 11 then a else null) | |
parents: (a) -> | |
c.dir a, 'parentNode' | |
parentsUntil: (a, b, d) -> | |
c.dir a, 'parentNode', d | |
next: (a) -> | |
c.nth a, 2, 'nextSibling' | |
prev: (a) -> | |
c.nth a, 2, 'previousSibling' | |
nextAll: (a) -> | |
c.dir a, 'nextSibling' | |
prevAll: (a) -> | |
c.dir a, 'previousSibling' | |
nextUntil: (a, b, d) -> | |
c.dir a, 'nextSibling', d | |
prevUntil: (a, b, d) -> | |
c.dir a, 'previousSibling', d | |
siblings: (a) -> | |
c.sibling a.parentNode.firstChild, a | |
children: (a) -> | |
c.sibling a.firstChild | |
contents: (a) -> | |
(if c.nodeName(a, 'iframe') then a.contentDocument or a.contentWindow.document else c.makeArray(a.childNodes)) | |
, (a, b) -> | |
c.fn[a] = (d, f) -> | |
e = c.map(this, b, d) | |
eb.test(a) or (f = d) | |
e = c.filter(f, e) if f and typeof(f) is 'string' | |
e = (if @length > 1 then c.unique(e) else e) | |
e = e.reverse() if (@length > 1 or gb.test(f)) and fb.test(a) | |
@pushStack e, a, R.call(arguments).join(',') | |
c.extend | |
filter: (a, b, d) -> | |
a = ':not(' + a + ')' if d | |
c.find.matches a, b | |
dir: (a, b, d) -> | |
f = [] | |
a = a[b] | |
while a and a.nodeType isnt 9 and (d is w or a.nodeType isnt 1 or not c(a).is(d)) | |
a.nodeType is 1 and f.push(a) | |
a = a[b] | |
f | |
nth: (a, b, d) -> | |
b = b or 1 | |
f = 0 | |
while a | |
break if a.nodeType is 1 and f++ is b | |
a = a[d] | |
a | |
sibling: (a, b) -> | |
d = [] | |
while a | |
a.nodeType is 1 and a isnt b and d.push(a) | |
a = a.nextSibling | |
d | |
Ja = RegExp(' jQuery\\d+="(?:\\d+|null)"', 'g') | |
V = /^\s+/ | |
Ka = /(<([\w:]+)[^>]*?)\/>/g | |
hb = /^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i | |
La = /<([\w:]+)/ | |
ib = /<tbody/i | |
jb = /<|&#?\w+;/ | |
ta = /<script|<object|<embed|<option|<style/i | |
ua = /checked\s*(?:[^=]|=\s*.checked.)/i | |
Ma = (a, b, d) -> | |
(if hb.test(d) then a else b + '></' + d + '>') | |
F = { | |
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, '', ''] | |
} | |
F.optgroup = F.option | |
F.tbody = F.tfoot = F.colgroup = F.caption = F.thead | |
F.th = F.td | |
F._default = [1, 'div<div>', '</div>'] if not c.support.htmlSerialize | |
c.fn.extend | |
text: (a) -> | |
if c.isFunction(a) | |
return @each((b) -> | |
d = c(this) | |
d.text a.call(this, b, d.text()) | |
) | |
return @empty().append((this[0] and this[0].ownerDocument or s).createTextNode(a)) if typeof(a) isnt 'object' and a isnt w | |
c.text this | |
wrapAll: (a) -> | |
if c.isFunction(a) | |
return @each((d) -> | |
c(this).wrapAll a.call(this, d) | |
) | |
if this[0] | |
b = c(a, this[0].ownerDocument).eq(0).clone(true) | |
this[0].parentNode and b.insertBefore(this[0]) | |
b.map(-> | |
d = this | |
while d.firstChild and d.firstChild.nodeType is 1 | |
d = d.firstChild | |
d | |
).append this | |
this | |
wrapInner: (a) -> | |
if c.isFunction(a) | |
return @each((b) -> | |
c(this).wrapInner a.call(this, b) | |
) | |
@each -> | |
b = c(this) | |
d = b.contents() | |
(if d.length then d.wrapAll(a) else b.append(a)) | |
wrap: (a) -> | |
@each -> | |
c(this).wrapAll a | |
unwrap: -> | |
@parent().each(-> | |
c.nodeName(this, 'body') or c(this).replaceWith(@childNodes) | |
).end() | |
append: -> | |
@domManip arguments, true, (a) -> | |
@nodeType is 1 and @appendChild(a) | |
prepend: -> | |
@domManip arguments, true, (a) -> | |
@nodeType is 1 and @insertBefore(a, @firstChild) | |
before: -> | |
if this[0] and this[0].parentNode | |
return @domManip(arguments, false, (b) -> | |
@parentNode.insertBefore b, this | |
) | |
else if arguments.length | |
a = c(arguments[0]) | |
a.push.apply a, @toArray() | |
return @pushStack(a, 'before', arguments) | |
after: -> | |
if this[0] and this[0].parentNode | |
return @domManip(arguments, false, (b) -> | |
@parentNode.insertBefore b, @nextSibling | |
) | |
else if arguments.length | |
a = @pushStack(this, 'after', arguments) | |
a.push.apply a, c(arguments[0]).toArray() | |
return a | |
remove: (a, b) -> | |
d = 0 | |
while (f = this[d]) != null | |
if not a or c.filter(a, [f]).length | |
if not b and f.nodeType is 1 | |
c.cleanData f.getElementsByTagName('*') | |
c.cleanData [f] | |
f.parentNode and f.parentNode.removeChild(f) | |
d++ | |
this | |
empty: -> | |
a = 0 | |
while (b = this[a]) != null | |
b.nodeType is 1 and c.cleanData(b.getElementsByTagName('*')) | |
while b.firstChild | |
b.removeChild b.firstChild | |
a++ | |
this | |
clone: (a) -> | |
b = @map(-> | |
if not c.support.noCloneEvent and not c.isXMLDoc(this) | |
d = @outerHTML | |
f = @ownerDocument | |
if not d | |
d = f.createElement('div') | |
d.appendChild @cloneNode(true) | |
d = d.innerHTML | |
return c.clean([d.replace(Ja, '').replace(RegExp('=([^="\'>\\s]+\\/)>', 'g'), '="$1">').replace(V, '')], f)[0] | |
else return @cloneNode(true) | |
) | |
if a is true | |
ra this, b | |
ra @find('*'), b.find('*') | |
b | |
html: (a) -> | |
if a is w | |
return (if this[0] and this[0].nodeType is 1 then this[0].innerHTML.replace(Ja, '') else null) | |
else if typeof(a) is 'string' and not ta.test(a) and (c.support.leadingWhitespace or not V.test(a)) and not F[(La.exec(a) or ['', ''])[1].toLowerCase()] | |
a = a.replace(Ka, Ma) | |
try | |
b = 0 | |
d = @length | |
while b < d | |
if this[b].nodeType is 1 | |
c.cleanData this[b].getElementsByTagName('*') | |
this[b].innerHTML = a | |
b++ | |
catch f | |
@empty().append a | |
else (if c.isFunction(a) then @each((e) -> | |
j = c(this) | |
i = j.html() | |
j.empty().append -> | |
a.call this, e, i | |
) else @empty().append(a)) | |
this | |
replaceWith: (a) -> | |
if this[0] and this[0].parentNode | |
if c.isFunction(a) | |
return @each((b) -> | |
d = c(this) | |
f = d.html() | |
d.replaceWith a.call(this, b, f) | |
) | |
a = c(a).detach() if typeof(a) isnt 'string' | |
return @each(-> | |
b = @nextSibling | |
d = @parentNode | |
c(this).remove() | |
(if b then c(b).before(a) else c(d).append(a)) | |
) | |
else return @pushStack(c((if c.isFunction(a) then a() else a)), 'replaceWith', a) | |
detach: (a) -> | |
@remove a, true | |
domManip: (a, b, d) -> | |
f = (u) -> | |
(if c.nodeName(u, 'table') then u.getElementsByTagName('tbody')[0] or u.appendChild(u.ownerDocument.createElement('tbody')) else u) | |
i = a[0] | |
o = [] | |
if not c.support.checkClone and arguments.length is 3 and typeof(i) is 'string' and ua.test(i) | |
return @each(-> | |
c(this).domManip a, b, d, true | |
) | |
if c.isFunction(i) | |
return @each((u) -> | |
z = c(this) | |
a[0] = i.call(this, u, (if b then z.html() else w)) | |
z.domManip a, b, d | |
) | |
if this[0] | |
e = i and i.parentNode | |
e = (if c.support.parentNode and e and e.nodeType is 11 and e.childNodes.length is @length then {fragment: e} else sa(a, this, o)) | |
k = e.fragment | |
if j = (if k.childNodes.length is 1 then (k = k.firstChild) else k.firstChild) | |
b = b and c.nodeName(j, 'tr') | |
n = 0 | |
r = @length | |
while n < r | |
d.call (if b then f(this[n], j) else this[n]), (if n > 0 or e.cacheable or @length > 1 then k.cloneNode(true) else k) | |
n++ | |
o.length and c.each(o, Qa) | |
this | |
c.fragments = {} | |
c.each | |
appendTo: 'append' | |
prependTo: 'prepend' | |
insertBefore: 'before' | |
insertAfter: 'after' | |
replaceAll: 'replaceWith' | |
, (a, b) -> | |
c.fn[a] = (d) -> | |
f = [] | |
d = c(d) | |
e = @length is 1 and this[0].parentNode | |
if e and e.nodeType is 11 and e.childNodes.length is 1 and d.length is 1 | |
d[b] this[0] | |
return this | |
else e = 0 | |
j = d.length | |
while e < j | |
i = ((if e > 0 then @clone(true) else this)).get() | |
c.fn[b].apply c(d[e]), i | |
f = f.concat(i) | |
e++ | |
return @pushStack(f, a, d.selector) | |
c.extend | |
clean: (a, b, d, f) -> | |
b = b or s | |
b = b.ownerDocument or b[0] and b[0].ownerDocument or s if typeof(b.createElement) is 'undefined' | |
e = [] | |
j = 0 | |
while (i = a[j]) != null | |
i = '' if typeof(i) is 'number' | |
if i | |
if typeof(i) is 'string' and not jb.test(i) | |
i = b.createTextNode(i) | |
else if typeof(i) is 'string' | |
i = i.replace(Ka, Ma) | |
o = (La.exec(i) or ['', ''])[1].toLowerCase() | |
k = F[o] or F._default | |
n = k[0] | |
r = b.createElement('div') | |
r.innerHTML = k[1] + i + k[2] | |
while n-- | |
r = r.lastChild | |
if not c.support.tbody | |
n = ib.test(i) | |
o = (if o is 'table' and not n then r.firstChild and r.firstChild.childNodes else (if k[1] is '<table>' and not n then r.childNodes else [])) | |
k = o.length - 1 | |
while k >= 0 | |
c.nodeName(o[k], 'tbody') and not o[k].childNodes.length and o[k].parentNode.removeChild(o[k]) | |
k-- | |
not c.support.leadingWhitespace and V.test(i) and r.insertBefore(b.createTextNode(V.exec(i)[0]), r.firstChild) | |
i = r.childNodes | |
if i.nodeType | |
e.push i | |
else e = c.merge(e, i) | |
j++ | |
if d | |
j = 0 | |
while e[j] | |
if f and c.nodeName(e[j], 'script') and (not e[j].type or e[j].type.toLowerCase() is 'text/javascript') | |
f.push (if e[j].parentNode then e[j].parentNode.removeChild(e[j]) else e[j]) | |
else e[j].nodeType is 1 and e.splice.apply(e, [j + 1, 0].concat(c.makeArray(e[j].getElementsByTagName('script')))) | |
d.appendChild e[j] | |
j++ | |
e | |
cleanData: (a) -> | |
f = c.cache | |
e = c.event.special | |
j = c.support.deleteExpando | |
i = 0 | |
while (o = a[i]) != null | |
if d = o[c.expando] | |
b = f[d] | |
if b.events | |
for k of b.events | |
(if e[k] then c.event.remove(o, k) else Ca(o, k, b.handle)) | |
if j | |
delete o[c.expando] | |
else o.removeAttribute and o.removeAttribute(c.expando) | |
delete f[d] | |
i++ | |
kb = /z-?index|font-?weight|opacity|zoom|line-?height/i | |
Na = /alpha\([^)]*\)/ | |
Oa = /opacity=([^)]*)/ | |
ha = /float/i | |
ia = /-([a-z])/ig | |
lb = /([A-Z])/g | |
mb = /^-?\d+(?:px)?$/i | |
nb = /^-?\d/ | |
ob = { | |
position: 'absolute' | |
visibility: 'hidden' | |
display: 'block' | |
} | |
pb = ['Left', 'Right'] | |
qb = ['Top', 'Bottom'] | |
rb = s.defaultView and s.defaultView.getComputedStyle | |
Pa = (if c.support.cssFloat then 'cssFloat' else 'styleFloat') | |
ja = (a, b) -> | |
b.toUpperCase() | |
c.fn.css = (a, b) -> | |
X this, a, b, true, (d, f, e) -> | |
return c.curCSS(d, f) if e is w | |
e = 'px' if typeof(e) is 'number' and not kb.test(f) | |
c.style d, f, e | |
c.extend | |
style: (a, b, d) -> | |
return w if not a or a.nodeType is 3 or a.nodeType is 8 | |
d = w if (b is 'width' or b is 'height') and parseFloat(d) < 0 | |
f = a.style or a | |
e = d isnt w | |
if not c.support.opacity and b is 'opacity' | |
if e | |
f.zoom = 1 | |
b = (if parseInt(d, 10) + '' is 'NaN' then '' else 'alpha(opacity=' + d * 100 + ')') | |
a = f.filter or c.curCSS(a, 'filter') or '' | |
f.filter = (if Na.test(a) then a.replace(Na, b) else b) | |
return (if f.filter and f.filter.indexOf('opacity=') >= 0 then parseFloat(Oa.exec(f.filter)[1]) / 100 + '' else '') | |
b = Pa if ha.test(b) | |
b = b.replace(ia, ja) | |
f[b] = d if e | |
f[b] | |
css: (a, b, d, f) -> | |
if b is 'width' or b is 'height' | |
i = -> | |
e = (if b is 'width' then a.offsetWidth else a.offsetHeight) | |
f isnt 'border' and c.each(j, -> | |
f or (e = parseFloat(c.curCSS(a, 'padding' + this, true)) or 0) | |
if f is 'margin' | |
e = parseFloat(c.curCSS(a, 'margin' + this, true)) or 0 | |
else e = parseFloat(c.curCSS(a, 'border' + this + 'Width', true)) or 0 | |
) | |
j = (if b is 'width' then pb else qb) | |
(if a.offsetWidth isnt 0 then i() else c.swap(a, ob, i)) | |
return Math.max(0, Math.round(e)) | |
c.curCSS a, b, d | |
curCSS: (a, b, d) -> | |
e = a.style | |
if not c.support.opacity and b is 'opacity' and a.currentStyle | |
f = (if Oa.test(a.currentStyle.filter or '') then parseFloat(RegExp.$1) / 100 + '' else '') | |
return (if f is '' then '1' else f) | |
b = Pa if ha.test(b) | |
if not d and e and e[b] | |
f = e[b] | |
else if rb | |
b = 'float' if ha.test(b) | |
b = b.replace(lb, '-$1').toLowerCase() | |
e = a.ownerDocument.defaultView | |
return null if not e | |
f = a.getPropertyValue(b) if a = e.getComputedStyle(a, null) | |
f = '1' if b is 'opacity' and f is '' | |
else if a.currentStyle | |
d = b.replace(ia, ja) | |
f = a.currentStyle[b] or a.currentStyle[d] | |
if not mb.test(f) and nb.test(f) | |
b = e.left | |
j = a.runtimeStyle.left | |
a.runtimeStyle.left = a.currentStyle.left | |
e.left = (if d is 'fontSize' then '1em' else f or 0) | |
f = e.pixelLeft + 'px' | |
e.left = b | |
a.runtimeStyle.left = j | |
f | |
swap: (a, b, d) -> | |
f = {} | |
for e of b | |
f[e] = a.style[e] | |
a.style[e] = b[e] | |
d.call a | |
for e of b | |
a.style[e] = f[e] | |
if c.expr and c.expr.filters | |
c.expr.filters.hidden = (a) -> | |
b = a.offsetWidth | |
d = a.offsetHeight | |
f = a.nodeName.toLowerCase() is 'tr' | |
(if b is 0 and d is 0 and not f then true else (if b > 0 and d > 0 and not f then false else c.curCSS(a, 'display') is 'none')) | |
c.expr.filters.visible = (a) -> | |
not c.expr.filters.hidden(a) | |
sb = J() | |
tb = /<script(.|\s)*?\/script>/gi | |
ub = /select|textarea/i | |
vb = /color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i | |
N = RegExp('=\\?(&|$)', '') | |
ka = /\?/ | |
wb = /(\?|&)_=.*?(&|$)/ | |
xb = /^(\w+:)?\/\/([^\/?#]+)/ | |
yb = /%20/g | |
zb = c.fn.load | |
c.fn.extend | |
load: (a, b, d) -> | |
if typeof(a) isnt 'string' | |
return zb.call(this, a) | |
else return this if not @length | |
f = a.indexOf(' ') | |
if f >= 0 | |
e = a.slice(f, a.length) | |
a = a.slice(0, f) | |
f = 'GET' | |
if b | |
if c.isFunction(b) | |
d = b | |
b = null | |
else if typeof(b) is 'object' | |
b = c.param(b, c.ajaxSettings.traditional) | |
f = 'POST' | |
j = this | |
c.ajax | |
url: a | |
type: f | |
dataType: 'html' | |
data: b | |
complete: (i, o) -> | |
j.html (if e then c('<div />').append(i.responseText.replace(tb, '')).find(e) else i.responseText) if o is 'success' or o is 'notmodified' | |
d and j.each(d, [i.responseText, o, i]) | |
this | |
serialize: -> | |
c.param @serializeArray() | |
serializeArray: -> | |
@map(-> | |
(if @elements then c.makeArray(@elements) else this) | |
).filter(-> | |
@name and not @disabled and (@checked or ub.test(@nodeName) or vb.test(@type)) | |
).map((a, b) -> | |
a = c(this).val() | |
(if a == null then null else (if c.isArray(a) then c.map(a, (d) -> | |
{ | |
name: b.name | |
value: d | |
} | |
) else { | |
name: b.name | |
value: a | |
})) | |
).get() | |
c.each 'ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend'.split(' '), (a, b) -> | |
c.fn[b] = (d) -> | |
@bind b, d | |
c.extend | |
get: (a, b, d, f) -> | |
if c.isFunction(b) | |
f = f or d | |
d = b | |
b = null | |
c.ajax | |
type: 'GET' | |
url: a | |
data: b | |
success: d | |
dataType: f | |
getScript: (a, b) -> | |
c.get a, null, b, 'script' | |
getJSON: (a, b, d) -> | |
c.get a, b, d, 'json' | |
post: (a, b, d, f) -> | |
if c.isFunction(b) | |
f = f or d | |
d = b | |
b = {} | |
c.ajax | |
type: 'POST' | |
url: a | |
data: b | |
success: d | |
dataType: f | |
ajaxSetup: (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: (if A.XMLHttpRequest and (A.location.protocol isnt 'file:' or not A.ActiveXObject) then -> | |
new A.XMLHttpRequest | |
else -> | |
try | |
return new A.ActiveXObject('Microsoft.XMLHTTP') | |
catch a | |
) | |
accepts: { | |
xml: 'application/xml, text/xml' | |
html: 'text/html' | |
script: 'text/javascript, application/javascript' | |
json: 'application/json, text/javascript' | |
text: 'text/plain' | |
_default: '*/*' | |
} | |
} | |
lastModified: {} | |
etag: {} | |
ajax: (a) -> | |
b = -> | |
e.success and e.success.call(k, o, i, x) | |
e.global and f('ajaxSuccess', [x, e]) | |
d = -> | |
e.complete and e.complete.call(k, x, i) | |
e.global and f('ajaxComplete', [x, e]) | |
e.global and not c.active-- and c.event.trigger('ajaxStop') | |
f = (q, p) -> | |
((if e.context then c(e.context) else c.event)).trigger q, p | |
e = c.extend(true, {}, c.ajaxSettings, a) | |
k = a and a.context or e | |
n = e.type.toUpperCase() | |
e.data = c.param(e.data, e.traditional) if e.data and e.processData and typeof(e.data) isnt 'string' | |
if e.dataType is 'jsonp' | |
if n is 'GET' | |
N.test(e.url) or (e.url = ((if ka.test(e.url) then '&' else '?')) + (e.jsonp or 'callback') + '=?') | |
else e.data = ((if e.data then e.data + '&' else '')) + (e.jsonp or 'callback') + '=?' if not e.data or not N.test(e.data) | |
e.dataType = 'json' | |
if e.dataType is 'json' and (e.data and N.test(e.data) or N.test(e.url)) | |
j = e.jsonpCallback or 'jsonp' + sb++ | |
e.data = (e.data + '').replace(N, '=' + j + '$1') if e.data | |
e.url = e.url.replace(N, '=' + j + '$1') | |
e.dataType = 'script' | |
A[j] = A[j] or (q) -> | |
o = q | |
b() | |
d() | |
A[j] = w | |
try | |
delete A[j] | |
catch p | |
z and z.removeChild(C) | |
e.cache = false if e.dataType is 'script' and e.cache is null | |
if e.cache is false and n is 'GET' | |
r = J() | |
u = e.url.replace(wb, '$1_=' + r + '$2') | |
e.url = u + ((if u is e.url then ((if ka.test(e.url) then '&' else '?')) + '_=' + r else '')) | |
e.url = ((if ka.test(e.url) then '&' else '?')) + e.data if e.data and n is 'GET' | |
e.global and not c.active++ and c.event.trigger('ajaxStart') | |
r = (r = xb.exec(e.url)) and (r[1] and r[1] isnt location.protocol or r[2] isnt location.host) | |
if e.dataType is 'script' and n is 'GET' and r | |
z = s.getElementsByTagName('head')[0] or s.documentElement | |
C = s.createElement('script') | |
C.src = e.url | |
C.charset = e.scriptCharset if e.scriptCharset | |
if not j | |
B = false | |
C.onload = C.onreadystatechange = -> | |
if not B and (not @readyState or @readyState is 'loaded' or @readyState is 'complete') | |
B = true | |
b() | |
d() | |
C.onload = C.onreadystatechange = null | |
z and C.parentNode and z.removeChild(C) | |
z.insertBefore C, z.firstChild | |
return w | |
E = false | |
x = e.xhr() | |
if x | |
(if e.username then x.open(n, e.url, e.async, e.username, e.password) else x.open(n, e.url, e.async)) | |
try | |
x.setRequestHeader 'Content-Type', e.contentType if e.data or a and a.contentType | |
if e.ifModified | |
c.lastModified[e.url] and x.setRequestHeader('If-Modified-Since', c.lastModified[e.url]) | |
c.etag[e.url] and x.setRequestHeader('If-None-Match', c.etag[e.url]) | |
r or x.setRequestHeader('X-Requested-With', 'XMLHttpRequest') | |
x.setRequestHeader 'Accept', (if e.dataType and e.accepts[e.dataType] then e.accepts[e.dataType] + ', */*' else e.accepts._default) | |
catch ga | |
if e.beforeSend and e.beforeSend.call(k, x, e) is false | |
e.global and not c.active-- and c.event.trigger('ajaxStop') | |
x.abort() | |
return false | |
e.global and f('ajaxSend', [x, e]) | |
g = x.onreadystatechange = (q) -> | |
if not x or x.readyState is 0 or q is 'abort' | |
E or d() | |
E = true | |
x.onreadystatechange = c.noop if x | |
else if not E and x and (x.readyState is 4 or q is 'timeout') | |
E = true | |
x.onreadystatechange = c.noop | |
i = (if q is 'timeout' then 'timeout' else (if not c.httpSuccess(x) then 'error' else (if e.ifModified and c.httpNotModified(x, e.url) then 'notmodified' else 'success'))) | |
if i is 'success' | |
try | |
o = c.httpData(x, e.dataType, e) | |
catch v | |
i = 'parsererror' | |
p = v | |
if i is 'success' or i is 'notmodified' | |
j or b() | |
else c.handleError e, x, i, p | |
d() | |
q is 'timeout' and x.abort() | |
x = null if e.async | |
try | |
h = x.abort | |
x.abort = -> | |
x and h.call(x) | |
g 'abort' | |
catch l | |
e.async and e.timeout > 0 and setTimeout(-> | |
x and not E and g('timeout') | |
, e.timeout | |
) | |
try | |
x.send (if n is 'POST' or n is 'PUT' or n is 'DELETE' then e.data else null) | |
catch m | |
c.handleError e, x, null, m | |
d() | |
e.async or g() | |
return x | |
handleError: (a, b, d, f) -> | |
a.error.call a.context or a, b, d, f if a.error | |
((if a.context then c(a.context) else c.event)).trigger 'ajaxError', [b, a, f] if a.global | |
active: 0 | |
httpSuccess: (a) -> | |
try | |
return not a.status and location.protocol is 'file:' or a.status >= 200 and a.status < 300 or a.status is 304 or a.status is 1223 or a.status is 0 | |
catch b | |
false | |
httpNotModified: (a, b) -> | |
d = a.getResponseHeader('Last-Modified') | |
f = a.getResponseHeader('Etag') | |
c.lastModified[b] = d if d | |
c.etag[b] = f if f | |
a.status is 304 or a.status is 0 | |
httpData: (a, b, d) -> | |
f = a.getResponseHeader('content-type') or '' | |
e = b is 'xml' or not b and f.indexOf('xml') >= 0 | |
a = (if e then a.responseXML else a.responseText) | |
e and a.documentElement.nodeName is 'parsererror' and c.error('parsererror') | |
a = d.dataFilter(a, b) if d and d.dataFilter | |
if typeof(a) is 'string' | |
if b is 'json' or not b and f.indexOf('json') >= 0 | |
a = c.parseJSON(a) | |
else c.globalEval a if b is 'script' or not b and f.indexOf('javascript') >= 0 | |
a | |
param: (a, b) -> | |
d = (i, o) -> | |
if c.isArray(o) | |
c.each o, (k, n) -> | |
(if b or /\[\]$/.test(i) then f(i, n) else d(i + '[' + ((if typeof(n) is 'object' or c.isArray(n) then k else '')) + ']', n)) | |
else (if not b and o != null and typeof(o) is 'object' then c.each(o, (k, n) -> | |
d i + '[' + k + ']', n | |
) else f(i, o)) | |
f = (i, o) -> | |
o = (if c.isFunction(o) then o() else o) | |
e[e.length] = encodeURIComponent(i) + '=' + encodeURIComponent(o) | |
e = [] | |
b = c.ajaxSettings.traditional if b is w | |
if c.isArray(a) or a.jquery | |
c.each a, -> | |
f @name, @value | |
else for j of a | |
d j, a[j] | |
e.join('&').replace yb, '+' | |
la = {} | |
Ab = /toggle|show|hide/ | |
Bb = /^([+-]=)?([\d+-.]+)(.*)$/ | |
va = [['height', 'marginTop', 'marginBottom', 'paddingTop', 'paddingBottom'], ['width', 'marginLeft', 'marginRight', 'paddingLeft', 'paddingRight'], ['opacity']] | |
c.fn.extend | |
show: (a, b) -> | |
if a or a is 0 | |
return @animate(K('show', 3), a, b) | |
else a = 0 | |
b = @length | |
while a < b | |
d = c.data(this[a], 'olddisplay') | |
this[a].style.display = d or '' | |
if c.css(this[a], 'display') is 'none' | |
d = this[a].nodeName | |
if la[d] | |
f = la[d] | |
else e = c('<' + d + ' />').appendTo('body') | |
f = e.css('display') | |
f = 'block' if f is 'none' | |
e.remove() | |
la[d] = f | |
c.data this[a], 'olddisplay', f | |
a++ | |
a = 0 | |
b = @length | |
while a < b | |
this[a].style.display = c.data(this[a], 'olddisplay') or '' | |
a++ | |
return this | |
hide: (a, b) -> | |
if a or a is 0 | |
return @animate(K('hide', 3), a, b) | |
else a = 0 | |
b = @length | |
while a < b | |
d = c.data(this[a], 'olddisplay') | |
not d and d isnt 'none' and c.data(this[a], 'olddisplay', c.css(this[a], 'display')) | |
a++ | |
a = 0 | |
b = @length | |
while a < b | |
this[a].style.display = 'none' | |
a++ | |
return this | |
_toggle: c.fn.toggle | |
toggle: (a, b) -> | |
d = typeof(a) is 'boolean' | |
if c.isFunction(a) and c.isFunction(b) | |
@_toggle.apply this, arguments | |
else (if a == null or d then @each(-> | |
f = (if d then a else c(this).is(':hidden')) | |
c(this)[(if f then 'show' else 'hide')]() | |
) else @animate(K('toggle', 3), a, b)) | |
this | |
fadeTo: (a, b, d) -> | |
@filter(':hidden').css('opacity', 0).show().end().animate {opacity: b}, a, d | |
animate: (a, b, d, f) -> | |
e = c.speed(b, d, f) | |
return @each(e.complete) if c.isEmptyObject(a) | |
this[(if e.queue is false then 'each' else 'queue')] -> | |
j = c.extend({}, e) | |
o = @nodeType is 1 and c(this).is(':hidden') | |
k = this | |
for i of a | |
n = i.replace(ia, ja) | |
if i isnt n | |
a[n] = a[i] | |
delete a[i] | |
i = n | |
return j.complete.call(this) if a[i] is 'hide' and o or a[i] is 'show' and not o | |
if (i is 'height' or i is 'width') and @style | |
j.display = c.css(this, 'display') | |
j.overflow = @style.overflow | |
if c.isArray(a[i]) | |
(j.specialEasing = j.specialEasing or {})[i] = a[i][1] | |
a[i] = a[i][0] | |
@style.overflow = 'hidden' if j.overflow != null | |
j.curAnim = c.extend({}, a) | |
c.each a, (r, u) -> | |
z = new c.fx(k, j, r) | |
if Ab.test(u) | |
z[(if u is 'toggle' then o else (if 'show' then 'hide' else u))] a | |
else C = Bb.exec(u) | |
B = z.cur(true) or 0 | |
if C | |
u = parseFloat(C[2]) | |
E = C[3] or 'px' | |
if E isnt 'px' | |
k.style[r] = (u or 1) + E | |
B = (u or 1) / z.cur(true) * B | |
k.style[r] = B + E | |
u = ((if C[1] is '-=' then -1 else 1)) * u + B if C[1] | |
z.custom B, u, E | |
else z.custom B, u, '' | |
true | |
stop: (a, b) -> | |
d = c.timers | |
a and @queue([]) | |
@each -> | |
f = d.length - 1 | |
while f >= 0 | |
if d[f].elem is this | |
b and d[f](true) | |
d.splice f, 1 | |
f-- | |
b or @dequeue() | |
this | |
c.each | |
slideDown: K('show', 1) | |
slideUp: K('hide', 1) | |
slideToggle: K('toggle', 1) | |
fadeIn: {opacity: 'show'} | |
fadeOut: {opacity: 'hide'} | |
, (a, b) -> | |
c.fn[a] = (d, f) -> | |
@animate b, d, f | |
c.extend | |
speed: (a, b, d) -> | |
f = (if a and typeof(a) is 'object' then a else { | |
complete: d or not d and b or c.isFunction(a) and a | |
duration: a | |
easing: d and b or b and not c.isFunction(b) and b | |
}) | |
f.duration = (if c.fx.off_ then 0 else (if typeof(f.duration) is 'number' then f.duration else c.fx.speeds[f.duration] or c.fx.speeds._default)) | |
f.old = f.complete | |
f.complete = -> | |
f.queue isnt false and c(this).dequeue() | |
c.isFunction(f.old) and f.old.call(this) | |
f | |
easing: { | |
linear: (a, b, d, f) -> | |
d + f * a | |
swing: (a, b, d, f) -> | |
(-Math.cos(a * Math.PI) / 2 + 0.5) * f + d | |
} | |
timers: [] | |
fx: (a, b, d) -> | |
@options = b | |
@elem = a | |
@prop = d | |
b.orig = {} if not b.orig | |
c.fx.prototype = | |
update: -> | |
@options.step and @options.step.call(@elem, @now, this) | |
(c.fx.step[@prop] or c.fx.step._default) this | |
@elem.style.display = 'block' if (@prop is 'height' or @prop is 'width') and @elem.style | |
cur: (a) -> | |
return @elem[@prop] if @elem[@prop] != null and (not @elem.style or @elem.style[@prop] == null) | |
(if (a = parseFloat(c.css(@elem, @prop, a))) and a > -10000 then a else parseFloat(c.curCSS(@elem, @prop)) or 0) | |
custom: (a, b, d) -> | |
f = (j) -> | |
e.step j | |
@startTime = J() | |
@start = a | |
@end = b | |
@unit = d or @unit or 'px' | |
@now = @start | |
@pos = @state = 0 | |
e = this | |
f.elem = @elem | |
W = setInterval(c.fx.tick, 13) if f() and c.timers.push(f) and not W | |
show: -> | |
@options.orig[@prop] = c.style(@elem, @prop) | |
@options.show = true | |
@custom (if @prop is 'width' or @prop is 'height' then 1 else 0), @cur() | |
c(@elem).show() | |
hide: -> | |
@options.orig[@prop] = c.style(@elem, @prop) | |
@options.hide = true | |
@custom @cur(), 0 | |
step: (a) -> | |
b = J() | |
d = true | |
if a or b >= @options.duration + @startTime | |
@now = @end | |
@pos = @state = 1 | |
@update() | |
@options.curAnim[@prop] = true | |
for f of @options.curAnim | |
d = false if @options.curAnim[f] isnt true | |
if d | |
if @options.display != null | |
@elem.style.overflow = @options.overflow | |
a = c.data(@elem, 'olddisplay') | |
@elem.style.display = (if a then a else @options.display) | |
@elem.style.display = 'block' if c.css(@elem, 'display') is 'none' | |
@options.hide and c(@elem).hide() | |
if @options.hide or @options.show | |
for e of @options.curAnim | |
c.style @elem, e, @options.orig[e] | |
@options.complete.call @elem | |
return false | |
else e = b - @startTime | |
@state = e / @options.duration | |
a = @options.easing or ((if c.easing.swing then 'swing' else 'linear')) | |
@pos = c.easing[@options.specialEasing and @options.specialEasing[@prop] or a](@state, e, 0, 1, @options.duration) | |
@now = @start + (@end - @start) * @pos | |
@update() | |
true | |
c.extend c.fx, | |
tick: -> | |
a = c.timers | |
b = 0 | |
while b < a.length | |
a[b]() or a.splice(b--, 1) | |
b++ | |
a.length or c.fx.stop() | |
stop: -> | |
clearInterval W | |
W = null | |
speeds: { | |
slow: 600 | |
fast: 200 | |
_default: 400 | |
} | |
step: { | |
opacity: (a) -> | |
c.style a.elem, 'opacity', a.now | |
_default: (a) -> | |
if a.elem.style and a.elem.style[a.prop] != null | |
a.elem.style[a.prop] = ((if a.prop is 'width' or a.prop is 'height' then Math.max(0, a.now) else a.now)) + a.unit | |
else a.elem[a.prop] = a.now | |
} | |
if c.expr and c.expr.filters | |
c.expr.filters.animated = (a) -> | |
c.grep(c.timers, (b) -> | |
a is b.elem | |
).length | |
c.fn.offset = (if 'getBoundingClientRect' in s.documentElement then (a) -> | |
b = this[0] | |
if a | |
return @each((e) -> | |
c.offset.setOffset this, a, e | |
) | |
return null if not b or not b.ownerDocument | |
return c.offset.bodyOffset(b) if b is b.ownerDocument.body | |
d = b.getBoundingClientRect() | |
f = b.ownerDocument | |
b = f.body | |
f = f.documentElement | |
{ | |
top: d.top + (self.pageYOffset or c.support.boxModel and f.scrollTop or b.scrollTop) - (f.clientTop or b.clientTop or 0) | |
left: d.left + (self.pageXOffset or c.support.boxModel and f.scrollLeft or b.scrollLeft) - (f.clientLeft or b.clientLeft or 0) | |
} | |
else (a) -> | |
b = this[0] | |
if a | |
return @each((r) -> | |
c.offset.setOffset this, a, r | |
) | |
return null if not b or not b.ownerDocument | |
return c.offset.bodyOffset(b) if b is b.ownerDocument.body | |
c.offset.initialize() | |
d = b.offsetParent | |
f = b | |
e = b.ownerDocument | |
i = e.documentElement | |
o = e.body | |
f = (if (e = e.defaultView) then e.getComputedStyle(b, null) else b.currentStyle) | |
k = b.offsetTop | |
n = b.offsetLeft | |
while (b = b.parentNode) and b isnt o and b isnt i | |
break if c.offset.supportsFixedPosition and f.position is 'fixed' | |
j = (if e then e.getComputedStyle(b, null) else b.currentStyle) | |
k = b.scrollTop | |
n = b.scrollLeft | |
if b is d | |
k = b.offsetTop | |
n = b.offsetLeft | |
if c.offset.doesNotAddBorder and not (c.offset.doesAddBorderForTableAndCells and /^t(able|d|h)$/i.test(b.nodeName)) | |
k = parseFloat(j.borderTopWidth) or 0 | |
n = parseFloat(j.borderLeftWidth) or 0 | |
f = d | |
d = b.offsetParent | |
if c.offset.subtractsBorderForOverflowNotVisible and j.overflow isnt 'visible' | |
k = parseFloat(j.borderTopWidth) or 0 | |
n = parseFloat(j.borderLeftWidth) or 0 | |
f = j | |
if f.position is 'relative' or f.position is 'static' | |
k = o.offsetTop | |
n = o.offsetLeft | |
if c.offset.supportsFixedPosition and f.position is 'fixed' | |
k = Math.max(i.scrollTop, o.scrollTop) | |
n = Math.max(i.scrollLeft, o.scrollLeft) | |
{ | |
top: k | |
left: n | |
} | |
) | |
c.offset = | |
initialize: -> | |
a = s.body | |
b = s.createElement('div') | |
j = parseFloat(c.curCSS(a, 'marginTop', true)) or 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 | |
f = d.firstChild | |
e = d.nextSibling.firstChild.firstChild | |
@doesNotAddBorder = f.offsetTop isnt 5 | |
@doesAddBorderForTableAndCells = e.offsetTop is 5 | |
f.style.position = 'fixed' | |
f.style.top = '20px' | |
@supportsFixedPosition = f.offsetTop is 20 or f.offsetTop is 15 | |
f.style.position = f.style.top = '' | |
d.style.overflow = 'hidden' | |
d.style.position = 'relative' | |
@subtractsBorderForOverflowNotVisible = f.offsetTop is -5 | |
@doesNotIncludeMarginInBodyOffset = a.offsetTop isnt j | |
a.removeChild b | |
c.offset.initialize = c.noop | |
bodyOffset: (a) -> | |
b = a.offsetTop | |
d = a.offsetLeft | |
c.offset.initialize() | |
if c.offset.doesNotIncludeMarginInBodyOffset | |
b = parseFloat(c.curCSS(a, 'marginTop', true)) or 0 | |
d = parseFloat(c.curCSS(a, 'marginLeft', true)) or 0 | |
{ | |
top: b | |
left: d | |
} | |
setOffset: (a, b, d) -> | |
a.style.position = 'relative' if /static/.test(c.curCSS(a, 'position')) | |
f = c(a) | |
e = f.offset() | |
j = parseInt(c.curCSS(a, 'top', true), 10) or 0 | |
i = parseInt(c.curCSS(a, 'left', true), 10) or 0 | |
b = b.call(a, d, e) if c.isFunction(b) | |
d = | |
top: b.top - e.top + j | |
left: b.left - e.left + i | |
(if 'using' in b then b.using.call(a, d) else f.css(d)) | |
c.fn.extend | |
position: -> | |
return null if not this[0] | |
a = this[0] | |
b = @offsetParent() | |
d = @offset() | |
f = (if /^body|html$/i.test(b[0].nodeName) then { | |
top: 0 | |
left: 0 | |
} else b.offset()) | |
d.top = parseFloat(c.curCSS(a, 'marginTop', true)) or 0 | |
d.left = parseFloat(c.curCSS(a, 'marginLeft', true)) or 0 | |
f.top = parseFloat(c.curCSS(b[0], 'borderTopWidth', true)) or 0 | |
f.left = parseFloat(c.curCSS(b[0], 'borderLeftWidth', true)) or 0 | |
{ | |
top: d.top - f.top | |
left: d.left - f.left | |
} | |
offsetParent: -> | |
@map -> | |
a = @offsetParent or s.body | |
while a and not /^body|html$/i.test(a.nodeName) and c.css(a, 'position') is 'static' | |
a = a.offsetParent | |
a | |
c.each ['Left', 'Top'], (a, b) -> | |
d = 'scroll' + b | |
c.fn[d] = (f) -> | |
e = this[0] | |
return null if not e | |
if f isnt w | |
return @each(-> | |
if j = wa(this) | |
j.scrollTo (if not a then f else c(j).scrollLeft()), (if a then f else c(j).scrollTop()) | |
else this[d] = f | |
) | |
else return (if (j = wa(e)) then 'pageXOffset' in j else (if j[(if a then 'pageYOffset' else 'pageXOffset')] then c.support.boxModel and j.document.documentElement[d] or j.document.body[d] else e[d])) | |
c.each ['Height', 'Width'], (a, b) -> | |
d = b.toLowerCase() | |
c.fn['inner' + b] = -> | |
(if this[0] then c.css(this[0], d, false, 'padding') else null) | |
c.fn['outer' + b] = (f) -> | |
(if this[0] then c.css(this[0], d, false, (if f then 'margin' else 'border')) else null) | |
c.fn[d] = (f) -> | |
e = this[0] | |
return (if f == null then null else this) if not e | |
if c.isFunction(f) | |
return @each((j) -> | |
i = c(this) | |
i[d] f.call(this, j, i[d]()) | |
) | |
(if 'scrollTo' in e and e.document then e.document.compatMode is 'CSS1Compat' and e.document.documentElement['client' + b] or e.document.body['client' + b] else (if e.nodeType is 9 then Math.max(e.documentElement['client' + b], e.body['scroll' + b], e.documentElement['scroll' + b], e.body['offset' + b], e.documentElement['offset' + b]) else (if f is w then c.css(e, d) else @css(d, (if typeof(f) is 'string' then f else f + 'px'))))) | |
A.jQuery = A.$ = c | |
) window | |
and back to javascript | |
(function() { | |
var __indexOf = Array.prototype.indexOf || function(item) { | |
for (var i = 0, l = this.length; i < l; i++) { | |
if (this[i] === item) return i; | |
} | |
return -1; | |
}; | |
(function(A, w) { | |
var $, $a, Aa, Ab, Ba, Bb, Ca, Da, Ea, F, Fa, G, Ga, Ia, J, Ja, K, Ka, L, La, Ma, N, Na, O, Oa, P, Pa, Q, Qa, R, Ra, Sa, T, Ta, Ua, V, Va, Wa, X, Xa, Y, Ya, Z, Za, aa, ab, ba, bb, c, ca, cb, da, db, ea, eb, fa, fb, gb, ha, hb, ia, ib, ja, jb, ka, kb, la, lb, ma, mb, na, nb, oa, ob, pa, pb, qa, qb, ra, rb, s, sa, sb, ta, tb, ua, ub, va, vb, wa, wb, xa, xb, ya, yb, za, zb; | |
ma = function() { | |
if (!c.isReady) { | |
try { | |
s.documentElement.doScroll('left'); | |
} catch (a) { | |
setTimeout(ma, 1); | |
return; | |
} | |
return c.ready(); | |
} | |
}; | |
Qa = function(a, b) { | |
if (b.src) { | |
c.ajax({ | |
url: b.src, | |
async: false, | |
dataType: 'script' | |
}); | |
} else { | |
c.globalEval(b.text || b.textContent || b.innerHTML || ''); | |
} | |
return b.parentNode && b.parentNode.removeChild(b); | |
}; | |
X = function(a, b, d, f, e, j) { | |
var i, o; | |
i = a.length; | |
if (typeof b === 'object') { | |
for (o in b) { | |
X(a, o, b[o], f, e, d); | |
} | |
return a; | |
} | |
if (d !== w) { | |
f = !j && f && c.isFunction(d); | |
o = 0; | |
while (o < i) { | |
e(a[o], b, (f ? d.call(a[o], o, e(a[o], b)) : d), j); | |
o++; | |
} | |
return a; | |
} | |
if (i) { | |
return e(a[0], b); | |
} else { | |
return w; | |
} | |
}; | |
J = function() { | |
return (new Date).getTime(); | |
}; | |
Y = function() { | |
return false; | |
}; | |
Z = function() { | |
return true; | |
}; | |
na = function(a, b, d) { | |
d[0].type = a; | |
return c.event.handle.apply(b, d); | |
}; | |
oa = function(a) { | |
var b, d, e, f, i, j, k, n, o, r, u; | |
d = []; | |
f = []; | |
e = arguments; | |
i = c.data(this, 'events'); | |
if (!(a.liveFired === this || !i || !i.live || a.button && a.type === 'click')) { | |
a.liveFired = this; | |
u = i.live.slice(0); | |
k = 0; | |
while (k < u.length) { | |
i = u[k]; | |
if (i.origType.replace(O, '') === a.type) { | |
f.push(i.selector); | |
} else { | |
u.splice(k--, 1); | |
} | |
k++; | |
} | |
j = c(a.target).closest(f, a.currentTarget); | |
n = 0; | |
r = j.length; | |
while (n < r) { | |
k = 0; | |
while (k < u.length) { | |
i = u[k]; | |
if (j[n].selector === i.selector) { | |
o = j[n].elem; | |
f = null; | |
if (i.preType === 'mouseenter' || i.preType === 'mouseleave') { | |
f = c(a.relatedTarget).closest(i.selector)[0]; | |
} | |
if (!f || f !== o) { | |
d.push({ | |
elem: o, | |
handleObj: i | |
}); | |
} | |
} | |
k++; | |
} | |
n++; | |
} | |
n = 0; | |
r = d.length; | |
while (n < r) { | |
j = d[n]; | |
a.currentTarget = j.elem; | |
a.data = j.handleObj.data; | |
a.handleObj = j.handleObj; | |
if (j.handleObj.origHandler.apply(j.elem, e) === false) { | |
b = false; | |
break; | |
} | |
n++; | |
} | |
return b; | |
} | |
}; | |
pa = function(a, b) { | |
return 'live.' + (a && a !== '*' ? a + '.' : '') + b.replace(/\./g, '`').replace(RegExp(' ', 'g'), '&'); | |
}; | |
qa = function(a) { | |
return !a || !a.parentNode || a.parentNode.nodeType === 11; | |
}; | |
ra = function(a, b) { | |
var d; | |
d = 0; | |
return b.each(function() { | |
var e, f, i, j, _results; | |
if (this.nodeName === (a[d] && a[d].nodeName)) { | |
f = c.data(a[d++]); | |
e = c.data(this, f); | |
if (f = f && f.events) { | |
delete e.handle; | |
e.events = {}; | |
_results = []; | |
for (j in f) { | |
_results.push((function() { | |
var _results; | |
_results = []; | |
for (i in f[j]) { | |
_results.push(c.event.add(this, j, f[j][i], f[j][i].data)); | |
} | |
return _results; | |
}).call(this)); | |
} | |
return _results; | |
} | |
} | |
}); | |
}; | |
sa = function(a, b, d) { | |
var e, f, j; | |
b = (b && b[0] ? b[0].ownerDocument || b[0] : s); | |
if (a.length === 1 && typeof a[0] === 'string' && a[0].length < 512 && b === s && !ta.test(a[0]) && (c.support.checkClone || !ua.test(a[0]))) { | |
e = true; | |
if ((j = c.fragments[a[0]]) ? j !== 1 : void 0) { | |
f = j; | |
} | |
} | |
if (!f) { | |
f = b.createDocumentFragment(); | |
c.clean(a, b, f, d); | |
} | |
if (e) { | |
c.fragments[a[0]] = (j ? f : 1); | |
} | |
return { | |
fragment: f, | |
cacheable: e | |
}; | |
}; | |
K = function(a, b) { | |
var d; | |
d = {}; | |
c.each(va.concat.apply([], va.slice(0, b)), function() { | |
return d[this] = a; | |
}); | |
return d; | |
}; | |
wa = function(a) { | |
if (__indexOf.call(a, 'scrollTo') >= 0 && a.document) { | |
return a; | |
} else { | |
if (a.nodeType === 9) { | |
return a.defaultView || a.parentWindow; | |
} else { | |
return false; | |
} | |
} | |
}; | |
c = function(a, b) { | |
return new c.fn.init(a, b); | |
}; | |
Ra = A.jQuery; | |
Sa = A.$; | |
s = A.document; | |
Ta = /^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/; | |
Ua = /^.[^:#\[\.,]*$/; | |
Va = /\S/; | |
Wa = /^(\s|\u00A0)+|(\s|\u00A0)+$/g; | |
Xa = /^<(\w+)\s*\/?>(?:<\/\1>)?$/; | |
P = navigator.userAgent; | |
xa = false; | |
Q = []; | |
$ = Object.prototype.toString; | |
aa = Object.prototype.hasOwnProperty; | |
ba = Array.prototype.push; | |
R = Array.prototype.slice; | |
ya = Array.prototype.indexOf; | |
c.fn = c.prototype = { | |
init: function(a, b) { | |
var d, f; | |
if (!a) { | |
return this; | |
} | |
if (a.nodeType) { | |
this.context = this[0] = a; | |
this.length = 1; | |
return this; | |
} | |
if (a === 'body' && !b) { | |
this.context = s; | |
this[0] = s.body; | |
this.selector = 'body'; | |
this.length = 1; | |
return this; | |
} | |
if (typeof a === 'string') { | |
if ((d = Ta.exec(a)) && (d[1] || !b)) { | |
if (d[1]) { | |
f = (b ? b.ownerDocument || b : s); | |
if (a = Xa.exec(a)) { | |
if (c.isPlainObject(b)) { | |
a = [s.createElement(a[1])]; | |
c.fn.attr.call(a, b, true); | |
} else { | |
a = [f.createElement(a[1])]; | |
} | |
} else { | |
a = sa([d[1]], [f]); | |
} | |
a = (a.cacheable ? a.fragment.cloneNode(true) : a.fragment).childNodes; | |
return c.merge(this, a); | |
} else if (b = s.getElementById(d[2])) { | |
if (b.id !== d[2]) { | |
return T.find(a); | |
} | |
this.length = 1; | |
this[0] = b; | |
} | |
this.context = s; | |
this.selector = a; | |
return this; | |
} else if (!b && /^\w+$/.test(a)) { | |
this.selector = a; | |
this.context = s; | |
a = s.getElementsByTagName(a); | |
return c.merge(this, a); | |
} else { | |
if (!b || b.jquery) { | |
return (b || T).find(a); | |
} else { | |
return c(b).find(a); | |
} | |
} | |
} else { | |
if (c.isFunction(a)) { | |
return T.ready(a); | |
} | |
} | |
if (a.selector !== w) { | |
this.selector = a.selector; | |
this.context = a.context; | |
} | |
return c.makeArray(a, this); | |
}, | |
selector: '', | |
jquery: '1.4.2', | |
length: 0, | |
size: function() { | |
return this.length; | |
}, | |
toArray: function() { | |
return R.call(this, 0); | |
}, | |
get: function(a) { | |
if (a === null) { | |
return this.toArray(); | |
} else { | |
if (a < 0) { | |
return this.slice(a)[0]; | |
} else { | |
return this[a]; | |
} | |
} | |
}, | |
pushStack: function(a, b, d) { | |
var f; | |
f = c(); | |
if (c.isArray(a)) { | |
ba.apply(f, a); | |
} else { | |
c.merge(f, a); | |
} | |
f.prevObject = this; | |
f.context = this.context; | |
if (b === 'find') { | |
f.selector = this.selector + (this.selector ? ' ' : '') + d; | |
} else { | |
if (b) { | |
f.selector = this.selector + '.' + b + '(' + d + ')'; | |
} | |
} | |
return f; | |
}, | |
each: function(a, b) { | |
return c.each(this, a, b); | |
}, | |
ready: function(a) { | |
c.bindReady(); | |
if (c.isReady) { | |
a.call(s, c); | |
} else { | |
Q && Q.push(a); | |
} | |
return this; | |
}, | |
eq: function(a) { | |
if (a === -1) { | |
return this.slice(a); | |
} else { | |
return this.slice(a, +a + 1); | |
} | |
}, | |
first: function() { | |
return this.eq(0); | |
}, | |
last: function() { | |
return this.eq(-1); | |
}, | |
slice: function() { | |
return this.pushStack(R.apply(this, arguments), 'slice', R.call(arguments).join(',')); | |
}, | |
map: function(a) { | |
return this.pushStack(c.map(this, function(b, d) { | |
return a.call(b, d, b); | |
})); | |
}, | |
end: function() { | |
return this.prevObject || c(null); | |
}, | |
push: ba, | |
sort: [].sort, | |
splice: [].splice | |
}; | |
c.fn.init.prototype = c.fn; | |
c.extend = c.fn.extend = function() { | |
var a, b, d, e, f, i, j, o; | |
a = arguments[0] || {}; | |
b = 1; | |
d = arguments.length; | |
f = false; | |
if (typeof a === 'boolean') { | |
f = a; | |
a = arguments[1] || {}; | |
b = 2; | |
} | |
if (typeof a !== 'object' && !c.isFunction(a)) { | |
a = {}; | |
} | |
if (d === b) { | |
a = this; | |
b--; | |
} | |
while (b < d) { | |
if ((e = arguments[b]) !== null) { | |
for (j in e) { | |
i = a[j]; | |
o = e[j]; | |
if (a !== o) { | |
if (f && o && (c.isPlainObject(o) || c.isArray(o))) { | |
i = (i && (c.isPlainObject(i) || c.isArray(i)) ? i : (c.isArray(o) ? [] : {})); | |
a[j] = c.extend(f, i, o); | |
} else { | |
if (o !== w) { | |
a[j] = o; | |
} | |
} | |
} | |
} | |
} | |
b++; | |
} | |
return a; | |
}; | |
c.extend({ | |
noConflict: function(a) { | |
A.$ = Sa; | |
if (a) { | |
A.jQuery = Ra; | |
} | |
return c; | |
}, | |
isReady: false, | |
ready: function() { | |
var a, b; | |
if (!c.isReady) { | |
if (!s.body) { | |
return setTimeout(c.ready, 13); | |
} | |
c.isReady = true; | |
if (Q) { | |
b = 0; | |
while (a = Q[b++]) { | |
a.call(s, c); | |
} | |
Q = null; | |
} | |
return c.fn.triggerHandler && c(s).triggerHandler('ready'); | |
} | |
}, | |
bindReady: function() { | |
var a; | |
if (!xa) { | |
xa = true; | |
if (s.readyState === 'complete') { | |
return c.ready(); | |
} | |
if (s.addEventListener) { | |
s.addEventListener('DOMContentLoaded', L, false); | |
return A.addEventListener('load', c.ready, false); | |
} else if (s.attachEvent) { | |
s.attachEvent('onreadystatechange', L); | |
A.attachEvent('onload', c.ready); | |
a = false; | |
try { | |
a = A.frameElement === null; | |
} catch (b) { | |
} | |
return s.documentElement.doScroll && a && ma(); | |
} | |
} | |
}, | |
isFunction: function(a) { | |
return $.call(a) === '[object Function]'; | |
}, | |
isArray: function(a) { | |
return $.call(a) === '[object Array]'; | |
}, | |
isPlainObject: function(a) { | |
var b; | |
if (!a || $.call(a) !== '[object Object]' || a.nodeType || a.setInterval) { | |
return false; | |
} | |
if (a.constructor && !aa.call(a, 'constructor') && !aa.call(a.constructor.prototype, 'isPrototypeOf')) { | |
return false; | |
} | |
for (b in a) { | |
0; | |
} | |
return b === w || aa.call(a, b); | |
}, | |
isEmptyObject: function(a) { | |
var b; | |
for (b in a) { | |
return false; | |
} | |
return true; | |
}, | |
error: function(a) { | |
throw a; | |
}, | |
parseJSON: function(a) { | |
if (typeof a !== 'string' || !a) { | |
return null; | |
} | |
a = c.trim(a); | |
if (/^[\],:{}\s]*$/.test(a.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, '@').replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']').replace(/(?:^|:|,)(?:\s*\[)+/g, ''))) { | |
if (A.JSON && A.JSON.parse) { | |
return A.JSON.parse(a); | |
} else { | |
return (new Function('return ' + a))(); | |
} | |
} else { | |
return c.error('Invalid JSON: ' + a); | |
} | |
}, | |
noop: function() {}, | |
globalEval: function(a) { | |
var b, d; | |
if (a && Va.test(a)) { | |
b = s.getElementsByTagName('head')[0] || s.documentElement; | |
d = s.createElement('script'); | |
d.type = 'text/javascript'; | |
if (c.support.scriptEval) { | |
d.appendChild(s.createTextNode(a)); | |
} else { | |
d.text = a; | |
} | |
b.insertBefore(d, b.firstChild); | |
return b.removeChild(d); | |
} | |
}, | |
nodeName: function(a, b) { | |
return a.nodeName && a.nodeName.toUpperCase() === b.toUpperCase(); | |
}, | |
each: function(a, b, d) { | |
var e, f, i, j; | |
e = 0; | |
j = a.length; | |
i = j === w || c.isFunction(a); | |
if (d) { | |
if (i) { | |
for (f in a) { | |
if (b.apply(a[f], d) === false) { | |
break; | |
} | |
} | |
} else { | |
while (e < j) { | |
if (b.apply(a[e++], d) === false) { | |
break; | |
} | |
} | |
} | |
} else if (i) { | |
for (f in a) { | |
if (b.call(a[f], f, a[f]) === false) { | |
break; | |
} | |
} | |
} else { | |
d = a[0]; | |
} | |
while (e < j && b.call(d, e, d) !== false) { | |
d = a[e++]; | |
} | |
return a; | |
}, | |
trim: function(a) { | |
return (a || '').replace(Wa, ''); | |
}, | |
makeArray: function(a, b) { | |
b = b || []; | |
if (a !== null) { | |
if (a.length === null || typeof a === 'string' || c.isFunction(a) || typeof a !== 'function' && a.setInterval) { | |
ba.call(b, a); | |
} else { | |
c.merge(b, a); | |
} | |
} | |
return b; | |
}, | |
inArray: function(a, b) { | |
var d, f; | |
if (b.indexOf) { | |
return b.indexOf(a); | |
} | |
d = 0; | |
f = b.length; | |
while (d < f) { | |
if (b[d] === a) { | |
return d; | |
} | |
d++; | |
} | |
return -1; | |
}, | |
merge: function(a, b) { | |
var d, e, f; | |
d = a.length; | |
f = 0; | |
if (typeof b.length === 'number') { | |
e = b.length; | |
while (f < e) { | |
a[d++] = b[f]; | |
f++; | |
} | |
} else { | |
while (b[f] !== w) { | |
a[d++] = b[f++]; | |
} | |
} | |
a.length = d; | |
return a; | |
}, | |
grep: function(a, b, d) { | |
var e, f, j; | |
f = []; | |
e = 0; | |
j = a.length; | |
while (e < j) { | |
!d !== !b(a[e], e) && f.push(a[e]); | |
e++; | |
} | |
return f; | |
}, | |
map: function(a, b, d) { | |
var e, f, i, j; | |
f = []; | |
j = 0; | |
i = a.length; | |
while (j < i) { | |
e = b(a[j], j, d); | |
if (e !== null) { | |
f[f.length] = e; | |
} | |
j++; | |
} | |
return f.concat.apply([], f); | |
}, | |
guid: 1, | |
proxy: function(a, b, d) { | |
if (arguments.length === 2) { | |
if (typeof b === 'string') { | |
d = a; | |
a = d[b]; | |
b = w; | |
} else if (b && !c.isFunction(b)) { | |
d = b; | |
b = w; | |
} | |
} | |
if (!b && a) { | |
b = function() { | |
return a.apply(d || this, arguments); | |
}; | |
} | |
if (a) { | |
b.guid = a.guid = a.guid || b.guid || c.guid++; | |
} | |
return b; | |
}, | |
uaMatch: function(a) { | |
a = a.toLowerCase(); | |
a = /(webkit)[ \/]([\w.]+)/.exec(a) || /(opera)(?:.*version)?[ \/]([\w.]+)/.exec(a) || /(msie) ([\w.]+)/.exec(a) || !/compatible/.test(a) && /(mozilla)(?:.*? rv:([\w.]+))?/.exec(a) || []; | |
return { | |
browser: a[1] || '', | |
version: a[2] || '0' | |
}; | |
}, | |
browser: {} | |
}); | |
P = c.uaMatch(P); | |
if (P.browser) { | |
c.browser[P.browser] = true; | |
c.browser.version = P.version; | |
} | |
if (c.browser.webkit) { | |
c.browser.safari = true; | |
} | |
if (ya) { | |
c.inArray = function(a, b) { | |
return ya.call(b, a); | |
}; | |
} | |
T = c(s); | |
if (s.addEventListener) { | |
L = function() { | |
s.removeEventListener('DOMContentLoaded', L, false); | |
return c.ready(); | |
}; | |
} else if (s.attachEvent) { | |
L = function() { | |
if (s.readyState === 'complete') { | |
s.detachEvent('onreadystatechange', L); | |
return c.ready(); | |
} | |
}; | |
} | |
(function() { | |
var a, b, d, e, f, j, k; | |
c.support = {}; | |
a = s.documentElement; | |
b = s.createElement('script'); | |
d = s.createElement('div'); | |
f = 'script' + J(); | |
d.style.display = 'none'; | |
d.innerHTML = " <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>"; | |
e = d.getElementsByTagName('*'); | |
j = d.getElementsByTagName('a')[0]; | |
if (!(!e || !e.length || !j)) { | |
c.support = { | |
leadingWhitespace: d.firstChild.nodeType === 3, | |
tbody: !d.getElementsByTagName('tbody').length, | |
htmlSerialize: !!d.getElementsByTagName('link').length, | |
style: /red/.test(j.getAttribute('style')), | |
hrefNormalized: j.getAttribute('href') === '/a', | |
opacity: /^0.55$/.test(j.style.opacity), | |
cssFloat: !!j.style.cssFloat, | |
checkOn: d.getElementsByTagName('input')[0].value === 'on', | |
optSelected: s.createElement('select').appendChild(s.createElement('option')).selected, | |
parentNode: d.removeChild(d.appendChild(s.createElement('div'))).parentNode === null, | |
deleteExpando: true, | |
checkClone: false, | |
scriptEval: false, | |
noCloneEvent: true, | |
boxModel: null | |
}; | |
b.type = 'text/javascript'; | |
try { | |
b.appendChild(s.createTextNode('window.' + f + '=1;')); | |
} catch (i) { | |
} | |
a.insertBefore(b, a.firstChild); | |
if (A[f]) { | |
c.support.scriptEval = true; | |
delete A[f]; | |
} | |
try { | |
delete b.test; | |
} catch (o) { | |
c.support.deleteExpando = false; | |
} | |
a.removeChild(b); | |
if (d.attachEvent && d.fireEvent) { | |
d.attachEvent('onclick', k = function() { | |
c.support.noCloneEvent = false; | |
return d.detachEvent('onclick', k); | |
}); | |
d.cloneNode(true).fireEvent('onclick'); | |
} | |
d = s.createElement('div'); | |
d.innerHTML = "<input type='radio' name='radiotest' checked='checked'/>"; | |
a = s.createDocumentFragment(); | |
a.appendChild(d.firstChild); | |
c.support.checkClone = a.cloneNode(true).cloneNode(true).lastChild.checked; | |
c(function() { | |
k = s.createElement('div'); | |
k.style.width = k.style.paddingLeft = '1px'; | |
s.body.appendChild(k); | |
c.boxModel = c.support.boxModel = k.offsetWidth === 2; | |
return s.body.removeChild(k).style.display = 'none'; | |
}); | |
a = function(k) { | |
var n, r; | |
n = s.createElement('div'); | |
k = 'on' + k; | |
r = __indexOf.call(n, k) >= 0; | |
if (!r) { | |
n.setAttribute(k, 'return;'); | |
r = typeof n[k] === 'function'; | |
} | |
return r; | |
}; | |
c.support.submitBubbles = a('submit'); | |
c.support.changeBubbles = a('change'); | |
return a = b = d = e = j = null; | |
} | |
})(); | |
c.props = { | |
'for': 'htmlFor', | |
'class': 'className', | |
readonly: 'readOnly', | |
maxlength: 'maxLength', | |
cellspacing: 'cellSpacing', | |
rowspan: 'rowSpan', | |
colspan: 'colSpan', | |
tabindex: 'tabIndex', | |
usemap: 'useMap', | |
frameborder: 'frameBorder' | |
}; | |
G = 'jQuery' + J(); | |
Ya = 0; | |
za = {}; | |
c.extend({ | |
cache: {}, | |
expando: G, | |
noData: { | |
embed: true, | |
object: true, | |
applet: true | |
}, | |
data: function(a, b, d) { | |
var e, f; | |
if (!(a.nodeName && c.noData[a.nodeName.toLowerCase()])) { | |
a = (a === A ? za : a); | |
f = a[G]; | |
e = c.cache; | |
if (!f && typeof b === 'string' && d === w) { | |
return null; | |
} | |
f || (f = Ya++); | |
if (typeof b === 'object') { | |
a[G] = f; | |
e[f] = c.extend(true, {}, b); | |
} else if (!e[f]) { | |
a[G] = f; | |
e[f] = {}; | |
} | |
a = e[f]; | |
if (d !== w) { | |
a[b] = d; | |
} | |
if (typeof b === 'string') { | |
return a[b]; | |
} else { | |
return a; | |
} | |
} | |
}, | |
removeData: function(a, b) { | |
var d, e, f; | |
if (!(a.nodeName && c.noData[a.nodeName.toLowerCase()])) { | |
a = (a === A ? za : a); | |
d = a[G]; | |
f = c.cache; | |
e = f[d]; | |
if (b) { | |
if (e) { | |
delete e[b]; | |
c.isEmptyObject(e) && c.removeData(a); | |
} | |
} else if (c.support.deleteExpando) { | |
delete a[c.expando]; | |
} else { | |
a.removeAttribute && a.removeAttribute(c.expando); | |
} | |
return delete f[d]; | |
} | |
} | |
}); | |
c.fn.extend({ | |
data: function(a, b) { | |
var d, f; | |
if (typeof a === 'undefined' && this.length) { | |
return c.data(this[0]); | |
} else if (typeof a === 'object') { | |
return this.each(function() { | |
return c.data(this, a); | |
}); | |
} | |
d = a.split('.'); | |
d[1] = (d[1] ? '.' + d[1] : ''); | |
if (b === w) { | |
f = this.triggerHandler('getData' + d[1] + '!', [d[0]]); | |
if (f === w && this.length) { | |
f = c.data(this[0], a); | |
} | |
if (f === w && d[1]) { | |
return this.data(d[0]); | |
} else { | |
return f; | |
} | |
} else { | |
return this.trigger('setData' + d[1] + '!', [d[0], b]).each(function() { | |
return c.data(this, a, b); | |
}); | |
} | |
}, | |
removeData: function(a) { | |
return this.each(function() { | |
return c.removeData(this, a); | |
}); | |
} | |
}); | |
c.extend({ | |
queue: function(a, b, d) { | |
var f; | |
if (a) { | |
b = (b || 'fx') + 'queue'; | |
f = c.data(a, b); | |
if (!d) { | |
return f || []; | |
} | |
if (!f || c.isArray(d)) { | |
f = c.data(a, b, c.makeArray(d)); | |
} else { | |
f.push(d); | |
} | |
return f; | |
} | |
}, | |
dequeue: function(a, b) { | |
var d, f; | |
b = b || 'fx'; | |
d = c.queue(a, b); | |
f = d.shift(); | |
if (f === 'inprogress') { | |
f = d.shift(); | |
} | |
if (f) { | |
b === 'fx' && d.unshift('inprogress'); | |
return f.call(a, function() { | |
return c.dequeue(a, b); | |
}); | |
} | |
} | |
}); | |
c.fn.extend({ | |
queue: function(a, b) { | |
if (typeof a !== 'string') { | |
b = a; | |
a = 'fx'; | |
} | |
if (b === w) { | |
return c.queue(this[0], a); | |
} | |
return this.each(function() { | |
var d; | |
d = c.queue(this, a, b); | |
return a === 'fx' && d[0] !== 'inprogress' && c.dequeue(this, a); | |
}); | |
}, | |
dequeue: function(a) { | |
return this.each(function() { | |
return 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; | |
d = this; | |
return setTimeout(function() { | |
return c.dequeue(d, b); | |
}, a); | |
}); | |
}, | |
clearQueue: function(a) { | |
return this.queue(a || 'fx', []); | |
} | |
}); | |
Aa = /[\n\t]/g; | |
ca = /\s+/; | |
Za = /\r/g; | |
$a = /href|src|style/; | |
ab = /(button|input)/i; | |
bb = /(button|input|object|select|textarea)/i; | |
cb = /^(a|area)$/i; | |
Ba = /radio|checkbox/; | |
c.fn.extend({ | |
attr: function(a, b) { | |
return X(this, a, b, true, c.attr); | |
}, | |
removeAttr: function(a) { | |
return this.each(function() { | |
c.attr(this, a, ''); | |
return this.nodeType === 1 && this.removeAttribute(a); | |
}); | |
}, | |
addClass: function(a) { | |
var b, d, e, f, i, j, k, o; | |
if (c.isFunction(a)) { | |
return this.each(function(n) { | |
var r; | |
r = c(this); | |
return r.addClass(a.call(this, n, r.attr('class'))); | |
}); | |
} | |
if (a && typeof a === 'string') { | |
b = (a || '').split(ca); | |
d = 0; | |
f = this.length; | |
while (d < f) { | |
e = this[d]; | |
if (e.nodeType === 1) { | |
if (e.className) { | |
j = ' ' + e.className + ' '; | |
i = e.className; | |
o = 0; | |
k = b.length; | |
while (o < k) { | |
if (j.indexOf(' ' + b[o] + ' ') < 0) { | |
i = ' ' + b[o]; | |
} | |
o++; | |
} | |
e.className = c.trim(i); | |
} else { | |
e.className = a; | |
} | |
} | |
d++; | |
} | |
} | |
return this; | |
}, | |
removeClass: function(a) { | |
var b, d, e, f, i, j, o; | |
if (c.isFunction(a)) { | |
return this.each(function(k) { | |
var n; | |
n = c(this); | |
return n.removeClass(a.call(this, k, n.attr('class'))); | |
}); | |
} | |
if (a && typeof a === 'string' || a === w) { | |
b = (a || '').split(ca); | |
d = 0; | |
f = this.length; | |
while (d < f) { | |
e = this[d]; | |
if (e.nodeType === 1 && e.className) { | |
if (a) { | |
j = (' ' + e.className + ' ').replace(Aa, ' '); | |
i = 0; | |
o = b.length; | |
while (i < o) { | |
j = j.replace(' ' + b[i] + ' ', ' '); | |
i++; | |
} | |
e.className = c.trim(j); | |
} else { | |
e.className = ''; | |
} | |
} | |
d++; | |
} | |
} | |
return this; | |
}, | |
toggleClass: function(a, b) { | |
var d, f; | |
d = typeof a; | |
f = typeof b === 'boolean'; | |
if (c.isFunction(a)) { | |
return this.each(function(e) { | |
var j; | |
j = c(this); | |
return j.toggleClass(a.call(this, e, j.attr('class'), b), b); | |
}); | |
} | |
return this.each(function() { | |
var e, i, j, k, o, _results; | |
if (d === 'string') { | |
j = 0; | |
i = c(this); | |
o = b; | |
k = a.split(ca); | |
_results = []; | |
while (e = k[j++]) { | |
o = (f ? o : !i.hasClass(e)); | |
_results.push(i[(o ? 'addClass' : 'removeClass')](e)); | |
} | |
return _results; | |
} else if (d === 'undefined' || d === 'boolean') { | |
this.className && c.data(this, '__className__', this.className); | |
return this.className = (this.className || a === false ? '' : c.data(this, '__className__') || ''); | |
} | |
}); | |
}, | |
hasClass: function(a) { | |
var b, d; | |
a = ' ' + a + ' '; | |
b = 0; | |
d = this.length; | |
while (b < d) { | |
if ((' ' + this[b].className + ' ').replace(Aa, ' ').indexOf(a) > -1) { | |
return true; | |
} | |
b++; | |
} | |
return false; | |
}, | |
val: function(a) { | |
var b, d, e, f, i, j, o; | |
if (a === w) { | |
b = this[0]; | |
if (b) { | |
if (c.nodeName(b, 'option')) { | |
if ((b.attributes.value || {}).specified) { | |
return b.value; | |
} else { | |
return b.text; | |
} | |
} | |
if (c.nodeName(b, 'select')) { | |
d = b.selectedIndex; | |
f = []; | |
e = b.options; | |
b = b.type === 'select-one'; | |
if (d < 0) { | |
return null; | |
} | |
j = (b ? d : 0); | |
d = (b ? d + 1 : e.length); | |
while (j < d) { | |
i = e[j]; | |
if (i.selected) { | |
a = c(i).val(); | |
if (b) { | |
return a; | |
} | |
f.push(a); | |
} | |
j++; | |
} | |
return f; | |
} | |
if (Ba.test(b.type) && !c.support.checkOn) { | |
if (b.getAttribute('value') === null) { | |
return 'on'; | |
} else { | |
return b.value; | |
} | |
} | |
return (b.value || '').replace(Za, ''); | |
} | |
return w; | |
} | |
o = c.isFunction(a); | |
return this.each(function(k) { | |
var n, r, u; | |
n = c(this); | |
r = a; | |
if (this.nodeType === 1) { | |
if (o) { | |
r = a.call(this, k, n.val()); | |
} | |
if (typeof r === 'number') { | |
r = ''; | |
} | |
if (c.isArray(r) && Ba.test(this.type)) { | |
return this.checked = c.inArray(n.val(), r) >= 0; | |
} else if (c.nodeName(this, 'select')) { | |
u = c.makeArray(r); | |
c('option', this).each(function() { | |
return this.selected = c.inArray(c(this).val(), u) >= 0; | |
}); | |
if (!u.length) { | |
return this.selectedIndex = -1; | |
} | |
} else { | |
return 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, f) { | |
var e, j; | |
if (!a || a.nodeType === 3 || a.nodeType === 8) { | |
return w; | |
} | |
if (f && __indexOf.call(c.attrFn, b) >= 0) { | |
return c(a)[b](d); | |
} | |
f = a.nodeType !== 1 || !c.isXMLDoc(a); | |
e = d !== w; | |
b = f && c.props[b] || b; | |
if (a.nodeType === 1) { | |
j = $a.test(b); | |
if (__indexOf.call(a, b) >= 0 && f && !j) { | |
if (e) { | |
b === 'type' && ab.test(a.nodeName) && a.parentNode && c.error("type property can't be changed"); | |
a[b] = d; | |
} | |
if (c.nodeName(a, 'form') && a.getAttributeNode(b)) { | |
return a.getAttributeNode(b).nodeValue; | |
} | |
if (b === 'tabIndex') { | |
if ((b = a.getAttributeNode('tabIndex')) && b.specified) { | |
return b.value; | |
} else { | |
if (bb.test(a.nodeName) || cb.test(a.nodeName) && a.href) { | |
return 0; | |
} else { | |
return w; | |
} | |
} | |
} | |
return a[b]; | |
} | |
if (!c.support.style && f && b === 'style') { | |
if (e) { | |
a.style.cssText = '' + d; | |
} | |
return a.style.cssText; | |
} | |
e && a.setAttribute(b, '' + d); | |
a = (!c.support.hrefNormalized && f && j ? a.getAttribute(b, 2) : a.getAttribute(b)); | |
if (a === null) { | |
return w; | |
} else { | |
return a; | |
} | |
} | |
return c.style(a, b, d); | |
} | |
}); | |
O = /\.(.*)$/; | |
db = function(a) { | |
return a.replace(/[^\w\s\.\|`]/g, function(b) { | |
return '\\' + b; | |
}); | |
}; | |
c.event = { | |
add: function(a, b, d, f) { | |
var e, i, j, k, n, o, r, u, z; | |
if (!(a.nodeType === 3 || a.nodeType === 8)) { | |
if (a.setInterval && a !== A && !a.frameElement) { | |
a = A; | |
} | |
if (d.handler) { | |
e = d; | |
d = e.handler; | |
} | |
if (!d.guid) { | |
d.guid = c.guid++; | |
} | |
if (j = c.data(a)) { | |
i = j.events = j.events || {}; | |
o = j.handle; | |
if (!o) { | |
j.handle = o = function() { | |
if (typeof c !== 'undefined' && !c.event.triggered) { | |
return c.event.handle.apply(o.elem, arguments); | |
} else { | |
return w; | |
} | |
}; | |
} | |
o.elem = a; | |
b = b.split(' '); | |
n = 0; | |
while (k = b[n++]) { | |
j = (e ? c.extend({}, e) : { | |
handler: d, | |
data: f | |
}); | |
if (k.indexOf('.') > -1) { | |
r = k.split('.'); | |
k = r.shift(); | |
j.namespace = r.slice(0).sort().join('.'); | |
} else { | |
r = []; | |
} | |
j.namespace = ''; | |
j.type = k; | |
j.guid = d.guid; | |
u = i[k]; | |
z = c.event.special[k] || {}; | |
if (!u) { | |
u = i[k] = []; | |
if (!z.setup || z.setup.call(a, f, r, o) === false) { | |
if (a.addEventListener) { | |
a.addEventListener(k, o, false); | |
} else { | |
a.attachEvent && a.attachEvent('on' + k, o); | |
} | |
} | |
} | |
if (z.add) { | |
z.add.call(a, j); | |
if (!j.handler.guid) { | |
j.handler.guid = d.guid; | |
} | |
} | |
u.push(j); | |
c.event.global[k] = true; | |
} | |
return a = null; | |
} | |
} | |
}, | |
global: {}, | |
remove: function(a, b, d, f) { | |
var B, C, e, i, j, k, n, o, r, u, z; | |
if (!(a.nodeType === 3 || a.nodeType === 8)) { | |
j = 0; | |
z = c.data(a); | |
C = z && z.events; | |
if (z && C) { | |
if (b && b.type) { | |
d = b.handler; | |
b = b.type; | |
} | |
if (!b || typeof b === 'string' && b.charAt(0) === '.') { | |
b = b || ''; | |
for (e in C) { | |
c.event.remove(a, e + b); | |
} | |
} else { | |
b = b.split(' '); | |
} | |
while (e = b[j++]) { | |
n = e; | |
i = e.indexOf('.') < 0; | |
o = []; | |
if (!i) { | |
o = e.split('.'); | |
e = o.shift(); | |
k = new RegExp('(^|\\.)' + c.map(o.slice(0).sort(), db).join('\\.(?:.*\\.)?') + '(\\.|$)'); | |
} | |
if (r = C[e]) { | |
if (d) { | |
n = c.event.special[e] || {}; | |
B = f || 0; | |
while (B < r.length) { | |
u = r[B]; | |
if (d.guid === u.guid) { | |
if (i || k.test(u.namespace)) { | |
f === null && r.splice(B--, 1); | |
n.remove && n.remove.call(a, u); | |
} | |
if (f !== null) { | |
break; | |
} | |
} | |
B++; | |
} | |
if (r.length === 0 || f !== null && r.length === 1) { | |
if (!n.teardown || n.teardown.call(a, o) === false) { | |
Ca(a, e, z.handle); | |
} | |
delete C[e]; | |
} | |
} else { | |
B = 0; | |
} | |
while (B < r.length) { | |
u = r[B]; | |
if (i || k.test(u.namespace)) { | |
c.event.remove(a, n, u.handler, B); | |
r.splice(B--, 1); | |
} | |
B++; | |
} | |
} | |
} | |
if (c.isEmptyObject(C)) { | |
if (b = z.handle) { | |
b.elem = null; | |
} | |
delete z.events; | |
delete z.handle; | |
return c.isEmptyObject(z) && c.removeData(a); | |
} | |
} | |
} | |
}, | |
trigger: function(a, b, d, f) { | |
var e, i, k, o; | |
e = a.type || a; | |
if (!f) { | |
a = (typeof a === 'object' ? a[G] : (a ? c.extend(c.Event(e), a) : c.Event(e))); | |
if (e.indexOf('!') >= 0) { | |
a.type = e = e.slice(0, -1); | |
a.exclusive = true; | |
} | |
if (!d) { | |
a.stopPropagation(); | |
c.event.global[e] && c.each(c.cache, function() { | |
return this.events && this.events[e] && c.event.trigger(a, b, this.handle.elem); | |
}); | |
} | |
if (!d || d.nodeType === 3 || d.nodeType === 8) { | |
return w; | |
} | |
a.result = w; | |
a.target = d; | |
b = c.makeArray(b); | |
b.unshift(a); | |
} | |
a.currentTarget = d; | |
(f = c.data(d, 'handle')) && f.apply(d, b); | |
f = d.parentNode || d.ownerDocument; | |
try { | |
if (!(d && d.nodeName && c.noData[d.nodeName.toLowerCase()]) ? d['on' + e] && d['on' + e].apply(d, b) === false : void 0) { | |
a.result = false; | |
} | |
} catch (j) { | |
} | |
if (!a.isPropagationStopped() && f) { | |
return c.event.trigger(a, b, f, true); | |
} else if (!a.isDefaultPrevented()) { | |
f = a.target; | |
o = c.nodeName(f, 'a') && e === 'click'; | |
k = c.event.special[e] || {}; | |
if ((!k._default || k._default.call(d, a) === false) && !o && !(f && f.nodeName && c.noData[f.nodeName.toLowerCase()])) { | |
try { | |
if (f[e]) { | |
if (i = f['on' + e]) { | |
f['on' + e] = null; | |
} | |
c.event.triggered = true; | |
f[e](); | |
} | |
} catch (n) { | |
} | |
if (i) { | |
f['on' + e] = i; | |
} | |
return c.event.triggered = false; | |
} | |
} | |
}, | |
handle: function(a) { | |
var b, d, e, f, i, j; | |
a = arguments[0] = c.event.fix(a || A.event); | |
a.currentTarget = this; | |
b = a.type.indexOf('.') < 0 && !a.exclusive; | |
if (!b) { | |
d = a.type.split('.'); | |
a.type = d.shift(); | |
f = new RegExp('(^|\\.)' + d.slice(0).sort().join('\\.(?:.*\\.)?') + '(\\.|$)'); | |
} | |
e = c.data(this, 'events'); | |
d = e[a.type]; | |
if (e && d) { | |
d = d.slice(0); | |
e = 0; | |
j = d.length; | |
while (e < j) { | |
i = d[e]; | |
if (b || f.test(i.namespace)) { | |
a.handler = i.handler; | |
a.data = i.data; | |
a.handleObj = i; | |
i = i.handler.apply(this, arguments); | |
if (i !== w) { | |
a.result = i; | |
if (i === false) { | |
a.preventDefault(); | |
a.stopPropagation(); | |
} | |
} | |
if (a.isImmediatePropagationStopped()) { | |
break; | |
} | |
} | |
e++; | |
} | |
} | |
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 originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which'.split(' '), | |
fix: function(a) { | |
var b, d, f; | |
if (a[G]) { | |
return a; | |
} | |
b = a; | |
a = c.Event(b); | |
d = this.props.length; | |
while (d) { | |
f = this.props[d--]; | |
a[f] = b[f]; | |
} | |
if (!a.target) { | |
a.target = a.srcElement || s; | |
} | |
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 = s.documentElement; | |
d = s.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 && (a.charCode || a.charCode === 0 ? a.charCode : a.keyCode)) { | |
a.which = a.charCode || a.keyCode; | |
} | |
if (!a.metaKey && a.ctrlKey) { | |
a.metaKey = a.ctrlKey; | |
} | |
if (!a.which && a.button !== w) { | |
a.which = (a.button & 1 ? 1 : (a.button & 2 ? 3 : (a.button & 4 ? 2 : 0))); | |
} | |
return a; | |
}, | |
guid: 100000000.0, | |
proxy: c.proxy, | |
special: { | |
ready: { | |
setup: c.bindReady, | |
teardown: c.noop | |
}, | |
live: { | |
add: function(a) { | |
return c.event.add(this, a.origType, c.extend({}, a, { | |
handler: oa | |
})); | |
}, | |
remove: function(a) { | |
var b, d; | |
b = true; | |
d = a.origType.replace(O, ''); | |
c.each(c.data(this, 'events').live || [], function() { | |
if (d === this.origType.replace(O, '')) { | |
return b = false; | |
} | |
}); | |
return b && c.event.remove(this, a.origType, oa); | |
} | |
}, | |
beforeunload: { | |
setup: function(a, b, d) { | |
if (this.setInterval) { | |
this.onbeforeunload = d; | |
} | |
return false; | |
}, | |
teardown: function(a, b) { | |
if (this.onbeforeunload === b) { | |
return this.onbeforeunload = null; | |
} | |
} | |
} | |
} | |
}; | |
Ca = (s.removeEventListener ? function(a, b, d) { | |
return a.removeEventListener(b, d, false); | |
} : function(a, b, d) { | |
return 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 = J(); | |
return this[G] = true; | |
}; | |
c.Event.prototype = { | |
preventDefault: function() { | |
var a; | |
this.isDefaultPrevented = Z; | |
a = this.originalEvent; | |
if (a) { | |
a.preventDefault && a.preventDefault(); | |
return a.returnValue = false; | |
} | |
}, | |
stopPropagation: function() { | |
var a; | |
this.isPropagationStopped = Z; | |
a = this.originalEvent; | |
if (a) { | |
a.stopPropagation && a.stopPropagation(); | |
return a.cancelBubble = true; | |
} | |
}, | |
stopImmediatePropagation: function() { | |
this.isImmediatePropagationStopped = Z; | |
return this.stopPropagation(); | |
}, | |
isDefaultPrevented: Y, | |
isPropagationStopped: Y, | |
isImmediatePropagationStopped: Y | |
}; | |
Da = function(a) { | |
var b; | |
b = a.relatedTarget; | |
try { | |
while (b && b !== this) { | |
b = b.parentNode; | |
} | |
if (b !== this) { | |
a.type = a.data; | |
return c.event.handle.apply(this, arguments); | |
} | |
} catch (d) { | |
} | |
}; | |
Ea = function(a) { | |
a.type = a.data; | |
return c.event.handle.apply(this, arguments); | |
}; | |
c.each({ | |
mouseenter: 'mouseover', | |
mouseleave: 'mouseout' | |
}, function(a, b) { | |
return c.event.special[a] = { | |
setup: function(d) { | |
return c.event.add(this, b, (d && d.selector ? Ea : Da), a); | |
}, | |
teardown: function(d) { | |
return c.event.remove(this, b, (d && d.selector ? Ea : Da)); | |
} | |
}; | |
}); | |
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, d; | |
b = a.target; | |
d = b.type; | |
if ((d === 'submit' || d === 'image') && c(b).closest('form').length) { | |
return na('submit', this, arguments); | |
} | |
}); | |
return c.event.add(this, 'keypress.specialSubmit', function(a) { | |
var b, d; | |
b = a.target; | |
d = b.type; | |
if ((d === 'text' || d === 'password') && c(b).closest('form').length && a.keyCode === 13) { | |
return na('submit', this, arguments); | |
} | |
}); | |
} else { | |
return false; | |
} | |
}, | |
teardown: function() { | |
return c.event.remove(this, '.specialSubmit'); | |
} | |
}; | |
} | |
if (!c.support.changeBubbles) { | |
da = /textarea|input|select/i; | |
Fa = function(a) { | |
var b, d; | |
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(f) { | |
return f.selected; | |
}).join('-') : ''); | |
} else { | |
if (a.nodeName.toLowerCase() === 'select') { | |
d = a.selectedIndex; | |
} | |
} | |
return d; | |
}; | |
fa = function(a, b) { | |
var d, e, f; | |
d = a.target; | |
if (!(!da.test(d.nodeName) || d.readOnly)) { | |
f = c.data(d, '_change_data'); | |
e = Fa(d); | |
if (a.type !== 'focusout' || d.type !== 'radio') { | |
c.data(d, '_change_data', e); | |
} | |
if (!(f === w || e === f)) { | |
if (f !== null || e) { | |
a.type = 'change'; | |
return c.event.trigger(a, b, d); | |
} | |
} | |
} | |
}; | |
c.event.special.change = { | |
filters: { | |
focusout: fa, | |
click: function(a) { | |
var b, d; | |
b = a.target; | |
d = b.type; | |
if (d === 'radio' || d === 'checkbox' || b.nodeName.toLowerCase() === 'select') { | |
return fa.call(this, a); | |
} | |
}, | |
keydown: function(a) { | |
var b, d; | |
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 fa.call(this, a); | |
} | |
}, | |
beforeactivate: function(a) { | |
a = a.target; | |
return c.data(a, '_change_data', Fa(a)); | |
} | |
}, | |
setup: function() { | |
var a; | |
if (this.type === 'file') { | |
return false; | |
} | |
for (a in ea) { | |
c.event.add(this, a + '.specialChange', ea[a]); | |
} | |
return da.test(this.nodeName); | |
}, | |
teardown: function() { | |
c.event.remove(this, '.specialChange'); | |
return da.test(this.nodeName); | |
} | |
}; | |
ea = c.event.special.change.filters; | |
} | |
s.addEventListener && c.each({ | |
focus: 'focusin', | |
blur: 'focusout' | |
}, function(a, b) { | |
var d; | |
d = function(f) { | |
f = c.event.fix(f); | |
f.type = b; | |
return c.event.handle.call(this, f); | |
}; | |
return c.event.special[b] = { | |
setup: function() { | |
return this.addEventListener(a, d, true); | |
}, | |
teardown: function() { | |
return this.removeEventListener(a, d, true); | |
} | |
}; | |
}); | |
c.each(['bind', 'one'], function(a, b) { | |
return c.fn[b] = function(d, f, e) { | |
var i, j, o; | |
if (typeof d === 'object') { | |
for (j in d) { | |
this[b](j, f, d[j], e); | |
} | |
return this; | |
} | |
if (c.isFunction(f)) { | |
e = f; | |
f = w; | |
} | |
i = (b === 'one' ? c.proxy(e, function(k) { | |
c(this).unbind(k, i); | |
return e.apply(this, arguments); | |
}) : e); | |
if (d === 'unload' && b !== 'one') { | |
this.one(d, f, e); | |
} else { | |
j = 0; | |
} | |
o = this.length; | |
while (j < o) { | |
c.event.add(this[j], d, i, f); | |
j++; | |
} | |
return this; | |
}; | |
}); | |
c.fn.extend({ | |
unbind: function(a, b) { | |
var d, f; | |
if (typeof a === 'object' && !a.preventDefault) { | |
for (d in a) { | |
this.unbind(d, a[d]); | |
} | |
} else { | |
d = 0; | |
} | |
f = this.length; | |
while (d < f) { | |
c.event.remove(this[d], a, b); | |
d++; | |
} | |
return this; | |
}, | |
delegate: function(a, b, d, f) { | |
return this.live(b, d, f, a); | |
}, | |
undelegate: function(a, b, d) { | |
if (arguments.length === 0) { | |
return this.unbind('live'); | |
} else { | |
return this.die(b, null, d, a); | |
} | |
}, | |
trigger: function(a, b) { | |
return this.each(function() { | |
return c.event.trigger(a, b, this); | |
}); | |
}, | |
triggerHandler: function(a, b) { | |
if (this[0]) { | |
a = c.Event(a); | |
a.preventDefault(); | |
a.stopPropagation(); | |
c.event.trigger(a, b, this[0]); | |
return a.result; | |
} | |
}, | |
toggle: function(a) { | |
var b, d; | |
b = arguments; | |
d = 1; | |
while (d < b.length) { | |
c.proxy(a, b[d++]); | |
} | |
return this.click(c.proxy(a, function(f) { | |
var e; | |
e = (c.data(this, 'lastToggle' + a.guid) || 0) % d; | |
c.data(this, 'lastToggle' + a.guid, e + 1); | |
f.preventDefault(); | |
return b[e].apply(this, arguments) || false; | |
})); | |
}, | |
hover: function(a, b) { | |
return this.mouseenter(a).mouseleave(b || a); | |
} | |
}); | |
Ga = { | |
focus: 'focusin', | |
blur: 'focusout', | |
mouseenter: 'mouseover', | |
mouseleave: 'mouseout' | |
}; | |
c.each(['live', 'die'], function(a, b) { | |
return c.fn[b] = function(d, f, e, j) { | |
var i, k, n, o, r, u; | |
o = 0; | |
r = j || this.selector; | |
u = (j ? this : c(this.context)); | |
if (c.isFunction(f)) { | |
e = f; | |
f = w; | |
} | |
d = (d || '').split(' '); | |
while ((i = d[o++]) !== null) { | |
j = O.exec(i); | |
k = ''; | |
if (j) { | |
k = j[0]; | |
i = i.replace(O, ''); | |
} | |
if (i === 'hover') { | |
d.push('mouseenter' + k, 'mouseleave' + k); | |
} else { | |
n = i; | |
} | |
if (i === 'focus' || i === 'blur') { | |
d.push(Ga[i] + k); | |
i = k; | |
} else { | |
i = (Ga[i] || i) + k; | |
} | |
if (b === 'live') { | |
u.each(function() { | |
return c.event.add(this, pa(i, r), { | |
data: f, | |
selector: r, | |
handler: e, | |
origType: i, | |
origHandler: e, | |
preType: n | |
}); | |
}); | |
} else { | |
u.unbind(pa(i, r), e); | |
} | |
} | |
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) { | |
if (d) { | |
return this.bind(b, d); | |
} else { | |
return this.trigger(b); | |
} | |
}; | |
if (c.attrFn) { | |
return c.attrFn[b] = true; | |
} | |
}); | |
A.attachEvent && !A.addEventListener && A.attachEvent('onunload', function() { | |
var a, _results; | |
_results = []; | |
for (a in c.cache) { | |
_results.push((function() { | |
if (c.cache[a].handle) { | |
try { | |
return c.event.remove(c.cache[a].handle.elem); | |
} catch (b) { | |
} | |
} | |
})()); | |
} | |
return _results; | |
}); | |
(function() { | |
var B, E, a, b, d, e, f, ga, i, j, k, n, o, r, u, x, z; | |
a = function(g) { | |
var h, l, m; | |
h = ''; | |
m = 0; | |
while (g[m]) { | |
l = g[m]; | |
if (l.nodeType === 3 || l.nodeType === 4) { | |
h = l.nodeValue; | |
} else { | |
if (l.nodeType !== 8) { | |
h = a(l.childNodes); | |
} | |
} | |
m++; | |
} | |
return h; | |
}; | |
b = function(g, h, l, m, q, p) { | |
var t, v, y, _results; | |
q = 0; | |
v = m.length; | |
_results = []; | |
while (q < v) { | |
t = m[q]; | |
if (t) { | |
t = t[g]; | |
y = false; | |
while (t) { | |
if (t.sizcache === l) { | |
y = m[t.sizset]; | |
break; | |
} | |
if (t.nodeType === 1 && !p) { | |
t.sizcache = l; | |
t.sizset = q; | |
} | |
if (t.nodeName.toLowerCase() === h) { | |
y = t; | |
break; | |
} | |
t = t[g]; | |
} | |
m[q] = y; | |
} | |
_results.push(q++); | |
} | |
return _results; | |
}; | |
d = function(g, h, l, m, q, p) { | |
var t, v, y, _results; | |
q = 0; | |
v = m.length; | |
_results = []; | |
while (q < v) { | |
t = m[q]; | |
if (t) { | |
t = t[g]; | |
y = false; | |
while (t) { | |
if (t.sizcache === l) { | |
y = m[t.sizset]; | |
break; | |
} | |
if (t.nodeType === 1) { | |
if (!p) { | |
t.sizcache = l; | |
t.sizset = q; | |
} | |
if (typeof h !== 'string') { | |
if (t === h) { | |
y = true; | |
break; | |
} | |
} else if (k.filter(h, [t]).length > 0) { | |
y = t; | |
break; | |
} | |
} | |
t = t[g]; | |
} | |
m[q] = y; | |
} | |
_results.push(q++); | |
} | |
return _results; | |
}; | |
f = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g; | |
e = 0; | |
j = Object.prototype.toString; | |
i = false; | |
o = true; | |
[0, 0].sort(function() { | |
o = false; | |
return 0; | |
}); | |
k = function(g, h, l, m) { | |
var D, H, I, M, S, p, q, t, v, y; | |
l = l || []; | |
q = h = h || s; | |
if (h.nodeType !== 1 && h.nodeType !== 9) { | |
return []; | |
} | |
if (!g || typeof g !== 'string') { | |
return l; | |
} | |
p = []; | |
H = true; | |
M = x(h); | |
I = g; | |
while ((f.exec(''), v = f.exec(I)) !== null) { | |
I = v[3]; | |
p.push(v[1]); | |
if (v[2]) { | |
S = v[3]; | |
break; | |
} | |
} | |
if (p.length > 1 && r.exec(g)) { | |
if (p.length === 2 && n.relative[p[0]]) { | |
t = ga(p[0] + p[1], h); | |
} else { | |
t = (n.relative[p[0]] ? [h] : k(p.shift(), h)); | |
} | |
while (p.length) { | |
g = p.shift(); | |
if (n.relative[g]) { | |
g = p.shift(); | |
} | |
t = ga(g, t); | |
} | |
} else if (!m && p.length > 1 && h.nodeType === 9 && !M && n.match.ID.test(p[0]) && !n.match.ID.test(p[p.length - 1])) { | |
v = k.find(p.shift(), h, M); | |
h = (v.expr ? k.filter(v.expr, v.set)[0] : v.set[0]); | |
} | |
if (h) { | |
v = (m ? { | |
expr: p.pop(), | |
set: z(m) | |
} : k.find(p.pop(), (p.length === 1 && (p[0] === '~' || p[0] === '+') && h.parentNode ? h.parentNode : h), M)); | |
t = (v.expr ? k.filter(v.expr, v.set) : v.set); | |
if (p.length > 0) { | |
y = z(t); | |
} else { | |
H = false; | |
} | |
while (p.length) { | |
D = p.pop(); | |
v = D; | |
if (n.relative[D]) { | |
v = p.pop(); | |
} else { | |
D = ''; | |
} | |
if (v === null) { | |
v = h; | |
} | |
n.relative[D](y, v, M); | |
} | |
} else { | |
y = []; | |
} | |
y || (y = t); | |
y || k.error(D || g); | |
if (j.call(y) === '[object Array]') { | |
if (H) { | |
if (h && h.nodeType === 1) { | |
g = 0; | |
while (y[g] !== null) { | |
if (y[g] && (y[g] === true || y[g].nodeType === 1 && E(h, y[g]))) { | |
l.push(t[g]); | |
} | |
g++; | |
} | |
} else { | |
g = 0; | |
} | |
while (y[g] !== null) { | |
y[g] && y[g].nodeType === 1 && l.push(t[g]); | |
g++; | |
} | |
} else { | |
l.push.apply(l, y); | |
} | |
} else { | |
z(y, l); | |
} | |
if (S) { | |
k(S, q, l, m); | |
k.uniqueSort(l); | |
} | |
return l; | |
}; | |
k.uniqueSort = function(g) { | |
var h; | |
if (B) { | |
i = o; | |
g.sort(B); | |
if (i) { | |
h = 1; | |
while (h < g.length) { | |
g[h] === g[h - 1] && g.splice(h--, 1); | |
h++; | |
} | |
} | |
} | |
return g; | |
}; | |
k.matches = function(g, h) { | |
return k(g, null, null, h); | |
}; | |
k.find = function(g, h, l) { | |
var m, p, q, t, v, y; | |
if (!g) { | |
return []; | |
} | |
p = 0; | |
v = n.order.length; | |
while (p < v) { | |
t = n.order[p]; | |
if (q = n.leftMatch[t].exec(g)) { | |
y = q[1]; | |
q.splice(1, 1); | |
if (y.substr(y.length - 1) !== '\\') { | |
q[1] = (q[1] || '').replace(/\\/g, ''); | |
m = n.find[t](q, h, l); | |
if (m !== null) { | |
g = g.replace(n.match[t], ''); | |
break; | |
} | |
} | |
} | |
p++; | |
} | |
m || (m = h.getElementsByTagName('*')); | |
return { | |
set: m, | |
expr: g | |
}; | |
}; | |
k.filter = function(g, h, l, m) { | |
var D, H, Ha, I, M, S, U, p, q, t, v, y; | |
q = g; | |
p = []; | |
v = h; | |
S = h && h[0] && x(h[0]); | |
while (g && h.length) { | |
for (H in n.filter) { | |
if ((t = n.leftMatch[H].exec(g)) !== null && t[2]) { | |
M = n.filter[H]; | |
D = t[1]; | |
y = false; | |
t.splice(1, 1); | |
if (D.substr(D.length - 1) !== '\\') { | |
if (v === p) { | |
p = []; | |
} | |
if (n.preFilter[H]) { | |
if (t = n.preFilter[H](t, v, l, p, m, S)) { | |
if (t === true) { | |
continue; | |
} | |
} else { | |
y = I = true; | |
} | |
} | |
if (t) { | |
U = 0; | |
while ((D = v[U]) !== null) { | |
if (D) { | |
I = M(D, t, U, v); | |
Ha = m ^ !!I; | |
if (l && I !== null) { | |
if (Ha) { | |
y = true; | |
} else { | |
v[U] = false; | |
} | |
} else if (Ha) { | |
p.push(D); | |
y = true; | |
} | |
} | |
U++; | |
} | |
} | |
if (I !== w) { | |
l || (v = p); | |
g = g.replace(n.match[H], ''); | |
if (!y) { | |
return []; | |
} | |
break; | |
} | |
} | |
} | |
} | |
if (g === q) { | |
if (y === null) { | |
k.error(g); | |
} else { | |
break; | |
} | |
} | |
q = g; | |
} | |
return v; | |
}; | |
k.error = function(g) { | |
throw 'Syntax error, unrecognized expression: ' + g; | |
}; | |
n = 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, h) { | |
var l, m, p, q; | |
l = typeof h === 'string'; | |
m = l && !/\W/.test(h); | |
l = l && !m; | |
if (m) { | |
h = h.toLowerCase(); | |
} | |
m = 0; | |
q = g.length; | |
while (m < q) { | |
if (p = g[m]) { | |
while ((p = p.previousSibling) && p.nodeType !== 1) { | |
0; | |
} | |
g[m] = (l || p && p.nodeName.toLowerCase() === h ? p || false : p === h); | |
} | |
m++; | |
} | |
return l && k.filter(h, g, true); | |
}, | |
'>': function(g, h) { | |
var l, m, p, q; | |
l = typeof h === 'string'; | |
if (l && !/\W/.test(h)) { | |
h = h.toLowerCase(); | |
m = 0; | |
q = g.length; | |
while (m < q) { | |
p = g[m]; | |
if (p) { | |
l = p.parentNode; | |
g[m] = (l.nodeName.toLowerCase() === h ? l : false); | |
} | |
m++; | |
} | |
} else { | |
m = 0; | |
} | |
q = g.length; | |
while (m < q) { | |
if (p = g[m]) { | |
g[m] = (l ? p.parentNode : p.parentNode === h); | |
} | |
m++; | |
} | |
return l && k.filter(h, g, true); | |
}, | |
'': function(g, h, l) { | |
var m, p, q; | |
m = e++; | |
q = d; | |
if (typeof h === 'string' && !/\W/.test(h)) { | |
p = h = h.toLowerCase(); | |
q = b; | |
} | |
return q('parentNode', h, m, g, p, l); | |
}, | |
'~': function(g, h, l) { | |
var m, p, q; | |
m = e++; | |
q = d; | |
if (typeof h === 'string' && !/\W/.test(h)) { | |
p = h = h.toLowerCase(); | |
q = b; | |
} | |
return q('previousSibling', h, m, g, p, l); | |
} | |
}, | |
find: { | |
ID: function(g, h, l) { | |
if (typeof h.getElementById !== 'undefined' && !l) { | |
if ((g = h.getElementById(g[1]))) { | |
return [g]; | |
} else { | |
return []; | |
} | |
} | |
}, | |
NAME: function(g, h) { | |
var l, m, q; | |
if (typeof h.getElementsByName !== 'undefined') { | |
l = []; | |
h = h.getElementsByName(g[1]); | |
m = 0; | |
q = h.length; | |
while (m < q) { | |
h[m].getAttribute('name') === g[1] && l.push(h[m]); | |
m++; | |
} | |
if (l.length === 0) { | |
return null; | |
} else { | |
return l; | |
} | |
} | |
}, | |
TAG: function(g, h) { | |
return h.getElementsByTagName(g[1]); | |
} | |
}, | |
preFilter: { | |
CLASS: function(g, h, l, m, q, p) { | |
var v; | |
g = ' ' + g[1].replace(/\\/g, '') + ' '; | |
if (p) { | |
return g; | |
} | |
p = 0; | |
while ((v = h[p]) !== null) { | |
if (v) { | |
if (q ^ (v.className && (' ' + v.className + ' ').replace(/[\t\n]/g, ' ').indexOf(g) >= 0)) { | |
l || m.push(v); | |
} else { | |
if (l) { | |
h[p] = false; | |
} | |
} | |
} | |
p++; | |
} | |
return false; | |
}, | |
ID: function(g) { | |
return g[1].replace(/\\/g, ''); | |
}, | |
TAG: function(g) { | |
return g[1].toLowerCase(); | |
}, | |
CHILD: function(g) { | |
var h; | |
if (g[1] === 'nth') { | |
h = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2] === 'even' && '2n' || g[2] === 'odd' && '2n+1' || !/\D/.test(g[2]) && '0n+' + g[2] || g[2]); | |
g[2] = h[1] + (h[2] || 1) - 0; | |
g[3] = h[3] - 0; | |
} | |
g[0] = e++; | |
return g; | |
}, | |
ATTR: function(g, h, l, m, q, p) { | |
h = g[1].replace(/\\/g, ''); | |
if (!p && n.attrMap[h]) { | |
g[1] = n.attrMap[h]; | |
} | |
if (g[2] === '~=') { | |
g[4] = ' ' + g[4] + ' '; | |
} | |
return g; | |
}, | |
PSEUDO: function(g, h, l, m, q) { | |
if (g[1] === 'not') { | |
if ((f.exec(g[3]) || '').length > 1 || /^\w/.test(g[3])) { | |
g[3] = k(g[3], null, null, h); | |
} else { | |
g = k.filter(g[3], h, l, true ^ q); | |
} | |
l || m.push.apply(m, g); | |
return false; | |
} else { | |
if (n.match.POS.test(g[0]) || n.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, h, l) { | |
return !!k(l[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, h) { | |
return h === 0; | |
}, | |
last: function(g, h, l, m) { | |
return h === m.length - 1; | |
}, | |
even: function(g, h) { | |
return h % 2 === 0; | |
}, | |
odd: function(g, h) { | |
return h % 2 === 1; | |
}, | |
lt: function(g, h, l) { | |
return h < l[3] - 0; | |
}, | |
gt: function(g, h, l) { | |
return h > l[3] - 0; | |
}, | |
nth: function(g, h, l) { | |
return l[3] - 0 === h; | |
}, | |
eq: function(g, h, l) { | |
return l[3] - 0 === h; | |
} | |
}, | |
filter: { | |
PSEUDO: function(g, h, l, m) { | |
var p, q; | |
q = h[1]; | |
p = n.filters[q]; | |
if (p) { | |
return p(g, l, h, m); | |
} else if (q === 'contains') { | |
return (g.textContent || g.innerText || a([g]) || '').indexOf(h[3]) >= 0; | |
} else if (q === 'not') { | |
h = h[3]; | |
l = 0; | |
m = h.length; | |
while (l < m) { | |
if (h[l] === g) { | |
return false; | |
} | |
l++; | |
} | |
return true; | |
} else { | |
return k.error('Syntax error, unrecognized expression: ' + q); | |
} | |
}, | |
CHILD: function(g, h) { | |
var l, m, p, q, v; | |
l = h[1]; | |
m = g; | |
if ('only' === l) { | |
; | |
} else if ('first' === l) { | |
while (m = m.previousSibling) { | |
if (m.nodeType === 1) { | |
return false; | |
} | |
} | |
if (l === 'first') { | |
return true; | |
} | |
return m = g; | |
} else if ('last' === l) { | |
while (m = m.nextSibling) { | |
if (m.nodeType === 1) { | |
return false; | |
} | |
} | |
return true; | |
} else if ('nth' === l) { | |
l = h[2]; | |
q = h[3]; | |
if (l === 1 && q === 0) { | |
return true; | |
} | |
h = h[0]; | |
p = g.parentNode; | |
if (p && (p.sizcache !== h || !g.nodeIndex)) { | |
v = 0; | |
m = p.firstChild; | |
while (m) { | |
if (m.nodeType === 1) { | |
m.nodeIndex = v++; | |
} | |
m = m.nextSibling; | |
} | |
p.sizcache = h; | |
} | |
g = g.nodeIndex - q; | |
if (l === 0) { | |
return g === 0; | |
} else { | |
return g % l === 0 && g / l >= 0; | |
} | |
} | |
}, | |
ID: function(g, h) { | |
return g.nodeType === 1 && g.getAttribute('id') === h; | |
}, | |
TAG: function(g, h) { | |
return h === '*' && g.nodeType === 1 || g.nodeName.toLowerCase() === h; | |
}, | |
CLASS: function(g, h) { | |
return (' ' + (g.className || g.getAttribute('class')) + ' ').indexOf(h) > -1; | |
}, | |
ATTR: function(g, h) { | |
var l, m; | |
l = h[1]; | |
g = (n.attrHandle[l] ? n.attrHandle[l](g) : (g[l] !== null ? g[l] : g.getAttribute(l))); | |
l = g + ''; | |
m = h[2]; | |
h = h[4]; | |
if (g === null) { | |
return m === '!='; | |
} else { | |
if (m === '=') { | |
return l === h; | |
} else { | |
if (m === '*=') { | |
return l.indexOf(h) >= 0; | |
} else { | |
if (m === '~=') { | |
return (' ' + l + ' ').indexOf(h) >= 0; | |
} else { | |
if (!h) { | |
return l && g !== false; | |
} else { | |
if (m === '!=') { | |
return l !== h; | |
} else { | |
if (m === '^=') { | |
return l.indexOf(h) === 0; | |
} else { | |
if (m === '$=') { | |
return l.substr(l.length - h.length) === h; | |
} else { | |
if (m === '|=') { | |
return l === h || l.substr(0, h.length + 1) === h + '-'; | |
} else { | |
return false; | |
} | |
} | |
} | |
} | |
} | |
} | |
} | |
} | |
} | |
}, | |
POS: function(g, h, l, m) { | |
var q; | |
q = n.setFilters[h[2]]; | |
if (q) { | |
return q(g, l, h, m); | |
} | |
} | |
} | |
}; | |
r = n.match.POS; | |
for (u in n.match) { | |
n.match[u] = new RegExp(n.match[u].source + /(?![^\[]*\])(?![^\(]*\))/.source); | |
n.leftMatch[u] = new RegExp(/(^(?:.|\r|\n)*?)/.source + n.match[u].source.replace(/\\(\d+)/g, function(g, h) { | |
return '\\' + (h - 0 + 1); | |
})); | |
} | |
z = function(g, h) { | |
g = Array.prototype.slice.call(g, 0); | |
if (h) { | |
h.push.apply(h, g); | |
return h; | |
} | |
return g; | |
}; | |
try { | |
Array.prototype.slice.call(s.documentElement.childNodes, 0); | |
} catch (C) { | |
z = function(g, h) { | |
var l, m; | |
h = h || []; | |
if (j.call(g) === '[object Array]') { | |
Array.prototype.push.apply(h, g); | |
} else if (typeof g.length === 'number') { | |
l = 0; | |
m = g.length; | |
while (l < m) { | |
h.push(g[l]); | |
l++; | |
} | |
} else { | |
l = 0; | |
} | |
while (g[l]) { | |
h.push(g[l]); | |
l++; | |
} | |
return h; | |
}; | |
} | |
if (s.documentElement.compareDocumentPosition) { | |
B = function(g, h) { | |
if (!g.compareDocumentPosition || !h.compareDocumentPosition) { | |
if (g === h) { | |
i = true; | |
} | |
if (g.compareDocumentPosition) { | |
return -1; | |
} else { | |
return 1; | |
} | |
} | |
g = (g.compareDocumentPosition(h) & 4 ? -1 : (g === h ? 0 : 1)); | |
if (g === 0) { | |
i = true; | |
} | |
return g; | |
}; | |
} else if (__indexOf.call(s.documentElement, 'sourceIndex') >= 0) { | |
B = function(g, h) { | |
if (!g.sourceIndex || !h.sourceIndex) { | |
if (g === h) { | |
i = true; | |
} | |
if (g.sourceIndex) { | |
return -1; | |
} else { | |
return 1; | |
} | |
} | |
g = g.sourceIndex - h.sourceIndex; | |
if (g === 0) { | |
i = true; | |
} | |
return g; | |
}; | |
} else if (s.createRange) { | |
B = function(g, h) { | |
var l, m; | |
if (!g.ownerDocument || !h.ownerDocument) { | |
if (g === h) { | |
i = true; | |
} | |
if (g.ownerDocument) { | |
return -1; | |
} else { | |
return 1; | |
} | |
} | |
l = g.ownerDocument.createRange(); | |
m = h.ownerDocument.createRange(); | |
l.setStart(g, 0); | |
l.setEnd(g, 0); | |
m.setStart(h, 0); | |
m.setEnd(h, 0); | |
g = l.compareBoundaryPoints(Range.START_TO_END, m); | |
if (g === 0) { | |
i = true; | |
} | |
return g; | |
}; | |
} | |
(function() { | |
var g, h, l; | |
g = s.createElement('div'); | |
h = 'script' + (new Date).getTime(); | |
g.innerHTML = "<a name='" + h + "'/>"; | |
l = s.documentElement; | |
l.insertBefore(g, l.firstChild); | |
if (s.getElementById(h)) { | |
n.find.ID = function(m, q, p) { | |
if (typeof q.getElementById !== 'undefined' && !p) { | |
if ((q = q.getElementById(m[1]))) { | |
return q.id === m[1] || typeof q.getAttributeNode !== 'undefined' && q.getAttributeNode('id').nodeValue === m[1]; | |
} else { | |
if ([q]) { | |
return w; | |
} else { | |
return []; | |
} | |
} | |
} | |
}; | |
n.filter.ID = function(m, q) { | |
var p; | |
p = typeof m.getAttributeNode !== 'undefined' && m.getAttributeNode('id'); | |
return m.nodeType === 1 && p && p.nodeValue === q; | |
}; | |
} | |
l.removeChild(g); | |
return l = g = null; | |
})(); | |
(function() { | |
var g; | |
g = s.createElement('div'); | |
g.appendChild(s.createComment('')); | |
if (g.getElementsByTagName('*').length > 0) { | |
n.find.TAG = function(h, l) { | |
var m; | |
l = l.getElementsByTagName(h[1]); | |
if (h[1] === '*') { | |
h = []; | |
m = 0; | |
while (l[m]) { | |
l[m].nodeType === 1 && h.push(l[m]); | |
m++; | |
} | |
l = h; | |
} | |
return l; | |
}; | |
} | |
g.innerHTML = "<a href='#'></a>"; | |
if (g.firstChild && typeof g.firstChild.getAttribute !== 'undefined' && g.firstChild.getAttribute('href') !== '#') { | |
n.attrHandle.href = function(h) { | |
return h.getAttribute('href', 2); | |
}; | |
} | |
return g = null; | |
})(); | |
s.querySelectorAll && function() { | |
var g, h, l; | |
g = k; | |
h = s.createElement('div'); | |
h.innerHTML = "<p class='TEST'></p>"; | |
if (!(h.querySelectorAll && h.querySelectorAll('.TEST').length === 0)) { | |
k = function(m, q, p, v) { | |
q = q || s; | |
if (!v && q.nodeType === 9 && !x(q)) { | |
try { | |
return z(q.querySelectorAll(m), p); | |
} catch (t) { | |
} | |
} | |
return g(m, q, p, v); | |
}; | |
for (l in g) { | |
k[l] = g[l]; | |
} | |
return h = null; | |
} | |
}; | |
(function() { | |
var g; | |
g = s.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) { | |
n.order.splice(1, 0, 'CLASS'); | |
n.find.CLASS = function(h, l, m) { | |
if (typeof l.getElementsByClassName !== 'undefined' && !m) { | |
return l.getElementsByClassName(h[1]); | |
} | |
}; | |
return g = null; | |
} | |
} | |
})(); | |
E = (s.compareDocumentPosition ? function(g, h) { | |
return !!(g.compareDocumentPosition(h) & 16); | |
} : function(g, h) { | |
return g !== h && (g.contains ? g.contains(h) : true); | |
}); | |
x = function(g) { | |
if ((g = (g ? g.ownerDocument || g : 0).documentElement)) { | |
return g.nodeName !== 'HTML'; | |
} else { | |
return false; | |
} | |
}; | |
ga = function(g, h) { | |
var l, m, p, q; | |
l = []; | |
m = ''; | |
h = (h.nodeType ? [h] : h); | |
while (q = n.match.PSEUDO.exec(g)) { | |
m = q[0]; | |
g = g.replace(n.match.PSEUDO, ''); | |
} | |
g = (n.relative[g] ? g + '*' : g); | |
q = 0; | |
p = h.length; | |
while (q < p) { | |
k(g, h[q], l); | |
q++; | |
} | |
return k.filter(m, l); | |
}; | |
c.find = k; | |
c.expr = k.selectors; | |
c.expr[':'] = c.expr.filters; | |
c.unique = k.uniqueSort; | |
c.text = a; | |
c.isXMLDoc = x; | |
return c.contains = E; | |
})(); | |
eb = /Until$/; | |
fb = /^(?:parents|prevUntil|prevAll)/; | |
gb = /,/; | |
R = Array.prototype.slice; | |
Ia = function(a, b, d) { | |
var f; | |
if (c.isFunction(b)) { | |
return c.grep(a, function(e, j) { | |
return !!b.call(e, j, e) === d; | |
}); | |
} else if (b.nodeType) { | |
return c.grep(a, function(e) { | |
return (e === b && b === d); | |
}); | |
} else if (typeof b === 'string') { | |
f = c.grep(a, function(e) { | |
return e.nodeType === 1; | |
}); | |
if (Ua.test(b)) { | |
return c.filter(b, f, !d); | |
} else { | |
b = c.filter(b, f); | |
} | |
} | |
return c.grep(a, function(e) { | |
return (c.inArray(e, b) >= 0 && 0 === d); | |
}); | |
}; | |
c.fn.extend({ | |
find: function(a) { | |
var b, d, e, f, i, j; | |
b = this.pushStack('', 'find', a); | |
d = 0; | |
f = 0; | |
e = this.length; | |
while (f < e) { | |
d = b.length; | |
c.find(a, this[f], b); | |
if (f > 0) { | |
j = d; | |
while (j < b.length) { | |
i = 0; | |
while (i < d) { | |
if (b[i] === b[j]) { | |
b.splice(j--, 1); | |
break; | |
} | |
i++; | |
} | |
j++; | |
} | |
} | |
f++; | |
} | |
return b; | |
}, | |
has: function(a) { | |
var b; | |
b = c(a); | |
return this.filter(function() { | |
var d, f, _results; | |
d = 0; | |
f = b.length; | |
_results = []; | |
while (d < f) { | |
if (c.contains(this, b[d])) { | |
return true; | |
} | |
_results.push(d++); | |
} | |
return _results; | |
}); | |
}, | |
not_: function(a) { | |
return this.pushStack(Ia(this, a, false), 'not', a); | |
}, | |
filter: function(a) { | |
return this.pushStack(Ia(this, a, true), 'filter', a); | |
}, | |
is: function(a) { | |
return !!a && c.filter(a, this).length > 0; | |
}, | |
closest: function(a, b) { | |
var d, e, f, i, j, k, o; | |
if (c.isArray(a)) { | |
d = []; | |
f = this[0]; | |
j = {}; | |
if (f && a.length) { | |
e = 0; | |
o = a.length; | |
while (e < o) { | |
i = a[e]; | |
j[i] || (j[i] = (c.expr.match.POS.test(i) ? c(i, b || this.context) : i)); | |
e++; | |
} | |
while (f && f.ownerDocument && f !== b) { | |
for (i in j) { | |
e = j[i]; | |
if ((e.jquery ? e.index(f) > -1 : c(f).is(e))) { | |
d.push({ | |
selector: i, | |
elem: f | |
}); | |
delete j[i]; | |
} | |
} | |
f = f.parentNode; | |
} | |
} | |
return d; | |
} | |
k = (c.expr.match.POS.test(a) ? c(a, b || this.context) : null); | |
return this.map(function(n, r) { | |
while (r && r.ownerDocument && r !== b) { | |
if ((k ? k.index(r) > -1 : c(r).is(a))) { | |
return r; | |
} | |
r = r.parentNode; | |
} | |
return null; | |
}); | |
}, | |
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) { | |
a = (typeof a === 'string' ? c(a, b || this.context) : c.makeArray(a)); | |
b = c.merge(this.get(), a); | |
return this.pushStack((qa(a[0]) || qa(b[0]) ? b : c.unique(b))); | |
}, | |
andSelf: function() { | |
return this.add(this.prevObject); | |
} | |
}); | |
c.each({ | |
parent: function(a) { | |
if ((a = a.parentNode) && a.nodeType !== 11) { | |
return a; | |
} else { | |
return 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) { | |
if (c.nodeName(a, 'iframe')) { | |
return a.contentDocument || a.contentWindow.document; | |
} else { | |
return c.makeArray(a.childNodes); | |
} | |
} | |
}, function(a, b) { | |
return c.fn[a] = function(d, f) { | |
var e; | |
e = c.map(this, b, d); | |
eb.test(a) || (f = d); | |
if (f && typeof f === 'string') { | |
e = c.filter(f, e); | |
} | |
e = (this.length > 1 ? c.unique(e) : e); | |
if ((this.length > 1 || gb.test(f)) && fb.test(a)) { | |
e = e.reverse(); | |
} | |
return this.pushStack(e, a, R.call(arguments).join(',')); | |
}; | |
}); | |
c.extend({ | |
filter: function(a, b, d) { | |
if (d) { | |
a = ':not(' + a + ')'; | |
} | |
return c.find.matches(a, b); | |
}, | |
dir: function(a, b, d) { | |
var f; | |
f = []; | |
a = a[b]; | |
while (a && a.nodeType !== 9 && (d === w || a.nodeType !== 1 || !c(a).is(d))) { | |
a.nodeType === 1 && f.push(a); | |
a = a[b]; | |
} | |
return f; | |
}, | |
nth: function(a, b, d) { | |
var f; | |
b = b || 1; | |
f = 0; | |
while (a) { | |
if (a.nodeType === 1 && f++ === b) { | |
break; | |
} | |
a = a[d]; | |
} | |
return a; | |
}, | |
sibling: function(a, b) { | |
var d; | |
d = []; | |
while (a) { | |
a.nodeType === 1 && a !== b && d.push(a); | |
a = a.nextSibling; | |
} | |
return d; | |
} | |
}); | |
Ja = RegExp(' jQuery\\d+="(?:\\d+|null)"', 'g'); | |
V = /^\s+/; | |
Ka = /(<([\w:]+)[^>]*?)\/>/g; | |
hb = /^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i; | |
La = /<([\w:]+)/; | |
ib = /<tbody/i; | |
jb = /<|&#?\w+;/; | |
ta = /<script|<object|<embed|<option|<style/i; | |
ua = /checked\s*(?:[^=]|=\s*.checked.)/i; | |
Ma = function(a, b, d) { | |
if (hb.test(d)) { | |
return a; | |
} else { | |
return b + '></' + d + '>'; | |
} | |
}; | |
F = { | |
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, '', ''] | |
}; | |
F.optgroup = F.option; | |
F.tbody = F.tfoot = F.colgroup = F.caption = F.thead; | |
F.th = F.td; | |
if (!c.support.htmlSerialize) { | |
F._default = [1, 'div<div>', '</div>']; | |
} | |
c.fn.extend({ | |
text: function(a) { | |
if (c.isFunction(a)) { | |
return this.each(function(b) { | |
var d; | |
d = c(this); | |
return d.text(a.call(this, b, d.text())); | |
}); | |
} | |
if (typeof a !== 'object' && a !== w) { | |
return this.empty().append((this[0] && this[0].ownerDocument || s).createTextNode(a)); | |
} | |
return c.text(this); | |
}, | |
wrapAll: function(a) { | |
var b; | |
if (c.isFunction(a)) { | |
return this.each(function(d) { | |
return c(this).wrapAll(a.call(this, d)); | |
}); | |
} | |
if (this[0]) { | |
b = c(a, this[0].ownerDocument).eq(0).clone(true); | |
this[0].parentNode && b.insertBefore(this[0]); | |
b.map(function() { | |
var d; | |
d = this; | |
while (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) { | |
return c(this).wrapInner(a.call(this, b)); | |
}); | |
} | |
return this.each(function() { | |
var b, d; | |
b = c(this); | |
d = b.contents(); | |
if (d.length) { | |
return d.wrapAll(a); | |
} else { | |
return b.append(a); | |
} | |
}); | |
}, | |
wrap: function(a) { | |
return this.each(function() { | |
return c(this).wrapAll(a); | |
}); | |
}, | |
unwrap: function() { | |
return this.parent().each(function() { | |
return c.nodeName(this, 'body') || c(this).replaceWith(this.childNodes); | |
}).end(); | |
}, | |
append: function() { | |
return this.domManip(arguments, true, function(a) { | |
return this.nodeType === 1 && this.appendChild(a); | |
}); | |
}, | |
prepend: function() { | |
return this.domManip(arguments, true, function(a) { | |
return this.nodeType === 1 && this.insertBefore(a, this.firstChild); | |
}); | |
}, | |
before: function() { | |
var a; | |
if (this[0] && this[0].parentNode) { | |
return this.domManip(arguments, false, function(b) { | |
return this.parentNode.insertBefore(b, this); | |
}); | |
} else if (arguments.length) { | |
a = c(arguments[0]); | |
a.push.apply(a, this.toArray()); | |
return this.pushStack(a, 'before', arguments); | |
} | |
}, | |
after: function() { | |
var a; | |
if (this[0] && this[0].parentNode) { | |
return this.domManip(arguments, false, function(b) { | |
return this.parentNode.insertBefore(b, this.nextSibling); | |
}); | |
} else if (arguments.length) { | |
a = this.pushStack(this, 'after', arguments); | |
a.push.apply(a, c(arguments[0]).toArray()); | |
return a; | |
} | |
}, | |
remove: function(a, b) { | |
var d, f; | |
d = 0; | |
while ((f = this[d]) !== null) { | |
if (!a || c.filter(a, [f]).length) { | |
if (!b && f.nodeType === 1) { | |
c.cleanData(f.getElementsByTagName('*')); | |
c.cleanData([f]); | |
} | |
f.parentNode && f.parentNode.removeChild(f); | |
} | |
d++; | |
} | |
return this; | |
}, | |
empty: function() { | |
var a, b; | |
a = 0; | |
while ((b = this[a]) !== null) { | |
b.nodeType === 1 && c.cleanData(b.getElementsByTagName('*')); | |
while (b.firstChild) { | |
b.removeChild(b.firstChild); | |
} | |
a++; | |
} | |
return this; | |
}, | |
clone: function(a) { | |
var b; | |
b = this.map(function() { | |
var d, f; | |
if (!c.support.noCloneEvent && !c.isXMLDoc(this)) { | |
d = this.outerHTML; | |
f = this.ownerDocument; | |
if (!d) { | |
d = f.createElement('div'); | |
d.appendChild(this.cloneNode(true)); | |
d = d.innerHTML; | |
} | |
return c.clean([d.replace(Ja, '').replace(RegExp('=([^="\'>\\s]+\\/)>', 'g'), '="$1">').replace(V, '')], f)[0]; | |
} else { | |
return this.cloneNode(true); | |
} | |
}); | |
if (a === true) { | |
ra(this, b); | |
ra(this.find('*'), b.find('*')); | |
} | |
return b; | |
}, | |
html: function(a) { | |
var b, d; | |
if (a === w) { | |
if (this[0] && this[0].nodeType === 1) { | |
return this[0].innerHTML.replace(Ja, ''); | |
} else { | |
return null; | |
} | |
} else if (typeof a === 'string' && !ta.test(a) && (c.support.leadingWhitespace || !V.test(a)) && !F[(La.exec(a) || ['', ''])[1].toLowerCase()]) { | |
a = a.replace(Ka, Ma); | |
try { | |
b = 0; | |
d = this.length; | |
while (b < d) { | |
if (this[b].nodeType === 1) { | |
c.cleanData(this[b].getElementsByTagName('*')); | |
this[b].innerHTML = a; | |
} | |
b++; | |
} | |
} catch (f) { | |
this.empty().append(a); | |
} | |
} else { | |
if (c.isFunction(a)) { | |
this.each(function(e) { | |
var i, j; | |
j = c(this); | |
i = j.html(); | |
return j.empty().append(function() { | |
return a.call(this, e, i); | |
}); | |
}); | |
} else { | |
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, f; | |
d = c(this); | |
f = d.html(); | |
return d.replaceWith(a.call(this, b, f)); | |
}); | |
} | |
if (typeof a !== 'string') { | |
a = c(a).detach(); | |
} | |
return this.each(function() { | |
var b, d; | |
b = this.nextSibling; | |
d = this.parentNode; | |
c(this).remove(); | |
if (b) { | |
return c(b).before(a); | |
} else { | |
return 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, i, j, k, n, o, r; | |
f = function(u) { | |
if (c.nodeName(u, 'table')) { | |
return u.getElementsByTagName('tbody')[0] || u.appendChild(u.ownerDocument.createElement('tbody')); | |
} else { | |
return u; | |
} | |
}; | |
i = a[0]; | |
o = []; | |
if (!c.support.checkClone && arguments.length === 3 && typeof i === 'string' && ua.test(i)) { | |
return this.each(function() { | |
return c(this).domManip(a, b, d, true); | |
}); | |
} | |
if (c.isFunction(i)) { | |
return this.each(function(u) { | |
var z; | |
z = c(this); | |
a[0] = i.call(this, u, (b ? z.html() : w)); | |
return z.domManip(a, b, d); | |
}); | |
} | |
if (this[0]) { | |
e = i && i.parentNode; | |
e = (c.support.parentNode && e && e.nodeType === 11 && e.childNodes.length === this.length ? { | |
fragment: e | |
} : sa(a, this, o)); | |
k = e.fragment; | |
if (j = (k.childNodes.length === 1 ? (k = k.firstChild) : k.firstChild)) { | |
b = b && c.nodeName(j, 'tr'); | |
n = 0; | |
r = this.length; | |
while (n < r) { | |
d.call((b ? f(this[n], j) : this[n]), (n > 0 || e.cacheable || this.length > 1 ? k.cloneNode(true) : k)); | |
n++; | |
} | |
} | |
o.length && c.each(o, Qa); | |
} | |
return this; | |
} | |
}); | |
c.fragments = {}; | |
c.each({ | |
appendTo: 'append', | |
prependTo: 'prepend', | |
insertBefore: 'before', | |
insertAfter: 'after', | |
replaceAll: 'replaceWith' | |
}, function(a, b) { | |
return c.fn[a] = function(d) { | |
var e, f, i, j; | |
f = []; | |
d = c(d); | |
e = this.length === 1 && this[0].parentNode; | |
if (e && e.nodeType === 11 && e.childNodes.length === 1 && d.length === 1) { | |
d[b](this[0]); | |
return this; | |
} else { | |
e = 0; | |
} | |
j = d.length; | |
while (e < j) { | |
i = (e > 0 ? this.clone(true) : this).get(); | |
c.fn[b].apply(c(d[e]), i); | |
f = f.concat(i); | |
e++; | |
} | |
return this.pushStack(f, a, d.selector); | |
}; | |
}); | |
c.extend({ | |
clean: function(a, b, d, f) { | |
var e, i, j, k, n, o, r; | |
b = b || s; | |
if (typeof b.createElement === 'undefined') { | |
b = b.ownerDocument || b[0] && b[0].ownerDocument || s; | |
} | |
e = []; | |
j = 0; | |
while ((i = a[j]) !== null) { | |
if (typeof i === 'number') { | |
i = ''; | |
} | |
if (i) { | |
if (typeof i === 'string' && !jb.test(i)) { | |
i = b.createTextNode(i); | |
} else if (typeof i === 'string') { | |
i = i.replace(Ka, Ma); | |
o = (La.exec(i) || ['', ''])[1].toLowerCase(); | |
k = F[o] || F._default; | |
n = k[0]; | |
r = b.createElement('div'); | |
r.innerHTML = k[1] + i + k[2]; | |
while (n--) { | |
r = r.lastChild; | |
} | |
if (!c.support.tbody) { | |
n = ib.test(i); | |
o = (o === 'table' && !n ? r.firstChild && r.firstChild.childNodes : (k[1] === '<table>' && !n ? r.childNodes : [])); | |
k = o.length - 1; | |
while (k >= 0) { | |
c.nodeName(o[k], 'tbody') && !o[k].childNodes.length && o[k].parentNode.removeChild(o[k]); | |
k--; | |
} | |
} | |
!c.support.leadingWhitespace && V.test(i) && r.insertBefore(b.createTextNode(V.exec(i)[0]), r.firstChild); | |
i = r.childNodes; | |
} | |
if (i.nodeType) { | |
e.push(i); | |
} else { | |
e = c.merge(e, i); | |
} | |
} | |
j++; | |
} | |
if (d) { | |
j = 0; | |
while (e[j]) { | |
if (f && c.nodeName(e[j], 'script') && (!e[j].type || e[j].type.toLowerCase() === 'text/javascript')) { | |
f.push((e[j].parentNode ? e[j].parentNode.removeChild(e[j]) : e[j])); | |
} else { | |
e[j].nodeType === 1 && e.splice.apply(e, [j + 1, 0].concat(c.makeArray(e[j].getElementsByTagName('script')))); | |
} | |
d.appendChild(e[j]); | |
j++; | |
} | |
} | |
return e; | |
}, | |
cleanData: function(a) { | |
var b, d, e, f, i, j, k, o, _results; | |
f = c.cache; | |
e = c.event.special; | |
j = c.support.deleteExpando; | |
i = 0; | |
_results = []; | |
while ((o = a[i]) !== null) { | |
if (d = o[c.expando]) { | |
b = f[d]; | |
if (b.events) { | |
for (k in b.events) { | |
if (e[k]) { | |
c.event.remove(o, k); | |
} else { | |
Ca(o, k, b.handle); | |
} | |
} | |
} | |
if (j) { | |
delete o[c.expando]; | |
} else { | |
o.removeAttribute && o.removeAttribute(c.expando); | |
} | |
delete f[d]; | |
} | |
_results.push(i++); | |
} | |
return _results; | |
} | |
}); | |
kb = /z-?index|font-?weight|opacity|zoom|line-?height/i; | |
Na = /alpha\([^)]*\)/; | |
Oa = /opacity=([^)]*)/; | |
ha = /float/i; | |
ia = /-([a-z])/ig; | |
lb = /([A-Z])/g; | |
mb = /^-?\d+(?:px)?$/i; | |
nb = /^-?\d/; | |
ob = { | |
position: 'absolute', | |
visibility: 'hidden', | |
display: 'block' | |
}; | |
pb = ['Left', 'Right']; | |
qb = ['Top', 'Bottom']; | |
rb = s.defaultView && s.defaultView.getComputedStyle; | |
Pa = (c.support.cssFloat ? 'cssFloat' : 'styleFloat'); | |
ja = function(a, b) { | |
return b.toUpperCase(); | |
}; | |
c.fn.css = function(a, b) { | |
return X(this, a, b, true, function(d, f, e) { | |
if (e === w) { | |
return c.curCSS(d, f); | |
} | |
if (typeof e === 'number' && !kb.test(f)) { | |
e = 'px'; | |
} | |
return c.style(d, f, e); | |
}); | |
}; | |
c.extend({ | |
style: function(a, b, d) { | |
var e, f; | |
if (!a || a.nodeType === 3 || a.nodeType === 8) { | |
return w; | |
} | |
if ((b === 'width' || b === 'height') && parseFloat(d) < 0) { | |
d = w; | |
} | |
f = a.style || a; | |
e = d !== w; | |
if (!c.support.opacity && b === 'opacity') { | |
if (e) { | |
f.zoom = 1; | |
b = (parseInt(d, 10) + '' === 'NaN' ? '' : 'alpha(opacity=' + d * 100 + ')'); | |
a = f.filter || c.curCSS(a, 'filter') || ''; | |
f.filter = (Na.test(a) ? a.replace(Na, b) : b); | |
} | |
if (f.filter && f.filter.indexOf('opacity=') >= 0) { | |
return parseFloat(Oa.exec(f.filter)[1]) / 100 + ''; | |
} else { | |
return ''; | |
} | |
} | |
if (ha.test(b)) { | |
b = Pa; | |
} | |
b = b.replace(ia, ja); | |
if (e) { | |
f[b] = d; | |
} | |
return f[b]; | |
}, | |
css: function(a, b, d, f) { | |
var i, j; | |
if (b === 'width' || b === 'height') { | |
i = function() { | |
var e; | |
e = (b === 'width' ? a.offsetWidth : a.offsetHeight); | |
return f !== 'border' && c.each(j, function() { | |
f || (e = parseFloat(c.curCSS(a, 'padding' + this, true)) || 0); | |
if (f === 'margin') { | |
return e = parseFloat(c.curCSS(a, 'margin' + this, true)) || 0; | |
} else { | |
return e = parseFloat(c.curCSS(a, 'border' + this + 'Width', true)) || 0; | |
} | |
}); | |
}; | |
j = (b === 'width' ? pb : qb); | |
if (a.offsetWidth !== 0) { | |
i(); | |
} else { | |
c.swap(a, ob, i); | |
} | |
return Math.max(0, Math.round(e)); | |
} | |
return c.curCSS(a, b, d); | |
}, | |
curCSS: function(a, b, d) { | |
var e, f, j; | |
e = a.style; | |
if (!c.support.opacity && b === 'opacity' && a.currentStyle) { | |
f = (Oa.test(a.currentStyle.filter || '') ? parseFloat(RegExp.$1) / 100 + '' : ''); | |
if (f === '') { | |
return '1'; | |
} else { | |
return f; | |
} | |
} | |
if (ha.test(b)) { | |
b = Pa; | |
} | |
if (!d && e && e[b]) { | |
f = e[b]; | |
} else if (rb) { | |
if (ha.test(b)) { | |
b = 'float'; | |
} | |
b = b.replace(lb, '-$1').toLowerCase(); | |
e = a.ownerDocument.defaultView; | |
if (!e) { | |
return null; | |
} | |
if (a = e.getComputedStyle(a, null)) { | |
f = a.getPropertyValue(b); | |
} | |
if (b === 'opacity' && f === '') { | |
f = '1'; | |
} | |
} else if (a.currentStyle) { | |
d = b.replace(ia, ja); | |
f = a.currentStyle[b] || a.currentStyle[d]; | |
if (!mb.test(f) && nb.test(f)) { | |
b = e.left; | |
j = a.runtimeStyle.left; | |
a.runtimeStyle.left = a.currentStyle.left; | |
e.left = (d === 'fontSize' ? '1em' : f || 0); | |
f = e.pixelLeft + 'px'; | |
e.left = b; | |
a.runtimeStyle.left = j; | |
} | |
} | |
return f; | |
}, | |
swap: function(a, b, d) { | |
var e, f, _results; | |
f = {}; | |
for (e in b) { | |
f[e] = a.style[e]; | |
a.style[e] = b[e]; | |
} | |
d.call(a); | |
_results = []; | |
for (e in b) { | |
_results.push(a.style[e] = f[e]); | |
} | |
return _results; | |
} | |
}); | |
if (c.expr && c.expr.filters) { | |
c.expr.filters.hidden = function(a) { | |
var b, d, f; | |
b = a.offsetWidth; | |
d = a.offsetHeight; | |
f = a.nodeName.toLowerCase() === 'tr'; | |
if (b === 0 && d === 0 && !f) { | |
return true; | |
} else { | |
if (b > 0 && d > 0 && !f) { | |
return false; | |
} else { | |
return c.curCSS(a, 'display') === 'none'; | |
} | |
} | |
}; | |
c.expr.filters.visible = function(a) { | |
return !c.expr.filters.hidden(a); | |
}; | |
} | |
sb = J(); | |
tb = /<script(.|\s)*?\/script>/gi; | |
ub = /select|textarea/i; | |
vb = /color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i; | |
N = RegExp('=\\?(&|$)', ''); | |
ka = /\?/; | |
wb = /(\?|&)_=.*?(&|$)/; | |
xb = /^(\w+:)?\/\/([^\/?#]+)/; | |
yb = /%20/g; | |
zb = c.fn.load; | |
c.fn.extend({ | |
load: function(a, b, d) { | |
var e, f, j; | |
if (typeof a !== 'string') { | |
return zb.call(this, a); | |
} else { | |
if (!this.length) { | |
return this; | |
} | |
} | |
f = a.indexOf(' '); | |
if (f >= 0) { | |
e = a.slice(f, a.length); | |
a = a.slice(0, f); | |
} | |
f = 'GET'; | |
if (b) { | |
if (c.isFunction(b)) { | |
d = b; | |
b = null; | |
} else if (typeof b === 'object') { | |
b = c.param(b, c.ajaxSettings.traditional); | |
f = 'POST'; | |
} | |
} | |
j = this; | |
c.ajax({ | |
url: a, | |
type: f, | |
dataType: 'html', | |
data: b, | |
complete: function(i, o) { | |
if (o === 'success' || o === 'notmodified') { | |
j.html((e ? c('<div />').append(i.responseText.replace(tb, '')).find(e) : i.responseText)); | |
} | |
return d && j.each(d, [i.responseText, o, i]); | |
} | |
}); | |
return this; | |
}, | |
serialize: function() { | |
return c.param(this.serializeArray()); | |
}, | |
serializeArray: function() { | |
return this.map(function() { | |
if (this.elements) { | |
return c.makeArray(this.elements); | |
} else { | |
return this; | |
} | |
}).filter(function() { | |
return this.name && !this.disabled && (this.checked || ub.test(this.nodeName) || vb.test(this.type)); | |
}).map(function(a, b) { | |
a = c(this).val(); | |
if (a === null) { | |
return null; | |
} else { | |
if (c.isArray(a)) { | |
return c.map(a, function(d) { | |
return { | |
name: b.name, | |
value: d | |
}; | |
}); | |
} else { | |
return { | |
name: b.name, | |
value: a | |
}; | |
} | |
} | |
}).get(); | |
} | |
}); | |
c.each('ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend'.split(' '), function(a, b) { | |
return c.fn[b] = function(d) { | |
return this.bind(b, d); | |
}; | |
}); | |
c.extend({ | |
get: function(a, b, d, f) { | |
if (c.isFunction(b)) { | |
f = f || d; | |
d = b; | |
b = null; | |
} | |
return c.ajax({ | |
type: 'GET', | |
url: a, | |
data: b, | |
success: d, | |
dataType: f | |
}); | |
}, | |
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, f) { | |
if (c.isFunction(b)) { | |
f = f || d; | |
d = b; | |
b = {}; | |
} | |
return c.ajax({ | |
type: 'POST', | |
url: a, | |
data: b, | |
success: d, | |
dataType: f | |
}); | |
}, | |
ajaxSetup: function(a) { | |
return c.extend(c.ajaxSettings, a); | |
}, | |
ajaxSettings: { | |
url: location.href, | |
global: true, | |
type: 'GET', | |
contentType: 'application/x-www-form-urlencoded', | |
processData: true, | |
async: true, | |
xhr: (A.XMLHttpRequest && (A.location.protocol !== 'file:' || !A.ActiveXObject) ? function() { | |
return new A.XMLHttpRequest; | |
} : function() { | |
try { | |
return new A.ActiveXObject('Microsoft.XMLHTTP'); | |
} catch (a) { | |
} | |
}), | |
accepts: { | |
xml: 'application/xml, text/xml', | |
html: 'text/html', | |
script: 'text/javascript, application/javascript', | |
json: 'application/json, text/javascript', | |
text: 'text/plain', | |
_default: '*/*' | |
} | |
}, | |
lastModified: {}, | |
etag: {}, | |
ajax: function(a) { | |
var B, C, E, b, d, e, f, g, h, j, k, n, r, u, x, z; | |
b = function() { | |
e.success && e.success.call(k, o, i, x); | |
return e.global && f('ajaxSuccess', [x, e]); | |
}; | |
d = function() { | |
e.complete && e.complete.call(k, x, i); | |
e.global && f('ajaxComplete', [x, e]); | |
return e.global && !c.active-- && c.event.trigger('ajaxStop'); | |
}; | |
f = function(q, p) { | |
return (e.context ? c(e.context) : c.event).trigger(q, p); | |
}; | |
e = c.extend(true, {}, c.ajaxSettings, a); | |
k = a && a.context || e; | |
n = e.type.toUpperCase(); | |
if (e.data && e.processData && typeof e.data !== 'string') { | |
e.data = c.param(e.data, e.traditional); | |
} | |
if (e.dataType === 'jsonp') { | |
if (n === 'GET') { | |
N.test(e.url) || (e.url = (ka.test(e.url) ? '&' : '?') + (e.jsonp || 'callback') + '=?'); | |
} else { | |
if (!e.data || !N.test(e.data)) { | |
e.data = (e.data ? e.data + '&' : '') + (e.jsonp || 'callback') + '=?'; | |
} | |
} | |
e.dataType = 'json'; | |
} | |
if (e.dataType === 'json' && (e.data && N.test(e.data) || N.test(e.url))) { | |
j = e.jsonpCallback || 'jsonp' + sb++; | |
if (e.data) { | |
e.data = (e.data + '').replace(N, '=' + j + '$1'); | |
} | |
e.url = e.url.replace(N, '=' + j + '$1'); | |
e.dataType = 'script'; | |
A[j] = A[j] || function(q) { | |
var o; | |
o = q; | |
b(); | |
d(); | |
A[j] = w; | |
try { | |
delete A[j]; | |
} catch (p) { | |
} | |
return z && z.removeChild(C); | |
}; | |
} | |
if (e.dataType === 'script' && e.cache === null) { | |
e.cache = false; | |
} | |
if (e.cache === false && n === 'GET') { | |
r = J(); | |
u = e.url.replace(wb, '$1_=' + r + '$2'); | |
e.url = u + (u === e.url ? (ka.test(e.url) ? '&' : '?') + '_=' + r : ''); | |
} | |
if (e.data && n === 'GET') { | |
e.url = (ka.test(e.url) ? '&' : '?') + e.data; | |
} | |
e.global && !c.active++ && c.event.trigger('ajaxStart'); | |
r = (r = xb.exec(e.url)) && (r[1] && r[1] !== location.protocol || r[2] !== location.host); | |
if (e.dataType === 'script' && n === 'GET' && r) { | |
z = s.getElementsByTagName('head')[0] || s.documentElement; | |
C = s.createElement('script'); | |
C.src = e.url; | |
if (e.scriptCharset) { | |
C.charset = e.scriptCharset; | |
} | |
if (!j) { | |
B = false; | |
C.onload = C.onreadystatechange = function() { | |
if (!B && (!this.readyState || this.readyState === 'loaded' || this.readyState === 'complete')) { | |
B = true; | |
b(); | |
d(); | |
C.onload = C.onreadystatechange = null; | |
return z && C.parentNode && z.removeChild(C); | |
} | |
}; | |
} | |
z.insertBefore(C, z.firstChild); | |
return w; | |
} | |
E = false; | |
x = e.xhr(); | |
if (x) { | |
if (e.username) { | |
x.open(n, e.url, e.async, e.username, e.password); | |
} else { | |
x.open(n, e.url, e.async); | |
} | |
try { | |
if (e.data || a && a.contentType) { | |
x.setRequestHeader('Content-Type', e.contentType); | |
} | |
if (e.ifModified) { | |
c.lastModified[e.url] && x.setRequestHeader('If-Modified-Since', c.lastModified[e.url]); | |
c.etag[e.url] && x.setRequestHeader('If-None-Match', c.etag[e.url]); | |
} | |
r || x.setRequestHeader('X-Requested-With', 'XMLHttpRequest'); | |
x.setRequestHeader('Accept', (e.dataType && e.accepts[e.dataType] ? e.accepts[e.dataType] + ', */*' : e.accepts._default)); | |
} catch (ga) { | |
} | |
if (e.beforeSend && e.beforeSend.call(k, x, e) === false) { | |
e.global && !c.active-- && c.event.trigger('ajaxStop'); | |
x.abort(); | |
return false; | |
} | |
e.global && f('ajaxSend', [x, e]); | |
g = x.onreadystatechange = function(q) { | |
var i, o, p; | |
if (!x || x.readyState === 0 || q === 'abort') { | |
E || d(); | |
E = true; | |
if (x) { | |
return x.onreadystatechange = c.noop; | |
} | |
} else if (!E && x && (x.readyState === 4 || q === 'timeout')) { | |
E = true; | |
x.onreadystatechange = c.noop; | |
i = (q === 'timeout' ? 'timeout' : (!c.httpSuccess(x) ? 'error' : (e.ifModified && c.httpNotModified(x, e.url) ? 'notmodified' : 'success'))); | |
if (i === 'success') { | |
try { | |
o = c.httpData(x, e.dataType, e); | |
} catch (v) { | |
i = 'parsererror'; | |
p = v; | |
} | |
} | |
if (i === 'success' || i === 'notmodified') { | |
j || b(); | |
} else { | |
c.handleError(e, x, i, p); | |
} | |
d(); | |
q === 'timeout' && x.abort(); | |
if (e.async) { | |
return x = null; | |
} | |
} | |
}; | |
try { | |
h = x.abort; | |
x.abort = function() { | |
x && h.call(x); | |
return g('abort'); | |
}; | |
} catch (l) { | |
} | |
e.async && e.timeout > 0 && setTimeout(function() { | |
return x && !E && g('timeout'); | |
}, e.timeout); | |
try { | |
x.send((n === 'POST' || n === 'PUT' || n === 'DELETE' ? e.data : null)); | |
} catch (m) { | |
c.handleError(e, x, null, m); | |
d(); | |
} | |
e.async || g(); | |
return x; | |
} | |
}, | |
handleError: function(a, b, d, f) { | |
if (a.error) { | |
a.error.call(a.context || a, b, d, f); | |
} | |
if (a.global) { | |
return (a.context ? c(a.context) : c.event).trigger('ajaxError', [b, a, f]); | |
} | |
}, | |
active: 0, | |
httpSuccess: function(a) { | |
try { | |
return !a.status && location.protocol === 'file:' || a.status >= 200 && a.status < 300 || a.status === 304 || a.status === 1223 || a.status === 0; | |
} catch (b) { | |
} | |
return false; | |
}, | |
httpNotModified: function(a, b) { | |
var d, f; | |
d = a.getResponseHeader('Last-Modified'); | |
f = a.getResponseHeader('Etag'); | |
if (d) { | |
c.lastModified[b] = d; | |
} | |
if (f) { | |
c.etag[b] = f; | |
} | |
return a.status === 304 || a.status === 0; | |
}, | |
httpData: function(a, b, d) { | |
var e, f; | |
f = a.getResponseHeader('content-type') || ''; | |
e = b === 'xml' || !b && f.indexOf('xml') >= 0; | |
a = (e ? a.responseXML : a.responseText); | |
e && a.documentElement.nodeName === 'parsererror' && c.error('parsererror'); | |
if (d && d.dataFilter) { | |
a = d.dataFilter(a, b); | |
} | |
if (typeof a === 'string') { | |
if (b === 'json' || !b && f.indexOf('json') >= 0) { | |
a = c.parseJSON(a); | |
} else { | |
if (b === 'script' || !b && f.indexOf('javascript') >= 0) { | |
c.globalEval(a); | |
} | |
} | |
} | |
return a; | |
}, | |
param: function(a, b) { | |
var d, e, f, j; | |
d = function(i, o) { | |
if (c.isArray(o)) { | |
return c.each(o, function(k, n) { | |
if (b || /\[\]$/.test(i)) { | |
return f(i, n); | |
} else { | |
return d(i + '[' + (typeof n === 'object' || c.isArray(n) ? k : '') + ']', n); | |
} | |
}); | |
} else { | |
if (!b && o !== null && typeof o === 'object') { | |
return c.each(o, function(k, n) { | |
return d(i + '[' + k + ']', n); | |
}); | |
} else { | |
return f(i, o); | |
} | |
} | |
}; | |
f = function(i, o) { | |
o = (c.isFunction(o) ? o() : o); | |
return e[e.length] = encodeURIComponent(i) + '=' + encodeURIComponent(o); | |
}; | |
e = []; | |
if (b === w) { | |
b = c.ajaxSettings.traditional; | |
} | |
if (c.isArray(a) || a.jquery) { | |
c.each(a, function() { | |
return f(this.name, this.value); | |
}); | |
} else { | |
for (j in a) { | |
d(j, a[j]); | |
} | |
} | |
return e.join('&').replace(yb, '+'); | |
} | |
}); | |
la = {}; | |
Ab = /toggle|show|hide/; | |
Bb = /^([+-]=)?([\d+-.]+)(.*)$/; | |
va = [['height', 'marginTop', 'marginBottom', 'paddingTop', 'paddingBottom'], ['width', 'marginLeft', 'marginRight', 'paddingLeft', 'paddingRight'], ['opacity']]; | |
c.fn.extend({ | |
show: function(a, b) { | |
var d, e, f; | |
if (a || a === 0) { | |
return this.animate(K('show', 3), a, b); | |
} else { | |
a = 0; | |
} | |
b = this.length; | |
while (a < b) { | |
d = c.data(this[a], 'olddisplay'); | |
this[a].style.display = d || ''; | |
if (c.css(this[a], 'display') === 'none') { | |
d = this[a].nodeName; | |
if (la[d]) { | |
f = la[d]; | |
} else { | |
e = c('<' + d + ' />').appendTo('body'); | |
} | |
f = e.css('display'); | |
if (f === 'none') { | |
f = 'block'; | |
} | |
e.remove(); | |
la[d] = f; | |
c.data(this[a], 'olddisplay', f); | |
} | |
a++; | |
} | |
a = 0; | |
b = this.length; | |
while (a < b) { | |
this[a].style.display = c.data(this[a], 'olddisplay') || ''; | |
a++; | |
} | |
return this; | |
}, | |
hide: function(a, b) { | |
var d; | |
if (a || a === 0) { | |
return this.animate(K('hide', 3), a, b); | |
} else { | |
a = 0; | |
} | |
b = this.length; | |
while (a < b) { | |
d = c.data(this[a], 'olddisplay'); | |
!d && d !== 'none' && c.data(this[a], 'olddisplay', c.css(this[a], 'display')); | |
a++; | |
} | |
a = 0; | |
b = this.length; | |
while (a < b) { | |
this[a].style.display = 'none'; | |
a++; | |
} | |
return this; | |
}, | |
_toggle: c.fn.toggle, | |
toggle: function(a, b) { | |
var d; | |
d = typeof a === 'boolean'; | |
if (c.isFunction(a) && c.isFunction(b)) { | |
this._toggle.apply(this, arguments); | |
} else { | |
if (a === null || d) { | |
this.each(function() { | |
var f; | |
f = (d ? a : c(this).is(':hidden')); | |
return c(this)[(f ? 'show' : 'hide')](); | |
}); | |
} else { | |
this.animate(K('toggle', 3), a, b); | |
} | |
} | |
return this; | |
}, | |
fadeTo: function(a, b, d) { | |
return this.filter(':hidden').css('opacity', 0).show().end().animate({ | |
opacity: b | |
}, a, d); | |
}, | |
animate: function(a, b, d, f) { | |
var e; | |
e = c.speed(b, d, f); | |
if (c.isEmptyObject(a)) { | |
return this.each(e.complete); | |
} | |
return this[(e.queue === false ? 'each' : 'queue')](function() { | |
var i, j, k, n, o; | |
j = c.extend({}, e); | |
o = this.nodeType === 1 && c(this).is(':hidden'); | |
k = this; | |
for (i in a) { | |
n = i.replace(ia, ja); | |
if (i !== n) { | |
a[n] = a[i]; | |
delete a[i]; | |
i = n; | |
} | |
if (a[i] === 'hide' && o || a[i] === 'show' && !o) { | |
return j.complete.call(this); | |
} | |
if ((i === 'height' || i === 'width') && this.style) { | |
j.display = c.css(this, 'display'); | |
j.overflow = this.style.overflow; | |
} | |
if (c.isArray(a[i])) { | |
(j.specialEasing = j.specialEasing || {})[i] = a[i][1]; | |
a[i] = a[i][0]; | |
} | |
} | |
if (j.overflow !== null) { | |
this.style.overflow = 'hidden'; | |
} | |
j.curAnim = c.extend({}, a); | |
c.each(a, function(r, u) { | |
var B, C, E, z; | |
z = new c.fx(k, j, r); | |
if (Ab.test(u)) { | |
z[(u === 'toggle' ? o : ('show' ? 'hide' : u))](a); | |
} else { | |
C = Bb.exec(u); | |
} | |
B = z.cur(true) || 0; | |
if (C) { | |
u = parseFloat(C[2]); | |
E = C[3] || 'px'; | |
if (E !== 'px') { | |
k.style[r] = (u || 1) + E; | |
B = (u || 1) / z.cur(true) * B; | |
k.style[r] = B + E; | |
} | |
if (C[1]) { | |
u = (C[1] === '-=' ? -1 : 1) * u + B; | |
} | |
return z.custom(B, u, E); | |
} else { | |
return z.custom(B, u, ''); | |
} | |
}); | |
return true; | |
}); | |
}, | |
stop: function(a, b) { | |
var d; | |
d = c.timers; | |
a && this.queue([]); | |
this.each(function() { | |
var f, _results; | |
f = d.length - 1; | |
_results = []; | |
while (f >= 0) { | |
if (d[f].elem === this) { | |
b && d[f](true); | |
d.splice(f, 1); | |
} | |
_results.push(f--); | |
} | |
return _results; | |
}); | |
b || this.dequeue(); | |
return this; | |
} | |
}); | |
c.each({ | |
slideDown: K('show', 1), | |
slideUp: K('hide', 1), | |
slideToggle: K('toggle', 1), | |
fadeIn: { | |
opacity: 'show' | |
}, | |
fadeOut: { | |
opacity: 'hide' | |
} | |
}, function(a, b) { | |
return c.fn[a] = function(d, f) { | |
return this.animate(b, d, f); | |
}; | |
}); | |
c.extend({ | |
speed: function(a, b, d) { | |
var f; | |
f = (a && typeof a === 'object' ? a : { | |
complete: d || !d && b || c.isFunction(a) && a, | |
duration: a, | |
easing: d && b || b && !c.isFunction(b) && b | |
}); | |
f.duration = (c.fx.off_ ? 0 : (typeof f.duration === 'number' ? f.duration : c.fx.speeds[f.duration] || c.fx.speeds._default)); | |
f.old = f.complete; | |
f.complete = function() { | |
f.queue !== false && c(this).dequeue(); | |
return c.isFunction(f.old) && f.old.call(this); | |
}; | |
return f; | |
}, | |
easing: { | |
linear: function(a, b, d, f) { | |
return d + f * a; | |
}, | |
swing: function(a, b, d, f) { | |
return (-Math.cos(a * Math.PI) / 2 + 0.5) * f + d; | |
} | |
}, | |
timers: [], | |
fx: function(a, b, d) { | |
this.options = b; | |
this.elem = a; | |
this.prop = d; | |
if (!b.orig) { | |
return 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); | |
if ((this.prop === 'height' || this.prop === 'width') && this.elem.style) { | |
return this.elem.style.display = 'block'; | |
} | |
}, | |
cur: function(a) { | |
if (this.elem[this.prop] !== null && (!this.elem.style || this.elem.style[this.prop] === null)) { | |
return this.elem[this.prop]; | |
} | |
if ((a = parseFloat(c.css(this.elem, this.prop, a))) && a > -10000) { | |
return a; | |
} else { | |
return parseFloat(c.curCSS(this.elem, this.prop)) || 0; | |
} | |
}, | |
custom: function(a, b, d) { | |
var W, e, f; | |
f = function(j) { | |
return e.step(j); | |
}; | |
this.startTime = J(); | |
this.start = a; | |
this.end = b; | |
this.unit = d || this.unit || 'px'; | |
this.now = this.start; | |
this.pos = this.state = 0; | |
e = this; | |
f.elem = this.elem; | |
if (f() && c.timers.push(f) && !W) { | |
return W = setInterval(c.fx.tick, 13); | |
} | |
}, | |
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()); | |
return c(this.elem).show(); | |
}, | |
hide: function() { | |
this.options.orig[this.prop] = c.style(this.elem, this.prop); | |
this.options.hide = true; | |
return this.custom(this.cur(), 0); | |
}, | |
step: function(a) { | |
var b, d, e, f; | |
b = J(); | |
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 (f in this.options.curAnim) { | |
if (this.options.curAnim[f] !== true) { | |
d = false; | |
} | |
} | |
if (d) { | |
if (this.options.display !== null) { | |
this.elem.style.overflow = this.options.overflow; | |
a = c.data(this.elem, 'olddisplay'); | |
this.elem.style.display = (a ? a : this.options.display); | |
if (c.css(this.elem, 'display') === 'none') { | |
this.elem.style.display = 'block'; | |
} | |
} | |
this.options.hide && c(this.elem).hide(); | |
if (this.options.hide || this.options.show) { | |
for (e in this.options.curAnim) { | |
c.style(this.elem, e, this.options.orig[e]); | |
} | |
} | |
this.options.complete.call(this.elem); | |
} | |
return false; | |
} else { | |
e = b - this.startTime; | |
} | |
this.state = e / this.options.duration; | |
a = this.options.easing || (c.easing.swing ? 'swing' : 'linear'); | |
this.pos = c.easing[this.options.specialEasing && this.options.specialEasing[this.prop] || a](this.state, e, 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() { | |
var a, b; | |
a = c.timers; | |
b = 0; | |
while (b < a.length) { | |
a[b]() || a.splice(b--, 1); | |
b++; | |
} | |
return a.length || c.fx.stop(); | |
}, | |
stop: function() { | |
var W; | |
clearInterval(W); | |
return W = null; | |
}, | |
speeds: { | |
slow: 600, | |
fast: 200, | |
_default: 400 | |
}, | |
step: { | |
opacity: function(a) { | |
return c.style(a.elem, 'opacity', a.now); | |
}, | |
_default: function(a) { | |
if (a.elem.style && a.elem.style[a.prop] !== null) { | |
return a.elem.style[a.prop] = (a.prop === 'width' || a.prop === 'height' ? Math.max(0, a.now) : a.now) + a.unit; | |
} else { | |
return 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; | |
}; | |
} | |
c.fn.offset = (__indexOf.call(s.documentElement, 'getBoundingClientRect') >= 0 ? function(a) { | |
var b, d, f; | |
b = this[0]; | |
if (a) { | |
return this.each(function(e) { | |
return c.offset.setOffset(this, a, e); | |
}); | |
} | |
if (!b || !b.ownerDocument) { | |
return null; | |
} | |
if (b === b.ownerDocument.body) { | |
return c.offset.bodyOffset(b); | |
} | |
d = b.getBoundingClientRect(); | |
f = b.ownerDocument; | |
b = f.body; | |
f = f.documentElement; | |
return { | |
top: d.top + (self.pageYOffset || c.support.boxModel && f.scrollTop || b.scrollTop) - (f.clientTop || b.clientTop || 0), | |
left: d.left + (self.pageXOffset || c.support.boxModel && f.scrollLeft || b.scrollLeft) - (f.clientLeft || b.clientLeft || 0) | |
}; | |
} : function(a) { | |
var b, d, e, f, i, j, k, n, o; | |
b = this[0]; | |
if (a) { | |
return this.each(function(r) { | |
return c.offset.setOffset(this, a, r); | |
}); | |
} | |
if (!b || !b.ownerDocument) { | |
return null; | |
} | |
if (b === b.ownerDocument.body) { | |
return c.offset.bodyOffset(b); | |
} | |
c.offset.initialize(); | |
d = b.offsetParent; | |
f = b; | |
e = b.ownerDocument; | |
i = e.documentElement; | |
o = e.body; | |
f = ((e = e.defaultView) ? e.getComputedStyle(b, null) : b.currentStyle); | |
k = b.offsetTop; | |
n = b.offsetLeft; | |
while ((b = b.parentNode) && b !== o && b !== i) { | |
if (c.offset.supportsFixedPosition && f.position === 'fixed') { | |
break; | |
} | |
j = (e ? e.getComputedStyle(b, null) : b.currentStyle); | |
k = b.scrollTop; | |
n = b.scrollLeft; | |
if (b === d) { | |
k = b.offsetTop; | |
n = b.offsetLeft; | |
if (c.offset.doesNotAddBorder && !(c.offset.doesAddBorderForTableAndCells && /^t(able|d|h)$/i.test(b.nodeName))) { | |
k = parseFloat(j.borderTopWidth) || 0; | |
n = parseFloat(j.borderLeftWidth) || 0; | |
} | |
f = d; | |
d = b.offsetParent; | |
} | |
if (c.offset.subtractsBorderForOverflowNotVisible && j.overflow !== 'visible') { | |
k = parseFloat(j.borderTopWidth) || 0; | |
n = parseFloat(j.borderLeftWidth) || 0; | |
} | |
f = j; | |
} | |
if (f.position === 'relative' || f.position === 'static') { | |
k = o.offsetTop; | |
n = o.offsetLeft; | |
} | |
if (c.offset.supportsFixedPosition && f.position === 'fixed') { | |
k = Math.max(i.scrollTop, o.scrollTop); | |
n = Math.max(i.scrollLeft, o.scrollLeft); | |
} | |
return { | |
top: k, | |
left: n | |
}; | |
}); | |
c.offset = { | |
initialize: function() { | |
var a, b, d, e, f, j; | |
a = s.body; | |
b = s.createElement('div'); | |
j = parseFloat(c.curCSS(a, 'marginTop', true)) || 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; | |
f = d.firstChild; | |
e = d.nextSibling.firstChild.firstChild; | |
this.doesNotAddBorder = f.offsetTop !== 5; | |
this.doesAddBorderForTableAndCells = e.offsetTop === 5; | |
f.style.position = 'fixed'; | |
f.style.top = '20px'; | |
this.supportsFixedPosition = f.offsetTop === 20 || f.offsetTop === 15; | |
f.style.position = f.style.top = ''; | |
d.style.overflow = 'hidden'; | |
d.style.position = 'relative'; | |
this.subtractsBorderForOverflowNotVisible = f.offsetTop === -5; | |
this.doesNotIncludeMarginInBodyOffset = a.offsetTop !== j; | |
a.removeChild(b); | |
return c.offset.initialize = c.noop; | |
}, | |
bodyOffset: function(a) { | |
var b, d; | |
b = a.offsetTop; | |
d = a.offsetLeft; | |
c.offset.initialize(); | |
if (c.offset.doesNotIncludeMarginInBodyOffset) { | |
b = parseFloat(c.curCSS(a, 'marginTop', true)) || 0; | |
d = parseFloat(c.curCSS(a, 'marginLeft', true)) || 0; | |
} | |
return { | |
top: b, | |
left: d | |
}; | |
}, | |
setOffset: function(a, b, d) { | |
var e, f, i, j; | |
if (/static/.test(c.curCSS(a, 'position'))) { | |
a.style.position = 'relative'; | |
} | |
f = c(a); | |
e = f.offset(); | |
j = parseInt(c.curCSS(a, 'top', true), 10) || 0; | |
i = parseInt(c.curCSS(a, 'left', true), 10) || 0; | |
if (c.isFunction(b)) { | |
b = b.call(a, d, e); | |
} | |
d = { | |
top: b.top - e.top + j, | |
left: b.left - e.left + i | |
}; | |
if (__indexOf.call(b, 'using') >= 0) { | |
return b.using.call(a, d); | |
} else { | |
return f.css(d); | |
} | |
} | |
}; | |
c.fn.extend({ | |
position: function() { | |
var a, b, d, f; | |
if (!this[0]) { | |
return null; | |
} | |
a = this[0]; | |
b = this.offsetParent(); | |
d = this.offset(); | |
f = (/^body|html$/i.test(b[0].nodeName) ? { | |
top: 0, | |
left: 0 | |
} : b.offset()); | |
d.top = parseFloat(c.curCSS(a, 'marginTop', true)) || 0; | |
d.left = parseFloat(c.curCSS(a, 'marginLeft', true)) || 0; | |
f.top = parseFloat(c.curCSS(b[0], 'borderTopWidth', true)) || 0; | |
f.left = parseFloat(c.curCSS(b[0], 'borderLeftWidth', true)) || 0; | |
return { | |
top: d.top - f.top, | |
left: d.left - f.left | |
}; | |
}, | |
offsetParent: function() { | |
return this.map(function() { | |
var a; | |
a = this.offsetParent || s.body; | |
while (a && !/^body|html$/i.test(a.nodeName) && c.css(a, 'position') === 'static') { | |
a = a.offsetParent; | |
} | |
return a; | |
}); | |
} | |
}); | |
c.each(['Left', 'Top'], function(a, b) { | |
var d; | |
d = 'scroll' + b; | |
return c.fn[d] = function(f) { | |
var e, j; | |
e = this[0]; | |
if (!e) { | |
return null; | |
} | |
if (f !== w) { | |
return this.each(function() { | |
var j; | |
if (j = wa(this)) { | |
return j.scrollTo((!a ? f : c(j).scrollLeft()), (a ? f : c(j).scrollTop())); | |
} else { | |
return this[d] = f; | |
} | |
}); | |
} else { | |
if ((j = wa(e))) { | |
return __indexOf.call(j, 'pageXOffset') >= 0; | |
} else { | |
if (j[(a ? 'pageYOffset' : 'pageXOffset')]) { | |
return c.support.boxModel && j.document.documentElement[d] || j.document.body[d]; | |
} else { | |
return e[d]; | |
} | |
} | |
} | |
}; | |
}); | |
c.each(['Height', 'Width'], function(a, b) { | |
var d; | |
d = b.toLowerCase(); | |
c.fn['inner' + b] = function() { | |
if (this[0]) { | |
return c.css(this[0], d, false, 'padding'); | |
} else { | |
return null; | |
} | |
}; | |
c.fn['outer' + b] = function(f) { | |
if (this[0]) { | |
return c.css(this[0], d, false, (f ? 'margin' : 'border')); | |
} else { | |
return null; | |
} | |
}; | |
return c.fn[d] = function(f) { | |
var e; | |
e = this[0]; | |
if (!e) { | |
if (f === null) { | |
return null; | |
} else { | |
return this; | |
} | |
} | |
if (c.isFunction(f)) { | |
return this.each(function(j) { | |
var i; | |
i = c(this); | |
return i[d](f.call(this, j, i[d]())); | |
}); | |
} | |
if (__indexOf.call(e, 'scrollTo') >= 0 && e.document) { | |
return e.document.compatMode === 'CSS1Compat' && e.document.documentElement['client' + b] || e.document.body['client' + b]; | |
} else { | |
if (e.nodeType === 9) { | |
return Math.max(e.documentElement['client' + b], e.body['scroll' + b], e.documentElement['scroll' + b], e.body['offset' + b], e.documentElement['offset' + b]); | |
} else { | |
if (f === w) { | |
return c.css(e, d); | |
} else { | |
return this.css(d, (typeof f === 'string' ? f : f + 'px')); | |
} | |
} | |
} | |
}; | |
}); | |
return A.jQuery = A.$ = c; | |
})(window); | |
}).call(this); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment