﻿/*
* jQuery JavaScript Library v1.3.1
* http://jquery.com/
*
* Copyright (c) 2009 John Resig
* Dual licensed under the MIT and GPL licenses.
* http://docs.jquery.com/License
*
* Date: 2009-01-21 20:42:16 -0500 (Wed, 21 Jan 2009)
* Revision: 6158
*/
(function() {
    var l = this, g, y = l.jQuery, p = l.$, o = l.jQuery = l.$ = function(E, F) { return new o.fn.init(E, F) }, D = /^[^<]*(<(.|\s)+>)[^>]*$|^#([\w-]+)$/, f = /^.[^:#\[\.,]*$/; o.fn = o.prototype = { init: function(E, H) { E = E || document; if (E.nodeType) { this[0] = E; this.length = 1; this.context = E; return this } if (typeof E === "string") { var G = D.exec(E); if (G && (G[1] || !H)) { if (G[1]) { E = o.clean([G[1]], H) } else { var I = document.getElementById(G[3]); if (I && I.id != G[3]) { return o().find(E) } var F = o(I || []); F.context = document; F.selector = E; return F } } else { return o(H).find(E) } } else { if (o.isFunction(E)) { return o(document).ready(E) } } if (E.selector && E.context) { this.selector = E.selector; this.context = E.context } return this.setArray(o.makeArray(E)) }, selector: "", jquery: "1.3.1", size: function() { return this.length }, get: function(E) { return E === g ? o.makeArray(this) : this[E] }, pushStack: function(F, H, E) { var G = o(F); G.prevObject = this; G.context = this.context; if (H === "find") { G.selector = this.selector + (this.selector ? " " : "") + E } else { if (H) { G.selector = this.selector + "." + H + "(" + E + ")" } } return G }, setArray: function(E) { this.length = 0; Array.prototype.push.apply(this, E); return this }, each: function(F, E) { return o.each(this, F, E) }, index: function(E) { return o.inArray(E && E.jquery ? E[0] : E, this) }, attr: function(F, H, G) { var E = F; if (typeof F === "string") { if (H === g) { return this[0] && o[G || "attr"](this[0], F) } else { E = {}; E[F] = H } } return this.each(function(I) { for (F in E) { o.attr(G ? this.style : this, F, o.prop(this, E[F], G, I, F)) } }) }, css: function(E, F) { if ((E == "width" || E == "height") && parseFloat(F) < 0) { F = g } return this.attr(E, F, "curCSS") }, text: function(F) { if (typeof F !== "object" && F != null) { return this.empty().append((this[0] && this[0].ownerDocument || document).createTextNode(F)) } var E = ""; o.each(F || this, function() { o.each(this.childNodes, function() { if (this.nodeType != 8) { E += this.nodeType != 1 ? this.nodeValue : o.fn.text([this]) } }) }); return E }, wrapAll: function(E) { if (this[0]) { var F = o(E, this[0].ownerDocument).clone(); if (this[0].parentNode) { F.insertBefore(this[0]) } F.map(function() { var G = this; while (G.firstChild) { G = G.firstChild } return G }).append(this) } return this }, wrapInner: function(E) { return this.each(function() { o(this).contents().wrapAll(E) }) }, wrap: function(E) { return this.each(function() { o(this).wrapAll(E) }) }, append: function() { return this.domManip(arguments, true, function(E) { if (this.nodeType == 1) { this.appendChild(E) } }) }, prepend: function() { return this.domManip(arguments, true, function(E) { if (this.nodeType == 1) { this.insertBefore(E, this.firstChild) } }) }, before: function() { return this.domManip(arguments, false, function(E) { this.parentNode.insertBefore(E, this) }) }, after: function() { return this.domManip(arguments, false, function(E) { this.parentNode.insertBefore(E, this.nextSibling) }) }, end: function() { return this.prevObject || o([]) }, push: [].push, find: function(E) { if (this.length === 1 && !/,/.test(E)) { var G = this.pushStack([], "find", E); G.length = 0; o.find(E, this[0], G); return G } else { var F = o.map(this, function(H) { return o.find(E, H) }); return this.pushStack(/[^+>] [^+>]/.test(E) ? o.unique(F) : F, "find", E) } }, clone: function(F) { var E = this.map(function() { if (!o.support.noCloneEvent && !o.isXMLDoc(this)) { var I = this.cloneNode(true), H = document.createElement("div"); H.appendChild(I); return o.clean([H.innerHTML])[0] } else { return this.cloneNode(true) } }); var G = E.find("*").andSelf().each(function() { if (this[h] !== g) { this[h] = null } }); if (F === true) { this.find("*").andSelf().each(function(I) { if (this.nodeType == 3) { return } var H = o.data(this, "events"); for (var K in H) { for (var J in H[K]) { o.event.add(G[I], K, H[K][J], H[K][J].data) } } }) } return E }, filter: function(E) { return this.pushStack(o.isFunction(E) && o.grep(this, function(G, F) { return E.call(G, F) }) || o.multiFilter(E, o.grep(this, function(F) { return F.nodeType === 1 })), "filter", E) }, closest: function(E) { var F = o.expr.match.POS.test(E) ? o(E) : null; return this.map(function() { var G = this; while (G && G.ownerDocument) { if (F ? F.index(G) > -1 : o(G).is(E)) { return G } G = G.parentNode } }) }, not: function(E) { if (typeof E === "string") { if (f.test(E)) { return this.pushStack(o.multiFilter(E, this, true), "not", E) } else { E = o.multiFilter(E, this) } } var F = E.length && E[E.length - 1] !== g && !E.nodeType; return this.filter(function() { return F ? o.inArray(this, E) < 0 : this != E }) }, add: function(E) { return this.pushStack(o.unique(o.merge(this.get(), typeof E === "string" ? o(E) : o.makeArray(E)))) }, is: function(E) { return !!E && o.multiFilter(E, this).length > 0 }, hasClass: function(E) { return !!E && this.is("." + E) }, val: function(K) { if (K === g) { var E = this[0]; if (E) { if (o.nodeName(E, "option")) { return (E.attributes.value || {}).specified ? E.value : E.text } if (o.nodeName(E, "select")) { var I = E.selectedIndex, L = [], M = E.options, H = E.type == "select-one"; if (I < 0) { return null } for (var F = H ? I : 0, J = H ? I + 1 : M.length; F < J; F++) { var G = M[F]; if (G.selected) { K = o(G).val(); if (H) { return K } L.push(K) } } return L } return (E.value || "").replace(/\r/g, "") } return g } if (typeof K === "number") { K += "" } return this.each(function() { if (this.nodeType != 1) { return } if (o.isArray(K) && /radio|checkbox/.test(this.type)) { this.checked = (o.inArray(this.value, K) >= 0 || o.inArray(this.name, K) >= 0) } else { if (o.nodeName(this, "select")) { var N = o.makeArray(K); o("option", this).each(function() { this.selected = (o.inArray(this.value, N) >= 0 || o.inArray(this.text, N) >= 0) }); if (!N.length) { this.selectedIndex = -1 } } else { this.value = K } } }) }, html: function(E) { return E === g ? (this[0] ? this[0].innerHTML : null) : this.empty().append(E) }, replaceWith: function(E) { return this.after(E).remove() }, eq: function(E) { return this.slice(E, +E + 1) }, slice: function() { return this.pushStack(Array.prototype.slice.apply(this, arguments), "slice", Array.prototype.slice.call(arguments).join(",")) }, map: function(E) { return this.pushStack(o.map(this, function(G, F) { return E.call(G, F, G) })) }, andSelf: function() { return this.add(this.prevObject) }, domManip: function(K, N, M) { if (this[0]) { var J = (this[0].ownerDocument || this[0]).createDocumentFragment(), G = o.clean(K, (this[0].ownerDocument || this[0]), J), I = J.firstChild, E = this.length > 1 ? J.cloneNode(true) : J; if (I) { for (var H = 0, F = this.length; H < F; H++) { M.call(L(this[H], I), H > 0 ? E.cloneNode(true) : J) } } if (G) { o.each(G, z) } } return this; function L(O, P) { return N && o.nodeName(O, "table") && o.nodeName(P, "tr") ? (O.getElementsByTagName("tbody")[0] || O.appendChild(O.ownerDocument.createElement("tbody"))) : O } } }; o.fn.init.prototype = o.fn; function z(E, F) { if (F.src) { o.ajax({ url: F.src, async: false, dataType: "script" }) } else { o.globalEval(F.text || F.textContent || F.innerHTML || "") } if (F.parentNode) { F.parentNode.removeChild(F) } } function e() { return +new Date } o.extend = o.fn.extend = function() { var J = arguments[0] || {}, H = 1, I = arguments.length, E = false, G; if (typeof J === "boolean") { E = J; J = arguments[1] || {}; H = 2 } if (typeof J !== "object" && !o.isFunction(J)) { J = {} } if (I == H) { J = this; --H } for (; H < I; H++) { if ((G = arguments[H]) != null) { for (var F in G) { var K = J[F], L = G[F]; if (J === L) { continue } if (E && L && typeof L === "object" && !L.nodeType) { J[F] = o.extend(E, K || (L.length != null ? [] : {}), L) } else { if (L !== g) { J[F] = L } } } } } return J }; var b = /z-?index|font-?weight|opacity|zoom|line-?height/i, q = document.defaultView || {}, s = Object.prototype.toString; o.extend({ noConflict: function(E) { l.$ = p; if (E) { l.jQuery = y } return o }, isFunction: function(E) { return s.call(E) === "[object Function]" }, isArray: function(E) { return s.call(E) === "[object Array]" }, isXMLDoc: function(E) { return E.nodeType === 9 && E.documentElement.nodeName !== "HTML" || !!E.ownerDocument && o.isXMLDoc(E.ownerDocument) }, globalEval: function(G) { G = o.trim(G); if (G) { var F = document.getElementsByTagName("head")[0] || document.documentElement, E = document.createElement("script"); E.type = "text/javascript"; if (o.support.scriptEval) { E.appendChild(document.createTextNode(G)) } else { E.text = G } F.insertBefore(E, F.firstChild); F.removeChild(E) } }, nodeName: function(F, E) { return F.nodeName && F.nodeName.toUpperCase() == E.toUpperCase() }, each: function(G, K, F) { var E, H = 0, I = G.length; if (F) { if (I === g) { for (E in G) { if (K.apply(G[E], F) === false) { break } } } else { for (; H < I; ) { if (K.apply(G[H++], F) === false) { break } } } } else { if (I === g) { for (E in G) { if (K.call(G[E], E, G[E]) === false) { break } } } else { for (var J = G[0]; H < I && K.call(J, H, J) !== false; J = G[++H]) { } } } return G }, prop: function(H, I, G, F, E) { if (o.isFunction(I)) { I = I.call(H, F) } return typeof I === "number" && G == "curCSS" && !b.test(E) ? I + "px" : I }, className: { add: function(E, F) { o.each((F || "").split(/\s+/), function(G, H) { if (E.nodeType == 1 && !o.className.has(E.className, H)) { E.className += (E.className ? " " : "") + H } }) }, remove: function(E, F) { if (E.nodeType == 1) { E.className = F !== g ? o.grep(E.className.split(/\s+/), function(G) { return !o.className.has(F, G) }).join(" ") : "" } }, has: function(F, E) { return F && o.inArray(E, (F.className || F).toString().split(/\s+/)) > -1 } }, swap: function(H, G, I) { var E = {}; for (var F in G) { E[F] = H.style[F]; H.style[F] = G[F] } I.call(H); for (var F in G) { H.style[F] = E[F] } }, css: function(G, E, I) { if (E == "width" || E == "height") { var K, F = { position: "absolute", visibility: "hidden", display: "block" }, J = E == "width" ? ["Left", "Right"] : ["Top", "Bottom"]; function H() { K = E == "width" ? G.offsetWidth : G.offsetHeight; var M = 0, L = 0; o.each(J, function() { M += parseFloat(o.curCSS(G, "padding" + this, true)) || 0; L += parseFloat(o.curCSS(G, "border" + this + "Width", true)) || 0 }); K -= Math.round(M + L) } if (o(G).is(":visible")) { H() } else { o.swap(G, F, H) } return Math.max(0, K) } return o.curCSS(G, E, I) }, curCSS: function(I, F, G) { var L, E = I.style; if (F == "opacity" && !o.support.opacity) { L = o.attr(E, "opacity"); return L == "" ? "1" : L } if (F.match(/float/i)) { F = w } if (!G && E && E[F]) { L = E[F] } else { if (q.getComputedStyle) { if (F.match(/float/i)) { F = "float" } F = F.replace(/([A-Z])/g, "-$1").toLowerCase(); var M = q.getComputedStyle(I, null); if (M) { L = M.getPropertyValue(F) } if (F == "opacity" && L == "") { L = "1" } } else { if (I.currentStyle) { var J = F.replace(/\-(\w)/g, function(N, O) { return O.toUpperCase() }); L = I.currentStyle[F] || I.currentStyle[J]; if (!/^\d+(px)?$/i.test(L) && /^\d/.test(L)) { var H = E.left, K = I.runtimeStyle.left; I.runtimeStyle.left = I.currentStyle.left; E.left = L || 0; L = E.pixelLeft + "px"; E.left = H; I.runtimeStyle.left = K } } } } return L }, clean: function(F, K, I) { K = K || document; if (typeof K.createElement === "undefined") { K = K.ownerDocument || K[0] && K[0].ownerDocument || document } if (!I && F.length === 1 && typeof F[0] === "string") { var H = /^<(\w+)\s*\/?>$/.exec(F[0]); if (H) { return [K.createElement(H[1])] } } var G = [], E = [], L = K.createElement("div"); o.each(F, function(P, R) { if (typeof R === "number") { R += "" } if (!R) { return } if (typeof R === "string") { R = R.replace(/(<(\w+)[^>]*?)\/>/g, function(T, U, S) { return S.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i) ? T : U + "></" + S + ">" }); var O = o.trim(R).toLowerCase(); var Q = !O.indexOf("<opt") && [1, "<select multiple='multiple'>", "</select>"] || !O.indexOf("<leg") && [1, "<fieldset>", "</fieldset>"] || O.match(/^<(thead|tbody|tfoot|colg|cap)/) && [1, "<table>", "</table>"] || !O.indexOf("<tr") && [2, "<table><tbody>", "</tbody></table>"] || (!O.indexOf("<td") || !O.indexOf("<th")) && [3, "<table><tbody><tr>", "</tr></tbody></table>"] || !O.indexOf("<col") && [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"] || !o.support.htmlSerialize && [1, "div<div>", "</div>"] || [0, "", ""]; L.innerHTML = Q[1] + R + Q[2]; while (Q[0]--) { L = L.lastChild } if (!o.support.tbody) { var N = !O.indexOf("<table") && O.indexOf("<tbody") < 0 ? L.firstChild && L.firstChild.childNodes : Q[1] == "<table>" && O.indexOf("<tbody") < 0 ? L.childNodes : []; for (var M = N.length - 1; M >= 0; --M) { if (o.nodeName(N[M], "tbody") && !N[M].childNodes.length) { N[M].parentNode.removeChild(N[M]) } } } if (!o.support.leadingWhitespace && /^\s/.test(R)) { L.insertBefore(K.createTextNode(R.match(/^\s*/)[0]), L.firstChild) } R = o.makeArray(L.childNodes) } if (R.nodeType) { G.push(R) } else { G = o.merge(G, R) } }); if (I) { for (var J = 0; G[J]; J++) { if (o.nodeName(G[J], "script") && (!G[J].type || G[J].type.toLowerCase() === "text/javascript")) { E.push(G[J].parentNode ? G[J].parentNode.removeChild(G[J]) : G[J]) } else { if (G[J].nodeType === 1) { G.splice.apply(G, [J + 1, 0].concat(o.makeArray(G[J].getElementsByTagName("script")))) } I.appendChild(G[J]) } } return E } return G }, attr: function(J, G, K) { if (!J || J.nodeType == 3 || J.nodeType == 8) { return g } var H = !o.isXMLDoc(J), L = K !== g; G = H && o.props[G] || G; if (J.tagName) { var F = /href|src|style/.test(G); if (G == "selected" && J.parentNode) { J.parentNode.selectedIndex } if (G in J && H && !F) { if (L) { if (G == "type" && o.nodeName(J, "input") && J.parentNode) { throw "type property can't be changed" } J[G] = K } if (o.nodeName(J, "form") && J.getAttributeNode(G)) { return J.getAttributeNode(G).nodeValue } if (G == "tabIndex") { var I = J.getAttributeNode("tabIndex"); return I && I.specified ? I.value : J.nodeName.match(/(button|input|object|select|textarea)/i) ? 0 : J.nodeName.match(/^(a|area)$/i) && J.href ? 0 : g } return J[G] } if (!o.support.style && H && G == "style") { return o.attr(J.style, "cssText", K) } if (L) { J.setAttribute(G, "" + K) } var E = !o.support.hrefNormalized && H && F ? J.getAttribute(G, 2) : J.getAttribute(G); return E === null ? g : E } if (!o.support.opacity && G == "opacity") { if (L) { J.zoom = 1; J.filter = (J.filter || "").replace(/alpha\([^)]*\)/, "") + (parseInt(K) + "" == "NaN" ? "" : "alpha(opacity=" + K * 100 + ")") } return J.filter && J.filter.indexOf("opacity=") >= 0 ? (parseFloat(J.filter.match(/opacity=([^)]*)/)[1]) / 100) + "" : "" } G = G.replace(/-([a-z])/ig, function(M, N) { return N.toUpperCase() }); if (L) { J[G] = K } return J[G] }, trim: function(E) { return (E || "").replace(/^\s+|\s+$/g, "") }, makeArray: function(G) { var E = []; if (G != null) { var F = G.length; if (F == null || typeof G === "string" || o.isFunction(G) || G.setInterval) { E[0] = G } else { while (F) { E[--F] = G[F] } } } return E }, inArray: function(G, H) { for (var E = 0, F = H.length; E < F; E++) { if (H[E] === G) { return E } } return -1 }, merge: function(H, E) { var F = 0, G, I = H.length; if (!o.support.getAll) { while ((G = E[F++]) != null) { if (G.nodeType != 8) { H[I++] = G } } } else { while ((G = E[F++]) != null) { H[I++] = G } } return H }, unique: function(K) { var F = [], E = {}; try { for (var G = 0, H = K.length; G < H; G++) { var J = o.data(K[G]); if (!E[J]) { E[J] = true; F.push(K[G]) } } } catch (I) { F = K } return F }, grep: function(F, J, E) { var G = []; for (var H = 0, I = F.length; H < I; H++) { if (!E != !J(F[H], H)) { G.push(F[H]) } } return G }, map: function(E, J) { var F = []; for (var G = 0, H = E.length; G < H; G++) { var I = J(E[G], G); if (I != null) { F[F.length] = I } } return F.concat.apply([], F) } }); var C = navigator.userAgent.toLowerCase(); o.browser = { version: (C.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/) || [0, "0"])[1], safari: /webkit/.test(C), opera: /opera/.test(C), msie: /msie/.test(C) && !/opera/.test(C), mozilla: /mozilla/.test(C) && !/(compatible|webkit)/.test(C) }; o.each({ parent: function(E) { return E.parentNode }, parents: function(E) { return o.dir(E, "parentNode") }, next: function(E) { return o.nth(E, 2, "nextSibling") }, prev: function(E) { return o.nth(E, 2, "previousSibling") }, nextAll: function(E) { return o.dir(E, "nextSibling") }, prevAll: function(E) { return o.dir(E, "previousSibling") }, siblings: function(E) { return o.sibling(E.parentNode.firstChild, E) }, children: function(E) { return o.sibling(E.firstChild) }, contents: function(E) { return o.nodeName(E, "iframe") ? E.contentDocument || E.contentWindow.document : o.makeArray(E.childNodes) } }, function(E, F) { o.fn[E] = function(G) { var H = o.map(this, F); if (G && typeof G == "string") { H = o.multiFilter(G, H) } return this.pushStack(o.unique(H), E, G) } }); o.each({ appendTo: "append", prependTo: "prepend", insertBefore: "before", insertAfter: "after", replaceAll: "replaceWith" }, function(E, F) { o.fn[E] = function() { var G = arguments; return this.each(function() { for (var H = 0, I = G.length; H < I; H++) { o(G[H])[F](this) } }) } }); o.each({ removeAttr: function(E) { o.attr(this, E, ""); if (this.nodeType == 1) { this.removeAttribute(E) } }, addClass: function(E) { o.className.add(this, E) }, removeClass: function(E) { o.className.remove(this, E) }, toggleClass: function(F, E) { if (typeof E !== "boolean") { E = !o.className.has(this, F) } o.className[E ? "add" : "remove"](this, F) }, remove: function(E) { if (!E || o.filter(E, [this]).length) { o("*", this).add([this]).each(function() { o.event.remove(this); o.removeData(this) }); if (this.parentNode) { this.parentNode.removeChild(this) } } }, empty: function() { o(">*", this).remove(); while (this.firstChild) { this.removeChild(this.firstChild) } } }, function(E, F) { o.fn[E] = function() { return this.each(F, arguments) } }); function j(E, F) { return E[0] && parseInt(o.curCSS(E[0], F, true), 10) || 0 } var h = "jQuery" + e(), v = 0, A = {}; o.extend({ cache: {}, data: function(F, E, G) { F = F == l ? A : F; var H = F[h]; if (!H) { H = F[h] = ++v } if (E && !o.cache[H]) { o.cache[H] = {} } if (G !== g) { o.cache[H][E] = G } return E ? o.cache[H][E] : H }, removeData: function(F, E) { F = F == l ? A : F; var H = F[h]; if (E) { if (o.cache[H]) { delete o.cache[H][E]; E = ""; for (E in o.cache[H]) { break } if (!E) { o.removeData(F) } } } else { try { delete F[h] } catch (G) { if (F.removeAttribute) { F.removeAttribute(h) } } delete o.cache[H] } }, queue: function(F, E, H) { if (F) { E = (E || "fx") + "queue"; var G = o.data(F, E); if (!G || o.isArray(H)) { G = o.data(F, E, o.makeArray(H)) } else { if (H) { G.push(H) } } } return G }, dequeue: function(H, G) { var E = o.queue(H, G), F = E.shift(); if (!G || G === "fx") { F = E[0] } if (F !== g) { F.call(H) } } }); o.fn.extend({ data: function(E, G) { var H = E.split("."); H[1] = H[1] ? "." + H[1] : ""; if (G === g) { var F = this.triggerHandler("getData" + H[1] + "!", [H[0]]); if (F === g && this.length) { F = o.data(this[0], E) } return F === g && H[1] ? this.data(H[0]) : F } else { return this.trigger("setData" + H[1] + "!", [H[0], G]).each(function() { o.data(this, E, G) }) } }, removeData: function(E) { return this.each(function() { o.removeData(this, E) }) }, queue: function(E, F) { if (typeof E !== "string") { F = E; E = "fx" } if (F === g) { return o.queue(this[0], E) } return this.each(function() { var G = o.queue(this, E, F); if (E == "fx" && G.length == 1) { G[0].call(this) } }) }, dequeue: function(E) { return this.each(function() { o.dequeue(this, E) }) } });
    /*
    * Sizzle CSS Selector Engine - v0.9.3
    *  Copyright 2009, The Dojo Foundation
    *  Released under the MIT, BSD, and GPL Licenses.
    *  More information: http://sizzlejs.com/
    */
    (function() { var Q = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]+['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[]+)+|[>+~])(\s*,\s*)?/g, K = 0, G = Object.prototype.toString; var F = function(X, T, aa, ab) { aa = aa || []; T = T || document; if (T.nodeType !== 1 && T.nodeType !== 9) { return [] } if (!X || typeof X !== "string") { return aa } var Y = [], V, ae, ah, S, ac, U, W = true; Q.lastIndex = 0; while ((V = Q.exec(X)) !== null) { Y.push(V[1]); if (V[2]) { U = RegExp.rightContext; break } } if (Y.length > 1 && L.exec(X)) { if (Y.length === 2 && H.relative[Y[0]]) { ae = I(Y[0] + Y[1], T) } else { ae = H.relative[Y[0]] ? [T] : F(Y.shift(), T); while (Y.length) { X = Y.shift(); if (H.relative[X]) { X += Y.shift() } ae = I(X, ae) } } } else { var ad = ab ? { expr: Y.pop(), set: E(ab)} : F.find(Y.pop(), Y.length === 1 && T.parentNode ? T.parentNode : T, P(T)); ae = F.filter(ad.expr, ad.set); if (Y.length > 0) { ah = E(ae) } else { W = false } while (Y.length) { var ag = Y.pop(), af = ag; if (!H.relative[ag]) { ag = "" } else { af = Y.pop() } if (af == null) { af = T } H.relative[ag](ah, af, P(T)) } } if (!ah) { ah = ae } if (!ah) { throw "Syntax error, unrecognized expression: " + (ag || X) } if (G.call(ah) === "[object Array]") { if (!W) { aa.push.apply(aa, ah) } else { if (T.nodeType === 1) { for (var Z = 0; ah[Z] != null; Z++) { if (ah[Z] && (ah[Z] === true || ah[Z].nodeType === 1 && J(T, ah[Z]))) { aa.push(ae[Z]) } } } else { for (var Z = 0; ah[Z] != null; Z++) { if (ah[Z] && ah[Z].nodeType === 1) { aa.push(ae[Z]) } } } } } else { E(ah, aa) } if (U) { F(U, T, aa, ab) } return aa }; F.matches = function(S, T) { return F(S, null, null, T) }; F.find = function(Z, S, aa) { var Y, W; if (!Z) { return [] } for (var V = 0, U = H.order.length; V < U; V++) { var X = H.order[V], W; if ((W = H.match[X].exec(Z))) { var T = RegExp.leftContext; if (T.substr(T.length - 1) !== "\\") { W[1] = (W[1] || "").replace(/\\/g, ""); Y = H.find[X](W, S, aa); if (Y != null) { Z = Z.replace(H.match[X], ""); break } } } } if (!Y) { Y = S.getElementsByTagName("*") } return { set: Y, expr: Z} }; F.filter = function(ab, aa, ae, V) { var U = ab, ag = [], Y = aa, X, S; while (ab && aa.length) { for (var Z in H.filter) { if ((X = H.match[Z].exec(ab)) != null) { var T = H.filter[Z], af, ad; S = false; if (Y == ag) { ag = [] } if (H.preFilter[Z]) { X = H.preFilter[Z](X, Y, ae, ag, V); if (!X) { S = af = true } else { if (X === true) { continue } } } if (X) { for (var W = 0; (ad = Y[W]) != null; W++) { if (ad) { af = T(ad, X, W, Y); var ac = V ^ !!af; if (ae && af != null) { if (ac) { S = true } else { Y[W] = false } } else { if (ac) { ag.push(ad); S = true } } } } } if (af !== g) { if (!ae) { Y = ag } ab = ab.replace(H.match[Z], ""); if (!S) { return [] } break } } } ab = ab.replace(/\s*,\s*/, ""); if (ab == U) { if (S == null) { throw "Syntax error, unrecognized expression: " + ab } else { break } } U = ab } return Y }; var H = F.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\(\)]*)+)\2\))?/ }, attrMap: { "class": "className", "for": "htmlFor" }, attrHandle: { href: function(S) { return S.getAttribute("href") } }, relative: { "+": function(W, T) { for (var U = 0, S = W.length; U < S; U++) { var V = W[U]; if (V) { var X = V.previousSibling; while (X && X.nodeType !== 1) { X = X.previousSibling } W[U] = typeof T === "string" ? X || false : X === T } } if (typeof T === "string") { F.filter(T, W, true) } }, ">": function(X, T, Y) { if (typeof T === "string" && !/\W/.test(T)) { T = Y ? T : T.toUpperCase(); for (var U = 0, S = X.length; U < S; U++) { var W = X[U]; if (W) { var V = W.parentNode; X[U] = V.nodeName === T ? V : false } } } else { for (var U = 0, S = X.length; U < S; U++) { var W = X[U]; if (W) { X[U] = typeof T === "string" ? W.parentNode : W.parentNode === T } } if (typeof T === "string") { F.filter(T, X, true) } } }, "": function(V, T, X) { var U = "done" + (K++), S = R; if (!T.match(/\W/)) { var W = T = X ? T : T.toUpperCase(); S = O } S("parentNode", T, U, V, W, X) }, "~": function(V, T, X) { var U = "done" + (K++), S = R; if (typeof T === "string" && !T.match(/\W/)) { var W = T = X ? T : T.toUpperCase(); S = O } S("previousSibling", T, U, V, W, X) } }, find: { ID: function(T, U, V) { if (typeof U.getElementById !== "undefined" && !V) { var S = U.getElementById(T[1]); return S ? [S] : [] } }, NAME: function(S, T, U) { if (typeof T.getElementsByName !== "undefined" && !U) { return T.getElementsByName(S[1]) } }, TAG: function(S, T) { return T.getElementsByTagName(S[1]) } }, preFilter: { CLASS: function(V, T, U, S, Y) { V = " " + V[1].replace(/\\/g, "") + " "; var X; for (var W = 0; (X = T[W]) != null; W++) { if (X) { if (Y ^ (" " + X.className + " ").indexOf(V) >= 0) { if (!U) { S.push(X) } } else { if (U) { T[W] = false } } } } return false }, ID: function(S) { return S[1].replace(/\\/g, "") }, TAG: function(T, S) { for (var U = 0; S[U] === false; U++) { } return S[U] && P(S[U]) ? T[1] : T[1].toUpperCase() }, CHILD: function(S) { if (S[1] == "nth") { var T = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(S[2] == "even" && "2n" || S[2] == "odd" && "2n+1" || !/\D/.test(S[2]) && "0n+" + S[2] || S[2]); S[2] = (T[1] + (T[2] || 1)) - 0; S[3] = T[3] - 0 } S[0] = "done" + (K++); return S }, ATTR: function(T) { var S = T[1].replace(/\\/g, ""); if (H.attrMap[S]) { T[1] = H.attrMap[S] } if (T[2] === "~=") { T[4] = " " + T[4] + " " } return T }, PSEUDO: function(W, T, U, S, X) { if (W[1] === "not") { if (W[3].match(Q).length > 1) { W[3] = F(W[3], null, null, T) } else { var V = F.filter(W[3], T, U, true ^ X); if (!U) { S.push.apply(S, V) } return false } } else { if (H.match.POS.test(W[0])) { return true } } return W }, POS: function(S) { S.unshift(true); return S } }, filters: { enabled: function(S) { return S.disabled === false && S.type !== "hidden" }, disabled: function(S) { return S.disabled === true }, checked: function(S) { return S.checked === true }, selected: function(S) { S.parentNode.selectedIndex; return S.selected === true }, parent: function(S) { return !!S.firstChild }, empty: function(S) { return !S.firstChild }, has: function(U, T, S) { return !!F(S[3], U).length }, header: function(S) { return /h\d/i.test(S.nodeName) }, text: function(S) { return "text" === S.type }, radio: function(S) { return "radio" === S.type }, checkbox: function(S) { return "checkbox" === S.type }, file: function(S) { return "file" === S.type }, password: function(S) { return "password" === S.type }, submit: function(S) { return "submit" === S.type }, image: function(S) { return "image" === S.type }, reset: function(S) { return "reset" === S.type }, button: function(S) { return "button" === S.type || S.nodeName.toUpperCase() === "BUTTON" }, input: function(S) { return /input|select|textarea|button/i.test(S.nodeName) } }, setFilters: { first: function(T, S) { return S === 0 }, last: function(U, T, S, V) { return T === V.length - 1 }, even: function(T, S) { return S % 2 === 0 }, odd: function(T, S) { return S % 2 === 1 }, lt: function(U, T, S) { return T < S[3] - 0 }, gt: function(U, T, S) { return T > S[3] - 0 }, nth: function(U, T, S) { return S[3] - 0 == T }, eq: function(U, T, S) { return S[3] - 0 == T } }, filter: { CHILD: function(S, V) { var Y = V[1], Z = S.parentNode; var X = V[0]; if (Z && (!Z[X] || !S.nodeIndex)) { var W = 1; for (var T = Z.firstChild; T; T = T.nextSibling) { if (T.nodeType == 1) { T.nodeIndex = W++ } } Z[X] = W - 1 } if (Y == "first") { return S.nodeIndex == 1 } else { if (Y == "last") { return S.nodeIndex == Z[X] } else { if (Y == "only") { return Z[X] == 1 } else { if (Y == "nth") { var ab = false, U = V[2], aa = V[3]; if (U == 1 && aa == 0) { return true } if (U == 0) { if (S.nodeIndex == aa) { ab = true } } else { if ((S.nodeIndex - aa) % U == 0 && (S.nodeIndex - aa) / U >= 0) { ab = true } } return ab } } } } }, PSEUDO: function(Y, U, V, Z) { var T = U[1], W = H.filters[T]; if (W) { return W(Y, V, U, Z) } else { if (T === "contains") { return (Y.textContent || Y.innerText || "").indexOf(U[3]) >= 0 } else { if (T === "not") { var X = U[3]; for (var V = 0, S = X.length; V < S; V++) { if (X[V] === Y) { return false } } return true } } } }, ID: function(T, S) { return T.nodeType === 1 && T.getAttribute("id") === S }, TAG: function(T, S) { return (S === "*" && T.nodeType === 1) || T.nodeName === S }, CLASS: function(T, S) { return S.test(T.className) }, ATTR: function(W, U) { var S = H.attrHandle[U[1]] ? H.attrHandle[U[1]](W) : W[U[1]] || W.getAttribute(U[1]), X = S + "", V = U[2], T = U[4]; return S == null ? V === "!=" : V === "=" ? X === T : V === "*=" ? X.indexOf(T) >= 0 : V === "~=" ? (" " + X + " ").indexOf(T) >= 0 : !U[4] ? S : V === "!=" ? X != T : V === "^=" ? X.indexOf(T) === 0 : V === "$=" ? X.substr(X.length - T.length) === T : V === "|=" ? X === T || X.substr(0, T.length + 1) === T + "-" : false }, POS: function(W, T, U, X) { var S = T[2], V = H.setFilters[S]; if (V) { return V(W, U, T, X) } } } }; var L = H.match.POS; for (var N in H.match) { H.match[N] = RegExp(H.match[N].source + /(?![^\[]*\])(?![^\(]*\))/.source) } var E = function(T, S) { T = Array.prototype.slice.call(T); if (S) { S.push.apply(S, T); return S } return T }; try { Array.prototype.slice.call(document.documentElement.childNodes) } catch (M) { E = function(W, V) { var T = V || []; if (G.call(W) === "[object Array]") { Array.prototype.push.apply(T, W) } else { if (typeof W.length === "number") { for (var U = 0, S = W.length; U < S; U++) { T.push(W[U]) } } else { for (var U = 0; W[U]; U++) { T.push(W[U]) } } } return T } } (function() { var T = document.createElement("form"), U = "script" + (new Date).getTime(); T.innerHTML = "<input name='" + U + "'/>"; var S = document.documentElement; S.insertBefore(T, S.firstChild); if (!!document.getElementById(U)) { H.find.ID = function(W, X, Y) { if (typeof X.getElementById !== "undefined" && !Y) { var V = X.getElementById(W[1]); return V ? V.id === W[1] || typeof V.getAttributeNode !== "undefined" && V.getAttributeNode("id").nodeValue === W[1] ? [V] : g : [] } }; H.filter.ID = function(X, V) { var W = typeof X.getAttributeNode !== "undefined" && X.getAttributeNode("id"); return X.nodeType === 1 && W && W.nodeValue === V } } S.removeChild(T) })(); (function() { var S = document.createElement("div"); S.appendChild(document.createComment("")); if (S.getElementsByTagName("*").length > 0) { H.find.TAG = function(T, X) { var W = X.getElementsByTagName(T[1]); if (T[1] === "*") { var V = []; for (var U = 0; W[U]; U++) { if (W[U].nodeType === 1) { V.push(W[U]) } } W = V } return W } } S.innerHTML = "<a href='#'></a>"; if (S.firstChild && S.firstChild.getAttribute("href") !== "#") { H.attrHandle.href = function(T) { return T.getAttribute("href", 2) } } })(); if (document.querySelectorAll) { (function() { var S = F, T = document.createElement("div"); T.innerHTML = "<p class='TEST'></p>"; if (T.querySelectorAll && T.querySelectorAll(".TEST").length === 0) { return } F = function(X, W, U, V) { W = W || document; if (!V && W.nodeType === 9 && !P(W)) { try { return E(W.querySelectorAll(X), U) } catch (Y) { } } return S(X, W, U, V) }; F.find = S.find; F.filter = S.filter; F.selectors = S.selectors; F.matches = S.matches })() } if (document.getElementsByClassName && document.documentElement.getElementsByClassName) { H.order.splice(1, 0, "CLASS"); H.find.CLASS = function(S, T) { return T.getElementsByClassName(S[1]) } } function O(T, Z, Y, ac, aa, ab) { for (var W = 0, U = ac.length; W < U; W++) { var S = ac[W]; if (S) { S = S[T]; var X = false; while (S && S.nodeType) { var V = S[Y]; if (V) { X = ac[V]; break } if (S.nodeType === 1 && !ab) { S[Y] = W } if (S.nodeName === Z) { X = S; break } S = S[T] } ac[W] = X } } } function R(T, Y, X, ab, Z, aa) { for (var V = 0, U = ab.length; V < U; V++) { var S = ab[V]; if (S) { S = S[T]; var W = false; while (S && S.nodeType) { if (S[X]) { W = ab[S[X]]; break } if (S.nodeType === 1) { if (!aa) { S[X] = V } if (typeof Y !== "string") { if (S === Y) { W = true; break } } else { if (F.filter(Y, [S]).length > 0) { W = S; break } } } S = S[T] } ab[V] = W } } } var J = document.compareDocumentPosition ? function(T, S) { return T.compareDocumentPosition(S) & 16 } : function(T, S) { return T !== S && (T.contains ? T.contains(S) : true) }; var P = function(S) { return S.nodeType === 9 && S.documentElement.nodeName !== "HTML" || !!S.ownerDocument && P(S.ownerDocument) }; var I = function(S, Z) { var V = [], W = "", X, U = Z.nodeType ? [Z] : Z; while ((X = H.match.PSEUDO.exec(S))) { W += X[0]; S = S.replace(H.match.PSEUDO, "") } S = H.relative[S] ? S + "*" : S; for (var Y = 0, T = U.length; Y < T; Y++) { F(S, U[Y], V) } return F.filter(W, V) }; o.find = F; o.filter = F.filter; o.expr = F.selectors; o.expr[":"] = o.expr.filters; F.selectors.filters.hidden = function(S) { return "hidden" === S.type || o.css(S, "display") === "none" || o.css(S, "visibility") === "hidden" }; F.selectors.filters.visible = function(S) { return "hidden" !== S.type && o.css(S, "display") !== "none" && o.css(S, "visibility") !== "hidden" }; F.selectors.filters.animated = function(S) { return o.grep(o.timers, function(T) { return S === T.elem }).length }; o.multiFilter = function(U, S, T) { if (T) { U = ":not(" + U + ")" } return F.matches(U, S) }; o.dir = function(U, T) { var S = [], V = U[T]; while (V && V != document) { if (V.nodeType == 1) { S.push(V) } V = V[T] } return S }; o.nth = function(W, S, U, V) { S = S || 1; var T = 0; for (; W; W = W[U]) { if (W.nodeType == 1 && ++T == S) { break } } return W }; o.sibling = function(U, T) { var S = []; for (; U; U = U.nextSibling) { if (U.nodeType == 1 && U != T) { S.push(U) } } return S }; return; l.Sizzle = F })(); o.event = { add: function(I, F, H, K) { if (I.nodeType == 3 || I.nodeType == 8) { return } if (I.setInterval && I != l) { I = l } if (!H.guid) { H.guid = this.guid++ } if (K !== g) { var G = H; H = this.proxy(G); H.data = K } var E = o.data(I, "events") || o.data(I, "events", {}), J = o.data(I, "handle") || o.data(I, "handle", function() { return typeof o !== "undefined" && !o.event.triggered ? o.event.handle.apply(arguments.callee.elem, arguments) : g }); J.elem = I; o.each(F.split(/\s+/), function(M, N) { var O = N.split("."); N = O.shift(); H.type = O.slice().sort().join("."); var L = E[N]; if (o.event.specialAll[N]) { o.event.specialAll[N].setup.call(I, K, O) } if (!L) { L = E[N] = {}; if (!o.event.special[N] || o.event.special[N].setup.call(I, K, O) === false) { if (I.addEventListener) { I.addEventListener(N, J, false) } else { if (I.attachEvent) { I.attachEvent("on" + N, J) } } } } L[H.guid] = H; o.event.global[N] = true }); I = null }, guid: 1, global: {}, remove: function(K, H, J) { if (K.nodeType == 3 || K.nodeType == 8) { return } var G = o.data(K, "events"), F, E; if (G) { if (H === g || (typeof H === "string" && H.charAt(0) == ".")) { for (var I in G) { this.remove(K, I + (H || "")) } } else { if (H.type) { J = H.handler; H = H.type } o.each(H.split(/\s+/), function(M, O) { var Q = O.split("."); O = Q.shift(); var N = RegExp("(^|\\.)" + Q.slice().sort().join(".*\\.") + "(\\.|$)"); if (G[O]) { if (J) { delete G[O][J.guid] } else { for (var P in G[O]) { if (N.test(G[O][P].type)) { delete G[O][P] } } } if (o.event.specialAll[O]) { o.event.specialAll[O].teardown.call(K, Q) } for (F in G[O]) { break } if (!F) { if (!o.event.special[O] || o.event.special[O].teardown.call(K, Q) === false) { if (K.removeEventListener) { K.removeEventListener(O, o.data(K, "handle"), false) } else { if (K.detachEvent) { K.detachEvent("on" + O, o.data(K, "handle")) } } } F = null; delete G[O] } } }) } for (F in G) { break } if (!F) { var L = o.data(K, "handle"); if (L) { L.elem = null } o.removeData(K, "events"); o.removeData(K, "handle") } } }, trigger: function(I, K, H, E) { var G = I.type || I; if (!E) { I = typeof I === "object" ? I[h] ? I : o.extend(o.Event(G), I) : o.Event(G); if (G.indexOf("!") >= 0) { I.type = G = G.slice(0, -1); I.exclusive = true } if (!H) { I.stopPropagation(); if (this.global[G]) { o.each(o.cache, function() { if (this.events && this.events[G]) { o.event.trigger(I, K, this.handle.elem) } }) } } if (!H || H.nodeType == 3 || H.nodeType == 8) { return g } I.result = g; I.target = H; K = o.makeArray(K); K.unshift(I) } I.currentTarget = H; var J = o.data(H, "handle"); if (J) { J.apply(H, K) } if ((!H[G] || (o.nodeName(H, "a") && G == "click")) && H["on" + G] && H["on" + G].apply(H, K) === false) { I.result = false } if (!E && H[G] && !I.isDefaultPrevented() && !(o.nodeName(H, "a") && G == "click")) { this.triggered = true; try { H[G]() } catch (L) { } } this.triggered = false; if (!I.isPropagationStopped()) { var F = H.parentNode || H.ownerDocument; if (F) { o.event.trigger(I, K, F, true) } } }, handle: function(K) { var J, E; K = arguments[0] = o.event.fix(K || l.event); var L = K.type.split("."); K.type = L.shift(); J = !L.length && !K.exclusive; var I = RegExp("(^|\\.)" + L.slice().sort().join(".*\\.") + "(\\.|$)"); E = (o.data(this, "events") || {})[K.type]; for (var G in E) { var H = E[G]; if (J || I.test(H.type)) { K.handler = H; K.data = H.data; var F = H.apply(this, arguments); if (F !== g) { K.result = F; if (F === false) { K.preventDefault(); K.stopPropagation() } } if (K.isImmediatePropagationStopped()) { break } } } }, props: "altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "), fix: function(H) { if (H[h]) { return H } var F = H; H = o.Event(F); for (var G = this.props.length, J; G; ) { J = this.props[--G]; H[J] = F[J] } if (!H.target) { H.target = H.srcElement || document } if (H.target.nodeType == 3) { H.target = H.target.parentNode } if (!H.relatedTarget && H.fromElement) { H.relatedTarget = H.fromElement == H.target ? H.toElement : H.fromElement } if (H.pageX == null && H.clientX != null) { var I = document.documentElement, E = document.body; H.pageX = H.clientX + (I && I.scrollLeft || E && E.scrollLeft || 0) - (I.clientLeft || 0); H.pageY = H.clientY + (I && I.scrollTop || E && E.scrollTop || 0) - (I.clientTop || 0) } if (!H.which && ((H.charCode || H.charCode === 0) ? H.charCode : H.keyCode)) { H.which = H.charCode || H.keyCode } if (!H.metaKey && H.ctrlKey) { H.metaKey = H.ctrlKey } if (!H.which && H.button) { H.which = (H.button & 1 ? 1 : (H.button & 2 ? 3 : (H.button & 4 ? 2 : 0))) } return H }, proxy: function(F, E) { E = E || function() { return F.apply(this, arguments) }; E.guid = F.guid = F.guid || E.guid || this.guid++; return E }, special: { ready: { setup: B, teardown: function() { } } }, specialAll: { live: { setup: function(E, F) { o.event.add(this, F[0], c) }, teardown: function(G) { if (G.length) { var E = 0, F = RegExp("(^|\\.)" + G[0] + "(\\.|$)"); o.each((o.data(this, "events").live || {}), function() { if (F.test(this.type)) { E++ } }); if (E < 1) { o.event.remove(this, G[0], c) } } } }} }; o.Event = function(E) { if (!this.preventDefault) { return new o.Event(E) } if (E && E.type) { this.originalEvent = E; this.type = E.type } else { this.type = E } this.timeStamp = e(); this[h] = true }; function k() { return false } function u() { return true } o.Event.prototype = { preventDefault: function() { this.isDefaultPrevented = u; var E = this.originalEvent; if (!E) { return } if (E.preventDefault) { E.preventDefault() } E.returnValue = false }, stopPropagation: function() { this.isPropagationStopped = u; var E = this.originalEvent; if (!E) { return } if (E.stopPropagation) { E.stopPropagation() } E.cancelBubble = true }, stopImmediatePropagation: function() { this.isImmediatePropagationStopped = u; this.stopPropagation() }, isDefaultPrevented: k, isPropagationStopped: k, isImmediatePropagationStopped: k }; var a = function(F) { var E = F.relatedTarget; while (E && E != this) { try { E = E.parentNode } catch (G) { E = this } } if (E != this) { F.type = F.data; o.event.handle.apply(this, arguments) } }; o.each({ mouseover: "mouseenter", mouseout: "mouseleave" }, function(F, E) { o.event.special[E] = { setup: function() { o.event.add(this, F, a, E) }, teardown: function() { o.event.remove(this, F, a) } } }); o.fn.extend({ bind: function(F, G, E) { return F == "unload" ? this.one(F, G, E) : this.each(function() { o.event.add(this, F, E || G, E && G) }) }, one: function(G, H, F) { var E = o.event.proxy(F || H, function(I) { o(this).unbind(I, E); return (F || H).apply(this, arguments) }); return this.each(function() { o.event.add(this, G, E, F && H) }) }, unbind: function(F, E) { return this.each(function() { o.event.remove(this, F, E) }) }, trigger: function(E, F) { return this.each(function() { o.event.trigger(E, F, this) }) }, triggerHandler: function(E, G) { if (this[0]) { var F = o.Event(E); F.preventDefault(); F.stopPropagation(); o.event.trigger(F, G, this[0]); return F.result } }, toggle: function(G) { var E = arguments, F = 1; while (F < E.length) { o.event.proxy(G, E[F++]) } return this.click(o.event.proxy(G, function(H) { this.lastToggle = (this.lastToggle || 0) % F; H.preventDefault(); return E[this.lastToggle++].apply(this, arguments) || false })) }, hover: function(E, F) { return this.mouseenter(E).mouseleave(F) }, ready: function(E) { B(); if (o.isReady) { E.call(document, o) } else { o.readyList.push(E) } return this }, live: function(G, F) { var E = o.event.proxy(F); E.guid += this.selector + G; o(document).bind(i(G, this.selector), this.selector, E); return this }, die: function(F, E) { o(document).unbind(i(F, this.selector), E ? { guid: E.guid + this.selector + F} : null); return this } }); function c(H) { var E = RegExp("(^|\\.)" + H.type + "(\\.|$)"), G = true, F = []; o.each(o.data(this, "events").live || [], function(I, J) { if (E.test(J.type)) { var K = o(H.target).closest(J.data)[0]; if (K) { F.push({ elem: K, fn: J }) } } }); o.each(F, function() { if (this.fn.call(this.elem, H, this.fn.data) === false) { G = false } }); return G } function i(F, E) { return ["live", F, E.replace(/\./g, "`").replace(/ /g, "|")].join(".") } o.extend({ isReady: false, readyList: [], ready: function() { if (!o.isReady) { o.isReady = true; if (o.readyList) { o.each(o.readyList, function() { this.call(document, o) }); o.readyList = null } o(document).triggerHandler("ready") } } }); var x = false; function B() { if (x) { return } x = true; if (document.addEventListener) { document.addEventListener("DOMContentLoaded", function() { document.removeEventListener("DOMContentLoaded", arguments.callee, false); o.ready() }, false) } else { if (document.attachEvent) { document.attachEvent("onreadystatechange", function() { if (document.readyState === "complete") { document.detachEvent("onreadystatechange", arguments.callee); o.ready() } }); if (document.documentElement.doScroll && typeof l.frameElement === "undefined") { (function() { if (o.isReady) { return } try { document.documentElement.doScroll("left") } catch (E) { setTimeout(arguments.callee, 0); return } o.ready() })() } } } o.event.add(l, "load", o.ready) } o.each(("blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error").split(","), function(F, E) { o.fn[E] = function(G) { return G ? this.bind(E, G) : this.trigger(E) } }); o(l).bind("unload", function() { for (var E in o.cache) { if (E != 1 && o.cache[E].handle) { o.event.remove(o.cache[E].handle.elem) } } }); (function() { o.support = {}; var F = document.documentElement, G = document.createElement("script"), K = document.createElement("div"), J = "script" + (new Date).getTime(); K.style.display = "none"; K.innerHTML = '   <link/><table></table><a href="/a" style="color:red;float:left;opacity:.5;">a</a><select><option>text</option></select><object><param/></object>'; var H = K.getElementsByTagName("*"), E = K.getElementsByTagName("a")[0]; if (!H || !H.length || !E) { return } o.support = { leadingWhitespace: K.firstChild.nodeType == 3, tbody: !K.getElementsByTagName("tbody").length, objectAll: !!K.getElementsByTagName("object")[0].getElementsByTagName("*").length, htmlSerialize: !!K.getElementsByTagName("link").length, style: /red/.test(E.getAttribute("style")), hrefNormalized: E.getAttribute("href") === "/a", opacity: E.style.opacity === "0.5", cssFloat: !!E.style.cssFloat, scriptEval: false, noCloneEvent: true, boxModel: null }; G.type = "text/javascript"; try { G.appendChild(document.createTextNode("window." + J + "=1;")) } catch (I) { } F.insertBefore(G, F.firstChild); if (l[J]) { o.support.scriptEval = true; delete l[J] } F.removeChild(G); if (K.attachEvent && K.fireEvent) { K.attachEvent("onclick", function() { o.support.noCloneEvent = false; K.detachEvent("onclick", arguments.callee) }); K.cloneNode(true).fireEvent("onclick") } o(function() { var L = document.createElement("div"); L.style.width = "1px"; L.style.paddingLeft = "1px"; document.body.appendChild(L); o.boxModel = o.support.boxModel = L.offsetWidth === 2; document.body.removeChild(L) }) })(); var w = o.support.cssFloat ? "cssFloat" : "styleFloat"; o.props = { "for": "htmlFor", "class": "className", "float": w, cssFloat: w, styleFloat: w, readonly: "readOnly", maxlength: "maxLength", cellspacing: "cellSpacing", rowspan: "rowSpan", tabindex: "tabIndex" }; o.fn.extend({ _load: o.fn.load, load: function(G, J, K) { if (typeof G !== "string") { return this._load(G) } var I = G.indexOf(" "); if (I >= 0) { var E = G.slice(I, G.length); G = G.slice(0, I) } var H = "GET"; if (J) { if (o.isFunction(J)) { K = J; J = null } else { if (typeof J === "object") { J = o.param(J); H = "POST" } } } var F = this; o.ajax({ url: G, type: H, dataType: "html", data: J, complete: function(M, L) { if (L == "success" || L == "notmodified") { F.html(E ? o("<div/>").append(M.responseText.replace(/<script(.|\s)*?\/script>/g, "")).find(E) : M.responseText) } if (K) { F.each(K, [M.responseText, L, M]) } } }); return this }, serialize: function() { return o.param(this.serializeArray()) }, serializeArray: function() { return this.map(function() { return this.elements ? o.makeArray(this.elements) : this }).filter(function() { return this.name && !this.disabled && (this.checked || /select|textarea/i.test(this.nodeName) || /text|hidden|password/i.test(this.type)) }).map(function(E, F) { var G = o(this).val(); return G == null ? null : o.isArray(G) ? o.map(G, function(I, H) { return { name: F.name, value: I} }) : { name: F.name, value: G} }).get() } }); o.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","), function(E, F) { o.fn[F] = function(G) { return this.bind(F, G) } }); var r = e(); o.extend({ get: function(E, G, H, F) { if (o.isFunction(G)) { H = G; G = null } return o.ajax({ type: "GET", url: E, data: G, success: H, dataType: F }) }, getScript: function(E, F) { return o.get(E, null, F, "script") }, getJSON: function(E, F, G) { return o.get(E, F, G, "json") }, post: function(E, G, H, F) { if (o.isFunction(G)) { H = G; G = {} } return o.ajax({ type: "POST", url: E, data: G, success: H, dataType: F }) }, ajaxSetup: function(E) { o.extend(o.ajaxSettings, E) }, ajaxSettings: { url: location.href, global: true, type: "GET", contentType: "application/x-www-form-urlencoded", processData: true, async: true, xhr: function() { return l.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest() }, accepts: { xml: "application/xml, text/xml", html: "text/html", script: "text/javascript, application/javascript", json: "application/json, text/javascript", text: "text/plain", _default: "*/*"} }, lastModified: {}, ajax: function(M) { M = o.extend(true, M, o.extend(true, {}, o.ajaxSettings, M)); var W, F = /=\?(&|$)/g, R, V, G = M.type.toUpperCase(); if (M.data && M.processData && typeof M.data !== "string") { M.data = o.param(M.data) } if (M.dataType == "jsonp") { if (G == "GET") { if (!M.url.match(F)) { M.url += (M.url.match(/\?/) ? "&" : "?") + (M.jsonp || "callback") + "=?" } } else { if (!M.data || !M.data.match(F)) { M.data = (M.data ? M.data + "&" : "") + (M.jsonp || "callback") + "=?" } } M.dataType = "json" } if (M.dataType == "json" && (M.data && M.data.match(F) || M.url.match(F))) { W = "jsonp" + r++; if (M.data) { M.data = (M.data + "").replace(F, "=" + W + "$1") } M.url = M.url.replace(F, "=" + W + "$1"); M.dataType = "script"; l[W] = function(X) { V = X; I(); L(); l[W] = g; try { delete l[W] } catch (Y) { } if (H) { H.removeChild(T) } } } if (M.dataType == "script" && M.cache == null) { M.cache = false } if (M.cache === false && G == "GET") { var E = e(); var U = M.url.replace(/(\?|&)_=.*?(&|$)/, "$1_=" + E + "$2"); M.url = U + ((U == M.url) ? (M.url.match(/\?/) ? "&" : "?") + "_=" + E : "") } if (M.data && G == "GET") { M.url += (M.url.match(/\?/) ? "&" : "?") + M.data; M.data = null } if (M.global && !o.active++) { o.event.trigger("ajaxStart") } var Q = /^(\w+:)?\/\/([^\/?#]+)/.exec(M.url); if (M.dataType == "script" && G == "GET" && Q && (Q[1] && Q[1] != location.protocol || Q[2] != location.host)) { var H = document.getElementsByTagName("head")[0]; var T = document.createElement("script"); T.src = M.url; if (M.scriptCharset) { T.charset = M.scriptCharset } if (!W) { var O = false; T.onload = T.onreadystatechange = function() { if (!O && (!this.readyState || this.readyState == "loaded" || this.readyState == "complete")) { O = true; I(); L(); H.removeChild(T) } } } H.appendChild(T); return g } var K = false; var J = M.xhr(); if (M.username) { J.open(G, M.url, M.async, M.username, M.password) } else { J.open(G, M.url, M.async) } try { if (M.data) { J.setRequestHeader("Content-Type", M.contentType) } if (M.ifModified) { J.setRequestHeader("If-Modified-Since", o.lastModified[M.url] || "Thu, 01 Jan 1970 00:00:00 GMT") } J.setRequestHeader("X-Requested-With", "XMLHttpRequest"); J.setRequestHeader("Accept", M.dataType && M.accepts[M.dataType] ? M.accepts[M.dataType] + ", */*" : M.accepts._default) } catch (S) { } if (M.beforeSend && M.beforeSend(J, M) === false) { if (M.global && ! --o.active) { o.event.trigger("ajaxStop") } J.abort(); return false } if (M.global) { o.event.trigger("ajaxSend", [J, M]) } var N = function(X) { if (J.readyState == 0) { if (P) { clearInterval(P); P = null; if (M.global && ! --o.active) { o.event.trigger("ajaxStop") } } } else { if (!K && J && (J.readyState == 4 || X == "timeout")) { K = true; if (P) { clearInterval(P); P = null } R = X == "timeout" ? "timeout" : !o.httpSuccess(J) ? "error" : M.ifModified && o.httpNotModified(J, M.url) ? "notmodified" : "success"; if (R == "success") { try { V = o.httpData(J, M.dataType, M) } catch (Z) { R = "parsererror" } } if (R == "success") { var Y; try { Y = J.getResponseHeader("Last-Modified") } catch (Z) { } if (M.ifModified && Y) { o.lastModified[M.url] = Y } if (!W) { I() } } else { o.handleError(M, J, R) } L(); if (X) { J.abort() } if (M.async) { J = null } } } }; if (M.async) { var P = setInterval(N, 13); if (M.timeout > 0) { setTimeout(function() { if (J && !K) { N("timeout") } }, M.timeout) } } try { J.send(M.data) } catch (S) { o.handleError(M, J, null, S) } if (!M.async) { N() } function I() { if (M.success) { M.success(V, R) } if (M.global) { o.event.trigger("ajaxSuccess", [J, M]) } } function L() { if (M.complete) { M.complete(J, R) } if (M.global) { o.event.trigger("ajaxComplete", [J, M]) } if (M.global && ! --o.active) { o.event.trigger("ajaxStop") } } return J }, handleError: function(F, H, E, G) { if (F.error) { F.error(H, E, G) } if (F.global) { o.event.trigger("ajaxError", [H, F, G]) } }, active: 0, httpSuccess: function(F) { try { return !F.status && location.protocol == "file:" || (F.status >= 200 && F.status < 300) || F.status == 304 || F.status == 1223 } catch (E) { } return false }, httpNotModified: function(G, E) { try { var H = G.getResponseHeader("Last-Modified"); return G.status == 304 || H == o.lastModified[E] } catch (F) { } return false }, httpData: function(J, H, G) { var F = J.getResponseHeader("content-type"), E = H == "xml" || !H && F && F.indexOf("xml") >= 0, I = E ? J.responseXML : J.responseText; if (E && I.documentElement.tagName == "parsererror") { throw "parsererror" } if (G && G.dataFilter) { I = G.dataFilter(I, H) } if (typeof I === "string") { if (H == "script") { o.globalEval(I) } if (H == "json") { I = l["eval"]("(" + I + ")") } } return I }, param: function(E) { var G = []; function H(I, J) { G[G.length] = encodeURIComponent(I) + "=" + encodeURIComponent(J) } if (o.isArray(E) || E.jquery) { o.each(E, function() { H(this.name, this.value) }) } else { for (var F in E) { if (o.isArray(E[F])) { o.each(E[F], function() { H(F, this) }) } else { H(F, o.isFunction(E[F]) ? E[F]() : E[F]) } } } return G.join("&").replace(/%20/g, "+") } }); var m = {}, n, d = [["height", "marginTop", "marginBottom", "paddingTop", "paddingBottom"], ["width", "marginLeft", "marginRight", "paddingLeft", "paddingRight"], ["opacity"]]; function t(F, E) { var G = {}; o.each(d.concat.apply([], d.slice(0, E)), function() { G[this] = F }); return G } o.fn.extend({ show: function(J, L) { if (J) { return this.animate(t("show", 3), J, L) } else { for (var H = 0, F = this.length; H < F; H++) { var E = o.data(this[H], "olddisplay"); this[H].style.display = E || ""; if (o.css(this[H], "display") === "none") { var G = this[H].tagName, K; if (m[G]) { K = m[G] } else { var I = o("<" + G + " />").appendTo("body"); K = I.css("display"); if (K === "none") { K = "block" } I.remove(); m[G] = K } this[H].style.display = o.data(this[H], "olddisplay", K) } } return this } }, hide: function(H, I) { if (H) { return this.animate(t("hide", 3), H, I) } else { for (var G = 0, F = this.length; G < F; G++) { var E = o.data(this[G], "olddisplay"); if (!E && E !== "none") { o.data(this[G], "olddisplay", o.css(this[G], "display")) } this[G].style.display = "none" } return this } }, _toggle: o.fn.toggle, toggle: function(G, F) { var E = typeof G === "boolean"; return o.isFunction(G) && o.isFunction(F) ? this._toggle.apply(this, arguments) : G == null || E ? this.each(function() { var H = E ? G : o(this).is(":hidden"); o(this)[H ? "show" : "hide"]() }) : this.animate(t("toggle", 3), G, F) }, fadeTo: function(E, G, F) { return this.animate({ opacity: G }, E, F) }, animate: function(I, F, H, G) { var E = o.speed(F, H, G); return this[E.queue === false ? "each" : "queue"](function() { var K = o.extend({}, E), M, L = this.nodeType == 1 && o(this).is(":hidden"), J = this; for (M in I) { if (I[M] == "hide" && L || I[M] == "show" && !L) { return K.complete.call(this) } if ((M == "height" || M == "width") && this.style) { K.display = o.css(this, "display"); K.overflow = this.style.overflow } } if (K.overflow != null) { this.style.overflow = "hidden" } K.curAnim = o.extend({}, I); o.each(I, function(O, S) { var R = new o.fx(J, K, O); if (/toggle|show|hide/.test(S)) { R[S == "toggle" ? L ? "show" : "hide" : S](I) } else { var Q = S.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/), T = R.cur(true) || 0; if (Q) { var N = parseFloat(Q[2]), P = Q[3] || "px"; if (P != "px") { J.style[O] = (N || 1) + P; T = ((N || 1) / R.cur(true)) * T; J.style[O] = T + P } if (Q[1]) { N = ((Q[1] == "-=" ? -1 : 1) * N) + T } R.custom(T, N, P) } else { R.custom(T, S, "") } } }); return true }) }, stop: function(F, E) { var G = o.timers; if (F) { this.queue([]) } this.each(function() { for (var H = G.length - 1; H >= 0; H--) { if (G[H].elem == this) { if (E) { G[H](true) } G.splice(H, 1) } } }); if (!E) { this.dequeue() } return this } }); o.each({ slideDown: t("show", 1), slideUp: t("hide", 1), slideToggle: t("toggle", 1), fadeIn: { opacity: "show" }, fadeOut: { opacity: "hide"} }, function(E, F) { o.fn[E] = function(G, H) { return this.animate(F, G, H) } }); o.extend({ speed: function(G, H, F) { var E = typeof G === "object" ? G : { complete: F || !F && H || o.isFunction(G) && G, duration: G, easing: F && H || H && !o.isFunction(H) && H }; E.duration = o.fx.off ? 0 : typeof E.duration === "number" ? E.duration : o.fx.speeds[E.duration] || o.fx.speeds._default; E.old = E.complete; E.complete = function() { if (E.queue !== false) { o(this).dequeue() } if (o.isFunction(E.old)) { E.old.call(this) } }; return E }, easing: { linear: function(G, H, E, F) { return E + F * G }, swing: function(G, H, E, F) { return ((-Math.cos(G * Math.PI) / 2) + 0.5) * F + E } }, timers: [], fx: function(F, E, G) { this.options = E; this.elem = F; this.prop = G; if (!E.orig) { E.orig = {} } } }); o.fx.prototype = { update: function() { if (this.options.step) { this.options.step.call(this.elem, this.now, this) } (o.fx.step[this.prop] || o.fx.step._default)(this); if ((this.prop == "height" || this.prop == "width") && this.elem.style) { this.elem.style.display = "block" } }, cur: function(F) { if (this.elem[this.prop] != null && (!this.elem.style || this.elem.style[this.prop] == null)) { return this.elem[this.prop] } var E = parseFloat(o.css(this.elem, this.prop, F)); return E && E > -10000 ? E : parseFloat(o.curCSS(this.elem, this.prop)) || 0 }, custom: function(I, H, G) { this.startTime = e(); this.start = I; this.end = H; this.unit = G || this.unit || "px"; this.now = this.start; this.pos = this.state = 0; var E = this; function F(J) { return E.step(J) } F.elem = this.elem; if (F() && o.timers.push(F) == 1) { n = setInterval(function() { var K = o.timers; for (var J = 0; J < K.length; J++) { if (!K[J]()) { K.splice(J--, 1) } } if (!K.length) { clearInterval(n) } }, 13) } }, show: function() { this.options.orig[this.prop] = o.attr(this.elem.style, this.prop); this.options.show = true; this.custom(this.prop == "width" || this.prop == "height" ? 1 : 0, this.cur()); o(this.elem).show() }, hide: function() { this.options.orig[this.prop] = o.attr(this.elem.style, this.prop); this.options.hide = true; this.custom(this.cur(), 0) }, step: function(H) { var G = e(); if (H || G >= this.options.duration + this.startTime) { this.now = this.end; this.pos = this.state = 1; this.update(); this.options.curAnim[this.prop] = true; var E = true; for (var F in this.options.curAnim) { if (this.options.curAnim[F] !== true) { E = false } } if (E) { if (this.options.display != null) { this.elem.style.overflow = this.options.overflow; this.elem.style.display = this.options.display; if (o.css(this.elem, "display") == "none") { this.elem.style.display = "block" } } if (this.options.hide) { o(this.elem).hide() } if (this.options.hide || this.options.show) { for (var I in this.options.curAnim) { o.attr(this.elem.style, I, this.options.orig[I]) } } this.options.complete.call(this.elem) } return false } else { var J = G - this.startTime; this.state = J / this.options.duration; this.pos = o.easing[this.options.easing || (o.easing.swing ? "swing" : "linear")](this.state, J, 0, 1, this.options.duration); this.now = this.start + ((this.end - this.start) * this.pos); this.update() } return true } }; o.extend(o.fx, { speeds: { slow: 600, fast: 200, _default: 400 }, step: { opacity: function(E) { o.attr(E.elem.style, "opacity", E.now) }, _default: function(E) { if (E.elem.style && E.elem.style[E.prop] != null) { E.elem.style[E.prop] = E.now + E.unit } else { E.elem[E.prop] = E.now } } } }); if (document.documentElement.getBoundingClientRect) { o.fn.offset = function() { if (!this[0]) { return { top: 0, left: 0} } if (this[0] === this[0].ownerDocument.body) { return o.offset.bodyOffset(this[0]) } var G = this[0].getBoundingClientRect(), J = this[0].ownerDocument, F = J.body, E = J.documentElement, L = E.clientTop || F.clientTop || 0, K = E.clientLeft || F.clientLeft || 0, I = G.top + (self.pageYOffset || o.boxModel && E.scrollTop || F.scrollTop) - L, H = G.left + (self.pageXOffset || o.boxModel && E.scrollLeft || F.scrollLeft) - K; return { top: I, left: H} } } else { o.fn.offset = function() { if (!this[0]) { return { top: 0, left: 0} } if (this[0] === this[0].ownerDocument.body) { return o.offset.bodyOffset(this[0]) } o.offset.initialized || o.offset.initialize(); var J = this[0], G = J.offsetParent, F = J, O = J.ownerDocument, M, H = O.documentElement, K = O.body, L = O.defaultView, E = L.getComputedStyle(J, null), N = J.offsetTop, I = J.offsetLeft; while ((J = J.parentNode) && J !== K && J !== H) { M = L.getComputedStyle(J, null); N -= J.scrollTop, I -= J.scrollLeft; if (J === G) { N += J.offsetTop, I += J.offsetLeft; if (o.offset.doesNotAddBorder && !(o.offset.doesAddBorderForTableAndCells && /^t(able|d|h)$/i.test(J.tagName))) { N += parseInt(M.borderTopWidth, 10) || 0, I += parseInt(M.borderLeftWidth, 10) || 0 } F = G, G = J.offsetParent } if (o.offset.subtractsBorderForOverflowNotVisible && M.overflow !== "visible") { N += parseInt(M.borderTopWidth, 10) || 0, I += parseInt(M.borderLeftWidth, 10) || 0 } E = M } if (E.position === "relative" || E.position === "static") { N += K.offsetTop, I += K.offsetLeft } if (E.position === "fixed") { N += Math.max(H.scrollTop, K.scrollTop), I += Math.max(H.scrollLeft, K.scrollLeft) } return { top: N, left: I} } } o.offset = { initialize: function() { if (this.initialized) { return } var L = document.body, F = document.createElement("div"), H, G, N, I, M, E, J = L.style.marginTop, K = '<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>'; M = { position: "absolute", top: 0, left: 0, margin: 0, border: 0, width: "1px", height: "1px", visibility: "hidden" }; for (E in M) { F.style[E] = M[E] } F.innerHTML = K; L.insertBefore(F, L.firstChild); H = F.firstChild, G = H.firstChild, I = H.nextSibling.firstChild.firstChild; this.doesNotAddBorder = (G.offsetTop !== 5); this.doesAddBorderForTableAndCells = (I.offsetTop === 5); H.style.overflow = "hidden", H.style.position = "relative"; this.subtractsBorderForOverflowNotVisible = (G.offsetTop === -5); L.style.marginTop = "1px"; this.doesNotIncludeMarginInBodyOffset = (L.offsetTop === 0); L.style.marginTop = J; L.removeChild(F); this.initialized = true }, bodyOffset: function(E) { o.offset.initialized || o.offset.initialize(); var G = E.offsetTop, F = E.offsetLeft; if (o.offset.doesNotIncludeMarginInBodyOffset) { G += parseInt(o.curCSS(E, "marginTop", true), 10) || 0, F += parseInt(o.curCSS(E, "marginLeft", true), 10) || 0 } return { top: G, left: F} } }; o.fn.extend({ position: function() { var I = 0, H = 0, F; if (this[0]) { var G = this.offsetParent(), J = this.offset(), E = /^body|html$/i.test(G[0].tagName) ? { top: 0, left: 0} : G.offset(); J.top -= j(this, "marginTop"); J.left -= j(this, "marginLeft"); E.top += j(G, "borderTopWidth"); E.left += j(G, "borderLeftWidth"); F = { top: J.top - E.top, left: J.left - E.left} } return F }, offsetParent: function() { var E = this[0].offsetParent || document.body; while (E && (!/^body|html$/i.test(E.tagName) && o.css(E, "position") == "static")) { E = E.offsetParent } return o(E) } }); o.each(["Left", "Top"], function(F, E) { var G = "scroll" + E; o.fn[G] = function(H) { if (!this[0]) { return null } return H !== g ? this.each(function() { this == l || this == document ? l.scrollTo(!F ? H : o(l).scrollLeft(), F ? H : o(l).scrollTop()) : this[G] = H }) : this[0] == l || this[0] == document ? self[F ? "pageYOffset" : "pageXOffset"] || o.boxModel && document.documentElement[G] || document.body[G] : this[0][G] } }); o.each(["Height", "Width"], function(H, F) { var E = H ? "Left" : "Top", G = H ? "Right" : "Bottom"; o.fn["inner" + F] = function() { return this[F.toLowerCase()]() + j(this, "padding" + E) + j(this, "padding" + G) }; o.fn["outer" + F] = function(J) { return this["inner" + F]() + j(this, "border" + E + "Width") + j(this, "border" + G + "Width") + (J ? j(this, "margin" + E) + j(this, "margin" + G) : 0) }; var I = F.toLowerCase(); o.fn[I] = function(J) { return this[0] == l ? document.compatMode == "CSS1Compat" && document.documentElement["client" + F] || document.body["client" + F] : this[0] == document ? Math.max(document.documentElement["client" + F], document.body["scroll" + F], document.documentElement["scroll" + F], document.body["offset" + F], document.documentElement["offset" + F]) : J === g ? (this.length ? o.css(this[0], I) : null) : this.css(I, typeof J === "string" ? J : J + "px") } })
})();
/*
* jqModal - Minimalist Modaling with jQuery
*   (http://dev.iceburg.net/jquery/jqModal/)
*
* Copyright (c) 2007,2008 Brice Burgess <bhb@iceburg.net>
* Dual licensed under the MIT and GPL licenses:
*   http://www.opensource.org/licenses/mit-license.php
*   http://www.gnu.org/licenses/gpl.html
* 
* $Version: 07/06/2008 +r13
*/
(function($) {
    $.fn.jqm = function(o) {
        var p = {
            overlay: 50,
            overlayClass: 'jqmOverlay',
            closeClass: 'jqmClose',
            trigger: '.jqModal',
            ajax: F,
            ajaxText: '',
            target: F,
            modal: F,
            toTop: F,
            onShow: F,
            onHide: F,
            onLoad: F
        };
        return this.each(function() {
            if (this._jqm) return H[this._jqm].c = $.extend({}, H[this._jqm].c, o); s++; this._jqm = s;
            H[s] = { c: $.extend(p, $.jqm.params, o), a: F, w: $(this).addClass('jqmID' + s), s: s };
            if (p.trigger) $(this).jqmAddTrigger(p.trigger);
        });
    };

    $.fn.jqmAddClose = function(e) { return hs(this, e, 'jqmHide'); };
    $.fn.jqmAddTrigger = function(e) { return hs(this, e, 'jqmShow'); };
    $.fn.jqmShow = function(t) { return this.each(function() { $.jqm.open(this._jqm, t); }); };
    $.fn.jqmHide = function(t) { return this.each(function() { $.jqm.close(this._jqm, t) }); };

    $.jqm = {
        hash: {},
        open: function(s, t) {
            var h = H[s], c = h.c, cc = '.' + c.closeClass, z = (parseInt(h.w.css('z-index'))), z = (z > 0) ? z : 3000, o = $('<div></div>').css({ height: '100%', width: '100%', position: 'fixed', left: 0, top: 0, 'z-index': z - 1, opacity: c.overlay / 100 }); if (h.a) return F; h.t = t; h.a = true; h.w.css('z-index', z);
            if (c.modal) { if (!A[0]) L('bind'); A.push(s); }
            else if (c.overlay > 0) h.w.jqmAddClose(o);
            else o = F;

            h.o = (o) ? o.addClass(c.overlayClass).prependTo('body') : F;
            if (ie6) { $('html,body').css({ height: '100%', width: '100%' }); if (o) { o = o.css({ position: 'absolute' })[0]; for (var y in { Top: 1, Left: 1 }) o.style.setExpression(y.toLowerCase(), "(_=(document.documentElement.scroll" + y + " || document.body.scroll" + y + "))+'px'"); } }

            if (c.ajax) {
                var r = c.target || h.w, u = c.ajax, r = (typeof r == 'string') ? $(r, h.w) : $(r), u = (u.substr(0, 1) == '@') ? $(t).attr(u.substring(1)) : u;
                r.html(c.ajaxText).load(u, function() { if (c.onLoad) c.onLoad.call(this, h); if (cc) h.w.jqmAddClose($(cc, h.w)); e(h); });
            }
            else if (cc) h.w.jqmAddClose($(cc, h.w));

            if (c.toTop && h.o) h.w.before('<span id="jqmP' + h.w[0]._jqm + '"></span>').insertAfter(h.o);
            (c.onShow) ? c.onShow(h) : h.w.show(); e(h); return F;
        },
        close: function(s) {
            var h = H[s]; if (!h.a) return F; h.a = F;
            if (A[0]) { A.pop(); if (!A[0]) L('unbind'); }
            if (h.c.toTop && h.o) $('#jqmP' + h.w[0]._jqm).after(h.w).remove();
            if (h.c.onHide) h.c.onHide(h); else { h.w.hide(); if (h.o) h.o.remove(); } return F;
        },
        params: {}
    };
    var s = 0, H = $.jqm.hash, A = [], ie6 = $.browser.msie && ($.browser.version == "6.0"), F = false,
i = $('<iframe src="javascript:false;document.write(\'\');" class="jqm"></iframe>').css({ opacity: 0 }),
e = function(h) { if (ie6) if (h.o) h.o.html('<p style="width:100%;height:100%"/>').prepend(i); else if (!$('iframe.jqm', h.w)[0]) h.w.prepend(i); f(h); },
f = function(h) { try { $(':input:visible', h.w)[0].focus(); } catch (_) { } },
L = function(t) { $()[t]("keypress", m)[t]("keydown", m)[t]("mousedown", m); },
m = function(e) { var h = H[A[A.length - 1]], r = (!$(e.target).parents('.jqmID' + h.s)[0]); if (r) f(h); return !r; },
hs = function(w, t, c) {
    return w.each(function() {
        var s = this._jqm; $(t).each(function() {
            if (!this[c]) { this[c] = []; $(this).click(function() { for (var i in { jqmShow: 1, jqmHide: 1 }) for (var s in this[i]) if (H[this[i][s]]) H[this[i][s]].w[i](this); return F; }); } this[c].push(s);
        });
    });
};
})(jQuery);
jQuery.fn.editInPlace = function(options) { var settings = { url: "", params: "", field_type: "text", select_options: "", textarea_cols: "25", textarea_rows: "10", bg_over: "#ffc", bg_out: "transparent", saving_text: "Saving...", saving_image: "", default_text: "(Click here to add text)", select_text: "Choose new value", value_required: null, element_id: "element_id", update_value: "update_value", original_html: "original_html", save_button: '<input type="submit" class="inplace_save" value="Save"/>', cancel_button: '<input type="submit" class="inplace_cancel" value="Cancel"/>', show_buttons: false, on_blur: "save", callback: null, success: null, error: function(request) { alert("Failed to save value: " + request.responseText || 'Unspecified Error') } }; if (options) { jQuery.extend(settings, options) } if (settings.saving_image != "") { var loading_image = new Image(); loading_image.src = settings.saving_image } String.prototype.trim = function() { return this.replace(/^\s+/, '').replace(/\s+$/, '') }; String.prototype.escape_html = function() { return this.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;") }; return this.each(function() { if (jQuery(this).html() == "") jQuery(this).html(settings.default_text); var editing = false; var original_element = jQuery(this); var click_count = 0; jQuery(this).mouseover(function() { jQuery(this).css("background", settings.bg_over) }).mouseout(function() { jQuery(this).css("background", settings.bg_out) }).click(function() { click_count++; if (!editing) { editing = true; var original_html = jQuery(this).html(); var buttons_code = (settings.show_buttons) ? settings.save_button + ' ' + settings.cancel_button : ''; if (original_html == settings.default_text) jQuery(this).html(''); if (settings.field_type == "textarea") { var use_field_type = '<textarea name="inplace_value" class="inplace_field" rows="' + settings.textarea_rows + '" cols="' + settings.textarea_cols + '">' + jQuery(this).text().trim().escape_html() + '</textarea>' } else if (settings.field_type == "text") { var use_field_type = '<input type="text" name="inplace_value" class="inplace_field" value="' + jQuery(this).text().trim().escape_html() + '" />' } else if (settings.field_type == "select") { var optionsArray = settings.select_options.split(','); var use_field_type = '<select name="inplace_value" class="inplace_field"><option value="">' + settings.select_text + '</option>'; for (var i = 0; i < optionsArray.length; i++) { var optionsValuesArray = optionsArray[i].split(':'); var use_value = optionsValuesArray[1] || optionsValuesArray[0]; var selected = use_value == original_html ? 'selected="selected" ' : ''; use_field_type += '<option ' + selected + 'value="' + use_value.trim().escape_html() + '">' + optionsValuesArray[0].trim().escape_html() + '</option>' } use_field_type += '</select>' } jQuery(this).html('<form class="inplace_form" style="display: inline; margin: 0; padding: 0;">' + use_field_type + ' ' + buttons_code + '</form>') } if (click_count == 1) { function cancelAction() { editing = false; click_count = 0; original_element.css("background", settings.bg_out); original_element.html(original_html); return false } function saveAction() { original_element.css("background", settings.bg_out); var this_elem = jQuery(this); var new_html = (this_elem.is('form')) ? this_elem.children(0).val() : this_elem.parent().children(0).val(); if (settings.saving_image != "") { var saving_message = '<img src="' + settings.saving_image + '" alt="Saving..." />' } else { var saving_message = settings.saving_text } original_element.html(saving_message); if (settings.params != "") { settings.params = "&" + settings.params } if (settings.callback) { html = settings.callback(original_element.attr("id"), new_html, original_html, settings.params); editing = false; click_count = 0; if (html) { original_element.html(html || new_html) } else { alert("Failed to save value: " + new_html); original_element.html(original_html) } } else if (settings.value_required && (new_html == "" || new_html == undefined)) { editing = false; click_count = 0; original_element.html(original_html); alert("Error: You must enter a value to save this field") } else { jQuery.ajax({ url: settings.url, type: "POST", data: settings.update_value + '=' + new_html + '&' + settings.element_id + '=' + original_element.attr("id") + settings.params + '&' + settings.original_html + '=' + original_html, dataType: "html", complete: function(request) { editing = false; click_count = 0 }, success: function(html) { var new_text = html || settings.default_text; original_element.html(new_text); if (settings.success) settings.success(html, original_element) }, error: function(request) { original_element.html(original_html); if (settings.error) settings.error(request, original_element) } }) } return false } original_element.children("form").children(".inplace_field").focus().select(); original_element.children("form").children(".inplace_cancel").click(cancelAction); original_element.children("form").children(".inplace_save").click(saveAction); if (!settings.show_buttons) { if (settings.on_blur == "save") original_element.children("form").children(".inplace_field").blur(saveAction); else original_element.children("form").children(".inplace_field").blur(cancelAction) } $(document).keyup(function(event) { if (event.keyCode == 27) { cancelAction() } }); original_element.children("form").submit(saveAction) } }) }) };
/*
* File:        jquery.dataTables.min.js
* Version:     1.4.0
* Author:      Allan Jardine (www.sprymedia.co.uk)
* 
* Copyright 2008-2009 Allan Jardine, all rights reserved.
*
* This source file is free software, under either the GPL v2 license or a
* BSD style license, as supplied with this software.
* 
* This source file is distributed in the hope that it will be useful, but 
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 
* or FITNESS FOR A PARTICULAR PURPOSE. See the license files for details.
*/
(function($) {
    $.fn.dataTableSettings = []; $.fn.dataTableExt = {}; $.fn.dataTableExt.oApi = {};
    $.fn.dataTableExt.oPagination = { two_button: { fnInit: function(oSettings, fnCallbackDraw) {
        oSettings.nPrevious = document.createElement("div");
        oSettings.nNext = document.createElement("div"); if (oSettings.sTableId !== "") {
            oSettings.nPaginate.setAttribute("id", oSettings.sTableId + "_paginate");
            oSettings.nPrevious.setAttribute("id", oSettings.sTableId + "_previous"); oSettings.nNext.setAttribute("id", oSettings.sTableId + "_next")
        } oSettings.nPrevious.className = "paginate_disabled_previous"; oSettings.nNext.className = "paginate_disabled_next";
        oSettings.nPaginate.appendChild(oSettings.nPrevious); oSettings.nPaginate.appendChild(oSettings.nNext);
        $(oSettings.nPaginate).insertAfter(oSettings.nTable); $(oSettings.nPrevious).click(function() {
            oSettings.iDisplayStart -= oSettings.iDisplayLength;
            if (oSettings.iDisplayStart < 0) { oSettings.iDisplayStart = 0 } fnCallbackDraw(oSettings)
        }); $(oSettings.nNext).click(function() {
            if (oSettings.iDisplayStart + oSettings.iDisplayLength < oSettings.aiDisplay.length) {
                oSettings.iDisplayStart += oSettings.iDisplayLength
            } fnCallbackDraw(oSettings)
        })
    }, fnUpdate: function(oSettings, fnCallbackDraw) {
        oSettings.nPrevious.className = (oSettings.iDisplayStart === 0) ? "paginate_disabled_previous" : "paginate_enabled_previous";
        oSettings.nNext.className = (oSettings.iDisplayEnd == oSettings.aiDisplay.length) ? "paginate_disabled_next" : "paginate_enabled_next"
    } 
    }, iFullNumbersShowPages: 5, full_numbers: { fnInit: function(oSettings, fnCallbackDraw) {
        var nFirst = document.createElement("span");
        var nPrevious = document.createElement("span"); var nList = document.createElement("span");
        var nNext = document.createElement("span"); var nLast = document.createElement("span");
        nFirst.innerHTML = oSettings.oLanguage.oPaginate.sFirst; nPrevious.innerHTML = oSettings.oLanguage.oPaginate.sPrevious;
        nNext.innerHTML = oSettings.oLanguage.oPaginate.sNext; nLast.innerHTML = oSettings.oLanguage.oPaginate.sLast;
        nFirst.className = "paginate_button first"; nPrevious.className = "paginate_button previous";
        nNext.className = "paginate_button next"; nLast.className = "paginate_button last"; oSettings.nPaginate.appendChild(nFirst);
        oSettings.nPaginate.appendChild(nPrevious); oSettings.nPaginate.appendChild(nList);
        oSettings.nPaginate.appendChild(nNext); oSettings.nPaginate.appendChild(nLast); $(nFirst).click(function() {
            oSettings.iDisplayStart = 0;
            fnCallbackDraw(oSettings)
        }); $(nPrevious).click(function() {
            oSettings.iDisplayStart -= oSettings.iDisplayLength;
            if (oSettings.iDisplayStart < 0) { oSettings.iDisplayStart = 0 } fnCallbackDraw(oSettings)
        }); $(nNext).click(function() {
            if (oSettings.iDisplayStart + oSettings.iDisplayLength < oSettings.aiDisplay.length) {
                oSettings.iDisplayStart += oSettings.iDisplayLength
            } fnCallbackDraw(oSettings)
        }); $(nLast).click(function() {
            var iPages = parseInt((oSettings.aiDisplay.length - 1) / oSettings.iDisplayLength, 10) + 1;
            oSettings.iDisplayStart = (iPages - 1) * oSettings.iDisplayLength; fnCallbackDraw(oSettings)
        }); $("span", oSettings.nPaginate).bind("mousedown", function() { return false }); $("span", oSettings.nPaginate).bind("selectstart", function() {
            return false
        }); oSettings.nPaginateList = nList
    }, fnUpdate: function(oSettings, fnCallbackDraw) {
        var iPageCount = jQuery.fn.dataTableExt.oPagination.iFullNumbersShowPages;
        var iPageCountHalf = Math.floor(iPageCount / 2); var iPages = parseInt((oSettings.aiDisplay.length - 1) / oSettings.iDisplayLength, 10) + 1;
        var iCurrentPage = parseInt(oSettings.iDisplayStart / oSettings.iDisplayLength, 10) + 1;
        var sList = ""; var iStartButton; var iEndButton; if (iPages < iPageCount) {
            iStartButton = 1;
            iEndButton = iPages
        } else {
            if (iCurrentPage <= iPageCountHalf) {
                iStartButton = 1; iEndButton = iPageCount
            } else {
                if (iCurrentPage >= (iPages - iPageCountHalf)) {
                    iStartButton = iPages - iPageCount + 1;
                    iEndButton = iPages
                } else {
                    iStartButton = iCurrentPage - Math.ceil(iPageCount / 2) + 1; iEndButton = iStartButton + iPageCount - 1
                } 
            } 
        } for (var i = iStartButton; i <= iEndButton; i++) {
            if (iCurrentPage != i) {
                sList += '<span class="paginate_button">' + i + "</span>"
            } else { sList += '<span class="paginate_active">' + i + "</span>" } 
        } oSettings.nPaginateList.innerHTML = sList;
        $("span", oSettings.nPaginateList).bind("mousedown", function() { return false }); $("span", oSettings.nPaginateList).bind("selectstart", function() {
            return false
        }); $("span", oSettings.nPaginateList).click(function() {
            var iTarget = (this.innerHTML * 1) - 1;
            oSettings.iDisplayStart = iTarget * oSettings.iDisplayLength; fnCallbackDraw(oSettings);
            return false
        })
    } }
    }; $.fn.dataTableExt.oSort = { "string-asc": function(a, b) {
        var x = a.toLowerCase();
        var y = b.toLowerCase(); return ((x < y) ? -1 : ((x > y) ? 1 : 0))
    }, "string-desc": function(a, b) {
        var x = a.toLowerCase();
        var y = b.toLowerCase(); return ((x < y) ? 1 : ((x > y) ? -1 : 0))
    }, "html-asc": function(a, b) {
        var x = a.replace(/<.*?>/g, "").toLowerCase();
        var y = b.replace(/<.*?>/g, "").toLowerCase(); return ((x < y) ? -1 : ((x > y) ? 1 : 0))
    }, "html-desc": function(a, b) {
        var x = a.replace(/<.*?>/g, "").toLowerCase();
        var y = b.replace(/<.*?>/g, "").toLowerCase(); return ((x < y) ? 1 : ((x > y) ? -1 : 0))
    }, "date-asc": function(a, b) {
        var x = Date.parse(a);
        var y = Date.parse(b); if (isNaN(x)) { x = Date.parse("01/01/1970 00:00:00") } if (isNaN(y)) {
            y = Date.parse("01/01/1970 00:00:00")
        } return x - y
    }, "date-desc": function(a, b) {
        var x = Date.parse(a); var y = Date.parse(b); if (isNaN(x)) {
            x = Date.parse("01/01/1970 00:00:00")
        } if (isNaN(y)) { y = Date.parse("01/01/1970 00:00:00") } return y - x
    }, "numeric-asc": function(a, b) {
        var x = a == "-" ? 0 : a;
        var y = b == "-" ? 0 : b; return x - y
    }, "numeric-desc": function(a, b) {
        var x = a == "-" ? 0 : a; var y = b == "-" ? 0 : b;
        return y - x
    } 
    }; $.fn.dataTableExt.aTypes = [function(sData) {
        var sValidChars = "0123456789.-";
        var Char; for (i = 0; i < sData.length; i++) {
            Char = sData.charAt(i); if (sValidChars.indexOf(Char) == -1) {
                return null
            } 
        } return "numeric"
    }, function(sData) {
        if (!isNaN(Date.parse(sData))) { return "date" } return null
    } ]; $.fn.dataTableExt._oExternConfig = { iNextUnique: 0 }; $.fn.dataTable = function(oInit) {
        var _aoSettings = $.fn.dataTableSettings;
        function classSettings() {
            this.sInstance = null; this.oFeatures = { bPaginate: true, bLengthChange: true, bFilter: true, bSort: true, bInfo: true, bAutoWidth: true, bProcessing: false, bSortClasses: true, bStateSave: false };
            this.oLanguage = { sProcessing: "Processing...", sLengthMenu: "Show _MENU_ entries", sZeroRecords: "No matching records found", sInfo: "Showing _START_ to _END_ of _TOTAL_ entries", sInfoEmpty: "Showing 0 to 0 of 0 entries", sInfoFiltered: "(filtered from _MAX_ total entries)", sInfoPostFix: "", sSearch: "Search:", sUrl: "", oPaginate: { sFirst: "First", sPrevious: "Previous", sNext: "Next", sLast: "Last"} };
            this.aoData = []; this.aiDisplay = []; this.aiDisplayMaster = []; this.aoColumns = []; this.iNextId = 0;
            this.asDataSearch = []; this.sPreviousSearch = ""; this.asPreSearchCols = []; this.nInfo = null;
            this.nProcessing = null; this.iDisplayLength = 10; this.iDisplayStart = 0; this.iDisplayEnd = 10;
            this.aaSorting = [[0, "asc"]]; this.asStripClasses = ["odd", "even"]; this.fnRowCallback = null;
            this.fnHeaderCallback = null; this.fnFooterCallback = null; this.fnDrawCallback = null; this.fnInitComplete = null;
            this.nFooter = null; this.sTableId = ""; this.nTable = null; this.iDefaultSortIndex = 0; this.bInitialised = false;
            this.nOpenRow = null; this.nPaginate = null; this.nPrevious = null; this.nNext = null; this.sDomPositioning = "lfrtip";
            this.sPaginationType = "two_button"; this.sAjaxSource = null; this.iCookieDuration = 60 * 60 * 2
        } this.oApi = {}; this.fnDraw = function() { _fnReDraw(_fnSettingsFromNode(this[0])) }; this.fnFilter = function(sInput, iColumn, bEscapeRegex) {
            var oSettings = _fnSettingsFromNode(this[0]);
            if (typeof iColumn == "undefined" || iColumn === null) {
                _fnFilterComplete(oSettings, sInput, 1, bEscapeRegex)
            } else {
                oSettings.asPreSearchCols[iColumn] = sInput; _fnFilterComplete(oSettings, oSettings.sPreviousSearch, 1, bEscapeRegex)
            } 
        }; this.fnSettings = function(nNode) { return _fnSettingsFromNode(this[0]) }; this.fnSort = function(aaSort) {
            var oSettings = _fnSettingsFromNode(this[0]);
            oSettings.aaSorting = aaSort; _fnSort(oSettings)
        }; this.fnAddData = function(mData, bRedraw) {
            var aiReturn = [];
            var iTest; if (typeof bRedraw == "undefined") { bRedraw = true } var oSettings = _fnSettingsFromNode(this[0]);
            if (typeof mData[0] == "object") {
                for (var i = 0; i < mData.length; i++) {
                    iTest = _fnAddData(oSettings, mData[i]);
                    if (iTest == -1) { return aiReturn } aiReturn.push(iTest)
                } 
            } else {
                iTest = _fnAddData(oSettings, mData);
                if (iTest == -1) { return aiReturn } aiReturn.push(iTest)
            } oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
            _fnBuildSearchArray(oSettings, 1); if (bRedraw) { _fnReDraw(oSettings) } return aiReturn
        }; this.fnDeleteRow = function(iAODataIndex, fnCallBack) {
            var oSettings = _fnSettingsFromNode(this[0]);
            var i; for (i = 0; i < oSettings.aiDisplayMaster.length; i++) {
                if (oSettings.aiDisplayMaster[i] == iAODataIndex) {
                    oSettings.aiDisplayMaster.splice(i, 1);
                    break
                } 
            } for (i = 0; i < oSettings.aiDisplay.length; i++) {
                if (oSettings.aiDisplay[i] == iAODataIndex) {
                    oSettings.aiDisplay.splice(i, 1)
                } 
            } _fnBuildSearchArray(oSettings, 1); if (typeof fnCallBack == "function") {
                fnCallBack.call(this)
            } if (oSettings.iDisplayStart > oSettings.aiDisplay.length) {
                oSettings.iDisplayStart -= oSettings.iDisplayLength
            } _fnCalculateEnd(oSettings); _fnDraw(oSettings); return oSettings.aoData[iAODataIndex]._aData.slice()
        }; this.fnClearTable = function() {
            var oSettings = _fnSettingsFromNode(this[0]); oSettings.aoData.length = 0;
            oSettings.aiDisplayMaster.length = 0; oSettings.aiDisplay.length = 0; _fnCalculateEnd(oSettings);
            _fnDraw(oSettings)
        }; this.fnOpen = function(nTr, sHtml, sClass) {
            var oSettings = _fnSettingsFromNode(this[0]);
            if (oSettings.nOpenRow !== null) { this.fnClose() } var nNewRow = document.createElement("tr");
            var nNewCell = document.createElement("td"); nNewRow.appendChild(nNewCell); nNewRow.className = sClass;
            nNewCell.colSpan = oSettings.aoColumns.length; nNewCell.innerHTML = sHtml; $(nNewRow).insertAfter(nTr);
            oSettings.nOpenRow = nNewRow
        }; this.fnClose = function() {
            var oSettings = _fnSettingsFromNode(this[0]);
            $(oSettings.nOpenRow).remove(); oSettings.nOpenRow = null
        }; this.fnGetData = function(iRow) {
            var oSettings = _fnSettingsFromNode(this[0]);
            var aaData = _fnGetDataMaster(oSettings); if (typeof iRow != "undefined") {
                return aaData[iRow]
            } return aaData
        }; this.fnGetNodes = function() {
            return _fnGetTrNodes(_fnSettingsFromNode(this[0]))
        }; this.fnGetPosition = function(nNode) {
            var oSettings = _fnSettingsFromNode(this[0]); var i;
            if (nNode.nodeName == "TR") {
                for (i = 0; i < oSettings.aoData.length; i++) {
                    if (oSettings.aoData[i].nTr == nNode) {
                        return i
                    } 
                } 
            } else {
                if (nNode.nodeName == "TD") {
                    for (i = 0; i < oSettings.aoData.length; i++) {
                        var iCorrector = 0;
                        for (var j = 0; j < oSettings.aoColumns.length; j++) {
                            if (oSettings.aoColumns[j].bVisible) {
                                if (oSettings.aoData[i].nTr.getElementsByTagName("td")[j - iCorrector] == nNode) {
                                    return [i, j - iCorrector]
                                } 
                            } else { iCorrector++ } 
                        } 
                    } 
                } 
            } return null
        }; this.fnUpdate = function(mData, iRow, iColumn, bRedraw) {
            var oSettings = _fnSettingsFromNode(this[0]);
            var iVisibleColumn; if (typeof bRedraw == "undefined") { bRedraw = true } if (typeof mData != "object") {
                oSettings.aoData[iRow]._aData[iColumn] = mData;
                iVisibleColumn = _fnColumnIndexToVisible(oSettings, iColumn); if (iVisibleColumn !== null) {
                    oSettings.aoData[iRow].nTr.getElementsByTagName("td")[iVisibleColumn].innerHTML = mData
                } 
            } else {
                if (mData.length != oSettings.aoColumns.length) {
                    alert("Warning: An array passed to fnUpdate must have the same number of columns as the table in question - in this case " + oSettings.aoColumns.length);
                    return 1
                } for (var i = 0; i < mData.length; i++) {
                    oSettings.aoData[iRow]._aData[i] = mData[i];
                    iVisibleColumn = _fnColumnIndexToVisible(oSettings, i); if (iVisibleColumn !== null) {
                        oSettings.aoData[iRow].nTr.getElementsByTagName("td")[iVisibleColumn].innerHTML = mData[i]
                    } 
                } 
            } _fnBuildSearchArray(oSettings, 1); if (bRedraw) { _fnReDraw(oSettings) } return 0
        }; function _fnExternApiFunc(sFunc) {
            return function() {
                var aArgs = [_fnSettingsFromNode(this[0])].concat(Array.prototype.slice.call(arguments));
                return $.fn.dataTableExt.oApi[sFunc].apply(this, aArgs)
            } 
        } var bApi = false; for (var sFunc in $.fn.dataTableExt.oApi) {
            if (sFunc) {
                this[sFunc] = _fnExternApiFunc(sFunc);
                bApi = true
            } 
        } function _fnInitalise(oSettings) {
            if (oSettings.bInitialised === false) {
                setTimeout(function() {
                    _fnInitalise(oSettings)
                }, 200); return
            } _fnAddOptionsHtml(oSettings); _fnDrawHead(oSettings); if (oSettings.oFeatures.bSort) {
                _fnSort(oSettings)
            } else {
                oSettings.aiDisplay = oSettings.aiDisplayMaster.slice(); _fnCalculateEnd(oSettings);
                _fnDraw(oSettings)
            } if (oSettings.sAjaxSource !== null) {
                _fnProcessingDisplay(oSettings, true);
                $.getJSON(oSettings.sAjaxSource, null, function(json) {
                    for (var i = 0; i < json.aaData.length;
i++) { _fnAddData(oSettings, json.aaData[i]) } oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
                    _fnCalculateEnd(oSettings); _fnDraw(oSettings); if (oSettings.oFeatures.bSort) {
                        _fnSortingClasses(oSettings)
                    } _fnProcessingDisplay(oSettings, false)
                })
            } if (oSettings.oFeatures.bSort) {
                _fnSortingClasses(oSettings)
            } if (typeof oSettings.fnInitComplete == "function") { oSettings.fnInitComplete() } 
        } function _fnLanguageProcess(oSettings, oLanguage) {
            if (typeof oLanguage.sProcessing != "undefined") {
                oSettings.oLanguage.sProcessing = oLanguage.sProcessing
            } if (typeof oLanguage.sLengthMenu != "undefined") {
                oSettings.oLanguage.sLengthMenu = oLanguage.sLengthMenu
            } if (typeof oLanguage.sZeroRecords != "undefined") {
                oSettings.oLanguage.sZeroRecords = oLanguage.sZeroRecords
            } if (typeof oLanguage.sInfo != "undefined") {
                oSettings.oLanguage.sInfo = oLanguage.sInfo
            } if (typeof oLanguage.sInfoEmpty != "undefined") {
                oSettings.oLanguage.sInfoEmpty = oLanguage.sInfoEmpty
            } if (typeof oLanguage.sInfoFiltered != "undefined") {
                oSettings.oLanguage.sInfoFiltered = oLanguage.sInfoFiltered
            } if (typeof oLanguage.sInfoPostFix != "undefined") {
                oSettings.oLanguage.sInfoPostFix = oLanguage.sInfoPostFix
            } if (typeof oLanguage.sSearch != "undefined") {
                oSettings.oLanguage.sSearch = oLanguage.sSearch
            } if (typeof oLanguage.oPaginate != "undefined") {
                if (typeof oLanguage.oPaginate != "undefined") {
                    oSettings.oLanguage.oPaginate.sFirst = oLanguage.oPaginate.sFirst
                } if (typeof oLanguage.oPaginate != "undefined") {
                    oSettings.oLanguage.oPaginate.sPrevious = oLanguage.oPaginate.sPrevious
                } if (typeof oLanguage.oPaginate != "undefined") {
                    oSettings.oLanguage.oPaginate.sNext = oLanguage.oPaginate.sNext
                } if (typeof oLanguage.oPaginate != "undefined") {
                    oSettings.oLanguage.oPaginate.sLast = oLanguage.oPaginate.sLast
                } 
            } _fnInitalise(oSettings)
        } function _fnAddColumn(oSettings, oOptions) {
            oSettings.aoColumns[oSettings.aoColumns.length++] = { sType: null, _bAutoType: true, bVisible: true, bSearchable: true, bSortable: true, sTitle: null, sWidth: null, sClass: null, fnRender: null, iDataSort: oSettings.aoColumns.length - 1 };
            if (typeof oOptions != "undefined" && oOptions !== null) {
                var iLength = oSettings.aoColumns.length - 1;
                if (typeof oOptions.sType != "undefined") {
                    oSettings.aoColumns[iLength].sType = oOptions.sType;
                    oSettings.aoColumns[iLength]._bAutoType = false
                } if (typeof oOptions.bVisible != "undefined") {
                    oSettings.aoColumns[iLength].bVisible = oOptions.bVisible
                } if (typeof oOptions.bSearchable != "undefined") {
                    oSettings.aoColumns[iLength].bSearchable = oOptions.bSearchable
                } if (typeof oOptions.bSortable != "undefined") {
                    oSettings.aoColumns[iLength].bSortable = oOptions.bSortable
                } if (typeof oOptions.sTitle != "undefined") {
                    oSettings.aoColumns[iLength].sTitle = oOptions.sTitle
                } if (typeof oOptions.sWidth != "undefined") {
                    oSettings.aoColumns[iLength].sWidth = oOptions.sWidth
                } if (typeof oOptions.sClass != "undefined") {
                    oSettings.aoColumns[iLength].sClass = oOptions.sClass
                } if (typeof oOptions.fnRender != "undefined") {
                    oSettings.aoColumns[iLength].fnRender = oOptions.fnRender
                } if (typeof oOptions.iDataSort != "undefined") {
                    oSettings.aoColumns[iLength].iDataSort = oOptions.iDataSort
                } 
            } oSettings.asPreSearchCols[oSettings.asPreSearchCols.length++] = ""
        } function _fnAddData(oSettings, aData) {
            if (aData.length != oSettings.aoColumns.length) {
                return -1
            } var iThisIndex = oSettings.aoData.length; oSettings.aoData.push({ _iId: oSettings.iNextId++, _aData: aData.slice(), nTr: document.createElement("tr") });
            var nTd; for (var i = 0; i < aData.length; i++) {
                if (oSettings.aoColumns[i].bVisible) {
                    nTd = document.createElement("td");
                    nTd.innerHTML = (typeof oSettings.aoColumns[i].fnRender == "function") ? oSettings.aoColumns[i].fnRender({ iDataRow: iThisIndex, iDataColumn: i, aData: _fnGetDataMaster(oSettings) }) : nTd.innerHTML = aData[i];
                    if (oSettings.aoColumns[i].sClass !== null) {
                        nTd.className = oSettings.aoColumns[i].sClass
                    } if (oSettings.aoColumns[i]._bAutoType && oSettings.aoColumns[i].sType != "string") {
                        if (oSettings.aoColumns[i].sType === null) {
                            oSettings.aoColumns[i].sType = _fnDetectType(aData[i])
                        } else {
                            if (oSettings.aoColumns[i].sType == "date" || oSettings.aoColumns[i].sType == "numeric") {
                                oSettings.aoColumns[i].sType = _fnDetectType(aData[i])
                            } 
                        } 
                    } oSettings.aoData[iThisIndex].nTr.appendChild(nTd)
                } 
            } oSettings.aiDisplayMaster.push(iThisIndex);
            return iThisIndex
        } function _fnGatherData(oSettings) {
            var nDataNodes; var iDataLength = $("tbody tr").length;
            var iLoop; var i, j; if ($("thead th", oSettings.nTable).length != oSettings.aoColumns.length) {
                alert("Warning - columns do not match")
            } oSettings.nHeader = $("thead", oSettings.nTable)[0]; if (typeof $("tfoot", oSettings.nTable)[0] != "undefined") {
                oSettings.nFooter = $("tfoot", oSettings.nTable)[0]
            } $("tbody tr", oSettings.nTable).each(function() {
                var iThisIndex = oSettings.aoData.length;
                oSettings.aoData.push({ _iId: oSettings.iNextId++, _aData: [], nTr: this }); oSettings.aiDisplayMaster.push(iThisIndex);
                var aLocalData = oSettings.aoData[iThisIndex]._aData; $("td", this).each(function(i) {
                    aLocalData[i] = this.innerHTML
                })
            }); var iCorrector = 0; for (i = 0; i < oSettings.aoColumns.length; i++) {
                if (oSettings.aoColumns[i].sTitle === null) {
                    oSettings.aoColumns[i].sTitle = $("thead th:nth-child(" + (i + 1) + ")", oSettings.nTable).html()
                } if (oSettings.aoColumns[i]._bAutoType) {
                    iLoop = oSettings.aoData.length; if (iLoop === 0) {
                        oSettings.aoColumns[i].sType = "string"
                    } for (j = 0; j < iLoop; j++) {
                        if (oSettings.aoColumns[i].sType === null) {
                            oSettings.aoColumns[i].sType = _fnDetectType(oSettings.aoData[j]._aData[i])
                        } else {
                            if (oSettings.aoColumns[i].sType == "date" || oSettings.aoColumns[i].sType == "numeric") {
                                oSettings.aoColumns[i].sType = _fnDetectType(oSettings.aoData[j]._aData[i])
                            } 
                        } 
                    } 
                } if (typeof oSettings.aoColumns[i].fnRender == "function") {
                    iLoop = oSettings.aoData.length;
                    var aData = _fnGetDataMaster(oSettings); for (j = 0; j < iLoop; j++) {
                        oSettings.aoData[j].nTr.getElementsByTagName("td")[i - iCorrector].innerHTML = oSettings.aoColumns[i].fnRender({ iDataRow: j, iDataColumn: i, aData: aData })
                    } 
                } if (!oSettings.aoColumns[i].bVisible) {
                    iLoop = oSettings.aoData.length; for (j = 0; j < iLoop;
j++) {
                        var nRemove = oSettings.aoData[j].nTr.getElementsByTagName("td")[i - iCorrector];
                        nRemove.parentNode.removeChild(nRemove)
                    } iCorrector++
                } 
            } 
        } function _fnDrawHead(oSettings) {
            var i;
            var nThOriginals = $("thead th", oSettings.nTable); if (nThOriginals.length == oSettings.aoColumns.length) {
                for (i = 0;
i < oSettings.aoColumns.length; i++) {
                    if (oSettings.aoColumns[i].bVisible) {
                        if (oSettings.aoColumns[i].sWidth !== null) {
                            nThOriginals[i].style.width = oSettings.aoColumns[i].sWidth
                        } if (oSettings.aoColumns[i].sTitle != nThOriginals[i].innerHTML) {
                            nThOriginals[i].innerHTML = oSettings.aoColumns[i].sTitle
                        } 
                    } else { nThOriginals[i].parentNode.removeChild(nThOriginals[i]) } 
                } 
            } else {
                var nTh; var nTr = document.createElement("tr");
                for (i = 0; i < oSettings.aoColumns.length; i++) {
                    if (oSettings.aoColumns[i].bVisible) {
                        nTh = document.createElement("th");
                        if (typeof nThOriginals[i] != "undefined" && nThOriginals[i].className !== "") {
                            nTh.className = nThOriginals[i].className
                        } if (oSettings.aoColumns[i].sWidth !== null) {
                            nTh.style.width = oSettings.aoColumns[i].sWidth
                        } nTh.innerHTML = oSettings.aoColumns[i].sTitle; nTr.appendChild(nTh)
                    } 
                } $("thead", oSettings.nTable).html("")[0].appendChild(nTr)
            } if (oSettings.oFeatures.bSort) {
                $("thead th", oSettings.nTable).click(function(e) {
                    var iDataIndex = $("thead th", oSettings.nTable).index(this);
                    iDataIndex = _fnVisibleToColumnIndex(oSettings, iDataIndex); if (oSettings.aoColumns[iDataIndex].bSortable === false) {
                        return
                    } _fnProcessingDisplay(oSettings, true); setTimeout(function() {
                        if (e.shiftKey) {
                            var bFound = false;
                            for (var i = 0; i < oSettings.aaSorting.length; i++) {
                                if (oSettings.aaSorting[i][0] == iDataIndex) {
                                    if (oSettings.aaSorting[i][1] == "asc") {
                                        oSettings.aaSorting[i][1] = "desc"
                                    } else { oSettings.aaSorting.splice(i, 1) } bFound = true; break
                                } 
                            } if (bFound === false) {
                                oSettings.aaSorting.push([iDataIndex, "asc"])
                            } 
                        } else {
                            if (oSettings.aaSorting.length == 1 && oSettings.aaSorting[0][0] == iDataIndex) {
                                oSettings.aaSorting[0][1] = oSettings.aaSorting[0][1] == "asc" ? "desc" : "asc"
                            } else {
                                oSettings.aaSorting.splice(0, oSettings.aaSorting.length); oSettings.aaSorting.push([iDataIndex, "asc"])
                            } 
                        } _fnSortingClasses(oSettings); _fnSort(oSettings); _fnProcessingDisplay(oSettings, false)
                    }, 0)
                }); $("thead th", oSettings.nTable).mousedown(function() {
                    this.onselectstart = function() {
                        return false
                    }; return false
                })
            } if (oSettings.oFeatures.bAutoWidth) {
                oSettings.nTable.style.width = oSettings.nTable.offsetWidth + "px"
            } 
        } function _fnDraw(oSettings) {
            var i; var anRows = []; var iRowCount = 0; var iStrips = oSettings.asStripClasses.length;
            if (oSettings.aiDisplay.length !== 0) {
                for (var j = oSettings.iDisplayStart; j < oSettings.iDisplayEnd;
j++) {
                    var nRow = oSettings.aoData[oSettings.aiDisplay[j]].nTr; $(nRow).removeClass(oSettings.asStripClasses.join(" "));
                    $(nRow).addClass(oSettings.asStripClasses[iRowCount % iStrips]); if (typeof oSettings.fnRowCallback == "function") {
                        anRows[iRowCount] = oSettings.fnRowCallback(nRow, oSettings.aoData[oSettings.aiDisplay[j]]._aData, iRowCount, j)
                    } anRows.push(nRow); iRowCount++
                } 
            } else {
                anRows[0] = document.createElement("tr"); if (typeof oSettings.asStripClasses[0] != "undefined") {
                    anRows[0].className = oSettings.asStripClasses[0]
                } var nTd = document.createElement("td"); nTd.setAttribute("valign", "top"); nTd.colSpan = oSettings.aoColumns.length;
                nTd.style.textAlign = "center"; nTd.className = "dataTables_empty"; nTd.innerHTML = oSettings.oLanguage.sZeroRecords;
                anRows[iRowCount].appendChild(nTd)
            } if (typeof oSettings.fnHeaderCallback == "function") {
                oSettings.fnHeaderCallback($("thead tr", oSettings.nTable)[0], _fnGetDataMaster(oSettings), oSettings.iDisplayStart, oSettings.iDisplayEnd, oSettings.aiDisplay)
            } if (typeof oSettings.fnFooterCallback == "function") {
                oSettings.fnFooterCallback(oSettings.nFooter, _fnGetDataMaster(oSettings), oSettings.iDisplayStart, oSettings.iDisplayEnd, oSettings.aiDisplay)
            } var nTrs = $("tbody:eq(0)>tr", oSettings.nTable); for (i = 0; i < nTrs.length; i++) {
                nTrs[i].parentNode.removeChild(nTrs[i])
            } var nBody = $("tbody:eq(0)", oSettings.nTable); for (i = 0; i < anRows.length; i++) {
                nBody[0].appendChild(anRows[i])
            } if (oSettings.oFeatures.bPaginate) {
                $.fn.dataTableExt.oPagination[oSettings.sPaginationType].fnUpdate(oSettings, function(oSettings) {
                    _fnCalculateEnd(oSettings);
                    _fnDraw(oSettings)
                })
            } if (oSettings.oFeatures.bInfo) {
                if (oSettings.aiDisplay.length === 0 && oSettings.aiDisplay.length == oSettings.aiDisplayMaster.length) {
                    oSettings.nInfo.innerHTML = oSettings.oLanguage.sInfoEmpty + " " + oSettings.oLanguage.sInfoPostFix
                } else {
                    if (oSettings.aiDisplay.length === 0) {
                        oSettings.nInfo.innerHTML = oSettings.oLanguage.sInfoEmpty + " " + oSettings.oLanguage.sInfoFiltered.replace("_MAX_", oSettings.aiDisplayMaster.length) + " " + oSettings.oLanguage.sInfoPostFix
                    } else {
                        if (oSettings.aiDisplay.length == oSettings.aiDisplayMaster.length) {
                            oSettings.nInfo.innerHTML = oSettings.oLanguage.sInfo.replace("_START_", oSettings.iDisplayStart + 1).replace("_END_", oSettings.iDisplayEnd).replace("_TOTAL_", oSettings.aiDisplay.length) + " " + oSettings.oLanguage.sInfoPostFix
                        } else {
                            oSettings.nInfo.innerHTML = oSettings.oLanguage.sInfo.replace("_START_", oSettings.iDisplayStart + 1).replace("_END_", oSettings.iDisplayEnd).replace("_TOTAL_", oSettings.aiDisplay.length) + " " + oSettings.oLanguage.sInfoFiltered.replace("_MAX_", oSettings.aiDisplayMaster.length) + " " + oSettings.oLanguage.sInfoPostFix
                        } 
                    } 
                } 
            } _fnSaveState(oSettings); if (typeof oSettings.fnDrawCallback == "function") {
                oSettings.fnDrawCallback()
            } 
        } function _fnReDraw(oSettings) {
            if (oSettings.oFeatures.bSort) {
                _fnSort(oSettings, oSettings.sPreviousSearch)
            } else {
                if (oSettings.oFeatures.bFilter) {
                    _fnFilterComplete(oSettings, oSettings.sPreviousSearch)
                } else { _fnCalculateEnd(oSettings); _fnDraw(oSettings) } 
            } 
        } function _fnAddOptionsHtml(oSettings) {
            var nHolding = document.createElement("div");
            oSettings.nTable.parentNode.insertBefore(nHolding, oSettings.nTable); var nWrapper = document.createElement("div");
            nWrapper.className = "dataTables_wrapper"; if (oSettings.sTableId !== "") {
                nWrapper.setAttribute("id", oSettings.sTableId + "_wrapper")
            } var nInsertNode = nWrapper; var sDom = oSettings.sDomPositioning.split(""); for (var i = 0;
i < sDom.length; i++) {
                var cOption = sDom[i]; if (cOption == "<") {
                    var nNewNode = document.createElement("div");
                    var cNext = sDom[i + 1]; if (cNext == "'" || cNext == '"') {
                        var sClass = ""; var j = 2; while (sDom[i + j] != cNext) {
                            sClass += sDom[i + j];
                            j++
                        } nNewNode.className = sClass; i += j
                    } nInsertNode.appendChild(nNewNode); nInsertNode = nNewNode
                } else {
                    if (cOption == ">") { nInsertNode = nInsertNode.parentNode } else {
                        if (cOption == "l" && oSettings.oFeatures.bPaginate && oSettings.oFeatures.bLengthChange) {
                            nInsertNode.appendChild(_fnFeatureHtmlLength(oSettings))
                        } else {
                            if (cOption == "f" && oSettings.oFeatures.bFilter) {
                                nInsertNode.appendChild(_fnFeatureHtmlFilter(oSettings))
                            } else {
                                if (cOption == "r" && oSettings.oFeatures.bProcessing) {
                                    nInsertNode.appendChild(_fnFeatureHtmlProcessing(oSettings))
                                } else {
                                    if (cOption == "t") { nInsertNode.appendChild(oSettings.nTable) } else {
                                        if (cOption == "i" && oSettings.oFeatures.bInfo) {
                                            nInsertNode.appendChild(_fnFeatureHtmlInfo(oSettings))
                                        } else {
                                            if (cOption == "p" && oSettings.oFeatures.bPaginate) {
                                                nInsertNode.appendChild(_fnFeatureHtmlPaginate(oSettings))
                                            } 
                                        } 
                                    } 
                                } 
                            } 
                        } 
                    } 
                } 
            } nHolding.parentNode.replaceChild(nWrapper, nHolding)
        } function _fnFeatureHtmlFilter(oSettings) {
            var nFilter = document.createElement("div");
            if (oSettings.sTableId !== "") {
                nFilter.setAttribute("id", oSettings.sTableId + "_filter")
            } nFilter.className = "dataTables_filter"; nFilter.innerHTML = oSettings.oLanguage.sSearch + ' <input type="text" value="' + oSettings.sPreviousSearch.replace('"', "&quot;") + '" />';
            $("input", nFilter).keyup(function(e) { _fnFilterComplete(oSettings, this.value) }); return nFilter
        } function _fnFeatureHtmlInfo(oSettings) {
            var nInfo = document.createElement("div"); oSettings.nInfo = nInfo;
            if (oSettings.sTableId !== "") {
                oSettings.nInfo.setAttribute("id", oSettings.sTableId + "_info")
            } oSettings.nInfo.className = "dataTables_info"; return nInfo
        } function _fnFeatureHtmlPaginate(oSettings) {
            var nPaginate = document.createElement("div");
            nPaginate.className = "dataTables_paginate"; oSettings.nPaginate = nPaginate; $.fn.dataTableExt.oPagination[oSettings.sPaginationType].fnInit(oSettings, function(oSettings) {
                _fnCalculateEnd(oSettings);
                _fnDraw(oSettings)
            }); return nPaginate
        } function _fnFeatureHtmlLength(oSettings) {
            var sName = (oSettings.sTableId === "") ? "" : 'name="' + oSettings.sTableId + '_length"';
            var sStdMenu = '<select size="1" ' + sName + '><option value="10">10</option><option value="25">25</option><option value="50">50</option><option value="100">100</option></select>';
            var nLength = document.createElement("div"); if (oSettings.sTableId !== "") {
                nLength.setAttribute("id", oSettings.sTableId + "_length")
            } nLength.className = "dataTables_length"; nLength.innerHTML = oSettings.oLanguage.sLengthMenu.replace("_MENU_", sStdMenu);
            $('select option[value="' + oSettings.iDisplayLength + '"]', nLength).attr("selected", true);
            $("select", nLength).change(function() {
                oSettings.iDisplayLength = parseInt($(this).val(), 10);
                _fnCalculateEnd(oSettings); if (oSettings.iDisplayEnd == oSettings.aiDisplay.length) {
                    oSettings.iDisplayStart = oSettings.iDisplayEnd - oSettings.iDisplayLength;
                    if (oSettings.iDisplayStart < 0) { oSettings.iDisplayStart = 0 } 
                } _fnDraw(oSettings)
            }); return nLength
        } function _fnFeatureHtmlProcessing(oSettings) {
            var nProcessing = document.createElement("div");
            oSettings.nProcessing = nProcessing; if (oSettings.sTableId !== "") {
                oSettings.nProcessing.setAttribute("id", oSettings.sTableId + "_processing")
            } oSettings.nProcessing.appendChild(document.createTextNode(oSettings.oLanguage.sProcessing));
            oSettings.nProcessing.className = "dataTables_processing"; oSettings.nProcessing.style.visibility = "hidden";
            oSettings.nTable.parentNode.insertBefore(oSettings.nProcessing, oSettings.nTable);
            return nProcessing
        } function _fnProcessingDisplay(oSettings, bShow) {
            if (oSettings.oFeatures.bProcessing) {
                if (bShow) {
                    oSettings.nProcessing.style.visibility = "visible"
                } else { oSettings.nProcessing.style.visibility = "hidden" } 
            } 
        } function _fnFilterComplete(oSettings, sInput, iForce, bEscapeRegex) {
            if (typeof bEscapeRegex == "undefined") {
                bEscapeRegex = true
            } _fnFilter(oSettings, sInput, iForce, bEscapeRegex); for (var i = 0; i < oSettings.asPreSearchCols.length;
i++) { _fnFilterColumn(oSettings, oSettings.asPreSearchCols[i], i, bEscapeRegex) } if (typeof oSettings.iInitDisplayStart != "undefined" && oSettings.iInitDisplayStart != -1) {
                oSettings.iDisplayStart = oSettings.iInitDisplayStart;
                oSettings.iInitDisplayStart = -1
            } else { oSettings.iDisplayStart = 0 } _fnCalculateEnd(oSettings);
            _fnDraw(oSettings); _fnBuildSearchArray(oSettings, 0)
        } function _fnFilterColumn(oSettings, sInput, iColumn, bEscapeRegex) {
            if (sInput === "") {
                return
            } var iIndexCorrector = 0; var sRegexMatch = bEscapeRegex ? _fnEscapeRegex(sInput) : sInput;
            var rpSearch = new RegExp(sRegexMatch, "i"); for (i = oSettings.aiDisplay.length - 1; i >= 0;
i--) {
                if (!rpSearch.test(oSettings.aoData[oSettings.aiDisplay[i]]._aData[iColumn])) {
                    oSettings.aiDisplay.splice(i, 1);
                    iIndexCorrector++
                } 
            } 
        } function _fnFilter(oSettings, sInput, iForce, bEscapeRegex) {
            var flag, i, j;
            if (typeof iForce == "undefined" || iForce === null) { iForce = 0 } if (typeof bRedraw == "undefined" || bRedraw === null) {
                bRedraw = true
            } var asSearch = bEscapeRegex ? _fnEscapeRegex(sInput).split(" ") : sInput.split(" "); var sRegExpString = "^(?=.*?" + asSearch.join(")(?=.*?") + ").*$";
            var rpSearch = new RegExp(sRegExpString, "i"); if (sInput.length <= 0) {
                oSettings.aiDisplay.splice(0, oSettings.aiDisplay.length);
                oSettings.aiDisplay = oSettings.aiDisplayMaster.slice(); oSettings.sPreviousSearch = sInput
            } else {
                if (oSettings.aiDisplay.length == oSettings.aiDisplayMaster.length || oSettings.sPreviousSearch.length > sInput.length || iForce == 1) {
                    oSettings.aiDisplay.splice(0, oSettings.aiDisplay.length);
                    _fnBuildSearchArray(oSettings, 1); for (i = 0; i < oSettings.aiDisplayMaster.length; i++) {
                        if (rpSearch.test(oSettings.asDataSearch[i])) {
                            oSettings.aiDisplay.push(oSettings.aiDisplayMaster[i])
                        } 
                    } 
                } else {
                    var iIndexCorrector = 0; for (i = 0; i < oSettings.asDataSearch.length; i++) {
                        if (!rpSearch.test(oSettings.asDataSearch[i])) {
                            oSettings.aiDisplay.splice(i - iIndexCorrector, 1);
                            iIndexCorrector++
                        } 
                    } 
                } oSettings.sPreviousSearch = sInput
            } 
        } function _fnSort(oSettings) {
            var sDynamicSort = "var fnLocalSorting = function(a,b){var iTest;var oSort = $.fn.dataTableExt.oSort;var aoData = oSettings.aoData;";
            var aaSort = oSettings.aaSorting; var iDataSort; var iDataType; if (aaSort.length !== 0) {
                for (var i = 0;
i < aaSort.length - 1; i++) {
                    iDataSort = oSettings.aoColumns[aaSort[i][0]].iDataSort; iDataType = oSettings.aoColumns[iDataSort].sType;
                    sDynamicSort += "iTest = oSort['" + iDataType + "-" + aaSort[i][1] + "']( aoData[a]._aData[" + iDataSort + "], aoData[b]._aData[" + iDataSort + "] ); if ( iTest === 0 )"
                } iDataSort = oSettings.aoColumns[aaSort[aaSort.length - 1][0]].iDataSort; iDataType = oSettings.aoColumns[iDataSort].sType;
                sDynamicSort += "iTest = oSort['" + iDataType + "-" + aaSort[aaSort.length - 1][1] + "']( aoData[a]._aData[" + iDataSort + "], aoData[b]._aData[" + iDataSort + "] ); return iTest;}";
                eval(sDynamicSort); oSettings.aiDisplayMaster.sort(fnLocalSorting)
            } if (oSettings.oFeatures.bFilter) {
                _fnFilterComplete(oSettings, oSettings.sPreviousSearch, 1)
            } else {
                oSettings.aiDisplay = oSettings.aiDisplayMaster.slice(); _fnCalculateEnd(oSettings);
                _fnDraw(oSettings)
            } 
        } function _fnSortingClasses(oSettings) {
            $("thead th", oSettings.nTable).removeClass("sorting_asc sorting_desc sorting");
            var iCorrector = 0; var i; for (i = 0; i < oSettings.aoColumns.length; i++) {
                if (oSettings.aoColumns[i].bSortable && oSettings.aoColumns[i].bVisible) {
                    var sClass = "sorting";
                    for (var j = 0; j < oSettings.aaSorting.length; j++) {
                        if (oSettings.aaSorting[j][0] == i) {
                            sClass = (oSettings.aaSorting[j][1] == "asc") ? "sorting_asc" : "sorting_desc";
                            break
                        } 
                    } $("thead th:eq(" + _fnColumnIndexToVisible(oSettings, i) + ")", oSettings.nTable).addClass(sClass)
                } 
            } if (oSettings.oFeatures.bSortClasses) {
                var nTrs = _fnGetTrNodes(oSettings); $("td", nTrs).removeClass("sorting_1 sorting_2 sorting_3");
                for (i = 0; i < oSettings.aaSorting.length; i++) {
                    if (i <= 1) {
                        $("td:eq(" + _fnColumnIndexToVisible(oSettings, oSettings.aaSorting[i][0]) + ")", nTrs).addClass("sorting_" + (i + 1))
                    } else {
                        $("td:eq(" + _fnColumnIndexToVisible(oSettings, oSettings.aaSorting[i][0]) + ")", nTrs).addClass("sorting_3")
                    } 
                } 
            } 
        } function _fnVisibleToColumnIndex(oSettings, iMatch) {
            var iColumn = -1; for (var i = 0;
i < oSettings.aoColumns.length; i++) {
                if (oSettings.aoColumns[i].bVisible === true) {
                    iColumn++
                } if (iColumn == iMatch) { return i } 
            } return null
        } function _fnColumnIndexToVisible(oSettings, iMatch) {
            var iColumn = 0;
            for (var i = 0; i < oSettings.aoColumns.length; i++) {
                if (i == iMatch) { return iColumn } if (oSettings.aoColumns[i].bVisible === true) {
                    iColumn++
                } 
            } return null
        } function _fnBuildSearchArray(oSettings, iMaster) {
            oSettings.asDataSearch.splice(0, oSettings.asDataSearch.length);
            var aArray = (typeof iMaster != "undefined" && iMaster == 1) ? oSettings.aiDisplayMaster : oSettings.aiDisplay;
            for (i = 0; i < aArray.length; i++) {
                oSettings.asDataSearch[i] = ""; for (j = 0; j < oSettings.aoColumns.length;
j++) {
                    if (oSettings.aoColumns[j].bSearchable) {
                        var sData = oSettings.aoData[aArray[i]]._aData[j];
                        if (oSettings.aoColumns[j].sType == "html") {
                            oSettings.asDataSearch[i] += sData.replace(/\n/g, " ").replace(/<.*?>/g, "") + " "
                        } else {
                            if (typeof sData == "string") {
                                oSettings.asDataSearch[i] += sData.replace(/\n/g, " ") + " "
                            } else { oSettings.asDataSearch[i] += sData + " " } 
                        } 
                    } 
                } 
            } 
        } function _fnCalculateEnd(oSettings) {
            if (oSettings.oFeatures.bPaginate === false) {
                oSettings.iDisplayEnd = oSettings.aiDisplay.length
            } else {
                if (oSettings.iDisplayStart + oSettings.iDisplayLength > oSettings.aiDisplay.length) {
                    oSettings.iDisplayEnd = oSettings.aiDisplay.length
                } else { oSettings.iDisplayEnd = oSettings.iDisplayStart + oSettings.iDisplayLength } 
            } 
        } function _fnConvertToWidth(sWidth, nParent) {
            if (!sWidth || sWidth === null || sWidth === "") {
                return 0
            } if (typeof nParent == "undefined") {
                nParent = document.getElementsByTagName("body")[0]
            } var iWidth; var nTmp = document.createElement("div"); nTmp.style.width = sWidth; nParent.appendChild(nTmp);
            iWidth = nTmp.offsetWidth; nParent.removeChild(nTmp); return (iWidth)
        } function _fnCalculateColumnWidths(oSettings) {
            var iTableWidth = oSettings.nTable.offsetWidth;
            var iTotalUserIpSize = 0; var iTmpWidth; var iVisibleColumns = 0; var i; var oHeaders = $("thead th", oSettings.nTable);
            for (i = 0; i < oSettings.aoColumns.length; i++) {
                if (oSettings.aoColumns[i].bVisible) {
                    iVisibleColumns++;
                    if (oSettings.aoColumns[i].sWidth !== null) {
                        iTmpWidth = _fnConvertToWidth(oSettings.aoColumns[i].sWidth, oSettings.nTable.parentNode);
                        iTotalUserIpSize += iTmpWidth; oSettings.aoColumns[i].sWidth = iTmpWidth + "px"
                    } 
                } 
            } if (oSettings.aoColumns.length == oHeaders.length && iTotalUserIpSize === 0) {
                for (i = 0;
i < oSettings.aoColumns.length; i++) {
                    oSettings.aoColumns[i].sWidth = oHeaders[i].offsetWidth + "px"
                } 
            } else {
                var nCalcTmp = oSettings.nTable.cloneNode(false); nCalcTmp.setAttribute("id", "");
                var sTableTmp = '<table class="' + nCalcTmp.className + '">'; var sCalcHead = "<tr>"; var sCalcHtml = "<tr>";
                for (i = 0; i < oSettings.aoColumns.length; i++) {
                    if (oSettings.aoColumns[i].bVisible) {
                        sCalcHead += "<th>" + oSettings.aoColumns[i].sTitle + "</th>";
                        if (oSettings.aoColumns[i].sWidth !== null) {
                            var sWidth = ""; if (oSettings.aoColumns[i].sWidth !== null) {
                                sWidth = ' style="width:' + oSettings.aoColumns[i].sWidth + ';"'
                            } sCalcHtml += "<td" + sWidth + ' tag_index="' + i + '">' + fnGetMaxLenString(oSettings, i) + "</td>"
                        } else { sCalcHtml += '<td tag_index="' + i + '">' + fnGetMaxLenString(oSettings, i) + "</td>" } 
                    } 
                } sCalcHead += "</tr>";
                sCalcHtml += "</tr>"; nCalcTmp = $(sTableTmp + sCalcHead + sCalcHtml + "</table>")[0]; nCalcTmp.style.width = iTableWidth + "px";
                nCalcTmp.style.visibility = "hidden"; nCalcTmp.style.position = "absolute"; oSettings.nTable.parentNode.appendChild(nCalcTmp);
                var oNodes = $("td", nCalcTmp); var iIndex; for (i = 0; i < oNodes.length; i++) {
                    iIndex = oNodes[i].getAttribute("tag_index");
                    oSettings.aoColumns[iIndex].sWidth = $("td", nCalcTmp)[i].offsetWidth + "px"
                } oSettings.nTable.parentNode.removeChild(nCalcTmp)
            } 
        } function fnGetMaxLenString(oSettings, iCol) {
            var iMax = 0; var iMaxIndex = -1; for (var i = 0;
i < oSettings.aoData.length; i++) {
                if (oSettings.aoData[i]._aData[iCol].length > iMax) {
                    iMax = oSettings.aoData[i]._aData[iCol].length;
                    iMaxIndex = i
                } 
            } if (iMaxIndex >= 0) { return oSettings.aoData[iMaxIndex]._aData[iCol] } return ""
        } function _fnArrayCmp(aArray1, aArray2) {
            if (aArray1.length != aArray2.length) {
                return 1
            } for (var i = 0; i < aArray1.length; i++) { if (aArray1[i] != aArray2[i]) { return 2 } } return 0
        } function _fnDetectType(sData) {
            var aTypes = $.fn.dataTableExt.aTypes;
            var iLen = aTypes.length; for (var i = 0; i < iLen; i++) {
                var sType = aTypes[i](sData); if (sType !== null) {
                    return sType
                } 
            } return "string"
        } function _fnSettingsFromNode(nTable) {
            for (var i = 0; i < _aoSettings.length;
i++) { if (_aoSettings[i].nTable == nTable) { return _aoSettings[i] } } return null
        } function _fnGetDataMaster(oSettings) {
            var aData = [];
            for (var i = 0; i < oSettings.aoData.length; i++) {
                aData.push(oSettings.aoData[i]._aData)
            } return aData
        } function _fnGetTrNodes(oSettings) {
            var aNodes = []; for (var i = 0; i < oSettings.aoData.length;
i++) { aNodes.push(oSettings.aoData[i].nTr) } return aNodes
        } function _fnEscapeRegex(sVal) {
            var acEscape = ["/", ".", "*", "+", "?", "|", "(", ")", "[", "]", "{", "}", "\\"];
            var reReplace = new RegExp("(\\" + acEscape.join("|\\") + ")", "g"); return sVal.replace(reReplace, "\\$1")
        } function _fnSaveState(oSettings) {
            if (!oSettings.oFeatures.bStateSave) { return } var sValue = "{";
            sValue += '"iStart": ' + oSettings.iDisplayStart + ","; sValue += '"iEnd": ' + oSettings.iDisplayEnd + ",";
            sValue += '"iLength": ' + oSettings.iDisplayLength + ","; sValue += '"sFilter": "' + oSettings.sPreviousSearch.replace('"', '\\"') + '",';
            sValue += '"aaSorting": [ '; for (var i = 0; i < oSettings.aaSorting.length; i++) {
                sValue += "[" + oSettings.aaSorting[i][0] + ",'" + oSettings.aaSorting[i][1] + "'],"
            } sValue = sValue.substring(0, sValue.length - 1); sValue += "]}"; _fnCreateCookie("SpryMedia_DataTables_" + oSettings.sInstance, sValue, oSettings.iCookieDuration)
        } function _fnLoadState(oSettings) {
            if (!oSettings.oFeatures.bStateSave) { return } var sData = _fnReadCookie("SpryMedia_DataTables_" + oSettings.sInstance);
            if (sData !== null && sData !== "") {
                oData = eval("(" + sData + ")"); oSettings.iDisplayStart = oData.iStart;
                oSettings.iInitDisplayStart = oData.iStart; oSettings.iDisplayEnd = oData.iEnd; oSettings.iDisplayLength = oData.iLength;
                oSettings.sPreviousSearch = oData.sFilter; oSettings.aaSorting = oData.aaSorting.slice()
            } 
        } function _fnCreateCookie(sName, sValue, iSecs) {
            var date = new Date(); date.setTime(date.getTime() + (iSecs * 1000));
            sName += "_" + window.location.pathname.replace(/[\/:]/g, ""); document.cookie = sName + "=" + sValue + "; expires=" + date.toGMTString() + "; path=/"
        } function _fnReadCookie(sName) {
            var sNameEQ = sName + "_" + window.location.pathname.replace(/[\/:]/g, "") + "=";
            var sCookieContents = document.cookie.split(";"); for (var i = 0; i < sCookieContents.length;
i++) {
                var c = sCookieContents[i]; while (c.charAt(0) == " ") { c = c.substring(1, c.length) } if (c.indexOf(sNameEQ) === 0) {
                    return c.substring(sNameEQ.length, c.length)
                } 
            } return null
        } if (bApi) {
            this.oApi._fnInitalise = _fnInitalise; this.oApi._fnLanguageProcess = _fnLanguageProcess;
            this.oApi._fnAddColumn = _fnAddColumn; this.oApi._fnAddData = _fnAddData; this.oApi._fnGatherData = _fnGatherData;
            this.oApi._fnDrawHead = _fnDrawHead; this.oApi._fnDraw = _fnDraw; this.oApi._fnAddOptionsHtml = _fnAddOptionsHtml;
            this.oApi._fnFeatureHtmlFilter = _fnFeatureHtmlFilter; this.oApi._fnFeatureHtmlInfo = _fnFeatureHtmlInfo;
            this.oApi._fnFeatureHtmlPaginate = _fnFeatureHtmlPaginate; this.oApi._fnFeatureHtmlLength = _fnFeatureHtmlLength;
            this.oApi._fnFeatureHtmlProcessing = _fnFeatureHtmlProcessing; this.oApi._fnProcessingDisplay = _fnProcessingDisplay;
            this.oApi._fnFilterComplete = _fnFilterComplete; this.oApi._fnFilterColumn = _fnFilterColumn;
            this.oApi._fnFilter = _fnFilter; this.oApi._fnSortingClasses = _fnSortingClasses; this.oApi._fnVisibleToColumnIndex = _fnVisibleToColumnIndex;
            this.oApi._fnColumnIndexToVisible = _fnColumnIndexToVisible; this.oApi._fnBuildSearchArray = _fnBuildSearchArray;
            this.oApi._fnCalculateEnd = _fnCalculateEnd; this.oApi._fnConvertToWidth = _fnConvertToWidth;
            this.oApi._fnCalculateColumnWidths = _fnCalculateColumnWidths; this.oApi._fnArrayCmp = _fnArrayCmp;
            this.oApi._fnDetectType = _fnDetectType; this.oApi._fnGetDataMaster = _fnGetDataMaster;
            this.oApi._fnGetTrNodes = _fnGetTrNodes; this.oApi._fnEscapeRegex = _fnEscapeRegex; this.oApi._fnSaveState = _fnSaveState;
            this.oApi._fnLoadState = _fnLoadState; this.oApi._fnCreateCookie = _fnCreateCookie; this.oApi._fnReadCookie = _fnReadCookie
        } return this.each(function() {
            var oSettings = new classSettings(); _aoSettings.push(oSettings);
            var bInitHandedOff = false; var bUsePassedData = false; var sId = this.getAttribute("id");
            if (sId !== null) { oSettings.sTableId = sId; oSettings.sInstance = sId } else {
                oSettings.sInstance = $.fn.dataTableExt._oExternConfig.iNextUnique++
            } oSettings.nTable = this; if (typeof oInit != "undefined" && oInit !== null) {
                if (typeof oInit.bPaginate != "undefined") {
                    oSettings.oFeatures.bPaginate = oInit.bPaginate
                } if (typeof oInit.bLengthChange != "undefined") {
                    oSettings.oFeatures.bLengthChange = oInit.bLengthChange
                } if (typeof oInit.bFilter != "undefined") { oSettings.oFeatures.bFilter = oInit.bFilter } if (typeof oInit.bSort != "undefined") {
                    oSettings.oFeatures.bSort = oInit.bSort
                } if (typeof oInit.bInfo != "undefined") { oSettings.oFeatures.bInfo = oInit.bInfo } if (typeof oInit.bProcessing != "undefined") {
                    oSettings.oFeatures.bProcessing = oInit.bProcessing
                } if (typeof oInit.bAutoWidth != "undefined") {
                    oSettings.oFeatures.bAutoWidth = oInit.bAutoWidth
                } if (typeof oInit.bSortClasses != "undefined") {
                    oSettings.oFeatures.bSortClasses = oInit.bSortClasses
                } if (typeof oInit.aaData != "undefined") { bUsePassedData = true } if (typeof oInit.iDisplayLength != "undefined") {
                    oSettings.iDisplayLength = oInit.iDisplayLength
                } if (typeof oInit.asStripClasses != "undefined") {
                    oSettings.asStripClasses = oInit.asStripClasses
                } if (typeof oInit.fnRowCallback != "undefined") {
                    oSettings.fnRowCallback = oInit.fnRowCallback
                } if (typeof oInit.fnHeaderCallback != "undefined") {
                    oSettings.fnHeaderCallback = oInit.fnHeaderCallback
                } if (typeof oInit.fnFooterCallback != "undefined") {
                    oSettings.fnFooterCallback = oInit.fnFooterCallback
                } if (typeof oInit.fnDrawCallback != "undefined") {
                    oSettings.fnDrawCallback = oInit.fnDrawCallback
                } if (typeof oInit.fnInitComplete != "undefined") {
                    oSettings.fnInitComplete = oInit.fnInitComplete
                } if (typeof oInit.aaSorting != "undefined") { oSettings.aaSorting = oInit.aaSorting } if (typeof oInit.sPaginationType != "undefined") {
                    oSettings.sPaginationType = oInit.sPaginationType
                } if (typeof oInit.sDom != "undefined") { oSettings.sDomPositioning = oInit.sDom } if (typeof oInit.sAjaxSource != "undefined") {
                    oSettings.sAjaxSource = oInit.sAjaxSource
                } if (typeof oInit.iCookieDuration != "undefined") {
                    oSettings.iCookieDuration = oInit.iCookieDuration
                } if (typeof oInit.bStateSave != "undefined") {
                    oSettings.oFeatures.bStateSave = oInit.bStateSave;
                    _fnLoadState(oSettings)
                } if (typeof oInit != "undefined" && typeof oInit.aoData != "undefined") {
                    oInit.aoColumns = oInit.aoData
                } if (typeof oInit.oLanguage != "undefined") {
                    bInitHandedOff = true; if (typeof oInit.oLanguage.sUrl != "undefined") {
                        oSettings.oLanguage.sUrl = oInit.oLanguage.sUrl;
                        $.getJSON(oSettings.oLanguage.sUrl, null, function(json) {
                            _fnLanguageProcess(oSettings, json)
                        })
                    } else { _fnLanguageProcess(oSettings, oInit.oLanguage) } 
                } 
            } if (typeof oInit != "undefined" && typeof oInit.aoColumns != "undefined") {
                for (var i = 0;
i < oInit.aoColumns.length; i++) { _fnAddColumn(oSettings, oInit.aoColumns[i]) } 
            } else {
                $("thead th", this).each(function() {
                    _fnAddColumn(oSettings, null)
                })
            } if (bUsePassedData) {
                for (var j = 0; j < oInit.aaData.length; j++) {
                    _fnAddData(oSettings, oInit.aaData[j])
                } if ($("thead", this).length === 0) {
                    this.appendChild(document.createElement("thead"))
                } if ($("tbody", this).length === 0) {
                    this.appendChild(document.createElement("tbody"))
                } 
            } else { _fnGatherData(oSettings) } oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
            if (oSettings.oFeatures.bAutoWidth) { _fnCalculateColumnWidths(oSettings) } oSettings.bInitialised = true;
            if (bInitHandedOff === false) { _fnInitalise(oSettings) } 
        })
    }
})(jQuery);
/*
* Autocomplete - jQuery plugin 1.0.2
*
* Copyright (c) 2007 Dylan Verheul, Dan G. Switzer, Anjesh Tuladhar, Jörn Zaefferer
*
* Dual licensed under the MIT and GPL licenses:
*   http://www.opensource.org/licenses/mit-license.php
*   http://www.gnu.org/licenses/gpl.html
*
* Revision: $Id: jquery.autocomplete.js 5747 2008-06-25 18:30:55Z joern.zaefferer $
*
*/
; (function($) {
    $.fn.extend({ autocomplete: function(urlOrData, options) { var isUrl = typeof urlOrData == "string"; options = $.extend({}, $.Autocompleter.defaults, { url: isUrl ? urlOrData : null, data: isUrl ? null : urlOrData, delay: isUrl ? $.Autocompleter.defaults.delay : 10, max: options && !options.scroll ? 10 : 150 }, options); options.highlight = options.highlight || function(value) { return value; }; options.formatMatch = options.formatMatch || options.formatItem; return this.each(function() { new $.Autocompleter(this, options); }); }, result: function(handler) { return this.bind("result", handler); }, search: function(handler) { return this.trigger("search", [handler]); }, flushCache: function() { return this.trigger("flushCache"); }, setOptions: function(options) { return this.trigger("setOptions", [options]); }, unautocomplete: function() { return this.trigger("unautocomplete"); } }); $.Autocompleter = function(input, options) {
        var KEY = { UP: 38, DOWN: 40, DEL: 46, TAB: 9, RETURN: 13, ESC: 27, COMMA: 188, PAGEUP: 33, PAGEDOWN: 34, BACKSPACE: 8 }; var $input = $(input).attr("autocomplete", "off").addClass(options.inputClass); var timeout; var previousValue = ""; var cache = $.Autocompleter.Cache(options); var hasFocus = 0; var lastKeyPressCode; var config = { mouseDownOnSelect: false }; var select = $.Autocompleter.Select(options, input, selectCurrent, config); var blockSubmit; $.browser.opera && $(input.form).bind("submit.autocomplete", function() { if (blockSubmit) { blockSubmit = false; return false; } }); $input.bind(($.browser.opera ? "keypress" : "keydown") + ".autocomplete", function(event) { lastKeyPressCode = event.keyCode; switch (event.keyCode) { case KEY.UP: event.preventDefault(); if (select.visible()) { select.prev(); } else { onChange(0, true); } break; case KEY.DOWN: event.preventDefault(); if (select.visible()) { select.next(); } else { onChange(0, true); } break; case KEY.PAGEUP: event.preventDefault(); if (select.visible()) { select.pageUp(); } else { onChange(0, true); } break; case KEY.PAGEDOWN: event.preventDefault(); if (select.visible()) { select.pageDown(); } else { onChange(0, true); } break; case options.multiple && $.trim(options.multipleSeparator) == "," && KEY.COMMA: case KEY.TAB: case KEY.RETURN: if (selectCurrent()) { event.preventDefault(); blockSubmit = true; return false; } break; case KEY.ESC: select.hide(); break; default: clearTimeout(timeout); timeout = setTimeout(onChange, options.delay); break; } }).focus(function() { hasFocus++; }).blur(function() { hasFocus = 0; if (!config.mouseDownOnSelect) { hideResults(); } }).click(function() { if (hasFocus++ > 1 && !select.visible()) { onChange(0, true); } }).bind("search", function() { var fn = (arguments.length > 1) ? arguments[1] : null; function findValueCallback(q, data) { var result; if (data && data.length) { for (var i = 0; i < data.length; i++) { if (data[i].result.toLowerCase() == q.toLowerCase()) { result = data[i]; break; } } } if (typeof fn == "function") fn(result); else $input.trigger("result", result && [result.data, result.value]); } $.each(trimWords($input.val()), function(i, value) { request(value, findValueCallback, findValueCallback); }); }).bind("flushCache", function() { cache.flush(); }).bind("setOptions", function() { $.extend(options, arguments[1]); if ("data" in arguments[1]) cache.populate(); }).bind("unautocomplete", function() { select.unbind(); $input.unbind(); $(input.form).unbind(".autocomplete"); }); function selectCurrent() { var selected = select.selected(); if (!selected) return false; var v = selected.result; previousValue = v; if (options.multiple) { var words = trimWords($input.val()); if (words.length > 1) { v = words.slice(0, words.length - 1).join(options.multipleSeparator) + options.multipleSeparator + v; } v += options.multipleSeparator; } $input.val(v); hideResultsNow(); $input.trigger("result", [selected.data, selected.value]); return true; } function onChange(crap, skipPrevCheck) { if (lastKeyPressCode == KEY.DEL) { select.hide(); return; } var currentValue = $input.val(); if (!skipPrevCheck && currentValue == previousValue) return; previousValue = currentValue; currentValue = lastWord(currentValue); if (currentValue.length >= options.minChars) { $input.addClass(options.loadingClass); if (!options.matchCase) currentValue = currentValue.toLowerCase(); request(currentValue, receiveData, hideResultsNow); } else { stopLoading(); select.hide(); } }; function trimWords(value) { if (!value) { return [""]; } var words = value.split(options.multipleSeparator); var result = []; $.each(words, function(i, value) { if ($.trim(value)) result[i] = $.trim(value); }); return result; } function lastWord(value) { if (!options.multiple) return value; var words = trimWords(value); return words[words.length - 1]; } function autoFill(q, sValue) { if (options.autoFill && (lastWord($input.val()).toLowerCase() == q.toLowerCase()) && lastKeyPressCode != KEY.BACKSPACE) { $input.val($input.val() + sValue.substring(lastWord(previousValue).length)); $.Autocompleter.Selection(input, previousValue.length, previousValue.length + sValue.length); } }; function hideResults() { clearTimeout(timeout); timeout = setTimeout(hideResultsNow, 200); }; function hideResultsNow() {
            var wasVisible = select.visible(); select.hide(); clearTimeout(timeout); stopLoading(); if (options.mustMatch) {
                $input.search(function(result) {
                    if (!result) {
                        if (options.multiple) { var words = trimWords($input.val()).slice(0, -1); $input.val(words.join(options.multipleSeparator) + (words.length ? options.multipleSeparator : "")); } else
                            $input.val("");
                    } 
                });
            } if (wasVisible) $.Autocompleter.Selection(input, input.value.length, input.value.length);
        }; function receiveData(q, data) { if (data && data.length && hasFocus) { stopLoading(); select.display(data, q); autoFill(q, data[0].value); select.show(); } else { hideResultsNow(); } }; function request(term, success, failure) { if (!options.matchCase) term = term.toLowerCase(); var data = cache.load(term); if (data && data.length) { success(term, data); } else if ((typeof options.url == "string") && (options.url.length > 0)) { var extraParams = { timestamp: +new Date() }; $.each(options.extraParams, function(key, param) { extraParams[key] = typeof param == "function" ? param() : param; }); $.ajax({ mode: "abort", port: "autocomplete" + input.name, dataType: options.dataType, url: options.url, data: $.extend({ q: lastWord(term), limit: options.max }, extraParams), success: function(data) { var parsed = options.parse && options.parse(data) || parse(data); cache.add(term, parsed); success(term, parsed); } }); } else { select.emptyList(); failure(term); } }; function parse(data) { var parsed = []; var rows = data.split("\n"); for (var i = 0; i < rows.length; i++) { var row = $.trim(rows[i]); if (row) { row = row.split("|"); parsed[parsed.length] = { data: row, value: row[0], result: options.formatResult && options.formatResult(row, row[0]) || row[0] }; } } return parsed; }; function stopLoading() { $input.removeClass(options.loadingClass); };
    }; $.Autocompleter.defaults = { inputClass: "ac_input", resultsClass: "ac_results", loadingClass: "ac_loading", minChars: 1, delay: 400, matchCase: false, matchSubset: true, matchContains: false, cacheLength: 10, max: 100, mustMatch: false, extraParams: {}, selectFirst: true, formatItem: function(row) { return row[0]; }, formatMatch: null, autoFill: false, width: 0, multiple: false, multipleSeparator: ", ", highlight: function(value, term) { return value.replace(new RegExp("(?![^&;]+;)(?!<[^<>]*)(" + term.replace(/([\^\$\(\)\[\]\{\}\*\.\+\?\|\\])/gi, "\\$1") + ")(?![^<>]*>)(?![^&;]+;)", "gi"), "<strong>$1</strong>"); }, scroll: true, scrollHeight: 180 }; $.Autocompleter.Cache = function(options) {
        var data = {}; var length = 0; function matchSubset(s, sub) { if (!options.matchCase) s = s.toLowerCase(); var i = s.indexOf(sub); if (i == -1) return false; return i == 0 || options.matchContains; }; function add(q, value) { if (length > options.cacheLength) { flush(); } if (!data[q]) { length++; } data[q] = value; } function populate() { if (!options.data) return false; var stMatchSets = {}, nullData = 0; if (!options.url) options.cacheLength = 1; stMatchSets[""] = []; for (var i = 0, ol = options.data.length; i < ol; i++) { var rawValue = options.data[i]; rawValue = (typeof rawValue == "string") ? [rawValue] : rawValue; var value = options.formatMatch(rawValue, i + 1, options.data.length); if (value === false) continue; var firstChar = value.charAt(0).toLowerCase(); if (!stMatchSets[firstChar]) stMatchSets[firstChar] = []; var row = { value: value, data: rawValue, result: options.formatResult && options.formatResult(rawValue) || value }; stMatchSets[firstChar].push(row); if (nullData++ < options.max) { stMatchSets[""].push(row); } }; $.each(stMatchSets, function(i, value) { options.cacheLength++; add(i, value); }); } setTimeout(populate, 25); function flush() { data = {}; length = 0; } return { flush: flush, add: add, populate: populate, load: function(q) {
            if (!options.cacheLength || !length) return null; if (!options.url && options.matchContains) { var csub = []; for (var k in data) { if (k.length > 0) { var c = data[k]; $.each(c, function(i, x) { if (matchSubset(x.value, q)) { csub.push(x); } }); } } return csub; } else
                if (data[q]) { return data[q]; } else
                if (options.matchSubset) { for (var i = q.length - 1; i >= options.minChars; i--) { var c = data[q.substr(0, i)]; if (c) { var csub = []; $.each(c, function(i, x) { if (matchSubset(x.value, q)) { csub[csub.length] = x; } }); return csub; } } } return null;
        } 
        };
    }; $.Autocompleter.Select = function(options, input, select, config) { var CLASSES = { ACTIVE: "ac_over" }; var listItems, active = -1, data, term = "", needsInit = true, element, list; function init() { if (!needsInit) return; element = $("<div/>").hide().addClass(options.resultsClass).css("position", "absolute").appendTo(document.body); list = $("<ul/>").appendTo(element).mouseover(function(event) { if (target(event).nodeName && target(event).nodeName.toUpperCase() == 'LI') { active = $("li", list).removeClass(CLASSES.ACTIVE).index(target(event)); $(target(event)).addClass(CLASSES.ACTIVE); } }).click(function(event) { $(target(event)).addClass(CLASSES.ACTIVE); select(); input.focus(); return false; }).mousedown(function() { config.mouseDownOnSelect = true; }).mouseup(function() { config.mouseDownOnSelect = false; }); if (options.width > 0) element.css("width", options.width); needsInit = false; } function target(event) { var element = event.target; while (element && element.tagName != "LI") element = element.parentNode; if (!element) return []; return element; } function moveSelect(step) { listItems.slice(active, active + 1).removeClass(CLASSES.ACTIVE); movePosition(step); var activeItem = listItems.slice(active, active + 1).addClass(CLASSES.ACTIVE); if (options.scroll) { var offset = 0; listItems.slice(0, active).each(function() { offset += this.offsetHeight; }); if ((offset + activeItem[0].offsetHeight - list.scrollTop()) > list[0].clientHeight) { list.scrollTop(offset + activeItem[0].offsetHeight - list.innerHeight()); } else if (offset < list.scrollTop()) { list.scrollTop(offset); } } }; function movePosition(step) { active += step; if (active < 0) { active = listItems.size() - 1; } else if (active >= listItems.size()) { active = 0; } } function limitNumberOfItems(available) { return options.max && options.max < available ? options.max : available; } function fillList() { list.empty(); var max = limitNumberOfItems(data.length); for (var i = 0; i < max; i++) { if (!data[i]) continue; var formatted = options.formatItem(data[i].data, i + 1, max, data[i].value, term); if (formatted === false) continue; var li = $("<li/>").html(options.highlight(formatted, term)).addClass(i % 2 == 0 ? "ac_even" : "ac_odd").appendTo(list)[0]; $.data(li, "ac_data", data[i]); } listItems = list.find("li"); if (options.selectFirst) { listItems.slice(0, 1).addClass(CLASSES.ACTIVE); active = 0; } if ($.fn.bgiframe) list.bgiframe(); } return { display: function(d, q) { init(); data = d; term = q; fillList(); }, next: function() { moveSelect(1); }, prev: function() { moveSelect(-1); }, pageUp: function() { if (active != 0 && active - 8 < 0) { moveSelect(-active); } else { moveSelect(-8); } }, pageDown: function() { if (active != listItems.size() - 1 && active + 8 > listItems.size()) { moveSelect(listItems.size() - 1 - active); } else { moveSelect(8); } }, hide: function() { element && element.hide(); listItems && listItems.removeClass(CLASSES.ACTIVE); active = -1; }, visible: function() { return element && element.is(":visible"); }, current: function() { return this.visible() && (listItems.filter("." + CLASSES.ACTIVE)[0] || options.selectFirst && listItems[0]); }, show: function() { var offset = $(input).offset(); element.css({ width: typeof options.width == "string" || options.width > 0 ? options.width : $(input).width(), top: offset.top + input.offsetHeight, left: offset.left }).show(); if (options.scroll) { list.scrollTop(0); list.css({ maxHeight: options.scrollHeight, overflow: 'auto' }); if ($.browser.msie && typeof document.body.style.maxHeight === "undefined") { var listHeight = 0; listItems.each(function() { listHeight += this.offsetHeight; }); var scrollbarsVisible = listHeight > options.scrollHeight; list.css('height', scrollbarsVisible ? options.scrollHeight : listHeight); if (!scrollbarsVisible) { listItems.width(list.width() - parseInt(listItems.css("padding-left")) - parseInt(listItems.css("padding-right"))); } } } }, selected: function() { var selected = listItems && listItems.filter("." + CLASSES.ACTIVE).removeClass(CLASSES.ACTIVE); return selected && selected.length && $.data(selected[0], "ac_data"); }, emptyList: function() { list && list.empty(); }, unbind: function() { element && element.remove(); } }; }; $.Autocompleter.Selection = function(field, start, end) { if (field.createTextRange) { var selRange = field.createTextRange(); selRange.collapse(true); selRange.moveStart("character", start); selRange.moveEnd("character", end); selRange.select(); } else if (field.setSelectionRange) { field.setSelectionRange(start, end); } else { if (field.selectionStart) { field.selectionStart = start; field.selectionEnd = end; } } field.focus(); };
})(jQuery);

/**
* jquery.qtip. The jQuery tooltip plugin
* 
* Copyright (c) 2009 Craig Thompson
* http://craigsworks.com
*
* Licensed under MIT
* http://www.opensource.org/licenses/mit-license.php
*
* Launch  : February 2009
* Version : 1.0.0-beta3
* Released: Thursday 19th March, 2009 - 17:15
*/


(function($) {
    $.fn.qtip = function(options) {
        if (typeof options == 'object') {
            if (typeof options.content !== 'object') options.content = { text: options.content }; if (typeof options.content.title !== 'object') options.content.title = { text: options.content.title }; if (typeof options.position !== 'object') options.position = {}; if (typeof options.position.corner !== 'object') options.position.corner = { target: options.position.corner, tooltip: options.position.corner }; if (typeof options.show !== 'object') options.show = { when: options.show }; if (typeof options.show.when !== 'object') options.show.when = { event: options.show.when }; if (typeof options.show.effect !== 'object') options.show.effect = { type: options.show.effect }; if (typeof options.hide !== 'object') options.hide = { when: options.hide }; if (typeof options.hide.when !== 'object') options.hide.when = { event: options.hide.when }; if (typeof options.hide.effect !== 'object') options.hide.effect = { type: options.hide.effect }; if (typeof options.style !== 'object') options.style = { name: options.style }; if (typeof options.style.tip !== 'object') options.style.tip = { corner: options.style.tip }; if (typeof options.style.tip.size !== 'object') options.style.tip.size = { x: options.style.tip.size, y: options.style.tip.size }; if (typeof options.style.border !== 'object') options.style.border = { width: options.style.border }; var opts = $.extend(true, {}, $.fn.qtip.defaults, options); var styleExtend = [opts.style]; while (typeof styleExtend[0].name == 'string')
            { styleExtend.unshift($.fn.qtip.styles[styleExtend[0].name]); }
            styleExtend.unshift(true, { classes: { tooltip: 'qtip-' + opts.style.name} }, $.fn.qtip.styles.defaults); opts.style = $.extend.apply($, styleExtend);
        }
        else if (typeof options == 'string' && options == 'api')
            return $(this).eq(0).data("qtip"); return $(this).each(function() {
                if (typeof options == 'string') {
                    switch (options)
                    { case 'disable': $(this).data("qtip").disable(true); break; case 'enable': $(this).data("qtip").disable(false); break; case 'destroy': $(this).data("qtip").destroy(); break; } 
                }
                else
                { var config = $.extend(true, {}, opts); config.hide.effect.length = opts.hide.effect.length; config.show.effect.length = opts.show.effect.length; if (config.position.container === false) config.position.container = $(document.body); if (config.position.target === false) config.position.target = $(this); if (config.show.when.target === false) config.show.when.target = $(this); if (config.hide.when.target === false) config.hide.when.target = $(this); var obj = new qTip($(this), config); $(this).data("qtip", obj); } 
            });
    }
    function qTip(target, options) {
        var self = this; self.options = options; self.elements = { target: target.addClass(self.options.style.classes.target), tooltip: null, content: null, title: null, tip: null }; self.timers = {}; $.extend(self, { construct: function() {
            if (self.options.content.prerender === false && self.options.show.when.event !== false) {
                var showTarget = self.options.show.when.target; var showEvent = self.options.show.when.event; showTarget.bind(showEvent + ".qtip-create", function()
                { showTarget.unbind(showEvent + ".qtip-create"); self.create(); showTarget.trigger(showEvent); });
            }
            else self.create();
        }, create: function() {
            self.elements.tooltip = $(document.createElement('div')).addClass('qtip').addClass(self.options.style.classes.tooltip || self.options.style).css('-moz-border-radius', '').css('-webkit-border-radius', '').css({ position: self.options.position.type, zIndex: 6000 + $('.qtip').length, width: self.options.style.width }).appendTo(self.options.position.container).data("qtip", self); self.elements.content = $(document.createElement('div')).addClass(self.options.style.classes.content).css({ background: self.options.style.background, color: self.options.style.color, padding: self.options.style.padding }).html(self.options.content.text).appendTo(self.elements.tooltip); if (self.options.content.title.text !== false) createTitle.call(self); var padding = parseInt($.trim(String(self.options.style.padding)).charAt(0)); self.elements.tooltip.css({ width: self.elements.tooltip.outerWidth() + padding + 6 }); createBorder.call(self); createTip.call(self); assignEvents.call(self); if (self.options.content.url !== false)
            { var url = self.options.content.url; var data = self.options.content.data; self.loadContent(url, data); }
            if (self.options.show.ready === true)
            { self.updatePosition(); self.elements.tooltip.show(); self.elements.tooltip.addClass(self.options.style.classes.active); }
            else self.elements.tooltip.hide();
        }, show: function(event) {
            if ($(self.elements.tooltip).is(':visible') !== false) return; self.beforeShow.call(self); function afterShow() { self.onShow.call(self); }
            if (typeof self.options.show.solo == 'object') var solo = $(self.options.show.solo); else if (self.options.show.solo === true) var solo = $('div.qtip').not(self.elements.tooltip); if (solo) solo.each(function() { $(this).qtip("api").hide(); }); self.updatePosition(event); if (typeof self.options.show.effect.type == 'function')
            { self.options.show.effect.type.call(self.elements.tooltip, self.options.show.effect.length); self.elements.tooltip.queue(function() { afterShow(); $(this).dequeue(); }); }
            else {
                switch (self.options.show.effect.type)
                { case 'fade': self.elements.tooltip.fadeIn(self.options.show.effect.length, afterShow); break; case 'slide': self.elements.tooltip.slideDown(self.options.show.effect.length, function() { afterShow(); self.updatePosition(); }); break; case 'grow': self.elements.tooltip.show(self.options.show.effect.length, afterShow); break; default: self.elements.tooltip.show(null, afterShow); break; }
                self.elements.tooltip.addClass(self.options.style.classes.active);
            }
            if (self.options.position.type.search(/(fixed|absolute)/) !== -1) self.focus(); self.onShow.call(self); return self;
        }, hide: function() {
            clearTimeout(self.timers.show); if ($(self.elements.tooltip).is(':visible') === false) return; self.beforeHide.call(self); function afterHide() { self.onHide.call(self); }
            if (typeof self.options.hide.effect.type == 'function')
            { self.options.hide.effect.type.call(self.elements.tooltip, self.options.hide.effect.length); self.elements.tooltip.queue(function() { afterHide(); $(this).dequeue(); }); }
            else {
                switch (self.options.hide.effect.type)
                { case 'fade': self.elements.tooltip.fadeOut(self.options.hide.effect.length, afterHide); break; case 'slide': self.elements.tooltip.slideUp(self.options.hide.effect.length, function() { afterHide(); self.updatePosition(); }); break; case 'grow': self.elements.tooltip.hide(self.options.hide.effect.length, afterHide); break; default: self.elements.tooltip.hide(null, afterHide); break; }
                self.elements.tooltip.removeClass(self.options.style.classes.active);
            }
            self.onHide.call(self); return self;
        }, focus: function() {
            var baseIndex = 6000; var curIndex = parseInt(self.elements.tooltip.css('z-index')); var newIndex = baseIndex + $('.qtip').length - 1; if (curIndex !== newIndex) {
                $('.qtip').not(self.elements.tooltip).each(function()
                { $(this).css({ zIndex: parseInt($(this).css('z-index')) - 1 }); })
                self.elements.tooltip.css({ zIndex: newIndex });
            } 
        }, disable: function(state)
        { return assignEvents.call(self, !state); }, updatePosition: function(event) {
            self.beforePositionUpdate.call(self); if (self.options.position.target == 'mouse')
            { var posX = event.pageX; var posY = event.pageY; }
            else
            { var corner = self.options.position.corner.target; var elemPos = self.options.position.target.offset(); var posX = elemPos.left; var posY = elemPos.top; if (corner.search(/bottom/i) !== -1) posY += self.options.position.target.outerHeight(); if (corner.search(/right/i) !== -1) posX += self.options.position.target.outerWidth(); if (corner.search(/(left|right)Middle/) !== -1) posY += self.options.position.target.outerHeight() / 2; else if (corner.search(/(top|bottom)Middle/) !== -1) posX += self.options.position.target.outerWidth() / 2; }
            var tooltipLink = self.options.position.corner.tooltip; if (tooltipLink.search(/bottom/i) !== -1) posY -= self.elements.tooltip.outerHeight(); if (tooltipLink.search(/right/i) !== -1) posX -= self.elements.tooltip.outerWidth(); if (tooltipLink.search(/(left|right)Middle/) !== -1) posY -= self.elements.tooltip.outerHeight() / 2; else if (tooltipLink.search(/(top|bottom)Middle/) !== -1) posX -= self.elements.tooltip.outerWidth() / 2; posX += self.options.position.adjust.x; posY += self.options.position.adjust.y; if (self.options.position.adjust.screen)
            { var newPos = screenAdjust(posX, posY, event, options); posX = newPos.left; posY = newPos.top; }
            if (self.options.position.target == 'mouse')
            { var adjust = (tooltipLink.search(/top/) !== -1) ? 3 : -3; posX += adjust; posY += adjust; }
            self.elements.tooltip.css({ left: posX, top: posY }); self.onPositionUpdate.call(self); return self;
        }, updateContent: function(html) {
            if (self.options.content.title.text !== false)
                self.elements.content.find('.' + self.options.style.classes.title).eq(0).after(html); else
                self.elements.content.html(html); return self;
        }, loadContent: function(url, data) {
            if (typeof data !== 'object') data = null; self.beforeContentLoad.call(self); self.elements.content.load(url, data, function()
            { self.onContentLoad.call(self); if (self.options.content.title.text !== false) createTitle.call(self); self.updatePosition(); }); return self;
        }, destroy: function()
        { assignEvents.call(self, false); self.elements.tooltip.remove(); self.elements.target.removeData("qtip"); return true; }, getVersion: function() { return [1, 0, 0, 'beta2']; }, getPos: function() { return self.elements.tooltip.offset(); }, beforePositionUpdate: self.options.api.beforePositionUpdate, onPositionUpdate: self.options.api.onPositionUpdate, beforeShow: self.options.api.beforeShow, onShow: self.options.api.onShow, beforeHide: self.options.api.beforeHide, onHide: self.options.api.onHide, beforeContentLoad: self.options.api.beforeContentLoad, onContentLoad: self.options.api.onContentLoad
        }); self.construct();
    }; function calculateTip(corner, width, height) {
        var tips = { bottomRight: [[0, 0], [width, height], [width, 0]], bottomLeft: [[0, 0], [width, 0], [0, height]], topRight: [[0, height], [width, 0], [width, height]], topLeft: [[0, 0], [0, height], [width, height]], topMiddle: [[0, height], [width / 2, 0], [width, height]], bottomMiddle: [[0, 0], [width, 0], [width / 2, height]], rightMiddle: [[0, 0], [width, height / 2], [0, height]], leftMiddle: [[width, 0], [width, height], [0, height / 2]] }
        tips.leftTop = tips.bottomRight; tips.rightTop = tips.bottomLeft; tips.leftBottom = tips.topRight; tips.rightBottom = tips.topLeft; return tips[corner];
    }; function createTitle() {
        var self = this; self.elements.title = $(document.createElement('div')).addClass(self.options.style.classes.title).html(self.options.content.title.text).prependTo(self.elements.content); if (self.options.content.title.button !== false)
        { var button = $(document.createElement('a')).attr('href', '#').css('float', 'right').addClass(self.options.style.classes.button).html(self.options.content.title.button).prependTo(self.elements.title).click(self.hide) } 
    }; function createBorder() {
        var self = this; var width = self.options.style.border.width; var radius = self.options.style.border.radius; var color = self.options.style.border.color || self.options.style.tip.color; if (radius === 0)
            self.elements.content.css({ border: width + 'px solid ' + color })
        else {
            var wrapper = $(document.createElement('div')).addClass('qtip-contentWrapper').append(self.elements.content).appendTo(self.elements.tooltip); var borders = { topLeft: [radius, radius], topRight: [0, radius], bottomLeft: [radius, 0], bottomRight: [0, 0] }
            var shapes = {}; for (var i in borders)
            { shapes[i] = $(document.createElement('div')).css({ height: radius, width: radius, overflow: 'hidden', float: (i.search(/Left/) !== -1) ? 'left' : 'right', lineHeight: 0.1 }) }
            if (document.createElement('canvas').getContext) {
                for (var i in borders)
                { var canvas = $(document.createElement('canvas')).attr('height', radius).attr('width', radius).css({ verticalAlign: 'top' }).appendTo(shapes[i]); var context = canvas.get(0).getContext('2d'); context.fillStyle = color; context.beginPath(); context.arc(borders[i][0], borders[i][1], radius, 0, Math.PI * 2, false); context.fill(); } 
            }
            else if ($.browser.msie || document.namespaces) {
                var borders = { topLeft: [-90, 90, 0], topRight: [-90, 90, -radius], bottomLeft: [90, 270, 0], bottomRight: [90, 270, -radius] }
                for (var i in borders) {
                    $(document.createElement('v:arc')).attr('fill', 'true').attr('fillcolor', color).attr('stroked', 'false').attr('startangle', borders[i][0]).attr('endangle', borders[i][1]).css({ width: radius * 2 + 3, height: radius * 2 + 3, marginLeft: (i.search(/Right/) !== -1) ? borders[i][2] - 3.5 : -1, marginTop: -1, verticalAlign: 'top' }).appendTo(shapes[i]); if (($.support && $.support.objectAll) || ($.browser.msie && parseInt($.browser.version.charAt(0)) < 7)) {
                        if (i.search(/Left/) !== -1)
                            shapes[i].css({ marginRight: -3 })
                        else if (i.search(/Right/) !== -1)
                            shapes[i].css({ marginLeft: -3 })
                    } 
                } 
            }
            var betweenCorners = $(document.createElement('div')).addClass('qtip-betweenCorners').css({ height: radius, overflow: 'hidden', backgroundColor: color, lineHeight: 0.1 })
            var borderTop = $(document.createElement('div')).addClass('qtip-borderTop').css({ height: radius }).append(shapes['topLeft']).append(shapes['topRight']).append(betweenCorners).prependTo(wrapper); var borderBottom = $(document.createElement('div')).addClass('qtip-borderBottom').css({ height: radius, clear: 'both' }).append(shapes['bottomLeft']).append(shapes['bottomRight']).append(betweenCorners.clone()).appendTo(wrapper); var sideWidth = Math.max(radius, (radius + (width - radius)))
            var vertWidth = Math.max(width - radius, 0); self.elements.content.css({ margin: 0, border: '0px solid ' + color, borderWidth: vertWidth + 'px ' + sideWidth + 'px', position: 'relative', clear: 'both' })
        } 
    }; function createTip(corner) {
        var self = this; if (self.options.style.tip.corner === false) return; else if (!corner) corner = self.options.style.tip.corner; var color = self.options.style.tip.color || self.options.style.border.color; $(self.elements.tooltip).find('.' + self.options.style.classes.tip).remove(); self.elements.tip = $(document.createElement('div')).addClass(self.options.style.classes.tip).css({ width: 12, margin: '0 auto', lineHeight: 0.1, textAlign: 'left' }).attr('rel', corner)
        var coordinates = calculateTip(corner, self.options.style.tip.size.x, self.options.style.tip.size.y); if (document.createElement('canvas').getContext)
        { var canvas = $(document.createElement('canvas')).attr('width', self.options.style.tip.size.x).attr('height', self.options.style.tip.size.y).appendTo(self.elements.tip); var context = canvas.get(0).getContext('2d'); context.fillStyle = color; context.beginPath(); context.moveTo(coordinates[0][0], coordinates[0][1]); context.lineTo(coordinates[1][0], coordinates[1][1]); context.lineTo(coordinates[2][0], coordinates[2][1]); context.fill(); }
        else if ($.browser.msie || document.namespaces)
        { var path = 'm' + coordinates[0][0] + ',' + coordinates[0][1]; path += ' l' + coordinates[1][0] + ',' + coordinates[1][1]; path += ' ' + coordinates[2][0] + ',' + coordinates[2][1]; path += ' xe'; $(document.createElement('v:shape')).attr('fillcolor', color).attr('stroked', 'false').attr('coordsize', self.options.style.tip.size.x + ',' + self.options.style.tip.size.y).attr('path', path).css({ width: self.options.style.tip.size.x, height: self.options.style.tip.size.y, marginTop: -1 }).appendTo(self.elements.tip) }
        else return; var radiusAdjust = self.options.style.border.radius; var sideAdjust = (self.options.style.border.radius == 0) ? 0 : radiusAdjust; var pixelAdjust = ($.browser.msie || document.namespaces) ? 1 : 0; if (corner.search(/top|bottom/) !== -1) {
            if (corner.search(/Left/) !== -1)
            { self.elements.tip.css({ marginLeft: radiusAdjust - pixelAdjust }); self.elements.tooltip.css({ marginLeft: -radiusAdjust }) }
            else if (corner.search(/Right/) !== -1)
            { self.elements.tip.css({ marginLeft: Math.floor(self.elements.tooltip.outerWidth() - self.options.style.tip.size.x - sideAdjust - pixelAdjust) }); self.elements.tooltip.css({ marginLeft: sideAdjust }) }
            if (corner.search(/top/) !== -1) self.elements.tip.css({ marginTop: -self.options.style.tip.size.y + 1 });
        }
        else if (corner.search(/left|right/) !== -1) {
            if (corner.search(/Middle/) !== -1)
                self.elements.tip.css({ position: 'absolute', marginTop: Math.floor((self.elements.tooltip.outerHeight() / 2) - (self.options.style.tip.size.y / 2)) }); else if (corner.search(/Top/) !== -1)
            { self.elements.tip.css({ position: 'relative', top: radiusAdjust + self.options.style.tip.size.y }); self.elements.tooltip.css({ marginTop: -radiusAdjust - self.options.style.tip.size.y }) }
            else if (corner.search(/Bottom/) !== -1)
            { self.elements.tip.css({ position: 'relative', top: Math.floor(self.elements.tooltip.outerHeight() - radiusAdjust) }); self.elements.tooltip.css({ marginTop: radiusAdjust }) }
            if (corner.search(/left/) !== -1)
                self.elements.tip.css({ marginLeft: -self.options.style.tip.size.y }); else
                self.elements.tip.css({ marginLeft: self.elements.tooltip.outerWidth() - 1 - pixelAdjust });
        }
        if (corner.search(/left|top|right/) !== -1)
            self.elements.tip.prependTo(self.elements.tooltip); else
            self.elements.tip.appendTo(self.elements.tooltip); var paddingCorner = 'padding-' + corner.match(/left|right|top|bottom/)[0]; var paddingSize = (paddingCorner.search(/left/) !== -1) ? self.options.style.tip.size.x : self.options.style.tip.size.y
        if (paddingCorner !== 'padding-bottom') self.elements.tooltip.css(paddingCorner, paddingSize - 1);
    }; function assignEvents(state) {
        var self = this; var showTarget = self.options.show.when.target; var hideTarget = self.options.hide.when.target; if (state !== false) {
            if (self.options.position.type.search(/(fixed|absolute)/) !== -1)
                self.elements.tooltip.bind("mouseover.qtip", self.focus); if (self.options.position.target == 'mouse')
            { showTarget.bind("mousemove.qtip", self.updatePosition); showTarget.bind("mouseout.qtip", self.hide); }
            var inactiveEvents = ['click', 'dblclick', 'mousedown', 'mouseup', 'mousemove', 'mouseout', 'mouseenter', 'mouseleave', 'mouseover']; function inactiveTimer() {
                clearTimeout(self.timers.inactive); self.timers.inactive = setTimeout(function() {
                    $(inactiveEvents).each(function()
                    { hideTarget.unbind(this + '.qtip-inactive'); self.elements.content.unbind(this + '.qtip-inactive'); }); self.hide();
                }, self.options.hide.delay);
            }
            function showMethod(event) {
                event.stopPropagation(); clearTimeout(self.timers.hide); if (self.options.hide.when.event == 'inactive') {
                    $(inactiveEvents).each(function()
                    { hideTarget.bind(this + '.qtip-inactive', inactiveTimer); self.elements.content.bind(this + '.qtip-inactive', inactiveTimer); }); inactiveTimer();
                }
                clearTimeout(self.timers.show); self.timers.show = setTimeout(function(event) { self.show(event) }, self.options.show.delay);
            }
            if (self.options.hide.when.event !== 'inactive') {
                function hideMethod(event) {
                    if (self.options.hide.fixed === true && self.options.hide.when.event.search(/mouse(move|over|out|enter|leave)/i) !== -1 && $(event.relatedTarget).parents('.qtip').length > 0)
                    { event.stopPropagation(); event.preventDefault(); return false; }
                    event.stopPropagation(); clearTimeout(self.timers.show); clearTimeout(self.timers.hide); self.timers.hide = setTimeout(function() { self.hide() }, self.options.hide.delay);
                } 
            }
            if (self.options.show.when.target.add(self.options.show.when.target).length === 1 && self.options.show.when.event == self.options.hide.when.event && self.options.show.when.event == 'click')
                showTarget.toggle(showMethod, hideMethod); else
            { if ($.isFunction(showMethod)) showTarget.bind(self.options.show.when.event + '.qtip', showMethod); if ($.isFunction(hideMethod)) hideTarget.bind(self.options.hide.when.event + '.qtip', hideMethod); } 
        }
        else
        { showTarget.unbind("mousemove.qtip", self.updatePosition); showTarget.unbind("mouseout.qtip", self.hide); showTarget.unbind(self.options.show.when.event + '.qtip'); hideTarget.unbind(self.options.hide.when.event + '.qtip'); self.elements.tooltip.unbind(self.options.hide.when.event + '.qtip'); self.elements.tooltip.unbind("mouseover.qtip", self.focus); }
        return state;
    }; function screenAdjust(posX, posY, event) {
        var self = this; var corner = self.options.style.tip.corner || self.options.position.tooltip; var newX = posX + self.elements.tooltip.outerWidth(); var newY = posY + self.elements.tooltip.outerHeight(); var windowWidth = $(window).width() + $(window).scrollLeft(); var windowHeight = $(window).height() + $(window).scrollTop(); var overflow = { leftMin: (posX < 0), leftMax: (newX >= windowWidth), topMin: (posY < $(window).scrollTop()), topMax: (newY >= windowHeight) }; if (overflow.leftMin || overflow.leftMax) {
            if (overflow.leftMin)
                posX = (self.options.position.target == 'mouse') ? event.pageX : self.options.position.target.offset().left + self.options.position.target.outerWidth(); else if (overflow.leftMax) {
                if (corner.search(/(top|bottom)Middle/) !== -1)
                    posX = posX - (self.elements.tooltip.outerWidth() / 2) - (self.options.position.adjust.x * 2); else
                    posX = posX - self.options.position.target.outerWidth() - self.elements.tooltip.outerWidth() - (self.options.position.adjust.x * 2);
            }
            if (self.options.style.tip.corner !== false) {
                if (corner.search(/(top|bottom)Middle/) !== -1) {
                    if (overflow.leftMin)
                        corner = corner.replace('Middle', 'Left'); else if (overflow.leftMax)
                        corner = corner.replace('Middle', 'Right');
                }
                else if (corner.search(/right/) !== -1) corner = corner.replace('right', 'left'); else if (corner.search(/Right/) !== -1) corner = corner.replace('Right', 'Left'); else if (corner.search(/left/) !== -1) corner = corner.replace('left', 'right'); else if (corner.search(/Left/) !== -1) corner = corner.replace('Left', 'Right');
            } 
        }
        if (overflow.topMin || overflow.topMax) {
            if (overflow.topMin)
                posY = (self.options.position.target == 'mouse') ? event.pageY : self.options.position.target.offset().top + self.options.position.target.outerHeight(); else if (overflow.topMax) {
                if (corner.search(/(left|right)Middle/) !== -1)
                    posY = posY - (self.options.position.target.outerHeight() / 2) - (self.elements.tooltip.outerHeight() / 2) - (self.options.position.adjust.y * 2); else
                    posY = posY - self.options.position.target.outerHeight() - self.elements.tooltip.outerHeight() - (self.options.position.adjust.y * 2);
            }
            if (self.options.style.tip.corner !== false) {
                if (corner.search(/(left|right)Middle/) !== -1) {
                    if (overflow.topMin)
                        corner = corner.replace('Middle', 'Top'); else if (overflow.topMax)
                        corner = corner.replace('Middle', 'Bottom');
                }
                else if (corner.search(/top/) !== -1) corner = corner.replace('top', 'bottom'); else if (corner.search(/Top/) !== -1) corner = corner.replace('Top', 'Bottom'); else if (corner.search(/bottom/) !== -1) corner = corner.replace('bottom', 'top'); else if (corner.search(/Bottom/) !== -1) corner = corner.replace('Bottom', 'Top');
            } 
        }
        if (self.options.style.tip.corner !== false)
            if (corner != self.elements.tip.attr('rel')) self.createTip(corner); return { left: posX, top: posY };
    }; function debug(text) {
        if (window.console && window.console.log)
            window.console.log('qTip: ' + text);
    }; $.fn.qtip.defaults = { content: { prerender: false, text: '', url: false, data: null, title: { text: false, button: false} }, position: { target: false, corner: { target: 'bottomRight', tooltip: 'topLeft' }, adjust: { x: 0, y: 0, screen: false }, type: 'absolute', container: false }, show: { when: { target: false, event: 'mouseover' }, effect: { type: 'fade', length: 100 }, delay: 140, solo: false, ready: false }, hide: { when: { target: false, event: 'mouseout' }, effect: { type: 'fade', length: 100 }, delay: 0, fixed: false }, api: { beforePositionUpdate: function() { }, onPositionUpdate: function() { }, beforeShow: function() { }, onShow: function() { }, beforeHide: function() { }, onHide: function() { }, beforeContentLoad: function() { }, onContentLoad: function() { } } }; $.fn.qtip.styles = { defaults: { width: 'auto', padding: 5, background: 'white', color: '#111', border: { width: 1, radius: 0, color: '#d3d3d3' }, tip: { corner: false, color: false, size: { x: 12, y: 12} }, classes: { target: '', tip: 'qtip-tip', title: 'qtip-title', content: 'qtip-content', active: 'qtip-active'} }, cream: { border: { width: 3, radius: 0, color: '#F9E98E' }, background: '#FBF7AA', color: '#a2844a', width: 'auto', classes: { tooltip: 'qtip-cream'} }, light: { border: { width: 3, radius: 0, color: '#E2E2E2' }, background: 'white', color: '#454545', width: 'auto', classes: { tooltip: 'qtip-light'} }, dark: { border: { width: 3, radius: 0, color: '#303030' }, background: '#505050', color: '#f3f3f3', width: 'auto', classes: { tooltip: 'qtip-dark'} }, red: { border: { width: 3, radius: 0, color: '#CE6F6F' }, background: '#F79992', color: '#A94141', width: 'auto', classes: { tooltip: 'qtip-red'} }, green: { border: { width: 3, radius: 0, color: '#A9DB66' }, background: '#CDE6AC', color: '#58792E', width: 'auto', classes: { tooltip: 'qtip-green'}}}
})(jQuery); if (document.namespaces && document.namespaces["v"] == null)
{ document.namespaces.add("v", "urn:schemas-microsoft-com:vml"); var stylesheet = document.createStyleSheet().owningElement; stylesheet.styleSheet.cssText = "v\\:*{behavior:url(#default#VML); display: inline-block }"; }



var emptyStrings = new Array("", "come on, don't be lazy", "whole numbers, no decimals", "can't leave this blank punk");
//hides all fields but 'thisone' that have class="new_control"
function hideAllBut(thisone) {
    $('.new_control').hide();
    $(thisone).slideDown("fast");
};

//runs on keyup
//hides 'hideThisButton' if 'testThisField' is empty     
function testForEmptyOnKeyup(testThisField, hideThisButton) {
    $(testThisField).keyup(function(event) {
        testForEmpty(testThisField, hideThisButton);
    });
};

//hides 'hideThisButton' if 'testThisField' is empty      
function testForEmpty(testThisField, hideThisButton) {
    if ($.trim($(testThisField).val()) == "" || $.trim($(testThisField).val()) == "come on, don't be lazy" || $.trim($(testThisField).val()) == "whole numbers, no decimals" || $.trim($(testThisField).val()) == "can't leave this blank punk") {
        $(hideThisButton).slideUp("fast");
    }
    else { $(hideThisButton).slideDown("fast"); }
    ShowSubmitNew();
};

//decides whether or not to show the submit button
function ShowSubmitNew() {
    if (
                ($("input[id$='txt_person']:first").val() != "" && $("input[id$='txt_person']:first").val() != "come on, don't be lazy") &&
                ($("input[id$='txt_amount']:first").val() != "" && $("input[id$='txt_amount']:first").val() != "whole numbers, no decimals") &&
                ($("input[id$='rad_i_borrowed']:first").attr('checked') || $("input[id$='rad_i_borrowed_false']:first").attr('checked')) &&
                (
                    $("input[id$='rad_is_money']").attr('checked') ||
                    (
                        $("input[id$='rad_is_money_false']").attr('checked') &&
                        $("input[id$='txt_what_stuff']:first").val() != "" &&
                        $("input[id$='txt_what_stuff']:first").val() != "can't leave this blank punk"
                    )
                )
            ) { $("#submitDebt").slideDown("fast"); }
    else { $("#submitDebt").hide(); }
}

function debtReset() {
    $("input[id$='txt_person']").keyup(function(event) { testForEmpty("input[id$='txt_person']:first", "#whoNext"); });
    $("input[id$='txt_what_stuff']").keyup(function(event) { testForEmpty("input[id$='txt_what_stuff']:first", "#whatNext"); });
    $("input[id$='txt_amount']").keyup(function(event) { ShowSubmitNew(); });
}

function formatCurrency(num) {
    num = num.toString().replace(/\$|\,/g, '');
    if (isNaN(num))
        num = "0";
    sign = (num == (num = Math.abs(num)));
    num = Math.floor(num * 100 + 0.50000000001);
    cents = num % 100;
    num = Math.floor(num / 100).toString();
    if (cents < 10)
        cents = "0" + cents;
    for (var i = 0; i < Math.floor((num.length - (1 + i)) / 3); i++)
        num = num.substring(0, num.length - (4 * i + 3)) + ',' + num.substring(num.length - (4 * i + 3));
    return (((sign) ? '' : '-') + '$' + num + '.' + cents).replace(".00", "");
}

function moneyToInt(num) {
    num = num.replace(new RegExp(",", "g"), "")
    return parseInt(num.replace("$",""));
}
