diff --git a/docs/assets/js/frappe-charts.min.js b/docs/assets/js/frappe-charts.min.js index 555c386..42dff23 100644 --- a/docs/assets/js/frappe-charts.min.js +++ b/docs/assets/js/frappe-charts.min.js @@ -1,2 +1,2 @@ -var frappe=function(){"use strict";function t(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function e(t){var e=t.getBoundingClientRect();return{top:e.top+(document.documentElement.scrollTop||document.body.scrollTop),left:e.left+(document.documentElement.scrollLeft||document.body.scrollLeft)}}function i(t){return null===t.offsetParent}function n(t){var e=t.getBoundingClientRect();return e.top>=0&&e.left>=0&&e.bottom<=(window.innerHeight||document.documentElement.clientHeight)&&e.right<=(window.innerWidth||document.documentElement.clientWidth)}function a(t){var e=window.getComputedStyle(t),i=parseFloat(e.paddingLeft)+parseFloat(e.paddingRight);return t.clientWidth-i}function s(t,e,i){var n=document.createEvent("HTMLEvents");n.initEvent(e,!0,!0);for(var a in i)n[a]=i[a];return t.dispatchEvent(n)}function r(t){return t.titleHeight+t.margins.top+t.paddings.top}function o(t){return t.margins.left+t.paddings.left}function l(t){return t.margins.top+t.margins.bottom+t.paddings.top+t.paddings.bottom+t.titleHeight+t.legendHeight}function h(t){return t.margins.left+t.margins.right+t.paddings.left+t.paddings.right}function u(t){return parseFloat(t.toFixed(2))}function c(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]&&arguments[3];i||(i=n?t[0]:t[t.length-1]);var a=new Array(Math.abs(e)).fill(i);return t=n?a.concat(t):t.concat(a)}function d(t,e){return(t+"").length*e}function p(t,e){return{x:Math.sin(t*te)*e,y:Math.cos(t*te)*e}}function f(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return!Number.isNaN(t)&&(void 0!==t&&(!!Number.isFinite(t)&&!(e&&t<0)))}function v(t){return Number(Math.round(t+"e4")+"e-4")}function g(t){var e=void 0,i=void 0,n=void 0;if(t instanceof Date)return new Date(t.getTime());if("object"!==(void 0===t?"undefined":Ft(t))||null===t)return t;e=Array.isArray(t)?[]:{};for(n in t)i=t[n],e[n]=g(i);return e}function y(t,e){var i=void 0,n=void 0;return t<=e?(i=e-t,n=t):(i=t-e,n=e),[i,n]}function m(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length-t.length;return i>0?t=c(t,i):e=c(e,i),[t,e]}function b(t,e){if(t)return t.length>e?t.slice(0,e-3)+"...":t}function x(t){var e=void 0;if("number"==typeof t)e=t;else if("string"==typeof t&&(e=Number(t),Number.isNaN(e)))return t;var i=Math.floor(Math.log10(Math.abs(e)));if(i<=2)return e;var n=Math.floor(i/3),a=Math.pow(10,i-3*n)*+(e/Math.pow(10,i)).toFixed(1);return Math.round(100*a)/100+" "+["","K","M","B","T"][n]}function k(t,e){for(var i=[],n=0;n255?255:t<0?0:t}function A(t,e){var i=ne(t),n=!1;"#"==i[0]&&(i=i.slice(1),n=!0);var a=parseInt(i,16),s=w((a>>16)+e),r=w((a>>8&255)+e),o=w((255&a)+e);return(n?"#":"")+(o|r<<8|s<<16).toString(16)}function P(t){var e=/(^\s*)(rgb|hsl)(a?)[(]\s*([\d.]+\s*%?)\s*,\s*([\d.]+\s*%?)\s*,\s*([\d.]+\s*%?)\s*(?:,\s*([\d.]+)\s*)?[)]$/i;return/(^\s*)(#)((?:[A-Fa-f0-9]{3}){1,2})$/i.test(t)||e.test(t)}function M(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function C(t,e){var i=document.createElementNS("http://www.w3.org/2000/svg",t);for(var n in e){var a=e[n];if("inside"===n)M(a).appendChild(i);else if("around"===n){var s=M(a);s.parentNode.insertBefore(i,s),i.appendChild(s)}else"styles"===n?"object"===(void 0===a?"undefined":Ft(a))&&Object.keys(a).map(function(t){i.style[t]=a[t]}):("className"===n&&(n="class"),"innerHTML"===n?i.textContent=a:i.setAttribute(n,a))}return i}function D(t,e){return C("linearGradient",{inside:t,id:e,x1:0,x2:0,y1:0,y2:1})}function T(t,e,i,n){return C("stop",{inside:t,style:"stop-color: "+i,offset:e,"stop-opacity":n})}function L(t,e,i,n){return C("svg",{className:e,inside:t,width:i,height:n})}function O(t){return C("defs",{inside:t})}function N(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,n={className:t,transform:e};return i&&(n.inside=i),C("g",n)}function S(t){return C("path",{className:arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",d:t,styles:{stroke:arguments.length>2&&void 0!==arguments[2]?arguments[2]:"none",fill:arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none","stroke-width":arguments.length>4&&void 0!==arguments[4]?arguments[4]:2}})}function E(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=i.x+t.x,o=i.y+t.y,l=i.x+e.x,h=i.y+e.y;return"M"+i.x+" "+i.y+"\n\t\tL"+r+" "+o+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+h+" z"}function _(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=i.x+t.x,o=i.y+t.y,l=i.x+e.x,h=2*i.y,u=i.y+e.y;return"M"+i.x+" "+i.y+"\n\t\tL"+r+" "+o+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+h+" z\n\t\tL"+r+" "+h+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+u+" z"}function z(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=i.x+t.x,o=i.y+t.y,l=i.x+e.x,h=i.y+e.y;return"M"+r+" "+o+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+h}function I(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=i.x+t.x,o=i.y+t.y,l=i.x+e.x,h=2*n+o,u=i.y+t.y;return"M"+r+" "+o+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+h+"\n\t\tM"+r+" "+h+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+u}function H(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n="path-fill-gradient-"+e+"-"+(i?"lighter":"default"),a=D(t,n),s=[1,.6,.2];return i&&(s=[.4,.2,0]),T(a,"0%",e,s[0]),T(a,"50%",e,s[1]),T(a,"100%",e,s[2]),n}function W(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:Kt,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"none";return C("rect",{className:"percentage-bar",x:t,y:e,width:i,height:n,fill:s,styles:{stroke:A(s,-25),"stroke-dasharray":"0, "+(n+i)+", "+i+", "+n,"stroke-width":a}})}function F(t,e,i,n,a){var s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"none",r=arguments.length>6&&void 0!==arguments[6]?arguments[6]:{},o={className:t,x:e,y:i,width:n,height:n,rx:a,fill:s};return Object.keys(r).map(function(t){o[t]=r[t]}),C("rect",o)}function j(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4];a=arguments.length>5&&void 0!==arguments[5]&&arguments[5]?b(a,re):a;var s={className:"legend-bar",x:0,y:0,width:i,height:"2px",fill:n},r=C("text",{className:"legend-dataset-text",x:0,y:0,dy:2*le+"px","font-size":1.2*le+"px","text-anchor":"start",fill:ue,innerHTML:a}),o=C("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(C("rect",s)),o.appendChild(r),o}function R(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4];a=arguments.length>5&&void 0!==arguments[5]&&arguments[5]?b(a,re):a;var s={className:"legend-dot",cx:0,cy:0,r:i,fill:n},r=C("text",{className:"legend-dataset-text",x:0,y:0,dx:le+"px",dy:le/3+"px","font-size":1.2*le+"px","text-anchor":"start",fill:ue,innerHTML:a}),o=C("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(C("circle",s)),o.appendChild(r),o}function Y(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=a.fontSize||le;return C("text",{className:t,x:e,y:i,dy:(void 0!==a.dy?a.dy:s/2)+"px","font-size":s+"px",fill:a.fill||ue,"text-anchor":a.textAnchor||"start",innerHTML:n})}function B(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=he);var s=C("line",{className:"line-vertical "+a.className,x1:0,x2:0,y1:i,y2:n,styles:{stroke:a.stroke}}),r=C("text",{x:0,y:i>n?i+se:i-se-le,dy:le+"px","font-size":le+"px","text-anchor":"middle",innerHTML:e+""}),o=C("g",{transform:"translate("+t+", 0)"});return o.appendChild(s),o.appendChild(r),o}function V(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=he),a.lineType||(a.lineType=""),a.alignment||(a.alignment="left"),a.shortenNumbers&&(e=x(e));var s=C("line",{className:"line-horizontal "+a.className+("dashed"===a.lineType?"dashed":""),x1:i,x2:n,y1:0,y2:0,styles:{stroke:a.stroke}}),r=C("text",{x:"left"===a.alignment?i-se:n+4*se,y:0,dy:le/2-2+"px","font-size":le+"px","text-anchor":i3&&void 0!==arguments[3]?arguments[3]:{};f(t)||(t=0),n.pos||(n.pos="left"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=he),n.className||(n.className="");var a=-1*ae,s="span"===n.mode?i+ae:0;"tick"===n.mode&&"right"===n.pos&&(a=i+ae,s=i);var r="left"===n.pos?-1*n.offset:n.offset;return a+=r,s+=r,V(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType,alignment:n.pos,shortenNumbers:n.shortenNumbers})}function q(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};f(t)||(t=0),n.pos||(n.pos="bottom"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=he),n.className||(n.className="");var a=i+ae,s="span"===n.mode?-1*ae:i;return"tick"===n.mode&&"top"===n.pos&&(a=-1*ae,s=0),B(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType})}function X(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};n.labelPos||(n.labelPos="right");var a=C("text",{className:"chart-label",x:"left"===n.labelPos?se:i-d(e,5)-se,y:0,dy:le/-2+"px","font-size":le+"px","text-anchor":"start",innerHTML:e+""}),s=V(t,"",0,i,{stroke:n.stroke||he,className:n.className||"",lineType:n.lineType});return s.appendChild(a),s}function J(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=t-e,r=C("rect",{className:"bar mini",styles:{fill:"rgba(228, 234, 239, 0.49)",stroke:he,"stroke-dasharray":i+", "+s},x:0,y:0,width:i,height:s});a.labelPos||(a.labelPos="right");var o=C("text",{className:"chart-label",x:"left"===a.labelPos?se:i-d(n+"",4.5)-se,y:0,dy:le/-2+"px","font-size":le+"px","text-anchor":"start",innerHTML:n+""}),l=C("g",{transform:"translate(0, "+e+")"});return l.appendChild(r),l.appendChild(o),l}function K(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,o=arguments.length>7&&void 0!==arguments[7]?arguments[7]:{},l=y(e,o.zeroLine),h=Ut(l,2),u=h[0],c=h[1];c-=r,0===u&&(u=o.minHeight,c-=o.minHeight),f(t)||(t=0),f(c)||(c=0),f(u,!0)||(u=0),f(i,!0)||(i=0);var d=C("rect",{className:"bar mini",style:"fill: "+n,"data-point-index":s,x:t,y:c,width:i,height:u});if((a+="")||a.length){d.setAttribute("y",0),d.setAttribute("x",0);var p=C("text",{className:"data-point-value",x:i/2,y:0,dy:le/2*-1+"px","font-size":le+"px","text-anchor":"middle",innerHTML:a}),v=C("g",{"data-point-index":s,transform:"translate("+t+", "+c+")"});return v.appendChild(d),v.appendChild(p),v}return d}function $(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=C("circle",{style:"fill: "+n,"data-point-index":s,cx:t,cy:e,r:i});if((a+="")||a.length){r.setAttribute("cy",0),r.setAttribute("cx",0);var o=C("text",{className:"data-point-value",x:0,y:0,dy:le/2*-1-i+"px","font-size":le+"px","text-anchor":"middle",innerHTML:a}),l=C("g",{"data-point-index":s,transform:"translate("+t+", "+e+")"});return l.appendChild(r),l.appendChild(o),l}return r}function Q(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=e.map(function(e,i){return t[i]+","+e}).join("L");n.spline&&(s=k(t,e));var r=S("M"+s,"line-graph-path",i);if(n.heatline){var o=H(a.svgDefs,i);r.style.stroke="url(#"+o+")"}var l={path:r};if(n.regionFill){var h=H(a.svgDefs,i,!0),u="M"+t[0]+","+a.zeroLine+"L"+s+"L"+t.slice(-1)[0]+","+a.zeroLine;l.region=S(u,"region-fill","none","url(#"+h+")")}return l}function Z(t,e,i,n){var a="string"==typeof e?e:e.join(", ");return[t,{transform:i.join(", ")},n,ye,"translate",{transform:a}]}function tt(t,e,i){return Z(t,[i,0],[e,0],ve)}function et(t,e,i){return Z(t,[0,i],[0,e],ve)}function it(t,e,i,n){var a=e-i,s=t.childNodes[0];return[[s,{height:a,"stroke-dasharray":s.getAttribute("width")+", "+a},ve,ye],Z(t,[0,n],[0,i],ve)]}function nt(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,s=y(i,(arguments.length>5&&void 0!==arguments[5]?arguments[5]:{}).zeroLine),r=Ut(s,2),o=r[0],l=r[1];return l-=a,"rect"!==t.nodeName?[[t.childNodes[0],{width:n,height:o},pe,ye],Z(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,l],ve)]:[[t,{width:n,height:o,x:e,y:l},pe,ye]]}function at(t,e,i){return"circle"!==t.nodeName?[Z(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,i],ve)]:[[t,{cx:e,cy:i},pe,ye]]}function st(t,e,i,n,a){var s=[],r=i.map(function(t,i){return e[i]+","+t}).join("L");a&&(r=k(e,i));var o=[t.path,{d:"M"+r},fe,ye];if(s.push(o),t.region){var l=e[0]+","+n+"L",h="L"+e.slice(-1)[0]+", "+n,u=[t.region,{d:"M"+l+r+h},fe,ye];s.push(u)}return s}function rt(t,e){return[t,{d:e},pe,ye]}function ot(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"linear",a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:void 0,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},r=t.cloneNode(!0),o=t.cloneNode(!0);for(var l in e){var h=void 0;h="transform"===l?document.createElementNS("http://www.w3.org/2000/svg","animateTransform"):document.createElementNS("http://www.w3.org/2000/svg","animate");var u=s[l]||t.getAttribute(l),c=e[l],d={attributeName:l,from:u,to:c,begin:"0s",dur:i/1e3+"s",values:u+";"+c,keySplines:me[n],keyTimes:"0;1",calcMode:"spline",fill:"freeze"};a&&(d.type=a);for(var p in d)h.setAttribute(p,d[p]);r.appendChild(h),a?o.setAttribute(l,"translate("+c+")"):o.setAttribute(l,c)}return[r,o]}function lt(t,e){t.style.transform=e,t.style.webkitTransform=e,t.style.msTransform=e,t.style.mozTransform=e,t.style.oTransform=e}function ht(t,e){var i=[],n=[];e.map(function(t){var e=t[0],a=e.parentNode,s=void 0,r=void 0;t[0]=e;var o=ot.apply(void 0,Gt(t)),l=Ut(o,2);s=l[0],r=l[1],i.push(r),n.push([s,a]),a&&a.replaceChild(s,e)});var a=t.cloneNode(!0);return n.map(function(t,n){t[1]&&(t[1].replaceChild(i[n],t[0]),e[n][0]=i[n])}),a}function ut(t,e,i){if(0!==i.length){var n=ht(e,i);e.parentNode==t&&(t.removeChild(e),t.appendChild(n)),setTimeout(function(){n.parentNode==t&&(t.removeChild(n),t.appendChild(e))},ge)}}function ct(t,e){var i=document.createElement("a");i.style="display: none";var n=new Blob(e,{type:"image/svg+xml; charset=utf-8"}),a=window.URL.createObjectURL(n);i.href=a,i.download=t,document.body.appendChild(i),i.click(),setTimeout(function(){document.body.removeChild(i),window.URL.revokeObjectURL(a)},300)}function dt(e){var i=e.cloneNode(!0);i.classList.add("chart-container"),i.setAttribute("xmlns","http://www.w3.org/2000/svg"),i.setAttribute("xmlns:xlink","http://www.w3.org/1999/xlink");var n=t.create("style",{innerHTML:be});i.insertBefore(n,i.firstChild);var a=t.create("div");return a.appendChild(i),a.innerHTML}function pt(t){var e=new Date(t);return e.setMinutes(e.getMinutes()-e.getTimezoneOffset()),e}function ft(t){var e=t.getDate(),i=t.getMonth()+1;return[t.getFullYear(),(i>9?"":"0")+i,(e>9?"":"0")+e].join("-")}function vt(t){return new Date(t.getTime())}function gt(t,e){var i=kt(t);return Math.ceil(yt(i,e)/we)}function yt(t,e){var i=Pe*Ae;return(pt(e)-pt(t))/i}function mt(t,e){return t.getMonth()===e.getMonth()&&t.getFullYear()===e.getFullYear()}function bt(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1],i=Me[t];return e?i.slice(0,3):i}function xt(t,e){return new Date(e,t+1,0)}function kt(t){var e=vt(t),i=e.getDay();return 0!==i&&wt(e,-1*i),e}function wt(t,e){t.setDate(t.getDate()+e)}function At(t,e,i){var n=Object.keys(Te).filter(function(e){return t.includes(e)}),a=Te[n[0]];return Object.assign(a,{constants:e,getData:i}),new De(a)}function Pt(t){if(0===t)return[0,0];if(isNaN(t))return{mantissa:-6755399441055744,exponent:972};var e=t>0?1:-1;if(!isFinite(t))return{mantissa:4503599627370496*e,exponent:972};t=Math.abs(t);var i=Math.floor(Math.log10(t));return[e*(t/Math.pow(10,i)),i]}function Mt(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=Math.ceil(t),n=Math.floor(e),a=i-n,s=a,r=1;a>5&&(a%2!=0&&(a=++i-n),s=a/2,r=2),a<=2&&(r=a/(s=4)),0===a&&(s=5,r=1);for(var o=[],l=0;l<=s;l++)o.push(n+r*l);return o}function Ct(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=Pt(t),n=Ut(i,2),a=n[0],s=n[1],r=e?e/Math.pow(10,s):0,o=Mt(a=a.toFixed(6),r);return o=o.map(function(t){return s<0?t/Math.pow(10,-s):t*Math.pow(10,s)})}function Dt(t){function e(t,e){for(var i=Ct(t),n=i[1]-i[0],a=0,s=1;a1&&void 0!==arguments[1]&&arguments[1],n=Math.max.apply(Math,Gt(t)),a=Math.min.apply(Math,Gt(t)),s=[];if(n>=0&&a>=0)Pt(n)[1],s=i?Ct(n,a):Ct(n);else if(n>0&&a<0){var r=Math.abs(a);n>=r?(Pt(n)[1],s=e(n,r)):(Pt(r)[1],s=e(r,n).reverse().map(function(t){return-1*t}))}else if(n<=0&&a<=0){var o=Math.abs(a),l=Math.abs(n);Pt(o)[1],s=(s=i?Ct(o,l):Ct(o)).reverse().map(function(t){return-1*t})}return s}function Tt(t){var e=Lt(t);return t.indexOf(0)>=0?t.indexOf(0):t[0]>0?-1*t[0]/e:-1*t[t.length-1]/e+(t.length-1)}function Lt(t){return t[1]-t[0]}function Ot(t){return t[t.length-1]-t[0]}function Nt(t,e){return u(e.zeroLine-t*e.scaleMultiplier)}function St(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n=e.reduce(function(e,i){return Math.abs(i-t)i?n.slice(0,i):c(n,i-n.length,0),t.values=n}else t.values=a;t.chartType||(Jt.includes(e),t.chartType=e)}),t.yRegions&&t.yRegions.map(function(t){if(t.end1&&void 0!==arguments[1]?arguments[1]:[],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=t/e.length;n<=0&&(n=1);var a=n/$t,s=void 0;if(i){var r=Math.max.apply(Math,Gt(e.map(function(t){return t.length})));s=Math.ceil(r/a)}return e.map(function(t,e){return(t+="").length>a&&(i?e%s!=0&&(t=""):t=a-3>0?t.slice(0,a-3)+" ...":t.slice(0,a)+".."),t})}function Wt(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"line",e=arguments[1],i=arguments[2];return"axis-mixed"===t?(i.type="line",new Se(e,i)):_e[t]?new _e[t](e,i):void console.error("Undefined chart type: "+t)}!function(t,e){void 0===e&&(e={});var i=e.insertAt;if(t&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css","top"===i&&n.firstChild?n.insertBefore(a,n.firstChild):n.appendChild(a),a.styleSheet?a.styleSheet.cssText=t:a.appendChild(document.createTextNode(t))}}('.chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ol,.graph-svg-tip ul{padding-left:0;display:-webkit-box;display:-ms-flexbox;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:" ";border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}');var Ft="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},jt=(function(){function t(t){this.value=t}function e(e){function i(t,e){return new Promise(function(i,a){var o={key:t,arg:e,resolve:i,reject:a,next:null};r?r=r.next=o:(s=r=o,n(t,e))})}function n(i,s){try{var r=e[i](s),o=r.value;o instanceof t?Promise.resolve(o.value).then(function(t){n("next",t)},function(t){n("throw",t)}):a(r.done?"return":"normal",r.value)}catch(t){a("throw",t)}}function a(t,e){switch(t){case"return":s.resolve({value:e,done:!0});break;case"throw":s.reject(e);break;default:s.resolve({value:e,done:!1})}(s=s.next)?n(s.key,s.arg):r=null}var s,r;this._invoke=i,"function"!=typeof e.return&&(this.return=void 0)}"function"==typeof Symbol&&Symbol.asyncIterator&&(e.prototype[Symbol.asyncIterator]=function(){return this}),e.prototype.next=function(t){return this._invoke("next",t)},e.prototype.throw=function(t){return this._invoke("throw",t)},e.prototype.return=function(t){return this._invoke("return",t)}}(),function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}),Rt=function(){function t(t,e){for(var i=0;i\n\t\t\t\t
    \n\t\t\t\t
    '}),this.hideTip(),this.title=this.container.querySelector(".title"),this.dataPointList=this.container.querySelector(".data-point-list"),this.parent.addEventListener("mouseleave",function(){e.hideTip()})}},{key:"fill",value:function(){var e=this,i=void 0;this.index&&this.container.setAttribute("data-point-index",this.index),i=this.titleValueFirst?""+this.titleValue+""+this.titleName:this.titleName+""+this.titleValue+"",this.title.innerHTML=i,this.dataPointList.innerHTML="",this.listValues.map(function(i,n){var a=e.colors[n]||"black",s=0===i.formatted||i.formatted?i.formatted:i.value,r=t.create("li",{styles:{"border-top":"3px solid "+a},innerHTML:''+(0===s||s?s:"")+"\n\t\t\t\t\t"+(i.title?i.title:"")});e.dataPointList.appendChild(r)})}},{key:"calcPosition",value:function(){var t=this.container.offsetWidth;this.top=this.y-this.container.offsetHeight-5,this.left=this.x-t/2;var e=this.parent.offsetWidth-t,i=this.container.querySelector(".svg-pointer");if(this.left<0)i.style.left="calc(50% - "+-1*this.left+"px)",this.left=0;else if(this.left>e){var n="calc(50% + "+(this.left-e)+"px)";i.style.left=n,this.left=e}else i.style.left="50%"}},{key:"setValues",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:-1;this.titleName=i.name,this.titleValue=i.value,this.listValues=n,this.x=t,this.y=e,this.titleValueFirst=i.valueFirst||0,this.index=a,this.refresh()}},{key:"hideTip",value:function(){this.container.style.top="0px",this.container.style.left="0px",this.container.style.opacity="0"}},{key:"showTip",value:function(){this.container.style.top=this.top+"px",this.container.style.left=this.left+"px",this.container.style.opacity="1"}}]),e}(),ie={"light-blue":"#7cd6fd",blue:"#5e64ff",violet:"#743ee2",red:"#ff5858",orange:"#ffa00a",yellow:"#feef72",green:"#28a745","light-green":"#98d85b",purple:"#b554ff",magenta:"#ffa3ef",black:"#36114C",grey:"#bdd3e6","light-grey":"#f0f4f7","dark-grey":"#b8c2cc"},ne=function(t){return/rgb[a]{0,1}\([\d, ]+\)/gim.test(t)?/\D+(\d*)\D+(\d*)\D+(\d*)/gim.exec(t).map(function(t,e){return 0!==e?Number(t).toString(16):"#"}).reduce(function(t,e){return""+t+e}):ie[t]||t},ae=6,se=4,re=15,oe=120,le=10,he="#dadada",ue="#555b51",ce={bar:function(t){var e=void 0;"rect"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode();return i.style.fill="#000000",i.style.opacity="0.4",e&&i.setAttribute("transform",e),i},dot:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i},heat_square:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i}},de={bar:function(t,e){var i=void 0;"rect"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["x","y","width","height"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},dot:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},heat_square:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)}},pe=350,fe=350,ve=pe,ge=250,ye="easein",me={ease:"0.25 0.1 0.25 1",linear:"0 0 1 1",easein:"0.1 0.8 0.2 1",easeout:"0 0 0.58 1",easeinout:"0.42 0 0.58 1"},be=".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}",xe=function(){function e(t,i){if(jt(this,e),i=g(i),this.parent="string"==typeof t?document.querySelector(t):t,!(this.parent instanceof HTMLElement))throw new Error("No `parent` element to render on was provided.");this.rawChartArgs=i,this.title=i.title||"",this.type=i.type||"",this.realData=this.prepareData(i.data),this.data=this.prepareFirstData(this.realData),this.colors=this.validateColors(i.colors,this.type),this.config={showTooltip:1,showLegend:1,isNavigable:i.isNavigable||0,animate:void 0!==i.animate?i.animate:1,truncateLegends:i.truncateLegends||1},this.measures=JSON.parse(JSON.stringify(qt));var n=this.measures;this.setMeasures(i),this.title.length||(n.titleHeight=0),this.config.showLegend||(n.legendHeight=0),this.argHeight=i.height||n.baseHeight,this.state={},this.options={},this.initTimeout=Xt,this.config.isNavigable&&(this.overlays=[]),this.configure(i)}return Rt(e,[{key:"prepareData",value:function(t){return t}},{key:"prepareFirstData",value:function(t){return t}},{key:"validateColors",value:function(t,e){var i=[];return(t=(t||[]).concat(Zt[e])).forEach(function(t){var e=ne(t);P(e)?i.push(e):console.warn('"'+t+'" is not a valid color.')}),i}},{key:"setMeasures",value:function(){}},{key:"configure",value:function(){var t=this,e=this.argHeight;this.baseHeight=e,this.height=e-l(this.measures),this.boundDrawFn=function(){return t.draw(!0)},ResizeObserver&&(this.resizeObserver=new ResizeObserver(this.boundDrawFn),this.resizeObserver.observe(this.parent)),window.addEventListener("resize",this.boundDrawFn),window.addEventListener("orientationchange",this.boundDrawFn)}},{key:"destroy",value:function(){this.resizeObserver&&this.resizeObserver.disconnect(),window.removeEventListener("resize",this.boundDrawFn),window.removeEventListener("orientationchange",this.boundDrawFn)}},{key:"setup",value:function(){this.makeContainer(),this.updateWidth(),this.makeTooltip(),this.draw(!1,!0)}},{key:"makeContainer",value:function(){this.parent.innerHTML="";var e={inside:this.parent,className:"chart-container"};this.independentWidth&&(e.styles={width:this.independentWidth+"px"}),this.container=t.create("div",e)}},{key:"makeTooltip",value:function(){this.tip=new ee({parent:this.container,colors:this.colors}),this.bindTooltip()}},{key:"bindTooltip",value:function(){}},{key:"draw",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],n=arguments.length>1&&void 0!==arguments[1]&&arguments[1];e&&i(this.parent)||(this.updateWidth(),this.calc(e),this.makeChartArea(),this.setupComponents(),this.components.forEach(function(e){return e.setup(t.drawArea)}),this.render(this.components,!1),n&&(this.data=this.realData,setTimeout(function(){t.update(t.data)},this.initTimeout)),this.renderLegend(),this.setupNavigation(n))}},{key:"calc",value:function(){}},{key:"updateWidth",value:function(){this.baseWidth=a(this.parent),this.width=this.baseWidth-h(this.measures)}},{key:"makeChartArea",value:function(){this.svg&&this.container.removeChild(this.svg);var t=this.measures;this.svg=L(this.container,"frappe-chart chart",this.baseWidth,this.baseHeight),this.svgDefs=O(this.svg),this.title.length&&(this.titleEL=Y("title",t.margins.left,t.margins.top,this.title,{fontSize:t.titleFontSize,fill:"#666666",dy:t.titleFontSize}));var e=r(t);this.drawArea=N(this.type+"-chart chart-draw-area","translate("+o(t)+", "+e+")"),this.config.showLegend&&(e+=this.height+t.paddings.bottom,this.legendArea=N("chart-legend","translate("+o(t)+", "+e+")")),this.title.length&&this.svg.appendChild(this.titleEL),this.svg.appendChild(this.drawArea),this.config.showLegend&&this.svg.appendChild(this.legendArea),this.updateTipOffset(o(t),r(t))}},{key:"updateTipOffset",value:function(t,e){this.tip.offset={x:t,y:e}}},{key:"setupComponents",value:function(){this.components=new Map}},{key:"update",value:function(t){t||console.error("No data to update."),this.data=this.prepareData(t),this.calc(),this.render(this.components,this.config.animate),this.renderLegend()}},{key:"render",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.components,i=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.config.isNavigable&&this.overlays.map(function(t){return t.parentNode.removeChild(t)});var n=[];e.forEach(function(t){n=n.concat(t.update(i))}),n.length>0?(ut(this.container,this.svg,n),setTimeout(function(){e.forEach(function(t){return t.make()}),t.updateNav()},400)):(e.forEach(function(t){return t.make()}),this.updateNav())}},{key:"updateNav",value:function(){this.config.isNavigable&&(this.makeOverlay(),this.bindUnits())}},{key:"renderLegend",value:function(){}},{key:"setupNavigation",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.config.isNavigable&&e&&(this.bindOverlay(),this.keyActions={13:this.onEnterKey.bind(this),37:this.onLeftArrow.bind(this),38:this.onUpArrow.bind(this),39:this.onRightArrow.bind(this),40:this.onDownArrow.bind(this)},document.addEventListener("keydown",function(e){n(t.container)&&(e=e||window.event,t.keyActions[e.keyCode]&&t.keyActions[e.keyCode]())}))}},{key:"makeOverlay",value:function(){}},{key:"updateOverlay",value:function(){}},{key:"bindOverlay",value:function(){}},{key:"bindUnits",value:function(){}},{key:"onLeftArrow",value:function(){}},{key:"onRightArrow",value:function(){}},{key:"onUpArrow",value:function(){}},{key:"onDownArrow",value:function(){}},{key:"onEnterKey",value:function(){}},{key:"addDataPoint",value:function(){}},{key:"removeDataPoint",value:function(){}},{key:"getDataPoint",value:function(){}},{key:"setCurrentDataPoint",value:function(){}},{key:"updateDataset",value:function(){}},{key:"export",value:function(){var t=dt(this.svg);ct(this.title||"Chart",[t])}}]),e}(),ke=function(t){function e(t,i){return jt(this,e),Vt(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i))}return Bt(e,t),Rt(e,[{key:"configure",value:function(t){Yt(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"configure",this).call(this,t),this.config.formatTooltipY=(t.tooltipOptions||{}).formatTooltipY,this.config.maxSlices=t.maxSlices||20,this.config.maxLegendPoints=t.maxLegendPoints||20}},{key:"calc",value:function(){var t=this,e=this.state,i=this.config.maxSlices;e.sliceTotals=[];var n=this.data.labels.map(function(e,i){var n=0;return t.data.datasets.map(function(t){n+=t.values[i]}),[n,e]}).filter(function(t){return t[0]>=0}),a=n;if(n.length>i){n.sort(function(t,e){return e[0]-t[0]}),a=n.slice(0,i-1);var s=0;n.slice(i-1).map(function(t){s+=t[0]}),a.push([s,"Rest"]),this.colors[i-1]="grey"}e.labels=[],a.map(function(t){e.sliceTotals.push(v(t[0])),e.labels.push(t[1])}),e.grandTotal=e.sliceTotals.reduce(function(t,e){return t+e},0),this.center={x:this.width/2,y:this.height/2}}},{key:"renderLegend",value:function(){var t=this,e=this.state;this.legendArea.textContent="",this.legendTotals=e.sliceTotals.slice(0,this.config.maxLegendPoints);var i=0,n=0;this.legendTotals.map(function(a,s){var r=150,o=Math.floor((t.width-h(t.measures))/r);t.legendTotals.lengtho&&(i=0,n+=20);var l=r*i+5,u=t.config.truncateLegends?b(e.labels[s],r/10):e.labels[s],c=t.config.formatTooltipY?t.config.formatTooltipY(a):a,d=R(l,n,5,t.colors[s],u+": "+c,!1);t.legendArea.appendChild(d),i++})}}]),e}(xe),we=7,Ae=1e3,Pe=86400,Me=["January","February","March","April","May","June","July","August","September","October","November","December"],Ce=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],De=function(){function t(e){var i=e.layerClass,n=void 0===i?"":i,a=e.layerTransform,s=void 0===a?"":a,r=e.constants,o=e.getData,l=e.makeElements,h=e.animateElements;jt(this,t),this.layerTransform=s,this.constants=r,this.makeElements=l,this.getData=o,this.animateElements=h,this.store=[],this.labels=[],this.layerClass=n,this.layerClass="function"==typeof this.layerClass?this.layerClass():this.layerClass,this.refresh()}return Rt(t,[{key:"refresh",value:function(t){this.data=t||this.getData()}},{key:"setup",value:function(t){this.layer=N(this.layerClass,this.layerTransform,t)}},{key:"make",value:function(){this.render(this.data),this.oldData=this.data}},{key:"render",value:function(t){var e=this;this.store=this.makeElements(t),this.layer.textContent="",this.store.forEach(function(t){t.length?t.forEach(function(t){e.layer.appendChild(t)}):e.layer.appendChild(t)}),this.labels.forEach(function(t){e.layer.appendChild(t)})}},{key:"update",value:function(){var t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];this.refresh();var e=[];return t&&(e=this.animateElements(this.data)||[]),e}}]),t}(),Te={donutSlices:{layerClass:"donut-slices",makeElements:function(t){return t.sliceStrings.map(function(e,i){var n=S(e,"donut-path",t.colors[i],"none",t.strokeWidth);return n.style.transition="transform .3s;",n})},animateElements:function(t){return this.store.map(function(e,i){return rt(e,t.sliceStrings[i])})}},pieSlices:{layerClass:"pie-slices",makeElements:function(t){return t.sliceStrings.map(function(e,i){var n=S(e,"pie-path","none",t.colors[i]);return n.style.transition="transform .3s;",n})},animateElements:function(t){return this.store.map(function(e,i){return rt(e,t.sliceStrings[i])})}},percentageBars:{layerClass:"percentage-bars",makeElements:function(t){var e=this;return t.xPositions.map(function(i,n){return W(i,0,t.widths[n],e.constants.barHeight,e.constants.barDepth,t.colors[n])})},animateElements:function(t){if(t)return[]}},yAxis:{layerClass:"y axis",makeElements:function(t){var e=this,i=[];return t.length?(t.forEach(function(n,a){n.positions.map(function(t,a){i.push(G(t,n.labels[a],e.constants.width,{mode:e.constants.mode,pos:n.pos||e.constants.pos,shortenNumbers:e.constants.shortenNumbers}))}),n.title&&i.push(U({title:n.title,position:n.pos,height:e.constants.height||t.zeroLine,width:e.constants.width}))}),i):(t.positions.forEach(function(n,a){i.push(G(n,t.labels[a],e.constants.width,{mode:e.constants.mode,pos:t.pos||e.constants.pos,shortenNumbers:e.constants.shortenNumbers}))}),t.title&&i.push(U({title:t.title,position:t.pos,height:this.constants.height||t.zeroLine,width:this.constants.width})),i)},animateElements:function(t){var e=this,i=function(t,i){var n=i.positions,a=i.labels,s=t.positions,r=t.labels,o=m(s,n),l=Ut(o,2);s=l[0],n=l[1];var h=m(r,a),u=Ut(h,2);return r=u[0],a=u[1],e.render({positions:s,labels:a}),e.store.map(function(t,e){return et(t,n[e],s[e])})};if(this.oldData instanceof Array)return this.oldData.forEach(function(e,n){i(e,t[n])});var n=t.positions,a=t.labels,s=this.oldData.positions,r=this.oldData.labels,o=m(s,n),l=Ut(o,2);s=l[0],n=l[1];var h=m(r,a),u=Ut(h,2);return r=u[0],a=u[1],this.render({positions:s,labels:a}),this.store.map(function(t,e){return et(t,n[e],s[e])})}},xAxis:{layerClass:"x axis",makeElements:function(t){var e=this;return t.positions.map(function(i,n){return q(i,t.calcLabels[n],e.constants.height,{mode:e.constants.mode,pos:e.constants.pos})})},animateElements:function(t){var e=t.positions,i=t.calcLabels,n=this.oldData.positions,a=this.oldData.calcLabels,s=m(n,e),r=Ut(s,2);n=r[0],e=r[1];var o=m(a,i),l=Ut(o,2);return a=l[0],i=l[1],this.render({positions:n,calcLabels:i}),this.store.map(function(t,i){return tt(t,e[i],n[i])})}},yMarkers:{layerClass:"y-markers",makeElements:function(t){var e=this;return t.map(function(t){return X(t.position,t.label,e.constants.width,{labelPos:t.options.labelPos,mode:"span",lineType:"dashed"})})},animateElements:function(t){var e=m(this.oldData,t),i=Ut(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.position}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.options}),r=this.oldData.map(function(t){return t.position});return this.render(r.map(function(t,e){return{position:r[e],label:a[e],options:s[e]}})),this.store.map(function(t,e){return et(t,n[e],r[e])})}},yRegions:{layerClass:"y-regions",makeElements:function(t){var e=this;return t.map(function(t){return J(t.startPos,t.endPos,e.constants.width,t.label,{labelPos:t.options.labelPos})})},animateElements:function(t){var e=m(this.oldData,t),i=Ut(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.endPos}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.startPos}),r=t.map(function(t){return t.options}),o=this.oldData.map(function(t){return t.endPos}),l=this.oldData.map(function(t){return t.startPos});this.render(o.map(function(t,e){return{startPos:l[e],endPos:o[e],label:a[e],options:r[e]}}));var h=[];return this.store.map(function(t,e){h=h.concat(it(t,s[e],n[e],o[e]))}),h}},heatDomain:{layerClass:function(){return"heat-domain domain-"+this.constants.index},makeElements:function(t){var e=this,i=this.constants,n=i.index,a=i.colWidth,s=i.rowHeight,r=i.squareSize,o=i.radius,l=i.xTranslate,h=0;return this.serializedSubDomains=[],t.cols.map(function(t,i){1===i&&e.labels.push(Y("domain-name",l,-12,bt(n,!0).toUpperCase(),{fontSize:9})),t.map(function(t,i){if(t.fill){var n={"data-date":t.yyyyMmDd,"data-value":t.dataValue,"data-day":i},a=F("day",l,h,r,o,t.fill,n);e.serializedSubDomains.push(a)}h+=s}),h=0,l+=a}),this.serializedSubDomains},animateElements:function(t){if(t)return[]}},barGraph:{layerClass:function(){return"dataset-units dataset-bars dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="bar",this.units=t.yPositions.map(function(i,n){return K(t.xPositions[n],i,t.barWidth,e.color,t.labels[n],n,t.offsets[n],{zeroLine:t.zeroLine,barsWidth:t.barsWidth,minHeight:e.minHeight})}),this.units},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.offsets,a=t.labels,s=this.oldData.xPositions,r=this.oldData.yPositions,o=this.oldData.offsets,l=this.oldData.labels,h=m(s,e),u=Ut(h,2);s=u[0],e=u[1];var c=m(r,i),d=Ut(c,2);r=d[0],i=d[1];var p=m(o,n),f=Ut(p,2);o=f[0],n=f[1];var v=m(l,a),g=Ut(v,2);l=g[0],a=g[1],this.render({xPositions:s,yPositions:r,offsets:o,labels:a,zeroLine:this.oldData.zeroLine,barsWidth:this.oldData.barsWidth,barWidth:this.oldData.barWidth});var y=[];return this.store.map(function(a,s){y=y.concat(nt(a,e[s],i[s],t.barWidth,n[s],{zeroLine:t.zeroLine}))}),y}},lineGraph:{layerClass:function(){return"dataset-units dataset-line dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="dot",this.paths={},e.hideLine||(this.paths=Q(t.xPositions,t.yPositions,e.color,{heatline:e.heatline,regionFill:e.regionFill,spline:e.spline},{svgDefs:e.svgDefs,zeroLine:t.zeroLine})),this.units=[],e.hideDots||(this.units=t.yPositions.map(function(i,n){return $(t.xPositions[n],i,t.radius,e.color,e.valuesOverPoints?t.values[n]:"",n)})),Object.values(this.paths).concat(this.units)},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.values,a=this.oldData.xPositions,s=this.oldData.yPositions,r=this.oldData.values,o=m(a,e),l=Ut(o,2);a=l[0],e=l[1];var h=m(s,i),u=Ut(h,2);s=u[0],i=u[1];var c=m(r,n),d=Ut(c,2);r=d[0],n=d[1],this.render({xPositions:a,yPositions:s,values:n,zeroLine:this.oldData.zeroLine,radius:this.oldData.radius});var p=[];return Object.keys(this.paths).length&&(p=p.concat(st(this.paths,e,i,t.zeroLine,this.constants.spline))),this.units.length&&this.units.map(function(t,n){p=p.concat(at(t,e[n],i[n]))}),p}}},Le=function(t){function i(t,e){jt(this,i);var n=Vt(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="percentage",n.setup(),n}return Bt(i,t),Rt(i,[{key:"setMeasures",value:function(t){var e=this.measures;this.barOptions=t.barOptions||{};var i=this.barOptions;i.height=i.height||20,i.depth=i.depth||Kt,e.paddings.right=30,e.legendHeight=60,e.baseHeight=8*(i.height+.5*i.depth)}},{key:"setupComponents",value:function(){var t=this.state,e=[["percentageBars",{barHeight:this.barOptions.height,barDepth:this.barOptions.depth},function(){return{xPositions:t.xPositions,widths:t.widths,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=At.apply(void 0,Gt(t));return[t[0],e]}))}},{key:"calc",value:function(){var t=this;Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;e.xPositions=[],e.widths=[];var n=0;e.sliceTotals.map(function(i){var a=t.width*i/e.grandTotal;e.widths.push(a),e.xPositions.push(n),n+=a})}},{key:"makeDataByIndex",value:function(){}},{key:"bindTooltip",value:function(){var t=this,i=this.state;this.container.addEventListener("mousemove",function(n){var a=t.components.get("percentageBars").store,s=n.target;if(a.includes(s)){var r=a.indexOf(s),o=e(t.container),l=e(s),h=l.left-o.left+parseInt(s.getAttribute("width"))/2,u=l.top-o.top,c=(t.formattedLabels&&t.formattedLabels.length>0?t.formattedLabels[r]:t.state.labels[r])+": ",d=i.sliceTotals[r]/i.grandTotal;t.tip.setValues(h,u,{name:c,value:(100*d).toFixed(1)+"%"}),t.tip.showTip()}})}}]),i}(ke),Oe=function(t){function i(t,e){jt(this,i);var n=Vt(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="pie",n.initTimeout=0,n.init=1,n.setup(),n}return Bt(i,t),Rt(i,[{key:"configure",value:function(t){Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),this.mouseMove=this.mouseMove.bind(this),this.mouseLeave=this.mouseLeave.bind(this),this.hoverRadio=t.hoverRadio||.1,this.config.startAngle=t.startAngle||0,this.clockWise=t.clockWise||!1}},{key:"calc",value:function(){var t=this;Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;this.radius=this.height>this.width?this.center.x:this.center.y;var n=this.radius,a=this.clockWise,s=e.slicesProperties||[];e.sliceStrings=[],e.slicesProperties=[];var r=180-this.config.startAngle;e.sliceTotals.map(function(i,o){var l=r,h=i/e.grandTotal*360,u=h>180?1:0,c=a?-h:h,d=r+=c,f=p(l,n),v=p(d,n),g=t.init&&s[o],y=void 0,m=void 0;t.init?(y=g?g.startPosition:f,m=g?g.endPosition:f):(y=f,m=v);var b=360===h?_(y,m,t.center,t.radius,a,u):E(y,m,t.center,t.radius,a,u);e.sliceStrings.push(b),e.slicesProperties.push({startPosition:f,endPosition:v,value:i,total:e.grandTotal,startAngle:l,endAngle:d,angle:c})}),this.init=0}},{key:"setupComponents",value:function(){var t=this.state,e=[["pieSlices",{},function(){return{sliceStrings:t.sliceStrings,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=At.apply(void 0,Gt(t));return[t[0],e]}))}},{key:"calTranslateByAngle",value:function(t){var e=this.radius,i=this.hoverRadio,n=p(t.startAngle+t.angle/2,e);return"translate3d("+n.x*i+"px,"+n.y*i+"px,0)"}},{key:"hoverSlice",value:function(t,i,n,a){if(t){var s=this.colors[i];if(n){lt(t,this.calTranslateByAngle(this.state.slicesProperties[i])),t.style.fill=A(s,50);var r=e(this.svg),o=a.pageX-r.left+10,l=a.pageY-r.top-10,h=(this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels[i]:this.state.labels[i])+": ",u=(100*this.state.sliceTotals[i]/this.state.grandTotal).toFixed(1);this.tip.setValues(o,l,{name:h,value:u+"%"}),this.tip.showTip()}else lt(t,"translate3d(0,0,0)"),this.tip.hideTip(),t.style.fill=s}}},{key:"bindTooltip",value:function(){this.container.addEventListener("mousemove",this.mouseMove),this.container.addEventListener("mouseleave",this.mouseLeave)}},{key:"mouseMove",value:function(t){var e=t.target,i=this.components.get("pieSlices").store,n=this.curActiveSliceIndex,a=this.curActiveSlice;if(i.includes(e)){var s=i.indexOf(e);this.hoverSlice(a,n,!1),this.curActiveSlice=e,this.curActiveSliceIndex=s,this.hoverSlice(e,s,!0,t)}else this.mouseLeave()}},{key:"mouseLeave",value:function(){this.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,!1)}}]),i}(ke),Ne=function(t){function e(t,i){jt(this,e);var n=Vt(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i));n.type="heatmap",n.countLabel=i.countLabel||"";var a=["Sunday","Monday"],s=a.includes(i.startSubDomain)?i.startSubDomain:"Sunday";return n.startSubDomainIndex=a.indexOf(s),n.setup(),n}return Bt(e,t),Rt(e,[{key:"setMeasures",value:function(t){var e=this.measures;this.discreteDomains=0===t.discreteDomains?0:1,e.paddings.top=36,e.paddings.bottom=0,e.legendHeight=24,e.baseHeight=12*we+l(e);var i=this.data,n=this.discreteDomains?12:0;this.independentWidth=12*(gt(i.start,i.end)+n)+h(e)}},{key:"updateWidth",value:function(){var t=this.discreteDomains?12:0,e=this.state.noOfWeeks?this.state.noOfWeeks:52;this.baseWidth=12*(e+t)+h(this.measures)}},{key:"prepareData",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data;if(t.start&&t.end&&t.start>t.end)throw new Error("Start date cannot be greater than end date.");if(t.start||(t.start=new Date,t.start.setFullYear(t.start.getFullYear()-1)),t.end||(t.end=new Date),t.dataPoints=t.dataPoints||{},parseInt(Object.keys(t.dataPoints)[0])>1e5){var e={};Object.keys(t.dataPoints).forEach(function(i){var n=new Date(i*Ae);e[ft(n)]=t.dataPoints[i]}),t.dataPoints=e}return t}},{key:"calc",value:function(){var t=this.state;t.start=vt(this.data.start),t.end=vt(this.data.end),t.firstWeekStart=vt(t.start),t.noOfWeeks=gt(t.start,t.end),t.distribution=Et(Object.values(this.data.dataPoints),5),t.domainConfigs=this.getDomains()}},{key:"setupComponents",value:function(){var t=this,e=this.state,i=this.discreteDomains?0:1,n=e.domainConfigs.map(function(n,a){return["heatDomain",{index:n.index,colWidth:12,rowHeight:12,squareSize:10,radius:t.rawChartArgs.radius||0,xTranslate:12*e.domainConfigs.filter(function(t,e){return e1&&void 0!==arguments[1]?arguments[1]:"",i=[t.getMonth(),t.getFullYear()],n=i[0],a=i[1],s=kt(t),r={index:n,cols:[]};wt(e=vt(e)||xt(n,a),1);for(var o=gt(s,e),l=[],h=void 0,u=0;u2&&void 0!==arguments[2]&&arguments[2],n=this.state,a=vt(t),s=[],r=0;r=n.start&&a<=n.end;i||a.getMonth()!==e||!l?o.yyyyMmDd=ft(a):o=this.getSubDomainConfig(a),s.push(o)}return s}},{key:"getSubDomainConfig",value:function(t){var e=ft(t),i=this.data.dataPoints[e];return{yyyyMmDd:e,dataValue:i||0,fill:this.colors[_t(i,this.state.distribution)]}}}]),e}(xe),Se=function(t){function i(t,e){jt(this,i);var n=Vt(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.barOptions=e.barOptions||{},n.lineOptions=e.lineOptions||{},n.type=e.type||"line",n.init=1,n.setup(),n}return Bt(i,t),Rt(i,[{key:"setMeasures",value:function(){this.data.datasets.length<=1&&(this.config.showLegend=0,this.measures.paddings.bottom=30)}},{key:"configure",value:function(t){Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t);var e=t.axisOptions,n=void 0===e?{}:e,a=n||{},s=a.xAxis,r=a.yAxis;t.tooltipOptions=t.tooltipOptions||{},this.config.xAxisMode=s?s.xAxisMode:n.xAxisMode||"span",r&&r.length?this.config.yAxisConfig=r.map(function(t){return{yAxisMode:t.yAxisMode,id:t.id,position:t.position,title:t.title}}):(this.config.yAxisMode=r?r.yAxisMode:n.yAxisMode||"span",r&&r.id&&r.position&&(this.config.yAxisConfig=[r])),this.config.xIsSeries=n.xIsSeries||0,this.config.shortenYAxisNumbers=n.shortenYAxisNumbers||0,this.config.formatTooltipX=t.tooltipOptions.formatTooltipX,this.config.formatTooltipY=t.tooltipOptions.formatTooltipY,this.config.valuesOverPoints=t.valuesOverPoints}},{key:"prepareData",value:function(){return zt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data,this.type)}},{key:"prepareFirstData",value:function(){return It(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data)}},{key:"calc",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.calcXPositions(),t||this.calcYAxisParameters(this.getAllYValues(),"line"===this.type),this.makeDataByIndex()}},{key:"calcXPositions",value:function(){var t=this.state,e=this.data.labels;t.datasetLength=e.length,t.unitWidth=this.width/t.datasetLength,t.xOffset=t.unitWidth/2,t.xAxis={labels:e,positions:e.map(function(e,i){return u(t.xOffset+i*t.unitWidth)})}}},{key:"calcYAxisParameters",value:function(t){var e=this,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"false",n=void 0,a=void 0,s=void 0,r=void 0,o=void 0,l=void 0,h=void 0,u=void 0;if(u=[],l=this.config.yAxisMode||{},h=l.position?l.position:"left",t instanceof Array)n=Dt(t,i),a=this.height/Ot(n),s=Lt(n)*a,r=this.height-Tt(n)*s,this.state.yAxis={labels:n,positions:n.map(function(t){return r-t*a}),title:l.title||null,pos:h,scaleMultiplier:a,zeroLine:r};else{this.state.yAxis=[];for(var c in t)!function(c){var d=t[c];if(l=e.config.yAxisConfig.find(function(t){return c===t.id})||[],h=l.position?l.position:"left",n=Dt(d,i),a=e.height/Ot(n),s=Lt(n)*a,r=e.height-Tt(n)*s,o=n.map(function(t){return r-t*a}),u.push(c),e.state.yAxis.length>1){var p=[],f=e.state.yAxis[0];a=e.height/Ot(n),f.positions.forEach(function(t){p.push(Math.ceil(t/a))}),n=p.reverse(),r=e.height-Tt(n)*s,o=f.positions}e.state.yAxis.push({axisID:c||"left-axis",labels:n,title:l.title,pos:h,scaleMultiplier:a,zeroLine:r,positions:o})}(c);if(this.state.yAxis[1]&&this.state.yAxis[0].labels.length!==this.state.yAxis[1].labels.length){var d=[],p=this.state.yAxis.reduce(function(t,e){return t.length>e.labels.length?e:t},{length:1/0}),f=this.state.yAxis.reduce(function(t,e){return t.length1?n.find(function(t){return i===t.axisID}):t.yAxis[0]),Nt(e,n)})};t.barChartIndex=1,t.datasets=this.data.datasets.map(function(i,n){var a=i.values,s=i.cumulativeYs||[];return{name:i.name&&i.name.replace(/<|>|&/g,function(t){return"&"==t?"&":"<"==t?"<":">"}),index:n,barIndex:"bar"===i.chartType?t.barChartIndex++:t.barChartIndex,chartType:i.chartType,values:a,yPositions:e(a,i.axisID),id:i.axisID,cumulativeYs:s,cumulativeYPos:e(s,i.axisID)}})}},{key:"calcYExtremes",value:function(){var t=this.state;if(this.barOptions.stacked)return void(t.yExtremes=t.datasets[t.datasets.length-1].cumulativeYPos);t.yExtremes=new Array(t.datasetLength).fill(9999),t.datasets.map(function(e){e.yPositions.map(function(e,i){e1?e.find(function(t){return o===t.axisID}):t.yAxis[0]);var d=t.xAxis.positions.map(function(t){return t-u/2});l||(d=d.map(function(t){return t+c*a-c}));var p=new Array(t.datasetLength).fill("");this.config.valuesOverPoints&&(p=l&&s.index===t.datasets.length-1?s.cumulativeYs:s.values);var f=new Array(t.datasetLength).fill(0);return l&&(f=s.yPositions.map(function(t,e){return t-s.cumulativeYPos[e]})),{xPositions:d,yPositions:s.yPositions,offsets:f,labels:p,zeroLine:e.zeroLine,barsWidth:u,barWidth:c}}.bind(t)]}),s=n.map(function(e){var i=e.index;return["lineGraph-"+e.index,{index:i,color:t.colors[i],svgDefs:t.svgDefs,heatline:t.lineOptions.heatline,regionFill:t.lineOptions.regionFill,spline:t.lineOptions.spline,hideDots:t.lineOptions.hideDots,hideLine:t.lineOptions.hideLine,valuesOverPoints:t.config.valuesOverPoints},function(){var t=this.state,e=t.datasets[i],n=t.yAxis.length?t.yAxis.find(function(t){return e.id===t.axisID})||t.yAxis[0]:t.yAxis,a=n.positions[0]r(n)?t.mapTooltipXPosition(s):t.tip.hideTip()})}},{key:"mapTooltipXPosition",value:function(t){var e=this.state;if(e.yExtremes){var i=St(t,e.xAxis.positions,!0);if(i>=0){var n=this.dataByIndex[i];this.tip.setValues(n.xPos+this.tip.offset.x,n.yExtreme+this.tip.offset.y,{name:n.formattedLabel,value:""},n.values,i),this.tip.showTip()}}}},{key:"renderLegend",value:function(){var t=this,e=this.data;e.datasets.length>1&&(this.legendArea.textContent="",e.datasets.map(function(e,i){var n=j(100*i,"0",100,t.colors[i],e.name,t.config.truncateLegends);t.legendArea.appendChild(n)}))}},{key:"makeOverlay",value:function(){var t=this;if(this.init)return void(this.init=0);this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)}),this.overlayGuides=this.dataUnitComponents.map(function(t){return{type:t.unitType,overlay:void 0,units:t.units}}),void 0===this.state.currentIndex&&(this.state.currentIndex=this.state.datasetLength-1),this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];e.overlay=ce[e.type](i),t.drawArea.appendChild(e.overlay)})}},{key:"updateOverlayGuides",value:function(){this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)})}},{key:"bindOverlay",value:function(){var t=this;this.parent.addEventListener("data-select",function(){t.updateOverlay()})}},{key:"bindUnits",value:function(){var t=this;this.dataUnitComponents.map(function(e){e.units.map(function(e){e.addEventListener("click",function(){var i=e.getAttribute("data-point-index");t.setCurrentDataPoint(i)})})}),this.tip.container.addEventListener("click",function(){var e=t.tip.container.getAttribute("data-point-index");t.setCurrentDataPoint(e)})}},{key:"updateOverlay",value:function(){var t=this;this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];de[e.type](i,e.overlay)})}},{key:"onLeftArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex-1)}},{key:"onRightArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex+1)}},{key:"getDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.currentIndex,e=this.state;return{index:t,label:e.xAxis.labels[t],values:e.datasets.map(function(e){return e.values[t]})}}},{key:"setCurrentDataPoint",value:function(t){var e=this.state;(t=parseInt(t))<0&&(t=0),t>=e.xAxis.labels.length&&(t=e.xAxis.labels.length-1),t!==e.currentIndex&&(e.currentIndex=t,s(this.parent,"data-select",this.getDataPoint()))}},{key:"addDataPoint",value:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.state.datasetLength;Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"addDataPoint",this).call(this,t,e,n),this.data.labels.splice(n,0,t),this.data.datasets.map(function(t,i){t.values.splice(n,0,e[i])}),this.update(this.data)}},{key:"removeDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.datasetLength-1;this.data.labels.length<=1||(Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"removeDataPoint",this).call(this,t),this.data.labels.splice(t,1),this.data.datasets.map(function(e){e.values.splice(t,1)}),this.update(this.data))}},{key:"updateDataset",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;this.data.datasets[e].values=t,this.update(this.data)}},{key:"updateDatasets",value:function(t){this.data.datasets.map(function(e,i){t[i]&&(e.values=t[i])}),this.update(this.data)}}]),i}(xe),Ee=function(t){function i(t,e){jt(this,i);var n=Vt(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="donut",n.initTimeout=0,n.init=1,n.setup(),n}return Bt(i,t),Rt(i,[{key:"configure",value:function(t){Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),this.mouseMove=this.mouseMove.bind(this),this.mouseLeave=this.mouseLeave.bind(this),this.hoverRadio=t.hoverRadio||.1,this.config.startAngle=t.startAngle||0,this.clockWise=t.clockWise||!1,this.strokeWidth=t.strokeWidth||30}},{key:"calc",value:function(){var t=this;Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;this.radius=this.height>this.width?this.center.x-this.strokeWidth/2:this.center.y-this.strokeWidth/2;var n=this.radius,a=this.clockWise,s=e.slicesProperties||[];e.sliceStrings=[],e.slicesProperties=[];var r=180-this.config.startAngle;e.sliceTotals.map(function(i,o){var l=r,h=i/e.grandTotal*360,u=h>180?1:0,c=a?-h:h,d=r+=c,f=p(l,n),v=p(d,n),g=t.init&&s[o],y=void 0,m=void 0;t.init?(y=g?g.startPosition:f,m=g?g.endPosition:f):(y=f,m=v);var b=360===h?I(y,m,t.center,t.radius,t.clockWise,u):z(y,m,t.center,t.radius,t.clockWise,u);e.sliceStrings.push(b),e.slicesProperties.push({startPosition:f,endPosition:v,value:i,total:e.grandTotal,startAngle:l,endAngle:d,angle:c})}),this.init=0}},{key:"setupComponents",value:function(){var t=this.state,e=[["donutSlices",{},function(){return{sliceStrings:t.sliceStrings,colors:this.colors,strokeWidth:this.strokeWidth}}.bind(this)]];this.components=new Map(e.map(function(t){var e=At.apply(void 0,Gt(t));return[t[0],e]}))}},{key:"calTranslateByAngle",value:function(t){var e=this.radius,i=this.hoverRadio,n=p(t.startAngle+t.angle/2,e);return"translate3d("+n.x*i+"px,"+n.y*i+"px,0)"}},{key:"hoverSlice",value:function(t,i,n,a){if(t){var s=this.colors[i];if(n){lt(t,this.calTranslateByAngle(this.state.slicesProperties[i])),t.style.stroke=A(s,50);var r=e(this.svg),o=a.pageX-r.left+10,l=a.pageY-r.top-10,h=(this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels[i]:this.state.labels[i])+": ",u=(100*this.state.sliceTotals[i]/this.state.grandTotal).toFixed(1);this.tip.setValues(o,l,{name:h,value:u+"%"}),this.tip.showTip()}else lt(t,"translate3d(0,0,0)"),this.tip.hideTip(),t.style.stroke=s}}},{key:"bindTooltip",value:function(){this.container.addEventListener("mousemove",this.mouseMove),this.container.addEventListener("mouseleave",this.mouseLeave)}},{key:"mouseMove",value:function(t){var e=t.target,i=this.components.get("donutSlices").store,n=this.curActiveSliceIndex,a=this.curActiveSlice;if(i.includes(e)){var s=i.indexOf(e);this.hoverSlice(a,n,!1),this.curActiveSlice=e,this.curActiveSliceIndex=s,this.hoverSlice(e,s,!0,t)}else this.mouseLeave()}},{key:"mouseLeave",value:function(){this.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,!1)}}]),i}(ke),_e={bar:Se,line:Se,percentage:Le,heatmap:Ne,pie:Oe,donut:Ee},ze=function t(e,i){return jt(this,t),Wt(i.type,e,i)},Ie=Object.freeze({Chart:ze,PercentageChart:Le,PieChart:Oe,Heatmap:Ne,AxisChart:Se}),He={};return He.NAME="Frappe Charts",He.VERSION="1.6.2",He=Object.assign({},He,Ie)}(); +var frappe=function(){"use strict";function t(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function e(t){var e=t.getBoundingClientRect();return{top:e.top+(document.documentElement.scrollTop||document.body.scrollTop),left:e.left+(document.documentElement.scrollLeft||document.body.scrollLeft)}}function i(t){return null===t.offsetParent}function n(t){var e=t.getBoundingClientRect();return e.top>=0&&e.left>=0&&e.bottom<=(window.innerHeight||document.documentElement.clientHeight)&&e.right<=(window.innerWidth||document.documentElement.clientWidth)}function a(t){var e=window.getComputedStyle(t),i=parseFloat(e.paddingLeft)+parseFloat(e.paddingRight);return t.clientWidth-i}function s(t,e,i){var n=document.createEvent("HTMLEvents");n.initEvent(e,!0,!0);for(var a in i)n[a]=i[a];return t.dispatchEvent(n)}function r(t){return t.titleHeight+t.margins.top+t.paddings.top}function o(t){return t.margins.left+t.paddings.left}function l(t){return t.margins.top+t.margins.bottom+t.paddings.top+t.paddings.bottom+t.titleHeight+t.legendHeight}function h(t){return t.margins.left+t.margins.right+t.paddings.left+t.paddings.right}function u(t){return parseFloat(t.toFixed(2))}function c(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]&&arguments[3];i||(i=n?t[0]:t[t.length-1]);var a=new Array(Math.abs(e)).fill(i);return t=n?a.concat(t):t.concat(a)}function d(t,e){return(t+"").length*e}function p(t,e){return{x:Math.sin(t*te)*e,y:Math.cos(t*te)*e}}function f(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return!Number.isNaN(t)&&(void 0!==t&&(!!Number.isFinite(t)&&!(e&&t<0)))}function v(t){return Number(Math.round(t+"e4")+"e-4")}function g(t){var e=void 0,i=void 0,n=void 0;if(t instanceof Date)return new Date(t.getTime());if("object"!==(void 0===t?"undefined":Ft(t))||null===t)return t;e=Array.isArray(t)?[]:{};for(n in t)i=t[n],e[n]=g(i);return e}function y(t,e){var i=void 0,n=void 0;return t<=e?(i=e-t,n=t):(i=t-e,n=e),[i,n]}function m(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length-t.length;return i>0?t=c(t,i):e=c(e,i),[t,e]}function b(t,e){if(t)return t.length>e?t.slice(0,e-3)+"...":t}function x(t){var e=void 0;if("number"==typeof t)e=t;else if("string"==typeof t&&(e=Number(t),Number.isNaN(e)))return t;var i=Math.floor(Math.log10(Math.abs(e)));if(i<=2)return e;var n=Math.floor(i/3),a=Math.pow(10,i-3*n)*+(e/Math.pow(10,i)).toFixed(1);return Math.round(100*a)/100+" "+["","K","M","B","T"][n]}function k(t,e){for(var i=[],n=0;n255?255:t<0?0:t}function A(t,e){var i=ne(t),n=!1;"#"==i[0]&&(i=i.slice(1),n=!0);var a=parseInt(i,16),s=w((a>>16)+e),r=w((a>>8&255)+e),o=w((255&a)+e);return(n?"#":"")+(o|r<<8|s<<16).toString(16)}function P(t){var e=/(^\s*)(rgb|hsl)(a?)[(]\s*([\d.]+\s*%?)\s*,\s*([\d.]+\s*%?)\s*,\s*([\d.]+\s*%?)\s*(?:,\s*([\d.]+)\s*)?[)]$/i;return/(^\s*)(#)((?:[A-Fa-f0-9]{3}){1,2})$/i.test(t)||e.test(t)}function M(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function C(t,e){var i=document.createElementNS("http://www.w3.org/2000/svg",t);for(var n in e){var a=e[n];if("inside"===n)M(a).appendChild(i);else if("around"===n){var s=M(a);s.parentNode.insertBefore(i,s),i.appendChild(s)}else"styles"===n?"object"===(void 0===a?"undefined":Ft(a))&&Object.keys(a).map(function(t){i.style[t]=a[t]}):("className"===n&&(n="class"),"innerHTML"===n?i.textContent=a:i.setAttribute(n,a))}return i}function D(t,e){return C("linearGradient",{inside:t,id:e,x1:0,x2:0,y1:0,y2:1})}function T(t,e,i,n){return C("stop",{inside:t,style:"stop-color: "+i,offset:e,"stop-opacity":n})}function L(t,e,i,n){return C("svg",{className:e,inside:t,width:i,height:n})}function O(t){return C("defs",{inside:t})}function N(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,n={className:t,transform:e};return i&&(n.inside=i),C("g",n)}function S(t){return C("path",{className:arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",d:t,styles:{stroke:arguments.length>2&&void 0!==arguments[2]?arguments[2]:"none",fill:arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none","stroke-width":arguments.length>4&&void 0!==arguments[4]?arguments[4]:2}})}function E(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=i.x+t.x,o=i.y+t.y,l=i.x+e.x,h=i.y+e.y;return"M"+i.x+" "+i.y+"\n\t\tL"+r+" "+o+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+h+" z"}function _(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=i.x+t.x,o=i.y+t.y,l=i.x+e.x,h=2*i.y,u=i.y+e.y;return"M"+i.x+" "+i.y+"\n\t\tL"+r+" "+o+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+h+" z\n\t\tL"+r+" "+h+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+u+" z"}function z(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=i.x+t.x,o=i.y+t.y,l=i.x+e.x,h=i.y+e.y;return"M"+r+" "+o+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+h}function I(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=i.x+t.x,o=i.y+t.y,l=i.x+e.x,h=2*n+o,u=i.y+t.y;return"M"+r+" "+o+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+h+"\n\t\tM"+r+" "+h+"\n\t\tA "+n+" "+n+" 0 "+s+" "+(a?1:0)+"\n\t\t"+l+" "+u}function H(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n="path-fill-gradient-"+e+"-"+(i?"lighter":"default"),a=D(t,n),s=[1,.6,.2];return i&&(s=[.4,.2,0]),T(a,"0%",e,s[0]),T(a,"50%",e,s[1]),T(a,"100%",e,s[2]),n}function W(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:Kt,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"none";return C("rect",{className:"percentage-bar",x:t,y:e,width:i,height:n,fill:s,styles:{stroke:A(s,-25),"stroke-dasharray":"0, "+(n+i)+", "+i+", "+n,"stroke-width":a}})}function F(t,e,i,n,a){var s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"none",r=arguments.length>6&&void 0!==arguments[6]?arguments[6]:{},o={className:t,x:e,y:i,width:n,height:n,rx:a,fill:s};return Object.keys(r).map(function(t){o[t]=r[t]}),C("rect",o)}function j(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4];a=arguments.length>5&&void 0!==arguments[5]&&arguments[5]?b(a,re):a;var s={className:"legend-bar",x:0,y:0,width:i,height:"2px",fill:n},r=C("text",{className:"legend-dataset-text",x:0,y:0,dy:2*le+"px","font-size":1.2*le+"px","text-anchor":"start",fill:ue,innerHTML:a}),o=C("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(C("rect",s)),o.appendChild(r),o}function R(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4];a=arguments.length>5&&void 0!==arguments[5]&&arguments[5]?b(a,re):a;var s={className:"legend-dot",cx:0,cy:0,r:i,fill:n},r=C("text",{className:"legend-dataset-text",x:0,y:0,dx:le+"px",dy:le/3+"px","font-size":1.2*le+"px","text-anchor":"start",fill:ue,innerHTML:a}),o=C("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(C("circle",s)),o.appendChild(r),o}function Y(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=a.fontSize||le;return C("text",{className:t,x:e,y:i,dy:(void 0!==a.dy?a.dy:s/2)+"px","font-size":s+"px",fill:a.fill||ue,"text-anchor":a.textAnchor||"start",innerHTML:n})}function B(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=he);var s=C("line",{className:"line-vertical "+a.className,x1:0,x2:0,y1:i,y2:n,styles:{stroke:a.stroke}}),r=C("text",{x:0,y:i>n?i+se:i-se-le,dy:le+"px","font-size":le+"px","text-anchor":"middle",innerHTML:e+""}),o=C("g",{transform:"translate("+t+", 0)"});return o.appendChild(s),o.appendChild(r),o}function V(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=he),a.lineType||(a.lineType=""),a.alignment||(a.alignment="left"),a.shortenNumbers&&(e=x(e));var s=C("line",{className:"line-horizontal "+a.className+("dashed"===a.lineType?"dashed":""),x1:i,x2:n,y1:0,y2:0,styles:{stroke:a.stroke}}),r=C("text",{x:"left"===a.alignment?i-se:n+4*se,y:0,dy:le/2-2+"px","font-size":le+"px","text-anchor":i3&&void 0!==arguments[3]?arguments[3]:{};f(t)||(t=0),n.pos||(n.pos="left"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=he),n.className||(n.className="");var a=-1*ae,s="span"===n.mode?i+ae:0;"tick"===n.mode&&"right"===n.pos&&(a=i+ae,s=i);var r="left"===n.pos?-1*n.offset:n.offset;return a+=r,s+=r,V(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType,alignment:n.pos,shortenNumbers:n.shortenNumbers})}function q(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};f(t)||(t=0),n.pos||(n.pos="bottom"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=he),n.className||(n.className="");var a=i+ae,s="span"===n.mode?-1*ae:i;return"tick"===n.mode&&"top"===n.pos&&(a=-1*ae,s=0),B(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType})}function X(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};n.labelPos||(n.labelPos="right");var a=C("text",{className:"chart-label",x:"left"===n.labelPos?se:i-d(e,5)-se,y:0,dy:le/-2+"px","font-size":le+"px","text-anchor":"start",innerHTML:e+""}),s=V(t,"",0,i,{stroke:n.stroke||he,className:n.className||"",lineType:n.lineType});return s.appendChild(a),s}function J(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=t-e,r=C("rect",{className:"bar mini",styles:{fill:"rgba(228, 234, 239, 0.49)",stroke:he,"stroke-dasharray":i+", "+s},x:0,y:0,width:i,height:s});a.labelPos||(a.labelPos="right");var o=C("text",{className:"chart-label",x:"left"===a.labelPos?se:i-d(n+"",4.5)-se,y:0,dy:le/-2+"px","font-size":le+"px","text-anchor":"start",innerHTML:n+""}),l=C("g",{transform:"translate(0, "+e+")"});return l.appendChild(r),l.appendChild(o),l}function K(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,o=arguments.length>7&&void 0!==arguments[7]?arguments[7]:{},l=y(e,o.zeroLine),h=Ut(l,2),u=h[0],c=h[1];c-=r,0===u&&(u=o.minHeight,c-=o.minHeight),f(t)||(t=0),f(c)||(c=0),f(u,!0)||(u=0),f(i,!0)||(i=0);var d=C("rect",{className:"bar mini",style:"fill: "+n,"data-point-index":s,x:t,y:c,width:i,height:u});if((a+="")||a.length){d.setAttribute("y",0),d.setAttribute("x",0);var p=C("text",{className:"data-point-value",x:i/2,y:0,dy:le/2*-1+"px","font-size":le+"px","text-anchor":"middle",innerHTML:a}),v=C("g",{"data-point-index":s,transform:"translate("+t+", "+c+")"});return v.appendChild(d),v.appendChild(p),v}return d}function $(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=C("circle",{style:"fill: "+n,"data-point-index":s,cx:t,cy:e,r:i});if((a+="")||a.length){r.setAttribute("cy",0),r.setAttribute("cx",0);var o=C("text",{className:"data-point-value",x:0,y:0,dy:le/2*-1-i+"px","font-size":le+"px","text-anchor":"middle",innerHTML:a}),l=C("g",{"data-point-index":s,transform:"translate("+t+", "+e+")"});return l.appendChild(r),l.appendChild(o),l}return r}function Q(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=e.map(function(e,i){return t[i]+","+e}).join("L");n.spline&&(s=k(t,e));var r=S("M"+s,"line-graph-path",i);if(n.heatline){var o=H(a.svgDefs,i);r.style.stroke="url(#"+o+")"}var l={path:r};if(n.regionFill){var h=H(a.svgDefs,i,!0),u="M"+t[0]+","+a.zeroLine+"L"+s+"L"+t.slice(-1)[0]+","+a.zeroLine;l.region=S(u,"region-fill","none","url(#"+h+")")}return l}function Z(t,e,i,n){var a="string"==typeof e?e:e.join(", ");return[t,{transform:i.join(", ")},n,ye,"translate",{transform:a}]}function tt(t,e,i){return Z(t,[i,0],[e,0],ve)}function et(t,e,i){return Z(t,[0,i],[0,e],ve)}function it(t,e,i,n){var a=e-i,s=t.childNodes[0];return[[s,{height:a,"stroke-dasharray":s.getAttribute("width")+", "+a},ve,ye],Z(t,[0,n],[0,i],ve)]}function nt(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,s=y(i,(arguments.length>5&&void 0!==arguments[5]?arguments[5]:{}).zeroLine),r=Ut(s,2),o=r[0],l=r[1];return l-=a,"rect"!==t.nodeName?[[t.childNodes[0],{width:n,height:o},pe,ye],Z(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,l],ve)]:[[t,{width:n,height:o,x:e,y:l},pe,ye]]}function at(t,e,i){return"circle"!==t.nodeName?[Z(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,i],ve)]:[[t,{cx:e,cy:i},pe,ye]]}function st(t,e,i,n,a){var s=[],r=i.map(function(t,i){return e[i]+","+t}).join("L");a&&(r=k(e,i));var o=[t.path,{d:"M"+r},fe,ye];if(s.push(o),t.region){var l=e[0]+","+n+"L",h="L"+e.slice(-1)[0]+", "+n,u=[t.region,{d:"M"+l+r+h},fe,ye];s.push(u)}return s}function rt(t,e){return[t,{d:e},pe,ye]}function ot(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"linear",a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:void 0,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},r=t.cloneNode(!0),o=t.cloneNode(!0);for(var l in e){var h=void 0;h="transform"===l?document.createElementNS("http://www.w3.org/2000/svg","animateTransform"):document.createElementNS("http://www.w3.org/2000/svg","animate");var u=s[l]||t.getAttribute(l),c=e[l],d={attributeName:l,from:u,to:c,begin:"0s",dur:i/1e3+"s",values:u+";"+c,keySplines:me[n],keyTimes:"0;1",calcMode:"spline",fill:"freeze"};a&&(d.type=a);for(var p in d)h.setAttribute(p,d[p]);r.appendChild(h),a?o.setAttribute(l,"translate("+c+")"):o.setAttribute(l,c)}return[r,o]}function lt(t,e){t.style.transform=e,t.style.webkitTransform=e,t.style.msTransform=e,t.style.mozTransform=e,t.style.oTransform=e}function ht(t,e){var i=[],n=[];e.map(function(t){var e=t[0],a=e.parentNode,s=void 0,r=void 0;t[0]=e;var o=ot.apply(void 0,Gt(t)),l=Ut(o,2);s=l[0],r=l[1],i.push(r),n.push([s,a]),a&&a.replaceChild(s,e)});var a=t.cloneNode(!0);return n.map(function(t,n){t[1]&&(t[1].replaceChild(i[n],t[0]),e[n][0]=i[n])}),a}function ut(t,e,i){if(0!==i.length){var n=ht(e,i);e.parentNode==t&&(t.removeChild(e),t.appendChild(n)),setTimeout(function(){n.parentNode==t&&(t.removeChild(n),t.appendChild(e))},ge)}}function ct(t,e){var i=document.createElement("a");i.style="display: none";var n=new Blob(e,{type:"image/svg+xml; charset=utf-8"}),a=window.URL.createObjectURL(n);i.href=a,i.download=t,document.body.appendChild(i),i.click(),setTimeout(function(){document.body.removeChild(i),window.URL.revokeObjectURL(a)},300)}function dt(e){var i=e.cloneNode(!0);i.classList.add("chart-container"),i.setAttribute("xmlns","http://www.w3.org/2000/svg"),i.setAttribute("xmlns:xlink","http://www.w3.org/1999/xlink");var n=t.create("style",{innerHTML:be});i.insertBefore(n,i.firstChild);var a=t.create("div");return a.appendChild(i),a.innerHTML}function pt(t){var e=new Date(t);return e.setMinutes(e.getMinutes()-e.getTimezoneOffset()),e}function ft(t){var e=t.getDate(),i=t.getMonth()+1;return[t.getFullYear(),(i>9?"":"0")+i,(e>9?"":"0")+e].join("-")}function vt(t){return new Date(t.getTime())}function gt(t,e){var i=kt(t);return Math.ceil(yt(i,e)/we)}function yt(t,e){var i=Pe*Ae;return(pt(e)-pt(t))/i}function mt(t,e){return t.getMonth()===e.getMonth()&&t.getFullYear()===e.getFullYear()}function bt(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1],i=Me[t];return e?i.slice(0,3):i}function xt(t,e){return new Date(e,t+1,0)}function kt(t){var e=vt(t),i=e.getDay();return 0!==i&&wt(e,-1*i),e}function wt(t,e){t.setDate(t.getDate()+e)}function At(t,e,i){var n=Object.keys(Te).filter(function(e){return t.includes(e)}),a=Te[n[0]];return Object.assign(a,{constants:e,getData:i}),new De(a)}function Pt(t){if(0===t)return[0,0];if(isNaN(t))return{mantissa:-6755399441055744,exponent:972};var e=t>0?1:-1;if(!isFinite(t))return{mantissa:4503599627370496*e,exponent:972};t=Math.abs(t);var i=Math.floor(Math.log10(t));return[e*(t/Math.pow(10,i)),i]}function Mt(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=Math.ceil(t),n=Math.floor(e),a=i-n,s=a,r=1;a>5&&(a%2!=0&&(a=++i-n),s=a/2,r=2),a<=2&&(r=a/(s=4)),0===a&&(s=5,r=1);for(var o=[],l=0;l<=s;l++)o.push(n+r*l);return o}function Ct(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=Pt(t),n=Ut(i,2),a=n[0],s=n[1],r=e?e/Math.pow(10,s):0,o=Mt(a=a.toFixed(6),r);return o=o.map(function(t){return s<0?t/Math.pow(10,-s):t*Math.pow(10,s)})}function Dt(t){function e(t,e){for(var i=Ct(t),n=i[1]-i[0],a=0,s=1;a1&&void 0!==arguments[1]&&arguments[1],n=Math.max.apply(Math,Gt(t)),a=Math.min.apply(Math,Gt(t)),s=[];if(n>=0&&a>=0)Pt(n)[1],s=i?Ct(n,a):Ct(n);else if(n>0&&a<0){var r=Math.abs(a);n>=r?(Pt(n)[1],s=e(n,r)):(Pt(r)[1],s=e(r,n).reverse().map(function(t){return-1*t}))}else if(n<=0&&a<=0){var o=Math.abs(a),l=Math.abs(n);Pt(o)[1],s=(s=i?Ct(o,l):Ct(o)).reverse().map(function(t){return-1*t})}return s}function Tt(t){var e=Lt(t);return t.indexOf(0)>=0?t.indexOf(0):t[0]>0?-1*t[0]/e:-1*t[t.length-1]/e+(t.length-1)}function Lt(t){return t[1]-t[0]}function Ot(t){return t[t.length-1]-t[0]}function Nt(t,e){return u(e.zeroLine-t*e.scaleMultiplier)}function St(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n=e.reduce(function(e,i){return Math.abs(i-t)i?n.slice(0,i):c(n,i-n.length,0),t.values=n}else t.values=a;t.chartType||(Jt.includes(e),t.chartType=e)}),t.yRegions&&t.yRegions.map(function(t){if(t.end1&&void 0!==arguments[1]?arguments[1]:[],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=t/e.length;n<=0&&(n=1);var a=n/$t,s=void 0;if(i){var r=Math.max.apply(Math,Gt(e.map(function(t){return t.length})));s=Math.ceil(r/a)}return e.map(function(t,e){return(t+="").length>a&&(i?e%s!=0&&(t=""):t=a-3>0?t.slice(0,a-3)+" ...":t.slice(0,a)+".."),t})}function Wt(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"line",e=arguments[1],i=arguments[2];return"axis-mixed"===t?(i.type="line",new Se(e,i)):_e[t]?new _e[t](e,i):void console.error("Undefined chart type: "+t)}!function(t,e){void 0===e&&(e={});var i=e.insertAt;if(t&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css","top"===i&&n.firstChild?n.insertBefore(a,n.firstChild):n.appendChild(a),a.styleSheet?a.styleSheet.cssText=t:a.appendChild(document.createTextNode(t))}}('.chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ol,.graph-svg-tip ul{padding-left:0;display:-webkit-box;display:-ms-flexbox;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:" ";border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}');var Ft="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},jt=(function(){function t(t){this.value=t}function e(e){function i(t,e){return new Promise(function(i,a){var o={key:t,arg:e,resolve:i,reject:a,next:null};r?r=r.next=o:(s=r=o,n(t,e))})}function n(i,s){try{var r=e[i](s),o=r.value;o instanceof t?Promise.resolve(o.value).then(function(t){n("next",t)},function(t){n("throw",t)}):a(r.done?"return":"normal",r.value)}catch(t){a("throw",t)}}function a(t,e){switch(t){case"return":s.resolve({value:e,done:!0});break;case"throw":s.reject(e);break;default:s.resolve({value:e,done:!1})}(s=s.next)?n(s.key,s.arg):r=null}var s,r;this._invoke=i,"function"!=typeof e.return&&(this.return=void 0)}"function"==typeof Symbol&&Symbol.asyncIterator&&(e.prototype[Symbol.asyncIterator]=function(){return this}),e.prototype.next=function(t){return this._invoke("next",t)},e.prototype.throw=function(t){return this._invoke("throw",t)},e.prototype.return=function(t){return this._invoke("return",t)}}(),function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}),Rt=function(){function t(t,e){for(var i=0;i\n\t\t\t\t
      \n\t\t\t\t
      '}),this.hideTip(),this.title=this.container.querySelector(".title"),this.dataPointList=this.container.querySelector(".data-point-list"),this.parent.addEventListener("mouseleave",function(){e.hideTip()})}},{key:"fill",value:function(){var e=this,i=void 0;this.index&&this.container.setAttribute("data-point-index",this.index),i=this.titleValueFirst?""+this.titleValue+""+this.titleName:this.titleName+""+this.titleValue+"",this.title.innerHTML=i,this.dataPointList.innerHTML="",this.listValues.map(function(i,n){var a=e.colors[n]||"black",s=0===i.formatted||i.formatted?i.formatted:i.value,r=t.create("li",{styles:{"border-top":"3px solid "+a},innerHTML:''+(0===s||s?s:"")+"\n\t\t\t\t\t"+(i.title?i.title:"")});e.dataPointList.appendChild(r)})}},{key:"calcPosition",value:function(){var t=this.container.offsetWidth;this.top=this.y-this.container.offsetHeight-5,this.left=this.x-t/2;var e=this.parent.offsetWidth-t,i=this.container.querySelector(".svg-pointer");if(this.left<0)i.style.left="calc(50% - "+-1*this.left+"px)",this.left=0;else if(this.left>e){var n="calc(50% + "+(this.left-e)+"px)";i.style.left=n,this.left=e}else i.style.left="50%"}},{key:"setValues",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:-1;this.titleName=i.name,this.titleValue=i.value,this.listValues=n,this.x=t,this.y=e,this.titleValueFirst=i.valueFirst||0,this.index=a,this.refresh()}},{key:"hideTip",value:function(){this.container.style.top="0px",this.container.style.left="0px",this.container.style.opacity="0"}},{key:"showTip",value:function(){this.container.style.top=this.top+"px",this.container.style.left=this.left+"px",this.container.style.opacity="1"}}]),e}(),ie={"light-blue":"#7cd6fd",blue:"#5e64ff",violet:"#743ee2",red:"#ff5858",orange:"#ffa00a",yellow:"#feef72",green:"#28a745","light-green":"#98d85b",purple:"#b554ff",magenta:"#ffa3ef",black:"#36114C",grey:"#bdd3e6","light-grey":"#f0f4f7","dark-grey":"#b8c2cc"},ne=function(t){return/rgb[a]{0,1}\([\d, ]+\)/gim.test(t)?/\D+(\d*)\D+(\d*)\D+(\d*)/gim.exec(t).map(function(t,e){return 0!==e?Number(t).toString(16):"#"}).reduce(function(t,e){return""+t+e}):ie[t]||t},ae=6,se=4,re=15,oe=120,le=10,he="#dadada",ue="#555b51",ce={bar:function(t){var e=void 0;"rect"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode();return i.style.fill="#000000",i.style.opacity="0.4",e&&i.setAttribute("transform",e),i},dot:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i},heat_square:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i}},de={bar:function(t,e){var i=void 0;"rect"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["x","y","width","height"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},dot:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},heat_square:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)}},pe=350,fe=350,ve=pe,ge=250,ye="easein",me={ease:"0.25 0.1 0.25 1",linear:"0 0 1 1",easein:"0.1 0.8 0.2 1",easeout:"0 0 0.58 1",easeinout:"0.42 0 0.58 1"},be=".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}",xe=function(){function e(t,i){if(jt(this,e),i=g(i),this.parent="string"==typeof t?document.querySelector(t):t,!(this.parent instanceof HTMLElement))throw new Error("No `parent` element to render on was provided.");this.rawChartArgs=i,this.title=i.title||"",this.type=i.type||"",this.realData=this.prepareData(i.data),this.data=this.prepareFirstData(this.realData),this.colors=this.validateColors(i.colors,this.type),this.config={showTooltip:1,showLegend:1,isNavigable:i.isNavigable||0,animate:void 0!==i.animate?i.animate:1,truncateLegends:i.truncateLegends||1},this.measures=JSON.parse(JSON.stringify(qt));var n=this.measures;this.setMeasures(i),this.title.length||(n.titleHeight=0),this.config.showLegend||(n.legendHeight=0),this.argHeight=i.height||n.baseHeight,this.state={},this.options={},this.initTimeout=Xt,this.config.isNavigable&&(this.overlays=[]),this.configure(i)}return Rt(e,[{key:"prepareData",value:function(t){return t}},{key:"prepareFirstData",value:function(t){return t}},{key:"validateColors",value:function(t,e){var i=[];return(t=(t||[]).concat(Zt[e])).forEach(function(t){var e=ne(t);P(e)?i.push(e):console.warn('"'+t+'" is not a valid color.')}),i}},{key:"setMeasures",value:function(){}},{key:"configure",value:function(){var t=this,e=this.argHeight;this.baseHeight=e,this.height=e-l(this.measures),this.boundDrawFn=function(){return t.draw(!0)},ResizeObserver&&(this.resizeObserver=new ResizeObserver(this.boundDrawFn),this.resizeObserver.observe(this.parent)),window.addEventListener("resize",this.boundDrawFn),window.addEventListener("orientationchange",this.boundDrawFn)}},{key:"destroy",value:function(){this.resizeObserver&&this.resizeObserver.disconnect(),window.removeEventListener("resize",this.boundDrawFn),window.removeEventListener("orientationchange",this.boundDrawFn)}},{key:"setup",value:function(){this.makeContainer(),this.updateWidth(),this.makeTooltip(),this.draw(!1,!0)}},{key:"makeContainer",value:function(){this.parent.innerHTML="";var e={inside:this.parent,className:"chart-container"};this.independentWidth&&(e.styles={width:this.independentWidth+"px"}),this.container=t.create("div",e)}},{key:"makeTooltip",value:function(){this.tip=new ee({parent:this.container,colors:this.colors}),this.bindTooltip()}},{key:"bindTooltip",value:function(){}},{key:"draw",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],n=arguments.length>1&&void 0!==arguments[1]&&arguments[1];e&&i(this.parent)||(this.updateWidth(),this.calc(e),this.makeChartArea(),this.setupComponents(),this.components.forEach(function(e){return e.setup(t.drawArea)}),this.render(this.components,!1),n&&(this.data=this.realData,setTimeout(function(){t.update(t.data)},this.initTimeout)),this.renderLegend(),this.setupNavigation(n))}},{key:"calc",value:function(){}},{key:"updateWidth",value:function(){this.baseWidth=a(this.parent),this.width=this.baseWidth-h(this.measures)}},{key:"makeChartArea",value:function(){this.svg&&this.container.removeChild(this.svg);var t=this.measures;this.svg=L(this.container,"frappe-chart chart",this.baseWidth,this.baseHeight),this.svgDefs=O(this.svg),this.title.length&&(this.titleEL=Y("title",t.margins.left,t.margins.top,this.title,{fontSize:t.titleFontSize,fill:"#666666",dy:t.titleFontSize}));var e=r(t);this.drawArea=N(this.type+"-chart chart-draw-area","translate("+o(t)+", "+e+")"),this.config.showLegend&&(e+=this.height+t.paddings.bottom,this.legendArea=N("chart-legend","translate("+o(t)+", "+e+")")),this.title.length&&this.svg.appendChild(this.titleEL),this.svg.appendChild(this.drawArea),this.config.showLegend&&this.svg.appendChild(this.legendArea),this.updateTipOffset(o(t),r(t))}},{key:"updateTipOffset",value:function(t,e){this.tip.offset={x:t,y:e}}},{key:"setupComponents",value:function(){this.components=new Map}},{key:"update",value:function(t){t||console.error("No data to update."),this.data=this.prepareData(t),this.calc(),this.render(this.components,this.config.animate),this.renderLegend()}},{key:"render",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.components,i=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.config.isNavigable&&this.overlays.map(function(t){return t.parentNode.removeChild(t)});var n=[];e.forEach(function(t){n=n.concat(t.update(i))}),n.length>0?(ut(this.container,this.svg,n),setTimeout(function(){e.forEach(function(t){return t.make()}),t.updateNav()},400)):(e.forEach(function(t){return t.make()}),this.updateNav())}},{key:"updateNav",value:function(){this.config.isNavigable&&(this.makeOverlay(),this.bindUnits())}},{key:"renderLegend",value:function(){}},{key:"setupNavigation",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.config.isNavigable&&e&&(this.bindOverlay(),this.keyActions={13:this.onEnterKey.bind(this),37:this.onLeftArrow.bind(this),38:this.onUpArrow.bind(this),39:this.onRightArrow.bind(this),40:this.onDownArrow.bind(this)},document.addEventListener("keydown",function(e){n(t.container)&&(e=e||window.event,t.keyActions[e.keyCode]&&t.keyActions[e.keyCode]())}))}},{key:"makeOverlay",value:function(){}},{key:"updateOverlay",value:function(){}},{key:"bindOverlay",value:function(){}},{key:"bindUnits",value:function(){}},{key:"onLeftArrow",value:function(){}},{key:"onRightArrow",value:function(){}},{key:"onUpArrow",value:function(){}},{key:"onDownArrow",value:function(){}},{key:"onEnterKey",value:function(){}},{key:"addDataPoint",value:function(){}},{key:"removeDataPoint",value:function(){}},{key:"getDataPoint",value:function(){}},{key:"setCurrentDataPoint",value:function(){}},{key:"updateDataset",value:function(){}},{key:"export",value:function(){var t=dt(this.svg);ct(this.title||"Chart",[t])}}]),e}(),ke=function(t){function e(t,i){return jt(this,e),Vt(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i))}return Bt(e,t),Rt(e,[{key:"configure",value:function(t){Yt(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"configure",this).call(this,t),this.config.formatTooltipY=(t.tooltipOptions||{}).formatTooltipY,this.config.maxSlices=t.maxSlices||20,this.config.maxLegendPoints=t.maxLegendPoints||20}},{key:"calc",value:function(){var t=this,e=this.state,i=this.config.maxSlices;e.sliceTotals=[];var n=this.data.labels.map(function(e,i){var n=0;return t.data.datasets.map(function(t){n+=t.values[i]}),[n,e]}).filter(function(t){return t[0]>=0}),a=n;if(n.length>i){n.sort(function(t,e){return e[0]-t[0]}),a=n.slice(0,i-1);var s=0;n.slice(i-1).map(function(t){s+=t[0]}),a.push([s,"Rest"]),this.colors[i-1]="grey"}e.labels=[],a.map(function(t){e.sliceTotals.push(v(t[0])),e.labels.push(t[1])}),e.grandTotal=e.sliceTotals.reduce(function(t,e){return t+e},0),this.center={x:this.width/2,y:this.height/2}}},{key:"renderLegend",value:function(){var t=this,e=this.state;this.legendArea.textContent="",this.legendTotals=e.sliceTotals.slice(0,this.config.maxLegendPoints);var i=0,n=0;this.legendTotals.map(function(a,s){var r=150,o=Math.floor((t.width-h(t.measures))/r);t.legendTotals.lengtho&&(i=0,n+=20);var l=r*i+5,u=t.config.truncateLegends?b(e.labels[s],r/10):e.labels[s],c=t.config.formatTooltipY?t.config.formatTooltipY(a):a,d=R(l,n,5,t.colors[s],u+": "+c,!1);t.legendArea.appendChild(d),i++})}}]),e}(xe),we=7,Ae=1e3,Pe=86400,Me=["January","February","March","April","May","June","July","August","September","October","November","December"],Ce=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],De=function(){function t(e){var i=e.layerClass,n=void 0===i?"":i,a=e.layerTransform,s=void 0===a?"":a,r=e.constants,o=e.getData,l=e.makeElements,h=e.animateElements;jt(this,t),this.layerTransform=s,this.constants=r,this.makeElements=l,this.getData=o,this.animateElements=h,this.store=[],this.labels=[],this.layerClass=n,this.layerClass="function"==typeof this.layerClass?this.layerClass():this.layerClass,this.refresh()}return Rt(t,[{key:"refresh",value:function(t){this.data=t||this.getData()}},{key:"setup",value:function(t){this.layer=N(this.layerClass,this.layerTransform,t)}},{key:"make",value:function(){this.render(this.data),this.oldData=this.data}},{key:"render",value:function(t){var e=this;this.store=this.makeElements(t),this.layer.textContent="",this.store.forEach(function(t){t.length?t.forEach(function(t){e.layer.appendChild(t)}):e.layer.appendChild(t)}),this.labels.forEach(function(t){e.layer.appendChild(t)})}},{key:"update",value:function(){var t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];this.refresh();var e=[];return t&&(e=this.animateElements(this.data)||[]),e}}]),t}(),Te={donutSlices:{layerClass:"donut-slices",makeElements:function(t){return t.sliceStrings.map(function(e,i){var n=S(e,"donut-path",t.colors[i],"none",t.strokeWidth);return n.style.transition="transform .3s;",n})},animateElements:function(t){return this.store.map(function(e,i){return rt(e,t.sliceStrings[i])})}},pieSlices:{layerClass:"pie-slices",makeElements:function(t){return t.sliceStrings.map(function(e,i){var n=S(e,"pie-path","none",t.colors[i]);return n.style.transition="transform .3s;",n})},animateElements:function(t){return this.store.map(function(e,i){return rt(e,t.sliceStrings[i])})}},percentageBars:{layerClass:"percentage-bars",makeElements:function(t){var e=this;return t.xPositions.map(function(i,n){return W(i,0,t.widths[n],e.constants.barHeight,e.constants.barDepth,t.colors[n])})},animateElements:function(t){if(t)return[]}},yAxis:{layerClass:"y axis",makeElements:function(t){var e=this,i=[];return t.length?(t.forEach(function(n,a){n.positions.map(function(t,a){i.push(G(t,n.labels[a],e.constants.width,{mode:e.constants.mode,pos:n.pos||e.constants.pos,shortenNumbers:e.constants.shortenNumbers}))}),n.title&&i.push(U({title:n.title,position:n.pos,height:e.constants.height||t.zeroLine,width:e.constants.width}))}),i):(t.positions.forEach(function(n,a){i.push(G(n,t.labels[a],e.constants.width,{mode:e.constants.mode,pos:t.pos||e.constants.pos,shortenNumbers:e.constants.shortenNumbers}))}),t.title&&i.push(U({title:t.title,position:t.pos,height:this.constants.height||t.zeroLine,width:this.constants.width})),i)},animateElements:function(t){var e=this,i=function(t,i){var n=i.positions,a=i.labels,s=t.positions,r=t.labels,o=m(s,n),l=Ut(o,2);s=l[0],n=l[1];var h=m(r,a),u=Ut(h,2);return r=u[0],a=u[1],e.render({positions:s,labels:a}),e.store.map(function(t,e){return et(t,n[e],s[e])})};if(this.oldData instanceof Array)return this.oldData.forEach(function(e,n){i(e,t[n])});var n=t.positions,a=t.labels,s=this.oldData.positions,r=this.oldData.labels,o=m(s,n),l=Ut(o,2);s=l[0],n=l[1];var h=m(r,a),u=Ut(h,2);return r=u[0],a=u[1],this.render({positions:s,labels:a}),this.store.map(function(t,e){return et(t,n[e],s[e])})}},xAxis:{layerClass:"x axis",makeElements:function(t){var e=this;return t.positions.map(function(i,n){return q(i,t.calcLabels[n],e.constants.height,{mode:e.constants.mode,pos:e.constants.pos})})},animateElements:function(t){var e=t.positions,i=t.calcLabels,n=this.oldData.positions,a=this.oldData.calcLabels,s=m(n,e),r=Ut(s,2);n=r[0],e=r[1];var o=m(a,i),l=Ut(o,2);return a=l[0],i=l[1],this.render({positions:n,calcLabels:i}),this.store.map(function(t,i){return tt(t,e[i],n[i])})}},yMarkers:{layerClass:"y-markers",makeElements:function(t){var e=this;return t.map(function(t){return X(t.position,t.label,e.constants.width,{labelPos:t.options.labelPos,mode:"span",lineType:"dashed"})})},animateElements:function(t){var e=m(this.oldData,t),i=Ut(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.position}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.options}),r=this.oldData.map(function(t){return t.position});return this.render(r.map(function(t,e){return{position:r[e],label:a[e],options:s[e]}})),this.store.map(function(t,e){return et(t,n[e],r[e])})}},yRegions:{layerClass:"y-regions",makeElements:function(t){var e=this;return t.map(function(t){return J(t.startPos,t.endPos,e.constants.width,t.label,{labelPos:t.options.labelPos})})},animateElements:function(t){var e=m(this.oldData,t),i=Ut(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.endPos}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.startPos}),r=t.map(function(t){return t.options}),o=this.oldData.map(function(t){return t.endPos}),l=this.oldData.map(function(t){return t.startPos});this.render(o.map(function(t,e){return{startPos:l[e],endPos:o[e],label:a[e],options:r[e]}}));var h=[];return this.store.map(function(t,e){h=h.concat(it(t,s[e],n[e],o[e]))}),h}},heatDomain:{layerClass:function(){return"heat-domain domain-"+this.constants.index},makeElements:function(t){var e=this,i=this.constants,n=i.index,a=i.colWidth,s=i.rowHeight,r=i.squareSize,o=i.radius,l=i.xTranslate,h=0;return this.serializedSubDomains=[],t.cols.map(function(t,i){1===i&&e.labels.push(Y("domain-name",l,-12,bt(n,!0).toUpperCase(),{fontSize:9})),t.map(function(t,i){if(t.fill){var n={"data-date":t.yyyyMmDd,"data-value":t.dataValue,"data-day":i},a=F("day",l,h,r,o,t.fill,n);e.serializedSubDomains.push(a)}h+=s}),h=0,l+=a}),this.serializedSubDomains},animateElements:function(t){if(t)return[]}},barGraph:{layerClass:function(){return"dataset-units dataset-bars dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="bar",this.units=t.yPositions.map(function(i,n){return K(t.xPositions[n],i,t.barWidth,e.color,t.labels[n],n,t.offsets[n],{zeroLine:t.zeroLine,barsWidth:t.barsWidth,minHeight:e.minHeight})}),this.units},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.offsets,a=t.labels,s=this.oldData.xPositions,r=this.oldData.yPositions,o=this.oldData.offsets,l=this.oldData.labels,h=m(s,e),u=Ut(h,2);s=u[0],e=u[1];var c=m(r,i),d=Ut(c,2);r=d[0],i=d[1];var p=m(o,n),f=Ut(p,2);o=f[0],n=f[1];var v=m(l,a),g=Ut(v,2);l=g[0],a=g[1],this.render({xPositions:s,yPositions:r,offsets:o,labels:a,zeroLine:this.oldData.zeroLine,barsWidth:this.oldData.barsWidth,barWidth:this.oldData.barWidth});var y=[];return this.store.map(function(a,s){y=y.concat(nt(a,e[s],i[s],t.barWidth,n[s],{zeroLine:t.zeroLine}))}),y}},lineGraph:{layerClass:function(){return"dataset-units dataset-line dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="dot",this.paths={},e.hideLine||(this.paths=Q(t.xPositions,t.yPositions,e.color,{heatline:e.heatline,regionFill:e.regionFill,spline:e.spline},{svgDefs:e.svgDefs,zeroLine:t.zeroLine})),this.units=[],e.hideDots||(this.units=t.yPositions.map(function(i,n){return $(t.xPositions[n],i,t.radius,e.color,e.valuesOverPoints?t.values[n]:"",n)})),Object.values(this.paths).concat(this.units)},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.values,a=this.oldData.xPositions,s=this.oldData.yPositions,r=this.oldData.values,o=m(a,e),l=Ut(o,2);a=l[0],e=l[1];var h=m(s,i),u=Ut(h,2);s=u[0],i=u[1];var c=m(r,n),d=Ut(c,2);r=d[0],n=d[1],this.render({xPositions:a,yPositions:s,values:n,zeroLine:this.oldData.zeroLine,radius:this.oldData.radius});var p=[];return Object.keys(this.paths).length&&(p=p.concat(st(this.paths,e,i,t.zeroLine,this.constants.spline))),this.units.length&&this.units.map(function(t,n){p=p.concat(at(t,e[n],i[n]))}),p}}},Le=function(t){function i(t,e){jt(this,i);var n=Vt(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="percentage",n.setup(),n}return Bt(i,t),Rt(i,[{key:"setMeasures",value:function(t){var e=this.measures;this.barOptions=t.barOptions||{};var i=this.barOptions;i.height=i.height||20,i.depth=i.depth||Kt,e.paddings.right=30,e.legendHeight=60,e.baseHeight=8*(i.height+.5*i.depth)}},{key:"setupComponents",value:function(){var t=this.state,e=[["percentageBars",{barHeight:this.barOptions.height,barDepth:this.barOptions.depth},function(){return{xPositions:t.xPositions,widths:t.widths,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=At.apply(void 0,Gt(t));return[t[0],e]}))}},{key:"calc",value:function(){var t=this;Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;e.xPositions=[],e.widths=[];var n=0;e.sliceTotals.map(function(i){var a=t.width*i/e.grandTotal;e.widths.push(a),e.xPositions.push(n),n+=a})}},{key:"makeDataByIndex",value:function(){}},{key:"bindTooltip",value:function(){var t=this,i=this.state;this.container.addEventListener("mousemove",function(n){var a=t.components.get("percentageBars").store,s=n.target;if(a.includes(s)){var r=a.indexOf(s),o=e(t.container),l=e(s),h=l.left-o.left+parseInt(s.getAttribute("width"))/2,u=l.top-o.top,c=(t.formattedLabels&&t.formattedLabels.length>0?t.formattedLabels[r]:t.state.labels[r])+": ",d=i.sliceTotals[r]/i.grandTotal;t.tip.setValues(h,u,{name:c,value:(100*d).toFixed(1)+"%"}),t.tip.showTip()}})}}]),i}(ke),Oe=function(t){function i(t,e){jt(this,i);var n=Vt(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="pie",n.initTimeout=0,n.init=1,n.setup(),n}return Bt(i,t),Rt(i,[{key:"configure",value:function(t){Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),this.mouseMove=this.mouseMove.bind(this),this.mouseLeave=this.mouseLeave.bind(this),this.hoverRadio=t.hoverRadio||.1,this.config.startAngle=t.startAngle||0,this.clockWise=t.clockWise||!1}},{key:"calc",value:function(){var t=this;Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;this.radius=this.height>this.width?this.center.x:this.center.y;var n=this.radius,a=this.clockWise,s=e.slicesProperties||[];e.sliceStrings=[],e.slicesProperties=[];var r=180-this.config.startAngle;e.sliceTotals.map(function(i,o){var l=r,h=i/e.grandTotal*360,u=h>180?1:0,c=a?-h:h,d=r+=c,f=p(l,n),v=p(d,n),g=t.init&&s[o],y=void 0,m=void 0;t.init?(y=g?g.startPosition:f,m=g?g.endPosition:f):(y=f,m=v);var b=360===h?_(y,m,t.center,t.radius,a,u):E(y,m,t.center,t.radius,a,u);e.sliceStrings.push(b),e.slicesProperties.push({startPosition:f,endPosition:v,value:i,total:e.grandTotal,startAngle:l,endAngle:d,angle:c})}),this.init=0}},{key:"setupComponents",value:function(){var t=this.state,e=[["pieSlices",{},function(){return{sliceStrings:t.sliceStrings,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=At.apply(void 0,Gt(t));return[t[0],e]}))}},{key:"calTranslateByAngle",value:function(t){var e=this.radius,i=this.hoverRadio,n=p(t.startAngle+t.angle/2,e);return"translate3d("+n.x*i+"px,"+n.y*i+"px,0)"}},{key:"hoverSlice",value:function(t,i,n,a){if(t){var s=this.colors[i];if(n){lt(t,this.calTranslateByAngle(this.state.slicesProperties[i])),t.style.fill=A(s,50);var r=e(this.svg),o=a.pageX-r.left+10,l=a.pageY-r.top-10,h=(this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels[i]:this.state.labels[i])+": ",u=(100*this.state.sliceTotals[i]/this.state.grandTotal).toFixed(1);this.tip.setValues(o,l,{name:h,value:u+"%"}),this.tip.showTip()}else lt(t,"translate3d(0,0,0)"),this.tip.hideTip(),t.style.fill=s}}},{key:"bindTooltip",value:function(){this.container.addEventListener("mousemove",this.mouseMove),this.container.addEventListener("mouseleave",this.mouseLeave)}},{key:"mouseMove",value:function(t){var e=t.target,i=this.components.get("pieSlices").store,n=this.curActiveSliceIndex,a=this.curActiveSlice;if(i.includes(e)){var s=i.indexOf(e);this.hoverSlice(a,n,!1),this.curActiveSlice=e,this.curActiveSliceIndex=s,this.hoverSlice(e,s,!0,t)}else this.mouseLeave()}},{key:"mouseLeave",value:function(){this.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,!1)}}]),i}(ke),Ne=function(t){function e(t,i){jt(this,e);var n=Vt(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i));n.type="heatmap",n.countLabel=i.countLabel||"";var a=["Sunday","Monday"],s=a.includes(i.startSubDomain)?i.startSubDomain:"Sunday";return n.startSubDomainIndex=a.indexOf(s),n.setup(),n}return Bt(e,t),Rt(e,[{key:"setMeasures",value:function(t){var e=this.measures;this.discreteDomains=0===t.discreteDomains?0:1,e.paddings.top=36,e.paddings.bottom=0,e.legendHeight=24,e.baseHeight=12*we+l(e);var i=this.data,n=this.discreteDomains?12:0;this.independentWidth=12*(gt(i.start,i.end)+n)+h(e)}},{key:"updateWidth",value:function(){var t=this.discreteDomains?12:0,e=this.state.noOfWeeks?this.state.noOfWeeks:52;this.baseWidth=12*(e+t)+h(this.measures)}},{key:"prepareData",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data;if(t.start&&t.end&&t.start>t.end)throw new Error("Start date cannot be greater than end date.");if(t.start||(t.start=new Date,t.start.setFullYear(t.start.getFullYear()-1)),t.end||(t.end=new Date),t.dataPoints=t.dataPoints||{},parseInt(Object.keys(t.dataPoints)[0])>1e5){var e={};Object.keys(t.dataPoints).forEach(function(i){var n=new Date(i*Ae);e[ft(n)]=t.dataPoints[i]}),t.dataPoints=e}return t}},{key:"calc",value:function(){var t=this.state;t.start=vt(this.data.start),t.end=vt(this.data.end),t.firstWeekStart=vt(t.start),t.noOfWeeks=gt(t.start,t.end),t.distribution=Et(Object.values(this.data.dataPoints),5),t.domainConfigs=this.getDomains()}},{key:"setupComponents",value:function(){var t=this,e=this.state,i=this.discreteDomains?0:1,n=e.domainConfigs.map(function(n,a){return["heatDomain",{index:n.index,colWidth:12,rowHeight:12,squareSize:10,radius:t.rawChartArgs.radius||0,xTranslate:12*e.domainConfigs.filter(function(t,e){return e1&&void 0!==arguments[1]?arguments[1]:"",i=[t.getMonth(),t.getFullYear()],n=i[0],a=i[1],s=kt(t),r={index:n,cols:[]};wt(e=vt(e)||xt(n,a),1);for(var o=gt(s,e),l=[],h=void 0,u=0;u2&&void 0!==arguments[2]&&arguments[2],n=this.state,a=vt(t),s=[],r=0;r=n.start&&a<=n.end;i||a.getMonth()!==e||!l?o.yyyyMmDd=ft(a):o=this.getSubDomainConfig(a),s.push(o)}return s}},{key:"getSubDomainConfig",value:function(t){var e=ft(t),i=this.data.dataPoints[e];return{yyyyMmDd:e,dataValue:i||0,fill:this.colors[_t(i,this.state.distribution)]}}}]),e}(xe),Se=function(t){function i(t,e){jt(this,i);var n=Vt(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.barOptions=e.barOptions||{},n.lineOptions=e.lineOptions||{},n.type=e.type||"line",n.init=1,n.setup(),n}return Bt(i,t),Rt(i,[{key:"setMeasures",value:function(){this.data.datasets.length<=1&&(this.config.showLegend=0,this.measures.paddings.bottom=30)}},{key:"configure",value:function(t){Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t);var e=t.axisOptions,n=void 0===e?{}:e,a=n||{},s=a.xAxis,r=a.yAxis;t.tooltipOptions=t.tooltipOptions||{},this.config.xAxisMode=s?s.xAxisMode:n.xAxisMode||"span",r&&r.length?this.config.yAxisConfig=r.map(function(t){return{yAxisMode:t.yAxisMode,id:t.id,position:t.position,title:t.title}}):(this.config.yAxisMode=r?r.yAxisMode:n.yAxisMode||"span",r&&r.id&&r.position&&(this.config.yAxisConfig=[r])),this.config.xIsSeries=n.xIsSeries||0,this.config.shortenYAxisNumbers=n.shortenYAxisNumbers||0,this.config.formatTooltipX=t.tooltipOptions.formatTooltipX,this.config.formatTooltipY=t.tooltipOptions.formatTooltipY,this.config.valuesOverPoints=t.valuesOverPoints}},{key:"prepareData",value:function(){return zt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data,this.type)}},{key:"prepareFirstData",value:function(){return It(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data)}},{key:"calc",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.calcXPositions(),t||this.calcYAxisParameters(this.getAllYValues(),"line"===this.type),this.makeDataByIndex()}},{key:"calcXPositions",value:function(){var t=this.state,e=this.data.labels;t.datasetLength=e.length,t.unitWidth=this.width/t.datasetLength,t.xOffset=t.unitWidth/2,t.xAxis={labels:e,positions:e.map(function(e,i){return u(t.xOffset+i*t.unitWidth)})}}},{key:"calcYAxisParameters",value:function(t){var e=this,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"false",n=void 0,a=void 0,s=void 0,r=void 0,o=void 0,l=void 0,h=void 0,u=void 0;if(u=[],l=this.config.yAxisMode||{},h=l.position?l.position:"left",t instanceof Array)n=Dt(t,i),a=this.height/Ot(n),s=Lt(n)*a,r=this.height-Tt(n)*s,this.state.yAxis={labels:n,positions:n.map(function(t){return r-t*a}),title:l.title||null,pos:h,scaleMultiplier:a,zeroLine:r};else{this.state.yAxis=[];for(var c in t)!function(c){var d=t[c];if(l=e.config.yAxisConfig.find(function(t){return c===t.id})||[],h=l.position?l.position:"left",n=Dt(d,i),a=e.height/Ot(n),s=Lt(n)*a,r=e.height-Tt(n)*s,o=n.map(function(t){return r-t*a}),u.push(c),e.state.yAxis.length>1){var p=[],f=e.state.yAxis[0];a=e.height/Ot(n),f.positions.forEach(function(t){p.push(Math.ceil(t/a))}),n=p.reverse(),r=e.height-Tt(n)*s,o=f.positions}e.state.yAxis.push({axisID:c||"left-axis",labels:n,title:l.title,pos:h,scaleMultiplier:a,zeroLine:r,positions:o})}(c);if(this.state.yAxis[1]&&this.state.yAxis[0].labels.length!==this.state.yAxis[1].labels.length){var d=[],p=this.state.yAxis.reduce(function(t,e){return t.length>e.labels.length?e:t},{length:1/0}),f=this.state.yAxis.reduce(function(t,e){return t.length1?n.find(function(t){return i===t.axisID}):t.yAxis[0]),Nt(e,n)})};t.barChartIndex=1,t.datasets=this.data.datasets.map(function(i,n){var a=i.values,s=i.cumulativeYs||[];return{name:i.name&&i.name.replace(/<|>|&/g,function(t){return"&"==t?"&":"<"==t?"<":">"}),index:n,barIndex:"bar"===i.chartType?t.barChartIndex++:t.barChartIndex,chartType:i.chartType,values:a,yPositions:e(a,i.axisID),id:i.axisID,cumulativeYs:s,cumulativeYPos:e(s,i.axisID)}})}},{key:"calcYExtremes",value:function(){var t=this.state;if(this.barOptions.stacked)return void(t.yExtremes=t.datasets[t.datasets.length-1].cumulativeYPos);t.yExtremes=new Array(t.datasetLength).fill(9999),t.datasets.map(function(e){e.yPositions.map(function(e,i){e1?e.find(function(t){return o===t.axisID}):t.yAxis[0]);var d=t.xAxis.positions.map(function(t){return t-u/2});l||(d=d.map(function(t){return t+c*a-c}));var p=new Array(t.datasetLength).fill("");this.config.valuesOverPoints&&(p=l&&s.index===t.datasets.length-1?s.cumulativeYs:s.values);var f=new Array(t.datasetLength).fill(0);return l&&(f=s.yPositions.map(function(t,e){return t-s.cumulativeYPos[e]})),{xPositions:d,yPositions:s.yPositions,offsets:f,labels:p,zeroLine:e.zeroLine,barsWidth:u,barWidth:c}}.bind(t)]}),s=n.map(function(e){var i=e.index;return["lineGraph-"+e.index,{index:i,color:t.colors[i],svgDefs:t.svgDefs,heatline:t.lineOptions.heatline,regionFill:t.lineOptions.regionFill,spline:t.lineOptions.spline,hideDots:t.lineOptions.hideDots,hideLine:t.lineOptions.hideLine,valuesOverPoints:t.config.valuesOverPoints},function(){var t=this.state,e=t.datasets[i],n=t.yAxis.length?t.yAxis.find(function(t){return e.id===t.axisID})||t.yAxis[0]:t.yAxis,a=n.positions[0]r(n)?t.mapTooltipXPosition(s):t.tip.hideTip()})}},{key:"mapTooltipXPosition",value:function(t){var e=this.state;if(e.yExtremes){var i=St(t,e.xAxis.positions,!0);if(i>=0){var n=this.dataByIndex[i];this.tip.setValues(n.xPos+this.tip.offset.x,n.yExtreme+this.tip.offset.y,{name:n.formattedLabel,value:""},n.values,i),this.tip.showTip()}}}},{key:"renderLegend",value:function(){var t=this,e=this.data;e.datasets.length>1&&(this.legendArea.textContent="",e.datasets.map(function(e,i){var n=j(100*i,"0",100,t.colors[i],e.name,t.config.truncateLegends);t.legendArea.appendChild(n)}))}},{key:"makeOverlay",value:function(){var t=this;if(this.init)return void(this.init=0);this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)}),this.overlayGuides=this.dataUnitComponents.map(function(t){return{type:t.unitType,overlay:void 0,units:t.units}}),void 0===this.state.currentIndex&&(this.state.currentIndex=this.state.datasetLength-1),this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];e.overlay=ce[e.type](i),t.drawArea.appendChild(e.overlay)})}},{key:"updateOverlayGuides",value:function(){this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)})}},{key:"bindOverlay",value:function(){var t=this;this.parent.addEventListener("data-select",function(){t.updateOverlay()})}},{key:"bindUnits",value:function(){var t=this;this.dataUnitComponents.map(function(e){e.units.map(function(e){e.addEventListener("click",function(){var i=e.getAttribute("data-point-index");t.setCurrentDataPoint(i)})})}),this.tip.container.addEventListener("click",function(){var e=t.tip.container.getAttribute("data-point-index");t.setCurrentDataPoint(e)})}},{key:"updateOverlay",value:function(){var t=this;this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];de[e.type](i,e.overlay)})}},{key:"onLeftArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex-1)}},{key:"onRightArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex+1)}},{key:"getDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.currentIndex,e=this.state;return{index:t,label:e.xAxis.labels[t],values:e.datasets.map(function(e){return e.values[t]})}}},{key:"setCurrentDataPoint",value:function(t){var e=this.state;(t=parseInt(t))<0&&(t=0),t>=e.xAxis.labels.length&&(t=e.xAxis.labels.length-1),t!==e.currentIndex&&(e.currentIndex=t,s(this.parent,"data-select",this.getDataPoint()))}},{key:"addDataPoint",value:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.state.datasetLength;Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"addDataPoint",this).call(this,t,e,n),this.data.labels.splice(n,0,t),this.data.datasets.map(function(t,i){t.values.splice(n,0,e[i])}),this.update(this.data)}},{key:"removeDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.datasetLength-1;this.data.labels.length<=1||(Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"removeDataPoint",this).call(this,t),this.data.labels.splice(t,1),this.data.datasets.map(function(e){e.values.splice(t,1)}),this.update(this.data))}},{key:"updateDataset",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;this.data.datasets[e].values=t,this.update(this.data)}},{key:"updateDatasets",value:function(t){this.data.datasets.map(function(e,i){t[i]&&(e.values=t[i])}),this.update(this.data)}}]),i}(xe),Ee=function(t){function i(t,e){jt(this,i);var n=Vt(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="donut",n.initTimeout=0,n.init=1,n.setup(),n}return Bt(i,t),Rt(i,[{key:"configure",value:function(t){Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),this.mouseMove=this.mouseMove.bind(this),this.mouseLeave=this.mouseLeave.bind(this),this.hoverRadio=t.hoverRadio||.1,this.config.startAngle=t.startAngle||0,this.clockWise=t.clockWise||!1,this.strokeWidth=t.strokeWidth||30}},{key:"calc",value:function(){var t=this;Yt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;this.radius=this.height>this.width?this.center.x-this.strokeWidth/2:this.center.y-this.strokeWidth/2;var n=this.radius,a=this.clockWise,s=e.slicesProperties||[];e.sliceStrings=[],e.slicesProperties=[];var r=180-this.config.startAngle;e.sliceTotals.map(function(i,o){var l=r,h=i/e.grandTotal*360,u=h>180?1:0,c=a?-h:h,d=r+=c,f=p(l,n),v=p(d,n),g=t.init&&s[o],y=void 0,m=void 0;t.init?(y=g?g.startPosition:f,m=g?g.endPosition:f):(y=f,m=v);var b=360===h?I(y,m,t.center,t.radius,t.clockWise,u):z(y,m,t.center,t.radius,t.clockWise,u);e.sliceStrings.push(b),e.slicesProperties.push({startPosition:f,endPosition:v,value:i,total:e.grandTotal,startAngle:l,endAngle:d,angle:c})}),this.init=0}},{key:"setupComponents",value:function(){var t=this.state,e=[["donutSlices",{},function(){return{sliceStrings:t.sliceStrings,colors:this.colors,strokeWidth:this.strokeWidth}}.bind(this)]];this.components=new Map(e.map(function(t){var e=At.apply(void 0,Gt(t));return[t[0],e]}))}},{key:"calTranslateByAngle",value:function(t){var e=this.radius,i=this.hoverRadio,n=p(t.startAngle+t.angle/2,e);return"translate3d("+n.x*i+"px,"+n.y*i+"px,0)"}},{key:"hoverSlice",value:function(t,i,n,a){if(t){var s=this.colors[i];if(n){lt(t,this.calTranslateByAngle(this.state.slicesProperties[i])),t.style.stroke=A(s,50);var r=e(this.svg),o=a.pageX-r.left+10,l=a.pageY-r.top-10,h=(this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels[i]:this.state.labels[i])+": ",u=(100*this.state.sliceTotals[i]/this.state.grandTotal).toFixed(1);this.tip.setValues(o,l,{name:h,value:u+"%"}),this.tip.showTip()}else lt(t,"translate3d(0,0,0)"),this.tip.hideTip(),t.style.stroke=s}}},{key:"bindTooltip",value:function(){this.container.addEventListener("mousemove",this.mouseMove),this.container.addEventListener("mouseleave",this.mouseLeave)}},{key:"mouseMove",value:function(t){var e=t.target,i=this.components.get("donutSlices").store,n=this.curActiveSliceIndex,a=this.curActiveSlice;if(i.includes(e)){var s=i.indexOf(e);this.hoverSlice(a,n,!1),this.curActiveSlice=e,this.curActiveSliceIndex=s,this.hoverSlice(e,s,!0,t)}else this.mouseLeave()}},{key:"mouseLeave",value:function(){this.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,!1)}}]),i}(ke),_e={bar:Se,line:Se,percentage:Le,heatmap:Ne,pie:Oe,donut:Ee},ze=function t(e,i){return jt(this,t),Wt(i.type,e,i)},Ie=Object.freeze({Chart:ze,PercentageChart:Le,PieChart:Oe,Heatmap:Ne,AxisChart:Se}),He={};return He.NAME="Frappe Charts",He.VERSION="1.6.2",He=Object.assign({},He,Ie)}(); //# sourceMappingURL=frappe-charts.min.js.map diff --git a/docs/assets/js/frappe-charts.min.js.map b/docs/assets/js/frappe-charts.min.js.map index 6356fe7..e78f44e 100644 --- a/docs/assets/js/frappe-charts.min.js.map +++ b/docs/assets/js/frappe-charts.min.js.map @@ -1 +1 @@ -{"version":3,"file":"frappe-charts.min.js","sources":["../../../src/js/utils/dom.js","../../../src/js/utils/constants.js","../../../src/js/utils/helpers.js","../../../src/js/utils/draw-utils.js","../../../src/js/utils/colors.js","../../../src/js/utils/draw.js","../../../src/js/utils/animate.js","../../../src/js/utils/animation.js","../../../src/js/utils/export.js","../../../src/js/utils/date-utils.js","../../../src/js/objects/ChartComponents.js","../../../src/js/utils/intervals.js","../../../src/js/utils/axis-chart-utils.js","../../../src/js/chart.js","../../../node_modules/style-inject/dist/style-inject.es.js","../../../src/js/objects/SvgTip.js","../../../src/css/chartsCss.js","../../../src/js/charts/BaseChart.js","../../../src/js/charts/AggregationChart.js","../../../src/js/charts/PercentageChart.js","../../../src/js/charts/PieChart.js","../../../src/js/charts/Heatmap.js","../../../src/js/charts/AxisChart.js","../../../src/js/charts/DonutChart.js","../../../src/js/index.js"],"sourcesContent":["export function $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function findNodeIndex(node)\n{\n\tvar i = 0;\n\twhile (node.previousSibling) {\n\t\tnode = node.previousSibling;\n\t\ti++;\n\t}\n\treturn i;\n}\n\n$.create = (tag, o) => {\n\tvar element = document.createElement(tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (i in element ) {\n\t\t\telement[i] = val;\n\t\t}\n\t\telse {\n\t\t\telement.setAttribute(i, val);\n\t\t}\n\t}\n\n\treturn element;\n};\n\nexport function getOffset(element) {\n\tlet rect = element.getBoundingClientRect();\n\treturn {\n\t\t// https://stackoverflow.com/a/7436602/6495043\n\t\t// rect.top varies with scroll, so we add whatever has been\n\t\t// scrolled to it to get absolute distance from actual page top\n\t\ttop: rect.top + (document.documentElement.scrollTop || document.body.scrollTop),\n\t\tleft: rect.left + (document.documentElement.scrollLeft || document.body.scrollLeft)\n\t};\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/offsetParent\n// an element's offsetParent property will return null whenever it, or any of its parents,\n// is hidden via the display style property.\nexport function isHidden(el) {\n\treturn (el.offsetParent === null);\n}\n\nexport function isElementInViewport(el) {\n\t// Although straightforward: https://stackoverflow.com/a/7557433/6495043\n\tvar rect = el.getBoundingClientRect();\n\n\treturn (\n\t\trect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */\n rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */\n\t);\n}\n\nexport function getElementContentWidth(element) {\n\tvar styles = window.getComputedStyle(element);\n\tvar padding = parseFloat(styles.paddingLeft) +\n\t\tparseFloat(styles.paddingRight);\n\n\treturn element.clientWidth - padding;\n}\n\nexport function bind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function (event) {\n\t\t\t\telement.addEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function unbind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function(event) {\n\t\t\t\telement.removeEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function fire(target, type, properties) {\n\tvar evt = document.createEvent(\"HTMLEvents\");\n\n\tevt.initEvent(type, true, true );\n\n\tfor (var j in properties) {\n\t\tevt[j] = properties[j];\n\t}\n\n\treturn target.dispatchEvent(evt);\n}\n\n// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/\nexport function forEachNode(nodeList, callback, scope) {\n\tif(!nodeList) return;\n\tfor (var i = 0; i < nodeList.length; i++) {\n\t\tcallback.call(scope, nodeList[i], i);\n\t}\n}\n\nexport function activate($parent, $child, commonClass, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`.${commonClass}.${activeClass}`);\n\n\tforEachNode($children, (node, i) => {\n\t\tif(index >= 0 && i <= index) return;\n\t\tnode.classList.remove(activeClass);\n\t});\n\n\t$child.classList.add(activeClass);\n}\n","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const DEFAULT_AXIS_CHART_TYPE = 'line';\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 0.5;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.00;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN,\n\tdonut: DEFAULT_CHART_COLORS\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\n/**\n * Check if a number is valid for svg attributes\n * @param {object} candidate Candidate to test\n * @param {Boolean} nonNegative flag to treat negative number as invalid\n */\nexport function isValidNumber(candidate, nonNegative=false) {\n\tif (Number.isNaN(candidate)) return false;\n\telse if (candidate === undefined) return false;\n\telse if (!Number.isFinite(candidate)) return false;\n\telse if (nonNegative && candidate < 0) return false;\n\telse return true;\n}\n\n/**\n * Round a number to the closes precision, max max precision 4\n * @param {Number} d Any Number\n */\nexport function round(d) {\n\t// https://floating-point-gui.de/\n\t// https://www.jacklmoore.com/notes/rounding-in-javascript/\n\treturn Number(Math.round(d + 'e4') + 'e-4');\n}\n\n/**\n * Creates a deep clone of an object\n * @param {Object} candidate Any Object\n */\n export function deepClone(candidate) {\n\tlet cloned, value, key;\n \n\tif (candidate instanceof Date) {\n\t return new Date(candidate.getTime());\n\t}\n \n\tif (typeof candidate !== \"object\" || candidate === null) {\n\t return candidate;\n\t}\n \n\tcloned = Array.isArray(candidate) ? [] : {};\n \n\tfor (key in candidate) {\n\t value = candidate[key];\n \n\t cloned[key] = deepClone(value);\n\t}\n \n\treturn cloned;\n }","import { fillArray } from './helpers';\n\nexport function getBarHeightAndYAttr(yTop, zeroLine) {\n\tlet height, y;\n\tif (yTop <= zeroLine) {\n\t\theight = zeroLine - yTop;\n\t\ty = yTop;\n\t} else {\n\t\theight = yTop - zeroLine;\n\t\ty = zeroLine;\n\t}\n\n\treturn [height, y];\n}\n\nexport function equilizeNoOfElements(array1, array2,\n\textraCount = array2.length - array1.length) {\n\n\t// Doesn't work if either has zero elements.\n\tif(extraCount > 0) {\n\t\tarray1 = fillArray(array1, extraCount);\n\t} else {\n\t\tarray2 = fillArray(array2, extraCount);\n\t}\n\treturn [array1, array2];\n}\n\nexport function truncateString(txt, len) {\n\tif (!txt) {\n\t\treturn;\n\t}\n\tif (txt.length > len) {\n\t\treturn txt.slice(0, len-3) + '...';\n\t} else {\n\t\treturn txt;\n\t}\n}\n\nexport function shortenLargeNumber(label) {\n\tlet number;\n\tif (typeof label === 'number') number = label;\n\telse if (typeof label === 'string') {\n\t\tnumber = Number(label);\n\t\tif (Number.isNaN(number)) return label;\n\t}\n\n\t// Using absolute since log wont work for negative numbers\n\tlet p = Math.floor(Math.log10(Math.abs(number)));\n\tif (p <= 2) return number; // Return as is for a 3 digit number of less\n\tlet\tl = Math.floor(p / 3);\n\tlet shortened = (Math.pow(10, p - l * 3) * +(number / Math.pow(10, p)).toFixed(1));\n\n\t// Correct for floating point error upto 2 decimal places\n\treturn Math.round(shortened*100)/100 + ' ' + ['', 'K', 'M', 'B', 'T'][l];\n}\n\n// cubic bezier curve calculation (from example by François Romain)\nexport function getSplineCurvePointsStr(xList, yList) {\n\n\tlet points=[];\n\tfor(let i=0;i {\n\t\tlet lengthX = pointB[0] - pointA[0];\n\t\tlet lengthY = pointB[1] - pointA[1];\n\t\treturn {\n\t\t\tlength: Math.sqrt(Math.pow(lengthX, 2) + Math.pow(lengthY, 2)),\n\t\t\tangle: Math.atan2(lengthY, lengthX)\n\t\t};\n\t};\n \n\tlet controlPoint = (current, previous, next, reverse) => {\n\t\tlet p = previous || current;\n\t\tlet n = next || current;\n\t\tlet o = line(p, n);\n\t\tlet angle = o.angle + (reverse ? Math.PI : 0);\n\t\tlet length = o.length * smoothing;\n\t\tlet x = current[0] + Math.cos(angle) * length;\n\t\tlet y = current[1] + Math.sin(angle) * length;\n\t\treturn [x, y];\n\t};\n \n\tlet bezierCommand = (point, i, a) => {\n\t\tlet cps = controlPoint(a[i - 1], a[i - 2], point);\n\t\tlet cpe = controlPoint(point, a[i - 1], a[i + 1], true);\n\t\treturn `C ${cps[0]},${cps[1]} ${cpe[0]},${cpe[1]} ${point[0]},${point[1]}`;\n\t};\n \n\tlet pointStr = (points, command) => {\n\t\treturn points.reduce((acc, point, i, a) => i === 0\n\t\t\t? `${point[0]},${point[1]}`\n\t\t\t: `${acc} ${command(point, i, a)}`, '');\n\t};\n \n\treturn pointStr(points, bezierCommand);\n}\n","const PRESET_COLOR_MAP = {\n\t'light-blue': '#7cd6fd',\n\t'blue': '#5e64ff',\n\t'violet': '#743ee2',\n\t'red': '#ff5858',\n\t'orange': '#ffa00a',\n\t'yellow': '#feef72',\n\t'green': '#28a745',\n\t'light-green': '#98d85b',\n\t'purple': '#b554ff',\n\t'magenta': '#ffa3ef',\n\t'black': '#36114C',\n\t'grey': '#bdd3e6',\n\t'light-grey': '#f0f4f7',\n\t'dark-grey': '#b8c2cc'\n};\n\nfunction limitColor(r){\n\tif (r > 255) return 255;\n\telse if (r < 0) return 0;\n\treturn r;\n}\n\nexport function lightenDarkenColor(color, amt) {\n\tlet col = getColor(color);\n\tlet usePound = false;\n\tif (col[0] == \"#\") {\n\t\tcol = col.slice(1);\n\t\tusePound = true;\n\t}\n\tlet num = parseInt(col,16);\n\tlet r = limitColor((num >> 16) + amt);\n\tlet b = limitColor(((num >> 8) & 0x00FF) + amt);\n\tlet g = limitColor((num & 0x0000FF) + amt);\n\treturn (usePound?\"#\":\"\") + (g | (b << 8) | (r << 16)).toString(16);\n}\n\nexport function isValidColor(string) {\n\t// https://stackoverflow.com/a/32685393\n\tlet HEX_RE = /(^\\s*)(#)((?:[A-Fa-f0-9]{3}){1,2})$/i;\n\tlet RGB_RE = /(^\\s*)(rgb|hsl)(a?)[(]\\s*([\\d.]+\\s*%?)\\s*,\\s*([\\d.]+\\s*%?)\\s*,\\s*([\\d.]+\\s*%?)\\s*(?:,\\s*([\\d.]+)\\s*)?[)]$/i;\n\treturn HEX_RE.test(string) || RGB_RE.test(string);\n}\n\nexport const getColor = (color) => {\n\t// When RGB color, convert to hexadecimal (alpha value is omitted)\n\tif((/rgb[a]{0,1}\\([\\d, ]+\\)/gim).test(color)) {\n\t\treturn (/\\D+(\\d*)\\D+(\\d*)\\D+(\\d*)/gim).exec(color)\n\t\t\t.map((x, i) => (i !== 0 ? Number(x).toString(16) : '#'))\n\t\t\t.reduce((c, ch) => `${c}${ch}`);\n\t}\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr, truncateString, shortenLargeNumber, getSplineCurvePointsStr } from './draw-utils';\nimport { getStringWidth, isValidNumber } from './helpers';\nimport { DOT_OVERLAY_SIZE_INCR, PERCENTAGE_BAR_DEFAULT_DEPTH } from './constants';\nimport { lightenDarkenColor } from './colors';\n\nexport const AXIS_TICK_LENGTH = 6;\nconst LABEL_MARGIN = 4;\nconst LABEL_MAX_CHARS = 15;\nconst TOTAL_PADDING = 120;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none', strokeWidth=2) {\n\treturn createSVG('path', {\n\t\tclassName: className,\n\t\td: pathStr,\n\t\tstyles: {\n\t\t\tstroke: stroke,\n\t\t\tfill: fill,\n\t\t\t'stroke-width': strokeWidth\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeCircleStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, midArc, arcEndY] = [center.x + endPosition.x, center.y * 2, center.y + endPosition.y];\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${midArc} z\n\t\tL${arcStartX} ${midArc}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeArcStrokePathStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\n\treturn `M${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY}`;\n}\n\nexport function makeStrokeCircleStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, midArc, arcEndY] = [center.x + endPosition.x, radius * 2 + arcStartY, center.y + startPosition.y];\n\n\treturn `M${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${midArc}\n\t\tM${arcStartX} ${midArc}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY}`;\n}\n\nexport function makeGradient(svgDefElem, color, lighter = false) {\n\tlet gradientId ='path-fill-gradient' + '-' + color + '-' +(lighter ? 'lighter' : 'default');\n\tlet gradientDef = renderVerticalGradient(svgDefElem, gradientId);\n\tlet opacities = [1, 0.6, 0.2];\n\tif(lighter) {\n\t\topacities = [0.4, 0.2, 0];\n\t}\n\n\tsetGradientStop(gradientDef, \"0%\", color, opacities[0]);\n\tsetGradientStop(gradientDef, \"50%\", color, opacities[1]);\n\tsetGradientStop(gradientDef, \"100%\", color, opacities[2]);\n\n\treturn gradientId;\n}\n\nexport function percentageBar(x, y, width, height,\n\tdepth=PERCENTAGE_BAR_DEFAULT_DEPTH, fill='none') {\n\n\tlet args = {\n\t\tclassName: 'percentage-bar',\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height,\n\t\tfill: fill,\n\t\tstyles: {\n\t\t\t'stroke': lightenDarkenColor(fill, -25),\n\t\t\t// Diabolically good: https://stackoverflow.com/a/9000859\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/stroke-dasharray\n\t\t\t'stroke-dasharray': `0, ${height + width}, ${width}, ${height}`,\n\t\t\t'stroke-width': depth\n\t\t},\n\t};\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function heatSquare(className, x, y, size, radius, fill='none', data={}) {\n\tlet args = {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: size,\n\t\theight: size,\n\t\trx: radius,\n\t\tfill: fill\n\t};\n\n\tObject.keys(data).map(key => {\n\t\targs[key] = data[key];\n\t});\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function legendBar(x, y, size, fill='none', label, truncate=false) {\n\tlabel = truncate ? truncateString(label, LABEL_MAX_CHARS) : label;\n\n\tlet args = {\n\t\tclassName: 'legend-bar',\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: size,\n\t\theight: '2px',\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE * 2) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"rect\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function legendDot(x, y, size, fill='none', label, truncate=false) {\n\tlabel = truncate ? truncateString(label, LABEL_MAX_CHARS) : label;\n\n\tlet args = {\n\t\tclassName: 'legend-dot',\n\t\tcx: 0,\n\t\tcy: 0,\n\t\tr: size,\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdx: (FONT_SIZE) + 'px',\n\t\tdy: (FONT_SIZE/3) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"circle\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function makeText(className, x, y, content, options = {}) {\n\tlet fontSize = options.fontSize || FONT_SIZE;\n\tlet dy = options.dy !== undefined ? options.dy : (fontSize / 2);\n\tlet fill = options.fill || FONT_FILL;\n\tlet textAnchor = options.textAnchor || 'start';\n\treturn createSVG('text', {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\tdy: dy + 'px',\n\t\t'font-size': fontSize + 'px',\n\t\tfill: fill,\n\t\t'text-anchor': textAnchor,\n\t\tinnerHTML: content\n\t});\n}\n\nfunction makeVertLine(x, label, y1, y2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tlet l = createSVG('line', {\n\t\tclassName: 'line-vertical ' + options.className,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: y1,\n\t\ty2: y2,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: 0,\n\t\ty: y1 > y2 ? y1 + LABEL_MARGIN : y1 - LABEL_MARGIN - FONT_SIZE,\n\t\tdy: FONT_SIZE + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'middle',\n\t\tinnerHTML: label + \"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(${ x }, 0)`\n\t});\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nfunction makeHoriLine(y, label, x1, x2, options = {}) {\n if (!options.stroke) options.stroke = BASE_LINE_COLOR;\n if (!options.lineType) options.lineType = '';\n if (!options.alignment) options.alignment = 'left';\n if (options.shortenNumbers) label = shortenLargeNumber(label);\n\n let className =\n 'line-horizontal ' +\n options.className +\n (options.lineType === 'dashed' ? 'dashed' : '');\n\n let l = createSVG('line', {\n className: className,\n x1: x1,\n x2: x2,\n y1: 0,\n y2: 0,\n styles: {\n stroke: options.stroke\n }\n });\n\n let text = createSVG('text', {\n x: options.alignment === 'left' ? x1 - LABEL_MARGIN : x2 + LABEL_MARGIN * 4,\n y: 0,\n dy: FONT_SIZE / 2 - 2 + 'px',\n 'font-size': FONT_SIZE + 'px',\n 'text-anchor': x1 < x2 ? 'end' : 'start',\n innerHTML: label + ''\n });\n\n let line = createSVG('g', {\n transform: `translate(0, ${y})`,\n 'stroke-opacity': 1\n });\n\n if (text === 0 || text === '0') {\n line.style.stroke = 'rgba(27, 31, 35, 0.6)';\n }\n\n line.appendChild(l);\n line.appendChild(text);\n\n return line;\n}\n\nexport function generateAxisLabel(options) {\n if (!options.title) return;\n\n const y = options.position === 'left' ? \n\t\t(options.height - TOTAL_PADDING) / 2 + (getStringWidth(options.title, 5) / 2) : \n\t\t(options.height - TOTAL_PADDING) / 2 - (getStringWidth(options.title, 5) / 2) ;\n\tconst x = options.position === 'left' ? 0 : options.width;\n\tconst y2 = options.position === 'left' ? FONT_SIZE / 3 : FONT_SIZE / 3 * -1;\n\n const rotation =\n options.position === 'right'\n ? `rotate(90)`\n : `rotate(270)`;\n\n const labelSvg = createSVG('text', {\n className: 'chart-label',\n x: 0, // getStringWidth(options.title, 5) / 2,\n y: 0, // y,\n dy: `${y2}px`,\n 'font-size': `${FONT_SIZE}px`,\n 'text-anchor': 'start',\n innerHTML: `${options.title} `\n });\n\n\tlet wrapper = createSVG('g', {\n\t\tx: 0,\n\t\ty: 0,\n\t\ttransformBox: 'fill-box',\n\t\ttransform: `translate(${x}, ${y}) ${rotation}`,\n\t\tclassName: `test-${options.position}`\n\t});\n\n\twrapper.appendChild(labelSvg);\n\n return wrapper;\n}\n\nexport function yLine(y, label, width, options = {}) {\n if (!isValidNumber(y)) y = 0;\n\n if (!options.pos) options.pos = 'left';\n if (!options.offset) options.offset = 0;\n if (!options.mode) options.mode = 'span';\n if (!options.stroke) options.stroke = BASE_LINE_COLOR;\n if (!options.className) options.className = '';\n\n let x1 = -1 * AXIS_TICK_LENGTH;\n let x2 = options.mode === 'span' ? width + AXIS_TICK_LENGTH : 0;\n\n if (options.mode === 'tick' && options.pos === 'right') {\n x1 = width + AXIS_TICK_LENGTH;\n x2 = width;\n }\n\n let offset = options.pos === 'left' ? -1 * options.offset : options.offset;\n\n x1 += offset;\n x2 += offset;\n\n return makeHoriLine(y, label, x1, x2, {\n stroke: options.stroke,\n className: options.className,\n lineType: options.lineType,\n alignment: options.pos,\n shortenNumbers: options.shortenNumbers\n });\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif (!isValidNumber(x)) x = 0;\n\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\t// Preprocess numbers to avoid svg building errors\n\tif (!isValidNumber(x)) x = 0;\n\tif (!isValidNumber(y)) y = 0;\n\tif (!isValidNumber(height, true)) height = 0;\n\tif (!isValidNumber(width, true)) width = 0;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\n\t// Spline\n\tif (options.spline)\n\t\tpointsStr = getSplineCurvePointsStr(xList, yList);\n\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.regionFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr, getSplineCurvePointsStr } from './draw-utils';\n\nexport const UNIT_ANIM_DUR = 350;\nexport const PATH_ANIM_DUR = 350;\nexport const MARKER_LINE_ANIM_DUR = UNIT_ANIM_DUR;\nexport const REPLACE_ALL_NEW_DUR = 250;\n\nexport const STD_EASING = 'easein';\n\nexport function translate(unit, oldCoord, newCoord, duration) {\n\tlet old = typeof oldCoord === 'string' ? oldCoord : oldCoord.join(', ');\n\treturn [\n\t\tunit,\n\t\t{transform: newCoord.join(', ')},\n\t\tduration,\n\t\tSTD_EASING,\n\t\t\"translate\",\n\t\t{transform: old}\n\t];\n}\n\nexport function translateVertLine(xLine, newX, oldX) {\n\treturn translate(xLine, [oldX, 0], [newX, 0], MARKER_LINE_ANIM_DUR);\n}\n\nexport function translateHoriLine(yLine, newY, oldY) {\n\treturn translate(yLine, [0, oldY], [0, newY], MARKER_LINE_ANIM_DUR);\n}\n\nexport function animateRegion(rectGroup, newY1, newY2, oldY2) {\n\tlet newHeight = newY1 - newY2;\n\tlet rect = rectGroup.childNodes[0];\n\tlet width = rect.getAttribute(\"width\");\n\tlet rectAnim = [\n\t\trect,\n\t\t{ height: newHeight, 'stroke-dasharray': `${width}, ${newHeight}` },\n\t\tMARKER_LINE_ANIM_DUR,\n\t\tSTD_EASING\n\t];\n\n\tlet groupAnim = translate(rectGroup, [0, oldY2], [0, newY2], MARKER_LINE_ANIM_DUR);\n\treturn [rectAnim, groupAnim];\n}\n\nexport function animateBar(bar, x, yTop, width, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\tif(bar.nodeName !== 'rect') {\n\t\tlet rect = bar.childNodes[0];\n\t\tlet rectAnim = [\n\t\t\trect,\n\t\t\t{width: width, height: height},\n\t\t\tUNIT_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\n\t\tlet oldCoordStr = bar.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(bar, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [rectAnim, groupAnim];\n\t} else {\n\t\treturn [[bar, {width: width, height: height, x: x, y: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// bar.animate({height: args.newHeight, y: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animateDot(dot, x, y) {\n\tif(dot.nodeName !== 'circle') {\n\t\tlet oldCoordStr = dot.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(dot, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [groupAnim];\n\t} else {\n\t\treturn [[dot, {cx: x, cy: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// dot.animate({cy: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animatePath(paths, newXList, newYList, zeroLine, spline) {\n\tlet pathComponents = [];\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y)).join(\"L\");\n\n\tif (spline)\n\t\tpointsStr = getSplineCurvePointsStr(newXList, newYList);\n\n\tconst animPath = [paths.path, {d:\"M\" + pointsStr}, PATH_ANIM_DUR, STD_EASING];\n\tpathComponents.push(animPath);\n\n\tif(paths.region) {\n\t\tlet regStartPt = `${newXList[0]},${zeroLine}L`;\n\t\tlet regEndPt = `L${newXList.slice(-1)[0]}, ${zeroLine}`;\n\n\t\tconst animRegion = [\n\t\t\tpaths.region,\n\t\t\t{d:\"M\" + regStartPt + pointsStr + regEndPt},\n\t\t\tPATH_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\t\tpathComponents.push(animRegion);\n\t}\n\n\treturn pathComponents;\n}\n\nexport function animatePathStr(oldPath, pathStr) {\n\treturn [oldPath, {d: pathStr}, UNIT_ANIM_DUR, STD_EASING];\n}\n","// Leveraging SMIL Animations\n\nimport { REPLACE_ALL_NEW_DUR } from './animate';\n\nconst EASING = {\n\tease: \"0.25 0.1 0.25 1\",\n\tlinear: \"0 0 1 1\",\n\t// easein: \"0.42 0 1 1\",\n\teasein: \"0.1 0.8 0.2 1\",\n\teaseout: \"0 0 0.58 1\",\n\teaseinout: \"0.42 0 0.58 1\"\n};\n\nfunction animateSVGElement(element, props, dur, easingType=\"linear\", type=undefined, oldValues={}) {\n\n\tlet animElement = element.cloneNode(true);\n\tlet newElement = element.cloneNode(true);\n\n\tfor(var attributeName in props) {\n\t\tlet animateElement;\n\t\tif(attributeName === 'transform') {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animateTransform\");\n\t\t} else {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animate\");\n\t\t}\n\t\tlet currentValue = oldValues[attributeName] || element.getAttribute(attributeName);\n\t\tlet value = props[attributeName];\n\n\t\tlet animAttr = {\n\t\t\tattributeName: attributeName,\n\t\t\tfrom: currentValue,\n\t\t\tto: value,\n\t\t\tbegin: \"0s\",\n\t\t\tdur: dur/1000 + \"s\",\n\t\t\tvalues: currentValue + \";\" + value,\n\t\t\tkeySplines: EASING[easingType],\n\t\t\tkeyTimes: \"0;1\",\n\t\t\tcalcMode: \"spline\",\n\t\t\tfill: 'freeze'\n\t\t};\n\n\t\tif(type) {\n\t\t\tanimAttr[\"type\"] = type;\n\t\t}\n\n\t\tfor (var i in animAttr) {\n\t\t\tanimateElement.setAttribute(i, animAttr[i]);\n\t\t}\n\n\t\tanimElement.appendChild(animateElement);\n\n\t\tif(type) {\n\t\t\tnewElement.setAttribute(attributeName, `translate(${value})`);\n\t\t} else {\n\t\t\tnewElement.setAttribute(attributeName, value);\n\t\t}\n\t}\n\n\treturn [animElement, newElement];\n}\n\nexport function transform(element, style) { // eslint-disable-line no-unused-vars\n\telement.style.transform = style;\n\telement.style.webkitTransform = style;\n\telement.style.msTransform = style;\n\telement.style.mozTransform = style;\n\telement.style.oTransform = style;\n}\n\nfunction animateSVG(svgContainer, elements) {\n\tlet newElements = [];\n\tlet animElements = [];\n\n\telements.map(element => {\n\t\tlet unit = element[0];\n\t\tlet parent = unit.parentNode;\n\n\t\tlet animElement, newElement;\n\n\t\telement[0] = unit;\n\t\t[animElement, newElement] = animateSVGElement(...element);\n\n\t\tnewElements.push(newElement);\n\t\tanimElements.push([animElement, parent]);\n\t\t\n\t\tif (parent) {\n\t\t\tparent.replaceChild(animElement, unit);\n\t\t}\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tif (animElement[1]) {\n\t\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\t\telements[i][0] = newElements[i];\n\t\t}\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport {\n makeText,\n makePath,\n xLine,\n yLine,\n generateAxisLabel,\n yMarker,\n yRegion,\n datasetBar,\n datasetDot,\n percentageBar,\n getPaths,\n heatSquare\n} from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport {\n translateHoriLine,\n translateVertLine,\n animateRegion,\n animateBar,\n animateDot,\n animatePath,\n animatePathStr\n} from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n constructor({\n layerClass = '',\n layerTransform = '',\n constants,\n\n getData,\n makeElements,\n animateElements\n }) {\n this.layerTransform = layerTransform;\n this.constants = constants;\n\n this.makeElements = makeElements;\n this.getData = getData;\n\n this.animateElements = animateElements;\n\n this.store = [];\n this.labels = [];\n\n this.layerClass = layerClass;\n this.layerClass =\n typeof this.layerClass === 'function' ? this.layerClass() : this.layerClass;\n\n this.refresh();\n }\n\n refresh(data) {\n this.data = data || this.getData();\n }\n\n setup(parent) {\n this.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n }\n\n make() {\n this.render(this.data);\n this.oldData = this.data;\n }\n\n render(data) {\n this.store = this.makeElements(data);\n\n this.layer.textContent = '';\n this.store.forEach((element) => {\n element.length\n ? element.forEach((el) => {\n this.layer.appendChild(el);\n })\n : this.layer.appendChild(element);\n });\n this.labels.forEach((element) => {\n this.layer.appendChild(element);\n });\n }\n\n update(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tdonutSlices: {\n\t\tlayerClass: 'donut-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) => {\n\t\t\t\tlet slice = makePath(s, 'donut-path', data.colors[i], 'none', data.strokeWidth);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) => animatePathStr(slice, newData.sliceStrings[i]));\n\t\t},\n\t},\n\tpieSlices: {\n\t\tlayerClass: 'pie-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) =>{\n\t\t\t\tlet slice = makePath(s, 'pie-path', 'none', data.colors[i]);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) =>\n\t\t\t\tanimatePathStr(slice, newData.sliceStrings[i])\n\t\t\t);\n\t\t}\n\t},\n\tpercentageBars: {\n\t\tlayerClass: 'percentage-bars',\n\t\tmakeElements(data) {\n\t\t\treturn data.xPositions.map((x, i) =>{\n\t\t\t\tlet y = 0;\n\t\t\t\tlet bar = percentageBar(x, y, data.widths[i],\n\t\t\t\t\tthis.constants.barHeight, this.constants.barDepth, data.colors[i]);\n\t\t\t\treturn bar;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n yAxis: {\n layerClass: 'y axis',\n makeElements(data) {\n let elements = [];\n\t\t\t// will loop through each yaxis dataset if it exists \n if (data.length) {\n data.forEach((item, i) => {\n item.positions.map((position, i) => {\n elements.push(\n yLine(position, item.labels[i], this.constants.width, {\n mode: this.constants.mode,\n pos: item.pos || this.constants.pos,\n shortenNumbers: this.constants.shortenNumbers\n })\n );\n });\n // we need to make yAxis titles if they are defined\n if (item.title) {\n elements.push(\n generateAxisLabel({\n title: item.title,\n position: item.pos,\n\t\t\t\t\t\t\t\theight: this.constants.height || data.zeroLine,\n width: this.constants.width\n })\n );\n }\n });\n\n return elements;\n }\n\n data.positions.forEach((position, i) => {\n elements.push(yLine(position, data.labels[i], this.constants.width, {\n mode: this.constants.mode,\n pos: data.pos || this.constants.pos,\n shortenNumbers: this.constants.shortenNumbers\n }));\n });\n\n\t\t\tif (data.title) {\n\t\t\t\telements.push(\n\t\t\t\t\tgenerateAxisLabel({\n\t\t\t\t\t\ttitle: data.title,\n\t\t\t\t\t\tposition: data.pos,\n\t\t\t\t\t\theight: this.constants.height || data.zeroLine,\n\t\t\t\t\t\twidth: this.constants.width\n\t\t\t\t\t})\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn elements;\n },\n\n animateElements(newData) {\n const animateMultipleElements = (oldData, newData) => {\n let newPos = newData.positions;\n let newLabels = newData.labels;\n let oldPos = oldData.positions;\n let oldLabels = oldData.labels;\n\n [oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n [oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n this.render({\n positions: oldPos,\n labels: newLabels\n });\n\n return this.store.map((line, i) => {\n return translateHoriLine(line, newPos[i], oldPos[i]);\n });\n };\n\n // we will need to animate both axis if we have more than one.\n // so check if the oldData is an array of values.\n if (this.oldData instanceof Array) {\n return this.oldData.forEach((old, i) => {\n animateMultipleElements(old, newData[i]);\n });\n }\n\n let newPos = newData.positions;\n let newLabels = newData.labels;\n let oldPos = this.oldData.positions;\n let oldLabels = this.oldData.labels;\n\n [oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n [oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n this.render({\n positions: oldPos,\n labels: newLabels\n });\n\n return this.store.map((line, i) => {\n return translateHoriLine(line, newPos[i], oldPos[i]);\n });\n }\n },\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map((m) => \n\t\t\t\tyMarker(m.position, m.label, this.constants.width, {\n\t\t\t\t\tlabelPos: m.options.labelPos,\n\t\t\t\t\tmode: 'span',\n\t\t\t\t\tlineType: 'dashed'\n\t\t\t\t})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, radius, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, radius, day.fill, data);\n\t\t\t\t\t\tthis.serializedSubDomains.push(square);\n\t\t\t\t\t}\n\t\t\t\t\ty += rowHeight;\n\t\t\t\t});\n\t\t\t\ty = 0;\n\t\t\t\tx += colWidth;\n\t\t\t});\n\n\t\t\treturn this.serializedSubDomains;\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\n\tbarGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-bars dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'bar';\n\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\treturn datasetBar(\n\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\ty,\n\t\t\t\t\tdata.barWidth,\n\t\t\t\t\tc.color,\n\t\t\t\t\tdata.labels[j],\n\t\t\t\t\tj,\n\t\t\t\t\tdata.offsets[j],\n\t\t\t\t\t{\n\t\t\t\t\t\tzeroLine: data.zeroLine,\n\t\t\t\t\t\tbarsWidth: data.barsWidth,\n\t\t\t\t\t\tminHeight: c.minHeight\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t});\n\t\t\treturn this.units;\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newOffsets = newData.offsets;\n\t\t\tlet newLabels = newData.labels;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldOffsets = this.oldData.offsets;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldOffsets, newOffsets] = equilizeNoOfElements(oldOffsets, newOffsets);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\toffsets: oldOffsets,\n\t\t\t\tlabels: newLabels,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tbarsWidth: this.oldData.barsWidth,\n\t\t\t\tbarWidth: this.oldData.barWidth,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((bar, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateBar(\n\t\t\t\t\tbar, newXPos[i], newYPos[i], newData.barWidth, newOffsets[i],\n\t\t\t\t\t{zeroLine: newData.zeroLine}\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n lineGraph: {\n layerClass: function () {\n return 'dataset-units dataset-line dataset-' + this.constants.index;\n },\n makeElements(data) {\n let c = this.constants;\n this.unitType = 'dot';\n this.paths = {};\n if (!c.hideLine) {\n this.paths = getPaths(\n data.xPositions,\n data.yPositions,\n c.color,\n {\n heatline: c.heatline,\n regionFill: c.regionFill,\n spline: c.spline\n },\n {\n svgDefs: c.svgDefs,\n zeroLine: data.zeroLine\n }\n );\n }\n\n this.units = [];\n\n if (!c.hideDots) {\n this.units = data.yPositions.map((y, j) => {\n return datasetDot(\n data.xPositions[j],\n y,\n data.radius,\n c.color,\n c.valuesOverPoints ? data.values[j] : '',\n j\n );\n });\n }\n\n return Object.values(this.paths).concat(this.units);\n },\n animateElements(newData) {\n let newXPos = newData.xPositions;\n let newYPos = newData.yPositions;\n let newValues = newData.values;\n\n let oldXPos = this.oldData.xPositions;\n let oldYPos = this.oldData.yPositions;\n let oldValues = this.oldData.values;\n\n [oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n [oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n [oldValues, newValues] = equilizeNoOfElements(oldValues, newValues);\n\n this.render({\n xPositions: oldXPos,\n yPositions: oldYPos,\n values: newValues,\n\n zeroLine: this.oldData.zeroLine,\n radius: this.oldData.radius\n });\n\n let animateElements = [];\n\n if (Object.keys(this.paths).length) {\n animateElements = animateElements.concat(\n animatePath(\n this.paths,\n newXPos,\n newYPos,\n newData.zeroLine,\n this.constants.spline\n )\n );\n }\n\n if (this.units.length) {\n this.units.map((dot, i) => {\n animateElements = animateElements.concat(\n animateDot(dot, newXPos[i], newYPos[i])\n );\n });\n }\n\n return animateElements;\n }\n }\n};\n\nexport function getComponent(name, constants, getData) {\n\tlet keys = Object.keys(componentConfigs).filter(k => name.includes(k));\n\tlet config = componentConfigs[keys[0]];\n\tObject.assign(config, {\n\t\tconstants: constants,\n\t\tgetData: getData\n\t});\n\treturn new ChartComponent(config);\n}\n","import { floatTwo } from './helpers';\n\nfunction normalize(x) {\n\t// Calculates mantissa and exponent of a number\n\t// Returns normalized number and exponent\n\t// https://stackoverflow.com/q/9383593/6495043\n\n\tif(x===0) {\n\t\treturn [0, 0];\n\t}\n\tif(isNaN(x)) {\n\t\treturn {mantissa: -6755399441055744, exponent: 972};\n\t}\n\tvar sig = x > 0 ? 1 : -1;\n\tif(!isFinite(x)) {\n\t\treturn {mantissa: sig * 4503599627370496, exponent: 972};\n\t}\n\n\tx = Math.abs(x);\n\tvar exp = Math.floor(Math.log10(x));\n\tvar man = x/Math.pow(10, exp);\n\n\treturn [sig * man, exp];\n}\n\nfunction getChartRangeIntervals(max, min=0) {\n\tlet upperBound = Math.ceil(max);\n\tlet lowerBound = Math.floor(min);\n\tlet range = upperBound - lowerBound;\n\n\tlet noOfParts = range;\n\tlet partSize = 1;\n\n\t// To avoid too many partitions\n\tif(range > 5) {\n\t\tif(range % 2 !== 0) {\n\t\t\tupperBound++;\n\t\t\t// Recalc range\n\t\t\trange = upperBound - lowerBound;\n\t\t}\n\t\tnoOfParts = range/2;\n\t\tpartSize = 2;\n\t}\n\n\t// Special case: 1 and 2\n\tif(range <= 2) {\n\t\tnoOfParts = 4;\n\t\tpartSize = range/noOfParts;\n\t}\n\n\t// Special case: 0\n\tif(range === 0) {\n\t\tnoOfParts = 5;\n\t\tpartSize = 1;\n\t}\n\n\tlet intervals = [];\n\tfor(var i = 0; i <= noOfParts; i++){\n\t\tintervals.push(lowerBound + partSize * i);\n\t}\n\treturn intervals;\n}\n\nfunction getChartIntervals(maxValue, minValue=0) {\n\tlet [normalMaxValue, exponent] = normalize(maxValue);\n\tlet normalMinValue = minValue ? minValue/Math.pow(10, exponent): 0;\n\n\t// Allow only 7 significant digits\n\tnormalMaxValue = normalMaxValue.toFixed(6);\n\n\tlet intervals = getChartRangeIntervals(normalMaxValue, normalMinValue);\n\tintervals = intervals.map(value => {\n\t\t// For negative exponents we want to divide by 10^-exponent to avoid\n\t\t// floating point arithmetic bugs. For instance, in javascript\n\t\t// 6 * 10^-1 == 0.6000000000000001, we instead want 6 / 10^1 == 0.6\n\t\tif (exponent < 0) {\n\t\t\treturn value / Math.pow(10, -exponent);\n\t\t}\n\t\treturn value * Math.pow(10, exponent);\n\t});\n\treturn intervals;\n}\n\nexport function calcChartIntervals(values, withMinimum=false) {\n\t//*** Where the magic happens ***\n\n\t// Calculates best-fit y intervals from given values\n\t// and returns the interval array\n\n\tlet maxValue = Math.max(...values);\n\tlet minValue = Math.min(...values);\n\n\t// Exponent to be used for pretty print\n\tlet exponent = 0, intervals = []; // eslint-disable-line no-unused-vars\n\n\tfunction getPositiveFirstIntervals(maxValue, absMinValue) {\n\t\tlet intervals = getChartIntervals(maxValue);\n\n\t\tlet intervalSize = intervals[1] - intervals[0];\n\n\t\t// Then unshift the negative values\n\t\tlet value = 0;\n\t\tfor(var i = 1; value < absMinValue; i++) {\n\t\t\tvalue += intervalSize;\n\t\t\tintervals.unshift((-1) * value);\n\t\t}\n\t\treturn intervals;\n\t}\n\n\t// CASE I: Both non-negative\n\n\tif(maxValue >= 0 && minValue >= 0) {\n\t\texponent = normalize(maxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(maxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(maxValue, minValue);\n\t\t}\n\t}\n\n\t// CASE II: Only minValue negative\n\n\telse if(maxValue > 0 && minValue < 0) {\n\t\t// `withMinimum` irrelevant in this case,\n\t\t// We'll be handling both sides of zero separately\n\t\t// (both starting from zero)\n\t\t// Because ceil() and floor() behave differently\n\t\t// in those two regions\n\n\t\tlet absMinValue = Math.abs(minValue);\n\n\t\tif(maxValue >= absMinValue) {\n\t\t\texponent = normalize(maxValue)[1];\n\t\t\tintervals = getPositiveFirstIntervals(maxValue, absMinValue);\n\t\t} else {\n\t\t\t// Mirror: maxValue => absMinValue, then change sign\n\t\t\texponent = normalize(absMinValue)[1];\n\t\t\tlet posIntervals = getPositiveFirstIntervals(absMinValue, maxValue);\n\t\t\tintervals = posIntervals.reverse().map(d => d * (-1));\n\t\t}\n\n\t}\n\n\t// CASE III: Both non-positive\n\n\telse if(maxValue <= 0 && minValue <= 0) {\n\t\t// Mirrored Case I:\n\t\t// Work with positives, then reverse the sign and array\n\n\t\tlet pseudoMaxValue = Math.abs(minValue);\n\t\tlet pseudoMinValue = Math.abs(maxValue);\n\n\t\texponent = normalize(pseudoMaxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue, pseudoMinValue);\n\t\t}\n\n\t\tintervals = intervals.reverse().map(d => d * (-1));\n\t}\n\n\treturn intervals;\n}\n\nexport function getZeroIndex(yPts) {\n\tlet zeroIndex;\n\tlet interval = getIntervalSize(yPts);\n\tif(yPts.indexOf(0) >= 0) {\n\t\t// the range has a given zero\n\t\t// zero-line on the chart\n\t\tzeroIndex = yPts.indexOf(0);\n\t} else if(yPts[0] > 0) {\n\t\t// Minimum value is positive\n\t\t// zero-line is off the chart: below\n\t\tlet min = yPts[0];\n\t\tzeroIndex = (-1) * min / interval;\n\t} else {\n\t\t// Maximum value is negative\n\t\t// zero-line is off the chart: above\n\t\tlet max = yPts[yPts.length - 1];\n\t\tzeroIndex = (-1) * max / interval + (yPts.length - 1);\n\t}\n\treturn zeroIndex;\n}\n\nexport function getRealIntervals(max, noOfIntervals, min = 0, asc = 1) {\n\tlet range = max - min;\n\tlet part = range * 1.0 / noOfIntervals;\n\tlet intervals = [];\n\n\tfor(var i = 0; i <= noOfIntervals; i++) {\n\t\tintervals.push(min + part * i);\n\t}\n\n\treturn asc ? intervals : intervals.reverse();\n}\n\nexport function getIntervalSize(orderedArray) {\n\treturn orderedArray[1] - orderedArray[0];\n}\n\nexport function getValueRange(orderedArray) {\n\treturn orderedArray[orderedArray.length-1] - orderedArray[0];\n}\n\nexport function scale(val, yAxis) {\n\treturn floatTwo(yAxis.zeroLine - val * yAxis.scaleMultiplier);\n}\n\nexport function isInRange(val, min, max) {\n\treturn val > min && val < max;\n}\n\nexport function isInRange2D(coord, minCoord, maxCoord) {\n\treturn isInRange(coord[0], minCoord[0], maxCoord[0])\n\t\t&& isInRange(coord[1], minCoord[1], maxCoord[1]);\n}\n\nexport function getClosestInArray(goal, arr, index = false) {\n\tlet closest = arr.reduce(function(prev, curr) {\n\t\treturn (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);\n\t}, []);\n\n\treturn index ? arr.indexOf(closest) : closest;\n}\n\nexport function calcDistribution(values, distributionSize) {\n\t// Assume non-negative values,\n\t// implying distribution minimum at zero\n\n\tlet dataMaxValue = Math.max(...values);\n\n\tlet distributionStep = 1 / (distributionSize - 1);\n\tlet distribution = [];\n\n\tfor(var i = 0; i < distributionSize; i++) {\n\t\tlet checkpoint = dataMaxValue * (distributionStep * i);\n\t\tdistribution.push(checkpoint);\n\t}\n\n\treturn distribution;\n}\n\nexport function getMaxCheckpoint(value, distribution) {\n\treturn distribution.filter(d => d < value).length;\n}\n","import { fillArray } from '../utils/helpers';\nimport { DEFAULT_AXIS_CHART_TYPE, AXIS_DATASET_CHART_TYPES, DEFAULT_CHAR_WIDTH } from '../utils/constants';\n\nexport function dataPrep(data, type) {\n\tdata.labels = data.labels || [];\n\n\tlet datasetLength = data.labels.length;\n\n\t// Datasets\n\tlet datasets = data.datasets;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\tif(!datasets) {\n\t\t// default\n\t\tdatasets = [{\n\t\t\tvalues: zeroArray\n\t\t}];\n\t}\n\n\tdatasets.map(d=> {\n\t\t// Set values\n\t\tif(!d.values) {\n\t\t\td.values = zeroArray;\n\t\t} else {\n\t\t\t// Check for non values\n\t\t\tlet vals = d.values;\n\t\t\tvals = vals.map(val => (!isNaN(val) ? val : 0));\n\n\t\t\t// Trim or extend\n\t\t\tif(vals.length > datasetLength) {\n\t\t\t\tvals = vals.slice(0, datasetLength);\n\t\t\t} else {\n\t\t\t\tvals = fillArray(vals, datasetLength - vals.length, 0);\n\t\t\t}\n\t\t\td.values = vals;\n\t\t}\n\n\t\t// Set type\n\t\tif(!d.chartType ) {\n\t\t\tif(!AXIS_DATASET_CHART_TYPES.includes(type)) type === DEFAULT_AXIS_CHART_TYPE;\n\t\t\td.chartType = type;\n\t\t}\n\n\t});\n\n\t// Markers\n\n\t// Regions\n\t// data.yRegions = data.yRegions || [];\n\tif(data.yRegions) {\n\t\tdata.yRegions.map(d => {\n\t\t\tif(d.end < d.start) {\n\t\t\t\t[d.start, d.end] = [d.end, d.start];\n\t\t\t}\n\t\t});\n\t}\n\n\treturn data;\n}\n\nexport function zeroDataPrep(realData) {\n\tlet datasetLength = realData.labels.length;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\n let zeroData = {\n labels: realData.labels.slice(0, -1),\n datasets: realData.datasets.map((d) => {\n const { axisID } = d;\n return {\n axisID,\n name: '',\n values: zeroArray.slice(0, -1),\n chartType: d.chartType\n };\n })\n };\n\n\tif(realData.yMarkers) {\n\t\tzeroData.yMarkers = [\n\t\t\t{\n\t\t\t\tvalue: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\tif(realData.yRegions) {\n\t\tzeroData.yRegions = [\n\t\t\t{\n\t\t\t\tstart: 0,\n\t\t\t\tend: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\treturn zeroData;\n}\n\nexport function getShortenedLabels(chartWidth, labels=[], isSeries=true) {\n\tlet allowedSpace = chartWidth / labels.length;\n\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet seriesMultiple;\n\tif(isSeries) {\n\t\t// Find the maximum label length for spacing calculations\n\t\tlet maxLabelLength = Math.max(...labels.map(label => label.length));\n\t\tseriesMultiple = Math.ceil(maxLabelLength/allowedLetters);\n\t}\n\n\tlet calcLabels = labels.map((label, i) => {\n\t\tlabel += \"\";\n\t\tif(label.length > allowedLetters) {\n\n\t\t\tif(!isSeries) {\n\t\t\t\tif(allowedLetters-3 > 0) {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters-3) + \" ...\";\n\t\t\t\t} else {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters) + '..';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif(i % seriesMultiple !== 0) {\n\t\t\t\t\tlabel = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn label;\n\t});\n\n\treturn calcLabels;\n}\n","import '../css/charts.scss';\n\n// import MultiAxisChart from './charts/MultiAxisChart';\nimport PercentageChart from './charts/PercentageChart';\nimport PieChart from './charts/PieChart';\nimport Heatmap from './charts/Heatmap';\nimport AxisChart from './charts/AxisChart';\nimport DonutChart from './charts/DonutChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart,\n\tdonut: DonutChart,\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };","function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `\n\t\t\t\t
        \n\t\t\t\t
        `\n\t\t});\n\t\tthis.hideTip();\n\n\t\tthis.title = this.container.querySelector('.title');\n\t\tthis.dataPointList = this.container.querySelector('.data-point-list');\n\n\t\tthis.parent.addEventListener('mouseleave', () => {\n\t\t\tthis.hideTip();\n\t\t});\n\t}\n\n\tfill() {\n\t\tlet title;\n\t\tif(this.index) {\n\t\t\tthis.container.setAttribute('data-point-index', this.index);\n\t\t}\n\t\tif(this.titleValueFirst) {\n\t\t\ttitle = `${this.titleValue}${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}${this.titleValue}`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `${ value === 0 || value ? value : '' }\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth, isHidden } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\nimport { deepClone } from '../utils/helpers';\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\t\t// deepclone options to avoid making changes to orignal object\n\t\toptions = deepClone(options);\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || '';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: (typeof options.animate !== 'undefined') ? options.animate : 1,\n\t\t\ttruncateLegends: options.truncateLegends || 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tthis.boundDrawFn = () => this.draw(true);\n\t\tif (ResizeObserver) {\n\t\t\tthis.resizeObserver = new ResizeObserver(this.boundDrawFn);\n\t\t\tthis.resizeObserver.observe(this.parent);\n\t\t}\n\t\twindow.addEventListener('resize', this.boundDrawFn);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn);\n\t}\n\n\tdestroy() {\n\t\tif (this.resizeObserver) this.resizeObserver.disconnect();\n\t\twindow.removeEventListener('resize', this.boundDrawFn);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn);\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t}\n\n\t\tthis.container = $.create('div', args);\n\t}\n\n\tmakeTooltip() {\n\t\tthis.tip = new SvgTip({\n\t\t\tparent: this.container,\n\t\t\tcolors: this.colors\n\t\t});\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {}\n\n\tdraw(onlyWidthChange=false, init=false) {\n\t\tif (onlyWidthChange && isHidden(this.parent)) {\n\t\t\t// Don't update anything if the chart is hidden\n\t\t\treturn;\n\t\t}\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render(this.components, this.config.animate);\n\t\tthis.renderLegend();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { truncateString } from '../utils/draw-utils';\nimport { legendDot } from '../utils/draw';\nimport { round } from '../utils/helpers';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.formatTooltipY = (args.tooltipOptions || {}).formatTooltipY;\n\t\tthis.config.maxSlices = args.maxSlices || 20;\n\t\tthis.config.maxLegendPoints = args.maxLegendPoints || 20;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\t\tlet maxSlices = this.config.maxSlices;\n\t\ts.sliceTotals = [];\n\n\t\tlet allTotals = this.data.labels.map((label, i) => {\n\t\t\tlet total = 0;\n\t\t\tthis.data.datasets.map(e => {\n\t\t\t\ttotal += e.values[i];\n\t\t\t});\n\t\t\treturn [total, label];\n\t\t}).filter(d => { return d[0] >= 0; }); // keep only positive results\n\n\t\tlet totals = allTotals;\n\t\tif(allTotals.length > maxSlices) {\n\t\t\t// Prune and keep a grey area for rest as per maxSlices\n\t\t\tallTotals.sort((a, b) => { return b[0] - a[0]; });\n\n\t\t\ttotals = allTotals.slice(0, maxSlices-1);\n\t\t\tlet remaining = allTotals.slice(maxSlices-1);\n\n\t\t\tlet sumOfRemaining = 0;\n\t\t\tremaining.map(d => {sumOfRemaining += d[0];});\n\t\t\ttotals.push([sumOfRemaining, 'Rest']);\n\t\t\tthis.colors[maxSlices-1] = 'grey';\n\t\t}\n\n\t\ts.labels = [];\n\t\ttotals.map(d => {\n\t\t\ts.sliceTotals.push(round(d[0]));\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 150;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif (this.legendTotals.length < divisor) {\n\t\t\t\tbarWidth = this.width/this.legendTotals.length;\n\t\t\t}\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet label = this.config.truncateLegends ? truncateString(s.labels[i], barWidth/10) : s.labels[i];\n\t\t\tlet formatted = this.config.formatTooltipY ? this.config.formatTooltipY(d) : d;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${label}: ${formatted}`,\n\t\t\t\tfalse\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 60;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr, makeCircleStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class PieChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'pie';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius = (this.height > this.width ? this.center.x : this.center.y);\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst largeArc = originDiffAngle > 180 ? 1: 0;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath =\n\t\t\t\toriginDiffAngle === 360\n\t\t\t\t\t? makeCircleStr(curStart, curEnd, this.center, this.radius, clockWise, largeArc)\n\t\t\t\t\t: makeArcPathStr(curStart, curEnd, this.center, this.radius, clockWise, largeArc);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\tradius: this.rawChartArgs.radius || 0,\n\t\t\t\txTranslate: s.domainConfigs\n\t\t\t\t\t.filter((config, j) => j < i)\n\t\t\t\t\t.map(config => config.cols.length - lessCol)\n\t\t\t\t\t.reduce((a, b) => a + b, 0)\n\t\t\t\t\t* COL_WIDTH\n\t\t\t},\n\t\t\tfunction() {\n\t\t\t\treturn s.domainConfigs[i];\n\t\t\t}.bind(this)\n\n\t\t]);\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map((args, i) => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0] + '-' + i, component];\n\t\t\t})\n\t\t);\n\n\t\tlet y = 0;\n\t\tDAY_NAMES_SHORT.forEach((dayName, i) => {\n\t\t\tif([1, 3, 5].includes(i)) {\n\t\t\t\tlet dayText = makeText('subdomain-name', -COL_WIDTH/2, y, dayName,\n\t\t\t\t\t{\n\t\t\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\t\t\tdy: 8,\n\t\t\t\t\t\ttextAnchor: 'end'\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tthis.drawArea.appendChild(dayText);\n\t\t\t}\n\t\t\ty += ROW_HEIGHT;\n\t\t});\n\t}\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\n\t\tthis.data = this.prepareData(data);\n\t\tthis.draw();\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tthis.components.forEach(comp => {\n\t\t\t\tlet daySquares = comp.store;\n\t\t\t\tlet daySquare = e.target;\n\t\t\t\tif(daySquares.includes(daySquare)) {\n\n\t\t\t\t\tlet count = daySquare.getAttribute('data-value');\n\t\t\t\t\tlet dateParts = daySquare.getAttribute('data-date').split('-');\n\n\t\t\t\t\tlet month = getMonthName(parseInt(dateParts[1])-1, true);\n\n\t\t\t\t\tlet gOff = this.container.getBoundingClientRect(), pOff = daySquare.getBoundingClientRect();\n\n\t\t\t\t\tlet width = parseInt(e.target.getAttribute('width'));\n\t\t\t\t\tlet x = pOff.left - gOff.left + width/2;\n\t\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\t\tlet value = count + ' ' + this.countLabel;\n\t\t\t\t\tlet name = ' on ' + month + ' ' + dateParts[0] + ', ' + dateParts[2];\n\n\t\t\t\t\tthis.tip.setValues(x, y, {name: name, value: value, valueFirst: 1}, []);\n\t\t\t\t\tthis.tip.showTip();\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\trenderLegend() {\n\t\tthis.legendArea.textContent = '';\n\t\tlet x = 0;\n\t\tlet y = ROW_HEIGHT;\n\t\tlet radius = this.rawChartArgs.radius || 0;\n\n\t\tlet lessText = makeText('subdomain-name', x, y, 'Less',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tx = (COL_WIDTH * 2) + COL_WIDTH/2;\n\t\tthis.legendArea.appendChild(lessText);\n\n\t\tthis.colors.slice(0, HEATMAP_DISTRIBUTION_SIZE).map((color, i) => {\n\t\t\tconst square = heatSquare('heatmap-legend-unit', x + (COL_WIDTH + 3) * i,\n\t\t\t\ty, HEATMAP_SQUARE_SIZE, radius, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.type = args.type || 'line';\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n super.configure(options);\n const { axisOptions = {} } = options;\n const { xAxis, yAxis } = axisOptions || {};\n\n options.tooltipOptions = options.tooltipOptions || {};\n\n this.config.xAxisMode = xAxis ? xAxis.xAxisMode : axisOptions.xAxisMode || 'span';\n\n // this will pass an array\n // lets determine if we need two yAxis based on if there is length\n // to the yAxis array\n if (yAxis && yAxis.length) {\n this.config.yAxisConfig = yAxis.map((item) => {\n return {\n yAxisMode: item.yAxisMode,\n id: item.id,\n position: item.position,\n title: item.title\n };\n });\n } else {\n this.config.yAxisMode = yAxis ? yAxis.yAxisMode : axisOptions.yAxisMode || 'span';\n\n\t\t\t// if we have yAxis config settings lets populate a yAxis config array.\n\t\t\tif (yAxis && yAxis.id && yAxis.position) {\n\t\t\t\tthis.config.yAxisConfig = [yAxis]\n\t\t\t}\n }\n\n this.config.xIsSeries = axisOptions.xIsSeries || 0;\n this.config.shortenYAxisNumbers = axisOptions.shortenYAxisNumbers || 0;\n\n this.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n this.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n this.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\n calcYAxisParameters(dataValues, withMinimum = 'false') {\n let yPts, scaleMultiplier, intervalHeight, zeroLine, positions, yAxisConfigObject, yAxisAlignment, yKeys;\n\t\tyKeys = [];\n\t\tyAxisConfigObject = this.config.yAxisMode || {};\t\n\t\tyAxisAlignment = yAxisConfigObject.position ? yAxisConfigObject.position : 'left';\t\n\n // if we have an object we have multiple yAxisParameters.\n if (dataValues instanceof Array) {\n yPts = calcChartIntervals(dataValues, withMinimum);\n scaleMultiplier = this.height / getValueRange(yPts);\n intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n zeroLine = this.height - getZeroIndex(yPts) * intervalHeight;\n\n this.state.yAxis = {\n labels: yPts,\n positions: yPts.map((d) => zeroLine - d * scaleMultiplier),\n\t\t\t\ttitle: yAxisConfigObject.title || null,\n\t\t\t\tpos: yAxisAlignment,\n scaleMultiplier: scaleMultiplier,\n zeroLine: zeroLine\n };\n } else {\n this.state.yAxis = [];\n for (let key in dataValues) {\n const dataValue = dataValues[key];\n\t\t\t\tyAxisConfigObject = this.config.yAxisConfig.find((item) => key === item.id) || [];\n\t\t\t\tyAxisAlignment = yAxisConfigObject.position ? yAxisConfigObject.position : 'left';\t\n yPts = calcChartIntervals(dataValue, withMinimum);\n scaleMultiplier = this.height / getValueRange(yPts);\n intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n zeroLine = this.height - getZeroIndex(yPts) * intervalHeight;\n positions = yPts.map((d) => zeroLine - d * scaleMultiplier);\n\t\t\t\tyKeys.push(key);\n\n if (this.state.yAxis.length > 1) {\n const yPtsArray = [];\n const firstArr = this.state.yAxis[0];\n\n\t\t\t\t\t// we need to calculate the scaleMultiplier.\n\n\t\t\t\t\t// now that we have an accurate scaleMultiplier we can \n // we need to loop through original positions.\n\t\t\t\t\tscaleMultiplier = this.height / getValueRange(yPts);\n firstArr.positions.forEach((pos) => {\n yPtsArray.push(Math.ceil(pos / scaleMultiplier));\n });\n yPts = yPtsArray.reverse();\n zeroLine = this.height - getZeroIndex(yPts) * intervalHeight;\n positions = firstArr.positions;\n }\n\n this.state.yAxis.push({\n axisID: key || 'left-axis',\n labels: yPts,\n title: yAxisConfigObject.title,\n pos: yAxisAlignment,\n scaleMultiplier,\n zeroLine,\n positions\n });\n }\n\n\t\t\t// the labels are not aligned in length between the two yAxis objects,\n\t\t\t// we need to run some new calculations.\n\t\t\tif (this.state.yAxis[1] && this.state.yAxis[0].labels.length !== this.state.yAxis[1].labels.length) {\n\t\t\t\tconst newYptsArr = [];\n\t\t\t\t// find the shorter array\n\t\t\t\tconst shortest = this.state.yAxis.reduce((p,c) => { \n\t\t\t\t\treturn p.length > c.labels.length ? c : p;\n\t\t\t\t},\n\t\t\t\t{ length: Infinity });\n\t\t\t\t// return the longest\n\t\t\t\tconst longest = this.state.yAxis.reduce((p,c) => { \n\t\t\t\t\treturn p.length < c.labels.length ? p : c;\n\t\t\t\t},\n\t\t\t\t{ length: Infinity });\n\n\t\t\t\t// we now need to populate the shortest obj with the new scale multiplier\n\t\t\t\t// with the positions of the longest obj.\n\t\t\t\tlongest.positions.forEach((pos) => {\n\t\t\t\t\t// calculate a new yPts\n\t\t\t\t\tnewYptsArr.push(Math.ceil(pos / shortest.scaleMultiplier));\n\t\t\t\t});\n\n\t\t\t\tshortest.labels = newYptsArr.reverse();\n\t\t\t\tshortest.positions = longest.positions;\n\t\t\t}\n }\n\n // Dependent if above changes\n this.calcDatasetPoints();\n this.calcYExtremes();\n this.calcYRegions();\n }\n\n calcDatasetPoints() {\n let s = this.state;\n let scaleAll = (values, id) => {\n return values.map((val) => {\n let { yAxis } = s;\n\n if (yAxis instanceof Array) {\n\t\t\t\t\tyAxis = yAxis.length > 1 ? yAxis.find((axis) => id === axis.axisID) : s.yAxis[0];\n }\n\n return scale(val, yAxis);\n });\n };\n\n s.barChartIndex = 1;\n s.datasets = this.data.datasets.map((d, i) => {\n let values = d.values;\n let cumulativeYs = d.cumulativeYs || [];\n\n return {\n name:\n d.name &&\n d.name.replace(/<|>|&/g, (char) =>\n char == '&' ? '&' : char == '<' ? '<' : '>'\n ),\n index: i,\n barIndex: d.chartType === 'bar' ? s.barChartIndex++ : s.barChartIndex,\n chartType: d.chartType,\n\n values: values,\n yPositions: scaleAll(values, d.axisID),\n id: d.axisID,\n\n cumulativeYs: cumulativeYs,\n cumulativeYPos: scaleAll(cumulativeYs, d.axisID)\n };\n });\n }\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n getAllYValues() {\n let key = 'values';\n let multiAxis = this.config.yAxisConfig ? true : false;\n let allValueLists = multiAxis ? {} : [];\n\n let groupBy = (arr, property) => {\n return arr.reduce((acc, cur) => {\n acc[cur[property]] = [...(acc[cur[property]] || []), cur];\n return acc;\n }, {});\n };\n\n let generateCumulative = (arr) => {\n let cumulative = new Array(this.state.datasetLength).fill(0);\n arr.forEach((d, i) => {\n let values = arr[i].values;\n d[key] = cumulative = cumulative.map((c, i) => {\n return c + values[i];\n });\n });\n };\n\n if (this.barOptions.stacked) {\n key = 'cumulativeYs';\n // we need to filter out the different yAxis ID's here.\n if (multiAxis) {\n const groupedDataSets = groupBy(this.data.datasets, 'axisID');\n // const dataSetsByAxis = this.data.dd\n for (var axisID in groupedDataSets) {\n generateCumulative(groupedDataSets[axisID]);\n }\n } else {\n generateCumulative(this.data.datasets);\n }\n }\n\n // this is the trouble maker, we don't want to merge all\n // datasets since we are trying to run two yAxis.\n if (multiAxis) {\n this.data.datasets.forEach((d) => {\n // if the array exists already just push more data into it.\n // otherwise create a new array into the object.\n allValueLists[d.axisID || key]\n ? allValueLists[d.axisID || key].push(...d[key])\n : (allValueLists[d.axisID || key] = [...d[key]]);\n });\n } else {\n allValueLists = this.data.datasets.map((d) => {\n return d[key];\n });\n }\n\n if (this.data.yMarkers && !multiAxis) {\n allValueLists.push(this.data.yMarkers.map((d) => d.value));\n }\n\n if (this.data.yRegions && !multiAxis) {\n this.data.yRegions.map((d) => {\n allValueLists.push([d.end, d.start]);\n });\n }\n\n return multiAxis ? allValueLists : [].concat(...allValueLists);\n }\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'xAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.xAxisMode,\n\t\t\t\t\theight: this.height,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\ts.xAxis.calcLabels = getShortenedLabels(this.width,\n\t\t\t\t\t\ts.xAxis.labels, this.config.xIsSeries);\n\n\t\t\t\t\treturn s.xAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'yRegions',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yRegions;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\t\t];\n\n // if we have multiple yAxisConfigs we need to update the yAxisDefault\n // components to multiple yAxis components.\n if (this.config.yAxisConfig && this.config.yAxisConfig.length) {\n this.config.yAxisConfig.forEach((yAxis) => {\n componentConfigs.push([\n 'yAxis',\n {\n mode: this.config.yAxisMode,\n width: this.width,\n\t\t\t\t\t\theight: this.baseHeight,\n shortenNumbers: this.config.shortenYAxisNumbers,\n pos: yAxis.position || 'left'\n },\n function () {\n return this.state.yAxis;\n }.bind(this)\n ]);\n });\n } else {\n componentConfigs.push([\n 'yAxis',\n {\n mode: this.config.yAxisMode,\n width: this.width,\n\t\t\t\t\theight: this.baseHeight,\n shortenNumbers: this.config.shortenYAxisNumbers\n },\n function () {\n return this.state.yAxis;\n }.bind(this)\n ]);\n }\n\n\t\tlet barDatasets = this.state.datasets.filter(d => d.chartType === 'bar');\n\t\tlet lineDatasets = this.state.datasets.filter(d => d.chartType === 'line');\n\n\t\tlet barsConfigs = barDatasets.map(d => {\n let index = d.index;\n let barIndex = d.barIndex || index;\n\t\t\treturn [\n\t\t\t\t'barGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tstacked: this.barOptions.stacked,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t\tminHeight: this.height * MIN_BAR_PERCENT_HEIGHT,\n\t\t\t\t},\n\t\t\t\tfunction() {\n let s = this.state;\n let { yAxis } = s;\n let d = s.datasets[index];\n let { id = 'left-axis' } = d;\n let stacked = this.barOptions.stacked;\n\n let spaceRatio = this.barOptions.spaceRatio || BAR_CHART_SPACE_RATIO;\n let barsWidth = s.unitWidth * (1 - spaceRatio);\n let barWidth = barsWidth / (stacked ? 1 : barDatasets.length);\n\n // if there are multiple yAxis we need to return the yAxis with the\n // proper ID.\n\t\t\t\t\tif (yAxis instanceof Array) {\n\t\t\t\t\t\t// if the person only configured one yAxis in the array return the first.\n\t\t\t\t\t\tyAxis = yAxis.length > 1 ? yAxis.find((axis) => id === axis.axisID) : s.yAxis[0];\n\t\t\t\t\t}\n\n\n let xPositions = s.xAxis.positions.map((x) => x - barsWidth / 2);\n\n if (!stacked) {\n xPositions = xPositions.map((p) => {\n return p + barWidth * barIndex - barWidth;\n });\n }\n\n let labels = new Array(s.datasetLength).fill('');\n if (this.config.valuesOverPoints) {\n if (stacked && d.index === s.datasets.length - 1) {\n labels = d.cumulativeYs;\n } else {\n labels = d.values;\n }\n }\n let offsets = new Array(s.datasetLength).fill(0);\n if (stacked) {\n offsets = d.yPositions.map((y, j) => y - d.cumulativeYPos[j]);\n }\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: xPositions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\t\t\t\t\t\toffsets: offsets,\n\t\t\t\t\t\t// values: d.values,\n\t\t\t\t\t\tlabels: labels,\n\n\t\t\t\t\t\tzeroLine: yAxis.zeroLine,\n\t\t\t\t\t\tbarsWidth: barsWidth,\n\t\t\t\t\t\tbarWidth: barWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n let lineConfigs = lineDatasets.map((d) => {\n let index = d.index;\n return [\n 'lineGraph' + '-' + d.index,\n {\n index: index,\n color: this.colors[index],\n svgDefs: this.svgDefs,\n heatline: this.lineOptions.heatline,\n regionFill: this.lineOptions.regionFill,\n spline: this.lineOptions.spline,\n hideDots: this.lineOptions.hideDots,\n hideLine: this.lineOptions.hideLine,\n\n // same for all datasets\n valuesOverPoints: this.config.valuesOverPoints\n },\n function () {\n let s = this.state;\n let d = s.datasets[index];\n\n // if we have more than one yindex lets map the values\n const yAxis = s.yAxis.length\n ? s.yAxis.find((axis) => d.id === axis.axisID) || s.yAxis[0]\n : s.yAxis;\n\n let minLine =\n yAxis.positions[0] < yAxis.zeroLine\n ? yAxis.positions[0]\n : yAxis.zeroLine;\n\n return {\n xPositions: s.xAxis.positions,\n yPositions: d.yPositions,\n\n values: d.values,\n\n zeroLine: minLine,\n radius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE\n };\n }.bind(this)\n ];\n });\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tif (index >= 0) {\n\t\t\tlet dbi = this.dataByIndex[index];\n\n\t\t\tthis.tip.setValues(\n\t\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\t\tdbi.values,\n\t\t\t\tindex\n\t\t\t);\n\n\t\t\tthis.tip.showTip();\n\t\t}\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name,\n\t\t\t\t\tthis.config.truncateLegends);\n\t\t\t\tthis.legendArea.appendChild(rect);\n\t\t\t});\n\t\t}\n\t}\n\n\n\n\t// Overlay\n\tmakeOverlay() {\n\t\tif(this.init) {\n\t\t\tthis.init = 0;\n\t\t\treturn;\n\t\t}\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\n\t\tthis.overlayGuides = this.dataUnitComponents.map(c => {\n\t\t\treturn {\n\t\t\t\ttype: c.unitType,\n\t\t\t\toverlay: undefined,\n\t\t\t\tunits: c.units,\n\t\t\t};\n\t\t});\n\n\t\tif(this.state.currentIndex === undefined) {\n\t\t\tthis.state.currentIndex = this.state.datasetLength - 1;\n\t\t}\n\n\t\t// Render overlays\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\n\t\t\td.overlay = makeOverlay[d.type](currentUnit);\n\t\t\tthis.drawArea.appendChild(d.overlay);\n\t\t});\n\t}\n\n\tupdateOverlayGuides() {\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\t}\n\n\tbindOverlay() {\n\t\tthis.parent.addEventListener('data-select', () => {\n\t\t\tthis.updateOverlay();\n\t\t});\n\t}\n\n\tbindUnits() {\n\t\tthis.dataUnitComponents.map(c => {\n\t\t\tc.units.map(unit => {\n\t\t\t\tunit.addEventListener('click', () => {\n\t\t\t\t\tlet index = unit.getAttribute('data-point-index');\n\t\t\t\t\tthis.setCurrentDataPoint(index);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\t// Note: Doesn't work as tooltip is absolutely positioned\n\t\tthis.tip.container.addEventListener('click', () => {\n\t\t\tlet index = this.tip.container.getAttribute('data-point-index');\n\t\t\tthis.setCurrentDataPoint(index);\n\t\t});\n\t}\n\n\tupdateOverlay() {\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\t\t\tupdateOverlay[d.type](currentUnit, d.overlay);\n\t\t});\n\t}\n\n\tonLeftArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex - 1);\n\t}\n\n\tonRightArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex + 1);\n\t}\n\n\tgetDataPoint(index=this.state.currentIndex) {\n\t\tlet s = this.state;\n\t\tlet data_point = {\n\t\t\tindex: index,\n\t\t\tlabel: s.xAxis.labels[index],\n\t\t\tvalues: s.datasets.map(d => d.values[index])\n\t\t};\n\t\treturn data_point;\n\t}\n\n\tsetCurrentDataPoint(index) {\n\t\tlet s = this.state;\n\t\tindex = parseInt(index);\n\t\tif(index < 0) index = 0;\n\t\tif(index >= s.xAxis.labels.length) index = s.xAxis.labels.length - 1;\n\t\tif(index === s.currentIndex) return;\n\t\ts.currentIndex = index;\n\t\tfire(this.parent, \"data-select\", this.getDataPoint());\n\t}\n\n\n\n\t// API\n\taddDataPoint(label, datasetValues, index=this.state.datasetLength) {\n\t\tsuper.addDataPoint(label, datasetValues, index);\n\t\tthis.data.labels.splice(index, 0, label);\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\td.values.splice(index, 0, datasetValues[i]);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tremoveDataPoint(index = this.state.datasetLength-1) {\n\t\tif (this.data.labels.length <= 1) {\n\t\t\treturn;\n\t\t}\n\t\tsuper.removeDataPoint(index);\n\t\tthis.data.labels.splice(index, 1);\n\t\tthis.data.datasets.map(d => {\n\t\t\td.values.splice(index, 1);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tupdateDataset(datasetValues, index=0) {\n\t\tthis.data.datasets[index].values = datasetValues;\n\t\tthis.update(this.data);\n\t}\n\t// addDataset(dataset, index) {}\n\t// removeDataset(index = 0) {}\n\n\tupdateDatasets(datasets) {\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\tif(datasets[i]) {\n\t\t\t\td.values = datasets[i];\n\t\t\t}\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\t// updateDataPoint(dataPoint, index = 0) {}\n\t// addDataPoint(dataPoint, index = 0) {}\n\t// removeDataPoint(index = 0) {}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcStrokePathStr, makeStrokeCircleStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class DonutChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'donut';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t\tthis.strokeWidth = args.strokeWidth || 30;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius =\n\t\t\tthis.height > this.width\n\t\t\t\t? this.center.x - this.strokeWidth / 2\n\t\t\t\t: this.center.y - this.strokeWidth / 2;\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst largeArc = originDiffAngle > 180 ? 1: 0;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath =\n\t\t\t\toriginDiffAngle === 360\n\t\t\t\t\t? makeStrokeCircleStr(curStart, curEnd, this.center, this.radius, this.clockWise, largeArc)\n\t\t\t\t\t: makeArcStrokePathStr(curStart, curEnd, this.center, this.radius, this.clockWise, largeArc);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'donutSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors,\n\t\t\t\t\t\tstrokeWidth: this.strokeWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{ radius, hoverRadio } = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.stroke = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.stroke = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('donutSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import * as Charts from './chart';\n\nlet frappe = { };\n\nfrappe.NAME = 'Frappe Charts';\nfrappe.VERSION = '1.6.2';\n\nfrappe = Object.assign({ }, frappe, Charts);\n\nexport default frappe;"],"names":["expr","con","document","querySelector","getOffset","element","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isHidden","el","offsetParent","isElementInViewport","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","type","properties","evt","createEvent","initEvent","j","dispatchEvent","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","legendHeight","getExtraWidth","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","Math","abs","fill","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","ANGLE_RATIO","cos","isValidNumber","candidate","nonNegative","Number","isNaN","undefined","isFinite","round","deepClone","cloned","value","key","Date","getTime","isArray","getBarHeightAndYAttr","yTop","zeroLine","height","y","equilizeNoOfElements","array1","array2","extraCount","truncateString","txt","len","slice","shortenLargeNumber","label","number","p","floor","log10","l","shortened","pow","getSplineCurvePointsStr","xList","yList","points","i","push","line","pointA","pointB","lengthX","lengthY","sqrt","atan2","controlPoint","current","previous","next","reverse","o","PI","command","reduce","acc","point","a","cps","cpe","limitColor","r","lightenDarkenColor","color","amt","col","getColor","usePound","num","parseInt","b","g","toString","isValidColor","RGB_RE","test","$","createSVG","tag","createElementNS","val","appendChild","ref","parentNode","insertBefore","keys","map","style","prop","setAttribute","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","opacity","makeSVGContainer","parent","className","width","makeSVGDefs","svgContainer","makeSVGGroup","transform","args","inside","makePath","pathStr","makeArcPathStr","startPosition","endPosition","center","clockWise","largeArc","arcStartX","x","arcStartY","arcEndX","arcEndY","makeCircleStr","midArc","makeArcStrokePathStr","makeStrokeCircleStr","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","PERCENTAGE_BAR_DEFAULT_DEPTH","heatSquare","size","data","legendBar","LABEL_MAX_CHARS","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","stroke","BASE_LINE_COLOR","LABEL_MARGIN","makeHoriLine","x1","x2","lineType","alignment","shortenNumbers","generateAxisLabel","title","position","TOTAL_PADDING","rotation","labelSvg","wrapper","yLine","pos","mode","AXIS_TICK_LENGTH","xLine","yMarker","labelPos","yRegion","region","datasetBar","index","meta","minHeight","datasetDot","dot","getPaths","pointsStr","join","spline","path","heatline","gradient_id","svgDefs","paths","regionFill","gradient_id_region","translate","unit","oldCoord","newCoord","duration","old","STD_EASING","translateVertLine","newX","oldX","MARKER_LINE_ANIM_DUR","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","childNodes","stroke-dasharray","getAttribute","animateBar","bar","nodeName","UNIT_ANIM_DUR","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","PATH_ANIM_DUR","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","animateSVGElement","props","dur","easingType","oldValues","animElement","cloneNode","newElement","attributeName","animateElement","currentValue","animAttr","EASING","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","REPLACE_ALL_NEW_DUR","downloadFile","filename","createElement","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","create","CSSTEXT","firstChild","container","innerHTML","treatAsUtc","date","result","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","getWeeksBetween","startDate","endDate","weekStartDate","setDayToSunday","ceil","getDaysBetween","NO_OF_DAYS_IN_WEEK","millisecondsPerDay","SEC_IN_DAY","NO_OF_MILLIS","areInSameMonth","getMonthName","short","monthName","MONTH_NAMES","getLastDateInMonth","month","year","newDate","day","getDay","addDays","numberOfDays","setDate","getComponent","name","constants","getData","Object","componentConfigs","filter","includes","k","config","assign","ChartComponent","normalize","mantissa","exponent","sig","exp","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","values","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","withMinimum","pseudoMaxValue","pseudoMinValue","getZeroIndex","yPts","interval","getIntervalSize","indexOf","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","prev","curr","calcDistribution","distributionSize","dataMaxValue","distributionStep","distribution","checkpoint","getMaxCheckpoint","dataPrep","labels","datasetLength","datasets","zeroArray","vals","chartType","AXIS_DATASET_CHART_TYPES","yRegions","end","zeroDataPrep","realData","zeroData","axisID","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedSpace","allowedLetters","DEFAULT_CHAR_WIDTH","seriesMultiple","maxLabelLength","getChartByType","AxisChart","chartTypes","error","css","insertAt","head","getElementsByTagName","styleSheet","cssText","createTextNode","BASE_MEASURES","INIT_CHART_UPDATE_TIMEOUT","DEFAULT_CHART_COLORS","DEFAULT_COLORS","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","dataPointList","addEventListener","set","_this2","formatted","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","exec","c","ch","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BaseChart","HTMLElement","Error","rawChartArgs","prepareData","prepareFirstData","validateColors","isNavigable","animate","truncateLegends","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","_this","draw","ResizeObserver","resizeObserver","observe","disconnect","removeEventListener","makeContainer","updateWidth","independentWidth","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","bind","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","e","_this4","event","keyCode","chartSvg","AggregationChart","formatTooltipY","tooltipOptions","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","barWidth","divisor","_this3","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","strokeWidth","transition","newData","xPositions","widths","barHeight","barDepth","item","positions","animateMultipleElements","newPos","newLabels","oldPos","oldLabels","calcLabels","_this5","_this6","newOptions","startPos","endPos","_this7","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","offsets","barsWidth","newXPos","newYPos","newOffsets","oldXPos","oldYPos","oldOffsets","hideLine","hideDots","valuesOverPoints","newValues","PercentageChart","barOptions","component","xPos","bars","get","gOff","pOff","formattedLabels","fraction","setValues","showTip","PieChart","mouseMove","mouseLeave","hoverRadio","startAngle","prevSlicesProperties","slicesProperties","curAngle","originDiffAngle","diffAngle","endAngle","prevProperty","curStart","curEnd","curPath","property","flag","calTranslateByAngle","g_off","pageX","pageY","formatted_labels","percent","slices","prevIndex","curActiveSliceIndex","prevAcitve","curActiveSlice","hoverSlice","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","ROW_HEIGHT","HEATMAP_SQUARE_SIZE","spacing","noOfWeeks","setFullYear","dataPoints","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","COL_WIDTH","moreText","HEATMAP_DISTRIBUTION_SIZE","startMonth","startYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","lineOptions","axisOptions","xAxis","xAxisMode","yAxisConfig","yAxisMode","id","xIsSeries","shortenYAxisNumbers","formatTooltipX","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","dataValues","intervalHeight","yAxisConfigObject","yAxisAlignment","yKeys","find","yPtsArray","firstArr","newYptsArr","shortest","Infinity","longest","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","axis","barChartIndex","cumulativeYs","replace","char","stacked","yExtremes","cumulativeYPos","multiAxis","allValueLists","generateCumulative","cumulative","groupedDataSets","cur","barDatasets","lineDatasets","barsConfigs","barIndex","spaceRatio","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","_this8","setCurrentDataPoint","_this10","_this11","getDataPoint","datasetValues","splice","DonutChart","Chart","frappe","NAME","VERSION","Charts"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"frappe-charts.min.js","sources":["../../../src/js/utils/dom.js","../../../src/js/utils/constants.js","../../../src/js/utils/helpers.js","../../../src/js/utils/draw-utils.js","../../../src/js/utils/colors.js","../../../src/js/utils/draw.js","../../../src/js/utils/animate.js","../../../src/js/utils/animation.js","../../../src/js/utils/export.js","../../../src/js/utils/date-utils.js","../../../src/js/objects/ChartComponents.js","../../../src/js/utils/intervals.js","../../../src/js/utils/axis-chart-utils.js","../../../src/js/chart.js","../../../node_modules/style-inject/dist/style-inject.es.js","../../../src/js/objects/SvgTip.js","../../../src/css/chartsCss.js","../../../src/js/charts/BaseChart.js","../../../src/js/charts/AggregationChart.js","../../../src/js/charts/PercentageChart.js","../../../src/js/charts/PieChart.js","../../../src/js/charts/Heatmap.js","../../../src/js/charts/AxisChart.js","../../../src/js/charts/DonutChart.js","../../../src/js/index.js"],"sourcesContent":["export function $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function findNodeIndex(node)\n{\n\tvar i = 0;\n\twhile (node.previousSibling) {\n\t\tnode = node.previousSibling;\n\t\ti++;\n\t}\n\treturn i;\n}\n\n$.create = (tag, o) => {\n\tvar element = document.createElement(tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (i in element ) {\n\t\t\telement[i] = val;\n\t\t}\n\t\telse {\n\t\t\telement.setAttribute(i, val);\n\t\t}\n\t}\n\n\treturn element;\n};\n\nexport function getOffset(element) {\n\tlet rect = element.getBoundingClientRect();\n\treturn {\n\t\t// https://stackoverflow.com/a/7436602/6495043\n\t\t// rect.top varies with scroll, so we add whatever has been\n\t\t// scrolled to it to get absolute distance from actual page top\n\t\ttop: rect.top + (document.documentElement.scrollTop || document.body.scrollTop),\n\t\tleft: rect.left + (document.documentElement.scrollLeft || document.body.scrollLeft)\n\t};\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/offsetParent\n// an element's offsetParent property will return null whenever it, or any of its parents,\n// is hidden via the display style property.\nexport function isHidden(el) {\n\treturn (el.offsetParent === null);\n}\n\nexport function isElementInViewport(el) {\n\t// Although straightforward: https://stackoverflow.com/a/7557433/6495043\n\tvar rect = el.getBoundingClientRect();\n\n\treturn (\n\t\trect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */\n rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */\n\t);\n}\n\nexport function getElementContentWidth(element) {\n\tvar styles = window.getComputedStyle(element);\n\tvar padding = parseFloat(styles.paddingLeft) +\n\t\tparseFloat(styles.paddingRight);\n\n\treturn element.clientWidth - padding;\n}\n\nexport function bind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function (event) {\n\t\t\t\telement.addEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function unbind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function(event) {\n\t\t\t\telement.removeEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function fire(target, type, properties) {\n\tvar evt = document.createEvent(\"HTMLEvents\");\n\n\tevt.initEvent(type, true, true );\n\n\tfor (var j in properties) {\n\t\tevt[j] = properties[j];\n\t}\n\n\treturn target.dispatchEvent(evt);\n}\n\n// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/\nexport function forEachNode(nodeList, callback, scope) {\n\tif(!nodeList) return;\n\tfor (var i = 0; i < nodeList.length; i++) {\n\t\tcallback.call(scope, nodeList[i], i);\n\t}\n}\n\nexport function activate($parent, $child, commonClass, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`.${commonClass}.${activeClass}`);\n\n\tforEachNode($children, (node, i) => {\n\t\tif(index >= 0 && i <= index) return;\n\t\tnode.classList.remove(activeClass);\n\t});\n\n\t$child.classList.add(activeClass);\n}\n","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const DEFAULT_AXIS_CHART_TYPE = 'line';\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 0.5;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.00;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN,\n\tdonut: DEFAULT_CHART_COLORS\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\n/**\n * Check if a number is valid for svg attributes\n * @param {object} candidate Candidate to test\n * @param {Boolean} nonNegative flag to treat negative number as invalid\n */\nexport function isValidNumber(candidate, nonNegative=false) {\n\tif (Number.isNaN(candidate)) return false;\n\telse if (candidate === undefined) return false;\n\telse if (!Number.isFinite(candidate)) return false;\n\telse if (nonNegative && candidate < 0) return false;\n\telse return true;\n}\n\n/**\n * Round a number to the closes precision, max max precision 4\n * @param {Number} d Any Number\n */\nexport function round(d) {\n\t// https://floating-point-gui.de/\n\t// https://www.jacklmoore.com/notes/rounding-in-javascript/\n\treturn Number(Math.round(d + 'e4') + 'e-4');\n}\n\n/**\n * Creates a deep clone of an object\n * @param {Object} candidate Any Object\n */\n export function deepClone(candidate) {\n\tlet cloned, value, key;\n \n\tif (candidate instanceof Date) {\n\t return new Date(candidate.getTime());\n\t}\n \n\tif (typeof candidate !== \"object\" || candidate === null) {\n\t return candidate;\n\t}\n \n\tcloned = Array.isArray(candidate) ? [] : {};\n \n\tfor (key in candidate) {\n\t value = candidate[key];\n \n\t cloned[key] = deepClone(value);\n\t}\n \n\treturn cloned;\n }","import { fillArray } from './helpers';\n\nexport function getBarHeightAndYAttr(yTop, zeroLine) {\n\tlet height, y;\n\tif (yTop <= zeroLine) {\n\t\theight = zeroLine - yTop;\n\t\ty = yTop;\n\t} else {\n\t\theight = yTop - zeroLine;\n\t\ty = zeroLine;\n\t}\n\n\treturn [height, y];\n}\n\nexport function equilizeNoOfElements(array1, array2,\n\textraCount = array2.length - array1.length) {\n\n\t// Doesn't work if either has zero elements.\n\tif(extraCount > 0) {\n\t\tarray1 = fillArray(array1, extraCount);\n\t} else {\n\t\tarray2 = fillArray(array2, extraCount);\n\t}\n\treturn [array1, array2];\n}\n\nexport function truncateString(txt, len) {\n\tif (!txt) {\n\t\treturn;\n\t}\n\tif (txt.length > len) {\n\t\treturn txt.slice(0, len-3) + '...';\n\t} else {\n\t\treturn txt;\n\t}\n}\n\nexport function shortenLargeNumber(label) {\n\tlet number;\n\tif (typeof label === 'number') number = label;\n\telse if (typeof label === 'string') {\n\t\tnumber = Number(label);\n\t\tif (Number.isNaN(number)) return label;\n\t}\n\n\t// Using absolute since log wont work for negative numbers\n\tlet p = Math.floor(Math.log10(Math.abs(number)));\n\tif (p <= 2) return number; // Return as is for a 3 digit number of less\n\tlet\tl = Math.floor(p / 3);\n\tlet shortened = (Math.pow(10, p - l * 3) * +(number / Math.pow(10, p)).toFixed(1));\n\n\t// Correct for floating point error upto 2 decimal places\n\treturn Math.round(shortened*100)/100 + ' ' + ['', 'K', 'M', 'B', 'T'][l];\n}\n\n// cubic bezier curve calculation (from example by François Romain)\nexport function getSplineCurvePointsStr(xList, yList) {\n\n\tlet points=[];\n\tfor(let i=0;i {\n\t\tlet lengthX = pointB[0] - pointA[0];\n\t\tlet lengthY = pointB[1] - pointA[1];\n\t\treturn {\n\t\t\tlength: Math.sqrt(Math.pow(lengthX, 2) + Math.pow(lengthY, 2)),\n\t\t\tangle: Math.atan2(lengthY, lengthX)\n\t\t};\n\t};\n \n\tlet controlPoint = (current, previous, next, reverse) => {\n\t\tlet p = previous || current;\n\t\tlet n = next || current;\n\t\tlet o = line(p, n);\n\t\tlet angle = o.angle + (reverse ? Math.PI : 0);\n\t\tlet length = o.length * smoothing;\n\t\tlet x = current[0] + Math.cos(angle) * length;\n\t\tlet y = current[1] + Math.sin(angle) * length;\n\t\treturn [x, y];\n\t};\n \n\tlet bezierCommand = (point, i, a) => {\n\t\tlet cps = controlPoint(a[i - 1], a[i - 2], point);\n\t\tlet cpe = controlPoint(point, a[i - 1], a[i + 1], true);\n\t\treturn `C ${cps[0]},${cps[1]} ${cpe[0]},${cpe[1]} ${point[0]},${point[1]}`;\n\t};\n \n\tlet pointStr = (points, command) => {\n\t\treturn points.reduce((acc, point, i, a) => i === 0\n\t\t\t? `${point[0]},${point[1]}`\n\t\t\t: `${acc} ${command(point, i, a)}`, '');\n\t};\n \n\treturn pointStr(points, bezierCommand);\n}\n","const PRESET_COLOR_MAP = {\n\t'light-blue': '#7cd6fd',\n\t'blue': '#5e64ff',\n\t'violet': '#743ee2',\n\t'red': '#ff5858',\n\t'orange': '#ffa00a',\n\t'yellow': '#feef72',\n\t'green': '#28a745',\n\t'light-green': '#98d85b',\n\t'purple': '#b554ff',\n\t'magenta': '#ffa3ef',\n\t'black': '#36114C',\n\t'grey': '#bdd3e6',\n\t'light-grey': '#f0f4f7',\n\t'dark-grey': '#b8c2cc'\n};\n\nfunction limitColor(r){\n\tif (r > 255) return 255;\n\telse if (r < 0) return 0;\n\treturn r;\n}\n\nexport function lightenDarkenColor(color, amt) {\n\tlet col = getColor(color);\n\tlet usePound = false;\n\tif (col[0] == \"#\") {\n\t\tcol = col.slice(1);\n\t\tusePound = true;\n\t}\n\tlet num = parseInt(col,16);\n\tlet r = limitColor((num >> 16) + amt);\n\tlet b = limitColor(((num >> 8) & 0x00FF) + amt);\n\tlet g = limitColor((num & 0x0000FF) + amt);\n\treturn (usePound?\"#\":\"\") + (g | (b << 8) | (r << 16)).toString(16);\n}\n\nexport function isValidColor(string) {\n\t// https://stackoverflow.com/a/32685393\n\tlet HEX_RE = /(^\\s*)(#)((?:[A-Fa-f0-9]{3}){1,2})$/i;\n\tlet RGB_RE = /(^\\s*)(rgb|hsl)(a?)[(]\\s*([\\d.]+\\s*%?)\\s*,\\s*([\\d.]+\\s*%?)\\s*,\\s*([\\d.]+\\s*%?)\\s*(?:,\\s*([\\d.]+)\\s*)?[)]$/i;\n\treturn HEX_RE.test(string) || RGB_RE.test(string);\n}\n\nexport const getColor = (color) => {\n\t// When RGB color, convert to hexadecimal (alpha value is omitted)\n\tif((/rgb[a]{0,1}\\([\\d, ]+\\)/gim).test(color)) {\n\t\treturn (/\\D+(\\d*)\\D+(\\d*)\\D+(\\d*)/gim).exec(color)\n\t\t\t.map((x, i) => (i !== 0 ? Number(x).toString(16) : '#'))\n\t\t\t.reduce((c, ch) => `${c}${ch}`);\n\t}\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr, truncateString, shortenLargeNumber, getSplineCurvePointsStr } from './draw-utils';\nimport { getStringWidth, isValidNumber } from './helpers';\nimport { DOT_OVERLAY_SIZE_INCR, PERCENTAGE_BAR_DEFAULT_DEPTH } from './constants';\nimport { lightenDarkenColor } from './colors';\n\nexport const AXIS_TICK_LENGTH = 6;\nconst LABEL_MARGIN = 4;\nconst LABEL_MAX_CHARS = 15;\nconst TOTAL_PADDING = 120;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none', strokeWidth=2) {\n\treturn createSVG('path', {\n\t\tclassName: className,\n\t\td: pathStr,\n\t\tstyles: {\n\t\t\tstroke: stroke,\n\t\t\tfill: fill,\n\t\t\t'stroke-width': strokeWidth\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeCircleStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, midArc, arcEndY] = [center.x + endPosition.x, center.y * 2, center.y + endPosition.y];\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${midArc} z\n\t\tL${arcStartX} ${midArc}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeArcStrokePathStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\n\treturn `M${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY}`;\n}\n\nexport function makeStrokeCircleStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, midArc, arcEndY] = [center.x + endPosition.x, radius * 2 + arcStartY, center.y + startPosition.y];\n\n\treturn `M${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${midArc}\n\t\tM${arcStartX} ${midArc}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY}`;\n}\n\nexport function makeGradient(svgDefElem, color, lighter = false) {\n\tlet gradientId ='path-fill-gradient' + '-' + color + '-' +(lighter ? 'lighter' : 'default');\n\tlet gradientDef = renderVerticalGradient(svgDefElem, gradientId);\n\tlet opacities = [1, 0.6, 0.2];\n\tif(lighter) {\n\t\topacities = [0.4, 0.2, 0];\n\t}\n\n\tsetGradientStop(gradientDef, \"0%\", color, opacities[0]);\n\tsetGradientStop(gradientDef, \"50%\", color, opacities[1]);\n\tsetGradientStop(gradientDef, \"100%\", color, opacities[2]);\n\n\treturn gradientId;\n}\n\nexport function percentageBar(x, y, width, height,\n\tdepth=PERCENTAGE_BAR_DEFAULT_DEPTH, fill='none') {\n\n\tlet args = {\n\t\tclassName: 'percentage-bar',\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height,\n\t\tfill: fill,\n\t\tstyles: {\n\t\t\t'stroke': lightenDarkenColor(fill, -25),\n\t\t\t// Diabolically good: https://stackoverflow.com/a/9000859\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/stroke-dasharray\n\t\t\t'stroke-dasharray': `0, ${height + width}, ${width}, ${height}`,\n\t\t\t'stroke-width': depth\n\t\t},\n\t};\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function heatSquare(className, x, y, size, radius, fill='none', data={}) {\n\tlet args = {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: size,\n\t\theight: size,\n\t\trx: radius,\n\t\tfill: fill\n\t};\n\n\tObject.keys(data).map(key => {\n\t\targs[key] = data[key];\n\t});\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function legendBar(x, y, size, fill='none', label, truncate=false) {\n\tlabel = truncate ? truncateString(label, LABEL_MAX_CHARS) : label;\n\n\tlet args = {\n\t\tclassName: 'legend-bar',\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: size,\n\t\theight: '2px',\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE * 2) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"rect\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function legendDot(x, y, size, fill='none', label, truncate=false) {\n\tlabel = truncate ? truncateString(label, LABEL_MAX_CHARS) : label;\n\n\tlet args = {\n\t\tclassName: 'legend-dot',\n\t\tcx: 0,\n\t\tcy: 0,\n\t\tr: size,\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdx: (FONT_SIZE) + 'px',\n\t\tdy: (FONT_SIZE/3) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"circle\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function makeText(className, x, y, content, options = {}) {\n\tlet fontSize = options.fontSize || FONT_SIZE;\n\tlet dy = options.dy !== undefined ? options.dy : (fontSize / 2);\n\tlet fill = options.fill || FONT_FILL;\n\tlet textAnchor = options.textAnchor || 'start';\n\treturn createSVG('text', {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\tdy: dy + 'px',\n\t\t'font-size': fontSize + 'px',\n\t\tfill: fill,\n\t\t'text-anchor': textAnchor,\n\t\tinnerHTML: content\n\t});\n}\n\nfunction makeVertLine(x, label, y1, y2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tlet l = createSVG('line', {\n\t\tclassName: 'line-vertical ' + options.className,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: y1,\n\t\ty2: y2,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: 0,\n\t\ty: y1 > y2 ? y1 + LABEL_MARGIN : y1 - LABEL_MARGIN - FONT_SIZE,\n\t\tdy: FONT_SIZE + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'middle',\n\t\tinnerHTML: label + \"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(${ x }, 0)`\n\t});\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nfunction makeHoriLine(y, label, x1, x2, options = {}) {\n if (!options.stroke) options.stroke = BASE_LINE_COLOR;\n if (!options.lineType) options.lineType = '';\n if (!options.alignment) options.alignment = 'left';\n if (options.shortenNumbers) label = shortenLargeNumber(label);\n\n let className =\n 'line-horizontal ' +\n options.className +\n (options.lineType === 'dashed' ? 'dashed' : '');\n\n let l = createSVG('line', {\n className: className,\n x1: x1,\n x2: x2,\n y1: 0,\n y2: 0,\n styles: {\n stroke: options.stroke\n }\n });\n\n let text = createSVG('text', {\n x: options.alignment === 'left' ? x1 - LABEL_MARGIN : x2 + LABEL_MARGIN * 4,\n y: 0,\n dy: FONT_SIZE / 2 - 2 + 'px',\n 'font-size': FONT_SIZE + 'px',\n 'text-anchor': x1 < x2 ? 'end' : 'start',\n innerHTML: label + ''\n });\n\n let line = createSVG('g', {\n transform: `translate(0, ${y})`,\n 'stroke-opacity': 1\n });\n\n if (text === 0 || text === '0') {\n line.style.stroke = 'rgba(27, 31, 35, 0.6)';\n }\n\n line.appendChild(l);\n line.appendChild(text);\n\n return line;\n}\n\nexport function generateAxisLabel(options) {\n if (!options.title) return;\n\n const y = options.position === 'left' ? \n\t\t(options.height - TOTAL_PADDING) / 2 + (getStringWidth(options.title, 5) / 2) : \n\t\t(options.height - TOTAL_PADDING) / 2 - (getStringWidth(options.title, 5) / 2) ;\n\tconst x = options.position === 'left' ? 0 : options.width;\n\tconst y2 = options.position === 'left' ? FONT_SIZE / 3 : FONT_SIZE / 3 * -1;\n\n const rotation =\n options.position === 'right'\n ? `rotate(90)`\n : `rotate(270)`;\n\n const labelSvg = createSVG('text', {\n className: 'chart-label',\n x: 0, // getStringWidth(options.title, 5) / 2,\n y: 0, // y,\n dy: `${y2}px`,\n 'font-size': `${FONT_SIZE}px`,\n 'text-anchor': 'start',\n innerHTML: `${options.title} `\n });\n\n\tlet wrapper = createSVG('g', {\n\t\tx: 0,\n\t\ty: 0,\n\t\ttransformBox: 'fill-box',\n\t\ttransform: `translate(${x}, ${y}) ${rotation}`,\n\t\tclassName: `test-${options.position}`\n\t});\n\n\twrapper.appendChild(labelSvg);\n\n return wrapper;\n}\n\nexport function yLine(y, label, width, options = {}) {\n if (!isValidNumber(y)) y = 0;\n\n if (!options.pos) options.pos = 'left';\n if (!options.offset) options.offset = 0;\n if (!options.mode) options.mode = 'span';\n if (!options.stroke) options.stroke = BASE_LINE_COLOR;\n if (!options.className) options.className = '';\n\n let x1 = -1 * AXIS_TICK_LENGTH;\n let x2 = options.mode === 'span' ? width + AXIS_TICK_LENGTH : 0;\n\n if (options.mode === 'tick' && options.pos === 'right') {\n x1 = width + AXIS_TICK_LENGTH;\n x2 = width;\n }\n\n let offset = options.pos === 'left' ? -1 * options.offset : options.offset;\n\n x1 += offset;\n x2 += offset;\n\n return makeHoriLine(y, label, x1, x2, {\n stroke: options.stroke,\n className: options.className,\n lineType: options.lineType,\n alignment: options.pos,\n shortenNumbers: options.shortenNumbers\n });\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif (!isValidNumber(x)) x = 0;\n\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\t// Preprocess numbers to avoid svg building errors\n\tif (!isValidNumber(x)) x = 0;\n\tif (!isValidNumber(y)) y = 0;\n\tif (!isValidNumber(height, true)) height = 0;\n\tif (!isValidNumber(width, true)) width = 0;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\n\t// Spline\n\tif (options.spline)\n\t\tpointsStr = getSplineCurvePointsStr(xList, yList);\n\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.regionFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr, getSplineCurvePointsStr } from './draw-utils';\n\nexport const UNIT_ANIM_DUR = 350;\nexport const PATH_ANIM_DUR = 350;\nexport const MARKER_LINE_ANIM_DUR = UNIT_ANIM_DUR;\nexport const REPLACE_ALL_NEW_DUR = 250;\n\nexport const STD_EASING = 'easein';\n\nexport function translate(unit, oldCoord, newCoord, duration) {\n\tlet old = typeof oldCoord === 'string' ? oldCoord : oldCoord.join(', ');\n\treturn [\n\t\tunit,\n\t\t{transform: newCoord.join(', ')},\n\t\tduration,\n\t\tSTD_EASING,\n\t\t\"translate\",\n\t\t{transform: old}\n\t];\n}\n\nexport function translateVertLine(xLine, newX, oldX) {\n\treturn translate(xLine, [oldX, 0], [newX, 0], MARKER_LINE_ANIM_DUR);\n}\n\nexport function translateHoriLine(yLine, newY, oldY) {\n\treturn translate(yLine, [0, oldY], [0, newY], MARKER_LINE_ANIM_DUR);\n}\n\nexport function animateRegion(rectGroup, newY1, newY2, oldY2) {\n\tlet newHeight = newY1 - newY2;\n\tlet rect = rectGroup.childNodes[0];\n\tlet width = rect.getAttribute(\"width\");\n\tlet rectAnim = [\n\t\trect,\n\t\t{ height: newHeight, 'stroke-dasharray': `${width}, ${newHeight}` },\n\t\tMARKER_LINE_ANIM_DUR,\n\t\tSTD_EASING\n\t];\n\n\tlet groupAnim = translate(rectGroup, [0, oldY2], [0, newY2], MARKER_LINE_ANIM_DUR);\n\treturn [rectAnim, groupAnim];\n}\n\nexport function animateBar(bar, x, yTop, width, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\tif(bar.nodeName !== 'rect') {\n\t\tlet rect = bar.childNodes[0];\n\t\tlet rectAnim = [\n\t\t\trect,\n\t\t\t{width: width, height: height},\n\t\t\tUNIT_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\n\t\tlet oldCoordStr = bar.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(bar, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [rectAnim, groupAnim];\n\t} else {\n\t\treturn [[bar, {width: width, height: height, x: x, y: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// bar.animate({height: args.newHeight, y: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animateDot(dot, x, y) {\n\tif(dot.nodeName !== 'circle') {\n\t\tlet oldCoordStr = dot.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(dot, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [groupAnim];\n\t} else {\n\t\treturn [[dot, {cx: x, cy: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// dot.animate({cy: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animatePath(paths, newXList, newYList, zeroLine, spline) {\n\tlet pathComponents = [];\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y)).join(\"L\");\n\n\tif (spline)\n\t\tpointsStr = getSplineCurvePointsStr(newXList, newYList);\n\n\tconst animPath = [paths.path, {d:\"M\" + pointsStr}, PATH_ANIM_DUR, STD_EASING];\n\tpathComponents.push(animPath);\n\n\tif(paths.region) {\n\t\tlet regStartPt = `${newXList[0]},${zeroLine}L`;\n\t\tlet regEndPt = `L${newXList.slice(-1)[0]}, ${zeroLine}`;\n\n\t\tconst animRegion = [\n\t\t\tpaths.region,\n\t\t\t{d:\"M\" + regStartPt + pointsStr + regEndPt},\n\t\t\tPATH_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\t\tpathComponents.push(animRegion);\n\t}\n\n\treturn pathComponents;\n}\n\nexport function animatePathStr(oldPath, pathStr) {\n\treturn [oldPath, {d: pathStr}, UNIT_ANIM_DUR, STD_EASING];\n}\n","// Leveraging SMIL Animations\n\nimport { REPLACE_ALL_NEW_DUR } from './animate';\n\nconst EASING = {\n\tease: \"0.25 0.1 0.25 1\",\n\tlinear: \"0 0 1 1\",\n\t// easein: \"0.42 0 1 1\",\n\teasein: \"0.1 0.8 0.2 1\",\n\teaseout: \"0 0 0.58 1\",\n\teaseinout: \"0.42 0 0.58 1\"\n};\n\nfunction animateSVGElement(element, props, dur, easingType=\"linear\", type=undefined, oldValues={}) {\n\n\tlet animElement = element.cloneNode(true);\n\tlet newElement = element.cloneNode(true);\n\n\tfor(var attributeName in props) {\n\t\tlet animateElement;\n\t\tif(attributeName === 'transform') {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animateTransform\");\n\t\t} else {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animate\");\n\t\t}\n\t\tlet currentValue = oldValues[attributeName] || element.getAttribute(attributeName);\n\t\tlet value = props[attributeName];\n\n\t\tlet animAttr = {\n\t\t\tattributeName: attributeName,\n\t\t\tfrom: currentValue,\n\t\t\tto: value,\n\t\t\tbegin: \"0s\",\n\t\t\tdur: dur/1000 + \"s\",\n\t\t\tvalues: currentValue + \";\" + value,\n\t\t\tkeySplines: EASING[easingType],\n\t\t\tkeyTimes: \"0;1\",\n\t\t\tcalcMode: \"spline\",\n\t\t\tfill: 'freeze'\n\t\t};\n\n\t\tif(type) {\n\t\t\tanimAttr[\"type\"] = type;\n\t\t}\n\n\t\tfor (var i in animAttr) {\n\t\t\tanimateElement.setAttribute(i, animAttr[i]);\n\t\t}\n\n\t\tanimElement.appendChild(animateElement);\n\n\t\tif(type) {\n\t\t\tnewElement.setAttribute(attributeName, `translate(${value})`);\n\t\t} else {\n\t\t\tnewElement.setAttribute(attributeName, value);\n\t\t}\n\t}\n\n\treturn [animElement, newElement];\n}\n\nexport function transform(element, style) { // eslint-disable-line no-unused-vars\n\telement.style.transform = style;\n\telement.style.webkitTransform = style;\n\telement.style.msTransform = style;\n\telement.style.mozTransform = style;\n\telement.style.oTransform = style;\n}\n\nfunction animateSVG(svgContainer, elements) {\n\tlet newElements = [];\n\tlet animElements = [];\n\n\telements.map(element => {\n\t\tlet unit = element[0];\n\t\tlet parent = unit.parentNode;\n\n\t\tlet animElement, newElement;\n\n\t\telement[0] = unit;\n\t\t[animElement, newElement] = animateSVGElement(...element);\n\n\t\tnewElements.push(newElement);\n\t\tanimElements.push([animElement, parent]);\n\t\t\n\t\tif (parent) {\n\t\t\tparent.replaceChild(animElement, unit);\n\t\t}\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tif (animElement[1]) {\n\t\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\t\telements[i][0] = newElements[i];\n\t\t}\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport {\n makeText,\n makePath,\n xLine,\n yLine,\n generateAxisLabel,\n yMarker,\n yRegion,\n datasetBar,\n datasetDot,\n percentageBar,\n getPaths,\n heatSquare\n} from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport {\n translateHoriLine,\n translateVertLine,\n animateRegion,\n animateBar,\n animateDot,\n animatePath,\n animatePathStr\n} from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n constructor({\n layerClass = '',\n layerTransform = '',\n constants,\n\n getData,\n makeElements,\n animateElements\n }) {\n this.layerTransform = layerTransform;\n this.constants = constants;\n\n this.makeElements = makeElements;\n this.getData = getData;\n\n this.animateElements = animateElements;\n\n this.store = [];\n this.labels = [];\n\n this.layerClass = layerClass;\n this.layerClass =\n typeof this.layerClass === 'function' ? this.layerClass() : this.layerClass;\n\n this.refresh();\n }\n\n refresh(data) {\n this.data = data || this.getData();\n }\n\n setup(parent) {\n this.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n }\n\n make() {\n this.render(this.data);\n this.oldData = this.data;\n }\n\n render(data) {\n this.store = this.makeElements(data);\n\n this.layer.textContent = '';\n this.store.forEach((element) => {\n element.length\n ? element.forEach((el) => {\n this.layer.appendChild(el);\n })\n : this.layer.appendChild(element);\n });\n this.labels.forEach((element) => {\n this.layer.appendChild(element);\n });\n }\n\n update(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tdonutSlices: {\n\t\tlayerClass: 'donut-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) => {\n\t\t\t\tlet slice = makePath(s, 'donut-path', data.colors[i], 'none', data.strokeWidth);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) => animatePathStr(slice, newData.sliceStrings[i]));\n\t\t},\n\t},\n\tpieSlices: {\n\t\tlayerClass: 'pie-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) =>{\n\t\t\t\tlet slice = makePath(s, 'pie-path', 'none', data.colors[i]);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) =>\n\t\t\t\tanimatePathStr(slice, newData.sliceStrings[i])\n\t\t\t);\n\t\t}\n\t},\n\tpercentageBars: {\n\t\tlayerClass: 'percentage-bars',\n\t\tmakeElements(data) {\n\t\t\treturn data.xPositions.map((x, i) =>{\n\t\t\t\tlet y = 0;\n\t\t\t\tlet bar = percentageBar(x, y, data.widths[i],\n\t\t\t\t\tthis.constants.barHeight, this.constants.barDepth, data.colors[i]);\n\t\t\t\treturn bar;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n yAxis: {\n layerClass: 'y axis',\n makeElements(data) {\n let elements = [];\n\t\t\t// will loop through each yaxis dataset if it exists \n if (data.length) {\n data.forEach((item, i) => {\n item.positions.map((position, i) => {\n elements.push(\n yLine(position, item.labels[i], this.constants.width, {\n mode: this.constants.mode,\n pos: item.pos || this.constants.pos,\n shortenNumbers: this.constants.shortenNumbers\n })\n );\n });\n // we need to make yAxis titles if they are defined\n if (item.title) {\n elements.push(\n generateAxisLabel({\n title: item.title,\n position: item.pos,\n\t\t\t\t\t\t\t\theight: this.constants.height || data.zeroLine,\n width: this.constants.width\n })\n );\n }\n });\n\n return elements;\n }\n\n data.positions.forEach((position, i) => {\n elements.push(yLine(position, data.labels[i], this.constants.width, {\n mode: this.constants.mode,\n pos: data.pos || this.constants.pos,\n shortenNumbers: this.constants.shortenNumbers\n }));\n });\n\n\t\t\tif (data.title) {\n\t\t\t\telements.push(\n\t\t\t\t\tgenerateAxisLabel({\n\t\t\t\t\t\ttitle: data.title,\n\t\t\t\t\t\tposition: data.pos,\n\t\t\t\t\t\theight: this.constants.height || data.zeroLine,\n\t\t\t\t\t\twidth: this.constants.width\n\t\t\t\t\t})\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn elements;\n },\n\n animateElements(newData) {\n const animateMultipleElements = (oldData, newData) => {\n let newPos = newData.positions;\n let newLabels = newData.labels;\n let oldPos = oldData.positions;\n let oldLabels = oldData.labels;\n\n [oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n [oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n this.render({\n positions: oldPos,\n labels: newLabels\n });\n\n return this.store.map((line, i) => {\n return translateHoriLine(line, newPos[i], oldPos[i]);\n });\n };\n\n // we will need to animate both axis if we have more than one.\n // so check if the oldData is an array of values.\n if (this.oldData instanceof Array) {\n return this.oldData.forEach((old, i) => {\n animateMultipleElements(old, newData[i]);\n });\n }\n\n let newPos = newData.positions;\n let newLabels = newData.labels;\n let oldPos = this.oldData.positions;\n let oldLabels = this.oldData.labels;\n\n [oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n [oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n this.render({\n positions: oldPos,\n labels: newLabels\n });\n\n return this.store.map((line, i) => {\n return translateHoriLine(line, newPos[i], oldPos[i]);\n });\n }\n },\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map((m) => \n\t\t\t\tyMarker(m.position, m.label, this.constants.width, {\n\t\t\t\t\tlabelPos: m.options.labelPos,\n\t\t\t\t\tmode: 'span',\n\t\t\t\t\tlineType: 'dashed'\n\t\t\t\t})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, radius, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, radius, day.fill, data);\n\t\t\t\t\t\tthis.serializedSubDomains.push(square);\n\t\t\t\t\t}\n\t\t\t\t\ty += rowHeight;\n\t\t\t\t});\n\t\t\t\ty = 0;\n\t\t\t\tx += colWidth;\n\t\t\t});\n\n\t\t\treturn this.serializedSubDomains;\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\n\tbarGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-bars dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'bar';\n\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\treturn datasetBar(\n\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\ty,\n\t\t\t\t\tdata.barWidth,\n\t\t\t\t\tc.color,\n\t\t\t\t\tdata.labels[j],\n\t\t\t\t\tj,\n\t\t\t\t\tdata.offsets[j],\n\t\t\t\t\t{\n\t\t\t\t\t\tzeroLine: data.zeroLine,\n\t\t\t\t\t\tbarsWidth: data.barsWidth,\n\t\t\t\t\t\tminHeight: c.minHeight\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t});\n\t\t\treturn this.units;\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newOffsets = newData.offsets;\n\t\t\tlet newLabels = newData.labels;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldOffsets = this.oldData.offsets;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldOffsets, newOffsets] = equilizeNoOfElements(oldOffsets, newOffsets);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\toffsets: oldOffsets,\n\t\t\t\tlabels: newLabels,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tbarsWidth: this.oldData.barsWidth,\n\t\t\t\tbarWidth: this.oldData.barWidth,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((bar, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateBar(\n\t\t\t\t\tbar, newXPos[i], newYPos[i], newData.barWidth, newOffsets[i],\n\t\t\t\t\t{zeroLine: newData.zeroLine}\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n lineGraph: {\n layerClass: function () {\n return 'dataset-units dataset-line dataset-' + this.constants.index;\n },\n makeElements(data) {\n let c = this.constants;\n this.unitType = 'dot';\n this.paths = {};\n if (!c.hideLine) {\n this.paths = getPaths(\n data.xPositions,\n data.yPositions,\n c.color,\n {\n heatline: c.heatline,\n regionFill: c.regionFill,\n spline: c.spline\n },\n {\n svgDefs: c.svgDefs,\n zeroLine: data.zeroLine\n }\n );\n }\n\n this.units = [];\n\n if (!c.hideDots) {\n this.units = data.yPositions.map((y, j) => {\n return datasetDot(\n data.xPositions[j],\n y,\n data.radius,\n c.color,\n c.valuesOverPoints ? data.values[j] : '',\n j\n );\n });\n }\n\n return Object.values(this.paths).concat(this.units);\n },\n animateElements(newData) {\n let newXPos = newData.xPositions;\n let newYPos = newData.yPositions;\n let newValues = newData.values;\n\n let oldXPos = this.oldData.xPositions;\n let oldYPos = this.oldData.yPositions;\n let oldValues = this.oldData.values;\n\n [oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n [oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n [oldValues, newValues] = equilizeNoOfElements(oldValues, newValues);\n\n this.render({\n xPositions: oldXPos,\n yPositions: oldYPos,\n values: newValues,\n\n zeroLine: this.oldData.zeroLine,\n radius: this.oldData.radius\n });\n\n let animateElements = [];\n\n if (Object.keys(this.paths).length) {\n animateElements = animateElements.concat(\n animatePath(\n this.paths,\n newXPos,\n newYPos,\n newData.zeroLine,\n this.constants.spline\n )\n );\n }\n\n if (this.units.length) {\n this.units.map((dot, i) => {\n animateElements = animateElements.concat(\n animateDot(dot, newXPos[i], newYPos[i])\n );\n });\n }\n\n return animateElements;\n }\n }\n};\n\nexport function getComponent(name, constants, getData) {\n\tlet keys = Object.keys(componentConfigs).filter(k => name.includes(k));\n\tlet config = componentConfigs[keys[0]];\n\tObject.assign(config, {\n\t\tconstants: constants,\n\t\tgetData: getData\n\t});\n\treturn new ChartComponent(config);\n}\n","import { floatTwo } from './helpers';\n\nfunction normalize(x) {\n\t// Calculates mantissa and exponent of a number\n\t// Returns normalized number and exponent\n\t// https://stackoverflow.com/q/9383593/6495043\n\n\tif(x===0) {\n\t\treturn [0, 0];\n\t}\n\tif(isNaN(x)) {\n\t\treturn {mantissa: -6755399441055744, exponent: 972};\n\t}\n\tvar sig = x > 0 ? 1 : -1;\n\tif(!isFinite(x)) {\n\t\treturn {mantissa: sig * 4503599627370496, exponent: 972};\n\t}\n\n\tx = Math.abs(x);\n\tvar exp = Math.floor(Math.log10(x));\n\tvar man = x/Math.pow(10, exp);\n\n\treturn [sig * man, exp];\n}\n\nfunction getChartRangeIntervals(max, min=0) {\n\tlet upperBound = Math.ceil(max);\n\tlet lowerBound = Math.floor(min);\n\tlet range = upperBound - lowerBound;\n\n\tlet noOfParts = range;\n\tlet partSize = 1;\n\n\t// To avoid too many partitions\n\tif(range > 5) {\n\t\tif(range % 2 !== 0) {\n\t\t\tupperBound++;\n\t\t\t// Recalc range\n\t\t\trange = upperBound - lowerBound;\n\t\t}\n\t\tnoOfParts = range/2;\n\t\tpartSize = 2;\n\t}\n\n\t// Special case: 1 and 2\n\tif(range <= 2) {\n\t\tnoOfParts = 4;\n\t\tpartSize = range/noOfParts;\n\t}\n\n\t// Special case: 0\n\tif(range === 0) {\n\t\tnoOfParts = 5;\n\t\tpartSize = 1;\n\t}\n\n\tlet intervals = [];\n\tfor(var i = 0; i <= noOfParts; i++){\n\t\tintervals.push(lowerBound + partSize * i);\n\t}\n\treturn intervals;\n}\n\nfunction getChartIntervals(maxValue, minValue=0) {\n\tlet [normalMaxValue, exponent] = normalize(maxValue);\n\tlet normalMinValue = minValue ? minValue/Math.pow(10, exponent): 0;\n\n\t// Allow only 7 significant digits\n\tnormalMaxValue = normalMaxValue.toFixed(6);\n\n\tlet intervals = getChartRangeIntervals(normalMaxValue, normalMinValue);\n\tintervals = intervals.map(value => {\n\t\t// For negative exponents we want to divide by 10^-exponent to avoid\n\t\t// floating point arithmetic bugs. For instance, in javascript\n\t\t// 6 * 10^-1 == 0.6000000000000001, we instead want 6 / 10^1 == 0.6\n\t\tif (exponent < 0) {\n\t\t\treturn value / Math.pow(10, -exponent);\n\t\t}\n\t\treturn value * Math.pow(10, exponent);\n\t});\n\treturn intervals;\n}\n\nexport function calcChartIntervals(values, withMinimum=false) {\n\t//*** Where the magic happens ***\n\n\t// Calculates best-fit y intervals from given values\n\t// and returns the interval array\n\n\tlet maxValue = Math.max(...values);\n\tlet minValue = Math.min(...values);\n\n\t// Exponent to be used for pretty print\n\tlet exponent = 0, intervals = []; // eslint-disable-line no-unused-vars\n\n\tfunction getPositiveFirstIntervals(maxValue, absMinValue) {\n\t\tlet intervals = getChartIntervals(maxValue);\n\n\t\tlet intervalSize = intervals[1] - intervals[0];\n\n\t\t// Then unshift the negative values\n\t\tlet value = 0;\n\t\tfor(var i = 1; value < absMinValue; i++) {\n\t\t\tvalue += intervalSize;\n\t\t\tintervals.unshift((-1) * value);\n\t\t}\n\t\treturn intervals;\n\t}\n\n\t// CASE I: Both non-negative\n\n\tif(maxValue >= 0 && minValue >= 0) {\n\t\texponent = normalize(maxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(maxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(maxValue, minValue);\n\t\t}\n\t}\n\n\t// CASE II: Only minValue negative\n\n\telse if(maxValue > 0 && minValue < 0) {\n\t\t// `withMinimum` irrelevant in this case,\n\t\t// We'll be handling both sides of zero separately\n\t\t// (both starting from zero)\n\t\t// Because ceil() and floor() behave differently\n\t\t// in those two regions\n\n\t\tlet absMinValue = Math.abs(minValue);\n\n\t\tif(maxValue >= absMinValue) {\n\t\t\texponent = normalize(maxValue)[1];\n\t\t\tintervals = getPositiveFirstIntervals(maxValue, absMinValue);\n\t\t} else {\n\t\t\t// Mirror: maxValue => absMinValue, then change sign\n\t\t\texponent = normalize(absMinValue)[1];\n\t\t\tlet posIntervals = getPositiveFirstIntervals(absMinValue, maxValue);\n\t\t\tintervals = posIntervals.reverse().map(d => d * (-1));\n\t\t}\n\n\t}\n\n\t// CASE III: Both non-positive\n\n\telse if(maxValue <= 0 && minValue <= 0) {\n\t\t// Mirrored Case I:\n\t\t// Work with positives, then reverse the sign and array\n\n\t\tlet pseudoMaxValue = Math.abs(minValue);\n\t\tlet pseudoMinValue = Math.abs(maxValue);\n\n\t\texponent = normalize(pseudoMaxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue, pseudoMinValue);\n\t\t}\n\n\t\tintervals = intervals.reverse().map(d => d * (-1));\n\t}\n\n\treturn intervals;\n}\n\nexport function getZeroIndex(yPts) {\n\tlet zeroIndex;\n\tlet interval = getIntervalSize(yPts);\n\tif(yPts.indexOf(0) >= 0) {\n\t\t// the range has a given zero\n\t\t// zero-line on the chart\n\t\tzeroIndex = yPts.indexOf(0);\n\t} else if(yPts[0] > 0) {\n\t\t// Minimum value is positive\n\t\t// zero-line is off the chart: below\n\t\tlet min = yPts[0];\n\t\tzeroIndex = (-1) * min / interval;\n\t} else {\n\t\t// Maximum value is negative\n\t\t// zero-line is off the chart: above\n\t\tlet max = yPts[yPts.length - 1];\n\t\tzeroIndex = (-1) * max / interval + (yPts.length - 1);\n\t}\n\treturn zeroIndex;\n}\n\nexport function getRealIntervals(max, noOfIntervals, min = 0, asc = 1) {\n\tlet range = max - min;\n\tlet part = range * 1.0 / noOfIntervals;\n\tlet intervals = [];\n\n\tfor(var i = 0; i <= noOfIntervals; i++) {\n\t\tintervals.push(min + part * i);\n\t}\n\n\treturn asc ? intervals : intervals.reverse();\n}\n\nexport function getIntervalSize(orderedArray) {\n\treturn orderedArray[1] - orderedArray[0];\n}\n\nexport function getValueRange(orderedArray) {\n\treturn orderedArray[orderedArray.length-1] - orderedArray[0];\n}\n\nexport function scale(val, yAxis) {\n\treturn floatTwo(yAxis.zeroLine - val * yAxis.scaleMultiplier);\n}\n\nexport function isInRange(val, min, max) {\n\treturn val > min && val < max;\n}\n\nexport function isInRange2D(coord, minCoord, maxCoord) {\n\treturn isInRange(coord[0], minCoord[0], maxCoord[0])\n\t\t&& isInRange(coord[1], minCoord[1], maxCoord[1]);\n}\n\nexport function getClosestInArray(goal, arr, index = false) {\n\tlet closest = arr.reduce(function(prev, curr) {\n\t\treturn (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);\n\t}, []);\n\n\treturn index ? arr.indexOf(closest) : closest;\n}\n\nexport function calcDistribution(values, distributionSize) {\n\t// Assume non-negative values,\n\t// implying distribution minimum at zero\n\n\tlet dataMaxValue = Math.max(...values);\n\n\tlet distributionStep = 1 / (distributionSize - 1);\n\tlet distribution = [];\n\n\tfor(var i = 0; i < distributionSize; i++) {\n\t\tlet checkpoint = dataMaxValue * (distributionStep * i);\n\t\tdistribution.push(checkpoint);\n\t}\n\n\treturn distribution;\n}\n\nexport function getMaxCheckpoint(value, distribution) {\n\treturn distribution.filter(d => d < value).length;\n}\n","import { fillArray } from '../utils/helpers';\nimport { DEFAULT_AXIS_CHART_TYPE, AXIS_DATASET_CHART_TYPES, DEFAULT_CHAR_WIDTH } from '../utils/constants';\n\nexport function dataPrep(data, type) {\n\tdata.labels = data.labels || [];\n\n\tlet datasetLength = data.labels.length;\n\n\t// Datasets\n\tlet datasets = data.datasets;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\tif(!datasets) {\n\t\t// default\n\t\tdatasets = [{\n\t\t\tvalues: zeroArray\n\t\t}];\n\t}\n\n\tdatasets.map(d=> {\n\t\t// Set values\n\t\tif(!d.values) {\n\t\t\td.values = zeroArray;\n\t\t} else {\n\t\t\t// Check for non values\n\t\t\tlet vals = d.values;\n\t\t\tvals = vals.map(val => (!isNaN(val) ? val : 0));\n\n\t\t\t// Trim or extend\n\t\t\tif(vals.length > datasetLength) {\n\t\t\t\tvals = vals.slice(0, datasetLength);\n\t\t\t} else {\n\t\t\t\tvals = fillArray(vals, datasetLength - vals.length, 0);\n\t\t\t}\n\t\t\td.values = vals;\n\t\t}\n\n\t\t// Set type\n\t\tif(!d.chartType ) {\n\t\t\tif(!AXIS_DATASET_CHART_TYPES.includes(type)) type === DEFAULT_AXIS_CHART_TYPE;\n\t\t\td.chartType = type;\n\t\t}\n\n\t});\n\n\t// Markers\n\n\t// Regions\n\t// data.yRegions = data.yRegions || [];\n\tif(data.yRegions) {\n\t\tdata.yRegions.map(d => {\n\t\t\tif(d.end < d.start) {\n\t\t\t\t[d.start, d.end] = [d.end, d.start];\n\t\t\t}\n\t\t});\n\t}\n\n\treturn data;\n}\n\nexport function zeroDataPrep(realData) {\n\tlet datasetLength = realData.labels.length;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\n let zeroData = {\n labels: realData.labels.slice(0, -1),\n datasets: realData.datasets.map((d) => {\n const { axisID } = d;\n return {\n axisID,\n name: '',\n values: zeroArray.slice(0, -1),\n chartType: d.chartType\n };\n })\n };\n\n\tif(realData.yMarkers) {\n\t\tzeroData.yMarkers = [\n\t\t\t{\n\t\t\t\tvalue: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\tif(realData.yRegions) {\n\t\tzeroData.yRegions = [\n\t\t\t{\n\t\t\t\tstart: 0,\n\t\t\t\tend: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\treturn zeroData;\n}\n\nexport function getShortenedLabels(chartWidth, labels=[], isSeries=true) {\n\tlet allowedSpace = chartWidth / labels.length;\n\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet seriesMultiple;\n\tif(isSeries) {\n\t\t// Find the maximum label length for spacing calculations\n\t\tlet maxLabelLength = Math.max(...labels.map(label => label.length));\n\t\tseriesMultiple = Math.ceil(maxLabelLength/allowedLetters);\n\t}\n\n\tlet calcLabels = labels.map((label, i) => {\n\t\tlabel += \"\";\n\t\tif(label.length > allowedLetters) {\n\n\t\t\tif(!isSeries) {\n\t\t\t\tif(allowedLetters-3 > 0) {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters-3) + \" ...\";\n\t\t\t\t} else {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters) + '..';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif(i % seriesMultiple !== 0) {\n\t\t\t\t\tlabel = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn label;\n\t});\n\n\treturn calcLabels;\n}\n","import '../css/charts.scss';\n\n// import MultiAxisChart from './charts/MultiAxisChart';\nimport PercentageChart from './charts/PercentageChart';\nimport PieChart from './charts/PieChart';\nimport Heatmap from './charts/Heatmap';\nimport AxisChart from './charts/AxisChart';\nimport DonutChart from './charts/DonutChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart,\n\tdonut: DonutChart,\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };","function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `\n\t\t\t\t
          \n\t\t\t\t
          `\n\t\t});\n\t\tthis.hideTip();\n\n\t\tthis.title = this.container.querySelector('.title');\n\t\tthis.dataPointList = this.container.querySelector('.data-point-list');\n\n\t\tthis.parent.addEventListener('mouseleave', () => {\n\t\t\tthis.hideTip();\n\t\t});\n\t}\n\n\tfill() {\n\t\tlet title;\n\t\tif(this.index) {\n\t\t\tthis.container.setAttribute('data-point-index', this.index);\n\t\t}\n\t\tif(this.titleValueFirst) {\n\t\t\ttitle = `${this.titleValue}${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}${this.titleValue}`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `${ value === 0 || value ? value : '' }\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth, isHidden } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\nimport { deepClone } from '../utils/helpers';\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\t\t// deepclone options to avoid making changes to orignal object\n\t\toptions = deepClone(options);\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || '';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: (typeof options.animate !== 'undefined') ? options.animate : 1,\n\t\t\ttruncateLegends: options.truncateLegends || 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tthis.boundDrawFn = () => this.draw(true);\n\t\tif (ResizeObserver) {\n\t\t\tthis.resizeObserver = new ResizeObserver(this.boundDrawFn);\n\t\t\tthis.resizeObserver.observe(this.parent);\n\t\t}\n\t\twindow.addEventListener('resize', this.boundDrawFn);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn);\n\t}\n\n\tdestroy() {\n\t\tif (this.resizeObserver) this.resizeObserver.disconnect();\n\t\twindow.removeEventListener('resize', this.boundDrawFn);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn);\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t}\n\n\t\tthis.container = $.create('div', args);\n\t}\n\n\tmakeTooltip() {\n\t\tthis.tip = new SvgTip({\n\t\t\tparent: this.container,\n\t\t\tcolors: this.colors\n\t\t});\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {}\n\n\tdraw(onlyWidthChange=false, init=false) {\n\t\tif (onlyWidthChange && isHidden(this.parent)) {\n\t\t\t// Don't update anything if the chart is hidden\n\t\t\treturn;\n\t\t}\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render(this.components, this.config.animate);\n\t\tthis.renderLegend();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { truncateString } from '../utils/draw-utils';\nimport { legendDot } from '../utils/draw';\nimport { round } from '../utils/helpers';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.formatTooltipY = (args.tooltipOptions || {}).formatTooltipY;\n\t\tthis.config.maxSlices = args.maxSlices || 20;\n\t\tthis.config.maxLegendPoints = args.maxLegendPoints || 20;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\t\tlet maxSlices = this.config.maxSlices;\n\t\ts.sliceTotals = [];\n\n\t\tlet allTotals = this.data.labels.map((label, i) => {\n\t\t\tlet total = 0;\n\t\t\tthis.data.datasets.map(e => {\n\t\t\t\ttotal += e.values[i];\n\t\t\t});\n\t\t\treturn [total, label];\n\t\t}).filter(d => { return d[0] >= 0; }); // keep only positive results\n\n\t\tlet totals = allTotals;\n\t\tif(allTotals.length > maxSlices) {\n\t\t\t// Prune and keep a grey area for rest as per maxSlices\n\t\t\tallTotals.sort((a, b) => { return b[0] - a[0]; });\n\n\t\t\ttotals = allTotals.slice(0, maxSlices-1);\n\t\t\tlet remaining = allTotals.slice(maxSlices-1);\n\n\t\t\tlet sumOfRemaining = 0;\n\t\t\tremaining.map(d => {sumOfRemaining += d[0];});\n\t\t\ttotals.push([sumOfRemaining, 'Rest']);\n\t\t\tthis.colors[maxSlices-1] = 'grey';\n\t\t}\n\n\t\ts.labels = [];\n\t\ttotals.map(d => {\n\t\t\ts.sliceTotals.push(round(d[0]));\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 150;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif (this.legendTotals.length < divisor) {\n\t\t\t\tbarWidth = this.width/this.legendTotals.length;\n\t\t\t}\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet label = this.config.truncateLegends ? truncateString(s.labels[i], barWidth/10) : s.labels[i];\n\t\t\tlet formatted = this.config.formatTooltipY ? this.config.formatTooltipY(d) : d;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${label}: ${formatted}`,\n\t\t\t\tfalse\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 60;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr, makeCircleStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class PieChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'pie';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius = (this.height > this.width ? this.center.x : this.center.y);\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst largeArc = originDiffAngle > 180 ? 1: 0;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath =\n\t\t\t\toriginDiffAngle === 360\n\t\t\t\t\t? makeCircleStr(curStart, curEnd, this.center, this.radius, clockWise, largeArc)\n\t\t\t\t\t: makeArcPathStr(curStart, curEnd, this.center, this.radius, clockWise, largeArc);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\tradius: this.rawChartArgs.radius || 0,\n\t\t\t\txTranslate: s.domainConfigs\n\t\t\t\t\t.filter((config, j) => j < i)\n\t\t\t\t\t.map(config => config.cols.length - lessCol)\n\t\t\t\t\t.reduce((a, b) => a + b, 0)\n\t\t\t\t\t* COL_WIDTH\n\t\t\t},\n\t\t\tfunction() {\n\t\t\t\treturn s.domainConfigs[i];\n\t\t\t}.bind(this)\n\n\t\t]);\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map((args, i) => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0] + '-' + i, component];\n\t\t\t})\n\t\t);\n\n\t\tlet y = 0;\n\t\tDAY_NAMES_SHORT.forEach((dayName, i) => {\n\t\t\tif([1, 3, 5].includes(i)) {\n\t\t\t\tlet dayText = makeText('subdomain-name', -COL_WIDTH/2, y, dayName,\n\t\t\t\t\t{\n\t\t\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\t\t\tdy: 8,\n\t\t\t\t\t\ttextAnchor: 'end'\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tthis.drawArea.appendChild(dayText);\n\t\t\t}\n\t\t\ty += ROW_HEIGHT;\n\t\t});\n\t}\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\n\t\tthis.data = this.prepareData(data);\n\t\tthis.draw();\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tthis.components.forEach(comp => {\n\t\t\t\tlet daySquares = comp.store;\n\t\t\t\tlet daySquare = e.target;\n\t\t\t\tif(daySquares.includes(daySquare)) {\n\n\t\t\t\t\tlet count = daySquare.getAttribute('data-value');\n\t\t\t\t\tlet dateParts = daySquare.getAttribute('data-date').split('-');\n\n\t\t\t\t\tlet month = getMonthName(parseInt(dateParts[1])-1, true);\n\n\t\t\t\t\tlet gOff = this.container.getBoundingClientRect(), pOff = daySquare.getBoundingClientRect();\n\n\t\t\t\t\tlet width = parseInt(e.target.getAttribute('width'));\n\t\t\t\t\tlet x = pOff.left - gOff.left + width/2;\n\t\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\t\tlet value = count + ' ' + this.countLabel;\n\t\t\t\t\tlet name = ' on ' + month + ' ' + dateParts[0] + ', ' + dateParts[2];\n\n\t\t\t\t\tthis.tip.setValues(x, y, {name: name, value: value, valueFirst: 1}, []);\n\t\t\t\t\tthis.tip.showTip();\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\trenderLegend() {\n\t\tthis.legendArea.textContent = '';\n\t\tlet x = 0;\n\t\tlet y = ROW_HEIGHT;\n\t\tlet radius = this.rawChartArgs.radius || 0;\n\n\t\tlet lessText = makeText('subdomain-name', x, y, 'Less',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tx = (COL_WIDTH * 2) + COL_WIDTH/2;\n\t\tthis.legendArea.appendChild(lessText);\n\n\t\tthis.colors.slice(0, HEATMAP_DISTRIBUTION_SIZE).map((color, i) => {\n\t\t\tconst square = heatSquare('heatmap-legend-unit', x + (COL_WIDTH + 3) * i,\n\t\t\t\ty, HEATMAP_SQUARE_SIZE, radius, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.type = args.type || 'line';\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n super.configure(options);\n const { axisOptions = {} } = options;\n const { xAxis, yAxis } = axisOptions || {};\n\n options.tooltipOptions = options.tooltipOptions || {};\n\n this.config.xAxisMode = xAxis ? xAxis.xAxisMode : axisOptions.xAxisMode || 'span';\n\n // this will pass an array\n // lets determine if we need two yAxis based on if there is length\n // to the yAxis array\n if (yAxis && yAxis.length) {\n this.config.yAxisConfig = yAxis.map((item) => {\n return {\n yAxisMode: item.yAxisMode,\n id: item.id,\n position: item.position,\n title: item.title\n };\n });\n } else {\n this.config.yAxisMode = yAxis ? yAxis.yAxisMode : axisOptions.yAxisMode || 'span';\n\n\t\t\t// if we have yAxis config settings lets populate a yAxis config array.\n\t\t\tif (yAxis && yAxis.id && yAxis.position) {\n\t\t\t\tthis.config.yAxisConfig = [yAxis]\n\t\t\t}\n }\n\n this.config.xIsSeries = axisOptions.xIsSeries || 0;\n this.config.shortenYAxisNumbers = axisOptions.shortenYAxisNumbers || 0;\n\n this.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n this.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n this.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\n calcYAxisParameters(dataValues, withMinimum = 'false') {\n let yPts, scaleMultiplier, intervalHeight, zeroLine, positions, yAxisConfigObject, yAxisAlignment, yKeys;\n\t\tyKeys = [];\n\t\tyAxisConfigObject = this.config.yAxisMode || {};\t\n\t\tyAxisAlignment = yAxisConfigObject.position ? yAxisConfigObject.position : 'left';\t\n\n // if we have an object we have multiple yAxisParameters.\n if (dataValues instanceof Array) {\n yPts = calcChartIntervals(dataValues, withMinimum);\n scaleMultiplier = this.height / getValueRange(yPts);\n intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n zeroLine = this.height - getZeroIndex(yPts) * intervalHeight;\n\n this.state.yAxis = {\n labels: yPts,\n positions: yPts.map((d) => zeroLine - d * scaleMultiplier),\n\t\t\t\ttitle: yAxisConfigObject.title || null,\n\t\t\t\tpos: yAxisAlignment,\n scaleMultiplier: scaleMultiplier,\n zeroLine: zeroLine\n };\n } else {\n this.state.yAxis = [];\n for (let key in dataValues) {\n const dataValue = dataValues[key];\n\t\t\t\tyAxisConfigObject = this.config.yAxisConfig.find((item) => key === item.id) || [];\n\t\t\t\tyAxisAlignment = yAxisConfigObject.position ? yAxisConfigObject.position : 'left';\t\n yPts = calcChartIntervals(dataValue, withMinimum);\n scaleMultiplier = this.height / getValueRange(yPts);\n intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n zeroLine = this.height - getZeroIndex(yPts) * intervalHeight;\n positions = yPts.map((d) => zeroLine - d * scaleMultiplier);\n\t\t\t\tyKeys.push(key);\n\n if (this.state.yAxis.length > 1) {\n const yPtsArray = [];\n const firstArr = this.state.yAxis[0];\n\n\t\t\t\t\t// we need to calculate the scaleMultiplier.\n\n\t\t\t\t\t// now that we have an accurate scaleMultiplier we can \n // we need to loop through original positions.\n\t\t\t\t\tscaleMultiplier = this.height / getValueRange(yPts);\n firstArr.positions.forEach((pos) => {\n yPtsArray.push(Math.ceil(pos / scaleMultiplier));\n });\n yPts = yPtsArray.reverse();\n zeroLine = this.height - getZeroIndex(yPts) * intervalHeight;\n positions = firstArr.positions;\n }\n\n this.state.yAxis.push({\n axisID: key || 'left-axis',\n labels: yPts,\n title: yAxisConfigObject.title,\n pos: yAxisAlignment,\n scaleMultiplier,\n zeroLine,\n positions\n });\n }\n\n\t\t\t// the labels are not aligned in length between the two yAxis objects,\n\t\t\t// we need to run some new calculations.\n\t\t\tif (this.state.yAxis[1] && this.state.yAxis[0].labels.length !== this.state.yAxis[1].labels.length) {\n\t\t\t\tconst newYptsArr = [];\n\t\t\t\t// find the shorter array\n\t\t\t\tconst shortest = this.state.yAxis.reduce((p,c) => { \n\t\t\t\t\treturn p.length > c.labels.length ? c : p;\n\t\t\t\t},\n\t\t\t\t{ length: Infinity });\n\t\t\t\t// return the longest\n\t\t\t\tconst longest = this.state.yAxis.reduce((p,c) => { \n\t\t\t\t\treturn p.length < c.labels.length ? p : c;\n\t\t\t\t},\n\t\t\t\t{ length: Infinity });\n\n\t\t\t\t// we now need to populate the shortest obj with the new scale multiplier\n\t\t\t\t// with the positions of the longest obj.\n\t\t\t\tlongest.positions.forEach((pos) => {\n\t\t\t\t\t// calculate a new yPts\n\t\t\t\t\tnewYptsArr.push(Math.ceil(pos / shortest.scaleMultiplier));\n\t\t\t\t});\n\n\t\t\t\tshortest.labels = newYptsArr.reverse();\n\t\t\t\tshortest.positions = longest.positions;\n\t\t\t}\n }\n\n // Dependent if above changes\n this.calcDatasetPoints();\n this.calcYExtremes();\n this.calcYRegions();\n }\n\n calcDatasetPoints() {\n let s = this.state;\n let scaleAll = (values, id) => {\n return values.map((val) => {\n let { yAxis } = s;\n\n if (yAxis instanceof Array) {\n\t\t\t\t\tyAxis = yAxis.length > 1 ? yAxis.find((axis) => id === axis.axisID) : s.yAxis[0];\n }\n\n return scale(val, yAxis);\n });\n };\n\n s.barChartIndex = 1;\n s.datasets = this.data.datasets.map((d, i) => {\n let values = d.values;\n let cumulativeYs = d.cumulativeYs || [];\n\n return {\n name:\n d.name &&\n d.name.replace(/<|>|&/g, (char) =>\n char == '&' ? '&' : char == '<' ? '<' : '>'\n ),\n index: i,\n barIndex: d.chartType === 'bar' ? s.barChartIndex++ : s.barChartIndex,\n chartType: d.chartType,\n\n values: values,\n yPositions: scaleAll(values, d.axisID),\n id: d.axisID,\n\n cumulativeYs: cumulativeYs,\n cumulativeYPos: scaleAll(cumulativeYs, d.axisID)\n };\n });\n }\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n getAllYValues() {\n let key = 'values';\n let multiAxis = this.config.yAxisConfig ? true : false;\n let allValueLists = multiAxis ? {} : [];\n\n let groupBy = (arr, property) => {\n return arr.reduce((acc, cur) => {\n acc[cur[property]] = [...(acc[cur[property]] || []), cur];\n return acc;\n }, {});\n };\n\n let generateCumulative = (arr) => {\n let cumulative = new Array(this.state.datasetLength).fill(0);\n arr.forEach((d, i) => {\n let values = arr[i].values;\n d[key] = cumulative = cumulative.map((c, i) => {\n return c + values[i];\n });\n });\n };\n\n if (this.barOptions.stacked) {\n key = 'cumulativeYs';\n // we need to filter out the different yAxis ID's here.\n if (multiAxis) {\n const groupedDataSets = groupBy(this.data.datasets, 'axisID');\n // const dataSetsByAxis = this.data.dd\n for (var axisID in groupedDataSets) {\n generateCumulative(groupedDataSets[axisID]);\n }\n } else {\n generateCumulative(this.data.datasets);\n }\n }\n\n // this is the trouble maker, we don't want to merge all\n // datasets since we are trying to run two yAxis.\n if (multiAxis) {\n this.data.datasets.forEach((d) => {\n // if the array exists already just push more data into it.\n // otherwise create a new array into the object.\n allValueLists[d.axisID || key]\n ? allValueLists[d.axisID || key].push(...d[key])\n : (allValueLists[d.axisID || key] = [...d[key]]);\n });\n } else {\n allValueLists = this.data.datasets.map((d) => {\n return d[key];\n });\n }\n\n if (this.data.yMarkers && !multiAxis) {\n allValueLists.push(this.data.yMarkers.map((d) => d.value));\n }\n\n if (this.data.yRegions && !multiAxis) {\n this.data.yRegions.map((d) => {\n allValueLists.push([d.end, d.start]);\n });\n }\n\n return multiAxis ? allValueLists : [].concat(...allValueLists);\n }\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'xAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.xAxisMode,\n\t\t\t\t\theight: this.height,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\ts.xAxis.calcLabels = getShortenedLabels(this.width,\n\t\t\t\t\t\ts.xAxis.labels, this.config.xIsSeries);\n\n\t\t\t\t\treturn s.xAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'yRegions',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yRegions;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\t\t];\n\n // if we have multiple yAxisConfigs we need to update the yAxisDefault\n // components to multiple yAxis components.\n if (this.config.yAxisConfig && this.config.yAxisConfig.length) {\n this.config.yAxisConfig.forEach((yAxis) => {\n componentConfigs.push([\n 'yAxis',\n {\n mode: yAxis.yAxisMode || 'span',\n width: this.width,\n\t\t\t\t\t\theight: this.baseHeight,\n shortenNumbers: this.config.shortenYAxisNumbers,\n pos: yAxis.position || 'left'\n },\n function () {\n return this.state.yAxis;\n }.bind(this)\n ]);\n });\n } else {\n componentConfigs.push([\n 'yAxis',\n {\n mode: this.config.yAxisMode,\n width: this.width,\n\t\t\t\t\theight: this.baseHeight,\n shortenNumbers: this.config.shortenYAxisNumbers\n },\n function () {\n return this.state.yAxis;\n }.bind(this)\n ]);\n }\n\n\t\tlet barDatasets = this.state.datasets.filter(d => d.chartType === 'bar');\n\t\tlet lineDatasets = this.state.datasets.filter(d => d.chartType === 'line');\n\n\t\tlet barsConfigs = barDatasets.map(d => {\n let index = d.index;\n let barIndex = d.barIndex || index;\n\t\t\treturn [\n\t\t\t\t'barGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tstacked: this.barOptions.stacked,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t\tminHeight: this.height * MIN_BAR_PERCENT_HEIGHT,\n\t\t\t\t},\n\t\t\t\tfunction() {\n let s = this.state;\n let { yAxis } = s;\n let d = s.datasets[index];\n let { id = 'left-axis' } = d;\n let stacked = this.barOptions.stacked;\n\n let spaceRatio = this.barOptions.spaceRatio || BAR_CHART_SPACE_RATIO;\n let barsWidth = s.unitWidth * (1 - spaceRatio);\n let barWidth = barsWidth / (stacked ? 1 : barDatasets.length);\n\n // if there are multiple yAxis we need to return the yAxis with the\n // proper ID.\n\t\t\t\t\tif (yAxis instanceof Array) {\n\t\t\t\t\t\t// if the person only configured one yAxis in the array return the first.\n\t\t\t\t\t\tyAxis = yAxis.length > 1 ? yAxis.find((axis) => id === axis.axisID) : s.yAxis[0];\n\t\t\t\t\t}\n\n\n let xPositions = s.xAxis.positions.map((x) => x - barsWidth / 2);\n\n if (!stacked) {\n xPositions = xPositions.map((p) => {\n return p + barWidth * barIndex - barWidth;\n });\n }\n\n let labels = new Array(s.datasetLength).fill('');\n if (this.config.valuesOverPoints) {\n if (stacked && d.index === s.datasets.length - 1) {\n labels = d.cumulativeYs;\n } else {\n labels = d.values;\n }\n }\n let offsets = new Array(s.datasetLength).fill(0);\n if (stacked) {\n offsets = d.yPositions.map((y, j) => y - d.cumulativeYPos[j]);\n }\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: xPositions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\t\t\t\t\t\toffsets: offsets,\n\t\t\t\t\t\t// values: d.values,\n\t\t\t\t\t\tlabels: labels,\n\n\t\t\t\t\t\tzeroLine: yAxis.zeroLine,\n\t\t\t\t\t\tbarsWidth: barsWidth,\n\t\t\t\t\t\tbarWidth: barWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n let lineConfigs = lineDatasets.map((d) => {\n let index = d.index;\n return [\n 'lineGraph' + '-' + d.index,\n {\n index: index,\n color: this.colors[index],\n svgDefs: this.svgDefs,\n heatline: this.lineOptions.heatline,\n regionFill: this.lineOptions.regionFill,\n spline: this.lineOptions.spline,\n hideDots: this.lineOptions.hideDots,\n hideLine: this.lineOptions.hideLine,\n\n // same for all datasets\n valuesOverPoints: this.config.valuesOverPoints\n },\n function () {\n let s = this.state;\n let d = s.datasets[index];\n\n // if we have more than one yindex lets map the values\n const yAxis = s.yAxis.length\n ? s.yAxis.find((axis) => d.id === axis.axisID) || s.yAxis[0]\n : s.yAxis;\n\n let minLine =\n yAxis.positions[0] < yAxis.zeroLine\n ? yAxis.positions[0]\n : yAxis.zeroLine;\n\n return {\n xPositions: s.xAxis.positions,\n yPositions: d.yPositions,\n\n values: d.values,\n\n zeroLine: minLine,\n radius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE\n };\n }.bind(this)\n ];\n });\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tif (index >= 0) {\n\t\t\tlet dbi = this.dataByIndex[index];\n\n\t\t\tthis.tip.setValues(\n\t\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\t\tdbi.values,\n\t\t\t\tindex\n\t\t\t);\n\n\t\t\tthis.tip.showTip();\n\t\t}\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name,\n\t\t\t\t\tthis.config.truncateLegends);\n\t\t\t\tthis.legendArea.appendChild(rect);\n\t\t\t});\n\t\t}\n\t}\n\n\n\n\t// Overlay\n\tmakeOverlay() {\n\t\tif(this.init) {\n\t\t\tthis.init = 0;\n\t\t\treturn;\n\t\t}\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\n\t\tthis.overlayGuides = this.dataUnitComponents.map(c => {\n\t\t\treturn {\n\t\t\t\ttype: c.unitType,\n\t\t\t\toverlay: undefined,\n\t\t\t\tunits: c.units,\n\t\t\t};\n\t\t});\n\n\t\tif(this.state.currentIndex === undefined) {\n\t\t\tthis.state.currentIndex = this.state.datasetLength - 1;\n\t\t}\n\n\t\t// Render overlays\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\n\t\t\td.overlay = makeOverlay[d.type](currentUnit);\n\t\t\tthis.drawArea.appendChild(d.overlay);\n\t\t});\n\t}\n\n\tupdateOverlayGuides() {\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\t}\n\n\tbindOverlay() {\n\t\tthis.parent.addEventListener('data-select', () => {\n\t\t\tthis.updateOverlay();\n\t\t});\n\t}\n\n\tbindUnits() {\n\t\tthis.dataUnitComponents.map(c => {\n\t\t\tc.units.map(unit => {\n\t\t\t\tunit.addEventListener('click', () => {\n\t\t\t\t\tlet index = unit.getAttribute('data-point-index');\n\t\t\t\t\tthis.setCurrentDataPoint(index);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\t// Note: Doesn't work as tooltip is absolutely positioned\n\t\tthis.tip.container.addEventListener('click', () => {\n\t\t\tlet index = this.tip.container.getAttribute('data-point-index');\n\t\t\tthis.setCurrentDataPoint(index);\n\t\t});\n\t}\n\n\tupdateOverlay() {\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\t\t\tupdateOverlay[d.type](currentUnit, d.overlay);\n\t\t});\n\t}\n\n\tonLeftArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex - 1);\n\t}\n\n\tonRightArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex + 1);\n\t}\n\n\tgetDataPoint(index=this.state.currentIndex) {\n\t\tlet s = this.state;\n\t\tlet data_point = {\n\t\t\tindex: index,\n\t\t\tlabel: s.xAxis.labels[index],\n\t\t\tvalues: s.datasets.map(d => d.values[index])\n\t\t};\n\t\treturn data_point;\n\t}\n\n\tsetCurrentDataPoint(index) {\n\t\tlet s = this.state;\n\t\tindex = parseInt(index);\n\t\tif(index < 0) index = 0;\n\t\tif(index >= s.xAxis.labels.length) index = s.xAxis.labels.length - 1;\n\t\tif(index === s.currentIndex) return;\n\t\ts.currentIndex = index;\n\t\tfire(this.parent, \"data-select\", this.getDataPoint());\n\t}\n\n\n\n\t// API\n\taddDataPoint(label, datasetValues, index=this.state.datasetLength) {\n\t\tsuper.addDataPoint(label, datasetValues, index);\n\t\tthis.data.labels.splice(index, 0, label);\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\td.values.splice(index, 0, datasetValues[i]);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tremoveDataPoint(index = this.state.datasetLength-1) {\n\t\tif (this.data.labels.length <= 1) {\n\t\t\treturn;\n\t\t}\n\t\tsuper.removeDataPoint(index);\n\t\tthis.data.labels.splice(index, 1);\n\t\tthis.data.datasets.map(d => {\n\t\t\td.values.splice(index, 1);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tupdateDataset(datasetValues, index=0) {\n\t\tthis.data.datasets[index].values = datasetValues;\n\t\tthis.update(this.data);\n\t}\n\t// addDataset(dataset, index) {}\n\t// removeDataset(index = 0) {}\n\n\tupdateDatasets(datasets) {\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\tif(datasets[i]) {\n\t\t\t\td.values = datasets[i];\n\t\t\t}\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\t// updateDataPoint(dataPoint, index = 0) {}\n\t// addDataPoint(dataPoint, index = 0) {}\n\t// removeDataPoint(index = 0) {}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcStrokePathStr, makeStrokeCircleStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class DonutChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'donut';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t\tthis.strokeWidth = args.strokeWidth || 30;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius =\n\t\t\tthis.height > this.width\n\t\t\t\t? this.center.x - this.strokeWidth / 2\n\t\t\t\t: this.center.y - this.strokeWidth / 2;\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst largeArc = originDiffAngle > 180 ? 1: 0;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath =\n\t\t\t\toriginDiffAngle === 360\n\t\t\t\t\t? makeStrokeCircleStr(curStart, curEnd, this.center, this.radius, this.clockWise, largeArc)\n\t\t\t\t\t: makeArcStrokePathStr(curStart, curEnd, this.center, this.radius, this.clockWise, largeArc);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'donutSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors,\n\t\t\t\t\t\tstrokeWidth: this.strokeWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{ radius, hoverRadio } = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.stroke = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.stroke = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('donutSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import * as Charts from './chart';\n\nlet frappe = { };\n\nfrappe.NAME = 'Frappe Charts';\nfrappe.VERSION = '1.6.2';\n\nfrappe = Object.assign({ }, frappe, Charts);\n\nexport default frappe;"],"names":["expr","con","document","querySelector","getOffset","element","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isHidden","el","offsetParent","isElementInViewport","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","type","properties","evt","createEvent","initEvent","j","dispatchEvent","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","legendHeight","getExtraWidth","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","Math","abs","fill","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","ANGLE_RATIO","cos","isValidNumber","candidate","nonNegative","Number","isNaN","undefined","isFinite","round","deepClone","cloned","value","key","Date","getTime","isArray","getBarHeightAndYAttr","yTop","zeroLine","height","y","equilizeNoOfElements","array1","array2","extraCount","truncateString","txt","len","slice","shortenLargeNumber","label","number","p","floor","log10","l","shortened","pow","getSplineCurvePointsStr","xList","yList","points","i","push","line","pointA","pointB","lengthX","lengthY","sqrt","atan2","controlPoint","current","previous","next","reverse","o","PI","command","reduce","acc","point","a","cps","cpe","limitColor","r","lightenDarkenColor","color","amt","col","getColor","usePound","num","parseInt","b","g","toString","isValidColor","RGB_RE","test","$","createSVG","tag","createElementNS","val","appendChild","ref","parentNode","insertBefore","keys","map","style","prop","setAttribute","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","opacity","makeSVGContainer","parent","className","width","makeSVGDefs","svgContainer","makeSVGGroup","transform","args","inside","makePath","pathStr","makeArcPathStr","startPosition","endPosition","center","clockWise","largeArc","arcStartX","x","arcStartY","arcEndX","arcEndY","makeCircleStr","midArc","makeArcStrokePathStr","makeStrokeCircleStr","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","PERCENTAGE_BAR_DEFAULT_DEPTH","heatSquare","size","data","legendBar","LABEL_MAX_CHARS","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","stroke","BASE_LINE_COLOR","LABEL_MARGIN","makeHoriLine","x1","x2","lineType","alignment","shortenNumbers","generateAxisLabel","title","position","TOTAL_PADDING","rotation","labelSvg","wrapper","yLine","pos","mode","AXIS_TICK_LENGTH","xLine","yMarker","labelPos","yRegion","region","datasetBar","index","meta","minHeight","datasetDot","dot","getPaths","pointsStr","join","spline","path","heatline","gradient_id","svgDefs","paths","regionFill","gradient_id_region","translate","unit","oldCoord","newCoord","duration","old","STD_EASING","translateVertLine","newX","oldX","MARKER_LINE_ANIM_DUR","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","childNodes","stroke-dasharray","getAttribute","animateBar","bar","nodeName","UNIT_ANIM_DUR","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","PATH_ANIM_DUR","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","animateSVGElement","props","dur","easingType","oldValues","animElement","cloneNode","newElement","attributeName","animateElement","currentValue","animAttr","EASING","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","REPLACE_ALL_NEW_DUR","downloadFile","filename","createElement","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","create","CSSTEXT","firstChild","container","innerHTML","treatAsUtc","date","result","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","getWeeksBetween","startDate","endDate","weekStartDate","setDayToSunday","ceil","getDaysBetween","NO_OF_DAYS_IN_WEEK","millisecondsPerDay","SEC_IN_DAY","NO_OF_MILLIS","areInSameMonth","getMonthName","short","monthName","MONTH_NAMES","getLastDateInMonth","month","year","newDate","day","getDay","addDays","numberOfDays","setDate","getComponent","name","constants","getData","Object","componentConfigs","filter","includes","k","config","assign","ChartComponent","normalize","mantissa","exponent","sig","exp","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","values","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","withMinimum","pseudoMaxValue","pseudoMinValue","getZeroIndex","yPts","interval","getIntervalSize","indexOf","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","prev","curr","calcDistribution","distributionSize","dataMaxValue","distributionStep","distribution","checkpoint","getMaxCheckpoint","dataPrep","labels","datasetLength","datasets","zeroArray","vals","chartType","AXIS_DATASET_CHART_TYPES","yRegions","end","zeroDataPrep","realData","zeroData","axisID","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedSpace","allowedLetters","DEFAULT_CHAR_WIDTH","seriesMultiple","maxLabelLength","getChartByType","AxisChart","chartTypes","error","css","insertAt","head","getElementsByTagName","styleSheet","cssText","createTextNode","BASE_MEASURES","INIT_CHART_UPDATE_TIMEOUT","DEFAULT_CHART_COLORS","DEFAULT_COLORS","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","dataPointList","addEventListener","set","_this2","formatted","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","exec","c","ch","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BaseChart","HTMLElement","Error","rawChartArgs","prepareData","prepareFirstData","validateColors","isNavigable","animate","truncateLegends","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","_this","draw","ResizeObserver","resizeObserver","observe","disconnect","removeEventListener","makeContainer","updateWidth","independentWidth","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","bind","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","e","_this4","event","keyCode","chartSvg","AggregationChart","formatTooltipY","tooltipOptions","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","barWidth","divisor","_this3","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","strokeWidth","transition","newData","xPositions","widths","barHeight","barDepth","item","positions","animateMultipleElements","newPos","newLabels","oldPos","oldLabels","calcLabels","_this5","_this6","newOptions","startPos","endPos","_this7","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","offsets","barsWidth","newXPos","newYPos","newOffsets","oldXPos","oldYPos","oldOffsets","hideLine","hideDots","valuesOverPoints","newValues","PercentageChart","barOptions","component","xPos","bars","get","gOff","pOff","formattedLabels","fraction","setValues","showTip","PieChart","mouseMove","mouseLeave","hoverRadio","startAngle","prevSlicesProperties","slicesProperties","curAngle","originDiffAngle","diffAngle","endAngle","prevProperty","curStart","curEnd","curPath","property","flag","calTranslateByAngle","g_off","pageX","pageY","formatted_labels","percent","slices","prevIndex","curActiveSliceIndex","prevAcitve","curActiveSlice","hoverSlice","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","ROW_HEIGHT","HEATMAP_SQUARE_SIZE","spacing","noOfWeeks","setFullYear","dataPoints","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","COL_WIDTH","moreText","HEATMAP_DISTRIBUTION_SIZE","startMonth","startYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","lineOptions","axisOptions","xAxis","xAxisMode","yAxisConfig","yAxisMode","id","xIsSeries","shortenYAxisNumbers","formatTooltipX","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","dataValues","intervalHeight","yAxisConfigObject","yAxisAlignment","yKeys","find","yPtsArray","firstArr","newYptsArr","shortest","Infinity","longest","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","axis","barChartIndex","cumulativeYs","replace","char","stacked","yExtremes","cumulativeYPos","multiAxis","allValueLists","generateCumulative","cumulative","groupedDataSets","cur","barDatasets","lineDatasets","barsConfigs","barIndex","spaceRatio","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","_this8","setCurrentDataPoint","_this10","_this11","getDataPoint","datasetValues","splice","DonutChart","Chart","frappe","NAME","VERSION","Charts"],"mappings":"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"} \ No newline at end of file diff --git a/src/js/charts/AxisChart.js b/src/js/charts/AxisChart.js index 56be818..9223f33 100644 --- a/src/js/charts/AxisChart.js +++ b/src/js/charts/AxisChart.js @@ -380,7 +380,7 @@ export default class AxisChart extends BaseChart { componentConfigs.push([ 'yAxis', { - mode: this.config.yAxisMode, + mode: yAxis.yAxisMode || 'span', width: this.width, height: this.baseHeight, shortenNumbers: this.config.shortenYAxisNumbers,