Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.
 
 
 

2 rader
57 KiB

  1. var Chart=function(){"use strict";function t(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function e(e,i,a,n,r,s){var o=t.createSVG("line",{x1:0,x2:0,y1:0,y2:e}),l=t.createSVG("text",{className:n,x:0,y:i,dy:".71em",innerHTML:a}),c=t.createSVG("g",{className:"tick "+r,transform:"translate("+s+", 0)"});return c.appendChild(o),c.appendChild(l),c}function i(e,i,a,n,r,s,o){var l=arguments.length>7&&void 0!==arguments[7]&&arguments[7],c=arguments.length>8&&void 0!==arguments[8]?arguments[8]:"",h=t.createSVG("line",{className:"dashed"===c?"dashed":"",x1:e,x2:i,y1:0,y2:0}),u=t.createSVG("text",{className:r,x:a,y:0,dy:".32em",innerHTML:n+""}),p=t.createSVG("g",{className:"tick "+s,transform:"translate(0, "+o+")","stroke-opacity":1});return l&&(h.style.stroke="rgba(27, 31, 35, 0.6)"),p.appendChild(h),p.appendChild(u),p}function a(t,e,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"linear",n=arguments.length>4&&void 0!==arguments[4]?arguments[4]:void 0,r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},s=t.cloneNode(!0),o=t.cloneNode(!0);for(var l in e){var c=void 0;c="transform"===l?document.createElementNS("http://www.w3.org/2000/svg","animateTransform"):document.createElementNS("http://www.w3.org/2000/svg","animate");var h=r[l]||t.getAttribute(l),u=e[l],p={attributeName:l,from:h,to:u,begin:"0s",dur:i/1e3+"s",values:h+";"+u,keySplines:L[a],keyTimes:"0;1",calcMode:"spline",fill:"freeze"};n&&(p.type=n);for(var _ in p)c.setAttribute(_,p[_]);s.appendChild(c),n?o.setAttribute(l,"translate("+u+")"):o.setAttribute(l,u)}return[s,o]}function n(t,e){t.style.transform=e,t.style.webkitTransform=e,t.style.msTransform=e,t.style.mozTransform=e,t.style.oTransform=e}function r(t,e){var i=[],n=[];e.map(function(t){var e=t[0],r=e.unit.parentNode,s=void 0,o=void 0;t[0]=e.unit;var l=a.apply(void 0,P(t)),c=T(l,2);s=c[0],o=c[1],i.push(o),n.push([s,r]),r.replaceChild(s,e.unit),e.array?e.array[e.index]=o:e.object[e.key]=o});var r=t.cloneNode(!0);return n.map(function(t,a){t[1].replaceChild(i[a],t[0]),e[a][0]=i[a]}),r}function s(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 o(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=Math.ceil(t),a=Math.floor(e),n=i-a,r=n,s=1;n>5&&(n%2!=0&&(n=++i-a),r=n/2,s=2),n<=2&&(s=n/(r=4)),0===n&&(r=5,s=1);for(var o=[],l=0;l<=r;l++)o.push(a+s*l);return o}function l(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=s(t),a=T(i,2),n=a[0],r=a[1],l=e?e/Math.pow(10,r):0,c=o(n=n.toFixed(6),l);return c=c.map(function(t){return t*Math.pow(10,r)})}function c(t){function e(t,e){for(var i=l(t),a=i[1]-i[0],n=0,r=1;n<e;r++)n+=a,i.unshift(-1*n);return i}var i=arguments.length>1&&void 0!==arguments[1]&&arguments[1],a=Math.max.apply(Math,P(t)),n=Math.min.apply(Math,P(t)),r=[];if(a>=0&&n>=0)s(a)[1],r=i?l(a,n):l(a);else if(a>0&&n<0){var o=Math.abs(n);a>=o?(s(a)[1],r=e(a,o)):(s(o)[1],r=e(o,a).map(function(t){return-1*t}))}else if(a<=0&&n<=0){var c=Math.abs(n),h=Math.abs(a);s(c)[1],r=(r=i?l(c,h):l(c)).reverse().map(function(t){return-1*t})}return r}function h(t,e){for(var i=Math.max.apply(Math,P(t)),a=1/(e-1),n=[],r=0;r<e;r++){var s=i*(a*r);n.push(s)}return n}function u(t,e){return e.filter(function(e){return e<t}).length}function p(t){return parseFloat(t.toFixed(2))}function _(t,e){if(t.length!==e.length)return!1;var i=!0;return t.map(function(t,a){e[a]!==t&&(i=!1)}),i}function d(t,e){return(t+"").length*e}function f(t){return t>255?255:t<0?0:t}function v(t,e){var i=!1;"#"==t[0]&&(t=t.slice(1),i=!0);var a=parseInt(t,16),n=f((a>>16)+e),r=f((a>>8&255)+e),s=f((255&a)+e);return(i?"#":"")+(s|r<<8|n<<16).toString(16)}function g(t){return/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(t)}function m(t){var e=new Date(t);return e.setMinutes(e.getMinutes()-e.getTimezoneOffset()),e}function y(t){var e=t.getDate(),i=t.getMonth()+1;return[(e>9?"":"0")+e,(i>9?"":"0")+i,t.getFullYear()].join("-")}function x(t,e){return Math.ceil(b(t,e)/7)}function b(t,e){return(m(e)-m(t))/864e5}function k(t,e){t.setDate(t.getDate()+e)}function w(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"line",e=arguments[1];return R[t]?new R[t](e):new D(e)}!function(t,e){if("undefined"==typeof document)return e;t=t||"";var i=document.head||document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css",i.appendChild(a),a.styleSheet?a.styleSheet.cssText=t:a.appendChild(document.createTextNode(t))}('.chart-container{font-family:Roboto,Geneva,Tahoma,sans-serif}.chart-container .graph-focus-margin{margin:0 5%}.chart-container>.title{margin-top:25px;margin-left:25px;text-align:left;font-weight:400;font-size:12px;color:#6c7680}.chart-container .graphics{margin-top:10px;padding-top:10px;padding-bottom:10px;position:relative}.chart-container .graph-stats-group{-ms-flex-pack:distribute;-webkit-box-flex:1;-ms-flex:1;flex:1}.chart-container .graph-stats-container,.chart-container .graph-stats-group{display:-webkit-box;display:-ms-flexbox;display:flex;justify-content:space-around}.chart-container .graph-stats-container{-ms-flex-pack:distribute;padding-top:10px}.chart-container .graph-stats-container .stats{padding-bottom:15px}.chart-container .graph-stats-container .stats-title{color:#8d99a6}.chart-container .graph-stats-container .stats-value{font-size:20px;font-weight:300}.chart-container .graph-stats-container .stats-description{font-size:12px;color:#8d99a6}.chart-container .graph-stats-container .graph-data .stats-value{color:#98d85b}.chart-container .axis,.chart-container .chart-label{font-size:11px;fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .percentage-graph .progress{margin-bottom:0}.chart-container .data-points circle{stroke:#fff;stroke-width:2}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .tick.x-axis-label{display:block}.chart-container .tick .specific-value{text-anchor:start}.chart-container .tick .y-value-text{text-anchor:end}.chart-container .tick .x-value-text{text-anchor:middle}.chart-container .progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f5f5f5;border-radius:4px;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,.1);box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.chart-container .progress-bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;background-color:#36414c;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);-webkit-transition:width .6s ease;transition:width .6s ease}.chart-container .graph-svg-tip{position:absolute;z-index:1;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.chart-container .graph-svg-tip ol,.chart-container .graph-svg-tip ul{padding-left:0;display:-webkit-box;display:-ms-flexbox;display:flex}.chart-container .graph-svg-tip ul.data-point-list li{min-width:90px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-weight:600}.chart-container .graph-svg-tip strong{color:#dfe2e5;font-weight:600}.chart-container .graph-svg-tip .svg-pointer{position:absolute;bottom:-10px;left:50%;width:5px;height:5px;margin:0 0 0 -5px;content:" ";border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.chart-container .graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.chart-container .graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.chart-container .graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.chart-container .graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}.chart-container .indicator,.chart-container .indicator-right{background:none;font-size:12px;vertical-align:middle;font-weight:700;color:#6c7680}.chart-container .indicator-right:after,.chart-container .indicator:before,.chart-container .indicator i{content:"";display:inline-block;height:8px;width:8px;border-radius:8px}.chart-container .indicator:before,.chart-container .indicator i{margin:0 4px 0 0}.chart-container .indicator-right:after{margin:0 0 0 4px}.chart-container .background.grey,.chart-container .indicator-right.grey:after,.chart-container .indicator.grey:before,.chart-container .indicator.grey i{background:#bdd3e6}.chart-container .background.light-grey,.chart-container .indicator-right.light-grey:after,.chart-container .indicator.light-grey:before,.chart-container .indicator.light-grey i{background:#f0f4f7}.chart-container .background.blue,.chart-container .indicator-right.blue:after,.chart-container .indicator.blue:before,.chart-container .indicator.blue i{background:#5e64ff}.chart-container .background.red,.chart-container .indicator-right.red:after,.chart-container .indicator.red:before,.chart-container .indicator.red i{background:#ff5858}.chart-container .background.green,.chart-container .indicator-right.green:after,.chart-container .indicator.green:before,.chart-container .indicator.green i{background:#28a745}.chart-container .background.light-green,.chart-container .indicator-right.light-green:after,.chart-container .indicator.light-green:before,.chart-container .indicator.light-green i{background:#98d85b}.chart-container .background.orange,.chart-container .indicator-right.orange:after,.chart-container .indicator.orange:before,.chart-container .indicator.orange i{background:#ffa00a}.chart-container .background.violet,.chart-container .indicator-right.violet:after,.chart-container .indicator.violet:before,.chart-container .indicator.violet i{background:#743ee2}.chart-container .background.dark-grey,.chart-container .indicator-right.dark-grey:after,.chart-container .indicator.dark-grey:before,.chart-container .indicator.dark-grey i{background:#b8c2cc}.chart-container .background.black,.chart-container .indicator-right.black:after,.chart-container .indicator.black:before,.chart-container .indicator.black i{background:#36414c}.chart-container .background.yellow,.chart-container .indicator-right.yellow:after,.chart-container .indicator.yellow:before,.chart-container .indicator.yellow i{background:#feef72}.chart-container .background.light-blue,.chart-container .indicator-right.light-blue:after,.chart-container .indicator.light-blue:before,.chart-container .indicator.light-blue i{background:#7cd6fd}.chart-container .background.purple,.chart-container .indicator-right.purple:after,.chart-container .indicator.purple:before,.chart-container .indicator.purple i{background:#b554ff}.chart-container .background.magenta,.chart-container .indicator-right.magenta:after,.chart-container .indicator.magenta:before,.chart-container .indicator.magenta i{background:#ffa3ef}.chart-container .stroke.grey{stroke:#bdd3e6}.chart-container .stroke.light-grey{stroke:#f0f4f7}.chart-container .stroke.blue{stroke:#5e64ff}.chart-container .stroke.red{stroke:#ff5858}.chart-container .stroke.light-green{stroke:#98d85b}.chart-container .stroke.green{stroke:#28a745}.chart-container .stroke.orange{stroke:#ffa00a}.chart-container .stroke.violet{stroke:#743ee2}.chart-container .stroke.dark-grey{stroke:#b8c2cc}.chart-container .stroke.black{stroke:#36414c}.chart-container .stroke.yellow{stroke:#feef72}.chart-container .stroke.light-blue{stroke:#7cd6fd}.chart-container .stroke.purple{stroke:#b554ff}.chart-container .stroke.magenta{stroke:#ffa3ef}.chart-container .fill.grey{fill:#bdd3e6}.chart-container .fill.light-grey{fill:#f0f4f7}.chart-container .fill.blue{fill:#5e64ff}.chart-container .fill.red{fill:#ff5858}.chart-container .fill.light-green{fill:#98d85b}.chart-container .fill.green{fill:#28a745}.chart-container .fill.orange{fill:#ffa00a}.chart-container .fill.violet{fill:#743ee2}.chart-container .fill.dark-grey{fill:#b8c2cc}.chart-container .fill.black{fill:#36414c}.chart-container .fill.yellow{fill:#feef72}.chart-container .fill.light-blue{fill:#7cd6fd}.chart-container .fill.purple{fill:#b554ff}.chart-container .fill.magenta{fill:#ffa3ef}.chart-container .border-top.grey{border-top:3px solid #bdd3e6}.chart-container .border-top.light-grey{border-top:3px solid #f0f4f7}.chart-container .border-top.blue{border-top:3px solid #5e64ff}.chart-container .border-top.red{border-top:3px solid #ff5858}.chart-container .border-top.light-green{border-top:3px solid #98d85b}.chart-container .border-top.green{border-top:3px solid #28a745}.chart-container .border-top.orange{border-top:3px solid #ffa00a}.chart-container .border-top.violet{border-top:3px solid #743ee2}.chart-container .border-top.dark-grey{border-top:3px solid #b8c2cc}.chart-container .border-top.black{border-top:3px solid #36414c}.chart-container .border-top.yellow{border-top:3px solid #feef72}.chart-container .border-top.light-blue{border-top:3px solid #7cd6fd}.chart-container .border-top.purple{border-top:3px solid #b554ff}.chart-container .border-top.magenta{border-top:3px solid #ffa3ef}.chart-container .stop-color.grey{stop-color:#bdd3e6}.chart-container .stop-color.light-grey{stop-color:#f0f4f7}.chart-container .stop-color.blue{stop-color:#5e64ff}.chart-container .stop-color.red{stop-color:#ff5858}.chart-container .stop-color.light-green{stop-color:#98d85b}.chart-container .stop-color.green{stop-color:#28a745}.chart-container .stop-color.orange{stop-color:#ffa00a}.chart-container .stop-color.violet{stop-color:#743ee2}.chart-container .stop-color.dark-grey{stop-color:#b8c2cc}.chart-container .stop-color.black{stop-color:#36414c}.chart-container .stop-color.yellow{stop-color:#feef72}.chart-container .stop-color.light-blue{stop-color:#7cd6fd}.chart-container .stop-color.purple{stop-color:#b554ff}.chart-container .stop-color.magenta{stop-color:#ffa3ef}',void 0);var S="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},N=(function(){function t(t){this.value=t}function e(e){function i(n,r){try{var s=e[n](r),o=s.value;o instanceof t?Promise.resolve(o.value).then(function(t){i("next",t)},function(t){i("throw",t)}):a(s.done?"return":"normal",s.value)}catch(t){a("throw",t)}}function a(t,e){switch(t){case"return":n.resolve({value:e,done:!0});break;case"throw":n.reject(e);break;default:n.resolve({value:e,done:!1})}(n=n.next)?i(n.key,n.arg):r=null}var n,r;this._invoke=function(t,e){return new Promise(function(a,s){var o={key:t,arg:e,resolve:a,reject:s,next:null};r?r=r.next=o:(n=r=o,i(t,e))})},"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")}),M=function(){function t(t,e){for(var i=0;i<e.length;i++){var a=e[i];a.enumerable=a.enumerable||!1,a.configurable=!0,"value"in a&&(a.writable=!0),Object.defineProperty(t,a.key,a)}}return function(e,i,a){return i&&t(e.prototype,i),a&&t(e,a),e}}(),A=function t(e,i,a){null===e&&(e=Function.prototype);var n=Object.getOwnPropertyDescriptor(e,i);if(void 0===n){var r=Object.getPrototypeOf(e);return null===r?void 0:t(r,i,a)}if("value"in n)return n.value;var s=n.get;if(void 0!==s)return s.call(a)},C=function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)},O=function(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e},T=function(){function t(t,e){var i=[],a=!0,n=!1,r=void 0;try{for(var s,o=t[Symbol.iterator]();!(a=(s=o.next()).done)&&(i.push(s.value),!e||i.length!==e);a=!0);}catch(t){n=!0,r=t}finally{try{!a&&o.return&&o.return()}finally{if(n)throw r}}return i}return function(e,i){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return t(e,i);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),P=function(t){if(Array.isArray(t)){for(var e=0,i=Array(t.length);e<t.length;e++)i[e]=t[e];return i}return Array.from(t)};t.findNodeIndex=function(t){for(var e=0;t.previousSibling;)t=t.previousSibling,e++;return e},t.create=function(e,i){var a=document.createElement(e);for(var n in i){var r=i[n];if("inside"===n)t(r).appendChild(a);else if("around"===n){var s=t(r);s.parentNode.insertBefore(a,s),a.appendChild(s)}else"styles"===n?"object"===(void 0===r?"undefined":S(r))&&Object.keys(r).map(function(t){a.style[t]=r[t]}):n in a?a[n]=r:a.setAttribute(n,r)}return a},t.createSVG=function(e,i){var a=document.createElementNS("http://www.w3.org/2000/svg",e);for(var n in i){var r=i[n];if("inside"===n)t(r).appendChild(a);else if("around"===n){var s=t(r);s.parentNode.insertBefore(a,s),a.appendChild(s)}else"className"===n&&(n="class"),"innerHTML"===n?a.textContent=r:a.setAttribute(n,r)}return a},t.offset=function(t){var e=t.getBoundingClientRect();return{top:e.top+(document.documentElement.scrollTop||document.body.scrollTop),left:e.left+(document.documentElement.scrollLeft||document.body.scrollLeft)}},t.isElementInViewport=function(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)},t.bind=function(t,e){if(t)for(var i in e){var a=e[i];i.split(/\s+/).forEach(function(e){t.addEventListener(e,a)})}},t.unbind=function(t,e){if(t)for(var i in e){var a=e[i];i.split(/\s+/).forEach(function(e){t.removeEventListener(e,a)})}},t.fire=function(t,e,i){var a=document.createEvent("HTMLEvents");a.initEvent(e,!0,!0);for(var n in i)a[n]=i[n];return t.dispatchEvent(a)};var z=function(){function e(t,e,i){var a=void 0,n=void 0;return t<=e?(n=t,0===(a=e-t)&&(n-=a=.01*i)):(n=e,0===(a=t-e)&&(a=.01*i)),[a,n]}var i=function(t,e,i){this.total_height=t,this.zero_line=e,this.avg_unit_width=i};return i.prototype={draw_bar:function(i,a,n,r,s,o,l){var c=this.avg_unit_width-n.space_width,h=c/l,u=i-c/2+h*o,p=e(a,this.zero_line,this.total_height),_=T(p,2),d=_[0],f=_[1];return t.createSVG("rect",{className:"bar mini fill "+r,"data-point-index":s,x:u,y:f,width:h,height:d})},draw_dot:function(e,i,a,n,r){return t.createSVG("circle",{className:"fill "+n,"data-point-index":r,cx:e,cy:i,r:a.radius})},animate_bar:function(t,i,a,n,r){var s=i-this.avg_unit_width/4,o=this.avg_unit_width/2/r,l=e(a,this.zero_line,this.total_height),c=T(l,2);return i=s+o*n,[t,{width:o,height:c[0],x:i,y:c[1]},350,"easein"]},animate_dot:function(t,e,i){return[t,{cx:e,cy:i},350,"easein"]}},i}(),L={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"},j=function(){function e(t){var i=t.parent,a=void 0===i?null:i;N(this,e),this.parent=a,this.title_name="",this.title_value="",this.list_values=[],this.title_value_first=0,this.x=0,this.y=0,this.top=0,this.left=0,this.setup()}return M(e,[{key:"setup",value:function(){this.make_tooltip()}},{key:"refresh",value:function(){this.fill(),this.calc_position()}},{key:"make_tooltip",value:function(){var e=this;this.container=t.create("div",{inside:this.parent,className:"graph-svg-tip comparison",innerHTML:'<span class="title"></span>\n\t\t\t\t<ul class="data-point-list"></ul>\n\t\t\t\t<div class="svg-pointer"></div>'}),this.hide_tip(),this.title=this.container.querySelector(".title"),this.data_point_list=this.container.querySelector(".data-point-list"),this.parent.addEventListener("mouseleave",function(){e.hide_tip()})}},{key:"fill",value:function(){var e=this,i=void 0;i=this.title_value_first?"<strong>"+this.title_value+"</strong>"+this.title_name:this.title_name+"<strong>"+this.title_value+"</strong>",this.title.innerHTML=i,this.data_point_list.innerHTML="",this.list_values.map(function(i){var a=t.create("li",{className:"border-top "+(i.color||"black"),innerHTML:'<strong style="display: block;">'+(0===i.value||i.value?i.value:"")+"</strong>\n\t\t\t\t\t"+(i.title?i.title:"")});e.data_point_list.appendChild(a)})}},{key:"calc_position",value:function(){var t=this.container.offsetWidth;this.top=this.y-this.container.offsetHeight,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 a="calc(50% + "+(this.left-e)+"px)";i.style.left=a,this.left=e}else i.style.left="50%"}},{key:"set_values",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"",a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"",n=arguments.length>4&&void 0!==arguments[4]?arguments[4]:[],r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0;this.title_name=i,this.title_value=a,this.list_values=n,this.x=t,this.y=e,this.title_value_first=r,this.refresh()}},{key:"hide_tip",value:function(){this.container.style.top="0px",this.container.style.left="0px",this.container.style.opacity="0"}},{key:"show_tip",value:function(){this.container.style.top=this.top+"px",this.container.style.left=this.left+"px",this.container.style.opacity="1"}}]),e}(),E=function(){function e(t){var i=t.height,a=void 0===i?240:i,n=t.title,r=void 0===n?"":n,s=t.subtitle,o=void 0===s?"":s,l=t.colors,c=void 0===l?[]:l,h=t.summary,u=void 0===h?[]:h,p=t.is_navigable,_=void 0===p?0:p,d=t.has_legend,f=void 0===d?0:d,v=(t.type,t.parent),g=t.data;N(this,e),this.raw_chart_args=arguments[0],this.parent="string"==typeof v?document.querySelector(v):v,this.title=r,this.subtitle=o,this.data=g,this.specific_values=g.specific_values||[],this.summary=u,this.is_navigable=_,this.is_navigable&&(this.current_index=0),this.has_legend=f,this.colors=c,(!this.colors||this.data.labels&&this.colors.length<this.data.labels.length)&&(this.colors=["light-blue","blue","violet","red","orange","yellow","green","light-green","purple","magenta"]),this.chart_types=["line","scatter","bar","percentage","heatmap","pie"],this.set_margins(a)}return M(e,[{key:"get_different_chart",value:function(t){if(this.chart_types.includes(t)||console.error("'"+t+"' is not a valid chart type."),t!==this.type){return{bar:["line","scatter","percentage","pie"],line:["scatter","bar","percentage","pie"],pie:["line","scatter","percentage","bar"],scatter:["line","bar","percentage","pie"],percentage:["bar","line","scatter","pie"],heatmap:[]}[this.type].includes(t)||console.error("'"+this.type+"' chart cannot be converted to a '"+t+"' chart."),new W({parent:this.raw_chart_args.parent,title:this.title,data:this.raw_chart_args.data,type:t,height:this.raw_chart_args.height})}}},{key:"set_margins",value:function(t){this.base_height=t,this.height=t-40,this.translate_x=60,this.translate_y=10}},{key:"setup",value:function(){this.parent?(this.validate_and_prepare_data(),this.bind_window_events(),this.refresh(!0)):console.error("No parent element to render on was provided.")}},{key:"validate_and_prepare_data",value:function(){}},{key:"bind_window_events",value:function(){var t=this;window.addEventListener("resize",function(){return t.refresh()}),window.addEventListener("orientationchange",function(){return t.refresh()})}},{key:"refresh",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.setup_base_values(),this.set_width(),this.setup_container(),this.setup_components(),this.setup_values(),this.setup_utils(),this.make_graph_components(t),this.make_tooltip(),this.summary.length>0?this.show_custom_summary():this.show_summary(),this.is_navigable&&this.setup_navigation(t)}},{key:"set_width",value:function(){var t=0;this.specific_values.map(function(e){var i=d(e.title+"",8);i>t&&(t=i-40)}),this.base_width=this.parent.offsetWidth-t,this.width=this.base_width-2*this.translate_x}},{key:"setup_base_values",value:function(){}},{key:"setup_container",value:function(){this.container=t.create("div",{className:"chart-container",innerHTML:'<h6 class="title">'+this.title+'</h6>\n\t\t\t\t<h6 class="sub-title uppercase">'+this.subtitle+'</h6>\n\t\t\t\t<div class="frappe-chart graphics"></div>\n\t\t\t\t<div class="graph-stats-container"></div>'}),this.parent.innerHTML="",this.parent.appendChild(this.container),this.chart_wrapper=this.container.querySelector(".frappe-chart"),this.stats_wrapper=this.container.querySelector(".graph-stats-container"),this.make_chart_area(),this.make_draw_area()}},{key:"make_chart_area",value:function(){return this.svg=t.createSVG("svg",{className:"chart",inside:this.chart_wrapper,width:this.base_width,height:this.base_height}),this.svg_defs=t.createSVG("defs",{inside:this.svg}),this.svg}},{key:"make_draw_area",value:function(){this.draw_area=t.createSVG("g",{className:this.type+"-chart",inside:this.svg,transform:"translate("+this.translate_x+", "+this.translate_y+")"})}},{key:"setup_components",value:function(){}},{key:"make_tooltip",value:function(){this.tip=new j({parent:this.chart_wrapper}),this.bind_tooltip()}},{key:"show_summary",value:function(){}},{key:"show_custom_summary",value:function(){var e=this;this.summary.map(function(i){var a=t.create("div",{className:"stats",innerHTML:'<span class="indicator '+i.color+'">'+i.title+": "+i.value+"</span>"});e.stats_wrapper.appendChild(a)})}},{key:"setup_navigation",value:function(){var e=this,i=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.make_overlay(),i&&(this.bind_overlay(),document.addEventListener("keydown",function(i){t.isElementInViewport(e.chart_wrapper)&&("37"==(i=i||window.event).keyCode?e.on_left_arrow():"39"==i.keyCode?e.on_right_arrow():"38"==i.keyCode?e.on_up_arrow():"40"==i.keyCode?e.on_down_arrow():"13"==i.keyCode&&e.on_enter_key())}))}},{key:"make_overlay",value:function(){}},{key:"bind_overlay",value:function(){}},{key:"bind_units",value:function(){}},{key:"on_left_arrow",value:function(){}},{key:"on_right_arrow",value:function(){}},{key:"on_up_arrow",value:function(){}},{key:"on_down_arrow",value:function(){}},{key:"on_enter_key",value:function(){}},{key:"get_data_point",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.current_index,e={index:t},i=this.y[0];return["svg_units","y_tops","values"].map(function(a){var n=a.slice(0,a.length-1);e[n]=i[a][t]}),e.label=this.x[t],e}},{key:"update_current_data_point",value:function(e){(e=parseInt(e))<0&&(e=0),e>=this.x.length&&(e=this.x.length-1),e!==this.current_index&&(this.current_index=e,t.fire(this.parent,"data-select",this.get_data_point()))}},{key:"setup_utils",value:function(){}}]),e}(),V=function(a){function n(t){N(this,n);var e=O(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,t));return e.x=e.data.labels,e.y=e.data.datasets,e.is_series=t.is_series,e.format_tooltip_y=t.format_tooltip_y,e.format_tooltip_x=t.format_tooltip_x,e.zero_line=e.height,e.old_values={},e}return C(n,E),M(n,[{key:"setup_values",value:function(){this.data.datasets.map(function(t){t.values=t.values.map(function(t){return isNaN(t)?0:t})}),this.setup_x(),this.setup_y()}},{key:"setup_x",value:function(){var t=this;this.set_avg_unit_width_and_x_offset(),this.x_axis_positions&&(this.x_old_axis_positions=this.x_axis_positions.slice()),this.x_axis_positions=this.x.map(function(e,i){return p(t.x_offset+i*t.avg_unit_width)}),this.x_old_axis_positions||(this.x_old_axis_positions=this.x_axis_positions.slice())}},{key:"setup_y",value:function(){this.y_axis_values&&(this.y_old_axis_values=this.y_axis_values.slice());var t=this.get_all_y_values();this.y_sums&&this.y_sums.length>0&&(t=t.concat(this.y_sums)),this.y_axis_values=c(t,"line"===this.type),this.y_old_axis_values||(this.y_old_axis_values=this.y_axis_values.slice());var e=this.y_axis_values,i=e[e.length-1]-e[0];this.multiplier&&(this.old_multiplier=this.multiplier),this.multiplier=this.height/i,this.old_multiplier||(this.old_multiplier=this.multiplier);var a=e[1]-e[0],n=a*this.multiplier,r=void 0;r=e.indexOf(0)>=0?e.indexOf(0):e[0]>0?-1*e[0]/a:-1*e[e.length-1]/a+(e.length-1),this.zero_line&&(this.old_zero_line=this.zero_line),this.zero_line=this.height-r*n,this.old_zero_line||(this.old_zero_line=this.zero_line)}},{key:"setup_components",value:function(){A(n.prototype.__proto__||Object.getPrototypeOf(n.prototype),"setup_components",this).call(this),this.setup_marker_components(),this.setup_aggregation_components(),this.setup_graph_components()}},{key:"setup_marker_components",value:function(){this.y_axis_group=t.createSVG("g",{className:"y axis",inside:this.draw_area}),this.x_axis_group=t.createSVG("g",{className:"x axis",inside:this.draw_area}),this.specific_y_group=t.createSVG("g",{className:"specific axis",inside:this.draw_area})}},{key:"setup_aggregation_components",value:function(){this.sum_group=t.createSVG("g",{className:"data-points",inside:this.draw_area}),this.average_group=t.createSVG("g",{className:"chart-area",inside:this.draw_area})}},{key:"setup_graph_components",value:function(){var e=this;this.svg_units_groups=[],this.y.map(function(i,a){e.svg_units_groups[a]=t.createSVG("g",{className:"data-points data-points-"+a,inside:e.draw_area})})}},{key:"make_graph_components",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.make_y_axis(),this.make_x_axis(),this.draw_graph(t),this.make_y_specifics()}},{key:"make_x_axis",value:function(){var t=this,i=arguments.length>0&&void 0!==arguments[0]&&arguments[0],a=void 0,n=void 0,r=void 0,s="";if("span"===this.x_axis_mode?(a=-7,n=this.height+15,r=this.height+25):"tick"===this.x_axis_mode&&(a=this.height,n=6,r=9,s="x-axis-label"),this.x_axis_group.setAttribute("transform","translate(0,"+a+")"),i)this.make_anim_x_axis(n,r,s);else{var o=1.5*this.avg_unit_width,l=o/8;this.x_axis_group.textContent="",this.x.map(function(i,a){var c=d(i,8)+2;if(c>o)if(t.is_series){for(var h=1;c/h*2>o;)h++;if(a%h!=0)return}else i=i.slice(0,l-3)+" ...";t.x_axis_group.appendChild(e(n,r,i,"x-value-text",s,t.x_axis_positions[a]))})}}},{key:"make_y_axis",value:function(){var t=this;if(arguments.length>0&&void 0!==arguments[0]&&arguments[0])return this.make_anim_y_axis(),void this.make_anim_y_specifics();var e=this.get_y_axis_line_props(),a=T(e,4),n=a[0],r=a[1],s=a[2],o=a[3];this.y_axis_group.textContent="",this.y_axis_values.map(function(e,a){t.y_axis_group.appendChild(i(o,n,r,e,"y-value-text",s,t.zero_line-e*t.multiplier,0===e&&0!==a))})}},{key:"get_y_axis_line_props",value:function(){if(arguments.length>0&&void 0!==arguments[0]&&arguments[0])return[this.width,this.width+5,"specific-value",0];var t=void 0,e="",i=0;return"span"===this.y_axis_mode?(t=this.width+6,i=-6):"tick"===this.y_axis_mode&&(t=-6,e="y-axis-label"),[t,-9,e,i]}},{key:"draw_graph",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];!this.raw_chart_args.hasOwnProperty("init")||this.raw_chart_args.init?e?this.draw_new_graph_and_animate():this.y.map(function(e,i){e.svg_units=[],t.make_path&&t.make_path(e,i,t.x_axis_positions,e.y_tops,e.color||t.colors[i]),t.make_new_units(e,i)}):this.y.map(function(e,i){e.svg_units=[],t.make_path&&t.make_path(e,i,t.x_axis_positions,e.y_tops,e.color||t.colors[i]),t.make_new_units(e,i),t.calc_y_dependencies()})}},{key:"draw_new_graph_and_animate",value:function(){var t=this,e=[];this.y.map(function(i,a){i.y_tops=new Array(i.values.length).fill(t.zero_line),e.push({values:i.values}),i.svg_units=[],t.make_path&&t.make_path(i,a,t.x_axis_positions,i.y_tops,i.color||t.colors[a]),t.make_new_units(i,a)}),setTimeout(function(){t.update_values(e)},350)}},{key:"setup_navigation",value:function(t){var e=this;t?setTimeout(function(){A(n.prototype.__proto__||Object.getPrototypeOf(n.prototype),"setup_navigation",e).call(e,t)},500):A(n.prototype.__proto__||Object.getPrototypeOf(n.prototype),"setup_navigation",this).call(this,t)}},{key:"make_new_units",value:function(t,e){this.make_new_units_for_dataset(this.x_axis_positions,t.y_tops,t.color||this.colors[e],e,this.y.length)}},{key:"make_new_units_for_dataset",value:function(t,e,i,a,n,r,s,o){r||(r=this.svg_units_groups[a]),s||(s=this.y[a].svg_units),o||(o=this.unit_args),r.textContent="",s.length=0;var l=new z(this.height,this.zero_line,this.avg_unit_width);e.map(function(e,c){var h=l["draw_"+o.type](t[c],e,o.args,i,c,a,n);r.appendChild(h),s.push(h)}),this.is_navigable&&this.bind_units(s)}},{key:"make_y_specifics",value:function(){var t=this;this.specific_y_group.textContent="",this.specific_values.map(function(e){t.specific_y_group.appendChild(i(0,t.width,t.width+5,e.title.toUpperCase(),"specific-value","specific-value",t.zero_line-e.value*t.multiplier,!1,e.line_type))})}},{key:"bind_tooltip",value:function(){var e=this;this.chart_wrapper.addEventListener("mousemove",function(i){var a=t.offset(e.chart_wrapper),n=i.pageX-a.left-e.translate_x;i.pageY-a.top-e.translate_y<e.height+2*e.translate_y?e.map_tooltip_x_position_and_show(n):e.tip.hide_tip()})}},{key:"map_tooltip_x_position_and_show",value:function(t){var e=this;if(this.y_min_tops){var i=this.x;this.format_tooltip_x&&this.format_tooltip_x(this.x[0])&&(i=this.x.map(function(t){return e.format_tooltip_x(t)}));for(var a=this.format_tooltip_y&&this.format_tooltip_y(this.y[0].values[0]),n=this.x_axis_positions.length-1;n>=0;n--){var r=this.x_axis_positions[n];if(t>r-this.avg_unit_width/2){var s=r+this.translate_x,o=this.y_min_tops[n]+this.translate_y,l=i[n],c=this.y.map(function(t,i){return{title:t.title,value:a?e.format_tooltip_y(t.values[n]):t.values[n],color:t.color||e.colors[i]}});this.tip.set_values(s,o,l,"",c),this.tip.show_tip();break}}}}},{key:"show_sums",value:function(){var t=this;this.updating=!0,this.y_sums=new Array(this.x_axis_positions.length).fill(0),this.y.map(function(e){e.values.map(function(e,i){t.y_sums[i]+=e})}),this.update_values(),this.sum_units=[],this.make_new_units_for_dataset(this.x_axis_positions,this.y_sums.map(function(e){return p(t.zero_line-e*t.multiplier)}),"light-grey",0,1,this.sum_group,this.sum_units),this.updating=!1}},{key:"hide_sums",value:function(){this.updating||(this.y_sums=[],this.sum_group.textContent="",this.sum_units=[],this.update_values())}},{key:"show_averages",value:function(){var t=this;this.old_specific_values=this.specific_values.slice(),this.y.map(function(e,i){var a=0;e.values.map(function(t){a+=t});var n=a/e.values.length;t.specific_values.push({title:"AVG "+(i+1),line_type:"dashed",value:n,auto:1})}),this.update_values()}},{key:"hide_averages",value:function(){var t=this;this.old_specific_values=this.specific_values.slice();var e=[];this.specific_values.map(function(t,i){t.auto&&e.unshift(i)}),e.map(function(e){t.specific_values.splice(e,1)}),this.update_values()}},{key:"update_values",value:function(t,e){var i=this;e||(e=this.x),this.elements_to_animate=[],this.updating=!0,this.old_x_values=this.x.slice(),this.old_y_axis_tops=this.y.map(function(t){return t.y_tops.slice()}),this.old_y_values=this.y.map(function(t){return t.values}),this.no_of_extra_pts=e.length-this.x.length,t&&this.y.map(function(e,i){e.values=t[i].values}),e&&(this.x=e),this.setup_x(),this.setup_y(),_(this.x_old_axis_positions,this.x_axis_positions)||(this.make_x_axis(!0),setTimeout(function(){i.updating||i.make_x_axis()},350)),(!_(this.y_old_axis_values,this.y_axis_values)||this.old_specific_values&&!_(this.old_specific_values,this.specific_values))&&(this.make_y_axis(!0),setTimeout(function(){i.updating||(i.make_y_axis(),i.make_y_specifics())},350)),this.calc_y_dependencies(),this.animate_graphs(),this.run_animation(),this.updating=!1}},{key:"add_data_point",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.x.length,a=this.y.map(function(t){return{values:t.values}});a.map(function(e,a){e.values.splice(i,0,t[a])});var n=this.x.slice();n.splice(i,0,e),this.update_values(a,n)}},{key:"remove_data_point",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.x.length-1;if(!(this.x.length<3)){var e=this.y.map(function(t){return{values:t.values}});e.map(function(e){e.values.splice(t,1)});var i=this.x.slice();i.splice(t,1),this.update_values(e,i)}}},{key:"run_animation",value:function(){var t=this,e=r(this.svg,this.elements_to_animate);this.svg.parentNode==this.chart_wrapper&&(this.chart_wrapper.removeChild(this.svg),this.chart_wrapper.appendChild(e)),setTimeout(function(){e.parentNode==t.chart_wrapper&&(t.chart_wrapper.removeChild(e),t.chart_wrapper.appendChild(t.svg))},250)}},{key:"animate_graphs",value:function(){var t=this;this.y.map(function(e,i){var a=t.calc_old_and_new_postions(e,i),n=T(a,4),r=n[0],s=n[1],o=n[2],l=n[3];t.no_of_extra_pts>=0&&(t.make_path&&t.make_path(e,i,r,s,e.color||t.colors[i]),t.make_new_units_for_dataset(r,s,e.color||t.colors[i],i,t.y.length)),e.path&&t.animate_path(e,i,r,s,o,l),t.animate_units(e,i,r,s,o,l)}),setTimeout(function(){t.y.map(function(e,i){t.make_path&&t.make_path(e,i,t.x_axis_positions,e.y_tops,e.color||t.colors[i]),t.make_new_units(e,i)})},400)}},{key:"animate_path",value:function(t,e,i,a,n,r){var s=r.map(function(t,e){return n[e]+","+t}).join("L"),o=[{unit:t.path,object:t,key:"path"},{d:"M"+s},350,"easein"];if(this.elements_to_animate.push(o),t.region_path){var l="0,"+this.zero_line+"L",c="L"+this.width+","+this.zero_line,h=[{unit:t.region_path,object:t,key:"region_path"},{d:"M"+l+s+c},350,"easein"];this.elements_to_animate.push(h)}}},{key:"animate_units",value:function(t,e,i,a,n,r){var s=this,o=this.unit_args.type,l=new z(this.height,this.zero_line,this.avg_unit_width);t.svg_units.map(function(i,a){void 0!==n[a]&&void 0!==r[a]&&s.elements_to_animate.push(l["animate_"+o]({unit:i,array:t.svg_units,index:a},n[a],r[a],e,s.y.length))})}},{key:"calc_old_and_new_postions",value:function(t,e){var i=this.x_old_axis_positions.slice(),a=this.x_axis_positions.slice(),n=this.old_y_axis_tops[e].slice(),r=t.y_tops.slice(),s=i[i.length-1],o=n[n.length-1],l=a[a.length-1],c=r[r.length-1];if(this.no_of_extra_pts>=0){var h=new Array(Math.abs(this.no_of_extra_pts)).fill(s),u=new Array(Math.abs(this.no_of_extra_pts)).fill(o);i=i.concat(h),n=n.concat(u)}else{var p=new Array(Math.abs(this.no_of_extra_pts)).fill(l),_=new Array(Math.abs(this.no_of_extra_pts)).fill(c);a=a.concat(p),r=r.concat(_)}return[i,n,a,r]}},{key:"make_anim_x_axis",value:function(t,i,a){var n=this,r=this.x_old_axis_positions,s=this.x_axis_positions,o=this.old_x_values,l=this.x,c=r[r.length-1];this.x_axis_group.textContent="",this.make_new_axis_anim_lines(r,s,o,l,c,function(r,s,o){"string"==typeof o&&(o=parseInt(o.substring(0,o.length-1)));var l=e(t,i,r,"x-value-text",a,s);n.x_axis_group.appendChild(l),n.elements_to_animate&&n.elements_to_animate.push([{unit:l,array:[0],index:0},{transform:o+", 0"},350,"easein","translate",{transform:s+", 0"}])})}},{key:"make_anim_y_axis",value:function(){var t=this,e=this.y_old_axis_values.map(function(e){return t.zero_line-e*t.multiplier}),i=this.y_axis_values.map(function(e){return t.zero_line-e*t.multiplier}),a=this.y_old_axis_values,n=this.y_axis_values,r=e[e.length-1];this.y_axis_group.textContent="",this.make_new_axis_anim_lines(e,i,a,n,r,this.add_and_animate_y_line.bind(this),this.y_axis_group)}},{key:"make_anim_y_specifics",value:function(){var t=this;this.specific_y_group.textContent="",this.specific_values.map(function(e){t.add_and_animate_y_line(e.title,t.old_zero_line-e.value*t.old_multiplier,t.zero_line-e.value*t.multiplier,0,t.specific_y_group,e.line_type,!0)})}},{key:"make_new_axis_anim_lines",value:function(t,e,i,a,n,r,s){var o=void 0,l=void 0,c=a.length-i.length;if(c>0)o=e.slice(0,t.length),l=a.slice(0,i.length);else{var h=new Array(Math.abs(c)).fill("");l=a.concat(h);var u=new Array(Math.abs(c)).fill(n+"F");o=e.concat(u)}if(l.map(function(e,i){r(e,t[i],o[i],i,s)}),c>0){var p=a.slice(i.length),_=e.slice(t.length);p.map(function(t,e){r(t,n,_[e],e,s)})}}},{key:"add_and_animate_y_line",value:function(t,e,a,n,r,s){var o=arguments.length>6&&void 0!==arguments[6]&&arguments[6],l=!1;"string"==typeof a&&(a=parseInt(a.substring(0,a.length-1)),l=!0);var c={transform:"0, "+a},h={transform:"0, "+e};l&&(c["stroke-opacity"]=0);var u=this.get_y_axis_line_props(o),p=T(u,4),_=p[0],d=p[1],f=p[2],v=p[3],g=o?"specific-value":"y-value-text",m=i(v,_,d,t=o?(t+"").toUpperCase():t,g,f,e,0===t&&0!==n,s);r.appendChild(m),this.elements_to_animate&&this.elements_to_animate.push([{unit:m,array:[0],index:0},c,350,"easein","translate",h])}},{key:"set_avg_unit_width_and_x_offset",value:function(){this.avg_unit_width=this.width/(this.x.length-1),this.x_offset=0}},{key:"get_all_y_values",value:function(){var t=[];return this.y.map(function(e){t=t.concat(e.values)}),t.concat(this.specific_values.map(function(t){return t.value}))}},{key:"calc_y_dependencies",value:function(){var t=this;this.y_min_tops=new Array(this.x_axis_positions.length).fill(9999),this.y.map(function(e){e.y_tops=e.values.map(function(e){return p(t.zero_line-e*t.multiplier)}),e.y_tops.map(function(e,i){e<t.y_min_tops[i]&&(t.y_min_tops[i]=e)})})}}]),n}(),G=function(t){function e(t){N(this,e);var i=O(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t));return i.type="bar",i.x_axis_mode=t.x_axis_mode||"tick",i.y_axis_mode=t.y_axis_mode||"span",i.setup(),i}return C(e,V),M(e,[{key:"setup_values",value:function(){A(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"setup_values",this).call(this),this.x_offset=this.avg_unit_width,this.unit_args={type:"bar",args:{space_width:this.avg_unit_width/2}}}},{key:"make_overlay",value:function(){var t=this.x.length-1,e=this.y[0].svg_units[t];this.update_current_data_point(t),this.overlay&&this.overlay.parentNode.removeChild(this.overlay),this.overlay=e.cloneNode(),this.overlay.style.fill="#000000",this.overlay.style.opacity="0.4",this.draw_area.appendChild(this.overlay)}},{key:"bind_overlay",value:function(){var t=this;this.parent.addEventListener("data-select",function(e){t.update_overlay(e.svg_unit)})}},{key:"bind_units",value:function(t){var e=this;t.map(function(t){t.addEventListener("click",function(){var i=t.getAttribute("data-point-index");e.update_current_data_point(i)})})}},{key:"update_overlay",value:function(t){var e=this,i=[];Object.keys(t.attributes).map(function(e){i.push(t.attributes[e])}),i.filter(function(t){return t.specified}).map(function(t){e.overlay.setAttribute(t.name,t.nodeValue)})}},{key:"on_left_arrow",value:function(){this.update_current_data_point(this.current_index-1)}},{key:"on_right_arrow",value:function(){this.update_current_data_point(this.current_index+1)}},{key:"set_avg_unit_width_and_x_offset",value:function(){this.avg_unit_width=this.width/(this.x.length+1),this.x_offset=this.avg_unit_width}}]),e}(),D=function(e){function i(t){N(this,i);var e=O(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t));return e.x_axis_mode=t.x_axis_mode||"span",e.y_axis_mode=t.y_axis_mode||"span",t.hasOwnProperty("show_dots")?e.show_dots=t.show_dots:e.show_dots=1,e.region_fill=t.region_fill,Object.getPrototypeOf(e)!==i.prototype?O(e):(e.dot_radius=t.dot_radius||4,e.heatline=t.heatline,e.type="line",e.setup(),e)}return C(i,V),M(i,[{key:"setup_graph_components",value:function(){this.setup_path_groups(),A(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"setup_graph_components",this).call(this)}},{key:"setup_path_groups",value:function(){var e=this;this.paths_groups=[],this.y.map(function(i,a){e.paths_groups[a]=t.createSVG("g",{className:"path-group path-group-"+a,inside:e.draw_area})})}},{key:"setup_values",value:function(){A(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"setup_values",this).call(this),this.unit_args={type:"dot",args:{radius:this.dot_radius}}}},{key:"make_new_units_for_dataset",value:function(t,e,a,n,r,s,o,l){this.show_dots&&A(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"make_new_units_for_dataset",this).call(this,t,e,a,n,r,s,o,l)}},{key:"make_paths",value:function(){var t=this;this.y.map(function(e,i){t.make_path(e,i,t.x_axis_positions,e.y_tops,e.color||t.colors[i])})}},{key:"make_path",value:function(e,i,a,n,r){var s=n.map(function(t,e){return a[e]+","+t}).join("L");if(this.paths_groups[i].textContent="",e.path=t.createSVG("path",{inside:this.paths_groups[i],className:"stroke "+r,d:"M"+s}),this.heatline){var o=this.make_gradient(r);e.path.style.stroke="url(#"+o+")"}this.region_fill&&this.fill_region_for_dataset(e,i,r,s)}},{key:"fill_region_for_dataset",value:function(e,i,a,n){var r=this.make_gradient(a,!0);e.region_path=t.createSVG("path",{inside:this.paths_groups[i],className:"region-fill",d:"M0,"+this.zero_line+"L"+n+"L"+this.width+","+this.zero_line}),e.region_path.style.stroke="none",e.region_path.style.fill="url(#"+r+")"}},{key:"make_gradient",value:function(e){var i=arguments.length>1&&void 0!==arguments[1]&&arguments[1],a="path-fill-gradient-"+e,n=t.createSVG("linearGradient",{inside:this.svg_defs,id:a,x1:0,x2:0,y1:0,y2:1}),r=function(e,i,a,n){t.createSVG("stop",{className:"stop-color "+a,inside:e,offset:i,"stop-opacity":n})},s=[1,.6,.2];return i&&(s=[.4,.2,0]),r(n,"0%",e,s[0]),r(n,"50%",e,s[1]),r(n,"100%",e,s[2]),a}}]),i}(),F=function(t){function e(t){N(this,e);var i=O(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t));return i.type="scatter",t.dot_radius?i.dot_radius=t.dot_radius:i.dot_radius=8,i.setup(),i}return C(e,D),M(e,[{key:"setup_graph_components",value:function(){this.setup_path_groups(),A(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"setup_graph_components",this).call(this)}},{key:"setup_path_groups",value:function(){}},{key:"setup_values",value:function(){A(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"setup_values",this).call(this),this.unit_args={type:"dot",args:{radius:this.dot_radius}}}},{key:"make_paths",value:function(){}},{key:"make_path",value:function(){}}]),e}(),H=function(e){function i(t){N(this,i);var e=O(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t));return e.type="percentage",e.max_slices=10,e.max_legend_points=6,e.setup(),e}return C(i,E),M(i,[{key:"make_chart_area",value:function(){this.chart_wrapper.className+=" graph-focus-margin",this.chart_wrapper.style.marginTop="45px",this.stats_wrapper.className+=" graph-focus-margin",this.stats_wrapper.style.marginBottom="30px",this.stats_wrapper.style.paddingTop="0px"}},{key:"make_draw_area",value:function(){this.chart_div=t.create("div",{className:"div",inside:this.chart_wrapper}),this.chart=t.create("div",{className:"progress-chart",inside:this.chart_div})}},{key:"setup_components",value:function(){this.percentage_bar=t.create("div",{className:"progress",inside:this.chart})}},{key:"setup_values",value:function(){var t=this;this.slice_totals=[];var e=this.data.labels.map(function(e,i){var a=0;return t.data.datasets.map(function(t){a+=t.values[i]}),[a,e]}).filter(function(t){return t[0]>0}),i=e;if(e.length>this.max_slices){e.sort(function(t,e){return e[0]-t[0]}),i=e.slice(0,this.max_slices-1);var a=0;e.slice(this.max_slices-1).map(function(t){a+=t[0]}),i.push([a,"Rest"]),this.colors[this.max_slices-1]="grey"}this.labels=[],i.map(function(e){t.slice_totals.push(e[0]),t.labels.push(e[1])}),this.legend_totals=this.slice_totals.slice(0,this.max_legend_points)}},{key:"make_graph_components",value:function(){var e=this;this.grand_total=this.slice_totals.reduce(function(t,e){return t+e},0),this.slices=[],this.slice_totals.map(function(i,a){var n=t.create("div",{className:"progress-bar background "+e.colors[a],inside:e.percentage_bar,styles:{width:100*i/e.grand_total+"%"}});e.slices.push(n)})}},{key:"bind_tooltip",value:function(){var e=this;this.slices.map(function(i,a){i.addEventListener("mouseenter",function(){var n=t.offset(e.chart_wrapper),r=t.offset(i),s=r.left-n.left+i.offsetWidth/2,o=r.top-n.top-6,l=(e.formatted_labels&&e.formatted_labels.length>0?e.formatted_labels[a]:e.labels[a])+": ",c=(100*e.slice_totals[a]/e.grand_total).toFixed(1);e.tip.set_values(s,o,l,c+"%"),e.tip.show_tip()})})}},{key:"show_summary",value:function(){var e=this,i=this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels:this.labels;this.legend_totals.map(function(a,n){a&&(t.create("div",{className:"stats",inside:e.stats_wrapper}).innerHTML='<span class="indicator '+e.colors[n]+'">\n\t\t\t\t\t<span class="text-muted">'+i[n]+":</span>\n\t\t\t\t\t"+a+"\n\t\t\t\t</span>")})}}]),i}(),I=Math.PI/180,B=function(e){function i(t){N(this,i);var e=O(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t));return e.type="pie",e.elements_to_animate=null,e.hoverRadio=t.hoverRadio||.1,e.max_slices=10,e.max_legend_points=6,e.isAnimate=!1,e.colors=t.colors,e.startAngle=t.startAngle||0,e.clockWise=t.clockWise||!1,(!e.colors||e.colors.length<e.data.labels.length)&&(e.colors=["#7cd6fd","#5e64ff","#743ee2","#ff5858","#ffa00a","#FEEF72","#28a745","#98d85b","#b554ff","#ffa3ef"]),e.mouseMove=e.mouseMove.bind(e),e.mouseLeave=e.mouseLeave.bind(e),e.setup(),e}return C(i,E),M(i,[{key:"setup_values",value:function(){var t=this;this.centerX=this.width/2,this.centerY=this.height/2,this.radius=this.height>this.width?this.centerX:this.centerY,this.slice_totals=[];var e=this.data.labels.map(function(e,i){var a=0;return t.data.datasets.map(function(t){a+=t.values[i]}),[a,e]}).filter(function(t){return t[0]>0}),i=e;if(e.length>this.max_slices){e.sort(function(t,e){return e[0]-t[0]}),i=e.slice(0,this.max_slices-1);var a=0;e.slice(this.max_slices-1).map(function(t){a+=t[0]}),i.push([a,"Rest"]),this.colors[this.max_slices-1]="grey"}this.labels=[],i.map(function(e){t.slice_totals.push(e[0]),t.labels.push(e[1])}),this.legend_totals=this.slice_totals.slice(0,this.max_legend_points)}},{key:"makeArcPath",value:function(t,e){var i=this.centerX,a=this.centerY,n=this.radius,r=this.clockWise;return"M"+i+" "+a+" L"+(i+t.x)+" "+(a+t.y)+" A "+n+" "+n+" 0 0 "+(r?1:0)+" "+(i+e.x)+" "+(a+e.y)+" z"}},{key:"make_graph_components",value:function(e){var a=this,n=this.radius,r=this.clockWise;this.grand_total=this.slice_totals.reduce(function(t,e){return t+e},0);var s=this.slicesProperties||[];this.slices=[],this.elements_to_animate=[],this.slicesProperties=[];var o=180-this.startAngle;this.slice_totals.map(function(l,c){var h=o,u=l/a.grand_total*360,p=r?-u:u,_=o+=p,d=i.getPositionByAngle(h,n),f=i.getPositionByAngle(_,n),v=e&&s[c],g=void 0,m=void 0;e?(g=v?v.startPosition:d,m=v?v.endPosition:d):(g=d,m=f);var y=a.makeArcPath(g,m),x=t.createSVG("path",{inside:a.draw_area,className:"pie-path",style:"transition:transform .3s;",d:y,fill:a.colors[c]});a.slices.push(x),a.slicesProperties.push({startPosition:d,endPosition:f,value:l,total:a.grand_total,startAngle:h,endAngle:_,angle:p}),e&&a.elements_to_animate.push([{unit:x,array:a.slices,index:a.slices.length-1},{d:a.makeArcPath(d,f)},650,"easein",null,{d:y}])}),e&&this.run_animation()}},{key:"run_animation",value:function(){var t=this;if(this.elements_to_animate&&0!==this.elements_to_animate.length){var e=r(this.svg,this.elements_to_animate);this.svg.parentNode==this.chart_wrapper&&(this.chart_wrapper.removeChild(this.svg),this.chart_wrapper.appendChild(e)),setTimeout(function(){e.parentNode==t.chart_wrapper&&(t.chart_wrapper.removeChild(e),t.chart_wrapper.appendChild(t.svg))},650)}}},{key:"calTranslateByAngle",value:function(t){var e=this.radius,a=this.hoverRadio,n=i.getPositionByAngle(t.startAngle+t.angle/2,e);return"translate3d("+n.x*a+"px,"+n.y*a+"px,0)"}},{key:"hoverSlice",value:function(e,i,a,r){if(e)if(a){n(e,this.calTranslateByAngle(this.slicesProperties[i])),e.setAttribute("fill",v(this.colors[i],50));var s=t.offset(this.svg),o=r.pageX-s.left+10,l=r.pageY-s.top-10,c=(this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels[i]:this.labels[i])+": ",h=(100*this.slice_totals[i]/this.grand_total).toFixed(1);this.tip.set_values(o,l,c,h+"%"),this.tip.show_tip()}else n(e,"translate3d(0,0,0)"),this.tip.hide_tip(),e.setAttribute("fill",this.colors[i])}},{key:"mouseMove",value:function(t){for(var e=t.target,i=this.curActiveSliceIndex,a=this.curActiveSlice,n=0;n<this.slices.length;n++)if(e===this.slices[n]){this.hoverSlice(a,i,!1),this.curActiveSlice=e,this.curActiveSliceIndex=n,this.hoverSlice(e,n,!0,t);break}}},{key:"mouseLeave",value:function(){this.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,!1)}},{key:"bind_tooltip",value:function(){this.draw_area.addEventListener("mousemove",this.mouseMove),this.draw_area.addEventListener("mouseleave",this.mouseLeave)}},{key:"show_summary",value:function(){var e=this,i=this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels:this.labels;this.legend_totals.map(function(a,n){a&&(t.create("div",{className:"stats",inside:e.stats_wrapper}).innerHTML='<span class="indicator">\n\t\t\t\t\t<i style="background-color:'+e.colors[n]+';"></i>\n\t\t\t\t\t<span class="text-muted">'+i[n]+":</span>\n\t\t\t\t\t"+a+"\n\t\t\t\t</span>")})}}],[{key:"getPositionByAngle",value:function(t,e){return{x:Math.sin(t*I)*e,y:Math.cos(t*I)*e}}}]),i}(),q=function(e){function i(t){var e=t.start,a=void 0===e?"":e,n=t.domain,r=void 0===n?"":n,s=t.subdomain,o=void 0===s?"":s,l=t.data,c=void 0===l?{}:l,h=t.discrete_domains,u=void 0===h?0:h,p=t.count_label,_=void 0===p?"":p,d=t.legend_colors,f=void 0===d?[]:d;N(this,i);var v=O(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,arguments[0]));v.type="heatmap",v.domain=r,v.subdomain=o,v.data=c,v.discrete_domains=u,v.count_label=_;var g=new Date;return v.start=a||k(g,365),f=f.slice(0,5),v.legend_colors=v.validate_colors(f)?f:["#ebedf0","#c6e48b","#7bc96f","#239a3b","#196127"],v.distribution_size=5,v.translate_x=0,v.setup(),v}return C(i,E),M(i,[{key:"validate_colors",value:function(t){if(t.length<5)return 0;var e=1;return t.forEach(function(t){g(t)||(e=0,console.warn('"'+t+'" is not a valid color.'))},this),e}},{key:"setup_base_values",value:function(){this.today=new Date,this.start||(this.start=new Date,this.start.setFullYear(this.start.getFullYear()-1)),this.first_week_start=new Date(this.start.toDateString()),this.last_week_start=new Date(this.today.toDateString()),7!==this.first_week_start.getDay()&&k(this.first_week_start,-1*this.first_week_start.getDay()),7!==this.last_week_start.getDay()&&k(this.last_week_start,-1*this.last_week_start.getDay()),this.no_of_cols=x(this.first_week_start+"",this.last_week_start+"")+1}},{key:"set_width",value:function(){this.base_width=12*(this.no_of_cols+3),this.discrete_domains&&(this.base_width+=144)}},{key:"setup_components",value:function(){this.domain_label_group=t.createSVG("g",{className:"domain-label-group chart-label",inside:this.draw_area}),this.data_groups=t.createSVG("g",{className:"data-groups",inside:this.draw_area,transform:"translate(0, 20)"})}},{key:"setup_values",value:function(){var t=this;this.domain_label_group.textContent="",this.data_groups.textContent="";var e=Object.keys(this.data).map(function(e){return t.data[e]});this.distribution=h(e,this.distribution_size),this.month_names=["January","February","March","April","May","June","July","August","September","October","November","December"],this.render_all_weeks_and_store_x_values(this.no_of_cols)}},{key:"render_all_weeks_and_store_x_values",value:function(t){var e=new Date(this.first_week_start);this.week_col=0,this.current_month=e.getMonth(),this.months=[this.current_month+""],this.month_weeks={},this.month_start_points=[],this.month_weeks[this.current_month]=0,this.month_start_points.push(13);for(var i=0;i<t;i++){var a=void 0,n=0,r=new Date(e),s=this.get_week_squares_group(r,this.week_col),o=T(s,2);a=o[0],n=o[1],this.data_groups.appendChild(a),this.week_col+=1+parseInt(this.discrete_domains&&n),this.month_weeks[this.current_month]++,n&&(this.current_month=(this.current_month+1)%12,this.months.push(this.current_month+""),this.month_weeks[this.current_month]=1),k(e,7)}this.render_month_labels()}},{key:"get_week_squares_group",value:function(e,i){for(var a=this.today.getTime(),n=0,r=0,s=t.createSVG("g",{className:"data-group",inside:this.data_groups}),o=0,l=0;l<7;l+=1,o+=12){var c=0,h=0,p=e.getTime()/1e3,_=Math.floor(p-p%86400).toFixed(1);this.data[_]&&(c=this.data[_]),this.data[Math.round(_)]&&(c=this.data[Math.round(_)]),c&&(h=u(c,this.distribution));var d=13+12*(i+r);t.createSVG("rect",{className:"day",inside:s,x:d,y:o,width:10,height:10,fill:this.legend_colors[h],"data-date":y(e),"data-value":c,"data-day":e.getDay()});var f=new Date(e);if(k(f,1),f.getTime()>a)break;f.getMonth()-e.getMonth()&&(n=1,this.discrete_domains&&(r=1),this.month_start_points.push(13+12*(i+r))),e=f}return[s,n]}},{key:"render_month_labels",value:function(){var e=this;this.months.shift(),this.month_start_points.shift(),this.months.pop(),this.month_start_points.pop(),this.month_start_points.map(function(i,a){var n=e.month_names[e.months[a]].substring(0,3);t.createSVG("text",{className:"y-value-text",inside:e.domain_label_group,x:i+12,y:10,dy:".32em",innerHTML:n})})}},{key:"make_graph_components",value:function(){Array.prototype.slice.call(this.container.querySelectorAll(".graph-stats-container, .sub-title, .title")).map(function(t){t.style.display="None"}),this.chart_wrapper.style.marginTop="0px",this.chart_wrapper.style.paddingTop="0px"}},{key:"bind_tooltip",value:function(){var t=this;Array.prototype.slice.call(document.querySelectorAll(".data-group .day")).map(function(e){e.addEventListener("mouseenter",function(e){var i=e.target.getAttribute("data-value"),a=e.target.getAttribute("data-date").split("-"),n=t.month_names[parseInt(a[1])-1].substring(0,3),r=t.chart_wrapper.getBoundingClientRect(),s=e.target.getBoundingClientRect(),o=parseInt(e.target.getAttribute("width")),l=s.left-r.left+(o+2)/2,c=s.top-r.top-(o+2)/2,h=i+" "+t.count_label,u=" on "+n+" "+a[0]+", "+a[2];t.tip.set_values(l,c,u,h,[],1),t.tip.show_tip()})})}},{key:"update",value:function(t){this.data=t,this.setup_values(),this.bind_tooltip()}}]),i}(),R={line:D,bar:G,scatter:F,percentage:H,heatmap:q,pie:B},W=function t(e){return N(this,t),w(e.type,arguments[0])};return W}();