kdj_singlish
Version:
KDJ Singlish is an app which created to help people to type in sinhala without making any mistakes. This will save your time and fix all the issues you are getting when you type. Just use it and let me know the issues.
1,073 lines (1,045 loc) • 150 kB
JavaScript
/*! jQuery v3.3.1 | (c) JS Foundation and other contributors | jquery.org/license */ ! function (e, t) {
"use strict";
"object" == typeof module && "object" == typeof module.exports ? module.exports = e.document ? t(e, !0) : function (e) {
if (!e.document) throw new Error("jQuery requires a window with a document");
return t(e)
} : t(e)
}("undefined" != typeof window ? window : this, function (e, t) {
"use strict";
var n = [],
r = e.document,
i = Object.getPrototypeOf,
o = n.slice,
a = n.concat,
s = n.push,
u = n.indexOf,
l = {},
c = l.toString,
f = l.hasOwnProperty,
p = f.toString,
d = p.call(Object),
h = {},
g = function e(t) {
return "function" == typeof t && "number" != typeof t.nodeType
},
y = function e(t) {
return null != t && t === t.window
},
v = {
type: !0,
src: !0,
noModule: !0
};
function m(e, t, n) {
var i, o = (t = t || r).createElement("script");
if (o.text = e, n)
for (i in v) n[i] && (o[i] = n[i]);
t.head.appendChild(o).parentNode.removeChild(o)
}
function x(e) {
return null == e ? e + "" : "object" == typeof e || "function" == typeof e ? l[c.call(e)] || "object" : typeof e
}
var b = "3.3.1",
w = function (e, t) {
return new w.fn.init(e, t)
},
T = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;
w.fn = w.prototype = {
jquery: "3.3.1",
constructor: w,
length: 0,
toArray: function () {
return o.call(this)
},
get: function (e) {
return null == e ? o.call(this) : e < 0 ? this[e + this.length] : this[e]
},
pushStack: function (e) {
var t = w.merge(this.constructor(), e);
return t.prevObject = this, t
},
each: function (e) {
return w.each(this, e)
},
map: function (e) {
return this.pushStack(w.map(this, function (t, n) {
return e.call(t, n, t)
}))
},
slice: function () {
return this.pushStack(o.apply(this, arguments))
},
first: function () {
return this.eq(0)
},
last: function () {
return this.eq(-1)
},
eq: function (e) {
var t = this.length,
n = +e + (e < 0 ? t : 0);
return this.pushStack(n >= 0 && n < t ? [this[n]] : [])
},
end: function () {
return this.prevObject || this.constructor()
},
push: s,
sort: n.sort,
splice: n.splice
}, w.extend = w.fn.extend = function () {
var e, t, n, r, i, o, a = arguments[0] || {},
s = 1,
u = arguments.length,
l = !1;
for ("boolean" == typeof a && (l = a, a = arguments[s] || {}, s++), "object" == typeof a || g(a) || (a = {}), s === u && (a = this, s--); s < u; s++)
if (null != (e = arguments[s]))
for (t in e) n = a[t], a !== (r = e[t]) && (l && r && (w.isPlainObject(r) || (i = Array.isArray(r))) ? (i ? (i = !1, o = n && Array.isArray(n) ? n : []) : o = n && w.isPlainObject(n) ? n : {}, a[t] = w.extend(l, o, r)) : void 0 !== r && (a[t] = r));
return a
}, w.extend({
expando: "jQuery" + ("3.3.1" + Math.random()).replace(/\D/g, ""),
isReady: !0,
error: function (e) {
throw new Error(e)
},
noop: function () {},
isPlainObject: function (e) {
var t, n;
return !(!e || "[object Object]" !== c.call(e)) && (!(t = i(e)) || "function" == typeof (n = f.call(t, "constructor") && t.constructor) && p.call(n) === d)
},
isEmptyObject: function (e) {
var t;
for (t in e) return !1;
return !0
},
globalEval: function (e) {
m(e)
},
each: function (e, t) {
var n, r = 0;
if (C(e)) {
for (n = e.length; r < n; r++)
if (!1 === t.call(e[r], r, e[r])) break
} else
for (r in e)
if (!1 === t.call(e[r], r, e[r])) break;
return e
},
trim: function (e) {
return null == e ? "" : (e + "").replace(T, "")
},
makeArray: function (e, t) {
var n = t || [];
return null != e && (C(Object(e)) ? w.merge(n, "string" == typeof e ? [e] : e) : s.call(n, e)), n
},
inArray: function (e, t, n) {
return null == t ? -1 : u.call(t, e, n)
},
merge: function (e, t) {
for (var n = +t.length, r = 0, i = e.length; r < n; r++) e[i++] = t[r];
return e.length = i, e
},
grep: function (e, t, n) {
for (var r, i = [], o = 0, a = e.length, s = !n; o < a; o++)(r = !t(e[o], o)) !== s && i.push(e[o]);
return i
},
map: function (e, t, n) {
var r, i, o = 0,
s = [];
if (C(e))
for (r = e.length; o < r; o++) null != (i = t(e[o], o, n)) && s.push(i);
else
for (o in e) null != (i = t(e[o], o, n)) && s.push(i);
return a.apply([], s)
},
guid: 1,
support: h
}), "function" == typeof Symbol && (w.fn[Symbol.iterator] = n[Symbol.iterator]), w.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function (e, t) {
l["[object " + t + "]"] = t.toLowerCase()
});
function C(e) {
var t = !!e && "length" in e && e.length,
n = x(e);
return !g(e) && !y(e) && ("array" === n || 0 === t || "number" == typeof t && t > 0 && t - 1 in e)
}
var E = function (e) {
var t, n, r, i, o, a, s, u, l, c, f, p, d, h, g, y, v, m, x, b = "sizzle" + 1 * new Date,
w = e.document,
T = 0,
C = 0,
E = ae(),
k = ae(),
S = ae(),
D = function (e, t) {
return e === t && (f = !0), 0
},
N = {}.hasOwnProperty,
A = [],
j = A.pop,
q = A.push,
L = A.push,
H = A.slice,
O = function (e, t) {
for (var n = 0, r = e.length; n < r; n++)
if (e[n] === t) return n;
return -1
},
P = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
M = "[\\x20\\t\\r\\n\\f]",
R = "(?:\\\\.|[\\w-]|[^\0-\\xa0])+",
I = "\\[" + M + "*(" + R + ")(?:" + M + "*([*^$|!~]?=)" + M + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + R + "))|)" + M + "*\\]",
W = ":(" + R + ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" + I + ")*)|.*)\\)|)",
$ = new RegExp(M + "+", "g"),
B = new RegExp("^" + M + "+|((?:^|[^\\\\])(?:\\\\.)*)" + M + "+$", "g"),
F = new RegExp("^" + M + "*," + M + "*"),
_ = new RegExp("^" + M + "*([>+~]|" + M + ")" + M + "*"),
z = new RegExp("=" + M + "*([^\\]'\"]*?)" + M + "*\\]", "g"),
X = new RegExp(W),
U = new RegExp("^" + R + "$"),
V = {
ID: new RegExp("^#(" + R + ")"),
CLASS: new RegExp("^\\.(" + R + ")"),
TAG: new RegExp("^(" + R + "|[*])"),
ATTR: new RegExp("^" + I),
PSEUDO: new RegExp("^" + W),
CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + M + "*(even|odd|(([+-]|)(\\d*)n|)" + M + "*(?:([+-]|)" + M + "*(\\d+)|))" + M + "*\\)|)", "i"),
bool: new RegExp("^(?:" + P + ")$", "i"),
needsContext: new RegExp("^" + M + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + M + "*((?:-\\d)?\\d*)" + M + "*\\)|)(?=[^-]|$)", "i")
},
G = /^(?:input|select|textarea|button)$/i,
Y = /^h\d$/i,
Q = /^[^{]+\{\s*\[native \w/,
J = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
K = /[+~]/,
Z = new RegExp("\\\\([\\da-f]{1,6}" + M + "?|(" + M + ")|.)", "ig"),
ee = function (e, t, n) {
var r = "0x" + t - 65536;
return r !== r || n ? t : r < 0 ? String.fromCharCode(r + 65536) : String.fromCharCode(r >> 10 | 55296, 1023 & r | 56320)
},
te = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,
ne = function (e, t) {
return t ? "\0" === e ? "\ufffd" : e.slice(0, -1) + "\\" + e.charCodeAt(e.length - 1).toString(16) + " " : "\\" + e
},
re = function () {
p()
},
ie = me(function (e) {
return !0 === e.disabled && ("form" in e || "label" in e)
}, {
dir: "parentNode",
next: "legend"
});
try {
L.apply(A = H.call(w.childNodes), w.childNodes), A[w.childNodes.length].nodeType
} catch (e) {
L = {
apply: A.length ? function (e, t) {
q.apply(e, H.call(t))
} : function (e, t) {
var n = e.length,
r = 0;
while (e[n++] = t[r++]);
e.length = n - 1
}
}
}
function oe(e, t, r, i) {
var o, s, l, c, f, h, v, m = t && t.ownerDocument,
T = t ? t.nodeType : 9;
if (r = r || [], "string" != typeof e || !e || 1 !== T && 9 !== T && 11 !== T) return r;
if (!i && ((t ? t.ownerDocument || t : w) !== d && p(t), t = t || d, g)) {
if (11 !== T && (f = J.exec(e)))
if (o = f[1]) {
if (9 === T) {
if (!(l = t.getElementById(o))) return r;
if (l.id === o) return r.push(l), r
} else if (m && (l = m.getElementById(o)) && x(t, l) && l.id === o) return r.push(l), r
} else {
if (f[2]) return L.apply(r, t.getElementsByTagName(e)), r;
if ((o = f[3]) && n.getElementsByClassName && t.getElementsByClassName) return L.apply(r, t.getElementsByClassName(o)), r
} if (n.qsa && !S[e + " "] && (!y || !y.test(e))) {
if (1 !== T) m = t, v = e;
else if ("object" !== t.nodeName.toLowerCase()) {
(c = t.getAttribute("id")) ? c = c.replace(te, ne): t.setAttribute("id", c = b), s = (h = a(e)).length;
while (s--) h[s] = "#" + c + " " + ve(h[s]);
v = h.join(","), m = K.test(e) && ge(t.parentNode) || t
}
if (v) try {
return L.apply(r, m.querySelectorAll(v)), r
} catch (e) {} finally {
c === b && t.removeAttribute("id")
}
}
}
return u(e.replace(B, "$1"), t, r, i)
}
function ae() {
var e = [];
function t(n, i) {
return e.push(n + " ") > r.cacheLength && delete t[e.shift()], t[n + " "] = i
}
return t
}
function se(e) {
return e[b] = !0, e
}
function ue(e) {
var t = d.createElement("fieldset");
try {
return !!e(t)
} catch (e) {
return !1
} finally {
t.parentNode && t.parentNode.removeChild(t), t = null
}
}
function le(e, t) {
var n = e.split("|"),
i = n.length;
while (i--) r.attrHandle[n[i]] = t
}
function ce(e, t) {
var n = t && e,
r = n && 1 === e.nodeType && 1 === t.nodeType && e.sourceIndex - t.sourceIndex;
if (r) return r;
if (n)
while (n = n.nextSibling)
if (n === t) return -1;
return e ? 1 : -1
}
function fe(e) {
return function (t) {
return "input" === t.nodeName.toLowerCase() && t.type === e
}
}
function pe(e) {
return function (t) {
var n = t.nodeName.toLowerCase();
return ("input" === n || "button" === n) && t.type === e
}
}
function de(e) {
return function (t) {
return "form" in t ? t.parentNode && !1 === t.disabled ? "label" in t ? "label" in t.parentNode ? t.parentNode.disabled === e : t.disabled === e : t.isDisabled === e || t.isDisabled !== !e && ie(t) === e : t.disabled === e : "label" in t && t.disabled === e
}
}
function he(e) {
return se(function (t) {
return t = +t, se(function (n, r) {
var i, o = e([], n.length, t),
a = o.length;
while (a--) n[i = o[a]] && (n[i] = !(r[i] = n[i]))
})
})
}
function ge(e) {
return e && "undefined" != typeof e.getElementsByTagName && e
}
n = oe.support = {}, o = oe.isXML = function (e) {
var t = e && (e.ownerDocument || e).documentElement;
return !!t && "HTML" !== t.nodeName
}, p = oe.setDocument = function (e) {
var t, i, a = e ? e.ownerDocument || e : w;
return a !== d && 9 === a.nodeType && a.documentElement ? (d = a, h = d.documentElement, g = !o(d), w !== d && (i = d.defaultView) && i.top !== i && (i.addEventListener ? i.addEventListener("unload", re, !1) : i.attachEvent && i.attachEvent("onunload", re)), n.attributes = ue(function (e) {
return e.className = "i", !e.getAttribute("className")
}), n.getElementsByTagName = ue(function (e) {
return e.appendChild(d.createComment("")), !e.getElementsByTagName("*").length
}), n.getElementsByClassName = Q.test(d.getElementsByClassName), n.getById = ue(function (e) {
return h.appendChild(e).id = b, !d.getElementsByName || !d.getElementsByName(b).length
}), n.getById ? (r.filter.ID = function (e) {
var t = e.replace(Z, ee);
return function (e) {
return e.getAttribute("id") === t
}
}, r.find.ID = function (e, t) {
if ("undefined" != typeof t.getElementById && g) {
var n = t.getElementById(e);
return n ? [n] : []
}
}) : (r.filter.ID = function (e) {
var t = e.replace(Z, ee);
return function (e) {
var n = "undefined" != typeof e.getAttributeNode && e.getAttributeNode("id");
return n && n.value === t
}
}, r.find.ID = function (e, t) {
if ("undefined" != typeof t.getElementById && g) {
var n, r, i, o = t.getElementById(e);
if (o) {
if ((n = o.getAttributeNode("id")) && n.value === e) return [o];
i = t.getElementsByName(e), r = 0;
while (o = i[r++])
if ((n = o.getAttributeNode("id")) && n.value === e) return [o]
}
return []
}
}), r.find.TAG = n.getElementsByTagName ? function (e, t) {
return "undefined" != typeof t.getElementsByTagName ? t.getElementsByTagName(e) : n.qsa ? t.querySelectorAll(e) : void 0
} : function (e, t) {
var n, r = [],
i = 0,
o = t.getElementsByTagName(e);
if ("*" === e) {
while (n = o[i++]) 1 === n.nodeType && r.push(n);
return r
}
return o
}, r.find.CLASS = n.getElementsByClassName && function (e, t) {
if ("undefined" != typeof t.getElementsByClassName && g) return t.getElementsByClassName(e)
}, v = [], y = [], (n.qsa = Q.test(d.querySelectorAll)) && (ue(function (e) {
h.appendChild(e).innerHTML = "<a id='" + b + "'></a><select id='" + b + "-\r\\' msallowcapture=''><option selected=''></option></select>", e.querySelectorAll("[msallowcapture^='']").length && y.push("[*^$]=" + M + "*(?:''|\"\")"), e.querySelectorAll("[selected]").length || y.push("\\[" + M + "*(?:value|" + P + ")"), e.querySelectorAll("[id~=" + b + "-]").length || y.push("~="), e.querySelectorAll(":checked").length || y.push(":checked"), e.querySelectorAll("a#" + b + "+*").length || y.push(".#.+[+~]")
}), ue(function (e) {
e.innerHTML = "<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";
var t = d.createElement("input");
t.setAttribute("type", "hidden"), e.appendChild(t).setAttribute("name", "D"), e.querySelectorAll("[name=d]").length && y.push("name" + M + "*[*^$|!~]?="), 2 !== e.querySelectorAll(":enabled").length && y.push(":enabled", ":disabled"), h.appendChild(e).disabled = !0, 2 !== e.querySelectorAll(":disabled").length && y.push(":enabled", ":disabled"), e.querySelectorAll("*,:x"), y.push(",.*:")
})), (n.matchesSelector = Q.test(m = h.matches || h.webkitMatchesSelector || h.mozMatchesSelector || h.oMatchesSelector || h.msMatchesSelector)) && ue(function (e) {
n.disconnectedMatch = m.call(e, "*"), m.call(e, "[s!='']:x"), v.push("!=", W)
}), y = y.length && new RegExp(y.join("|")), v = v.length && new RegExp(v.join("|")), t = Q.test(h.compareDocumentPosition), x = t || Q.test(h.contains) ? function (e, t) {
var n = 9 === e.nodeType ? e.documentElement : e,
r = t && t.parentNode;
return e === r || !(!r || 1 !== r.nodeType || !(n.contains ? n.contains(r) : e.compareDocumentPosition && 16 & e.compareDocumentPosition(r)))
} : function (e, t) {
if (t)
while (t = t.parentNode)
if (t === e) return !0;
return !1
}, D = t ? function (e, t) {
if (e === t) return f = !0, 0;
var r = !e.compareDocumentPosition - !t.compareDocumentPosition;
return r || (1 & (r = (e.ownerDocument || e) === (t.ownerDocument || t) ? e.compareDocumentPosition(t) : 1) || !n.sortDetached && t.compareDocumentPosition(e) === r ? e === d || e.ownerDocument === w && x(w, e) ? -1 : t === d || t.ownerDocument === w && x(w, t) ? 1 : c ? O(c, e) - O(c, t) : 0 : 4 & r ? -1 : 1)
} : function (e, t) {
if (e === t) return f = !0, 0;
var n, r = 0,
i = e.parentNode,
o = t.parentNode,
a = [e],
s = [t];
if (!i || !o) return e === d ? -1 : t === d ? 1 : i ? -1 : o ? 1 : c ? O(c, e) - O(c, t) : 0;
if (i === o) return ce(e, t);
n = e;
while (n = n.parentNode) a.unshift(n);
n = t;
while (n = n.parentNode) s.unshift(n);
while (a[r] === s[r]) r++;
return r ? ce(a[r], s[r]) : a[r] === w ? -1 : s[r] === w ? 1 : 0
}, d) : d
}, oe.matches = function (e, t) {
return oe(e, null, null, t)
}, oe.matchesSelector = function (e, t) {
if ((e.ownerDocument || e) !== d && p(e), t = t.replace(z, "='$1']"), n.matchesSelector && g && !S[t + " "] && (!v || !v.test(t)) && (!y || !y.test(t))) try {
var r = m.call(e, t);
if (r || n.disconnectedMatch || e.document && 11 !== e.document.nodeType) return r
} catch (e) {}
return oe(t, d, null, [e]).length > 0
}, oe.contains = function (e, t) {
return (e.ownerDocument || e) !== d && p(e), x(e, t)
}, oe.attr = function (e, t) {
(e.ownerDocument || e) !== d && p(e);
var i = r.attrHandle[t.toLowerCase()],
o = i && N.call(r.attrHandle, t.toLowerCase()) ? i(e, t, !g) : void 0;
return void 0 !== o ? o : n.attributes || !g ? e.getAttribute(t) : (o = e.getAttributeNode(t)) && o.specified ? o.value : null
}, oe.escape = function (e) {
return (e + "").replace(te, ne)
}, oe.error = function (e) {
throw new Error("Syntax error, unrecognized expression: " + e)
}, oe.uniqueSort = function (e) {
var t, r = [],
i = 0,
o = 0;
if (f = !n.detectDuplicates, c = !n.sortStable && e.slice(0), e.sort(D), f) {
while (t = e[o++]) t === e[o] && (i = r.push(o));
while (i--) e.splice(r[i], 1)
}
return c = null, e
}, i = oe.getText = function (e) {
var t, n = "",
r = 0,
o = e.nodeType;
if (o) {
if (1 === o || 9 === o || 11 === o) {
if ("string" == typeof e.textContent) return e.textContent;
for (e = e.firstChild; e; e = e.nextSibling) n += i(e)
} else if (3 === o || 4 === o) return e.nodeValue
} else
while (t = e[r++]) n += i(t);
return n
}, (r = oe.selectors = {
cacheLength: 50,
createPseudo: se,
match: V,
attrHandle: {},
find: {},
relative: {
">": {
dir: "parentNode",
first: !0
},
" ": {
dir: "parentNode"
},
"+": {
dir: "previousSibling",
first: !0
},
"~": {
dir: "previousSibling"
}
},
preFilter: {
ATTR: function (e) {
return e[1] = e[1].replace(Z, ee), e[3] = (e[3] || e[4] || e[5] || "").replace(Z, ee), "~=" === e[2] && (e[3] = " " + e[3] + " "), e.slice(0, 4)
},
CHILD: function (e) {
return e[1] = e[1].toLowerCase(), "nth" === e[1].slice(0, 3) ? (e[3] || oe.error(e[0]), e[4] = +(e[4] ? e[5] + (e[6] || 1) : 2 * ("even" === e[3] || "odd" === e[3])), e[5] = +(e[7] + e[8] || "odd" === e[3])) : e[3] && oe.error(e[0]), e
},
PSEUDO: function (e) {
var t, n = !e[6] && e[2];
return V.CHILD.test(e[0]) ? null : (e[3] ? e[2] = e[4] || e[5] || "" : n && X.test(n) && (t = a(n, !0)) && (t = n.indexOf(")", n.length - t) - n.length) && (e[0] = e[0].slice(0, t), e[2] = n.slice(0, t)), e.slice(0, 3))
}
},
filter: {
TAG: function (e) {
var t = e.replace(Z, ee).toLowerCase();
return "*" === e ? function () {
return !0
} : function (e) {
return e.nodeName && e.nodeName.toLowerCase() === t
}
},
CLASS: function (e) {
var t = E[e + " "];
return t || (t = new RegExp("(^|" + M + ")" + e + "(" + M + "|$)")) && E(e, function (e) {
return t.test("string" == typeof e.className && e.className || "undefined" != typeof e.getAttribute && e.getAttribute("class") || "")
})
},
ATTR: function (e, t, n) {
return function (r) {
var i = oe.attr(r, e);
return null == i ? "!=" === t : !t || (i += "", "=" === t ? i === n : "!=" === t ? i !== n : "^=" === t ? n && 0 === i.indexOf(n) : "*=" === t ? n && i.indexOf(n) > -1 : "$=" === t ? n && i.slice(-n.length) === n : "~=" === t ? (" " + i.replace($, " ") + " ").indexOf(n) > -1 : "|=" === t && (i === n || i.slice(0, n.length + 1) === n + "-"))
}
},
CHILD: function (e, t, n, r, i) {
var o = "nth" !== e.slice(0, 3),
a = "last" !== e.slice(-4),
s = "of-type" === t;
return 1 === r && 0 === i ? function (e) {
return !!e.parentNode
} : function (t, n, u) {
var l, c, f, p, d, h, g = o !== a ? "nextSibling" : "previousSibling",
y = t.parentNode,
v = s && t.nodeName.toLowerCase(),
m = !u && !s,
x = !1;
if (y) {
if (o) {
while (g) {
p = t;
while (p = p[g])
if (s ? p.nodeName.toLowerCase() === v : 1 === p.nodeType) return !1;
h = g = "only" === e && !h && "nextSibling"
}
return !0
}
if (h = [a ? y.firstChild : y.lastChild], a && m) {
x = (d = (l = (c = (f = (p = y)[b] || (p[b] = {}))[p.uniqueID] || (f[p.uniqueID] = {}))[e] || [])[0] === T && l[1]) && l[2], p = d && y.childNodes[d];
while (p = ++d && p && p[g] || (x = d = 0) || h.pop())
if (1 === p.nodeType && ++x && p === t) {
c[e] = [T, d, x];
break
}
} else if (m && (x = d = (l = (c = (f = (p = t)[b] || (p[b] = {}))[p.uniqueID] || (f[p.uniqueID] = {}))[e] || [])[0] === T && l[1]), !1 === x)
while (p = ++d && p && p[g] || (x = d = 0) || h.pop())
if ((s ? p.nodeName.toLowerCase() === v : 1 === p.nodeType) && ++x && (m && ((c = (f = p[b] || (p[b] = {}))[p.uniqueID] || (f[p.uniqueID] = {}))[e] = [T, x]), p === t)) break;
return (x -= i) === r || x % r == 0 && x / r >= 0
}
}
},
PSEUDO: function (e, t) {
var n, i = r.pseudos[e] || r.setFilters[e.toLowerCase()] || oe.error("unsupported pseudo: " + e);
return i[b] ? i(t) : i.length > 1 ? (n = [e, e, "", t], r.setFilters.hasOwnProperty(e.toLowerCase()) ? se(function (e, n) {
var r, o = i(e, t),
a = o.length;
while (a--) e[r = O(e, o[a])] = !(n[r] = o[a])
}) : function (e) {
return i(e, 0, n)
}) : i
}
},
pseudos: {
not: se(function (e) {
var t = [],
n = [],
r = s(e.replace(B, "$1"));
return r[b] ? se(function (e, t, n, i) {
var o, a = r(e, null, i, []),
s = e.length;
while (s--)(o = a[s]) && (e[s] = !(t[s] = o))
}) : function (e, i, o) {
return t[0] = e, r(t, null, o, n), t[0] = null, !n.pop()
}
}),
has: se(function (e) {
return function (t) {
return oe(e, t).length > 0
}
}),
contains: se(function (e) {
return e = e.replace(Z, ee),
function (t) {
return (t.textContent || t.innerText || i(t)).indexOf(e) > -1
}
}),
lang: se(function (e) {
return U.test(e || "") || oe.error("unsupported lang: " + e), e = e.replace(Z, ee).toLowerCase(),
function (t) {
var n;
do {
if (n = g ? t.lang : t.getAttribute("xml:lang") || t.getAttribute("lang")) return (n = n.toLowerCase()) === e || 0 === n.indexOf(e + "-")
} while ((t = t.parentNode) && 1 === t.nodeType);
return !1
}
}),
target: function (t) {
var n = e.location && e.location.hash;
return n && n.slice(1) === t.id
},
root: function (e) {
return e === h
},
focus: function (e) {
return e === d.activeElement && (!d.hasFocus || d.hasFocus()) && !!(e.type || e.href || ~e.tabIndex)
},
enabled: de(!1),
disabled: de(!0),
checked: function (e) {
var t = e.nodeName.toLowerCase();
return "input" === t && !!e.checked || "option" === t && !!e.selected
},
selected: function (e) {
return e.parentNode && e.parentNode.selectedIndex, !0 === e.selected
},
empty: function (e) {
for (e = e.firstChild; e; e = e.nextSibling)
if (e.nodeType < 6) return !1;
return !0
},
parent: function (e) {
return !r.pseudos.empty(e)
},
header: function (e) {
return Y.test(e.nodeName)
},
input: function (e) {
return G.test(e.nodeName)
},
button: function (e) {
var t = e.nodeName.toLowerCase();
return "input" === t && "button" === e.type || "button" === t
},
text: function (e) {
var t;
return "input" === e.nodeName.toLowerCase() && "text" === e.type && (null == (t = e.getAttribute("type")) || "text" === t.toLowerCase())
},
first: he(function () {
return [0]
}),
last: he(function (e, t) {
return [t - 1]
}),
eq: he(function (e, t, n) {
return [n < 0 ? n + t : n]
}),
even: he(function (e, t) {
for (var n = 0; n < t; n += 2) e.push(n);
return e
}),
odd: he(function (e, t) {
for (var n = 1; n < t; n += 2) e.push(n);
return e
}),
lt: he(function (e, t, n) {
for (var r = n < 0 ? n + t : n; --r >= 0;) e.push(r);
return e
}),
gt: he(function (e, t, n) {
for (var r = n < 0 ? n + t : n; ++r < t;) e.push(r);
return e
})
}
}).pseudos.nth = r.pseudos.eq;
for (t in {
radio: !0,
checkbox: !0,
file: !0,
password: !0,
image: !0
}) r.pseudos[t] = fe(t);
for (t in {
submit: !0,
reset: !0
}) r.pseudos[t] = pe(t);
function ye() {}
ye.prototype = r.filters = r.pseudos, r.setFilters = new ye, a = oe.tokenize = function (e, t) {
var n, i, o, a, s, u, l, c = k[e + " "];
if (c) return t ? 0 : c.slice(0);
s = e, u = [], l = r.preFilter;
while (s) {
n && !(i = F.exec(s)) || (i && (s = s.slice(i[0].length) || s), u.push(o = [])), n = !1, (i = _.exec(s)) && (n = i.shift(), o.push({
value: n,
type: i[0].replace(B, " ")
}), s = s.slice(n.length));
for (a in r.filter) !(i = V[a].exec(s)) || l[a] && !(i = l[a](i)) || (n = i.shift(), o.push({
value: n,
type: a,
matches: i
}), s = s.slice(n.length));
if (!n) break
}
return t ? s.length : s ? oe.error(e) : k(e, u).slice(0)
};
function ve(e) {
for (var t = 0, n = e.length, r = ""; t < n; t++) r += e[t].value;
return r
}
function me(e, t, n) {
var r = t.dir,
i = t.next,
o = i || r,
a = n && "parentNode" === o,
s = C++;
return t.first ? function (t, n, i) {
while (t = t[r])
if (1 === t.nodeType || a) return e(t, n, i);
return !1
} : function (t, n, u) {
var l, c, f, p = [T, s];
if (u) {
while (t = t[r])
if ((1 === t.nodeType || a) && e(t, n, u)) return !0
} else
while (t = t[r])
if (1 === t.nodeType || a)
if (f = t[b] || (t[b] = {}), c = f[t.uniqueID] || (f[t.uniqueID] = {}), i && i === t.nodeName.toLowerCase()) t = t[r] || t;
else {
if ((l = c[o]) && l[0] === T && l[1] === s) return p[2] = l[2];
if (c[o] = p, p[2] = e(t, n, u)) return !0
} return !1
}
}
function xe(e) {
return e.length > 1 ? function (t, n, r) {
var i = e.length;
while (i--)
if (!e[i](t, n, r)) return !1;
return !0
} : e[0]
}
function be(e, t, n) {
for (var r = 0, i = t.length; r < i; r++) oe(e, t[r], n);
return n
}
function we(e, t, n, r, i) {
for (var o, a = [], s = 0, u = e.length, l = null != t; s < u; s++)(o = e[s]) && (n && !n(o, r, i) || (a.push(o), l && t.push(s)));
return a
}
function Te(e, t, n, r, i, o) {
return r && !r[b] && (r = Te(r)), i && !i[b] && (i = Te(i, o)), se(function (o, a, s, u) {
var l, c, f, p = [],
d = [],
h = a.length,
g = o || be(t || "*", s.nodeType ? [s] : s, []),
y = !e || !o && t ? g : we(g, p, e, s, u),
v = n ? i || (o ? e : h || r) ? [] : a : y;
if (n && n(y, v, s, u), r) {
l = we(v, d), r(l, [], s, u), c = l.length;
while (c--)(f = l[c]) && (v[d[c]] = !(y[d[c]] = f))
}
if (o) {
if (i || e) {
if (i) {
l = [], c = v.length;
while (c--)(f = v[c]) && l.push(y[c] = f);
i(null, v = [], l, u)
}
c = v.length;
while (c--)(f = v[c]) && (l = i ? O(o, f) : p[c]) > -1 && (o[l] = !(a[l] = f))
}
} else v = we(v === a ? v.splice(h, v.length) : v), i ? i(null, a, v, u) : L.apply(a, v)
})
}
function Ce(e) {
for (var t, n, i, o = e.length, a = r.relative[e[0].type], s = a || r.relative[" "], u = a ? 1 : 0, c = me(function (e) {
return e === t
}, s, !0), f = me(function (e) {
return O(t, e) > -1
}, s, !0), p = [function (e, n, r) {
var i = !a && (r || n !== l) || ((t = n).nodeType ? c(e, n, r) : f(e, n, r));
return t = null, i
}]; u < o; u++)
if (n = r.relative[e[u].type]) p = [me(xe(p), n)];
else {
if ((n = r.filter[e[u].type].apply(null, e[u].matches))[b]) {
for (i = ++u; i < o; i++)
if (r.relative[e[i].type]) break;
return Te(u > 1 && xe(p), u > 1 && ve(e.slice(0, u - 1).concat({
value: " " === e[u - 2].type ? "*" : ""
})).replace(B, "$1"), n, u < i && Ce(e.slice(u, i)), i < o && Ce(e = e.slice(i)), i < o && ve(e))
}
p.push(n)
} return xe(p)
}
function Ee(e, t) {
var n = t.length > 0,
i = e.length > 0,
o = function (o, a, s, u, c) {
var f, h, y, v = 0,
m = "0",
x = o && [],
b = [],
w = l,
C = o || i && r.find.TAG("*", c),
E = T += null == w ? 1 : Math.random() || .1,
k = C.length;
for (c && (l = a === d || a || c); m !== k && null != (f = C[m]); m++) {
if (i && f) {
h = 0, a || f.ownerDocument === d || (p(f), s = !g);
while (y = e[h++])
if (y(f, a || d, s)) {
u.push(f);
break
} c && (T = E)
}
n && ((f = !y && f) && v--, o && x.push(f))
}
if (v += m, n && m !== v) {
h = 0;
while (y = t[h++]) y(x, b, a, s);
if (o) {
if (v > 0)
while (m--) x[m] || b[m] || (b[m] = j.call(u));
b = we(b)
}
L.apply(u, b), c && !o && b.length > 0 && v + t.length > 1 && oe.uniqueSort(u)
}
return c && (T = E, l = w), x
};
return n ? se(o) : o
}
return s = oe.compile = function (e, t) {
var n, r = [],
i = [],
o = S[e + " "];
if (!o) {
t || (t = a(e)), n = t.length;
while (n--)(o = Ce(t[n]))[b] ? r.push(o) : i.push(o);
(o = S(e, Ee(i, r))).selector = e
}
return o
}, u = oe.select = function (e, t, n, i) {
var o, u, l, c, f, p = "function" == typeof e && e,
d = !i && a(e = p.selector || e);
if (n = n || [], 1 === d.length) {
if ((u = d[0] = d[0].slice(0)).length > 2 && "ID" === (l = u[0]).type && 9 === t.nodeType && g && r.relative[u[1].type]) {
if (!(t = (r.find.ID(l.matches[0].replace(Z, ee), t) || [])[0])) return n;
p && (t = t.parentNode), e = e.slice(u.shift().value.length)
}
o = V.needsContext.test(e) ? 0 : u.length;
while (o--) {
if (l = u[o], r.relative[c = l.type]) break;
if ((f = r.find[c]) && (i = f(l.matches[0].replace(Z, ee), K.test(u[0].type) && ge(t.parentNode) || t))) {
if (u.splice(o, 1), !(e = i.length && ve(u))) return L.apply(n, i), n;
break
}
}
}
return (p || s(e, d))(i, t, !g, n, !t || K.test(e) && ge(t.parentNode) || t), n
}, n.sortStable = b.split("").sort(D).join("") === b, n.detectDuplicates = !!f, p(), n.sortDetached = ue(function (e) {
return 1 & e.compareDocumentPosition(d.createElement("fieldset"))
}), ue(function (e) {
return e.innerHTML = "<a href='#'></a>", "#" === e.firstChild.getAttribute("href")
}) || le("type|href|height|width", function (e, t, n) {
if (!n) return e.getAttribute(t, "type" === t.toLowerCase() ? 1 : 2)
}), n.attributes && ue(function (e) {
return e.innerHTML = "<input/>", e.firstChild.setAttribute("value", ""), "" === e.firstChild.getAttribute("value")
}) || le("value", function (e, t, n) {
if (!n && "input" === e.nodeName.toLowerCase()) return e.defaultValue
}), ue(function (e) {
return null == e.getAttribute("disabled")
}) || le(P, function (e, t, n) {
var r;
if (!n) return !0 === e[t] ? t.toLowerCase() : (r = e.getAttributeNode(t)) && r.specified ? r.value : null
}), oe
}(e);
w.find = E, w.expr = E.selectors, w.expr[":"] = w.expr.pseudos, w.uniqueSort = w.unique = E.uniqueSort, w.text = E.getText, w.isXMLDoc = E.isXML, w.contains = E.contains, w.escapeSelector = E.escape;
var k = function (e, t, n) {
var r = [],
i = void 0 !== n;
while ((e = e[t]) && 9 !== e.nodeType)
if (1 === e.nodeType) {
if (i && w(e).is(n)) break;
r.push(e)
} return r
},
S = function (e, t) {
for (var n = []; e; e = e.nextSibling) 1 === e.nodeType && e !== t && n.push(e);
return n
},
D = w.expr.match.needsContext;
function N(e, t) {
return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase()
}
var A = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;
function j(e, t, n) {
return g(t) ? w.grep(e, function (e, r) {
return !!t.call(e, r, e) !== n
}) : t.nodeType ? w.grep(e, function (e) {
return e === t !== n
}) : "string" != typeof t ? w.grep(e, function (e) {
return u.call(t, e) > -1 !== n
}) : w.filter(t, e, n)
}
w.filter = function (e, t, n) {
var r = t[0];
return n && (e = ":not(" + e + ")"), 1 === t.length && 1 === r.nodeType ? w.find.matchesSelector(r, e) ? [r] : [] : w.find.matches(e, w.grep(t, function (e) {
return 1 === e.nodeType
}))
}, w.fn.extend({
find: function (e) {
var t, n, r = this.length,
i = this;
if ("string" != typeof e) return this.pushStack(w(e).filter(function () {
for (t = 0; t < r; t++)
if (w.contains(i[t], this)) return !0
}));
for (n = this.pushStack([]), t = 0; t < r; t++) w.find(e, i[t], n);
return r > 1 ? w.uniqueSort(n) : n
},
filter: function (e) {
return this.pushStack(j(this, e || [], !1))
},
not: function (e) {
return this.pushStack(j(this, e || [], !0))
},
is: function (e) {
return !!j(this, "string" == typeof e && D.test(e) ? w(e) : e || [], !1).length
}
});
var q, L = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;
(w.fn.init = function (e, t, n) {
var i, o;
if (!e) return this;
if (n = n || q, "string" == typeof e) {
if (!(i = "<" === e[0] && ">" === e[e.length - 1] && e.length >= 3 ? [null, e, null] : L.exec(e)) || !i[1] && t) return !t || t.jquery ? (t || n).find(e) : this.constructor(t).find(e);
if (i[1]) {
if (t = t instanceof w ? t[0] : t, w.merge(this, w.parseHTML(i[1], t && t.nodeType ? t.ownerDocument || t : r, !0)), A.test(i[1]) && w.isPlainObject(t))
for (i in t) g(this[i]) ? this[i](t[i]) : this.attr(i, t[i]);
return this
}
return (o = r.getElementById(i[2])) && (this[0] = o, this.length = 1), this
}
return e.nodeType ? (this[0] = e, this.length = 1, this) : g(e) ? void 0 !== n.ready ? n.ready(e) : e(w) : w.makeArray(e, this)
}).prototype = w.fn, q = w(r);
var H = /^(?:parents|prev(?:Until|All))/,
O = {
children: !0,
contents: !0,
next: !0,
prev: !0
};
w.fn.extend({
has: function (e) {
var t = w(e, this),
n = t.length;
return this.filter(function () {
for (var e = 0; e < n; e++)
if (w.contains(this, t[e])) return !0
})
},
closest: function (e, t) {
var n, r = 0,
i = this.length,
o = [],
a = "string" != typeof e && w(e);
if (!D.test(e))
for (; r < i; r++)
for (n = this[r]; n && n !== t; n = n.parentNode)
if (n.nodeType < 11 && (a ? a.index(n) > -1 : 1 === n.nodeType && w.find.matchesSelector(n, e))) {
o.push(n);
break
} return this.pushStack(o.length > 1 ? w.uniqueSort(o) : o)
},
index: function (e) {
return e ? "string" == typeof e ? u.call(w(e), this[0]) : u.call(this, e.jquery ? e[0] : e) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1
},
add: function (e, t) {
return this.pushStack(w.uniqueSort(w.merge(this.get(), w(e, t))))
},
addBack: function (e) {
return this.add(null == e ? this.prevObject : this.prevObject.filter(e))
}
});
function P(e, t) {
while ((e = e[t]) && 1 !== e.nodeType);
return e
}
w.each({
parent: function (e) {
var t = e.parentNode;
return t && 11 !== t.nodeType ? t : null
},
parents: function (e) {
return k(e, "parentNode")
},
parentsUntil: function (e, t, n) {
return k(e, "parentNode", n)
},
next: function (e) {
return P(e, "nextSibling")
},
prev: function (e) {
return P(e, "previousSibling")
},
nextAll: function (e) {
return k(e, "nextSibling")
},
prevAll: function (e) {
return k(e, "previousSibling")
},
nextUntil: function (e, t, n) {
return k(e, "nextSibling", n)
},
prevUntil: function (e, t, n) {
return k(e, "previousSibling", n)
},
siblings: function (e) {
return S((e.parentNode || {}).firstChild, e)
},
children: function (e) {
return S(e.firstChild)
},
contents: function (e) {
return N(e, "iframe") ? e.contentDocument : (N(e, "template") && (e = e.content || e), w.merge([], e.childNodes))
}
}, function (e, t) {
w.fn[e] = function (n, r) {
var i = w.map(this, t, n);
return "Until" !== e.slice(-5) && (r = n), r && "string" == typeof r && (i = w.filter(r, i)), this.length > 1 && (O[e] || w.uniqueSort(i), H.test(e) && i.reverse()), this.pushStack(i)
}
});
var M = /[^\x20\t\r\n\f]+/g;
function R(e) {
var t = {};
return w.each(e.match(M) || [], function (e, n) {
t[n] = !0
}), t
}
w.Callbacks = function (e) {
e = "string" == typeof e ? R(e) : w.extend({}, e);
var t, n, r, i, o = [],
a = [],
s = -1,
u = function () {
for (i = i || e.once, r = t = !0; a.length; s = -1) {
n = a.shift();
while (++s < o.length) !1 === o[s].apply(n[0], n[1]) && e.stopOnFalse && (s = o.length, n = !1)
}
e.memory || (n = !1), t = !1, i && (o =