Files
SIPAIIS_WMS_JSSW/bin/WebRoot/JS/raphael-min.js
2026-01-16 14:13:44 +08:00

3680 lines
87 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
* Raphael 1.5.2 - JavaScript Vector Library
*
* Copyright (c) 2010 Dmitry Baranovskiy (http://raphaeljs.com)
* Licensed under the MIT (http://raphaeljs.com/license.html) license.
*/
(function() {
function a() {
if (a.is(arguments[0], G)) {
var b = arguments[0], d = bV[m](a, b.splice(0, 3 + a.is(b[0], E))), e = d
.set();
for (var g = 0, h = b[w]; g < h; g++) {
var i = b[g] || {};
c[f](i.type) && e[L](d[i.type]().attr(i))
}
return e
}
return bV[m](a, arguments)
}
a.version = "1.5.2";
var b = /[, ]+/, c = {
circle : 1,
rect : 1,
path : 1,
ellipse : 1,
text : 1,
image : 1
}, d = /\{(\d+)\}/g, e = "prototype", f = "hasOwnProperty", g = document, h = window, i = {
was : Object[e][f].call(h, "Raphael"),
is : h.Raphael
}, j = function() {
this.customAttributes = {}
}, k, l = "appendChild", m = "apply", n = "concat", o = "createTouch" in g, p = "", q = " ", r = String, s = "split", t = "click dblclick mousedown mousemove mouseout mouseover mouseup touchstart touchmove touchend orientationchange touchcancel gesturestart gesturechange gestureend"[s]
(q), u = {
mousedown : "touchstart",
mousemove : "touchmove",
mouseup : "touchend"
}, v = "join", w = "length", x = r[e].toLowerCase, y = Math, z = y.max, A = y.min, B = y.abs, C = y.pow, D = y.PI, E = "number", F = "string", G = "array", H = "toString", I = "fill", J = Object[e][H], K = {}, L = "push", M = /^url\(['"]?([^\)]+?)['"]?\)$/i, N = /^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i, O = {
"NaN" : 1,
Infinity : 1,
"-Infinity" : 1
}, P = /^(?:cubic-)?bezier\(([^,]+),([^,]+),([^,]+),([^\)]+)\)/, Q = y.round, R = "setAttribute", S = parseFloat, T = parseInt, U = " progid:DXImageTransform.Microsoft", V = r[e].toUpperCase, W = {
blur : 0,
"clip-rect" : "0 0 1e9 1e9",
cursor : "default",
cx : 0,
cy : 0,
fill : "#fff",
"fill-opacity" : 1,
font : "10px \"Arial\"",
"font-family" : "\"Arial\"",
"font-size" : "10",
"font-style" : "normal",
"font-weight" : 400,
gradient : 0,
height : 0,
href : "http://raphaeljs.com/",
opacity : 1,
path : "M0,0",
r : 0,
rotation : 0,
rx : 0,
ry : 0,
scale : "1 1",
src : "",
stroke : "#000",
"stroke-dasharray" : "",
"stroke-linecap" : "butt",
"stroke-linejoin" : "butt",
"stroke-miterlimit" : 0,
"stroke-opacity" : 1,
"stroke-width" : 1,
target : "_blank",
"text-anchor" : "middle",
title : "Raphael",
translation : "0 0",
width : 0,
x : 0,
y : 0
}, X = {
along : "along",
blur : E,
"clip-rect" : "csv",
cx : E,
cy : E,
fill : "colour",
"fill-opacity" : E,
"font-size" : E,
height : E,
opacity : E,
path : "path",
r : E,
rotation : "csv",
rx : E,
ry : E,
scale : "csv",
stroke : "colour",
"stroke-opacity" : E,
"stroke-width" : E,
translation : "csv",
width : E,
x : E,
y : E
}, Y = "replace", Z = /^(from|to|\d+%?)$/, $ = /\s*,\s*/, _ = {
hs : 1,
rg : 1
}, ba = /,?([achlmqrstvxz]),?/gi, bb = /([achlmqstvz])[\s,]*((-?\d*\.?\d*(?:e[-+]?\d+)?\s*,?\s*)+)/ig, bc = /(-?\d*\.?\d*(?:e[-+]?\d+)?)\s*,?\s*/ig, bd = /^r(?:\(([^,]+?)\s*,\s*([^\)]+?)\))?/, be = function(
a, b) {
return a.key - b.key
};
a.type = h.SVGAngle
|| g.implementation.hasFeature(
"http://www.w3.org/TR/SVG11/feature#BasicStructure", "1.1") ? "SVG"
: "VML";
if (a.type == "VML") {
var bf = g.createElement("div"), bg;
bf.innerHTML = "<v:shape adj=\"1\"/>";
bg = bf.firstChild;
bg.style.behavior = "url(#default#VML)";
if (!(bg && typeof bg.adj == "object"))
return a.type = null;
bf = null
}
a.svg = !(a.vml = a.type == "VML");
j[e] = a[e];
k = j[e];
a._id = 0;
a._oid = 0;
a.fn = {};
a.is = function(a, b) {
b = x.call(b);
if (b == "finite")
return !O[f](+a);
return b == "null" && a === null || b == typeof a || b == "object"
&& a === Object(a) || b == "array" && Array.isArray
&& Array.isArray(a)
|| J.call(a).slice(8, -1).toLowerCase() == b
};
a.angle = function(b, c, d, e, f, g) {
{
if (f == null) {
var h = b - d, i = c - e;
if (!h && !i)
return 0;
return ((h < 0) * 180 + y.atan(-i / -h) * 180 / D + 360) % 360
}
return a.angle(b, c, f, g) - a.angle(d, e, f, g)
}
};
a.rad = function(a) {
return a % 360 * D / 180
};
a.deg = function(a) {
return a * 180 / D % 360
};
a.snapTo = function(b, c, d) {
d = a.is(d, "finite") ? d : 10;
if (a.is(b, G)) {
var e = b.length;
while (e--)
if (B(b[e] - c) <= d)
return b[e]
} else {
b = +b;
var f = c % b;
if (f < d)
return c - f;
if (f > b - d)
return c - f + b
}
return c
};
function bh() {
var a = [], b = 0;
for (; b < 32; b++)
a[b] = (~(~(y.random() * 16)))[H](16);
a[12] = 4;
a[16] = (a[16] & 3 | 8)[H](16);
return "r-" + a[v]("")
}
a.setWindow = function(a) {
h = a;
g = h.document
};
var bi = function(b) {
if (a.vml) {
var c = /^\s+|\s+$/g, d;
try {
var e = new ActiveXObject("htmlfile");
e.write("<body>");
e.close();
d = e.body
} catch (a) {
d = createPopup().document.body
}
var f = d.createTextRange();
bi = bm(function(a) {
try {
d.style.color = r(a)[Y](c, p);
var b = f.queryCommandValue("ForeColor");
b = (b & 255) << 16 | b & 65280 | (b & 16711680) >>> 16;
return "#" + ("000000" + b[H](16)).slice(-6)
} catch (a) {
return "none"
}
})
} else {
var h = g.createElement("i");
h.title = "Raphaël Colour Picker";
h.style.display = "none";
g.body[l](h);
bi = bm(function(a) {
h.style.color = a;
return g.defaultView.getComputedStyle(h, p).getPropertyValue(
"color")
})
}
return bi(b)
}, bj = function() {
return "hsb(" + [ this.h, this.s, this.b ] + ")"
}, bk = function() {
return "hsl(" + [ this.h, this.s, this.l ] + ")"
}, bl = function() {
return this.hex
};
a.hsb2rgb = function(b, c, d, e) {
if (a.is(b, "object") && "h" in b && "s" in b && "b" in b) {
d = b.b;
c = b.s;
b = b.h;
e = b.o
}
return a.hsl2rgb(b, c, d / 2, e)
};
a.hsl2rgb = function(b, c, d, e) {
if (a.is(b, "object") && "h" in b && "s" in b && "l" in b) {
d = b.l;
c = b.s;
b = b.h
}
if (b > 1 || c > 1 || d > 1) {
b /= 360;
c /= 100;
d /= 100
}
var f = {}, g = [ "r", "g", "b" ], h, i, j, k, l, m;
if (c) {
d < 0.5 ? h = d * (1 + c) : h = d + c - d * c;
i = 2 * d - h;
for (var n = 0; n < 3; n++) {
j = b + 1 / 3 * -(n - 1);
j < 0 && j++;
j > 1 && j--;
j * 6 < 1 ? f[g[n]] = i + (h - i) * 6 * j
: j * 2 < 1 ? f[g[n]] = h : j * 3 < 2 ? f[g[n]] = i
+ (h - i) * (2 / 3 - j) * 6 : f[g[n]] = i
}
} else
f = {
r : d,
g : d,
b : d
};
f.r *= 255;
f.g *= 255;
f.b *= 255;
f.hex = "#"
+ (16777216 | f.b | f.g << 8 | f.r << 16).toString(16).slice(1);
a.is(e, "finite") && (f.opacity = e);
f.toString = bl;
return f
};
a.rgb2hsb = function(b, c, d) {
if (c == null && a.is(b, "object") && "r" in b && "g" in b && "b" in b) {
d = b.b;
c = b.g;
b = b.r
}
if (c == null && a.is(b, F)) {
var e = a.getRGB(b);
b = e.r;
c = e.g;
d = e.b
}
if (b > 1 || c > 1 || d > 1) {
b /= 255;
c /= 255;
d /= 255
}
var f = z(b, c, d), g = A(b, c, d), h, i, j = f;
{
if (g == f)
return {
h : 0,
s : 0,
b : f,
toString : bj
};
var k = f - g;
i = k / f;
b == f ? h = (c - d) / k : c == f ? h = 2 + (d - b) / k : h = 4
+ (b - c) / k;
h /= 6;
h < 0 && h++;
h > 1 && h--
}
return {
h : h,
s : i,
b : j,
toString : bj
}
};
a.rgb2hsl = function(b, c, d) {
if (c == null && a.is(b, "object") && "r" in b && "g" in b && "b" in b) {
d = b.b;
c = b.g;
b = b.r
}
if (c == null && a.is(b, F)) {
var e = a.getRGB(b);
b = e.r;
c = e.g;
d = e.b
}
if (b > 1 || c > 1 || d > 1) {
b /= 255;
c /= 255;
d /= 255
}
var f = z(b, c, d), g = A(b, c, d), h, i, j = (f + g) / 2, k;
if (g == f)
k = {
h : 0,
s : 0,
l : j
};
else {
var l = f - g;
i = j < 0.5 ? l / (f + g) : l / (2 - f - g);
b == f ? h = (c - d) / l : c == f ? h = 2 + (d - b) / l : h = 4
+ (b - c) / l;
h /= 6;
h < 0 && h++;
h > 1 && h--;
k = {
h : h,
s : i,
l : j
}
}
k.toString = bk;
return k
};
a._path2string = function() {
return this.join(",")[Y](ba, "$1")
};
function bm(a, b, c) {
function d() {
var g = Array[e].slice.call(arguments, 0), h = g[v]("►"), i = d.cache = d.cache
|| {}, j = d.count = d.count || [];
if (i[f](h))
return c ? c(i[h]) : i[h];
j[w] >= 1000 && delete i[j.shift()];
j[L](h);
i[h] = a[m](b, g);
return c ? c(i[h]) : i[h]
}
return d
}
a.getRGB = bm(function(b) {
if (!b || !(!((b = r(b)).indexOf("-") + 1)))
return {
r : -1,
g : -1,
b : -1,
hex : "none",
error : 1
};
if (b == "none")
return {
r : -1,
g : -1,
b : -1,
hex : "none"
};
!(_[f](b.toLowerCase().substring(0, 2)) || b.charAt() == "#")
&& (b = bi(b));
var c, d, e, g, h, i, j, k = b.match(N);
if (k) {
if (k[2]) {
g = T(k[2].substring(5), 16);
e = T(k[2].substring(3, 5), 16);
d = T(k[2].substring(1, 3), 16)
}
if (k[3]) {
g = T((i = k[3].charAt(3)) + i, 16);
e = T((i = k[3].charAt(2)) + i, 16);
d = T((i = k[3].charAt(1)) + i, 16)
}
if (k[4]) {
j = k[4][s]($);
d = S(j[0]);
j[0].slice(-1) == "%" && (d *= 2.55);
e = S(j[1]);
j[1].slice(-1) == "%" && (e *= 2.55);
g = S(j[2]);
j[2].slice(-1) == "%" && (g *= 2.55);
k[1].toLowerCase().slice(0, 4) == "rgba" && (h = S(j[3]));
j[3] && j[3].slice(-1) == "%" && (h /= 100)
}
if (k[5]) {
j = k[5][s]($);
d = S(j[0]);
j[0].slice(-1) == "%" && (d *= 2.55);
e = S(j[1]);
j[1].slice(-1) == "%" && (e *= 2.55);
g = S(j[2]);
j[2].slice(-1) == "%" && (g *= 2.55);
(j[0].slice(-3) == "deg" || j[0].slice(-1) == "°")
&& (d /= 360);
k[1].toLowerCase().slice(0, 4) == "hsba" && (h = S(j[3]));
j[3] && j[3].slice(-1) == "%" && (h /= 100);
return a.hsb2rgb(d, e, g, h)
}
if (k[6]) {
j = k[6][s]($);
d = S(j[0]);
j[0].slice(-1) == "%" && (d *= 2.55);
e = S(j[1]);
j[1].slice(-1) == "%" && (e *= 2.55);
g = S(j[2]);
j[2].slice(-1) == "%" && (g *= 2.55);
(j[0].slice(-3) == "deg" || j[0].slice(-1) == "°")
&& (d /= 360);
k[1].toLowerCase().slice(0, 4) == "hsla" && (h = S(j[3]));
j[3] && j[3].slice(-1) == "%" && (h /= 100);
return a.hsl2rgb(d, e, g, h)
}
k = {
r : d,
g : e,
b : g
};
k.hex = "#"
+ (16777216 | g | e << 8 | d << 16).toString(16).slice(1);
a.is(h, "finite") && (k.opacity = h);
return k
}
return {
r : -1,
g : -1,
b : -1,
hex : "none",
error : 1
}
}, a);
a.getColor = function(a) {
var b = this.getColor.start = this.getColor.start || {
h : 0,
s : 1,
b : a || 0.75
}, c = this.hsb2rgb(b.h, b.s, b.b);
b.h += 0.075;
if (b.h > 1) {
b.h = 0;
b.s -= 0.2;
b.s <= 0 && (this.getColor.start = {
h : 0,
s : 1,
b : b.b
})
}
return c.hex
};
a.getColor.reset = function() {
delete this.start
};
a.parsePathString = bm(function(b) {
if (!b)
return null;
var c = {
a : 7,
c : 6,
h : 1,
l : 2,
m : 2,
q : 4,
s : 4,
t : 2,
v : 1,
z : 0
}, d = [];
a.is(b, G) && a.is(b[0], G) && (d = bo(b));
d[w] || r(b)[Y](bb, function(a, b, e) {
var f = [], g = x.call(b);
e[Y](bc, function(a, b) {
b && f[L](+b)
});
if (g == "m" && f[w] > 2) {
d[L]([ b ][n](f.splice(0, 2)));
g = "l";
b = b == "m" ? "l" : "L"
}
while (f[w] >= c[g]) {
d[L]([ b ][n](f.splice(0, c[g])));
if (!c[g])
break
}
});
d[H] = a._path2string;
return d
});
a.findDotsAtSegment = function(a, b, c, d, e, f, g, h, i) {
var j = 1 - i, k = C(j, 3) * a + C(j, 2) * 3 * i * c + j * 3 * i * i
* e + C(i, 3) * g, l = C(j, 3) * b + C(j, 2) * 3 * i * d + j
* 3 * i * i * f + C(i, 3) * h, m = a + 2 * i * (c - a) + i * i
* (e - 2 * c + a), n = b + 2 * i * (d - b) + i * i
* (f - 2 * d + b), o = c + 2 * i * (e - c) + i * i
* (g - 2 * e + c), p = d + 2 * i * (f - d) + i * i
* (h - 2 * f + d), q = (1 - i) * a + i * c, r = (1 - i) * b + i
* d, s = (1 - i) * e + i * g, t = (1 - i) * f + i * h, u = 90
- y.atan((m - o) / (n - p)) * 180 / D;
(m > o || n < p) && (u += 180);
return {
x : k,
y : l,
m : {
x : m,
y : n
},
n : {
x : o,
y : p
},
start : {
x : q,
y : r
},
end : {
x : s,
y : t
},
alpha : u
}
};
var bn = bm(function(a) {
if (!a)
return {
x : 0,
y : 0,
width : 0,
height : 0
};
a = bw(a);
var b = 0, c = 0, d = [], e = [], f;
for (var g = 0, h = a[w]; g < h; g++) {
f = a[g];
if (f[0] == "M") {
b = f[1];
c = f[2];
d[L](b);
e[L](c)
} else {
var i = bv(b, c, f[1], f[2], f[3], f[4], f[5], f[6]);
d = d[n](i.min.x, i.max.x);
e = e[n](i.min.y, i.max.y);
b = f[5];
c = f[6]
}
}
var j = A[m](0, d), k = A[m](0, e);
return {
x : j,
y : k,
width : z[m](0, d) - j,
height : z[m](0, e) - k
}
}), bo = function(b) {
var c = [];
if (!a.is(b, G) || !a.is(b && b[0], G))
b = a.parsePathString(b);
for (var d = 0, e = b[w]; d < e; d++) {
c[d] = [];
for (var f = 0, g = b[d][w]; f < g; f++)
c[d][f] = b[d][f]
}
c[H] = a._path2string;
return c
}, bp = bm(function(b) {
if (!a.is(b, G) || !a.is(b && b[0], G))
b = a.parsePathString(b);
var c = [], d = 0, e = 0, f = 0, g = 0, h = 0;
if (b[0][0] == "M") {
d = b[0][1];
e = b[0][2];
f = d;
g = e;
h++;
c[L]([ "M", d, e ])
}
for (var i = h, j = b[w]; i < j; i++) {
var k = c[i] = [], l = b[i];
if (l[0] != x.call(l[0])) {
k[0] = x.call(l[0]);
switch (k[0]) {
case "a":
k[1] = l[1];
k[2] = l[2];
k[3] = l[3];
k[4] = l[4];
k[5] = l[5];
k[6] = +(l[6] - d).toFixed(3);
k[7] = +(l[7] - e).toFixed(3);
break;
case "v":
k[1] = +(l[1] - e).toFixed(3);
break;
case "m":
f = l[1];
g = l[2];
default:
for (var m = 1, n = l[w]; m < n; m++)
k[m] = +(l[m] - (m % 2 ? d : e)).toFixed(3)
}
} else {
k = c[i] = [];
if (l[0] == "m") {
f = l[1] + d;
g = l[2] + e
}
for (var o = 0, p = l[w]; o < p; o++)
c[i][o] = l[o]
}
var q = c[i][w];
switch (c[i][0]) {
case "z":
d = f;
e = g;
break;
case "h":
d += +c[i][q - 1];
break;
case "v":
e += +c[i][q - 1];
break;
default:
d += +c[i][q - 2];
e += +c[i][q - 1]
}
}
c[H] = a._path2string;
return c
}, 0, bo), bq = bm(function(b) {
if (!a.is(b, G) || !a.is(b && b[0], G))
b = a.parsePathString(b);
var c = [], d = 0, e = 0, f = 0, g = 0, h = 0;
if (b[0][0] == "M") {
d = +b[0][1];
e = +b[0][2];
f = d;
g = e;
h++;
c[0] = [ "M", d, e ]
}
for (var i = h, j = b[w]; i < j; i++) {
var k = c[i] = [], l = b[i];
if (l[0] != V.call(l[0])) {
k[0] = V.call(l[0]);
switch (k[0]) {
case "A":
k[1] = l[1];
k[2] = l[2];
k[3] = l[3];
k[4] = l[4];
k[5] = l[5];
k[6] = +(l[6] + d);
k[7] = +(l[7] + e);
break;
case "V":
k[1] = +l[1] + e;
break;
case "H":
k[1] = +l[1] + d;
break;
case "M":
f = +l[1] + d;
g = +l[2] + e;
default:
for (var m = 1, n = l[w]; m < n; m++)
k[m] = +l[m] + (m % 2 ? d : e)
}
} else
for (var o = 0, p = l[w]; o < p; o++)
c[i][o] = l[o];
switch (k[0]) {
case "Z":
d = f;
e = g;
break;
case "H":
d = k[1];
break;
case "V":
e = k[1];
break;
case "M":
f = c[i][c[i][w] - 2];
g = c[i][c[i][w] - 1];
default:
d = c[i][c[i][w] - 2];
e = c[i][c[i][w] - 1]
}
}
c[H] = a._path2string;
return c
}, null, bo), br = function(a, b, c, d) {
return [ a, b, c, d, c, d ]
}, bs = function(a, b, c, d, e, f) {
var g = 1 / 3, h = 2 / 3;
return [ g * a + h * c, g * b + h * d, g * e + h * c, g * f + h * d, e,
f ]
}, bt = function(a, b, c, d, e, f, g, h, i, j) {
var k = D * 120 / 180, l = D / 180 * (+e || 0), m = [], o, p = bm(function(
a, b, c) {
var d = a * y.cos(c) - b * y.sin(c), e = a * y.sin(c) + b
* y.cos(c);
return {
x : d,
y : e
}
});
if (j) {
G = j[0];
H = j[1];
E = j[2];
F = j[3]
} else {
o = p(a, b, -l);
a = o.x;
b = o.y;
o = p(h, i, -l);
h = o.x;
i = o.y;
var q = y.cos(D / 180 * e), r = y.sin(D / 180 * e), t = (a - h) / 2, u = (b - i) / 2, x = t
* t / (c * c) + u * u / (d * d);
if (x > 1) {
x = y.sqrt(x);
c = x * c;
d = x * d
}
var z = c * c, A = d * d, C = (f == g ? -1 : 1)
* y.sqrt(B((z * A - z * u * u - A * t * t)
/ (z * u * u + A * t * t))), E = C * c * u / d
+ (a + h) / 2, F = C * -d * t / c + (b + i) / 2, G = y
.asin(((b - F) / d).toFixed(9)), H = y.asin(((i - F) / d)
.toFixed(9));
G = a < E ? D - G : G;
H = h < E ? D - H : H;
G < 0 && (G = D * 2 + G);
H < 0 && (H = D * 2 + H);
g && G > H && (G = G - D * 2);
!g && H > G && (H = H - D * 2)
}
var I = H - G;
if (B(I) > k) {
var J = H, K = h, L = i;
H = G + k * (g && H > G ? 1 : -1);
h = E + c * y.cos(H);
i = F + d * y.sin(H);
m = bt(h, i, c, d, e, 0, g, K, L, [ H, J, E, F ])
}
I = H - G;
var M = y.cos(G), N = y.sin(G), O = y.cos(H), P = y.sin(H), Q = y
.tan(I / 4), R = 4 / 3 * c * Q, S = 4 / 3 * d * Q, T = [ a, b ], U = [
a + R * N, b - S * M ], V = [ h + R * P, i - S * O ], W = [ h,
i ];
U[0] = 2 * T[0] - U[0];
U[1] = 2 * T[1] - U[1];
{
if (j)
return [ U, V, W ][n](m);
m = [ U, V, W ][n](m)[v]()[s](",");
var X = [];
for (var Y = 0, Z = m[w]; Y < Z; Y++)
X[Y] = Y % 2 ? p(m[Y - 1], m[Y], l).y : p(m[Y], m[Y + 1], l).x;
return X
}
}, bu = function(a, b, c, d, e, f, g, h, i) {
var j = 1 - i;
return {
x : C(j, 3) * a + C(j, 2) * 3 * i * c + j * 3 * i * i * e + C(i, 3)
* g,
y : C(j, 3) * b + C(j, 2) * 3 * i * d + j * 3 * i * i * f + C(i, 3)
* h
}
}, bv = bm(function(a, b, c, d, e, f, g, h) {
var i = e - 2 * c + a - (g - 2 * e + c), j = 2 * (c - a) - 2 * (e - c), k = a
- c, l = (-j + y.sqrt(j * j - 4 * i * k)) / 2 / i, n = (-j - y
.sqrt(j * j - 4 * i * k))
/ 2 / i, o = [ b, h ], p = [ a, g ], q;
B(l) > "1e12" && (l = 0.5);
B(n) > "1e12" && (n = 0.5);
if (l > 0 && l < 1) {
q = bu(a, b, c, d, e, f, g, h, l);
p[L](q.x);
o[L](q.y)
}
if (n > 0 && n < 1) {
q = bu(a, b, c, d, e, f, g, h, n);
p[L](q.x);
o[L](q.y)
}
i = f - 2 * d + b - (h - 2 * f + d);
j = 2 * (d - b) - 2 * (f - d);
k = b - d;
l = (-j + y.sqrt(j * j - 4 * i * k)) / 2 / i;
n = (-j - y.sqrt(j * j - 4 * i * k)) / 2 / i;
B(l) > "1e12" && (l = 0.5);
B(n) > "1e12" && (n = 0.5);
if (l > 0 && l < 1) {
q = bu(a, b, c, d, e, f, g, h, l);
p[L](q.x);
o[L](q.y)
}
if (n > 0 && n < 1) {
q = bu(a, b, c, d, e, f, g, h, n);
p[L](q.x);
o[L](q.y)
}
return {
min : {
x : A[m](0, p),
y : A[m](0, o)
},
max : {
x : z[m](0, p),
y : z[m](0, o)
}
}
}), bw = bm(function(a, b) {
var c = bq(a), d = b && bq(b), e = {
x : 0,
y : 0,
bx : 0,
by : 0,
X : 0,
Y : 0,
qx : null,
qy : null
}, f = {
x : 0,
y : 0,
bx : 0,
by : 0,
X : 0,
Y : 0,
qx : null,
qy : null
}, g = function(a, b) {
var c, d;
if (!a)
return [ "C", b.x, b.y, b.x, b.y, b.x, b.y ];
!(a[0] in {
T : 1,
Q : 1
}) && (b.qx = b.qy = null);
switch (a[0]) {
case "M":
b.X = a[1];
b.Y = a[2];
break;
case "A":
a = [ "C" ][n](bt[m](0, [ b.x, b.y ][n](a.slice(1))));
break;
case "S":
c = b.x + (b.x - (b.bx || b.x));
d = b.y + (b.y - (b.by || b.y));
a = [ "C", c, d ][n](a.slice(1));
break;
case "T":
b.qx = b.x + (b.x - (b.qx || b.x));
b.qy = b.y + (b.y - (b.qy || b.y));
a = [ "C" ][n](bs(b.x, b.y, b.qx, b.qy, a[1], a[2]));
break;
case "Q":
b.qx = a[1];
b.qy = a[2];
a = [ "C" ][n](bs(b.x, b.y, a[1], a[2], a[3], a[4]));
break;
case "L":
a = [ "C" ][n](br(b.x, b.y, a[1], a[2]));
break;
case "H":
a = [ "C" ][n](br(b.x, b.y, a[1], b.y));
break;
case "V":
a = [ "C" ][n](br(b.x, b.y, b.x, a[1]));
break;
case "Z":
a = [ "C" ][n](br(b.x, b.y, b.X, b.Y));
break
}
return a
}, h = function(a, b) {
if (a[b][w] > 7) {
a[b].shift();
var e = a[b];
while (e[w])
a.splice(b++, 0, [ "C" ][n](e.splice(0, 6)));
a.splice(b, 1);
k = z(c[w], d && d[w] || 0)
}
}, i = function(a, b, e, f, g) {
if (a && b && a[g][0] == "M" && b[g][0] != "M") {
b.splice(g, 0, [ "M", f.x, f.y ]);
e.bx = 0;
e.by = 0;
e.x = a[g][1];
e.y = a[g][2];
k = z(c[w], d && d[w] || 0)
}
};
for (var j = 0, k = z(c[w], d && d[w] || 0); j < k; j++) {
c[j] = g(c[j], e);
h(c, j);
d && (d[j] = g(d[j], f));
d && h(d, j);
i(c, d, e, f, j);
i(d, c, f, e, j);
var l = c[j], o = d && d[j], p = l[w], q = d && o[w];
e.x = l[p - 2];
e.y = l[p - 1];
e.bx = S(l[p - 4]) || e.x;
e.by = S(l[p - 3]) || e.y;
f.bx = d && (S(o[q - 4]) || f.x);
f.by = d && (S(o[q - 3]) || f.y);
f.x = d && o[q - 2];
f.y = d && o[q - 1]
}
return d ? [ c, d ] : c
}, null, bo), bx = bm(function(b) {
var c = [];
for (var d = 0, e = b[w]; d < e; d++) {
var f = {}, g = b[d].match(/^([^:]*):?([\d\.]*)/);
f.color = a.getRGB(g[1]);
if (f.color.error)
return null;
f.color = f.color.hex;
g[2] && (f.offset = g[2] + "%");
c[L](f)
}
for (d = 1, e = c[w] - 1; d < e; d++) {
if (!c[d].offset) {
var h = S(c[d - 1].offset || 0), i = 0;
for (var j = d + 1; j < e; j++) {
if (c[j].offset) {
i = c[j].offset;
break
}
}
if (!i) {
i = 100;
j = e
}
i = S(i);
var k = (i - h) / (j - d + 1);
for (; d < j; d++) {
h += k;
c[d].offset = h + "%"
}
}
}
return c
}), by = function(b, c, d, e) {
var f;
if (a.is(b, F) || a.is(b, "object")) {
f = a.is(b, F) ? g.getElementById(b) : b;
if (f.tagName)
return c == null ? {
container : f,
width : f.style.pixelWidth || f.offsetWidth,
height : f.style.pixelHeight || f.offsetHeight
} : {
container : f,
width : c,
height : d
}
} else
return {
container : 1,
x : b,
y : c,
width : d,
height : e
}
}, bz = function(a, b) {
var c = this;
for ( var d in b) {
if (b[f](d) && !(d in a))
switch (typeof b[d]) {
case "function":
(function(b) {
a[d] = a === c ? b : function() {
return b[m](c, arguments)
}
})(b[d]);
break;
case "object":
a[d] = a[d] || {};
bz.call(this, a[d], b[d]);
break;
default:
a[d] = b[d];
break
}
}
}, bA = function(a, b) {
a == b.top && (b.top = a.prev);
a == b.bottom && (b.bottom = a.next);
a.next && (a.next.prev = a.prev);
a.prev && (a.prev.next = a.next)
}, bB = function(a, b) {
if (b.top === a)
return;
bA(a, b);
a.next = null;
a.prev = b.top;
b.top.next = a;
b.top = a
}, bC = function(a, b) {
if (b.bottom === a)
return;
bA(a, b);
a.next = b.bottom;
a.prev = null;
b.bottom.prev = a;
b.bottom = a
}, bD = function(a, b, c) {
bA(a, c);
b == c.top && (c.top = a);
b.next && (b.next.prev = a);
a.next = b.next;
a.prev = b;
b.next = a
}, bE = function(a, b, c) {
bA(a, c);
b == c.bottom && (c.bottom = a);
b.prev && (b.prev.next = a);
a.prev = b.prev;
b.prev = a;
a.next = b
}, bF = function(a) {
return function() {
throw new Error("Raphaël: you are calling to method “" + a
+ "” of removed object")
}
};
a.pathToRelative = bp;
if (a.svg) {
k.svgns = "http://www.w3.org/2000/svg";
k.xlink = "http://www.w3.org/1999/xlink";
Q = function(a) {
return +a + (~(~a) === a) * 0.5
};
var bG = function(a, b) {
if (b)
for ( var c in b)
b[f](c) && a[R](c, r(b[c]));
else {
a = g.createElementNS(k.svgns, a);
a.style.webkitTapHighlightColor = "rgba(0,0,0,0)";
return a
}
};
a[H] = function() {
return "Your browser supports SVG.\nYou are running Raphaël "
+ this.version
};
var bH = function(a, b) {
var c = bG("path");
b.canvas && b.canvas[l](c);
var d = new bN(c, b);
d.type = "path";
bK(d, {
fill : "none",
stroke : "#000",
path : a
});
return d
}, bI = function(a, b, c) {
var d = "linear", e = 0.5, f = 0.5, h = a.style;
b = r(b)[Y](bd, function(a, b, c) {
d = "radial";
if (b && c) {
e = S(b);
f = S(c);
var g = (f > 0.5) * 2 - 1;
C(e - 0.5, 2) + C(f - 0.5, 2) > 0.25
&& (f = y.sqrt(0.25 - C(e - 0.5, 2)) * g + 0.5)
&& f != 0.5 && (f = f.toFixed(5) - 0.00001 * g)
}
return p
});
b = b[s](/\s*\-\s*/);
if (d == "linear") {
var i = b.shift();
i = -S(i);
if (isNaN(i))
return null;
var j = [ 0, 0, y.cos(i * D / 180), y.sin(i * D / 180) ], k = 1 / (z(
B(j[2]), B(j[3])) || 1);
j[2] *= k;
j[3] *= k;
if (j[2] < 0) {
j[0] = -j[2];
j[2] = 0
}
if (j[3] < 0) {
j[1] = -j[3];
j[3] = 0
}
}
var m = bx(b);
if (!m)
return null;
var n = a.getAttribute(I);
n = n.match(/^url\(#(.*)\)$/);
n && c.defs.removeChild(g.getElementById(n[1]));
var o = bG(d + "Gradient");
o.id = bh();
bG(o, d == "radial" ? {
fx : e,
fy : f
} : {
x1 : j[0],
y1 : j[1],
x2 : j[2],
y2 : j[3]
});
c.defs[l](o);
for (var q = 0, t = m[w]; q < t; q++) {
var u = bG("stop");
bG(u, {
offset : m[q].offset ? m[q].offset : q ? "100%" : "0%",
"stop-color" : m[q].color || "#fff"
});
o[l](u)
}
bG(a, {
fill : "url(#" + o.id + ")",
opacity : 1,
"fill-opacity" : 1
});
h.fill = p;
h.opacity = 1;
h.fillOpacity = 1;
return 1
}, bJ = function(b) {
var c = b.getBBox();
bG(b.pattern, {
patternTransform : a.format("translate({0},{1})", c.x, c.y)
})
}, bK = function(c, d) {
var e = {
"" : [ 0 ],
none : [ 0 ],
"-" : [ 3, 1 ],
"." : [ 1, 1 ],
"-." : [ 3, 1, 1, 1 ],
"-.." : [ 3, 1, 1, 1, 1, 1 ],
". " : [ 1, 3 ],
"- " : [ 4, 3 ],
"--" : [ 8, 3 ],
"- ." : [ 4, 3, 1, 3 ],
"--." : [ 8, 3, 1, 3 ],
"--.." : [ 8, 3, 1, 3, 1, 3 ]
}, h = c.node, i = c.attrs, j = c.rotate(), k = function(a, b) {
b = e[x.call(b)];
if (b) {
var c = a.attrs["stroke-width"] || "1", f = ({
round : c,
square : c,
butt : 0
})[a.attrs["stroke-linecap"] || d["stroke-linecap"]] || 0, g = [], i = b[w];
while (i--)
g[i] = b[i] * c + (i % 2 ? 1 : -1) * f;
bG(h, {
"stroke-dasharray" : g[v](",")
})
}
};
d[f]("rotation") && (j = d.rotation);
var m = r(j)[s](b);
if (m.length - 1) {
m[1] = +m[1];
m[2] = +m[2]
} else
m = null;
S(j) && c.rotate(0, true);
for ( var n in d) {
if (d[f](n)) {
if (!W[f](n))
continue;
var o = d[n];
i[n] = o;
switch (n) {
case "blur":
c.blur(o);
break;
case "rotation":
c.rotate(o, true);
break;
case "href":
case "title":
case "target":
var t = h.parentNode;
if (x.call(t.tagName) != "a") {
var u = bG("a");
t.insertBefore(u, h);
u[l](h);
t = u
}
n == "target" && o == "blank" ? t.setAttributeNS(
c.paper.xlink, "show", "new") : t
.setAttributeNS(c.paper.xlink, n, o);
break;
case "cursor":
h.style.cursor = o;
break;
case "clip-rect":
var y = r(o)[s](b);
if (y[w] == 4) {
c.clip
&& c.clip.parentNode.parentNode
.removeChild(c.clip.parentNode);
var z = bG("clipPath"), A = bG("rect");
z.id = bh();
bG(A, {
x : y[0],
y : y[1],
width : y[2],
height : y[3]
});
z[l](A);
c.paper.defs[l](z);
bG(h, {
"clip-path" : "url(#" + z.id + ")"
});
c.clip = A
}
if (!o) {
var B = g.getElementById(h
.getAttribute("clip-path")[Y](
/(^url\(#|\)$)/g, p));
B && B.parentNode.removeChild(B);
bG(h, {
"clip-path" : p
});
delete c.clip
}
break;
case "path":
c.type == "path" && bG(h, {
d : o ? i.path = bq(o) : "M0,0"
});
break;
case "width":
h[R](n, o);
if (i.fx) {
n = "x";
o = i.x
} else
break;
case "x":
i.fx && (o = -i.x - (i.width || 0));
case "rx":
if (n == "rx" && c.type == "rect")
break;
case "cx":
m && (n == "x" || n == "cx") && (m[1] += o - i[n]);
h[R](n, o);
c.pattern && bJ(c);
break;
case "height":
h[R](n, o);
if (i.fy) {
n = "y";
o = i.y
} else
break;
case "y":
i.fy && (o = -i.y - (i.height || 0));
case "ry":
if (n == "ry" && c.type == "rect")
break;
case "cy":
m && (n == "y" || n == "cy") && (m[2] += o - i[n]);
h[R](n, o);
c.pattern && bJ(c);
break;
case "r":
c.type == "rect" ? bG(h, {
rx : o,
ry : o
}) : h[R](n, o);
break;
case "src":
c.type == "image"
&& h.setAttributeNS(c.paper.xlink, "href", o);
break;
case "stroke-width":
h.style.strokeWidth = o;
h[R](n, o);
i["stroke-dasharray"] && k(c, i["stroke-dasharray"]);
break;
case "stroke-dasharray":
k(c, o);
break;
case "translation":
var C = r(o)[s](b);
C[0] = +C[0] || 0;
C[1] = +C[1] || 0;
if (m) {
m[1] += C[0];
m[2] += C[1]
}
cz.call(c, C[0], C[1]);
break;
case "scale":
C = r(o)[s](b);
c.scale(+C[0] || 1, +C[1] || +C[0] || 1,
isNaN(S(C[2])) ? null : +C[2],
isNaN(S(C[3])) ? null : +C[3]);
break;
case I:
var D = r(o).match(M);
if (D) {
z = bG("pattern");
var E = bG("image");
z.id = bh();
bG(z, {
x : 0,
y : 0,
patternUnits : "userSpaceOnUse",
height : 1,
width : 1
});
bG(E, {
x : 0,
y : 0
});
E.setAttributeNS(c.paper.xlink, "href", D[1]);
z[l](E);
var F = g.createElement("img");
F.style.cssText = "position:absolute;left:-9999em;top-9999em";
F.onload = function() {
bG(z, {
width : this.offsetWidth,
height : this.offsetHeight
});
bG(E, {
width : this.offsetWidth,
height : this.offsetHeight
});
g.body.removeChild(this);
c.paper.safari()
};
g.body[l](F);
F.src = D[1];
c.paper.defs[l](z);
h.style.fill = "url(#" + z.id + ")";
bG(h, {
fill : "url(#" + z.id + ")"
});
c.pattern = z;
c.pattern && bJ(c);
break
}
var G = a.getRGB(o);
if (G.error)
if ((({
circle : 1,
ellipse : 1
})[f](c.type) || r(o).charAt() != "r")
&& bI(h, o, c.paper)) {
i.gradient = o;
i.fill = "none";
break
} else {
delete d.gradient;
delete i.gradient;
!a.is(i.opacity, "undefined")
&& a.is(d.opacity, "undefined")
&& bG(h, {
opacity : i.opacity
});
!a.is(i["fill-opacity"], "undefined")
&& a.is(d["fill-opacity"], "undefined")
&& bG(h, {
"fill-opacity" : i["fill-opacity"]
})
}
G[f]("opacity")
&& bG(
h,
{
"fill-opacity" : G.opacity > 1 ? G.opacity / 100
: G.opacity
});
case "stroke":
G = a.getRGB(o);
h[R](n, G.hex);
n == "stroke"
&& G[f]("opacity")
&& bG(
h,
{
"stroke-opacity" : G.opacity > 1 ? G.opacity / 100
: G.opacity
});
break;
case "gradient":
(({
circle : 1,
ellipse : 1
})[f](c.type) || r(o).charAt() != "r")
&& bI(h, o, c.paper);
break;
case "opacity":
i.gradient && !i[f]("stroke-opacity") && bG(h, {
"stroke-opacity" : o > 1 ? o / 100 : o
});
case "fill-opacity":
if (i.gradient) {
var H = g.getElementById(h.getAttribute(I)[Y](
/^url\(#|\)$/g, p));
if (H) {
var J = H.getElementsByTagName("stop");
J[J[w] - 1][R]("stop-opacity", o)
}
break
}
default:
n == "font-size" && (o = T(o, 10) + "px");
var K = n[Y](/(\-.)/g, function(a) {
return V.call(a.substring(1))
});
h.style[K] = o;
h[R](n, o);
break
}
}
}
bM(c, d);
m ? c.rotate(m.join(q)) : S(j) && c.rotate(j, true)
}, bL = 1.2, bM = function(b, c) {
if (b.type != "text"
|| !(c[f]("text") || c[f]("font") || c[f]("font-size")
|| c[f]("x") || c[f]("y")))
return;
var d = b.attrs, e = b.node, h = e.firstChild ? T(g.defaultView
.getComputedStyle(e.firstChild, p).getPropertyValue(
"font-size"), 10) : 10;
if (c[f]("text")) {
d.text = c.text;
while (e.firstChild)
e.removeChild(e.firstChild);
var i = r(c.text)[s]("\n");
for (var j = 0, k = i[w]; j < k; j++)
if (i[j]) {
var m = bG("tspan");
j && bG(m, {
dy : h * bL,
x : d.x
});
m[l](g.createTextNode(i[j]));
e[l](m)
}
} else {
i = e.getElementsByTagName("tspan");
for (j = 0, k = i[w]; j < k; j++)
j && bG(i[j], {
dy : h * bL,
x : d.x
})
}
bG(e, {
y : d.y
});
var n = b.getBBox(), o = d.y - (n.y + n.height / 2);
o && a.is(o, "finite") && bG(e, {
y : d.y + o
})
}, bN = function(b, c) {
var d = 0, e = 0;
this[0] = b;
this.id = a._oid++;
this.node = b;
b.raphael = this;
this.paper = c;
this.attrs = this.attrs || {};
this.transformations = [];
this._ = {
tx : 0,
ty : 0,
rt : {
deg : 0,
cx : 0,
cy : 0
},
sx : 1,
sy : 1
};
!c.bottom && (c.bottom = this);
this.prev = c.top;
c.top && (c.top.next = this);
c.top = this;
this.next = null
}, bO = bN[e];
bN[e].rotate = function(c, d, e) {
if (this.removed)
return this;
if (c == null) {
if (this._.rt.cx)
return [ this._.rt.deg, this._.rt.cx, this._.rt.cy ][v](q);
return this._.rt.deg
}
var f = this.getBBox();
c = r(c)[s](b);
if (c[w] - 1) {
d = S(c[1]);
e = S(c[2])
}
c = S(c[0]);
d != null && d !== false ? this._.rt.deg = c : this._.rt.deg += c;
e == null && (d = null);
this._.rt.cx = d;
this._.rt.cy = e;
d = d == null ? f.x + f.width / 2 : d;
e = e == null ? f.y + f.height / 2 : e;
if (this._.rt.deg) {
this.transformations[0] = a.format("rotate({0} {1} {2})",
this._.rt.deg, d, e);
this.clip
&& bG(this.clip, {
transform : a.format("rotate({0} {1} {2})",
-this._.rt.deg, d, e)
})
} else {
this.transformations[0] = p;
this.clip && bG(this.clip, {
transform : p
})
}
bG(this.node, {
transform : this.transformations[v](q)
});
return this
};
bN[e].hide = function() {
!this.removed && (this.node.style.display = "none");
return this
};
bN[e].show = function() {
!this.removed && (this.node.style.display = "");
return this
};
bN[e].remove = function() {
if (this.removed)
return;
bA(this, this.paper);
this.node.parentNode.removeChild(this.node);
for ( var a in this)
delete this[a];
this.removed = true
};
bN[e].getBBox = function() {
if (this.removed)
return this;
if (this.type == "path")
return bn(this.attrs.path);
if (this.node.style.display == "none") {
this.show();
var a = true
}
var b = {};
try {
b = this.node.getBBox()
} catch (a) {
} finally {
b = b || {}
}
if (this.type == "text") {
b = {
x : b.x,
y : Infinity,
width : 0,
height : 0
};
for (var c = 0, d = this.node.getNumberOfChars(); c < d; c++) {
var e = this.node.getExtentOfChar(c);
e.y < b.y && (b.y = e.y);
e.y + e.height - b.y > b.height
&& (b.height = e.y + e.height - b.y);
e.x + e.width - b.x > b.width
&& (b.width = e.x + e.width - b.x)
}
}
a && this.hide();
return b
};
bN[e].attr = function(b, c) {
if (this.removed)
return this;
if (b == null) {
var d = {};
for ( var e in this.attrs)
this.attrs[f](e) && (d[e] = this.attrs[e]);
this._.rt.deg && (d.rotation = this.rotate());
(this._.sx != 1 || this._.sy != 1) && (d.scale = this.scale());
d.gradient && d.fill == "none" && (d.fill = d.gradient)
&& delete d.gradient;
return d
}
if (c == null && a.is(b, F)) {
if (b == "translation")
return cz.call(this);
if (b == "rotation")
return this.rotate();
if (b == "scale")
return this.scale();
if (b == I && this.attrs.fill == "none" && this.attrs.gradient)
return this.attrs.gradient;
return this.attrs[b]
}
if (c == null && a.is(b, G)) {
var g = {};
for (var h = 0, i = b.length; h < i; h++)
g[b[h]] = this.attr(b[h]);
return g
}
if (c != null) {
var j = {};
j[b] = c
} else
b != null && a.is(b, "object") && (j = b);
for ( var k in this.paper.customAttributes)
if (this.paper.customAttributes[f](k) && j[f](k)
&& a.is(this.paper.customAttributes[k], "function")) {
var l = this.paper.customAttributes[k].apply(this, [][n]
(j[k]));
this.attrs[k] = j[k];
for ( var m in l)
l[f](m) && (j[m] = l[m])
}
bK(this, j);
return this
};
bN[e].toFront = function() {
if (this.removed)
return this;
this.node.parentNode[l](this.node);
var a = this.paper;
a.top != this && bB(this, a);
return this
};
bN[e].toBack = function() {
if (this.removed)
return this;
if (this.node.parentNode.firstChild != this.node) {
this.node.parentNode.insertBefore(this.node,
this.node.parentNode.firstChild);
bC(this, this.paper);
var a = this.paper
}
return this
};
bN[e].insertAfter = function(a) {
if (this.removed)
return this;
var b = a.node || a[a.length - 1].node;
b.nextSibling ? b.parentNode.insertBefore(this.node, b.nextSibling)
: b.parentNode[l](this.node);
bD(this, a, this.paper);
return this
};
bN[e].insertBefore = function(a) {
if (this.removed)
return this;
var b = a.node || a[0].node;
b.parentNode.insertBefore(this.node, b);
bE(this, a, this.paper);
return this
};
bN[e].blur = function(a) {
var b = this;
if (+a !== 0) {
var c = bG("filter"), d = bG("feGaussianBlur");
b.attrs.blur = a;
c.id = bh();
bG(d, {
stdDeviation : +a || 1.5
});
c.appendChild(d);
b.paper.defs.appendChild(c);
b._blur = c;
bG(b.node, {
filter : "url(#" + c.id + ")"
})
} else {
if (b._blur) {
b._blur.parentNode.removeChild(b._blur);
delete b._blur;
delete b.attrs.blur
}
b.node.removeAttribute("filter")
}
};
var bP = function(a, b, c, d) {
var e = bG("circle");
a.canvas && a.canvas[l](e);
var f = new bN(e, a);
f.attrs = {
cx : b,
cy : c,
r : d,
fill : "none",
stroke : "#000"
};
f.type = "circle";
bG(e, f.attrs);
return f
}, bQ = function(a, b, c, d, e, f) {
var g = bG("rect");
a.canvas && a.canvas[l](g);
var h = new bN(g, a);
h.attrs = {
x : b,
y : c,
width : d,
height : e,
r : f || 0,
rx : f || 0,
ry : f || 0,
fill : "none",
stroke : "#000"
};
h.type = "rect";
bG(g, h.attrs);
return h
}, bR = function(a, b, c, d, e) {
var f = bG("ellipse");
a.canvas && a.canvas[l](f);
var g = new bN(f, a);
g.attrs = {
cx : b,
cy : c,
rx : d,
ry : e,
fill : "none",
stroke : "#000"
};
g.type = "ellipse";
bG(f, g.attrs);
return g
}, bS = function(a, b, c, d, e, f) {
var g = bG("image");
bG(g, {
x : c,
y : d,
width : e,
height : f,
preserveAspectRatio : "none"
});
g.setAttributeNS(a.xlink, "href", b);
a.canvas && a.canvas[l](g);
var h = new bN(g, a);
h.attrs = {
x : c,
y : d,
width : e,
height : f,
src : b
};
h.type = "image";
return h
}, bT = function(a, b, c, d) {
var e = bG("text");
bG(e, {
x : b,
y : c,
"text-anchor" : "middle"
});
a.canvas && a.canvas[l](e);
var f = new bN(e, a);
f.attrs = {
x : b,
y : c,
"text-anchor" : "middle",
text : d,
font : W.font,
stroke : "none",
fill : "#000"
};
f.type = "text";
bK(f, f.attrs);
return f
}, bU = function(a, b) {
this.width = a || this.width;
this.height = b || this.height;
this.canvas[R]("width", this.width);
this.canvas[R]("height", this.height);
return this
}, bV = function() {
var b = by[m](0, arguments), c = b && b.container, d = b.x, e = b.y, f = b.width, h = b.height;
if (!c)
throw new Error("SVG container not found.");
var i = bG("svg");
d = d || 0;
e = e || 0;
f = f || 512;
h = h || 342;
bG(i, {
xmlns : "http://www.w3.org/2000/svg",
version : 1.1,
width : f,
height : h
});
if (c == 1) {
i.style.cssText = "position:absolute;left:" + d + "px;top:" + e
+ "px";
g.body[l](i)
} else
c.firstChild ? c.insertBefore(i, c.firstChild) : c[l](i);
c = new j;
c.width = f;
c.height = h;
c.canvas = i;
bz.call(c, c, a.fn);
c.clear();
return c
};
k.clear = function() {
var a = this.canvas;
while (a.firstChild)
a.removeChild(a.firstChild);
this.bottom = this.top = null;
(this.desc = bG("desc"))[l](g
.createTextNode("Created with Raphaël"));
a[l](this.desc);
a[l](this.defs = bG("defs"))
};
k.remove = function() {
this.canvas.parentNode
&& this.canvas.parentNode.removeChild(this.canvas);
for ( var a in this)
this[a] = bF(a)
}
}
if (a.vml) {
var bW = {
M : "m",
L : "l",
C : "c",
Z : "x",
m : "t",
l : "r",
c : "v",
z : "x"
}, bX = /([clmz]),?([^clmz]*)/gi, bY = / progid:\S+Blur\([^\)]+\)/g, bZ = /-?[^,\s-]+/g, b$ = 1000 + q + 1000, b_ = 10, ca = {
path : 1,
rect : 1
}, cb = function(a) {
var b = /[ahqstv]/ig, c = bq;
r(a).match(b) && (c = bw);
b = /[clmz]/g;
if (c == bq && !r(a).match(b)) {
var d = r(a)[Y](bX, function(a, b, c) {
var d = [], e = x.call(b) == "m", f = bW[b];
c[Y](bZ, function(a) {
if (e && d[w] == 2) {
f += d + bW[b == "m" ? "l" : "L"];
d = []
}
d[L](Q(a * b_))
});
return f + d
});
return d
}
var e = c(a), f, g;
d = [];
for (var h = 0, i = e[w]; h < i; h++) {
f = e[h];
g = x.call(e[h][0]);
g == "z" && (g = "x");
for (var j = 1, k = f[w]; j < k; j++)
g += Q(f[j] * b_) + (j != k - 1 ? "," : p);
d[L](g)
}
return d[v](q)
};
a[H] = function() {
return "Your browser doesnt support SVG. Falling down to VML.\nYou are running Raphaël "
+ this.version
};
bH = function(a, b) {
var c = cd("group");
c.style.cssText = "position:absolute;left:0;top:0;width:" + b.width
+ "px;height:" + b.height + "px";
c.coordsize = b.coordsize;
c.coordorigin = b.coordorigin;
var d = cd("shape"), e = d.style;
e.width = b.width + "px";
e.height = b.height + "px";
d.coordsize = b$;
d.coordorigin = b.coordorigin;
c[l](d);
var f = new bN(d, c, b), g = {
fill : "none",
stroke : "#000"
};
a && (g.path = a);
f.type = "path";
f.path = [];
f.Path = p;
bK(f, g);
b.canvas[l](c);
return f
};
bK = function(c, d) {
c.attrs = c.attrs || {};
var e = c.node, h = c.attrs, i = e.style, j, k = (d.x != h.x
|| d.y != h.y || d.width != h.width || d.height != h.height || d.r != h.r)
&& c.type == "rect", m = c;
for ( var n in d)
d[f](n) && (h[n] = d[n]);
if (k) {
h.path = cc(h.x, h.y, h.width, h.height, h.r);
c.X = h.x;
c.Y = h.y;
c.W = h.width;
c.H = h.height
}
d.href && (e.href = d.href);
d.title && (e.title = d.title);
d.target && (e.target = d.target);
d.cursor && (i.cursor = d.cursor);
"blur" in d && c.blur(d.blur);
if (d.path && c.type == "path" || k)
e.path = cb(h.path);
d.rotation != null && c.rotate(d.rotation, true);
if (d.translation) {
j = r(d.translation)[s](b);
cz.call(c, j[0], j[1]);
if (c._.rt.cx != null) {
c._.rt.cx += +j[0];
c._.rt.cy += +j[1];
c.setBox(c.attrs, j[0], j[1])
}
}
if (d.scale) {
j = r(d.scale)[s](b);
c.scale(+j[0] || 1, +j[1] || +j[0] || 1, +j[2] || null, +j[3]
|| null)
}
if ("clip-rect" in d) {
var o = r(d["clip-rect"])[s](b);
if (o[w] == 4) {
o[2] = +o[2] + +o[0];
o[3] = +o[3] + +o[1];
var q = e.clipRect || g.createElement("div"), t = q.style, u = e.parentNode;
t.clip = a.format("rect({1}px {2}px {3}px {0}px)", o);
if (!e.clipRect) {
t.position = "absolute";
t.top = 0;
t.left = 0;
t.width = c.paper.width + "px";
t.height = c.paper.height + "px";
u.parentNode.insertBefore(q, u);
q[l](u);
e.clipRect = q
}
}
d["clip-rect"] || e.clipRect && (e.clipRect.style.clip = p)
}
c.type == "image" && d.src && (e.src = d.src);
if (c.type == "image" && d.opacity) {
e.filterOpacity = U + ".Alpha(opacity=" + d.opacity * 100 + ")";
i.filter = (e.filterMatrix || p) + (e.filterOpacity || p)
}
d.font && (i.font = d.font);
d["font-family"]
&& (i.fontFamily = "\""
+ d["font-family"][s](",")[0][Y](/^['"]+|['"]+$/g,
p) + "\"");
d["font-size"] && (i.fontSize = d["font-size"]);
d["font-weight"] && (i.fontWeight = d["font-weight"]);
d["font-style"] && (i.fontStyle = d["font-style"]);
if (d.opacity != null || d["stroke-width"] != null
|| d.fill != null || d.stroke != null
|| d["stroke-width"] != null || d["stroke-opacity"] != null
|| d["fill-opacity"] != null
|| d["stroke-dasharray"] != null
|| d["stroke-miterlimit"] != null
|| d["stroke-linejoin"] != null
|| d["stroke-linecap"] != null) {
e = c.shape || e;
var v = e.getElementsByTagName(I)
&& e.getElementsByTagName(I)[0], x = false;
!v && (x = v = cd(I));
if ("fill-opacity" in d || "opacity" in d) {
var y = ((+h["fill-opacity"] + 1 || 2) - 1)
* ((+h.opacity + 1 || 2) - 1)
* ((+a.getRGB(d.fill).o + 1 || 2) - 1);
y = A(z(y, 0), 1);
v.opacity = y
}
d.fill && (v.on = true);
if (v.on == null || d.fill == "none")
v.on = false;
if (v.on && d.fill) {
var B = d.fill.match(M);
if (B) {
v.src = B[1];
v.type = "tile"
} else {
v.color = a.getRGB(d.fill).hex;
v.src = p;
v.type = "solid";
if (a.getRGB(d.fill).error && (m.type in {
circle : 1,
ellipse : 1
} || r(d.fill).charAt() != "r") && bI(m, d.fill)) {
h.fill = "none";
h.gradient = d.fill
}
}
}
x && e[l](v);
var C = e.getElementsByTagName("stroke")
&& e.getElementsByTagName("stroke")[0], D = false;
!C && (D = C = cd("stroke"));
if (d.stroke && d.stroke != "none" || d["stroke-width"]
|| d["stroke-opacity"] != null || d["stroke-dasharray"]
|| d["stroke-miterlimit"] || d["stroke-linejoin"]
|| d["stroke-linecap"])
C.on = true;
(d.stroke == "none" || C.on == null || d.stroke == 0 || d["stroke-width"] == 0)
&& (C.on = false);
var E = a.getRGB(d.stroke);
C.on && d.stroke && (C.color = E.hex);
y = ((+h["stroke-opacity"] + 1 || 2) - 1)
* ((+h.opacity + 1 || 2) - 1) * ((+E.o + 1 || 2) - 1);
var F = (S(d["stroke-width"]) || 1) * 0.75;
y = A(z(y, 0), 1);
d["stroke-width"] == null && (F = h["stroke-width"]);
d["stroke-width"] && (C.weight = F);
F && F < 1 && (y *= F) && (C.weight = 1);
C.opacity = y;
d["stroke-linejoin"]
&& (C.joinstyle = d["stroke-linejoin"] || "miter");
C.miterlimit = d["stroke-miterlimit"] || 8;
d["stroke-linecap"]
&& (C.endcap = d["stroke-linecap"] == "butt" ? "flat"
: d["stroke-linecap"] == "square" ? "square"
: "round");
if (d["stroke-dasharray"]) {
var G = {
"-" : "shortdash",
"." : "shortdot",
"-." : "shortdashdot",
"-.." : "shortdashdotdot",
". " : "dot",
"- " : "dash",
"--" : "longdash",
"- ." : "dashdot",
"--." : "longdashdot",
"--.." : "longdashdotdot"
};
C.dashstyle = G[f](d["stroke-dasharray"]) ? G[d["stroke-dasharray"]]
: p
}
D && e[l](C)
}
if (m.type == "text") {
i = m.paper.span.style;
h.font && (i.font = h.font);
h["font-family"] && (i.fontFamily = h["font-family"]);
h["font-size"] && (i.fontSize = h["font-size"]);
h["font-weight"] && (i.fontWeight = h["font-weight"]);
h["font-style"] && (i.fontStyle = h["font-style"]);
m.node.string
&& (m.paper.span.innerHTML = r(m.node.string)[Y](/</g,
"&#60;")[Y](/&/g, "&#38;")[Y](/\n/g, "<br>"));
m.W = h.w = m.paper.span.offsetWidth;
m.H = h.h = m.paper.span.offsetHeight;
m.X = h.x;
m.Y = h.y + Q(m.H / 2);
switch (h["text-anchor"]) {
case "start":
m.node.style["v-text-align"] = "left";
m.bbx = Q(m.W / 2);
break;
case "end":
m.node.style["v-text-align"] = "right";
m.bbx = -Q(m.W / 2);
break;
default:
m.node.style["v-text-align"] = "center";
break
}
}
};
bI = function(a, b) {
a.attrs = a.attrs || {};
var c = a.attrs, d, e = "linear", f = ".5 .5";
a.attrs.gradient = b;
b = r(b)[Y](bd, function(a, b, c) {
e = "radial";
if (b && c) {
b = S(b);
c = S(c);
C(b - 0.5, 2) + C(c - 0.5, 2) > 0.25
&& (c = y.sqrt(0.25 - C(b - 0.5, 2))
* ((c > 0.5) * 2 - 1) + 0.5);
f = b + q + c
}
return p
});
b = b[s](/\s*\-\s*/);
if (e == "linear") {
var g = b.shift();
g = -S(g);
if (isNaN(g))
return null
}
var h = bx(b);
if (!h)
return null;
a = a.shape || a.node;
d = a.getElementsByTagName(I)[0] || cd(I);
!d.parentNode && a.appendChild(d);
if (h[w]) {
d.on = true;
d.method = "none";
d.color = h[0].color;
d.color2 = h[h[w] - 1].color;
var i = [];
for (var j = 0, k = h[w]; j < k; j++)
h[j].offset && i[L](h[j].offset + q + h[j].color);
d.colors && (d.colors.value = i[w] ? i[v]() : "0% " + d.color);
if (e == "radial") {
d.type = "gradientradial";
d.focus = "100%";
d.focussize = f;
d.focusposition = f
} else {
d.type = "gradient";
d.angle = (270 - g) % 360
}
}
return 1
};
bN = function(b, c, d) {
var e = 0, f = 0, g = 0, h = 1;
this[0] = b;
this.id = a._oid++;
this.node = b;
b.raphael = this;
this.X = 0;
this.Y = 0;
this.attrs = {};
this.Group = c;
this.paper = d;
this._ = {
tx : 0,
ty : 0,
rt : {
deg : 0
},
sx : 1,
sy : 1
};
!d.bottom && (d.bottom = this);
this.prev = d.top;
d.top && (d.top.next = this);
d.top = this;
this.next = null
};
bO = bN[e];
bO.rotate = function(a, c, d) {
if (this.removed)
return this;
if (a == null) {
if (this._.rt.cx)
return [ this._.rt.deg, this._.rt.cx, this._.rt.cy ][v](q);
return this._.rt.deg
}
a = r(a)[s](b);
if (a[w] - 1) {
c = S(a[1]);
d = S(a[2])
}
a = S(a[0]);
c != null ? this._.rt.deg = a : this._.rt.deg += a;
d == null && (c = null);
this._.rt.cx = c;
this._.rt.cy = d;
this.setBox(this.attrs, c, d);
this.Group.style.rotation = this._.rt.deg;
return this
};
bO.setBox = function(a, b, c) {
if (this.removed)
return this;
var d = this.Group.style, e = this.shape && this.shape.style
|| this.node.style;
a = a || {};
for ( var g in a)
a[f](g) && (this.attrs[g] = a[g]);
b = b || this._.rt.cx;
c = c || this._.rt.cy;
var h = this.attrs, i, j, k, l;
switch (this.type) {
case "circle":
i = h.cx - h.r;
j = h.cy - h.r;
k = l = h.r * 2;
break;
case "ellipse":
i = h.cx - h.rx;
j = h.cy - h.ry;
k = h.rx * 2;
l = h.ry * 2;
break;
case "image":
i = +h.x;
j = +h.y;
k = h.width || 0;
l = h.height || 0;
break;
case "text":
this.textpath.v = [ "m", Q(h.x), ", ", Q(h.y - 2), "l",
Q(h.x) + 1, ", ", Q(h.y - 2) ][v](p);
i = h.x - Q(this.W / 2);
j = h.y - this.H / 2;
k = this.W;
l = this.H;
break;
case "rect":
case "path":
if (this.attrs.path) {
var m = bn(this.attrs.path);
i = m.x;
j = m.y;
k = m.width;
l = m.height
} else {
i = 0;
j = 0;
k = this.paper.width;
l = this.paper.height
}
break;
default:
i = 0;
j = 0;
k = this.paper.width;
l = this.paper.height;
break
}
b = b == null ? i + k / 2 : b;
c = c == null ? j + l / 2 : c;
var n = b - this.paper.width / 2, o = c - this.paper.height / 2, q;
d.left != (q = n + "px") && (d.left = q);
d.top != (q = o + "px") && (d.top = q);
this.X = ca[f](this.type) ? -n : i;
this.Y = ca[f](this.type) ? -o : j;
this.W = k;
this.H = l;
if (ca[f](this.type)) {
e.left != (q = -n * b_ + "px") && (e.left = q);
e.top != (q = -o * b_ + "px") && (e.top = q)
} else if (this.type == "text") {
e.left != (q = -n + "px") && (e.left = q);
e.top != (q = -o + "px") && (e.top = q)
} else {
d.width != (q = this.paper.width + "px") && (d.width = q);
d.height != (q = this.paper.height + "px") && (d.height = q);
e.left != (q = i - n + "px") && (e.left = q);
e.top != (q = j - o + "px") && (e.top = q);
e.width != (q = k + "px") && (e.width = q);
e.height != (q = l + "px") && (e.height = q)
}
};
bO.hide = function() {
!this.removed && (this.Group.style.display = "none");
return this
};
bO.show = function() {
!this.removed && (this.Group.style.display = "block");
return this
};
bO.getBBox = function() {
if (this.removed)
return this;
if (ca[f](this.type))
return bn(this.attrs.path);
return {
x : this.X + (this.bbx || 0),
y : this.Y,
width : this.W,
height : this.H
}
};
bO.remove = function() {
if (this.removed)
return;
bA(this, this.paper);
this.node.parentNode.removeChild(this.node);
this.Group.parentNode.removeChild(this.Group);
this.shape && this.shape.parentNode.removeChild(this.shape);
for ( var a in this)
delete this[a];
this.removed = true
};
bO.attr = function(b, c) {
if (this.removed)
return this;
if (b == null) {
var d = {};
for ( var e in this.attrs)
this.attrs[f](e) && (d[e] = this.attrs[e]);
this._.rt.deg && (d.rotation = this.rotate());
(this._.sx != 1 || this._.sy != 1) && (d.scale = this.scale());
d.gradient && d.fill == "none" && (d.fill = d.gradient)
&& delete d.gradient;
return d
}
if (c == null && a.is(b, "string")) {
if (b == "translation")
return cz.call(this);
if (b == "rotation")
return this.rotate();
if (b == "scale")
return this.scale();
if (b == I && this.attrs.fill == "none" && this.attrs.gradient)
return this.attrs.gradient;
return this.attrs[b]
}
if (this.attrs && c == null && a.is(b, G)) {
var g, h = {};
for (e = 0, g = b[w]; e < g; e++)
h[b[e]] = this.attr(b[e]);
return h
}
var i;
if (c != null) {
i = {};
i[b] = c
}
c == null && a.is(b, "object") && (i = b);
if (i) {
for ( var j in this.paper.customAttributes)
if (this.paper.customAttributes[f](j) && i[f](j)
&& a.is(this.paper.customAttributes[j], "function")) {
var k = this.paper.customAttributes[j].apply(this,
[][n](i[j]));
this.attrs[j] = i[j];
for ( var l in k)
k[f](l) && (i[l] = k[l])
}
i.text && this.type == "text" && (this.node.string = i.text);
bK(this, i);
i.gradient && (({
circle : 1,
ellipse : 1
})[f](this.type) || r(i.gradient).charAt() != "r")
&& bI(this, i.gradient);
(!ca[f](this.type) || this._.rt.deg) && this.setBox(this.attrs)
}
return this
};
bO.toFront = function() {
!this.removed && this.Group.parentNode[l](this.Group);
this.paper.top != this && bB(this, this.paper);
return this
};
bO.toBack = function() {
if (this.removed)
return this;
if (this.Group.parentNode.firstChild != this.Group) {
this.Group.parentNode.insertBefore(this.Group,
this.Group.parentNode.firstChild);
bC(this, this.paper)
}
return this
};
bO.insertAfter = function(a) {
if (this.removed)
return this;
a.constructor == cC && (a = a[a.length - 1]);
a.Group.nextSibling ? a.Group.parentNode.insertBefore(this.Group,
a.Group.nextSibling) : a.Group.parentNode[l](this.Group);
bD(this, a, this.paper);
return this
};
bO.insertBefore = function(a) {
if (this.removed)
return this;
a.constructor == cC && (a = a[0]);
a.Group.parentNode.insertBefore(this.Group, a.Group);
bE(this, a, this.paper);
return this
};
bO.blur = function(b) {
var c = this.node.runtimeStyle, d = c.filter;
d = d.replace(bY, p);
if (+b !== 0) {
this.attrs.blur = b;
c.filter = d + q + U + ".Blur(pixelradius=" + (+b || 1.5) + ")";
c.margin = a.format("-{0}px 0 0 -{0}px", Q(+b || 1.5))
} else {
c.filter = d;
c.margin = 0;
delete this.attrs.blur
}
};
bP = function(a, b, c, d) {
var e = cd("group"), f = cd("oval"), g = f.style;
e.style.cssText = "position:absolute;left:0;top:0;width:" + a.width
+ "px;height:" + a.height + "px";
e.coordsize = b$;
e.coordorigin = a.coordorigin;
e[l](f);
var h = new bN(f, e, a);
h.type = "circle";
bK(h, {
stroke : "#000",
fill : "none"
});
h.attrs.cx = b;
h.attrs.cy = c;
h.attrs.r = d;
h.setBox({
x : b - d,
y : c - d,
width : d * 2,
height : d * 2
});
a.canvas[l](e);
return h
};
function cc(b, c, d, e, f) {
return f ? a
.format(
"M{0},{1}l{2},0a{3},{3},0,0,1,{3},{3}l0,{5}a{3},{3},0,0,1,{4},{3}l{6},0a{3},{3},0,0,1,{4},{4}l0,{7}a{3},{3},0,0,1,{3},{4}z",
b + f, c, d - f * 2, f, -f, e - f * 2, f * 2 - d, f
* 2 - e)
: a.format("M{0},{1}l{2},0,0,{3},{4},0z", b, c, d, e, -d)
}
bQ = function(a, b, c, d, e, f) {
var g = cc(b, c, d, e, f), h = a.path(g), i = h.attrs;
h.X = i.x = b;
h.Y = i.y = c;
h.W = i.width = d;
h.H = i.height = e;
i.r = f;
i.path = g;
h.type = "rect";
return h
};
bR = function(a, b, c, d, e) {
var f = cd("group"), g = cd("oval"), h = g.style;
f.style.cssText = "position:absolute;left:0;top:0;width:" + a.width
+ "px;height:" + a.height + "px";
f.coordsize = b$;
f.coordorigin = a.coordorigin;
f[l](g);
var i = new bN(g, f, a);
i.type = "ellipse";
bK(i, {
stroke : "#000"
});
i.attrs.cx = b;
i.attrs.cy = c;
i.attrs.rx = d;
i.attrs.ry = e;
i.setBox({
x : b - d,
y : c - e,
width : d * 2,
height : e * 2
});
a.canvas[l](f);
return i
};
bS = function(a, b, c, d, e, f) {
var g = cd("group"), h = cd("image");
g.style.cssText = "position:absolute;left:0;top:0;width:" + a.width
+ "px;height:" + a.height + "px";
g.coordsize = b$;
g.coordorigin = a.coordorigin;
h.src = b;
g[l](h);
var i = new bN(h, g, a);
i.type = "image";
i.attrs.src = b;
i.attrs.x = c;
i.attrs.y = d;
i.attrs.w = e;
i.attrs.h = f;
i.setBox({
x : c,
y : d,
width : e,
height : f
});
a.canvas[l](g);
return i
};
bT = function(b, c, d, e) {
var f = cd("group"), g = cd("shape"), h = g.style, i = cd("path"), j = i.style, k = cd("textpath");
f.style.cssText = "position:absolute;left:0;top:0;width:" + b.width
+ "px;height:" + b.height + "px";
f.coordsize = b$;
f.coordorigin = b.coordorigin;
i.v = a.format("m{0},{1}l{2},{1}", Q(c * 10), Q(d * 10),
Q(c * 10) + 1);
i.textpathok = true;
h.width = b.width;
h.height = b.height;
k.string = r(e);
k.on = true;
g[l](k);
g[l](i);
f[l](g);
var m = new bN(k, f, b);
m.shape = g;
m.textpath = i;
m.type = "text";
m.attrs.text = e;
m.attrs.x = c;
m.attrs.y = d;
m.attrs.w = 1;
m.attrs.h = 1;
bK(m, {
font : W.font,
stroke : "none",
fill : "#000"
});
m.setBox();
b.canvas[l](f);
return m
};
bU = function(a, b) {
var c = this.canvas.style;
a == +a && (a += "px");
b == +b && (b += "px");
c.width = a;
c.height = b;
c.clip = "rect(0 " + a + " " + b + " 0)";
return this
};
var cd;
g.createStyleSheet().addRule(".rvml", "behavior:url(#default#VML)");
try {
!g.namespaces.rvml
&& g.namespaces
.add("rvml", "urn:schemas-microsoft-com:vml");
cd = function(a) {
return g.createElement("<rvml:" + a + " class=\"rvml\">")
}
} catch (a) {
cd = function(a) {
return g
.createElement("<"
+ a
+ " xmlns=\"urn:schemas-microsoft.com:vml\" class=\"rvml\">")
}
}
bV = function() {
var b = by[m](0, arguments), c = b.container, d = b.height, e, f = b.width, h = b.x, i = b.y;
if (!c)
throw new Error("VML container not found.");
var k = new j, n = k.canvas = g.createElement("div"), o = n.style;
h = h || 0;
i = i || 0;
f = f || 512;
d = d || 342;
f == +f && (f += "px");
d == +d && (d += "px");
k.width = 1000;
k.height = 1000;
k.coordsize = b_ * 1000 + q + b_ * 1000;
k.coordorigin = "0 0";
k.span = g.createElement("span");
k.span.style.cssText = "position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;";
n[l](k.span);
o.cssText = a
.format(
"top:0;left:0;width:{0};height:{1};display:inline-block;position:relative;clip:rect(0 {0} {1} 0);overflow:hidden",
f, d);
if (c == 1) {
g.body[l](n);
o.left = h + "px";
o.top = i + "px";
o.position = "absolute"
} else
c.firstChild ? c.insertBefore(n, c.firstChild) : c[l](n);
bz.call(k, k, a.fn);
return k
};
k.clear = function() {
this.canvas.innerHTML = p;
this.span = g.createElement("span");
this.span.style.cssText = "position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;";
this.canvas[l](this.span);
this.bottom = this.top = null
};
k.remove = function() {
this.canvas.parentNode.removeChild(this.canvas);
for ( var a in this)
this[a] = bF(a);
return true
}
}
var ce = navigator.userAgent.match(/Version\\x2f(.*?)\s/);
navigator.vendor == "Apple Computer, Inc."
&& (ce && ce[1] < 4 || navigator.platform.slice(0, 2) == "iP") ? k.safari = function() {
var a = this.rect(-99, -99, this.width + 99, this.height + 99).attr({
stroke : "none"
});
h.setTimeout(function() {
a.remove()
})
}
: k.safari = function() {
};
var cf = function() {
this.returnValue = false
}, cg = function() {
return this.originalEvent.preventDefault()
}, ch = function() {
this.cancelBubble = true
}, ci = function() {
return this.originalEvent.stopPropagation()
}, cj = (function() {
{
if (g.addEventListener)
return function(a, b, c, d) {
var e = o && u[b] ? u[b] : b, g = function(e) {
if (o && u[f](b))
for (var g = 0, h = e.targetTouches
&& e.targetTouches.length; g < h; g++) {
if (e.targetTouches[g].target == a) {
var i = e;
e = e.targetTouches[g];
e.originalEvent = i;
e.preventDefault = cg;
e.stopPropagation = ci;
break
}
}
return c.call(d, e)
};
a.addEventListener(e, g, false);
return function() {
a.removeEventListener(e, g, false);
return true
}
};
if (g.attachEvent)
return function(a, b, c, d) {
var e = function(a) {
a = a || h.event;
a.preventDefault = a.preventDefault || cf;
a.stopPropagation = a.stopPropagation || ch;
return c.call(d, a)
};
a.attachEvent("on" + b, e);
var f = function() {
a.detachEvent("on" + b, e);
return true
};
return f
}
}
})(), ck = [], cl = function(a) {
var b = a.clientX, c = a.clientY, d = g.documentElement.scrollTop
|| g.body.scrollTop, e = g.documentElement.scrollLeft
|| g.body.scrollLeft, f, h = ck.length;
while (h--) {
f = ck[h];
if (o) {
var i = a.touches.length, j;
while (i--) {
j = a.touches[i];
if (j.identifier == f.el._drag.id) {
b = j.clientX;
c = j.clientY;
(a.originalEvent ? a.originalEvent : a)
.preventDefault();
break
}
}
} else
a.preventDefault();
b += e;
c += d;
f.move
&& f.move.call(f.move_scope || f.el, b - f.el._drag.x, c
- f.el._drag.y, b, c, a)
}
}, cm = function(b) {
a.unmousemove(cl).unmouseup(cm);
var c = ck.length, d;
while (c--) {
d = ck[c];
d.el._drag = {};
d.end
&& d.end.call(d.end_scope || d.start_scope || d.move_scope
|| d.el, b)
}
ck = []
};
for (var cn = t[w]; cn--;)
(function(b) {
a[b] = bN[e][b] = function(c, d) {
if (a.is(c, "function")) {
this.events = this.events || [];
this.events.push({
name : b,
f : c,
unbind : cj(this.shape || this.node || g, b, c, d
|| this)
})
}
return this
};
a["un" + b] = bN[e]["un" + b] = function(a) {
var c = this.events, d = c[w];
while (d--)
if (c[d].name == b && c[d].f == a) {
c[d].unbind();
c.splice(d, 1);
!c.length && delete this.events;
return this
}
return this
}
})(t[cn]);
bO.hover = function(a, b, c, d) {
return this.mouseover(a, c).mouseout(b, d || c)
};
bO.unhover = function(a, b) {
return this.unmouseover(a).unmouseout(b)
};
bO.drag = function(b, c, d, e, f, h) {
this._drag = {};
this
.mousedown(function(i) {
(i.originalEvent || i).preventDefault();
var j = g.documentElement.scrollTop || g.body.scrollTop, k = g.documentElement.scrollLeft
|| g.body.scrollLeft;
this._drag.x = i.clientX + k;
this._drag.y = i.clientY + j;
this._drag.id = i.identifier;
c
&& c.call(f || e || this, i.clientX + k, i.clientY
+ j, i);
!ck.length && a.mousemove(cl).mouseup(cm);
ck.push({
el : this,
move : b,
end : d,
move_scope : e,
start_scope : f,
end_scope : h
})
});
return this
};
bO.undrag = function(b, c, d) {
var e = ck.length;
while (e--)
ck[e].el == this && (ck[e].move == b && ck[e].end == d)
&& ck.splice(e++, 1);
!ck.length && a.unmousemove(cl).unmouseup(cm)
};
k.circle = function(a, b, c) {
return bP(this, a || 0, b || 0, c || 0)
};
k.rect = function(a, b, c, d, e) {
return bQ(this, a || 0, b || 0, c || 0, d || 0, e || 0)
};
k.ellipse = function(a, b, c, d) {
return bR(this, a || 0, b || 0, c || 0, d || 0)
};
k.path = function(b) {
b && !a.is(b, F) && !a.is(b[0], G) && (b += p);
return bH(a.format[m](a, arguments), this)
};
k.image = function(a, b, c, d, e) {
return bS(this, a || "about:blank", b || 0, c || 0, d || 0, e || 0)
};
k.text = function(a, b, c) {
return bT(this, a || 0, b || 0, r(c))
};
k.set = function(a) {
arguments[w] > 1
&& (a = Array[e].splice.call(arguments, 0, arguments[w]));
return new cC(a)
};
k.setSize = bU;
k.top = k.bottom = null;
k.raphael = a;
function co() {
return this.x + q + this.y
}
bO.resetScale = function() {
if (this.removed)
return this;
this._.sx = 1;
this._.sy = 1;
this.attrs.scale = "1 1"
};
bO.scale = function(a, b, c, d) {
if (this.removed)
return this;
if (a == null && b == null)
return {
x : this._.sx,
y : this._.sy,
toString : co
};
b = b || a;
!(+b) && (b = a);
var e, f, g, h, i = this.attrs;
if (a != 0) {
var j = this.getBBox(), k = j.x + j.width / 2, l = j.y + j.height
/ 2, m = B(a / this._.sx), o = B(b / this._.sy);
c = +c || c == 0 ? c : k;
d = +d || d == 0 ? d : l;
var r = this._.sx > 0, s = this._.sy > 0, t = ~(~(a / B(a))), u = ~(~(b / B(b))), x = m
* t, y = o * u, z = this.node.style, A = c + B(k - c) * x
* (k > c == r ? 1 : -1), C = d + B(l - d) * y
* (l > d == s ? 1 : -1), D = a * t > b * u ? o : m;
switch (this.type) {
case "rect":
case "image":
var E = i.width * m, F = i.height * o;
this.attr({
height : F,
r : i.r * D,
width : E,
x : A - E / 2,
y : C - F / 2
});
break;
case "circle":
case "ellipse":
this.attr({
rx : i.rx * m,
ry : i.ry * o,
r : i.r * D,
cx : A,
cy : C
});
break;
case "text":
this.attr({
x : A,
y : C
});
break;
case "path":
var G = bp(i.path), H = true, I = r ? x : m, J = s ? y : o;
for (var K = 0, L = G[w]; K < L; K++) {
var M = G[K], N = V.call(M[0]);
{
if (N == "M" && H)
continue;
H = false
}
if (N == "A") {
M[G[K][w] - 2] *= I;
M[G[K][w] - 1] *= J;
M[1] *= m;
M[2] *= o;
M[5] = +(t + u ? !(!(+M[5])) : !(+M[5]))
} else if (N == "H")
for (var O = 1, P = M[w]; O < P; O++)
M[O] *= I;
else if (N == "V")
for (O = 1, P = M[w]; O < P; O++)
M[O] *= J;
else
for (O = 1, P = M[w]; O < P; O++)
M[O] *= O % 2 ? I : J
}
var Q = bn(G);
e = A - Q.x - Q.width / 2;
f = C - Q.y - Q.height / 2;
G[0][1] += e;
G[0][2] += f;
this.attr({
path : G
});
break
}
if (this.type in {
text : 1,
image : 1
} && (t != 1 || u != 1))
if (this.transformations) {
this.transformations[2] = "scale("[n](t, ",", u, ")");
this.node[R]("transform", this.transformations[v](q));
e = t == -1 ? -i.x - (E || 0) : i.x;
f = u == -1 ? -i.y - (F || 0) : i.y;
this.attr({
x : e,
y : f
});
i.fx = t - 1;
i.fy = u - 1
} else {
this.node.filterMatrix = U
+ ".Matrix(M11="[n]
(t, ", M12=0, M21=0, M22=", u,
", Dx=0, Dy=0, sizingmethod='auto expand', filtertype='bilinear')");
z.filter = (this.node.filterMatrix || p)
+ (this.node.filterOpacity || p)
}
else if (this.transformations) {
this.transformations[2] = p;
this.node[R]("transform", this.transformations[v](q));
i.fx = 0;
i.fy = 0
} else {
this.node.filterMatrix = p;
z.filter = (this.node.filterMatrix || p)
+ (this.node.filterOpacity || p)
}
i.scale = [ a, b, c, d ][v](q);
this._.sx = a;
this._.sy = b
}
return this
};
bO.clone = function() {
if (this.removed)
return null;
var a = this.attr();
delete a.scale;
delete a.translation;
return this.paper[this.type]().attr(a)
};
var cp = {}, cq = function(b, c, d, e, f, g, h, i, j) {
var k = 0, l = 100, m = [ b, c, d, e, f, g, h, i ].join(), n = cp[m], o, p;
!n && (cp[m] = n = {
data : []
});
n.timer && clearTimeout(n.timer);
n.timer = setTimeout(function() {
delete cp[m]
}, 2000);
if (j != null) {
var q = cq(b, c, d, e, f, g, h, i);
l = ~(~q) * 10
}
for (var r = 0; r < l + 1; r++) {
if (n.data[j] > r)
p = n.data[r * l];
else {
p = a.findDotsAtSegment(b, c, d, e, f, g, h, i, r / l);
n.data[r] = p
}
r && (k += C(C(o.x - p.x, 2) + C(o.y - p.y, 2), 0.5));
if (j != null && k >= j)
return p;
o = p
}
if (j == null)
return k
}, cr = function(b, c) {
return function(d, e, f) {
d = bw(d);
var g, h, i, j, k = "", l = {}, m, n = 0;
for (var o = 0, p = d.length; o < p; o++) {
i = d[o];
if (i[0] == "M") {
g = +i[1];
h = +i[2]
} else {
j = cq(g, h, i[1], i[2], i[3], i[4], i[5], i[6]);
if (n + j > e) {
if (c && !l.start) {
m = cq(g, h, i[1], i[2], i[3], i[4], i[5], i[6], e
- n);
k += [ "C", m.start.x, m.start.y, m.m.x, m.m.y,
m.x, m.y ];
if (f)
return k;
l.start = k;
k = [ "M", m.x, m.y + "C", m.n.x, m.n.y, m.end.x,
m.end.y, i[5], i[6] ][v]();
n += j;
g = +i[5];
h = +i[6];
continue
}
if (!b && !c) {
m = cq(g, h, i[1], i[2], i[3], i[4], i[5], i[6], e
- n);
return {
x : m.x,
y : m.y,
alpha : m.alpha
}
}
}
n += j;
g = +i[5];
h = +i[6]
}
k += i
}
l.end = k;
m = b ? n : c ? l : a.findDotsAtSegment(g, h, i[1], i[2], i[3],
i[4], i[5], i[6], 1);
m.alpha && (m = {
x : m.x,
y : m.y,
alpha : m.alpha
});
return m
}
}, cs = cr(1), ct = cr(), cu = cr(0, 1);
bO.getTotalLength = function() {
if (this.type != "path")
return;
if (this.node.getTotalLength)
return this.node.getTotalLength();
return cs(this.attrs.path)
};
bO.getPointAtLength = function(a) {
if (this.type != "path")
return;
return ct(this.attrs.path, a)
};
bO.getSubpath = function(a, b) {
if (this.type != "path")
return;
if (B(this.getTotalLength() - b) < "1e-6")
return cu(this.attrs.path, a).end;
var c = cu(this.attrs.path, b, 1);
return a ? cu(c, a).end : c
};
a.easing_formulas = {
linear : function(a) {
return a
},
"<" : function(a) {
return C(a, 3)
},
">" : function(a) {
return C(a - 1, 3) + 1
},
"<>" : function(a) {
a = a * 2;
if (a < 1)
return C(a, 3) / 2;
a -= 2;
return (C(a, 3) + 2) / 2
},
backIn : function(a) {
var b = 1.70158;
return a * a * ((b + 1) * a - b)
},
backOut : function(a) {
a = a - 1;
var b = 1.70158;
return a * a * ((b + 1) * a + b) + 1
},
elastic : function(a) {
if (a == 0 || a == 1)
return a;
var b = 0.3, c = b / 4;
return C(2, -10 * a) * y.sin((a - c) * (2 * D) / b) + 1
},
bounce : function(a) {
var b = 7.5625, c = 2.75, d;
if (a < 1 / c)
d = b * a * a;
else if (a < 2 / c) {
a -= 1.5 / c;
d = b * a * a + 0.75
} else if (a < 2.5 / c) {
a -= 2.25 / c;
d = b * a * a + 0.9375
} else {
a -= 2.625 / c;
d = b * a * a + 0.984375
}
return d
}
};
var cv = [], cw = function() {
var b = +(new Date);
for (var c = 0; c < cv[w]; c++) {
var d = cv[c];
if (d.stop || d.el.removed)
continue;
var e = b - d.start, g = d.ms, h = d.easing, i = d.from, j = d.diff, k = d.to, l = d.t, m = d.el, n = {}, o;
if (e < g) {
var r = h(e / g);
for ( var s in i)
if (i[f](s)) {
switch (X[s]) {
case "along":
o = r * g * j[s];
k.back && (o = k.len - o);
var t = ct(k[s], o);
m.translate(j.sx - j.x || 0, j.sy - j.y || 0);
j.x = t.x;
j.y = t.y;
m.translate(t.x - j.sx, t.y - j.sy);
k.rot && m.rotate(j.r + t.alpha, t.x, t.y);
break;
case E:
o = +i[s] + r * g * j[s];
break;
case "colour":
o = "rgb("
+ [ cy(Q(i[s].r + r * g * j[s].r)),
cy(Q(i[s].g + r * g * j[s].g)),
cy(Q(i[s].b + r * g * j[s].b)) ][v]
(",") + ")";
break;
case "path":
o = [];
for (var u = 0, x = i[s][w]; u < x; u++) {
o[u] = [ i[s][u][0] ];
for (var y = 1, z = i[s][u][w]; y < z; y++)
o[u][y] = +i[s][u][y] + r * g * j[s][u][y];
o[u] = o[u][v](q)
}
o = o[v](q);
break;
case "csv":
switch (s) {
case "translation":
var A = r * g * j[s][0] - l.x, B = r * g
* j[s][1] - l.y;
l.x += A;
l.y += B;
o = A + q + B;
break;
case "rotation":
o = +i[s][0] + r * g * j[s][0];
i[s][1] && (o += "," + i[s][1] + "," + i[s][2]);
break;
case "scale":
o = [ +i[s][0] + r * g * j[s][0],
+i[s][1] + r * g * j[s][1],
2 in k[s] ? k[s][2] : p,
3 in k[s] ? k[s][3] : p ][v](q);
break;
case "clip-rect":
o = [];
u = 4;
while (u--)
o[u] = +i[s][u] + r * g * j[s][u];
break
}
break;
default:
var C = [].concat(i[s]);
o = [];
u = m.paper.customAttributes[s].length;
while (u--)
o[u] = +C[u] + r * g * j[s][u];
break
}
n[s] = o
}
m.attr(n);
m._run && m._run.call(m)
} else {
if (k.along) {
t = ct(k.along, k.len * !k.back);
m.translate(j.sx - (j.x || 0) + t.x - j.sx, j.sy
- (j.y || 0) + t.y - j.sy);
k.rot && m.rotate(j.r + t.alpha, t.x, t.y)
}
(l.x || l.y) && m.translate(-l.x, -l.y);
k.scale && (k.scale += p);
m.attr(k);
cv.splice(c--, 1)
}
}
a.svg && m && m.paper && m.paper.safari();
cv[w] && setTimeout(cw)
}, cx = function(b, c, d, e, f) {
var g = d - e;
c.timeouts.push(setTimeout(function() {
a.is(f, "function") && f.call(c);
c.animate(b, g, b.easing)
}, e))
}, cy = function(a) {
return z(A(a, 255), 0)
}, cz = function(a, b) {
if (a == null)
return {
x : this._.tx,
y : this._.ty,
toString : co
};
this._.tx += +a;
this._.ty += +b;
switch (this.type) {
case "circle":
case "ellipse":
this.attr({
cx : +a + this.attrs.cx,
cy : +b + this.attrs.cy
});
break;
case "rect":
case "image":
case "text":
this.attr({
x : +a + this.attrs.x,
y : +b + this.attrs.y
});
break;
case "path":
var c = bp(this.attrs.path);
c[0][1] += +a;
c[0][2] += +b;
this.attr({
path : c
});
break
}
return this
};
bO.animateWith = function(a, b, c, d, e) {
for (var f = 0, g = cv.length; f < g; f++)
cv[f].el.id == a.id && (b.start = cv[f].start);
return this.animate(b, c, d, e)
};
bO.animateAlong = cA();
bO.animateAlongBack = cA(1);
function cA(b) {
return function(c, d, e, f) {
var g = {
back : b
};
a.is(e, "function") ? f = e : g.rot = e;
c && c.constructor == bN && (c = c.attrs.path);
c && (g.along = c);
return this.animate(g, d, f)
}
}
function cB(a, b, c, d, e, f) {
var g = 3 * b, h = 3 * (d - b) - g, i = 1 - g - h, j = 3 * c, k = 3
* (e - c) - j, l = 1 - j - k;
function m(a) {
return ((i * a + h) * a + g) * a
}
function n(a, b) {
var c = o(a, b);
return ((l * c + k) * c + j) * c
}
function o(a, b) {
var c, d, e, f, j, k;
for (e = a, k = 0; k < 8; k++) {
f = m(e) - a;
if (B(f) < b)
return e;
j = (3 * i * e + 2 * h) * e + g;
if (B(j) < 0.000001)
break;
e = e - f / j
}
c = 0;
d = 1;
e = a;
if (e < c)
return c;
if (e > d)
return d;
while (c < d) {
f = m(e);
if (B(f - a) < b)
return e;
a > f ? c = e : d = e;
e = (d - c) / 2 + c
}
return e
}
return n(a, 1 / (200 * f))
}
bO.onAnimation = function(a) {
this._run = a || 0;
return this
};
bO.animate = function(c, d, e, g) {
var h = this;
h.timeouts = h.timeouts || [];
if (a.is(e, "function") || !e)
g = e || null;
if (h.removed) {
g && g.call(h);
return h
}
var i = {}, j = {}, k = false, l = {};
for ( var m in c)
if (c[f](m)) {
if (X[f](m) || h.paper.customAttributes[f](m)) {
k = true;
i[m] = h.attr(m);
i[m] == null && (i[m] = W[m]);
j[m] = c[m];
switch (X[m]) {
case "along":
var n = cs(c[m]), o = ct(c[m], n * !(!c.back)), p = h
.getBBox();
l[m] = n / d;
l.tx = p.x;
l.ty = p.y;
l.sx = o.x;
l.sy = o.y;
j.rot = c.rot;
j.back = c.back;
j.len = n;
c.rot && (l.r = S(h.rotate()) || 0);
break;
case E:
l[m] = (j[m] - i[m]) / d;
break;
case "colour":
i[m] = a.getRGB(i[m]);
var q = a.getRGB(j[m]);
l[m] = {
r : (q.r - i[m].r) / d,
g : (q.g - i[m].g) / d,
b : (q.b - i[m].b) / d
};
break;
case "path":
var t = bw(i[m], j[m]);
i[m] = t[0];
var u = t[1];
l[m] = [];
for (var v = 0, x = i[m][w]; v < x; v++) {
l[m][v] = [ 0 ];
for (var y = 1, z = i[m][v][w]; y < z; y++)
l[m][v][y] = (u[v][y] - i[m][v][y]) / d
}
break;
case "csv":
var A = r(c[m])[s](b), B = r(i[m])[s](b);
switch (m) {
case "translation":
i[m] = [ 0, 0 ];
l[m] = [ A[0] / d, A[1] / d ];
break;
case "rotation":
i[m] = B[1] == A[1] && B[2] == A[2] ? B : [ 0,
A[1], A[2] ];
l[m] = [ (A[0] - i[m][0]) / d, 0, 0 ];
break;
case "scale":
c[m] = A;
i[m] = r(i[m])[s](b);
l[m] = [ (A[0] - i[m][0]) / d,
(A[1] - i[m][1]) / d, 0, 0 ];
break;
case "clip-rect":
i[m] = r(i[m])[s](b);
l[m] = [];
v = 4;
while (v--)
l[m][v] = (A[v] - i[m][v]) / d;
break
}
j[m] = A;
break;
default:
A = [].concat(c[m]);
B = [].concat(i[m]);
l[m] = [];
v = h.paper.customAttributes[m][w];
while (v--)
l[m][v] = ((A[v] || 0) - (B[v] || 0)) / d;
break
}
}
}
if (k) {
var G = a.easing_formulas[e];
if (!G) {
G = r(e).match(P);
if (G && G[w] == 5) {
var H = G;
G = function(a) {
return cB(a, +H[1], +H[2], +H[3], +H[4], d)
}
} else
G = function(a) {
return a
}
}
cv.push({
start : c.start || +(new Date),
ms : d,
easing : G,
from : i,
diff : l,
to : j,
el : h,
t : {
x : 0,
y : 0
}
});
a.is(g, "function") && (h._ac = setTimeout(function() {
g.call(h)
}, d));
cv[w] == 1 && setTimeout(cw)
} else {
var C = [], D;
for ( var F in c)
if (c[f](F) && Z.test(F)) {
m = {
value : c[F]
};
F == "from" && (F = 0);
F == "to" && (F = 100);
m.key = T(F, 10);
C.push(m)
}
C.sort(be);
C[0].key && C.unshift({
key : 0,
value : h.attrs
});
for (v = 0, x = C[w]; v < x; v++)
cx(C[v].value, h, d / 100 * C[v].key, d / 100
* (C[v - 1] && C[v - 1].key || 0), C[v - 1]
&& C[v - 1].value.callback);
D = C[C[w] - 1].value.callback;
D && h.timeouts.push(setTimeout(function() {
D.call(h)
}, d))
}
return this
};
bO.stop = function() {
for (var a = 0; a < cv.length; a++)
cv[a].el.id == this.id && cv.splice(a--, 1);
for (a = 0, ii = this.timeouts && this.timeouts.length; a < ii; a++)
clearTimeout(this.timeouts[a]);
this.timeouts = [];
clearTimeout(this._ac);
delete this._ac;
return this
};
bO.translate = function(a, b) {
return this.attr({
translation : a + " " + b
})
};
bO[H] = function() {
return "Raphaëls object"
};
a.ae = cv;
var cC = function(a) {
this.items = [];
this[w] = 0;
this.type = "set";
if (a)
for (var b = 0, c = a[w]; b < c; b++) {
if (a[b] && (a[b].constructor == bN || a[b].constructor == cC)) {
this[this.items[w]] = this.items[this.items[w]] = a[b];
this[w]++
}
}
};
cC[e][L] = function() {
var a, b;
for (var c = 0, d = arguments[w]; c < d; c++) {
a = arguments[c];
if (a && (a.constructor == bN || a.constructor == cC)) {
b = this.items[w];
this[b] = this.items[b] = a;
this[w]++
}
}
return this
};
cC[e].pop = function() {
delete this[this[w]--];
return this.items.pop()
};
for ( var cD in bO)
bO[f](cD) && (cC[e][cD] = (function(a) {
return function() {
for (var b = 0, c = this.items[w]; b < c; b++)
this.items[b][a][m](this.items[b], arguments);
return this
}
})(cD));
cC[e].attr = function(b, c) {
if (b && a.is(b, G) && a.is(b[0], "object"))
for (var d = 0, e = b[w]; d < e; d++)
this.items[d].attr(b[d]);
else
for (var f = 0, g = this.items[w]; f < g; f++)
this.items[f].attr(b, c);
return this
};
cC[e].animate = function(b, c, d, e) {
(a.is(d, "function") || !d) && (e = d || null);
var f = this.items[w], g = f, h, i = this, j;
e && (j = function() {
!(--f) && e.call(i)
});
d = a.is(d, F) ? d : j;
h = this.items[--g].animate(b, c, d, j);
while (g--)
this.items[g] && !this.items[g].removed
&& this.items[g].animateWith(h, b, c, d, j);
return this
};
cC[e].insertAfter = function(a) {
var b = this.items[w];
while (b--)
this.items[b].insertAfter(a);
return this
};
cC[e].getBBox = function() {
var a = [], b = [], c = [], d = [];
for (var e = this.items[w]; e--;) {
var f = this.items[e].getBBox();
a[L](f.x);
b[L](f.y);
c[L](f.x + f.width);
d[L](f.y + f.height)
}
a = A[m](0, a);
b = A[m](0, b);
return {
x : a,
y : b,
width : z[m](0, c) - a,
height : z[m](0, d) - b
}
};
cC[e].clone = function(a) {
a = new cC;
for (var b = 0, c = this.items[w]; b < c; b++)
a[L](this.items[b].clone());
return a
};
a.registerFont = function(a) {
if (!a.face)
return a;
this.fonts = this.fonts || {};
var b = {
w : a.w,
face : {},
glyphs : {}
}, c = a.face["font-family"];
for ( var d in a.face)
a.face[f](d) && (b.face[d] = a.face[d]);
this.fonts[c] ? this.fonts[c][L](b) : this.fonts[c] = [ b ];
if (!a.svg) {
b.face["units-per-em"] = T(a.face["units-per-em"], 10);
for ( var e in a.glyphs)
if (a.glyphs[f](e)) {
var g = a.glyphs[e];
b.glyphs[e] = {
w : g.w,
k : {},
d : g.d && "M" + g.d[Y](/[mlcxtrv]/g, function(a) {
return ({
l : "L",
c : "C",
x : "z",
t : "m",
r : "l",
v : "c"
})[a] || "M"
}) + "z"
};
if (g.k)
for ( var h in g.k)
g[f](h) && (b.glyphs[e].k[h] = g.k[h])
}
}
return a
};
k.getFont = function(b, c, d, e) {
e = e || "normal";
d = d || "normal";
c = +c || ({
normal : 400,
bold : 700,
lighter : 300,
bolder : 800
})[c] || 400;
if (!a.fonts)
return;
var g = a.fonts[b];
if (!g) {
var h = new RegExp("(^|\\s)" + b[Y](/[^\w\d\s+!~.:_-]/g, p)
+ "(\\s|$)", "i");
for ( var i in a.fonts)
if (a.fonts[f](i)) {
if (h.test(i)) {
g = a.fonts[i];
break
}
}
}
var j;
if (g)
for (var k = 0, l = g[w]; k < l; k++) {
j = g[k];
if (j.face["font-weight"] == c
&& (j.face["font-style"] == d || !j.face["font-style"])
&& j.face["font-stretch"] == e)
break
}
return j
};
k.print = function(c, d, e, f, g, h, i) {
h = h || "middle";
i = z(A(i || 0, 1), -1);
var j = this.set(), k = r(e)[s](p), l = 0, m = p, n;
a.is(f, e) && (f = this.getFont(f));
if (f) {
n = (g || 16) / f.face["units-per-em"];
var o = f.face.bbox.split(b), q = +o[0], t = +o[1]
+ (h == "baseline" ? o[3] - o[1] + +f.face.descent
: (o[3] - o[1]) / 2);
for (var u = 0, v = k[w]; u < v; u++) {
var x = u && f.glyphs[k[u - 1]] || {}, y = f.glyphs[k[u]];
l += u ? (x.w || f.w) + (x.k && x.k[k[u]] || 0) + f.w * i : 0;
y && y.d && j[L](this.path(y.d).attr({
fill : "#000",
stroke : "none",
translation : [ l, 0 ]
}))
}
j.scale(n, n, q, t).translate(c - q, d - t)
}
return j
};
a.format = function(b, c) {
var e = a.is(c, G) ? [ 0 ][n](c) : arguments;
b && a.is(b, F) && e[w] - 1 && (b = b[Y](d, function(a, b) {
return e[++b] == null ? p : e[b]
}));
return b || p
};
a.ninja = function() {
i.was ? h.Raphael = i.is : delete Raphael;
return a
};
a.el = bO;
a.st = cC[e];
i.was ? h.Raphael = a : Raphael = a
})()