├── .gitattributes ├── README.md ├── assets ├── bg.svg ├── jquery.js ├── main.js └── style.css ├── index.php └── main ├── config.php ├── home.php ├── login.php ├── logout.php └── smssend.php /.gitattributes: -------------------------------------------------------------------------------- 1 | # Auto detect text files and perform LF normalization 2 | * text=auto 3 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # SMS sending SimplePHP 2 | PHP & MySQL, JS, jQuery, Bootstrap. Used D7 SMS Api, RapidAPI 3 | ## how to run 4 | First download and then setup DB on your MySQl database. 5 | Second get API key on (https://d7sms.p.rapidapi.com) and set it on main/smssend.php 6 | and then you can run it on your local or cpanel. 7 | 8 | ## Working 9 |  10 | 11 | simple design and responsive 12 |  13 |  14 | -------------------------------------------------------------------------------- /assets/jquery.js: -------------------------------------------------------------------------------- 1 | /*! jQuery v3.5.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(C, e) { 2 | "use strict"; 3 | var t = [], 4 | r = Object.getPrototypeOf, 5 | s = t.slice, 6 | g = t.flat ? function(e) { return t.flat.call(e) } : function(e) { return t.concat.apply([], e) }, 7 | u = t.push, 8 | i = t.indexOf, 9 | n = {}, 10 | o = n.toString, 11 | v = n.hasOwnProperty, 12 | a = v.toString, 13 | l = a.call(Object), 14 | y = {}, 15 | m = function(e) { return "function" == typeof e && "number" != typeof e.nodeType }, 16 | x = function(e) { return null != e && e === e.window }, 17 | E = C.document, 18 | c = { type: !0, src: !0, nonce: !0, noModule: !0 }; 19 | 20 | function b(e, t, n) { 21 | var r, i, o = (n = n || E).createElement("script"); 22 | if (o.text = e, t) 23 | for (r in c)(i = t[r] || t.getAttribute && t.getAttribute(r)) && o.setAttribute(r, i); 24 | n.head.appendChild(o).parentNode.removeChild(o) 25 | } 26 | 27 | function w(e) { return null == e ? e + "" : "object" == typeof e || "function" == typeof e ? n[o.call(e)] || "object" : typeof e } 28 | var f = "3.5.1", 29 | S = function(e, t) { return new S.fn.init(e, t) }; 30 | 31 | function p(e) { 32 | var t = !!e && "length" in e && e.length, 33 | n = w(e); 34 | return !m(e) && !x(e) && ("array" === n || 0 === t || "number" == typeof t && 0 < t && t - 1 in e) 35 | } 36 | S.fn = S.prototype = { 37 | jquery: f, 38 | constructor: S, 39 | length: 0, 40 | toArray: function() { return s.call(this) }, 41 | get: function(e) { return null == e ? s.call(this) : e < 0 ? this[e + this.length] : this[e] }, 42 | pushStack: function(e) { var t = S.merge(this.constructor(), e); return t.prevObject = this, t }, 43 | each: function(e) { return S.each(this, e) }, 44 | map: function(n) { return this.pushStack(S.map(this, function(e, t) { return n.call(e, t, e) })) }, 45 | slice: function() { return this.pushStack(s.apply(this, arguments)) }, 46 | first: function() { return this.eq(0) }, 47 | last: function() { return this.eq(-1) }, 48 | even: function() { return this.pushStack(S.grep(this, function(e, t) { return (t + 1) % 2 })) }, 49 | odd: function() { return this.pushStack(S.grep(this, function(e, t) { return t % 2 })) }, 50 | eq: function(e) { 51 | var t = this.length, 52 | n = +e + (e < 0 ? t : 0); 53 | return this.pushStack(0 <= n && n < t ? [this[n]] : []) 54 | }, 55 | end: function() { return this.prevObject || this.constructor() }, 56 | push: u, 57 | sort: t.sort, 58 | splice: t.splice 59 | }, S.extend = S.fn.extend = function() { 60 | var e, t, n, r, i, o, a = arguments[0] || {}, 61 | s = 1, 62 | u = arguments.length, 63 | l = !1; 64 | for ("boolean" == typeof a && (l = a, a = arguments[s] || {}, s++), "object" == typeof a || m(a) || (a = {}), s === u && (a = this, s--); s < u; s++) 65 | if (null != (e = arguments[s])) 66 | for (t in e) r = e[t], "__proto__" !== t && a !== r && (l && r && (S.isPlainObject(r) || (i = Array.isArray(r))) ? (n = a[t], o = i && !Array.isArray(n) ? [] : i || S.isPlainObject(n) ? n : {}, i = !1, a[t] = S.extend(l, o, r)) : void 0 !== r && (a[t] = r)); 67 | return a 68 | }, S.extend({ 69 | expando: "jQuery" + (f + Math.random()).replace(/\D/g, ""), 70 | isReady: !0, 71 | error: function(e) { throw new Error(e) }, 72 | noop: function() {}, 73 | isPlainObject: function(e) { var t, n; return !(!e || "[object Object]" !== o.call(e)) && (!(t = r(e)) || "function" == typeof(n = v.call(t, "constructor") && t.constructor) && a.call(n) === l) }, 74 | isEmptyObject: function(e) { var t; for (t in e) return !1; return !0 }, 75 | globalEval: function(e, t, n) { b(e, { nonce: t && t.nonce }, n) }, 76 | each: function(e, t) { 77 | var n, r = 0; 78 | if (p(e)) { 79 | for (n = e.length; r < n; r++) 80 | if (!1 === t.call(e[r], r, e[r])) break 81 | } else 82 | for (r in e) 83 | if (!1 === t.call(e[r], r, e[r])) break; return e 84 | }, 85 | makeArray: function(e, t) { var n = t || []; return null != e && (p(Object(e)) ? S.merge(n, "string" == typeof e ? [e] : e) : u.call(n, e)), n }, 86 | inArray: function(e, t, n) { return null == t ? -1 : i.call(t, e, n) }, 87 | 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 }, 88 | grep: function(e, t, n) { for (var r = [], i = 0, o = e.length, a = !n; i < o; i++) !t(e[i], i) !== a && r.push(e[i]); return r }, 89 | map: function(e, t, n) { 90 | var r, i, o = 0, 91 | a = []; 92 | if (p(e)) 93 | for (r = e.length; o < r; o++) null != (i = t(e[o], o, n)) && a.push(i); 94 | else 95 | for (o in e) null != (i = t(e[o], o, n)) && a.push(i); 96 | return g(a) 97 | }, 98 | guid: 1, 99 | support: y 100 | }), "function" == typeof Symbol && (S.fn[Symbol.iterator] = t[Symbol.iterator]), S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function(e, t) { n["[object " + t + "]"] = t.toLowerCase() }); 101 | var d = function(n) { 102 | var e, d, b, o, i, h, f, g, w, u, l, T, C, a, E, v, s, c, y, S = "sizzle" + 1 * new Date, 103 | p = n.document, 104 | k = 0, 105 | r = 0, 106 | m = ue(), 107 | x = ue(), 108 | A = ue(), 109 | N = ue(), 110 | D = function(e, t) { return e === t && (l = !0), 0 }, 111 | j = {}.hasOwnProperty, 112 | t = [], 113 | q = t.pop, 114 | L = t.push, 115 | H = t.push, 116 | O = t.slice, 117 | P = function(e, t) { 118 | for (var n = 0, r = e.length; n < r; n++) 119 | if (e[n] === t) return n; 120 | return -1 121 | }, 122 | R = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped", 123 | M = "[\\x20\\t\\r\\n\\f]", 124 | I = "(?:\\\\[\\da-fA-F]{1,6}" + M + "?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+", 125 | W = "\\[" + M + "*(" + I + ")(?:" + M + "*([*^$|!~]?=)" + M + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + I + "))|)" + M + "*\\]", 126 | F = ":(" + I + ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" + W + ")*)|.*)\\)|)", 127 | B = new RegExp(M + "+", "g"), 128 | $ = new RegExp("^" + M + "+|((?:^|[^\\\\])(?:\\\\.)*)" + M + "+$", "g"), 129 | _ = new RegExp("^" + M + "*," + M + "*"), 130 | z = new RegExp("^" + M + "*([>+~]|" + M + ")" + M + "*"), 131 | U = new RegExp(M + "|>"), 132 | X = new RegExp(F), 133 | V = new RegExp("^" + I + "$"), 134 | G = { ID: new RegExp("^#(" + I + ")"), CLASS: new RegExp("^\\.(" + I + ")"), TAG: new RegExp("^(" + I + "|[*])"), ATTR: new RegExp("^" + W), PSEUDO: new RegExp("^" + F), 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("^(?:" + R + ")$", "i"), needsContext: new RegExp("^" + M + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + M + "*((?:-\\d)?\\d*)" + M + "*\\)|)(?=[^-]|$)", "i") }, 135 | Y = /HTML$/i, 136 | Q = /^(?:input|select|textarea|button)$/i, 137 | J = /^h\d$/i, 138 | K = /^[^{]+\{\s*\[native \w/, 139 | Z = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, 140 | ee = /[+~]/, 141 | te = new RegExp("\\\\[\\da-fA-F]{1,6}" + M + "?|\\\\([^\\r\\n\\f])", "g"), 142 | ne = function(e, t) { var n = "0x" + e.slice(1) - 65536; return t || (n < 0 ? String.fromCharCode(n + 65536) : String.fromCharCode(n >> 10 | 55296, 1023 & n | 56320)) }, 143 | re = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g, 144 | ie = function(e, t) { return t ? "\0" === e ? "\ufffd" : e.slice(0, -1) + "\\" + e.charCodeAt(e.length - 1).toString(16) + " " : "\\" + e }, 145 | oe = function() { T() }, 146 | ae = be(function(e) { return !0 === e.disabled && "fieldset" === e.nodeName.toLowerCase() }, { dir: "parentNode", next: "legend" }); 147 | try { H.apply(t = O.call(p.childNodes), p.childNodes), t[p.childNodes.length].nodeType } catch (e) { 148 | H = { 149 | apply: t.length ? function(e, t) { L.apply(e, O.call(t)) } : function(e, t) { 150 | var n = e.length, 151 | r = 0; 152 | while (e[n++] = t[r++]); 153 | e.length = n - 1 154 | } 155 | } 156 | } 157 | 158 | function se(t, e, n, r) { 159 | var i, o, a, s, u, l, c, f = e && e.ownerDocument, 160 | p = e ? e.nodeType : 9; 161 | if (n = n || [], "string" != typeof t || !t || 1 !== p && 9 !== p && 11 !== p) return n; 162 | if (!r && (T(e), e = e || C, E)) { 163 | if (11 !== p && (u = Z.exec(t))) 164 | if (i = u[1]) { if (9 === p) { if (!(a = e.getElementById(i))) return n; if (a.id === i) return n.push(a), n } else if (f && (a = f.getElementById(i)) && y(e, a) && a.id === i) return n.push(a), n } else { if (u[2]) return H.apply(n, e.getElementsByTagName(t)), n; if ((i = u[3]) && d.getElementsByClassName && e.getElementsByClassName) return H.apply(n, e.getElementsByClassName(i)), n } 165 | if (d.qsa && !N[t + " "] && (!v || !v.test(t)) && (1 !== p || "object" !== e.nodeName.toLowerCase())) { 166 | if (c = t, f = e, 1 === p && (U.test(t) || z.test(t))) { 167 | (f = ee.test(t) && ye(e.parentNode) || e) === e && d.scope || ((s = e.getAttribute("id")) ? s = s.replace(re, ie) : e.setAttribute("id", s = S)), o = (l = h(t)).length; 168 | while (o--) l[o] = (s ? "#" + s : ":scope") + " " + xe(l[o]); 169 | c = l.join(",") 170 | } 171 | try { return H.apply(n, f.querySelectorAll(c)), n } catch (e) { N(t, !0) } finally { s === S && e.removeAttribute("id") } 172 | } 173 | } 174 | return g(t.replace($, "$1"), e, n, r) 175 | } 176 | 177 | function ue() { var r = []; return function e(t, n) { return r.push(t + " ") > b.cacheLength && delete e[r.shift()], e[t + " "] = n } } 178 | 179 | function le(e) { return e[S] = !0, e } 180 | 181 | function ce(e) { var t = C.createElement("fieldset"); try { return !!e(t) } catch (e) { return !1 } finally { t.parentNode && t.parentNode.removeChild(t), t = null } } 182 | 183 | function fe(e, t) { 184 | var n = e.split("|"), 185 | r = n.length; 186 | while (r--) b.attrHandle[n[r]] = t 187 | } 188 | 189 | function pe(e, t) { 190 | var n = t && e, 191 | r = n && 1 === e.nodeType && 1 === t.nodeType && e.sourceIndex - t.sourceIndex; 192 | if (r) return r; 193 | if (n) 194 | while (n = n.nextSibling) 195 | if (n === t) return -1; 196 | return e ? 1 : -1 197 | } 198 | 199 | function de(t) { return function(e) { return "input" === e.nodeName.toLowerCase() && e.type === t } } 200 | 201 | function he(n) { return function(e) { var t = e.nodeName.toLowerCase(); return ("input" === t || "button" === t) && e.type === n } } 202 | 203 | function ge(t) { return function(e) { return "form" in e ? e.parentNode && !1 === e.disabled ? "label" in e ? "label" in e.parentNode ? e.parentNode.disabled === t : e.disabled === t : e.isDisabled === t || e.isDisabled !== !t && ae(e) === t : e.disabled === t : "label" in e && e.disabled === t } } 204 | 205 | function ve(a) { 206 | return le(function(o) { 207 | return o = +o, le(function(e, t) { 208 | var n, r = a([], e.length, o), 209 | i = r.length; 210 | while (i--) e[n = r[i]] && (e[n] = !(t[n] = e[n])) 211 | }) 212 | }) 213 | } 214 | 215 | function ye(e) { return e && "undefined" != typeof e.getElementsByTagName && e } 216 | for (e in d = se.support = {}, i = se.isXML = function(e) { 217 | var t = e.namespaceURI, 218 | n = (e.ownerDocument || e).documentElement; 219 | return !Y.test(t || n && n.nodeName || "HTML") 220 | }, T = se.setDocument = function(e) { 221 | var t, n, r = e ? e.ownerDocument || e : p; 222 | return r != C && 9 === r.nodeType && r.documentElement && (a = (C = r).documentElement, E = !i(C), p != C && (n = C.defaultView) && n.top !== n && (n.addEventListener ? n.addEventListener("unload", oe, !1) : n.attachEvent && n.attachEvent("onunload", oe)), d.scope = ce(function(e) { return a.appendChild(e).appendChild(C.createElement("div")), "undefined" != typeof e.querySelectorAll && !e.querySelectorAll(":scope fieldset div").length }), d.attributes = ce(function(e) { return e.className = "i", !e.getAttribute("className") }), d.getElementsByTagName = ce(function(e) { return e.appendChild(C.createComment("")), !e.getElementsByTagName("*").length }), d.getElementsByClassName = K.test(C.getElementsByClassName), d.getById = ce(function(e) { return a.appendChild(e).id = S, !C.getElementsByName || !C.getElementsByName(S).length }), d.getById ? (b.filter.ID = function(e) { var t = e.replace(te, ne); return function(e) { return e.getAttribute("id") === t } }, b.find.ID = function(e, t) { if ("undefined" != typeof t.getElementById && E) { var n = t.getElementById(e); return n ? [n] : [] } }) : (b.filter.ID = function(e) { var n = e.replace(te, ne); return function(e) { var t = "undefined" != typeof e.getAttributeNode && e.getAttributeNode("id"); return t && t.value === n } }, b.find.ID = function(e, t) { 223 | if ("undefined" != typeof t.getElementById && E) { 224 | var n, r, i, o = t.getElementById(e); 225 | if (o) { 226 | if ((n = o.getAttributeNode("id")) && n.value === e) return [o]; 227 | i = t.getElementsByName(e), r = 0; 228 | while (o = i[r++]) 229 | if ((n = o.getAttributeNode("id")) && n.value === e) return [o] 230 | } 231 | return [] 232 | } 233 | }), b.find.TAG = d.getElementsByTagName ? function(e, t) { return "undefined" != typeof t.getElementsByTagName ? t.getElementsByTagName(e) : d.qsa ? t.querySelectorAll(e) : void 0 } : function(e, t) { 234 | var n, r = [], 235 | i = 0, 236 | o = t.getElementsByTagName(e); 237 | if ("*" === e) { while (n = o[i++]) 1 === n.nodeType && r.push(n); return r } 238 | return o 239 | }, b.find.CLASS = d.getElementsByClassName && function(e, t) { if ("undefined" != typeof t.getElementsByClassName && E) return t.getElementsByClassName(e) }, s = [], v = [], (d.qsa = K.test(C.querySelectorAll)) && (ce(function(e) { 240 | var t; 241 | a.appendChild(e).innerHTML = "", e.querySelectorAll("[msallowcapture^='']").length && v.push("[*^$]=" + M + "*(?:''|\"\")"), e.querySelectorAll("[selected]").length || v.push("\\[" + M + "*(?:value|" + R + ")"), e.querySelectorAll("[id~=" + S + "-]").length || v.push("~="), (t = C.createElement("input")).setAttribute("name", ""), e.appendChild(t), e.querySelectorAll("[name='']").length || v.push("\\[" + M + "*name" + M + "*=" + M + "*(?:''|\"\")"), e.querySelectorAll(":checked").length || v.push(":checked"), e.querySelectorAll("a#" + S + "+*").length || v.push(".#.+[+~]"), e.querySelectorAll("\\\f"), v.push("[\\r\\n\\f]") 242 | }), ce(function(e) { 243 | e.innerHTML = ""; 244 | var t = C.createElement("input"); 245 | t.setAttribute("type", "hidden"), e.appendChild(t).setAttribute("name", "D"), e.querySelectorAll("[name=d]").length && v.push("name" + M + "*[*^$|!~]?="), 2 !== e.querySelectorAll(":enabled").length && v.push(":enabled", ":disabled"), a.appendChild(e).disabled = !0, 2 !== e.querySelectorAll(":disabled").length && v.push(":enabled", ":disabled"), e.querySelectorAll("*,:x"), v.push(",.*:") 246 | })), (d.matchesSelector = K.test(c = a.matches || a.webkitMatchesSelector || a.mozMatchesSelector || a.oMatchesSelector || a.msMatchesSelector)) && ce(function(e) { d.disconnectedMatch = c.call(e, "*"), c.call(e, "[s!='']:x"), s.push("!=", F) }), v = v.length && new RegExp(v.join("|")), s = s.length && new RegExp(s.join("|")), t = K.test(a.compareDocumentPosition), y = t || K.test(a.contains) ? function(e, t) { 247 | var n = 9 === e.nodeType ? e.documentElement : e, 248 | r = t && t.parentNode; 249 | return e === r || !(!r || 1 !== r.nodeType || !(n.contains ? n.contains(r) : e.compareDocumentPosition && 16 & e.compareDocumentPosition(r))) 250 | } : function(e, t) { 251 | if (t) 252 | while (t = t.parentNode) 253 | if (t === e) return !0; 254 | return !1 255 | }, D = t ? function(e, t) { if (e === t) return l = !0, 0; var n = !e.compareDocumentPosition - !t.compareDocumentPosition; return n || (1 & (n = (e.ownerDocument || e) == (t.ownerDocument || t) ? e.compareDocumentPosition(t) : 1) || !d.sortDetached && t.compareDocumentPosition(e) === n ? e == C || e.ownerDocument == p && y(p, e) ? -1 : t == C || t.ownerDocument == p && y(p, t) ? 1 : u ? P(u, e) - P(u, t) : 0 : 4 & n ? -1 : 1) } : function(e, t) { 256 | if (e === t) return l = !0, 0; 257 | var n, r = 0, 258 | i = e.parentNode, 259 | o = t.parentNode, 260 | a = [e], 261 | s = [t]; 262 | if (!i || !o) return e == C ? -1 : t == C ? 1 : i ? -1 : o ? 1 : u ? P(u, e) - P(u, t) : 0; 263 | if (i === o) return pe(e, t); 264 | n = e; 265 | while (n = n.parentNode) a.unshift(n); 266 | n = t; 267 | while (n = n.parentNode) s.unshift(n); 268 | while (a[r] === s[r]) r++; 269 | return r ? pe(a[r], s[r]) : a[r] == p ? -1 : s[r] == p ? 1 : 0 270 | }), C 271 | }, se.matches = function(e, t) { return se(e, null, null, t) }, se.matchesSelector = function(e, t) { 272 | if (T(e), d.matchesSelector && E && !N[t + " "] && (!s || !s.test(t)) && (!v || !v.test(t))) try { var n = c.call(e, t); if (n || d.disconnectedMatch || e.document && 11 !== e.document.nodeType) return n } catch (e) { N(t, !0) } 273 | return 0 < se(t, C, null, [e]).length 274 | }, se.contains = function(e, t) { return (e.ownerDocument || e) != C && T(e), y(e, t) }, se.attr = function(e, t) { 275 | (e.ownerDocument || e) != C && T(e); 276 | var n = b.attrHandle[t.toLowerCase()], 277 | r = n && j.call(b.attrHandle, t.toLowerCase()) ? n(e, t, !E) : void 0; 278 | return void 0 !== r ? r : d.attributes || !E ? e.getAttribute(t) : (r = e.getAttributeNode(t)) && r.specified ? r.value : null 279 | }, se.escape = function(e) { return (e + "").replace(re, ie) }, se.error = function(e) { throw new Error("Syntax error, unrecognized expression: " + e) }, se.uniqueSort = function(e) { 280 | var t, n = [], 281 | r = 0, 282 | i = 0; 283 | if (l = !d.detectDuplicates, u = !d.sortStable && e.slice(0), e.sort(D), l) { while (t = e[i++]) t === e[i] && (r = n.push(i)); while (r--) e.splice(n[r], 1) } 284 | return u = null, e 285 | }, o = se.getText = function(e) { 286 | var t, n = "", 287 | r = 0, 288 | i = e.nodeType; 289 | if (i) { if (1 === i || 9 === i || 11 === i) { if ("string" == typeof e.textContent) return e.textContent; for (e = e.firstChild; e; e = e.nextSibling) n += o(e) } else if (3 === i || 4 === i) return e.nodeValue } else 290 | while (t = e[r++]) n += o(t); 291 | return n 292 | }, (b = se.selectors = { 293 | cacheLength: 50, 294 | createPseudo: le, 295 | match: G, 296 | attrHandle: {}, 297 | find: {}, 298 | relative: { ">": { dir: "parentNode", first: !0 }, " ": { dir: "parentNode" }, "+": { dir: "previousSibling", first: !0 }, "~": { dir: "previousSibling" } }, 299 | preFilter: { ATTR: function(e) { return e[1] = e[1].replace(te, ne), e[3] = (e[3] || e[4] || e[5] || "").replace(te, ne), "~=" === 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] || se.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] && se.error(e[0]), e }, PSEUDO: function(e) { var t, n = !e[6] && e[2]; return G.CHILD.test(e[0]) ? null : (e[3] ? e[2] = e[4] || e[5] || "" : n && X.test(n) && (t = h(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)) } }, 300 | filter: { 301 | TAG: function(e) { var t = e.replace(te, ne).toLowerCase(); return "*" === e ? function() { return !0 } : function(e) { return e.nodeName && e.nodeName.toLowerCase() === t } }, 302 | CLASS: function(e) { var t = m[e + " "]; return t || (t = new RegExp("(^|" + M + ")" + e + "(" + M + "|$)")) && m(e, function(e) { return t.test("string" == typeof e.className && e.className || "undefined" != typeof e.getAttribute && e.getAttribute("class") || "") }) }, 303 | ATTR: function(n, r, i) { return function(e) { var t = se.attr(e, n); return null == t ? "!=" === r : !r || (t += "", "=" === r ? t === i : "!=" === r ? t !== i : "^=" === r ? i && 0 === t.indexOf(i) : "*=" === r ? i && -1 < t.indexOf(i) : "$=" === r ? i && t.slice(-i.length) === i : "~=" === r ? -1 < (" " + t.replace(B, " ") + " ").indexOf(i) : "|=" === r && (t === i || t.slice(0, i.length + 1) === i + "-")) } }, 304 | CHILD: function(h, e, t, g, v) { 305 | var y = "nth" !== h.slice(0, 3), 306 | m = "last" !== h.slice(-4), 307 | x = "of-type" === e; 308 | return 1 === g && 0 === v ? function(e) { return !!e.parentNode } : function(e, t, n) { 309 | var r, i, o, a, s, u, l = y !== m ? "nextSibling" : "previousSibling", 310 | c = e.parentNode, 311 | f = x && e.nodeName.toLowerCase(), 312 | p = !n && !x, 313 | d = !1; 314 | if (c) { 315 | if (y) { 316 | while (l) { 317 | a = e; 318 | while (a = a[l]) 319 | if (x ? a.nodeName.toLowerCase() === f : 1 === a.nodeType) return !1; 320 | u = l = "only" === h && !u && "nextSibling" 321 | } 322 | return !0 323 | } 324 | if (u = [m ? c.firstChild : c.lastChild], m && p) { 325 | d = (s = (r = (i = (o = (a = c)[S] || (a[S] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] || [])[0] === k && r[1]) && r[2], a = s && c.childNodes[s]; 326 | while (a = ++s && a && a[l] || (d = s = 0) || u.pop()) 327 | if (1 === a.nodeType && ++d && a === e) { i[h] = [k, s, d]; break } 328 | } else if (p && (d = s = (r = (i = (o = (a = e)[S] || (a[S] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] || [])[0] === k && r[1]), !1 === d) 329 | while (a = ++s && a && a[l] || (d = s = 0) || u.pop()) 330 | if ((x ? a.nodeName.toLowerCase() === f : 1 === a.nodeType) && ++d && (p && ((i = (o = a[S] || (a[S] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] = [k, d]), a === e)) break; 331 | return (d -= v) === g || d % g == 0 && 0 <= d / g 332 | } 333 | } 334 | }, 335 | PSEUDO: function(e, o) { 336 | var t, a = b.pseudos[e] || b.setFilters[e.toLowerCase()] || se.error("unsupported pseudo: " + e); 337 | return a[S] ? a(o) : 1 < a.length ? (t = [e, e, "", o], b.setFilters.hasOwnProperty(e.toLowerCase()) ? le(function(e, t) { 338 | var n, r = a(e, o), 339 | i = r.length; 340 | while (i--) e[n = P(e, r[i])] = !(t[n] = r[i]) 341 | }) : function(e) { return a(e, 0, t) }) : a 342 | } 343 | }, 344 | pseudos: { 345 | not: le(function(e) { 346 | var r = [], 347 | i = [], 348 | s = f(e.replace($, "$1")); 349 | return s[S] ? le(function(e, t, n, r) { 350 | var i, o = s(e, null, r, []), 351 | a = e.length; 352 | while (a--)(i = o[a]) && (e[a] = !(t[a] = i)) 353 | }) : function(e, t, n) { return r[0] = e, s(r, null, n, i), r[0] = null, !i.pop() } 354 | }), 355 | has: le(function(t) { return function(e) { return 0 < se(t, e).length } }), 356 | contains: le(function(t) { 357 | return t = t.replace(te, ne), 358 | function(e) { return -1 < (e.textContent || o(e)).indexOf(t) } 359 | }), 360 | lang: le(function(n) { 361 | return V.test(n || "") || se.error("unsupported lang: " + n), n = n.replace(te, ne).toLowerCase(), 362 | function(e) { 363 | var t; 364 | do { if (t = E ? e.lang : e.getAttribute("xml:lang") || e.getAttribute("lang")) return (t = t.toLowerCase()) === n || 0 === t.indexOf(n + "-") } while ((e = e.parentNode) && 1 === e.nodeType); 365 | return !1 366 | } 367 | }), 368 | target: function(e) { var t = n.location && n.location.hash; return t && t.slice(1) === e.id }, 369 | root: function(e) { return e === a }, 370 | focus: function(e) { return e === C.activeElement && (!C.hasFocus || C.hasFocus()) && !!(e.type || e.href || ~e.tabIndex) }, 371 | enabled: ge(!1), 372 | disabled: ge(!0), 373 | checked: function(e) { var t = e.nodeName.toLowerCase(); return "input" === t && !!e.checked || "option" === t && !!e.selected }, 374 | selected: function(e) { return e.parentNode && e.parentNode.selectedIndex, !0 === e.selected }, 375 | empty: function(e) { 376 | for (e = e.firstChild; e; e = e.nextSibling) 377 | if (e.nodeType < 6) return !1; 378 | return !0 379 | }, 380 | parent: function(e) { return !b.pseudos.empty(e) }, 381 | header: function(e) { return J.test(e.nodeName) }, 382 | input: function(e) { return Q.test(e.nodeName) }, 383 | button: function(e) { var t = e.nodeName.toLowerCase(); return "input" === t && "button" === e.type || "button" === t }, 384 | text: function(e) { var t; return "input" === e.nodeName.toLowerCase() && "text" === e.type && (null == (t = e.getAttribute("type")) || "text" === t.toLowerCase()) }, 385 | first: ve(function() { return [0] }), 386 | last: ve(function(e, t) { return [t - 1] }), 387 | eq: ve(function(e, t, n) { return [n < 0 ? n + t : n] }), 388 | even: ve(function(e, t) { for (var n = 0; n < t; n += 2) e.push(n); return e }), 389 | odd: ve(function(e, t) { for (var n = 1; n < t; n += 2) e.push(n); return e }), 390 | lt: ve(function(e, t, n) { for (var r = n < 0 ? n + t : t < n ? t : n; 0 <= --r;) e.push(r); return e }), 391 | gt: ve(function(e, t, n) { for (var r = n < 0 ? n + t : n; ++r < t;) e.push(r); return e }) 392 | } 393 | }).pseudos.nth = b.pseudos.eq, { radio: !0, checkbox: !0, file: !0, password: !0, image: !0 }) b.pseudos[e] = de(e); 394 | for (e in { submit: !0, reset: !0 }) b.pseudos[e] = he(e); 395 | 396 | function me() {} 397 | 398 | function xe(e) { for (var t = 0, n = e.length, r = ""; t < n; t++) r += e[t].value; return r } 399 | 400 | function be(s, e, t) { 401 | var u = e.dir, 402 | l = e.next, 403 | c = l || u, 404 | f = t && "parentNode" === c, 405 | p = r++; 406 | return e.first ? function(e, t, n) { 407 | while (e = e[u]) 408 | if (1 === e.nodeType || f) return s(e, t, n); 409 | return !1 410 | } : function(e, t, n) { 411 | var r, i, o, a = [k, p]; 412 | if (n) { 413 | while (e = e[u]) 414 | if ((1 === e.nodeType || f) && s(e, t, n)) return !0 415 | } else 416 | while (e = e[u]) 417 | if (1 === e.nodeType || f) 418 | if (i = (o = e[S] || (e[S] = {}))[e.uniqueID] || (o[e.uniqueID] = {}), l && l === e.nodeName.toLowerCase()) e = e[u] || e; 419 | else { if ((r = i[c]) && r[0] === k && r[1] === p) return a[2] = r[2]; if ((i[c] = a)[2] = s(e, t, n)) return !0 } return !1 420 | } 421 | } 422 | 423 | function we(i) { 424 | return 1 < i.length ? function(e, t, n) { 425 | var r = i.length; 426 | while (r--) 427 | if (!i[r](e, t, n)) return !1; 428 | return !0 429 | } : i[0] 430 | } 431 | 432 | function Te(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 } 433 | 434 | function Ce(d, h, g, v, y, e) { 435 | return v && !v[S] && (v = Ce(v)), y && !y[S] && (y = Ce(y, e)), le(function(e, t, n, r) { 436 | var i, o, a, s = [], 437 | u = [], 438 | l = t.length, 439 | c = e || function(e, t, n) { for (var r = 0, i = t.length; r < i; r++) se(e, t[r], n); return n }(h || "*", n.nodeType ? [n] : n, []), 440 | f = !d || !e && h ? c : Te(c, s, d, n, r), 441 | p = g ? y || (e ? d : l || v) ? [] : t : f; 442 | if (g && g(f, p, n, r), v) { i = Te(p, u), v(i, [], n, r), o = i.length; while (o--)(a = i[o]) && (p[u[o]] = !(f[u[o]] = a)) } 443 | if (e) { 444 | if (y || d) { 445 | if (y) { 446 | i = [], o = p.length; 447 | while (o--)(a = p[o]) && i.push(f[o] = a); 448 | y(null, p = [], i, r) 449 | } 450 | o = p.length; 451 | while (o--)(a = p[o]) && -1 < (i = y ? P(e, a) : s[o]) && (e[i] = !(t[i] = a)) 452 | } 453 | } else p = Te(p === t ? p.splice(l, p.length) : p), y ? y(null, t, p, r) : H.apply(t, p) 454 | }) 455 | } 456 | 457 | function Ee(e) { 458 | for (var i, t, n, r = e.length, o = b.relative[e[0].type], a = o || b.relative[" "], s = o ? 1 : 0, u = be(function(e) { return e === i }, a, !0), l = be(function(e) { return -1 < P(i, e) }, a, !0), c = [function(e, t, n) { var r = !o && (n || t !== w) || ((i = t).nodeType ? u(e, t, n) : l(e, t, n)); return i = null, r }]; s < r; s++) 459 | if (t = b.relative[e[s].type]) c = [be(we(c), t)]; 460 | else { 461 | if ((t = b.filter[e[s].type].apply(null, e[s].matches))[S]) { 462 | for (n = ++s; n < r; n++) 463 | if (b.relative[e[n].type]) break; 464 | return Ce(1 < s && we(c), 1 < s && xe(e.slice(0, s - 1).concat({ value: " " === e[s - 2].type ? "*" : "" })).replace($, "$1"), t, s < n && Ee(e.slice(s, n)), n < r && Ee(e = e.slice(n)), n < r && xe(e)) 465 | } 466 | c.push(t) 467 | } 468 | return we(c) 469 | } 470 | return me.prototype = b.filters = b.pseudos, b.setFilters = new me, h = se.tokenize = function(e, t) { 471 | var n, r, i, o, a, s, u, l = x[e + " "]; 472 | if (l) return t ? 0 : l.slice(0); 473 | a = e, s = [], u = b.preFilter; 474 | while (a) { for (o in n && !(r = _.exec(a)) || (r && (a = a.slice(r[0].length) || a), s.push(i = [])), n = !1, (r = z.exec(a)) && (n = r.shift(), i.push({ value: n, type: r[0].replace($, " ") }), a = a.slice(n.length)), b.filter) !(r = G[o].exec(a)) || u[o] && !(r = u[o](r)) || (n = r.shift(), i.push({ value: n, type: o, matches: r }), a = a.slice(n.length)); if (!n) break } 475 | return t ? a.length : a ? se.error(e) : x(e, s).slice(0) 476 | }, f = se.compile = function(e, t) { 477 | var n, v, y, m, x, r, i = [], 478 | o = [], 479 | a = A[e + " "]; 480 | if (!a) { 481 | t || (t = h(e)), n = t.length; 482 | while (n--)(a = Ee(t[n]))[S] ? i.push(a) : o.push(a); 483 | (a = A(e, (v = o, m = 0 < (y = i).length, x = 0 < v.length, r = function(e, t, n, r, i) { 484 | var o, a, s, u = 0, 485 | l = "0", 486 | c = e && [], 487 | f = [], 488 | p = w, 489 | d = e || x && b.find.TAG("*", i), 490 | h = k += null == p ? 1 : Math.random() || .1, 491 | g = d.length; 492 | for (i && (w = t == C || t || i); l !== g && null != (o = d[l]); l++) { 493 | if (x && o) { 494 | a = 0, t || o.ownerDocument == C || (T(o), n = !E); 495 | while (s = v[a++]) 496 | if (s(o, t || C, n)) { r.push(o); break } 497 | i && (k = h) 498 | } 499 | m && ((o = !s && o) && u--, e && c.push(o)) 500 | } 501 | if (u += l, m && l !== u) { 502 | a = 0; 503 | while (s = y[a++]) s(c, f, t, n); 504 | if (e) { 505 | if (0 < u) 506 | while (l--) c[l] || f[l] || (f[l] = q.call(r)); 507 | f = Te(f) 508 | } 509 | H.apply(r, f), i && !e && 0 < f.length && 1 < u + y.length && se.uniqueSort(r) 510 | } 511 | return i && (k = h, w = p), c 512 | }, m ? le(r) : r))).selector = e 513 | } 514 | return a 515 | }, g = se.select = function(e, t, n, r) { 516 | var i, o, a, s, u, l = "function" == typeof e && e, 517 | c = !r && h(e = l.selector || e); 518 | if (n = n || [], 1 === c.length) { 519 | if (2 < (o = c[0] = c[0].slice(0)).length && "ID" === (a = o[0]).type && 9 === t.nodeType && E && b.relative[o[1].type]) { 520 | if (!(t = (b.find.ID(a.matches[0].replace(te, ne), t) || [])[0])) return n; 521 | l && (t = t.parentNode), e = e.slice(o.shift().value.length) 522 | } 523 | i = G.needsContext.test(e) ? 0 : o.length; 524 | while (i--) { if (a = o[i], b.relative[s = a.type]) break; if ((u = b.find[s]) && (r = u(a.matches[0].replace(te, ne), ee.test(o[0].type) && ye(t.parentNode) || t))) { if (o.splice(i, 1), !(e = r.length && xe(o))) return H.apply(n, r), n; break } } 525 | } 526 | return (l || f(e, c))(r, t, !E, n, !t || ee.test(e) && ye(t.parentNode) || t), n 527 | }, d.sortStable = S.split("").sort(D).join("") === S, d.detectDuplicates = !!l, T(), d.sortDetached = ce(function(e) { return 1 & e.compareDocumentPosition(C.createElement("fieldset")) }), ce(function(e) { return e.innerHTML = "", "#" === e.firstChild.getAttribute("href") }) || fe("type|href|height|width", function(e, t, n) { if (!n) return e.getAttribute(t, "type" === t.toLowerCase() ? 1 : 2) }), d.attributes && ce(function(e) { return e.innerHTML = "", e.firstChild.setAttribute("value", ""), "" === e.firstChild.getAttribute("value") }) || fe("value", function(e, t, n) { if (!n && "input" === e.nodeName.toLowerCase()) return e.defaultValue }), ce(function(e) { return null == e.getAttribute("disabled") }) || fe(R, function(e, t, n) { var r; if (!n) return !0 === e[t] ? t.toLowerCase() : (r = e.getAttributeNode(t)) && r.specified ? r.value : null }), se 528 | }(C); 529 | S.find = d, S.expr = d.selectors, S.expr[":"] = S.expr.pseudos, S.uniqueSort = S.unique = d.uniqueSort, S.text = d.getText, S.isXMLDoc = d.isXML, S.contains = d.contains, S.escapeSelector = d.escape; 530 | var h = function(e, t, n) { 531 | var r = [], 532 | i = void 0 !== n; 533 | while ((e = e[t]) && 9 !== e.nodeType) 534 | if (1 === e.nodeType) { 535 | if (i && S(e).is(n)) break; 536 | r.push(e) 537 | } 538 | return r 539 | }, 540 | T = function(e, t) { for (var n = []; e; e = e.nextSibling) 1 === e.nodeType && e !== t && n.push(e); return n }, 541 | k = S.expr.match.needsContext; 542 | 543 | function A(e, t) { return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase() } 544 | var N = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i; 545 | 546 | function D(e, n, r) { return m(n) ? S.grep(e, function(e, t) { return !!n.call(e, t, e) !== r }) : n.nodeType ? S.grep(e, function(e) { return e === n !== r }) : "string" != typeof n ? S.grep(e, function(e) { return -1 < i.call(n, e) !== r }) : S.filter(n, e, r) } 547 | S.filter = function(e, t, n) { var r = t[0]; return n && (e = ":not(" + e + ")"), 1 === t.length && 1 === r.nodeType ? S.find.matchesSelector(r, e) ? [r] : [] : S.find.matches(e, S.grep(t, function(e) { return 1 === e.nodeType })) }, S.fn.extend({ 548 | find: function(e) { 549 | var t, n, r = this.length, 550 | i = this; 551 | if ("string" != typeof e) return this.pushStack(S(e).filter(function() { 552 | for (t = 0; t < r; t++) 553 | if (S.contains(i[t], this)) return !0 554 | })); 555 | for (n = this.pushStack([]), t = 0; t < r; t++) S.find(e, i[t], n); 556 | return 1 < r ? S.uniqueSort(n) : n 557 | }, 558 | filter: function(e) { return this.pushStack(D(this, e || [], !1)) }, 559 | not: function(e) { return this.pushStack(D(this, e || [], !0)) }, 560 | is: function(e) { return !!D(this, "string" == typeof e && k.test(e) ? S(e) : e || [], !1).length } 561 | }); 562 | var j, q = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/; 563 | (S.fn.init = function(e, t, n) { 564 | var r, i; 565 | if (!e) return this; 566 | if (n = n || j, "string" == typeof e) { 567 | if (!(r = "<" === e[0] && ">" === e[e.length - 1] && 3 <= e.length ? [null, e, null] : q.exec(e)) || !r[1] && t) return !t || t.jquery ? (t || n).find(e) : this.constructor(t).find(e); 568 | if (r[1]) { 569 | if (t = t instanceof S ? t[0] : t, S.merge(this, S.parseHTML(r[1], t && t.nodeType ? t.ownerDocument || t : E, !0)), N.test(r[1]) && S.isPlainObject(t)) 570 | for (r in t) m(this[r]) ? this[r](t[r]) : this.attr(r, t[r]); 571 | return this 572 | } 573 | return (i = E.getElementById(r[2])) && (this[0] = i, this.length = 1), this 574 | } 575 | return e.nodeType ? (this[0] = e, this.length = 1, this) : m(e) ? void 0 !== n.ready ? n.ready(e) : e(S) : S.makeArray(e, this) 576 | }).prototype = S.fn, j = S(E); 577 | var L = /^(?:parents|prev(?:Until|All))/, 578 | H = { children: !0, contents: !0, next: !0, prev: !0 }; 579 | 580 | function O(e, t) { while ((e = e[t]) && 1 !== e.nodeType); return e } 581 | S.fn.extend({ 582 | has: function(e) { 583 | var t = S(e, this), 584 | n = t.length; 585 | return this.filter(function() { 586 | for (var e = 0; e < n; e++) 587 | if (S.contains(this, t[e])) return !0 588 | }) 589 | }, 590 | closest: function(e, t) { 591 | var n, r = 0, 592 | i = this.length, 593 | o = [], 594 | a = "string" != typeof e && S(e); 595 | if (!k.test(e)) 596 | for (; r < i; r++) 597 | for (n = this[r]; n && n !== t; n = n.parentNode) 598 | if (n.nodeType < 11 && (a ? -1 < a.index(n) : 1 === n.nodeType && S.find.matchesSelector(n, e))) { o.push(n); break } 599 | return this.pushStack(1 < o.length ? S.uniqueSort(o) : o) 600 | }, 601 | index: function(e) { return e ? "string" == typeof e ? i.call(S(e), this[0]) : i.call(this, e.jquery ? e[0] : e) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1 }, 602 | add: function(e, t) { return this.pushStack(S.uniqueSort(S.merge(this.get(), S(e, t)))) }, 603 | addBack: function(e) { return this.add(null == e ? this.prevObject : this.prevObject.filter(e)) } 604 | }), S.each({ parent: function(e) { var t = e.parentNode; return t && 11 !== t.nodeType ? t : null }, parents: function(e) { return h(e, "parentNode") }, parentsUntil: function(e, t, n) { return h(e, "parentNode", n) }, next: function(e) { return O(e, "nextSibling") }, prev: function(e) { return O(e, "previousSibling") }, nextAll: function(e) { return h(e, "nextSibling") }, prevAll: function(e) { return h(e, "previousSibling") }, nextUntil: function(e, t, n) { return h(e, "nextSibling", n) }, prevUntil: function(e, t, n) { return h(e, "previousSibling", n) }, siblings: function(e) { return T((e.parentNode || {}).firstChild, e) }, children: function(e) { return T(e.firstChild) }, contents: function(e) { return null != e.contentDocument && r(e.contentDocument) ? e.contentDocument : (A(e, "template") && (e = e.content || e), S.merge([], e.childNodes)) } }, function(r, i) { S.fn[r] = function(e, t) { var n = S.map(this, i, e); return "Until" !== r.slice(-5) && (t = e), t && "string" == typeof t && (n = S.filter(t, n)), 1 < this.length && (H[r] || S.uniqueSort(n), L.test(r) && n.reverse()), this.pushStack(n) } }); 605 | var P = /[^\x20\t\r\n\f]+/g; 606 | 607 | function R(e) { return e } 608 | 609 | function M(e) { throw e } 610 | 611 | function I(e, t, n, r) { var i; try { e && m(i = e.promise) ? i.call(e).done(t).fail(n) : e && m(i = e.then) ? i.call(e, t, n) : t.apply(void 0, [e].slice(r)) } catch (e) { n.apply(void 0, [e]) } } 612 | S.Callbacks = function(r) { 613 | var e, n; 614 | r = "string" == typeof r ? (e = r, n = {}, S.each(e.match(P) || [], function(e, t) { n[t] = !0 }), n) : S.extend({}, r); 615 | var i, t, o, a, s = [], 616 | u = [], 617 | l = -1, 618 | c = function() { 619 | for (a = a || r.once, o = i = !0; u.length; l = -1) { t = u.shift(); while (++l < s.length) !1 === s[l].apply(t[0], t[1]) && r.stopOnFalse && (l = s.length, t = !1) } 620 | r.memory || (t = !1), i = !1, a && (s = t ? [] : "") 621 | }, 622 | f = { add: function() { return s && (t && !i && (l = s.length - 1, u.push(t)), function n(e) { S.each(e, function(e, t) { m(t) ? r.unique && f.has(t) || s.push(t) : t && t.length && "string" !== w(t) && n(t) }) }(arguments), t && !i && c()), this }, remove: function() { return S.each(arguments, function(e, t) { var n; while (-1 < (n = S.inArray(t, s, n))) s.splice(n, 1), n <= l && l-- }), this }, has: function(e) { return e ? -1 < S.inArray(e, s) : 0 < s.length }, empty: function() { return s && (s = []), this }, disable: function() { return a = u = [], s = t = "", this }, disabled: function() { return !s }, lock: function() { return a = u = [], t || i || (s = t = ""), this }, locked: function() { return !!a }, fireWith: function(e, t) { return a || (t = [e, (t = t || []).slice ? t.slice() : t], u.push(t), i || c()), this }, fire: function() { return f.fireWith(this, arguments), this }, fired: function() { return !!o } }; 623 | return f 624 | }, S.extend({ 625 | Deferred: function(e) { 626 | var o = [ 627 | ["notify", "progress", S.Callbacks("memory"), S.Callbacks("memory"), 2], 628 | ["resolve", "done", S.Callbacks("once memory"), S.Callbacks("once memory"), 0, "resolved"], 629 | ["reject", "fail", S.Callbacks("once memory"), S.Callbacks("once memory"), 1, "rejected"] 630 | ], 631 | i = "pending", 632 | a = { 633 | state: function() { return i }, 634 | always: function() { return s.done(arguments).fail(arguments), this }, 635 | "catch": function(e) { return a.then(null, e) }, 636 | pipe: function() { 637 | var i = arguments; 638 | return S.Deferred(function(r) { 639 | S.each(o, function(e, t) { 640 | var n = m(i[t[4]]) && i[t[4]]; 641 | s[t[1]](function() { 642 | var e = n && n.apply(this, arguments); 643 | e && m(e.promise) ? e.promise().progress(r.notify).done(r.resolve).fail(r.reject) : r[t[0] + "With"](this, n ? [e] : arguments) 644 | }) 645 | }), i = null 646 | }).promise() 647 | }, 648 | then: function(t, n, r) { 649 | var u = 0; 650 | 651 | function l(i, o, a, s) { 652 | return function() { 653 | var n = this, 654 | r = arguments, 655 | e = function() { 656 | var e, t; 657 | if (!(i < u)) { 658 | if ((e = a.apply(n, r)) === o.promise()) throw new TypeError("Thenable self-resolution"); 659 | t = e && ("object" == typeof e || "function" == typeof e) && e.then, m(t) ? s ? t.call(e, l(u, o, R, s), l(u, o, M, s)) : (u++, t.call(e, l(u, o, R, s), l(u, o, M, s), l(u, o, R, o.notifyWith))) : (a !== R && (n = void 0, r = [e]), (s || o.resolveWith)(n, r)) 660 | } 661 | }, 662 | t = s ? e : function() { try { e() } catch (e) { S.Deferred.exceptionHook && S.Deferred.exceptionHook(e, t.stackTrace), u <= i + 1 && (a !== M && (n = void 0, r = [e]), o.rejectWith(n, r)) } }; 663 | i ? t() : (S.Deferred.getStackHook && (t.stackTrace = S.Deferred.getStackHook()), C.setTimeout(t)) 664 | } 665 | } 666 | return S.Deferred(function(e) { o[0][3].add(l(0, e, m(r) ? r : R, e.notifyWith)), o[1][3].add(l(0, e, m(t) ? t : R)), o[2][3].add(l(0, e, m(n) ? n : M)) }).promise() 667 | }, 668 | promise: function(e) { return null != e ? S.extend(e, a) : a } 669 | }, 670 | s = {}; 671 | return S.each(o, function(e, t) { 672 | var n = t[2], 673 | r = t[5]; 674 | a[t[1]] = n.add, r && n.add(function() { i = r }, o[3 - e][2].disable, o[3 - e][3].disable, o[0][2].lock, o[0][3].lock), n.add(t[3].fire), s[t[0]] = function() { return s[t[0] + "With"](this === s ? void 0 : this, arguments), this }, s[t[0] + "With"] = n.fireWith 675 | }), a.promise(s), e && e.call(s, s), s 676 | }, 677 | when: function(e) { 678 | var n = arguments.length, 679 | t = n, 680 | r = Array(t), 681 | i = s.call(arguments), 682 | o = S.Deferred(), 683 | a = function(t) { return function(e) { r[t] = this, i[t] = 1 < arguments.length ? s.call(arguments) : e, --n || o.resolveWith(r, i) } }; 684 | if (n <= 1 && (I(e, o.done(a(t)).resolve, o.reject, !n), "pending" === o.state() || m(i[t] && i[t].then))) return o.then(); 685 | while (t--) I(i[t], a(t), o.reject); 686 | return o.promise() 687 | } 688 | }); 689 | var W = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/; 690 | S.Deferred.exceptionHook = function(e, t) { C.console && C.console.warn && e && W.test(e.name) && C.console.warn("jQuery.Deferred exception: " + e.message, e.stack, t) }, S.readyException = function(e) { C.setTimeout(function() { throw e }) }; 691 | var F = S.Deferred(); 692 | 693 | function B() { E.removeEventListener("DOMContentLoaded", B), C.removeEventListener("load", B), S.ready() } 694 | S.fn.ready = function(e) { return F.then(e)["catch"](function(e) { S.readyException(e) }), this }, S.extend({ 695 | isReady: !1, 696 | readyWait: 1, 697 | ready: function(e) { 698 | (!0 === e ? --S.readyWait : S.isReady) || (S.isReady = !0) !== e && 0 < --S.readyWait || F.resolveWith(E, [S]) 699 | } 700 | }), S.ready.then = F.then, "complete" === E.readyState || "loading" !== E.readyState && !E.documentElement.doScroll ? C.setTimeout(S.ready) : (E.addEventListener("DOMContentLoaded", B), C.addEventListener("load", B)); 701 | var $ = function(e, t, n, r, i, o, a) { 702 | var s = 0, 703 | u = e.length, 704 | l = null == n; 705 | if ("object" === w(n)) 706 | for (s in i = !0, n) $(e, t, s, n[s], !0, o, a); 707 | else if (void 0 !== r && (i = !0, m(r) || (a = !0), l && (a ? (t.call(e, r), t = null) : (l = t, t = function(e, t, n) { return l.call(S(e), n) })), t)) 708 | for (; s < u; s++) t(e[s], n, a ? r : r.call(e[s], s, t(e[s], n))); 709 | return i ? e : l ? t.call(e) : u ? t(e[0], n) : o 710 | }, 711 | _ = /^-ms-/, 712 | z = /-([a-z])/g; 713 | 714 | function U(e, t) { return t.toUpperCase() } 715 | 716 | function X(e) { return e.replace(_, "ms-").replace(z, U) } 717 | var V = function(e) { return 1 === e.nodeType || 9 === e.nodeType || !+e.nodeType }; 718 | 719 | function G() { this.expando = S.expando + G.uid++ } 720 | G.uid = 1, G.prototype = { 721 | cache: function(e) { var t = e[this.expando]; return t || (t = {}, V(e) && (e.nodeType ? e[this.expando] = t : Object.defineProperty(e, this.expando, { value: t, configurable: !0 }))), t }, 722 | set: function(e, t, n) { 723 | var r, i = this.cache(e); 724 | if ("string" == typeof t) i[X(t)] = n; 725 | else 726 | for (r in t) i[X(r)] = t[r]; 727 | return i 728 | }, 729 | get: function(e, t) { return void 0 === t ? this.cache(e) : e[this.expando] && e[this.expando][X(t)] }, 730 | access: function(e, t, n) { return void 0 === t || t && "string" == typeof t && void 0 === n ? this.get(e, t) : (this.set(e, t, n), void 0 !== n ? n : t) }, 731 | remove: function(e, t) { var n, r = e[this.expando]; if (void 0 !== r) { if (void 0 !== t) { n = (t = Array.isArray(t) ? t.map(X) : (t = X(t)) in r ? [t] : t.match(P) || []).length; while (n--) delete r[t[n]] }(void 0 === t || S.isEmptyObject(r)) && (e.nodeType ? e[this.expando] = void 0 : delete e[this.expando]) } }, 732 | hasData: function(e) { var t = e[this.expando]; return void 0 !== t && !S.isEmptyObject(t) } 733 | }; 734 | var Y = new G, 735 | Q = new G, 736 | J = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, 737 | K = /[A-Z]/g; 738 | 739 | function Z(e, t, n) { 740 | var r, i; 741 | if (void 0 === n && 1 === e.nodeType) 742 | if (r = "data-" + t.replace(K, "-$&").toLowerCase(), "string" == typeof(n = e.getAttribute(r))) { 743 | try { n = "true" === (i = n) || "false" !== i && ("null" === i ? null : i === +i + "" ? +i : J.test(i) ? JSON.parse(i) : i) } catch (e) {} 744 | Q.set(e, t, n) 745 | } else n = void 0; 746 | return n 747 | } 748 | S.extend({ hasData: function(e) { return Q.hasData(e) || Y.hasData(e) }, data: function(e, t, n) { return Q.access(e, t, n) }, removeData: function(e, t) { Q.remove(e, t) }, _data: function(e, t, n) { return Y.access(e, t, n) }, _removeData: function(e, t) { Y.remove(e, t) } }), S.fn.extend({ 749 | data: function(n, e) { 750 | var t, r, i, o = this[0], 751 | a = o && o.attributes; 752 | if (void 0 === n) { 753 | if (this.length && (i = Q.get(o), 1 === o.nodeType && !Y.get(o, "hasDataAttrs"))) { 754 | t = a.length; 755 | while (t--) a[t] && 0 === (r = a[t].name).indexOf("data-") && (r = X(r.slice(5)), Z(o, r, i[r])); 756 | Y.set(o, "hasDataAttrs", !0) 757 | } 758 | return i 759 | } 760 | return "object" == typeof n ? this.each(function() { Q.set(this, n) }) : $(this, function(e) { 761 | var t; 762 | if (o && void 0 === e) return void 0 !== (t = Q.get(o, n)) ? t : void 0 !== (t = Z(o, n)) ? t : void 0; 763 | this.each(function() { Q.set(this, n, e) }) 764 | }, null, e, 1 < arguments.length, null, !0) 765 | }, 766 | removeData: function(e) { return this.each(function() { Q.remove(this, e) }) } 767 | }), S.extend({ 768 | queue: function(e, t, n) { var r; if (e) return t = (t || "fx") + "queue", r = Y.get(e, t), n && (!r || Array.isArray(n) ? r = Y.access(e, t, S.makeArray(n)) : r.push(n)), r || [] }, 769 | dequeue: function(e, t) { 770 | t = t || "fx"; 771 | var n = S.queue(e, t), 772 | r = n.length, 773 | i = n.shift(), 774 | o = S._queueHooks(e, t); 775 | "inprogress" === i && (i = n.shift(), r--), i && ("fx" === t && n.unshift("inprogress"), delete o.stop, i.call(e, function() { S.dequeue(e, t) }, o)), !r && o && o.empty.fire() 776 | }, 777 | _queueHooks: function(e, t) { var n = t + "queueHooks"; return Y.get(e, n) || Y.access(e, n, { empty: S.Callbacks("once memory").add(function() { Y.remove(e, [t + "queue", n]) }) }) } 778 | }), S.fn.extend({ 779 | queue: function(t, n) { 780 | var e = 2; 781 | return "string" != typeof t && (n = t, t = "fx", e--), arguments.length < e ? S.queue(this[0], t) : void 0 === n ? this : this.each(function() { 782 | var e = S.queue(this, t, n); 783 | S._queueHooks(this, t), "fx" === t && "inprogress" !== e[0] && S.dequeue(this, t) 784 | }) 785 | }, 786 | dequeue: function(e) { return this.each(function() { S.dequeue(this, e) }) }, 787 | clearQueue: function(e) { return this.queue(e || "fx", []) }, 788 | promise: function(e, t) { 789 | var n, r = 1, 790 | i = S.Deferred(), 791 | o = this, 792 | a = this.length, 793 | s = function() {--r || i.resolveWith(o, [o]) }; 794 | "string" != typeof e && (t = e, e = void 0), e = e || "fx"; 795 | while (a--)(n = Y.get(o[a], e + "queueHooks")) && n.empty && (r++, n.empty.add(s)); 796 | return s(), i.promise(t) 797 | } 798 | }); 799 | var ee = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source, 800 | te = new RegExp("^(?:([+-])=|)(" + ee + ")([a-z%]*)$", "i"), 801 | ne = ["Top", "Right", "Bottom", "Left"], 802 | re = E.documentElement, 803 | ie = function(e) { return S.contains(e.ownerDocument, e) }, 804 | oe = { composed: !0 }; 805 | re.getRootNode && (ie = function(e) { return S.contains(e.ownerDocument, e) || e.getRootNode(oe) === e.ownerDocument }); 806 | var ae = function(e, t) { return "none" === (e = t || e).style.display || "" === e.style.display && ie(e) && "none" === S.css(e, "display") }; 807 | 808 | function se(e, t, n, r) { 809 | var i, o, a = 20, 810 | s = r ? function() { return r.cur() } : function() { return S.css(e, t, "") }, 811 | u = s(), 812 | l = n && n[3] || (S.cssNumber[t] ? "" : "px"), 813 | c = e.nodeType && (S.cssNumber[t] || "px" !== l && +u) && te.exec(S.css(e, t)); 814 | if (c && c[3] !== l) { 815 | u /= 2, l = l || c[3], c = +u || 1; 816 | while (a--) S.style(e, t, c + l), (1 - o) * (1 - (o = s() / u || .5)) <= 0 && (a = 0), c /= o; 817 | c *= 2, S.style(e, t, c + l), n = n || [] 818 | } 819 | return n && (c = +c || +u || 0, i = n[1] ? c + (n[1] + 1) * n[2] : +n[2], r && (r.unit = l, r.start = c, r.end = i)), i 820 | } 821 | var ue = {}; 822 | 823 | function le(e, t) { for (var n, r, i, o, a, s, u, l = [], c = 0, f = e.length; c < f; c++)(r = e[c]).style && (n = r.style.display, t ? ("none" === n && (l[c] = Y.get(r, "display") || null, l[c] || (r.style.display = "")), "" === r.style.display && ae(r) && (l[c] = (u = a = o = void 0, a = (i = r).ownerDocument, s = i.nodeName, (u = ue[s]) || (o = a.body.appendChild(a.createElement(s)), u = S.css(o, "display"), o.parentNode.removeChild(o), "none" === u && (u = "block"), ue[s] = u)))) : "none" !== n && (l[c] = "none", Y.set(r, "display", n))); for (c = 0; c < f; c++) null != l[c] && (e[c].style.display = l[c]); return e } 824 | S.fn.extend({ show: function() { return le(this, !0) }, hide: function() { return le(this) }, toggle: function(e) { return "boolean" == typeof e ? e ? this.show() : this.hide() : this.each(function() { ae(this) ? S(this).show() : S(this).hide() }) } }); 825 | var ce, fe, pe = /^(?:checkbox|radio)$/i, 826 | de = /<([a-z][^\/\0>\x20\t\r\n\f]*)/i, 827 | he = /^$|^module$|\/(?:java|ecma)script/i; 828 | ce = E.createDocumentFragment().appendChild(E.createElement("div")), (fe = E.createElement("input")).setAttribute("type", "radio"), fe.setAttribute("checked", "checked"), fe.setAttribute("name", "t"), ce.appendChild(fe), y.checkClone = ce.cloneNode(!0).cloneNode(!0).lastChild.checked, ce.innerHTML = "", y.noCloneChecked = !!ce.cloneNode(!0).lastChild.defaultValue, ce.innerHTML = "", y.option = !!ce.lastChild; 829 | var ge = { thead: [1, "