mirror of https://github.com/OWASP/Nettacker.git
11905 lines
444 KiB
Python
11905 lines
444 KiB
Python
#!/usr/bin/env python
|
|
# -*- coding: utf-8 -*-
|
|
import string
|
|
import random
|
|
import json
|
|
from core.alert import messages
|
|
from core.compatible import version
|
|
|
|
|
|
def start(graph_flag, language, data, _HOST, _USERNAME, _PASSWORD, _PORT, _TYPE, _DESCRIPTION):
|
|
"""
|
|
generate the d3_tree_v1_graph with events
|
|
|
|
Args:
|
|
graph_flag: graph name
|
|
language: language
|
|
data: events in JSON
|
|
_HOST: host key
|
|
_USERNAME: username key
|
|
_PASSWORD: password key
|
|
_PORT: port key
|
|
_TYPE: module name key
|
|
_DESCRIPTION: description key
|
|
|
|
Returns:
|
|
a graph in HTML
|
|
"""
|
|
|
|
# define a normalised_json
|
|
normalisedjson = {
|
|
"name": "Started attack",
|
|
"children": {}
|
|
}
|
|
# get data for normalised_json
|
|
for each_scan in data:
|
|
|
|
if each_scan['HOST'] not in normalisedjson['children']:
|
|
normalisedjson['children'].update({each_scan['HOST']: {}})
|
|
normalisedjson['children'][each_scan['HOST']].update(
|
|
{each_scan['TYPE']: []})
|
|
|
|
if each_scan['TYPE'] not in normalisedjson['children'][each_scan['HOST']]:
|
|
normalisedjson['children'][each_scan['HOST']].update(
|
|
{each_scan['TYPE']: []})
|
|
|
|
normalisedjson['children'][each_scan['HOST']][each_scan['TYPE']].append("HOST: \"%s\", PORT:\"%s\", DESCRIPTION:\"%s\", USERNAME:\"%s\", PASSWORD:\"%s\"" % (
|
|
each_scan['HOST'], each_scan['PORT'], each_scan['DESCRIPTION'], each_scan['USERNAME'], each_scan['PASSWORD']))
|
|
|
|
# define a d3_structure_json
|
|
d3_structure = {"name": "Starting attack",
|
|
"children": []}
|
|
# get data for normalised_json
|
|
for host in list(normalisedjson['children'].keys()):
|
|
|
|
d3_structure["children"].append({"name": host, "children": [{"name": otype, "children": [{"name": description}
|
|
for description in normalisedjson['children'][host][otype]]} for otype in list(normalisedjson['children'][host].keys())]})
|
|
|
|
data = '''<!DOCTYPE html>
|
|
<!-- THIS PAGE COPIED AND MODIFIED FROM http://bl.ocks.org/robschmuecker/7880033-->
|
|
<title>__html_title_to_replace__</title>
|
|
<meta charset="utf-8">
|
|
<div class="header">
|
|
<h3><a href="https://github.com/OWASP/Nettacker">OWASP Nettacker</a></h3>
|
|
<h3>__title_to_replace__</h3>
|
|
</div>
|
|
<style type="text/css">
|
|
|
|
\t.header{
|
|
margin:2%;
|
|
text-align:center;
|
|
}
|
|
.node {
|
|
cursor: pointer;
|
|
}
|
|
|
|
.overlay{
|
|
background-color:#EEE;
|
|
}
|
|
|
|
.node circle {
|
|
fill: #fff;
|
|
stroke: steelblue;
|
|
stroke-width: 1.5px;
|
|
}
|
|
|
|
.node text {
|
|
font-size:12px;
|
|
font-family:sans-serif;
|
|
}
|
|
|
|
.link {
|
|
fill: none;
|
|
stroke: #ccc;
|
|
stroke-width: 1.5px;
|
|
}
|
|
|
|
.templink {
|
|
fill: none;
|
|
stroke: red;
|
|
stroke-width: 3px;
|
|
}
|
|
|
|
.ghostCircle.show{
|
|
display:block;
|
|
}
|
|
|
|
.ghostCircle, .activeDrag .ghostCircle{
|
|
display: none;
|
|
}
|
|
|
|
.description{
|
|
margin:2% auto;
|
|
text-align:center;
|
|
width:70%;
|
|
}
|
|
|
|
.footer{
|
|
text-align:center;
|
|
font-size:small;
|
|
}
|
|
</style>
|
|
<script>
|
|
/*! jQuery v1.10.2 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license
|
|
//@ sourceMappingURL=jquery-1.10.2.min.map
|
|
*/
|
|
(function(e, t) {
|
|
var n, r, i = typeof t,
|
|
o = e.location,
|
|
a = e.document,
|
|
s = a.documentElement,
|
|
l = e.jQuery,
|
|
u = e.$,
|
|
c = {},
|
|
p = [],
|
|
f = "1.10.2",
|
|
d = p.concat,
|
|
h = p.push,
|
|
g = p.slice,
|
|
m = p.indexOf,
|
|
y = c.toString,
|
|
v = c.hasOwnProperty,
|
|
b = f.trim,
|
|
x = function(e, t) {
|
|
return new x.fn.init(e, t, r)
|
|
},
|
|
w = /[+-]?(?:\\d*\\.|)\\d+(?:[eE][+-]?\\d+|)/.source,
|
|
T = /\\S+/g,
|
|
C = /^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g,
|
|
N = /^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]*))$/,
|
|
k = /^<(\\w+)\\s*\\/?>(?:<\\/\\1>|)$/,
|
|
E = /^[\\],:{}\\s]*$/,
|
|
S = /(?:^|:|,)(?:\\s*\\[)+/g,
|
|
A = /\\\\(?:["\\\\\\/bfnrt]|u[\\da-fA-F]{4})/g,
|
|
j = /"[^"\\\\\\r\
|
|
]*"|true|false|null|-?(?:\\d+\\.|)\\d+(?:[eE][+-]?\\d+|)/g,
|
|
D = /^-ms-/,
|
|
L = /-([\\da-z])/gi,
|
|
H = function(e, t) {
|
|
return t.toUpperCase()
|
|
},
|
|
q = function(e) {
|
|
(a.addEventListener || "load" === e.type || "complete" === a.readyState) && (_(), x.ready())
|
|
},
|
|
_ = function() {
|
|
a.addEventListener ? (a.removeEventListener("DOMContentLoaded", q, !1), e.removeEventListener("load", q, !1)) : (a.detachEvent("onreadystatechange", q), e.detachEvent("onload", q))
|
|
};
|
|
x.fn = x.prototype = {
|
|
jquery: f,
|
|
constructor: x,
|
|
init: function(e, n, r) {
|
|
var i, o;
|
|
if (!e) return this;
|
|
if ("string" == typeof e) {
|
|
if (i = "<" === e.charAt(0) && ">" === e.charAt(e.length - 1) && e.length >= 3 ? [null, e, null] : N.exec(e), !i || !i[1] && n) return !n || n.jquery ? (n || r).find(e) : this.constructor(n).find(e);
|
|
if (i[1]) {
|
|
if (n = n instanceof x ? n[0] : n, x.merge(this, x.parseHTML(i[1], n && n.nodeType ? n.ownerDocument || n : a, !0)), k.test(i[1]) && x.isPlainObject(n))
|
|
for (i in n) x.isFunction(this[i]) ? this[i](n[i]) : this.attr(i, n[i]);
|
|
return this
|
|
}
|
|
if (o = a.getElementById(i[2]), o && o.parentNode) {
|
|
if (o.id !== i[2]) return r.find(e);
|
|
this.length = 1, this[0] = o
|
|
}
|
|
return this.context = a, this.selector = e, this
|
|
}
|
|
return e.nodeType ? (this.context = this[0] = e, this.length = 1, this) : x.isFunction(e) ? r.ready(e) : (e.selector !== t && (this.selector = e.selector, this.context = e.context), x.makeArray(e, this))
|
|
},
|
|
selector: "",
|
|
length: 0,
|
|
toArray: function() {
|
|
return g.call(this)
|
|
},
|
|
get: function(e) {
|
|
return null == e ? this.toArray() : 0 > e ? this[this.length + e] : this[e]
|
|
},
|
|
pushStack: function(e) {
|
|
var t = x.merge(this.constructor(), e);
|
|
return t.prevObject = this, t.context = this.context, t
|
|
},
|
|
each: function(e, t) {
|
|
return x.each(this, e, t)
|
|
},
|
|
ready: function(e) {
|
|
return x.ready.promise().done(e), this
|
|
},
|
|
slice: function() {
|
|
return this.pushStack(g.apply(this, arguments))
|
|
},
|
|
first: function() {
|
|
return this.eq(0)
|
|
},
|
|
last: function() {
|
|
return this.eq(-1)
|
|
},
|
|
eq: function(e) {
|
|
var t = this.length,
|
|
n = +e + (0 > e ? t : 0);
|
|
return this.pushStack(n >= 0 && t > n ? [this[n]] : [])
|
|
},
|
|
map: function(e) {
|
|
return this.pushStack(x.map(this, function(t, n) {
|
|
return e.call(t, n, t)
|
|
}))
|
|
},
|
|
end: function() {
|
|
return this.prevObject || this.constructor(null)
|
|
},
|
|
push: h,
|
|
sort: [].sort,
|
|
splice: [].splice
|
|
}, x.fn.init.prototype = x.fn, x.extend = x.fn.extend = function() {
|
|
var e, n, r, i, o, a, s = arguments[0] || {},
|
|
l = 1,
|
|
u = arguments.length,
|
|
c = !1;
|
|
for ("boolean" == typeof s && (c = s, s = arguments[1] || {}, l = 2), "object" == typeof s || x.isFunction(s) || (s = {}), u === l && (s = this, --l); u > l; l++)
|
|
if (null != (o = arguments[l]))
|
|
for (i in o) e = s[i], r = o[i], s !== r && (c && r && (x.isPlainObject(r) || (n = x.isArray(r))) ? (n ? (n = !1, a = e && x.isArray(e) ? e : []) : a = e && x.isPlainObject(e) ? e : {}, s[i] = x.extend(c, a, r)) : r !== t && (s[i] = r));
|
|
return s
|
|
}, x.extend({
|
|
expando: "jQuery" + (f + Math.random()).replace(/\\D/g, ""),
|
|
noConflict: function(t) {
|
|
return e.$ === x && (e.$ = u), t && e.jQuery === x && (e.jQuery = l), x
|
|
},
|
|
isReady: !1,
|
|
readyWait: 1,
|
|
holdReady: function(e) {
|
|
e ? x.readyWait++ : x.ready(!0)
|
|
},
|
|
ready: function(e) {
|
|
if (e === !0 ? !--x.readyWait : !x.isReady) {
|
|
if (!a.body) return setTimeout(x.ready);
|
|
x.isReady = !0, e !== !0 && --x.readyWait > 0 || (n.resolveWith(a, [x]), x.fn.trigger && x(a).trigger("ready").off("ready"))
|
|
}
|
|
},
|
|
isFunction: function(e) {
|
|
return "function" === x.type(e)
|
|
},
|
|
isArray: Array.isArray || function(e) {
|
|
return "array" === x.type(e)
|
|
},
|
|
isWindow: function(e) {
|
|
return null != e && e == e.window
|
|
},
|
|
isNumeric: function(e) {
|
|
return !isNaN(parseFloat(e)) && isFinite(e)
|
|
},
|
|
type: function(e) {
|
|
return null == e ? e + "" : "object" == typeof e || "function" == typeof e ? c[y.call(e)] || "object" : typeof e
|
|
},
|
|
isPlainObject: function(e) {
|
|
var n;
|
|
if (!e || "object" !== x.type(e) || e.nodeType || x.isWindow(e)) return !1;
|
|
try {
|
|
if (e.constructor && !v.call(e, "constructor") && !v.call(e.constructor.prototype, "isPrototypeOf")) return !1
|
|
} catch (r) {
|
|
return !1
|
|
}
|
|
if (x.support.ownLast)
|
|
for (n in e) return v.call(e, n);
|
|
for (n in e);
|
|
return n === t || v.call(e, n)
|
|
},
|
|
isEmptyObject: function(e) {
|
|
var t;
|
|
for (t in e) return !1;
|
|
return !0
|
|
},
|
|
error: function(e) {
|
|
throw Error(e)
|
|
},
|
|
parseHTML: function(e, t, n) {
|
|
if (!e || "string" != typeof e) return null;
|
|
"boolean" == typeof t && (n = t, t = !1), t = t || a;
|
|
var r = k.exec(e),
|
|
i = !n && [];
|
|
return r ? [t.createElement(r[1])] : (r = x.buildFragment([e], t, i), i && x(i).remove(), x.merge([], r.childNodes))
|
|
},
|
|
parseJSON: function(n) {
|
|
return e.JSON && e.JSON.parse ? e.JSON.parse(n) : null === n ? n : "string" == typeof n && (n = x.trim(n), n && E.test(n.replace(A, "@").replace(j, "]").replace(S, ""))) ? Function("return " + n)() : (x.error("Invalid JSON: " + n), t)
|
|
},
|
|
parseXML: function(n) {
|
|
var r, i;
|
|
if (!n || "string" != typeof n) return null;
|
|
try {
|
|
e.DOMParser ? (i = new DOMParser, r = i.parseFromString(n, "text/xml")) : (r = new ActiveXObject("Microsoft.XMLDOM"), r.async = "false", r.loadXML(n))
|
|
} catch (o) {
|
|
r = t
|
|
}
|
|
return r && r.documentElement && !r.getElementsByTagName("parsererror").length || x.error("Invalid XML: " + n), r
|
|
},
|
|
noop: function() {},
|
|
globalEval: function(t) {
|
|
t && x.trim(t) && (e.execScript || function(t) {
|
|
e.eval.call(e, t)
|
|
})(t)
|
|
},
|
|
camelCase: function(e) {
|
|
return e.replace(D, "ms-").replace(L, H)
|
|
},
|
|
nodeName: function(e, t) {
|
|
return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase()
|
|
},
|
|
each: function(e, t, n) {
|
|
var r, i = 0,
|
|
o = e.length,
|
|
a = M(e);
|
|
if (n) {
|
|
if (a) {
|
|
for (; o > i; i++)
|
|
if (r = t.apply(e[i], n), r === !1) break
|
|
} else
|
|
for (i in e)
|
|
if (r = t.apply(e[i], n), r === !1) break
|
|
} else if (a) {
|
|
for (; o > i; i++)
|
|
if (r = t.call(e[i], i, e[i]), r === !1) break
|
|
} else
|
|
for (i in e)
|
|
if (r = t.call(e[i], i, e[i]), r === !1) break;
|
|
return e
|
|
},
|
|
trim: b && !b.call("\\ufeff\\u00a0") ? function(e) {
|
|
return null == e ? "" : b.call(e)
|
|
} : function(e) {
|
|
return null == e ? "" : (e + "").replace(C, "")
|
|
},
|
|
makeArray: function(e, t) {
|
|
var n = t || [];
|
|
return null != e && (M(Object(e)) ? x.merge(n, "string" == typeof e ? [e] : e) : h.call(n, e)), n
|
|
},
|
|
inArray: function(e, t, n) {
|
|
var r;
|
|
if (t) {
|
|
if (m) return m.call(t, e, n);
|
|
for (r = t.length, n = n ? 0 > n ? Math.max(0, r + n) : n : 0; r > n; n++)
|
|
if (n in t && t[n] === e) return n
|
|
}
|
|
return -1
|
|
},
|
|
merge: function(e, n) {
|
|
var r = n.length,
|
|
i = e.length,
|
|
o = 0;
|
|
if ("number" == typeof r)
|
|
for (; r > o; o++) e[i++] = n[o];
|
|
else
|
|
while (n[o] !== t) e[i++] = n[o++];
|
|
return e.length = i, e
|
|
},
|
|
grep: function(e, t, n) {
|
|
var r, i = [],
|
|
o = 0,
|
|
a = e.length;
|
|
for (n = !!n; a > o; o++) r = !!t(e[o], o), n !== r && i.push(e[o]);
|
|
return i
|
|
},
|
|
map: function(e, t, n) {
|
|
var r, i = 0,
|
|
o = e.length,
|
|
a = M(e),
|
|
s = [];
|
|
if (a)
|
|
for (; o > i; i++) r = t(e[i], i, n), null != r && (s[s.length] = r);
|
|
else
|
|
for (i in e) r = t(e[i], i, n), null != r && (s[s.length] = r);
|
|
return d.apply([], s)
|
|
},
|
|
guid: 1,
|
|
proxy: function(e, n) {
|
|
var r, i, o;
|
|
return "string" == typeof n && (o = e[n], n = e, e = o), x.isFunction(e) ? (r = g.call(arguments, 2), i = function() {
|
|
return e.apply(n || this, r.concat(g.call(arguments)))
|
|
}, i.guid = e.guid = e.guid || x.guid++, i) : t
|
|
},
|
|
access: function(e, n, r, i, o, a, s) {
|
|
var l = 0,
|
|
u = e.length,
|
|
c = null == r;
|
|
if ("object" === x.type(r)) {
|
|
o = !0;
|
|
for (l in r) x.access(e, n, l, r[l], !0, a, s)
|
|
} else if (i !== t && (o = !0, x.isFunction(i) || (s = !0), c && (s ? (n.call(e, i), n = null) : (c = n, n = function(e, t, n) {
|
|
return c.call(x(e), n)
|
|
})), n))
|
|
for (; u > l; l++) n(e[l], r, s ? i : i.call(e[l], l, n(e[l], r)));
|
|
return o ? e : c ? n.call(e) : u ? n(e[0], r) : a
|
|
},
|
|
now: function() {
|
|
return (new Date).getTime()
|
|
},
|
|
swap: function(e, t, n, r) {
|
|
var i, o, a = {};
|
|
for (o in t) a[o] = e.style[o], e.style[o] = t[o];
|
|
i = n.apply(e, r || []);
|
|
for (o in t) e.style[o] = a[o];
|
|
return i
|
|
}
|
|
}), x.ready.promise = function(t) {
|
|
if (!n)
|
|
if (n = x.Deferred(), "complete" === a.readyState) setTimeout(x.ready);
|
|
else if (a.addEventListener) a.addEventListener("DOMContentLoaded", q, !1), e.addEventListener("load", q, !1);
|
|
else {
|
|
a.attachEvent("onreadystatechange", q), e.attachEvent("onload", q);
|
|
var r = !1;
|
|
try {
|
|
r = null == e.frameElement && a.documentElement
|
|
} catch (i) {}
|
|
r && r.doScroll && function o() {
|
|
if (!x.isReady) {
|
|
try {
|
|
r.doScroll("left")
|
|
} catch (e) {
|
|
return setTimeout(o, 50)
|
|
}
|
|
_(), x.ready()
|
|
}
|
|
}()
|
|
}
|
|
return n.promise(t)
|
|
}, x.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), function(e, t) {
|
|
c["[object " + t + "]"] = t.toLowerCase()
|
|
});
|
|
|
|
function M(e) {
|
|
var t = e.length,
|
|
n = x.type(e);
|
|
return x.isWindow(e) ? !1 : 1 === e.nodeType && t ? !0 : "array" === n || "function" !== n && (0 === t || "number" == typeof t && t > 0 && t - 1 in e)
|
|
}
|
|
r = x(a),
|
|
function(e, t) {
|
|
var n, r, i, o, a, s, l, u, c, p, f, d, h, g, m, y, v, b = "sizzle" + -new Date,
|
|
w = e.document,
|
|
T = 0,
|
|
C = 0,
|
|
N = st(),
|
|
k = st(),
|
|
E = st(),
|
|
S = !1,
|
|
A = function(e, t) {
|
|
return e === t ? (S = !0, 0) : 0
|
|
},
|
|
j = typeof t,
|
|
D = 1 << 31,
|
|
L = {}.hasOwnProperty,
|
|
H = [],
|
|
q = H.pop,
|
|
_ = H.push,
|
|
M = H.push,
|
|
O = H.slice,
|
|
F = H.indexOf || function(e) {
|
|
var t = 0,
|
|
n = this.length;
|
|
for (; n > t; t++)
|
|
if (this[t] === e) return t;
|
|
return -1
|
|
},
|
|
B = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
|
|
P = "[\\\\x20\\\\t\\\\r\\\
|
|
\\\\f]",
|
|
R = "(?:\\\\\\\\.|[\\\\w-]|[^\\\\x00-\\\\xa0])+",
|
|
W = R.replace("w", "w#"),
|
|
$ = "\\\\[" + P + "*(" + R + ")" + P + "*(?:([*^$|!~]?=)" + P + "*(?:([\'\\"])((?:\\\\\\\\.|[^\\\\\\\\])*?)\\\\3|(" + W + ")|)|)" + P + "*\\\\]",
|
|
I = ":(" + R + ")(?:\\\\((([\'\\"])((?:\\\\\\\\.|[^\\\\\\\\])*?)\\\\3|((?:\\\\\\\\.|[^\\\\\\\\()[\\\\]]|" + $.replace(3, 8) + ")*)|.*)\\\\)|)",
|
|
z = RegExp("^" + P + "+|((?:^|[^\\\\\\\\])(?:\\\\\\\\.)*)" + P + "+$", "g"),
|
|
X = RegExp("^" + P + "*," + P + "*"),
|
|
U = RegExp("^" + P + "*([>+~]|" + P + ")" + P + "*"),
|
|
V = RegExp(P + "*[+~]"),
|
|
Y = RegExp("=" + P + "*([^\\\\]\'\\"]*)" + P + "*\\\\]", "g"),
|
|
J = RegExp(I),
|
|
G = RegExp("^" + W + "$"),
|
|
Q = {
|
|
ID: RegExp("^#(" + R + ")"),
|
|
CLASS: RegExp("^\\\\.(" + R + ")"),
|
|
TAG: RegExp("^(" + R.replace("w", "w*") + ")"),
|
|
ATTR: RegExp("^" + $),
|
|
PSEUDO: RegExp("^" + I),
|
|
CHILD: RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\\\(" + P + "*(even|odd|(([+-]|)(\\\\d*)n|)" + P + "*(?:([+-]|)" + P + "*(\\\\d+)|))" + P + "*\\\\)|)", "i"),
|
|
bool: RegExp("^(?:" + B + ")$", "i"),
|
|
needsContext: RegExp("^" + P + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\(" + P + "*((?:-\\\\d)?\\\\d*)" + P + "*\\\\)|)(?=[^-]|$)", "i")
|
|
},
|
|
K = /^[^{]+\\{\\s*\\[native \\w/,
|
|
Z = /^(?:#([\\w-]+)|(\\w+)|\\.([\\w-]+))$/,
|
|
et = /^(?:input|select|textarea|button)$/i,
|
|
tt = /^h\\d$/i,
|
|
nt = /\'|\\\\/g,
|
|
rt = RegExp("\\\\\\\\([\\\\da-f]{1,6}" + P + "?|(" + P + ")|.)", "ig"),
|
|
it = function(e, t, n) {
|
|
var r = "0x" + t - 65536;
|
|
return r !== r || n ? t : 0 > r ? String.fromCharCode(r + 65536) : String.fromCharCode(55296 | r >> 10, 56320 | 1023 & r)
|
|
};
|
|
try {
|
|
M.apply(H = O.call(w.childNodes), w.childNodes), H[w.childNodes.length].nodeType
|
|
} catch (ot) {
|
|
M = {
|
|
apply: H.length ? function(e, t) {
|
|
_.apply(e, O.call(t))
|
|
} : function(e, t) {
|
|
var n = e.length,
|
|
r = 0;
|
|
while (e[n++] = t[r++]);
|
|
e.length = n - 1
|
|
}
|
|
}
|
|
}
|
|
|
|
function at(e, t, n, i) {
|
|
var o, a, s, l, u, c, d, m, y, x;
|
|
if ((t ? t.ownerDocument || t : w) !== f && p(t), t = t || f, n = n || [], !e || "string" != typeof e) return n;
|
|
if (1 !== (l = t.nodeType) && 9 !== l) return [];
|
|
if (h && !i) {
|
|
if (o = Z.exec(e))
|
|
if (s = o[1]) {
|
|
if (9 === l) {
|
|
if (a = t.getElementById(s), !a || !a.parentNode) return n;
|
|
if (a.id === s) return n.push(a), n
|
|
} else if (t.ownerDocument && (a = t.ownerDocument.getElementById(s)) && v(t, a) && a.id === s) return n.push(a), n
|
|
} else {
|
|
if (o[2]) return M.apply(n, t.getElementsByTagName(e)), n;
|
|
if ((s = o[3]) && r.getElementsByClassName && t.getElementsByClassName) return M.apply(n, t.getElementsByClassName(s)), n
|
|
}
|
|
if (r.qsa && (!g || !g.test(e))) {
|
|
if (m = d = b, y = t, x = 9 === l && e, 1 === l && "object" !== t.nodeName.toLowerCase()) {
|
|
c = mt(e), (d = t.getAttribute("id")) ? m = d.replace(nt, "\\\\$&") : t.setAttribute("id", m), m = "[id=\'" + m + "\'] ", u = c.length;
|
|
while (u--) c[u] = m + yt(c[u]);
|
|
y = V.test(e) && t.parentNode || t, x = c.join(",")
|
|
}
|
|
if (x) try {
|
|
return M.apply(n, y.querySelectorAll(x)), n
|
|
} catch (T) {} finally {
|
|
d || t.removeAttribute("id")
|
|
}
|
|
}
|
|
}
|
|
return kt(e.replace(z, "$1"), t, n, i)
|
|
}
|
|
|
|
function st() {
|
|
var e = [];
|
|
|
|
function t(n, r) {
|
|
return e.push(n += " ") > o.cacheLength && delete t[e.shift()], t[n] = r
|
|
}
|
|
return t
|
|
}
|
|
|
|
function lt(e) {
|
|
return e[b] = !0, e
|
|
}
|
|
|
|
function ut(e) {
|
|
var t = f.createElement("div");
|
|
try {
|
|
return !!e(t)
|
|
} catch (n) {
|
|
return !1
|
|
} finally {
|
|
t.parentNode && t.parentNode.removeChild(t), t = null
|
|
}
|
|
}
|
|
|
|
function ct(e, t) {
|
|
var n = e.split("|"),
|
|
r = e.length;
|
|
while (r--) o.attrHandle[n[r]] = t
|
|
}
|
|
|
|
function pt(e, t) {
|
|
var n = t && e,
|
|
r = n && 1 === e.nodeType && 1 === t.nodeType && (~t.sourceIndex || D) - (~e.sourceIndex || D);
|
|
if (r) return r;
|
|
if (n)
|
|
while (n = n.nextSibling)
|
|
if (n === t) return -1;
|
|
return e ? 1 : -1
|
|
}
|
|
|
|
function ft(e) {
|
|
return function(t) {
|
|
var n = t.nodeName.toLowerCase();
|
|
return "input" === n && t.type === e
|
|
}
|
|
}
|
|
|
|
function dt(e) {
|
|
return function(t) {
|
|
var n = t.nodeName.toLowerCase();
|
|
return ("input" === n || "button" === n) && t.type === e
|
|
}
|
|
}
|
|
|
|
function ht(e) {
|
|
return lt(function(t) {
|
|
return t = +t, lt(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]))
|
|
})
|
|
})
|
|
}
|
|
s = at.isXML = function(e) {
|
|
var t = e && (e.ownerDocument || e).documentElement;
|
|
return t ? "HTML" !== t.nodeName : !1
|
|
}, r = at.support = {}, p = at.setDocument = function(e) {
|
|
var n = e ? e.ownerDocument || e : w,
|
|
i = n.defaultView;
|
|
return n !== f && 9 === n.nodeType && n.documentElement ? (f = n, d = n.documentElement, h = !s(n), i && i.attachEvent && i !== i.top && i.attachEvent("onbeforeunload", function() {
|
|
p()
|
|
}), r.attributes = ut(function(e) {
|
|
return e.className = "i", !e.getAttribute("className")
|
|
}), r.getElementsByTagName = ut(function(e) {
|
|
return e.appendChild(n.createComment("")), !e.getElementsByTagName("*").length
|
|
}), r.getElementsByClassName = ut(function(e) {
|
|
return e.innerHTML = "<div class=\'a\'></div><div class=\'a i\'></div>", e.firstChild.className = "i", 2 === e.getElementsByClassName("i").length
|
|
}), r.getById = ut(function(e) {
|
|
return d.appendChild(e).id = b, !n.getElementsByName || !n.getElementsByName(b).length
|
|
}), r.getById ? (o.find.ID = function(e, t) {
|
|
if (typeof t.getElementById !== j && h) {
|
|
var n = t.getElementById(e);
|
|
return n && n.parentNode ? [n] : []
|
|
}
|
|
}, o.filter.ID = function(e) {
|
|
var t = e.replace(rt, it);
|
|
return function(e) {
|
|
return e.getAttribute("id") === t
|
|
}
|
|
}) : (delete o.find.ID, o.filter.ID = function(e) {
|
|
var t = e.replace(rt, it);
|
|
return function(e) {
|
|
var n = typeof e.getAttributeNode !== j && e.getAttributeNode("id");
|
|
return n && n.value === t
|
|
}
|
|
}), o.find.TAG = r.getElementsByTagName ? function(e, n) {
|
|
return typeof n.getElementsByTagName !== j ? n.getElementsByTagName(e) : t
|
|
} : 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
|
|
}, o.find.CLASS = r.getElementsByClassName && function(e, n) {
|
|
return typeof n.getElementsByClassName !== j && h ? n.getElementsByClassName(e) : t
|
|
}, m = [], g = [], (r.qsa = K.test(n.querySelectorAll)) && (ut(function(e) {
|
|
e.innerHTML = "<select><option selected=\'\'></option></select>", e.querySelectorAll("[selected]").length || g.push("\\\\[" + P + "*(?:value|" + B + ")"), e.querySelectorAll(":checked").length || g.push(":checked")
|
|
}), ut(function(e) {
|
|
var t = n.createElement("input");
|
|
t.setAttribute("type", "hidden"), e.appendChild(t).setAttribute("t", ""), e.querySelectorAll("[t^=\'\']").length && g.push("[*^$]=" + P + "*(?:\'\'|\\"\\")"), e.querySelectorAll(":enabled").length || g.push(":enabled", ":disabled"), e.querySelectorAll("*,:x"), g.push(",.*:")
|
|
})), (r.matchesSelector = K.test(y = d.webkitMatchesSelector || d.mozMatchesSelector || d.oMatchesSelector || d.msMatchesSelector)) && ut(function(e) {
|
|
r.disconnectedMatch = y.call(e, "div"), y.call(e, "[s!=\'\']:x"), m.push("!=", I)
|
|
}), g = g.length && RegExp(g.join("|")), m = m.length && RegExp(m.join("|")), v = K.test(d.contains) || d.compareDocumentPosition ? 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
|
|
}, A = d.compareDocumentPosition ? function(e, t) {
|
|
if (e === t) return S = !0, 0;
|
|
var i = t.compareDocumentPosition && e.compareDocumentPosition && e.compareDocumentPosition(t);
|
|
return i ? 1 & i || !r.sortDetached && t.compareDocumentPosition(e) === i ? e === n || v(w, e) ? -1 : t === n || v(w, t) ? 1 : c ? F.call(c, e) - F.call(c, t) : 0 : 4 & i ? -1 : 1 : e.compareDocumentPosition ? -1 : 1
|
|
} : function(e, t) {
|
|
var r, i = 0,
|
|
o = e.parentNode,
|
|
a = t.parentNode,
|
|
s = [e],
|
|
l = [t];
|
|
if (e === t) return S = !0, 0;
|
|
if (!o || !a) return e === n ? -1 : t === n ? 1 : o ? -1 : a ? 1 : c ? F.call(c, e) - F.call(c, t) : 0;
|
|
if (o === a) return pt(e, t);
|
|
r = e;
|
|
while (r = r.parentNode) s.unshift(r);
|
|
r = t;
|
|
while (r = r.parentNode) l.unshift(r);
|
|
while (s[i] === l[i]) i++;
|
|
return i ? pt(s[i], l[i]) : s[i] === w ? -1 : l[i] === w ? 1 : 0
|
|
}, n) : f
|
|
}, at.matches = function(e, t) {
|
|
return at(e, null, null, t)
|
|
}, at.matchesSelector = function(e, t) {
|
|
if ((e.ownerDocument || e) !== f && p(e), t = t.replace(Y, "=\'$1\']"), !(!r.matchesSelector || !h || m && m.test(t) || g && g.test(t))) try {
|
|
var n = y.call(e, t);
|
|
if (n || r.disconnectedMatch || e.document && 11 !== e.document.nodeType) return n
|
|
} catch (i) {}
|
|
return at(t, f, null, [e]).length > 0
|
|
}, at.contains = function(e, t) {
|
|
return (e.ownerDocument || e) !== f && p(e), v(e, t)
|
|
}, at.attr = function(e, n) {
|
|
(e.ownerDocument || e) !== f && p(e);
|
|
var i = o.attrHandle[n.toLowerCase()],
|
|
a = i && L.call(o.attrHandle, n.toLowerCase()) ? i(e, n, !h) : t;
|
|
return a === t ? r.attributes || !h ? e.getAttribute(n) : (a = e.getAttributeNode(n)) && a.specified ? a.value : null : a
|
|
}, at.error = function(e) {
|
|
throw Error("Syntax error, unrecognized expression: " + e)
|
|
}, at.uniqueSort = function(e) {
|
|
var t, n = [],
|
|
i = 0,
|
|
o = 0;
|
|
if (S = !r.detectDuplicates, c = !r.sortStable && e.slice(0), e.sort(A), S) {
|
|
while (t = e[o++]) t === e[o] && (i = n.push(o));
|
|
while (i--) e.splice(n[i], 1)
|
|
}
|
|
return e
|
|
}, a = at.getText = function(e) {
|
|
var t, n = "",
|
|
r = 0,
|
|
i = e.nodeType;
|
|
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 += a(e)
|
|
} else if (3 === i || 4 === i) return e.nodeValue
|
|
} else
|
|
for (; t = e[r]; r++) n += a(t);
|
|
return n
|
|
}, o = at.selectors = {
|
|
cacheLength: 50,
|
|
createPseudo: lt,
|
|
match: Q,
|
|
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(rt, it), e[3] = (e[4] || e[5] || "").replace(rt, it), "~=" === 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] || at.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] && at.error(e[0]), e
|
|
},
|
|
PSEUDO: function(e) {
|
|
var n, r = !e[5] && e[2];
|
|
return Q.CHILD.test(e[0]) ? null : (e[3] && e[4] !== t ? e[2] = e[4] : r && J.test(r) && (n = mt(r, !0)) && (n = r.indexOf(")", r.length - n) - r.length) && (e[0] = e[0].slice(0, n), e[2] = r.slice(0, n)), e.slice(0, 3))
|
|
}
|
|
},
|
|
filter: {
|
|
TAG: function(e) {
|
|
var t = e.replace(rt, it).toLowerCase();
|
|
return "*" === e ? function() {
|
|
return !0
|
|
} : function(e) {
|
|
return e.nodeName && e.nodeName.toLowerCase() === t
|
|
}
|
|
},
|
|
CLASS: function(e) {
|
|
var t = N[e + " "];
|
|
return t || (t = RegExp("(^|" + P + ")" + e + "(" + P + "|$)")) && N(e, function(e) {
|
|
return t.test("string" == typeof e.className && e.className || typeof e.getAttribute !== j && e.getAttribute("class") || "")
|
|
})
|
|
},
|
|
ATTR: function(e, t, n) {
|
|
return function(r) {
|
|
var i = at.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 + " ").indexOf(n) > -1 : "|=" === t ? i === n || i.slice(0, n.length + 1) === n + "-" : !1) : !0
|
|
}
|
|
},
|
|
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, l) {
|
|
var u, c, p, f, d, h, g = o !== a ? "nextSibling" : "previousSibling",
|
|
m = t.parentNode,
|
|
y = s && t.nodeName.toLowerCase(),
|
|
v = !l && !s;
|
|
if (m) {
|
|
if (o) {
|
|
while (g) {
|
|
p = t;
|
|
while (p = p[g])
|
|
if (s ? p.nodeName.toLowerCase() === y : 1 === p.nodeType) return !1;
|
|
h = g = "only" === e && !h && "nextSibling"
|
|
}
|
|
return !0
|
|
}
|
|
if (h = [a ? m.firstChild : m.lastChild], a && v) {
|
|
c = m[b] || (m[b] = {}), u = c[e] || [], d = u[0] === T && u[1], f = u[0] === T && u[2], p = d && m.childNodes[d];
|
|
while (p = ++d && p && p[g] || (f = d = 0) || h.pop())
|
|
if (1 === p.nodeType && ++f && p === t) {
|
|
c[e] = [T, d, f];
|
|
break
|
|
}
|
|
} else if (v && (u = (t[b] || (t[b] = {}))[e]) && u[0] === T) f = u[1];
|
|
else
|
|
while (p = ++d && p && p[g] || (f = d = 0) || h.pop())
|
|
if ((s ? p.nodeName.toLowerCase() === y : 1 === p.nodeType) && ++f && (v && ((p[b] || (p[b] = {}))[e] = [T, f]), p === t)) break;
|
|
return f -= i, f === r || 0 === f % r && f / r >= 0
|
|
}
|
|
}
|
|
},
|
|
PSEUDO: function(e, t) {
|
|
var n, r = o.pseudos[e] || o.setFilters[e.toLowerCase()] || at.error("unsupported pseudo: " + e);
|
|
return r[b] ? r(t) : r.length > 1 ? (n = [e, e, "", t], o.setFilters.hasOwnProperty(e.toLowerCase()) ? lt(function(e, n) {
|
|
var i, o = r(e, t),
|
|
a = o.length;
|
|
while (a--) i = F.call(e, o[a]), e[i] = !(n[i] = o[a])
|
|
}) : function(e) {
|
|
return r(e, 0, n)
|
|
}) : r
|
|
}
|
|
},
|
|
pseudos: {
|
|
not: lt(function(e) {
|
|
var t = [],
|
|
n = [],
|
|
r = l(e.replace(z, "$1"));
|
|
return r[b] ? lt(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), !n.pop()
|
|
}
|
|
}),
|
|
has: lt(function(e) {
|
|
return function(t) {
|
|
return at(e, t).length > 0
|
|
}
|
|
}),
|
|
contains: lt(function(e) {
|
|
return function(t) {
|
|
return (t.textContent || t.innerText || a(t)).indexOf(e) > -1
|
|
}
|
|
}),
|
|
lang: lt(function(e) {
|
|
return G.test(e || "") || at.error("unsupported lang: " + e), e = e.replace(rt, it).toLowerCase(),
|
|
function(t) {
|
|
var n;
|
|
do
|
|
if (n = h ? t.lang : t.getAttribute("xml:lang") || t.getAttribute("lang")) return n = n.toLowerCase(), n === 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 === d
|
|
},
|
|
focus: function(e) {
|
|
return e === f.activeElement && (!f.hasFocus || f.hasFocus()) && !!(e.type || e.href || ~e.tabIndex)
|
|
},
|
|
enabled: function(e) {
|
|
return e.disabled === !1
|
|
},
|
|
disabled: function(e) {
|
|
return e.disabled === !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, e.selected === !0
|
|
},
|
|
empty: function(e) {
|
|
for (e = e.firstChild; e; e = e.nextSibling)
|
|
if (e.nodeName > "@" || 3 === e.nodeType || 4 === e.nodeType) return !1;
|
|
return !0
|
|
},
|
|
parent: function(e) {
|
|
return !o.pseudos.empty(e)
|
|
},
|
|
header: function(e) {
|
|
return tt.test(e.nodeName)
|
|
},
|
|
input: function(e) {
|
|
return et.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")) || t.toLowerCase() === e.type)
|
|
},
|
|
first: ht(function() {
|
|
return [0]
|
|
}),
|
|
last: ht(function(e, t) {
|
|
return [t - 1]
|
|
}),
|
|
eq: ht(function(e, t, n) {
|
|
return [0 > n ? n + t : n]
|
|
}),
|
|
even: ht(function(e, t) {
|
|
var n = 0;
|
|
for (; t > n; n += 2) e.push(n);
|
|
return e
|
|
}),
|
|
odd: ht(function(e, t) {
|
|
var n = 1;
|
|
for (; t > n; n += 2) e.push(n);
|
|
return e
|
|
}),
|
|
lt: ht(function(e, t, n) {
|
|
var r = 0 > n ? n + t : n;
|
|
for (; --r >= 0;) e.push(r);
|
|
return e
|
|
}),
|
|
gt: ht(function(e, t, n) {
|
|
var r = 0 > n ? n + t : n;
|
|
for (; t > ++r;) e.push(r);
|
|
return e
|
|
})
|
|
}
|
|
}, o.pseudos.nth = o.pseudos.eq;
|
|
for (n in {
|
|
radio: !0,
|
|
checkbox: !0,
|
|
file: !0,
|
|
password: !0,
|
|
image: !0
|
|
}) o.pseudos[n] = ft(n);
|
|
for (n in {
|
|
submit: !0,
|
|
reset: !0
|
|
}) o.pseudos[n] = dt(n);
|
|
|
|
function gt() {}
|
|
gt.prototype = o.filters = o.pseudos, o.setFilters = new gt;
|
|
|
|
function mt(e, t) {
|
|
var n, r, i, a, s, l, u, c = k[e + " "];
|
|
if (c) return t ? 0 : c.slice(0);
|
|
s = e, l = [], u = o.preFilter;
|
|
while (s) {
|
|
(!n || (r = X.exec(s))) && (r && (s = s.slice(r[0].length) || s), l.push(i = [])), n = !1, (r = U.exec(s)) && (n = r.shift(), i.push({
|
|
value: n,
|
|
type: r[0].replace(z, " ")
|
|
}), s = s.slice(n.length));
|
|
for (a in o.filter) !(r = Q[a].exec(s)) || u[a] && !(r = u[a](r)) || (n = r.shift(), i.push({
|
|
value: n,
|
|
type: a,
|
|
matches: r
|
|
}), s = s.slice(n.length));
|
|
if (!n) break
|
|
}
|
|
return t ? s.length : s ? at.error(e) : k(e, l).slice(0)
|
|
}
|
|
|
|
function yt(e) {
|
|
var t = 0,
|
|
n = e.length,
|
|
r = "";
|
|
for (; n > t; t++) r += e[t].value;
|
|
return r
|
|
}
|
|
|
|
function vt(e, t, n) {
|
|
var r = t.dir,
|
|
o = n && "parentNode" === r,
|
|
a = C++;
|
|
return t.first ? function(t, n, i) {
|
|
while (t = t[r])
|
|
if (1 === t.nodeType || o) return e(t, n, i)
|
|
} : function(t, n, s) {
|
|
var l, u, c, p = T + " " + a;
|
|
if (s) {
|
|
while (t = t[r])
|
|
if ((1 === t.nodeType || o) && e(t, n, s)) return !0
|
|
} else
|
|
while (t = t[r])
|
|
if (1 === t.nodeType || o)
|
|
if (c = t[b] || (t[b] = {}), (u = c[r]) && u[0] === p) {
|
|
if ((l = u[1]) === !0 || l === i) return l === !0
|
|
} else if (u = c[r] = [p], u[1] = e(t, n, s) || i, u[1] === !0) return !0
|
|
}
|
|
}
|
|
|
|
function bt(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 xt(e, t, n, r, i) {
|
|
var o, a = [],
|
|
s = 0,
|
|
l = e.length,
|
|
u = null != t;
|
|
for (; l > s; s++)(o = e[s]) && (!n || n(o, r, i)) && (a.push(o), u && t.push(s));
|
|
return a
|
|
}
|
|
|
|
function wt(e, t, n, r, i, o) {
|
|
return r && !r[b] && (r = wt(r)), i && !i[b] && (i = wt(i, o)), lt(function(o, a, s, l) {
|
|
var u, c, p, f = [],
|
|
d = [],
|
|
h = a.length,
|
|
g = o || Nt(t || "*", s.nodeType ? [s] : s, []),
|
|
m = !e || !o && t ? g : xt(g, f, e, s, l),
|
|
y = n ? i || (o ? e : h || r) ? [] : a : m;
|
|
if (n && n(m, y, s, l), r) {
|
|
u = xt(y, d), r(u, [], s, l), c = u.length;
|
|
while (c--)(p = u[c]) && (y[d[c]] = !(m[d[c]] = p))
|
|
}
|
|
if (o) {
|
|
if (i || e) {
|
|
if (i) {
|
|
u = [], c = y.length;
|
|
while (c--)(p = y[c]) && u.push(m[c] = p);
|
|
i(null, y = [], u, l)
|
|
}
|
|
c = y.length;
|
|
while (c--)(p = y[c]) && (u = i ? F.call(o, p) : f[c]) > -1 && (o[u] = !(a[u] = p))
|
|
}
|
|
} else y = xt(y === a ? y.splice(h, y.length) : y), i ? i(null, a, y, l) : M.apply(a, y)
|
|
})
|
|
}
|
|
|
|
function Tt(e) {
|
|
var t, n, r, i = e.length,
|
|
a = o.relative[e[0].type],
|
|
s = a || o.relative[" "],
|
|
l = a ? 1 : 0,
|
|
c = vt(function(e) {
|
|
return e === t
|
|
}, s, !0),
|
|
p = vt(function(e) {
|
|
return F.call(t, e) > -1
|
|
}, s, !0),
|
|
f = [function(e, n, r) {
|
|
return !a && (r || n !== u) || ((t = n).nodeType ? c(e, n, r) : p(e, n, r))
|
|
}];
|
|
for (; i > l; l++)
|
|
if (n = o.relative[e[l].type]) f = [vt(bt(f), n)];
|
|
else {
|
|
if (n = o.filter[e[l].type].apply(null, e[l].matches), n[b]) {
|
|
for (r = ++l; i > r; r++)
|
|
if (o.relative[e[r].type]) break;
|
|
return wt(l > 1 && bt(f), l > 1 && yt(e.slice(0, l - 1).concat({
|
|
value: " " === e[l - 2].type ? "*" : ""
|
|
})).replace(z, "$1"), n, r > l && Tt(e.slice(l, r)), i > r && Tt(e = e.slice(r)), i > r && yt(e))
|
|
}
|
|
f.push(n)
|
|
}
|
|
return bt(f)
|
|
}
|
|
|
|
function Ct(e, t) {
|
|
var n = 0,
|
|
r = t.length > 0,
|
|
a = e.length > 0,
|
|
s = function(s, l, c, p, d) {
|
|
var h, g, m, y = [],
|
|
v = 0,
|
|
b = "0",
|
|
x = s && [],
|
|
w = null != d,
|
|
C = u,
|
|
N = s || a && o.find.TAG("*", d && l.parentNode || l),
|
|
k = T += null == C ? 1 : Math.random() || .1;
|
|
for (w && (u = l !== f && l, i = n); null != (h = N[b]); b++) {
|
|
if (a && h) {
|
|
g = 0;
|
|
while (m = e[g++])
|
|
if (m(h, l, c)) {
|
|
p.push(h);
|
|
break
|
|
}
|
|
w && (T = k, i = ++n)
|
|
}
|
|
r && ((h = !m && h) && v--, s && x.push(h))
|
|
}
|
|
if (v += b, r && b !== v) {
|
|
g = 0;
|
|
while (m = t[g++]) m(x, y, l, c);
|
|
if (s) {
|
|
if (v > 0)
|
|
while (b--) x[b] || y[b] || (y[b] = q.call(p));
|
|
y = xt(y)
|
|
}
|
|
M.apply(p, y), w && !s && y.length > 0 && v + t.length > 1 && at.uniqueSort(p)
|
|
}
|
|
return w && (T = k, u = C), x
|
|
};
|
|
return r ? lt(s) : s
|
|
}
|
|
l = at.compile = function(e, t) {
|
|
var n, r = [],
|
|
i = [],
|
|
o = E[e + " "];
|
|
if (!o) {
|
|
t || (t = mt(e)), n = t.length;
|
|
while (n--) o = Tt(t[n]), o[b] ? r.push(o) : i.push(o);
|
|
o = E(e, Ct(i, r))
|
|
}
|
|
return o
|
|
};
|
|
|
|
function Nt(e, t, n) {
|
|
var r = 0,
|
|
i = t.length;
|
|
for (; i > r; r++) at(e, t[r], n);
|
|
return n
|
|
}
|
|
|
|
function kt(e, t, n, i) {
|
|
var a, s, u, c, p, f = mt(e);
|
|
if (!i && 1 === f.length) {
|
|
if (s = f[0] = f[0].slice(0), s.length > 2 && "ID" === (u = s[0]).type && r.getById && 9 === t.nodeType && h && o.relative[s[1].type]) {
|
|
if (t = (o.find.ID(u.matches[0].replace(rt, it), t) || [])[0], !t) return n;
|
|
e = e.slice(s.shift().value.length)
|
|
}
|
|
a = Q.needsContext.test(e) ? 0 : s.length;
|
|
while (a--) {
|
|
if (u = s[a], o.relative[c = u.type]) break;
|
|
if ((p = o.find[c]) && (i = p(u.matches[0].replace(rt, it), V.test(s[0].type) && t.parentNode || t))) {
|
|
if (s.splice(a, 1), e = i.length && yt(s), !e) return M.apply(n, i), n;
|
|
break
|
|
}
|
|
}
|
|
}
|
|
return l(e, f)(i, t, !h, n, V.test(e)), n
|
|
}
|
|
r.sortStable = b.split("").sort(A).join("") === b, r.detectDuplicates = S, p(), r.sortDetached = ut(function(e) {
|
|
return 1 & e.compareDocumentPosition(f.createElement("div"))
|
|
}), ut(function(e) {
|
|
return e.innerHTML = "<a href=\'#\'></a>", "#" === e.firstChild.getAttribute("href")
|
|
}) || ct("type|href|height|width", function(e, n, r) {
|
|
return r ? t : e.getAttribute(n, "type" === n.toLowerCase() ? 1 : 2)
|
|
}), r.attributes && ut(function(e) {
|
|
return e.innerHTML = "<input/>", e.firstChild.setAttribute("value", ""), "" === e.firstChild.getAttribute("value")
|
|
}) || ct("value", function(e, n, r) {
|
|
return r || "input" !== e.nodeName.toLowerCase() ? t : e.defaultValue
|
|
}), ut(function(e) {
|
|
return null == e.getAttribute("disabled")
|
|
}) || ct(B, function(e, n, r) {
|
|
var i;
|
|
return r ? t : (i = e.getAttributeNode(n)) && i.specified ? i.value : e[n] === !0 ? n.toLowerCase() : null
|
|
}), x.find = at, x.expr = at.selectors, x.expr[":"] = x.expr.pseudos, x.unique = at.uniqueSort, x.text = at.getText, x.isXMLDoc = at.isXML, x.contains = at.contains
|
|
}(e);
|
|
var O = {};
|
|
|
|
function F(e) {
|
|
var t = O[e] = {};
|
|
return x.each(e.match(T) || [], function(e, n) {
|
|
t[n] = !0
|
|
}), t
|
|
}
|
|
x.Callbacks = function(e) {
|
|
e = "string" == typeof e ? O[e] || F(e) : x.extend({}, e);
|
|
var n, r, i, o, a, s, l = [],
|
|
u = !e.once && [],
|
|
c = function(t) {
|
|
for (r = e.memory && t, i = !0, a = s || 0, s = 0, o = l.length, n = !0; l && o > a; a++)
|
|
if (l[a].apply(t[0], t[1]) === !1 && e.stopOnFalse) {
|
|
r = !1;
|
|
break
|
|
}
|
|
n = !1, l && (u ? u.length && c(u.shift()) : r ? l = [] : p.disable())
|
|
},
|
|
p = {
|
|
add: function() {
|
|
if (l) {
|
|
var t = l.length;
|
|
(function i(t) {
|
|
x.each(t, function(t, n) {
|
|
var r = x.type(n);
|
|
"function" === r ? e.unique && p.has(n) || l.push(n) : n && n.length && "string" !== r && i(n)
|
|
})
|
|
})(arguments), n ? o = l.length : r && (s = t, c(r))
|
|
}
|
|
return this
|
|
},
|
|
remove: function() {
|
|
return l && x.each(arguments, function(e, t) {
|
|
var r;
|
|
while ((r = x.inArray(t, l, r)) > -1) l.splice(r, 1), n && (o >= r && o--, a >= r && a--)
|
|
}), this
|
|
},
|
|
has: function(e) {
|
|
return e ? x.inArray(e, l) > -1 : !(!l || !l.length)
|
|
},
|
|
empty: function() {
|
|
return l = [], o = 0, this
|
|
},
|
|
disable: function() {
|
|
return l = u = r = t, this
|
|
},
|
|
disabled: function() {
|
|
return !l
|
|
},
|
|
lock: function() {
|
|
return u = t, r || p.disable(), this
|
|
},
|
|
locked: function() {
|
|
return !u
|
|
},
|
|
fireWith: function(e, t) {
|
|
return !l || i && !u || (t = t || [], t = [e, t.slice ? t.slice() : t], n ? u.push(t) : c(t)), this
|
|
},
|
|
fire: function() {
|
|
return p.fireWith(this, arguments), this
|
|
},
|
|
fired: function() {
|
|
return !!i
|
|
}
|
|
};
|
|
return p
|
|
}, x.extend({
|
|
Deferred: function(e) {
|
|
var t = [
|
|
["resolve", "done", x.Callbacks("once memory"), "resolved"],
|
|
["reject", "fail", x.Callbacks("once memory"), "rejected"],
|
|
["notify", "progress", x.Callbacks("memory")]
|
|
],
|
|
n = "pending",
|
|
r = {
|
|
state: function() {
|
|
return n
|
|
},
|
|
always: function() {
|
|
return i.done(arguments).fail(arguments), this
|
|
},
|
|
then: function() {
|
|
var e = arguments;
|
|
return x.Deferred(function(n) {
|
|
x.each(t, function(t, o) {
|
|
var a = o[0],
|
|
s = x.isFunction(e[t]) && e[t];
|
|
i[o[1]](function() {
|
|
var e = s && s.apply(this, arguments);
|
|
e && x.isFunction(e.promise) ? e.promise().done(n.resolve).fail(n.reject).progress(n.notify) : n[a + "With"](this === r ? n.promise() : this, s ? [e] : arguments)
|
|
})
|
|
}), e = null
|
|
}).promise()
|
|
},
|
|
promise: function(e) {
|
|
return null != e ? x.extend(e, r) : r
|
|
}
|
|
},
|
|
i = {};
|
|
return r.pipe = r.then, x.each(t, function(e, o) {
|
|
var a = o[2],
|
|
s = o[3];
|
|
r[o[1]] = a.add, s && a.add(function() {
|
|
n = s
|
|
}, t[1 ^ e][2].disable, t[2][2].lock), i[o[0]] = function() {
|
|
return i[o[0] + "With"](this === i ? r : this, arguments), this
|
|
}, i[o[0] + "With"] = a.fireWith
|
|
}), r.promise(i), e && e.call(i, i), i
|
|
},
|
|
when: function(e) {
|
|
var t = 0,
|
|
n = g.call(arguments),
|
|
r = n.length,
|
|
i = 1 !== r || e && x.isFunction(e.promise) ? r : 0,
|
|
o = 1 === i ? e : x.Deferred(),
|
|
a = function(e, t, n) {
|
|
return function(r) {
|
|
t[e] = this, n[e] = arguments.length > 1 ? g.call(arguments) : r, n === s ? o.notifyWith(t, n) : --i || o.resolveWith(t, n)
|
|
}
|
|
},
|
|
s, l, u;
|
|
if (r > 1)
|
|
for (s = Array(r), l = Array(r), u = Array(r); r > t; t++) n[t] && x.isFunction(n[t].promise) ? n[t].promise().done(a(t, u, n)).fail(o.reject).progress(a(t, l, s)) : --i;
|
|
return i || o.resolveWith(u, n), o.promise()
|
|
}
|
|
}), x.support = function(t) {
|
|
var n, r, o, s, l, u, c, p, f, d = a.createElement("div");
|
|
if (d.setAttribute("className", "t"), d.innerHTML = " <link/><table></table><a href=\'/a\'>a</a><input type=\'checkbox\'/>", n = d.getElementsByTagName("*") || [], r = d.getElementsByTagName("a")[0], !r || !r.style || !n.length) return t;
|
|
s = a.createElement("select"), u = s.appendChild(a.createElement("option")), o = d.getElementsByTagName("input")[0], r.style.cssText = "top:1px;float:left;opacity:.5", t.getSetAttribute = "t" !== d.className, t.leadingWhitespace = 3 === d.firstChild.nodeType, t.tbody = !d.getElementsByTagName("tbody").length, t.htmlSerialize = !!d.getElementsByTagName("link").length, t.style = /top/.test(r.getAttribute("style")), t.hrefNormalized = "/a" === r.getAttribute("href"), t.opacity = /^0.5/.test(r.style.opacity), t.cssFloat = !!r.style.cssFloat, t.checkOn = !!o.value, t.optSelected = u.selected, t.enctype = !!a.createElement("form").enctype, t.html5Clone = "<:nav></:nav>" !== a.createElement("nav").cloneNode(!0).outerHTML, t.inlineBlockNeedsLayout = !1, t.shrinkWrapBlocks = !1, t.pixelPosition = !1, t.deleteExpando = !0, t.noCloneEvent = !0, t.reliableMarginRight = !0, t.boxSizingReliable = !0, o.checked = !0, t.noCloneChecked = o.cloneNode(!0).checked, s.disabled = !0, t.optDisabled = !u.disabled;
|
|
try {
|
|
delete d.test
|
|
} catch (h) {
|
|
t.deleteExpando = !1
|
|
}
|
|
o = a.createElement("input"), o.setAttribute("value", ""), t.input = "" === o.getAttribute("value"), o.value = "t", o.setAttribute("type", "radio"), t.radioValue = "t" === o.value, o.setAttribute("checked", "t"), o.setAttribute("name", "t"), l = a.createDocumentFragment(), l.appendChild(o), t.appendChecked = o.checked, t.checkClone = l.cloneNode(!0).cloneNode(!0).lastChild.checked, d.attachEvent && (d.attachEvent("onclick", function() {
|
|
t.noCloneEvent = !1
|
|
}), d.cloneNode(!0).click());
|
|
for (f in {
|
|
submit: !0,
|
|
change: !0,
|
|
focusin: !0
|
|
}) d.setAttribute(c = "on" + f, "t"), t[f + "Bubbles"] = c in e || d.attributes[c].expando === !1;
|
|
d.style.backgroundClip = "content-box", d.cloneNode(!0).style.backgroundClip = "", t.clearCloneStyle = "content-box" === d.style.backgroundClip;
|
|
for (f in x(t)) break;
|
|
return t.ownLast = "0" !== f, x(function() {
|
|
var n, r, o, s = "padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;",
|
|
l = a.getElementsByTagName("body")[0];
|
|
l && (n = a.createElement("div"), n.style.cssText = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px", l.appendChild(n).appendChild(d), d.innerHTML = "<table><tr><td></td><td>t</td></tr></table>", o = d.getElementsByTagName("td"), o[0].style.cssText = "padding:0;margin:0;border:0;display:none", p = 0 === o[0].offsetHeight, o[0].style.display = "", o[1].style.display = "none", t.reliableHiddenOffsets = p && 0 === o[0].offsetHeight, d.innerHTML = "", d.style.cssText = "box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;", x.swap(l, null != l.style.zoom ? {
|
|
zoom: 1
|
|
} : {}, function() {
|
|
t.boxSizing = 4 === d.offsetWidth
|
|
}), e.getComputedStyle && (t.pixelPosition = "1%" !== (e.getComputedStyle(d, null) || {}).top, t.boxSizingReliable = "4px" === (e.getComputedStyle(d, null) || {
|
|
width: "4px"
|
|
}).width, r = d.appendChild(a.createElement("div")), r.style.cssText = d.style.cssText = s, r.style.marginRight = r.style.width = "0", d.style.width = "1px", t.reliableMarginRight = !parseFloat((e.getComputedStyle(r, null) || {}).marginRight)), typeof d.style.zoom !== i && (d.innerHTML = "", d.style.cssText = s + "width:1px;padding:1px;display:inline;zoom:1", t.inlineBlockNeedsLayout = 3 === d.offsetWidth, d.style.display = "block", d.innerHTML = "<div></div>", d.firstChild.style.width = "5px", t.shrinkWrapBlocks = 3 !== d.offsetWidth, t.inlineBlockNeedsLayout && (l.style.zoom = 1)), l.removeChild(n), n = d = o = r = null)
|
|
}), n = s = l = u = r = o = null, t
|
|
}({});
|
|
var B = /(?:\\{[\\s\\S]*\\}|\\[[\\s\\S]*\\])$/,
|
|
P = /([A-Z])/g;
|
|
|
|
function R(e, n, r, i) {
|
|
if (x.acceptData(e)) {
|
|
var o, a, s = x.expando,
|
|
l = e.nodeType,
|
|
u = l ? x.cache : e,
|
|
c = l ? e[s] : e[s] && s;
|
|
if (c && u[c] && (i || u[c].data) || r !== t || "string" != typeof n) return c || (c = l ? e[s] = p.pop() || x.guid++ : s), u[c] || (u[c] = l ? {} : {
|
|
toJSON: x.noop
|
|
}), ("object" == typeof n || "function" == typeof n) && (i ? u[c] = x.extend(u[c], n) : u[c].data = x.extend(u[c].data, n)), a = u[c], i || (a.data || (a.data = {}), a = a.data), r !== t && (a[x.camelCase(n)] = r), "string" == typeof n ? (o = a[n], null == o && (o = a[x.camelCase(n)])) : o = a, o
|
|
}
|
|
}
|
|
|
|
function W(e, t, n) {
|
|
if (x.acceptData(e)) {
|
|
var r, i, o = e.nodeType,
|
|
a = o ? x.cache : e,
|
|
s = o ? e[x.expando] : x.expando;
|
|
if (a[s]) {
|
|
if (t && (r = n ? a[s] : a[s].data)) {
|
|
x.isArray(t) ? t = t.concat(x.map(t, x.camelCase)) : t in r ? t = [t] : (t = x.camelCase(t), t = t in r ? [t] : t.split(" ")), i = t.length;
|
|
while (i--) delete r[t[i]];
|
|
if (n ? !I(r) : !x.isEmptyObject(r)) return
|
|
}(n || (delete a[s].data, I(a[s]))) && (o ? x.cleanData([e], !0) : x.support.deleteExpando || a != a.window ? delete a[s] : a[s] = null)
|
|
}
|
|
}
|
|
}
|
|
x.extend({
|
|
cache: {},
|
|
noData: {
|
|
applet: !0,
|
|
embed: !0,
|
|
object: "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
|
|
},
|
|
hasData: function(e) {
|
|
return e = e.nodeType ? x.cache[e[x.expando]] : e[x.expando], !!e && !I(e)
|
|
},
|
|
data: function(e, t, n) {
|
|
return R(e, t, n)
|
|
},
|
|
removeData: function(e, t) {
|
|
return W(e, t)
|
|
},
|
|
_data: function(e, t, n) {
|
|
return R(e, t, n, !0)
|
|
},
|
|
_removeData: function(e, t) {
|
|
return W(e, t, !0)
|
|
},
|
|
acceptData: function(e) {
|
|
if (e.nodeType && 1 !== e.nodeType && 9 !== e.nodeType) return !1;
|
|
var t = e.nodeName && x.noData[e.nodeName.toLowerCase()];
|
|
return !t || t !== !0 && e.getAttribute("classid") === t
|
|
}
|
|
}), x.fn.extend({
|
|
data: function(e, n) {
|
|
var r, i, o = null,
|
|
a = 0,
|
|
s = this[0];
|
|
if (e === t) {
|
|
if (this.length && (o = x.data(s), 1 === s.nodeType && !x._data(s, "parsedAttrs"))) {
|
|
for (r = s.attributes; r.length > a; a++) i = r[a].name, 0 === i.indexOf("data-") && (i = x.camelCase(i.slice(5)), $(s, i, o[i]));
|
|
x._data(s, "parsedAttrs", !0)
|
|
}
|
|
return o
|
|
}
|
|
return "object" == typeof e ? this.each(function() {
|
|
x.data(this, e)
|
|
}) : arguments.length > 1 ? this.each(function() {
|
|
x.data(this, e, n)
|
|
}) : s ? $(s, e, x.data(s, e)) : null
|
|
},
|
|
removeData: function(e) {
|
|
return this.each(function() {
|
|
x.removeData(this, e)
|
|
})
|
|
}
|
|
});
|
|
|
|
function $(e, n, r) {
|
|
if (r === t && 1 === e.nodeType) {
|
|
var i = "data-" + n.replace(P, "-$1").toLowerCase();
|
|
if (r = e.getAttribute(i), "string" == typeof r) {
|
|
try {
|
|
r = "true" === r ? !0 : "false" === r ? !1 : "null" === r ? null : +r + "" === r ? +r : B.test(r) ? x.parseJSON(r) : r
|
|
} catch (o) {}
|
|
x.data(e, n, r)
|
|
} else r = t
|
|
}
|
|
return r
|
|
}
|
|
|
|
function I(e) {
|
|
var t;
|
|
for (t in e)
|
|
if (("data" !== t || !x.isEmptyObject(e[t])) && "toJSON" !== t) return !1;
|
|
return !0
|
|
}
|
|
x.extend({
|
|
queue: function(e, n, r) {
|
|
var i;
|
|
return e ? (n = (n || "fx") + "queue", i = x._data(e, n), r && (!i || x.isArray(r) ? i = x._data(e, n, x.makeArray(r)) : i.push(r)), i || []) : t
|
|
},
|
|
dequeue: function(e, t) {
|
|
t = t || "fx";
|
|
var n = x.queue(e, t),
|
|
r = n.length,
|
|
i = n.shift(),
|
|
o = x._queueHooks(e, t),
|
|
a = function() {
|
|
x.dequeue(e, t)
|
|
};
|
|
"inprogress" === i && (i = n.shift(), r--), i && ("fx" === t && n.unshift("inprogress"), delete o.stop, i.call(e, a, o)), !r && o && o.empty.fire()
|
|
},
|
|
_queueHooks: function(e, t) {
|
|
var n = t + "queueHooks";
|
|
return x._data(e, n) || x._data(e, n, {
|
|
empty: x.Callbacks("once memory").add(function() {
|
|
x._removeData(e, t + "queue"), x._removeData(e, n)
|
|
})
|
|
})
|
|
}
|
|
}), x.fn.extend({
|
|
queue: function(e, n) {
|
|
var r = 2;
|
|
return "string" != typeof e && (n = e, e = "fx", r--), r > arguments.length ? x.queue(this[0], e) : n === t ? this : this.each(function() {
|
|
var t = x.queue(this, e, n);
|
|
x._queueHooks(this, e), "fx" === e && "inprogress" !== t[0] && x.dequeue(this, e)
|
|
})
|
|
},
|
|
dequeue: function(e) {
|
|
return this.each(function() {
|
|
x.dequeue(this, e)
|
|
})
|
|
},
|
|
delay: function(e, t) {
|
|
return e = x.fx ? x.fx.speeds[e] || e : e, t = t || "fx", this.queue(t, function(t, n) {
|
|
var r = setTimeout(t, e);
|
|
n.stop = function() {
|
|
clearTimeout(r)
|
|
}
|
|
})
|
|
},
|
|
clearQueue: function(e) {
|
|
return this.queue(e || "fx", [])
|
|
},
|
|
promise: function(e, n) {
|
|
var r, i = 1,
|
|
o = x.Deferred(),
|
|
a = this,
|
|
s = this.length,
|
|
l = function() {
|
|
--i || o.resolveWith(a, [a])
|
|
};
|
|
"string" != typeof e && (n = e, e = t), e = e || "fx";
|
|
while (s--) r = x._data(a[s], e + "queueHooks"), r && r.empty && (i++, r.empty.add(l));
|
|
return l(), o.promise(n)
|
|
}
|
|
});
|
|
var z, X, U = /[\\t\\r\
|
|
\\f]/g,
|
|
V = /\\r/g,
|
|
Y = /^(?:input|select|textarea|button|object)$/i,
|
|
J = /^(?:a|area)$/i,
|
|
G = /^(?:checked|selected)$/i,
|
|
Q = x.support.getSetAttribute,
|
|
K = x.support.input;
|
|
x.fn.extend({
|
|
attr: function(e, t) {
|
|
return x.access(this, x.attr, e, t, arguments.length > 1)
|
|
},
|
|
removeAttr: function(e) {
|
|
return this.each(function() {
|
|
x.removeAttr(this, e)
|
|
})
|
|
},
|
|
prop: function(e, t) {
|
|
return x.access(this, x.prop, e, t, arguments.length > 1)
|
|
},
|
|
removeProp: function(e) {
|
|
return e = x.propFix[e] || e, this.each(function() {
|
|
try {
|
|
this[e] = t, delete this[e]
|
|
} catch (n) {}
|
|
})
|
|
},
|
|
addClass: function(e) {
|
|
var t, n, r, i, o, a = 0,
|
|
s = this.length,
|
|
l = "string" == typeof e && e;
|
|
if (x.isFunction(e)) return this.each(function(t) {
|
|
x(this).addClass(e.call(this, t, this.className))
|
|
});
|
|
if (l)
|
|
for (t = (e || "").match(T) || []; s > a; a++)
|
|
if (n = this[a], r = 1 === n.nodeType && (n.className ? (" " + n.className + " ").replace(U, " ") : " ")) {
|
|
o = 0;
|
|
while (i = t[o++]) 0 > r.indexOf(" " + i + " ") && (r += i + " ");
|
|
n.className = x.trim(r)
|
|
}
|
|
return this
|
|
},
|
|
removeClass: function(e) {
|
|
var t, n, r, i, o, a = 0,
|
|
s = this.length,
|
|
l = 0 === arguments.length || "string" == typeof e && e;
|
|
if (x.isFunction(e)) return this.each(function(t) {
|
|
x(this).removeClass(e.call(this, t, this.className))
|
|
});
|
|
if (l)
|
|
for (t = (e || "").match(T) || []; s > a; a++)
|
|
if (n = this[a], r = 1 === n.nodeType && (n.className ? (" " + n.className + " ").replace(U, " ") : "")) {
|
|
o = 0;
|
|
while (i = t[o++])
|
|
while (r.indexOf(" " + i + " ") >= 0) r = r.replace(" " + i + " ", " ");
|
|
n.className = e ? x.trim(r) : ""
|
|
}
|
|
return this
|
|
},
|
|
toggleClass: function(e, t) {
|
|
var n = typeof e;
|
|
return "boolean" == typeof t && "string" === n ? t ? this.addClass(e) : this.removeClass(e) : x.isFunction(e) ? this.each(function(n) {
|
|
x(this).toggleClass(e.call(this, n, this.className, t), t)
|
|
}) : this.each(function() {
|
|
if ("string" === n) {
|
|
var t, r = 0,
|
|
o = x(this),
|
|
a = e.match(T) || [];
|
|
while (t = a[r++]) o.hasClass(t) ? o.removeClass(t) : o.addClass(t)
|
|
} else(n === i || "boolean" === n) && (this.className && x._data(this, "__className__", this.className), this.className = this.className || e === !1 ? "" : x._data(this, "__className__") || "")
|
|
})
|
|
},
|
|
hasClass: function(e) {
|
|
var t = " " + e + " ",
|
|
n = 0,
|
|
r = this.length;
|
|
for (; r > n; n++)
|
|
if (1 === this[n].nodeType && (" " + this[n].className + " ").replace(U, " ").indexOf(t) >= 0) return !0;
|
|
return !1
|
|
},
|
|
val: function(e) {
|
|
var n, r, i, o = this[0]; {
|
|
if (arguments.length) return i = x.isFunction(e), this.each(function(n) {
|
|
var o;
|
|
1 === this.nodeType && (o = i ? e.call(this, n, x(this).val()) : e, null == o ? o = "" : "number" == typeof o ? o += "" : x.isArray(o) && (o = x.map(o, function(e) {
|
|
return null == e ? "" : e + ""
|
|
})), r = x.valHooks[this.type] || x.valHooks[this.nodeName.toLowerCase()], r && "set" in r && r.set(this, o, "value") !== t || (this.value = o))
|
|
});
|
|
if (o) return r = x.valHooks[o.type] || x.valHooks[o.nodeName.toLowerCase()], r && "get" in r && (n = r.get(o, "value")) !== t ? n : (n = o.value, "string" == typeof n ? n.replace(V, "") : null == n ? "" : n)
|
|
}
|
|
}
|
|
}), x.extend({
|
|
valHooks: {
|
|
option: {
|
|
get: function(e) {
|
|
var t = x.find.attr(e, "value");
|
|
return null != t ? t : e.text
|
|
}
|
|
},
|
|
select: {
|
|
get: function(e) {
|
|
var t, n, r = e.options,
|
|
i = e.selectedIndex,
|
|
o = "select-one" === e.type || 0 > i,
|
|
a = o ? null : [],
|
|
s = o ? i + 1 : r.length,
|
|
l = 0 > i ? s : o ? i : 0;
|
|
for (; s > l; l++)
|
|
if (n = r[l], !(!n.selected && l !== i || (x.support.optDisabled ? n.disabled : null !== n.getAttribute("disabled")) || n.parentNode.disabled && x.nodeName(n.parentNode, "optgroup"))) {
|
|
if (t = x(n).val(), o) return t;
|
|
a.push(t)
|
|
}
|
|
return a
|
|
},
|
|
set: function(e, t) {
|
|
var n, r, i = e.options,
|
|
o = x.makeArray(t),
|
|
a = i.length;
|
|
while (a--) r = i[a], (r.selected = x.inArray(x(r).val(), o) >= 0) && (n = !0);
|
|
return n || (e.selectedIndex = -1), o
|
|
}
|
|
}
|
|
},
|
|
attr: function(e, n, r) {
|
|
var o, a, s = e.nodeType;
|
|
if (e && 3 !== s && 8 !== s && 2 !== s) return typeof e.getAttribute === i ? x.prop(e, n, r) : (1 === s && x.isXMLDoc(e) || (n = n.toLowerCase(), o = x.attrHooks[n] || (x.expr.match.bool.test(n) ? X : z)), r === t ? o && "get" in o && null !== (a = o.get(e, n)) ? a : (a = x.find.attr(e, n), null == a ? t : a) : null !== r ? o && "set" in o && (a = o.set(e, r, n)) !== t ? a : (e.setAttribute(n, r + ""), r) : (x.removeAttr(e, n), t))
|
|
},
|
|
removeAttr: function(e, t) {
|
|
var n, r, i = 0,
|
|
o = t && t.match(T);
|
|
if (o && 1 === e.nodeType)
|
|
while (n = o[i++]) r = x.propFix[n] || n, x.expr.match.bool.test(n) ? K && Q || !G.test(n) ? e[r] = !1 : e[x.camelCase("default-" + n)] = e[r] = !1 : x.attr(e, n, ""), e.removeAttribute(Q ? n : r)
|
|
},
|
|
attrHooks: {
|
|
type: {
|
|
set: function(e, t) {
|
|
if (!x.support.radioValue && "radio" === t && x.nodeName(e, "input")) {
|
|
var n = e.value;
|
|
return e.setAttribute("type", t), n && (e.value = n), t
|
|
}
|
|
}
|
|
}
|
|
},
|
|
propFix: {
|
|
"for": "htmlFor",
|
|
"class": "className"
|
|
},
|
|
prop: function(e, n, r) {
|
|
var i, o, a, s = e.nodeType;
|
|
if (e && 3 !== s && 8 !== s && 2 !== s) return a = 1 !== s || !x.isXMLDoc(e), a && (n = x.propFix[n] || n, o = x.propHooks[n]), r !== t ? o && "set" in o && (i = o.set(e, r, n)) !== t ? i : e[n] = r : o && "get" in o && null !== (i = o.get(e, n)) ? i : e[n]
|
|
},
|
|
propHooks: {
|
|
tabIndex: {
|
|
get: function(e) {
|
|
var t = x.find.attr(e, "tabindex");
|
|
return t ? parseInt(t, 10) : Y.test(e.nodeName) || J.test(e.nodeName) && e.href ? 0 : -1
|
|
}
|
|
}
|
|
}
|
|
}), X = {
|
|
set: function(e, t, n) {
|
|
return t === !1 ? x.removeAttr(e, n) : K && Q || !G.test(n) ? e.setAttribute(!Q && x.propFix[n] || n, n) : e[x.camelCase("default-" + n)] = e[n] = !0, n
|
|
}
|
|
}, x.each(x.expr.match.bool.source.match(/\\w+/g), function(e, n) {
|
|
var r = x.expr.attrHandle[n] || x.find.attr;
|
|
x.expr.attrHandle[n] = K && Q || !G.test(n) ? function(e, n, i) {
|
|
var o = x.expr.attrHandle[n],
|
|
a = i ? t : (x.expr.attrHandle[n] = t) != r(e, n, i) ? n.toLowerCase() : null;
|
|
return x.expr.attrHandle[n] = o, a
|
|
} : function(e, n, r) {
|
|
return r ? t : e[x.camelCase("default-" + n)] ? n.toLowerCase() : null
|
|
}
|
|
}), K && Q || (x.attrHooks.value = {
|
|
set: function(e, n, r) {
|
|
return x.nodeName(e, "input") ? (e.defaultValue = n, t) : z && z.set(e, n, r)
|
|
}
|
|
}), Q || (z = {
|
|
set: function(e, n, r) {
|
|
var i = e.getAttributeNode(r);
|
|
return i || e.setAttributeNode(i = e.ownerDocument.createAttribute(r)), i.value = n += "", "value" === r || n === e.getAttribute(r) ? n : t
|
|
}
|
|
}, x.expr.attrHandle.id = x.expr.attrHandle.name = x.expr.attrHandle.coords = function(e, n, r) {
|
|
var i;
|
|
return r ? t : (i = e.getAttributeNode(n)) && "" !== i.value ? i.value : null
|
|
}, x.valHooks.button = {
|
|
get: function(e, n) {
|
|
var r = e.getAttributeNode(n);
|
|
return r && r.specified ? r.value : t
|
|
},
|
|
set: z.set
|
|
}, x.attrHooks.contenteditable = {
|
|
set: function(e, t, n) {
|
|
z.set(e, "" === t ? !1 : t, n)
|
|
}
|
|
}, x.each(["width", "height"], function(e, n) {
|
|
x.attrHooks[n] = {
|
|
set: function(e, r) {
|
|
return "" === r ? (e.setAttribute(n, "auto"), r) : t
|
|
}
|
|
}
|
|
})), x.support.hrefNormalized || x.each(["href", "src"], function(e, t) {
|
|
x.propHooks[t] = {
|
|
get: function(e) {
|
|
return e.getAttribute(t, 4)
|
|
}
|
|
}
|
|
}), x.support.style || (x.attrHooks.style = {
|
|
get: function(e) {
|
|
return e.style.cssText || t
|
|
},
|
|
set: function(e, t) {
|
|
return e.style.cssText = t + ""
|
|
}
|
|
}), x.support.optSelected || (x.propHooks.selected = {
|
|
get: function(e) {
|
|
var t = e.parentNode;
|
|
return t && (t.selectedIndex, t.parentNode && t.parentNode.selectedIndex), null
|
|
}
|
|
}), x.each(["tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable"], function() {
|
|
x.propFix[this.toLowerCase()] = this
|
|
}), x.support.enctype || (x.propFix.enctype = "encoding"), x.each(["radio", "checkbox"], function() {
|
|
x.valHooks[this] = {
|
|
set: function(e, n) {
|
|
return x.isArray(n) ? e.checked = x.inArray(x(e).val(), n) >= 0 : t
|
|
}
|
|
}, x.support.checkOn || (x.valHooks[this].get = function(e) {
|
|
return null === e.getAttribute("value") ? "on" : e.value
|
|
})
|
|
});
|
|
var Z = /^(?:input|select|textarea)$/i,
|
|
et = /^key/,
|
|
tt = /^(?:mouse|contextmenu)|click/,
|
|
nt = /^(?:focusinfocus|focusoutblur)$/,
|
|
rt = /^([^.]*)(?:\\.(.+)|)$/;
|
|
|
|
function it() {
|
|
return !0
|
|
}
|
|
|
|
function ot() {
|
|
return !1
|
|
}
|
|
|
|
function at() {
|
|
try {
|
|
return a.activeElement
|
|
} catch (e) {}
|
|
}
|
|
x.event = {
|
|
global: {},
|
|
add: function(e, n, r, o, a) {
|
|
var s, l, u, c, p, f, d, h, g, m, y, v = x._data(e);
|
|
if (v) {
|
|
r.handler && (c = r, r = c.handler, a = c.selector), r.guid || (r.guid = x.guid++), (l = v.events) || (l = v.events = {}), (f = v.handle) || (f = v.handle = function(e) {
|
|
return typeof x === i || e && x.event.triggered === e.type ? t : x.event.dispatch.apply(f.elem, arguments)
|
|
}, f.elem = e), n = (n || "").match(T) || [""], u = n.length;
|
|
while (u--) s = rt.exec(n[u]) || [], g = y = s[1], m = (s[2] || "").split(".").sort(), g && (p = x.event.special[g] || {}, g = (a ? p.delegateType : p.bindType) || g, p = x.event.special[g] || {}, d = x.extend({
|
|
type: g,
|
|
origType: y,
|
|
data: o,
|
|
handler: r,
|
|
guid: r.guid,
|
|
selector: a,
|
|
needsContext: a && x.expr.match.needsContext.test(a),
|
|
namespace: m.join(".")
|
|
}, c), (h = l[g]) || (h = l[g] = [], h.delegateCount = 0, p.setup && p.setup.call(e, o, m, f) !== !1 || (e.addEventListener ? e.addEventListener(g, f, !1) : e.attachEvent && e.attachEvent("on" + g, f))), p.add && (p.add.call(e, d), d.handler.guid || (d.handler.guid = r.guid)), a ? h.splice(h.delegateCount++, 0, d) : h.push(d), x.event.global[g] = !0);
|
|
e = null
|
|
}
|
|
},
|
|
remove: function(e, t, n, r, i) {
|
|
var o, a, s, l, u, c, p, f, d, h, g, m = x.hasData(e) && x._data(e);
|
|
if (m && (c = m.events)) {
|
|
t = (t || "").match(T) || [""], u = t.length;
|
|
while (u--)
|
|
if (s = rt.exec(t[u]) || [], d = g = s[1], h = (s[2] || "").split(".").sort(), d) {
|
|
p = x.event.special[d] || {}, d = (r ? p.delegateType : p.bindType) || d, f = c[d] || [], s = s[2] && RegExp("(^|\\\\.)" + h.join("\\\\.(?:.*\\\\.|)") + "(\\\\.|$)"), l = o = f.length;
|
|
while (o--) a = f[o], !i && g !== a.origType || n && n.guid !== a.guid || s && !s.test(a.namespace) || r && r !== a.selector && ("**" !== r || !a.selector) || (f.splice(o, 1), a.selector && f.delegateCount--, p.remove && p.remove.call(e, a));
|
|
l && !f.length && (p.teardown && p.teardown.call(e, h, m.handle) !== !1 || x.removeEvent(e, d, m.handle), delete c[d])
|
|
} else
|
|
for (d in c) x.event.remove(e, d + t[u], n, r, !0);
|
|
x.isEmptyObject(c) && (delete m.handle, x._removeData(e, "events"))
|
|
}
|
|
},
|
|
trigger: function(n, r, i, o) {
|
|
var s, l, u, c, p, f, d, h = [i || a],
|
|
g = v.call(n, "type") ? n.type : n,
|
|
m = v.call(n, "namespace") ? n.namespace.split(".") : [];
|
|
if (u = f = i = i || a, 3 !== i.nodeType && 8 !== i.nodeType && !nt.test(g + x.event.triggered) && (g.indexOf(".") >= 0 && (m = g.split("."), g = m.shift(), m.sort()), l = 0 > g.indexOf(":") && "on" + g, n = n[x.expando] ? n : new x.Event(g, "object" == typeof n && n), n.isTrigger = o ? 2 : 3, n.namespace = m.join("."), n.namespace_re = n.namespace ? RegExp("(^|\\\\.)" + m.join("\\\\.(?:.*\\\\.|)") + "(\\\\.|$)") : null, n.result = t, n.target || (n.target = i), r = null == r ? [n] : x.makeArray(r, [n]), p = x.event.special[g] || {}, o || !p.trigger || p.trigger.apply(i, r) !== !1)) {
|
|
if (!o && !p.noBubble && !x.isWindow(i)) {
|
|
for (c = p.delegateType || g, nt.test(c + g) || (u = u.parentNode); u; u = u.parentNode) h.push(u), f = u;
|
|
f === (i.ownerDocument || a) && h.push(f.defaultView || f.parentWindow || e)
|
|
}
|
|
d = 0;
|
|
while ((u = h[d++]) && !n.isPropagationStopped()) n.type = d > 1 ? c : p.bindType || g, s = (x._data(u, "events") || {})[n.type] && x._data(u, "handle"), s && s.apply(u, r), s = l && u[l], s && x.acceptData(u) && s.apply && s.apply(u, r) === !1 && n.preventDefault();
|
|
if (n.type = g, !o && !n.isDefaultPrevented() && (!p._default || p._default.apply(h.pop(), r) === !1) && x.acceptData(i) && l && i[g] && !x.isWindow(i)) {
|
|
f = i[l], f && (i[l] = null), x.event.triggered = g;
|
|
try {
|
|
i[g]()
|
|
} catch (y) {}
|
|
x.event.triggered = t, f && (i[l] = f)
|
|
}
|
|
return n.result
|
|
}
|
|
},
|
|
dispatch: function(e) {
|
|
e = x.event.fix(e);
|
|
var n, r, i, o, a, s = [],
|
|
l = g.call(arguments),
|
|
u = (x._data(this, "events") || {})[e.type] || [],
|
|
c = x.event.special[e.type] || {};
|
|
if (l[0] = e, e.delegateTarget = this, !c.preDispatch || c.preDispatch.call(this, e) !== !1) {
|
|
s = x.event.handlers.call(this, e, u), n = 0;
|
|
while ((o = s[n++]) && !e.isPropagationStopped()) {
|
|
e.currentTarget = o.elem, a = 0;
|
|
while ((i = o.handlers[a++]) && !e.isImmediatePropagationStopped())(!e.namespace_re || e.namespace_re.test(i.namespace)) && (e.handleObj = i, e.data = i.data, r = ((x.event.special[i.origType] || {}).handle || i.handler).apply(o.elem, l), r !== t && (e.result = r) === !1 && (e.preventDefault(), e.stopPropagation()))
|
|
}
|
|
return c.postDispatch && c.postDispatch.call(this, e), e.result
|
|
}
|
|
},
|
|
handlers: function(e, n) {
|
|
var r, i, o, a, s = [],
|
|
l = n.delegateCount,
|
|
u = e.target;
|
|
if (l && u.nodeType && (!e.button || "click" !== e.type))
|
|
for (; u != this; u = u.parentNode || this)
|
|
if (1 === u.nodeType && (u.disabled !== !0 || "click" !== e.type)) {
|
|
for (o = [], a = 0; l > a; a++) i = n[a], r = i.selector + " ", o[r] === t && (o[r] = i.needsContext ? x(r, this).index(u) >= 0 : x.find(r, this, null, [u]).length), o[r] && o.push(i);
|
|
o.length && s.push({
|
|
elem: u,
|
|
handlers: o
|
|
})
|
|
}
|
|
return n.length > l && s.push({
|
|
elem: this,
|
|
handlers: n.slice(l)
|
|
}), s
|
|
},
|
|
fix: function(e) {
|
|
if (e[x.expando]) return e;
|
|
var t, n, r, i = e.type,
|
|
o = e,
|
|
s = this.fixHooks[i];
|
|
s || (this.fixHooks[i] = s = tt.test(i) ? this.mouseHooks : et.test(i) ? this.keyHooks : {}), r = s.props ? this.props.concat(s.props) : this.props, e = new x.Event(o), t = r.length;
|
|
while (t--) n = r[t], e[n] = o[n];
|
|
return e.target || (e.target = o.srcElement || a), 3 === e.target.nodeType && (e.target = e.target.parentNode), e.metaKey = !!e.metaKey, s.filter ? s.filter(e, o) : e
|
|
},
|
|
props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),
|
|
fixHooks: {},
|
|
keyHooks: {
|
|
props: "char charCode key keyCode".split(" "),
|
|
filter: function(e, t) {
|
|
return null == e.which && (e.which = null != t.charCode ? t.charCode : t.keyCode), e
|
|
}
|
|
},
|
|
mouseHooks: {
|
|
props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),
|
|
filter: function(e, n) {
|
|
var r, i, o, s = n.button,
|
|
l = n.fromElement;
|
|
return null == e.pageX && null != n.clientX && (i = e.target.ownerDocument || a, o = i.documentElement, r = i.body, e.pageX = n.clientX + (o && o.scrollLeft || r && r.scrollLeft || 0) - (o && o.clientLeft || r && r.clientLeft || 0), e.pageY = n.clientY + (o && o.scrollTop || r && r.scrollTop || 0) - (o && o.clientTop || r && r.clientTop || 0)), !e.relatedTarget && l && (e.relatedTarget = l === e.target ? n.toElement : l), e.which || s === t || (e.which = 1 & s ? 1 : 2 & s ? 3 : 4 & s ? 2 : 0), e
|
|
}
|
|
},
|
|
special: {
|
|
load: {
|
|
noBubble: !0
|
|
},
|
|
focus: {
|
|
trigger: function() {
|
|
if (this !== at() && this.focus) try {
|
|
return this.focus(), !1
|
|
} catch (e) {}
|
|
},
|
|
delegateType: "focusin"
|
|
},
|
|
blur: {
|
|
trigger: function() {
|
|
return this === at() && this.blur ? (this.blur(), !1) : t
|
|
},
|
|
delegateType: "focusout"
|
|
},
|
|
click: {
|
|
trigger: function() {
|
|
return x.nodeName(this, "input") && "checkbox" === this.type && this.click ? (this.click(), !1) : t
|
|
},
|
|
_default: function(e) {
|
|
return x.nodeName(e.target, "a")
|
|
}
|
|
},
|
|
beforeunload: {
|
|
postDispatch: function(e) {
|
|
e.result !== t && (e.originalEvent.returnValue = e.result)
|
|
}
|
|
}
|
|
},
|
|
simulate: function(e, t, n, r) {
|
|
var i = x.extend(new x.Event, n, {
|
|
type: e,
|
|
isSimulated: !0,
|
|
originalEvent: {}
|
|
});
|
|
r ? x.event.trigger(i, null, t) : x.event.dispatch.call(t, i), i.isDefaultPrevented() && n.preventDefault()
|
|
}
|
|
}, x.removeEvent = a.removeEventListener ? function(e, t, n) {
|
|
e.removeEventListener && e.removeEventListener(t, n, !1)
|
|
} : function(e, t, n) {
|
|
var r = "on" + t;
|
|
e.detachEvent && (typeof e[r] === i && (e[r] = null), e.detachEvent(r, n))
|
|
}, x.Event = function(e, n) {
|
|
return this instanceof x.Event ? (e && e.type ? (this.originalEvent = e, this.type = e.type, this.isDefaultPrevented = e.defaultPrevented || e.returnValue === !1 || e.getPreventDefault && e.getPreventDefault() ? it : ot) : this.type = e, n && x.extend(this, n), this.timeStamp = e && e.timeStamp || x.now(), this[x.expando] = !0, t) : new x.Event(e, n)
|
|
}, x.Event.prototype = {
|
|
isDefaultPrevented: ot,
|
|
isPropagationStopped: ot,
|
|
isImmediatePropagationStopped: ot,
|
|
preventDefault: function() {
|
|
var e = this.originalEvent;
|
|
this.isDefaultPrevented = it, e && (e.preventDefault ? e.preventDefault() : e.returnValue = !1)
|
|
},
|
|
stopPropagation: function() {
|
|
var e = this.originalEvent;
|
|
this.isPropagationStopped = it, e && (e.stopPropagation && e.stopPropagation(), e.cancelBubble = !0)
|
|
},
|
|
stopImmediatePropagation: function() {
|
|
this.isImmediatePropagationStopped = it, this.stopPropagation()
|
|
}
|
|
}, x.each({
|
|
mouseenter: "mouseover",
|
|
mouseleave: "mouseout"
|
|
}, function(e, t) {
|
|
x.event.special[e] = {
|
|
delegateType: t,
|
|
bindType: t,
|
|
handle: function(e) {
|
|
var n, r = this,
|
|
i = e.relatedTarget,
|
|
o = e.handleObj;
|
|
return (!i || i !== r && !x.contains(r, i)) && (e.type = o.origType, n = o.handler.apply(this, arguments), e.type = t), n
|
|
}
|
|
}
|
|
}), x.support.submitBubbles || (x.event.special.submit = {
|
|
setup: function() {
|
|
return x.nodeName(this, "form") ? !1 : (x.event.add(this, "click._submit keypress._submit", function(e) {
|
|
var n = e.target,
|
|
r = x.nodeName(n, "input") || x.nodeName(n, "button") ? n.form : t;
|
|
r && !x._data(r, "submitBubbles") && (x.event.add(r, "submit._submit", function(e) {
|
|
e._submit_bubble = !0
|
|
}), x._data(r, "submitBubbles", !0))
|
|
}), t)
|
|
},
|
|
postDispatch: function(e) {
|
|
e._submit_bubble && (delete e._submit_bubble, this.parentNode && !e.isTrigger && x.event.simulate("submit", this.parentNode, e, !0))
|
|
},
|
|
teardown: function() {
|
|
return x.nodeName(this, "form") ? !1 : (x.event.remove(this, "._submit"), t)
|
|
}
|
|
}), x.support.changeBubbles || (x.event.special.change = {
|
|
setup: function() {
|
|
return Z.test(this.nodeName) ? (("checkbox" === this.type || "radio" === this.type) && (x.event.add(this, "propertychange._change", function(e) {
|
|
"checked" === e.originalEvent.propertyName && (this._just_changed = !0)
|
|
}), x.event.add(this, "click._change", function(e) {
|
|
this._just_changed && !e.isTrigger && (this._just_changed = !1), x.event.simulate("change", this, e, !0)
|
|
})), !1) : (x.event.add(this, "beforeactivate._change", function(e) {
|
|
var t = e.target;
|
|
Z.test(t.nodeName) && !x._data(t, "changeBubbles") && (x.event.add(t, "change._change", function(e) {
|
|
!this.parentNode || e.isSimulated || e.isTrigger || x.event.simulate("change", this.parentNode, e, !0)
|
|
}), x._data(t, "changeBubbles", !0))
|
|
}), t)
|
|
},
|
|
handle: function(e) {
|
|
var n = e.target;
|
|
return this !== n || e.isSimulated || e.isTrigger || "radio" !== n.type && "checkbox" !== n.type ? e.handleObj.handler.apply(this, arguments) : t
|
|
},
|
|
teardown: function() {
|
|
return x.event.remove(this, "._change"), !Z.test(this.nodeName)
|
|
}
|
|
}), x.support.focusinBubbles || x.each({
|
|
focus: "focusin",
|
|
blur: "focusout"
|
|
}, function(e, t) {
|
|
var n = 0,
|
|
r = function(e) {
|
|
x.event.simulate(t, e.target, x.event.fix(e), !0)
|
|
};
|
|
x.event.special[t] = {
|
|
setup: function() {
|
|
0 === n++ && a.addEventListener(e, r, !0)
|
|
},
|
|
teardown: function() {
|
|
0 === --n && a.removeEventListener(e, r, !0)
|
|
}
|
|
}
|
|
}), x.fn.extend({
|
|
on: function(e, n, r, i, o) {
|
|
var a, s;
|
|
if ("object" == typeof e) {
|
|
"string" != typeof n && (r = r || n, n = t);
|
|
for (a in e) this.on(a, n, r, e[a], o);
|
|
return this
|
|
}
|
|
if (null == r && null == i ? (i = n, r = n = t) : null == i && ("string" == typeof n ? (i = r, r = t) : (i = r, r = n, n = t)), i === !1) i = ot;
|
|
else if (!i) return this;
|
|
return 1 === o && (s = i, i = function(e) {
|
|
return x().off(e), s.apply(this, arguments)
|
|
}, i.guid = s.guid || (s.guid = x.guid++)), this.each(function() {
|
|
x.event.add(this, e, i, r, n)
|
|
})
|
|
},
|
|
one: function(e, t, n, r) {
|
|
return this.on(e, t, n, r, 1)
|
|
},
|
|
off: function(e, n, r) {
|
|
var i, o;
|
|
if (e && e.preventDefault && e.handleObj) return i = e.handleObj, x(e.delegateTarget).off(i.namespace ? i.origType + "." + i.namespace : i.origType, i.selector, i.handler), this;
|
|
if ("object" == typeof e) {
|
|
for (o in e) this.off(o, n, e[o]);
|
|
return this
|
|
}
|
|
return (n === !1 || "function" == typeof n) && (r = n, n = t), r === !1 && (r = ot), this.each(function() {
|
|
x.event.remove(this, e, r, n)
|
|
})
|
|
},
|
|
trigger: function(e, t) {
|
|
return this.each(function() {
|
|
x.event.trigger(e, t, this)
|
|
})
|
|
},
|
|
triggerHandler: function(e, n) {
|
|
var r = this[0];
|
|
return r ? x.event.trigger(e, n, r, !0) : t
|
|
}
|
|
});
|
|
var st = /^.[^:#\\[\\.,]*$/,
|
|
lt = /^(?:parents|prev(?:Until|All))/,
|
|
ut = x.expr.match.needsContext,
|
|
ct = {
|
|
children: !0,
|
|
contents: !0,
|
|
next: !0,
|
|
prev: !0
|
|
};
|
|
x.fn.extend({
|
|
find: function(e) {
|
|
var t, n = [],
|
|
r = this,
|
|
i = r.length;
|
|
if ("string" != typeof e) return this.pushStack(x(e).filter(function() {
|
|
for (t = 0; i > t; t++)
|
|
if (x.contains(r[t], this)) return !0
|
|
}));
|
|
for (t = 0; i > t; t++) x.find(e, r[t], n);
|
|
return n = this.pushStack(i > 1 ? x.unique(n) : n), n.selector = this.selector ? this.selector + " " + e : e, n
|
|
},
|
|
has: function(e) {
|
|
var t, n = x(e, this),
|
|
r = n.length;
|
|
return this.filter(function() {
|
|
for (t = 0; r > t; t++)
|
|
if (x.contains(this, n[t])) return !0
|
|
})
|
|
},
|
|
not: function(e) {
|
|
return this.pushStack(ft(this, e || [], !0))
|
|
},
|
|
filter: function(e) {
|
|
return this.pushStack(ft(this, e || [], !1))
|
|
},
|
|
is: function(e) {
|
|
return !!ft(this, "string" == typeof e && ut.test(e) ? x(e) : e || [], !1).length
|
|
},
|
|
closest: function(e, t) {
|
|
var n, r = 0,
|
|
i = this.length,
|
|
o = [],
|
|
a = ut.test(e) || "string" != typeof e ? x(e, t || this.context) : 0;
|
|
for (; i > r; r++)
|
|
for (n = this[r]; n && n !== t; n = n.parentNode)
|
|
if (11 > n.nodeType && (a ? a.index(n) > -1 : 1 === n.nodeType && x.find.matchesSelector(n, e))) {
|
|
n = o.push(n);
|
|
break
|
|
}
|
|
return this.pushStack(o.length > 1 ? x.unique(o) : o)
|
|
},
|
|
index: function(e) {
|
|
return e ? "string" == typeof e ? x.inArray(this[0], x(e)) : x.inArray(e.jquery ? e[0] : e, this) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1
|
|
},
|
|
add: function(e, t) {
|
|
var n = "string" == typeof e ? x(e, t) : x.makeArray(e && e.nodeType ? [e] : e),
|
|
r = x.merge(this.get(), n);
|
|
return this.pushStack(x.unique(r))
|
|
},
|
|
addBack: function(e) {
|
|
return this.add(null == e ? this.prevObject : this.prevObject.filter(e))
|
|
}
|
|
});
|
|
|
|
function pt(e, t) {
|
|
do e = e[t]; while (e && 1 !== e.nodeType);
|
|
return e
|
|
}
|
|
x.each({
|
|
parent: function(e) {
|
|
var t = e.parentNode;
|
|
return t && 11 !== t.nodeType ? t : null
|
|
},
|
|
parents: function(e) {
|
|
return x.dir(e, "parentNode")
|
|
},
|
|
parentsUntil: function(e, t, n) {
|
|
return x.dir(e, "parentNode", n)
|
|
},
|
|
next: function(e) {
|
|
return pt(e, "nextSibling")
|
|
},
|
|
prev: function(e) {
|
|
return pt(e, "previousSibling")
|
|
},
|
|
nextAll: function(e) {
|
|
return x.dir(e, "nextSibling")
|
|
},
|
|
prevAll: function(e) {
|
|
return x.dir(e, "previousSibling")
|
|
},
|
|
nextUntil: function(e, t, n) {
|
|
return x.dir(e, "nextSibling", n)
|
|
},
|
|
prevUntil: function(e, t, n) {
|
|
return x.dir(e, "previousSibling", n)
|
|
},
|
|
siblings: function(e) {
|
|
return x.sibling((e.parentNode || {}).firstChild, e)
|
|
},
|
|
children: function(e) {
|
|
return x.sibling(e.firstChild)
|
|
},
|
|
contents: function(e) {
|
|
return x.nodeName(e, "iframe") ? e.contentDocument || e.contentWindow.document : x.merge([], e.childNodes)
|
|
}
|
|
}, function(e, t) {
|
|
x.fn[e] = function(n, r) {
|
|
var i = x.map(this, t, n);
|
|
return "Until" !== e.slice(-5) && (r = n), r && "string" == typeof r && (i = x.filter(r, i)), this.length > 1 && (ct[e] || (i = x.unique(i)), lt.test(e) && (i = i.reverse())), this.pushStack(i)
|
|
}
|
|
}), x.extend({
|
|
filter: function(e, t, n) {
|
|
var r = t[0];
|
|
return n && (e = ":not(" + e + ")"), 1 === t.length && 1 === r.nodeType ? x.find.matchesSelector(r, e) ? [r] : [] : x.find.matches(e, x.grep(t, function(e) {
|
|
return 1 === e.nodeType
|
|
}))
|
|
},
|
|
dir: function(e, n, r) {
|
|
var i = [],
|
|
o = e[n];
|
|
while (o && 9 !== o.nodeType && (r === t || 1 !== o.nodeType || !x(o).is(r))) 1 === o.nodeType && i.push(o), o = o[n];
|
|
return i
|
|
},
|
|
sibling: function(e, t) {
|
|
var n = [];
|
|
for (; e; e = e.nextSibling) 1 === e.nodeType && e !== t && n.push(e);
|
|
return n
|
|
}
|
|
});
|
|
|
|
function ft(e, t, n) {
|
|
if (x.isFunction(t)) return x.grep(e, function(e, r) {
|
|
return !!t.call(e, r, e) !== n
|
|
});
|
|
if (t.nodeType) return x.grep(e, function(e) {
|
|
return e === t !== n
|
|
});
|
|
if ("string" == typeof t) {
|
|
if (st.test(t)) return x.filter(t, e, n);
|
|
t = x.filter(t, e)
|
|
}
|
|
return x.grep(e, function(e) {
|
|
return x.inArray(e, t) >= 0 !== n
|
|
})
|
|
}
|
|
|
|
function dt(e) {
|
|
var t = ht.split("|"),
|
|
n = e.createDocumentFragment();
|
|
if (n.createElement)
|
|
while (t.length) n.createElement(t.pop());
|
|
return n
|
|
}
|
|
var ht = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",
|
|
gt = / jQuery\\d+="(?:null|\\d+)"/g,
|
|
mt = RegExp("<(?:" + ht + ")[\\\\s/>]", "i"),
|
|
yt = /^\\s+/,
|
|
vt = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\\w:]+)[^>]*)\\/>/gi,
|
|
bt = /<([\\w:]+)/,
|
|
xt = /<tbody/i,
|
|
wt = /<|&#?\\w+;/,
|
|
Tt = /<(?:script|style|link)/i,
|
|
Ct = /^(?:checkbox|radio)$/i,
|
|
Nt = /checked\\s*(?:[^=]|=\\s*.checked.)/i,
|
|
kt = /^$|\\/(?:java|ecma)script/i,
|
|
Et = /^true\\/(.*)/,
|
|
St = /^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g,
|
|
At = {
|
|
option: [1, "<select multiple=\'multiple\'>", "</select>"],
|
|
legend: [1, "<fieldset>", "</fieldset>"],
|
|
area: [1, "<map>", "</map>"],
|
|
param: [1, "<object>", "</object>"],
|
|
thead: [1, "<table>", "</table>"],
|
|
tr: [2, "<table><tbody>", "</tbody></table>"],
|
|
col: [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"],
|
|
td: [3, "<table><tbody><tr>", "</tr></tbody></table>"],
|
|
_default: x.support.htmlSerialize ? [0, "", ""] : [1, "X<div>", "</div>"]
|
|
},
|
|
jt = dt(a),
|
|
Dt = jt.appendChild(a.createElement("div"));
|
|
At.optgroup = At.option, At.tbody = At.tfoot = At.colgroup = At.caption = At.thead, At.th = At.td, x.fn.extend({
|
|
text: function(e) {
|
|
return x.access(this, function(e) {
|
|
return e === t ? x.text(this) : this.empty().append((this[0] && this[0].ownerDocument || a).createTextNode(e))
|
|
}, null, e, arguments.length)
|
|
},
|
|
append: function() {
|
|
return this.domManip(arguments, function(e) {
|
|
if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
|
|
var t = Lt(this, e);
|
|
t.appendChild(e)
|
|
}
|
|
})
|
|
},
|
|
prepend: function() {
|
|
return this.domManip(arguments, function(e) {
|
|
if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
|
|
var t = Lt(this, e);
|
|
t.insertBefore(e, t.firstChild)
|
|
}
|
|
})
|
|
},
|
|
before: function() {
|
|
return this.domManip(arguments, function(e) {
|
|
this.parentNode && this.parentNode.insertBefore(e, this)
|
|
})
|
|
},
|
|
after: function() {
|
|
return this.domManip(arguments, function(e) {
|
|
this.parentNode && this.parentNode.insertBefore(e, this.nextSibling)
|
|
})
|
|
},
|
|
remove: function(e, t) {
|
|
var n, r = e ? x.filter(e, this) : this,
|
|
i = 0;
|
|
for (; null != (n = r[i]); i++) t || 1 !== n.nodeType || x.cleanData(Ft(n)), n.parentNode && (t && x.contains(n.ownerDocument, n) && _t(Ft(n, "script")), n.parentNode.removeChild(n));
|
|
return this
|
|
},
|
|
empty: function() {
|
|
var e, t = 0;
|
|
for (; null != (e = this[t]); t++) {
|
|
1 === e.nodeType && x.cleanData(Ft(e, !1));
|
|
while (e.firstChild) e.removeChild(e.firstChild);
|
|
e.options && x.nodeName(e, "select") && (e.options.length = 0)
|
|
}
|
|
return this
|
|
},
|
|
clone: function(e, t) {
|
|
return e = null == e ? !1 : e, t = null == t ? e : t, this.map(function() {
|
|
return x.clone(this, e, t)
|
|
})
|
|
},
|
|
html: function(e) {
|
|
return x.access(this, function(e) {
|
|
var n = this[0] || {},
|
|
r = 0,
|
|
i = this.length;
|
|
if (e === t) return 1 === n.nodeType ? n.innerHTML.replace(gt, "") : t;
|
|
if (!("string" != typeof e || Tt.test(e) || !x.support.htmlSerialize && mt.test(e) || !x.support.leadingWhitespace && yt.test(e) || At[(bt.exec(e) || ["", ""])[1].toLowerCase()])) {
|
|
e = e.replace(vt, "<$1></$2>");
|
|
try {
|
|
for (; i > r; r++) n = this[r] || {}, 1 === n.nodeType && (x.cleanData(Ft(n, !1)), n.innerHTML = e);
|
|
n = 0
|
|
} catch (o) {}
|
|
}
|
|
n && this.empty().append(e)
|
|
}, null, e, arguments.length)
|
|
},
|
|
replaceWith: function() {
|
|
var e = x.map(this, function(e) {
|
|
return [e.nextSibling, e.parentNode]
|
|
}),
|
|
t = 0;
|
|
return this.domManip(arguments, function(n) {
|
|
var r = e[t++],
|
|
i = e[t++];
|
|
i && (r && r.parentNode !== i && (r = this.nextSibling), x(this).remove(), i.insertBefore(n, r))
|
|
}, !0), t ? this : this.remove()
|
|
},
|
|
detach: function(e) {
|
|
return this.remove(e, !0)
|
|
},
|
|
domManip: function(e, t, n) {
|
|
e = d.apply([], e);
|
|
var r, i, o, a, s, l, u = 0,
|
|
c = this.length,
|
|
p = this,
|
|
f = c - 1,
|
|
h = e[0],
|
|
g = x.isFunction(h);
|
|
if (g || !(1 >= c || "string" != typeof h || x.support.checkClone) && Nt.test(h)) return this.each(function(r) {
|
|
var i = p.eq(r);
|
|
g && (e[0] = h.call(this, r, i.html())), i.domManip(e, t, n)
|
|
});
|
|
if (c && (l = x.buildFragment(e, this[0].ownerDocument, !1, !n && this), r = l.firstChild, 1 === l.childNodes.length && (l = r), r)) {
|
|
for (a = x.map(Ft(l, "script"), Ht), o = a.length; c > u; u++) i = l, u !== f && (i = x.clone(i, !0, !0), o && x.merge(a, Ft(i, "script"))), t.call(this[u], i, u);
|
|
if (o)
|
|
for (s = a[a.length - 1].ownerDocument, x.map(a, qt), u = 0; o > u; u++) i = a[u], kt.test(i.type || "") && !x._data(i, "globalEval") && x.contains(s, i) && (i.src ? x._evalUrl(i.src) : x.globalEval((i.text || i.textContent || i.innerHTML || "").replace(St, "")));
|
|
l = r = null
|
|
}
|
|
return this
|
|
}
|
|
});
|
|
|
|
function Lt(e, t) {
|
|
return x.nodeName(e, "table") && x.nodeName(1 === t.nodeType ? t : t.firstChild, "tr") ? e.getElementsByTagName("tbody")[0] || e.appendChild(e.ownerDocument.createElement("tbody")) : e
|
|
}
|
|
|
|
function Ht(e) {
|
|
return e.type = (null !== x.find.attr(e, "type")) + "/" + e.type, e
|
|
}
|
|
|
|
function qt(e) {
|
|
var t = Et.exec(e.type);
|
|
return t ? e.type = t[1] : e.removeAttribute("type"), e
|
|
}
|
|
|
|
function _t(e, t) {
|
|
var n, r = 0;
|
|
for (; null != (n = e[r]); r++) x._data(n, "globalEval", !t || x._data(t[r], "globalEval"))
|
|
}
|
|
|
|
function Mt(e, t) {
|
|
if (1 === t.nodeType && x.hasData(e)) {
|
|
var n, r, i, o = x._data(e),
|
|
a = x._data(t, o),
|
|
s = o.events;
|
|
if (s) {
|
|
delete a.handle, a.events = {};
|
|
for (n in s)
|
|
for (r = 0, i = s[n].length; i > r; r++) x.event.add(t, n, s[n][r])
|
|
}
|
|
a.data && (a.data = x.extend({}, a.data))
|
|
}
|
|
}
|
|
|
|
function Ot(e, t) {
|
|
var n, r, i;
|
|
if (1 === t.nodeType) {
|
|
if (n = t.nodeName.toLowerCase(), !x.support.noCloneEvent && t[x.expando]) {
|
|
i = x._data(t);
|
|
for (r in i.events) x.removeEvent(t, r, i.handle);
|
|
t.removeAttribute(x.expando)
|
|
}
|
|
"script" === n && t.text !== e.text ? (Ht(t).text = e.text, qt(t)) : "object" === n ? (t.parentNode && (t.outerHTML = e.outerHTML), x.support.html5Clone && e.innerHTML && !x.trim(t.innerHTML) && (t.innerHTML = e.innerHTML)) : "input" === n && Ct.test(e.type) ? (t.defaultChecked = t.checked = e.checked, t.value !== e.value && (t.value = e.value)) : "option" === n ? t.defaultSelected = t.selected = e.defaultSelected : ("input" === n || "textarea" === n) && (t.defaultValue = e.defaultValue)
|
|
}
|
|
}
|
|
x.each({
|
|
appendTo: "append",
|
|
prependTo: "prepend",
|
|
insertBefore: "before",
|
|
insertAfter: "after",
|
|
replaceAll: "replaceWith"
|
|
}, function(e, t) {
|
|
x.fn[e] = function(e) {
|
|
var n, r = 0,
|
|
i = [],
|
|
o = x(e),
|
|
a = o.length - 1;
|
|
for (; a >= r; r++) n = r === a ? this : this.clone(!0), x(o[r])[t](n), h.apply(i, n.get());
|
|
return this.pushStack(i)
|
|
}
|
|
});
|
|
|
|
function Ft(e, n) {
|
|
var r, o, a = 0,
|
|
s = typeof e.getElementsByTagName !== i ? e.getElementsByTagName(n || "*") : typeof e.querySelectorAll !== i ? e.querySelectorAll(n || "*") : t;
|
|
if (!s)
|
|
for (s = [], r = e.childNodes || e; null != (o = r[a]); a++) !n || x.nodeName(o, n) ? s.push(o) : x.merge(s, Ft(o, n));
|
|
return n === t || n && x.nodeName(e, n) ? x.merge([e], s) : s
|
|
}
|
|
|
|
function Bt(e) {
|
|
Ct.test(e.type) && (e.defaultChecked = e.checked)
|
|
}
|
|
x.extend({
|
|
clone: function(e, t, n) {
|
|
var r, i, o, a, s, l = x.contains(e.ownerDocument, e);
|
|
if (x.support.html5Clone || x.isXMLDoc(e) || !mt.test("<" + e.nodeName + ">") ? o = e.cloneNode(!0) : (Dt.innerHTML = e.outerHTML, Dt.removeChild(o = Dt.firstChild)), !(x.support.noCloneEvent && x.support.noCloneChecked || 1 !== e.nodeType && 11 !== e.nodeType || x.isXMLDoc(e)))
|
|
for (r = Ft(o), s = Ft(e), a = 0; null != (i = s[a]); ++a) r[a] && Ot(i, r[a]);
|
|
if (t)
|
|
if (n)
|
|
for (s = s || Ft(e), r = r || Ft(o), a = 0; null != (i = s[a]); a++) Mt(i, r[a]);
|
|
else Mt(e, o);
|
|
return r = Ft(o, "script"), r.length > 0 && _t(r, !l && Ft(e, "script")), r = s = i = null, o
|
|
},
|
|
buildFragment: function(e, t, n, r) {
|
|
var i, o, a, s, l, u, c, p = e.length,
|
|
f = dt(t),
|
|
d = [],
|
|
h = 0;
|
|
for (; p > h; h++)
|
|
if (o = e[h], o || 0 === o)
|
|
if ("object" === x.type(o)) x.merge(d, o.nodeType ? [o] : o);
|
|
else if (wt.test(o)) {
|
|
s = s || f.appendChild(t.createElement("div")), l = (bt.exec(o) || ["", ""])[1].toLowerCase(), c = At[l] || At._default, s.innerHTML = c[1] + o.replace(vt, "<$1></$2>") + c[2], i = c[0];
|
|
while (i--) s = s.lastChild;
|
|
if (!x.support.leadingWhitespace && yt.test(o) && d.push(t.createTextNode(yt.exec(o)[0])), !x.support.tbody) {
|
|
o = "table" !== l || xt.test(o) ? "<table>" !== c[1] || xt.test(o) ? 0 : s : s.firstChild, i = o && o.childNodes.length;
|
|
while (i--) x.nodeName(u = o.childNodes[i], "tbody") && !u.childNodes.length && o.removeChild(u)
|
|
}
|
|
x.merge(d, s.childNodes), s.textContent = "";
|
|
while (s.firstChild) s.removeChild(s.firstChild);
|
|
s = f.lastChild
|
|
} else d.push(t.createTextNode(o));
|
|
s && f.removeChild(s), x.support.appendChecked || x.grep(Ft(d, "input"), Bt), h = 0;
|
|
while (o = d[h++])
|
|
if ((!r || -1 === x.inArray(o, r)) && (a = x.contains(o.ownerDocument, o), s = Ft(f.appendChild(o), "script"), a && _t(s), n)) {
|
|
i = 0;
|
|
while (o = s[i++]) kt.test(o.type || "") && n.push(o)
|
|
}
|
|
return s = null, f
|
|
},
|
|
cleanData: function(e, t) {
|
|
var n, r, o, a, s = 0,
|
|
l = x.expando,
|
|
u = x.cache,
|
|
c = x.support.deleteExpando,
|
|
f = x.event.special;
|
|
for (; null != (n = e[s]); s++)
|
|
if ((t || x.acceptData(n)) && (o = n[l], a = o && u[o])) {
|
|
if (a.events)
|
|
for (r in a.events) f[r] ? x.event.remove(n, r) : x.removeEvent(n, r, a.handle);
|
|
u[o] && (delete u[o], c ? delete n[l] : typeof n.removeAttribute !== i ? n.removeAttribute(l) : n[l] = null, p.push(o))
|
|
}
|
|
},
|
|
_evalUrl: function(e) {
|
|
return x.ajax({
|
|
url: e,
|
|
type: "GET",
|
|
dataType: "script",
|
|
async: !1,
|
|
global: !1,
|
|
"throws": !0
|
|
})
|
|
}
|
|
}), x.fn.extend({
|
|
wrapAll: function(e) {
|
|
if (x.isFunction(e)) return this.each(function(t) {
|
|
x(this).wrapAll(e.call(this, t))
|
|
});
|
|
if (this[0]) {
|
|
var t = x(e, this[0].ownerDocument).eq(0).clone(!0);
|
|
this[0].parentNode && t.insertBefore(this[0]), t.map(function() {
|
|
var e = this;
|
|
while (e.firstChild && 1 === e.firstChild.nodeType) e = e.firstChild;
|
|
return e
|
|
}).append(this)
|
|
}
|
|
return this
|
|
},
|
|
wrapInner: function(e) {
|
|
return x.isFunction(e) ? this.each(function(t) {
|
|
x(this).wrapInner(e.call(this, t))
|
|
}) : this.each(function() {
|
|
var t = x(this),
|
|
n = t.contents();
|
|
n.length ? n.wrapAll(e) : t.append(e)
|
|
})
|
|
},
|
|
wrap: function(e) {
|
|
var t = x.isFunction(e);
|
|
return this.each(function(n) {
|
|
x(this).wrapAll(t ? e.call(this, n) : e)
|
|
})
|
|
},
|
|
unwrap: function() {
|
|
return this.parent().each(function() {
|
|
x.nodeName(this, "body") || x(this).replaceWith(this.childNodes)
|
|
}).end()
|
|
}
|
|
});
|
|
var Pt, Rt, Wt, $t = /alpha\\([^)]*\\)/i,
|
|
It = /opacity\\s*=\\s*([^)]*)/,
|
|
zt = /^(top|right|bottom|left)$/,
|
|
Xt = /^(none|table(?!-c[ea]).+)/,
|
|
Ut = /^margin/,
|
|
Vt = RegExp("^(" + w + ")(.*)$", "i"),
|
|
Yt = RegExp("^(" + w + ")(?!px)[a-z%]+$", "i"),
|
|
Jt = RegExp("^([+-])=(" + w + ")", "i"),
|
|
Gt = {
|
|
BODY: "block"
|
|
},
|
|
Qt = {
|
|
position: "absolute",
|
|
visibility: "hidden",
|
|
display: "block"
|
|
},
|
|
Kt = {
|
|
letterSpacing: 0,
|
|
fontWeight: 400
|
|
},
|
|
Zt = ["Top", "Right", "Bottom", "Left"],
|
|
en = ["Webkit", "O", "Moz", "ms"];
|
|
|
|
function tn(e, t) {
|
|
if (t in e) return t;
|
|
var n = t.charAt(0).toUpperCase() + t.slice(1),
|
|
r = t,
|
|
i = en.length;
|
|
while (i--)
|
|
if (t = en[i] + n, t in e) return t;
|
|
return r
|
|
}
|
|
|
|
function nn(e, t) {
|
|
return e = t || e, "none" === x.css(e, "display") || !x.contains(e.ownerDocument, e)
|
|
}
|
|
|
|
function rn(e, t) {
|
|
var n, r, i, o = [],
|
|
a = 0,
|
|
s = e.length;
|
|
for (; s > a; a++) r = e[a], r.style && (o[a] = x._data(r, "olddisplay"), n = r.style.display, t ? (o[a] || "none" !== n || (r.style.display = ""), "" === r.style.display && nn(r) && (o[a] = x._data(r, "olddisplay", ln(r.nodeName)))) : o[a] || (i = nn(r), (n && "none" !== n || !i) && x._data(r, "olddisplay", i ? n : x.css(r, "display"))));
|
|
for (a = 0; s > a; a++) r = e[a], r.style && (t && "none" !== r.style.display && "" !== r.style.display || (r.style.display = t ? o[a] || "" : "none"));
|
|
return e
|
|
}
|
|
x.fn.extend({
|
|
css: function(e, n) {
|
|
return x.access(this, function(e, n, r) {
|
|
var i, o, a = {},
|
|
s = 0;
|
|
if (x.isArray(n)) {
|
|
for (o = Rt(e), i = n.length; i > s; s++) a[n[s]] = x.css(e, n[s], !1, o);
|
|
return a
|
|
}
|
|
return r !== t ? x.style(e, n, r) : x.css(e, n)
|
|
}, e, n, arguments.length > 1)
|
|
},
|
|
show: function() {
|
|
return rn(this, !0)
|
|
},
|
|
hide: function() {
|
|
return rn(this)
|
|
},
|
|
toggle: function(e) {
|
|
return "boolean" == typeof e ? e ? this.show() : this.hide() : this.each(function() {
|
|
nn(this) ? x(this).show() : x(this).hide()
|
|
})
|
|
}
|
|
}), x.extend({
|
|
cssHooks: {
|
|
opacity: {
|
|
get: function(e, t) {
|
|
if (t) {
|
|
var n = Wt(e, "opacity");
|
|
return "" === n ? "1" : n
|
|
}
|
|
}
|
|
}
|
|
},
|
|
cssNumber: {
|
|
columnCount: !0,
|
|
fillOpacity: !0,
|
|
fontWeight: !0,
|
|
lineHeight: !0,
|
|
opacity: !0,
|
|
order: !0,
|
|
orphans: !0,
|
|
widows: !0,
|
|
zIndex: !0,
|
|
zoom: !0
|
|
},
|
|
cssProps: {
|
|
"float": x.support.cssFloat ? "cssFloat" : "styleFloat"
|
|
},
|
|
style: function(e, n, r, i) {
|
|
if (e && 3 !== e.nodeType && 8 !== e.nodeType && e.style) {
|
|
var o, a, s, l = x.camelCase(n),
|
|
u = e.style;
|
|
if (n = x.cssProps[l] || (x.cssProps[l] = tn(u, l)), s = x.cssHooks[n] || x.cssHooks[l], r === t) return s && "get" in s && (o = s.get(e, !1, i)) !== t ? o : u[n];
|
|
if (a = typeof r, "string" === a && (o = Jt.exec(r)) && (r = (o[1] + 1) * o[2] + parseFloat(x.css(e, n)), a = "number"), !(null == r || "number" === a && isNaN(r) || ("number" !== a || x.cssNumber[l] || (r += "px"), x.support.clearCloneStyle || "" !== r || 0 !== n.indexOf("background") || (u[n] = "inherit"), s && "set" in s && (r = s.set(e, r, i)) === t))) try {
|
|
u[n] = r
|
|
} catch (c) {}
|
|
}
|
|
},
|
|
css: function(e, n, r, i) {
|
|
var o, a, s, l = x.camelCase(n);
|
|
return n = x.cssProps[l] || (x.cssProps[l] = tn(e.style, l)), s = x.cssHooks[n] || x.cssHooks[l], s && "get" in s && (a = s.get(e, !0, r)), a === t && (a = Wt(e, n, i)), "normal" === a && n in Kt && (a = Kt[n]), "" === r || r ? (o = parseFloat(a), r === !0 || x.isNumeric(o) ? o || 0 : a) : a
|
|
}
|
|
}), e.getComputedStyle ? (Rt = function(t) {
|
|
return e.getComputedStyle(t, null)
|
|
}, Wt = function(e, n, r) {
|
|
var i, o, a, s = r || Rt(e),
|
|
l = s ? s.getPropertyValue(n) || s[n] : t,
|
|
u = e.style;
|
|
return s && ("" !== l || x.contains(e.ownerDocument, e) || (l = x.style(e, n)), Yt.test(l) && Ut.test(n) && (i = u.width, o = u.minWidth, a = u.maxWidth, u.minWidth = u.maxWidth = u.width = l, l = s.width, u.width = i, u.minWidth = o, u.maxWidth = a)), l
|
|
}) : a.documentElement.currentStyle && (Rt = function(e) {
|
|
return e.currentStyle
|
|
}, Wt = function(e, n, r) {
|
|
var i, o, a, s = r || Rt(e),
|
|
l = s ? s[n] : t,
|
|
u = e.style;
|
|
return null == l && u && u[n] && (l = u[n]), Yt.test(l) && !zt.test(n) && (i = u.left, o = e.runtimeStyle, a = o && o.left, a && (o.left = e.currentStyle.left), u.left = "fontSize" === n ? "1em" : l, l = u.pixelLeft + "px", u.left = i, a && (o.left = a)), "" === l ? "auto" : l
|
|
});
|
|
|
|
function on(e, t, n) {
|
|
var r = Vt.exec(t);
|
|
return r ? Math.max(0, r[1] - (n || 0)) + (r[2] || "px") : t
|
|
}
|
|
|
|
function an(e, t, n, r, i) {
|
|
var o = n === (r ? "border" : "content") ? 4 : "width" === t ? 1 : 0,
|
|
a = 0;
|
|
for (; 4 > o; o += 2) "margin" === n && (a += x.css(e, n + Zt[o], !0, i)), r ? ("content" === n && (a -= x.css(e, "padding" + Zt[o], !0, i)), "margin" !== n && (a -= x.css(e, "border" + Zt[o] + "Width", !0, i))) : (a += x.css(e, "padding" + Zt[o], !0, i), "padding" !== n && (a += x.css(e, "border" + Zt[o] + "Width", !0, i)));
|
|
return a
|
|
}
|
|
|
|
function sn(e, t, n) {
|
|
var r = !0,
|
|
i = "width" === t ? e.offsetWidth : e.offsetHeight,
|
|
o = Rt(e),
|
|
a = x.support.boxSizing && "border-box" === x.css(e, "boxSizing", !1, o);
|
|
if (0 >= i || null == i) {
|
|
if (i = Wt(e, t, o), (0 > i || null == i) && (i = e.style[t]), Yt.test(i)) return i;
|
|
r = a && (x.support.boxSizingReliable || i === e.style[t]), i = parseFloat(i) || 0
|
|
}
|
|
return i + an(e, t, n || (a ? "border" : "content"), r, o) + "px"
|
|
}
|
|
|
|
function ln(e) {
|
|
var t = a,
|
|
n = Gt[e];
|
|
return n || (n = un(e, t), "none" !== n && n || (Pt = (Pt || x("<iframe frameborder=\'0\' width=\'0\' height=\'0\'/>").css("cssText", "display:block !important")).appendTo(t.documentElement), t = (Pt[0].contentWindow || Pt[0].contentDocument).document, t.write("<!doctype html><html><body>"), t.close(), n = un(e, t), Pt.detach()), Gt[e] = n), n
|
|
}
|
|
|
|
function un(e, t) {
|
|
var n = x(t.createElement(e)).appendTo(t.body),
|
|
r = x.css(n[0], "display");
|
|
return n.remove(), r
|
|
}
|
|
x.each(["height", "width"], function(e, n) {
|
|
x.cssHooks[n] = {
|
|
get: function(e, r, i) {
|
|
return r ? 0 === e.offsetWidth && Xt.test(x.css(e, "display")) ? x.swap(e, Qt, function() {
|
|
return sn(e, n, i)
|
|
}) : sn(e, n, i) : t
|
|
},
|
|
set: function(e, t, r) {
|
|
var i = r && Rt(e);
|
|
return on(e, t, r ? an(e, n, r, x.support.boxSizing && "border-box" === x.css(e, "boxSizing", !1, i), i) : 0)
|
|
}
|
|
}
|
|
}), x.support.opacity || (x.cssHooks.opacity = {
|
|
get: function(e, t) {
|
|
return It.test((t && e.currentStyle ? e.currentStyle.filter : e.style.filter) || "") ? .01 * parseFloat(RegExp.$1) + "" : t ? "1" : ""
|
|
},
|
|
set: function(e, t) {
|
|
var n = e.style,
|
|
r = e.currentStyle,
|
|
i = x.isNumeric(t) ? "alpha(opacity=" + 100 * t + ")" : "",
|
|
o = r && r.filter || n.filter || "";
|
|
n.zoom = 1, (t >= 1 || "" === t) && "" === x.trim(o.replace($t, "")) && n.removeAttribute && (n.removeAttribute("filter"), "" === t || r && !r.filter) || (n.filter = $t.test(o) ? o.replace($t, i) : o + " " + i)
|
|
}
|
|
}), x(function() {
|
|
x.support.reliableMarginRight || (x.cssHooks.marginRight = {
|
|
get: function(e, n) {
|
|
return n ? x.swap(e, {
|
|
display: "inline-block"
|
|
}, Wt, [e, "marginRight"]) : t
|
|
}
|
|
}), !x.support.pixelPosition && x.fn.position && x.each(["top", "left"], function(e, n) {
|
|
x.cssHooks[n] = {
|
|
get: function(e, r) {
|
|
return r ? (r = Wt(e, n), Yt.test(r) ? x(e).position()[n] + "px" : r) : t
|
|
}
|
|
}
|
|
})
|
|
}), x.expr && x.expr.filters && (x.expr.filters.hidden = function(e) {
|
|
return 0 >= e.offsetWidth && 0 >= e.offsetHeight || !x.support.reliableHiddenOffsets && "none" === (e.style && e.style.display || x.css(e, "display"))
|
|
}, x.expr.filters.visible = function(e) {
|
|
return !x.expr.filters.hidden(e)
|
|
}), x.each({
|
|
margin: "",
|
|
padding: "",
|
|
border: "Width"
|
|
}, function(e, t) {
|
|
x.cssHooks[e + t] = {
|
|
expand: function(n) {
|
|
var r = 0,
|
|
i = {},
|
|
o = "string" == typeof n ? n.split(" ") : [n];
|
|
for (; 4 > r; r++) i[e + Zt[r] + t] = o[r] || o[r - 2] || o[0];
|
|
return i
|
|
}
|
|
}, Ut.test(e) || (x.cssHooks[e + t].set = on)
|
|
});
|
|
var cn = /%20/g,
|
|
pn = /\\[\\]$/,
|
|
fn = /\\r?\
|
|
/g,
|
|
dn = /^(?:submit|button|image|reset|file)$/i,
|
|
hn = /^(?:input|select|textarea|keygen)/i;
|
|
x.fn.extend({
|
|
serialize: function() {
|
|
return x.param(this.serializeArray())
|
|
},
|
|
serializeArray: function() {
|
|
return this.map(function() {
|
|
var e = x.prop(this, "elements");
|
|
return e ? x.makeArray(e) : this
|
|
}).filter(function() {
|
|
var e = this.type;
|
|
return this.name && !x(this).is(":disabled") && hn.test(this.nodeName) && !dn.test(e) && (this.checked || !Ct.test(e))
|
|
}).map(function(e, t) {
|
|
var n = x(this).val();
|
|
return null == n ? null : x.isArray(n) ? x.map(n, function(e) {
|
|
return {
|
|
name: t.name,
|
|
value: e.replace(fn, "\\r\
|
|
")
|
|
}
|
|
}) : {
|
|
name: t.name,
|
|
value: n.replace(fn, "\\r\
|
|
")
|
|
}
|
|
}).get()
|
|
}
|
|
}), x.param = function(e, n) {
|
|
var r, i = [],
|
|
o = function(e, t) {
|
|
t = x.isFunction(t) ? t() : null == t ? "" : t, i[i.length] = encodeURIComponent(e) + "=" + encodeURIComponent(t)
|
|
};
|
|
if (n === t && (n = x.ajaxSettings && x.ajaxSettings.traditional), x.isArray(e) || e.jquery && !x.isPlainObject(e)) x.each(e, function() {
|
|
o(this.name, this.value)
|
|
});
|
|
else
|
|
for (r in e) gn(r, e[r], n, o);
|
|
return i.join("&").replace(cn, "+")
|
|
};
|
|
|
|
function gn(e, t, n, r) {
|
|
var i;
|
|
if (x.isArray(t)) x.each(t, function(t, i) {
|
|
n || pn.test(e) ? r(e, i) : gn(e + "[" + ("object" == typeof i ? t : "") + "]", i, n, r)
|
|
});
|
|
else if (n || "object" !== x.type(t)) r(e, t);
|
|
else
|
|
for (i in t) gn(e + "[" + i + "]", t[i], n, r)
|
|
}
|
|
x.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "), function(e, t) {
|
|
x.fn[t] = function(e, n) {
|
|
return arguments.length > 0 ? this.on(t, null, e, n) : this.trigger(t)
|
|
}
|
|
}), x.fn.extend({
|
|
hover: function(e, t) {
|
|
return this.mouseenter(e).mouseleave(t || e)
|
|
},
|
|
bind: function(e, t, n) {
|
|
return this.on(e, null, t, n)
|
|
},
|
|
unbind: function(e, t) {
|
|
return this.off(e, null, t)
|
|
},
|
|
delegate: function(e, t, n, r) {
|
|
return this.on(t, e, n, r)
|
|
},
|
|
undelegate: function(e, t, n) {
|
|
return 1 === arguments.length ? this.off(e, "**") : this.off(t, e || "**", n)
|
|
}
|
|
});
|
|
var mn, yn, vn = x.now(),
|
|
bn = /\\?/,
|
|
xn = /#.*$/,
|
|
wn = /([?&])_=[^&]*/,
|
|
Tn = /^(.*?):[ \\t]*([^\\r\
|
|
]*)\\r?$/gm,
|
|
Cn = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,
|
|
Nn = /^(?:GET|HEAD)$/,
|
|
kn = /^\\/\\//,
|
|
En = /^([\\w.+-]+:)(?:\\/\\/([^\\/?#:]*)(?::(\\d+)|)|)/,
|
|
Sn = x.fn.load,
|
|
An = {},
|
|
jn = {},
|
|
Dn = "*/".concat("*");
|
|
try {
|
|
yn = o.href
|
|
} catch (Ln) {
|
|
yn = a.createElement("a"), yn.href = "", yn = yn.href
|
|
}
|
|
mn = En.exec(yn.toLowerCase()) || [];
|
|
|
|
function Hn(e) {
|
|
return function(t, n) {
|
|
"string" != typeof t && (n = t, t = "*");
|
|
var r, i = 0,
|
|
o = t.toLowerCase().match(T) || [];
|
|
if (x.isFunction(n))
|
|
while (r = o[i++]) "+" === r[0] ? (r = r.slice(1) || "*", (e[r] = e[r] || []).unshift(n)) : (e[r] = e[r] || []).push(n)
|
|
}
|
|
}
|
|
|
|
function qn(e, n, r, i) {
|
|
var o = {},
|
|
a = e === jn;
|
|
|
|
function s(l) {
|
|
var u;
|
|
return o[l] = !0, x.each(e[l] || [], function(e, l) {
|
|
var c = l(n, r, i);
|
|
return "string" != typeof c || a || o[c] ? a ? !(u = c) : t : (n.dataTypes.unshift(c), s(c), !1)
|
|
}), u
|
|
}
|
|
return s(n.dataTypes[0]) || !o["*"] && s("*")
|
|
}
|
|
|
|
function _n(e, n) {
|
|
var r, i, o = x.ajaxSettings.flatOptions || {};
|
|
for (i in n) n[i] !== t && ((o[i] ? e : r || (r = {}))[i] = n[i]);
|
|
return r && x.extend(!0, e, r), e
|
|
}
|
|
x.fn.load = function(e, n, r) {
|
|
if ("string" != typeof e && Sn) return Sn.apply(this, arguments);
|
|
var i, o, a, s = this,
|
|
l = e.indexOf(" ");
|
|
return l >= 0 && (i = e.slice(l, e.length), e = e.slice(0, l)), x.isFunction(n) ? (r = n, n = t) : n && "object" == typeof n && (a = "POST"), s.length > 0 && x.ajax({
|
|
url: e,
|
|
type: a,
|
|
dataType: "html",
|
|
data: n
|
|
}).done(function(e) {
|
|
o = arguments, s.html(i ? x("<div>").append(x.parseHTML(e)).find(i) : e)
|
|
}).complete(r && function(e, t) {
|
|
s.each(r, o || [e.responseText, t, e])
|
|
}), this
|
|
}, x.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"], function(e, t) {
|
|
x.fn[t] = function(e) {
|
|
return this.on(t, e)
|
|
}
|
|
}), x.extend({
|
|
active: 0,
|
|
lastModified: {},
|
|
etag: {},
|
|
ajaxSettings: {
|
|
url: yn,
|
|
type: "GET",
|
|
isLocal: Cn.test(mn[1]),
|
|
global: !0,
|
|
processData: !0,
|
|
async: !0,
|
|
contentType: "application/x-www-form-urlencoded; charset=UTF-8",
|
|
accepts: {
|
|
"*": Dn,
|
|
text: "text/plain",
|
|
html: "text/html",
|
|
xml: "application/xml, text/xml",
|
|
json: "application/json, text/javascript"
|
|
},
|
|
contents: {
|
|
xml: /xml/,
|
|
html: /html/,
|
|
json: /json/
|
|
},
|
|
responseFields: {
|
|
xml: "responseXML",
|
|
text: "responseText",
|
|
json: "responseJSON"
|
|
},
|
|
converters: {
|
|
"* text": String,
|
|
"text html": !0,
|
|
"text json": x.parseJSON,
|
|
"text xml": x.parseXML
|
|
},
|
|
flatOptions: {
|
|
url: !0,
|
|
context: !0
|
|
}
|
|
},
|
|
ajaxSetup: function(e, t) {
|
|
return t ? _n(_n(e, x.ajaxSettings), t) : _n(x.ajaxSettings, e)
|
|
},
|
|
ajaxPrefilter: Hn(An),
|
|
ajaxTransport: Hn(jn),
|
|
ajax: function(e, n) {
|
|
"object" == typeof e && (n = e, e = t), n = n || {};
|
|
var r, i, o, a, s, l, u, c, p = x.ajaxSetup({}, n),
|
|
f = p.context || p,
|
|
d = p.context && (f.nodeType || f.jquery) ? x(f) : x.event,
|
|
h = x.Deferred(),
|
|
g = x.Callbacks("once memory"),
|
|
m = p.statusCode || {},
|
|
y = {},
|
|
v = {},
|
|
b = 0,
|
|
w = "canceled",
|
|
C = {
|
|
readyState: 0,
|
|
getResponseHeader: function(e) {
|
|
var t;
|
|
if (2 === b) {
|
|
if (!c) {
|
|
c = {};
|
|
while (t = Tn.exec(a)) c[t[1].toLowerCase()] = t[2]
|
|
}
|
|
t = c[e.toLowerCase()]
|
|
}
|
|
return null == t ? null : t
|
|
},
|
|
getAllResponseHeaders: function() {
|
|
return 2 === b ? a : null
|
|
},
|
|
setRequestHeader: function(e, t) {
|
|
var n = e.toLowerCase();
|
|
return b || (e = v[n] = v[n] || e, y[e] = t), this
|
|
},
|
|
overrideMimeType: function(e) {
|
|
return b || (p.mimeType = e), this
|
|
},
|
|
statusCode: function(e) {
|
|
var t;
|
|
if (e)
|
|
if (2 > b)
|
|
for (t in e) m[t] = [m[t], e[t]];
|
|
else C.always(e[C.status]);
|
|
return this
|
|
},
|
|
abort: function(e) {
|
|
var t = e || w;
|
|
return u && u.abort(t), k(0, t), this
|
|
}
|
|
};
|
|
if (h.promise(C).complete = g.add, C.success = C.done, C.error = C.fail, p.url = ((e || p.url || yn) + "").replace(xn, "").replace(kn, mn[1] + "//"), p.type = n.method || n.type || p.method || p.type, p.dataTypes = x.trim(p.dataType || "*").toLowerCase().match(T) || [""], null == p.crossDomain && (r = En.exec(p.url.toLowerCase()), p.crossDomain = !(!r || r[1] === mn[1] && r[2] === mn[2] && (r[3] || ("http:" === r[1] ? "80" : "443")) === (mn[3] || ("http:" === mn[1] ? "80" : "443")))), p.data && p.processData && "string" != typeof p.data && (p.data = x.param(p.data, p.traditional)), qn(An, p, n, C), 2 === b) return C;
|
|
l = p.global, l && 0 === x.active++ && x.event.trigger("ajaxStart"), p.type = p.type.toUpperCase(), p.hasContent = !Nn.test(p.type), o = p.url, p.hasContent || (p.data && (o = p.url += (bn.test(o) ? "&" : "?") + p.data, delete p.data), p.cache === !1 && (p.url = wn.test(o) ? o.replace(wn, "$1_=" + vn++) : o + (bn.test(o) ? "&" : "?") + "_=" + vn++)), p.ifModified && (x.lastModified[o] && C.setRequestHeader("If-Modified-Since", x.lastModified[o]), x.etag[o] && C.setRequestHeader("If-None-Match", x.etag[o])), (p.data && p.hasContent && p.contentType !== !1 || n.contentType) && C.setRequestHeader("Content-Type", p.contentType), C.setRequestHeader("Accept", p.dataTypes[0] && p.accepts[p.dataTypes[0]] ? p.accepts[p.dataTypes[0]] + ("*" !== p.dataTypes[0] ? ", " + Dn + "; q=0.01" : "") : p.accepts["*"]);
|
|
for (i in p.headers) C.setRequestHeader(i, p.headers[i]);
|
|
if (p.beforeSend && (p.beforeSend.call(f, C, p) === !1 || 2 === b)) return C.abort();
|
|
w = "abort";
|
|
for (i in {
|
|
success: 1,
|
|
error: 1,
|
|
complete: 1
|
|
}) C[i](p[i]);
|
|
if (u = qn(jn, p, n, C)) {
|
|
C.readyState = 1, l && d.trigger("ajaxSend", [C, p]), p.async && p.timeout > 0 && (s = setTimeout(function() {
|
|
C.abort("timeout")
|
|
}, p.timeout));
|
|
try {
|
|
b = 1, u.send(y, k)
|
|
} catch (N) {
|
|
if (!(2 > b)) throw N;
|
|
k(-1, N)
|
|
}
|
|
} else k(-1, "No Transport");
|
|
|
|
function k(e, n, r, i) {
|
|
var c, y, v, w, T, N = n;
|
|
2 !== b && (b = 2, s && clearTimeout(s), u = t, a = i || "", C.readyState = e > 0 ? 4 : 0, c = e >= 200 && 300 > e || 304 === e, r && (w = Mn(p, C, r)), w = On(p, w, C, c), c ? (p.ifModified && (T = C.getResponseHeader("Last-Modified"), T && (x.lastModified[o] = T), T = C.getResponseHeader("etag"), T && (x.etag[o] = T)), 204 === e || "HEAD" === p.type ? N = "nocontent" : 304 === e ? N = "notmodified" : (N = w.state, y = w.data, v = w.error, c = !v)) : (v = N, (e || !N) && (N = "error", 0 > e && (e = 0))), C.status = e, C.statusText = (n || N) + "", c ? h.resolveWith(f, [y, N, C]) : h.rejectWith(f, [C, N, v]), C.statusCode(m), m = t, l && d.trigger(c ? "ajaxSuccess" : "ajaxError", [C, p, c ? y : v]), g.fireWith(f, [C, N]), l && (d.trigger("ajaxComplete", [C, p]), --x.active || x.event.trigger("ajaxStop")))
|
|
}
|
|
return C
|
|
},
|
|
getJSON: function(e, t, n) {
|
|
return x.get(e, t, n, "json")
|
|
},
|
|
getScript: function(e, n) {
|
|
return x.get(e, t, n, "script")
|
|
}
|
|
}), x.each(["get", "post"], function(e, n) {
|
|
x[n] = function(e, r, i, o) {
|
|
return x.isFunction(r) && (o = o || i, i = r, r = t), x.ajax({
|
|
url: e,
|
|
type: n,
|
|
dataType: o,
|
|
data: r,
|
|
success: i
|
|
})
|
|
}
|
|
});
|
|
|
|
function Mn(e, n, r) {
|
|
var i, o, a, s, l = e.contents,
|
|
u = e.dataTypes;
|
|
while ("*" === u[0]) u.shift(), o === t && (o = e.mimeType || n.getResponseHeader("Content-Type"));
|
|
if (o)
|
|
for (s in l)
|
|
if (l[s] && l[s].test(o)) {
|
|
u.unshift(s);
|
|
break
|
|
}
|
|
if (u[0] in r) a = u[0];
|
|
else {
|
|
for (s in r) {
|
|
if (!u[0] || e.converters[s + " " + u[0]]) {
|
|
a = s;
|
|
break
|
|
}
|
|
i || (i = s)
|
|
}
|
|
a = a || i
|
|
}
|
|
return a ? (a !== u[0] && u.unshift(a), r[a]) : t
|
|
}
|
|
|
|
function On(e, t, n, r) {
|
|
var i, o, a, s, l, u = {},
|
|
c = e.dataTypes.slice();
|
|
if (c[1])
|
|
for (a in e.converters) u[a.toLowerCase()] = e.converters[a];
|
|
o = c.shift();
|
|
while (o)
|
|
if (e.responseFields[o] && (n[e.responseFields[o]] = t), !l && r && e.dataFilter && (t = e.dataFilter(t, e.dataType)), l = o, o = c.shift())
|
|
if ("*" === o) o = l;
|
|
else if ("*" !== l && l !== o) {
|
|
if (a = u[l + " " + o] || u["* " + o], !a)
|
|
for (i in u)
|
|
if (s = i.split(" "), s[1] === o && (a = u[l + " " + s[0]] || u["* " + s[0]])) {
|
|
a === !0 ? a = u[i] : u[i] !== !0 && (o = s[0], c.unshift(s[1]));
|
|
break
|
|
}
|
|
if (a !== !0)
|
|
if (a && e["throws"]) t = a(t);
|
|
else try {
|
|
t = a(t)
|
|
} catch (p) {
|
|
return {
|
|
state: "parsererror",
|
|
error: a ? p : "No conversion from " + l + " to " + o
|
|
}
|
|
}
|
|
}
|
|
return {
|
|
state: "success",
|
|
data: t
|
|
}
|
|
}
|
|
x.ajaxSetup({
|
|
accepts: {
|
|
script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"
|
|
},
|
|
contents: {
|
|
script: /(?:java|ecma)script/
|
|
},
|
|
converters: {
|
|
"text script": function(e) {
|
|
return x.globalEval(e), e
|
|
}
|
|
}
|
|
}), x.ajaxPrefilter("script", function(e) {
|
|
e.cache === t && (e.cache = !1), e.crossDomain && (e.type = "GET", e.global = !1)
|
|
}), x.ajaxTransport("script", function(e) {
|
|
if (e.crossDomain) {
|
|
var n, r = a.head || x("head")[0] || a.documentElement;
|
|
return {
|
|
send: function(t, i) {
|
|
n = a.createElement("script"), n.async = !0, e.scriptCharset && (n.charset = e.scriptCharset), n.src = e.url, n.onload = n.onreadystatechange = function(e, t) {
|
|
(t || !n.readyState || /loaded|complete/.test(n.readyState)) && (n.onload = n.onreadystatechange = null, n.parentNode && n.parentNode.removeChild(n), n = null, t || i(200, "success"))
|
|
}, r.insertBefore(n, r.firstChild)
|
|
},
|
|
abort: function() {
|
|
n && n.onload(t, !0)
|
|
}
|
|
}
|
|
}
|
|
});
|
|
var Fn = [],
|
|
Bn = /(=)\\?(?=&|$)|\\?\\?/;
|
|
x.ajaxSetup({
|
|
jsonp: "callback",
|
|
jsonpCallback: function() {
|
|
var e = Fn.pop() || x.expando + "_" + vn++;
|
|
return this[e] = !0, e
|
|
}
|
|
}), x.ajaxPrefilter("json jsonp", function(n, r, i) {
|
|
var o, a, s, l = n.jsonp !== !1 && (Bn.test(n.url) ? "url" : "string" == typeof n.data && !(n.contentType || "").indexOf("application/x-www-form-urlencoded") && Bn.test(n.data) && "data");
|
|
return l || "jsonp" === n.dataTypes[0] ? (o = n.jsonpCallback = x.isFunction(n.jsonpCallback) ? n.jsonpCallback() : n.jsonpCallback, l ? n[l] = n[l].replace(Bn, "$1" + o) : n.jsonp !== !1 && (n.url += (bn.test(n.url) ? "&" : "?") + n.jsonp + "=" + o), n.converters["script json"] = function() {
|
|
return s || x.error(o + " was not called"), s[0]
|
|
}, n.dataTypes[0] = "json", a = e[o], e[o] = function() {
|
|
s = arguments
|
|
}, i.always(function() {
|
|
e[o] = a, n[o] && (n.jsonpCallback = r.jsonpCallback, Fn.push(o)), s && x.isFunction(a) && a(s[0]), s = a = t
|
|
}), "script") : t
|
|
});
|
|
var Pn, Rn, Wn = 0,
|
|
$n = e.ActiveXObject && function() {
|
|
var e;
|
|
for (e in Pn) Pn[e](t, !0)
|
|
};
|
|
|
|
function In() {
|
|
try {
|
|
return new e.XMLHttpRequest
|
|
} catch (t) {}
|
|
}
|
|
|
|
function zn() {
|
|
try {
|
|
return new e.ActiveXObject("Microsoft.XMLHTTP")
|
|
} catch (t) {}
|
|
}
|
|
x.ajaxSettings.xhr = e.ActiveXObject ? function() {
|
|
return !this.isLocal && In() || zn()
|
|
} : In, Rn = x.ajaxSettings.xhr(), x.support.cors = !!Rn && "withCredentials" in Rn, Rn = x.support.ajax = !!Rn, Rn && x.ajaxTransport(function(n) {
|
|
if (!n.crossDomain || x.support.cors) {
|
|
var r;
|
|
return {
|
|
send: function(i, o) {
|
|
var a, s, l = n.xhr();
|
|
if (n.username ? l.open(n.type, n.url, n.async, n.username, n.password) : l.open(n.type, n.url, n.async), n.xhrFields)
|
|
for (s in n.xhrFields) l[s] = n.xhrFields[s];
|
|
n.mimeType && l.overrideMimeType && l.overrideMimeType(n.mimeType), n.crossDomain || i["X-Requested-With"] || (i["X-Requested-With"] = "XMLHttpRequest");
|
|
try {
|
|
for (s in i) l.setRequestHeader(s, i[s])
|
|
} catch (u) {}
|
|
l.send(n.hasContent && n.data || null), r = function(e, i) {
|
|
var s, u, c, p;
|
|
try {
|
|
if (r && (i || 4 === l.readyState))
|
|
if (r = t, a && (l.onreadystatechange = x.noop, $n && delete Pn[a]), i) 4 !== l.readyState && l.abort();
|
|
else {
|
|
p = {}, s = l.status, u = l.getAllResponseHeaders(), "string" == typeof l.responseText && (p.text = l.responseText);
|
|
try {
|
|
c = l.statusText
|
|
} catch (f) {
|
|
c = ""
|
|
}
|
|
s || !n.isLocal || n.crossDomain ? 1223 === s && (s = 204) : s = p.text ? 200 : 404
|
|
}
|
|
} catch (d) {
|
|
i || o(-1, d)
|
|
}
|
|
p && o(s, c, p, u)
|
|
}, n.async ? 4 === l.readyState ? setTimeout(r) : (a = ++Wn, $n && (Pn || (Pn = {}, x(e).unload($n)), Pn[a] = r), l.onreadystatechange = r) : r()
|
|
},
|
|
abort: function() {
|
|
r && r(t, !0)
|
|
}
|
|
}
|
|
}
|
|
});
|
|
var Xn, Un, Vn = /^(?:toggle|show|hide)$/,
|
|
Yn = RegExp("^(?:([+-])=|)(" + w + ")([a-z%]*)$", "i"),
|
|
Jn = /queueHooks$/,
|
|
Gn = [nr],
|
|
Qn = {
|
|
"*": [function(e, t) {
|
|
var n = this.createTween(e, t),
|
|
r = n.cur(),
|
|
i = Yn.exec(t),
|
|
o = i && i[3] || (x.cssNumber[e] ? "" : "px"),
|
|
a = (x.cssNumber[e] || "px" !== o && +r) && Yn.exec(x.css(n.elem, e)),
|
|
s = 1,
|
|
l = 20;
|
|
if (a && a[3] !== o) {
|
|
o = o || a[3], i = i || [], a = +r || 1;
|
|
do s = s || ".5", a /= s, x.style(n.elem, e, a + o); while (s !== (s = n.cur() / r) && 1 !== s && --l)
|
|
}
|
|
return i && (a = n.start = +a || +r || 0, n.unit = o, n.end = i[1] ? a + (i[1] + 1) * i[2] : +i[2]), n
|
|
}]
|
|
};
|
|
|
|
function Kn() {
|
|
return setTimeout(function() {
|
|
Xn = t
|
|
}), Xn = x.now()
|
|
}
|
|
|
|
function Zn(e, t, n) {
|
|
var r, i = (Qn[t] || []).concat(Qn["*"]),
|
|
o = 0,
|
|
a = i.length;
|
|
for (; a > o; o++)
|
|
if (r = i[o].call(n, t, e)) return r
|
|
}
|
|
|
|
function er(e, t, n) {
|
|
var r, i, o = 0,
|
|
a = Gn.length,
|
|
s = x.Deferred().always(function() {
|
|
delete l.elem
|
|
}),
|
|
l = function() {
|
|
if (i) return !1;
|
|
var t = Xn || Kn(),
|
|
n = Math.max(0, u.startTime + u.duration - t),
|
|
r = n / u.duration || 0,
|
|
o = 1 - r,
|
|
a = 0,
|
|
l = u.tweens.length;
|
|
for (; l > a; a++) u.tweens[a].run(o);
|
|
return s.notifyWith(e, [u, o, n]), 1 > o && l ? n : (s.resolveWith(e, [u]), !1)
|
|
},
|
|
u = s.promise({
|
|
elem: e,
|
|
props: x.extend({}, t),
|
|
opts: x.extend(!0, {
|
|
specialEasing: {}
|
|
}, n),
|
|
originalProperties: t,
|
|
originalOptions: n,
|
|
startTime: Xn || Kn(),
|
|
duration: n.duration,
|
|
tweens: [],
|
|
createTween: function(t, n) {
|
|
var r = x.Tween(e, u.opts, t, n, u.opts.specialEasing[t] || u.opts.easing);
|
|
return u.tweens.push(r), r
|
|
},
|
|
stop: function(t) {
|
|
var n = 0,
|
|
r = t ? u.tweens.length : 0;
|
|
if (i) return this;
|
|
for (i = !0; r > n; n++) u.tweens[n].run(1);
|
|
return t ? s.resolveWith(e, [u, t]) : s.rejectWith(e, [u, t]), this
|
|
}
|
|
}),
|
|
c = u.props;
|
|
for (tr(c, u.opts.specialEasing); a > o; o++)
|
|
if (r = Gn[o].call(u, e, c, u.opts)) return r;
|
|
return x.map(c, Zn, u), x.isFunction(u.opts.start) && u.opts.start.call(e, u), x.fx.timer(x.extend(l, {
|
|
elem: e,
|
|
anim: u,
|
|
queue: u.opts.queue
|
|
})), u.progress(u.opts.progress).done(u.opts.done, u.opts.complete).fail(u.opts.fail).always(u.opts.always)
|
|
}
|
|
|
|
function tr(e, t) {
|
|
var n, r, i, o, a;
|
|
for (n in e)
|
|
if (r = x.camelCase(n), i = t[r], o = e[n], x.isArray(o) && (i = o[1], o = e[n] = o[0]), n !== r && (e[r] = o, delete e[n]), a = x.cssHooks[r], a && "expand" in a) {
|
|
o = a.expand(o), delete e[r];
|
|
for (n in o) n in e || (e[n] = o[n], t[n] = i)
|
|
} else t[r] = i
|
|
}
|
|
x.Animation = x.extend(er, {
|
|
tweener: function(e, t) {
|
|
x.isFunction(e) ? (t = e, e = ["*"]) : e = e.split(" ");
|
|
var n, r = 0,
|
|
i = e.length;
|
|
for (; i > r; r++) n = e[r], Qn[n] = Qn[n] || [], Qn[n].unshift(t)
|
|
},
|
|
prefilter: function(e, t) {
|
|
t ? Gn.unshift(e) : Gn.push(e)
|
|
}
|
|
});
|
|
|
|
function nr(e, t, n) {
|
|
var r, i, o, a, s, l, u = this,
|
|
c = {},
|
|
p = e.style,
|
|
f = e.nodeType && nn(e),
|
|
d = x._data(e, "fxshow");
|
|
n.queue || (s = x._queueHooks(e, "fx"), null == s.unqueued && (s.unqueued = 0, l = s.empty.fire, s.empty.fire = function() {
|
|
s.unqueued || l()
|
|
}), s.unqueued++, u.always(function() {
|
|
u.always(function() {
|
|
s.unqueued--, x.queue(e, "fx").length || s.empty.fire()
|
|
})
|
|
})), 1 === e.nodeType && ("height" in t || "width" in t) && (n.overflow = [p.overflow, p.overflowX, p.overflowY], "inline" === x.css(e, "display") && "none" === x.css(e, "float") && (x.support.inlineBlockNeedsLayout && "inline" !== ln(e.nodeName) ? p.zoom = 1 : p.display = "inline-block")), n.overflow && (p.overflow = "hidden", x.support.shrinkWrapBlocks || u.always(function() {
|
|
p.overflow = n.overflow[0], p.overflowX = n.overflow[1], p.overflowY = n.overflow[2]
|
|
}));
|
|
for (r in t)
|
|
if (i = t[r], Vn.exec(i)) {
|
|
if (delete t[r], o = o || "toggle" === i, i === (f ? "hide" : "show")) continue;
|
|
c[r] = d && d[r] || x.style(e, r)
|
|
}
|
|
if (!x.isEmptyObject(c)) {
|
|
d ? "hidden" in d && (f = d.hidden) : d = x._data(e, "fxshow", {}), o && (d.hidden = !f), f ? x(e).show() : u.done(function() {
|
|
x(e).hide()
|
|
}), u.done(function() {
|
|
var t;
|
|
x._removeData(e, "fxshow");
|
|
for (t in c) x.style(e, t, c[t])
|
|
});
|
|
for (r in c) a = Zn(f ? d[r] : 0, r, u), r in d || (d[r] = a.start, f && (a.end = a.start, a.start = "width" === r || "height" === r ? 1 : 0))
|
|
}
|
|
}
|
|
|
|
function rr(e, t, n, r, i) {
|
|
return new rr.prototype.init(e, t, n, r, i)
|
|
}
|
|
x.Tween = rr, rr.prototype = {
|
|
constructor: rr,
|
|
init: function(e, t, n, r, i, o) {
|
|
this.elem = e, this.prop = n, this.easing = i || "swing", this.options = t, this.start = this.now = this.cur(), this.end = r, this.unit = o || (x.cssNumber[n] ? "" : "px")
|
|
},
|
|
cur: function() {
|
|
var e = rr.propHooks[this.prop];
|
|
return e && e.get ? e.get(this) : rr.propHooks._default.get(this)
|
|
},
|
|
run: function(e) {
|
|
var t, n = rr.propHooks[this.prop];
|
|
return this.pos = t = this.options.duration ? x.easing[this.easing](e, this.options.duration * e, 0, 1, this.options.duration) : e, this.now = (this.end - this.start) * t + this.start, this.options.step && this.options.step.call(this.elem, this.now, this), n && n.set ? n.set(this) : rr.propHooks._default.set(this), this
|
|
}
|
|
}, rr.prototype.init.prototype = rr.prototype, rr.propHooks = {
|
|
_default: {
|
|
get: function(e) {
|
|
var t;
|
|
return null == e.elem[e.prop] || e.elem.style && null != e.elem.style[e.prop] ? (t = x.css(e.elem, e.prop, ""), t && "auto" !== t ? t : 0) : e.elem[e.prop]
|
|
},
|
|
set: function(e) {
|
|
x.fx.step[e.prop] ? x.fx.step[e.prop](e) : e.elem.style && (null != e.elem.style[x.cssProps[e.prop]] || x.cssHooks[e.prop]) ? x.style(e.elem, e.prop, e.now + e.unit) : e.elem[e.prop] = e.now
|
|
}
|
|
}
|
|
}, rr.propHooks.scrollTop = rr.propHooks.scrollLeft = {
|
|
set: function(e) {
|
|
e.elem.nodeType && e.elem.parentNode && (e.elem[e.prop] = e.now)
|
|
}
|
|
}, x.each(["toggle", "show", "hide"], function(e, t) {
|
|
var n = x.fn[t];
|
|
x.fn[t] = function(e, r, i) {
|
|
return null == e || "boolean" == typeof e ? n.apply(this, arguments) : this.animate(ir(t, !0), e, r, i)
|
|
}
|
|
}), x.fn.extend({
|
|
fadeTo: function(e, t, n, r) {
|
|
return this.filter(nn).css("opacity", 0).show().end().animate({
|
|
opacity: t
|
|
}, e, n, r)
|
|
},
|
|
animate: function(e, t, n, r) {
|
|
var i = x.isEmptyObject(e),
|
|
o = x.speed(t, n, r),
|
|
a = function() {
|
|
var t = er(this, x.extend({}, e), o);
|
|
(i || x._data(this, "finish")) && t.stop(!0)
|
|
};
|
|
return a.finish = a, i || o.queue === !1 ? this.each(a) : this.queue(o.queue, a)
|
|
},
|
|
stop: function(e, n, r) {
|
|
var i = function(e) {
|
|
var t = e.stop;
|
|
delete e.stop, t(r)
|
|
};
|
|
return "string" != typeof e && (r = n, n = e, e = t), n && e !== !1 && this.queue(e || "fx", []), this.each(function() {
|
|
var t = !0,
|
|
n = null != e && e + "queueHooks",
|
|
o = x.timers,
|
|
a = x._data(this);
|
|
if (n) a[n] && a[n].stop && i(a[n]);
|
|
else
|
|
for (n in a) a[n] && a[n].stop && Jn.test(n) && i(a[n]);
|
|
for (n = o.length; n--;) o[n].elem !== this || null != e && o[n].queue !== e || (o[n].anim.stop(r), t = !1, o.splice(n, 1));
|
|
(t || !r) && x.dequeue(this, e)
|
|
})
|
|
},
|
|
finish: function(e) {
|
|
return e !== !1 && (e = e || "fx"), this.each(function() {
|
|
var t, n = x._data(this),
|
|
r = n[e + "queue"],
|
|
i = n[e + "queueHooks"],
|
|
o = x.timers,
|
|
a = r ? r.length : 0;
|
|
for (n.finish = !0, x.queue(this, e, []), i && i.stop && i.stop.call(this, !0), t = o.length; t--;) o[t].elem === this && o[t].queue === e && (o[t].anim.stop(!0), o.splice(t, 1));
|
|
for (t = 0; a > t; t++) r[t] && r[t].finish && r[t].finish.call(this);
|
|
delete n.finish
|
|
})
|
|
}
|
|
});
|
|
|
|
function ir(e, t) {
|
|
var n, r = {
|
|
height: e
|
|
},
|
|
i = 0;
|
|
for (t = t ? 1 : 0; 4 > i; i += 2 - t) n = Zt[i], r["margin" + n] = r["padding" + n] = e;
|
|
return t && (r.opacity = r.width = e), r
|
|
}
|
|
x.each({
|
|
slideDown: ir("show"),
|
|
slideUp: ir("hide"),
|
|
slideToggle: ir("toggle"),
|
|
fadeIn: {
|
|
opacity: "show"
|
|
},
|
|
fadeOut: {
|
|
opacity: "hide"
|
|
},
|
|
fadeToggle: {
|
|
opacity: "toggle"
|
|
}
|
|
}, function(e, t) {
|
|
x.fn[e] = function(e, n, r) {
|
|
return this.animate(t, e, n, r)
|
|
}
|
|
}), x.speed = function(e, t, n) {
|
|
var r = e && "object" == typeof e ? x.extend({}, e) : {
|
|
complete: n || !n && t || x.isFunction(e) && e,
|
|
duration: e,
|
|
easing: n && t || t && !x.isFunction(t) && t
|
|
};
|
|
return r.duration = x.fx.off ? 0 : "number" == typeof r.duration ? r.duration : r.duration in x.fx.speeds ? x.fx.speeds[r.duration] : x.fx.speeds._default, (null == r.queue || r.queue === !0) && (r.queue = "fx"), r.old = r.complete, r.complete = function() {
|
|
x.isFunction(r.old) && r.old.call(this), r.queue && x.dequeue(this, r.queue)
|
|
}, r
|
|
}, x.easing = {
|
|
linear: function(e) {
|
|
return e
|
|
},
|
|
swing: function(e) {
|
|
return .5 - Math.cos(e * Math.PI) / 2
|
|
}
|
|
}, x.timers = [], x.fx = rr.prototype.init, x.fx.tick = function() {
|
|
var e, n = x.timers,
|
|
r = 0;
|
|
for (Xn = x.now(); n.length > r; r++) e = n[r], e() || n[r] !== e || n.splice(r--, 1);
|
|
n.length || x.fx.stop(), Xn = t
|
|
}, x.fx.timer = function(e) {
|
|
e() && x.timers.push(e) && x.fx.start()
|
|
}, x.fx.interval = 13, x.fx.start = function() {
|
|
Un || (Un = setInterval(x.fx.tick, x.fx.interval))
|
|
}, x.fx.stop = function() {
|
|
clearInterval(Un), Un = null
|
|
}, x.fx.speeds = {
|
|
slow: 600,
|
|
fast: 200,
|
|
_default: 400
|
|
}, x.fx.step = {}, x.expr && x.expr.filters && (x.expr.filters.animated = function(e) {
|
|
return x.grep(x.timers, function(t) {
|
|
return e === t.elem
|
|
}).length
|
|
}), x.fn.offset = function(e) {
|
|
if (arguments.length) return e === t ? this : this.each(function(t) {
|
|
x.offset.setOffset(this, e, t)
|
|
});
|
|
var n, r, o = {
|
|
top: 0,
|
|
left: 0
|
|
},
|
|
a = this[0],
|
|
s = a && a.ownerDocument;
|
|
if (s) return n = s.documentElement, x.contains(n, a) ? (typeof a.getBoundingClientRect !== i && (o = a.getBoundingClientRect()), r = or(s), {
|
|
top: o.top + (r.pageYOffset || n.scrollTop) - (n.clientTop || 0),
|
|
left: o.left + (r.pageXOffset || n.scrollLeft) - (n.clientLeft || 0)
|
|
}) : o
|
|
}, x.offset = {
|
|
setOffset: function(e, t, n) {
|
|
var r = x.css(e, "position");
|
|
"static" === r && (e.style.position = "relative");
|
|
var i = x(e),
|
|
o = i.offset(),
|
|
a = x.css(e, "top"),
|
|
s = x.css(e, "left"),
|
|
l = ("absolute" === r || "fixed" === r) && x.inArray("auto", [a, s]) > -1,
|
|
u = {},
|
|
c = {},
|
|
p, f;
|
|
l ? (c = i.position(), p = c.top, f = c.left) : (p = parseFloat(a) || 0, f = parseFloat(s) || 0), x.isFunction(t) && (t = t.call(e, n, o)), null != t.top && (u.top = t.top - o.top + p), null != t.left && (u.left = t.left - o.left + f), "using" in t ? t.using.call(e, u) : i.css(u)
|
|
}
|
|
}, x.fn.extend({
|
|
position: function() {
|
|
if (this[0]) {
|
|
var e, t, n = {
|
|
top: 0,
|
|
left: 0
|
|
},
|
|
r = this[0];
|
|
return "fixed" === x.css(r, "position") ? t = r.getBoundingClientRect() : (e = this.offsetParent(), t = this.offset(), x.nodeName(e[0], "html") || (n = e.offset()), n.top += x.css(e[0], "borderTopWidth", !0), n.left += x.css(e[0], "borderLeftWidth", !0)), {
|
|
top: t.top - n.top - x.css(r, "marginTop", !0),
|
|
left: t.left - n.left - x.css(r, "marginLeft", !0)
|
|
}
|
|
}
|
|
},
|
|
offsetParent: function() {
|
|
return this.map(function() {
|
|
var e = this.offsetParent || s;
|
|
while (e && !x.nodeName(e, "html") && "static" === x.css(e, "position")) e = e.offsetParent;
|
|
return e || s
|
|
})
|
|
}
|
|
}), x.each({
|
|
scrollLeft: "pageXOffset",
|
|
scrollTop: "pageYOffset"
|
|
}, function(e, n) {
|
|
var r = /Y/.test(n);
|
|
x.fn[e] = function(i) {
|
|
return x.access(this, function(e, i, o) {
|
|
var a = or(e);
|
|
return o === t ? a ? n in a ? a[n] : a.document.documentElement[i] : e[i] : (a ? a.scrollTo(r ? x(a).scrollLeft() : o, r ? o : x(a).scrollTop()) : e[i] = o, t)
|
|
}, e, i, arguments.length, null)
|
|
}
|
|
});
|
|
|
|
function or(e) {
|
|
return x.isWindow(e) ? e : 9 === e.nodeType ? e.defaultView || e.parentWindow : !1
|
|
}
|
|
x.each({
|
|
Height: "height",
|
|
Width: "width"
|
|
}, function(e, n) {
|
|
x.each({
|
|
padding: "inner" + e,
|
|
content: n,
|
|
"": "outer" + e
|
|
}, function(r, i) {
|
|
x.fn[i] = function(i, o) {
|
|
var a = arguments.length && (r || "boolean" != typeof i),
|
|
s = r || (i === !0 || o === !0 ? "margin" : "border");
|
|
return x.access(this, function(n, r, i) {
|
|
var o;
|
|
return x.isWindow(n) ? n.document.documentElement["client" + e] : 9 === n.nodeType ? (o = n.documentElement, Math.max(n.body["scroll" + e], o["scroll" + e], n.body["offset" + e], o["offset" + e], o["client" + e])) : i === t ? x.css(n, r, s) : x.style(n, r, i, s)
|
|
}, n, a ? i : t, a, null)
|
|
}
|
|
})
|
|
}), x.fn.size = function() {
|
|
return this.length
|
|
}, x.fn.andSelf = x.fn.addBack, "object" == typeof module && module && "object" == typeof module.exports ? module.exports = x : (e.jQuery = e.$ = x, "function" == typeof define && define.amd && define("jquery", [], function() {
|
|
return x
|
|
}))
|
|
})(window);
|
|
</script>
|
|
<script>
|
|
! function() {
|
|
function n(n) {
|
|
return n && (n.ownerDocument || n.document || n).documentElement
|
|
}
|
|
|
|
function t(n) {
|
|
return n && (n.ownerDocument && n.ownerDocument.defaultView || n.document && n || n.defaultView)
|
|
}
|
|
|
|
function e(n, t) {
|
|
return t > n ? -1 : n > t ? 1 : n >= t ? 0 : NaN
|
|
}
|
|
|
|
function r(n) {
|
|
return null === n ? NaN : +n
|
|
}
|
|
|
|
function i(n) {
|
|
return !isNaN(n)
|
|
}
|
|
|
|
function u(n) {
|
|
return {
|
|
left: function(t, e, r, i) {
|
|
for (arguments.length < 3 && (r = 0), arguments.length < 4 && (i = t.length); i > r;) {
|
|
var u = r + i >>> 1;
|
|
n(t[u], e) < 0 ? r = u + 1 : i = u
|
|
}
|
|
return r
|
|
},
|
|
right: function(t, e, r, i) {
|
|
for (arguments.length < 3 && (r = 0), arguments.length < 4 && (i = t.length); i > r;) {
|
|
var u = r + i >>> 1;
|
|
n(t[u], e) > 0 ? i = u : r = u + 1
|
|
}
|
|
return r
|
|
}
|
|
}
|
|
}
|
|
|
|
function o(n) {
|
|
return n.length
|
|
}
|
|
|
|
function a(n) {
|
|
for (var t = 1; n * t % 1;) t *= 10;
|
|
return t
|
|
}
|
|
|
|
function l(n, t) {
|
|
for (var e in t) Object.defineProperty(n.prototype, e, {
|
|
value: t[e],
|
|
enumerable: !1
|
|
})
|
|
}
|
|
|
|
function c() {
|
|
this._ = Object.create(null)
|
|
}
|
|
|
|
function f(n) {
|
|
return (n += "") === bo || n[0] === _o ? _o + n : n
|
|
}
|
|
|
|
function s(n) {
|
|
return (n += "")[0] === _o ? n.slice(1) : n
|
|
}
|
|
|
|
function h(n) {
|
|
return f(n) in this._
|
|
}
|
|
|
|
function p(n) {
|
|
return (n = f(n)) in this._ && delete this._[n]
|
|
}
|
|
|
|
function g() {
|
|
var n = [];
|
|
for (var t in this._) n.push(s(t));
|
|
return n
|
|
}
|
|
|
|
function v() {
|
|
var n = 0;
|
|
for (var t in this._) ++n;
|
|
return n
|
|
}
|
|
|
|
function d() {
|
|
for (var n in this._) return !1;
|
|
return !0
|
|
}
|
|
|
|
function y() {
|
|
this._ = Object.create(null)
|
|
}
|
|
|
|
function m(n) {
|
|
return n
|
|
}
|
|
|
|
function M(n, t, e) {
|
|
return function() {
|
|
var r = e.apply(t, arguments);
|
|
return r === t ? n : r
|
|
}
|
|
}
|
|
|
|
function x(n, t) {
|
|
if (t in n) return t;
|
|
t = t.charAt(0).toUpperCase() + t.slice(1);
|
|
for (var e = 0, r = wo.length; r > e; ++e) {
|
|
var i = wo[e] + t;
|
|
if (i in n) return i
|
|
}
|
|
}
|
|
|
|
function b() {}
|
|
|
|
function _() {}
|
|
|
|
function w(n) {
|
|
function t() {
|
|
for (var t, r = e, i = -1, u = r.length; ++i < u;)(t = r[i].on) && t.apply(this, arguments);
|
|
return n
|
|
}
|
|
var e = [],
|
|
r = new c;
|
|
return t.on = function(t, i) {
|
|
var u, o = r.get(t);
|
|
return arguments.length < 2 ? o && o.on : (o && (o.on = null, e = e.slice(0, u = e.indexOf(o)).concat(e.slice(u + 1)), r.remove(t)), i && e.push(r.set(t, {
|
|
on: i
|
|
})), n)
|
|
}, t
|
|
}
|
|
|
|
function S() {
|
|
ao.event.preventDefault()
|
|
}
|
|
|
|
function k() {
|
|
for (var n, t = ao.event; n = t.sourceEvent;) t = n;
|
|
return t
|
|
}
|
|
|
|
function N(n) {
|
|
for (var t = new _, e = 0, r = arguments.length; ++e < r;) t[arguments[e]] = w(t);
|
|
return t.of = function(e, r) {
|
|
return function(i) {
|
|
try {
|
|
var u = i.sourceEvent = ao.event;
|
|
i.target = n, ao.event = i, t[i.type].apply(e, r)
|
|
} finally {
|
|
ao.event = u
|
|
}
|
|
}
|
|
}, t
|
|
}
|
|
|
|
function E(n) {
|
|
return ko(n, Co), n
|
|
}
|
|
|
|
function A(n) {
|
|
return "function" == typeof n ? n : function() {
|
|
return No(n, this)
|
|
}
|
|
}
|
|
|
|
function C(n) {
|
|
return "function" == typeof n ? n : function() {
|
|
return Eo(n, this)
|
|
}
|
|
}
|
|
|
|
function z(n, t) {
|
|
function e() {
|
|
this.removeAttribute(n)
|
|
}
|
|
|
|
function r() {
|
|
this.removeAttributeNS(n.space, n.local)
|
|
}
|
|
|
|
function i() {
|
|
this.setAttribute(n, t)
|
|
}
|
|
|
|
function u() {
|
|
this.setAttributeNS(n.space, n.local, t)
|
|
}
|
|
|
|
function o() {
|
|
var e = t.apply(this, arguments);
|
|
null == e ? this.removeAttribute(n) : this.setAttribute(n, e)
|
|
}
|
|
|
|
function a() {
|
|
var e = t.apply(this, arguments);
|
|
null == e ? this.removeAttributeNS(n.space, n.local) : this.setAttributeNS(n.space, n.local, e)
|
|
}
|
|
return n = ao.ns.qualify(n), null == t ? n.local ? r : e : "function" == typeof t ? n.local ? a : o : n.local ? u : i
|
|
}
|
|
|
|
function L(n) {
|
|
return n.trim().replace(/\\s+/g, " ")
|
|
}
|
|
|
|
function q(n) {
|
|
return new RegExp("(?:^|\\\\s+)" + ao.requote(n) + "(?:\\\\s+|$)", "g")
|
|
}
|
|
|
|
function T(n) {
|
|
return (n + "").trim().split(/^|\\s+/)
|
|
}
|
|
|
|
function R(n, t) {
|
|
function e() {
|
|
for (var e = -1; ++e < i;) n[e](this, t)
|
|
}
|
|
|
|
function r() {
|
|
for (var e = -1, r = t.apply(this, arguments); ++e < i;) n[e](this, r)
|
|
}
|
|
n = T(n).map(D);
|
|
var i = n.length;
|
|
return "function" == typeof t ? r : e
|
|
}
|
|
|
|
function D(n) {
|
|
var t = q(n);
|
|
return function(e, r) {
|
|
if (i = e.classList) return r ? i.add(n) : i.remove(n);
|
|
var i = e.getAttribute("class") || "";
|
|
r ? (t.lastIndex = 0, t.test(i) || e.setAttribute("class", L(i + " " + n))) : e.setAttribute("class", L(i.replace(t, " ")))
|
|
}
|
|
}
|
|
|
|
function P(n, t, e) {
|
|
function r() {
|
|
this.style.removeProperty(n)
|
|
}
|
|
|
|
function i() {
|
|
this.style.setProperty(n, t, e)
|
|
}
|
|
|
|
function u() {
|
|
var r = t.apply(this, arguments);
|
|
null == r ? this.style.removeProperty(n) : this.style.setProperty(n, r, e)
|
|
}
|
|
return null == t ? r : "function" == typeof t ? u : i
|
|
}
|
|
|
|
function U(n, t) {
|
|
function e() {
|
|
delete this[n]
|
|
}
|
|
|
|
function r() {
|
|
this[n] = t
|
|
}
|
|
|
|
function i() {
|
|
var e = t.apply(this, arguments);
|
|
null == e ? delete this[n] : this[n] = e
|
|
}
|
|
return null == t ? e : "function" == typeof t ? i : r
|
|
}
|
|
|
|
function j(n) {
|
|
function t() {
|
|
var t = this.ownerDocument,
|
|
e = this.namespaceURI;
|
|
return e === zo && t.documentElement.namespaceURI === zo ? t.createElement(n) : t.createElementNS(e, n)
|
|
}
|
|
|
|
function e() {
|
|
return this.ownerDocument.createElementNS(n.space, n.local)
|
|
}
|
|
return "function" == typeof n ? n : (n = ao.ns.qualify(n)).local ? e : t
|
|
}
|
|
|
|
function F() {
|
|
var n = this.parentNode;
|
|
n && n.removeChild(this)
|
|
}
|
|
|
|
function H(n) {
|
|
return {
|
|
__data__: n
|
|
}
|
|
}
|
|
|
|
function O(n) {
|
|
return function() {
|
|
return Ao(this, n)
|
|
}
|
|
}
|
|
|
|
function I(n) {
|
|
return arguments.length || (n = e),
|
|
function(t, e) {
|
|
return t && e ? n(t.__data__, e.__data__) : !t - !e
|
|
}
|
|
}
|
|
|
|
function Y(n, t) {
|
|
for (var e = 0, r = n.length; r > e; e++)
|
|
for (var i, u = n[e], o = 0, a = u.length; a > o; o++)(i = u[o]) && t(i, o, e);
|
|
return n
|
|
}
|
|
|
|
function Z(n) {
|
|
return ko(n, qo), n
|
|
}
|
|
|
|
function V(n) {
|
|
var t, e;
|
|
return function(r, i, u) {
|
|
var o, a = n[u].update,
|
|
l = a.length;
|
|
for (u != e && (e = u, t = 0), i >= t && (t = i + 1); !(o = a[t]) && ++t < l;);
|
|
return o
|
|
}
|
|
}
|
|
|
|
function X(n, t, e) {
|
|
function r() {
|
|
var t = this[o];
|
|
t && (this.removeEventListener(n, t, t.$), delete this[o])
|
|
}
|
|
|
|
function i() {
|
|
var i = l(t, co(arguments));
|
|
r.call(this), this.addEventListener(n, this[o] = i, i.$ = e), i._ = t
|
|
}
|
|
|
|
function u() {
|
|
var t, e = new RegExp("^__on([^.]+)" + ao.requote(n) + "$");
|
|
for (var r in this)
|
|
if (t = r.match(e)) {
|
|
var i = this[r];
|
|
this.removeEventListener(t[1], i, i.$), delete this[r]
|
|
}
|
|
}
|
|
var o = "__on" + n,
|
|
a = n.indexOf("."),
|
|
l = $;
|
|
a > 0 && (n = n.slice(0, a));
|
|
var c = To.get(n);
|
|
return c && (n = c, l = B), a ? t ? i : r : t ? b : u
|
|
}
|
|
|
|
function $(n, t) {
|
|
return function(e) {
|
|
var r = ao.event;
|
|
ao.event = e, t[0] = this.__data__;
|
|
try {
|
|
n.apply(this, t)
|
|
} finally {
|
|
ao.event = r
|
|
}
|
|
}
|
|
}
|
|
|
|
function B(n, t) {
|
|
var e = $(n, t);
|
|
return function(n) {
|
|
var t = this,
|
|
r = n.relatedTarget;
|
|
r && (r === t || 8 & r.compareDocumentPosition(t)) || e.call(t, n)
|
|
}
|
|
}
|
|
|
|
function W(e) {
|
|
var r = ".dragsuppress-" + ++Do,
|
|
i = "click" + r,
|
|
u = ao.select(t(e)).on("touchmove" + r, S).on("dragstart" + r, S).on("selectstart" + r, S);
|
|
if (null == Ro && (Ro = "onselectstart" in e ? !1 : x(e.style, "userSelect")), Ro) {
|
|
var o = n(e).style,
|
|
a = o[Ro];
|
|
o[Ro] = "none"
|
|
}
|
|
return function(n) {
|
|
if (u.on(r, null), Ro && (o[Ro] = a), n) {
|
|
var t = function() {
|
|
u.on(i, null)
|
|
};
|
|
u.on(i, function() {
|
|
S(), t()
|
|
}, !0), setTimeout(t, 0)
|
|
}
|
|
}
|
|
}
|
|
|
|
function J(n, e) {
|
|
e.changedTouches && (e = e.changedTouches[0]);
|
|
var r = n.ownerSVGElement || n;
|
|
if (r.createSVGPoint) {
|
|
var i = r.createSVGPoint();
|
|
if (0 > Po) {
|
|
var u = t(n);
|
|
if (u.scrollX || u.scrollY) {
|
|
r = ao.select("body").append("svg").style({
|
|
position: "absolute",
|
|
top: 0,
|
|
left: 0,
|
|
margin: 0,
|
|
padding: 0,
|
|
border: "none"
|
|
}, "important");
|
|
var o = r[0][0].getScreenCTM();
|
|
Po = !(o.f || o.e), r.remove()
|
|
}
|
|
}
|
|
return Po ? (i.x = e.pageX, i.y = e.pageY) : (i.x = e.clientX, i.y = e.clientY), i = i.matrixTransform(n.getScreenCTM().inverse()), [i.x, i.y]
|
|
}
|
|
var a = n.getBoundingClientRect();
|
|
return [e.clientX - a.left - n.clientLeft, e.clientY - a.top - n.clientTop]
|
|
}
|
|
|
|
function G() {
|
|
return ao.event.changedTouches[0].identifier
|
|
}
|
|
|
|
function K(n) {
|
|
return n > 0 ? 1 : 0 > n ? -1 : 0
|
|
}
|
|
|
|
function Q(n, t, e) {
|
|
return (t[0] - n[0]) * (e[1] - n[1]) - (t[1] - n[1]) * (e[0] - n[0])
|
|
}
|
|
|
|
function nn(n) {
|
|
return n > 1 ? 0 : -1 > n ? Fo : Math.acos(n)
|
|
}
|
|
|
|
function tn(n) {
|
|
return n > 1 ? Io : -1 > n ? -Io : Math.asin(n)
|
|
}
|
|
|
|
function en(n) {
|
|
return ((n = Math.exp(n)) - 1 / n) / 2
|
|
}
|
|
|
|
function rn(n) {
|
|
return ((n = Math.exp(n)) + 1 / n) / 2
|
|
}
|
|
|
|
function un(n) {
|
|
return ((n = Math.exp(2 * n)) - 1) / (n + 1)
|
|
}
|
|
|
|
function on(n) {
|
|
return (n = Math.sin(n / 2)) * n
|
|
}
|
|
|
|
function an() {}
|
|
|
|
function ln(n, t, e) {
|
|
return this instanceof ln ? (this.h = +n, this.s = +t, void(this.l = +e)) : arguments.length < 2 ? n instanceof ln ? new ln(n.h, n.s, n.l) : _n("" + n, wn, ln) : new ln(n, t, e)
|
|
}
|
|
|
|
function cn(n, t, e) {
|
|
function r(n) {
|
|
return n > 360 ? n -= 360 : 0 > n && (n += 360), 60 > n ? u + (o - u) * n / 60 : 180 > n ? o : 240 > n ? u + (o - u) * (240 - n) / 60 : u
|
|
}
|
|
|
|
function i(n) {
|
|
return Math.round(255 * r(n))
|
|
}
|
|
var u, o;
|
|
return n = isNaN(n) ? 0 : (n %= 360) < 0 ? n + 360 : n, t = isNaN(t) ? 0 : 0 > t ? 0 : t > 1 ? 1 : t, e = 0 > e ? 0 : e > 1 ? 1 : e, o = .5 >= e ? e * (1 + t) : e + t - e * t, u = 2 * e - o, new mn(i(n + 120), i(n), i(n - 120))
|
|
}
|
|
|
|
function fn(n, t, e) {
|
|
return this instanceof fn ? (this.h = +n, this.c = +t, void(this.l = +e)) : arguments.length < 2 ? n instanceof fn ? new fn(n.h, n.c, n.l) : n instanceof hn ? gn(n.l, n.a, n.b) : gn((n = Sn((n = ao.rgb(n)).r, n.g, n.b)).l, n.a, n.b) : new fn(n, t, e)
|
|
}
|
|
|
|
function sn(n, t, e) {
|
|
return isNaN(n) && (n = 0), isNaN(t) && (t = 0), new hn(e, Math.cos(n *= Yo) * t, Math.sin(n) * t)
|
|
}
|
|
|
|
function hn(n, t, e) {
|
|
return this instanceof hn ? (this.l = +n, this.a = +t, void(this.b = +e)) : arguments.length < 2 ? n instanceof hn ? new hn(n.l, n.a, n.b) : n instanceof fn ? sn(n.h, n.c, n.l) : Sn((n = mn(n)).r, n.g, n.b) : new hn(n, t, e)
|
|
}
|
|
|
|
function pn(n, t, e) {
|
|
var r = (n + 16) / 116,
|
|
i = r + t / 500,
|
|
u = r - e / 200;
|
|
return i = vn(i) * na, r = vn(r) * ta, u = vn(u) * ea, new mn(yn(3.2404542 * i - 1.5371385 * r - .4985314 * u), yn(-.969266 * i + 1.8760108 * r + .041556 * u), yn(.0556434 * i - .2040259 * r + 1.0572252 * u))
|
|
}
|
|
|
|
function gn(n, t, e) {
|
|
return n > 0 ? new fn(Math.atan2(e, t) * Zo, Math.sqrt(t * t + e * e), n) : new fn(NaN, NaN, n)
|
|
}
|
|
|
|
function vn(n) {
|
|
return n > .206893034 ? n * n * n : (n - 4 / 29) / 7.787037
|
|
}
|
|
|
|
function dn(n) {
|
|
return n > .008856 ? Math.pow(n, 1 / 3) : 7.787037 * n + 4 / 29
|
|
}
|
|
|
|
function yn(n) {
|
|
return Math.round(255 * (.00304 >= n ? 12.92 * n : 1.055 * Math.pow(n, 1 / 2.4) - .055))
|
|
}
|
|
|
|
function mn(n, t, e) {
|
|
return this instanceof mn ? (this.r = ~~n, this.g = ~~t, void(this.b = ~~e)) : arguments.length < 2 ? n instanceof mn ? new mn(n.r, n.g, n.b) : _n("" + n, mn, cn) : new mn(n, t, e)
|
|
}
|
|
|
|
function Mn(n) {
|
|
return new mn(n >> 16, n >> 8 & 255, 255 & n)
|
|
}
|
|
|
|
function xn(n) {
|
|
return Mn(n) + ""
|
|
}
|
|
|
|
function bn(n) {
|
|
return 16 > n ? "0" + Math.max(0, n).toString(16) : Math.min(255, n).toString(16)
|
|
}
|
|
|
|
function _n(n, t, e) {
|
|
var r, i, u, o = 0,
|
|
a = 0,
|
|
l = 0;
|
|
if (r = /([a-z]+)\\((.*)\\)/.exec(n = n.toLowerCase())) switch (i = r[2].split(","), r[1]) {
|
|
case "hsl":
|
|
return e(parseFloat(i[0]), parseFloat(i[1]) / 100, parseFloat(i[2]) / 100);
|
|
case "rgb":
|
|
return t(Nn(i[0]), Nn(i[1]), Nn(i[2]))
|
|
}
|
|
return (u = ua.get(n)) ? t(u.r, u.g, u.b) : (null == n || "#" !== n.charAt(0) || isNaN(u = parseInt(n.slice(1), 16)) || (4 === n.length ? (o = (3840 & u) >> 4, o = o >> 4 | o, a = 240 & u, a = a >> 4 | a, l = 15 & u, l = l << 4 | l) : 7 === n.length && (o = (16711680 & u) >> 16, a = (65280 & u) >> 8, l = 255 & u)), t(o, a, l))
|
|
}
|
|
|
|
function wn(n, t, e) {
|
|
var r, i, u = Math.min(n /= 255, t /= 255, e /= 255),
|
|
o = Math.max(n, t, e),
|
|
a = o - u,
|
|
l = (o + u) / 2;
|
|
return a ? (i = .5 > l ? a / (o + u) : a / (2 - o - u), r = n == o ? (t - e) / a + (e > t ? 6 : 0) : t == o ? (e - n) / a + 2 : (n - t) / a + 4, r *= 60) : (r = NaN, i = l > 0 && 1 > l ? 0 : r), new ln(r, i, l)
|
|
}
|
|
|
|
function Sn(n, t, e) {
|
|
n = kn(n), t = kn(t), e = kn(e);
|
|
var r = dn((.4124564 * n + .3575761 * t + .1804375 * e) / na),
|
|
i = dn((.2126729 * n + .7151522 * t + .072175 * e) / ta),
|
|
u = dn((.0193339 * n + .119192 * t + .9503041 * e) / ea);
|
|
return hn(116 * i - 16, 500 * (r - i), 200 * (i - u))
|
|
}
|
|
|
|
function kn(n) {
|
|
return (n /= 255) <= .04045 ? n / 12.92 : Math.pow((n + .055) / 1.055, 2.4)
|
|
}
|
|
|
|
function Nn(n) {
|
|
var t = parseFloat(n);
|
|
return "%" === n.charAt(n.length - 1) ? Math.round(2.55 * t) : t
|
|
}
|
|
|
|
function En(n) {
|
|
return "function" == typeof n ? n : function() {
|
|
return n
|
|
}
|
|
}
|
|
|
|
function An(n) {
|
|
return function(t, e, r) {
|
|
return 2 === arguments.length && "function" == typeof e && (r = e, e = null), Cn(t, e, n, r)
|
|
}
|
|
}
|
|
|
|
function Cn(n, t, e, r) {
|
|
function i() {
|
|
var n, t = l.status;
|
|
if (!t && Ln(l) || t >= 200 && 300 > t || 304 === t) {
|
|
try {
|
|
n = e.call(u, l)
|
|
} catch (r) {
|
|
return void o.error.call(u, r)
|
|
}
|
|
o.load.call(u, n)
|
|
} else o.error.call(u, l)
|
|
}
|
|
var u = {},
|
|
o = ao.dispatch("beforesend", "progress", "load", "error"),
|
|
a = {},
|
|
l = new XMLHttpRequest,
|
|
c = null;
|
|
return !this.XDomainRequest || "withCredentials" in l || !/^(http(s)?:)?\\/\\//.test(n) || (l = new XDomainRequest), "onload" in l ? l.onload = l.onerror = i : l.onreadystatechange = function() {
|
|
l.readyState > 3 && i()
|
|
}, l.onprogress = function(n) {
|
|
var t = ao.event;
|
|
ao.event = n;
|
|
try {
|
|
o.progress.call(u, l)
|
|
} finally {
|
|
ao.event = t
|
|
}
|
|
}, u.header = function(n, t) {
|
|
return n = (n + "").toLowerCase(), arguments.length < 2 ? a[n] : (null == t ? delete a[n] : a[n] = t + "", u)
|
|
}, u.mimeType = function(n) {
|
|
return arguments.length ? (t = null == n ? null : n + "", u) : t
|
|
}, u.responseType = function(n) {
|
|
return arguments.length ? (c = n, u) : c
|
|
}, u.response = function(n) {
|
|
return e = n, u
|
|
}, ["get", "post"].forEach(function(n) {
|
|
u[n] = function() {
|
|
return u.send.apply(u, [n].concat(co(arguments)))
|
|
}
|
|
}), u.send = function(e, r, i) {
|
|
if (2 === arguments.length && "function" == typeof r && (i = r, r = null), l.open(e, n, !0), null == t || "accept" in a || (a.accept = t + ",*/*"), l.setRequestHeader)
|
|
for (var f in a) l.setRequestHeader(f, a[f]);
|
|
return null != t && l.overrideMimeType && l.overrideMimeType(t), null != c && (l.responseType = c), null != i && u.on("error", i).on("load", function(n) {
|
|
i(null, n)
|
|
}), o.beforesend.call(u, l), l.send(null == r ? null : r), u
|
|
}, u.abort = function() {
|
|
return l.abort(), u
|
|
}, ao.rebind(u, o, "on"), null == r ? u : u.get(zn(r))
|
|
}
|
|
|
|
function zn(n) {
|
|
return 1 === n.length ? function(t, e) {
|
|
n(null == t ? e : null)
|
|
} : n
|
|
}
|
|
|
|
function Ln(n) {
|
|
var t = n.responseType;
|
|
return t && "text" !== t ? n.response : n.responseText
|
|
}
|
|
|
|
function qn(n, t, e) {
|
|
var r = arguments.length;
|
|
2 > r && (t = 0), 3 > r && (e = Date.now());
|
|
var i = e + t,
|
|
u = {
|
|
c: n,
|
|
t: i,
|
|
n: null
|
|
};
|
|
return aa ? aa.n = u : oa = u, aa = u, la || (ca = clearTimeout(ca), la = 1, fa(Tn)), u
|
|
}
|
|
|
|
function Tn() {
|
|
var n = Rn(),
|
|
t = Dn() - n;
|
|
t > 24 ? (isFinite(t) && (clearTimeout(ca), ca = setTimeout(Tn, t)), la = 0) : (la = 1, fa(Tn))
|
|
}
|
|
|
|
function Rn() {
|
|
for (var n = Date.now(), t = oa; t;) n >= t.t && t.c(n - t.t) && (t.c = null), t = t.n;
|
|
return n
|
|
}
|
|
|
|
function Dn() {
|
|
for (var n, t = oa, e = 1 / 0; t;) t.c ? (t.t < e && (e = t.t), t = (n = t).n) : t = n ? n.n = t.n : oa = t.n;
|
|
return aa = n, e
|
|
}
|
|
|
|
function Pn(n, t) {
|
|
return t - (n ? Math.ceil(Math.log(n) / Math.LN10) : 1)
|
|
}
|
|
|
|
function Un(n, t) {
|
|
var e = Math.pow(10, 3 * xo(8 - t));
|
|
return {
|
|
scale: t > 8 ? function(n) {
|
|
return n / e
|
|
} : function(n) {
|
|
return n * e
|
|
},
|
|
symbol: n
|
|
}
|
|
}
|
|
|
|
function jn(n) {
|
|
var t = n.decimal,
|
|
e = n.thousands,
|
|
r = n.grouping,
|
|
i = n.currency,
|
|
u = r && e ? function(n, t) {
|
|
for (var i = n.length, u = [], o = 0, a = r[0], l = 0; i > 0 && a > 0 && (l + a + 1 > t && (a = Math.max(1, t - l)), u.push(n.substring(i -= a, i + a)), !((l += a + 1) > t));) a = r[o = (o + 1) % r.length];
|
|
return u.reverse().join(e)
|
|
} : m;
|
|
return function(n) {
|
|
var e = ha.exec(n),
|
|
r = e[1] || " ",
|
|
o = e[2] || ">",
|
|
a = e[3] || "-",
|
|
l = e[4] || "",
|
|
c = e[5],
|
|
f = +e[6],
|
|
s = e[7],
|
|
h = e[8],
|
|
p = e[9],
|
|
g = 1,
|
|
v = "",
|
|
d = "",
|
|
y = !1,
|
|
m = !0;
|
|
switch (h && (h = +h.substring(1)), (c || "0" === r && "=" === o) && (c = r = "0", o = "="), p) {
|
|
case "n":
|
|
s = !0, p = "g";
|
|
break;
|
|
case "%":
|
|
g = 100, d = "%", p = "f";
|
|
break;
|
|
case "p":
|
|
g = 100, d = "%", p = "r";
|
|
break;
|
|
case "b":
|
|
case "o":
|
|
case "x":
|
|
case "X":
|
|
"#" === l && (v = "0" + p.toLowerCase());
|
|
case "c":
|
|
m = !1;
|
|
case "d":
|
|
y = !0, h = 0;
|
|
break;
|
|
case "s":
|
|
g = -1, p = "r"
|
|
}
|
|
"$" === l && (v = i[0], d = i[1]), "r" != p || h || (p = "g"), null != h && ("g" == p ? h = Math.max(1, Math.min(21, h)) : "e" != p && "f" != p || (h = Math.max(0, Math.min(20, h)))), p = pa.get(p) || Fn;
|
|
var M = c && s;
|
|
return function(n) {
|
|
var e = d;
|
|
if (y && n % 1) return "";
|
|
var i = 0 > n || 0 === n && 0 > 1 / n ? (n = -n, "-") : "-" === a ? "" : a;
|
|
if (0 > g) {
|
|
var l = ao.formatPrefix(n, h);
|
|
n = l.scale(n), e = l.symbol + d
|
|
} else n *= g;
|
|
n = p(n, h);
|
|
var x, b, _ = n.lastIndexOf(".");
|
|
if (0 > _) {
|
|
var w = m ? n.lastIndexOf("e") : -1;
|
|
0 > w ? (x = n, b = "") : (x = n.substring(0, w), b = n.substring(w))
|
|
} else x = n.substring(0, _), b = t + n.substring(_ + 1);
|
|
!c && s && (x = u(x, 1 / 0));
|
|
var S = v.length + x.length + b.length + (M ? 0 : i.length),
|
|
k = f > S ? new Array(S = f - S + 1).join(r) : "";
|
|
return M && (x = u(k + x, k.length ? f - b.length : 1 / 0)), i += v, n = x + b, ("<" === o ? i + n + k : ">" === o ? k + i + n : "^" === o ? k.substring(0, S >>= 1) + i + n + k.substring(S) : i + (M ? n : k + n)) + e
|
|
}
|
|
}
|
|
}
|
|
|
|
function Fn(n) {
|
|
return n + ""
|
|
}
|
|
|
|
function Hn() {
|
|
this._ = new Date(arguments.length > 1 ? Date.UTC.apply(this, arguments) : arguments[0])
|
|
}
|
|
|
|
function On(n, t, e) {
|
|
function r(t) {
|
|
var e = n(t),
|
|
r = u(e, 1);
|
|
return r - t > t - e ? e : r
|
|
}
|
|
|
|
function i(e) {
|
|
return t(e = n(new va(e - 1)), 1), e
|
|
}
|
|
|
|
function u(n, e) {
|
|
return t(n = new va(+n), e), n
|
|
}
|
|
|
|
function o(n, r, u) {
|
|
var o = i(n),
|
|
a = [];
|
|
if (u > 1)
|
|
for (; r > o;) e(o) % u || a.push(new Date(+o)), t(o, 1);
|
|
else
|
|
for (; r > o;) a.push(new Date(+o)), t(o, 1);
|
|
return a
|
|
}
|
|
|
|
function a(n, t, e) {
|
|
try {
|
|
va = Hn;
|
|
var r = new Hn;
|
|
return r._ = n, o(r, t, e)
|
|
} finally {
|
|
va = Date
|
|
}
|
|
}
|
|
n.floor = n, n.round = r, n.ceil = i, n.offset = u, n.range = o;
|
|
var l = n.utc = In(n);
|
|
return l.floor = l, l.round = In(r), l.ceil = In(i), l.offset = In(u), l.range = a, n
|
|
}
|
|
|
|
function In(n) {
|
|
return function(t, e) {
|
|
try {
|
|
va = Hn;
|
|
var r = new Hn;
|
|
return r._ = t, n(r, e)._
|
|
} finally {
|
|
va = Date
|
|
}
|
|
}
|
|
}
|
|
|
|
function Yn(n) {
|
|
function t(n) {
|
|
function t(t) {
|
|
for (var e, i, u, o = [], a = -1, l = 0; ++a < r;) 37 === n.charCodeAt(a) && (o.push(n.slice(l, a)), null != (i = ya[e = n.charAt(++a)]) && (e = n.charAt(++a)), (u = A[e]) && (e = u(t, null == i ? "e" === e ? " " : "0" : i)), o.push(e), l = a + 1);
|
|
return o.push(n.slice(l, a)), o.join("")
|
|
}
|
|
var r = n.length;
|
|
return t.parse = function(t) {
|
|
var r = {
|
|
y: 1900,
|
|
m: 0,
|
|
d: 1,
|
|
H: 0,
|
|
M: 0,
|
|
S: 0,
|
|
L: 0,
|
|
Z: null
|
|
},
|
|
i = e(r, n, t, 0);
|
|
if (i != t.length) return null;
|
|
"p" in r && (r.H = r.H % 12 + 12 * r.p);
|
|
var u = null != r.Z && va !== Hn,
|
|
o = new(u ? Hn : va);
|
|
return "j" in r ? o.setFullYear(r.y, 0, r.j) : "W" in r || "U" in r ? ("w" in r || (r.w = "W" in r ? 1 : 0), o.setFullYear(r.y, 0, 1), o.setFullYear(r.y, 0, "W" in r ? (r.w + 6) % 7 + 7 * r.W - (o.getDay() + 5) % 7 : r.w + 7 * r.U - (o.getDay() + 6) % 7)) : o.setFullYear(r.y, r.m, r.d), o.setHours(r.H + (r.Z / 100 | 0), r.M + r.Z % 100, r.S, r.L), u ? o._ : o
|
|
}, t.toString = function() {
|
|
return n
|
|
}, t
|
|
}
|
|
|
|
function e(n, t, e, r) {
|
|
for (var i, u, o, a = 0, l = t.length, c = e.length; l > a;) {
|
|
if (r >= c) return -1;
|
|
if (i = t.charCodeAt(a++), 37 === i) {
|
|
if (o = t.charAt(a++), u = C[o in ya ? t.charAt(a++) : o], !u || (r = u(n, e, r)) < 0) return -1
|
|
} else if (i != e.charCodeAt(r++)) return -1
|
|
}
|
|
return r
|
|
}
|
|
|
|
function r(n, t, e) {
|
|
_.lastIndex = 0;
|
|
var r = _.exec(t.slice(e));
|
|
return r ? (n.w = w.get(r[0].toLowerCase()), e + r[0].length) : -1
|
|
}
|
|
|
|
function i(n, t, e) {
|
|
x.lastIndex = 0;
|
|
var r = x.exec(t.slice(e));
|
|
return r ? (n.w = b.get(r[0].toLowerCase()), e + r[0].length) : -1
|
|
}
|
|
|
|
function u(n, t, e) {
|
|
N.lastIndex = 0;
|
|
var r = N.exec(t.slice(e));
|
|
return r ? (n.m = E.get(r[0].toLowerCase()), e + r[0].length) : -1
|
|
}
|
|
|
|
function o(n, t, e) {
|
|
S.lastIndex = 0;
|
|
var r = S.exec(t.slice(e));
|
|
return r ? (n.m = k.get(r[0].toLowerCase()), e + r[0].length) : -1
|
|
}
|
|
|
|
function a(n, t, r) {
|
|
return e(n, A.c.toString(), t, r)
|
|
}
|
|
|
|
function l(n, t, r) {
|
|
return e(n, A.x.toString(), t, r)
|
|
}
|
|
|
|
function c(n, t, r) {
|
|
return e(n, A.X.toString(), t, r)
|
|
}
|
|
|
|
function f(n, t, e) {
|
|
var r = M.get(t.slice(e, e += 2).toLowerCase());
|
|
return null == r ? -1 : (n.p = r, e)
|
|
}
|
|
var s = n.dateTime,
|
|
h = n.date,
|
|
p = n.time,
|
|
g = n.periods,
|
|
v = n.days,
|
|
d = n.shortDays,
|
|
y = n.months,
|
|
m = n.shortMonths;
|
|
t.utc = function(n) {
|
|
function e(n) {
|
|
try {
|
|
va = Hn;
|
|
var t = new va;
|
|
return t._ = n, r(t)
|
|
} finally {
|
|
va = Date
|
|
}
|
|
}
|
|
var r = t(n);
|
|
return e.parse = function(n) {
|
|
try {
|
|
va = Hn;
|
|
var t = r.parse(n);
|
|
return t && t._
|
|
} finally {
|
|
va = Date
|
|
}
|
|
}, e.toString = r.toString, e
|
|
}, t.multi = t.utc.multi = ct;
|
|
var M = ao.map(),
|
|
x = Vn(v),
|
|
b = Xn(v),
|
|
_ = Vn(d),
|
|
w = Xn(d),
|
|
S = Vn(y),
|
|
k = Xn(y),
|
|
N = Vn(m),
|
|
E = Xn(m);
|
|
g.forEach(function(n, t) {
|
|
M.set(n.toLowerCase(), t)
|
|
});
|
|
var A = {
|
|
a: function(n) {
|
|
return d[n.getDay()]
|
|
},
|
|
A: function(n) {
|
|
return v[n.getDay()]
|
|
},
|
|
b: function(n) {
|
|
return m[n.getMonth()]
|
|
},
|
|
B: function(n) {
|
|
return y[n.getMonth()]
|
|
},
|
|
c: t(s),
|
|
d: function(n, t) {
|
|
return Zn(n.getDate(), t, 2)
|
|
},
|
|
e: function(n, t) {
|
|
return Zn(n.getDate(), t, 2)
|
|
},
|
|
H: function(n, t) {
|
|
return Zn(n.getHours(), t, 2)
|
|
},
|
|
I: function(n, t) {
|
|
return Zn(n.getHours() % 12 || 12, t, 2)
|
|
},
|
|
j: function(n, t) {
|
|
return Zn(1 + ga.dayOfYear(n), t, 3)
|
|
},
|
|
L: function(n, t) {
|
|
return Zn(n.getMilliseconds(), t, 3)
|
|
},
|
|
m: function(n, t) {
|
|
return Zn(n.getMonth() + 1, t, 2)
|
|
},
|
|
M: function(n, t) {
|
|
return Zn(n.getMinutes(), t, 2)
|
|
},
|
|
p: function(n) {
|
|
return g[+(n.getHours() >= 12)]
|
|
},
|
|
S: function(n, t) {
|
|
return Zn(n.getSeconds(), t, 2)
|
|
},
|
|
U: function(n, t) {
|
|
return Zn(ga.sundayOfYear(n), t, 2)
|
|
},
|
|
w: function(n) {
|
|
return n.getDay()
|
|
},
|
|
W: function(n, t) {
|
|
return Zn(ga.mondayOfYear(n), t, 2)
|
|
},
|
|
x: t(h),
|
|
X: t(p),
|
|
y: function(n, t) {
|
|
return Zn(n.getFullYear() % 100, t, 2)
|
|
},
|
|
Y: function(n, t) {
|
|
return Zn(n.getFullYear() % 1e4, t, 4)
|
|
},
|
|
Z: at,
|
|
"%": function() {
|
|
return "%"
|
|
}
|
|
},
|
|
C = {
|
|
a: r,
|
|
A: i,
|
|
b: u,
|
|
B: o,
|
|
c: a,
|
|
d: tt,
|
|
e: tt,
|
|
H: rt,
|
|
I: rt,
|
|
j: et,
|
|
L: ot,
|
|
m: nt,
|
|
M: it,
|
|
p: f,
|
|
S: ut,
|
|
U: Bn,
|
|
w: $n,
|
|
W: Wn,
|
|
x: l,
|
|
X: c,
|
|
y: Gn,
|
|
Y: Jn,
|
|
Z: Kn,
|
|
"%": lt
|
|
};
|
|
return t
|
|
}
|
|
|
|
function Zn(n, t, e) {
|
|
var r = 0 > n ? "-" : "",
|
|
i = (r ? -n : n) + "",
|
|
u = i.length;
|
|
return r + (e > u ? new Array(e - u + 1).join(t) + i : i)
|
|
}
|
|
|
|
function Vn(n) {
|
|
return new RegExp("^(?:" + n.map(ao.requote).join("|") + ")", "i")
|
|
}
|
|
|
|
function Xn(n) {
|
|
for (var t = new c, e = -1, r = n.length; ++e < r;) t.set(n[e].toLowerCase(), e);
|
|
return t
|
|
}
|
|
|
|
function $n(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 1));
|
|
return r ? (n.w = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function Bn(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e));
|
|
return r ? (n.U = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function Wn(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e));
|
|
return r ? (n.W = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function Jn(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 4));
|
|
return r ? (n.y = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function Gn(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 2));
|
|
return r ? (n.y = Qn(+r[0]), e + r[0].length) : -1
|
|
}
|
|
|
|
function Kn(n, t, e) {
|
|
return /^[+-]\\d{4}$/.test(t = t.slice(e, e + 5)) ? (n.Z = -t, e + 5) : -1
|
|
}
|
|
|
|
function Qn(n) {
|
|
return n + (n > 68 ? 1900 : 2e3)
|
|
}
|
|
|
|
function nt(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 2));
|
|
return r ? (n.m = r[0] - 1, e + r[0].length) : -1
|
|
}
|
|
|
|
function tt(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 2));
|
|
return r ? (n.d = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function et(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 3));
|
|
return r ? (n.j = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function rt(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 2));
|
|
return r ? (n.H = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function it(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 2));
|
|
return r ? (n.M = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function ut(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 2));
|
|
return r ? (n.S = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function ot(n, t, e) {
|
|
ma.lastIndex = 0;
|
|
var r = ma.exec(t.slice(e, e + 3));
|
|
return r ? (n.L = +r[0], e + r[0].length) : -1
|
|
}
|
|
|
|
function at(n) {
|
|
var t = n.getTimezoneOffset(),
|
|
e = t > 0 ? "-" : "+",
|
|
r = xo(t) / 60 | 0,
|
|
i = xo(t) % 60;
|
|
return e + Zn(r, "0", 2) + Zn(i, "0", 2)
|
|
}
|
|
|
|
function lt(n, t, e) {
|
|
Ma.lastIndex = 0;
|
|
var r = Ma.exec(t.slice(e, e + 1));
|
|
return r ? e + r[0].length : -1
|
|
}
|
|
|
|
function ct(n) {
|
|
for (var t = n.length, e = -1; ++e < t;) n[e][0] = this(n[e][0]);
|
|
return function(t) {
|
|
for (var e = 0, r = n[e]; !r[1](t);) r = n[++e];
|
|
return r[0](t)
|
|
}
|
|
}
|
|
|
|
function ft() {}
|
|
|
|
function st(n, t, e) {
|
|
var r = e.s = n + t,
|
|
i = r - n,
|
|
u = r - i;
|
|
e.t = n - u + (t - i)
|
|
}
|
|
|
|
function ht(n, t) {
|
|
n && wa.hasOwnProperty(n.type) && wa[n.type](n, t)
|
|
}
|
|
|
|
function pt(n, t, e) {
|
|
var r, i = -1,
|
|
u = n.length - e;
|
|
for (t.lineStart(); ++i < u;) r = n[i], t.point(r[0], r[1], r[2]);
|
|
t.lineEnd()
|
|
}
|
|
|
|
function gt(n, t) {
|
|
var e = -1,
|
|
r = n.length;
|
|
for (t.polygonStart(); ++e < r;) pt(n[e], t, 1);
|
|
t.polygonEnd()
|
|
}
|
|
|
|
function vt() {
|
|
function n(n, t) {
|
|
n *= Yo, t = t * Yo / 2 + Fo / 4;
|
|
var e = n - r,
|
|
o = e >= 0 ? 1 : -1,
|
|
a = o * e,
|
|
l = Math.cos(t),
|
|
c = Math.sin(t),
|
|
f = u * c,
|
|
s = i * l + f * Math.cos(a),
|
|
h = f * o * Math.sin(a);
|
|
ka.add(Math.atan2(h, s)), r = n, i = l, u = c
|
|
}
|
|
var t, e, r, i, u;
|
|
Na.point = function(o, a) {
|
|
Na.point = n, r = (t = o) * Yo, i = Math.cos(a = (e = a) * Yo / 2 + Fo / 4), u = Math.sin(a)
|
|
}, Na.lineEnd = function() {
|
|
n(t, e)
|
|
}
|
|
}
|
|
|
|
function dt(n) {
|
|
var t = n[0],
|
|
e = n[1],
|
|
r = Math.cos(e);
|
|
return [r * Math.cos(t), r * Math.sin(t), Math.sin(e)]
|
|
}
|
|
|
|
function yt(n, t) {
|
|
return n[0] * t[0] + n[1] * t[1] + n[2] * t[2]
|
|
}
|
|
|
|
function mt(n, t) {
|
|
return [n[1] * t[2] - n[2] * t[1], n[2] * t[0] - n[0] * t[2], n[0] * t[1] - n[1] * t[0]]
|
|
}
|
|
|
|
function Mt(n, t) {
|
|
n[0] += t[0], n[1] += t[1], n[2] += t[2]
|
|
}
|
|
|
|
function xt(n, t) {
|
|
return [n[0] * t, n[1] * t, n[2] * t]
|
|
}
|
|
|
|
function bt(n) {
|
|
var t = Math.sqrt(n[0] * n[0] + n[1] * n[1] + n[2] * n[2]);
|
|
n[0] /= t, n[1] /= t, n[2] /= t
|
|
}
|
|
|
|
function _t(n) {
|
|
return [Math.atan2(n[1], n[0]), tn(n[2])]
|
|
}
|
|
|
|
function wt(n, t) {
|
|
return xo(n[0] - t[0]) < Uo && xo(n[1] - t[1]) < Uo
|
|
}
|
|
|
|
function St(n, t) {
|
|
n *= Yo;
|
|
var e = Math.cos(t *= Yo);
|
|
kt(e * Math.cos(n), e * Math.sin(n), Math.sin(t))
|
|
}
|
|
|
|
function kt(n, t, e) {
|
|
++Ea, Ca += (n - Ca) / Ea, za += (t - za) / Ea, La += (e - La) / Ea
|
|
}
|
|
|
|
function Nt() {
|
|
function n(n, i) {
|
|
n *= Yo;
|
|
var u = Math.cos(i *= Yo),
|
|
o = u * Math.cos(n),
|
|
a = u * Math.sin(n),
|
|
l = Math.sin(i),
|
|
c = Math.atan2(Math.sqrt((c = e * l - r * a) * c + (c = r * o - t * l) * c + (c = t * a - e * o) * c), t * o + e * a + r * l);
|
|
Aa += c, qa += c * (t + (t = o)), Ta += c * (e + (e = a)), Ra += c * (r + (r = l)), kt(t, e, r)
|
|
}
|
|
var t, e, r;
|
|
ja.point = function(i, u) {
|
|
i *= Yo;
|
|
var o = Math.cos(u *= Yo);
|
|
t = o * Math.cos(i), e = o * Math.sin(i), r = Math.sin(u), ja.point = n, kt(t, e, r)
|
|
}
|
|
}
|
|
|
|
function Et() {
|
|
ja.point = St
|
|
}
|
|
|
|
function At() {
|
|
function n(n, t) {
|
|
n *= Yo;
|
|
var e = Math.cos(t *= Yo),
|
|
o = e * Math.cos(n),
|
|
a = e * Math.sin(n),
|
|
l = Math.sin(t),
|
|
c = i * l - u * a,
|
|
f = u * o - r * l,
|
|
s = r * a - i * o,
|
|
h = Math.sqrt(c * c + f * f + s * s),
|
|
p = r * o + i * a + u * l,
|
|
g = h && -nn(p) / h,
|
|
v = Math.atan2(h, p);
|
|
Da += g * c, Pa += g * f, Ua += g * s, Aa += v, qa += v * (r + (r = o)), Ta += v * (i + (i = a)), Ra += v * (u + (u = l)), kt(r, i, u)
|
|
}
|
|
var t, e, r, i, u;
|
|
ja.point = function(o, a) {
|
|
t = o, e = a, ja.point = n, o *= Yo;
|
|
var l = Math.cos(a *= Yo);
|
|
r = l * Math.cos(o), i = l * Math.sin(o), u = Math.sin(a), kt(r, i, u)
|
|
}, ja.lineEnd = function() {
|
|
n(t, e), ja.lineEnd = Et, ja.point = St
|
|
}
|
|
}
|
|
|
|
function Ct(n, t) {
|
|
function e(e, r) {
|
|
return e = n(e, r), t(e[0], e[1])
|
|
}
|
|
return n.invert && t.invert && (e.invert = function(e, r) {
|
|
return e = t.invert(e, r), e && n.invert(e[0], e[1])
|
|
}), e
|
|
}
|
|
|
|
function zt() {
|
|
return !0
|
|
}
|
|
|
|
function Lt(n, t, e, r, i) {
|
|
var u = [],
|
|
o = [];
|
|
if (n.forEach(function(n) {
|
|
if (!((t = n.length - 1) <= 0)) {
|
|
var t, e = n[0],
|
|
r = n[t];
|
|
if (wt(e, r)) {
|
|
i.lineStart();
|
|
for (var a = 0; t > a; ++a) i.point((e = n[a])[0], e[1]);
|
|
return void i.lineEnd()
|
|
}
|
|
var l = new Tt(e, n, null, !0),
|
|
c = new Tt(e, null, l, !1);
|
|
l.o = c, u.push(l), o.push(c), l = new Tt(r, n, null, !1), c = new Tt(r, null, l, !0), l.o = c, u.push(l), o.push(c)
|
|
}
|
|
}), o.sort(t), qt(u), qt(o), u.length) {
|
|
for (var a = 0, l = e, c = o.length; c > a; ++a) o[a].e = l = !l;
|
|
for (var f, s, h = u[0];;) {
|
|
for (var p = h, g = !0; p.v;)
|
|
if ((p = p.n) === h) return;
|
|
f = p.z, i.lineStart();
|
|
do {
|
|
if (p.v = p.o.v = !0, p.e) {
|
|
if (g)
|
|
for (var a = 0, c = f.length; c > a; ++a) i.point((s = f[a])[0], s[1]);
|
|
else r(p.x, p.n.x, 1, i);
|
|
p = p.n
|
|
} else {
|
|
if (g) {
|
|
f = p.p.z;
|
|
for (var a = f.length - 1; a >= 0; --a) i.point((s = f[a])[0], s[1])
|
|
} else r(p.x, p.p.x, -1, i);
|
|
p = p.p
|
|
}
|
|
p = p.o, f = p.z, g = !g
|
|
} while (!p.v);
|
|
i.lineEnd()
|
|
}
|
|
}
|
|
}
|
|
|
|
function qt(n) {
|
|
if (t = n.length) {
|
|
for (var t, e, r = 0, i = n[0]; ++r < t;) i.n = e = n[r], e.p = i, i = e;
|
|
i.n = e = n[0], e.p = i
|
|
}
|
|
}
|
|
|
|
function Tt(n, t, e, r) {
|
|
this.x = n, this.z = t, this.o = e, this.e = r, this.v = !1, this.n = this.p = null
|
|
}
|
|
|
|
function Rt(n, t, e, r) {
|
|
return function(i, u) {
|
|
function o(t, e) {
|
|
var r = i(t, e);
|
|
n(t = r[0], e = r[1]) && u.point(t, e)
|
|
}
|
|
|
|
function a(n, t) {
|
|
var e = i(n, t);
|
|
d.point(e[0], e[1])
|
|
}
|
|
|
|
function l() {
|
|
m.point = a, d.lineStart()
|
|
}
|
|
|
|
function c() {
|
|
m.point = o, d.lineEnd()
|
|
}
|
|
|
|
function f(n, t) {
|
|
v.push([n, t]);
|
|
var e = i(n, t);
|
|
x.point(e[0], e[1])
|
|
}
|
|
|
|
function s() {
|
|
x.lineStart(), v = []
|
|
}
|
|
|
|
function h() {
|
|
f(v[0][0], v[0][1]), x.lineEnd();
|
|
var n, t = x.clean(),
|
|
e = M.buffer(),
|
|
r = e.length;
|
|
if (v.pop(), g.push(v), v = null, r)
|
|
if (1 & t) {
|
|
n = e[0];
|
|
var i, r = n.length - 1,
|
|
o = -1;
|
|
if (r > 0) {
|
|
for (b || (u.polygonStart(), b = !0), u.lineStart(); ++o < r;) u.point((i = n[o])[0], i[1]);
|
|
u.lineEnd()
|
|
}
|
|
} else r > 1 && 2 & t && e.push(e.pop().concat(e.shift())), p.push(e.filter(Dt))
|
|
}
|
|
var p, g, v, d = t(u),
|
|
y = i.invert(r[0], r[1]),
|
|
m = {
|
|
point: o,
|
|
lineStart: l,
|
|
lineEnd: c,
|
|
polygonStart: function() {
|
|
m.point = f, m.lineStart = s, m.lineEnd = h, p = [], g = []
|
|
},
|
|
polygonEnd: function() {
|
|
m.point = o, m.lineStart = l, m.lineEnd = c, p = ao.merge(p);
|
|
var n = Ot(y, g);
|
|
p.length ? (b || (u.polygonStart(), b = !0), Lt(p, Ut, n, e, u)) : n && (b || (u.polygonStart(), b = !0), u.lineStart(), e(null, null, 1, u), u.lineEnd()), b && (u.polygonEnd(), b = !1), p = g = null
|
|
},
|
|
sphere: function() {
|
|
u.polygonStart(), u.lineStart(), e(null, null, 1, u), u.lineEnd(), u.polygonEnd()
|
|
}
|
|
},
|
|
M = Pt(),
|
|
x = t(M),
|
|
b = !1;
|
|
return m
|
|
}
|
|
}
|
|
|
|
function Dt(n) {
|
|
return n.length > 1
|
|
}
|
|
|
|
function Pt() {
|
|
var n, t = [];
|
|
return {
|
|
lineStart: function() {
|
|
t.push(n = [])
|
|
},
|
|
point: function(t, e) {
|
|
n.push([t, e])
|
|
},
|
|
lineEnd: b,
|
|
buffer: function() {
|
|
var e = t;
|
|
return t = [], n = null, e
|
|
},
|
|
rejoin: function() {
|
|
t.length > 1 && t.push(t.pop().concat(t.shift()))
|
|
}
|
|
}
|
|
}
|
|
|
|
function Ut(n, t) {
|
|
return ((n = n.x)[0] < 0 ? n[1] - Io - Uo : Io - n[1]) - ((t = t.x)[0] < 0 ? t[1] - Io - Uo : Io - t[1])
|
|
}
|
|
|
|
function jt(n) {
|
|
var t, e = NaN,
|
|
r = NaN,
|
|
i = NaN;
|
|
return {
|
|
lineStart: function() {
|
|
n.lineStart(), t = 1
|
|
},
|
|
point: function(u, o) {
|
|
var a = u > 0 ? Fo : -Fo,
|
|
l = xo(u - e);
|
|
xo(l - Fo) < Uo ? (n.point(e, r = (r + o) / 2 > 0 ? Io : -Io), n.point(i, r), n.lineEnd(), n.lineStart(), n.point(a, r), n.point(u, r), t = 0) : i !== a && l >= Fo && (xo(e - i) < Uo && (e -= i * Uo), xo(u - a) < Uo && (u -= a * Uo), r = Ft(e, r, u, o), n.point(i, r), n.lineEnd(), n.lineStart(), n.point(a, r), t = 0), n.point(e = u, r = o), i = a
|
|
},
|
|
lineEnd: function() {
|
|
n.lineEnd(), e = r = NaN
|
|
},
|
|
clean: function() {
|
|
return 2 - t
|
|
}
|
|
}
|
|
}
|
|
|
|
function Ft(n, t, e, r) {
|
|
var i, u, o = Math.sin(n - e);
|
|
return xo(o) > Uo ? Math.atan((Math.sin(t) * (u = Math.cos(r)) * Math.sin(e) - Math.sin(r) * (i = Math.cos(t)) * Math.sin(n)) / (i * u * o)) : (t + r) / 2
|
|
}
|
|
|
|
function Ht(n, t, e, r) {
|
|
var i;
|
|
if (null == n) i = e * Io, r.point(-Fo, i), r.point(0, i), r.point(Fo, i), r.point(Fo, 0), r.point(Fo, -i), r.point(0, -i), r.point(-Fo, -i), r.point(-Fo, 0), r.point(-Fo, i);
|
|
else if (xo(n[0] - t[0]) > Uo) {
|
|
var u = n[0] < t[0] ? Fo : -Fo;
|
|
i = e * u / 2, r.point(-u, i), r.point(0, i), r.point(u, i)
|
|
} else r.point(t[0], t[1])
|
|
}
|
|
|
|
function Ot(n, t) {
|
|
var e = n[0],
|
|
r = n[1],
|
|
i = [Math.sin(e), -Math.cos(e), 0],
|
|
u = 0,
|
|
o = 0;
|
|
ka.reset();
|
|
for (var a = 0, l = t.length; l > a; ++a) {
|
|
var c = t[a],
|
|
f = c.length;
|
|
if (f)
|
|
for (var s = c[0], h = s[0], p = s[1] / 2 + Fo / 4, g = Math.sin(p), v = Math.cos(p), d = 1;;) {
|
|
d === f && (d = 0), n = c[d];
|
|
var y = n[0],
|
|
m = n[1] / 2 + Fo / 4,
|
|
M = Math.sin(m),
|
|
x = Math.cos(m),
|
|
b = y - h,
|
|
_ = b >= 0 ? 1 : -1,
|
|
w = _ * b,
|
|
S = w > Fo,
|
|
k = g * M;
|
|
if (ka.add(Math.atan2(k * _ * Math.sin(w), v * x + k * Math.cos(w))), u += S ? b + _ * Ho : b, S ^ h >= e ^ y >= e) {
|
|
var N = mt(dt(s), dt(n));
|
|
bt(N);
|
|
var E = mt(i, N);
|
|
bt(E);
|
|
var A = (S ^ b >= 0 ? -1 : 1) * tn(E[2]);
|
|
(r > A || r === A && (N[0] || N[1])) && (o += S ^ b >= 0 ? 1 : -1)
|
|
}
|
|
if (!d++) break;
|
|
h = y, g = M, v = x, s = n
|
|
}
|
|
}
|
|
return (-Uo > u || Uo > u && -Uo > ka) ^ 1 & o
|
|
}
|
|
|
|
function It(n) {
|
|
function t(n, t) {
|
|
return Math.cos(n) * Math.cos(t) > u
|
|
}
|
|
|
|
function e(n) {
|
|
var e, u, l, c, f;
|
|
return {
|
|
lineStart: function() {
|
|
c = l = !1, f = 1
|
|
},
|
|
point: function(s, h) {
|
|
var p, g = [s, h],
|
|
v = t(s, h),
|
|
d = o ? v ? 0 : i(s, h) : v ? i(s + (0 > s ? Fo : -Fo), h) : 0;
|
|
if (!e && (c = l = v) && n.lineStart(), v !== l && (p = r(e, g), (wt(e, p) || wt(g, p)) && (g[0] += Uo, g[1] += Uo, v = t(g[0], g[1]))), v !== l) f = 0, v ? (n.lineStart(), p = r(g, e), n.point(p[0], p[1])) : (p = r(e, g), n.point(p[0], p[1]), n.lineEnd()), e = p;
|
|
else if (a && e && o ^ v) {
|
|
var y;
|
|
d & u || !(y = r(g, e, !0)) || (f = 0, o ? (n.lineStart(), n.point(y[0][0], y[0][1]), n.point(y[1][0], y[1][1]), n.lineEnd()) : (n.point(y[1][0], y[1][1]), n.lineEnd(), n.lineStart(), n.point(y[0][0], y[0][1])))
|
|
}!v || e && wt(e, g) || n.point(g[0], g[1]), e = g, l = v, u = d
|
|
},
|
|
lineEnd: function() {
|
|
l && n.lineEnd(), e = null
|
|
},
|
|
clean: function() {
|
|
return f | (c && l) << 1
|
|
}
|
|
}
|
|
}
|
|
|
|
function r(n, t, e) {
|
|
var r = dt(n),
|
|
i = dt(t),
|
|
o = [1, 0, 0],
|
|
a = mt(r, i),
|
|
l = yt(a, a),
|
|
c = a[0],
|
|
f = l - c * c;
|
|
if (!f) return !e && n;
|
|
var s = u * l / f,
|
|
h = -u * c / f,
|
|
p = mt(o, a),
|
|
g = xt(o, s),
|
|
v = xt(a, h);
|
|
Mt(g, v);
|
|
var d = p,
|
|
y = yt(g, d),
|
|
m = yt(d, d),
|
|
M = y * y - m * (yt(g, g) - 1);
|
|
if (!(0 > M)) {
|
|
var x = Math.sqrt(M),
|
|
b = xt(d, (-y - x) / m);
|
|
if (Mt(b, g), b = _t(b), !e) return b;
|
|
var _, w = n[0],
|
|
S = t[0],
|
|
k = n[1],
|
|
N = t[1];
|
|
w > S && (_ = w, w = S, S = _);
|
|
var E = S - w,
|
|
A = xo(E - Fo) < Uo,
|
|
C = A || Uo > E;
|
|
if (!A && k > N && (_ = k, k = N, N = _), C ? A ? k + N > 0 ^ b[1] < (xo(b[0] - w) < Uo ? k : N) : k <= b[1] && b[1] <= N : E > Fo ^ (w <= b[0] && b[0] <= S)) {
|
|
var z = xt(d, (-y + x) / m);
|
|
return Mt(z, g), [b, _t(z)]
|
|
}
|
|
}
|
|
}
|
|
|
|
function i(t, e) {
|
|
var r = o ? n : Fo - n,
|
|
i = 0;
|
|
return -r > t ? i |= 1 : t > r && (i |= 2), -r > e ? i |= 4 : e > r && (i |= 8), i
|
|
}
|
|
var u = Math.cos(n),
|
|
o = u > 0,
|
|
a = xo(u) > Uo,
|
|
l = ve(n, 6 * Yo);
|
|
return Rt(t, e, l, o ? [0, -n] : [-Fo, n - Fo])
|
|
}
|
|
|
|
function Yt(n, t, e, r) {
|
|
return function(i) {
|
|
var u, o = i.a,
|
|
a = i.b,
|
|
l = o.x,
|
|
c = o.y,
|
|
f = a.x,
|
|
s = a.y,
|
|
h = 0,
|
|
p = 1,
|
|
g = f - l,
|
|
v = s - c;
|
|
if (u = n - l, g || !(u > 0)) {
|
|
if (u /= g, 0 > g) {
|
|
if (h > u) return;
|
|
p > u && (p = u)
|
|
} else if (g > 0) {
|
|
if (u > p) return;
|
|
u > h && (h = u)
|
|
}
|
|
if (u = e - l, g || !(0 > u)) {
|
|
if (u /= g, 0 > g) {
|
|
if (u > p) return;
|
|
u > h && (h = u)
|
|
} else if (g > 0) {
|
|
if (h > u) return;
|
|
p > u && (p = u)
|
|
}
|
|
if (u = t - c, v || !(u > 0)) {
|
|
if (u /= v, 0 > v) {
|
|
if (h > u) return;
|
|
p > u && (p = u)
|
|
} else if (v > 0) {
|
|
if (u > p) return;
|
|
u > h && (h = u)
|
|
}
|
|
if (u = r - c, v || !(0 > u)) {
|
|
if (u /= v, 0 > v) {
|
|
if (u > p) return;
|
|
u > h && (h = u)
|
|
} else if (v > 0) {
|
|
if (h > u) return;
|
|
p > u && (p = u)
|
|
}
|
|
return h > 0 && (i.a = {
|
|
x: l + h * g,
|
|
y: c + h * v
|
|
}), 1 > p && (i.b = {
|
|
x: l + p * g,
|
|
y: c + p * v
|
|
}), i
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function Zt(n, t, e, r) {
|
|
function i(r, i) {
|
|
return xo(r[0] - n) < Uo ? i > 0 ? 0 : 3 : xo(r[0] - e) < Uo ? i > 0 ? 2 : 1 : xo(r[1] - t) < Uo ? i > 0 ? 1 : 0 : i > 0 ? 3 : 2
|
|
}
|
|
|
|
function u(n, t) {
|
|
return o(n.x, t.x)
|
|
}
|
|
|
|
function o(n, t) {
|
|
var e = i(n, 1),
|
|
r = i(t, 1);
|
|
return e !== r ? e - r : 0 === e ? t[1] - n[1] : 1 === e ? n[0] - t[0] : 2 === e ? n[1] - t[1] : t[0] - n[0]
|
|
}
|
|
return function(a) {
|
|
function l(n) {
|
|
for (var t = 0, e = d.length, r = n[1], i = 0; e > i; ++i)
|
|
for (var u, o = 1, a = d[i], l = a.length, c = a[0]; l > o; ++o) u = a[o], c[1] <= r ? u[1] > r && Q(c, u, n) > 0 && ++t : u[1] <= r && Q(c, u, n) < 0 && --t, c = u;
|
|
return 0 !== t
|
|
}
|
|
|
|
function c(u, a, l, c) {
|
|
var f = 0,
|
|
s = 0;
|
|
if (null == u || (f = i(u, l)) !== (s = i(a, l)) || o(u, a) < 0 ^ l > 0) {
|
|
do c.point(0 === f || 3 === f ? n : e, f > 1 ? r : t); while ((f = (f + l + 4) % 4) !== s)
|
|
} else c.point(a[0], a[1])
|
|
}
|
|
|
|
function f(i, u) {
|
|
return i >= n && e >= i && u >= t && r >= u
|
|
}
|
|
|
|
function s(n, t) {
|
|
f(n, t) && a.point(n, t)
|
|
}
|
|
|
|
function h() {
|
|
C.point = g, d && d.push(y = []), S = !0, w = !1, b = _ = NaN
|
|
}
|
|
|
|
function p() {
|
|
v && (g(m, M), x && w && E.rejoin(), v.push(E.buffer())), C.point = s, w && a.lineEnd()
|
|
}
|
|
|
|
function g(n, t) {
|
|
n = Math.max(-Ha, Math.min(Ha, n)), t = Math.max(-Ha, Math.min(Ha, t));
|
|
var e = f(n, t);
|
|
if (d && y.push([n, t]), S) m = n, M = t, x = e, S = !1, e && (a.lineStart(), a.point(n, t));
|
|
else if (e && w) a.point(n, t);
|
|
else {
|
|
var r = {
|
|
a: {
|
|
x: b,
|
|
y: _
|
|
},
|
|
b: {
|
|
x: n,
|
|
y: t
|
|
}
|
|
};
|
|
A(r) ? (w || (a.lineStart(), a.point(r.a.x, r.a.y)), a.point(r.b.x, r.b.y), e || a.lineEnd(), k = !1) : e && (a.lineStart(), a.point(n, t), k = !1)
|
|
}
|
|
b = n, _ = t, w = e
|
|
}
|
|
var v, d, y, m, M, x, b, _, w, S, k, N = a,
|
|
E = Pt(),
|
|
A = Yt(n, t, e, r),
|
|
C = {
|
|
point: s,
|
|
lineStart: h,
|
|
lineEnd: p,
|
|
polygonStart: function() {
|
|
a = E, v = [], d = [], k = !0
|
|
},
|
|
polygonEnd: function() {
|
|
a = N, v = ao.merge(v);
|
|
var t = l([n, r]),
|
|
e = k && t,
|
|
i = v.length;
|
|
(e || i) && (a.polygonStart(), e && (a.lineStart(), c(null, null, 1, a), a.lineEnd()), i && Lt(v, u, t, c, a), a.polygonEnd()), v = d = y = null
|
|
}
|
|
};
|
|
return C
|
|
}
|
|
}
|
|
|
|
function Vt(n) {
|
|
var t = 0,
|
|
e = Fo / 3,
|
|
r = ae(n),
|
|
i = r(t, e);
|
|
return i.parallels = function(n) {
|
|
return arguments.length ? r(t = n[0] * Fo / 180, e = n[1] * Fo / 180) : [t / Fo * 180, e / Fo * 180]
|
|
}, i
|
|
}
|
|
|
|
function Xt(n, t) {
|
|
function e(n, t) {
|
|
var e = Math.sqrt(u - 2 * i * Math.sin(t)) / i;
|
|
return [e * Math.sin(n *= i), o - e * Math.cos(n)]
|
|
}
|
|
var r = Math.sin(n),
|
|
i = (r + Math.sin(t)) / 2,
|
|
u = 1 + r * (2 * i - r),
|
|
o = Math.sqrt(u) / i;
|
|
return e.invert = function(n, t) {
|
|
var e = o - t;
|
|
return [Math.atan2(n, e) / i, tn((u - (n * n + e * e) * i * i) / (2 * i))]
|
|
}, e
|
|
}
|
|
|
|
function $t() {
|
|
function n(n, t) {
|
|
Ia += i * n - r * t, r = n, i = t
|
|
}
|
|
var t, e, r, i;
|
|
$a.point = function(u, o) {
|
|
$a.point = n, t = r = u, e = i = o
|
|
}, $a.lineEnd = function() {
|
|
n(t, e)
|
|
}
|
|
}
|
|
|
|
function Bt(n, t) {
|
|
Ya > n && (Ya = n), n > Va && (Va = n), Za > t && (Za = t), t > Xa && (Xa = t)
|
|
}
|
|
|
|
function Wt() {
|
|
function n(n, t) {
|
|
o.push("M", n, ",", t, u)
|
|
}
|
|
|
|
function t(n, t) {
|
|
o.push("M", n, ",", t), a.point = e
|
|
}
|
|
|
|
function e(n, t) {
|
|
o.push("L", n, ",", t)
|
|
}
|
|
|
|
function r() {
|
|
a.point = n
|
|
}
|
|
|
|
function i() {
|
|
o.push("Z")
|
|
}
|
|
var u = Jt(4.5),
|
|
o = [],
|
|
a = {
|
|
point: n,
|
|
lineStart: function() {
|
|
a.point = t
|
|
},
|
|
lineEnd: r,
|
|
polygonStart: function() {
|
|
a.lineEnd = i
|
|
},
|
|
polygonEnd: function() {
|
|
a.lineEnd = r, a.point = n
|
|
},
|
|
pointRadius: function(n) {
|
|
return u = Jt(n), a
|
|
},
|
|
result: function() {
|
|
if (o.length) {
|
|
var n = o.join("");
|
|
return o = [], n
|
|
}
|
|
}
|
|
};
|
|
return a
|
|
}
|
|
|
|
function Jt(n) {
|
|
return "m0," + n + "a" + n + "," + n + " 0 1,1 0," + -2 * n + "a" + n + "," + n + " 0 1,1 0," + 2 * n + "z"
|
|
}
|
|
|
|
function Gt(n, t) {
|
|
Ca += n, za += t, ++La
|
|
}
|
|
|
|
function Kt() {
|
|
function n(n, r) {
|
|
var i = n - t,
|
|
u = r - e,
|
|
o = Math.sqrt(i * i + u * u);
|
|
qa += o * (t + n) / 2, Ta += o * (e + r) / 2, Ra += o, Gt(t = n, e = r)
|
|
}
|
|
var t, e;
|
|
Wa.point = function(r, i) {
|
|
Wa.point = n, Gt(t = r, e = i)
|
|
}
|
|
}
|
|
|
|
function Qt() {
|
|
Wa.point = Gt
|
|
}
|
|
|
|
function ne() {
|
|
function n(n, t) {
|
|
var e = n - r,
|
|
u = t - i,
|
|
o = Math.sqrt(e * e + u * u);
|
|
qa += o * (r + n) / 2, Ta += o * (i + t) / 2, Ra += o, o = i * n - r * t, Da += o * (r + n), Pa += o * (i + t), Ua += 3 * o, Gt(r = n, i = t)
|
|
}
|
|
var t, e, r, i;
|
|
Wa.point = function(u, o) {
|
|
Wa.point = n, Gt(t = r = u, e = i = o)
|
|
}, Wa.lineEnd = function() {
|
|
n(t, e)
|
|
}
|
|
}
|
|
|
|
function te(n) {
|
|
function t(t, e) {
|
|
n.moveTo(t + o, e), n.arc(t, e, o, 0, Ho)
|
|
}
|
|
|
|
function e(t, e) {
|
|
n.moveTo(t, e), a.point = r
|
|
}
|
|
|
|
function r(t, e) {
|
|
n.lineTo(t, e)
|
|
}
|
|
|
|
function i() {
|
|
a.point = t
|
|
}
|
|
|
|
function u() {
|
|
n.closePath()
|
|
}
|
|
var o = 4.5,
|
|
a = {
|
|
point: t,
|
|
lineStart: function() {
|
|
a.point = e
|
|
},
|
|
lineEnd: i,
|
|
polygonStart: function() {
|
|
a.lineEnd = u
|
|
},
|
|
polygonEnd: function() {
|
|
a.lineEnd = i, a.point = t
|
|
},
|
|
pointRadius: function(n) {
|
|
return o = n, a
|
|
},
|
|
result: b
|
|
};
|
|
return a
|
|
}
|
|
|
|
function ee(n) {
|
|
function t(n) {
|
|
return (a ? r : e)(n)
|
|
}
|
|
|
|
function e(t) {
|
|
return ue(t, function(e, r) {
|
|
e = n(e, r), t.point(e[0], e[1])
|
|
})
|
|
}
|
|
|
|
function r(t) {
|
|
function e(e, r) {
|
|
e = n(e, r), t.point(e[0], e[1])
|
|
}
|
|
|
|
function r() {
|
|
M = NaN, S.point = u, t.lineStart()
|
|
}
|
|
|
|
function u(e, r) {
|
|
var u = dt([e, r]),
|
|
o = n(e, r);
|
|
i(M, x, m, b, _, w, M = o[0], x = o[1], m = e, b = u[0], _ = u[1], w = u[2], a, t), t.point(M, x)
|
|
}
|
|
|
|
function o() {
|
|
S.point = e, t.lineEnd()
|
|
}
|
|
|
|
function l() {
|
|
r(), S.point = c, S.lineEnd = f
|
|
}
|
|
|
|
function c(n, t) {
|
|
u(s = n, h = t), p = M, g = x, v = b, d = _, y = w, S.point = u
|
|
}
|
|
|
|
function f() {
|
|
i(M, x, m, b, _, w, p, g, s, v, d, y, a, t), S.lineEnd = o, o()
|
|
}
|
|
var s, h, p, g, v, d, y, m, M, x, b, _, w, S = {
|
|
point: e,
|
|
lineStart: r,
|
|
lineEnd: o,
|
|
polygonStart: function() {
|
|
t.polygonStart(), S.lineStart = l
|
|
},
|
|
polygonEnd: function() {
|
|
t.polygonEnd(), S.lineStart = r
|
|
}
|
|
};
|
|
return S
|
|
}
|
|
|
|
function i(t, e, r, a, l, c, f, s, h, p, g, v, d, y) {
|
|
var m = f - t,
|
|
M = s - e,
|
|
x = m * m + M * M;
|
|
if (x > 4 * u && d--) {
|
|
var b = a + p,
|
|
_ = l + g,
|
|
w = c + v,
|
|
S = Math.sqrt(b * b + _ * _ + w * w),
|
|
k = Math.asin(w /= S),
|
|
N = xo(xo(w) - 1) < Uo || xo(r - h) < Uo ? (r + h) / 2 : Math.atan2(_, b),
|
|
E = n(N, k),
|
|
A = E[0],
|
|
C = E[1],
|
|
z = A - t,
|
|
L = C - e,
|
|
q = M * z - m * L;
|
|
(q * q / x > u || xo((m * z + M * L) / x - .5) > .3 || o > a * p + l * g + c * v) && (i(t, e, r, a, l, c, A, C, N, b /= S, _ /= S, w, d, y), y.point(A, C), i(A, C, N, b, _, w, f, s, h, p, g, v, d, y))
|
|
}
|
|
}
|
|
var u = .5,
|
|
o = Math.cos(30 * Yo),
|
|
a = 16;
|
|
return t.precision = function(n) {
|
|
return arguments.length ? (a = (u = n * n) > 0 && 16, t) : Math.sqrt(u)
|
|
}, t
|
|
}
|
|
|
|
function re(n) {
|
|
var t = ee(function(t, e) {
|
|
return n([t * Zo, e * Zo])
|
|
});
|
|
return function(n) {
|
|
return le(t(n))
|
|
}
|
|
}
|
|
|
|
function ie(n) {
|
|
this.stream = n
|
|
}
|
|
|
|
function ue(n, t) {
|
|
return {
|
|
point: t,
|
|
sphere: function() {
|
|
n.sphere()
|
|
},
|
|
lineStart: function() {
|
|
n.lineStart()
|
|
},
|
|
lineEnd: function() {
|
|
n.lineEnd()
|
|
},
|
|
polygonStart: function() {
|
|
n.polygonStart()
|
|
},
|
|
polygonEnd: function() {
|
|
n.polygonEnd()
|
|
}
|
|
}
|
|
}
|
|
|
|
function oe(n) {
|
|
return ae(function() {
|
|
return n
|
|
})()
|
|
}
|
|
|
|
function ae(n) {
|
|
function t(n) {
|
|
return n = a(n[0] * Yo, n[1] * Yo), [n[0] * h + l, c - n[1] * h]
|
|
}
|
|
|
|
function e(n) {
|
|
return n = a.invert((n[0] - l) / h, (c - n[1]) / h), n && [n[0] * Zo, n[1] * Zo]
|
|
}
|
|
|
|
function r() {
|
|
a = Ct(o = se(y, M, x), u);
|
|
var n = u(v, d);
|
|
return l = p - n[0] * h, c = g + n[1] * h, i()
|
|
}
|
|
|
|
function i() {
|
|
return f && (f.valid = !1, f = null), t
|
|
}
|
|
var u, o, a, l, c, f, s = ee(function(n, t) {
|
|
return n = u(n, t), [n[0] * h + l, c - n[1] * h]
|
|
}),
|
|
h = 150,
|
|
p = 480,
|
|
g = 250,
|
|
v = 0,
|
|
d = 0,
|
|
y = 0,
|
|
M = 0,
|
|
x = 0,
|
|
b = Fa,
|
|
_ = m,
|
|
w = null,
|
|
S = null;
|
|
return t.stream = function(n) {
|
|
return f && (f.valid = !1), f = le(b(o, s(_(n)))), f.valid = !0, f
|
|
}, t.clipAngle = function(n) {
|
|
return arguments.length ? (b = null == n ? (w = n, Fa) : It((w = +n) * Yo), i()) : w
|
|
}, t.clipExtent = function(n) {
|
|
return arguments.length ? (S = n, _ = n ? Zt(n[0][0], n[0][1], n[1][0], n[1][1]) : m, i()) : S
|
|
}, t.scale = function(n) {
|
|
return arguments.length ? (h = +n, r()) : h
|
|
}, t.translate = function(n) {
|
|
return arguments.length ? (p = +n[0], g = +n[1], r()) : [p, g]
|
|
}, t.center = function(n) {
|
|
return arguments.length ? (v = n[0] % 360 * Yo, d = n[1] % 360 * Yo, r()) : [v * Zo, d * Zo]
|
|
}, t.rotate = function(n) {
|
|
return arguments.length ? (y = n[0] % 360 * Yo, M = n[1] % 360 * Yo, x = n.length > 2 ? n[2] % 360 * Yo : 0, r()) : [y * Zo, M * Zo, x * Zo]
|
|
}, ao.rebind(t, s, "precision"),
|
|
function() {
|
|
return u = n.apply(this, arguments), t.invert = u.invert && e, r()
|
|
}
|
|
}
|
|
|
|
function le(n) {
|
|
return ue(n, function(t, e) {
|
|
n.point(t * Yo, e * Yo)
|
|
})
|
|
}
|
|
|
|
function ce(n, t) {
|
|
return [n, t]
|
|
}
|
|
|
|
function fe(n, t) {
|
|
return [n > Fo ? n - Ho : -Fo > n ? n + Ho : n, t]
|
|
}
|
|
|
|
function se(n, t, e) {
|
|
return n ? t || e ? Ct(pe(n), ge(t, e)) : pe(n) : t || e ? ge(t, e) : fe
|
|
}
|
|
|
|
function he(n) {
|
|
return function(t, e) {
|
|
return t += n, [t > Fo ? t - Ho : -Fo > t ? t + Ho : t, e]
|
|
}
|
|
}
|
|
|
|
function pe(n) {
|
|
var t = he(n);
|
|
return t.invert = he(-n), t
|
|
}
|
|
|
|
function ge(n, t) {
|
|
function e(n, t) {
|
|
var e = Math.cos(t),
|
|
a = Math.cos(n) * e,
|
|
l = Math.sin(n) * e,
|
|
c = Math.sin(t),
|
|
f = c * r + a * i;
|
|
return [Math.atan2(l * u - f * o, a * r - c * i), tn(f * u + l * o)]
|
|
}
|
|
var r = Math.cos(n),
|
|
i = Math.sin(n),
|
|
u = Math.cos(t),
|
|
o = Math.sin(t);
|
|
return e.invert = function(n, t) {
|
|
var e = Math.cos(t),
|
|
a = Math.cos(n) * e,
|
|
l = Math.sin(n) * e,
|
|
c = Math.sin(t),
|
|
f = c * u - l * o;
|
|
return [Math.atan2(l * u + c * o, a * r + f * i), tn(f * r - a * i)]
|
|
}, e
|
|
}
|
|
|
|
function ve(n, t) {
|
|
var e = Math.cos(n),
|
|
r = Math.sin(n);
|
|
return function(i, u, o, a) {
|
|
var l = o * t;
|
|
null != i ? (i = de(e, i), u = de(e, u), (o > 0 ? u > i : i > u) && (i += o * Ho)) : (i = n + o * Ho, u = n - .5 * l);
|
|
for (var c, f = i; o > 0 ? f > u : u > f; f -= l) a.point((c = _t([e, -r * Math.cos(f), -r * Math.sin(f)]))[0], c[1])
|
|
}
|
|
}
|
|
|
|
function de(n, t) {
|
|
var e = dt(t);
|
|
e[0] -= n, bt(e);
|
|
var r = nn(-e[1]);
|
|
return ((-e[2] < 0 ? -r : r) + 2 * Math.PI - Uo) % (2 * Math.PI)
|
|
}
|
|
|
|
function ye(n, t, e) {
|
|
var r = ao.range(n, t - Uo, e).concat(t);
|
|
return function(n) {
|
|
return r.map(function(t) {
|
|
return [n, t]
|
|
})
|
|
}
|
|
}
|
|
|
|
function me(n, t, e) {
|
|
var r = ao.range(n, t - Uo, e).concat(t);
|
|
return function(n) {
|
|
return r.map(function(t) {
|
|
return [t, n]
|
|
})
|
|
}
|
|
}
|
|
|
|
function Me(n) {
|
|
return n.source
|
|
}
|
|
|
|
function xe(n) {
|
|
return n.target
|
|
}
|
|
|
|
function be(n, t, e, r) {
|
|
var i = Math.cos(t),
|
|
u = Math.sin(t),
|
|
o = Math.cos(r),
|
|
a = Math.sin(r),
|
|
l = i * Math.cos(n),
|
|
c = i * Math.sin(n),
|
|
f = o * Math.cos(e),
|
|
s = o * Math.sin(e),
|
|
h = 2 * Math.asin(Math.sqrt(on(r - t) + i * o * on(e - n))),
|
|
p = 1 / Math.sin(h),
|
|
g = h ? function(n) {
|
|
var t = Math.sin(n *= h) * p,
|
|
e = Math.sin(h - n) * p,
|
|
r = e * l + t * f,
|
|
i = e * c + t * s,
|
|
o = e * u + t * a;
|
|
return [Math.atan2(i, r) * Zo, Math.atan2(o, Math.sqrt(r * r + i * i)) * Zo]
|
|
} : function() {
|
|
return [n * Zo, t * Zo]
|
|
};
|
|
return g.distance = h, g
|
|
}
|
|
|
|
function _e() {
|
|
function n(n, i) {
|
|
var u = Math.sin(i *= Yo),
|
|
o = Math.cos(i),
|
|
a = xo((n *= Yo) - t),
|
|
l = Math.cos(a);
|
|
Ja += Math.atan2(Math.sqrt((a = o * Math.sin(a)) * a + (a = r * u - e * o * l) * a), e * u + r * o * l), t = n, e = u, r = o
|
|
}
|
|
var t, e, r;
|
|
Ga.point = function(i, u) {
|
|
t = i * Yo, e = Math.sin(u *= Yo), r = Math.cos(u), Ga.point = n
|
|
}, Ga.lineEnd = function() {
|
|
Ga.point = Ga.lineEnd = b
|
|
}
|
|
}
|
|
|
|
function we(n, t) {
|
|
function e(t, e) {
|
|
var r = Math.cos(t),
|
|
i = Math.cos(e),
|
|
u = n(r * i);
|
|
return [u * i * Math.sin(t), u * Math.sin(e)]
|
|
}
|
|
return e.invert = function(n, e) {
|
|
var r = Math.sqrt(n * n + e * e),
|
|
i = t(r),
|
|
u = Math.sin(i),
|
|
o = Math.cos(i);
|
|
return [Math.atan2(n * u, r * o), Math.asin(r && e * u / r)]
|
|
}, e
|
|
}
|
|
|
|
function Se(n, t) {
|
|
function e(n, t) {
|
|
o > 0 ? -Io + Uo > t && (t = -Io + Uo) : t > Io - Uo && (t = Io - Uo);
|
|
var e = o / Math.pow(i(t), u);
|
|
return [e * Math.sin(u * n), o - e * Math.cos(u * n)]
|
|
}
|
|
var r = Math.cos(n),
|
|
i = function(n) {
|
|
return Math.tan(Fo / 4 + n / 2)
|
|
},
|
|
u = n === t ? Math.sin(n) : Math.log(r / Math.cos(t)) / Math.log(i(t) / i(n)),
|
|
o = r * Math.pow(i(n), u) / u;
|
|
return u ? (e.invert = function(n, t) {
|
|
var e = o - t,
|
|
r = K(u) * Math.sqrt(n * n + e * e);
|
|
return [Math.atan2(n, e) / u, 2 * Math.atan(Math.pow(o / r, 1 / u)) - Io]
|
|
}, e) : Ne
|
|
}
|
|
|
|
function ke(n, t) {
|
|
function e(n, t) {
|
|
var e = u - t;
|
|
return [e * Math.sin(i * n), u - e * Math.cos(i * n)]
|
|
}
|
|
var r = Math.cos(n),
|
|
i = n === t ? Math.sin(n) : (r - Math.cos(t)) / (t - n),
|
|
u = r / i + n;
|
|
return xo(i) < Uo ? ce : (e.invert = function(n, t) {
|
|
var e = u - t;
|
|
return [Math.atan2(n, e) / i, u - K(i) * Math.sqrt(n * n + e * e)]
|
|
}, e)
|
|
}
|
|
|
|
function Ne(n, t) {
|
|
return [n, Math.log(Math.tan(Fo / 4 + t / 2))]
|
|
}
|
|
|
|
function Ee(n) {
|
|
var t, e = oe(n),
|
|
r = e.scale,
|
|
i = e.translate,
|
|
u = e.clipExtent;
|
|
return e.scale = function() {
|
|
var n = r.apply(e, arguments);
|
|
return n === e ? t ? e.clipExtent(null) : e : n
|
|
}, e.translate = function() {
|
|
var n = i.apply(e, arguments);
|
|
return n === e ? t ? e.clipExtent(null) : e : n
|
|
}, e.clipExtent = function(n) {
|
|
var o = u.apply(e, arguments);
|
|
if (o === e) {
|
|
if (t = null == n) {
|
|
var a = Fo * r(),
|
|
l = i();
|
|
u([
|
|
[l[0] - a, l[1] - a],
|
|
[l[0] + a, l[1] + a]
|
|
])
|
|
}
|
|
} else t && (o = null);
|
|
return o
|
|
}, e.clipExtent(null)
|
|
}
|
|
|
|
function Ae(n, t) {
|
|
return [Math.log(Math.tan(Fo / 4 + t / 2)), -n]
|
|
}
|
|
|
|
function Ce(n) {
|
|
return n[0]
|
|
}
|
|
|
|
function ze(n) {
|
|
return n[1]
|
|
}
|
|
|
|
function Le(n) {
|
|
for (var t = n.length, e = [0, 1], r = 2, i = 2; t > i; i++) {
|
|
for (; r > 1 && Q(n[e[r - 2]], n[e[r - 1]], n[i]) <= 0;) --r;
|
|
e[r++] = i
|
|
}
|
|
return e.slice(0, r)
|
|
}
|
|
|
|
function qe(n, t) {
|
|
return n[0] - t[0] || n[1] - t[1]
|
|
}
|
|
|
|
function Te(n, t, e) {
|
|
return (e[0] - t[0]) * (n[1] - t[1]) < (e[1] - t[1]) * (n[0] - t[0])
|
|
}
|
|
|
|
function Re(n, t, e, r) {
|
|
var i = n[0],
|
|
u = e[0],
|
|
o = t[0] - i,
|
|
a = r[0] - u,
|
|
l = n[1],
|
|
c = e[1],
|
|
f = t[1] - l,
|
|
s = r[1] - c,
|
|
h = (a * (l - c) - s * (i - u)) / (s * o - a * f);
|
|
return [i + h * o, l + h * f]
|
|
}
|
|
|
|
function De(n) {
|
|
var t = n[0],
|
|
e = n[n.length - 1];
|
|
return !(t[0] - e[0] || t[1] - e[1])
|
|
}
|
|
|
|
function Pe() {
|
|
rr(this), this.edge = this.site = this.circle = null
|
|
}
|
|
|
|
function Ue(n) {
|
|
var t = cl.pop() || new Pe;
|
|
return t.site = n, t
|
|
}
|
|
|
|
function je(n) {
|
|
Be(n), ol.remove(n), cl.push(n), rr(n)
|
|
}
|
|
|
|
function Fe(n) {
|
|
var t = n.circle,
|
|
e = t.x,
|
|
r = t.cy,
|
|
i = {
|
|
x: e,
|
|
y: r
|
|
},
|
|
u = n.P,
|
|
o = n.N,
|
|
a = [n];
|
|
je(n);
|
|
for (var l = u; l.circle && xo(e - l.circle.x) < Uo && xo(r - l.circle.cy) < Uo;) u = l.P, a.unshift(l), je(l), l = u;
|
|
a.unshift(l), Be(l);
|
|
for (var c = o; c.circle && xo(e - c.circle.x) < Uo && xo(r - c.circle.cy) < Uo;) o = c.N, a.push(c), je(c), c = o;
|
|
a.push(c), Be(c);
|
|
var f, s = a.length;
|
|
for (f = 1; s > f; ++f) c = a[f], l = a[f - 1], nr(c.edge, l.site, c.site, i);
|
|
l = a[0], c = a[s - 1], c.edge = Ke(l.site, c.site, null, i), $e(l), $e(c)
|
|
}
|
|
|
|
function He(n) {
|
|
for (var t, e, r, i, u = n.x, o = n.y, a = ol._; a;)
|
|
if (r = Oe(a, o) - u, r > Uo) a = a.L;
|
|
else {
|
|
if (i = u - Ie(a, o), !(i > Uo)) {
|
|
r > -Uo ? (t = a.P, e = a) : i > -Uo ? (t = a, e = a.N) : t = e = a;
|
|
break
|
|
}
|
|
if (!a.R) {
|
|
t = a;
|
|
break
|
|
}
|
|
a = a.R
|
|
}
|
|
var l = Ue(n);
|
|
if (ol.insert(t, l), t || e) {
|
|
if (t === e) return Be(t), e = Ue(t.site), ol.insert(l, e), l.edge = e.edge = Ke(t.site, l.site), $e(t), void $e(e);
|
|
if (!e) return void(l.edge = Ke(t.site, l.site));
|
|
Be(t), Be(e);
|
|
var c = t.site,
|
|
f = c.x,
|
|
s = c.y,
|
|
h = n.x - f,
|
|
p = n.y - s,
|
|
g = e.site,
|
|
v = g.x - f,
|
|
d = g.y - s,
|
|
y = 2 * (h * d - p * v),
|
|
m = h * h + p * p,
|
|
M = v * v + d * d,
|
|
x = {
|
|
x: (d * m - p * M) / y + f,
|
|
y: (h * M - v * m) / y + s
|
|
};
|
|
nr(e.edge, c, g, x), l.edge = Ke(c, n, null, x), e.edge = Ke(n, g, null, x), $e(t), $e(e)
|
|
}
|
|
}
|
|
|
|
function Oe(n, t) {
|
|
var e = n.site,
|
|
r = e.x,
|
|
i = e.y,
|
|
u = i - t;
|
|
if (!u) return r;
|
|
var o = n.P;
|
|
if (!o) return -(1 / 0);
|
|
e = o.site;
|
|
var a = e.x,
|
|
l = e.y,
|
|
c = l - t;
|
|
if (!c) return a;
|
|
var f = a - r,
|
|
s = 1 / u - 1 / c,
|
|
h = f / c;
|
|
return s ? (-h + Math.sqrt(h * h - 2 * s * (f * f / (-2 * c) - l + c / 2 + i - u / 2))) / s + r : (r + a) / 2
|
|
}
|
|
|
|
function Ie(n, t) {
|
|
var e = n.N;
|
|
if (e) return Oe(e, t);
|
|
var r = n.site;
|
|
return r.y === t ? r.x : 1 / 0
|
|
}
|
|
|
|
function Ye(n) {
|
|
this.site = n, this.edges = []
|
|
}
|
|
|
|
function Ze(n) {
|
|
for (var t, e, r, i, u, o, a, l, c, f, s = n[0][0], h = n[1][0], p = n[0][1], g = n[1][1], v = ul, d = v.length; d--;)
|
|
if (u = v[d], u && u.prepare())
|
|
for (a = u.edges, l = a.length, o = 0; l > o;) f = a[o].end(), r = f.x, i = f.y, c = a[++o % l].start(), t = c.x, e = c.y, (xo(r - t) > Uo || xo(i - e) > Uo) && (a.splice(o, 0, new tr(Qe(u.site, f, xo(r - s) < Uo && g - i > Uo ? {
|
|
x: s,
|
|
y: xo(t - s) < Uo ? e : g
|
|
} : xo(i - g) < Uo && h - r > Uo ? {
|
|
x: xo(e - g) < Uo ? t : h,
|
|
y: g
|
|
} : xo(r - h) < Uo && i - p > Uo ? {
|
|
x: h,
|
|
y: xo(t - h) < Uo ? e : p
|
|
} : xo(i - p) < Uo && r - s > Uo ? {
|
|
x: xo(e - p) < Uo ? t : s,
|
|
y: p
|
|
} : null), u.site, null)), ++l)
|
|
}
|
|
|
|
function Ve(n, t) {
|
|
return t.angle - n.angle
|
|
}
|
|
|
|
function Xe() {
|
|
rr(this), this.x = this.y = this.arc = this.site = this.cy = null
|
|
}
|
|
|
|
function $e(n) {
|
|
var t = n.P,
|
|
e = n.N;
|
|
if (t && e) {
|
|
var r = t.site,
|
|
i = n.site,
|
|
u = e.site;
|
|
if (r !== u) {
|
|
var o = i.x,
|
|
a = i.y,
|
|
l = r.x - o,
|
|
c = r.y - a,
|
|
f = u.x - o,
|
|
s = u.y - a,
|
|
h = 2 * (l * s - c * f);
|
|
if (!(h >= -jo)) {
|
|
var p = l * l + c * c,
|
|
g = f * f + s * s,
|
|
v = (s * p - c * g) / h,
|
|
d = (l * g - f * p) / h,
|
|
s = d + a,
|
|
y = fl.pop() || new Xe;
|
|
y.arc = n, y.site = i, y.x = v + o, y.y = s + Math.sqrt(v * v + d * d), y.cy = s, n.circle = y;
|
|
for (var m = null, M = ll._; M;)
|
|
if (y.y < M.y || y.y === M.y && y.x <= M.x) {
|
|
if (!M.L) {
|
|
m = M.P;
|
|
break
|
|
}
|
|
M = M.L
|
|
} else {
|
|
if (!M.R) {
|
|
m = M;
|
|
break
|
|
}
|
|
M = M.R
|
|
}
|
|
ll.insert(m, y), m || (al = y)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function Be(n) {
|
|
var t = n.circle;
|
|
t && (t.P || (al = t.N), ll.remove(t), fl.push(t), rr(t), n.circle = null)
|
|
}
|
|
|
|
function We(n) {
|
|
for (var t, e = il, r = Yt(n[0][0], n[0][1], n[1][0], n[1][1]), i = e.length; i--;) t = e[i], (!Je(t, n) || !r(t) || xo(t.a.x - t.b.x) < Uo && xo(t.a.y - t.b.y) < Uo) && (t.a = t.b = null, e.splice(i, 1))
|
|
}
|
|
|
|
function Je(n, t) {
|
|
var e = n.b;
|
|
if (e) return !0;
|
|
var r, i, u = n.a,
|
|
o = t[0][0],
|
|
a = t[1][0],
|
|
l = t[0][1],
|
|
c = t[1][1],
|
|
f = n.l,
|
|
s = n.r,
|
|
h = f.x,
|
|
p = f.y,
|
|
g = s.x,
|
|
v = s.y,
|
|
d = (h + g) / 2,
|
|
y = (p + v) / 2;
|
|
if (v === p) {
|
|
if (o > d || d >= a) return;
|
|
if (h > g) {
|
|
if (u) {
|
|
if (u.y >= c) return
|
|
} else u = {
|
|
x: d,
|
|
y: l
|
|
};
|
|
e = {
|
|
x: d,
|
|
y: c
|
|
}
|
|
} else {
|
|
if (u) {
|
|
if (u.y < l) return
|
|
} else u = {
|
|
x: d,
|
|
y: c
|
|
};
|
|
e = {
|
|
x: d,
|
|
y: l
|
|
}
|
|
}
|
|
} else if (r = (h - g) / (v - p), i = y - r * d, -1 > r || r > 1)
|
|
if (h > g) {
|
|
if (u) {
|
|
if (u.y >= c) return
|
|
} else u = {
|
|
x: (l - i) / r,
|
|
y: l
|
|
};
|
|
e = {
|
|
x: (c - i) / r,
|
|
y: c
|
|
}
|
|
} else {
|
|
if (u) {
|
|
if (u.y < l) return
|
|
} else u = {
|
|
x: (c - i) / r,
|
|
y: c
|
|
};
|
|
e = {
|
|
x: (l - i) / r,
|
|
y: l
|
|
}
|
|
}
|
|
else if (v > p) {
|
|
if (u) {
|
|
if (u.x >= a) return
|
|
} else u = {
|
|
x: o,
|
|
y: r * o + i
|
|
};
|
|
e = {
|
|
x: a,
|
|
y: r * a + i
|
|
}
|
|
} else {
|
|
if (u) {
|
|
if (u.x < o) return
|
|
} else u = {
|
|
x: a,
|
|
y: r * a + i
|
|
};
|
|
e = {
|
|
x: o,
|
|
y: r * o + i
|
|
}
|
|
}
|
|
return n.a = u, n.b = e, !0
|
|
}
|
|
|
|
function Ge(n, t) {
|
|
this.l = n, this.r = t, this.a = this.b = null
|
|
}
|
|
|
|
function Ke(n, t, e, r) {
|
|
var i = new Ge(n, t);
|
|
return il.push(i), e && nr(i, n, t, e), r && nr(i, t, n, r), ul[n.i].edges.push(new tr(i, n, t)), ul[t.i].edges.push(new tr(i, t, n)), i
|
|
}
|
|
|
|
function Qe(n, t, e) {
|
|
var r = new Ge(n, null);
|
|
return r.a = t, r.b = e, il.push(r), r
|
|
}
|
|
|
|
function nr(n, t, e, r) {
|
|
n.a || n.b ? n.l === e ? n.b = r : n.a = r : (n.a = r, n.l = t, n.r = e)
|
|
}
|
|
|
|
function tr(n, t, e) {
|
|
var r = n.a,
|
|
i = n.b;
|
|
this.edge = n, this.site = t, this.angle = e ? Math.atan2(e.y - t.y, e.x - t.x) : n.l === t ? Math.atan2(i.x - r.x, r.y - i.y) : Math.atan2(r.x - i.x, i.y - r.y)
|
|
}
|
|
|
|
function er() {
|
|
this._ = null
|
|
}
|
|
|
|
function rr(n) {
|
|
n.U = n.C = n.L = n.R = n.P = n.N = null
|
|
}
|
|
|
|
function ir(n, t) {
|
|
var e = t,
|
|
r = t.R,
|
|
i = e.U;
|
|
i ? i.L === e ? i.L = r : i.R = r : n._ = r, r.U = i, e.U = r, e.R = r.L, e.R && (e.R.U = e), r.L = e
|
|
}
|
|
|
|
function ur(n, t) {
|
|
var e = t,
|
|
r = t.L,
|
|
i = e.U;
|
|
i ? i.L === e ? i.L = r : i.R = r : n._ = r, r.U = i, e.U = r, e.L = r.R, e.L && (e.L.U = e), r.R = e
|
|
}
|
|
|
|
function or(n) {
|
|
for (; n.L;) n = n.L;
|
|
return n
|
|
}
|
|
|
|
function ar(n, t) {
|
|
var e, r, i, u = n.sort(lr).pop();
|
|
for (il = [], ul = new Array(n.length), ol = new er, ll = new er;;)
|
|
if (i = al, u && (!i || u.y < i.y || u.y === i.y && u.x < i.x)) u.x === e && u.y === r || (ul[u.i] = new Ye(u), He(u), e = u.x, r = u.y), u = n.pop();
|
|
else {
|
|
if (!i) break;
|
|
Fe(i.arc)
|
|
}
|
|
t && (We(t), Ze(t));
|
|
var o = {
|
|
cells: ul,
|
|
edges: il
|
|
};
|
|
return ol = ll = il = ul = null, o
|
|
}
|
|
|
|
function lr(n, t) {
|
|
return t.y - n.y || t.x - n.x
|
|
}
|
|
|
|
function cr(n, t, e) {
|
|
return (n.x - e.x) * (t.y - n.y) - (n.x - t.x) * (e.y - n.y)
|
|
}
|
|
|
|
function fr(n) {
|
|
return n.x
|
|
}
|
|
|
|
function sr(n) {
|
|
return n.y
|
|
}
|
|
|
|
function hr() {
|
|
return {
|
|
leaf: !0,
|
|
nodes: [],
|
|
point: null,
|
|
x: null,
|
|
y: null
|
|
}
|
|
}
|
|
|
|
function pr(n, t, e, r, i, u) {
|
|
if (!n(t, e, r, i, u)) {
|
|
var o = .5 * (e + i),
|
|
a = .5 * (r + u),
|
|
l = t.nodes;
|
|
l[0] && pr(n, l[0], e, r, o, a), l[1] && pr(n, l[1], o, r, i, a), l[2] && pr(n, l[2], e, a, o, u), l[3] && pr(n, l[3], o, a, i, u)
|
|
}
|
|
}
|
|
|
|
function gr(n, t, e, r, i, u, o) {
|
|
var a, l = 1 / 0;
|
|
return function c(n, f, s, h, p) {
|
|
if (!(f > u || s > o || r > h || i > p)) {
|
|
if (g = n.point) {
|
|
var g, v = t - n.x,
|
|
d = e - n.y,
|
|
y = v * v + d * d;
|
|
if (l > y) {
|
|
var m = Math.sqrt(l = y);
|
|
r = t - m, i = e - m, u = t + m, o = e + m, a = g
|
|
}
|
|
}
|
|
for (var M = n.nodes, x = .5 * (f + h), b = .5 * (s + p), _ = t >= x, w = e >= b, S = w << 1 | _, k = S + 4; k > S; ++S)
|
|
if (n = M[3 & S]) switch (3 & S) {
|
|
case 0:
|
|
c(n, f, s, x, b);
|
|
break;
|
|
case 1:
|
|
c(n, x, s, h, b);
|
|
break;
|
|
case 2:
|
|
c(n, f, b, x, p);
|
|
break;
|
|
case 3:
|
|
c(n, x, b, h, p)
|
|
}
|
|
}
|
|
}(n, r, i, u, o), a
|
|
}
|
|
|
|
function vr(n, t) {
|
|
n = ao.rgb(n), t = ao.rgb(t);
|
|
var e = n.r,
|
|
r = n.g,
|
|
i = n.b,
|
|
u = t.r - e,
|
|
o = t.g - r,
|
|
a = t.b - i;
|
|
return function(n) {
|
|
return "#" + bn(Math.round(e + u * n)) + bn(Math.round(r + o * n)) + bn(Math.round(i + a * n))
|
|
}
|
|
}
|
|
|
|
function dr(n, t) {
|
|
var e, r = {},
|
|
i = {};
|
|
for (e in n) e in t ? r[e] = Mr(n[e], t[e]) : i[e] = n[e];
|
|
for (e in t) e in n || (i[e] = t[e]);
|
|
return function(n) {
|
|
for (e in r) i[e] = r[e](n);
|
|
return i
|
|
}
|
|
}
|
|
|
|
function yr(n, t) {
|
|
return n = +n, t = +t,
|
|
function(e) {
|
|
return n * (1 - e) + t * e
|
|
}
|
|
}
|
|
|
|
function mr(n, t) {
|
|
var e, r, i, u = hl.lastIndex = pl.lastIndex = 0,
|
|
o = -1,
|
|
a = [],
|
|
l = [];
|
|
for (n += "", t += "";
|
|
(e = hl.exec(n)) && (r = pl.exec(t));)(i = r.index) > u && (i = t.slice(u, i), a[o] ? a[o] += i : a[++o] = i), (e = e[0]) === (r = r[0]) ? a[o] ? a[o] += r : a[++o] = r : (a[++o] = null, l.push({
|
|
i: o,
|
|
x: yr(e, r)
|
|
})), u = pl.lastIndex;
|
|
return u < t.length && (i = t.slice(u), a[o] ? a[o] += i : a[++o] = i), a.length < 2 ? l[0] ? (t = l[0].x, function(n) {
|
|
return t(n) + ""
|
|
}) : function() {
|
|
return t
|
|
} : (t = l.length, function(n) {
|
|
for (var e, r = 0; t > r; ++r) a[(e = l[r]).i] = e.x(n);
|
|
return a.join("")
|
|
})
|
|
}
|
|
|
|
function Mr(n, t) {
|
|
for (var e, r = ao.interpolators.length; --r >= 0 && !(e = ao.interpolators[r](n, t)););
|
|
return e
|
|
}
|
|
|
|
function xr(n, t) {
|
|
var e, r = [],
|
|
i = [],
|
|
u = n.length,
|
|
o = t.length,
|
|
a = Math.min(n.length, t.length);
|
|
for (e = 0; a > e; ++e) r.push(Mr(n[e], t[e]));
|
|
for (; u > e; ++e) i[e] = n[e];
|
|
for (; o > e; ++e) i[e] = t[e];
|
|
return function(n) {
|
|
for (e = 0; a > e; ++e) i[e] = r[e](n);
|
|
return i
|
|
}
|
|
}
|
|
|
|
function br(n) {
|
|
return function(t) {
|
|
return 0 >= t ? 0 : t >= 1 ? 1 : n(t)
|
|
}
|
|
}
|
|
|
|
function _r(n) {
|
|
return function(t) {
|
|
return 1 - n(1 - t)
|
|
}
|
|
}
|
|
|
|
function wr(n) {
|
|
return function(t) {
|
|
return .5 * (.5 > t ? n(2 * t) : 2 - n(2 - 2 * t))
|
|
}
|
|
}
|
|
|
|
function Sr(n) {
|
|
return n * n
|
|
}
|
|
|
|
function kr(n) {
|
|
return n * n * n
|
|
}
|
|
|
|
function Nr(n) {
|
|
if (0 >= n) return 0;
|
|
if (n >= 1) return 1;
|
|
var t = n * n,
|
|
e = t * n;
|
|
return 4 * (.5 > n ? e : 3 * (n - t) + e - .75)
|
|
}
|
|
|
|
function Er(n) {
|
|
return function(t) {
|
|
return Math.pow(t, n)
|
|
}
|
|
}
|
|
|
|
function Ar(n) {
|
|
return 1 - Math.cos(n * Io)
|
|
}
|
|
|
|
function Cr(n) {
|
|
return Math.pow(2, 10 * (n - 1))
|
|
}
|
|
|
|
function zr(n) {
|
|
return 1 - Math.sqrt(1 - n * n)
|
|
}
|
|
|
|
function Lr(n, t) {
|
|
var e;
|
|
return arguments.length < 2 && (t = .45), arguments.length ? e = t / Ho * Math.asin(1 / n) : (n = 1, e = t / 4),
|
|
function(r) {
|
|
return 1 + n * Math.pow(2, -10 * r) * Math.sin((r - e) * Ho / t)
|
|
}
|
|
}
|
|
|
|
function qr(n) {
|
|
return n || (n = 1.70158),
|
|
function(t) {
|
|
return t * t * ((n + 1) * t - n)
|
|
}
|
|
}
|
|
|
|
function Tr(n) {
|
|
return 1 / 2.75 > n ? 7.5625 * n * n : 2 / 2.75 > n ? 7.5625 * (n -= 1.5 / 2.75) * n + .75 : 2.5 / 2.75 > n ? 7.5625 * (n -= 2.25 / 2.75) * n + .9375 : 7.5625 * (n -= 2.625 / 2.75) * n + .984375
|
|
}
|
|
|
|
function Rr(n, t) {
|
|
n = ao.hcl(n), t = ao.hcl(t);
|
|
var e = n.h,
|
|
r = n.c,
|
|
i = n.l,
|
|
u = t.h - e,
|
|
o = t.c - r,
|
|
a = t.l - i;
|
|
return isNaN(o) && (o = 0, r = isNaN(r) ? t.c : r), isNaN(u) ? (u = 0, e = isNaN(e) ? t.h : e) : u > 180 ? u -= 360 : -180 > u && (u += 360),
|
|
function(n) {
|
|
return sn(e + u * n, r + o * n, i + a * n) + ""
|
|
}
|
|
}
|
|
|
|
function Dr(n, t) {
|
|
n = ao.hsl(n), t = ao.hsl(t);
|
|
var e = n.h,
|
|
r = n.s,
|
|
i = n.l,
|
|
u = t.h - e,
|
|
o = t.s - r,
|
|
a = t.l - i;
|
|
return isNaN(o) && (o = 0, r = isNaN(r) ? t.s : r), isNaN(u) ? (u = 0, e = isNaN(e) ? t.h : e) : u > 180 ? u -= 360 : -180 > u && (u += 360),
|
|
function(n) {
|
|
return cn(e + u * n, r + o * n, i + a * n) + ""
|
|
}
|
|
}
|
|
|
|
function Pr(n, t) {
|
|
n = ao.lab(n), t = ao.lab(t);
|
|
var e = n.l,
|
|
r = n.a,
|
|
i = n.b,
|
|
u = t.l - e,
|
|
o = t.a - r,
|
|
a = t.b - i;
|
|
return function(n) {
|
|
return pn(e + u * n, r + o * n, i + a * n) + ""
|
|
}
|
|
}
|
|
|
|
function Ur(n, t) {
|
|
return t -= n,
|
|
function(e) {
|
|
return Math.round(n + t * e)
|
|
}
|
|
}
|
|
|
|
function jr(n) {
|
|
var t = [n.a, n.b],
|
|
e = [n.c, n.d],
|
|
r = Hr(t),
|
|
i = Fr(t, e),
|
|
u = Hr(Or(e, t, -i)) || 0;
|
|
t[0] * e[1] < e[0] * t[1] && (t[0] *= -1, t[1] *= -1, r *= -1, i *= -1), this.rotate = (r ? Math.atan2(t[1], t[0]) : Math.atan2(-e[0], e[1])) * Zo, this.translate = [n.e, n.f], this.scale = [r, u], this.skew = u ? Math.atan2(i, u) * Zo : 0
|
|
}
|
|
|
|
function Fr(n, t) {
|
|
return n[0] * t[0] + n[1] * t[1]
|
|
}
|
|
|
|
function Hr(n) {
|
|
var t = Math.sqrt(Fr(n, n));
|
|
return t && (n[0] /= t, n[1] /= t), t
|
|
}
|
|
|
|
function Or(n, t, e) {
|
|
return n[0] += e * t[0], n[1] += e * t[1], n
|
|
}
|
|
|
|
function Ir(n) {
|
|
return n.length ? n.pop() + "," : ""
|
|
}
|
|
|
|
function Yr(n, t, e, r) {
|
|
if (n[0] !== t[0] || n[1] !== t[1]) {
|
|
var i = e.push("translate(", null, ",", null, ")");
|
|
r.push({
|
|
i: i - 4,
|
|
x: yr(n[0], t[0])
|
|
}, {
|
|
i: i - 2,
|
|
x: yr(n[1], t[1])
|
|
})
|
|
} else(t[0] || t[1]) && e.push("translate(" + t + ")")
|
|
}
|
|
|
|
function Zr(n, t, e, r) {
|
|
n !== t ? (n - t > 180 ? t += 360 : t - n > 180 && (n += 360), r.push({
|
|
i: e.push(Ir(e) + "rotate(", null, ")") - 2,
|
|
x: yr(n, t)
|
|
})) : t && e.push(Ir(e) + "rotate(" + t + ")")
|
|
}
|
|
|
|
function Vr(n, t, e, r) {
|
|
n !== t ? r.push({
|
|
i: e.push(Ir(e) + "skewX(", null, ")") - 2,
|
|
x: yr(n, t)
|
|
}) : t && e.push(Ir(e) + "skewX(" + t + ")")
|
|
}
|
|
|
|
function Xr(n, t, e, r) {
|
|
if (n[0] !== t[0] || n[1] !== t[1]) {
|
|
var i = e.push(Ir(e) + "scale(", null, ",", null, ")");
|
|
r.push({
|
|
i: i - 4,
|
|
x: yr(n[0], t[0])
|
|
}, {
|
|
i: i - 2,
|
|
x: yr(n[1], t[1])
|
|
})
|
|
} else 1 === t[0] && 1 === t[1] || e.push(Ir(e) + "scale(" + t + ")")
|
|
}
|
|
|
|
function $r(n, t) {
|
|
var e = [],
|
|
r = [];
|
|
return n = ao.transform(n), t = ao.transform(t), Yr(n.translate, t.translate, e, r), Zr(n.rotate, t.rotate, e, r), Vr(n.skew, t.skew, e, r), Xr(n.scale, t.scale, e, r), n = t = null,
|
|
function(n) {
|
|
for (var t, i = -1, u = r.length; ++i < u;) e[(t = r[i]).i] = t.x(n);
|
|
return e.join("")
|
|
}
|
|
}
|
|
|
|
function Br(n, t) {
|
|
return t = (t -= n = +n) || 1 / t,
|
|
function(e) {
|
|
return (e - n) / t
|
|
}
|
|
}
|
|
|
|
function Wr(n, t) {
|
|
return t = (t -= n = +n) || 1 / t,
|
|
function(e) {
|
|
return Math.max(0, Math.min(1, (e - n) / t))
|
|
}
|
|
}
|
|
|
|
function Jr(n) {
|
|
for (var t = n.source, e = n.target, r = Kr(t, e), i = [t]; t !== r;) t = t.parent, i.push(t);
|
|
for (var u = i.length; e !== r;) i.splice(u, 0, e), e = e.parent;
|
|
return i
|
|
}
|
|
|
|
function Gr(n) {
|
|
for (var t = [], e = n.parent; null != e;) t.push(n), n = e, e = e.parent;
|
|
return t.push(n), t
|
|
}
|
|
|
|
function Kr(n, t) {
|
|
if (n === t) return n;
|
|
for (var e = Gr(n), r = Gr(t), i = e.pop(), u = r.pop(), o = null; i === u;) o = i, i = e.pop(), u = r.pop();
|
|
return o
|
|
}
|
|
|
|
function Qr(n) {
|
|
n.fixed |= 2
|
|
}
|
|
|
|
function ni(n) {
|
|
n.fixed &= -7
|
|
}
|
|
|
|
function ti(n) {
|
|
n.fixed |= 4, n.px = n.x, n.py = n.y
|
|
}
|
|
|
|
function ei(n) {
|
|
n.fixed &= -5
|
|
}
|
|
|
|
function ri(n, t, e) {
|
|
var r = 0,
|
|
i = 0;
|
|
if (n.charge = 0, !n.leaf)
|
|
for (var u, o = n.nodes, a = o.length, l = -1; ++l < a;) u = o[l], null != u && (ri(u, t, e), n.charge += u.charge, r += u.charge * u.cx, i += u.charge * u.cy);
|
|
if (n.point) {
|
|
n.leaf || (n.point.x += Math.random() - .5, n.point.y += Math.random() - .5);
|
|
var c = t * e[n.point.index];
|
|
n.charge += n.pointCharge = c, r += c * n.point.x, i += c * n.point.y
|
|
}
|
|
n.cx = r / n.charge, n.cy = i / n.charge
|
|
}
|
|
|
|
function ii(n, t) {
|
|
return ao.rebind(n, t, "sort", "children", "value"), n.nodes = n, n.links = fi, n
|
|
}
|
|
|
|
function ui(n, t) {
|
|
for (var e = [n]; null != (n = e.pop());)
|
|
if (t(n), (i = n.children) && (r = i.length))
|
|
for (var r, i; --r >= 0;) e.push(i[r])
|
|
}
|
|
|
|
function oi(n, t) {
|
|
for (var e = [n], r = []; null != (n = e.pop());)
|
|
if (r.push(n), (u = n.children) && (i = u.length))
|
|
for (var i, u, o = -1; ++o < i;) e.push(u[o]);
|
|
for (; null != (n = r.pop());) t(n)
|
|
}
|
|
|
|
function ai(n) {
|
|
return n.children
|
|
}
|
|
|
|
function li(n) {
|
|
return n.value
|
|
}
|
|
|
|
function ci(n, t) {
|
|
return t.value - n.value
|
|
}
|
|
|
|
function fi(n) {
|
|
return ao.merge(n.map(function(n) {
|
|
return (n.children || []).map(function(t) {
|
|
return {
|
|
source: n,
|
|
target: t
|
|
}
|
|
})
|
|
}))
|
|
}
|
|
|
|
function si(n) {
|
|
return n.x
|
|
}
|
|
|
|
function hi(n) {
|
|
return n.y
|
|
}
|
|
|
|
function pi(n, t, e) {
|
|
n.y0 = t, n.y = e
|
|
}
|
|
|
|
function gi(n) {
|
|
return ao.range(n.length)
|
|
}
|
|
|
|
function vi(n) {
|
|
for (var t = -1, e = n[0].length, r = []; ++t < e;) r[t] = 0;
|
|
return r
|
|
}
|
|
|
|
function di(n) {
|
|
for (var t, e = 1, r = 0, i = n[0][1], u = n.length; u > e; ++e)(t = n[e][1]) > i && (r = e, i = t);
|
|
return r
|
|
}
|
|
|
|
function yi(n) {
|
|
return n.reduce(mi, 0)
|
|
}
|
|
|
|
function mi(n, t) {
|
|
return n + t[1]
|
|
}
|
|
|
|
function Mi(n, t) {
|
|
return xi(n, Math.ceil(Math.log(t.length) / Math.LN2 + 1))
|
|
}
|
|
|
|
function xi(n, t) {
|
|
for (var e = -1, r = +n[0], i = (n[1] - r) / t, u = []; ++e <= t;) u[e] = i * e + r;
|
|
return u
|
|
}
|
|
|
|
function bi(n) {
|
|
return [ao.min(n), ao.max(n)]
|
|
}
|
|
|
|
function _i(n, t) {
|
|
return n.value - t.value
|
|
}
|
|
|
|
function wi(n, t) {
|
|
var e = n._pack_next;
|
|
n._pack_next = t, t._pack_prev = n, t._pack_next = e, e._pack_prev = t
|
|
}
|
|
|
|
function Si(n, t) {
|
|
n._pack_next = t, t._pack_prev = n
|
|
}
|
|
|
|
function ki(n, t) {
|
|
var e = t.x - n.x,
|
|
r = t.y - n.y,
|
|
i = n.r + t.r;
|
|
return .999 * i * i > e * e + r * r
|
|
}
|
|
|
|
function Ni(n) {
|
|
function t(n) {
|
|
f = Math.min(n.x - n.r, f), s = Math.max(n.x + n.r, s), h = Math.min(n.y - n.r, h), p = Math.max(n.y + n.r, p)
|
|
}
|
|
if ((e = n.children) && (c = e.length)) {
|
|
var e, r, i, u, o, a, l, c, f = 1 / 0,
|
|
s = -(1 / 0),
|
|
h = 1 / 0,
|
|
p = -(1 / 0);
|
|
if (e.forEach(Ei), r = e[0], r.x = -r.r, r.y = 0, t(r), c > 1 && (i = e[1], i.x = i.r, i.y = 0, t(i), c > 2))
|
|
for (u = e[2], zi(r, i, u), t(u), wi(r, u), r._pack_prev = u, wi(u, i), i = r._pack_next, o = 3; c > o; o++) {
|
|
zi(r, i, u = e[o]);
|
|
var g = 0,
|
|
v = 1,
|
|
d = 1;
|
|
for (a = i._pack_next; a !== i; a = a._pack_next, v++)
|
|
if (ki(a, u)) {
|
|
g = 1;
|
|
break
|
|
}
|
|
if (1 == g)
|
|
for (l = r._pack_prev; l !== a._pack_prev && !ki(l, u); l = l._pack_prev, d++);
|
|
g ? (d > v || v == d && i.r < r.r ? Si(r, i = a) : Si(r = l, i), o--) : (wi(r, u), i = u, t(u))
|
|
}
|
|
var y = (f + s) / 2,
|
|
m = (h + p) / 2,
|
|
M = 0;
|
|
for (o = 0; c > o; o++) u = e[o], u.x -= y, u.y -= m, M = Math.max(M, u.r + Math.sqrt(u.x * u.x + u.y * u.y));
|
|
n.r = M, e.forEach(Ai)
|
|
}
|
|
}
|
|
|
|
function Ei(n) {
|
|
n._pack_next = n._pack_prev = n
|
|
}
|
|
|
|
function Ai(n) {
|
|
delete n._pack_next, delete n._pack_prev
|
|
}
|
|
|
|
function Ci(n, t, e, r) {
|
|
var i = n.children;
|
|
if (n.x = t += r * n.x, n.y = e += r * n.y, n.r *= r, i)
|
|
for (var u = -1, o = i.length; ++u < o;) Ci(i[u], t, e, r)
|
|
}
|
|
|
|
function zi(n, t, e) {
|
|
var r = n.r + e.r,
|
|
i = t.x - n.x,
|
|
u = t.y - n.y;
|
|
if (r && (i || u)) {
|
|
var o = t.r + e.r,
|
|
a = i * i + u * u;
|
|
o *= o, r *= r;
|
|
var l = .5 + (r - o) / (2 * a),
|
|
c = Math.sqrt(Math.max(0, 2 * o * (r + a) - (r -= a) * r - o * o)) / (2 * a);
|
|
e.x = n.x + l * i + c * u, e.y = n.y + l * u - c * i
|
|
} else e.x = n.x + r, e.y = n.y
|
|
}
|
|
|
|
function Li(n, t) {
|
|
return n.parent == t.parent ? 1 : 2
|
|
}
|
|
|
|
function qi(n) {
|
|
var t = n.children;
|
|
return t.length ? t[0] : n.t
|
|
}
|
|
|
|
function Ti(n) {
|
|
var t, e = n.children;
|
|
return (t = e.length) ? e[t - 1] : n.t
|
|
}
|
|
|
|
function Ri(n, t, e) {
|
|
var r = e / (t.i - n.i);
|
|
t.c -= r, t.s += e, n.c += r, t.z += e, t.m += e
|
|
}
|
|
|
|
function Di(n) {
|
|
for (var t, e = 0, r = 0, i = n.children, u = i.length; --u >= 0;) t = i[u], t.z += e, t.m += e, e += t.s + (r += t.c)
|
|
}
|
|
|
|
function Pi(n, t, e) {
|
|
return n.a.parent === t.parent ? n.a : e
|
|
}
|
|
|
|
function Ui(n) {
|
|
return 1 + ao.max(n, function(n) {
|
|
return n.y
|
|
})
|
|
}
|
|
|
|
function ji(n) {
|
|
return n.reduce(function(n, t) {
|
|
return n + t.x
|
|
}, 0) / n.length
|
|
}
|
|
|
|
function Fi(n) {
|
|
var t = n.children;
|
|
return t && t.length ? Fi(t[0]) : n
|
|
}
|
|
|
|
function Hi(n) {
|
|
var t, e = n.children;
|
|
return e && (t = e.length) ? Hi(e[t - 1]) : n
|
|
}
|
|
|
|
function Oi(n) {
|
|
return {
|
|
x: n.x,
|
|
y: n.y,
|
|
dx: n.dx,
|
|
dy: n.dy
|
|
}
|
|
}
|
|
|
|
function Ii(n, t) {
|
|
var e = n.x + t[3],
|
|
r = n.y + t[0],
|
|
i = n.dx - t[1] - t[3],
|
|
u = n.dy - t[0] - t[2];
|
|
return 0 > i && (e += i / 2, i = 0), 0 > u && (r += u / 2, u = 0), {
|
|
x: e,
|
|
y: r,
|
|
dx: i,
|
|
dy: u
|
|
}
|
|
}
|
|
|
|
function Yi(n) {
|
|
var t = n[0],
|
|
e = n[n.length - 1];
|
|
return e > t ? [t, e] : [e, t]
|
|
}
|
|
|
|
function Zi(n) {
|
|
return n.rangeExtent ? n.rangeExtent() : Yi(n.range())
|
|
}
|
|
|
|
function Vi(n, t, e, r) {
|
|
var i = e(n[0], n[1]),
|
|
u = r(t[0], t[1]);
|
|
return function(n) {
|
|
return u(i(n))
|
|
}
|
|
}
|
|
|
|
function Xi(n, t) {
|
|
var e, r = 0,
|
|
i = n.length - 1,
|
|
u = n[r],
|
|
o = n[i];
|
|
return u > o && (e = r, r = i, i = e, e = u, u = o, o = e), n[r] = t.floor(u), n[i] = t.ceil(o), n
|
|
}
|
|
|
|
function $i(n) {
|
|
return n ? {
|
|
floor: function(t) {
|
|
return Math.floor(t / n) * n
|
|
},
|
|
ceil: function(t) {
|
|
return Math.ceil(t / n) * n
|
|
}
|
|
} : Sl
|
|
}
|
|
|
|
function Bi(n, t, e, r) {
|
|
var i = [],
|
|
u = [],
|
|
o = 0,
|
|
a = Math.min(n.length, t.length) - 1;
|
|
for (n[a] < n[0] && (n = n.slice().reverse(), t = t.slice().reverse()); ++o <= a;) i.push(e(n[o - 1], n[o])), u.push(r(t[o - 1], t[o]));
|
|
return function(t) {
|
|
var e = ao.bisect(n, t, 1, a) - 1;
|
|
return u[e](i[e](t))
|
|
}
|
|
}
|
|
|
|
function Wi(n, t, e, r) {
|
|
function i() {
|
|
var i = Math.min(n.length, t.length) > 2 ? Bi : Vi,
|
|
l = r ? Wr : Br;
|
|
return o = i(n, t, l, e), a = i(t, n, l, Mr), u
|
|
}
|
|
|
|
function u(n) {
|
|
return o(n)
|
|
}
|
|
var o, a;
|
|
return u.invert = function(n) {
|
|
return a(n)
|
|
}, u.domain = function(t) {
|
|
return arguments.length ? (n = t.map(Number), i()) : n
|
|
}, u.range = function(n) {
|
|
return arguments.length ? (t = n, i()) : t
|
|
}, u.rangeRound = function(n) {
|
|
return u.range(n).interpolate(Ur)
|
|
}, u.clamp = function(n) {
|
|
return arguments.length ? (r = n, i()) : r
|
|
}, u.interpolate = function(n) {
|
|
return arguments.length ? (e = n, i()) : e
|
|
}, u.ticks = function(t) {
|
|
return Qi(n, t)
|
|
}, u.tickFormat = function(t, e) {
|
|
return nu(n, t, e)
|
|
}, u.nice = function(t) {
|
|
return Gi(n, t), i()
|
|
}, u.copy = function() {
|
|
return Wi(n, t, e, r)
|
|
}, i()
|
|
}
|
|
|
|
function Ji(n, t) {
|
|
return ao.rebind(n, t, "range", "rangeRound", "interpolate", "clamp")
|
|
}
|
|
|
|
function Gi(n, t) {
|
|
return Xi(n, $i(Ki(n, t)[2])), Xi(n, $i(Ki(n, t)[2])), n
|
|
}
|
|
|
|
function Ki(n, t) {
|
|
null == t && (t = 10);
|
|
var e = Yi(n),
|
|
r = e[1] - e[0],
|
|
i = Math.pow(10, Math.floor(Math.log(r / t) / Math.LN10)),
|
|
u = t / r * i;
|
|
return .15 >= u ? i *= 10 : .35 >= u ? i *= 5 : .75 >= u && (i *= 2), e[0] = Math.ceil(e[0] / i) * i, e[1] = Math.floor(e[1] / i) * i + .5 * i, e[2] = i, e
|
|
}
|
|
|
|
function Qi(n, t) {
|
|
return ao.range.apply(ao, Ki(n, t))
|
|
}
|
|
|
|
function nu(n, t, e) {
|
|
var r = Ki(n, t);
|
|
if (e) {
|
|
var i = ha.exec(e);
|
|
if (i.shift(), "s" === i[8]) {
|
|
var u = ao.formatPrefix(Math.max(xo(r[0]), xo(r[1])));
|
|
return i[7] || (i[7] = "." + tu(u.scale(r[2]))), i[8] = "f", e = ao.format(i.join("")),
|
|
function(n) {
|
|
return e(u.scale(n)) + u.symbol
|
|
}
|
|
}
|
|
i[7] || (i[7] = "." + eu(i[8], r)), e = i.join("")
|
|
} else e = ",." + tu(r[2]) + "f";
|
|
return ao.format(e)
|
|
}
|
|
|
|
function tu(n) {
|
|
return -Math.floor(Math.log(n) / Math.LN10 + .01)
|
|
}
|
|
|
|
function eu(n, t) {
|
|
var e = tu(t[2]);
|
|
return n in kl ? Math.abs(e - tu(Math.max(xo(t[0]), xo(t[1])))) + +("e" !== n) : e - 2 * ("%" === n)
|
|
}
|
|
|
|
function ru(n, t, e, r) {
|
|
function i(n) {
|
|
return (e ? Math.log(0 > n ? 0 : n) : -Math.log(n > 0 ? 0 : -n)) / Math.log(t)
|
|
}
|
|
|
|
function u(n) {
|
|
return e ? Math.pow(t, n) : -Math.pow(t, -n)
|
|
}
|
|
|
|
function o(t) {
|
|
return n(i(t))
|
|
}
|
|
return o.invert = function(t) {
|
|
return u(n.invert(t))
|
|
}, o.domain = function(t) {
|
|
return arguments.length ? (e = t[0] >= 0, n.domain((r = t.map(Number)).map(i)), o) : r
|
|
}, o.base = function(e) {
|
|
return arguments.length ? (t = +e, n.domain(r.map(i)), o) : t
|
|
}, o.nice = function() {
|
|
var t = Xi(r.map(i), e ? Math : El);
|
|
return n.domain(t), r = t.map(u), o
|
|
}, o.ticks = function() {
|
|
var n = Yi(r),
|
|
o = [],
|
|
a = n[0],
|
|
l = n[1],
|
|
c = Math.floor(i(a)),
|
|
f = Math.ceil(i(l)),
|
|
s = t % 1 ? 2 : t;
|
|
if (isFinite(f - c)) {
|
|
if (e) {
|
|
for (; f > c; c++)
|
|
for (var h = 1; s > h; h++) o.push(u(c) * h);
|
|
o.push(u(c))
|
|
} else
|
|
for (o.push(u(c)); c++ < f;)
|
|
for (var h = s - 1; h > 0; h--) o.push(u(c) * h);
|
|
for (c = 0; o[c] < a; c++);
|
|
for (f = o.length; o[f - 1] > l; f--);
|
|
o = o.slice(c, f)
|
|
}
|
|
return o
|
|
}, o.tickFormat = function(n, e) {
|
|
if (!arguments.length) return Nl;
|
|
arguments.length < 2 ? e = Nl : "function" != typeof e && (e = ao.format(e));
|
|
var r = Math.max(1, t * n / o.ticks().length);
|
|
return function(n) {
|
|
var o = n / u(Math.round(i(n)));
|
|
return t - .5 > o * t && (o *= t), r >= o ? e(n) : ""
|
|
}
|
|
}, o.copy = function() {
|
|
return ru(n.copy(), t, e, r)
|
|
}, Ji(o, n)
|
|
}
|
|
|
|
function iu(n, t, e) {
|
|
function r(t) {
|
|
return n(i(t))
|
|
}
|
|
var i = uu(t),
|
|
u = uu(1 / t);
|
|
return r.invert = function(t) {
|
|
return u(n.invert(t))
|
|
}, r.domain = function(t) {
|
|
return arguments.length ? (n.domain((e = t.map(Number)).map(i)), r) : e
|
|
}, r.ticks = function(n) {
|
|
return Qi(e, n)
|
|
}, r.tickFormat = function(n, t) {
|
|
return nu(e, n, t)
|
|
}, r.nice = function(n) {
|
|
return r.domain(Gi(e, n))
|
|
}, r.exponent = function(o) {
|
|
return arguments.length ? (i = uu(t = o), u = uu(1 / t), n.domain(e.map(i)), r) : t
|
|
}, r.copy = function() {
|
|
return iu(n.copy(), t, e)
|
|
}, Ji(r, n)
|
|
}
|
|
|
|
function uu(n) {
|
|
return function(t) {
|
|
return 0 > t ? -Math.pow(-t, n) : Math.pow(t, n)
|
|
}
|
|
}
|
|
|
|
function ou(n, t) {
|
|
function e(e) {
|
|
return u[((i.get(e) || ("range" === t.t ? i.set(e, n.push(e)) : NaN)) - 1) % u.length]
|
|
}
|
|
|
|
function r(t, e) {
|
|
return ao.range(n.length).map(function(n) {
|
|
return t + e * n
|
|
})
|
|
}
|
|
var i, u, o;
|
|
return e.domain = function(r) {
|
|
if (!arguments.length) return n;
|
|
n = [], i = new c;
|
|
for (var u, o = -1, a = r.length; ++o < a;) i.has(u = r[o]) || i.set(u, n.push(u));
|
|
return e[t.t].apply(e, t.a)
|
|
}, e.range = function(n) {
|
|
return arguments.length ? (u = n, o = 0, t = {
|
|
t: "range",
|
|
a: arguments
|
|
}, e) : u
|
|
}, e.rangePoints = function(i, a) {
|
|
arguments.length < 2 && (a = 0);
|
|
var l = i[0],
|
|
c = i[1],
|
|
f = n.length < 2 ? (l = (l + c) / 2, 0) : (c - l) / (n.length - 1 + a);
|
|
return u = r(l + f * a / 2, f), o = 0, t = {
|
|
t: "rangePoints",
|
|
a: arguments
|
|
}, e
|
|
}, e.rangeRoundPoints = function(i, a) {
|
|
arguments.length < 2 && (a = 0);
|
|
var l = i[0],
|
|
c = i[1],
|
|
f = n.length < 2 ? (l = c = Math.round((l + c) / 2), 0) : (c - l) / (n.length - 1 + a) | 0;
|
|
return u = r(l + Math.round(f * a / 2 + (c - l - (n.length - 1 + a) * f) / 2), f), o = 0, t = {
|
|
t: "rangeRoundPoints",
|
|
a: arguments
|
|
}, e
|
|
}, e.rangeBands = function(i, a, l) {
|
|
arguments.length < 2 && (a = 0), arguments.length < 3 && (l = a);
|
|
var c = i[1] < i[0],
|
|
f = i[c - 0],
|
|
s = i[1 - c],
|
|
h = (s - f) / (n.length - a + 2 * l);
|
|
return u = r(f + h * l, h), c && u.reverse(), o = h * (1 - a), t = {
|
|
t: "rangeBands",
|
|
a: arguments
|
|
}, e
|
|
}, e.rangeRoundBands = function(i, a, l) {
|
|
arguments.length < 2 && (a = 0), arguments.length < 3 && (l = a);
|
|
var c = i[1] < i[0],
|
|
f = i[c - 0],
|
|
s = i[1 - c],
|
|
h = Math.floor((s - f) / (n.length - a + 2 * l));
|
|
return u = r(f + Math.round((s - f - (n.length - a) * h) / 2), h), c && u.reverse(), o = Math.round(h * (1 - a)), t = {
|
|
t: "rangeRoundBands",
|
|
a: arguments
|
|
}, e
|
|
}, e.rangeBand = function() {
|
|
return o
|
|
}, e.rangeExtent = function() {
|
|
return Yi(t.a[0])
|
|
}, e.copy = function() {
|
|
return ou(n, t)
|
|
}, e.domain(n)
|
|
}
|
|
|
|
function au(n, t) {
|
|
function u() {
|
|
var e = 0,
|
|
r = t.length;
|
|
for (a = []; ++e < r;) a[e - 1] = ao.quantile(n, e / r);
|
|
return o
|
|
}
|
|
|
|
function o(n) {
|
|
return isNaN(n = +n) ? void 0 : t[ao.bisect(a, n)]
|
|
}
|
|
var a;
|
|
return o.domain = function(t) {
|
|
return arguments.length ? (n = t.map(r).filter(i).sort(e), u()) : n
|
|
}, o.range = function(n) {
|
|
return arguments.length ? (t = n, u()) : t
|
|
}, o.quantiles = function() {
|
|
return a
|
|
}, o.invertExtent = function(e) {
|
|
return e = t.indexOf(e), 0 > e ? [NaN, NaN] : [e > 0 ? a[e - 1] : n[0], e < a.length ? a[e] : n[n.length - 1]]
|
|
}, o.copy = function() {
|
|
return au(n, t)
|
|
}, u()
|
|
}
|
|
|
|
function lu(n, t, e) {
|
|
function r(t) {
|
|
return e[Math.max(0, Math.min(o, Math.floor(u * (t - n))))]
|
|
}
|
|
|
|
function i() {
|
|
return u = e.length / (t - n), o = e.length - 1, r
|
|
}
|
|
var u, o;
|
|
return r.domain = function(e) {
|
|
return arguments.length ? (n = +e[0], t = +e[e.length - 1], i()) : [n, t]
|
|
}, r.range = function(n) {
|
|
return arguments.length ? (e = n, i()) : e
|
|
}, r.invertExtent = function(t) {
|
|
return t = e.indexOf(t), t = 0 > t ? NaN : t / u + n, [t, t + 1 / u]
|
|
}, r.copy = function() {
|
|
return lu(n, t, e)
|
|
}, i()
|
|
}
|
|
|
|
function cu(n, t) {
|
|
function e(e) {
|
|
return e >= e ? t[ao.bisect(n, e)] : void 0
|
|
}
|
|
return e.domain = function(t) {
|
|
return arguments.length ? (n = t, e) : n
|
|
}, e.range = function(n) {
|
|
return arguments.length ? (t = n, e) : t
|
|
}, e.invertExtent = function(e) {
|
|
return e = t.indexOf(e), [n[e - 1], n[e]]
|
|
}, e.copy = function() {
|
|
return cu(n, t)
|
|
}, e
|
|
}
|
|
|
|
function fu(n) {
|
|
function t(n) {
|
|
return +n
|
|
}
|
|
return t.invert = t, t.domain = t.range = function(e) {
|
|
return arguments.length ? (n = e.map(t), t) : n
|
|
}, t.ticks = function(t) {
|
|
return Qi(n, t)
|
|
}, t.tickFormat = function(t, e) {
|
|
return nu(n, t, e)
|
|
}, t.copy = function() {
|
|
return fu(n)
|
|
}, t
|
|
}
|
|
|
|
function su() {
|
|
return 0
|
|
}
|
|
|
|
function hu(n) {
|
|
return n.innerRadius
|
|
}
|
|
|
|
function pu(n) {
|
|
return n.outerRadius
|
|
}
|
|
|
|
function gu(n) {
|
|
return n.startAngle
|
|
}
|
|
|
|
function vu(n) {
|
|
return n.endAngle
|
|
}
|
|
|
|
function du(n) {
|
|
return n && n.padAngle
|
|
}
|
|
|
|
function yu(n, t, e, r) {
|
|
return (n - e) * t - (t - r) * n > 0 ? 0 : 1
|
|
}
|
|
|
|
function mu(n, t, e, r, i) {
|
|
var u = n[0] - t[0],
|
|
o = n[1] - t[1],
|
|
a = (i ? r : -r) / Math.sqrt(u * u + o * o),
|
|
l = a * o,
|
|
c = -a * u,
|
|
f = n[0] + l,
|
|
s = n[1] + c,
|
|
h = t[0] + l,
|
|
p = t[1] + c,
|
|
g = (f + h) / 2,
|
|
v = (s + p) / 2,
|
|
d = h - f,
|
|
y = p - s,
|
|
m = d * d + y * y,
|
|
M = e - r,
|
|
x = f * p - h * s,
|
|
b = (0 > y ? -1 : 1) * Math.sqrt(Math.max(0, M * M * m - x * x)),
|
|
_ = (x * y - d * b) / m,
|
|
w = (-x * d - y * b) / m,
|
|
S = (x * y + d * b) / m,
|
|
k = (-x * d + y * b) / m,
|
|
N = _ - g,
|
|
E = w - v,
|
|
A = S - g,
|
|
C = k - v;
|
|
return N * N + E * E > A * A + C * C && (_ = S, w = k), [
|
|
[_ - l, w - c],
|
|
[_ * e / M, w * e / M]
|
|
]
|
|
}
|
|
|
|
function Mu(n) {
|
|
function t(t) {
|
|
function o() {
|
|
c.push("M", u(n(f), a))
|
|
}
|
|
for (var l, c = [], f = [], s = -1, h = t.length, p = En(e), g = En(r); ++s < h;) i.call(this, l = t[s], s) ? f.push([+p.call(this, l, s), +g.call(this, l, s)]) : f.length && (o(), f = []);
|
|
return f.length && o(), c.length ? c.join("") : null
|
|
}
|
|
var e = Ce,
|
|
r = ze,
|
|
i = zt,
|
|
u = xu,
|
|
o = u.key,
|
|
a = .7;
|
|
return t.x = function(n) {
|
|
return arguments.length ? (e = n, t) : e
|
|
}, t.y = function(n) {
|
|
return arguments.length ? (r = n, t) : r
|
|
}, t.defined = function(n) {
|
|
return arguments.length ? (i = n, t) : i
|
|
}, t.interpolate = function(n) {
|
|
return arguments.length ? (o = "function" == typeof n ? u = n : (u = Tl.get(n) || xu).key, t) : o
|
|
}, t.tension = function(n) {
|
|
return arguments.length ? (a = n, t) : a
|
|
}, t
|
|
}
|
|
|
|
function xu(n) {
|
|
return n.length > 1 ? n.join("L") : n + "Z"
|
|
}
|
|
|
|
function bu(n) {
|
|
return n.join("L") + "Z"
|
|
}
|
|
|
|
function _u(n) {
|
|
for (var t = 0, e = n.length, r = n[0], i = [r[0], ",", r[1]]; ++t < e;) i.push("H", (r[0] + (r = n[t])[0]) / 2, "V", r[1]);
|
|
return e > 1 && i.push("H", r[0]), i.join("")
|
|
}
|
|
|
|
function wu(n) {
|
|
for (var t = 0, e = n.length, r = n[0], i = [r[0], ",", r[1]]; ++t < e;) i.push("V", (r = n[t])[1], "H", r[0]);
|
|
return i.join("")
|
|
}
|
|
|
|
function Su(n) {
|
|
for (var t = 0, e = n.length, r = n[0], i = [r[0], ",", r[1]]; ++t < e;) i.push("H", (r = n[t])[0], "V", r[1]);
|
|
return i.join("")
|
|
}
|
|
|
|
function ku(n, t) {
|
|
return n.length < 4 ? xu(n) : n[1] + Au(n.slice(1, -1), Cu(n, t))
|
|
}
|
|
|
|
function Nu(n, t) {
|
|
return n.length < 3 ? bu(n) : n[0] + Au((n.push(n[0]), n), Cu([n[n.length - 2]].concat(n, [n[1]]), t))
|
|
}
|
|
|
|
function Eu(n, t) {
|
|
return n.length < 3 ? xu(n) : n[0] + Au(n, Cu(n, t))
|
|
}
|
|
|
|
function Au(n, t) {
|
|
if (t.length < 1 || n.length != t.length && n.length != t.length + 2) return xu(n);
|
|
var e = n.length != t.length,
|
|
r = "",
|
|
i = n[0],
|
|
u = n[1],
|
|
o = t[0],
|
|
a = o,
|
|
l = 1;
|
|
if (e && (r += "Q" + (u[0] - 2 * o[0] / 3) + "," + (u[1] - 2 * o[1] / 3) + "," + u[0] + "," + u[1], i = n[1], l = 2), t.length > 1) {
|
|
a = t[1], u = n[l], l++, r += "C" + (i[0] + o[0]) + "," + (i[1] + o[1]) + "," + (u[0] - a[0]) + "," + (u[1] - a[1]) + "," + u[0] + "," + u[1];
|
|
for (var c = 2; c < t.length; c++, l++) u = n[l], a = t[c], r += "S" + (u[0] - a[0]) + "," + (u[1] - a[1]) + "," + u[0] + "," + u[1]
|
|
}
|
|
if (e) {
|
|
var f = n[l];
|
|
r += "Q" + (u[0] + 2 * a[0] / 3) + "," + (u[1] + 2 * a[1] / 3) + "," + f[0] + "," + f[1]
|
|
}
|
|
return r
|
|
}
|
|
|
|
function Cu(n, t) {
|
|
for (var e, r = [], i = (1 - t) / 2, u = n[0], o = n[1], a = 1, l = n.length; ++a < l;) e = u, u = o, o = n[a], r.push([i * (o[0] - e[0]), i * (o[1] - e[1])]);
|
|
return r
|
|
}
|
|
|
|
function zu(n) {
|
|
if (n.length < 3) return xu(n);
|
|
var t = 1,
|
|
e = n.length,
|
|
r = n[0],
|
|
i = r[0],
|
|
u = r[1],
|
|
o = [i, i, i, (r = n[1])[0]],
|
|
a = [u, u, u, r[1]],
|
|
l = [i, ",", u, "L", Ru(Pl, o), ",", Ru(Pl, a)];
|
|
for (n.push(n[e - 1]); ++t <= e;) r = n[t], o.shift(), o.push(r[0]), a.shift(), a.push(r[1]), Du(l, o, a);
|
|
return n.pop(), l.push("L", r), l.join("")
|
|
}
|
|
|
|
function Lu(n) {
|
|
if (n.length < 4) return xu(n);
|
|
for (var t, e = [], r = -1, i = n.length, u = [0], o = [0]; ++r < 3;) t = n[r], u.push(t[0]), o.push(t[1]);
|
|
for (e.push(Ru(Pl, u) + "," + Ru(Pl, o)), --r; ++r < i;) t = n[r], u.shift(), u.push(t[0]), o.shift(), o.push(t[1]), Du(e, u, o);
|
|
return e.join("")
|
|
}
|
|
|
|
function qu(n) {
|
|
for (var t, e, r = -1, i = n.length, u = i + 4, o = [], a = []; ++r < 4;) e = n[r % i], o.push(e[0]), a.push(e[1]);
|
|
for (t = [Ru(Pl, o), ",", Ru(Pl, a)], --r; ++r < u;) e = n[r % i], o.shift(), o.push(e[0]), a.shift(), a.push(e[1]), Du(t, o, a);
|
|
return t.join("")
|
|
}
|
|
|
|
function Tu(n, t) {
|
|
var e = n.length - 1;
|
|
if (e)
|
|
for (var r, i, u = n[0][0], o = n[0][1], a = n[e][0] - u, l = n[e][1] - o, c = -1; ++c <= e;) r = n[c], i = c / e, r[0] = t * r[0] + (1 - t) * (u + i * a), r[1] = t * r[1] + (1 - t) * (o + i * l);
|
|
return zu(n)
|
|
}
|
|
|
|
function Ru(n, t) {
|
|
return n[0] * t[0] + n[1] * t[1] + n[2] * t[2] + n[3] * t[3]
|
|
}
|
|
|
|
function Du(n, t, e) {
|
|
n.push("C", Ru(Rl, t), ",", Ru(Rl, e), ",", Ru(Dl, t), ",", Ru(Dl, e), ",", Ru(Pl, t), ",", Ru(Pl, e))
|
|
}
|
|
|
|
function Pu(n, t) {
|
|
return (t[1] - n[1]) / (t[0] - n[0])
|
|
}
|
|
|
|
function Uu(n) {
|
|
for (var t = 0, e = n.length - 1, r = [], i = n[0], u = n[1], o = r[0] = Pu(i, u); ++t < e;) r[t] = (o + (o = Pu(i = u, u = n[t + 1]))) / 2;
|
|
return r[t] = o, r
|
|
}
|
|
|
|
function ju(n) {
|
|
for (var t, e, r, i, u = [], o = Uu(n), a = -1, l = n.length - 1; ++a < l;) t = Pu(n[a], n[a + 1]), xo(t) < Uo ? o[a] = o[a + 1] = 0 : (e = o[a] / t, r = o[a + 1] / t, i = e * e + r * r, i > 9 && (i = 3 * t / Math.sqrt(i), o[a] = i * e, o[a + 1] = i * r));
|
|
for (a = -1; ++a <= l;) i = (n[Math.min(l, a + 1)][0] - n[Math.max(0, a - 1)][0]) / (6 * (1 + o[a] * o[a])), u.push([i || 0, o[a] * i || 0]);
|
|
return u
|
|
}
|
|
|
|
function Fu(n) {
|
|
return n.length < 3 ? xu(n) : n[0] + Au(n, ju(n))
|
|
}
|
|
|
|
function Hu(n) {
|
|
for (var t, e, r, i = -1, u = n.length; ++i < u;) t = n[i], e = t[0], r = t[1] - Io, t[0] = e * Math.cos(r), t[1] = e * Math.sin(r);
|
|
return n
|
|
}
|
|
|
|
function Ou(n) {
|
|
function t(t) {
|
|
function l() {
|
|
v.push("M", a(n(y), s), f, c(n(d.reverse()), s), "Z")
|
|
}
|
|
for (var h, p, g, v = [], d = [], y = [], m = -1, M = t.length, x = En(e), b = En(i), _ = e === r ? function() {
|
|
return p
|
|
} : En(r), w = i === u ? function() {
|
|
return g
|
|
} : En(u); ++m < M;) o.call(this, h = t[m], m) ? (d.push([p = +x.call(this, h, m), g = +b.call(this, h, m)]), y.push([+_.call(this, h, m), +w.call(this, h, m)])) : d.length && (l(), d = [], y = []);
|
|
return d.length && l(), v.length ? v.join("") : null
|
|
}
|
|
var e = Ce,
|
|
r = Ce,
|
|
i = 0,
|
|
u = ze,
|
|
o = zt,
|
|
a = xu,
|
|
l = a.key,
|
|
c = a,
|
|
f = "L",
|
|
s = .7;
|
|
return t.x = function(n) {
|
|
return arguments.length ? (e = r = n, t) : r
|
|
}, t.x0 = function(n) {
|
|
return arguments.length ? (e = n, t) : e
|
|
}, t.x1 = function(n) {
|
|
return arguments.length ? (r = n, t) : r
|
|
}, t.y = function(n) {
|
|
return arguments.length ? (i = u = n, t) : u
|
|
}, t.y0 = function(n) {
|
|
return arguments.length ? (i = n, t) : i
|
|
}, t.y1 = function(n) {
|
|
return arguments.length ? (u = n, t) : u
|
|
}, t.defined = function(n) {
|
|
return arguments.length ? (o = n, t) : o
|
|
}, t.interpolate = function(n) {
|
|
return arguments.length ? (l = "function" == typeof n ? a = n : (a = Tl.get(n) || xu).key, c = a.reverse || a, f = a.closed ? "M" : "L", t) : l
|
|
}, t.tension = function(n) {
|
|
return arguments.length ? (s = n, t) : s
|
|
}, t
|
|
}
|
|
|
|
function Iu(n) {
|
|
return n.radius
|
|
}
|
|
|
|
function Yu(n) {
|
|
return [n.x, n.y]
|
|
}
|
|
|
|
function Zu(n) {
|
|
return function() {
|
|
var t = n.apply(this, arguments),
|
|
e = t[0],
|
|
r = t[1] - Io;
|
|
return [e * Math.cos(r), e * Math.sin(r)]
|
|
}
|
|
}
|
|
|
|
function Vu() {
|
|
return 64
|
|
}
|
|
|
|
function Xu() {
|
|
return "circle"
|
|
}
|
|
|
|
function $u(n) {
|
|
var t = Math.sqrt(n / Fo);
|
|
return "M0," + t + "A" + t + "," + t + " 0 1,1 0," + -t + "A" + t + "," + t + " 0 1,1 0," + t + "Z"
|
|
}
|
|
|
|
function Bu(n) {
|
|
return function() {
|
|
var t, e, r;
|
|
(t = this[n]) && (r = t[e = t.active]) && (r.timer.c = null, r.timer.t = NaN, --t.count ? delete t[e] : delete this[n], t.active += .5, r.event && r.event.interrupt.call(this, this.__data__, r.index))
|
|
}
|
|
}
|
|
|
|
function Wu(n, t, e) {
|
|
return ko(n, Yl), n.namespace = t, n.id = e, n
|
|
}
|
|
|
|
function Ju(n, t, e, r) {
|
|
var i = n.id,
|
|
u = n.namespace;
|
|
return Y(n, "function" == typeof e ? function(n, o, a) {
|
|
n[u][i].tween.set(t, r(e.call(n, n.__data__, o, a)))
|
|
} : (e = r(e), function(n) {
|
|
n[u][i].tween.set(t, e)
|
|
}))
|
|
}
|
|
|
|
function Gu(n) {
|
|
return null == n && (n = ""),
|
|
function() {
|
|
this.textContent = n
|
|
}
|
|
}
|
|
|
|
function Ku(n) {
|
|
return null == n ? "__transition__" : "__transition_" + n + "__"
|
|
}
|
|
|
|
function Qu(n, t, e, r, i) {
|
|
function u(n) {
|
|
var t = v.delay;
|
|
return f.t = t + l, n >= t ? o(n - t) : void(f.c = o)
|
|
}
|
|
|
|
function o(e) {
|
|
var i = g.active,
|
|
u = g[i];
|
|
u && (u.timer.c = null, u.timer.t = NaN, --g.count, delete g[i], u.event && u.event.interrupt.call(n, n.__data__, u.index));
|
|
for (var o in g)
|
|
if (r > +o) {
|
|
var c = g[o];
|
|
c.timer.c = null, c.timer.t = NaN, --g.count, delete g[o]
|
|
}
|
|
f.c = a, qn(function() {
|
|
return f.c && a(e || 1) && (f.c = null, f.t = NaN), 1
|
|
}, 0, l), g.active = r, v.event && v.event.start.call(n, n.__data__, t), p = [], v.tween.forEach(function(e, r) {
|
|
(r = r.call(n, n.__data__, t)) && p.push(r)
|
|
}), h = v.ease, s = v.duration
|
|
}
|
|
|
|
function a(i) {
|
|
for (var u = i / s, o = h(u), a = p.length; a > 0;) p[--a].call(n, o);
|
|
return u >= 1 ? (v.event && v.event.end.call(n, n.__data__, t), --g.count ? delete g[r] : delete n[e], 1) : void 0
|
|
}
|
|
var l, f, s, h, p, g = n[e] || (n[e] = {
|
|
active: 0,
|
|
count: 0
|
|
}),
|
|
v = g[r];
|
|
v || (l = i.time, f = qn(u, 0, l), v = g[r] = {
|
|
tween: new c,
|
|
time: l,
|
|
timer: f,
|
|
delay: i.delay,
|
|
duration: i.duration,
|
|
ease: i.ease,
|
|
index: t
|
|
}, i = null, ++g.count)
|
|
}
|
|
|
|
function no(n, t, e) {
|
|
n.attr("transform", function(n) {
|
|
var r = t(n);
|
|
return "translate(" + (isFinite(r) ? r : e(n)) + ",0)"
|
|
})
|
|
}
|
|
|
|
function to(n, t, e) {
|
|
n.attr("transform", function(n) {
|
|
var r = t(n);
|
|
return "translate(0," + (isFinite(r) ? r : e(n)) + ")"
|
|
})
|
|
}
|
|
|
|
function eo(n) {
|
|
return n.toISOString()
|
|
}
|
|
|
|
function ro(n, t, e) {
|
|
function r(t) {
|
|
return n(t)
|
|
}
|
|
|
|
function i(n, e) {
|
|
var r = n[1] - n[0],
|
|
i = r / e,
|
|
u = ao.bisect(Kl, i);
|
|
return u == Kl.length ? [t.year, Ki(n.map(function(n) {
|
|
return n / 31536e6
|
|
}), e)[2]] : u ? t[i / Kl[u - 1] < Kl[u] / i ? u - 1 : u] : [tc, Ki(n, e)[2]]
|
|
}
|
|
return r.invert = function(t) {
|
|
return io(n.invert(t))
|
|
}, r.domain = function(t) {
|
|
return arguments.length ? (n.domain(t), r) : n.domain().map(io)
|
|
}, r.nice = function(n, t) {
|
|
function e(e) {
|
|
return !isNaN(e) && !n.range(e, io(+e + 1), t).length
|
|
}
|
|
var u = r.domain(),
|
|
o = Yi(u),
|
|
a = null == n ? i(o, 10) : "number" == typeof n && i(o, n);
|
|
return a && (n = a[0], t = a[1]), r.domain(Xi(u, t > 1 ? {
|
|
floor: function(t) {
|
|
for (; e(t = n.floor(t));) t = io(t - 1);
|
|
return t
|
|
},
|
|
ceil: function(t) {
|
|
for (; e(t = n.ceil(t));) t = io(+t + 1);
|
|
return t
|
|
}
|
|
} : n))
|
|
}, r.ticks = function(n, t) {
|
|
var e = Yi(r.domain()),
|
|
u = null == n ? i(e, 10) : "number" == typeof n ? i(e, n) : !n.range && [{
|
|
range: n
|
|
}, t];
|
|
return u && (n = u[0], t = u[1]), n.range(e[0], io(+e[1] + 1), 1 > t ? 1 : t)
|
|
}, r.tickFormat = function() {
|
|
return e
|
|
}, r.copy = function() {
|
|
return ro(n.copy(), t, e)
|
|
}, Ji(r, n)
|
|
}
|
|
|
|
function io(n) {
|
|
return new Date(n)
|
|
}
|
|
|
|
function uo(n) {
|
|
return JSON.parse(n.responseText)
|
|
}
|
|
|
|
function oo(n) {
|
|
var t = fo.createRange();
|
|
return t.selectNode(fo.body), t.createContextualFragment(n.responseText)
|
|
}
|
|
var ao = {
|
|
version: "3.5.17"
|
|
},
|
|
lo = [].slice,
|
|
co = function(n) {
|
|
return lo.call(n)
|
|
},
|
|
fo = this.document;
|
|
if (fo) try {
|
|
co(fo.documentElement.childNodes)[0].nodeType
|
|
} catch (so) {
|
|
co = function(n) {
|
|
for (var t = n.length, e = new Array(t); t--;) e[t] = n[t];
|
|
return e
|
|
}
|
|
}
|
|
if (Date.now || (Date.now = function() {
|
|
return +new Date
|
|
}), fo) try {
|
|
fo.createElement("DIV").style.setProperty("opacity", 0, "")
|
|
} catch (ho) {
|
|
var po = this.Element.prototype,
|
|
go = po.setAttribute,
|
|
vo = po.setAttributeNS,
|
|
yo = this.CSSStyleDeclaration.prototype,
|
|
mo = yo.setProperty;
|
|
po.setAttribute = function(n, t) {
|
|
go.call(this, n, t + "")
|
|
}, po.setAttributeNS = function(n, t, e) {
|
|
vo.call(this, n, t, e + "")
|
|
}, yo.setProperty = function(n, t, e) {
|
|
mo.call(this, n, t + "", e)
|
|
}
|
|
}
|
|
ao.ascending = e, ao.descending = function(n, t) {
|
|
return n > t ? -1 : t > n ? 1 : t >= n ? 0 : NaN
|
|
}, ao.min = function(n, t) {
|
|
var e, r, i = -1,
|
|
u = n.length;
|
|
if (1 === arguments.length) {
|
|
for (; ++i < u;)
|
|
if (null != (r = n[i]) && r >= r) {
|
|
e = r;
|
|
break
|
|
}
|
|
for (; ++i < u;) null != (r = n[i]) && e > r && (e = r)
|
|
} else {
|
|
for (; ++i < u;)
|
|
if (null != (r = t.call(n, n[i], i)) && r >= r) {
|
|
e = r;
|
|
break
|
|
}
|
|
for (; ++i < u;) null != (r = t.call(n, n[i], i)) && e > r && (e = r)
|
|
}
|
|
return e
|
|
}, ao.max = function(n, t) {
|
|
var e, r, i = -1,
|
|
u = n.length;
|
|
if (1 === arguments.length) {
|
|
for (; ++i < u;)
|
|
if (null != (r = n[i]) && r >= r) {
|
|
e = r;
|
|
break
|
|
}
|
|
for (; ++i < u;) null != (r = n[i]) && r > e && (e = r)
|
|
} else {
|
|
for (; ++i < u;)
|
|
if (null != (r = t.call(n, n[i], i)) && r >= r) {
|
|
e = r;
|
|
break
|
|
}
|
|
for (; ++i < u;) null != (r = t.call(n, n[i], i)) && r > e && (e = r)
|
|
}
|
|
return e
|
|
}, ao.extent = function(n, t) {
|
|
var e, r, i, u = -1,
|
|
o = n.length;
|
|
if (1 === arguments.length) {
|
|
for (; ++u < o;)
|
|
if (null != (r = n[u]) && r >= r) {
|
|
e = i = r;
|
|
break
|
|
}
|
|
for (; ++u < o;) null != (r = n[u]) && (e > r && (e = r), r > i && (i = r))
|
|
} else {
|
|
for (; ++u < o;)
|
|
if (null != (r = t.call(n, n[u], u)) && r >= r) {
|
|
e = i = r;
|
|
break
|
|
}
|
|
for (; ++u < o;) null != (r = t.call(n, n[u], u)) && (e > r && (e = r), r > i && (i = r))
|
|
}
|
|
return [e, i]
|
|
}, ao.sum = function(n, t) {
|
|
var e, r = 0,
|
|
u = n.length,
|
|
o = -1;
|
|
if (1 === arguments.length)
|
|
for (; ++o < u;) i(e = +n[o]) && (r += e);
|
|
else
|
|
for (; ++o < u;) i(e = +t.call(n, n[o], o)) && (r += e);
|
|
return r
|
|
}, ao.mean = function(n, t) {
|
|
var e, u = 0,
|
|
o = n.length,
|
|
a = -1,
|
|
l = o;
|
|
if (1 === arguments.length)
|
|
for (; ++a < o;) i(e = r(n[a])) ? u += e : --l;
|
|
else
|
|
for (; ++a < o;) i(e = r(t.call(n, n[a], a))) ? u += e : --l;
|
|
return l ? u / l : void 0
|
|
}, ao.quantile = function(n, t) {
|
|
var e = (n.length - 1) * t + 1,
|
|
r = Math.floor(e),
|
|
i = +n[r - 1],
|
|
u = e - r;
|
|
return u ? i + u * (n[r] - i) : i
|
|
}, ao.median = function(n, t) {
|
|
var u, o = [],
|
|
a = n.length,
|
|
l = -1;
|
|
if (1 === arguments.length)
|
|
for (; ++l < a;) i(u = r(n[l])) && o.push(u);
|
|
else
|
|
for (; ++l < a;) i(u = r(t.call(n, n[l], l))) && o.push(u);
|
|
return o.length ? ao.quantile(o.sort(e), .5) : void 0
|
|
}, ao.variance = function(n, t) {
|
|
var e, u, o = n.length,
|
|
a = 0,
|
|
l = 0,
|
|
c = -1,
|
|
f = 0;
|
|
if (1 === arguments.length)
|
|
for (; ++c < o;) i(e = r(n[c])) && (u = e - a, a += u / ++f, l += u * (e - a));
|
|
else
|
|
for (; ++c < o;) i(e = r(t.call(n, n[c], c))) && (u = e - a, a += u / ++f, l += u * (e - a));
|
|
return f > 1 ? l / (f - 1) : void 0
|
|
}, ao.deviation = function() {
|
|
var n = ao.variance.apply(this, arguments);
|
|
return n ? Math.sqrt(n) : n
|
|
};
|
|
var Mo = u(e);
|
|
ao.bisectLeft = Mo.left, ao.bisect = ao.bisectRight = Mo.right, ao.bisector = function(n) {
|
|
return u(1 === n.length ? function(t, r) {
|
|
return e(n(t), r)
|
|
} : n)
|
|
}, ao.shuffle = function(n, t, e) {
|
|
(u = arguments.length) < 3 && (e = n.length, 2 > u && (t = 0));
|
|
for (var r, i, u = e - t; u;) i = Math.random() * u-- | 0, r = n[u + t], n[u + t] = n[i + t], n[i + t] = r;
|
|
return n
|
|
}, ao.permute = function(n, t) {
|
|
for (var e = t.length, r = new Array(e); e--;) r[e] = n[t[e]];
|
|
return r
|
|
}, ao.pairs = function(n) {
|
|
for (var t, e = 0, r = n.length - 1, i = n[0], u = new Array(0 > r ? 0 : r); r > e;) u[e] = [t = i, i = n[++e]];
|
|
return u
|
|
}, ao.transpose = function(n) {
|
|
if (!(i = n.length)) return [];
|
|
for (var t = -1, e = ao.min(n, o), r = new Array(e); ++t < e;)
|
|
for (var i, u = -1, a = r[t] = new Array(i); ++u < i;) a[u] = n[u][t];
|
|
return r
|
|
}, ao.zip = function() {
|
|
return ao.transpose(arguments)
|
|
}, ao.keys = function(n) {
|
|
var t = [];
|
|
for (var e in n) t.push(e);
|
|
return t
|
|
}, ao.values = function(n) {
|
|
var t = [];
|
|
for (var e in n) t.push(n[e]);
|
|
return t
|
|
}, ao.entries = function(n) {
|
|
var t = [];
|
|
for (var e in n) t.push({
|
|
key: e,
|
|
value: n[e]
|
|
});
|
|
return t
|
|
}, ao.merge = function(n) {
|
|
for (var t, e, r, i = n.length, u = -1, o = 0; ++u < i;) o += n[u].length;
|
|
for (e = new Array(o); --i >= 0;)
|
|
for (r = n[i], t = r.length; --t >= 0;) e[--o] = r[t];
|
|
return e
|
|
};
|
|
var xo = Math.abs;
|
|
ao.range = function(n, t, e) {
|
|
if (arguments.length < 3 && (e = 1, arguments.length < 2 && (t = n, n = 0)), (t - n) / e === 1 / 0) throw new Error("infinite range");
|
|
var r, i = [],
|
|
u = a(xo(e)),
|
|
o = -1;
|
|
if (n *= u, t *= u, e *= u, 0 > e)
|
|
for (;
|
|
(r = n + e * ++o) > t;) i.push(r / u);
|
|
else
|
|
for (;
|
|
(r = n + e * ++o) < t;) i.push(r / u);
|
|
return i
|
|
}, ao.map = function(n, t) {
|
|
var e = new c;
|
|
if (n instanceof c) n.forEach(function(n, t) {
|
|
e.set(n, t)
|
|
});
|
|
else if (Array.isArray(n)) {
|
|
var r, i = -1,
|
|
u = n.length;
|
|
if (1 === arguments.length)
|
|
for (; ++i < u;) e.set(i, n[i]);
|
|
else
|
|
for (; ++i < u;) e.set(t.call(n, r = n[i], i), r)
|
|
} else
|
|
for (var o in n) e.set(o, n[o]);
|
|
return e
|
|
};
|
|
var bo = "__proto__",
|
|
_o = "\\x00";
|
|
l(c, {
|
|
has: h,
|
|
get: function(n) {
|
|
return this._[f(n)]
|
|
},
|
|
set: function(n, t) {
|
|
return this._[f(n)] = t
|
|
},
|
|
remove: p,
|
|
keys: g,
|
|
values: function() {
|
|
var n = [];
|
|
for (var t in this._) n.push(this._[t]);
|
|
return n
|
|
},
|
|
entries: function() {
|
|
var n = [];
|
|
for (var t in this._) n.push({
|
|
key: s(t),
|
|
value: this._[t]
|
|
});
|
|
return n
|
|
},
|
|
size: v,
|
|
empty: d,
|
|
forEach: function(n) {
|
|
for (var t in this._) n.call(this, s(t), this._[t])
|
|
}
|
|
}), ao.nest = function() {
|
|
function n(t, o, a) {
|
|
if (a >= u.length) return r ? r.call(i, o) : e ? o.sort(e) : o;
|
|
for (var l, f, s, h, p = -1, g = o.length, v = u[a++], d = new c; ++p < g;)(h = d.get(l = v(f = o[p]))) ? h.push(f) : d.set(l, [f]);
|
|
return t ? (f = t(), s = function(e, r) {
|
|
f.set(e, n(t, r, a))
|
|
}) : (f = {}, s = function(e, r) {
|
|
f[e] = n(t, r, a)
|
|
}), d.forEach(s), f
|
|
}
|
|
|
|
function t(n, e) {
|
|
if (e >= u.length) return n;
|
|
var r = [],
|
|
i = o[e++];
|
|
return n.forEach(function(n, i) {
|
|
r.push({
|
|
key: n,
|
|
values: t(i, e)
|
|
})
|
|
}), i ? r.sort(function(n, t) {
|
|
return i(n.key, t.key)
|
|
}) : r
|
|
}
|
|
var e, r, i = {},
|
|
u = [],
|
|
o = [];
|
|
return i.map = function(t, e) {
|
|
return n(e, t, 0)
|
|
}, i.entries = function(e) {
|
|
return t(n(ao.map, e, 0), 0)
|
|
}, i.key = function(n) {
|
|
return u.push(n), i
|
|
}, i.sortKeys = function(n) {
|
|
return o[u.length - 1] = n, i
|
|
}, i.sortValues = function(n) {
|
|
return e = n, i
|
|
}, i.rollup = function(n) {
|
|
return r = n, i
|
|
}, i
|
|
}, ao.set = function(n) {
|
|
var t = new y;
|
|
if (n)
|
|
for (var e = 0, r = n.length; r > e; ++e) t.add(n[e]);
|
|
return t
|
|
}, l(y, {
|
|
has: h,
|
|
add: function(n) {
|
|
return this._[f(n += "")] = !0, n
|
|
},
|
|
remove: p,
|
|
values: g,
|
|
size: v,
|
|
empty: d,
|
|
forEach: function(n) {
|
|
for (var t in this._) n.call(this, s(t))
|
|
}
|
|
}), ao.behavior = {}, ao.rebind = function(n, t) {
|
|
for (var e, r = 1, i = arguments.length; ++r < i;) n[e = arguments[r]] = M(n, t, t[e]);
|
|
return n
|
|
};
|
|
var wo = ["webkit", "ms", "moz", "Moz", "o", "O"];
|
|
ao.dispatch = function() {
|
|
for (var n = new _, t = -1, e = arguments.length; ++t < e;) n[arguments[t]] = w(n);
|
|
return n
|
|
}, _.prototype.on = function(n, t) {
|
|
var e = n.indexOf("."),
|
|
r = "";
|
|
if (e >= 0 && (r = n.slice(e + 1), n = n.slice(0, e)), n) return arguments.length < 2 ? this[n].on(r) : this[n].on(r, t);
|
|
if (2 === arguments.length) {
|
|
if (null == t)
|
|
for (n in this) this.hasOwnProperty(n) && this[n].on(r, null);
|
|
return this
|
|
}
|
|
}, ao.event = null, ao.requote = function(n) {
|
|
return n.replace(So, "\\\\$&")
|
|
};
|
|
var So = /[\\\\\\^\\$\\*\\+\\?\\|\\[\\]\\(\\)\\.\\{\\}]/g,
|
|
ko = {}.__proto__ ? function(n, t) {
|
|
n.__proto__ = t
|
|
} : function(n, t) {
|
|
for (var e in t) n[e] = t[e]
|
|
},
|
|
No = function(n, t) {
|
|
return t.querySelector(n)
|
|
},
|
|
Eo = function(n, t) {
|
|
return t.querySelectorAll(n)
|
|
},
|
|
Ao = function(n, t) {
|
|
var e = n.matches || n[x(n, "matchesSelector")];
|
|
return (Ao = function(n, t) {
|
|
return e.call(n, t)
|
|
})(n, t)
|
|
};
|
|
"function" == typeof Sizzle && (No = function(n, t) {
|
|
return Sizzle(n, t)[0] || null
|
|
}, Eo = Sizzle, Ao = Sizzle.matchesSelector), ao.selection = function() {
|
|
return ao.select(fo.documentElement)
|
|
};
|
|
var Co = ao.selection.prototype = [];
|
|
Co.select = function(n) {
|
|
var t, e, r, i, u = [];
|
|
n = A(n);
|
|
for (var o = -1, a = this.length; ++o < a;) {
|
|
u.push(t = []), t.parentNode = (r = this[o]).parentNode;
|
|
for (var l = -1, c = r.length; ++l < c;)(i = r[l]) ? (t.push(e = n.call(i, i.__data__, l, o)), e && "__data__" in i && (e.__data__ = i.__data__)) : t.push(null)
|
|
}
|
|
return E(u)
|
|
}, Co.selectAll = function(n) {
|
|
var t, e, r = [];
|
|
n = C(n);
|
|
for (var i = -1, u = this.length; ++i < u;)
|
|
for (var o = this[i], a = -1, l = o.length; ++a < l;)(e = o[a]) && (r.push(t = co(n.call(e, e.__data__, a, i))), t.parentNode = e);
|
|
return E(r)
|
|
};
|
|
var zo = "http://www.w3.org/1999/xhtml",
|
|
Lo = {
|
|
svg: "http://www.w3.org/2000/svg",
|
|
xhtml: zo,
|
|
xlink: "http://www.w3.org/1999/xlink",
|
|
xml: "http://www.w3.org/XML/1998/namespace",
|
|
xmlns: "http://www.w3.org/2000/xmlns/"
|
|
};
|
|
ao.ns = {
|
|
prefix: Lo,
|
|
qualify: function(n) {
|
|
var t = n.indexOf(":"),
|
|
e = n;
|
|
return t >= 0 && "xmlns" !== (e = n.slice(0, t)) && (n = n.slice(t + 1)), Lo.hasOwnProperty(e) ? {
|
|
space: Lo[e],
|
|
local: n
|
|
} : n
|
|
}
|
|
}, Co.attr = function(n, t) {
|
|
if (arguments.length < 2) {
|
|
if ("string" == typeof n) {
|
|
var e = this.node();
|
|
return n = ao.ns.qualify(n), n.local ? e.getAttributeNS(n.space, n.local) : e.getAttribute(n)
|
|
}
|
|
for (t in n) this.each(z(t, n[t]));
|
|
return this
|
|
}
|
|
return this.each(z(n, t))
|
|
}, Co.classed = function(n, t) {
|
|
if (arguments.length < 2) {
|
|
if ("string" == typeof n) {
|
|
var e = this.node(),
|
|
r = (n = T(n)).length,
|
|
i = -1;
|
|
if (t = e.classList) {
|
|
for (; ++i < r;)
|
|
if (!t.contains(n[i])) return !1
|
|
} else
|
|
for (t = e.getAttribute("class"); ++i < r;)
|
|
if (!q(n[i]).test(t)) return !1;
|
|
return !0
|
|
}
|
|
for (t in n) this.each(R(t, n[t]));
|
|
return this
|
|
}
|
|
return this.each(R(n, t))
|
|
}, Co.style = function(n, e, r) {
|
|
var i = arguments.length;
|
|
if (3 > i) {
|
|
if ("string" != typeof n) {
|
|
2 > i && (e = "");
|
|
for (r in n) this.each(P(r, n[r], e));
|
|
return this
|
|
}
|
|
if (2 > i) {
|
|
var u = this.node();
|
|
return t(u).getComputedStyle(u, null).getPropertyValue(n)
|
|
}
|
|
r = ""
|
|
}
|
|
return this.each(P(n, e, r))
|
|
}, Co.property = function(n, t) {
|
|
if (arguments.length < 2) {
|
|
if ("string" == typeof n) return this.node()[n];
|
|
for (t in n) this.each(U(t, n[t]));
|
|
return this
|
|
}
|
|
return this.each(U(n, t))
|
|
}, Co.text = function(n) {
|
|
return arguments.length ? this.each("function" == typeof n ? function() {
|
|
var t = n.apply(this, arguments);
|
|
this.textContent = null == t ? "" : t
|
|
} : null == n ? function() {
|
|
this.textContent = ""
|
|
} : function() {
|
|
this.textContent = n
|
|
}) : this.node().textContent
|
|
}, Co.html = function(n) {
|
|
return arguments.length ? this.each("function" == typeof n ? function() {
|
|
var t = n.apply(this, arguments);
|
|
this.innerHTML = null == t ? "" : t
|
|
} : null == n ? function() {
|
|
this.innerHTML = ""
|
|
} : function() {
|
|
this.innerHTML = n
|
|
}) : this.node().innerHTML
|
|
}, Co.append = function(n) {
|
|
return n = j(n), this.select(function() {
|
|
return this.appendChild(n.apply(this, arguments))
|
|
})
|
|
}, Co.insert = function(n, t) {
|
|
return n = j(n), t = A(t), this.select(function() {
|
|
return this.insertBefore(n.apply(this, arguments), t.apply(this, arguments) || null)
|
|
})
|
|
}, Co.remove = function() {
|
|
return this.each(F)
|
|
}, Co.data = function(n, t) {
|
|
function e(n, e) {
|
|
var r, i, u, o = n.length,
|
|
s = e.length,
|
|
h = Math.min(o, s),
|
|
p = new Array(s),
|
|
g = new Array(s),
|
|
v = new Array(o);
|
|
if (t) {
|
|
var d, y = new c,
|
|
m = new Array(o);
|
|
for (r = -1; ++r < o;)(i = n[r]) && (y.has(d = t.call(i, i.__data__, r)) ? v[r] = i : y.set(d, i), m[r] = d);
|
|
for (r = -1; ++r < s;)(i = y.get(d = t.call(e, u = e[r], r))) ? i !== !0 && (p[r] = i, i.__data__ = u) : g[r] = H(u), y.set(d, !0);
|
|
for (r = -1; ++r < o;) r in m && y.get(m[r]) !== !0 && (v[r] = n[r])
|
|
} else {
|
|
for (r = -1; ++r < h;) i = n[r], u = e[r], i ? (i.__data__ = u, p[r] = i) : g[r] = H(u);
|
|
for (; s > r; ++r) g[r] = H(e[r]);
|
|
for (; o > r; ++r) v[r] = n[r]
|
|
}
|
|
g.update = p, g.parentNode = p.parentNode = v.parentNode = n.parentNode, a.push(g), l.push(p), f.push(v)
|
|
}
|
|
var r, i, u = -1,
|
|
o = this.length;
|
|
if (!arguments.length) {
|
|
for (n = new Array(o = (r = this[0]).length); ++u < o;)(i = r[u]) && (n[u] = i.__data__);
|
|
return n
|
|
}
|
|
var a = Z([]),
|
|
l = E([]),
|
|
f = E([]);
|
|
if ("function" == typeof n)
|
|
for (; ++u < o;) e(r = this[u], n.call(r, r.parentNode.__data__, u));
|
|
else
|
|
for (; ++u < o;) e(r = this[u], n);
|
|
return l.enter = function() {
|
|
return a
|
|
}, l.exit = function() {
|
|
return f
|
|
}, l
|
|
}, Co.datum = function(n) {
|
|
return arguments.length ? this.property("__data__", n) : this.property("__data__")
|
|
}, Co.filter = function(n) {
|
|
var t, e, r, i = [];
|
|
"function" != typeof n && (n = O(n));
|
|
for (var u = 0, o = this.length; o > u; u++) {
|
|
i.push(t = []), t.parentNode = (e = this[u]).parentNode;
|
|
for (var a = 0, l = e.length; l > a; a++)(r = e[a]) && n.call(r, r.__data__, a, u) && t.push(r)
|
|
}
|
|
return E(i)
|
|
}, Co.order = function() {
|
|
for (var n = -1, t = this.length; ++n < t;)
|
|
for (var e, r = this[n], i = r.length - 1, u = r[i]; --i >= 0;)(e = r[i]) && (u && u !== e.nextSibling && u.parentNode.insertBefore(e, u), u = e);
|
|
return this
|
|
}, Co.sort = function(n) {
|
|
n = I.apply(this, arguments);
|
|
for (var t = -1, e = this.length; ++t < e;) this[t].sort(n);
|
|
return this.order()
|
|
}, Co.each = function(n) {
|
|
return Y(this, function(t, e, r) {
|
|
n.call(t, t.__data__, e, r)
|
|
})
|
|
}, Co.call = function(n) {
|
|
var t = co(arguments);
|
|
return n.apply(t[0] = this, t), this
|
|
}, Co.empty = function() {
|
|
return !this.node()
|
|
}, Co.node = function() {
|
|
for (var n = 0, t = this.length; t > n; n++)
|
|
for (var e = this[n], r = 0, i = e.length; i > r; r++) {
|
|
var u = e[r];
|
|
if (u) return u
|
|
}
|
|
return null
|
|
}, Co.size = function() {
|
|
var n = 0;
|
|
return Y(this, function() {
|
|
++n
|
|
}), n
|
|
};
|
|
var qo = [];
|
|
ao.selection.enter = Z, ao.selection.enter.prototype = qo, qo.append = Co.append, qo.empty = Co.empty, qo.node = Co.node, qo.call = Co.call, qo.size = Co.size, qo.select = function(n) {
|
|
for (var t, e, r, i, u, o = [], a = -1, l = this.length; ++a < l;) {
|
|
r = (i = this[a]).update, o.push(t = []), t.parentNode = i.parentNode;
|
|
for (var c = -1, f = i.length; ++c < f;)(u = i[c]) ? (t.push(r[c] = e = n.call(i.parentNode, u.__data__, c, a)), e.__data__ = u.__data__) : t.push(null)
|
|
}
|
|
return E(o)
|
|
}, qo.insert = function(n, t) {
|
|
return arguments.length < 2 && (t = V(this)), Co.insert.call(this, n, t)
|
|
}, ao.select = function(t) {
|
|
var e;
|
|
return "string" == typeof t ? (e = [No(t, fo)], e.parentNode = fo.documentElement) : (e = [t], e.parentNode = n(t)), E([e])
|
|
}, ao.selectAll = function(n) {
|
|
var t;
|
|
return "string" == typeof n ? (t = co(Eo(n, fo)), t.parentNode = fo.documentElement) : (t = co(n), t.parentNode = null), E([t])
|
|
}, Co.on = function(n, t, e) {
|
|
var r = arguments.length;
|
|
if (3 > r) {
|
|
if ("string" != typeof n) {
|
|
2 > r && (t = !1);
|
|
for (e in n) this.each(X(e, n[e], t));
|
|
return this
|
|
}
|
|
if (2 > r) return (r = this.node()["__on" + n]) && r._;
|
|
e = !1
|
|
}
|
|
return this.each(X(n, t, e))
|
|
};
|
|
var To = ao.map({
|
|
mouseenter: "mouseover",
|
|
mouseleave: "mouseout"
|
|
});
|
|
fo && To.forEach(function(n) {
|
|
"on" + n in fo && To.remove(n)
|
|
});
|
|
var Ro, Do = 0;
|
|
ao.mouse = function(n) {
|
|
return J(n, k())
|
|
};
|
|
var Po = this.navigator && /WebKit/.test(this.navigator.userAgent) ? -1 : 0;
|
|
ao.touch = function(n, t, e) {
|
|
if (arguments.length < 3 && (e = t, t = k().changedTouches), t)
|
|
for (var r, i = 0, u = t.length; u > i; ++i)
|
|
if ((r = t[i]).identifier === e) return J(n, r)
|
|
}, ao.behavior.drag = function() {
|
|
function n() {
|
|
this.on("mousedown.drag", u).on("touchstart.drag", o)
|
|
}
|
|
|
|
function e(n, t, e, u, o) {
|
|
return function() {
|
|
function a() {
|
|
var n, e, r = t(h, v);
|
|
r && (n = r[0] - M[0], e = r[1] - M[1], g |= n | e, M = r, p({
|
|
type: "drag",
|
|
x: r[0] + c[0],
|
|
y: r[1] + c[1],
|
|
dx: n,
|
|
dy: e
|
|
}))
|
|
}
|
|
|
|
function l() {
|
|
t(h, v) && (y.on(u + d, null).on(o + d, null), m(g), p({
|
|
type: "dragend"
|
|
}))
|
|
}
|
|
var c, f = this,
|
|
s = ao.event.target.correspondingElement || ao.event.target,
|
|
h = f.parentNode,
|
|
p = r.of(f, arguments),
|
|
g = 0,
|
|
v = n(),
|
|
d = ".drag" + (null == v ? "" : "-" + v),
|
|
y = ao.select(e(s)).on(u + d, a).on(o + d, l),
|
|
m = W(s),
|
|
M = t(h, v);
|
|
i ? (c = i.apply(f, arguments), c = [c.x - M[0], c.y - M[1]]) : c = [0, 0], p({
|
|
type: "dragstart"
|
|
})
|
|
}
|
|
}
|
|
var r = N(n, "drag", "dragstart", "dragend"),
|
|
i = null,
|
|
u = e(b, ao.mouse, t, "mousemove", "mouseup"),
|
|
o = e(G, ao.touch, m, "touchmove", "touchend");
|
|
return n.origin = function(t) {
|
|
return arguments.length ? (i = t, n) : i
|
|
}, ao.rebind(n, r, "on")
|
|
}, ao.touches = function(n, t) {
|
|
return arguments.length < 2 && (t = k().touches), t ? co(t).map(function(t) {
|
|
var e = J(n, t);
|
|
return e.identifier = t.identifier, e
|
|
}) : []
|
|
};
|
|
var Uo = 1e-6,
|
|
jo = Uo * Uo,
|
|
Fo = Math.PI,
|
|
Ho = 2 * Fo,
|
|
Oo = Ho - Uo,
|
|
Io = Fo / 2,
|
|
Yo = Fo / 180,
|
|
Zo = 180 / Fo,
|
|
Vo = Math.SQRT2,
|
|
Xo = 2,
|
|
$o = 4;
|
|
ao.interpolateZoom = function(n, t) {
|
|
var e, r, i = n[0],
|
|
u = n[1],
|
|
o = n[2],
|
|
a = t[0],
|
|
l = t[1],
|
|
c = t[2],
|
|
f = a - i,
|
|
s = l - u,
|
|
h = f * f + s * s;
|
|
if (jo > h) r = Math.log(c / o) / Vo, e = function(n) {
|
|
return [i + n * f, u + n * s, o * Math.exp(Vo * n * r)]
|
|
};
|
|
else {
|
|
var p = Math.sqrt(h),
|
|
g = (c * c - o * o + $o * h) / (2 * o * Xo * p),
|
|
v = (c * c - o * o - $o * h) / (2 * c * Xo * p),
|
|
d = Math.log(Math.sqrt(g * g + 1) - g),
|
|
y = Math.log(Math.sqrt(v * v + 1) - v);
|
|
r = (y - d) / Vo, e = function(n) {
|
|
var t = n * r,
|
|
e = rn(d),
|
|
a = o / (Xo * p) * (e * un(Vo * t + d) - en(d));
|
|
return [i + a * f, u + a * s, o * e / rn(Vo * t + d)]
|
|
}
|
|
}
|
|
return e.duration = 1e3 * r, e
|
|
}, ao.behavior.zoom = function() {
|
|
function n(n) {
|
|
n.on(L, s).on(Wo + ".zoom", p).on("dblclick.zoom", g).on(R, h)
|
|
}
|
|
|
|
function e(n) {
|
|
return [(n[0] - k.x) / k.k, (n[1] - k.y) / k.k]
|
|
}
|
|
|
|
function r(n) {
|
|
return [n[0] * k.k + k.x, n[1] * k.k + k.y]
|
|
}
|
|
|
|
function i(n) {
|
|
k.k = Math.max(A[0], Math.min(A[1], n))
|
|
}
|
|
|
|
function u(n, t) {
|
|
t = r(t), k.x += n[0] - t[0], k.y += n[1] - t[1]
|
|
}
|
|
|
|
function o(t, e, r, o) {
|
|
t.__chart__ = {
|
|
x: k.x,
|
|
y: k.y,
|
|
k: k.k
|
|
}, i(Math.pow(2, o)), u(d = e, r), t = ao.select(t), C > 0 && (t = t.transition().duration(C)), t.call(n.event)
|
|
}
|
|
|
|
function a() {
|
|
b && b.domain(x.range().map(function(n) {
|
|
return (n - k.x) / k.k
|
|
}).map(x.invert)), w && w.domain(_.range().map(function(n) {
|
|
return (n - k.y) / k.k
|
|
}).map(_.invert))
|
|
}
|
|
|
|
function l(n) {
|
|
z++ || n({
|
|
type: "zoomstart"
|
|
})
|
|
}
|
|
|
|
function c(n) {
|
|
a(), n({
|
|
type: "zoom",
|
|
scale: k.k,
|
|
translate: [k.x, k.y]
|
|
})
|
|
}
|
|
|
|
function f(n) {
|
|
--z || (n({
|
|
type: "zoomend"
|
|
}), d = null)
|
|
}
|
|
|
|
function s() {
|
|
function n() {
|
|
a = 1, u(ao.mouse(i), h), c(o)
|
|
}
|
|
|
|
function r() {
|
|
s.on(q, null).on(T, null), p(a), f(o)
|
|
}
|
|
var i = this,
|
|
o = D.of(i, arguments),
|
|
a = 0,
|
|
s = ao.select(t(i)).on(q, n).on(T, r),
|
|
h = e(ao.mouse(i)),
|
|
p = W(i);
|
|
Il.call(i), l(o)
|
|
}
|
|
|
|
function h() {
|
|
function n() {
|
|
var n = ao.touches(g);
|
|
return p = k.k, n.forEach(function(n) {
|
|
n.identifier in d && (d[n.identifier] = e(n))
|
|
}), n
|
|
}
|
|
|
|
function t() {
|
|
var t = ao.event.target;
|
|
ao.select(t).on(x, r).on(b, a), _.push(t);
|
|
for (var e = ao.event.changedTouches, i = 0, u = e.length; u > i; ++i) d[e[i].identifier] = null;
|
|
var l = n(),
|
|
c = Date.now();
|
|
if (1 === l.length) {
|
|
if (500 > c - M) {
|
|
var f = l[0];
|
|
o(g, f, d[f.identifier], Math.floor(Math.log(k.k) / Math.LN2) + 1), S()
|
|
}
|
|
M = c
|
|
} else if (l.length > 1) {
|
|
var f = l[0],
|
|
s = l[1],
|
|
h = f[0] - s[0],
|
|
p = f[1] - s[1];
|
|
y = h * h + p * p
|
|
}
|
|
}
|
|
|
|
function r() {
|
|
var n, t, e, r, o = ao.touches(g);
|
|
Il.call(g);
|
|
for (var a = 0, l = o.length; l > a; ++a, r = null)
|
|
if (e = o[a], r = d[e.identifier]) {
|
|
if (t) break;
|
|
n = e, t = r
|
|
}
|
|
if (r) {
|
|
var f = (f = e[0] - n[0]) * f + (f = e[1] - n[1]) * f,
|
|
s = y && Math.sqrt(f / y);
|
|
n = [(n[0] + e[0]) / 2, (n[1] + e[1]) / 2], t = [(t[0] + r[0]) / 2, (t[1] + r[1]) / 2], i(s * p)
|
|
}
|
|
M = null, u(n, t), c(v)
|
|
}
|
|
|
|
function a() {
|
|
if (ao.event.touches.length) {
|
|
for (var t = ao.event.changedTouches, e = 0, r = t.length; r > e; ++e) delete d[t[e].identifier];
|
|
for (var i in d) return void n()
|
|
}
|
|
ao.selectAll(_).on(m, null), w.on(L, s).on(R, h), N(), f(v)
|
|
}
|
|
var p, g = this,
|
|
v = D.of(g, arguments),
|
|
d = {},
|
|
y = 0,
|
|
m = ".zoom-" + ao.event.changedTouches[0].identifier,
|
|
x = "touchmove" + m,
|
|
b = "touchend" + m,
|
|
_ = [],
|
|
w = ao.select(g),
|
|
N = W(g);
|
|
t(), l(v), w.on(L, null).on(R, t)
|
|
}
|
|
|
|
function p() {
|
|
var n = D.of(this, arguments);
|
|
m ? clearTimeout(m) : (Il.call(this), v = e(d = y || ao.mouse(this)), l(n)), m = setTimeout(function() {
|
|
m = null, f(n)
|
|
}, 50), S(), i(Math.pow(2, .002 * Bo()) * k.k), u(d, v), c(n)
|
|
}
|
|
|
|
function g() {
|
|
var n = ao.mouse(this),
|
|
t = Math.log(k.k) / Math.LN2;
|
|
o(this, n, e(n), ao.event.shiftKey ? Math.ceil(t) - 1 : Math.floor(t) + 1)
|
|
}
|
|
var v, d, y, m, M, x, b, _, w, k = {
|
|
x: 0,
|
|
y: 0,
|
|
k: 1
|
|
},
|
|
E = [960, 500],
|
|
A = Jo,
|
|
C = 250,
|
|
z = 0,
|
|
L = "mousedown.zoom",
|
|
q = "mousemove.zoom",
|
|
T = "mouseup.zoom",
|
|
R = "touchstart.zoom",
|
|
D = N(n, "zoomstart", "zoom", "zoomend");
|
|
return Wo || (Wo = "onwheel" in fo ? (Bo = function() {
|
|
return -ao.event.deltaY * (ao.event.deltaMode ? 120 : 1)
|
|
}, "wheel") : "onmousewheel" in fo ? (Bo = function() {
|
|
return ao.event.wheelDelta
|
|
}, "mousewheel") : (Bo = function() {
|
|
return -ao.event.detail
|
|
}, "MozMousePixelScroll")), n.event = function(n) {
|
|
n.each(function() {
|
|
var n = D.of(this, arguments),
|
|
t = k;
|
|
Hl ? ao.select(this).transition().each("start.zoom", function() {
|
|
k = this.__chart__ || {
|
|
x: 0,
|
|
y: 0,
|
|
k: 1
|
|
}, l(n)
|
|
}).tween("zoom:zoom", function() {
|
|
var e = E[0],
|
|
r = E[1],
|
|
i = d ? d[0] : e / 2,
|
|
u = d ? d[1] : r / 2,
|
|
o = ao.interpolateZoom([(i - k.x) / k.k, (u - k.y) / k.k, e / k.k], [(i - t.x) / t.k, (u - t.y) / t.k, e / t.k]);
|
|
return function(t) {
|
|
var r = o(t),
|
|
a = e / r[2];
|
|
this.__chart__ = k = {
|
|
x: i - r[0] * a,
|
|
y: u - r[1] * a,
|
|
k: a
|
|
}, c(n)
|
|
}
|
|
}).each("interrupt.zoom", function() {
|
|
f(n)
|
|
}).each("end.zoom", function() {
|
|
f(n)
|
|
}) : (this.__chart__ = k, l(n), c(n), f(n))
|
|
})
|
|
}, n.translate = function(t) {
|
|
return arguments.length ? (k = {
|
|
x: +t[0],
|
|
y: +t[1],
|
|
k: k.k
|
|
}, a(), n) : [k.x, k.y]
|
|
}, n.scale = function(t) {
|
|
return arguments.length ? (k = {
|
|
x: k.x,
|
|
y: k.y,
|
|
k: null
|
|
}, i(+t), a(), n) : k.k
|
|
}, n.scaleExtent = function(t) {
|
|
return arguments.length ? (A = null == t ? Jo : [+t[0], +t[1]], n) : A
|
|
}, n.center = function(t) {
|
|
return arguments.length ? (y = t && [+t[0], +t[1]], n) : y
|
|
}, n.size = function(t) {
|
|
return arguments.length ? (E = t && [+t[0], +t[1]], n) : E
|
|
}, n.duration = function(t) {
|
|
return arguments.length ? (C = +t, n) : C
|
|
}, n.x = function(t) {
|
|
return arguments.length ? (b = t, x = t.copy(), k = {
|
|
x: 0,
|
|
y: 0,
|
|
k: 1
|
|
}, n) : b
|
|
}, n.y = function(t) {
|
|
return arguments.length ? (w = t, _ = t.copy(), k = {
|
|
x: 0,
|
|
y: 0,
|
|
k: 1
|
|
}, n) : w
|
|
}, ao.rebind(n, D, "on")
|
|
};
|
|
var Bo, Wo, Jo = [0, 1 / 0];
|
|
ao.color = an, an.prototype.toString = function() {
|
|
return this.rgb() + ""
|
|
}, ao.hsl = ln;
|
|
var Go = ln.prototype = new an;
|
|
Go.brighter = function(n) {
|
|
return n = Math.pow(.7, arguments.length ? n : 1), new ln(this.h, this.s, this.l / n)
|
|
}, Go.darker = function(n) {
|
|
return n = Math.pow(.7, arguments.length ? n : 1), new ln(this.h, this.s, n * this.l)
|
|
}, Go.rgb = function() {
|
|
return cn(this.h, this.s, this.l)
|
|
}, ao.hcl = fn;
|
|
var Ko = fn.prototype = new an;
|
|
Ko.brighter = function(n) {
|
|
return new fn(this.h, this.c, Math.min(100, this.l + Qo * (arguments.length ? n : 1)))
|
|
}, Ko.darker = function(n) {
|
|
return new fn(this.h, this.c, Math.max(0, this.l - Qo * (arguments.length ? n : 1)))
|
|
}, Ko.rgb = function() {
|
|
return sn(this.h, this.c, this.l).rgb()
|
|
}, ao.lab = hn;
|
|
var Qo = 18,
|
|
na = .95047,
|
|
ta = 1,
|
|
ea = 1.08883,
|
|
ra = hn.prototype = new an;
|
|
ra.brighter = function(n) {
|
|
return new hn(Math.min(100, this.l + Qo * (arguments.length ? n : 1)), this.a, this.b)
|
|
}, ra.darker = function(n) {
|
|
return new hn(Math.max(0, this.l - Qo * (arguments.length ? n : 1)), this.a, this.b)
|
|
}, ra.rgb = function() {
|
|
return pn(this.l, this.a, this.b)
|
|
}, ao.rgb = mn;
|
|
var ia = mn.prototype = new an;
|
|
ia.brighter = function(n) {
|
|
n = Math.pow(.7, arguments.length ? n : 1);
|
|
var t = this.r,
|
|
e = this.g,
|
|
r = this.b,
|
|
i = 30;
|
|
return t || e || r ? (t && i > t && (t = i), e && i > e && (e = i), r && i > r && (r = i), new mn(Math.min(255, t / n), Math.min(255, e / n), Math.min(255, r / n))) : new mn(i, i, i)
|
|
}, ia.darker = function(n) {
|
|
return n = Math.pow(.7, arguments.length ? n : 1), new mn(n * this.r, n * this.g, n * this.b)
|
|
}, ia.hsl = function() {
|
|
return wn(this.r, this.g, this.b)
|
|
}, ia.toString = function() {
|
|
return "#" + bn(this.r) + bn(this.g) + bn(this.b)
|
|
};
|
|
var ua = ao.map({
|
|
aliceblue: 15792383,
|
|
antiquewhite: 16444375,
|
|
aqua: 65535,
|
|
aquamarine: 8388564,
|
|
azure: 15794175,
|
|
beige: 16119260,
|
|
bisque: 16770244,
|
|
black: 0,
|
|
blanchedalmond: 16772045,
|
|
blue: 255,
|
|
blueviolet: 9055202,
|
|
brown: 10824234,
|
|
burlywood: 14596231,
|
|
cadetblue: 6266528,
|
|
chartreuse: 8388352,
|
|
chocolate: 13789470,
|
|
coral: 16744272,
|
|
cornflowerblue: 6591981,
|
|
cornsilk: 16775388,
|
|
crimson: 14423100,
|
|
cyan: 65535,
|
|
darkblue: 139,
|
|
darkcyan: 35723,
|
|
darkgoldenrod: 12092939,
|
|
darkgray: 11119017,
|
|
darkgreen: 25600,
|
|
darkgrey: 11119017,
|
|
darkkhaki: 12433259,
|
|
darkmagenta: 9109643,
|
|
darkolivegreen: 5597999,
|
|
darkorange: 16747520,
|
|
darkorchid: 10040012,
|
|
darkred: 9109504,
|
|
darksalmon: 15308410,
|
|
darkseagreen: 9419919,
|
|
darkslateblue: 4734347,
|
|
darkslategray: 3100495,
|
|
darkslategrey: 3100495,
|
|
darkturquoise: 52945,
|
|
darkviolet: 9699539,
|
|
deeppink: 16716947,
|
|
deepskyblue: 49151,
|
|
dimgray: 6908265,
|
|
dimgrey: 6908265,
|
|
dodgerblue: 2003199,
|
|
firebrick: 11674146,
|
|
floralwhite: 16775920,
|
|
forestgreen: 2263842,
|
|
fuchsia: 16711935,
|
|
gainsboro: 14474460,
|
|
ghostwhite: 16316671,
|
|
gold: 16766720,
|
|
goldenrod: 14329120,
|
|
gray: 8421504,
|
|
green: 32768,
|
|
greenyellow: 11403055,
|
|
grey: 8421504,
|
|
honeydew: 15794160,
|
|
hotpink: 16738740,
|
|
indianred: 13458524,
|
|
indigo: 4915330,
|
|
ivory: 16777200,
|
|
khaki: 15787660,
|
|
lavender: 15132410,
|
|
lavenderblush: 16773365,
|
|
lawngreen: 8190976,
|
|
lemonchiffon: 16775885,
|
|
lightblue: 11393254,
|
|
lightcoral: 15761536,
|
|
lightcyan: 14745599,
|
|
lightgoldenrodyellow: 16448210,
|
|
lightgray: 13882323,
|
|
lightgreen: 9498256,
|
|
lightgrey: 13882323,
|
|
lightpink: 16758465,
|
|
lightsalmon: 16752762,
|
|
lightseagreen: 2142890,
|
|
lightskyblue: 8900346,
|
|
lightslategray: 7833753,
|
|
lightslategrey: 7833753,
|
|
lightsteelblue: 11584734,
|
|
lightyellow: 16777184,
|
|
lime: 65280,
|
|
limegreen: 3329330,
|
|
linen: 16445670,
|
|
magenta: 16711935,
|
|
maroon: 8388608,
|
|
mediumaquamarine: 6737322,
|
|
mediumblue: 205,
|
|
mediumorchid: 12211667,
|
|
mediumpurple: 9662683,
|
|
mediumseagreen: 3978097,
|
|
mediumslateblue: 8087790,
|
|
mediumspringgreen: 64154,
|
|
mediumturquoise: 4772300,
|
|
mediumvioletred: 13047173,
|
|
midnightblue: 1644912,
|
|
mintcream: 16121850,
|
|
mistyrose: 16770273,
|
|
moccasin: 16770229,
|
|
navajowhite: 16768685,
|
|
navy: 128,
|
|
oldlace: 16643558,
|
|
olive: 8421376,
|
|
olivedrab: 7048739,
|
|
orange: 16753920,
|
|
orangered: 16729344,
|
|
orchid: 14315734,
|
|
palegoldenrod: 15657130,
|
|
palegreen: 10025880,
|
|
paleturquoise: 11529966,
|
|
palevioletred: 14381203,
|
|
papayawhip: 16773077,
|
|
peachpuff: 16767673,
|
|
peru: 13468991,
|
|
pink: 16761035,
|
|
plum: 14524637,
|
|
powderblue: 11591910,
|
|
purple: 8388736,
|
|
rebeccapurple: 6697881,
|
|
red: 16711680,
|
|
rosybrown: 12357519,
|
|
royalblue: 4286945,
|
|
saddlebrown: 9127187,
|
|
salmon: 16416882,
|
|
sandybrown: 16032864,
|
|
seagreen: 3050327,
|
|
seashell: 16774638,
|
|
sienna: 10506797,
|
|
silver: 12632256,
|
|
skyblue: 8900331,
|
|
slateblue: 6970061,
|
|
slategray: 7372944,
|
|
slategrey: 7372944,
|
|
snow: 16775930,
|
|
springgreen: 65407,
|
|
steelblue: 4620980,
|
|
tan: 13808780,
|
|
teal: 32896,
|
|
thistle: 14204888,
|
|
tomato: 16737095,
|
|
turquoise: 4251856,
|
|
violet: 15631086,
|
|
wheat: 16113331,
|
|
white: 16777215,
|
|
whitesmoke: 16119285,
|
|
yellow: 16776960,
|
|
yellowgreen: 10145074
|
|
});
|
|
ua.forEach(function(n, t) {
|
|
ua.set(n, Mn(t))
|
|
}), ao.functor = En, ao.xhr = An(m), ao.dsv = function(n, t) {
|
|
function e(n, e, u) {
|
|
arguments.length < 3 && (u = e, e = null);
|
|
var o = Cn(n, t, null == e ? r : i(e), u);
|
|
return o.row = function(n) {
|
|
return arguments.length ? o.response(null == (e = n) ? r : i(n)) : e
|
|
}, o
|
|
}
|
|
|
|
function r(n) {
|
|
return e.parse(n.responseText)
|
|
}
|
|
|
|
function i(n) {
|
|
return function(t) {
|
|
return e.parse(t.responseText, n)
|
|
}
|
|
}
|
|
|
|
function u(t) {
|
|
return t.map(o).join(n)
|
|
}
|
|
|
|
function o(n) {
|
|
return a.test(n) ? \'"\' + n.replace(/\\"/g, \'""\') + \'"\' : n
|
|
}
|
|
var a = new RegExp(\'["\' + n + "\
|
|
]"),
|
|
l = n.charCodeAt(0);
|
|
return e.parse = function(n, t) {
|
|
var r;
|
|
return e.parseRows(n, function(n, e) {
|
|
if (r) return r(n, e - 1);
|
|
var i = new Function("d", "return {" + n.map(function(n, t) {
|
|
return JSON.stringify(n) + ": d[" + t + "]"
|
|
}).join(",") + "}");
|
|
r = t ? function(n, e) {
|
|
return t(i(n), e)
|
|
} : i
|
|
})
|
|
}, e.parseRows = function(n, t) {
|
|
function e() {
|
|
if (f >= c) return o;
|
|
if (i) return i = !1, u;
|
|
var t = f;
|
|
if (34 === n.charCodeAt(t)) {
|
|
for (var e = t; e++ < c;)
|
|
if (34 === n.charCodeAt(e)) {
|
|
if (34 !== n.charCodeAt(e + 1)) break;
|
|
++e
|
|
}
|
|
f = e + 2;
|
|
var r = n.charCodeAt(e + 1);
|
|
return 13 === r ? (i = !0, 10 === n.charCodeAt(e + 2) && ++f) : 10 === r && (i = !0), n.slice(t + 1, e).replace(/""/g, \'"\')
|
|
}
|
|
for (; c > f;) {
|
|
var r = n.charCodeAt(f++),
|
|
a = 1;
|
|
if (10 === r) i = !0;
|
|
else if (13 === r) i = !0, 10 === n.charCodeAt(f) && (++f, ++a);
|
|
else if (r !== l) continue;
|
|
return n.slice(t, f - a)
|
|
}
|
|
return n.slice(t)
|
|
}
|
|
for (var r, i, u = {}, o = {}, a = [], c = n.length, f = 0, s = 0;
|
|
(r = e()) !== o;) {
|
|
for (var h = []; r !== u && r !== o;) h.push(r), r = e();
|
|
t && null == (h = t(h, s++)) || a.push(h)
|
|
}
|
|
return a
|
|
}, e.format = function(t) {
|
|
if (Array.isArray(t[0])) return e.formatRows(t);
|
|
var r = new y,
|
|
i = [];
|
|
return t.forEach(function(n) {
|
|
for (var t in n) r.has(t) || i.push(r.add(t))
|
|
}), [i.map(o).join(n)].concat(t.map(function(t) {
|
|
return i.map(function(n) {
|
|
return o(t[n])
|
|
}).join(n)
|
|
})).join("\
|
|
")
|
|
}, e.formatRows = function(n) {
|
|
return n.map(u).join("\
|
|
")
|
|
}, e
|
|
}, ao.csv = ao.dsv(",", "text/csv"), ao.tsv = ao.dsv("\t", "text/tab-separated-values");
|
|
var oa, aa, la, ca, fa = this[x(this, "requestAnimationFrame")] || function(n) {
|
|
setTimeout(n, 17)
|
|
};
|
|
ao.timer = function() {
|
|
qn.apply(this, arguments)
|
|
}, ao.timer.flush = function() {
|
|
Rn(), Dn()
|
|
}, ao.round = function(n, t) {
|
|
return t ? Math.round(n * (t = Math.pow(10, t))) / t : Math.round(n)
|
|
};
|
|
var sa = ["y", "z", "a", "f", "p", "n", "\\xb5", "m", "", "k", "M", "G", "T", "P", "E", "Z", "Y"].map(Un);
|
|
ao.formatPrefix = function(n, t) {
|
|
var e = 0;
|
|
return (n = +n) && (0 > n && (n *= -1), t && (n = ao.round(n, Pn(n, t))), e = 1 + Math.floor(1e-12 + Math.log(n) / Math.LN10), e = Math.max(-24, Math.min(24, 3 * Math.floor((e - 1) / 3)))), sa[8 + e / 3]
|
|
};
|
|
var ha = /(?:([^{])?([<>=^]))?([+\\- ])?([$#])?(0)?(\\d+)?(,)?(\\.-?\\d+)?([a-z%])?/i,
|
|
pa = ao.map({
|
|
b: function(n) {
|
|
return n.toString(2)
|
|
},
|
|
c: function(n) {
|
|
return String.fromCharCode(n)
|
|
},
|
|
o: function(n) {
|
|
return n.toString(8)
|
|
},
|
|
x: function(n) {
|
|
return n.toString(16)
|
|
},
|
|
X: function(n) {
|
|
return n.toString(16).toUpperCase()
|
|
},
|
|
g: function(n, t) {
|
|
return n.toPrecision(t)
|
|
},
|
|
e: function(n, t) {
|
|
return n.toExponential(t)
|
|
},
|
|
f: function(n, t) {
|
|
return n.toFixed(t)
|
|
},
|
|
r: function(n, t) {
|
|
return (n = ao.round(n, Pn(n, t))).toFixed(Math.max(0, Math.min(20, Pn(n * (1 + 1e-15), t))))
|
|
}
|
|
}),
|
|
ga = ao.time = {},
|
|
va = Date;
|
|
Hn.prototype = {
|
|
getDate: function() {
|
|
return this._.getUTCDate()
|
|
},
|
|
getDay: function() {
|
|
return this._.getUTCDay()
|
|
},
|
|
getFullYear: function() {
|
|
return this._.getUTCFullYear()
|
|
},
|
|
getHours: function() {
|
|
return this._.getUTCHours()
|
|
},
|
|
getMilliseconds: function() {
|
|
return this._.getUTCMilliseconds()
|
|
},
|
|
getMinutes: function() {
|
|
return this._.getUTCMinutes()
|
|
},
|
|
getMonth: function() {
|
|
return this._.getUTCMonth()
|
|
},
|
|
getSeconds: function() {
|
|
return this._.getUTCSeconds()
|
|
},
|
|
getTime: function() {
|
|
return this._.getTime()
|
|
},
|
|
getTimezoneOffset: function() {
|
|
return 0
|
|
},
|
|
valueOf: function() {
|
|
return this._.valueOf()
|
|
},
|
|
setDate: function() {
|
|
da.setUTCDate.apply(this._, arguments)
|
|
},
|
|
setDay: function() {
|
|
da.setUTCDay.apply(this._, arguments)
|
|
},
|
|
setFullYear: function() {
|
|
da.setUTCFullYear.apply(this._, arguments)
|
|
},
|
|
setHours: function() {
|
|
da.setUTCHours.apply(this._, arguments)
|
|
},
|
|
setMilliseconds: function() {
|
|
da.setUTCMilliseconds.apply(this._, arguments)
|
|
},
|
|
setMinutes: function() {
|
|
da.setUTCMinutes.apply(this._, arguments)
|
|
},
|
|
setMonth: function() {
|
|
da.setUTCMonth.apply(this._, arguments)
|
|
},
|
|
setSeconds: function() {
|
|
da.setUTCSeconds.apply(this._, arguments)
|
|
},
|
|
setTime: function() {
|
|
da.setTime.apply(this._, arguments)
|
|
}
|
|
};
|
|
var da = Date.prototype;
|
|
ga.year = On(function(n) {
|
|
return n = ga.day(n), n.setMonth(0, 1), n
|
|
}, function(n, t) {
|
|
n.setFullYear(n.getFullYear() + t)
|
|
}, function(n) {
|
|
return n.getFullYear()
|
|
}), ga.years = ga.year.range, ga.years.utc = ga.year.utc.range, ga.day = On(function(n) {
|
|
var t = new va(2e3, 0);
|
|
return t.setFullYear(n.getFullYear(), n.getMonth(), n.getDate()), t
|
|
}, function(n, t) {
|
|
n.setDate(n.getDate() + t)
|
|
}, function(n) {
|
|
return n.getDate() - 1
|
|
}), ga.days = ga.day.range, ga.days.utc = ga.day.utc.range, ga.dayOfYear = function(n) {
|
|
var t = ga.year(n);
|
|
return Math.floor((n - t - 6e4 * (n.getTimezoneOffset() - t.getTimezoneOffset())) / 864e5)
|
|
}, ["sunday", "monday", "tuesday", "wednesday", "thursday", "friday", "saturday"].forEach(function(n, t) {
|
|
t = 7 - t;
|
|
var e = ga[n] = On(function(n) {
|
|
return (n = ga.day(n)).setDate(n.getDate() - (n.getDay() + t) % 7), n
|
|
}, function(n, t) {
|
|
n.setDate(n.getDate() + 7 * Math.floor(t))
|
|
}, function(n) {
|
|
var e = ga.year(n).getDay();
|
|
return Math.floor((ga.dayOfYear(n) + (e + t) % 7) / 7) - (e !== t)
|
|
});
|
|
ga[n + "s"] = e.range, ga[n + "s"].utc = e.utc.range, ga[n + "OfYear"] = function(n) {
|
|
var e = ga.year(n).getDay();
|
|
return Math.floor((ga.dayOfYear(n) + (e + t) % 7) / 7)
|
|
}
|
|
}), ga.week = ga.sunday, ga.weeks = ga.sunday.range, ga.weeks.utc = ga.sunday.utc.range, ga.weekOfYear = ga.sundayOfYear;
|
|
var ya = {
|
|
"-": "",
|
|
_: " ",
|
|
0: "0"
|
|
},
|
|
ma = /^\\s*\\d+/,
|
|
Ma = /^%/;
|
|
ao.locale = function(n) {
|
|
return {
|
|
numberFormat: jn(n),
|
|
timeFormat: Yn(n)
|
|
}
|
|
};
|
|
var xa = ao.locale({
|
|
decimal: ".",
|
|
thousands: ",",
|
|
grouping: [3],
|
|
currency: ["$", ""],
|
|
dateTime: "%a %b %e %X %Y",
|
|
date: "%m/%d/%Y",
|
|
time: "%H:%M:%S",
|
|
periods: ["AM", "PM"],
|
|
days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],
|
|
shortDays: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
|
|
months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
|
|
shortMonths: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]
|
|
});
|
|
ao.format = xa.numberFormat, ao.geo = {}, ft.prototype = {
|
|
s: 0,
|
|
t: 0,
|
|
add: function(n) {
|
|
st(n, this.t, ba), st(ba.s, this.s, this), this.s ? this.t += ba.t : this.s = ba.t
|
|
},
|
|
reset: function() {
|
|
this.s = this.t = 0
|
|
},
|
|
valueOf: function() {
|
|
return this.s
|
|
}
|
|
};
|
|
var ba = new ft;
|
|
ao.geo.stream = function(n, t) {
|
|
n && _a.hasOwnProperty(n.type) ? _a[n.type](n, t) : ht(n, t)
|
|
};
|
|
var _a = {
|
|
Feature: function(n, t) {
|
|
ht(n.geometry, t)
|
|
},
|
|
FeatureCollection: function(n, t) {
|
|
for (var e = n.features, r = -1, i = e.length; ++r < i;) ht(e[r].geometry, t)
|
|
}
|
|
},
|
|
wa = {
|
|
Sphere: function(n, t) {
|
|
t.sphere()
|
|
},
|
|
Point: function(n, t) {
|
|
n = n.coordinates, t.point(n[0], n[1], n[2])
|
|
},
|
|
MultiPoint: function(n, t) {
|
|
for (var e = n.coordinates, r = -1, i = e.length; ++r < i;) n = e[r], t.point(n[0], n[1], n[2])
|
|
},
|
|
LineString: function(n, t) {
|
|
pt(n.coordinates, t, 0)
|
|
},
|
|
MultiLineString: function(n, t) {
|
|
for (var e = n.coordinates, r = -1, i = e.length; ++r < i;) pt(e[r], t, 0)
|
|
},
|
|
Polygon: function(n, t) {
|
|
gt(n.coordinates, t)
|
|
},
|
|
MultiPolygon: function(n, t) {
|
|
for (var e = n.coordinates, r = -1, i = e.length; ++r < i;) gt(e[r], t)
|
|
},
|
|
GeometryCollection: function(n, t) {
|
|
for (var e = n.geometries, r = -1, i = e.length; ++r < i;) ht(e[r], t)
|
|
}
|
|
};
|
|
ao.geo.area = function(n) {
|
|
return Sa = 0, ao.geo.stream(n, Na), Sa
|
|
};
|
|
var Sa, ka = new ft,
|
|
Na = {
|
|
sphere: function() {
|
|
Sa += 4 * Fo
|
|
},
|
|
point: b,
|
|
lineStart: b,
|
|
lineEnd: b,
|
|
polygonStart: function() {
|
|
ka.reset(), Na.lineStart = vt
|
|
},
|
|
polygonEnd: function() {
|
|
var n = 2 * ka;
|
|
Sa += 0 > n ? 4 * Fo + n : n, Na.lineStart = Na.lineEnd = Na.point = b
|
|
}
|
|
};
|
|
ao.geo.bounds = function() {
|
|
function n(n, t) {
|
|
M.push(x = [f = n, h = n]), s > t && (s = t), t > p && (p = t)
|
|
}
|
|
|
|
function t(t, e) {
|
|
var r = dt([t * Yo, e * Yo]);
|
|
if (y) {
|
|
var i = mt(y, r),
|
|
u = [i[1], -i[0], 0],
|
|
o = mt(u, i);
|
|
bt(o), o = _t(o);
|
|
var l = t - g,
|
|
c = l > 0 ? 1 : -1,
|
|
v = o[0] * Zo * c,
|
|
d = xo(l) > 180;
|
|
if (d ^ (v > c * g && c * t > v)) {
|
|
var m = o[1] * Zo;
|
|
m > p && (p = m)
|
|
} else if (v = (v + 360) % 360 - 180, d ^ (v > c * g && c * t > v)) {
|
|
var m = -o[1] * Zo;
|
|
s > m && (s = m)
|
|
} else s > e && (s = e), e > p && (p = e);
|
|
d ? g > t ? a(f, t) > a(f, h) && (h = t) : a(t, h) > a(f, h) && (f = t) : h >= f ? (f > t && (f = t), t > h && (h = t)) : t > g ? a(f, t) > a(f, h) && (h = t) : a(t, h) > a(f, h) && (f = t)
|
|
} else n(t, e);
|
|
y = r, g = t
|
|
}
|
|
|
|
function e() {
|
|
b.point = t
|
|
}
|
|
|
|
function r() {
|
|
x[0] = f, x[1] = h, b.point = n, y = null
|
|
}
|
|
|
|
function i(n, e) {
|
|
if (y) {
|
|
var r = n - g;
|
|
m += xo(r) > 180 ? r + (r > 0 ? 360 : -360) : r
|
|
} else v = n, d = e;
|
|
Na.point(n, e), t(n, e)
|
|
}
|
|
|
|
function u() {
|
|
Na.lineStart()
|
|
}
|
|
|
|
function o() {
|
|
i(v, d), Na.lineEnd(), xo(m) > Uo && (f = -(h = 180)), x[0] = f, x[1] = h, y = null
|
|
}
|
|
|
|
function a(n, t) {
|
|
return (t -= n) < 0 ? t + 360 : t
|
|
}
|
|
|
|
function l(n, t) {
|
|
return n[0] - t[0]
|
|
}
|
|
|
|
function c(n, t) {
|
|
return t[0] <= t[1] ? t[0] <= n && n <= t[1] : n < t[0] || t[1] < n
|
|
}
|
|
var f, s, h, p, g, v, d, y, m, M, x, b = {
|
|
point: n,
|
|
lineStart: e,
|
|
lineEnd: r,
|
|
polygonStart: function() {
|
|
b.point = i, b.lineStart = u, b.lineEnd = o, m = 0, Na.polygonStart()
|
|
},
|
|
polygonEnd: function() {
|
|
Na.polygonEnd(), b.point = n, b.lineStart = e, b.lineEnd = r, 0 > ka ? (f = -(h = 180), s = -(p = 90)) : m > Uo ? p = 90 : -Uo > m && (s = -90), x[0] = f, x[1] = h
|
|
}
|
|
};
|
|
return function(n) {
|
|
p = h = -(f = s = 1 / 0), M = [], ao.geo.stream(n, b);
|
|
var t = M.length;
|
|
if (t) {
|
|
M.sort(l);
|
|
for (var e, r = 1, i = M[0], u = [i]; t > r; ++r) e = M[r], c(e[0], i) || c(e[1], i) ? (a(i[0], e[1]) > a(i[0], i[1]) && (i[1] = e[1]), a(e[0], i[1]) > a(i[0], i[1]) && (i[0] = e[0])) : u.push(i = e);
|
|
for (var o, e, g = -(1 / 0), t = u.length - 1, r = 0, i = u[t]; t >= r; i = e, ++r) e = u[r], (o = a(i[1], e[0])) > g && (g = o, f = e[0], h = i[1])
|
|
}
|
|
return M = x = null, f === 1 / 0 || s === 1 / 0 ? [
|
|
[NaN, NaN],
|
|
[NaN, NaN]
|
|
] : [
|
|
[f, s],
|
|
[h, p]
|
|
]
|
|
}
|
|
}(), ao.geo.centroid = function(n) {
|
|
Ea = Aa = Ca = za = La = qa = Ta = Ra = Da = Pa = Ua = 0, ao.geo.stream(n, ja);
|
|
var t = Da,
|
|
e = Pa,
|
|
r = Ua,
|
|
i = t * t + e * e + r * r;
|
|
return jo > i && (t = qa, e = Ta, r = Ra, Uo > Aa && (t = Ca, e = za, r = La), i = t * t + e * e + r * r, jo > i) ? [NaN, NaN] : [Math.atan2(e, t) * Zo, tn(r / Math.sqrt(i)) * Zo]
|
|
};
|
|
var Ea, Aa, Ca, za, La, qa, Ta, Ra, Da, Pa, Ua, ja = {
|
|
sphere: b,
|
|
point: St,
|
|
lineStart: Nt,
|
|
lineEnd: Et,
|
|
polygonStart: function() {
|
|
ja.lineStart = At
|
|
},
|
|
polygonEnd: function() {
|
|
ja.lineStart = Nt
|
|
}
|
|
},
|
|
Fa = Rt(zt, jt, Ht, [-Fo, -Fo / 2]),
|
|
Ha = 1e9;
|
|
ao.geo.clipExtent = function() {
|
|
var n, t, e, r, i, u, o = {
|
|
stream: function(n) {
|
|
return i && (i.valid = !1), i = u(n), i.valid = !0, i
|
|
},
|
|
extent: function(a) {
|
|
return arguments.length ? (u = Zt(n = +a[0][0], t = +a[0][1], e = +a[1][0], r = +a[1][1]), i && (i.valid = !1, i = null), o) : [
|
|
[n, t],
|
|
[e, r]
|
|
]
|
|
}
|
|
};
|
|
return o.extent([
|
|
[0, 0],
|
|
[960, 500]
|
|
])
|
|
}, (ao.geo.conicEqualArea = function() {
|
|
return Vt(Xt)
|
|
}).raw = Xt, ao.geo.albers = function() {
|
|
return ao.geo.conicEqualArea().rotate([96, 0]).center([-.6, 38.7]).parallels([29.5, 45.5]).scale(1070)
|
|
}, ao.geo.albersUsa = function() {
|
|
function n(n) {
|
|
var u = n[0],
|
|
o = n[1];
|
|
return t = null, e(u, o), t || (r(u, o), t) || i(u, o), t
|
|
}
|
|
var t, e, r, i, u = ao.geo.albers(),
|
|
o = ao.geo.conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]),
|
|
a = ao.geo.conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]),
|
|
l = {
|
|
point: function(n, e) {
|
|
t = [n, e]
|
|
}
|
|
};
|
|
return n.invert = function(n) {
|
|
var t = u.scale(),
|
|
e = u.translate(),
|
|
r = (n[0] - e[0]) / t,
|
|
i = (n[1] - e[1]) / t;
|
|
return (i >= .12 && .234 > i && r >= -.425 && -.214 > r ? o : i >= .166 && .234 > i && r >= -.214 && -.115 > r ? a : u).invert(n)
|
|
}, n.stream = function(n) {
|
|
var t = u.stream(n),
|
|
e = o.stream(n),
|
|
r = a.stream(n);
|
|
return {
|
|
point: function(n, i) {
|
|
t.point(n, i), e.point(n, i), r.point(n, i)
|
|
},
|
|
sphere: function() {
|
|
t.sphere(), e.sphere(), r.sphere()
|
|
},
|
|
lineStart: function() {
|
|
t.lineStart(), e.lineStart(), r.lineStart()
|
|
},
|
|
lineEnd: function() {
|
|
t.lineEnd(), e.lineEnd(), r.lineEnd()
|
|
},
|
|
polygonStart: function() {
|
|
t.polygonStart(), e.polygonStart(), r.polygonStart()
|
|
},
|
|
polygonEnd: function() {
|
|
t.polygonEnd(), e.polygonEnd(), r.polygonEnd()
|
|
}
|
|
}
|
|
}, n.precision = function(t) {
|
|
return arguments.length ? (u.precision(t), o.precision(t), a.precision(t), n) : u.precision()
|
|
}, n.scale = function(t) {
|
|
return arguments.length ? (u.scale(t), o.scale(.35 * t), a.scale(t), n.translate(u.translate())) : u.scale()
|
|
}, n.translate = function(t) {
|
|
if (!arguments.length) return u.translate();
|
|
var c = u.scale(),
|
|
f = +t[0],
|
|
s = +t[1];
|
|
return e = u.translate(t).clipExtent([
|
|
[f - .455 * c, s - .238 * c],
|
|
[f + .455 * c, s + .238 * c]
|
|
]).stream(l).point, r = o.translate([f - .307 * c, s + .201 * c]).clipExtent([
|
|
[f - .425 * c + Uo, s + .12 * c + Uo],
|
|
[f - .214 * c - Uo, s + .234 * c - Uo]
|
|
]).stream(l).point, i = a.translate([f - .205 * c, s + .212 * c]).clipExtent([
|
|
[f - .214 * c + Uo, s + .166 * c + Uo],
|
|
[f - .115 * c - Uo, s + .234 * c - Uo]
|
|
]).stream(l).point, n
|
|
}, n.scale(1070)
|
|
};
|
|
var Oa, Ia, Ya, Za, Va, Xa, $a = {
|
|
point: b,
|
|
lineStart: b,
|
|
lineEnd: b,
|
|
polygonStart: function() {
|
|
Ia = 0, $a.lineStart = $t
|
|
},
|
|
polygonEnd: function() {
|
|
$a.lineStart = $a.lineEnd = $a.point = b, Oa += xo(Ia / 2)
|
|
}
|
|
},
|
|
Ba = {
|
|
point: Bt,
|
|
lineStart: b,
|
|
lineEnd: b,
|
|
polygonStart: b,
|
|
polygonEnd: b
|
|
},
|
|
Wa = {
|
|
point: Gt,
|
|
lineStart: Kt,
|
|
lineEnd: Qt,
|
|
polygonStart: function() {
|
|
Wa.lineStart = ne
|
|
},
|
|
polygonEnd: function() {
|
|
Wa.point = Gt, Wa.lineStart = Kt, Wa.lineEnd = Qt
|
|
}
|
|
};
|
|
ao.geo.path = function() {
|
|
function n(n) {
|
|
return n && ("function" == typeof a && u.pointRadius(+a.apply(this, arguments)), o && o.valid || (o = i(u)), ao.geo.stream(n, o)), u.result()
|
|
}
|
|
|
|
function t() {
|
|
return o = null, n
|
|
}
|
|
var e, r, i, u, o, a = 4.5;
|
|
return n.area = function(n) {
|
|
return Oa = 0, ao.geo.stream(n, i($a)), Oa
|
|
}, n.centroid = function(n) {
|
|
return Ca = za = La = qa = Ta = Ra = Da = Pa = Ua = 0, ao.geo.stream(n, i(Wa)), Ua ? [Da / Ua, Pa / Ua] : Ra ? [qa / Ra, Ta / Ra] : La ? [Ca / La, za / La] : [NaN, NaN]
|
|
}, n.bounds = function(n) {
|
|
return Va = Xa = -(Ya = Za = 1 / 0), ao.geo.stream(n, i(Ba)), [
|
|
[Ya, Za],
|
|
[Va, Xa]
|
|
]
|
|
}, n.projection = function(n) {
|
|
return arguments.length ? (i = (e = n) ? n.stream || re(n) : m, t()) : e
|
|
}, n.context = function(n) {
|
|
return arguments.length ? (u = null == (r = n) ? new Wt : new te(n), "function" != typeof a && u.pointRadius(a), t()) : r
|
|
}, n.pointRadius = function(t) {
|
|
return arguments.length ? (a = "function" == typeof t ? t : (u.pointRadius(+t), +t), n) : a
|
|
}, n.projection(ao.geo.albersUsa()).context(null)
|
|
}, ao.geo.transform = function(n) {
|
|
return {
|
|
stream: function(t) {
|
|
var e = new ie(t);
|
|
for (var r in n) e[r] = n[r];
|
|
return e
|
|
}
|
|
}
|
|
}, ie.prototype = {
|
|
point: function(n, t) {
|
|
this.stream.point(n, t)
|
|
},
|
|
sphere: function() {
|
|
this.stream.sphere()
|
|
},
|
|
lineStart: function() {
|
|
this.stream.lineStart()
|
|
},
|
|
lineEnd: function() {
|
|
this.stream.lineEnd()
|
|
},
|
|
polygonStart: function() {
|
|
this.stream.polygonStart()
|
|
},
|
|
polygonEnd: function() {
|
|
this.stream.polygonEnd()
|
|
}
|
|
}, ao.geo.projection = oe, ao.geo.projectionMutator = ae, (ao.geo.equirectangular = function() {
|
|
return oe(ce)
|
|
}).raw = ce.invert = ce, ao.geo.rotation = function(n) {
|
|
function t(t) {
|
|
return t = n(t[0] * Yo, t[1] * Yo), t[0] *= Zo, t[1] *= Zo, t
|
|
}
|
|
return n = se(n[0] % 360 * Yo, n[1] * Yo, n.length > 2 ? n[2] * Yo : 0), t.invert = function(t) {
|
|
return t = n.invert(t[0] * Yo, t[1] * Yo), t[0] *= Zo, t[1] *= Zo, t
|
|
}, t
|
|
}, fe.invert = ce, ao.geo.circle = function() {
|
|
function n() {
|
|
var n = "function" == typeof r ? r.apply(this, arguments) : r,
|
|
t = se(-n[0] * Yo, -n[1] * Yo, 0).invert,
|
|
i = [];
|
|
return e(null, null, 1, {
|
|
point: function(n, e) {
|
|
i.push(n = t(n, e)), n[0] *= Zo, n[1] *= Zo
|
|
}
|
|
}), {
|
|
type: "Polygon",
|
|
coordinates: [i]
|
|
}
|
|
}
|
|
var t, e, r = [0, 0],
|
|
i = 6;
|
|
return n.origin = function(t) {
|
|
return arguments.length ? (r = t, n) : r
|
|
}, n.angle = function(r) {
|
|
return arguments.length ? (e = ve((t = +r) * Yo, i * Yo), n) : t
|
|
}, n.precision = function(r) {
|
|
return arguments.length ? (e = ve(t * Yo, (i = +r) * Yo), n) : i
|
|
}, n.angle(90)
|
|
}, ao.geo.distance = function(n, t) {
|
|
var e, r = (t[0] - n[0]) * Yo,
|
|
i = n[1] * Yo,
|
|
u = t[1] * Yo,
|
|
o = Math.sin(r),
|
|
a = Math.cos(r),
|
|
l = Math.sin(i),
|
|
c = Math.cos(i),
|
|
f = Math.sin(u),
|
|
s = Math.cos(u);
|
|
return Math.atan2(Math.sqrt((e = s * o) * e + (e = c * f - l * s * a) * e), l * f + c * s * a)
|
|
}, ao.geo.graticule = function() {
|
|
function n() {
|
|
return {
|
|
type: "MultiLineString",
|
|
coordinates: t()
|
|
}
|
|
}
|
|
|
|
function t() {
|
|
return ao.range(Math.ceil(u / d) * d, i, d).map(h).concat(ao.range(Math.ceil(c / y) * y, l, y).map(p)).concat(ao.range(Math.ceil(r / g) * g, e, g).filter(function(n) {
|
|
return xo(n % d) > Uo
|
|
}).map(f)).concat(ao.range(Math.ceil(a / v) * v, o, v).filter(function(n) {
|
|
return xo(n % y) > Uo
|
|
}).map(s))
|
|
}
|
|
var e, r, i, u, o, a, l, c, f, s, h, p, g = 10,
|
|
v = g,
|
|
d = 90,
|
|
y = 360,
|
|
m = 2.5;
|
|
return n.lines = function() {
|
|
return t().map(function(n) {
|
|
return {
|
|
type: "LineString",
|
|
coordinates: n
|
|
}
|
|
})
|
|
}, n.outline = function() {
|
|
return {
|
|
type: "Polygon",
|
|
coordinates: [h(u).concat(p(l).slice(1), h(i).reverse().slice(1), p(c).reverse().slice(1))]
|
|
}
|
|
}, n.extent = function(t) {
|
|
return arguments.length ? n.majorExtent(t).minorExtent(t) : n.minorExtent()
|
|
}, n.majorExtent = function(t) {
|
|
return arguments.length ? (u = +t[0][0], i = +t[1][0], c = +t[0][1], l = +t[1][1], u > i && (t = u, u = i, i = t), c > l && (t = c, c = l, l = t), n.precision(m)) : [
|
|
[u, c],
|
|
[i, l]
|
|
]
|
|
}, n.minorExtent = function(t) {
|
|
return arguments.length ? (r = +t[0][0], e = +t[1][0], a = +t[0][1], o = +t[1][1], r > e && (t = r, r = e, e = t), a > o && (t = a, a = o, o = t), n.precision(m)) : [
|
|
[r, a],
|
|
[e, o]
|
|
]
|
|
}, n.step = function(t) {
|
|
return arguments.length ? n.majorStep(t).minorStep(t) : n.minorStep()
|
|
}, n.majorStep = function(t) {
|
|
return arguments.length ? (d = +t[0], y = +t[1], n) : [d, y]
|
|
}, n.minorStep = function(t) {
|
|
return arguments.length ? (g = +t[0], v = +t[1], n) : [g, v]
|
|
}, n.precision = function(t) {
|
|
return arguments.length ? (m = +t, f = ye(a, o, 90), s = me(r, e, m), h = ye(c, l, 90), p = me(u, i, m), n) : m
|
|
}, n.majorExtent([
|
|
[-180, -90 + Uo],
|
|
[180, 90 - Uo]
|
|
]).minorExtent([
|
|
[-180, -80 - Uo],
|
|
[180, 80 + Uo]
|
|
])
|
|
}, ao.geo.greatArc = function() {
|
|
function n() {
|
|
return {
|
|
type: "LineString",
|
|
coordinates: [t || r.apply(this, arguments), e || i.apply(this, arguments)]
|
|
}
|
|
}
|
|
var t, e, r = Me,
|
|
i = xe;
|
|
return n.distance = function() {
|
|
return ao.geo.distance(t || r.apply(this, arguments), e || i.apply(this, arguments))
|
|
}, n.source = function(e) {
|
|
return arguments.length ? (r = e, t = "function" == typeof e ? null : e, n) : r
|
|
}, n.target = function(t) {
|
|
return arguments.length ? (i = t, e = "function" == typeof t ? null : t, n) : i
|
|
}, n.precision = function() {
|
|
return arguments.length ? n : 0
|
|
}, n
|
|
}, ao.geo.interpolate = function(n, t) {
|
|
return be(n[0] * Yo, n[1] * Yo, t[0] * Yo, t[1] * Yo)
|
|
}, ao.geo.length = function(n) {
|
|
return Ja = 0, ao.geo.stream(n, Ga), Ja
|
|
};
|
|
var Ja, Ga = {
|
|
sphere: b,
|
|
point: b,
|
|
lineStart: _e,
|
|
lineEnd: b,
|
|
polygonStart: b,
|
|
polygonEnd: b
|
|
},
|
|
Ka = we(function(n) {
|
|
return Math.sqrt(2 / (1 + n))
|
|
}, function(n) {
|
|
return 2 * Math.asin(n / 2)
|
|
});
|
|
(ao.geo.azimuthalEqualArea = function() {
|
|
return oe(Ka)
|
|
}).raw = Ka;
|
|
var Qa = we(function(n) {
|
|
var t = Math.acos(n);
|
|
return t && t / Math.sin(t)
|
|
}, m);
|
|
(ao.geo.azimuthalEquidistant = function() {
|
|
return oe(Qa)
|
|
}).raw = Qa, (ao.geo.conicConformal = function() {
|
|
return Vt(Se)
|
|
}).raw = Se, (ao.geo.conicEquidistant = function() {
|
|
return Vt(ke)
|
|
}).raw = ke;
|
|
var nl = we(function(n) {
|
|
return 1 / n
|
|
}, Math.atan);
|
|
(ao.geo.gnomonic = function() {
|
|
return oe(nl)
|
|
}).raw = nl, Ne.invert = function(n, t) {
|
|
return [n, 2 * Math.atan(Math.exp(t)) - Io]
|
|
}, (ao.geo.mercator = function() {
|
|
return Ee(Ne)
|
|
}).raw = Ne;
|
|
var tl = we(function() {
|
|
return 1
|
|
}, Math.asin);
|
|
(ao.geo.orthographic = function() {
|
|
return oe(tl)
|
|
}).raw = tl;
|
|
var el = we(function(n) {
|
|
return 1 / (1 + n)
|
|
}, function(n) {
|
|
return 2 * Math.atan(n)
|
|
});
|
|
(ao.geo.stereographic = function() {
|
|
return oe(el)
|
|
}).raw = el, Ae.invert = function(n, t) {
|
|
return [-t, 2 * Math.atan(Math.exp(n)) - Io]
|
|
}, (ao.geo.transverseMercator = function() {
|
|
var n = Ee(Ae),
|
|
t = n.center,
|
|
e = n.rotate;
|
|
return n.center = function(n) {
|
|
return n ? t([-n[1], n[0]]) : (n = t(), [n[1], -n[0]])
|
|
}, n.rotate = function(n) {
|
|
return n ? e([n[0], n[1], n.length > 2 ? n[2] + 90 : 90]) : (n = e(), [n[0], n[1], n[2] - 90])
|
|
}, e([0, 0, 90])
|
|
}).raw = Ae, ao.geom = {}, ao.geom.hull = function(n) {
|
|
function t(n) {
|
|
if (n.length < 3) return [];
|
|
var t, i = En(e),
|
|
u = En(r),
|
|
o = n.length,
|
|
a = [],
|
|
l = [];
|
|
for (t = 0; o > t; t++) a.push([+i.call(this, n[t], t), +u.call(this, n[t], t), t]);
|
|
for (a.sort(qe), t = 0; o > t; t++) l.push([a[t][0], -a[t][1]]);
|
|
var c = Le(a),
|
|
f = Le(l),
|
|
s = f[0] === c[0],
|
|
h = f[f.length - 1] === c[c.length - 1],
|
|
p = [];
|
|
for (t = c.length - 1; t >= 0; --t) p.push(n[a[c[t]][2]]);
|
|
for (t = +s; t < f.length - h; ++t) p.push(n[a[f[t]][2]]);
|
|
return p
|
|
}
|
|
var e = Ce,
|
|
r = ze;
|
|
return arguments.length ? t(n) : (t.x = function(n) {
|
|
return arguments.length ? (e = n, t) : e
|
|
}, t.y = function(n) {
|
|
return arguments.length ? (r = n, t) : r
|
|
}, t)
|
|
}, ao.geom.polygon = function(n) {
|
|
return ko(n, rl), n
|
|
};
|
|
var rl = ao.geom.polygon.prototype = [];
|
|
rl.area = function() {
|
|
for (var n, t = -1, e = this.length, r = this[e - 1], i = 0; ++t < e;) n = r, r = this[t], i += n[1] * r[0] - n[0] * r[1];
|
|
return .5 * i
|
|
}, rl.centroid = function(n) {
|
|
var t, e, r = -1,
|
|
i = this.length,
|
|
u = 0,
|
|
o = 0,
|
|
a = this[i - 1];
|
|
for (arguments.length || (n = -1 / (6 * this.area())); ++r < i;) t = a, a = this[r], e = t[0] * a[1] - a[0] * t[1], u += (t[0] + a[0]) * e, o += (t[1] + a[1]) * e;
|
|
return [u * n, o * n]
|
|
}, rl.clip = function(n) {
|
|
for (var t, e, r, i, u, o, a = De(n), l = -1, c = this.length - De(this), f = this[c - 1]; ++l < c;) {
|
|
for (t = n.slice(), n.length = 0, i = this[l], u = t[(r = t.length - a) - 1], e = -1; ++e < r;) o = t[e], Te(o, f, i) ? (Te(u, f, i) || n.push(Re(u, o, f, i)), n.push(o)) : Te(u, f, i) && n.push(Re(u, o, f, i)), u = o;
|
|
a && n.push(n[0]), f = i
|
|
}
|
|
return n
|
|
};
|
|
var il, ul, ol, al, ll, cl = [],
|
|
fl = [];
|
|
Ye.prototype.prepare = function() {
|
|
for (var n, t = this.edges, e = t.length; e--;) n = t[e].edge, n.b && n.a || t.splice(e, 1);
|
|
return t.sort(Ve), t.length
|
|
}, tr.prototype = {
|
|
start: function() {
|
|
return this.edge.l === this.site ? this.edge.a : this.edge.b
|
|
},
|
|
end: function() {
|
|
return this.edge.l === this.site ? this.edge.b : this.edge.a
|
|
}
|
|
}, er.prototype = {
|
|
insert: function(n, t) {
|
|
var e, r, i;
|
|
if (n) {
|
|
if (t.P = n, t.N = n.N, n.N && (n.N.P = t), n.N = t, n.R) {
|
|
for (n = n.R; n.L;) n = n.L;
|
|
n.L = t
|
|
} else n.R = t;
|
|
e = n
|
|
} else this._ ? (n = or(this._), t.P = null, t.N = n, n.P = n.L = t, e = n) : (t.P = t.N = null, this._ = t, e = null);
|
|
for (t.L = t.R = null, t.U = e, t.C = !0, n = t; e && e.C;) r = e.U, e === r.L ? (i = r.R, i && i.C ? (e.C = i.C = !1, r.C = !0, n = r) : (n === e.R && (ir(this, e), n = e, e = n.U), e.C = !1, r.C = !0, ur(this, r))) : (i = r.L, i && i.C ? (e.C = i.C = !1, r.C = !0, n = r) : (n === e.L && (ur(this, e), n = e, e = n.U), e.C = !1, r.C = !0, ir(this, r))), e = n.U;
|
|
this._.C = !1
|
|
},
|
|
remove: function(n) {
|
|
n.N && (n.N.P = n.P), n.P && (n.P.N = n.N), n.N = n.P = null;
|
|
var t, e, r, i = n.U,
|
|
u = n.L,
|
|
o = n.R;
|
|
if (e = u ? o ? or(o) : u : o, i ? i.L === n ? i.L = e : i.R = e : this._ = e, u && o ? (r = e.C, e.C = n.C, e.L = u, u.U = e, e !== o ? (i = e.U, e.U = n.U, n = e.R, i.L = n, e.R = o, o.U = e) : (e.U = i, i = e, n = e.R)) : (r = n.C, n = e), n && (n.U = i), !r) {
|
|
if (n && n.C) return void(n.C = !1);
|
|
do {
|
|
if (n === this._) break;
|
|
if (n === i.L) {
|
|
if (t = i.R, t.C && (t.C = !1, i.C = !0, ir(this, i), t = i.R), t.L && t.L.C || t.R && t.R.C) {
|
|
t.R && t.R.C || (t.L.C = !1, t.C = !0, ur(this, t), t = i.R), t.C = i.C, i.C = t.R.C = !1, ir(this, i), n = this._;
|
|
break
|
|
}
|
|
} else if (t = i.L, t.C && (t.C = !1, i.C = !0, ur(this, i), t = i.L), t.L && t.L.C || t.R && t.R.C) {
|
|
t.L && t.L.C || (t.R.C = !1, t.C = !0, ir(this, t), t = i.L), t.C = i.C, i.C = t.L.C = !1, ur(this, i), n = this._;
|
|
break
|
|
}
|
|
t.C = !0, n = i, i = i.U
|
|
} while (!n.C);
|
|
n && (n.C = !1)
|
|
}
|
|
}
|
|
}, ao.geom.voronoi = function(n) {
|
|
function t(n) {
|
|
var t = new Array(n.length),
|
|
r = a[0][0],
|
|
i = a[0][1],
|
|
u = a[1][0],
|
|
o = a[1][1];
|
|
return ar(e(n), a).cells.forEach(function(e, a) {
|
|
var l = e.edges,
|
|
c = e.site,
|
|
f = t[a] = l.length ? l.map(function(n) {
|
|
var t = n.start();
|
|
return [t.x, t.y]
|
|
}) : c.x >= r && c.x <= u && c.y >= i && c.y <= o ? [
|
|
[r, o],
|
|
[u, o],
|
|
[u, i],
|
|
[r, i]
|
|
] : [];
|
|
f.point = n[a]
|
|
}), t
|
|
}
|
|
|
|
function e(n) {
|
|
return n.map(function(n, t) {
|
|
return {
|
|
x: Math.round(u(n, t) / Uo) * Uo,
|
|
y: Math.round(o(n, t) / Uo) * Uo,
|
|
i: t
|
|
}
|
|
})
|
|
}
|
|
var r = Ce,
|
|
i = ze,
|
|
u = r,
|
|
o = i,
|
|
a = sl;
|
|
return n ? t(n) : (t.links = function(n) {
|
|
return ar(e(n)).edges.filter(function(n) {
|
|
return n.l && n.r
|
|
}).map(function(t) {
|
|
return {
|
|
source: n[t.l.i],
|
|
target: n[t.r.i]
|
|
}
|
|
})
|
|
}, t.triangles = function(n) {
|
|
var t = [];
|
|
return ar(e(n)).cells.forEach(function(e, r) {
|
|
for (var i, u, o = e.site, a = e.edges.sort(Ve), l = -1, c = a.length, f = a[c - 1].edge, s = f.l === o ? f.r : f.l; ++l < c;) i = f, u = s, f = a[l].edge, s = f.l === o ? f.r : f.l, r < u.i && r < s.i && cr(o, u, s) < 0 && t.push([n[r], n[u.i], n[s.i]])
|
|
}), t
|
|
}, t.x = function(n) {
|
|
return arguments.length ? (u = En(r = n), t) : r
|
|
}, t.y = function(n) {
|
|
return arguments.length ? (o = En(i = n), t) : i
|
|
}, t.clipExtent = function(n) {
|
|
return arguments.length ? (a = null == n ? sl : n, t) : a === sl ? null : a
|
|
}, t.size = function(n) {
|
|
return arguments.length ? t.clipExtent(n && [
|
|
[0, 0], n
|
|
]) : a === sl ? null : a && a[1]
|
|
}, t)
|
|
};
|
|
var sl = [
|
|
[-1e6, -1e6],
|
|
[1e6, 1e6]
|
|
];
|
|
ao.geom.delaunay = function(n) {
|
|
return ao.geom.voronoi().triangles(n)
|
|
}, ao.geom.quadtree = function(n, t, e, r, i) {
|
|
function u(n) {
|
|
function u(n, t, e, r, i, u, o, a) {
|
|
if (!isNaN(e) && !isNaN(r))
|
|
if (n.leaf) {
|
|
var l = n.x,
|
|
f = n.y;
|
|
if (null != l)
|
|
if (xo(l - e) + xo(f - r) < .01) c(n, t, e, r, i, u, o, a);
|
|
else {
|
|
var s = n.point;
|
|
n.x = n.y = n.point = null, c(n, s, l, f, i, u, o, a), c(n, t, e, r, i, u, o, a)
|
|
}
|
|
else n.x = e, n.y = r, n.point = t
|
|
} else c(n, t, e, r, i, u, o, a)
|
|
}
|
|
|
|
function c(n, t, e, r, i, o, a, l) {
|
|
var c = .5 * (i + a),
|
|
f = .5 * (o + l),
|
|
s = e >= c,
|
|
h = r >= f,
|
|
p = h << 1 | s;
|
|
n.leaf = !1, n = n.nodes[p] || (n.nodes[p] = hr()), s ? i = c : a = c, h ? o = f : l = f, u(n, t, e, r, i, o, a, l)
|
|
}
|
|
var f, s, h, p, g, v, d, y, m, M = En(a),
|
|
x = En(l);
|
|
if (null != t) v = t, d = e, y = r, m = i;
|
|
else if (y = m = -(v = d = 1 / 0), s = [], h = [], g = n.length, o)
|
|
for (p = 0; g > p; ++p) f = n[p], f.x < v && (v = f.x), f.y < d && (d = f.y), f.x > y && (y = f.x), f.y > m && (m = f.y), s.push(f.x), h.push(f.y);
|
|
else
|
|
for (p = 0; g > p; ++p) {
|
|
var b = +M(f = n[p], p),
|
|
_ = +x(f, p);
|
|
v > b && (v = b), d > _ && (d = _), b > y && (y = b), _ > m && (m = _), s.push(b), h.push(_)
|
|
}
|
|
var w = y - v,
|
|
S = m - d;
|
|
w > S ? m = d + w : y = v + S;
|
|
var k = hr();
|
|
if (k.add = function(n) {
|
|
u(k, n, +M(n, ++p), +x(n, p), v, d, y, m)
|
|
}, k.visit = function(n) {
|
|
pr(n, k, v, d, y, m)
|
|
}, k.find = function(n) {
|
|
return gr(k, n[0], n[1], v, d, y, m)
|
|
}, p = -1, null == t) {
|
|
for (; ++p < g;) u(k, n[p], s[p], h[p], v, d, y, m);
|
|
--p
|
|
} else n.forEach(k.add);
|
|
return s = h = n = f = null, k
|
|
}
|
|
var o, a = Ce,
|
|
l = ze;
|
|
return (o = arguments.length) ? (a = fr, l = sr, 3 === o && (i = e, r = t, e = t = 0), u(n)) : (u.x = function(n) {
|
|
return arguments.length ? (a = n, u) : a
|
|
}, u.y = function(n) {
|
|
return arguments.length ? (l = n, u) : l
|
|
}, u.extent = function(n) {
|
|
return arguments.length ? (null == n ? t = e = r = i = null : (t = +n[0][0], e = +n[0][1], r = +n[1][0], i = +n[1][1]), u) : null == t ? null : [
|
|
[t, e],
|
|
[r, i]
|
|
]
|
|
}, u.size = function(n) {
|
|
return arguments.length ? (null == n ? t = e = r = i = null : (t = e = 0, r = +n[0], i = +n[1]), u) : null == t ? null : [r - t, i - e]
|
|
}, u)
|
|
}, ao.interpolateRgb = vr, ao.interpolateObject = dr, ao.interpolateNumber = yr, ao.interpolateString = mr;
|
|
var hl = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,
|
|
pl = new RegExp(hl.source, "g");
|
|
ao.interpolate = Mr, ao.interpolators = [function(n, t) {
|
|
var e = typeof t;
|
|
return ("string" === e ? ua.has(t.toLowerCase()) || /^(#|rgb\\(|hsl\\()/i.test(t) ? vr : mr : t instanceof an ? vr : Array.isArray(t) ? xr : "object" === e && isNaN(t) ? dr : yr)(n, t)
|
|
}], ao.interpolateArray = xr;
|
|
var gl = function() {
|
|
return m
|
|
},
|
|
vl = ao.map({
|
|
linear: gl,
|
|
poly: Er,
|
|
quad: function() {
|
|
return Sr
|
|
},
|
|
cubic: function() {
|
|
return kr
|
|
},
|
|
sin: function() {
|
|
return Ar
|
|
},
|
|
exp: function() {
|
|
return Cr
|
|
},
|
|
circle: function() {
|
|
return zr
|
|
},
|
|
elastic: Lr,
|
|
back: qr,
|
|
bounce: function() {
|
|
return Tr
|
|
}
|
|
}),
|
|
dl = ao.map({
|
|
"in": m,
|
|
out: _r,
|
|
"in-out": wr,
|
|
"out-in": function(n) {
|
|
return wr(_r(n))
|
|
}
|
|
});
|
|
ao.ease = function(n) {
|
|
var t = n.indexOf("-"),
|
|
e = t >= 0 ? n.slice(0, t) : n,
|
|
r = t >= 0 ? n.slice(t + 1) : "in";
|
|
return e = vl.get(e) || gl, r = dl.get(r) || m, br(r(e.apply(null, lo.call(arguments, 1))))
|
|
}, ao.interpolateHcl = Rr, ao.interpolateHsl = Dr, ao.interpolateLab = Pr, ao.interpolateRound = Ur, ao.transform = function(n) {
|
|
var t = fo.createElementNS(ao.ns.prefix.svg, "g");
|
|
return (ao.transform = function(n) {
|
|
if (null != n) {
|
|
t.setAttribute("transform", n);
|
|
var e = t.transform.baseVal.consolidate()
|
|
}
|
|
return new jr(e ? e.matrix : yl)
|
|
})(n)
|
|
}, jr.prototype.toString = function() {
|
|
return "translate(" + this.translate + ")rotate(" + this.rotate + ")skewX(" + this.skew + ")scale(" + this.scale + ")"
|
|
};
|
|
var yl = {
|
|
a: 1,
|
|
b: 0,
|
|
c: 0,
|
|
d: 1,
|
|
e: 0,
|
|
f: 0
|
|
};
|
|
ao.interpolateTransform = $r, ao.layout = {}, ao.layout.bundle = function() {
|
|
return function(n) {
|
|
for (var t = [], e = -1, r = n.length; ++e < r;) t.push(Jr(n[e]));
|
|
return t
|
|
}
|
|
}, ao.layout.chord = function() {
|
|
function n() {
|
|
var n, c, s, h, p, g = {},
|
|
v = [],
|
|
d = ao.range(u),
|
|
y = [];
|
|
for (e = [], r = [], n = 0, h = -1; ++h < u;) {
|
|
for (c = 0, p = -1; ++p < u;) c += i[h][p];
|
|
v.push(c), y.push(ao.range(u)), n += c
|
|
}
|
|
for (o && d.sort(function(n, t) {
|
|
return o(v[n], v[t])
|
|
}), a && y.forEach(function(n, t) {
|
|
n.sort(function(n, e) {
|
|
return a(i[t][n], i[t][e])
|
|
})
|
|
}), n = (Ho - f * u) / n, c = 0, h = -1; ++h < u;) {
|
|
for (s = c, p = -1; ++p < u;) {
|
|
var m = d[h],
|
|
M = y[m][p],
|
|
x = i[m][M],
|
|
b = c,
|
|
_ = c += x * n;
|
|
g[m + "-" + M] = {
|
|
index: m,
|
|
subindex: M,
|
|
startAngle: b,
|
|
endAngle: _,
|
|
value: x
|
|
}
|
|
}
|
|
r[m] = {
|
|
index: m,
|
|
startAngle: s,
|
|
endAngle: c,
|
|
value: v[m]
|
|
}, c += f
|
|
}
|
|
for (h = -1; ++h < u;)
|
|
for (p = h - 1; ++p < u;) {
|
|
var w = g[h + "-" + p],
|
|
S = g[p + "-" + h];
|
|
(w.value || S.value) && e.push(w.value < S.value ? {
|
|
source: S,
|
|
target: w
|
|
} : {
|
|
source: w,
|
|
target: S
|
|
})
|
|
}
|
|
l && t()
|
|
}
|
|
|
|
function t() {
|
|
e.sort(function(n, t) {
|
|
return l((n.source.value + n.target.value) / 2, (t.source.value + t.target.value) / 2)
|
|
})
|
|
}
|
|
var e, r, i, u, o, a, l, c = {},
|
|
f = 0;
|
|
return c.matrix = function(n) {
|
|
return arguments.length ? (u = (i = n) && i.length, e = r = null, c) : i
|
|
}, c.padding = function(n) {
|
|
return arguments.length ? (f = n, e = r = null, c) : f
|
|
}, c.sortGroups = function(n) {
|
|
return arguments.length ? (o = n, e = r = null, c) : o
|
|
}, c.sortSubgroups = function(n) {
|
|
return arguments.length ? (a = n, e = null, c) : a
|
|
}, c.sortChords = function(n) {
|
|
return arguments.length ? (l = n, e && t(), c) : l
|
|
}, c.chords = function() {
|
|
return e || n(), e
|
|
}, c.groups = function() {
|
|
return r || n(), r
|
|
}, c
|
|
}, ao.layout.force = function() {
|
|
function n(n) {
|
|
return function(t, e, r, i) {
|
|
if (t.point !== n) {
|
|
var u = t.cx - n.x,
|
|
o = t.cy - n.y,
|
|
a = i - e,
|
|
l = u * u + o * o;
|
|
if (l > a * a / y) {
|
|
if (v > l) {
|
|
var c = t.charge / l;
|
|
n.px -= u * c, n.py -= o * c
|
|
}
|
|
return !0
|
|
}
|
|
if (t.point && l && v > l) {
|
|
var c = t.pointCharge / l;
|
|
n.px -= u * c, n.py -= o * c
|
|
}
|
|
}
|
|
return !t.charge
|
|
}
|
|
}
|
|
|
|
function t(n) {
|
|
n.px = ao.event.x, n.py = ao.event.y, l.resume()
|
|
}
|
|
var e, r, i, u, o, a, l = {},
|
|
c = ao.dispatch("start", "tick", "end"),
|
|
f = [1, 1],
|
|
s = .9,
|
|
h = ml,
|
|
p = Ml,
|
|
g = -30,
|
|
v = xl,
|
|
d = .1,
|
|
y = .64,
|
|
M = [],
|
|
x = [];
|
|
return l.tick = function() {
|
|
if ((i *= .99) < .005) return e = null, c.end({
|
|
type: "end",
|
|
alpha: i = 0
|
|
}), !0;
|
|
var t, r, l, h, p, v, y, m, b, _ = M.length,
|
|
w = x.length;
|
|
for (r = 0; w > r; ++r) l = x[r], h = l.source, p = l.target, m = p.x - h.x, b = p.y - h.y, (v = m * m + b * b) && (v = i * o[r] * ((v = Math.sqrt(v)) - u[r]) / v, m *= v, b *= v, p.x -= m * (y = h.weight + p.weight ? h.weight / (h.weight + p.weight) : .5), p.y -= b * y, h.x += m * (y = 1 - y), h.y += b * y);
|
|
if ((y = i * d) && (m = f[0] / 2, b = f[1] / 2, r = -1, y))
|
|
for (; ++r < _;) l = M[r], l.x += (m - l.x) * y, l.y += (b - l.y) * y;
|
|
if (g)
|
|
for (ri(t = ao.geom.quadtree(M), i, a), r = -1; ++r < _;)(l = M[r]).fixed || t.visit(n(l));
|
|
for (r = -1; ++r < _;) l = M[r], l.fixed ? (l.x = l.px, l.y = l.py) : (l.x -= (l.px - (l.px = l.x)) * s, l.y -= (l.py - (l.py = l.y)) * s);
|
|
c.tick({
|
|
type: "tick",
|
|
alpha: i
|
|
})
|
|
}, l.nodes = function(n) {
|
|
return arguments.length ? (M = n, l) : M
|
|
}, l.links = function(n) {
|
|
return arguments.length ? (x = n, l) : x
|
|
}, l.size = function(n) {
|
|
return arguments.length ? (f = n, l) : f
|
|
}, l.linkDistance = function(n) {
|
|
return arguments.length ? (h = "function" == typeof n ? n : +n, l) : h
|
|
}, l.distance = l.linkDistance, l.linkStrength = function(n) {
|
|
return arguments.length ? (p = "function" == typeof n ? n : +n, l) : p
|
|
}, l.friction = function(n) {
|
|
return arguments.length ? (s = +n, l) : s
|
|
}, l.charge = function(n) {
|
|
return arguments.length ? (g = "function" == typeof n ? n : +n, l) : g
|
|
}, l.chargeDistance = function(n) {
|
|
return arguments.length ? (v = n * n, l) : Math.sqrt(v)
|
|
}, l.gravity = function(n) {
|
|
return arguments.length ? (d = +n, l) : d
|
|
}, l.theta = function(n) {
|
|
return arguments.length ? (y = n * n, l) : Math.sqrt(y)
|
|
}, l.alpha = function(n) {
|
|
return arguments.length ? (n = +n, i ? n > 0 ? i = n : (e.c = null, e.t = NaN, e = null, c.end({
|
|
type: "end",
|
|
alpha: i = 0
|
|
})) : n > 0 && (c.start({
|
|
type: "start",
|
|
alpha: i = n
|
|
}), e = qn(l.tick)), l) : i
|
|
}, l.start = function() {
|
|
function n(n, r) {
|
|
if (!e) {
|
|
for (e = new Array(i), l = 0; i > l; ++l) e[l] = [];
|
|
for (l = 0; c > l; ++l) {
|
|
var u = x[l];
|
|
e[u.source.index].push(u.target), e[u.target.index].push(u.source)
|
|
}
|
|
}
|
|
for (var o, a = e[t], l = -1, f = a.length; ++l < f;)
|
|
if (!isNaN(o = a[l][n])) return o;
|
|
return Math.random() * r
|
|
}
|
|
var t, e, r, i = M.length,
|
|
c = x.length,
|
|
s = f[0],
|
|
v = f[1];
|
|
for (t = 0; i > t; ++t)(r = M[t]).index = t, r.weight = 0;
|
|
for (t = 0; c > t; ++t) r = x[t], "number" == typeof r.source && (r.source = M[r.source]), "number" == typeof r.target && (r.target = M[r.target]), ++r.source.weight, ++r.target.weight;
|
|
for (t = 0; i > t; ++t) r = M[t], isNaN(r.x) && (r.x = n("x", s)), isNaN(r.y) && (r.y = n("y", v)), isNaN(r.px) && (r.px = r.x), isNaN(r.py) && (r.py = r.y);
|
|
if (u = [], "function" == typeof h)
|
|
for (t = 0; c > t; ++t) u[t] = +h.call(this, x[t], t);
|
|
else
|
|
for (t = 0; c > t; ++t) u[t] = h;
|
|
if (o = [], "function" == typeof p)
|
|
for (t = 0; c > t; ++t) o[t] = +p.call(this, x[t], t);
|
|
else
|
|
for (t = 0; c > t; ++t) o[t] = p;
|
|
if (a = [], "function" == typeof g)
|
|
for (t = 0; i > t; ++t) a[t] = +g.call(this, M[t], t);
|
|
else
|
|
for (t = 0; i > t; ++t) a[t] = g;
|
|
return l.resume()
|
|
}, l.resume = function() {
|
|
return l.alpha(.1)
|
|
}, l.stop = function() {
|
|
return l.alpha(0)
|
|
}, l.drag = function() {
|
|
return r || (r = ao.behavior.drag().origin(m).on("dragstart.force", Qr).on("drag.force", t).on("dragend.force", ni)), arguments.length ? void this.on("mouseover.force", ti).on("mouseout.force", ei).call(r) : r
|
|
}, ao.rebind(l, c, "on")
|
|
};
|
|
var ml = 20,
|
|
Ml = 1,
|
|
xl = 1 / 0;
|
|
ao.layout.hierarchy = function() {
|
|
function n(i) {
|
|
var u, o = [i],
|
|
a = [];
|
|
for (i.depth = 0; null != (u = o.pop());)
|
|
if (a.push(u), (c = e.call(n, u, u.depth)) && (l = c.length)) {
|
|
for (var l, c, f; --l >= 0;) o.push(f = c[l]), f.parent = u, f.depth = u.depth + 1;
|
|
r && (u.value = 0), u.children = c
|
|
} else r && (u.value = +r.call(n, u, u.depth) || 0), delete u.children;
|
|
return oi(i, function(n) {
|
|
var e, i;
|
|
t && (e = n.children) && e.sort(t), r && (i = n.parent) && (i.value += n.value)
|
|
}), a
|
|
}
|
|
var t = ci,
|
|
e = ai,
|
|
r = li;
|
|
return n.sort = function(e) {
|
|
return arguments.length ? (t = e, n) : t
|
|
}, n.children = function(t) {
|
|
return arguments.length ? (e = t, n) : e
|
|
}, n.value = function(t) {
|
|
return arguments.length ? (r = t, n) : r
|
|
}, n.revalue = function(t) {
|
|
return r && (ui(t, function(n) {
|
|
n.children && (n.value = 0)
|
|
}), oi(t, function(t) {
|
|
var e;
|
|
t.children || (t.value = +r.call(n, t, t.depth) || 0), (e = t.parent) && (e.value += t.value)
|
|
})), t
|
|
}, n
|
|
}, ao.layout.partition = function() {
|
|
function n(t, e, r, i) {
|
|
var u = t.children;
|
|
if (t.x = e, t.y = t.depth * i, t.dx = r, t.dy = i, u && (o = u.length)) {
|
|
var o, a, l, c = -1;
|
|
for (r = t.value ? r / t.value : 0; ++c < o;) n(a = u[c], e, l = a.value * r, i), e += l
|
|
}
|
|
}
|
|
|
|
function t(n) {
|
|
var e = n.children,
|
|
r = 0;
|
|
if (e && (i = e.length))
|
|
for (var i, u = -1; ++u < i;) r = Math.max(r, t(e[u]));
|
|
return 1 + r
|
|
}
|
|
|
|
function e(e, u) {
|
|
var o = r.call(this, e, u);
|
|
return n(o[0], 0, i[0], i[1] / t(o[0])), o
|
|
}
|
|
var r = ao.layout.hierarchy(),
|
|
i = [1, 1];
|
|
return e.size = function(n) {
|
|
return arguments.length ? (i = n, e) : i
|
|
}, ii(e, r)
|
|
}, ao.layout.pie = function() {
|
|
function n(o) {
|
|
var a, l = o.length,
|
|
c = o.map(function(e, r) {
|
|
return +t.call(n, e, r)
|
|
}),
|
|
f = +("function" == typeof r ? r.apply(this, arguments) : r),
|
|
s = ("function" == typeof i ? i.apply(this, arguments) : i) - f,
|
|
h = Math.min(Math.abs(s) / l, +("function" == typeof u ? u.apply(this, arguments) : u)),
|
|
p = h * (0 > s ? -1 : 1),
|
|
g = ao.sum(c),
|
|
v = g ? (s - l * p) / g : 0,
|
|
d = ao.range(l),
|
|
y = [];
|
|
return null != e && d.sort(e === bl ? function(n, t) {
|
|
return c[t] - c[n]
|
|
} : function(n, t) {
|
|
return e(o[n], o[t])
|
|
}), d.forEach(function(n) {
|
|
y[n] = {
|
|
data: o[n],
|
|
value: a = c[n],
|
|
startAngle: f,
|
|
endAngle: f += a * v + p,
|
|
padAngle: h
|
|
}
|
|
}), y
|
|
}
|
|
var t = Number,
|
|
e = bl,
|
|
r = 0,
|
|
i = Ho,
|
|
u = 0;
|
|
return n.value = function(e) {
|
|
return arguments.length ? (t = e, n) : t
|
|
}, n.sort = function(t) {
|
|
return arguments.length ? (e = t, n) : e
|
|
}, n.startAngle = function(t) {
|
|
return arguments.length ? (r = t, n) : r
|
|
}, n.endAngle = function(t) {
|
|
return arguments.length ? (i = t, n) : i
|
|
}, n.padAngle = function(t) {
|
|
return arguments.length ? (u = t, n) : u
|
|
}, n
|
|
};
|
|
var bl = {};
|
|
ao.layout.stack = function() {
|
|
function n(a, l) {
|
|
if (!(h = a.length)) return a;
|
|
var c = a.map(function(e, r) {
|
|
return t.call(n, e, r)
|
|
}),
|
|
f = c.map(function(t) {
|
|
return t.map(function(t, e) {
|
|
return [u.call(n, t, e), o.call(n, t, e)]
|
|
})
|
|
}),
|
|
s = e.call(n, f, l);
|
|
c = ao.permute(c, s), f = ao.permute(f, s);
|
|
var h, p, g, v, d = r.call(n, f, l),
|
|
y = c[0].length;
|
|
for (g = 0; y > g; ++g)
|
|
for (i.call(n, c[0][g], v = d[g], f[0][g][1]), p = 1; h > p; ++p) i.call(n, c[p][g], v += f[p - 1][g][1], f[p][g][1]);
|
|
return a
|
|
}
|
|
var t = m,
|
|
e = gi,
|
|
r = vi,
|
|
i = pi,
|
|
u = si,
|
|
o = hi;
|
|
return n.values = function(e) {
|
|
return arguments.length ? (t = e, n) : t
|
|
}, n.order = function(t) {
|
|
return arguments.length ? (e = "function" == typeof t ? t : _l.get(t) || gi, n) : e
|
|
}, n.offset = function(t) {
|
|
return arguments.length ? (r = "function" == typeof t ? t : wl.get(t) || vi, n) : r
|
|
}, n.x = function(t) {
|
|
return arguments.length ? (u = t, n) : u
|
|
}, n.y = function(t) {
|
|
return arguments.length ? (o = t, n) : o
|
|
}, n.out = function(t) {
|
|
return arguments.length ? (i = t, n) : i
|
|
}, n
|
|
};
|
|
var _l = ao.map({
|
|
"inside-out": function(n) {
|
|
var t, e, r = n.length,
|
|
i = n.map(di),
|
|
u = n.map(yi),
|
|
o = ao.range(r).sort(function(n, t) {
|
|
return i[n] - i[t]
|
|
}),
|
|
a = 0,
|
|
l = 0,
|
|
c = [],
|
|
f = [];
|
|
for (t = 0; r > t; ++t) e = o[t], l > a ? (a += u[e], c.push(e)) : (l += u[e], f.push(e));
|
|
return f.reverse().concat(c)
|
|
},
|
|
reverse: function(n) {
|
|
return ao.range(n.length).reverse()
|
|
},
|
|
"default": gi
|
|
}),
|
|
wl = ao.map({
|
|
silhouette: function(n) {
|
|
var t, e, r, i = n.length,
|
|
u = n[0].length,
|
|
o = [],
|
|
a = 0,
|
|
l = [];
|
|
for (e = 0; u > e; ++e) {
|
|
for (t = 0, r = 0; i > t; t++) r += n[t][e][1];
|
|
r > a && (a = r), o.push(r)
|
|
}
|
|
for (e = 0; u > e; ++e) l[e] = (a - o[e]) / 2;
|
|
return l
|
|
},
|
|
wiggle: function(n) {
|
|
var t, e, r, i, u, o, a, l, c, f = n.length,
|
|
s = n[0],
|
|
h = s.length,
|
|
p = [];
|
|
for (p[0] = l = c = 0, e = 1; h > e; ++e) {
|
|
for (t = 0, i = 0; f > t; ++t) i += n[t][e][1];
|
|
for (t = 0, u = 0, a = s[e][0] - s[e - 1][0]; f > t; ++t) {
|
|
for (r = 0, o = (n[t][e][1] - n[t][e - 1][1]) / (2 * a); t > r; ++r) o += (n[r][e][1] - n[r][e - 1][1]) / a;
|
|
u += o * n[t][e][1]
|
|
}
|
|
p[e] = l -= i ? u / i * a : 0, c > l && (c = l)
|
|
}
|
|
for (e = 0; h > e; ++e) p[e] -= c;
|
|
return p
|
|
},
|
|
expand: function(n) {
|
|
var t, e, r, i = n.length,
|
|
u = n[0].length,
|
|
o = 1 / i,
|
|
a = [];
|
|
for (e = 0; u > e; ++e) {
|
|
for (t = 0, r = 0; i > t; t++) r += n[t][e][1];
|
|
if (r)
|
|
for (t = 0; i > t; t++) n[t][e][1] /= r;
|
|
else
|
|
for (t = 0; i > t; t++) n[t][e][1] = o
|
|
}
|
|
for (e = 0; u > e; ++e) a[e] = 0;
|
|
return a
|
|
},
|
|
zero: vi
|
|
});
|
|
ao.layout.histogram = function() {
|
|
function n(n, u) {
|
|
for (var o, a, l = [], c = n.map(e, this), f = r.call(this, c, u), s = i.call(this, f, c, u), u = -1, h = c.length, p = s.length - 1, g = t ? 1 : 1 / h; ++u < p;) o = l[u] = [], o.dx = s[u + 1] - (o.x = s[u]), o.y = 0;
|
|
if (p > 0)
|
|
for (u = -1; ++u < h;) a = c[u], a >= f[0] && a <= f[1] && (o = l[ao.bisect(s, a, 1, p) - 1], o.y += g, o.push(n[u]));
|
|
return l
|
|
}
|
|
var t = !0,
|
|
e = Number,
|
|
r = bi,
|
|
i = Mi;
|
|
return n.value = function(t) {
|
|
return arguments.length ? (e = t, n) : e
|
|
}, n.range = function(t) {
|
|
return arguments.length ? (r = En(t), n) : r
|
|
}, n.bins = function(t) {
|
|
return arguments.length ? (i = "number" == typeof t ? function(n) {
|
|
return xi(n, t)
|
|
} : En(t), n) : i
|
|
}, n.frequency = function(e) {
|
|
return arguments.length ? (t = !!e, n) : t
|
|
}, n
|
|
}, ao.layout.pack = function() {
|
|
function n(n, u) {
|
|
var o = e.call(this, n, u),
|
|
a = o[0],
|
|
l = i[0],
|
|
c = i[1],
|
|
f = null == t ? Math.sqrt : "function" == typeof t ? t : function() {
|
|
return t
|
|
};
|
|
if (a.x = a.y = 0, oi(a, function(n) {
|
|
n.r = +f(n.value)
|
|
}), oi(a, Ni), r) {
|
|
var s = r * (t ? 1 : Math.max(2 * a.r / l, 2 * a.r / c)) / 2;
|
|
oi(a, function(n) {
|
|
n.r += s
|
|
}), oi(a, Ni), oi(a, function(n) {
|
|
n.r -= s
|
|
})
|
|
}
|
|
return Ci(a, l / 2, c / 2, t ? 1 : 1 / Math.max(2 * a.r / l, 2 * a.r / c)), o
|
|
}
|
|
var t, e = ao.layout.hierarchy().sort(_i),
|
|
r = 0,
|
|
i = [1, 1];
|
|
return n.size = function(t) {
|
|
return arguments.length ? (i = t, n) : i
|
|
}, n.radius = function(e) {
|
|
return arguments.length ? (t = null == e || "function" == typeof e ? e : +e, n) : t
|
|
}, n.padding = function(t) {
|
|
return arguments.length ? (r = +t, n) : r
|
|
}, ii(n, e)
|
|
}, ao.layout.tree = function() {
|
|
function n(n, i) {
|
|
var f = o.call(this, n, i),
|
|
s = f[0],
|
|
h = t(s);
|
|
if (oi(h, e), h.parent.m = -h.z, ui(h, r), c) ui(s, u);
|
|
else {
|
|
var p = s,
|
|
g = s,
|
|
v = s;
|
|
ui(s, function(n) {
|
|
n.x < p.x && (p = n), n.x > g.x && (g = n), n.depth > v.depth && (v = n)
|
|
});
|
|
var d = a(p, g) / 2 - p.x,
|
|
y = l[0] / (g.x + a(g, p) / 2 + d),
|
|
m = l[1] / (v.depth || 1);
|
|
ui(s, function(n) {
|
|
n.x = (n.x + d) * y, n.y = n.depth * m
|
|
})
|
|
}
|
|
return f
|
|
}
|
|
|
|
function t(n) {
|
|
for (var t, e = {
|
|
A: null,
|
|
children: [n]
|
|
}, r = [e]; null != (t = r.pop());)
|
|
for (var i, u = t.children, o = 0, a = u.length; a > o; ++o) r.push((u[o] = i = {
|
|
_: u[o],
|
|
parent: t,
|
|
children: (i = u[o].children) && i.slice() || [],
|
|
A: null,
|
|
a: null,
|
|
z: 0,
|
|
m: 0,
|
|
c: 0,
|
|
s: 0,
|
|
t: null,
|
|
i: o
|
|
}).a = i);
|
|
return e.children[0]
|
|
}
|
|
|
|
function e(n) {
|
|
var t = n.children,
|
|
e = n.parent.children,
|
|
r = n.i ? e[n.i - 1] : null;
|
|
if (t.length) {
|
|
Di(n);
|
|
var u = (t[0].z + t[t.length - 1].z) / 2;
|
|
r ? (n.z = r.z + a(n._, r._), n.m = n.z - u) : n.z = u
|
|
} else r && (n.z = r.z + a(n._, r._));
|
|
n.parent.A = i(n, r, n.parent.A || e[0])
|
|
}
|
|
|
|
function r(n) {
|
|
n._.x = n.z + n.parent.m, n.m += n.parent.m
|
|
}
|
|
|
|
function i(n, t, e) {
|
|
if (t) {
|
|
for (var r, i = n, u = n, o = t, l = i.parent.children[0], c = i.m, f = u.m, s = o.m, h = l.m; o = Ti(o), i = qi(i), o && i;) l = qi(l), u = Ti(u), u.a = n, r = o.z + s - i.z - c + a(o._, i._), r > 0 && (Ri(Pi(o, n, e), n, r), c += r, f += r), s += o.m, c += i.m, h += l.m, f += u.m;
|
|
o && !Ti(u) && (u.t = o, u.m += s - f), i && !qi(l) && (l.t = i, l.m += c - h, e = n)
|
|
}
|
|
return e
|
|
}
|
|
|
|
function u(n) {
|
|
n.x *= l[0], n.y = n.depth * l[1]
|
|
}
|
|
var o = ao.layout.hierarchy().sort(null).value(null),
|
|
a = Li,
|
|
l = [1, 1],
|
|
c = null;
|
|
return n.separation = function(t) {
|
|
return arguments.length ? (a = t, n) : a
|
|
}, n.size = function(t) {
|
|
return arguments.length ? (c = null == (l = t) ? u : null, n) : c ? null : l
|
|
}, n.nodeSize = function(t) {
|
|
return arguments.length ? (c = null == (l = t) ? null : u, n) : c ? l : null
|
|
}, ii(n, o)
|
|
}, ao.layout.cluster = function() {
|
|
function n(n, u) {
|
|
var o, a = t.call(this, n, u),
|
|
l = a[0],
|
|
c = 0;
|
|
oi(l, function(n) {
|
|
var t = n.children;
|
|
t && t.length ? (n.x = ji(t), n.y = Ui(t)) : (n.x = o ? c += e(n, o) : 0, n.y = 0, o = n)
|
|
});
|
|
var f = Fi(l),
|
|
s = Hi(l),
|
|
h = f.x - e(f, s) / 2,
|
|
p = s.x + e(s, f) / 2;
|
|
return oi(l, i ? function(n) {
|
|
n.x = (n.x - l.x) * r[0], n.y = (l.y - n.y) * r[1]
|
|
} : function(n) {
|
|
n.x = (n.x - h) / (p - h) * r[0], n.y = (1 - (l.y ? n.y / l.y : 1)) * r[1]
|
|
}), a
|
|
}
|
|
var t = ao.layout.hierarchy().sort(null).value(null),
|
|
e = Li,
|
|
r = [1, 1],
|
|
i = !1;
|
|
return n.separation = function(t) {
|
|
return arguments.length ? (e = t, n) : e
|
|
}, n.size = function(t) {
|
|
return arguments.length ? (i = null == (r = t), n) : i ? null : r
|
|
}, n.nodeSize = function(t) {
|
|
return arguments.length ? (i = null != (r = t), n) : i ? r : null
|
|
}, ii(n, t)
|
|
}, ao.layout.treemap = function() {
|
|
function n(n, t) {
|
|
for (var e, r, i = -1, u = n.length; ++i < u;) r = (e = n[i]).value * (0 > t ? 0 : t), e.area = isNaN(r) || 0 >= r ? 0 : r
|
|
}
|
|
|
|
function t(e) {
|
|
var u = e.children;
|
|
if (u && u.length) {
|
|
var o, a, l, c = s(e),
|
|
f = [],
|
|
h = u.slice(),
|
|
g = 1 / 0,
|
|
v = "slice" === p ? c.dx : "dice" === p ? c.dy : "slice-dice" === p ? 1 & e.depth ? c.dy : c.dx : Math.min(c.dx, c.dy);
|
|
for (n(h, c.dx * c.dy / e.value), f.area = 0;
|
|
(l = h.length) > 0;) f.push(o = h[l - 1]), f.area += o.area, "squarify" !== p || (a = r(f, v)) <= g ? (h.pop(), g = a) : (f.area -= f.pop().area, i(f, v, c, !1), v = Math.min(c.dx, c.dy), f.length = f.area = 0, g = 1 / 0);
|
|
f.length && (i(f, v, c, !0), f.length = f.area = 0), u.forEach(t)
|
|
}
|
|
}
|
|
|
|
function e(t) {
|
|
var r = t.children;
|
|
if (r && r.length) {
|
|
var u, o = s(t),
|
|
a = r.slice(),
|
|
l = [];
|
|
for (n(a, o.dx * o.dy / t.value), l.area = 0; u = a.pop();) l.push(u), l.area += u.area, null != u.z && (i(l, u.z ? o.dx : o.dy, o, !a.length), l.length = l.area = 0);
|
|
r.forEach(e)
|
|
}
|
|
}
|
|
|
|
function r(n, t) {
|
|
for (var e, r = n.area, i = 0, u = 1 / 0, o = -1, a = n.length; ++o < a;)(e = n[o].area) && (u > e && (u = e), e > i && (i = e));
|
|
return r *= r, t *= t, r ? Math.max(t * i * g / r, r / (t * u * g)) : 1 / 0
|
|
}
|
|
|
|
function i(n, t, e, r) {
|
|
var i, u = -1,
|
|
o = n.length,
|
|
a = e.x,
|
|
c = e.y,
|
|
f = t ? l(n.area / t) : 0;
|
|
if (t == e.dx) {
|
|
for ((r || f > e.dy) && (f = e.dy); ++u < o;) i = n[u], i.x = a, i.y = c, i.dy = f, a += i.dx = Math.min(e.x + e.dx - a, f ? l(i.area / f) : 0);
|
|
i.z = !0, i.dx += e.x + e.dx - a, e.y += f, e.dy -= f
|
|
} else {
|
|
for ((r || f > e.dx) && (f = e.dx); ++u < o;) i = n[u], i.x = a, i.y = c, i.dx = f, c += i.dy = Math.min(e.y + e.dy - c, f ? l(i.area / f) : 0);
|
|
i.z = !1, i.dy += e.y + e.dy - c, e.x += f, e.dx -= f
|
|
}
|
|
}
|
|
|
|
function u(r) {
|
|
var i = o || a(r),
|
|
u = i[0];
|
|
return u.x = u.y = 0, u.value ? (u.dx = c[0], u.dy = c[1]) : u.dx = u.dy = 0, o && a.revalue(u), n([u], u.dx * u.dy / u.value), (o ? e : t)(u), h && (o = i), i
|
|
}
|
|
var o, a = ao.layout.hierarchy(),
|
|
l = Math.round,
|
|
c = [1, 1],
|
|
f = null,
|
|
s = Oi,
|
|
h = !1,
|
|
p = "squarify",
|
|
g = .5 * (1 + Math.sqrt(5));
|
|
return u.size = function(n) {
|
|
return arguments.length ? (c = n, u) : c
|
|
}, u.padding = function(n) {
|
|
function t(t) {
|
|
var e = n.call(u, t, t.depth);
|
|
return null == e ? Oi(t) : Ii(t, "number" == typeof e ? [e, e, e, e] : e)
|
|
}
|
|
|
|
function e(t) {
|
|
return Ii(t, n)
|
|
}
|
|
if (!arguments.length) return f;
|
|
var r;
|
|
return s = null == (f = n) ? Oi : "function" == (r = typeof n) ? t : "number" === r ? (n = [n, n, n, n], e) : e, u
|
|
}, u.round = function(n) {
|
|
return arguments.length ? (l = n ? Math.round : Number, u) : l != Number
|
|
}, u.sticky = function(n) {
|
|
return arguments.length ? (h = n, o = null, u) : h
|
|
}, u.ratio = function(n) {
|
|
return arguments.length ? (g = n, u) : g
|
|
}, u.mode = function(n) {
|
|
return arguments.length ? (p = n + "", u) : p
|
|
}, ii(u, a)
|
|
}, ao.random = {
|
|
normal: function(n, t) {
|
|
var e = arguments.length;
|
|
return 2 > e && (t = 1), 1 > e && (n = 0),
|
|
function() {
|
|
var e, r, i;
|
|
do e = 2 * Math.random() - 1, r = 2 * Math.random() - 1, i = e * e + r * r; while (!i || i > 1);
|
|
return n + t * e * Math.sqrt(-2 * Math.log(i) / i)
|
|
}
|
|
},
|
|
logNormal: function() {
|
|
var n = ao.random.normal.apply(ao, arguments);
|
|
return function() {
|
|
return Math.exp(n())
|
|
}
|
|
},
|
|
bates: function(n) {
|
|
var t = ao.random.irwinHall(n);
|
|
return function() {
|
|
return t() / n
|
|
}
|
|
},
|
|
irwinHall: function(n) {
|
|
return function() {
|
|
for (var t = 0, e = 0; n > e; e++) t += Math.random();
|
|
return t
|
|
}
|
|
}
|
|
}, ao.scale = {};
|
|
var Sl = {
|
|
floor: m,
|
|
ceil: m
|
|
};
|
|
ao.scale.linear = function() {
|
|
return Wi([0, 1], [0, 1], Mr, !1)
|
|
};
|
|
var kl = {
|
|
s: 1,
|
|
g: 1,
|
|
p: 1,
|
|
r: 1,
|
|
e: 1
|
|
};
|
|
ao.scale.log = function() {
|
|
return ru(ao.scale.linear().domain([0, 1]), 10, !0, [1, 10])
|
|
};
|
|
var Nl = ao.format(".0e"),
|
|
El = {
|
|
floor: function(n) {
|
|
return -Math.ceil(-n)
|
|
},
|
|
ceil: function(n) {
|
|
return -Math.floor(-n)
|
|
}
|
|
};
|
|
ao.scale.pow = function() {
|
|
return iu(ao.scale.linear(), 1, [0, 1])
|
|
}, ao.scale.sqrt = function() {
|
|
return ao.scale.pow().exponent(.5)
|
|
}, ao.scale.ordinal = function() {
|
|
return ou([], {
|
|
t: "range",
|
|
a: [
|
|
[]
|
|
]
|
|
})
|
|
}, ao.scale.category10 = function() {
|
|
return ao.scale.ordinal().range(Al)
|
|
}, ao.scale.category20 = function() {
|
|
return ao.scale.ordinal().range(Cl)
|
|
}, ao.scale.category20b = function() {
|
|
return ao.scale.ordinal().range(zl)
|
|
}, ao.scale.category20c = function() {
|
|
return ao.scale.ordinal().range(Ll)
|
|
};
|
|
var Al = [2062260, 16744206, 2924588, 14034728, 9725885, 9197131, 14907330, 8355711, 12369186, 1556175].map(xn),
|
|
Cl = [2062260, 11454440, 16744206, 16759672, 2924588, 10018698, 14034728, 16750742, 9725885, 12955861, 9197131, 12885140, 14907330, 16234194, 8355711, 13092807, 12369186, 14408589, 1556175, 10410725].map(xn),
|
|
zl = [3750777, 5395619, 7040719, 10264286, 6519097, 9216594, 11915115, 13556636, 9202993, 12426809, 15186514, 15190932, 8666169, 11356490, 14049643, 15177372, 8077683, 10834324, 13528509, 14589654].map(xn),
|
|
Ll = [3244733, 7057110, 10406625, 13032431, 15095053, 16616764, 16625259, 16634018, 3253076, 7652470, 10607003, 13101504, 7695281, 10394312, 12369372, 14342891, 6513507, 9868950, 12434877, 14277081].map(xn);
|
|
ao.scale.quantile = function() {
|
|
return au([], [])
|
|
}, ao.scale.quantize = function() {
|
|
return lu(0, 1, [0, 1])
|
|
}, ao.scale.threshold = function() {
|
|
return cu([.5], [0, 1])
|
|
}, ao.scale.identity = function() {
|
|
return fu([0, 1])
|
|
}, ao.svg = {}, ao.svg.arc = function() {
|
|
function n() {
|
|
var n = Math.max(0, +e.apply(this, arguments)),
|
|
c = Math.max(0, +r.apply(this, arguments)),
|
|
f = o.apply(this, arguments) - Io,
|
|
s = a.apply(this, arguments) - Io,
|
|
h = Math.abs(s - f),
|
|
p = f > s ? 0 : 1;
|
|
if (n > c && (g = c, c = n, n = g), h >= Oo) return t(c, p) + (n ? t(n, 1 - p) : "") + "Z";
|
|
var g, v, d, y, m, M, x, b, _, w, S, k, N = 0,
|
|
E = 0,
|
|
A = [];
|
|
if ((y = (+l.apply(this, arguments) || 0) / 2) && (d = u === ql ? Math.sqrt(n * n + c * c) : +u.apply(this, arguments), p || (E *= -1), c && (E = tn(d / c * Math.sin(y))), n && (N = tn(d / n * Math.sin(y)))), c) {
|
|
m = c * Math.cos(f + E), M = c * Math.sin(f + E), x = c * Math.cos(s - E), b = c * Math.sin(s - E);
|
|
var C = Math.abs(s - f - 2 * E) <= Fo ? 0 : 1;
|
|
if (E && yu(m, M, x, b) === p ^ C) {
|
|
var z = (f + s) / 2;
|
|
m = c * Math.cos(z), M = c * Math.sin(z), x = b = null
|
|
}
|
|
} else m = M = 0;
|
|
if (n) {
|
|
_ = n * Math.cos(s - N), w = n * Math.sin(s - N), S = n * Math.cos(f + N), k = n * Math.sin(f + N);
|
|
var L = Math.abs(f - s + 2 * N) <= Fo ? 0 : 1;
|
|
if (N && yu(_, w, S, k) === 1 - p ^ L) {
|
|
var q = (f + s) / 2;
|
|
_ = n * Math.cos(q), w = n * Math.sin(q), S = k = null
|
|
}
|
|
} else _ = w = 0;
|
|
if (h > Uo && (g = Math.min(Math.abs(c - n) / 2, +i.apply(this, arguments))) > .001) {
|
|
v = c > n ^ p ? 0 : 1;
|
|
var T = g,
|
|
R = g;
|
|
if (Fo > h) {
|
|
var D = null == S ? [_, w] : null == x ? [m, M] : Re([m, M], [S, k], [x, b], [_, w]),
|
|
P = m - D[0],
|
|
U = M - D[1],
|
|
j = x - D[0],
|
|
F = b - D[1],
|
|
H = 1 / Math.sin(Math.acos((P * j + U * F) / (Math.sqrt(P * P + U * U) * Math.sqrt(j * j + F * F))) / 2),
|
|
O = Math.sqrt(D[0] * D[0] + D[1] * D[1]);
|
|
R = Math.min(g, (n - O) / (H - 1)), T = Math.min(g, (c - O) / (H + 1))
|
|
}
|
|
if (null != x) {
|
|
var I = mu(null == S ? [_, w] : [S, k], [m, M], c, T, p),
|
|
Y = mu([x, b], [_, w], c, T, p);
|
|
g === T ? A.push("M", I[0], "A", T, ",", T, " 0 0,", v, " ", I[1], "A", c, ",", c, " 0 ", 1 - p ^ yu(I[1][0], I[1][1], Y[1][0], Y[1][1]), ",", p, " ", Y[1], "A", T, ",", T, " 0 0,", v, " ", Y[0]) : A.push("M", I[0], "A", T, ",", T, " 0 1,", v, " ", Y[0])
|
|
} else A.push("M", m, ",", M);
|
|
if (null != S) {
|
|
var Z = mu([m, M], [S, k], n, -R, p),
|
|
V = mu([_, w], null == x ? [m, M] : [x, b], n, -R, p);
|
|
g === R ? A.push("L", V[0], "A", R, ",", R, " 0 0,", v, " ", V[1], "A", n, ",", n, " 0 ", p ^ yu(V[1][0], V[1][1], Z[1][0], Z[1][1]), ",", 1 - p, " ", Z[1], "A", R, ",", R, " 0 0,", v, " ", Z[0]) : A.push("L", V[0], "A", R, ",", R, " 0 0,", v, " ", Z[0])
|
|
} else A.push("L", _, ",", w)
|
|
} else A.push("M", m, ",", M), null != x && A.push("A", c, ",", c, " 0 ", C, ",", p, " ", x, ",", b), A.push("L", _, ",", w), null != S && A.push("A", n, ",", n, " 0 ", L, ",", 1 - p, " ", S, ",", k);
|
|
return A.push("Z"), A.join("")
|
|
}
|
|
|
|
function t(n, t) {
|
|
return "M0," + n + "A" + n + "," + n + " 0 1," + t + " 0," + -n + "A" + n + "," + n + " 0 1," + t + " 0," + n
|
|
}
|
|
var e = hu,
|
|
r = pu,
|
|
i = su,
|
|
u = ql,
|
|
o = gu,
|
|
a = vu,
|
|
l = du;
|
|
return n.innerRadius = function(t) {
|
|
return arguments.length ? (e = En(t), n) : e
|
|
}, n.outerRadius = function(t) {
|
|
return arguments.length ? (r = En(t), n) : r
|
|
}, n.cornerRadius = function(t) {
|
|
return arguments.length ? (i = En(t), n) : i
|
|
}, n.padRadius = function(t) {
|
|
return arguments.length ? (u = t == ql ? ql : En(t), n) : u
|
|
}, n.startAngle = function(t) {
|
|
return arguments.length ? (o = En(t), n) : o
|
|
}, n.endAngle = function(t) {
|
|
return arguments.length ? (a = En(t), n) : a
|
|
}, n.padAngle = function(t) {
|
|
return arguments.length ? (l = En(t), n) : l
|
|
}, n.centroid = function() {
|
|
var n = (+e.apply(this, arguments) + +r.apply(this, arguments)) / 2,
|
|
t = (+o.apply(this, arguments) + +a.apply(this, arguments)) / 2 - Io;
|
|
return [Math.cos(t) * n, Math.sin(t) * n]
|
|
}, n
|
|
};
|
|
var ql = "auto";
|
|
ao.svg.line = function() {
|
|
return Mu(m)
|
|
};
|
|
var Tl = ao.map({
|
|
linear: xu,
|
|
"linear-closed": bu,
|
|
step: _u,
|
|
"step-before": wu,
|
|
"step-after": Su,
|
|
basis: zu,
|
|
"basis-open": Lu,
|
|
"basis-closed": qu,
|
|
bundle: Tu,
|
|
cardinal: Eu,
|
|
"cardinal-open": ku,
|
|
"cardinal-closed": Nu,
|
|
monotone: Fu
|
|
});
|
|
Tl.forEach(function(n, t) {
|
|
t.key = n, t.closed = /-closed$/.test(n)
|
|
});
|
|
var Rl = [0, 2 / 3, 1 / 3, 0],
|
|
Dl = [0, 1 / 3, 2 / 3, 0],
|
|
Pl = [0, 1 / 6, 2 / 3, 1 / 6];
|
|
ao.svg.line.radial = function() {
|
|
var n = Mu(Hu);
|
|
return n.radius = n.x, delete n.x, n.angle = n.y, delete n.y, n
|
|
}, wu.reverse = Su, Su.reverse = wu, ao.svg.area = function() {
|
|
return Ou(m)
|
|
}, ao.svg.area.radial = function() {
|
|
var n = Ou(Hu);
|
|
return n.radius = n.x, delete n.x, n.innerRadius = n.x0, delete n.x0, n.outerRadius = n.x1, delete n.x1, n.angle = n.y, delete n.y, n.startAngle = n.y0, delete n.y0, n.endAngle = n.y1, delete n.y1, n
|
|
}, ao.svg.chord = function() {
|
|
function n(n, a) {
|
|
var l = t(this, u, n, a),
|
|
c = t(this, o, n, a);
|
|
return "M" + l.p0 + r(l.r, l.p1, l.a1 - l.a0) + (e(l, c) ? i(l.r, l.p1, l.r, l.p0) : i(l.r, l.p1, c.r, c.p0) + r(c.r, c.p1, c.a1 - c.a0) + i(c.r, c.p1, l.r, l.p0)) + "Z"
|
|
}
|
|
|
|
function t(n, t, e, r) {
|
|
var i = t.call(n, e, r),
|
|
u = a.call(n, i, r),
|
|
o = l.call(n, i, r) - Io,
|
|
f = c.call(n, i, r) - Io;
|
|
return {
|
|
r: u,
|
|
a0: o,
|
|
a1: f,
|
|
p0: [u * Math.cos(o), u * Math.sin(o)],
|
|
p1: [u * Math.cos(f), u * Math.sin(f)]
|
|
}
|
|
}
|
|
|
|
function e(n, t) {
|
|
return n.a0 == t.a0 && n.a1 == t.a1
|
|
}
|
|
|
|
function r(n, t, e) {
|
|
return "A" + n + "," + n + " 0 " + +(e > Fo) + ",1 " + t
|
|
}
|
|
|
|
function i(n, t, e, r) {
|
|
return "Q 0,0 " + r
|
|
}
|
|
var u = Me,
|
|
o = xe,
|
|
a = Iu,
|
|
l = gu,
|
|
c = vu;
|
|
return n.radius = function(t) {
|
|
return arguments.length ? (a = En(t), n) : a
|
|
}, n.source = function(t) {
|
|
return arguments.length ? (u = En(t), n) : u
|
|
}, n.target = function(t) {
|
|
return arguments.length ? (o = En(t), n) : o
|
|
}, n.startAngle = function(t) {
|
|
return arguments.length ? (l = En(t), n) : l
|
|
}, n.endAngle = function(t) {
|
|
return arguments.length ? (c = En(t), n) : c
|
|
}, n
|
|
}, ao.svg.diagonal = function() {
|
|
function n(n, i) {
|
|
var u = t.call(this, n, i),
|
|
o = e.call(this, n, i),
|
|
a = (u.y + o.y) / 2,
|
|
l = [u, {
|
|
x: u.x,
|
|
y: a
|
|
}, {
|
|
x: o.x,
|
|
y: a
|
|
}, o];
|
|
return l = l.map(r), "M" + l[0] + "C" + l[1] + " " + l[2] + " " + l[3]
|
|
}
|
|
var t = Me,
|
|
e = xe,
|
|
r = Yu;
|
|
return n.source = function(e) {
|
|
return arguments.length ? (t = En(e), n) : t
|
|
}, n.target = function(t) {
|
|
return arguments.length ? (e = En(t), n) : e
|
|
}, n.projection = function(t) {
|
|
return arguments.length ? (r = t, n) : r
|
|
}, n
|
|
}, ao.svg.diagonal.radial = function() {
|
|
var n = ao.svg.diagonal(),
|
|
t = Yu,
|
|
e = n.projection;
|
|
return n.projection = function(n) {
|
|
return arguments.length ? e(Zu(t = n)) : t
|
|
}, n
|
|
}, ao.svg.symbol = function() {
|
|
function n(n, r) {
|
|
return (Ul.get(t.call(this, n, r)) || $u)(e.call(this, n, r))
|
|
}
|
|
var t = Xu,
|
|
e = Vu;
|
|
return n.type = function(e) {
|
|
return arguments.length ? (t = En(e), n) : t
|
|
}, n.size = function(t) {
|
|
return arguments.length ? (e = En(t), n) : e
|
|
}, n
|
|
};
|
|
var Ul = ao.map({
|
|
circle: $u,
|
|
cross: function(n) {
|
|
var t = Math.sqrt(n / 5) / 2;
|
|
return "M" + -3 * t + "," + -t + "H" + -t + "V" + -3 * t + "H" + t + "V" + -t + "H" + 3 * t + "V" + t + "H" + t + "V" + 3 * t + "H" + -t + "V" + t + "H" + -3 * t + "Z"
|
|
},
|
|
diamond: function(n) {
|
|
var t = Math.sqrt(n / (2 * Fl)),
|
|
e = t * Fl;
|
|
return "M0," + -t + "L" + e + ",0 0," + t + " " + -e + ",0Z"
|
|
},
|
|
square: function(n) {
|
|
var t = Math.sqrt(n) / 2;
|
|
return "M" + -t + "," + -t + "L" + t + "," + -t + " " + t + "," + t + " " + -t + "," + t + "Z"
|
|
},
|
|
"triangle-down": function(n) {
|
|
var t = Math.sqrt(n / jl),
|
|
e = t * jl / 2;
|
|
return "M0," + e + "L" + t + "," + -e + " " + -t + "," + -e + "Z"
|
|
},
|
|
"triangle-up": function(n) {
|
|
var t = Math.sqrt(n / jl),
|
|
e = t * jl / 2;
|
|
return "M0," + -e + "L" + t + "," + e + " " + -t + "," + e + "Z"
|
|
}
|
|
});
|
|
ao.svg.symbolTypes = Ul.keys();
|
|
var jl = Math.sqrt(3),
|
|
Fl = Math.tan(30 * Yo);
|
|
Co.transition = function(n) {
|
|
for (var t, e, r = Hl || ++Zl, i = Ku(n), u = [], o = Ol || {
|
|
time: Date.now(),
|
|
ease: Nr,
|
|
delay: 0,
|
|
duration: 250
|
|
}, a = -1, l = this.length; ++a < l;) {
|
|
u.push(t = []);
|
|
for (var c = this[a], f = -1, s = c.length; ++f < s;)(e = c[f]) && Qu(e, f, i, r, o), t.push(e)
|
|
}
|
|
return Wu(u, i, r)
|
|
}, Co.interrupt = function(n) {
|
|
return this.each(null == n ? Il : Bu(Ku(n)))
|
|
};
|
|
var Hl, Ol, Il = Bu(Ku()),
|
|
Yl = [],
|
|
Zl = 0;
|
|
Yl.call = Co.call, Yl.empty = Co.empty, Yl.node = Co.node, Yl.size = Co.size, ao.transition = function(n, t) {
|
|
return n && n.transition ? Hl ? n.transition(t) : n : ao.selection().transition(n)
|
|
}, ao.transition.prototype = Yl, Yl.select = function(n) {
|
|
var t, e, r, i = this.id,
|
|
u = this.namespace,
|
|
o = [];
|
|
n = A(n);
|
|
for (var a = -1, l = this.length; ++a < l;) {
|
|
o.push(t = []);
|
|
for (var c = this[a], f = -1, s = c.length; ++f < s;)(r = c[f]) && (e = n.call(r, r.__data__, f, a)) ? ("__data__" in r && (e.__data__ = r.__data__), Qu(e, f, u, i, r[u][i]), t.push(e)) : t.push(null)
|
|
}
|
|
return Wu(o, u, i)
|
|
}, Yl.selectAll = function(n) {
|
|
var t, e, r, i, u, o = this.id,
|
|
a = this.namespace,
|
|
l = [];
|
|
n = C(n);
|
|
for (var c = -1, f = this.length; ++c < f;)
|
|
for (var s = this[c], h = -1, p = s.length; ++h < p;)
|
|
if (r = s[h]) {
|
|
u = r[a][o], e = n.call(r, r.__data__, h, c), l.push(t = []);
|
|
for (var g = -1, v = e.length; ++g < v;)(i = e[g]) && Qu(i, g, a, o, u), t.push(i)
|
|
}
|
|
return Wu(l, a, o)
|
|
}, Yl.filter = function(n) {
|
|
var t, e, r, i = [];
|
|
"function" != typeof n && (n = O(n));
|
|
for (var u = 0, o = this.length; o > u; u++) {
|
|
i.push(t = []);
|
|
for (var e = this[u], a = 0, l = e.length; l > a; a++)(r = e[a]) && n.call(r, r.__data__, a, u) && t.push(r)
|
|
}
|
|
return Wu(i, this.namespace, this.id)
|
|
}, Yl.tween = function(n, t) {
|
|
var e = this.id,
|
|
r = this.namespace;
|
|
return arguments.length < 2 ? this.node()[r][e].tween.get(n) : Y(this, null == t ? function(t) {
|
|
t[r][e].tween.remove(n)
|
|
} : function(i) {
|
|
i[r][e].tween.set(n, t)
|
|
})
|
|
}, Yl.attr = function(n, t) {
|
|
function e() {
|
|
this.removeAttribute(a)
|
|
}
|
|
|
|
function r() {
|
|
this.removeAttributeNS(a.space, a.local)
|
|
}
|
|
|
|
function i(n) {
|
|
return null == n ? e : (n += "", function() {
|
|
var t, e = this.getAttribute(a);
|
|
return e !== n && (t = o(e, n), function(n) {
|
|
this.setAttribute(a, t(n))
|
|
})
|
|
})
|
|
}
|
|
|
|
function u(n) {
|
|
return null == n ? r : (n += "", function() {
|
|
var t, e = this.getAttributeNS(a.space, a.local);
|
|
return e !== n && (t = o(e, n), function(n) {
|
|
this.setAttributeNS(a.space, a.local, t(n))
|
|
})
|
|
})
|
|
}
|
|
if (arguments.length < 2) {
|
|
for (t in n) this.attr(t, n[t]);
|
|
return this
|
|
}
|
|
var o = "transform" == n ? $r : Mr,
|
|
a = ao.ns.qualify(n);
|
|
return Ju(this, "attr." + n, t, a.local ? u : i)
|
|
}, Yl.attrTween = function(n, t) {
|
|
function e(n, e) {
|
|
var r = t.call(this, n, e, this.getAttribute(i));
|
|
return r && function(n) {
|
|
this.setAttribute(i, r(n))
|
|
}
|
|
}
|
|
|
|
function r(n, e) {
|
|
var r = t.call(this, n, e, this.getAttributeNS(i.space, i.local));
|
|
return r && function(n) {
|
|
this.setAttributeNS(i.space, i.local, r(n))
|
|
}
|
|
}
|
|
var i = ao.ns.qualify(n);
|
|
return this.tween("attr." + n, i.local ? r : e)
|
|
}, Yl.style = function(n, e, r) {
|
|
function i() {
|
|
this.style.removeProperty(n)
|
|
}
|
|
|
|
function u(e) {
|
|
return null == e ? i : (e += "", function() {
|
|
var i, u = t(this).getComputedStyle(this, null).getPropertyValue(n);
|
|
return u !== e && (i = Mr(u, e), function(t) {
|
|
this.style.setProperty(n, i(t), r)
|
|
})
|
|
})
|
|
}
|
|
var o = arguments.length;
|
|
if (3 > o) {
|
|
if ("string" != typeof n) {
|
|
2 > o && (e = "");
|
|
for (r in n) this.style(r, n[r], e);
|
|
return this
|
|
}
|
|
r = ""
|
|
}
|
|
return Ju(this, "style." + n, e, u)
|
|
}, Yl.styleTween = function(n, e, r) {
|
|
function i(i, u) {
|
|
var o = e.call(this, i, u, t(this).getComputedStyle(this, null).getPropertyValue(n));
|
|
return o && function(t) {
|
|
this.style.setProperty(n, o(t), r)
|
|
}
|
|
}
|
|
return arguments.length < 3 && (r = ""), this.tween("style." + n, i)
|
|
}, Yl.text = function(n) {
|
|
return Ju(this, "text", n, Gu)
|
|
}, Yl.remove = function() {
|
|
var n = this.namespace;
|
|
return this.each("end.transition", function() {
|
|
var t;
|
|
this[n].count < 2 && (t = this.parentNode) && t.removeChild(this)
|
|
})
|
|
}, Yl.ease = function(n) {
|
|
var t = this.id,
|
|
e = this.namespace;
|
|
return arguments.length < 1 ? this.node()[e][t].ease : ("function" != typeof n && (n = ao.ease.apply(ao, arguments)), Y(this, function(r) {
|
|
r[e][t].ease = n
|
|
}))
|
|
}, Yl.delay = function(n) {
|
|
var t = this.id,
|
|
e = this.namespace;
|
|
return arguments.length < 1 ? this.node()[e][t].delay : Y(this, "function" == typeof n ? function(r, i, u) {
|
|
r[e][t].delay = +n.call(r, r.__data__, i, u)
|
|
} : (n = +n, function(r) {
|
|
r[e][t].delay = n
|
|
}))
|
|
}, Yl.duration = function(n) {
|
|
var t = this.id,
|
|
e = this.namespace;
|
|
return arguments.length < 1 ? this.node()[e][t].duration : Y(this, "function" == typeof n ? function(r, i, u) {
|
|
r[e][t].duration = Math.max(1, n.call(r, r.__data__, i, u))
|
|
} : (n = Math.max(1, n), function(r) {
|
|
r[e][t].duration = n
|
|
}))
|
|
}, Yl.each = function(n, t) {
|
|
var e = this.id,
|
|
r = this.namespace;
|
|
if (arguments.length < 2) {
|
|
var i = Ol,
|
|
u = Hl;
|
|
try {
|
|
Hl = e, Y(this, function(t, i, u) {
|
|
Ol = t[r][e], n.call(t, t.__data__, i, u)
|
|
})
|
|
} finally {
|
|
Ol = i, Hl = u
|
|
}
|
|
} else Y(this, function(i) {
|
|
var u = i[r][e];
|
|
(u.event || (u.event = ao.dispatch("start", "end", "interrupt"))).on(n, t)
|
|
});
|
|
return this
|
|
}, Yl.transition = function() {
|
|
for (var n, t, e, r, i = this.id, u = ++Zl, o = this.namespace, a = [], l = 0, c = this.length; c > l; l++) {
|
|
a.push(n = []);
|
|
for (var t = this[l], f = 0, s = t.length; s > f; f++)(e = t[f]) && (r = e[o][i], Qu(e, f, o, u, {
|
|
time: r.time,
|
|
ease: r.ease,
|
|
delay: r.delay + r.duration,
|
|
duration: r.duration
|
|
})), n.push(e)
|
|
}
|
|
return Wu(a, o, u)
|
|
}, ao.svg.axis = function() {
|
|
function n(n) {
|
|
n.each(function() {
|
|
var n, c = ao.select(this),
|
|
f = this.__chart__ || e,
|
|
s = this.__chart__ = e.copy(),
|
|
h = null == l ? s.ticks ? s.ticks.apply(s, a) : s.domain() : l,
|
|
p = null == t ? s.tickFormat ? s.tickFormat.apply(s, a) : m : t,
|
|
g = c.selectAll(".tick").data(h, s),
|
|
v = g.enter().insert("g", ".domain").attr("class", "tick").style("opacity", Uo),
|
|
d = ao.transition(g.exit()).style("opacity", Uo).remove(),
|
|
y = ao.transition(g.order()).style("opacity", 1),
|
|
M = Math.max(i, 0) + o,
|
|
x = Zi(s),
|
|
b = c.selectAll(".domain").data([0]),
|
|
_ = (b.enter().append("path").attr("class", "domain"), ao.transition(b));
|
|
v.append("line"), v.append("text");
|
|
var w, S, k, N, E = v.select("line"),
|
|
A = y.select("line"),
|
|
C = g.select("text").text(p),
|
|
z = v.select("text"),
|
|
L = y.select("text"),
|
|
q = "top" === r || "left" === r ? -1 : 1;
|
|
if ("bottom" === r || "top" === r ? (n = no, w = "x", k = "y", S = "x2", N = "y2", C.attr("dy", 0 > q ? "0em" : ".71em").style("text-anchor", "middle"), _.attr("d", "M" + x[0] + "," + q * u + "V0H" + x[1] + "V" + q * u)) : (n = to, w = "y", k = "x", S = "y2", N = "x2", C.attr("dy", ".32em").style("text-anchor", 0 > q ? "end" : "start"), _.attr("d", "M" + q * u + "," + x[0] + "H0V" + x[1] + "H" + q * u)), E.attr(N, q * i), z.attr(k, q * M), A.attr(S, 0).attr(N, q * i), L.attr(w, 0).attr(k, q * M), s.rangeBand) {
|
|
var T = s,
|
|
R = T.rangeBand() / 2;
|
|
f = s = function(n) {
|
|
return T(n) + R
|
|
}
|
|
} else f.rangeBand ? f = s : d.call(n, s, f);
|
|
v.call(n, f, s), y.call(n, s, s)
|
|
})
|
|
}
|
|
var t, e = ao.scale.linear(),
|
|
r = Vl,
|
|
i = 6,
|
|
u = 6,
|
|
o = 3,
|
|
a = [10],
|
|
l = null;
|
|
return n.scale = function(t) {
|
|
return arguments.length ? (e = t, n) : e
|
|
}, n.orient = function(t) {
|
|
return arguments.length ? (r = t in Xl ? t + "" : Vl, n) : r
|
|
}, n.ticks = function() {
|
|
return arguments.length ? (a = co(arguments), n) : a
|
|
}, n.tickValues = function(t) {
|
|
return arguments.length ? (l = t, n) : l
|
|
}, n.tickFormat = function(e) {
|
|
return arguments.length ? (t = e, n) : t
|
|
}, n.tickSize = function(t) {
|
|
var e = arguments.length;
|
|
return e ? (i = +t, u = +arguments[e - 1], n) : i
|
|
}, n.innerTickSize = function(t) {
|
|
return arguments.length ? (i = +t, n) : i
|
|
}, n.outerTickSize = function(t) {
|
|
return arguments.length ? (u = +t, n) : u
|
|
}, n.tickPadding = function(t) {
|
|
return arguments.length ? (o = +t, n) : o
|
|
}, n.tickSubdivide = function() {
|
|
return arguments.length && n
|
|
}, n
|
|
};
|
|
var Vl = "bottom",
|
|
Xl = {
|
|
top: 1,
|
|
right: 1,
|
|
bottom: 1,
|
|
left: 1
|
|
};
|
|
ao.svg.brush = function() {
|
|
function n(t) {
|
|
t.each(function() {
|
|
var t = ao.select(this).style("pointer-events", "all").style("-webkit-tap-highlight-color", "rgba(0,0,0,0)").on("mousedown.brush", u).on("touchstart.brush", u),
|
|
o = t.selectAll(".background").data([0]);
|
|
o.enter().append("rect").attr("class", "background").style("visibility", "hidden").style("cursor", "crosshair"), t.selectAll(".extent").data([0]).enter().append("rect").attr("class", "extent").style("cursor", "move");
|
|
var a = t.selectAll(".resize").data(v, m);
|
|
a.exit().remove(), a.enter().append("g").attr("class", function(n) {
|
|
return "resize " + n
|
|
}).style("cursor", function(n) {
|
|
return $l[n]
|
|
}).append("rect").attr("x", function(n) {
|
|
return /[ew]$/.test(n) ? -3 : null
|
|
}).attr("y", function(n) {
|
|
return /^[ns]/.test(n) ? -3 : null
|
|
}).attr("width", 6).attr("height", 6).style("visibility", "hidden"), a.style("display", n.empty() ? "none" : null);
|
|
var l, s = ao.transition(t),
|
|
h = ao.transition(o);
|
|
c && (l = Zi(c), h.attr("x", l[0]).attr("width", l[1] - l[0]), r(s)), f && (l = Zi(f), h.attr("y", l[0]).attr("height", l[1] - l[0]), i(s)), e(s)
|
|
})
|
|
}
|
|
|
|
function e(n) {
|
|
n.selectAll(".resize").attr("transform", function(n) {
|
|
return "translate(" + s[+/e$/.test(n)] + "," + h[+/^s/.test(n)] + ")"
|
|
})
|
|
}
|
|
|
|
function r(n) {
|
|
n.select(".extent").attr("x", s[0]), n.selectAll(".extent,.n>rect,.s>rect").attr("width", s[1] - s[0])
|
|
}
|
|
|
|
function i(n) {
|
|
n.select(".extent").attr("y", h[0]), n.selectAll(".extent,.e>rect,.w>rect").attr("height", h[1] - h[0])
|
|
}
|
|
|
|
function u() {
|
|
function u() {
|
|
32 == ao.event.keyCode && (C || (M = null, L[0] -= s[1], L[1] -= h[1], C = 2), S())
|
|
}
|
|
|
|
function v() {
|
|
32 == ao.event.keyCode && 2 == C && (L[0] += s[1], L[1] += h[1], C = 0, S())
|
|
}
|
|
|
|
function d() {
|
|
var n = ao.mouse(b),
|
|
t = !1;
|
|
x && (n[0] += x[0], n[1] += x[1]), C || (ao.event.altKey ? (M || (M = [(s[0] + s[1]) / 2, (h[0] + h[1]) / 2]), L[0] = s[+(n[0] < M[0])], L[1] = h[+(n[1] < M[1])]) : M = null), E && y(n, c, 0) && (r(k), t = !0), A && y(n, f, 1) && (i(k), t = !0), t && (e(k), w({
|
|
type: "brush",
|
|
mode: C ? "move" : "resize"
|
|
}))
|
|
}
|
|
|
|
function y(n, t, e) {
|
|
var r, i, u = Zi(t),
|
|
l = u[0],
|
|
c = u[1],
|
|
f = L[e],
|
|
v = e ? h : s,
|
|
d = v[1] - v[0];
|
|
return C && (l -= f, c -= d + f), r = (e ? g : p) ? Math.max(l, Math.min(c, n[e])) : n[e], C ? i = (r += f) + d : (M && (f = Math.max(l, Math.min(c, 2 * M[e] - r))), r > f ? (i = r, r = f) : i = f), v[0] != r || v[1] != i ? (e ? a = null : o = null, v[0] = r, v[1] = i, !0) : void 0
|
|
}
|
|
|
|
function m() {
|
|
d(), k.style("pointer-events", "all").selectAll(".resize").style("display", n.empty() ? "none" : null), ao.select("body").style("cursor", null), q.on("mousemove.brush", null).on("mouseup.brush", null).on("touchmove.brush", null).on("touchend.brush", null).on("keydown.brush", null).on("keyup.brush", null), z(), w({
|
|
type: "brushend"
|
|
})
|
|
}
|
|
var M, x, b = this,
|
|
_ = ao.select(ao.event.target),
|
|
w = l.of(b, arguments),
|
|
k = ao.select(b),
|
|
N = _.datum(),
|
|
E = !/^(n|s)$/.test(N) && c,
|
|
A = !/^(e|w)$/.test(N) && f,
|
|
C = _.classed("extent"),
|
|
z = W(b),
|
|
L = ao.mouse(b),
|
|
q = ao.select(t(b)).on("keydown.brush", u).on("keyup.brush", v);
|
|
if (ao.event.changedTouches ? q.on("touchmove.brush", d).on("touchend.brush", m) : q.on("mousemove.brush", d).on("mouseup.brush", m), k.interrupt().selectAll("*").interrupt(), C) L[0] = s[0] - L[0], L[1] = h[0] - L[1];
|
|
else if (N) {
|
|
var T = +/w$/.test(N),
|
|
R = +/^n/.test(N);
|
|
x = [s[1 - T] - L[0], h[1 - R] - L[1]], L[0] = s[T], L[1] = h[R]
|
|
} else ao.event.altKey && (M = L.slice());
|
|
k.style("pointer-events", "none").selectAll(".resize").style("display", null), ao.select("body").style("cursor", _.style("cursor")), w({
|
|
type: "brushstart"
|
|
}), d()
|
|
}
|
|
var o, a, l = N(n, "brushstart", "brush", "brushend"),
|
|
c = null,
|
|
f = null,
|
|
s = [0, 0],
|
|
h = [0, 0],
|
|
p = !0,
|
|
g = !0,
|
|
v = Bl[0];
|
|
return n.event = function(n) {
|
|
n.each(function() {
|
|
var n = l.of(this, arguments),
|
|
t = {
|
|
x: s,
|
|
y: h,
|
|
i: o,
|
|
j: a
|
|
},
|
|
e = this.__chart__ || t;
|
|
this.__chart__ = t, Hl ? ao.select(this).transition().each("start.brush", function() {
|
|
o = e.i, a = e.j, s = e.x, h = e.y, n({
|
|
type: "brushstart"
|
|
})
|
|
}).tween("brush:brush", function() {
|
|
var e = xr(s, t.x),
|
|
r = xr(h, t.y);
|
|
return o = a = null,
|
|
function(i) {
|
|
s = t.x = e(i), h = t.y = r(i), n({
|
|
type: "brush",
|
|
mode: "resize"
|
|
})
|
|
}
|
|
}).each("end.brush", function() {
|
|
o = t.i, a = t.j, n({
|
|
type: "brush",
|
|
mode: "resize"
|
|
}), n({
|
|
type: "brushend"
|
|
})
|
|
}) : (n({
|
|
type: "brushstart"
|
|
}), n({
|
|
type: "brush",
|
|
mode: "resize"
|
|
}), n({
|
|
type: "brushend"
|
|
}))
|
|
})
|
|
}, n.x = function(t) {
|
|
return arguments.length ? (c = t, v = Bl[!c << 1 | !f], n) : c
|
|
}, n.y = function(t) {
|
|
return arguments.length ? (f = t, v = Bl[!c << 1 | !f], n) : f
|
|
}, n.clamp = function(t) {
|
|
return arguments.length ? (c && f ? (p = !!t[0], g = !!t[1]) : c ? p = !!t : f && (g = !!t), n) : c && f ? [p, g] : c ? p : f ? g : null
|
|
}, n.extent = function(t) {
|
|
var e, r, i, u, l;
|
|
return arguments.length ? (c && (e = t[0], r = t[1], f && (e = e[0], r = r[0]), o = [e, r], c.invert && (e = c(e), r = c(r)), e > r && (l = e, e = r, r = l), e == s[0] && r == s[1] || (s = [e, r])), f && (i = t[0], u = t[1], c && (i = i[1], u = u[1]), a = [i, u], f.invert && (i = f(i), u = f(u)), i > u && (l = i, i = u, u = l), i == h[0] && u == h[1] || (h = [i, u])), n) : (c && (o ? (e = o[0], r = o[1]) : (e = s[0], r = s[1], c.invert && (e = c.invert(e), r = c.invert(r)), e > r && (l = e, e = r, r = l))), f && (a ? (i = a[0], u = a[1]) : (i = h[0], u = h[1], f.invert && (i = f.invert(i), u = f.invert(u)), i > u && (l = i, i = u, u = l))), c && f ? [
|
|
[e, i],
|
|
[r, u]
|
|
] : c ? [e, r] : f && [i, u])
|
|
}, n.clear = function() {
|
|
return n.empty() || (s = [0, 0], h = [0, 0], o = a = null), n
|
|
}, n.empty = function() {
|
|
return !!c && s[0] == s[1] || !!f && h[0] == h[1]
|
|
}, ao.rebind(n, l, "on")
|
|
};
|
|
var $l = {
|
|
n: "ns-resize",
|
|
e: "ew-resize",
|
|
s: "ns-resize",
|
|
w: "ew-resize",
|
|
nw: "nwse-resize",
|
|
ne: "nesw-resize",
|
|
se: "nwse-resize",
|
|
sw: "nesw-resize"
|
|
},
|
|
Bl = [
|
|
["n", "e", "s", "w", "nw", "ne", "se", "sw"],
|
|
["e", "w"],
|
|
["n", "s"],
|
|
[]
|
|
],
|
|
Wl = ga.format = xa.timeFormat,
|
|
Jl = Wl.utc,
|
|
Gl = Jl("%Y-%m-%dT%H:%M:%S.%LZ");
|
|
Wl.iso = Date.prototype.toISOString && +new Date("2000-01-01T00:00:00.000Z") ? eo : Gl, eo.parse = function(n) {
|
|
var t = new Date(n);
|
|
return isNaN(t) ? null : t
|
|
}, eo.toString = Gl.toString, ga.second = On(function(n) {
|
|
return new va(1e3 * Math.floor(n / 1e3))
|
|
}, function(n, t) {
|
|
n.setTime(n.getTime() + 1e3 * Math.floor(t))
|
|
}, function(n) {
|
|
return n.getSeconds()
|
|
}), ga.seconds = ga.second.range, ga.seconds.utc = ga.second.utc.range, ga.minute = On(function(n) {
|
|
return new va(6e4 * Math.floor(n / 6e4))
|
|
}, function(n, t) {
|
|
n.setTime(n.getTime() + 6e4 * Math.floor(t))
|
|
}, function(n) {
|
|
return n.getMinutes()
|
|
}), ga.minutes = ga.minute.range, ga.minutes.utc = ga.minute.utc.range, ga.hour = On(function(n) {
|
|
var t = n.getTimezoneOffset() / 60;
|
|
return new va(36e5 * (Math.floor(n / 36e5 - t) + t))
|
|
}, function(n, t) {
|
|
n.setTime(n.getTime() + 36e5 * Math.floor(t))
|
|
}, function(n) {
|
|
return n.getHours()
|
|
}), ga.hours = ga.hour.range, ga.hours.utc = ga.hour.utc.range, ga.month = On(function(n) {
|
|
return n = ga.day(n), n.setDate(1), n
|
|
}, function(n, t) {
|
|
n.setMonth(n.getMonth() + t)
|
|
}, function(n) {
|
|
return n.getMonth()
|
|
}), ga.months = ga.month.range, ga.months.utc = ga.month.utc.range;
|
|
var Kl = [1e3, 5e3, 15e3, 3e4, 6e4, 3e5, 9e5, 18e5, 36e5, 108e5, 216e5, 432e5, 864e5, 1728e5, 6048e5, 2592e6, 7776e6, 31536e6],
|
|
Ql = [
|
|
[ga.second, 1],
|
|
[ga.second, 5],
|
|
[ga.second, 15],
|
|
[ga.second, 30],
|
|
[ga.minute, 1],
|
|
[ga.minute, 5],
|
|
[ga.minute, 15],
|
|
[ga.minute, 30],
|
|
[ga.hour, 1],
|
|
[ga.hour, 3],
|
|
[ga.hour, 6],
|
|
[ga.hour, 12],
|
|
[ga.day, 1],
|
|
[ga.day, 2],
|
|
[ga.week, 1],
|
|
[ga.month, 1],
|
|
[ga.month, 3],
|
|
[ga.year, 1]
|
|
],
|
|
nc = Wl.multi([
|
|
[".%L", function(n) {
|
|
return n.getMilliseconds()
|
|
}],
|
|
[":%S", function(n) {
|
|
return n.getSeconds()
|
|
}],
|
|
["%I:%M", function(n) {
|
|
return n.getMinutes()
|
|
}],
|
|
["%I %p", function(n) {
|
|
return n.getHours()
|
|
}],
|
|
["%a %d", function(n) {
|
|
return n.getDay() && 1 != n.getDate()
|
|
}],
|
|
["%b %d", function(n) {
|
|
return 1 != n.getDate()
|
|
}],
|
|
["%B", function(n) {
|
|
return n.getMonth()
|
|
}],
|
|
["%Y", zt]
|
|
]),
|
|
tc = {
|
|
range: function(n, t, e) {
|
|
return ao.range(Math.ceil(n / e) * e, +t, e).map(io)
|
|
},
|
|
floor: m,
|
|
ceil: m
|
|
};
|
|
Ql.year = ga.year, ga.scale = function() {
|
|
return ro(ao.scale.linear(), Ql, nc)
|
|
};
|
|
var ec = Ql.map(function(n) {
|
|
return [n[0].utc, n[1]]
|
|
}),
|
|
rc = Jl.multi([
|
|
[".%L", function(n) {
|
|
return n.getUTCMilliseconds()
|
|
}],
|
|
[":%S", function(n) {
|
|
return n.getUTCSeconds()
|
|
}],
|
|
["%I:%M", function(n) {
|
|
return n.getUTCMinutes()
|
|
}],
|
|
["%I %p", function(n) {
|
|
return n.getUTCHours()
|
|
}],
|
|
["%a %d", function(n) {
|
|
return n.getUTCDay() && 1 != n.getUTCDate()
|
|
}],
|
|
["%b %d", function(n) {
|
|
return 1 != n.getUTCDate()
|
|
}],
|
|
["%B", function(n) {
|
|
return n.getUTCMonth()
|
|
}],
|
|
["%Y", zt]
|
|
]);
|
|
ec.year = ga.year.utc, ga.scale.utc = function() {
|
|
return ro(ao.scale.linear(), ec, rc)
|
|
}, ao.text = An(function(n) {
|
|
return n.responseText
|
|
}), ao.json = function(n, t) {
|
|
return Cn(n, "application/json", uo, t)
|
|
}, ao.html = function(n, t) {
|
|
return Cn(n, "text/html", oo, t)
|
|
}, ao.xml = An(function(n) {
|
|
return n.responseXML
|
|
}), "function" == typeof define && define.amd ? (this.d3 = ao, define(ao)) : "object" == typeof module && module.exports ? module.exports = ao : this.d3 = ao
|
|
}();
|
|
</script>
|
|
<script>
|
|
/*Copyright (c) 2013-2016, Rob Schmuecker
|
|
All rights reserved.
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
* Redistributions of source code must retain the above copyright notice, this
|
|
list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright notice,
|
|
this list of conditions and the following disclaimer in the documentation
|
|
and/or other materials provided with the distribution.
|
|
|
|
* The name Rob Schmuecker may not be used to endorse or promote products
|
|
derived from this software without specific prior written permission.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
DISCLAIMED. IN NO EVENT SHALL MICHAEL BOSTOCK BE LIABLE FOR ANY DIRECT,
|
|
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
|
OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
|
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.*/
|
|
|
|
|
|
// Get JSON data
|
|
treeJSON = d3.json("https://github.com/OWASP/Nettacker", function(error, treeData) {
|
|
|
|
// Calculate total nodes, max label length
|
|
treeData = __data_will_locate_here__;
|
|
var totalNodes = 0;
|
|
var maxLabelLength = 0;
|
|
// variables for drag/drop
|
|
var selectedNode = null;
|
|
var draggingNode = null;
|
|
// panning variables
|
|
var panSpeed = 200;
|
|
var panBoundary = 20; // Within 20px from edges will pan when dragging.
|
|
// Misc. variables
|
|
var i = 0;
|
|
var duration = 750;
|
|
var root;
|
|
|
|
// size of the diagram
|
|
var viewerWidth = ($(window).width() / 100) * 80;
|
|
var viewerHeight = ($(window).height() / 100 ) * 65;
|
|
|
|
var tree = d3.layout.tree()
|
|
.size([viewerHeight, viewerWidth]);
|
|
|
|
// define a d3 diagonal projection for use by the node paths later on.
|
|
var diagonal = d3.svg.diagonal()
|
|
.projection(function(d) {
|
|
return [d.y, d.x];
|
|
});
|
|
|
|
// A recursive helper function for performing some setup by walking through all nodes
|
|
|
|
function visit(parent, visitFn, childrenFn) {
|
|
if (!parent) return;
|
|
|
|
visitFn(parent);
|
|
|
|
var children = childrenFn(parent);
|
|
if (children) {
|
|
var count = children.length;
|
|
for (var i = 0; i < count; i++) {
|
|
visit(children[i], visitFn, childrenFn);
|
|
}
|
|
}
|
|
}
|
|
|
|
// Call visit function to establish maxLabelLength
|
|
visit(treeData, function(d) {
|
|
totalNodes++;
|
|
maxLabelLength = Math.max(d.name.length, maxLabelLength);
|
|
|
|
}, function(d) {
|
|
return d.children && d.children.length > 0 ? d.children : null;
|
|
});
|
|
|
|
|
|
// sort the tree according to the node names
|
|
|
|
function sortTree() {
|
|
tree.sort(function(a, b) {
|
|
return b.name.toLowerCase() < a.name.toLowerCase() ? 1 : -1;
|
|
});
|
|
}
|
|
// Sort the tree initially incase the JSON isn\'t in a sorted order.
|
|
sortTree();
|
|
|
|
// TODO: Pan function, can be better implemented.
|
|
|
|
function pan(domNode, direction) {
|
|
var speed = panSpeed;
|
|
if (panTimer) {
|
|
clearTimeout(panTimer);
|
|
translateCoords = d3.transform(svgGroup.attr("transform"));
|
|
if (direction == \'left\' || direction == \'right\') {
|
|
translateX = direction == \'left\' ? translateCoords.translate[0] + speed : translateCoords.translate[0] - speed;
|
|
translateY = translateCoords.translate[1];
|
|
} else if (direction == \'up\' || direction == \'down\') {
|
|
translateX = translateCoords.translate[0];
|
|
translateY = direction == \'up\' ? translateCoords.translate[1] + speed : translateCoords.translate[1] - speed;
|
|
}
|
|
scaleX = translateCoords.scale[0];
|
|
scaleY = translateCoords.scale[1];
|
|
scale = zoomListener.scale();
|
|
svgGroup.transition().attr("transform", "translate(" + translateX + "," + translateY + ")scale(" + scale + ")");
|
|
d3.select(domNode).select(\'g.node\').attr("transform", "translate(" + translateX + "," + translateY + ")");
|
|
zoomListener.scale(zoomListener.scale());
|
|
zoomListener.translate([translateX, translateY]);
|
|
panTimer = setTimeout(function() {
|
|
pan(domNode, speed, direction);
|
|
}, 50);
|
|
}
|
|
}
|
|
|
|
// Define the zoom function for the zoomable tree
|
|
|
|
function zoom() {
|
|
svgGroup.attr("transform", "translate(" + d3.event.translate + ")scale(" + d3.event.scale + ")");
|
|
}
|
|
|
|
|
|
// define the zoomListener which calls the zoom function on the "zoom" event constrained within the scaleExtents
|
|
var zoomListener = d3.behavior.zoom().scaleExtent([0.1, 3]).on("zoom", zoom);
|
|
|
|
|
|
|
|
// define the baseSvg, attaching a class for styling and the zoomListener
|
|
var baseSvg = d3.select("#tree-container").append("svg")
|
|
.attr("width", viewerWidth)
|
|
.attr("height", viewerHeight)
|
|
.attr("class", "overlay")
|
|
.call(zoomListener);
|
|
|
|
|
|
// Define the drag listeners for drag/drop behaviour of nodes.
|
|
dragListener = d3.behavior.drag()
|
|
.on("dragstart", function(d) {
|
|
if (d == root) {
|
|
return;
|
|
}
|
|
dragStarted = true;
|
|
nodes = tree.nodes(d);
|
|
d3.event.sourceEvent.stopPropagation();
|
|
// it\'s important that we suppress the mouseover event on the node being dragged. Otherwise it will absorb the mouseover event and the underlying node will not detect it d3.select(this).attr(\'pointer-events\', \'none\');
|
|
})
|
|
.on("drag", function(d) {
|
|
if (d == root) {
|
|
return;
|
|
}
|
|
if (dragStarted) {
|
|
domNode = this;
|
|
initiateDrag(d, domNode);
|
|
}
|
|
|
|
// get coords of mouseEvent relative to svg container to allow for panning
|
|
relCoords = d3.mouse($(\'svg\').get(0));
|
|
if (relCoords[0] < panBoundary) {
|
|
panTimer = true;
|
|
pan(this, \'left\');
|
|
} else if (relCoords[0] > ($(\'svg\').width() - panBoundary)) {
|
|
|
|
panTimer = true;
|
|
pan(this, \'right\');
|
|
} else if (relCoords[1] < panBoundary) {
|
|
panTimer = true;
|
|
pan(this, \'up\');
|
|
} else if (relCoords[1] > ($(\'svg\').height() - panBoundary)) {
|
|
panTimer = true;
|
|
pan(this, \'down\');
|
|
} else {
|
|
try {
|
|
clearTimeout(panTimer);
|
|
} catch (e) {
|
|
|
|
}
|
|
}
|
|
|
|
d.x0 += d3.event.dy;
|
|
d.y0 += d3.event.dx;
|
|
var node = d3.select(this);
|
|
node.attr("transform", "translate(" + d.y0 + "," + d.x0 + ")");
|
|
updateTempConnector();
|
|
}).on("dragend", function(d) {
|
|
if (d == root) {
|
|
return;
|
|
}
|
|
domNode = this;
|
|
if (selectedNode) {
|
|
// now remove the element from the parent, and insert it into the new elements children
|
|
var index = draggingNode.parent.children.indexOf(draggingNode);
|
|
if (index > -1) {
|
|
draggingNode.parent.children.splice(index, 1);
|
|
}
|
|
if (typeof selectedNode.children !== \'undefined\' || typeof selectedNode._children !== \'undefined\') {
|
|
if (typeof selectedNode.children !== \'undefined\') {
|
|
selectedNode.children.push(draggingNode);
|
|
} else {
|
|
selectedNode._children.push(draggingNode);
|
|
}
|
|
} else {
|
|
selectedNode.children = [];
|
|
selectedNode.children.push(draggingNode);
|
|
}
|
|
// Make sure that the node being added to is expanded so user can see added node is correctly moved
|
|
expand(selectedNode);
|
|
sortTree();
|
|
endDrag();
|
|
} else {
|
|
endDrag();
|
|
}
|
|
});
|
|
|
|
function endDrag() {
|
|
selectedNode = null;
|
|
d3.selectAll(\'.ghostCircle\').attr(\'class\', \'ghostCircle\');
|
|
d3.select(domNode).attr(\'class\', \'node\');
|
|
// now restore the mouseover event or we won\'t be able to drag a 2nd time
|
|
d3.select(domNode).select(\'.ghostCircle\').attr(\'pointer-events\', \'\');
|
|
updateTempConnector();
|
|
if (draggingNode !== null) {
|
|
update(root);
|
|
centerNode(draggingNode);
|
|
draggingNode = null;
|
|
}
|
|
}
|
|
|
|
// Helper functions for collapsing and expanding nodes.
|
|
|
|
function collapse(d) {
|
|
if (d.children) {
|
|
d._children = d.children;
|
|
d._children.forEach(collapse);
|
|
d.children = null;
|
|
}
|
|
}
|
|
|
|
function expand(d) {
|
|
if (d._children) {
|
|
d.children = d._children;
|
|
d.children.forEach(expand);
|
|
d._children = null;
|
|
}
|
|
}
|
|
|
|
var overCircle = function(d) {
|
|
selectedNode = d;
|
|
updateTempConnector();
|
|
};
|
|
var outCircle = function(d) {
|
|
selectedNode = null;
|
|
updateTempConnector();
|
|
};
|
|
|
|
// Function to update the temporary connector indicating dragging affiliation
|
|
var updateTempConnector = function() {
|
|
var data = [];
|
|
if (draggingNode !== null && selectedNode !== null) {
|
|
// have to flip the source coordinates since we did this for the existing connectors on the original tree
|
|
data = [{
|
|
source: {
|
|
x: selectedNode.y0,
|
|
y: selectedNode.x0
|
|
},
|
|
target: {
|
|
x: draggingNode.y0,
|
|
y: draggingNode.x0
|
|
}
|
|
}];
|
|
}
|
|
var link = svgGroup.selectAll(".templink").data(data);
|
|
|
|
link.enter().append("path")
|
|
.attr("class", "templink")
|
|
.attr("d", d3.svg.diagonal())
|
|
.attr(\'pointer-events\', \'none\');
|
|
|
|
link.attr("d", d3.svg.diagonal());
|
|
|
|
link.exit().remove();
|
|
};
|
|
|
|
// Function to center node when clicked/dropped so node doesn\'t get lost when collapsing/moving with large amount of children.
|
|
|
|
function centerNode(source) {
|
|
scale = zoomListener.scale();
|
|
x = -source.y0;
|
|
y = -source.x0;
|
|
x = x * scale + viewerWidth / 2;
|
|
y = y * scale + viewerHeight / 2;
|
|
d3.select(\'g\').transition()
|
|
.duration(duration)
|
|
.attr("transform", "translate(" + x + "," + y + ")scale(" + scale + ")");
|
|
zoomListener.scale(scale);
|
|
zoomListener.translate([x, y]);
|
|
}
|
|
|
|
// Toggle children function
|
|
|
|
function toggleChildren(d) {
|
|
if (d.children) {
|
|
d._children = d.children;
|
|
d.children = null;
|
|
} else if (d._children) {
|
|
d.children = d._children;
|
|
d._children = null;
|
|
}
|
|
return d;
|
|
}
|
|
|
|
// Toggle children on click.
|
|
|
|
function click(d) {
|
|
if (d3.event.defaultPrevented) return; // click suppressed
|
|
d = toggleChildren(d);
|
|
update(d);
|
|
centerNode(d);
|
|
}
|
|
|
|
function update(source) {
|
|
// Compute the new height, function counts total children of root node and sets tree height accordingly.
|
|
// This prevents the layout looking squashed when new nodes are made visible or looking sparse when nodes are removed
|
|
// This makes the layout more consistent.
|
|
var levelWidth = [1];
|
|
var childCount = function(level, n) {
|
|
|
|
if (n.children && n.children.length > 0) {
|
|
if (levelWidth.length <= level + 1) levelWidth.push(0);
|
|
|
|
levelWidth[level + 1] += n.children.length;
|
|
n.children.forEach(function(d) {
|
|
childCount(level + 1, d);
|
|
});
|
|
}
|
|
};
|
|
childCount(0, root);
|
|
var newHeight = d3.max(levelWidth) * 25; // 25 pixels per line
|
|
tree = tree.size([newHeight, viewerWidth]);
|
|
|
|
// Compute the new tree layout.
|
|
var nodes = tree.nodes(root).reverse(),
|
|
links = tree.links(nodes);
|
|
|
|
// Set widths between levels based on maxLabelLength.
|
|
nodes.forEach(function(d) {
|
|
d.y = (d.depth * (maxLabelLength * 3)); //maxLabelLength * 10px
|
|
// alternatively to keep a fixed scale one can set a fixed depth per level
|
|
// Normalize for fixed-depth by commenting out below line
|
|
// d.y = (d.depth * 500); //500px per level.
|
|
});
|
|
|
|
// Update the nodes\xc3\xa2\xe2\x82\xac\xc2\xa6
|
|
node = svgGroup.selectAll("g.node")
|
|
.data(nodes, function(d) {
|
|
return d.id || (d.id = ++i);
|
|
});
|
|
|
|
// Enter any new nodes at the parent\'s previous position.
|
|
var nodeEnter = node.enter().append("g")
|
|
.call(dragListener)
|
|
.attr("class", "node")
|
|
.attr("transform", function(d) {
|
|
return "translate(" + source.y0 + "," + source.x0 + ")";
|
|
})
|
|
.on(\'click\', click);
|
|
|
|
nodeEnter.append("circle")
|
|
.attr(\'class\', \'nodeCircle\')
|
|
.attr("r", 0)
|
|
.style("fill", function(d) {
|
|
return d._children ? "lightsteelblue" : "#fff";
|
|
});
|
|
|
|
nodeEnter.append("text")
|
|
.attr("x", function(d) {
|
|
return d.children || d._children ? -10 : 10;
|
|
})
|
|
.attr("dy", ".35em")
|
|
.attr(\'class\', \'nodeText\')
|
|
.attr("text-anchor", function(d) {
|
|
return d.children || d._children ? "end" : "start";
|
|
})
|
|
.text(function(d) {
|
|
return d.name;
|
|
})
|
|
.style("fill-opacity", 0);
|
|
|
|
// phantom node to give us mouseover in a radius around it
|
|
nodeEnter.append("circle")
|
|
.attr(\'class\', \'ghostCircle\')
|
|
.attr("r", 30)
|
|
.attr("opacity", 0.2) // change this to zero to hide the target area
|
|
.style("fill", "red")
|
|
.attr(\'pointer-events\', \'mouseover\')
|
|
.on("mouseover", function(node) {
|
|
overCircle(node);
|
|
})
|
|
.on("mouseout", function(node) {
|
|
outCircle(node);
|
|
});
|
|
|
|
// Update the text to reflect whether node has children or not.
|
|
node.select(\'text\')
|
|
.attr("x", function(d) {
|
|
return d.children || d._children ? -10 : 10;
|
|
})
|
|
.attr("text-anchor", function(d) {
|
|
return d.children || d._children ? "end" : "start";
|
|
})
|
|
.text(function(d) {
|
|
return d.name;
|
|
});
|
|
|
|
// Change the circle fill depending on whether it has children and is collapsed
|
|
node.select("circle.nodeCircle")
|
|
.attr("r", 4.5)
|
|
.style("fill", function(d) {
|
|
return d._children ? "lightsteelblue" : "#fff";
|
|
});
|
|
|
|
// Transition nodes to their new position.
|
|
var nodeUpdate = node.transition()
|
|
.duration(duration)
|
|
.attr("transform", function(d) {
|
|
return "translate(" + d.y + "," + d.x + ")";
|
|
});
|
|
|
|
// Fade the text in
|
|
nodeUpdate.select("text")
|
|
.style("fill-opacity", 1);
|
|
|
|
// Transition exiting nodes to the parent\'s new position.
|
|
var nodeExit = node.exit().transition()
|
|
.duration(duration)
|
|
.attr("transform", function(d) {
|
|
return "translate(" + source.y + "," + source.x + ")";
|
|
})
|
|
.remove();
|
|
|
|
nodeExit.select("circle")
|
|
.attr("r", 0);
|
|
|
|
nodeExit.select("text")
|
|
.style("fill-opacity", 0);
|
|
|
|
// Update the links\xc3\xa2\xe2\x82\xac\xc2\xa6
|
|
var link = svgGroup.selectAll("path.link")
|
|
.data(links, function(d) {
|
|
return d.target.id;
|
|
});
|
|
|
|
// Enter any new links at the parent\'s previous position.
|
|
link.enter().insert("path", "g")
|
|
.attr("class", "link")
|
|
.attr("d", function(d) {
|
|
var o = {
|
|
x: source.x0,
|
|
y: source.y0
|
|
};
|
|
return diagonal({
|
|
source: o,
|
|
target: o
|
|
});
|
|
});
|
|
|
|
// Transition links to their new position.
|
|
link.transition()
|
|
.duration(duration)
|
|
.attr("d", diagonal);
|
|
|
|
// Transition exiting nodes to the parent\'s new position.
|
|
link.exit().transition()
|
|
.duration(duration)
|
|
.attr("d", function(d) {
|
|
var o = {
|
|
x: source.x,
|
|
y: source.y
|
|
};
|
|
return diagonal({
|
|
source: o,
|
|
target: o
|
|
});
|
|
})
|
|
.remove();
|
|
|
|
// Stash the old positions for transition.
|
|
nodes.forEach(function(d) {
|
|
d.x0 = d.x;
|
|
d.y0 = d.y;
|
|
});
|
|
}
|
|
|
|
// Append a group which holds all nodes and which the zoom Listener can act upon.
|
|
var svgGroup = baseSvg.append("g");
|
|
|
|
// Define the root
|
|
root = treeData;
|
|
root.x0 = viewerHeight / 2;
|
|
root.y0 = 0;
|
|
|
|
\t root.children.forEach(function(child){
|
|
collapse(child);
|
|
\t });
|
|
|
|
// Layout the tree initially and center on the root node.
|
|
update(root);
|
|
centerNode(root);
|
|
});
|
|
</script>
|
|
<body style="background-color:#F0F0F0;"><p class='description'>__description_to_replace__</p><br><br>
|
|
<center>
|
|
<div id="tree-container"></div><br>
|
|
</center>
|
|
</body>'''.replace('__data_will_locate_here__', json.dumps(d3_structure)) \
|
|
.replace('__title_to_replace__', messages(language, "pentest_graphs")) \
|
|
.replace('__description_to_replace__', messages(language, "graph_message")) \
|
|
.replace('__html_title_to_replace__', messages(language, "nettacker_report"))
|
|
if version() is 2:
|
|
return data.decode('utf8')
|
|
return data
|