Quite good looking graph derived from d3.js http://c3js.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

68 lines
34 KiB

(function(M){function wc(){function n(e,c){e.attr("transform",function(e){return"translate("+(c(e)+$)+", 0)"})}function t(e,c){e.attr("transform",function(e){return"translate(0,"+c(e)+")"})}function M(e){var c=e[0];e=e[e.length-1];return c<e?[c,e]:[e,c]}function Aa(e){for(var c=[],n=Math.ceil(e[0]);n<e[1];n++)c.push(n);0<c.length&&0<c[0]&&c.unshift(c[0]-(c[1]-c[0]));return c}function m(m){m.each(function(){var m=e.select(this),Z=Aa(G.domain()),N=m.selectAll(".tick.major").data(Z,String),O=N.enter().insert("g",
"path").attr("class","tick major").style("opacity",1E-6),aa=e.transition(N.exit()).style("opacity",1E-6).remove(),L=e.transition(N).style("opacity",1),y,P=G.rangeExtent?G.rangeExtent():M(G.range()),m=m.selectAll(".domain").data([0]);m.enter().append("path").attr("class","domain");var m=e.transition(m),H=G.copy(),ka=this.__chart__||H;this.__chart__=H;O.append("line");O.append("text");var Qa=O.select("line"),Ra=L.select("line"),Q=N.select("text"),sa=O.select("text"),Sa=L.select("text");$=(H(1)-H(0))/
2;N=c?0:$;switch(v){case "bottom":y=n;Qa.attr("y2",B);sa.attr("y",Math.max(B,0)+C);Ra.attr("x1",N).attr("x2",N).attr("y2",B);Sa.attr("x",0).attr("y",Math.max(B,0)+C);Q.attr("dy",".71em").style("text-anchor","middle");Q.text(function(e){return Z.length<R||0===e%Math.ceil(Z.length/R)?e<S.length?S[e]:e:""});m.attr("d","M"+P[0]+","+ba+"V0H"+P[1]+"V"+ba);break;case "left":y=t,Qa.attr("x2",-B),sa.attr("x",-(Math.max(B,0)+C)),Ra.attr("x2",-B).attr("y2",0),Sa.attr("x",-(Math.max(B,0)+C)).attr("y",$),Q.attr("dy",
".32em").style("text-anchor","end"),Q.text(function(e){return Z.length<R||0===e%Math.ceil(Z.length/R)?e<S.length?S[e]:e:""}),m.attr("d","M"+-ba+","+P[0]+"H0V"+P[1]+"H"+-ba)}if(G.ticks)O.call(y,ka),L.call(y,H),aa.call(y,H);else{var gb=H.rangeBand()/2,aa=function(e){return H(e)+gb};O.call(y,aa);L.call(y,aa)}})}var G=e.scale.linear(),v="bottom",B=6,ba=6,C=3,c=!1,R=10,$=0,S=[];m.scale=function(e){if(!arguments.length)return G;G=e;return m};m.orient=function(e){if(!arguments.length)return v;v=e in{top:1,
right:1,bottom:1,left:1}?e+"":"bottom";return m};m.categories=function(e){if(!arguments.length)return S;S=e;return m};m.tickCentered=function(e){if(!arguments.length)return c;c=e;return m};m.tickTextNum=function(e){if(!arguments.length)return R;R=e;return m};m.tickOffset=function(){return $};m.ticks=function(){};return m}function t(e){return"undefined"===typeof e}function n(e){return"undefined"!==typeof e}var hb=M.c3={},e=M.d3;hb.generate=function(Y){var Eb,Fb,Aa,m,G,v,B,ba,C;function c(a,b){for(var d=
Y,g=0;g<a.length;g++){if(!(a[g]in d))return b;d=d[a[g]]}return d}function R(){ib=null===Ta?S():Ta;ta=$();Gb=20+Hb+la;Ib=Jb?Jb:Kb?jb||f?1:40:20;Ua=Lb?Lb:kb?1:40;Mb=ta-Hb-la;Nb=20+la;Ob=ta-la;v=0;B=Ib;ba=Gb;C=Ua;Aa=Mb;m=Nb;G=Ua;Eb=Ob;Fb=Ua;r=ib-C-B;q=ta-v-ba;ma=ta-Aa-m}function $(){var a=null===Pb?+e.select(ua).style("height").replace("px",""):Pb;return 0<a?a:320}function S(){return+e.select(ua).style("width").replace("px","")}function Z(){return r+2+C+B}function hb(){return 40}function xc(){return C+
20}function N(){return q-v+42}function O(){Qb=f?10:0;Rb=f?q:r;lb=f?0:q;mb=f?r:1;l=aa(Qb,Rb,n(l)?l.domain():void 0,function(){return I.tickOffset()});z=L(lb,mb,n(z)?z.domain():void 0);T=L(lb,mb,n(T)?T.domain():void 0);ca=aa(0,r,n(U)?U:void 0,function(a){return 0===a%1?Ba.tickOffset():0});Va=L(ma,10);Wa=L(ma,10);I=H(l,yc);na=e.svg.axis().scale(z).orient(zc);Xa=e.svg.axis().scale(T).orient(Ac);Ba=H(ca,Bc)}function aa(a,b,d,g){var p=(A?e.time.scale():e.scale.linear()).range([a,b]);p.orgDomain=function(){return p.domain()};
n(d)&&p.domain(d);t(g)&&(g=function(){return 0});if(da){var c=p,s,p=function(a){return c(a)+g(a)};for(s in c)p[s]=c[s];p.orgDomain=function(){return c.domain()};p.domain=function(a){if(!arguments.length)return a=c.domain(),[a[0],a[1]+1];c.domain(a);return p}}return p}function L(a,b){return e.scale.linear().range([a,b])}function y(a){return"y2"===ka(a)?T:z}function P(a){return"y2"===ka(a)?Wa:Va}function H(a,b){var d=(da?wc():e.svg.axis()).scale(a).orient(b);A&&d.tickFormat(Sb?function(a){return e.time.format(Sb)(a)}:
Cc);da?d.categories(Ca).tickCentered(Dc):d.tickOffset=function(){return 0};return d}function ka(a){return a in Tb?Tb[a]:"y"}function Qa(a){return e.min(a,function(a){return e.min(a.values,function(a){return a.value})})}function Ra(a){var b={},d,g;a.forEach(function(a){b[a.id]=[];a.values.forEach(function(d){b[a.id].push(d.value)})});for(d=0;d<w.length;d++)for(g=1;g<w[d].length;g++)Da(w[d][g])&&(t(b[w[d][g]])||b[w[d][g]].forEach(function(a,e){ka(w[d][g])===ka(w[d][0])&&(b[w[d][0]][e]+=1*a)}));return e.max(Object.keys(b).map(function(a){return e.max(b[a])}))}
function Q(a){var b=Ya(function(b){return ka(b.id)===a}),d="y2"===a?Ec:Fc,g="y2"===a?Gc:Hc,d=null!==d?d:Qa(b),g=null!==g?g:Ra(b),p=0.1*Math.abs(g-d),e=p,c=p,f="y2"===a?Ic:Jc;null!==f&&(d=Math.max(Math.abs(d),Math.abs(g)),g=d-f,d=f-d);"y"===a&&null!==Ea&&(e=n(Ea.top)?Ea.top:p,c=n(Ea.bottom)?Ea.bottom:p);"y2"===a&&null!==Fa&&(e=n(Fa.top)?Fa.top:p,c=n(Fa.bottom)?Fa.bottom:p);return[Kc(b,"bar")?0:d-c,g+e]}function sa(a){var b;a?(a=l.domain(),b=E.extent()):(a=U,b=l.domain());return(a[1]-a[0])/(b[1]-b[0])}
function Sa(a){for(var b=0;b<a.length;b++)if(!(a[b]in Za))return!1;return!0}function gb(a){for(var b=[],d=0;d<a.length;d++)a[d]in Za&&b.push(Ub(Za[a[d]]));return b}function fb(a){return"start"in a?l(A?oa(a.start):a.start):0}function Vb(a){var b=fb(a);a=("end"in a?l(A?oa(a.end):a.end):r)-b;return 0>a?0:a}function nb(a){var b=Ga[a.id];a.name=n(b)?b:a.id;return a}function Wb(a){var b=a[0],d={},g=[],p,e;for(p=1;p<a.length;p++){d={};for(e=0;e<a[p].length;e++)d[b[e]]=a[p][e];g.push(d)}return g}function Xb(a){var b=
[],d,g,e;for(d=0;d<a.length;d++)for(e=a[d][0],g=1;g<a[d].length;g++)t(b[g-1])&&(b[g-1]={}),b[g-1][e]=a[d][g];return b}function Ha(a){var b=e.keys(a[0]).filter(function(a){return a!==V}),d,g;if(A&&!V)return M.alert('data.x must be specified when axis.x.type == "timeseries"'),[];ob&&t(h.data.x)&&(h.data.x=a.map(function(a){return a[V]}));d=0;a.forEach(function(a){if(A){if(!(V in a))throw Error("'"+V+"' must be included in data");g=oa(a[V]);if(null===g)throw Error("Failed to parse timeseries date in data");
a.x=g}else a.x=ob?n(a[V])?a[V]:h.data.x[d]:d;null===$a&&($a=new Date(a.x));pb=new Date(a.x);d++});b=b.map(function(b){var d=Lc(b);return{id:d,id_org:b,values:a.map(function(a){return{x:a.x,value:null===a[b]||isNaN(a[b])?null:+a[b],id:d}})}});b.forEach(function(a){Za[a.id_org]=Ub(a)});return b}function Ub(a){return{id:a.id,id_org:a.id_org,values:a.values.map(function(a){return{x:a.x,value:a.value,id:a.id}})}}function va(){return e.max(h.data.targets,function(a){return a.values.length})}function qb(a){a=
t(a)?h.data.targets:a;return a.map(function(a){return a.id})}function rb(a){var b=qb(),d;for(d=0;d<b.length;d++)if(b[d]===a)return!0;return!1}function Ya(a){return n(a)?h.data.targets.filter(a):h.data.targets}function sb(a){return"-shapes -shapes-"+a.id}function Yb(a){return sb(a)+" -line -line-"+a.id}function Mc(a){return sb(a)+" -circles -circles-"+a.id}function Zb(a){return sb(a)+" -bars -bars-"+a.id}function Nc(a,b){return"-shape -shape-"+b+" -circle -circle-"+b}function $b(a,b){return"-shape -shape-"+
b+" -bar -bar-"+b}function Oc(a,b){return"region region-"+b+" "+("classes"in a?[].concat(a.classes).join(" "):"")}function ab(a){return l(a.x)}function Ia(a){return l(A?oa(a.value):a.value)}function ac(a){return z(a.value)}function ea(a){return l(a.x)}function fa(a){return y(a.id)(a.value)}function Pc(){var a={},b=0,d,g;Ya(Da).forEach(function(e){for(d=0;d<w.length;d++)if(!(0>w[d].indexOf(e.id)))for(g=0;g<w[d].length;g++)if(w[d][g]in a){a[e.id]=a[w[d][g]];break}t(a[e.id])&&(a[e.id]=b++)});a.__max__=
b-1;return a}function bc(a,b,d,g){var e=g?ca:l;return function(g){var c=g.id in d?d[g.id]:0;return e(g.x)-a*(b/2-c)}}function cc(a,b,d,g){var e=Object.keys(b);return function(c,f){var h=0,k=g?P(c.id):y(c.id);Ya(Da).forEach(function(d){d.id!==c.id&&b[d.id]===b[c.id]&&e.indexOf(d.id)<e.indexOf(c.id)&&(h+=a(d.values[f]))});return d?h:k(c.value)-h}}function dc(a,b){var d=null===a?function(a){return a}:function(b){return a-b};return function(a){var e=b?P(a.id):y(a.id);return d(e(a.value))}}function tb(a,
b){var d=t(a)?qb():a;"string"===typeof d&&(d=[d]);for(var g=0;g<d.length;g++)ga[d[g]]=b}function Kc(a,b){var d=!1;a.forEach(function(a){ga[a.id]===b&&(d=!0);a.id in ga||"line"!==b||(d=!0)});return d}function ub(a){a="string"===typeof a?a:a.id;return!(a in ga)||"line"===ga[a]||"spline"===ga[a]}function Da(a){return"bar"===ga["string"===typeof a?a:a.id]}function Qc(a){return ub(a)?a.values:[]}function ec(a){return Da(a)?a.values:[]}function fc(a,b){var d=e.mouse(a),g=e.select(a),c=1*g.attr("cx"),g=
1*g.attr("cy");return Math.sqrt(Math.pow(c-d[0],2)+Math.pow(g-d[1],2))<b}function gc(a){var b=e.mouse(a),d=e.select(a);a=1*d.attr("x");var g=1*d.attr("y"),d=1*d.attr("width");return a-10<b[0]&&b[0]<a+d+10&&g-10<b[1]}function Rc(a,b){var d;for(d=0;d<b.length;d++)if(b[d].start<a&&a<=b[d].end)return!0;return!1}function hc(a,b,d){Sc(a,b);k.select(".selected-circles-"+b.id).selectAll(".selected-circle-"+d).data([b]).enter().append("circle").attr("class",function(){return"selected-circle selected-circle-"+
d}).attr("cx",f?fa:ea).attr("cy",f?ea:fa).attr("stroke",function(){return W(b.id)}).attr("r",1.4*Ja).transition().duration(100).attr("r",Ja)}function vb(a,b,d){Tc(a,b);k.select(".selected-circles-"+b.id).selectAll(".selected-circle-"+d).transition().duration(100).attr("r",0).remove()}function ic(a,b,d,e){a?hc(b,d,e):vb(b,d,e)}function Uc(){}function jc(){}function kc(a,b,d,e){}function lc(a){return a.filter(function(a){return null!==a.value})}function Vc(a,b,d,e){var c,h,s="M",k,l,u,m,r,q=[];if(n(e))for(c=
0;c<e.length;c++)q[c]={},t(e[c].start)?q[c].start=a[0].x:A&&(q[c].start=oa(e[c].start)),t(e[c].end)?q[c].end=a[a.length-1].x:A&&(q[c].end=oa(e[c].end));m=f?function(a){return d(a.value)}:function(a){return b(a.x)};r=f?function(a){return b(a.x)}:function(a){return d(a.value)};e=A?function(a,e,c,g){var f=a.x.getTime();a=e.x-a.x;e=new Date(f+a*(c+g));return"M"+b(new Date(f+a*c))+" "+d(l(c))+" "+b(e)+" "+d(l(c+g))}:function(a,e,c,g){return"M"+b(k(c))+" "+d(l(c))+" "+b(k(c+g))+" "+d(l(c+g))};for(c=0;c<
a.length;c++)if(t(q)||!Rc(a[c].x,q))s+=" "+m(a[c])+" "+r(a[c]);else{k=aa(a[c-1].x,a[c].x);l=L(a[c-1].value,a[c].value);h=b(a[c].x)-b(a[c-1].x);u=d(a[c].value)-d(a[c-1].value);h=Math.sqrt(Math.pow(h,2)+Math.pow(u,2));u=2/h;var v=2*u;for(h=u;1>=h;h+=v)s+=e(a[c-1],a[c],h,u)}return s}function wb(a){var b,d;bb=e.select(ua);if(bb.empty())M.alert('No bind element found. Check the selector specified by "bindto" and existance of that element. Default "bindto" is "#chart".');else{bb.html("");h.data.x=void 0;
h.data.targets=Ha(a);R();O();l.domain(e.extent(a.map(function(a){return a.x})));z.domain(Q("y"));T.domain(Q("y2"));ca.domain(l.domain());Va.domain(z.domain());Wa.domain(T.domain());I.ticks(10>a.length?a.length:10);na.ticks(Wc).outerTickSize(0).tickFormat(Xc);Xa.ticks(Yc).outerTickSize(0).tickFormat(Zc);U=l.domain();E.x(ca);pa&&F.x(l);Ka=e.select(ua).append("svg").attr("width",r+C+B).attr("height",q+v+ba).on("mouseenter",$c).on("mouseleave",ad);cb=Ka.append("defs");cb.append("clipPath").attr("id",
xb).append("rect").attr("y",v).attr("width",r).attr("height",q-v);cb.append("clipPath").attr("id","xaxis-clip").append("rect").attr("x",-1-C).attr("y",-20).attr("width",Z).attr("height",hb);cb.append("clipPath").attr("id","yaxis-clip").append("rect").attr("x",-C+1).attr("y",v-1).attr("width",xc).attr("height",N);k=Ka.append("g").attr("transform",J.main);x=wa?Ka.append("g").attr("transform",J.context):null;xa=ya?Ka.append("g").attr("transform",J.legend):null;X=e.select(ua).style("position","relative").append("div").style("position",
"absolute").style("z-index","10").style("display","none");k.append("g").attr("class","x axis").attr("clip-path",f?"":"url(#xaxis-clip)").attr("transform",J.x).call(f?na:I).append("text").attr("class","-axis-x-label").attr("x",r).attr("dy","-.5em").style("text-anchor","end").text(bd);k.append("g").attr("class","y axis").attr("clip-path",f?"url(#yaxis-clip)":"").call(f?I:na).append("text").attr("transform","rotate(-90)").attr("dy","1.2em").attr("dx","-.5em").style("text-anchor","end").text(cd);Kb&&
k.append("g").attr("class","y2 axis").attr("transform",J.y2).call(Xa);b=k.append("g").attr("clip-path",La).attr("class","grid");mc&&b.append("g").attr("class","xgrids");yb&&(d=b.append("g").attr("class","xgrid-lines").selectAll(".xgrid-line").data(yb).enter().append("g").attr("class","xgrid-line"),d.append("line").attr("class",function(a){return""+a["class"]}),d.append("text").attr("class",function(a){return""+a["class"]}).attr("text-anchor","end").attr("transform",f?"":"rotate(-90)").attr("dx",f?
0:-v).attr("dy",-6).text(function(a){return a.text}));dd&&b.append("g").attr("class","xgrid-focus").append("line").attr("class","xgrid-focus").attr("x1",f?0:-10).attr("x2",f?r:-10).attr("y1",f?-10:v).attr("y2",f?-10:q);nc&&b.append("g").attr("class","ygrids");zb&&b.append("g").attr("class","ygrid-lines").selectAll("ygrid-line").data(zb).enter().append("line").attr("class",function(a){return"ygrid-line "+a["class"]});k.append("g").attr("clip-path",La).attr("class","regions");k.append("g").attr("clip-path",
La).attr("class","chart");k.select(".chart").append("g").attr("class","event-rects").style("fill-opacity",0).style("cursor",pa?"ew-resize":null).selectAll(".event-rects").data(a).enter().append("rect").attr("class",function(a,b){return"event-rect event-rect-"+b}).style("cursor",ha&&qa?"pointer":null).on("mouseover",function(a,b){if(!db){var d=h.data.targets.map(function(a){return nb(a.values[b])}),e,c;if(0<Object.keys(Ga).length){c=[];for(var l in Ga)for(e=0;e<d.length;e++)if(d[e].id===l){c.push(d[e]);
d.shift(e);break}d=c.concat(d)}oc&&k.selectAll(".-circle-"+b).classed(ia,!0).attr("r",pc);k.selectAll(".-bar-"+b).classed(ia,!0);k.selectAll("line.xgrid-focus").style("visibility","visible").data([d[0]]).attr(f?"y1":"x1",ab).attr(f?"y2":"x2",ab)}}).on("mouseout",function(a,b){k.select("line.xgrid-focus").style("visibility","hidden");X.style("display","none");k.selectAll(".-circle-"+b).filter(function(){return e.select(this).classed(ia)}).classed(ia,!1).attr("r",Ab);k.selectAll(".-bar-"+b).classed(ia,
!1)}).on("mousemove",function(a,b){var d=h.data.targets.map(function(a){return nb(a.values[b])});X.html(qc(d)).style("visibility","hidden").style("display","block");var c=X.property("offsetWidth"),n=X.property("offsetHeight");X.style("top",(e.mouse(this)[1]+15+n<$()?e.mouse(this)[1]+15:e.mouse(this)[1]-n)+"px").style("left",f?e.mouse(this)[0]:l(d[0].x)+60+c<(null===Ta?S():Ta)?l(d[0].x)+60+"px":l(d[0].x)-c+30+"px").style("visibility","visible");ha&&!db&&(qa||k.selectAll(".-shape-"+b).filter(function(a){return ra(a)}).each(function(){var a=
e.select(this).classed(ia,!0);"circle"===this.nodeName&&a.attr("r",pc);e.select(".event-rect-"+b).style("cursor",null)}).filter(function(){var a=e.select(this);if("circle"===this.nodeName)return fc(this,Ja);if("rect"===this.nodeName)return gc(this,a.attr("x"),a.attr("y"))}).each(function(){var a=e.select(this);a.classed(ia)||(a.classed(ia,!0),"circle"===this.nodeName&&a.attr("r",Ja));e.select(".event-rect-"+b).style("cursor","pointer")}))}).on("click",function(a,b){Bb?Bb=!1:k.selectAll(".-shape-"+
b).each(function(a){var d=e.select(this),c=d.classed(ja),g=!1,f;"circle"===this.nodeName?(g=fc(this,1.5*Ja),f=ic):"rect"===this.nodeName&&(g=gc(this),f=kc);if(qa||g)ha&&ra(a)&&(d.classed(ja,!c),f(!c,d,a,b)),ed(a,d)})}).call(e.behavior.drag().origin(Object).on("drag",function(){if(ha&&(!pa||F.altDomain)){var a=Cb[0],b=Cb[1],d=e.mouse(this),c=d[0],d=d[1],f=Math.min(a,c),h=Math.max(a,c),l=qa?v:Math.min(b,d),n=qa?q:Math.max(b,d);k.select(".dragarea").attr("x",f).attr("y",l).attr("width",h-f).attr("height",
n-l);k.selectAll(".-shapes").selectAll(".-shape").filter(function(a){return ra(a)}).each(function(a,b){var d=e.select(this),c=d.classed(ja),g=d.classed(Db),k,p,s,m;k=!1;"circle"===this.nodeName?(k=1*d.attr("cx"),p=1*d.attr("cy"),m=ic,k=f<k&&k<h&&l<p&&p<n):"rect"===this.nodeName&&(k=1*d.attr("x"),p=1*d.attr("y"),s=1*d.attr("width"),m=kc,k=f<k+s&&k<h&&p<n);k^g&&(d.classed(Db,!g),d.classed(ja,!c),m(!c,d,a,b))})}}).on("dragstart",function(){ha&&(Cb=e.mouse(this),k.select(".chart").append("rect").attr("class",
"dragarea").style("opacity",0.1),db=!0)}).on("dragend",function(){ha&&(k.select(".dragarea").transition().duration(100).style("opacity",0).remove(),k.selectAll(".-shape").classed(Db,!1),db=!1)})).call(F).on("dblclick.zoom",null);k.select(".chart").append("g").attr("class","chart-bars");k.select(".chart").append("g").attr("class","chart-lines");if(pa)k.insert("rect",fd?null:"g.grid").attr("class","zoom-rect").attr("width",r).attr("height",q).style("opacity",0).style("cursor","ew-resize").call(F).on("dblclick.zoom",
null);null!==Ma&&E.extent("function"!==typeof Ma?Ma:A?Ma($a,pb):Ma(0,va()-1));wa&&(x.append("g").attr("clip-path",La).attr("class","chart"),x.select(".chart").append("g").attr("class","chart-bars"),x.select(".chart").append("g").attr("class","chart-lines"),x.append("g").attr("clip-path",La).attr("class","x brush").call(E).selectAll("rect").attr("height",ma),x.append("g").attr("class","x axis").attr("transform",J.subx).call(Ba));ya&&eb(h.data.targets);rc(h.data.targets);D({withTransition:!1,withUpdateXDomain:!0});
if(gd){if(A&&"string"===typeof za){za=oa(za);for(a=0;a<h.data.targets[0].values.length&&0!==h.data.targets[0].values[a].x-za;a++);za=a}X.html(qc(h.data.targets.map(function(a){return nb(a.values[za])})));X.style("top",sc.top).style("left",sc.left).style("display","block")}null==M.onresize&&(M.onresize=hd)}}function D(a){var b,d,c=Pc(),p=c.__max__+1,m,s,t,w,u;a=n(a)?a:{};b=n(a.withY)?a.withY:!0;w=n(a.withSubchart)?a.withSubchart:!0;u=n(a.withTransition)?a.withTransition:!0;a=n(a.withUpdateXDomain)?
a.withUpdateXDomain:!1;u=u?250:0;a&&(l.domain(E.empty()?U:E.extent()),pa&&F.x(l).updateScaleExtent());z.domain(Q("y"));T.domain(Q("y2"));k.select(".x.axis").transition().duration(f?u:0).call(f?na:I);k.select(".y.axis").transition().duration(f?0:u).call(f?I:na);k.select(".y2.axis").transition().call(Xa);k.select(".x.axis .-axis-x-label").attr("x",r);Va.domain(z.domain());Wa.domain(T.domain());X.style("display","none");k.select("line.xgrid-focus").style("visibility","hidden").attr("y2",q);if(mc){if("year"===
id)for(a=[],s=$a.getFullYear(),m=pb.getFullYear();s<=m;s++)a.push(new Date(s+"-01-01 00:00:00"));else a=l.ticks(10);a=k.select(".xgrids").selectAll(".xgrid").data(a);a.enter().append("line").attr("class","xgrid");a.exit().remove();k.selectAll(".xgrid").attr("x1",function(a){return l(a)-I.tickOffset()}).attr("x2",function(a){return l(a)-I.tickOffset()}).attr("y1",v).attr("y2",q)}yb&&(a=k.selectAll(".xgrid-lines"),a.selectAll("line").attr("x1",f?0:Ia).attr("x2",f?r:Ia).attr("y1",f?Ia:v).attr("y2",f?
Ia:q),a.selectAll("text").attr("x",f?r:0).attr("y",Ia));b&&nc&&(a=k.select(".ygrids").selectAll(".ygrid").data(z.ticks(10)),a.enter().append("line").attr("class","ygrid"),a.attr("x1",f?z:0).attr("x2",f?z:r).attr("y1",f?0:z).attr("y2",f?q:z).attr("opacity",0).transition().attr("opacity",1),a.exit().remove());b&&zb&&k.select(".ygrid-lines").selectAll(".ygrid-line").attr("y1",ac).attr("y2",ac);m=da?1.2*I.tickOffset()/p:0.6*((f?q:r)*sa(!1)/(va()-1));s=dc(f?null:q);b=bc(m,p,c);a=cc(s,c,f);d=k.selectAll(".-bars").selectAll(".-bar").data(ec);
d.transition().duration(u).attr("x",f?a:b).attr("y",f?b:a).attr("width",f?s:m).attr("height",f?m:s);d.enter().append("rect").attr("class",$b).attr("x",f?a:b).attr("y",f?b:a).attr("width",f?s:m).attr("height",f?m:s).style("opacity",0).transition().duration(u).style("opacity",1);d.exit().transition().duration(u).style("opacity",0).remove();k.selectAll(".-line").transition().duration(u).attr("d",jd);b=k.selectAll(".-circles").selectAll(".-circle").data(Qc);b.transition().duration(u).style("opacity",
function(a){return null===a.value?0:1}).attr("cx",f?fa:ea).attr("cy",f?ea:fa);b.enter().append("circle").style("opacity",function(a){return null===a.value?0:1}).attr("class",Nc).attr("cx",f?fa:ea).attr("cy",f?ea:fa).attr("r",Ab);b.exit().remove();wa&&(null!==e.event&&"zoom"===e.event.type&&E.extent(l.orgDomain()).update(),w&&(x.select(".x.axis").transition().duration(f?u:0).call(f?na:Ba),E.empty()||E.extent(l.orgDomain()).update(),m=da?1.2*Ba.tickOffset()/p:0.6*((f?q:r)*sa(!0)/(va()-1)),s=dc(ma,!0),
b=bc(m,p,c,!0),a=cc(s,c,!1,!0),c=x.selectAll(".-bars").selectAll(".-bar").data(ec),c.transition().duration(u).attr("x",b).attr("y",a).attr("width",m).attr("height",s),c.enter().append("rect").attr("class",$b).attr("x",b).attr("y",a).attr("width",m).attr("height",s).style("opacity",0).transition().style("opacity",1),c.exit().transition().style("opacity",0).remove(),x.selectAll(".-line").transition().duration(u).attr("d",kd)));k.selectAll(".selected-circles").filter(function(a){return Da(a)}).selectAll("circle").remove();
k.selectAll(".selected-circle").transition().duration(u).attr("cx",f?fa:ea).attr("cy",f?ea:fa);ob?(t=function(a,b){var d=0<b?h.data.targets[0].values[b-1].x:void 0,c=b<va()-1?h.data.targets[0].values[b+1].x:void 0;return(l(c?c:a.x+50)-l(d?d:a.x-50))/2},c=function(a,b){var d=0<b?h.data.targets[0].values[b-1].x:void 0;return(l(a.x)+l(d?d:a.x-50))/2}):(t=(f?q:r)*sa()/(va()-1),c=function(a){return l(a.x)-t/2});k.selectAll(".event-rect").attr("x",f?0:c).attr("y",f?c:0).attr("width",f?r:t).attr("height",
f?t:q);c=k.select(".regions").selectAll("rect.region").data(K);c.enter().append("rect");c.attr("class",Oc).attr("x",f?0:fb).attr("y",f?fb:v).attr("width",f?r:Vb).attr("height",f?Vb:q).style("fill-opacity",function(a){return n(a.opacity)?a.opacity:0.1});c.exit().transition().duration(u).style("fill-opacity",0).remove()}function ld(){"mousemove"===e.event.sourceEvent.type&&F.altDomain?(l.domain(F.altDomain),F.x(l).updateScaleExtent()):(da&&l.orgDomain()[0]===U[0]&&l.domain([U[0]-1E-10,l.orgDomain()[1]]),
D({withTransition:!1,withY:!1,withSubchart:!1}),"mousemove"===e.event.sourceEvent.type&&(Bb=!0))}function hd(){R();O();E.x(ca);pa&&F.x(l);e.select("svg").attr("width",ib).attr("height",ta);e.select("#"+xb).select("rect").attr("width",r).attr("height",q);e.select("#xaxis-clip").select("rect").attr("width",Z);e.select(".zoom-rect").attr("width",r).attr("height",q);k.select(".x.axis").attr("transform",J.x);k.select(".y2.axis").attr("transform",J.y2);wa&&(x.select(".x.brush").selectAll("rect").attr("height",
ma),x.attr("transform",J.context),x.select(".x.axis").attr("transform",J.subx));ya&&(xa.attr("transform",J.legend),eb(h.data.targets,{withTransition:!1}));D({withTransition:!1,withUpdateXDomain:!0})}function rc(a){var b;k.select(".chart-bars").selectAll(".chart-bar").data(a).enter().append("g").attr("class",function(a){return"chart-bar target target-"+a.id}).style("pointer-events","none").style("opacity",0).append("g").attr("class",Zb).style("fill",function(a){return W(a.id)}).style("stroke",function(a){return W(a.id)}).style("stroke-width",
0).style("cursor",function(a){return ra(a)?"pointer":null});b=k.select(".chart-lines").selectAll(".chart-line").data(a).enter().append("g").attr("class",function(a){return"chart-line target target-"+a.id}).style("pointer-events","none").style("opacity",0);b.append("path").attr("class",Yb).style("stroke",function(a){return W(a.id)});b.append("g").attr("class",function(a){return"selected-circles selected-circles-"+a.id});b.append("g").attr("class",Mc).style("fill",function(a){return W(a.id)}).style("cursor",
function(a){return ra(a)?"pointer":null});a.forEach(function(a){k.selectAll(".selected-circles-"+a.id).selectAll(".selected-circle").each(function(b){b.value=a.values[b.x].value})});wa&&(b=x.select(".chart-bars").selectAll(".chart-bar").data(a),b=b.enter().append("g").attr("class",function(a){return"chart-bar target target-"+a.id}).style("opacity",0),b.append("g").attr("class",Zb).style("fill",function(a){return W(a.id)}),b=x.select(".chart-lines").selectAll(".chart-line").data(a),b=b.enter().append("g").attr("class",
function(a){return"chart-line target target-"+a.id}).style("opacity",0),b.append("path").attr("class",Yb).style("stroke",function(a){return W(a.id)}));ya&&eb(a);e.selectAll(".target").transition().style("opacity",1)}function Na(a,b){h.data.targets.forEach(function(b){for(var c=0;c<a.length;c++)if(b.id===a[c].id){b.values=a[c].values;a.splice(c,1);break}});h.data.targets=h.data.targets.concat(a);rc(h.data.targets);D();b()}function eb(a,b){var d=qb(a),c,f=r/2-Oa*Object.keys(a).length/2,k;b=t(b)?{}:
b;k=n(b.withTransition)?b.withTransition:!0;c=xa.selectAll(".legend-item").data(d).enter().append("g").attr("class",function(a){return"legend-item legend-item-"+a}).style("cursor","pointer").on("click",function(a){md(a)}).on("mouseover",function(a){e.selectAll(".legend-item").filter(function(b){return b!==a}).transition().duration(100).style("opacity",0.3);h.focus(a)}).on("mouseout",function(){e.selectAll(".legend-item").transition().duration(100).style("opacity",1);h.revert()});c.append("rect").attr("class",
"legend-item-event").style("fill-opacity",0).attr("x",-200).attr("y",function(){return la/2-16}).attr("width",Oa).attr("height",24);c.append("rect").attr("class","legend-item-tile").style("fill",function(a){return W(a)}).attr("x",-200).attr("y",function(){return la/2-9}).attr("width",10).attr("height",10);c.append("text").text(function(a){return n(Ga[a])?Ga[a]:a}).attr("x",-200).attr("y",function(){return la/2});xa.selectAll("rect.legend-item-event").data(d).transition().duration(k?250:0).attr("x",
function(a,b){return f+Oa*b});xa.selectAll("rect.legend-item-tile").data(d).transition().duration(k?250:0).attr("x",function(a,b){return f+Oa*b});xa.selectAll("text").data(d).transition().duration(k?250:0).attr("x",function(a,b){return f+Oa*b+14})}function Pa(a){return n(a)?".target-"+a:".target"}var h={data:{}},Za={},ia="_expanded_",ja="_selected_",Db="_included_",ua=c(["bindto"],"#chart"),Ta=c(["size","width"],null),Pb=c(["size","height"],null),Lb=c(["padding","left"],null),Jb=c(["padding","right"],
null),pa=c(["zoom","enabled"],!1),tc=c(["zoom","extent"],null),fd=c(["zoom","privileged"],!1),$c=c(["onenter"],function(){}),ad=c(["onleave"],function(){});if(!("data"in Y))throw Error("data is required in config");var V=c(["data","x"],void 0),nd=c(["data","x_format"],"%Y-%m-%d"),Lc=c(["data","id_converter"],function(a){return a}),Ga=c(["data","names"],{}),w=c(["data","groups"],[]),Tb=c(["data","axes"],{}),ga=c(["data","types"],{}),uc=c(["data","regions"],{}),od=c(["data","colors"],{}),ha=c(["data",
"selection","enabled"],!1),qa=c(["data","selection","grouped"],!1),ra=c(["data","selection","isselectable"],function(){return!0}),wa=c(["subchart","show"],!1),Hb=wa?c(["subchart","size","height"],60):0,pd=c(["color","pattern"],null),ya=c(["legend","show"],!0),Oa=c(["legend","item","width"],80),md=c(["legend","item","onclick"],function(){}),vc=c(["axis","x","type"],"indexed"),Ca=c(["axis","x","categories"],[]),Dc=c(["axis","x","tick","centered"],!1),Sb=c(["axis","x","tick","format"],null),Ma=c(["axis",
"x","default"],null),bd=c(["axis","x","label"],null),Hc=c(["axis","y","max"],null),Fc=c(["axis","y","min"],null),Jc=c(["axis","y","center"],null),cd=c(["axis","y","label"],null),kb=c(["axis","y","inner"],!1),Xc=c(["axis","y","format"],function(a){return a}),Ea=c(["axis","y","padding"],null),Wc=c(["axis","y","ticks"],10),Kb=c(["axis","y2","show"],!1),Gc=c(["axis","y2","max"],null),Ec=c(["axis","y2","min"],null),Ic=c(["axis","y2","center"],null),jb=c(["axis","y2","inner"],!1),Zc=c(["axis","y2","format"],
function(a){return a}),Fa=c(["axis","y2","padding"],null),Yc=c(["axis","y2","ticks"],10),f=c(["axis","rotated"],!1),mc=c(["grid","x","show"],!1),id=c(["grid","x","type"],"tick"),yb=c(["grid","x","lines"],null),nc=c(["grid","y","show"],!1),zb=c(["grid","y","lines"],null),Ab=c(["point","show"],!0)?c(["point","r"],2.5):0,dd=c(["point","focus","line","enabled"],!0),oc=c(["point","focus","expand","enabled"],!0),pc=c(["point","focus","expand","r"],oc?4:Ab),Ja=c(["point","focus","select","r"],8),ed=c(["point",
"onclick"],function(){}),Sc=c(["point","onselected"],function(){}),Tc=c(["point","onunselected"],function(){}),K=c(["regions"],[]),qc=c(["tooltip","contents"],function(a){var b="<table class='-tooltip'><tr><th colspan='2'>"+(A?a[0].x.getFullYear()+"."+(a[0].x.getMonth()+1)+"."+a[0].x.getDate():da?a[0].x<Ca.length?Ca[a[0].x]:a[0].x:a[0].x)+"</th></tr>",d,c,e;for(d=0;d<a.length;d++)n(a[d])?(c=n(a[d].value)?(Math.round(100*a[d].value)/100).toFixed(2):"-",e=a[d].name):e=c="-",b+="<tr class='-tooltip-name-"+
a[d].id+"'><td class='name'><span style='background-color:"+W(a[d].id)+"'></span>"+e+"</td><td class='value'>"+c+"</td></tr>";return b+"</table>"}),gd=c(["tooltip","init","show"],!1),za=c(["tooltip","init","x"],0),sc=c(["tooltip","init","position"],{top:"0px",left:"50px"}),xb=ua.replace("#","")+"-clip",La="url(#"+xb+")",A="timeseries"===vc,da="categorized"===vc,ob=!A&&V,Cb=null,db=!1,Bb=!1,la=ya?40:0,oa=e.time.format(nd).parse,W=function(a,b){var d=[],c=null!==b?b:"#1f77b4 #ff7f0e #2ca02c #d62728 #9467bd #8c564b #e377c2 #7f7f7f #bcbd22 #17becf".split(" ");
return function(b){if(b in a)return a[b];-1===d.indexOf(b)&&d.push(b);return c[d.indexOf(b)%c.length]}}(od,pd),Cc=function(){var a=[[e.time.format("%Y/%-m/%-d"),function(){return!0}],[e.time.format("%-m/%-d"),function(a){return a.getMonth()}],[e.time.format("%-m/%-d"),function(a){return 1!==a.getDate()}],[e.time.format("%-m/%-d"),function(a){return a.getDay()&&1!==a.getDate()}],[e.time.format("%I %p"),function(a){return a.getHours()}],[e.time.format("%I:%M"),function(a){return a.getMinutes()}],[e.time.format(":%S"),
function(a){return a.getSeconds()}],[e.time.format(".%L"),function(a){return a.getMilliseconds()}]];return function(b){for(var d=a.length-1,c=a[d];!c[1](b);)c=a[--d];return c[0](b)}}(),Gb,Nb,Ib,Ua,Mb,Ob,r,q,ma,ib,ta,Qb,Rb,lb,mb,l,z,T,ca,Va,Wa,I,na,Xa,Ba,yc=f?"left":"bottom",zc=f?kb?"top":"bottom":kb?"right":"left",Ac=f?jb?"bottom":"top":jb?"left":"right",Bc="bottom",J={main:function(){return"translate("+C+","+v+")"},context:function(){return"translate("+G+","+Aa+")"},legend:function(){return"translate("+
Fb+","+Eb+")"},y2:function(){return"translate("+(f?0:r)+","+(f?10:0)+")"},x:function(){return"translate(0,"+q+")"},subx:function(){return"translate(0,"+ma+")"}},jd=function(){var a=e.svg.line().x(f?function(a){return y(a.id)(a.value)}:ab).y(f?ab:function(a){return y(a.id)(a.value)});return function(b){var d=lc(b.values),c;if(ub(b))return"spline"===ga["string"===typeof b?b:b.id]?a.interpolate("cardinal"):a.interpolate("linear"),0<Object.keys(uc).length?Vc(d,l,y(b.id),uc[b.id]):a(d);c=l(d[0].x);b=y(b.id)(d[0].value);
return f?"M "+b+" "+c:"M "+c+" "+b}}(),kd=function(){var a=e.svg.line().x(function(a){return ca(a.x)}).y(function(a){return P(a.id)(a.value)});return function(b){var d=lc(b.values);return ub(b)?a(d):"M "+ca(d[0].x)+" "+P(b.id)(d[0].value)}}(),E=e.svg.brush().on("brush",function(){D({withTransition:!1,withY:!1,withSubchart:!1,withUpdateXDomain:!0})}),F=e.behavior.zoom().on("zoomstart",function(){F.altDomain=e.event.sourceEvent.altKey?l.orgDomain():null}).on("zoom",pa?ld:null);E.update=function(){x&&
x.select(".x.brush").call(this);return this};F.orgScaleExtent=function(){var a=tc?tc:[1,10];return[a[0],Math.max(va()/a[1],a[1])]};F.updateScaleExtent=function(){var a=l.orgDomain(),a=(a[1]-a[0])/(U[1]-U[0]),b=this.orgScaleExtent();this.scaleExtent([b[0]*a,b[1]*a]);return this};var Ka,cb,k,x,xa,X,bb,$a=null,pb=null,U;h.focus=function(a){h.defocus();e.selectAll(Pa(a)).filter(function(a){return rb(a.id)}).classed("focused",!0).transition().duration(100).style("opacity",1)};h.defocus=function(a){e.selectAll(Pa(a)).filter(function(a){return rb(a.id)}).classed("focused",
!1).transition().duration(100).style("opacity",0.3)};h.revert=function(a){e.selectAll(Pa(a)).filter(function(a){return rb(a.id)}).classed("focused",!1).transition().duration(100).style("opacity",1)};h.show=function(a){e.selectAll(Pa(a)).transition().style("opacity",1)};h.hide=function(a){e.selectAll(Pa(a)).transition().style("opacity",0)};h.unzoom=function(){E.clear().update();D({withUpdateXDomain:!0})};h.load=function(a){t(a.done)&&(a.done=function(){});"categories"in a&&da&&(Ca=a.categories,I.categories(Ca));
if("cacheIds"in a&&Sa(a.cacheIds))Na(gb(a.cacheIds),a.done);else if("data"in a)Na(Ha(a.data),a.done);else if("url"in a)e.csv(a.url,function(b,d){Na(Ha(d),a.done)});else if("rows"in a)Na(Ha(Wb(a.rows)),a.done);else if("columns"in a)Na(Ha(Xb(a.columns)),a.done);else throw Error("url or rows or columns is required.");};h.unload=function(a){h.data.targets=h.data.targets.filter(function(b){return b.id!==a});e.selectAll(".target-"+a).transition().style("opacity",0).remove();ya&&(e.selectAll(".legend-item-"+
a).remove(),eb(h.data.targets));0<h.data.targets.length&&D()};h.selected=function(a){a=n(a)?"-"+a:"";return e.merge(k.selectAll(".-shapes"+a).selectAll(".-shape").filter(function(){return e.select(this).classed(ja)}).map(function(a){return a.map(function(a){return a.__data__})}))};h.select=function(a,b,d){ha&&k.selectAll(".-shapes").selectAll(".-shape").each(function(c,f){var h="circle"===this.nodeName?hc:Uc,k="circle"===this.nodeName?vb:jc;0<=b.indexOf(f)?ra(c)&&(qa||t(a)||0<=a.indexOf(c.id))&&h(e.select(this).classed(ja,
!0),c,f):n(d)&&d&&k(e.select(this).classed(ja,!1),c,f)})};h.unselect=function(a,b){ha&&k.selectAll(".-shapes").selectAll(".-shape").each(function(d,c){var f="circle"===this.nodeName?vb:jc;(t(b)||0<=b.indexOf(c))&&ra(d)&&(qa||t(a)||0<=a.indexOf(d.id))&&f(e.select(this).classed(ja,!1),d,c)})};h.toLine=function(a){tb(a,"line");D()};h.toSpline=function(a){tb(a,"spline");D()};h.toBar=function(a){tb(a,"bar");D()};h.groups=function(a){if(t(a))return w;w=a;D();return w};h.regions=function(a){if(t(a))return K;
K=a;D();return K};h.regions.add=function(a){if(t(a))return K;K=K.concat(a);D();return K};h.regions.remove=function(a,b){var c=[].concat(a);b=n(b)?b:{};c.forEach(function(a){var c=e.selectAll("."+a);n(b.duration)&&(c=c.transition().duration(b.duration).style("fill-opacity",0));c.remove();K=K.filter(function(b){return 0>b.classes.indexOf(a)})});return K};h.data.get=function(a){a=h.data.getAsTarget(a);return n(a)?a.values.map(function(a){return a.value}):void 0};h.data.getAsTarget=function(a){var b=
Ya(function(b){return b.id===a});return 0<b.length?b[0]:void 0};h.destroy=function(){h.data.targets=void 0;h.data.x=void 0;bb.html("");M.onresize=null};if("url"in Y.data)e.csv(Y.data.url,function(a,b){wb(b)});else if("rows"in Y.data)wb(Wb(Y.data.rows));else if("columns"in Y.data)wb(Xb(Y.data.columns));else throw Error("url or rows or columns is required.");return h}})(window);