Skip to content

Instantly share code, notes, and snippets.

@patrickkettner
Created May 31, 2011 08:11
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save patrickkettner/1000151 to your computer and use it in GitHub Desktop.
Save patrickkettner/1000151 to your computer and use it in GitHub Desktop.
jquery translate party - javascript to coffescript and back again
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