ng2-charts
Advanced tools
Comparing version 2.0.3 to 2.0.4
@@ -272,2 +272,11 @@ (function (global, factory) { | ||
*/ | ||
/** @enum {number} */ | ||
var UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
var BaseChartDirective = /** @class */ (function () { | ||
@@ -352,3 +361,10 @@ function BaseChartDirective(element, themeService) { | ||
/** @type {?} */ | ||
var updateRequired = false; | ||
var updateRequired_1 = UpdateType.Default; | ||
/** @type {?} */ | ||
var wantUpdate = ( /** | ||
* @param {?} x | ||
* @return {?} | ||
*/function (x) { | ||
updateRequired_1 = x > updateRequired_1 ? x : updateRequired_1; | ||
}); | ||
// Check if the changes are in the data or datasets or labels or legend | ||
@@ -362,7 +378,7 @@ if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) { | ||
} | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (changes.hasOwnProperty('labels')) { | ||
this.chart.data.labels = changes.labels.currentValue; | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
@@ -372,11 +388,15 @@ if (changes.hasOwnProperty('legend')) { | ||
this.chart.generateLegend(); | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (updateRequired) { | ||
// ... if so, update chart | ||
this.chart.update(); | ||
if (changes.hasOwnProperty('options')) { | ||
wantUpdate(UpdateType.Refresh); | ||
} | ||
else { | ||
// otherwise rebuild the chart | ||
this.refresh(); | ||
switch (( /** @type {?} */(updateRequired_1))) { | ||
case UpdateType.Update: | ||
this.update(); | ||
break; | ||
case UpdateType.Refresh: | ||
case UpdateType.Default: | ||
this.refresh(); | ||
break; | ||
} | ||
@@ -728,3 +748,3 @@ } | ||
if (!datasets) { | ||
throw new Error("ng-charts configuration error,\n data or datasets field are required to render char " + this.chartType); | ||
throw new Error("ng-charts configuration error,\n data or datasets field are required to render chart " + this.chartType); | ||
} | ||
@@ -731,0 +751,0 @@ return datasets; |
@@ -1,2 +0,2 @@ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("chart.js"),require("@angular/core"),require("rxjs"),require("lodash")):"function"==typeof define&&define.amd?define("ng2-charts",["exports","chart.js","@angular/core","rxjs","lodash"],e):e(t["ng2-charts"]={},t.chart_js,t.ng.core,t.rxjs,t._)}(this,function(t,i,r,e,s){"use strict";function o(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var n,a,o=r.call(t),i=[];try{for(;(void 0===e||0<e--)&&!(n=o.next()).done;)i.push(n.value)}catch(s){a={error:s}}finally{try{n&&!n.done&&(r=o["return"])&&r.call(o)}finally{if(a)throw a.error}}return i}var n=[[255,99,132],[54,162,235],[255,206,86],[231,233,237],[75,192,192],[151,187,205],[220,220,220],[247,70,74],[70,191,189],[253,180,92],[148,159,177],[77,83,96]];function c(t,e,r){if("pie"===t||"doughnut"===t)return u(d(r));if("polarArea"===t)return function n(t){return{backgroundColor:t.map(function(t){return h(t,.6)}),borderColor:t.map(function(t){return h(t,1)}),hoverBackgroundColor:t.map(function(t){return h(t,.8)}),hoverBorderColor:t.map(function(t){return h(t,1)})}}(d(r));if("line"===t||"radar"===t)return function a(t){return{backgroundColor:h(t,.4),borderColor:h(t,1),pointBackgroundColor:h(t,1),pointBorderColor:"#fff",pointHoverBackgroundColor:"#fff",pointHoverBorderColor:h(t,.8)}}(p(e));if("bar"===t||"horizontalBar"===t)return function o(t){return{backgroundColor:h(t,.6),borderColor:h(t,1),hoverBackgroundColor:h(t,.8),hoverBorderColor:h(t,1)}}(p(e));if("bubble"===t)return u(d(r));if("scatter"===t)return u(d(r));throw new Error("getColors - Unsupported chart type "+t)}function h(t,e){return"rgba("+t.concat(e).join(",")+")"}function a(t,e){return Math.floor(Math.random()*(e-t+1))+t}function u(t){return{backgroundColor:t.map(function(t){return h(t,.6)}),borderColor:t.map(function(){return"#fff"}),pointBackgroundColor:t.map(function(t){return h(t,1)}),pointBorderColor:t.map(function(){return"#fff"}),pointHoverBackgroundColor:t.map(function(t){return h(t,1)}),pointHoverBorderColor:t.map(function(t){return h(t,1)})}}function l(){return[a(0,255),a(0,255),a(0,255)]}function p(t){return n[t]||l()}function d(t){for(var e=new Array(t),r=0;r<t;r++)e[r]=n[r]||l();return e}var f=function(){function t(){this.pColorschemesOptions={},this.colorschemesOptions=new e.BehaviorSubject({})}return t.prototype.setColorschemesOptions=function(t){this.pColorschemesOptions=t,this.colorschemesOptions.next(t)},t.prototype.getColorschemesOptions=function(){return this.pColorschemesOptions},t.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],t.ctorParameters=function(){return[]},t.ngInjectableDef=r.defineInjectable({factory:function(){return new t},token:t,providedIn:"root"}),t}(),g=function(){function t(t,e){this.element=t,this.themeService=e,this.options={},this.chartClick=new r.EventEmitter,this.chartHover=new r.EventEmitter,this.initFlag=!1,this.subs=[]}return t.registerPlugin=function(t){i.Chart.plugins.register(t)},t.unregisterPlugin=function(t){i.Chart.plugins.unregister(t)},t.prototype.ngOnInit=function(){var e=this;this.ctx=this.element.nativeElement.getContext("2d"),this.initFlag=!0,(this.data||this.datasets)&&this.refresh(),this.subs.push(this.themeService.colorschemesOptions.subscribe(function(t){return e.themeChanged(t)}))},t.prototype.themeChanged=function(t){this.refresh()},t.prototype.ngOnChanges=function(t){if(this.initFlag){var e=!1;(t.hasOwnProperty("data")||t.hasOwnProperty("datasets"))&&(t.data?this.updateChartData(t.data.currentValue):this.updateChartData(t.datasets.currentValue),e=!0),t.hasOwnProperty("labels")&&(this.chart.data.labels=t.labels.currentValue,e=!0),t.hasOwnProperty("legend")&&(this.chart.config.options.legend.display=t.legend.currentValue,this.chart.generateLegend(),e=!0),e?this.chart.update():this.refresh()}},t.prototype.ngOnDestroy=function(){this.chart&&(this.chart.destroy(),this.chart=void 0),this.subs.forEach(function(t){return t.unsubscribe()})},t.prototype.update=function(t,e){return this.chart.update(t,e)},t.prototype.hideDataset=function(t,e){this.chart.getDatasetMeta(t).hidden=e,this.chart.update()},t.prototype.isDatasetHidden=function(t){return this.chart.getDatasetMeta(t).hidden},t.prototype.toBase64Image=function(){return this.chart.toBase64Image()},t.prototype.getChartBuilder=function(t){var r=this,e=this.getDatasets(),n=Object.assign({},this.options);!1===this.legend&&(n.legend={display:!1}),n.hover=n.hover||{},n.hover.onHover||(n.hover.onHover=function(t,e){e&&!e.length||r.chartHover.emit({event:t,active:e})}),n.onClick||(n.onClick=function(t,e){r.chartClick.emit({event:t,active:e})});var a=this.smartMerge(n,this.themeService.getColorschemesOptions()),o={type:this.chartType,data:{labels:this.labels,datasets:e},plugins:this.plugins,options:a};return new i.Chart(t,o)},t.prototype.smartMerge=function(r,n,a){var o=this;if(void 0===a&&(a=0),0===a&&(r=s.cloneDeep(r)),Object.keys(n).forEach(function(e){if(Array.isArray(n[e])){var t=r[e];t&&t.forEach(function(t){o.smartMerge(t,n[e][0],a+1)})}else"object"==typeof n[e]?(e in r||(r[e]={}),o.smartMerge(r[e],n[e],a+1)):r[e]=n[e]}),0===a)return r},t.prototype.isChartDataSetsArray=function(t){var e=t[0];return"object"==typeof e&&"data"in e},t.prototype.isMultiLineLabel=function(t){return Array.isArray(t)},t.prototype.joinLabel=function(t){return t?this.isMultiLineLabel(t)?t.join(" "):t:null},t.prototype.updateChartData=function(r){var n=this;this.isChartDataSetsArray(r)?r.length===this.chart.data.datasets.length?this.chart.data.datasets.forEach(function(t,e){t.data=r[e].data,r[e].label&&(t.label=r[e].label)}):this.chart.data.datasets=function a(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(o(arguments[e]));return t}(r):this.isSingleDataSet(r)?this.chart.data.datasets[0].data=r:r.length===this.chart.data.datasets.length?this.chart.data.datasets.forEach(function(t,e){t.data=r[e]}):this.chart.data.datasets=r.map(function(t,e){return{data:t,label:n.joinLabel(n.labels[e])||"Label "+e}}),this.chart.data.datasets.forEach(function(t,e){n.colors&&n.colors[e]?Object.assign(t,n.colors[e]):Object.assign(t,c(n.chartType,e,t.data.length))})},t.prototype.isSingleDataSet=function(t){return!Array.isArray(t[0])},t.prototype.getDatasets=function(){var n=this,t=void 0;if((!this.datasets||!this.datasets.length&&this.data&&this.data.length)&&(t=this.isSingleDataSet(this.data)?[{data:this.data,label:"Label 0"}]:this.data.map(function(t,e){return{data:t,label:n.joinLabel(n.labels[e])||"Label "+e}})),(this.datasets&&this.datasets.length||t&&t.length)&&(t=(this.datasets||t).map(function(t,e){var r=Object.assign({},t);return n.colors&&n.colors.length?Object.assign(r,n.colors[e]):Object.assign(r,c(n.chartType,e,r.data.length)),r})),!t)throw new Error("ng-charts configuration error,\n data or datasets field are required to render char "+this.chartType);return t},t.prototype.refresh=function(){this.chart&&(this.chart.destroy(),this.chart=void 0),this.chart=this.getChartBuilder(this.ctx)},t.decorators=[{type:r.Directive,args:[{selector:"canvas[baseChart]",exportAs:"base-chart"}]}],t.ctorParameters=function(){return[{type:r.ElementRef},{type:f}]},t.propDecorators={data:[{type:r.Input}],datasets:[{type:r.Input}],labels:[{type:r.Input}],options:[{type:r.Input}],chartType:[{type:r.Input}],colors:[{type:r.Input}],legend:[{type:r.Input}],plugins:[{type:r.Input}],chartClick:[{type:r.Output}],chartHover:[{type:r.Output}]},t}(),y=function(){function t(){}return t.decorators=[{type:r.NgModule,args:[{declarations:[g],imports:[],exports:[g]}]}],t}();t.ChartsModule=y,t.BaseChartDirective=g,t.defaultColors=n,t.ThemeService=f,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("chart.js"),require("@angular/core"),require("rxjs"),require("lodash")):"function"==typeof define&&define.amd?define("ng2-charts",["exports","chart.js","@angular/core","rxjs","lodash"],e):e(t["ng2-charts"]={},t.chart_js,t.ng.core,t.rxjs,t._)}(this,function(t,i,r,e,s){"use strict";function o(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var a,n,o=r.call(t),i=[];try{for(;(void 0===e||0<e--)&&!(a=o.next()).done;)i.push(a.value)}catch(s){n={error:s}}finally{try{a&&!a.done&&(r=o["return"])&&r.call(o)}finally{if(n)throw n.error}}return i}var a=[[255,99,132],[54,162,235],[255,206,86],[231,233,237],[75,192,192],[151,187,205],[220,220,220],[247,70,74],[70,191,189],[253,180,92],[148,159,177],[77,83,96]];function c(t,e,r){if("pie"===t||"doughnut"===t)return u(d(r));if("polarArea"===t)return function a(t){return{backgroundColor:t.map(function(t){return h(t,.6)}),borderColor:t.map(function(t){return h(t,1)}),hoverBackgroundColor:t.map(function(t){return h(t,.8)}),hoverBorderColor:t.map(function(t){return h(t,1)})}}(d(r));if("line"===t||"radar"===t)return function n(t){return{backgroundColor:h(t,.4),borderColor:h(t,1),pointBackgroundColor:h(t,1),pointBorderColor:"#fff",pointHoverBackgroundColor:"#fff",pointHoverBorderColor:h(t,.8)}}(p(e));if("bar"===t||"horizontalBar"===t)return function o(t){return{backgroundColor:h(t,.6),borderColor:h(t,1),hoverBackgroundColor:h(t,.8),hoverBorderColor:h(t,1)}}(p(e));if("bubble"===t)return u(d(r));if("scatter"===t)return u(d(r));throw new Error("getColors - Unsupported chart type "+t)}function h(t,e){return"rgba("+t.concat(e).join(",")+")"}function n(t,e){return Math.floor(Math.random()*(e-t+1))+t}function u(t){return{backgroundColor:t.map(function(t){return h(t,.6)}),borderColor:t.map(function(){return"#fff"}),pointBackgroundColor:t.map(function(t){return h(t,1)}),pointBorderColor:t.map(function(){return"#fff"}),pointHoverBackgroundColor:t.map(function(t){return h(t,1)}),pointHoverBorderColor:t.map(function(t){return h(t,1)})}}function l(){return[n(0,255),n(0,255),n(0,255)]}function p(t){return a[t]||l()}function d(t){for(var e=new Array(t),r=0;r<t;r++)e[r]=a[r]||l();return e}var f=function(){function t(){this.pColorschemesOptions={},this.colorschemesOptions=new e.BehaviorSubject({})}return t.prototype.setColorschemesOptions=function(t){this.pColorschemesOptions=t,this.colorschemesOptions.next(t)},t.prototype.getColorschemesOptions=function(){return this.pColorschemesOptions},t.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],t.ctorParameters=function(){return[]},t.ngInjectableDef=r.defineInjectable({factory:function(){return new t},token:t,providedIn:"root"}),t}(),g={Default:0,Update:1,Refresh:2};g[g.Default]="Default",g[g.Update]="Update",g[g.Refresh]="Refresh";var y=function(){function t(t,e){this.element=t,this.themeService=e,this.options={},this.chartClick=new r.EventEmitter,this.chartHover=new r.EventEmitter,this.initFlag=!1,this.subs=[]}return t.registerPlugin=function(t){i.Chart.plugins.register(t)},t.unregisterPlugin=function(t){i.Chart.plugins.unregister(t)},t.prototype.ngOnInit=function(){var e=this;this.ctx=this.element.nativeElement.getContext("2d"),this.initFlag=!0,(this.data||this.datasets)&&this.refresh(),this.subs.push(this.themeService.colorschemesOptions.subscribe(function(t){return e.themeChanged(t)}))},t.prototype.themeChanged=function(t){this.refresh()},t.prototype.ngOnChanges=function(t){if(this.initFlag){var e=g.Default,r=function(t){e=e<t?t:e};switch((t.hasOwnProperty("data")||t.hasOwnProperty("datasets"))&&(t.data?this.updateChartData(t.data.currentValue):this.updateChartData(t.datasets.currentValue),r(g.Update)),t.hasOwnProperty("labels")&&(this.chart.data.labels=t.labels.currentValue,r(g.Update)),t.hasOwnProperty("legend")&&(this.chart.config.options.legend.display=t.legend.currentValue,this.chart.generateLegend(),r(g.Update)),t.hasOwnProperty("options")&&r(g.Refresh),e){case g.Update:this.update();break;case g.Refresh:case g.Default:this.refresh()}}},t.prototype.ngOnDestroy=function(){this.chart&&(this.chart.destroy(),this.chart=void 0),this.subs.forEach(function(t){return t.unsubscribe()})},t.prototype.update=function(t,e){return this.chart.update(t,e)},t.prototype.hideDataset=function(t,e){this.chart.getDatasetMeta(t).hidden=e,this.chart.update()},t.prototype.isDatasetHidden=function(t){return this.chart.getDatasetMeta(t).hidden},t.prototype.toBase64Image=function(){return this.chart.toBase64Image()},t.prototype.getChartBuilder=function(t){var r=this,e=this.getDatasets(),a=Object.assign({},this.options);!1===this.legend&&(a.legend={display:!1}),a.hover=a.hover||{},a.hover.onHover||(a.hover.onHover=function(t,e){e&&!e.length||r.chartHover.emit({event:t,active:e})}),a.onClick||(a.onClick=function(t,e){r.chartClick.emit({event:t,active:e})});var n=this.smartMerge(a,this.themeService.getColorschemesOptions()),o={type:this.chartType,data:{labels:this.labels,datasets:e},plugins:this.plugins,options:n};return new i.Chart(t,o)},t.prototype.smartMerge=function(r,a,n){var o=this;if(void 0===n&&(n=0),0===n&&(r=s.cloneDeep(r)),Object.keys(a).forEach(function(e){if(Array.isArray(a[e])){var t=r[e];t&&t.forEach(function(t){o.smartMerge(t,a[e][0],n+1)})}else"object"==typeof a[e]?(e in r||(r[e]={}),o.smartMerge(r[e],a[e],n+1)):r[e]=a[e]}),0===n)return r},t.prototype.isChartDataSetsArray=function(t){var e=t[0];return"object"==typeof e&&"data"in e},t.prototype.isMultiLineLabel=function(t){return Array.isArray(t)},t.prototype.joinLabel=function(t){return t?this.isMultiLineLabel(t)?t.join(" "):t:null},t.prototype.updateChartData=function(r){var a=this;this.isChartDataSetsArray(r)?r.length===this.chart.data.datasets.length?this.chart.data.datasets.forEach(function(t,e){t.data=r[e].data,r[e].label&&(t.label=r[e].label)}):this.chart.data.datasets=function n(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(o(arguments[e]));return t}(r):this.isSingleDataSet(r)?this.chart.data.datasets[0].data=r:r.length===this.chart.data.datasets.length?this.chart.data.datasets.forEach(function(t,e){t.data=r[e]}):this.chart.data.datasets=r.map(function(t,e){return{data:t,label:a.joinLabel(a.labels[e])||"Label "+e}}),this.chart.data.datasets.forEach(function(t,e){a.colors&&a.colors[e]?Object.assign(t,a.colors[e]):Object.assign(t,c(a.chartType,e,t.data.length))})},t.prototype.isSingleDataSet=function(t){return!Array.isArray(t[0])},t.prototype.getDatasets=function(){var a=this,t=void 0;if((!this.datasets||!this.datasets.length&&this.data&&this.data.length)&&(t=this.isSingleDataSet(this.data)?[{data:this.data,label:"Label 0"}]:this.data.map(function(t,e){return{data:t,label:a.joinLabel(a.labels[e])||"Label "+e}})),(this.datasets&&this.datasets.length||t&&t.length)&&(t=(this.datasets||t).map(function(t,e){var r=Object.assign({},t);return a.colors&&a.colors.length?Object.assign(r,a.colors[e]):Object.assign(r,c(a.chartType,e,r.data.length)),r})),!t)throw new Error("ng-charts configuration error,\n data or datasets field are required to render chart "+this.chartType);return t},t.prototype.refresh=function(){this.chart&&(this.chart.destroy(),this.chart=void 0),this.chart=this.getChartBuilder(this.ctx)},t.decorators=[{type:r.Directive,args:[{selector:"canvas[baseChart]",exportAs:"base-chart"}]}],t.ctorParameters=function(){return[{type:r.ElementRef},{type:f}]},t.propDecorators={data:[{type:r.Input}],datasets:[{type:r.Input}],labels:[{type:r.Input}],options:[{type:r.Input}],chartType:[{type:r.Input}],colors:[{type:r.Input}],legend:[{type:r.Input}],plugins:[{type:r.Input}],chartClick:[{type:r.Output}],chartHover:[{type:r.Output}]},t}(),b=function(){function t(){}return t.decorators=[{type:r.NgModule,args:[{declarations:[y],imports:[],exports:[y]}]}],t}();t.ChartsModule=b,t.BaseChartDirective=y,t.defaultColors=a,t.ThemeService=f,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ng2-charts.umd.min.js.map |
@@ -10,2 +10,11 @@ /** | ||
import * as _ from 'lodash'; | ||
/** @enum {number} */ | ||
const UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
export class BaseChartDirective { | ||
@@ -70,3 +79,11 @@ /** | ||
/** @type {?} */ | ||
let updateRequired = false; | ||
let updateRequired = UpdateType.Default; | ||
/** @type {?} */ | ||
const wantUpdate = (/** | ||
* @param {?} x | ||
* @return {?} | ||
*/ | ||
(x) => { | ||
updateRequired = x > updateRequired ? x : updateRequired; | ||
}); | ||
// Check if the changes are in the data or datasets or labels or legend | ||
@@ -80,7 +97,7 @@ if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) { | ||
} | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (changes.hasOwnProperty('labels')) { | ||
this.chart.data.labels = changes.labels.currentValue; | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
@@ -90,11 +107,15 @@ if (changes.hasOwnProperty('legend')) { | ||
this.chart.generateLegend(); | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (updateRequired) { | ||
// ... if so, update chart | ||
this.chart.update(); | ||
if (changes.hasOwnProperty('options')) { | ||
wantUpdate(UpdateType.Refresh); | ||
} | ||
else { | ||
// otherwise rebuild the chart | ||
this.refresh(); | ||
switch ((/** @type {?} */ (updateRequired))) { | ||
case UpdateType.Update: | ||
this.update(); | ||
break; | ||
case UpdateType.Refresh: | ||
case UpdateType.Default: | ||
this.refresh(); | ||
break; | ||
} | ||
@@ -392,3 +413,3 @@ } | ||
throw new Error(`ng-charts configuration error, | ||
data or datasets field are required to render char ${this.chartType}`); | ||
data or datasets field are required to render chart ${this.chartType}`); | ||
} | ||
@@ -483,2 +504,2 @@ return datasets; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-chart.directive.js","sourceRoot":"ng://ng2-charts/","sources":["lib/base-chart.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  OnDestroy,\r\n  OnChanges,\r\n  OnInit,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ElementRef,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport * as chartJs from 'chart.js';\r\nimport { getColors } from './get-colors';\r\nimport { Color } from './color';\r\nimport { ThemeService } from './theme.service';\r\nimport { Subscription } from 'rxjs';\r\nimport * as _ from 'lodash';\r\n\r\nexport type SingleDataSet = (number[] | chartJs.ChartPoint[]);\r\nexport type MultiDataSet = (number[] | chartJs.ChartPoint[])[];\r\nexport type SingleOrMultiDataSet = SingleDataSet | MultiDataSet;\r\n\r\nexport type PluginServiceGlobalRegistrationAndOptions = chartJs.PluginServiceGlobalRegistration & chartJs.PluginServiceRegistrationOptions;\r\nexport type SingleLineLabel = string;\r\nexport type MultiLineLabel = string[];\r\nexport type Label = SingleLineLabel | MultiLineLabel;\r\n\r\n@Directive({\r\n  // tslint:disable-next-line:directive-selector\r\n  selector: 'canvas[baseChart]',\r\n  exportAs: 'base-chart'\r\n})\r\nexport class BaseChartDirective implements OnDestroy, OnChanges, OnInit, OnDestroy {\r\n  @Input() public data: SingleOrMultiDataSet;\r\n  @Input() public datasets: chartJs.ChartDataSets[];\r\n  @Input() public labels: Label[];\r\n  @Input() public options: chartJs.ChartOptions = {};\r\n  @Input() public chartType: chartJs.ChartType;\r\n  @Input() public colors: Color[];\r\n  @Input() public legend: boolean;\r\n  @Input() public plugins: PluginServiceGlobalRegistrationAndOptions[];\r\n\r\n  @Output() public chartClick: EventEmitter<{ event?: MouseEvent, active?: {}[] }> = new EventEmitter();\r\n  @Output() public chartHover: EventEmitter<{ event: MouseEvent, active: {}[] }> = new EventEmitter();\r\n\r\n  public ctx: string;\r\n  public chart: Chart;\r\n  private initFlag = false;\r\n\r\n  private subs: Subscription[] = [];\r\n\r\n  /**\r\n   * Register a plugin.\r\n   */\r\n  public static registerPlugin(plugin: PluginServiceGlobalRegistrationAndOptions) {\r\n    chartJs.Chart.plugins.register(plugin);\r\n  }\r\n\r\n  public static unregisterPlugin(plugin: PluginServiceGlobalRegistrationAndOptions) {\r\n    chartJs.Chart.plugins.unregister(plugin);\r\n  }\r\n\r\n  public constructor(\r\n    private element: ElementRef,\r\n    private themeService: ThemeService,\r\n  ) { }\r\n\r\n  public ngOnInit() {\r\n    this.ctx = this.element.nativeElement.getContext('2d');\r\n    this.initFlag = true;\r\n    if (this.data || this.datasets) {\r\n      this.refresh();\r\n    }\r\n    this.subs.push(this.themeService.colorschemesOptions.subscribe(r => this.themeChanged(r)));\r\n  }\r\n\r\n  private themeChanged(options: {}) {\r\n    this.refresh();\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges) {\r\n    if (this.initFlag) {\r\n      let updateRequired = false;\r\n      // Check if the changes are in the data or datasets or labels or legend\r\n\r\n      if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) {\r\n        if (changes.data) {\r\n          this.updateChartData(changes.data.currentValue);\r\n        } else {\r\n          this.updateChartData(changes.datasets.currentValue);\r\n        }\r\n\r\n        updateRequired = true;\r\n      }\r\n\r\n      if (changes.hasOwnProperty('labels')) {\r\n        this.chart.data.labels = changes.labels.currentValue;\r\n\r\n        updateRequired = true;\r\n      }\r\n\r\n      if (changes.hasOwnProperty('legend')) {\r\n        this.chart.config.options.legend.display = changes.legend.currentValue;\r\n        this.chart.generateLegend();\r\n\r\n        updateRequired = true;\r\n      }\r\n\r\n      if (updateRequired) {\r\n        // ... if so, update chart\r\n        this.chart.update();\r\n      } else {\r\n        // otherwise rebuild the chart\r\n        this.refresh();\r\n      }\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = void 0;\r\n    }\r\n    this.subs.forEach(x => x.unsubscribe());\r\n  }\r\n\r\n  public update(duration?: any, lazy?: any) {\r\n    return this.chart.update(duration, lazy);\r\n  }\r\n\r\n  public hideDataset(index: number, hidden: boolean) {\r\n    this.chart.getDatasetMeta(index).hidden = hidden;\r\n    this.chart.update();\r\n  }\r\n\r\n  public isDatasetHidden(index: number): boolean {\r\n    return this.chart.getDatasetMeta(index).hidden;\r\n  }\r\n\r\n  public toBase64Image(): string {\r\n    return this.chart.toBase64Image();\r\n  }\r\n\r\n  public getChartBuilder(ctx: string/*, data:any[], options:any*/): Chart {\r\n    const datasets = this.getDatasets();\r\n\r\n    const options = Object.assign({}, this.options);\r\n    if (this.legend === false) {\r\n      options.legend = { display: false };\r\n    }\r\n    // hook for onHover and onClick events\r\n    options.hover = options.hover || {};\r\n    if (!options.hover.onHover) {\r\n      options.hover.onHover = (event: MouseEvent, active: {}[]) => {\r\n        if (active && !active.length) {\r\n          return;\r\n        }\r\n        this.chartHover.emit({ event, active });\r\n      };\r\n    }\r\n\r\n    if (!options.onClick) {\r\n      options.onClick = (event?: MouseEvent, active?: {}[]) => {\r\n        this.chartClick.emit({ event, active });\r\n      };\r\n    }\r\n\r\n    const mergedOptions = this.smartMerge(options, this.themeService.getColorschemesOptions());\r\n\r\n    const chartConfig: chartJs.ChartConfiguration = {\r\n      type: this.chartType,\r\n      data: {\r\n        labels: this.labels,\r\n        datasets\r\n      },\r\n      plugins: this.plugins,\r\n      options: mergedOptions,\r\n    };\r\n\r\n    return new chartJs.Chart(ctx, chartConfig);\r\n  }\r\n\r\n  smartMerge(options: any, overrides: any, level: number = 0): any {\r\n    if (level === 0) {\r\n      options = _.cloneDeep(options);\r\n    }\r\n    const keysToUpdate = Object.keys(overrides);\r\n    keysToUpdate.forEach(key => {\r\n      if (Array.isArray(overrides[key])) {\r\n        const arrayElements = options[key];\r\n        if (arrayElements) {\r\n          arrayElements.forEach(r => {\r\n            this.smartMerge(r, overrides[key][0], level + 1);\r\n          });\r\n        }\r\n      } else if (typeof (overrides[key]) === 'object') {\r\n        if (!(key in options)) {\r\n          options[key] = {};\r\n        }\r\n        this.smartMerge(options[key], overrides[key], level + 1);\r\n      } else {\r\n        options[key] = overrides[key];\r\n      }\r\n    });\r\n    if (level === 0) {\r\n      return options;\r\n    }\r\n  }\r\n\r\n  private isChartDataSetsArray(v: SingleOrMultiDataSet | chartJs.ChartDataSets[]): v is chartJs.ChartDataSets[] {\r\n    const elm = v[0];\r\n    return (typeof (elm) === 'object') && 'data' in elm;\r\n  }\r\n\r\n  private isMultiLineLabel(label: Label): label is MultiLineLabel {\r\n    return Array.isArray(label);\r\n  }\r\n\r\n  private joinLabel(label: Label): string {\r\n    if (!label) {\r\n      return null;\r\n    }\r\n    if (this.isMultiLineLabel(label)) {\r\n      return label.join(' ');\r\n    } else {\r\n      return label;\r\n    }\r\n  }\r\n\r\n  private updateChartData(newDataValues: SingleOrMultiDataSet | chartJs.ChartDataSets[]): void {\r\n    if (this.isChartDataSetsArray(newDataValues)) {\r\n      if (newDataValues.length === this.chart.data.datasets.length) {\r\n        this.chart.data.datasets.forEach((dataset, i: number) => {\r\n          dataset.data = newDataValues[i].data;\r\n          if (newDataValues[i].label) {\r\n            dataset.label = newDataValues[i].label;\r\n          }\r\n        });\r\n      } else {\r\n        this.chart.data.datasets = [...newDataValues];\r\n      }\r\n    } else if (!this.isSingleDataSet(newDataValues)) {\r\n      if (newDataValues.length === this.chart.data.datasets.length) {\r\n        this.chart.data.datasets.forEach((dataset, i: number) => {\r\n          dataset.data = newDataValues[i];\r\n        });\r\n      } else {\r\n        this.chart.data.datasets = newDataValues.map((data: number[], index: number) => {\r\n          return { data, label: this.joinLabel(this.labels[index]) || `Label ${index}` };\r\n        });\r\n      }\r\n    } else {\r\n      this.chart.data.datasets[0].data = newDataValues;\r\n    }\r\n    this.chart.data.datasets.forEach((elm, index) => {\r\n      if (this.colors && this.colors[index]) {\r\n        Object.assign(elm, this.colors[index]);\r\n      } else {\r\n        Object.assign(elm, getColors(this.chartType, index, elm.data.length));\r\n      }\r\n    });\r\n  }\r\n\r\n  private isSingleDataSet(data: SingleOrMultiDataSet): data is SingleDataSet {\r\n    return !Array.isArray(data[0]);\r\n  }\r\n\r\n  private getDatasets() {\r\n    let datasets: chartJs.ChartDataSets[] = void 0;\r\n    // in case if datasets is not provided, but data is present\r\n    if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) {\r\n      if (!this.isSingleDataSet(this.data)) {\r\n        datasets = this.data.map((data: number[], index: number) => {\r\n          return { data, label: this.joinLabel(this.labels[index]) || `Label ${index}` };\r\n        });\r\n      } else {\r\n        datasets = [{ data: this.data, label: `Label 0` }];\r\n      }\r\n    }\r\n\r\n    if (this.datasets && this.datasets.length ||\r\n      (datasets && datasets.length)) {\r\n      datasets = (this.datasets || datasets)\r\n        .map((elm: chartJs.ChartDataSets, index: number) => {\r\n          const newElm: chartJs.ChartDataSets = Object.assign({}, elm);\r\n          if (this.colors && this.colors.length) {\r\n            Object.assign(newElm, this.colors[index]);\r\n          } else {\r\n            Object.assign(newElm, getColors(this.chartType, index, newElm.data.length));\r\n          }\r\n          return newElm;\r\n        });\r\n    }\r\n\r\n    if (!datasets) {\r\n      throw new Error(`ng-charts configuration error,\r\n      data or datasets field are required to render char ${this.chartType}`);\r\n    }\r\n\r\n    return datasets;\r\n  }\r\n\r\n  private refresh() {\r\n    // if (this.options && this.options.responsive) {\r\n    //   setTimeout(() => this.refresh(), 50);\r\n    // }\r\n\r\n    // todo: remove this line, it is producing flickering\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = void 0;\r\n    }\r\n    this.chart = this.getChartBuilder(this.ctx/*, data, this.options*/);\r\n  }\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-chart.directive.js","sourceRoot":"ng://ng2-charts/","sources":["lib/base-chart.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  OnDestroy,\r\n  OnChanges,\r\n  OnInit,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ElementRef,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport * as chartJs from 'chart.js';\r\nimport { getColors } from './get-colors';\r\nimport { Color } from './color';\r\nimport { ThemeService } from './theme.service';\r\nimport { Subscription } from 'rxjs';\r\nimport * as _ from 'lodash';\r\n\r\nexport type SingleDataSet = (number[] | chartJs.ChartPoint[]);\r\nexport type MultiDataSet = (number[] | chartJs.ChartPoint[])[];\r\nexport type SingleOrMultiDataSet = SingleDataSet | MultiDataSet;\r\n\r\nexport type PluginServiceGlobalRegistrationAndOptions = chartJs.PluginServiceGlobalRegistration & chartJs.PluginServiceRegistrationOptions;\r\nexport type SingleLineLabel = string;\r\nexport type MultiLineLabel = string[];\r\nexport type Label = SingleLineLabel | MultiLineLabel;\r\n\r\nenum UpdateType {\r\n  Default,\r\n  Update,\r\n  Refresh\r\n}\r\n\r\n@Directive({\r\n  // tslint:disable-next-line:directive-selector\r\n  selector: 'canvas[baseChart]',\r\n  exportAs: 'base-chart'\r\n})\r\nexport class BaseChartDirective implements OnDestroy, OnChanges, OnInit, OnDestroy {\r\n  @Input() public data: SingleOrMultiDataSet;\r\n  @Input() public datasets: chartJs.ChartDataSets[];\r\n  @Input() public labels: Label[];\r\n  @Input() public options: chartJs.ChartOptions = {};\r\n  @Input() public chartType: chartJs.ChartType;\r\n  @Input() public colors: Color[];\r\n  @Input() public legend: boolean;\r\n  @Input() public plugins: PluginServiceGlobalRegistrationAndOptions[];\r\n\r\n  @Output() public chartClick: EventEmitter<{ event?: MouseEvent, active?: {}[] }> = new EventEmitter();\r\n  @Output() public chartHover: EventEmitter<{ event: MouseEvent, active: {}[] }> = new EventEmitter();\r\n\r\n  public ctx: string;\r\n  public chart: Chart;\r\n  private initFlag = false;\r\n\r\n  private subs: Subscription[] = [];\r\n\r\n  /**\r\n   * Register a plugin.\r\n   */\r\n  public static registerPlugin(plugin: PluginServiceGlobalRegistrationAndOptions) {\r\n    chartJs.Chart.plugins.register(plugin);\r\n  }\r\n\r\n  public static unregisterPlugin(plugin: PluginServiceGlobalRegistrationAndOptions) {\r\n    chartJs.Chart.plugins.unregister(plugin);\r\n  }\r\n\r\n  public constructor(\r\n    private element: ElementRef,\r\n    private themeService: ThemeService,\r\n  ) { }\r\n\r\n  public ngOnInit() {\r\n    this.ctx = this.element.nativeElement.getContext('2d');\r\n    this.initFlag = true;\r\n    if (this.data || this.datasets) {\r\n      this.refresh();\r\n    }\r\n    this.subs.push(this.themeService.colorschemesOptions.subscribe(r => this.themeChanged(r)));\r\n  }\r\n\r\n  private themeChanged(options: {}) {\r\n    this.refresh();\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges) {\r\n    if (this.initFlag) {\r\n      let updateRequired = UpdateType.Default;\r\n      const wantUpdate = (x: UpdateType) => {\r\n        updateRequired = x > updateRequired ? x : updateRequired;\r\n      };\r\n\r\n      // Check if the changes are in the data or datasets or labels or legend\r\n\r\n      if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) {\r\n        if (changes.data) {\r\n          this.updateChartData(changes.data.currentValue);\r\n        } else {\r\n          this.updateChartData(changes.datasets.currentValue);\r\n        }\r\n\r\n        wantUpdate(UpdateType.Update);\r\n      }\r\n\r\n      if (changes.hasOwnProperty('labels')) {\r\n        this.chart.data.labels = changes.labels.currentValue;\r\n\r\n        wantUpdate(UpdateType.Update);\r\n      }\r\n\r\n      if (changes.hasOwnProperty('legend')) {\r\n        this.chart.config.options.legend.display = changes.legend.currentValue;\r\n        this.chart.generateLegend();\r\n\r\n        wantUpdate(UpdateType.Update);\r\n      }\r\n\r\n      if (changes.hasOwnProperty('options')) {\r\n        wantUpdate(UpdateType.Refresh);\r\n      }\r\n\r\n      switch (updateRequired as UpdateType) {\r\n        case UpdateType.Update:\r\n          this.update();\r\n          break;\r\n        case UpdateType.Refresh:\r\n        case UpdateType.Default:\r\n          this.refresh();\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = void 0;\r\n    }\r\n    this.subs.forEach(x => x.unsubscribe());\r\n  }\r\n\r\n  public update(duration?: any, lazy?: any) {\r\n    return this.chart.update(duration, lazy);\r\n  }\r\n\r\n  public hideDataset(index: number, hidden: boolean) {\r\n    this.chart.getDatasetMeta(index).hidden = hidden;\r\n    this.chart.update();\r\n  }\r\n\r\n  public isDatasetHidden(index: number): boolean {\r\n    return this.chart.getDatasetMeta(index).hidden;\r\n  }\r\n\r\n  public toBase64Image(): string {\r\n    return this.chart.toBase64Image();\r\n  }\r\n\r\n  public getChartBuilder(ctx: string/*, data:any[], options:any*/): Chart {\r\n    const datasets = this.getDatasets();\r\n\r\n    const options = Object.assign({}, this.options);\r\n    if (this.legend === false) {\r\n      options.legend = { display: false };\r\n    }\r\n    // hook for onHover and onClick events\r\n    options.hover = options.hover || {};\r\n    if (!options.hover.onHover) {\r\n      options.hover.onHover = (event: MouseEvent, active: {}[]) => {\r\n        if (active && !active.length) {\r\n          return;\r\n        }\r\n        this.chartHover.emit({ event, active });\r\n      };\r\n    }\r\n\r\n    if (!options.onClick) {\r\n      options.onClick = (event?: MouseEvent, active?: {}[]) => {\r\n        this.chartClick.emit({ event, active });\r\n      };\r\n    }\r\n\r\n    const mergedOptions = this.smartMerge(options, this.themeService.getColorschemesOptions());\r\n\r\n    const chartConfig: chartJs.ChartConfiguration = {\r\n      type: this.chartType,\r\n      data: {\r\n        labels: this.labels,\r\n        datasets\r\n      },\r\n      plugins: this.plugins,\r\n      options: mergedOptions,\r\n    };\r\n\r\n    return new chartJs.Chart(ctx, chartConfig);\r\n  }\r\n\r\n  smartMerge(options: any, overrides: any, level: number = 0): any {\r\n    if (level === 0) {\r\n      options = _.cloneDeep(options);\r\n    }\r\n    const keysToUpdate = Object.keys(overrides);\r\n    keysToUpdate.forEach(key => {\r\n      if (Array.isArray(overrides[key])) {\r\n        const arrayElements = options[key];\r\n        if (arrayElements) {\r\n          arrayElements.forEach(r => {\r\n            this.smartMerge(r, overrides[key][0], level + 1);\r\n          });\r\n        }\r\n      } else if (typeof (overrides[key]) === 'object') {\r\n        if (!(key in options)) {\r\n          options[key] = {};\r\n        }\r\n        this.smartMerge(options[key], overrides[key], level + 1);\r\n      } else {\r\n        options[key] = overrides[key];\r\n      }\r\n    });\r\n    if (level === 0) {\r\n      return options;\r\n    }\r\n  }\r\n\r\n  private isChartDataSetsArray(v: SingleOrMultiDataSet | chartJs.ChartDataSets[]): v is chartJs.ChartDataSets[] {\r\n    const elm = v[0];\r\n    return (typeof (elm) === 'object') && 'data' in elm;\r\n  }\r\n\r\n  private isMultiLineLabel(label: Label): label is MultiLineLabel {\r\n    return Array.isArray(label);\r\n  }\r\n\r\n  private joinLabel(label: Label): string {\r\n    if (!label) {\r\n      return null;\r\n    }\r\n    if (this.isMultiLineLabel(label)) {\r\n      return label.join(' ');\r\n    } else {\r\n      return label;\r\n    }\r\n  }\r\n\r\n  private updateChartData(newDataValues: SingleOrMultiDataSet | chartJs.ChartDataSets[]): void {\r\n    if (this.isChartDataSetsArray(newDataValues)) {\r\n      if (newDataValues.length === this.chart.data.datasets.length) {\r\n        this.chart.data.datasets.forEach((dataset, i: number) => {\r\n          dataset.data = newDataValues[i].data;\r\n          if (newDataValues[i].label) {\r\n            dataset.label = newDataValues[i].label;\r\n          }\r\n        });\r\n      } else {\r\n        this.chart.data.datasets = [...newDataValues];\r\n      }\r\n    } else if (!this.isSingleDataSet(newDataValues)) {\r\n      if (newDataValues.length === this.chart.data.datasets.length) {\r\n        this.chart.data.datasets.forEach((dataset, i: number) => {\r\n          dataset.data = newDataValues[i];\r\n        });\r\n      } else {\r\n        this.chart.data.datasets = newDataValues.map((data: number[], index: number) => {\r\n          return { data, label: this.joinLabel(this.labels[index]) || `Label ${index}` };\r\n        });\r\n      }\r\n    } else {\r\n      this.chart.data.datasets[0].data = newDataValues;\r\n    }\r\n    this.chart.data.datasets.forEach((elm, index) => {\r\n      if (this.colors && this.colors[index]) {\r\n        Object.assign(elm, this.colors[index]);\r\n      } else {\r\n        Object.assign(elm, getColors(this.chartType, index, elm.data.length));\r\n      }\r\n    });\r\n  }\r\n\r\n  private isSingleDataSet(data: SingleOrMultiDataSet): data is SingleDataSet {\r\n    return !Array.isArray(data[0]);\r\n  }\r\n\r\n  private getDatasets() {\r\n    let datasets: chartJs.ChartDataSets[] = void 0;\r\n    // in case if datasets is not provided, but data is present\r\n    if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) {\r\n      if (!this.isSingleDataSet(this.data)) {\r\n        datasets = this.data.map((data: number[], index: number) => {\r\n          return { data, label: this.joinLabel(this.labels[index]) || `Label ${index}` };\r\n        });\r\n      } else {\r\n        datasets = [{ data: this.data, label: `Label 0` }];\r\n      }\r\n    }\r\n\r\n    if (this.datasets && this.datasets.length ||\r\n      (datasets && datasets.length)) {\r\n      datasets = (this.datasets || datasets)\r\n        .map((elm: chartJs.ChartDataSets, index: number) => {\r\n          const newElm: chartJs.ChartDataSets = Object.assign({}, elm);\r\n          if (this.colors && this.colors.length) {\r\n            Object.assign(newElm, this.colors[index]);\r\n          } else {\r\n            Object.assign(newElm, getColors(this.chartType, index, newElm.data.length));\r\n          }\r\n          return newElm;\r\n        });\r\n    }\r\n\r\n    if (!datasets) {\r\n      throw new Error(`ng-charts configuration error,\r\n      data or datasets field are required to render chart ${this.chartType}`);\r\n    }\r\n\r\n    return datasets;\r\n  }\r\n\r\n  private refresh() {\r\n    // if (this.options && this.options.responsive) {\r\n    //   setTimeout(() => this.refresh(), 50);\r\n    // }\r\n\r\n    // todo: remove this line, it is producing flickering\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = void 0;\r\n    }\r\n    this.chart = this.getChartBuilder(this.ctx/*, data, this.options*/);\r\n  }\r\n}\r\n"]} |
@@ -11,2 +11,11 @@ /** | ||
import * as _ from 'lodash'; | ||
/** @enum {number} */ | ||
var UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
var BaseChartDirective = /** @class */ (function () { | ||
@@ -92,3 +101,11 @@ function BaseChartDirective(element, themeService) { | ||
/** @type {?} */ | ||
var updateRequired = false; | ||
var updateRequired_1 = UpdateType.Default; | ||
/** @type {?} */ | ||
var wantUpdate = (/** | ||
* @param {?} x | ||
* @return {?} | ||
*/ | ||
function (x) { | ||
updateRequired_1 = x > updateRequired_1 ? x : updateRequired_1; | ||
}); | ||
// Check if the changes are in the data or datasets or labels or legend | ||
@@ -102,7 +119,7 @@ if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) { | ||
} | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (changes.hasOwnProperty('labels')) { | ||
this.chart.data.labels = changes.labels.currentValue; | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
@@ -112,11 +129,15 @@ if (changes.hasOwnProperty('legend')) { | ||
this.chart.generateLegend(); | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (updateRequired) { | ||
// ... if so, update chart | ||
this.chart.update(); | ||
if (changes.hasOwnProperty('options')) { | ||
wantUpdate(UpdateType.Refresh); | ||
} | ||
else { | ||
// otherwise rebuild the chart | ||
this.refresh(); | ||
switch ((/** @type {?} */ (updateRequired_1))) { | ||
case UpdateType.Update: | ||
this.update(); | ||
break; | ||
case UpdateType.Refresh: | ||
case UpdateType.Default: | ||
this.refresh(); | ||
break; | ||
} | ||
@@ -477,3 +498,3 @@ } | ||
if (!datasets) { | ||
throw new Error("ng-charts configuration error,\n data or datasets field are required to render char " + this.chartType); | ||
throw new Error("ng-charts configuration error,\n data or datasets field are required to render chart " + this.chartType); | ||
} | ||
@@ -574,2 +595,2 @@ return datasets; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-chart.directive.js","sourceRoot":"ng://ng2-charts/","sources":["lib/base-chart.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  OnDestroy,\r\n  OnChanges,\r\n  OnInit,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ElementRef,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport * as chartJs from 'chart.js';\r\nimport { getColors } from './get-colors';\r\nimport { Color } from './color';\r\nimport { ThemeService } from './theme.service';\r\nimport { Subscription } from 'rxjs';\r\nimport * as _ from 'lodash';\r\n\r\nexport type SingleDataSet = (number[] | chartJs.ChartPoint[]);\r\nexport type MultiDataSet = (number[] | chartJs.ChartPoint[])[];\r\nexport type SingleOrMultiDataSet = SingleDataSet | MultiDataSet;\r\n\r\nexport type PluginServiceGlobalRegistrationAndOptions = chartJs.PluginServiceGlobalRegistration & chartJs.PluginServiceRegistrationOptions;\r\nexport type SingleLineLabel = string;\r\nexport type MultiLineLabel = string[];\r\nexport type Label = SingleLineLabel | MultiLineLabel;\r\n\r\n@Directive({\r\n  // tslint:disable-next-line:directive-selector\r\n  selector: 'canvas[baseChart]',\r\n  exportAs: 'base-chart'\r\n})\r\nexport class BaseChartDirective implements OnDestroy, OnChanges, OnInit, OnDestroy {\r\n  @Input() public data: SingleOrMultiDataSet;\r\n  @Input() public datasets: chartJs.ChartDataSets[];\r\n  @Input() public labels: Label[];\r\n  @Input() public options: chartJs.ChartOptions = {};\r\n  @Input() public chartType: chartJs.ChartType;\r\n  @Input() public colors: Color[];\r\n  @Input() public legend: boolean;\r\n  @Input() public plugins: PluginServiceGlobalRegistrationAndOptions[];\r\n\r\n  @Output() public chartClick: EventEmitter<{ event?: MouseEvent, active?: {}[] }> = new EventEmitter();\r\n  @Output() public chartHover: EventEmitter<{ event: MouseEvent, active: {}[] }> = new EventEmitter();\r\n\r\n  public ctx: string;\r\n  public chart: Chart;\r\n  private initFlag = false;\r\n\r\n  private subs: Subscription[] = [];\r\n\r\n  /**\r\n   * Register a plugin.\r\n   */\r\n  public static registerPlugin(plugin: PluginServiceGlobalRegistrationAndOptions) {\r\n    chartJs.Chart.plugins.register(plugin);\r\n  }\r\n\r\n  public static unregisterPlugin(plugin: PluginServiceGlobalRegistrationAndOptions) {\r\n    chartJs.Chart.plugins.unregister(plugin);\r\n  }\r\n\r\n  public constructor(\r\n    private element: ElementRef,\r\n    private themeService: ThemeService,\r\n  ) { }\r\n\r\n  public ngOnInit() {\r\n    this.ctx = this.element.nativeElement.getContext('2d');\r\n    this.initFlag = true;\r\n    if (this.data || this.datasets) {\r\n      this.refresh();\r\n    }\r\n    this.subs.push(this.themeService.colorschemesOptions.subscribe(r => this.themeChanged(r)));\r\n  }\r\n\r\n  private themeChanged(options: {}) {\r\n    this.refresh();\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges) {\r\n    if (this.initFlag) {\r\n      let updateRequired = false;\r\n      // Check if the changes are in the data or datasets or labels or legend\r\n\r\n      if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) {\r\n        if (changes.data) {\r\n          this.updateChartData(changes.data.currentValue);\r\n        } else {\r\n          this.updateChartData(changes.datasets.currentValue);\r\n        }\r\n\r\n        updateRequired = true;\r\n      }\r\n\r\n      if (changes.hasOwnProperty('labels')) {\r\n        this.chart.data.labels = changes.labels.currentValue;\r\n\r\n        updateRequired = true;\r\n      }\r\n\r\n      if (changes.hasOwnProperty('legend')) {\r\n        this.chart.config.options.legend.display = changes.legend.currentValue;\r\n        this.chart.generateLegend();\r\n\r\n        updateRequired = true;\r\n      }\r\n\r\n      if (updateRequired) {\r\n        // ... if so, update chart\r\n        this.chart.update();\r\n      } else {\r\n        // otherwise rebuild the chart\r\n        this.refresh();\r\n      }\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = void 0;\r\n    }\r\n    this.subs.forEach(x => x.unsubscribe());\r\n  }\r\n\r\n  public update(duration?: any, lazy?: any) {\r\n    return this.chart.update(duration, lazy);\r\n  }\r\n\r\n  public hideDataset(index: number, hidden: boolean) {\r\n    this.chart.getDatasetMeta(index).hidden = hidden;\r\n    this.chart.update();\r\n  }\r\n\r\n  public isDatasetHidden(index: number): boolean {\r\n    return this.chart.getDatasetMeta(index).hidden;\r\n  }\r\n\r\n  public toBase64Image(): string {\r\n    return this.chart.toBase64Image();\r\n  }\r\n\r\n  public getChartBuilder(ctx: string/*, data:any[], options:any*/): Chart {\r\n    const datasets = this.getDatasets();\r\n\r\n    const options = Object.assign({}, this.options);\r\n    if (this.legend === false) {\r\n      options.legend = { display: false };\r\n    }\r\n    // hook for onHover and onClick events\r\n    options.hover = options.hover || {};\r\n    if (!options.hover.onHover) {\r\n      options.hover.onHover = (event: MouseEvent, active: {}[]) => {\r\n        if (active && !active.length) {\r\n          return;\r\n        }\r\n        this.chartHover.emit({ event, active });\r\n      };\r\n    }\r\n\r\n    if (!options.onClick) {\r\n      options.onClick = (event?: MouseEvent, active?: {}[]) => {\r\n        this.chartClick.emit({ event, active });\r\n      };\r\n    }\r\n\r\n    const mergedOptions = this.smartMerge(options, this.themeService.getColorschemesOptions());\r\n\r\n    const chartConfig: chartJs.ChartConfiguration = {\r\n      type: this.chartType,\r\n      data: {\r\n        labels: this.labels,\r\n        datasets\r\n      },\r\n      plugins: this.plugins,\r\n      options: mergedOptions,\r\n    };\r\n\r\n    return new chartJs.Chart(ctx, chartConfig);\r\n  }\r\n\r\n  smartMerge(options: any, overrides: any, level: number = 0): any {\r\n    if (level === 0) {\r\n      options = _.cloneDeep(options);\r\n    }\r\n    const keysToUpdate = Object.keys(overrides);\r\n    keysToUpdate.forEach(key => {\r\n      if (Array.isArray(overrides[key])) {\r\n        const arrayElements = options[key];\r\n        if (arrayElements) {\r\n          arrayElements.forEach(r => {\r\n            this.smartMerge(r, overrides[key][0], level + 1);\r\n          });\r\n        }\r\n      } else if (typeof (overrides[key]) === 'object') {\r\n        if (!(key in options)) {\r\n          options[key] = {};\r\n        }\r\n        this.smartMerge(options[key], overrides[key], level + 1);\r\n      } else {\r\n        options[key] = overrides[key];\r\n      }\r\n    });\r\n    if (level === 0) {\r\n      return options;\r\n    }\r\n  }\r\n\r\n  private isChartDataSetsArray(v: SingleOrMultiDataSet | chartJs.ChartDataSets[]): v is chartJs.ChartDataSets[] {\r\n    const elm = v[0];\r\n    return (typeof (elm) === 'object') && 'data' in elm;\r\n  }\r\n\r\n  private isMultiLineLabel(label: Label): label is MultiLineLabel {\r\n    return Array.isArray(label);\r\n  }\r\n\r\n  private joinLabel(label: Label): string {\r\n    if (!label) {\r\n      return null;\r\n    }\r\n    if (this.isMultiLineLabel(label)) {\r\n      return label.join(' ');\r\n    } else {\r\n      return label;\r\n    }\r\n  }\r\n\r\n  private updateChartData(newDataValues: SingleOrMultiDataSet | chartJs.ChartDataSets[]): void {\r\n    if (this.isChartDataSetsArray(newDataValues)) {\r\n      if (newDataValues.length === this.chart.data.datasets.length) {\r\n        this.chart.data.datasets.forEach((dataset, i: number) => {\r\n          dataset.data = newDataValues[i].data;\r\n          if (newDataValues[i].label) {\r\n            dataset.label = newDataValues[i].label;\r\n          }\r\n        });\r\n      } else {\r\n        this.chart.data.datasets = [...newDataValues];\r\n      }\r\n    } else if (!this.isSingleDataSet(newDataValues)) {\r\n      if (newDataValues.length === this.chart.data.datasets.length) {\r\n        this.chart.data.datasets.forEach((dataset, i: number) => {\r\n          dataset.data = newDataValues[i];\r\n        });\r\n      } else {\r\n        this.chart.data.datasets = newDataValues.map((data: number[], index: number) => {\r\n          return { data, label: this.joinLabel(this.labels[index]) || `Label ${index}` };\r\n        });\r\n      }\r\n    } else {\r\n      this.chart.data.datasets[0].data = newDataValues;\r\n    }\r\n    this.chart.data.datasets.forEach((elm, index) => {\r\n      if (this.colors && this.colors[index]) {\r\n        Object.assign(elm, this.colors[index]);\r\n      } else {\r\n        Object.assign(elm, getColors(this.chartType, index, elm.data.length));\r\n      }\r\n    });\r\n  }\r\n\r\n  private isSingleDataSet(data: SingleOrMultiDataSet): data is SingleDataSet {\r\n    return !Array.isArray(data[0]);\r\n  }\r\n\r\n  private getDatasets() {\r\n    let datasets: chartJs.ChartDataSets[] = void 0;\r\n    // in case if datasets is not provided, but data is present\r\n    if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) {\r\n      if (!this.isSingleDataSet(this.data)) {\r\n        datasets = this.data.map((data: number[], index: number) => {\r\n          return { data, label: this.joinLabel(this.labels[index]) || `Label ${index}` };\r\n        });\r\n      } else {\r\n        datasets = [{ data: this.data, label: `Label 0` }];\r\n      }\r\n    }\r\n\r\n    if (this.datasets && this.datasets.length ||\r\n      (datasets && datasets.length)) {\r\n      datasets = (this.datasets || datasets)\r\n        .map((elm: chartJs.ChartDataSets, index: number) => {\r\n          const newElm: chartJs.ChartDataSets = Object.assign({}, elm);\r\n          if (this.colors && this.colors.length) {\r\n            Object.assign(newElm, this.colors[index]);\r\n          } else {\r\n            Object.assign(newElm, getColors(this.chartType, index, newElm.data.length));\r\n          }\r\n          return newElm;\r\n        });\r\n    }\r\n\r\n    if (!datasets) {\r\n      throw new Error(`ng-charts configuration error,\r\n      data or datasets field are required to render char ${this.chartType}`);\r\n    }\r\n\r\n    return datasets;\r\n  }\r\n\r\n  private refresh() {\r\n    // if (this.options && this.options.responsive) {\r\n    //   setTimeout(() => this.refresh(), 50);\r\n    // }\r\n\r\n    // todo: remove this line, it is producing flickering\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = void 0;\r\n    }\r\n    this.chart = this.getChartBuilder(this.ctx/*, data, this.options*/);\r\n  }\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-chart.directive.js","sourceRoot":"ng://ng2-charts/","sources":["lib/base-chart.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  OnDestroy,\r\n  OnChanges,\r\n  OnInit,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ElementRef,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport * as chartJs from 'chart.js';\r\nimport { getColors } from './get-colors';\r\nimport { Color } from './color';\r\nimport { ThemeService } from './theme.service';\r\nimport { Subscription } from 'rxjs';\r\nimport * as _ from 'lodash';\r\n\r\nexport type SingleDataSet = (number[] | chartJs.ChartPoint[]);\r\nexport type MultiDataSet = (number[] | chartJs.ChartPoint[])[];\r\nexport type SingleOrMultiDataSet = SingleDataSet | MultiDataSet;\r\n\r\nexport type PluginServiceGlobalRegistrationAndOptions = chartJs.PluginServiceGlobalRegistration & chartJs.PluginServiceRegistrationOptions;\r\nexport type SingleLineLabel = string;\r\nexport type MultiLineLabel = string[];\r\nexport type Label = SingleLineLabel | MultiLineLabel;\r\n\r\nenum UpdateType {\r\n  Default,\r\n  Update,\r\n  Refresh\r\n}\r\n\r\n@Directive({\r\n  // tslint:disable-next-line:directive-selector\r\n  selector: 'canvas[baseChart]',\r\n  exportAs: 'base-chart'\r\n})\r\nexport class BaseChartDirective implements OnDestroy, OnChanges, OnInit, OnDestroy {\r\n  @Input() public data: SingleOrMultiDataSet;\r\n  @Input() public datasets: chartJs.ChartDataSets[];\r\n  @Input() public labels: Label[];\r\n  @Input() public options: chartJs.ChartOptions = {};\r\n  @Input() public chartType: chartJs.ChartType;\r\n  @Input() public colors: Color[];\r\n  @Input() public legend: boolean;\r\n  @Input() public plugins: PluginServiceGlobalRegistrationAndOptions[];\r\n\r\n  @Output() public chartClick: EventEmitter<{ event?: MouseEvent, active?: {}[] }> = new EventEmitter();\r\n  @Output() public chartHover: EventEmitter<{ event: MouseEvent, active: {}[] }> = new EventEmitter();\r\n\r\n  public ctx: string;\r\n  public chart: Chart;\r\n  private initFlag = false;\r\n\r\n  private subs: Subscription[] = [];\r\n\r\n  /**\r\n   * Register a plugin.\r\n   */\r\n  public static registerPlugin(plugin: PluginServiceGlobalRegistrationAndOptions) {\r\n    chartJs.Chart.plugins.register(plugin);\r\n  }\r\n\r\n  public static unregisterPlugin(plugin: PluginServiceGlobalRegistrationAndOptions) {\r\n    chartJs.Chart.plugins.unregister(plugin);\r\n  }\r\n\r\n  public constructor(\r\n    private element: ElementRef,\r\n    private themeService: ThemeService,\r\n  ) { }\r\n\r\n  public ngOnInit() {\r\n    this.ctx = this.element.nativeElement.getContext('2d');\r\n    this.initFlag = true;\r\n    if (this.data || this.datasets) {\r\n      this.refresh();\r\n    }\r\n    this.subs.push(this.themeService.colorschemesOptions.subscribe(r => this.themeChanged(r)));\r\n  }\r\n\r\n  private themeChanged(options: {}) {\r\n    this.refresh();\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges) {\r\n    if (this.initFlag) {\r\n      let updateRequired = UpdateType.Default;\r\n      const wantUpdate = (x: UpdateType) => {\r\n        updateRequired = x > updateRequired ? x : updateRequired;\r\n      };\r\n\r\n      // Check if the changes are in the data or datasets or labels or legend\r\n\r\n      if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) {\r\n        if (changes.data) {\r\n          this.updateChartData(changes.data.currentValue);\r\n        } else {\r\n          this.updateChartData(changes.datasets.currentValue);\r\n        }\r\n\r\n        wantUpdate(UpdateType.Update);\r\n      }\r\n\r\n      if (changes.hasOwnProperty('labels')) {\r\n        this.chart.data.labels = changes.labels.currentValue;\r\n\r\n        wantUpdate(UpdateType.Update);\r\n      }\r\n\r\n      if (changes.hasOwnProperty('legend')) {\r\n        this.chart.config.options.legend.display = changes.legend.currentValue;\r\n        this.chart.generateLegend();\r\n\r\n        wantUpdate(UpdateType.Update);\r\n      }\r\n\r\n      if (changes.hasOwnProperty('options')) {\r\n        wantUpdate(UpdateType.Refresh);\r\n      }\r\n\r\n      switch (updateRequired as UpdateType) {\r\n        case UpdateType.Update:\r\n          this.update();\r\n          break;\r\n        case UpdateType.Refresh:\r\n        case UpdateType.Default:\r\n          this.refresh();\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = void 0;\r\n    }\r\n    this.subs.forEach(x => x.unsubscribe());\r\n  }\r\n\r\n  public update(duration?: any, lazy?: any) {\r\n    return this.chart.update(duration, lazy);\r\n  }\r\n\r\n  public hideDataset(index: number, hidden: boolean) {\r\n    this.chart.getDatasetMeta(index).hidden = hidden;\r\n    this.chart.update();\r\n  }\r\n\r\n  public isDatasetHidden(index: number): boolean {\r\n    return this.chart.getDatasetMeta(index).hidden;\r\n  }\r\n\r\n  public toBase64Image(): string {\r\n    return this.chart.toBase64Image();\r\n  }\r\n\r\n  public getChartBuilder(ctx: string/*, data:any[], options:any*/): Chart {\r\n    const datasets = this.getDatasets();\r\n\r\n    const options = Object.assign({}, this.options);\r\n    if (this.legend === false) {\r\n      options.legend = { display: false };\r\n    }\r\n    // hook for onHover and onClick events\r\n    options.hover = options.hover || {};\r\n    if (!options.hover.onHover) {\r\n      options.hover.onHover = (event: MouseEvent, active: {}[]) => {\r\n        if (active && !active.length) {\r\n          return;\r\n        }\r\n        this.chartHover.emit({ event, active });\r\n      };\r\n    }\r\n\r\n    if (!options.onClick) {\r\n      options.onClick = (event?: MouseEvent, active?: {}[]) => {\r\n        this.chartClick.emit({ event, active });\r\n      };\r\n    }\r\n\r\n    const mergedOptions = this.smartMerge(options, this.themeService.getColorschemesOptions());\r\n\r\n    const chartConfig: chartJs.ChartConfiguration = {\r\n      type: this.chartType,\r\n      data: {\r\n        labels: this.labels,\r\n        datasets\r\n      },\r\n      plugins: this.plugins,\r\n      options: mergedOptions,\r\n    };\r\n\r\n    return new chartJs.Chart(ctx, chartConfig);\r\n  }\r\n\r\n  smartMerge(options: any, overrides: any, level: number = 0): any {\r\n    if (level === 0) {\r\n      options = _.cloneDeep(options);\r\n    }\r\n    const keysToUpdate = Object.keys(overrides);\r\n    keysToUpdate.forEach(key => {\r\n      if (Array.isArray(overrides[key])) {\r\n        const arrayElements = options[key];\r\n        if (arrayElements) {\r\n          arrayElements.forEach(r => {\r\n            this.smartMerge(r, overrides[key][0], level + 1);\r\n          });\r\n        }\r\n      } else if (typeof (overrides[key]) === 'object') {\r\n        if (!(key in options)) {\r\n          options[key] = {};\r\n        }\r\n        this.smartMerge(options[key], overrides[key], level + 1);\r\n      } else {\r\n        options[key] = overrides[key];\r\n      }\r\n    });\r\n    if (level === 0) {\r\n      return options;\r\n    }\r\n  }\r\n\r\n  private isChartDataSetsArray(v: SingleOrMultiDataSet | chartJs.ChartDataSets[]): v is chartJs.ChartDataSets[] {\r\n    const elm = v[0];\r\n    return (typeof (elm) === 'object') && 'data' in elm;\r\n  }\r\n\r\n  private isMultiLineLabel(label: Label): label is MultiLineLabel {\r\n    return Array.isArray(label);\r\n  }\r\n\r\n  private joinLabel(label: Label): string {\r\n    if (!label) {\r\n      return null;\r\n    }\r\n    if (this.isMultiLineLabel(label)) {\r\n      return label.join(' ');\r\n    } else {\r\n      return label;\r\n    }\r\n  }\r\n\r\n  private updateChartData(newDataValues: SingleOrMultiDataSet | chartJs.ChartDataSets[]): void {\r\n    if (this.isChartDataSetsArray(newDataValues)) {\r\n      if (newDataValues.length === this.chart.data.datasets.length) {\r\n        this.chart.data.datasets.forEach((dataset, i: number) => {\r\n          dataset.data = newDataValues[i].data;\r\n          if (newDataValues[i].label) {\r\n            dataset.label = newDataValues[i].label;\r\n          }\r\n        });\r\n      } else {\r\n        this.chart.data.datasets = [...newDataValues];\r\n      }\r\n    } else if (!this.isSingleDataSet(newDataValues)) {\r\n      if (newDataValues.length === this.chart.data.datasets.length) {\r\n        this.chart.data.datasets.forEach((dataset, i: number) => {\r\n          dataset.data = newDataValues[i];\r\n        });\r\n      } else {\r\n        this.chart.data.datasets = newDataValues.map((data: number[], index: number) => {\r\n          return { data, label: this.joinLabel(this.labels[index]) || `Label ${index}` };\r\n        });\r\n      }\r\n    } else {\r\n      this.chart.data.datasets[0].data = newDataValues;\r\n    }\r\n    this.chart.data.datasets.forEach((elm, index) => {\r\n      if (this.colors && this.colors[index]) {\r\n        Object.assign(elm, this.colors[index]);\r\n      } else {\r\n        Object.assign(elm, getColors(this.chartType, index, elm.data.length));\r\n      }\r\n    });\r\n  }\r\n\r\n  private isSingleDataSet(data: SingleOrMultiDataSet): data is SingleDataSet {\r\n    return !Array.isArray(data[0]);\r\n  }\r\n\r\n  private getDatasets() {\r\n    let datasets: chartJs.ChartDataSets[] = void 0;\r\n    // in case if datasets is not provided, but data is present\r\n    if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) {\r\n      if (!this.isSingleDataSet(this.data)) {\r\n        datasets = this.data.map((data: number[], index: number) => {\r\n          return { data, label: this.joinLabel(this.labels[index]) || `Label ${index}` };\r\n        });\r\n      } else {\r\n        datasets = [{ data: this.data, label: `Label 0` }];\r\n      }\r\n    }\r\n\r\n    if (this.datasets && this.datasets.length ||\r\n      (datasets && datasets.length)) {\r\n      datasets = (this.datasets || datasets)\r\n        .map((elm: chartJs.ChartDataSets, index: number) => {\r\n          const newElm: chartJs.ChartDataSets = Object.assign({}, elm);\r\n          if (this.colors && this.colors.length) {\r\n            Object.assign(newElm, this.colors[index]);\r\n          } else {\r\n            Object.assign(newElm, getColors(this.chartType, index, newElm.data.length));\r\n          }\r\n          return newElm;\r\n        });\r\n    }\r\n\r\n    if (!datasets) {\r\n      throw new Error(`ng-charts configuration error,\r\n      data or datasets field are required to render chart ${this.chartType}`);\r\n    }\r\n\r\n    return datasets;\r\n  }\r\n\r\n  private refresh() {\r\n    // if (this.options && this.options.responsive) {\r\n    //   setTimeout(() => this.refresh(), 50);\r\n    // }\r\n\r\n    // todo: remove this line, it is producing flickering\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = void 0;\r\n    }\r\n    this.chart = this.getChartBuilder(this.ctx/*, data, this.options*/);\r\n  }\r\n}\r\n"]} |
@@ -229,2 +229,11 @@ import { Chart } from 'chart.js'; | ||
*/ | ||
/** @enum {number} */ | ||
const UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
class BaseChartDirective { | ||
@@ -289,3 +298,11 @@ /** | ||
/** @type {?} */ | ||
let updateRequired = false; | ||
let updateRequired = UpdateType.Default; | ||
/** @type {?} */ | ||
const wantUpdate = (/** | ||
* @param {?} x | ||
* @return {?} | ||
*/ | ||
(x) => { | ||
updateRequired = x > updateRequired ? x : updateRequired; | ||
}); | ||
// Check if the changes are in the data or datasets or labels or legend | ||
@@ -299,7 +316,7 @@ if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) { | ||
} | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (changes.hasOwnProperty('labels')) { | ||
this.chart.data.labels = changes.labels.currentValue; | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
@@ -309,11 +326,15 @@ if (changes.hasOwnProperty('legend')) { | ||
this.chart.generateLegend(); | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (updateRequired) { | ||
// ... if so, update chart | ||
this.chart.update(); | ||
if (changes.hasOwnProperty('options')) { | ||
wantUpdate(UpdateType.Refresh); | ||
} | ||
else { | ||
// otherwise rebuild the chart | ||
this.refresh(); | ||
switch ((/** @type {?} */ (updateRequired))) { | ||
case UpdateType.Update: | ||
this.update(); | ||
break; | ||
case UpdateType.Refresh: | ||
case UpdateType.Default: | ||
this.refresh(); | ||
break; | ||
} | ||
@@ -611,3 +632,3 @@ } | ||
throw new Error(`ng-charts configuration error, | ||
data or datasets field are required to render char ${this.chartType}`); | ||
data or datasets field are required to render chart ${this.chartType}`); | ||
} | ||
@@ -614,0 +635,0 @@ return datasets; |
@@ -238,2 +238,11 @@ import { __spread } from 'tslib'; | ||
*/ | ||
/** @enum {number} */ | ||
var UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
var BaseChartDirective = /** @class */ (function () { | ||
@@ -319,3 +328,11 @@ function BaseChartDirective(element, themeService) { | ||
/** @type {?} */ | ||
var updateRequired = false; | ||
var updateRequired_1 = UpdateType.Default; | ||
/** @type {?} */ | ||
var wantUpdate = (/** | ||
* @param {?} x | ||
* @return {?} | ||
*/ | ||
function (x) { | ||
updateRequired_1 = x > updateRequired_1 ? x : updateRequired_1; | ||
}); | ||
// Check if the changes are in the data or datasets or labels or legend | ||
@@ -329,7 +346,7 @@ if (changes.hasOwnProperty('data') || changes.hasOwnProperty('datasets')) { | ||
} | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (changes.hasOwnProperty('labels')) { | ||
this.chart.data.labels = changes.labels.currentValue; | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
@@ -339,11 +356,15 @@ if (changes.hasOwnProperty('legend')) { | ||
this.chart.generateLegend(); | ||
updateRequired = true; | ||
wantUpdate(UpdateType.Update); | ||
} | ||
if (updateRequired) { | ||
// ... if so, update chart | ||
this.chart.update(); | ||
if (changes.hasOwnProperty('options')) { | ||
wantUpdate(UpdateType.Refresh); | ||
} | ||
else { | ||
// otherwise rebuild the chart | ||
this.refresh(); | ||
switch ((/** @type {?} */ (updateRequired_1))) { | ||
case UpdateType.Update: | ||
this.update(); | ||
break; | ||
case UpdateType.Refresh: | ||
case UpdateType.Default: | ||
this.refresh(); | ||
break; | ||
} | ||
@@ -704,3 +725,3 @@ } | ||
if (!datasets) { | ||
throw new Error("ng-charts configuration error,\n data or datasets field are required to render char " + this.chartType); | ||
throw new Error("ng-charts configuration error,\n data or datasets field are required to render chart " + this.chartType); | ||
} | ||
@@ -707,0 +728,0 @@ return datasets; |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"ChartsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"BaseChartDirective"}],"imports":[],"exports":[{"__symbolic":"reference","name":"BaseChartDirective"}]}]}],"members":{}},"SingleDataSet":{"__symbolic":"interface"},"MultiDataSet":{"__symbolic":"interface"},"SingleOrMultiDataSet":{"__symbolic":"interface"},"PluginServiceGlobalRegistrationAndOptions":{"__symbolic":"interface"},"SingleLineLabel":{"__symbolic":"interface"},"MultiLineLabel":{"__symbolic":"interface"},"Label":{"__symbolic":"interface"},"BaseChartDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":27,"character":1},"arguments":[{"selector":"canvas[baseChart]","exportAs":"base-chart"}]}],"members":{"data":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"datasets":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":34,"character":3}}]}],"labels":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":35,"character":3}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"chartType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":37,"character":3}}]}],"colors":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":38,"character":3}}]}],"legend":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"plugins":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"chartClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"chartHover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":43,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":63,"character":21},{"__symbolic":"reference","name":"ThemeService"}]}],"ngOnInit":[{"__symbolic":"method"}],"themeChanged":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"update":[{"__symbolic":"method"}],"hideDataset":[{"__symbolic":"method"}],"isDatasetHidden":[{"__symbolic":"method"}],"toBase64Image":[{"__symbolic":"method"}],"getChartBuilder":[{"__symbolic":"method"}],"smartMerge":[{"__symbolic":"method"}],"isChartDataSetsArray":[{"__symbolic":"method"}],"isMultiLineLabel":[{"__symbolic":"method"}],"joinLabel":[{"__symbolic":"method"}],"updateChartData":[{"__symbolic":"method"}],"isSingleDataSet":[{"__symbolic":"method"}],"getDatasets":[{"__symbolic":"method"}],"refresh":[{"__symbolic":"method"}]}},"Color":{"__symbolic":"interface"},"Colors":{"__symbolic":"interface"},"defaultColors":[[255,99,132],[54,162,235],[255,206,86],[231,233,237],[75,192,192],[151,187,205],[220,220,220],[247,70,74],[70,191,189],[253,180,92],[148,159,177],[77,83,96]],"ThemeService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"setColorschemesOptions":[{"__symbolic":"method"}],"getColorschemesOptions":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}}},"origins":{"ChartsModule":"./lib/charts.module","SingleDataSet":"./lib/base-chart.directive","MultiDataSet":"./lib/base-chart.directive","SingleOrMultiDataSet":"./lib/base-chart.directive","PluginServiceGlobalRegistrationAndOptions":"./lib/base-chart.directive","SingleLineLabel":"./lib/base-chart.directive","MultiLineLabel":"./lib/base-chart.directive","Label":"./lib/base-chart.directive","BaseChartDirective":"./lib/base-chart.directive","Color":"./lib/color","Colors":"./lib/colors","defaultColors":"./lib/default-colors","ThemeService":"./lib/theme.service"},"importAs":"ng2-charts"} | ||
{"__symbolic":"module","version":4,"metadata":{"ChartsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"BaseChartDirective"}],"imports":[],"exports":[{"__symbolic":"reference","name":"BaseChartDirective"}]}]}],"members":{}},"SingleDataSet":{"__symbolic":"interface"},"MultiDataSet":{"__symbolic":"interface"},"SingleOrMultiDataSet":{"__symbolic":"interface"},"PluginServiceGlobalRegistrationAndOptions":{"__symbolic":"interface"},"SingleLineLabel":{"__symbolic":"interface"},"MultiLineLabel":{"__symbolic":"interface"},"Label":{"__symbolic":"interface"},"BaseChartDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":33,"character":1},"arguments":[{"selector":"canvas[baseChart]","exportAs":"base-chart"}]}],"members":{"data":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"datasets":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"labels":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":41,"character":3}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"chartType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"colors":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":44,"character":3}}]}],"legend":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"plugins":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":3}}]}],"chartClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":48,"character":3}}]}],"chartHover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":49,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":69,"character":21},{"__symbolic":"reference","name":"ThemeService"}]}],"ngOnInit":[{"__symbolic":"method"}],"themeChanged":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"update":[{"__symbolic":"method"}],"hideDataset":[{"__symbolic":"method"}],"isDatasetHidden":[{"__symbolic":"method"}],"toBase64Image":[{"__symbolic":"method"}],"getChartBuilder":[{"__symbolic":"method"}],"smartMerge":[{"__symbolic":"method"}],"isChartDataSetsArray":[{"__symbolic":"method"}],"isMultiLineLabel":[{"__symbolic":"method"}],"joinLabel":[{"__symbolic":"method"}],"updateChartData":[{"__symbolic":"method"}],"isSingleDataSet":[{"__symbolic":"method"}],"getDatasets":[{"__symbolic":"method"}],"refresh":[{"__symbolic":"method"}]}},"Color":{"__symbolic":"interface"},"Colors":{"__symbolic":"interface"},"defaultColors":[[255,99,132],[54,162,235],[255,206,86],[231,233,237],[75,192,192],[151,187,205],[220,220,220],[247,70,74],[70,191,189],[253,180,92],[148,159,177],[77,83,96]],"ThemeService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"setColorschemesOptions":[{"__symbolic":"method"}],"getColorschemesOptions":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}}},"origins":{"ChartsModule":"./lib/charts.module","SingleDataSet":"./lib/base-chart.directive","MultiDataSet":"./lib/base-chart.directive","SingleOrMultiDataSet":"./lib/base-chart.directive","PluginServiceGlobalRegistrationAndOptions":"./lib/base-chart.directive","SingleLineLabel":"./lib/base-chart.directive","MultiLineLabel":"./lib/base-chart.directive","Label":"./lib/base-chart.directive","BaseChartDirective":"./lib/base-chart.directive","Color":"./lib/color","Colors":"./lib/colors","defaultColors":"./lib/default-colors","ThemeService":"./lib/theme.service"},"importAs":"ng2-charts"} |
{ | ||
"name": "ng2-charts", | ||
"version": "2.0.3", | ||
"version": "2.0.4", | ||
"peerDependencies": { | ||
@@ -5,0 +5,0 @@ "@angular/common": "^7.2.0", |
@@ -114,3 +114,3 @@ # ng2-charts [](http://badge.fury.io/js/ng2-charts) [](https://npmjs.org/ng2-charts)  [slack](https://ngx-home.slack.com) | ||
} | ||
this.themeService.setColorschemesOptions(options); | ||
this.themeService.setColorschemesOptions(overrides); | ||
} | ||
@@ -127,2 +127,20 @@ | ||
## Schematics | ||
There are schematics that may be used to generate chart components using Angular CLI. The components are defined in package `ng2-charts-schematics`. | ||
### Installation of Schematics Package | ||
```bash | ||
npm install --save-dev ng2-charts-schematics | ||
``` | ||
### Example of Generating a Line Chart using Angular CLI | ||
```bash | ||
ng generate ng2-charts-schematics:line my-line-chart | ||
``` | ||
This calls angular's component schematics and then modifies the result, so all the options for the component schematic are also usable here. This schematics will also add the `ChartsModule` as an imported module in the main app module (or another module as specified in the `--module` command switch). | ||
## Troubleshooting | ||
@@ -129,0 +147,0 @@ |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
372172
4233
156