ng2-charts
Advanced tools
Comparing version 2.0.3 to 3.0.0-beta.2
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('chart.js'), require('@angular/core'), require('rxjs'), require('lodash')) : | ||
typeof define === 'function' && define.amd ? define('ng2-charts', ['exports', 'chart.js', '@angular/core', 'rxjs', 'lodash'], factory) : | ||
(factory((global['ng2-charts'] = {}),global.chart_js,global.ng.core,global.rxjs,global._)); | ||
}(this, (function (exports,chartJs,i0,rxjs,_) { 'use strict'; | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('rxjs'), require('lodash'), require('chart.js')) : | ||
typeof define === 'function' && define.amd ? define('ng2-charts', ['exports', '@angular/core', 'rxjs', 'lodash', 'chart.js'], factory) : | ||
(factory((global['ng2-charts'] = {}),global.ng.core,global.rxjs,global._)); | ||
}(this, (function (exports,i0,rxjs,_) { 'use strict'; | ||
@@ -21,2 +21,16 @@ /*! ***************************************************************************** | ||
***************************************************************************** */ | ||
/* global Reflect, Promise */ | ||
var extendStatics = function (d, b) { | ||
extendStatics = Object.setPrototypeOf || | ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || | ||
function (d, b) { for (var p in b) | ||
if (b.hasOwnProperty(p)) | ||
d[p] = b[p]; }; | ||
return extendStatics(d, b); | ||
}; | ||
function __extends(d, b) { | ||
extendStatics(d, b); | ||
function __() { this.constructor = d; } | ||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); | ||
} | ||
function __read(o, n) { | ||
@@ -232,2 +246,5 @@ var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
*/ | ||
/** | ||
* @template T | ||
*/ | ||
var ThemeService = /** @class */ (function () { | ||
@@ -274,2 +291,35 @@ function ThemeService() { | ||
*/ | ||
// @dynamic | ||
/** | ||
* @template T | ||
*/ | ||
var | ||
// @dynamic | ||
/** | ||
* @template T | ||
*/ | ||
AngularChart = /** @class */ (function (_super) { | ||
__extends(AngularChart, _super); | ||
function AngularChart(context, options) { | ||
return _super.call(this, context, ( /** @type {?} */(options))) || this; | ||
} | ||
return AngularChart; | ||
}(Chart)); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @enum {number} */ | ||
var UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
/** | ||
* @template T | ||
*/ | ||
var BaseChartDirective = /** @class */ (function () { | ||
@@ -290,2 +340,3 @@ function BaseChartDirective(element, themeService) { | ||
* Register a plugin. | ||
* @template T | ||
* @param {?} plugin | ||
@@ -296,2 +347,3 @@ * @return {?} | ||
* Register a plugin. | ||
* @template T | ||
* @param {?} plugin | ||
@@ -301,5 +353,6 @@ * @return {?} | ||
function (plugin) { | ||
chartJs.Chart.plugins.register(plugin); | ||
AngularChart.plugins.register(plugin); | ||
}; | ||
/** | ||
* @template T | ||
* @param {?} plugin | ||
@@ -309,2 +362,3 @@ * @return {?} | ||
BaseChartDirective.unregisterPlugin = /** | ||
* @template T | ||
* @param {?} plugin | ||
@@ -314,3 +368,3 @@ * @return {?} | ||
function (plugin) { | ||
chartJs.Chart.plugins.unregister(plugin); | ||
AngularChart.plugins.unregister(plugin); | ||
}; | ||
@@ -359,3 +413,10 @@ /** | ||
/** @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 | ||
@@ -369,7 +430,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); | ||
} | ||
@@ -379,11 +440,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; | ||
} | ||
@@ -474,4 +539,4 @@ } | ||
options.hover = options.hover || {}; | ||
if (!options.hover.onHover) { | ||
options.hover.onHover = ( /** | ||
if (!options.onHover) { | ||
options.onHover = ( /** | ||
* @param {?} event | ||
@@ -508,3 +573,3 @@ * @param {?} active | ||
}; | ||
return new chartJs.Chart(ctx, chartConfig); | ||
return new AngularChart(ctx, chartConfig); | ||
}; | ||
@@ -641,3 +706,3 @@ /** | ||
} | ||
else if (!this.isSingleDataSet(newDataValues)) { | ||
else if (this.isMultiDataSet(newDataValues)) { | ||
if (newDataValues.length === this.chart.data.datasets.length) { | ||
@@ -693,4 +758,17 @@ this.chart.data.datasets.forEach(( /** | ||
* @private | ||
* @param {?} data | ||
* @return {?} | ||
*/ | ||
BaseChartDirective.prototype.isMultiDataSet = /** | ||
* @private | ||
* @param {?} data | ||
* @return {?} | ||
*/ | ||
function (data) { | ||
return Array.isArray(data[0]); | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
BaseChartDirective.prototype.getDatasets = /** | ||
@@ -706,3 +784,3 @@ * @private | ||
if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) { | ||
if (!this.isSingleDataSet(this.data)) { | ||
if (this.isMultiDataSet(this.data)) { | ||
datasets = this.data.map(( /** | ||
@@ -817,2 +895,7 @@ * @param {?} data | ||
*/ | ||
var BaseChartMetaConfig = /** @class */ (function () { | ||
function BaseChartMetaConfig() { | ||
} | ||
return BaseChartMetaConfig; | ||
}()); | ||
@@ -823,3 +906,20 @@ /** | ||
*/ | ||
var ChartMetaConfig = /** @class */ (function (_super) { | ||
__extends(ChartMetaConfig, _super); | ||
function ChartMetaConfig() { | ||
return _super !== null && _super.apply(this, arguments) || this; | ||
} | ||
return ChartMetaConfig; | ||
}(BaseChartMetaConfig)); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
exports.ChartsModule = ChartsModule; | ||
@@ -829,2 +929,5 @@ exports.BaseChartDirective = BaseChartDirective; | ||
exports.ThemeService = ThemeService; | ||
exports.AngularChart = AngularChart; | ||
exports.BaseChartMetaConfig = BaseChartMetaConfig; | ||
exports.ChartMetaConfig = ChartMetaConfig; | ||
@@ -831,0 +934,0 @@ Object.defineProperty(exports, '__esModule', { value: true }); |
@@ -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("@angular/core"),require("rxjs"),require("lodash"),require("chart.js")):"function"==typeof define&&define.amd?define("ng2-charts",["exports","@angular/core","rxjs","lodash","chart.js"],e):e(t["ng2-charts"]={},t.ng.core,t.rxjs,t._)}(this,function(t,r,e,i){"use strict";var n=function(t,e){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var r in e)e.hasOwnProperty(r)&&(t[r]=e[r])})(t,e)};function a(t,e){function r(){this.constructor=t}n(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)}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 s=[[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 l(d(r));if("polarArea"===t)return function n(t){return{backgroundColor:t.map(function(t){return u(t,.6)}),borderColor:t.map(function(t){return u(t,1)}),hoverBackgroundColor:t.map(function(t){return u(t,.8)}),hoverBorderColor:t.map(function(t){return u(t,1)})}}(d(r));if("line"===t||"radar"===t)return function a(t){return{backgroundColor:u(t,.4),borderColor:u(t,1),pointBackgroundColor:u(t,1),pointBorderColor:"#fff",pointHoverBackgroundColor:"#fff",pointHoverBorderColor:u(t,.8)}}(f(e));if("bar"===t||"horizontalBar"===t)return function o(t){return{backgroundColor:u(t,.6),borderColor:u(t,1),hoverBackgroundColor:u(t,.8),hoverBorderColor:u(t,1)}}(f(e));if("bubble"===t)return l(d(r));if("scatter"===t)return l(d(r));throw new Error("getColors - Unsupported chart type "+t)}function u(t,e){return"rgba("+t.concat(e).join(",")+")"}function h(t,e){return Math.floor(Math.random()*(e-t+1))+t}function l(t){return{backgroundColor:t.map(function(t){return u(t,.6)}),borderColor:t.map(function(){return"#fff"}),pointBackgroundColor:t.map(function(t){return u(t,1)}),pointBorderColor:t.map(function(){return"#fff"}),pointHoverBackgroundColor:t.map(function(t){return u(t,1)}),pointHoverBorderColor:t.map(function(t){return u(t,1)})}}function p(){return[h(0,255),h(0,255),h(0,255)]}function f(t){return s[t]||p()}function d(t){for(var e=new Array(t),r=0;r<t;r++)e[r]=s[r]||p();return e}var g=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}(),y=function(r){function t(t,e){return r.call(this,t,e)||this}return a(t,r),t}(Chart),b={Default:0,Update:1,Refresh:2};b[b.Default]="Default",b[b.Update]="Update",b[b.Refresh]="Refresh";var v=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){y.plugins.register(t)},t.unregisterPlugin=function(t){y.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=b.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(b.Update)),t.hasOwnProperty("labels")&&(this.chart.data.labels=t.labels.currentValue,r(b.Update)),t.hasOwnProperty("legend")&&(this.chart.config.options.legend.display=t.legend.currentValue,this.chart.generateLegend(),r(b.Update)),t.hasOwnProperty("options")&&r(b.Refresh),e){case b.Update:this.update();break;case b.Refresh:case b.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(),n=Object.assign({},this.options);!1===this.legend&&(n.legend={display:!1}),n.hover=n.hover||{},n.onHover||(n.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 y(t,o)},t.prototype.smartMerge=function(r,n,a){var o=this;if(void 0===a&&(a=0),0===a&&(r=i.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.isMultiDataSet(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[0].data=r,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.isMultiDataSet=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.isMultiDataSet(this.data)?this.data.map(function(t,e){return{data:t,label:n.joinLabel(n.labels[e])||"Label "+e}}):[{data:this.data,label:"Label 0"}]),(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:g}]},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}(),C=function(){function t(){}return t.decorators=[{type:r.NgModule,args:[{declarations:[v],imports:[],exports:[v]}]}],t}(),m=function j(){},O=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return a(e,t),e}(m);t.ChartsModule=C,t.BaseChartDirective=v,t.defaultColors=s,t.ThemeService=g,t.AngularChart=y,t.BaseChartMetaConfig=m,t.ChartMetaConfig=O,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ng2-charts.umd.min.js.map |
@@ -6,6 +6,18 @@ /** | ||
import { Directive, Input, Output, EventEmitter, ElementRef, } from '@angular/core'; | ||
import * as chartJs from 'chart.js'; | ||
import { getColors } from './get-colors'; | ||
import { ThemeService } from './theme.service'; | ||
import * as _ from 'lodash'; | ||
import { AngularChart } from './chartjs/angular-chart'; | ||
/** @enum {number} */ | ||
const UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
/** | ||
* @template T | ||
*/ | ||
export class BaseChartDirective { | ||
@@ -27,2 +39,3 @@ /** | ||
* Register a plugin. | ||
* @template T | ||
* @param {?} plugin | ||
@@ -32,5 +45,6 @@ * @return {?} | ||
static registerPlugin(plugin) { | ||
chartJs.Chart.plugins.register(plugin); | ||
AngularChart.plugins.register(plugin); | ||
} | ||
/** | ||
* @template T | ||
* @param {?} plugin | ||
@@ -40,3 +54,3 @@ * @return {?} | ||
static unregisterPlugin(plugin) { | ||
chartJs.Chart.plugins.unregister(plugin); | ||
AngularChart.plugins.unregister(plugin); | ||
} | ||
@@ -73,3 +87,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 | ||
@@ -83,7 +105,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); | ||
} | ||
@@ -93,11 +115,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; | ||
} | ||
@@ -164,4 +190,4 @@ } | ||
options.hover = options.hover || {}; | ||
if (!options.hover.onHover) { | ||
options.hover.onHover = (/** | ||
if (!options.onHover) { | ||
options.onHover = (/** | ||
* @param {?} event | ||
@@ -200,3 +226,3 @@ * @param {?} active | ||
}; | ||
return new chartJs.Chart(ctx, chartConfig); | ||
return new AngularChart(ctx, chartConfig); | ||
} | ||
@@ -305,3 +331,3 @@ /** | ||
} | ||
else if (!this.isSingleDataSet(newDataValues)) { | ||
else if (this.isMultiDataSet(newDataValues)) { | ||
if (newDataValues.length === this.chart.data.datasets.length) { | ||
@@ -355,4 +381,12 @@ this.chart.data.datasets.forEach((/** | ||
* @private | ||
* @param {?} data | ||
* @return {?} | ||
*/ | ||
isMultiDataSet(data) { | ||
return Array.isArray(data[0]); | ||
} | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
getDatasets() { | ||
@@ -363,3 +397,3 @@ /** @type {?} */ | ||
if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) { | ||
if (!this.isSingleDataSet(this.data)) { | ||
if (this.isMultiDataSet(this.data)) { | ||
datasets = this.data.map((/** | ||
@@ -490,2 +524,2 @@ * @param {?} data | ||
} | ||
//# 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 { 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\nimport { BaseChartMetaConfig } from './chartjs/base-chart-meta-config';\r\nimport { PluginServiceGlobalRegistration } from './chartjs/plugin-service-global-registration';\r\nimport { PluginServiceRegistrationOptions } from './chartjs/plugin-service-registration-options';\r\nimport { ChartOptions } from './chartjs/chart-options';\r\nimport { ChartConfiguration } from './chartjs/chart-configuration';\r\nimport { ChartDataSetsUnion } from './chartjs/chart-data-sets-union';\r\nimport { AngularChart } from './chartjs/angular-chart';\r\n\r\nexport type SingleDataSet<T extends BaseChartMetaConfig> = T['datasetTypes']['data'];\r\nexport type MultiDataSet<T extends BaseChartMetaConfig> = Array<T['datasetTypes']['data']>;\r\nexport type SingleOrMultiDataSet<T extends BaseChartMetaConfig> = SingleDataSet<T> | MultiDataSet<T>;\r\n\r\nexport type PluginServiceGlobalRegistrationAndOptions<T extends BaseChartMetaConfig> =\r\n  PluginServiceGlobalRegistration & PluginServiceRegistrationOptions<T>;\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<T extends BaseChartMetaConfig>\r\n  implements OnDestroy, OnChanges, OnInit, OnDestroy {\r\n  @Input() public data: T['datasetTypes']['data'];\r\n  @Input() public datasets: T['datasetTypes'][];\r\n  @Input() public labels: Label[];\r\n  @Input() public options: ChartOptions<T> = {};\r\n  @Input() public chartType: T['datasetTypes']['type'];\r\n  @Input() public colors: Color[];\r\n  @Input() public legend: boolean;\r\n  @Input() public plugins: PluginServiceGlobalRegistrationAndOptions<T>[];\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: AngularChart<T>;\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<T extends BaseChartMetaConfig>(plugin: PluginServiceGlobalRegistrationAndOptions<T>) {\r\n    AngularChart.plugins.register(plugin);\r\n  }\r\n\r\n  public static unregisterPlugin<T extends BaseChartMetaConfig>(plugin: PluginServiceGlobalRegistrationAndOptions<T>) {\r\n    AngularChart.plugins.unregister(plugin);\r\n  }\r\n\r\n  public constructor(\r\n    private element: ElementRef,\r\n    private themeService: ThemeService<T>,\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*/): AngularChart<T> {\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.onHover) {\r\n      options.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: ChartConfiguration<T> = {\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 AngularChart(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: T['datasetTypes']['data'] | Array<T['datasetTypes']>): v is T['datasetTypes'][] {\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: T['datasetTypes']['data'] | Array<T['datasetTypes']>): 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.isMultiDataSet(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<T>): data is SingleDataSet<T> {\r\n    return !Array.isArray(data[0]);\r\n  }\r\n\r\n  private isMultiDataSet(data: SingleOrMultiDataSet<T>): data is MultiDataSet<T> {\r\n    return Array.isArray(data[0]);\r\n  }\r\n\r\n  private getDatasets() {\r\n    let datasets: Array<T['datasetTypes']> = 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.isMultiDataSet(this.data)) {\r\n        datasets = this.data.map((data, 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: ChartDataSetsUnion, index: number) => {\r\n          const newElm: ChartDataSetsUnion = 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"]} |
@@ -8,2 +8,5 @@ /** | ||
import * as i0 from "@angular/core"; | ||
/** | ||
* @template T | ||
*/ | ||
export class ThemeService { | ||
@@ -46,2 +49,2 @@ constructor() { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJsaWIvdGhlbWUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDOztBQU12QyxNQUFNLE9BQU8sWUFBWTtJQUl2QjtRQUhRLHlCQUFvQixHQUFpQixFQUFFLENBQUM7UUFDekMsd0JBQW1CLEdBQUcsSUFBSSxlQUFlLENBQWUsRUFBRSxDQUFDLENBQUM7SUFFbkQsQ0FBQzs7Ozs7SUFFakIsc0JBQXNCLENBQUMsT0FBcUI7UUFDMUMsSUFBSSxDQUFDLG9CQUFvQixHQUFHLE9BQU8sQ0FBQztRQUNwQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3pDLENBQUM7Ozs7SUFFRCxzQkFBc0I7UUFDcEIsT0FBTyxJQUFJLENBQUMsb0JBQW9CLENBQUM7SUFDbkMsQ0FBQzs7O1lBaEJGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7Ozs7Ozs7OztJQUVDLDRDQUFnRDs7SUFDaEQsMkNBQW1FIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ2hhcnRPcHRpb25zIH0gZnJvbSAnY2hhcnQuanMnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgVGhlbWVTZXJ2aWNlIHtcclxuICBwcml2YXRlIHBDb2xvcnNjaGVtZXNPcHRpb25zOiBDaGFydE9wdGlvbnMgPSB7fTtcclxuICBwdWJsaWMgY29sb3JzY2hlbWVzT3B0aW9ucyA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Q2hhcnRPcHRpb25zPih7fSk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIHNldENvbG9yc2NoZW1lc09wdGlvbnMob3B0aW9uczogQ2hhcnRPcHRpb25zKSB7XHJcbiAgICB0aGlzLnBDb2xvcnNjaGVtZXNPcHRpb25zID0gb3B0aW9ucztcclxuICAgIHRoaXMuY29sb3JzY2hlbWVzT3B0aW9ucy5uZXh0KG9wdGlvbnMpO1xyXG4gIH1cclxuXHJcbiAgZ2V0Q29sb3JzY2hlbWVzT3B0aW9ucygpIHtcclxuICAgIHJldHVybiB0aGlzLnBDb2xvcnNjaGVtZXNPcHRpb25zO1xyXG4gIH1cclxufVxyXG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJsaWIvdGhlbWUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7OztBQU92QyxNQUFNLE9BQU8sWUFBWTtJQUl2QjtRQUhRLHlCQUFvQixHQUFvQixFQUFFLENBQUM7UUFDNUMsd0JBQW1CLEdBQUcsSUFBSSxlQUFlLENBQWtCLEVBQUUsQ0FBQyxDQUFDO0lBRXRELENBQUM7Ozs7O0lBRWpCLHNCQUFzQixDQUFDLE9BQXdCO1FBQzdDLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxPQUFPLENBQUM7UUFDcEMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN6QyxDQUFDOzs7O0lBRUQsc0JBQXNCO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDO0lBQ25DLENBQUM7OztZQWhCRixVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkI7Ozs7Ozs7Ozs7SUFFQyw0Q0FBbUQ7O0lBQ25ELDJDQUFzRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEJhc2VDaGFydE1ldGFDb25maWcgfSBmcm9tICcuL2NoYXJ0anMvYmFzZS1jaGFydC1tZXRhLWNvbmZpZyc7XHJcbmltcG9ydCB7IENoYXJ0T3B0aW9ucyB9IGZyb20gJy4vY2hhcnRqcy9jaGFydC1vcHRpb25zJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFRoZW1lU2VydmljZTxUIGV4dGVuZHMgQmFzZUNoYXJ0TWV0YUNvbmZpZz4ge1xyXG4gIHByaXZhdGUgcENvbG9yc2NoZW1lc09wdGlvbnM6IENoYXJ0T3B0aW9uczxUPiA9IHt9O1xyXG4gIHB1YmxpYyBjb2xvcnNjaGVtZXNPcHRpb25zID0gbmV3IEJlaGF2aW9yU3ViamVjdDxDaGFydE9wdGlvbnM8VD4+KHt9KTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgc2V0Q29sb3JzY2hlbWVzT3B0aW9ucyhvcHRpb25zOiBDaGFydE9wdGlvbnM8VD4pIHtcclxuICAgIHRoaXMucENvbG9yc2NoZW1lc09wdGlvbnMgPSBvcHRpb25zO1xyXG4gICAgdGhpcy5jb2xvcnNjaGVtZXNPcHRpb25zLm5leHQob3B0aW9ucyk7XHJcbiAgfVxyXG5cclxuICBnZXRDb2xvcnNjaGVtZXNPcHRpb25zKCkge1xyXG4gICAgcmV0dXJuIHRoaXMucENvbG9yc2NoZW1lc09wdGlvbnM7XHJcbiAgfVxyXG59XHJcbiJdfQ== |
@@ -8,3 +8,3 @@ /** | ||
*/ | ||
export { ChartsModule, BaseChartDirective, defaultColors, ThemeService } from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmcyLWNoYXJ0cy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJuZzItY2hhcnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSw4RUFBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0= | ||
export { ChartsModule, BaseChartDirective, defaultColors, ThemeService, AngularChart, BaseChartMetaConfig, ChartMetaConfig } from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmcyLWNoYXJ0cy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJuZzItY2hhcnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxrSUFBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG5cbmV4cG9ydCB7Q2hhcnRDb25maWd1cmF0aW9uIGFzIMm1YX0gZnJvbSAnLi9saWIvY2hhcnRqcy9jaGFydC1jb25maWd1cmF0aW9uJzsiXX0= |
@@ -14,2 +14,24 @@ /** | ||
export { ThemeService } from './lib/theme.service'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSw2QkFBYyxxQkFBcUIsQ0FBQztBQUNwQyxtQ0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxlQUFjLGFBQWEsQ0FBQztBQUM1QixlQUFjLGNBQWMsQ0FBQztBQUM3Qiw4QkFBYyxzQkFBc0IsQ0FBQztBQUNyQyw2QkFBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuZzItY2hhcnRzXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhcnRzLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Jhc2UtY2hhcnQuZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sb3InO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2xvcnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZWZhdWx0LWNvbG9ycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RoZW1lLnNlcnZpY2UnO1xyXG4iXX0= | ||
export { AngularChart } from './lib/chartjs/angular-chart'; | ||
export {} from './lib/chartjs/chart-options'; | ||
export {} from './lib/chartjs/chart-type'; | ||
export {} from './lib/chartjs/chart-data-sets-base'; | ||
export {} from './lib/chartjs/chart-data-sets-bar'; | ||
export {} from './lib/chartjs/chart-data-sets-bubble'; | ||
export {} from './lib/chartjs/chart-data-sets-doughnut'; | ||
export {} from './lib/chartjs/chart-data-sets-line'; | ||
export {} from './lib/chartjs/chart-data-sets-radar'; | ||
export {} from './lib/chartjs/chart-data-sets-scatter'; | ||
export {} from './lib/chartjs/chart-data-sets-union'; | ||
export { BaseChartMetaConfig } from './lib/chartjs/base-chart-meta-config'; | ||
export { ChartMetaConfig } from './lib/chartjs/chart-meta-config'; | ||
export {} from './lib/chartjs/legacy-meta-config'; | ||
export {} from './lib/chartjs/promiscuous-meta-config'; | ||
export {} from './lib/chartjs/linear-scale'; | ||
export {} from './lib/chartjs/logarithmic-scale'; | ||
export {} from './lib/chartjs/category-scale'; | ||
export {} from './lib/chartjs/cartesian-scale'; | ||
export {} from './lib/chartjs/radial-scale'; | ||
export {} from './lib/chartjs/radial-linear-scale'; | ||
export {} from './lib/chartjs/scale-union'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSw2QkFBYyxxQkFBcUIsQ0FBQztBQUNwQyxtQ0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxlQUFjLGFBQWEsQ0FBQztBQUM1QixlQUFjLGNBQWMsQ0FBQztBQUM3Qiw4QkFBYyxzQkFBc0IsQ0FBQztBQUNyQyw2QkFBYyxxQkFBcUIsQ0FBQztBQUNwQyw2QkFBYyw2QkFBNkIsQ0FBQztBQUM1QyxlQUFjLDZCQUE2QixDQUFDO0FBQzVDLGVBQWMsMEJBQTBCLENBQUM7QUFDekMsZUFBYyxvQ0FBb0MsQ0FBQztBQUNuRCxlQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGVBQWMsc0NBQXNDLENBQUM7QUFDckQsZUFBYyx3Q0FBd0MsQ0FBQztBQUN2RCxlQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGVBQWMscUNBQXFDLENBQUM7QUFDcEQsZUFBYyx1Q0FBdUMsQ0FBQztBQUN0RCxlQUFjLHFDQUFxQyxDQUFDO0FBQ3BELG9DQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGdDQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGVBQWMsa0NBQWtDLENBQUM7QUFDakQsZUFBYyx1Q0FBdUMsQ0FBQztBQUN0RCxlQUFjLDRCQUE0QixDQUFDO0FBQzNDLGVBQWMsaUNBQWlDLENBQUM7QUFDaEQsZUFBYyw4QkFBOEIsQ0FBQztBQUM3QyxlQUFjLCtCQUErQixDQUFDO0FBQzlDLGVBQWMsNEJBQTRCLENBQUM7QUFDM0MsZUFBYyxtQ0FBbUMsQ0FBQztBQUNsRCxlQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5nMi1jaGFydHNcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydHMubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFzZS1jaGFydC5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2xvcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbG9ycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RlZmF1bHQtY29sb3JzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGhlbWUuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvYW5ndWxhci1jaGFydCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtb3B0aW9ucyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtdHlwZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtZGF0YS1zZXRzLWJhc2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy1iYXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy1idWJibGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy1kb3VnaG51dCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtZGF0YS1zZXRzLWxpbmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy1yYWRhcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtZGF0YS1zZXRzLXNjYXR0ZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy11bmlvbic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvYmFzZS1jaGFydC1tZXRhLWNvbmZpZyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtbWV0YS1jb25maWcnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2xlZ2FjeS1tZXRhLWNvbmZpZyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvcHJvbWlzY3VvdXMtbWV0YS1jb25maWcnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2xpbmVhci1zY2FsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvbG9nYXJpdGhtaWMtc2NhbGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NhdGVnb3J5LXNjYWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhcnRqcy9jYXJ0ZXNpYW4tc2NhbGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL3JhZGlhbC1zY2FsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvcmFkaWFsLWxpbmVhci1zY2FsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvc2NhbGUtdW5pb24nO1xyXG4iXX0= |
@@ -7,6 +7,18 @@ /** | ||
import { Directive, Input, Output, EventEmitter, ElementRef, } from '@angular/core'; | ||
import * as chartJs from 'chart.js'; | ||
import { getColors } from './get-colors'; | ||
import { ThemeService } from './theme.service'; | ||
import * as _ from 'lodash'; | ||
import { AngularChart } from './chartjs/angular-chart'; | ||
/** @enum {number} */ | ||
var UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
/** | ||
* @template T | ||
*/ | ||
var BaseChartDirective = /** @class */ (function () { | ||
@@ -27,2 +39,3 @@ function BaseChartDirective(element, themeService) { | ||
* Register a plugin. | ||
* @template T | ||
* @param {?} plugin | ||
@@ -33,2 +46,3 @@ * @return {?} | ||
* Register a plugin. | ||
* @template T | ||
* @param {?} plugin | ||
@@ -38,5 +52,6 @@ * @return {?} | ||
function (plugin) { | ||
chartJs.Chart.plugins.register(plugin); | ||
AngularChart.plugins.register(plugin); | ||
}; | ||
/** | ||
* @template T | ||
* @param {?} plugin | ||
@@ -46,2 +61,3 @@ * @return {?} | ||
BaseChartDirective.unregisterPlugin = /** | ||
* @template T | ||
* @param {?} plugin | ||
@@ -51,3 +67,3 @@ * @return {?} | ||
function (plugin) { | ||
chartJs.Chart.plugins.unregister(plugin); | ||
AngularChart.plugins.unregister(plugin); | ||
}; | ||
@@ -97,3 +113,11 @@ /** | ||
/** @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 | ||
@@ -107,7 +131,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); | ||
} | ||
@@ -117,11 +141,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; | ||
} | ||
@@ -213,4 +241,4 @@ } | ||
options.hover = options.hover || {}; | ||
if (!options.hover.onHover) { | ||
options.hover.onHover = (/** | ||
if (!options.onHover) { | ||
options.onHover = (/** | ||
* @param {?} event | ||
@@ -249,3 +277,3 @@ * @param {?} active | ||
}; | ||
return new chartJs.Chart(ctx, chartConfig); | ||
return new AngularChart(ctx, chartConfig); | ||
}; | ||
@@ -383,3 +411,3 @@ /** | ||
} | ||
else if (!this.isSingleDataSet(newDataValues)) { | ||
else if (this.isMultiDataSet(newDataValues)) { | ||
if (newDataValues.length === this.chart.data.datasets.length) { | ||
@@ -438,4 +466,17 @@ this.chart.data.datasets.forEach((/** | ||
* @private | ||
* @param {?} data | ||
* @return {?} | ||
*/ | ||
BaseChartDirective.prototype.isMultiDataSet = /** | ||
* @private | ||
* @param {?} data | ||
* @return {?} | ||
*/ | ||
function (data) { | ||
return Array.isArray(data[0]); | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
BaseChartDirective.prototype.getDatasets = /** | ||
@@ -451,3 +492,3 @@ * @private | ||
if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) { | ||
if (!this.isSingleDataSet(this.data)) { | ||
if (this.isMultiDataSet(this.data)) { | ||
datasets = this.data.map((/** | ||
@@ -583,2 +624,2 @@ * @param {?} data | ||
} | ||
//# 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 { 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\nimport { BaseChartMetaConfig } from './chartjs/base-chart-meta-config';\r\nimport { PluginServiceGlobalRegistration } from './chartjs/plugin-service-global-registration';\r\nimport { PluginServiceRegistrationOptions } from './chartjs/plugin-service-registration-options';\r\nimport { ChartOptions } from './chartjs/chart-options';\r\nimport { ChartConfiguration } from './chartjs/chart-configuration';\r\nimport { ChartDataSetsUnion } from './chartjs/chart-data-sets-union';\r\nimport { AngularChart } from './chartjs/angular-chart';\r\n\r\nexport type SingleDataSet<T extends BaseChartMetaConfig> = T['datasetTypes']['data'];\r\nexport type MultiDataSet<T extends BaseChartMetaConfig> = Array<T['datasetTypes']['data']>;\r\nexport type SingleOrMultiDataSet<T extends BaseChartMetaConfig> = SingleDataSet<T> | MultiDataSet<T>;\r\n\r\nexport type PluginServiceGlobalRegistrationAndOptions<T extends BaseChartMetaConfig> =\r\n  PluginServiceGlobalRegistration & PluginServiceRegistrationOptions<T>;\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<T extends BaseChartMetaConfig>\r\n  implements OnDestroy, OnChanges, OnInit, OnDestroy {\r\n  @Input() public data: T['datasetTypes']['data'];\r\n  @Input() public datasets: T['datasetTypes'][];\r\n  @Input() public labels: Label[];\r\n  @Input() public options: ChartOptions<T> = {};\r\n  @Input() public chartType: T['datasetTypes']['type'];\r\n  @Input() public colors: Color[];\r\n  @Input() public legend: boolean;\r\n  @Input() public plugins: PluginServiceGlobalRegistrationAndOptions<T>[];\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: AngularChart<T>;\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<T extends BaseChartMetaConfig>(plugin: PluginServiceGlobalRegistrationAndOptions<T>) {\r\n    AngularChart.plugins.register(plugin);\r\n  }\r\n\r\n  public static unregisterPlugin<T extends BaseChartMetaConfig>(plugin: PluginServiceGlobalRegistrationAndOptions<T>) {\r\n    AngularChart.plugins.unregister(plugin);\r\n  }\r\n\r\n  public constructor(\r\n    private element: ElementRef,\r\n    private themeService: ThemeService<T>,\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*/): AngularChart<T> {\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.onHover) {\r\n      options.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: ChartConfiguration<T> = {\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 AngularChart(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: T['datasetTypes']['data'] | Array<T['datasetTypes']>): v is T['datasetTypes'][] {\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: T['datasetTypes']['data'] | Array<T['datasetTypes']>): 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.isMultiDataSet(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<T>): data is SingleDataSet<T> {\r\n    return !Array.isArray(data[0]);\r\n  }\r\n\r\n  private isMultiDataSet(data: SingleOrMultiDataSet<T>): data is MultiDataSet<T> {\r\n    return Array.isArray(data[0]);\r\n  }\r\n\r\n  private getDatasets() {\r\n    let datasets: Array<T['datasetTypes']> = 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.isMultiDataSet(this.data)) {\r\n        datasets = this.data.map((data, 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: ChartDataSetsUnion, index: number) => {\r\n          const newElm: ChartDataSetsUnion = 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"]} |
@@ -8,2 +8,5 @@ /** | ||
import * as i0 from "@angular/core"; | ||
/** | ||
* @template T | ||
*/ | ||
var ThemeService = /** @class */ (function () { | ||
@@ -55,2 +58,2 @@ function ThemeService() { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJsaWIvdGhlbWUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDOztBQUd2QztJQU9FO1FBSFEseUJBQW9CLEdBQWlCLEVBQUUsQ0FBQztRQUN6Qyx3QkFBbUIsR0FBRyxJQUFJLGVBQWUsQ0FBZSxFQUFFLENBQUMsQ0FBQztJQUVuRCxDQUFDOzs7OztJQUVqQiw2Q0FBc0I7Ozs7SUFBdEIsVUFBdUIsT0FBcUI7UUFDMUMsSUFBSSxDQUFDLG9CQUFvQixHQUFHLE9BQU8sQ0FBQztRQUNwQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3pDLENBQUM7Ozs7SUFFRCw2Q0FBc0I7OztJQUF0QjtRQUNFLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDO0lBQ25DLENBQUM7O2dCQWhCRixVQUFVLFNBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzs7Ozt1QkFORDtDQXFCQyxBQWpCRCxJQWlCQztTQWRZLFlBQVk7Ozs7OztJQUN2Qiw0Q0FBZ0Q7O0lBQ2hELDJDQUFtRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IENoYXJ0T3B0aW9ucyB9IGZyb20gJ2NoYXJ0LmpzJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFRoZW1lU2VydmljZSB7XHJcbiAgcHJpdmF0ZSBwQ29sb3JzY2hlbWVzT3B0aW9uczogQ2hhcnRPcHRpb25zID0ge307XHJcbiAgcHVibGljIGNvbG9yc2NoZW1lc09wdGlvbnMgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PENoYXJ0T3B0aW9ucz4oe30pO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBzZXRDb2xvcnNjaGVtZXNPcHRpb25zKG9wdGlvbnM6IENoYXJ0T3B0aW9ucykge1xyXG4gICAgdGhpcy5wQ29sb3JzY2hlbWVzT3B0aW9ucyA9IG9wdGlvbnM7XHJcbiAgICB0aGlzLmNvbG9yc2NoZW1lc09wdGlvbnMubmV4dChvcHRpb25zKTtcclxuICB9XHJcblxyXG4gIGdldENvbG9yc2NoZW1lc09wdGlvbnMoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5wQ29sb3JzY2hlbWVzT3B0aW9ucztcclxuICB9XHJcbn1cclxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJsaWIvdGhlbWUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7OztBQUl2QztJQU9FO1FBSFEseUJBQW9CLEdBQW9CLEVBQUUsQ0FBQztRQUM1Qyx3QkFBbUIsR0FBRyxJQUFJLGVBQWUsQ0FBa0IsRUFBRSxDQUFDLENBQUM7SUFFdEQsQ0FBQzs7Ozs7SUFFakIsNkNBQXNCOzs7O0lBQXRCLFVBQXVCLE9BQXdCO1FBQzdDLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxPQUFPLENBQUM7UUFDcEMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN6QyxDQUFDOzs7O0lBRUQsNkNBQXNCOzs7SUFBdEI7UUFDRSxPQUFPLElBQUksQ0FBQyxvQkFBb0IsQ0FBQztJQUNuQyxDQUFDOztnQkFoQkYsVUFBVSxTQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7Ozs7dUJBUEQ7Q0FzQkMsQUFqQkQsSUFpQkM7U0FkWSxZQUFZOzs7Ozs7SUFDdkIsNENBQW1EOztJQUNuRCwyQ0FBc0UiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBCYXNlQ2hhcnRNZXRhQ29uZmlnIH0gZnJvbSAnLi9jaGFydGpzL2Jhc2UtY2hhcnQtbWV0YS1jb25maWcnO1xyXG5pbXBvcnQgeyBDaGFydE9wdGlvbnMgfSBmcm9tICcuL2NoYXJ0anMvY2hhcnQtb3B0aW9ucyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUaGVtZVNlcnZpY2U8VCBleHRlbmRzIEJhc2VDaGFydE1ldGFDb25maWc+IHtcclxuICBwcml2YXRlIHBDb2xvcnNjaGVtZXNPcHRpb25zOiBDaGFydE9wdGlvbnM8VD4gPSB7fTtcclxuICBwdWJsaWMgY29sb3JzY2hlbWVzT3B0aW9ucyA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Q2hhcnRPcHRpb25zPFQ+Pih7fSk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIHNldENvbG9yc2NoZW1lc09wdGlvbnMob3B0aW9uczogQ2hhcnRPcHRpb25zPFQ+KSB7XHJcbiAgICB0aGlzLnBDb2xvcnNjaGVtZXNPcHRpb25zID0gb3B0aW9ucztcclxuICAgIHRoaXMuY29sb3JzY2hlbWVzT3B0aW9ucy5uZXh0KG9wdGlvbnMpO1xyXG4gIH1cclxuXHJcbiAgZ2V0Q29sb3JzY2hlbWVzT3B0aW9ucygpIHtcclxuICAgIHJldHVybiB0aGlzLnBDb2xvcnNjaGVtZXNPcHRpb25zO1xyXG4gIH1cclxufVxyXG4iXX0= |
@@ -8,3 +8,3 @@ /** | ||
*/ | ||
export { ChartsModule, BaseChartDirective, defaultColors, ThemeService } from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmcyLWNoYXJ0cy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJuZzItY2hhcnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSw4RUFBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0= | ||
export { ChartsModule, BaseChartDirective, defaultColors, ThemeService, AngularChart, BaseChartMetaConfig, ChartMetaConfig } from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmcyLWNoYXJ0cy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJuZzItY2hhcnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxrSUFBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG5cbmV4cG9ydCB7Q2hhcnRDb25maWd1cmF0aW9uIGFzIMm1YX0gZnJvbSAnLi9saWIvY2hhcnRqcy9jaGFydC1jb25maWd1cmF0aW9uJzsiXX0= |
@@ -14,2 +14,24 @@ /** | ||
export { ThemeService } from './lib/theme.service'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSw2QkFBYyxxQkFBcUIsQ0FBQztBQUNwQyxtQ0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxlQUFjLGFBQWEsQ0FBQztBQUM1QixlQUFjLGNBQWMsQ0FBQztBQUM3Qiw4QkFBYyxzQkFBc0IsQ0FBQztBQUNyQyw2QkFBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuZzItY2hhcnRzXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhcnRzLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Jhc2UtY2hhcnQuZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sb3InO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2xvcnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZWZhdWx0LWNvbG9ycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RoZW1lLnNlcnZpY2UnO1xyXG4iXX0= | ||
export { AngularChart } from './lib/chartjs/angular-chart'; | ||
export {} from './lib/chartjs/chart-options'; | ||
export {} from './lib/chartjs/chart-type'; | ||
export {} from './lib/chartjs/chart-data-sets-base'; | ||
export {} from './lib/chartjs/chart-data-sets-bar'; | ||
export {} from './lib/chartjs/chart-data-sets-bubble'; | ||
export {} from './lib/chartjs/chart-data-sets-doughnut'; | ||
export {} from './lib/chartjs/chart-data-sets-line'; | ||
export {} from './lib/chartjs/chart-data-sets-radar'; | ||
export {} from './lib/chartjs/chart-data-sets-scatter'; | ||
export {} from './lib/chartjs/chart-data-sets-union'; | ||
export { BaseChartMetaConfig } from './lib/chartjs/base-chart-meta-config'; | ||
export { ChartMetaConfig } from './lib/chartjs/chart-meta-config'; | ||
export {} from './lib/chartjs/legacy-meta-config'; | ||
export {} from './lib/chartjs/promiscuous-meta-config'; | ||
export {} from './lib/chartjs/linear-scale'; | ||
export {} from './lib/chartjs/logarithmic-scale'; | ||
export {} from './lib/chartjs/category-scale'; | ||
export {} from './lib/chartjs/cartesian-scale'; | ||
export {} from './lib/chartjs/radial-scale'; | ||
export {} from './lib/chartjs/radial-linear-scale'; | ||
export {} from './lib/chartjs/scale-union'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1jaGFydHMvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSw2QkFBYyxxQkFBcUIsQ0FBQztBQUNwQyxtQ0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxlQUFjLGFBQWEsQ0FBQztBQUM1QixlQUFjLGNBQWMsQ0FBQztBQUM3Qiw4QkFBYyxzQkFBc0IsQ0FBQztBQUNyQyw2QkFBYyxxQkFBcUIsQ0FBQztBQUNwQyw2QkFBYyw2QkFBNkIsQ0FBQztBQUM1QyxlQUFjLDZCQUE2QixDQUFDO0FBQzVDLGVBQWMsMEJBQTBCLENBQUM7QUFDekMsZUFBYyxvQ0FBb0MsQ0FBQztBQUNuRCxlQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGVBQWMsc0NBQXNDLENBQUM7QUFDckQsZUFBYyx3Q0FBd0MsQ0FBQztBQUN2RCxlQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGVBQWMscUNBQXFDLENBQUM7QUFDcEQsZUFBYyx1Q0FBdUMsQ0FBQztBQUN0RCxlQUFjLHFDQUFxQyxDQUFDO0FBQ3BELG9DQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGdDQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGVBQWMsa0NBQWtDLENBQUM7QUFDakQsZUFBYyx1Q0FBdUMsQ0FBQztBQUN0RCxlQUFjLDRCQUE0QixDQUFDO0FBQzNDLGVBQWMsaUNBQWlDLENBQUM7QUFDaEQsZUFBYyw4QkFBOEIsQ0FBQztBQUM3QyxlQUFjLCtCQUErQixDQUFDO0FBQzlDLGVBQWMsNEJBQTRCLENBQUM7QUFDM0MsZUFBYyxtQ0FBbUMsQ0FBQztBQUNsRCxlQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5nMi1jaGFydHNcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydHMubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFzZS1jaGFydC5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2xvcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbG9ycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RlZmF1bHQtY29sb3JzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGhlbWUuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvYW5ndWxhci1jaGFydCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtb3B0aW9ucyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtdHlwZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtZGF0YS1zZXRzLWJhc2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy1iYXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy1idWJibGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy1kb3VnaG51dCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtZGF0YS1zZXRzLWxpbmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy1yYWRhcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtZGF0YS1zZXRzLXNjYXR0ZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NoYXJ0LWRhdGEtc2V0cy11bmlvbic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvYmFzZS1jaGFydC1tZXRhLWNvbmZpZyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvY2hhcnQtbWV0YS1jb25maWcnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2xlZ2FjeS1tZXRhLWNvbmZpZyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvcHJvbWlzY3VvdXMtbWV0YS1jb25maWcnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2xpbmVhci1zY2FsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvbG9nYXJpdGhtaWMtc2NhbGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL2NhdGVnb3J5LXNjYWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhcnRqcy9jYXJ0ZXNpYW4tc2NhbGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzL3JhZGlhbC1zY2FsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvcmFkaWFsLWxpbmVhci1zY2FsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXJ0anMvc2NhbGUtdW5pb24nO1xyXG4iXX0= |
@@ -1,5 +0,5 @@ | ||
import { Chart } from 'chart.js'; | ||
import { Injectable, NgModule, Directive, Input, Output, EventEmitter, ElementRef, defineInjectable } from '@angular/core'; | ||
import { BehaviorSubject } from 'rxjs'; | ||
import { cloneDeep } from 'lodash'; | ||
import 'chart.js'; | ||
@@ -196,2 +196,5 @@ /** | ||
*/ | ||
/** | ||
* @template T | ||
*/ | ||
class ThemeService { | ||
@@ -230,2 +233,32 @@ constructor() { | ||
*/ | ||
// @dynamic | ||
/** | ||
* @template T | ||
*/ | ||
class AngularChart extends Chart { | ||
/** | ||
* @param {?} context | ||
* @param {?} options | ||
*/ | ||
constructor(context, options) { | ||
super(context, (/** @type {?} */ (options))); | ||
} | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @enum {number} */ | ||
const UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
/** | ||
* @template T | ||
*/ | ||
class BaseChartDirective { | ||
@@ -247,2 +280,3 @@ /** | ||
* Register a plugin. | ||
* @template T | ||
* @param {?} plugin | ||
@@ -252,5 +286,6 @@ * @return {?} | ||
static registerPlugin(plugin) { | ||
Chart.plugins.register(plugin); | ||
AngularChart.plugins.register(plugin); | ||
} | ||
/** | ||
* @template T | ||
* @param {?} plugin | ||
@@ -260,3 +295,3 @@ * @return {?} | ||
static unregisterPlugin(plugin) { | ||
Chart.plugins.unregister(plugin); | ||
AngularChart.plugins.unregister(plugin); | ||
} | ||
@@ -293,3 +328,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 | ||
@@ -303,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); | ||
} | ||
@@ -313,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))) { | ||
case UpdateType.Update: | ||
this.update(); | ||
break; | ||
case UpdateType.Refresh: | ||
case UpdateType.Default: | ||
this.refresh(); | ||
break; | ||
} | ||
@@ -384,4 +431,4 @@ } | ||
options.hover = options.hover || {}; | ||
if (!options.hover.onHover) { | ||
options.hover.onHover = (/** | ||
if (!options.onHover) { | ||
options.onHover = (/** | ||
* @param {?} event | ||
@@ -420,3 +467,3 @@ * @param {?} active | ||
}; | ||
return new Chart(ctx, chartConfig); | ||
return new AngularChart(ctx, chartConfig); | ||
} | ||
@@ -525,3 +572,3 @@ /** | ||
} | ||
else if (!this.isSingleDataSet(newDataValues)) { | ||
else if (this.isMultiDataSet(newDataValues)) { | ||
if (newDataValues.length === this.chart.data.datasets.length) { | ||
@@ -575,4 +622,12 @@ this.chart.data.datasets.forEach((/** | ||
* @private | ||
* @param {?} data | ||
* @return {?} | ||
*/ | ||
isMultiDataSet(data) { | ||
return Array.isArray(data[0]); | ||
} | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
getDatasets() { | ||
@@ -583,3 +638,3 @@ /** @type {?} */ | ||
if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) { | ||
if (!this.isSingleDataSet(this.data)) { | ||
if (this.isMultiDataSet(this.data)) { | ||
datasets = this.data.map((/** | ||
@@ -703,4 +758,113 @@ * @param {?} data | ||
export { ChartsModule, BaseChartDirective, defaultColors, ThemeService }; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
class BaseChartMetaConfig { | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
class ChartMetaConfig extends BaseChartMetaConfig { | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { ChartsModule, BaseChartDirective, defaultColors, ThemeService, AngularChart, BaseChartMetaConfig, ChartMetaConfig }; | ||
//# sourceMappingURL=ng2-charts.js.map |
@@ -1,6 +0,6 @@ | ||
import { __spread } from 'tslib'; | ||
import { Chart } from 'chart.js'; | ||
import { Injectable, NgModule, EventEmitter, Directive, ElementRef, Input, Output, defineInjectable } from '@angular/core'; | ||
import { Injectable, NgModule, defineInjectable, EventEmitter, Directive, ElementRef, Input, Output } from '@angular/core'; | ||
import { BehaviorSubject } from 'rxjs'; | ||
import { cloneDeep } from 'lodash'; | ||
import 'chart.js'; | ||
import { __extends, __spread } from 'tslib'; | ||
@@ -197,2 +197,5 @@ /** | ||
*/ | ||
/** | ||
* @template T | ||
*/ | ||
var ThemeService = /** @class */ (function () { | ||
@@ -239,2 +242,35 @@ function ThemeService() { | ||
*/ | ||
// @dynamic | ||
/** | ||
* @template T | ||
*/ | ||
var | ||
// @dynamic | ||
/** | ||
* @template T | ||
*/ | ||
AngularChart = /** @class */ (function (_super) { | ||
__extends(AngularChart, _super); | ||
function AngularChart(context, options) { | ||
return _super.call(this, context, (/** @type {?} */ (options))) || this; | ||
} | ||
return AngularChart; | ||
}(Chart)); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @enum {number} */ | ||
var UpdateType = { | ||
Default: 0, | ||
Update: 1, | ||
Refresh: 2, | ||
}; | ||
UpdateType[UpdateType.Default] = 'Default'; | ||
UpdateType[UpdateType.Update] = 'Update'; | ||
UpdateType[UpdateType.Refresh] = 'Refresh'; | ||
/** | ||
* @template T | ||
*/ | ||
var BaseChartDirective = /** @class */ (function () { | ||
@@ -255,2 +291,3 @@ function BaseChartDirective(element, themeService) { | ||
* Register a plugin. | ||
* @template T | ||
* @param {?} plugin | ||
@@ -261,2 +298,3 @@ * @return {?} | ||
* Register a plugin. | ||
* @template T | ||
* @param {?} plugin | ||
@@ -266,5 +304,6 @@ * @return {?} | ||
function (plugin) { | ||
Chart.plugins.register(plugin); | ||
AngularChart.plugins.register(plugin); | ||
}; | ||
/** | ||
* @template T | ||
* @param {?} plugin | ||
@@ -274,2 +313,3 @@ * @return {?} | ||
BaseChartDirective.unregisterPlugin = /** | ||
* @template T | ||
* @param {?} plugin | ||
@@ -279,3 +319,3 @@ * @return {?} | ||
function (plugin) { | ||
Chart.plugins.unregister(plugin); | ||
AngularChart.plugins.unregister(plugin); | ||
}; | ||
@@ -325,3 +365,11 @@ /** | ||
/** @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 | ||
@@ -335,7 +383,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); | ||
} | ||
@@ -345,11 +393,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; | ||
} | ||
@@ -441,4 +493,4 @@ } | ||
options.hover = options.hover || {}; | ||
if (!options.hover.onHover) { | ||
options.hover.onHover = (/** | ||
if (!options.onHover) { | ||
options.onHover = (/** | ||
* @param {?} event | ||
@@ -477,3 +529,3 @@ * @param {?} active | ||
}; | ||
return new Chart(ctx, chartConfig); | ||
return new AngularChart(ctx, chartConfig); | ||
}; | ||
@@ -611,3 +663,3 @@ /** | ||
} | ||
else if (!this.isSingleDataSet(newDataValues)) { | ||
else if (this.isMultiDataSet(newDataValues)) { | ||
if (newDataValues.length === this.chart.data.datasets.length) { | ||
@@ -666,4 +718,17 @@ this.chart.data.datasets.forEach((/** | ||
* @private | ||
* @param {?} data | ||
* @return {?} | ||
*/ | ||
BaseChartDirective.prototype.isMultiDataSet = /** | ||
* @private | ||
* @param {?} data | ||
* @return {?} | ||
*/ | ||
function (data) { | ||
return Array.isArray(data[0]); | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
BaseChartDirective.prototype.getDatasets = /** | ||
@@ -679,3 +744,3 @@ * @private | ||
if (!this.datasets || !this.datasets.length && (this.data && this.data.length)) { | ||
if (!this.isSingleDataSet(this.data)) { | ||
if (this.isMultiDataSet(this.data)) { | ||
datasets = this.data.map((/** | ||
@@ -806,4 +871,121 @@ * @param {?} data | ||
export { ChartsModule, BaseChartDirective, defaultColors, ThemeService }; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
var BaseChartMetaConfig = /** @class */ (function () { | ||
function BaseChartMetaConfig() { | ||
} | ||
return BaseChartMetaConfig; | ||
}()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
var ChartMetaConfig = /** @class */ (function (_super) { | ||
__extends(ChartMetaConfig, _super); | ||
function ChartMetaConfig() { | ||
return _super !== null && _super.apply(this, arguments) || this; | ||
} | ||
return ChartMetaConfig; | ||
}(BaseChartMetaConfig)); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { ChartsModule, BaseChartDirective, defaultColors, ThemeService, AngularChart, BaseChartMetaConfig, ChartMetaConfig }; | ||
//# sourceMappingURL=ng2-charts.js.map |
import { OnDestroy, OnChanges, OnInit, EventEmitter, ElementRef, SimpleChanges } from '@angular/core'; | ||
import * as chartJs from 'chart.js'; | ||
import { Color } from './color'; | ||
import { ThemeService } from './theme.service'; | ||
export declare type SingleDataSet = (number[] | chartJs.ChartPoint[]); | ||
export declare type MultiDataSet = (number[] | chartJs.ChartPoint[])[]; | ||
export declare type SingleOrMultiDataSet = SingleDataSet | MultiDataSet; | ||
export declare type PluginServiceGlobalRegistrationAndOptions = chartJs.PluginServiceGlobalRegistration & chartJs.PluginServiceRegistrationOptions; | ||
import { BaseChartMetaConfig } from './chartjs/base-chart-meta-config'; | ||
import { PluginServiceGlobalRegistration } from './chartjs/plugin-service-global-registration'; | ||
import { PluginServiceRegistrationOptions } from './chartjs/plugin-service-registration-options'; | ||
import { ChartOptions } from './chartjs/chart-options'; | ||
import { AngularChart } from './chartjs/angular-chart'; | ||
export declare type SingleDataSet<T extends BaseChartMetaConfig> = T['datasetTypes']['data']; | ||
export declare type MultiDataSet<T extends BaseChartMetaConfig> = Array<T['datasetTypes']['data']>; | ||
export declare type SingleOrMultiDataSet<T extends BaseChartMetaConfig> = SingleDataSet<T> | MultiDataSet<T>; | ||
export declare type PluginServiceGlobalRegistrationAndOptions<T extends BaseChartMetaConfig> = PluginServiceGlobalRegistration & PluginServiceRegistrationOptions<T>; | ||
export declare type SingleLineLabel = string; | ||
export declare type MultiLineLabel = string[]; | ||
export declare type Label = SingleLineLabel | MultiLineLabel; | ||
export declare class BaseChartDirective implements OnDestroy, OnChanges, OnInit, OnDestroy { | ||
export declare class BaseChartDirective<T extends BaseChartMetaConfig> implements OnDestroy, OnChanges, OnInit, OnDestroy { | ||
private element; | ||
private themeService; | ||
data: SingleOrMultiDataSet; | ||
datasets: chartJs.ChartDataSets[]; | ||
data: T['datasetTypes']['data']; | ||
datasets: T['datasetTypes'][]; | ||
labels: Label[]; | ||
options: chartJs.ChartOptions; | ||
chartType: chartJs.ChartType; | ||
options: ChartOptions<T>; | ||
chartType: T['datasetTypes']['type']; | ||
colors: Color[]; | ||
legend: boolean; | ||
plugins: PluginServiceGlobalRegistrationAndOptions[]; | ||
plugins: PluginServiceGlobalRegistrationAndOptions<T>[]; | ||
chartClick: EventEmitter<{ | ||
@@ -32,3 +36,3 @@ event?: MouseEvent; | ||
ctx: string; | ||
chart: Chart; | ||
chart: AngularChart<T>; | ||
private initFlag; | ||
@@ -39,5 +43,5 @@ private subs; | ||
*/ | ||
static registerPlugin(plugin: PluginServiceGlobalRegistrationAndOptions): void; | ||
static unregisterPlugin(plugin: PluginServiceGlobalRegistrationAndOptions): void; | ||
constructor(element: ElementRef, themeService: ThemeService); | ||
static registerPlugin<T extends BaseChartMetaConfig>(plugin: PluginServiceGlobalRegistrationAndOptions<T>): void; | ||
static unregisterPlugin<T extends BaseChartMetaConfig>(plugin: PluginServiceGlobalRegistrationAndOptions<T>): void; | ||
constructor(element: ElementRef, themeService: ThemeService<T>); | ||
ngOnInit(): void; | ||
@@ -51,3 +55,3 @@ private themeChanged; | ||
toBase64Image(): string; | ||
getChartBuilder(ctx: string): Chart; | ||
getChartBuilder(ctx: string): AngularChart<T>; | ||
smartMerge(options: any, overrides: any, level?: number): any; | ||
@@ -59,4 +63,5 @@ private isChartDataSetsArray; | ||
private isSingleDataSet; | ||
private isMultiDataSet; | ||
private getDatasets; | ||
private refresh; | ||
} |
import { BehaviorSubject } from 'rxjs'; | ||
import { ChartOptions } from 'chart.js'; | ||
export declare class ThemeService { | ||
import { BaseChartMetaConfig } from './chartjs/base-chart-meta-config'; | ||
import { ChartOptions } from './chartjs/chart-options'; | ||
export declare class ThemeService<T extends BaseChartMetaConfig> { | ||
private pColorschemesOptions; | ||
colorschemesOptions: BehaviorSubject<ChartOptions>; | ||
colorschemesOptions: BehaviorSubject<ChartOptions<T>>; | ||
constructor(); | ||
setColorschemesOptions(options: ChartOptions): void; | ||
getColorschemesOptions(): ChartOptions; | ||
setColorschemesOptions(options: ChartOptions<T>): void; | ||
getColorschemesOptions(): ChartOptions<T>; | ||
} |
@@ -5,1 +5,2 @@ /** | ||
export * from './public_api'; | ||
export { ChartConfiguration as ɵa } from './lib/chartjs/chart-configuration'; |
@@ -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","arity":1,"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":40,"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":47,"character":3}}]}],"datasets":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"labels":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":49,"character":3}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":50,"character":3}}]}],"chartType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3}}]}],"colors":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":3}}]}],"legend":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":53,"character":3}}]}],"plugins":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":54,"character":3}}]}],"chartClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":56,"character":3}}]}],"chartHover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":57,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":77,"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"}],"isMultiDataSet":[{"__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","arity":1,"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":5,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"setColorschemesOptions":[{"__symbolic":"method"}],"getColorschemesOptions":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}},"AngularChart":{"__symbolic":"class","arity":1,"extends":{"__symbolic":"error","message":"Reference to non-exported class","line":13,"character":0,"context":{"className":"Chart"},"module":"./lib/chartjs/angular-chart"},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":39,"character":22,"context":{"typeName":"CanvasRenderingContext2D"},"module":"./lib/chartjs/angular-chart"},{"__symbolic":"reference","name":"ɵa"}]}]},"statics":{"pluginService":{"__symbolic":"error","message":"Variable not initialized","line":21,"character":9},"plugins":{"__symbolic":"error","message":"Variable not initialized","line":22,"character":9},"defaults":{"__symbolic":"error","message":"Variable not initialized","line":23,"character":9},"controllers":{"__symbolic":"error","message":"Variable not initialized","line":27,"character":9},"helpers":{"__symbolic":"error","message":"Variable not initialized","line":30,"character":9},"Tooltip":{"__symbolic":"error","message":"Variable not initialized","line":37,"character":9}}},"ChartOptions":{"__symbolic":"interface"},"ChartType":{"__symbolic":"interface"},"ChartDataSetsBase":{"__symbolic":"interface"},"ChartDataSetsBar":{"__symbolic":"interface"},"ChartDataSetsBubble":{"__symbolic":"interface"},"ChartDataSetsDoughnut":{"__symbolic":"interface"},"ChartDataSetsLine":{"__symbolic":"interface"},"ChartDataSetsRadar":{"__symbolic":"interface"},"ChartDataSetsScatter":{"__symbolic":"interface"},"ChartDataSetsUnion":{"__symbolic":"interface"},"BaseChartMetaConfig":{"__symbolic":"class","members":{}},"ChartMetaConfig":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"BaseChartMetaConfig"},"members":{}},"LegacyMetaConfig":{"__symbolic":"interface"},"PromiscuousMetaConfig":{"__symbolic":"interface"},"LinearScale":{"__symbolic":"interface"},"LogarithmicScale":{"__symbolic":"interface"},"CategoryScale":{"__symbolic":"interface"},"CartesianScale":{"__symbolic":"interface"},"RadialScale":{"__symbolic":"interface"},"RadialLinearScale":{"__symbolic":"interface"},"ScaleUnion":{"__symbolic":"interface"},"ɵa":{"__symbolic":"interface"}},"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","AngularChart":"./lib/chartjs/angular-chart","ChartOptions":"./lib/chartjs/chart-options","ChartType":"./lib/chartjs/chart-type","ChartDataSetsBase":"./lib/chartjs/chart-data-sets-base","ChartDataSetsBar":"./lib/chartjs/chart-data-sets-bar","ChartDataSetsBubble":"./lib/chartjs/chart-data-sets-bubble","ChartDataSetsDoughnut":"./lib/chartjs/chart-data-sets-doughnut","ChartDataSetsLine":"./lib/chartjs/chart-data-sets-line","ChartDataSetsRadar":"./lib/chartjs/chart-data-sets-radar","ChartDataSetsScatter":"./lib/chartjs/chart-data-sets-scatter","ChartDataSetsUnion":"./lib/chartjs/chart-data-sets-union","BaseChartMetaConfig":"./lib/chartjs/base-chart-meta-config","ChartMetaConfig":"./lib/chartjs/chart-meta-config","LegacyMetaConfig":"./lib/chartjs/legacy-meta-config","PromiscuousMetaConfig":"./lib/chartjs/promiscuous-meta-config","LinearScale":"./lib/chartjs/linear-scale","LogarithmicScale":"./lib/chartjs/logarithmic-scale","CategoryScale":"./lib/chartjs/category-scale","CartesianScale":"./lib/chartjs/cartesian-scale","RadialScale":"./lib/chartjs/radial-scale","RadialLinearScale":"./lib/chartjs/radial-linear-scale","ScaleUnion":"./lib/chartjs/scale-union","ɵa":"./lib/chartjs/chart-configuration"},"importAs":"ng2-charts"} |
{ | ||
"name": "ng2-charts", | ||
"version": "2.0.3", | ||
"version": "3.0.0-beta.2", | ||
"peerDependencies": { | ||
"@angular/common": "^7.2.0", | ||
"@angular/core": "^7.2.0", | ||
"chart.js": "^2.7.3", | ||
"chart.js": "^2.8.0", | ||
"rxjs": "^6.3.3" | ||
}, | ||
"dependencies": { | ||
"@types/chart.js": "^2.7.48", | ||
"lodash": "^4.17.11", | ||
@@ -13,0 +12,0 @@ "tslib": "^1.9.0" |
@@ -7,1 +7,23 @@ export * from './lib/charts.module'; | ||
export * from './lib/theme.service'; | ||
export * from './lib/chartjs/angular-chart'; | ||
export * from './lib/chartjs/chart-options'; | ||
export * from './lib/chartjs/chart-type'; | ||
export * from './lib/chartjs/chart-data-sets-base'; | ||
export * from './lib/chartjs/chart-data-sets-bar'; | ||
export * from './lib/chartjs/chart-data-sets-bubble'; | ||
export * from './lib/chartjs/chart-data-sets-doughnut'; | ||
export * from './lib/chartjs/chart-data-sets-line'; | ||
export * from './lib/chartjs/chart-data-sets-radar'; | ||
export * from './lib/chartjs/chart-data-sets-scatter'; | ||
export * from './lib/chartjs/chart-data-sets-union'; | ||
export * from './lib/chartjs/base-chart-meta-config'; | ||
export * from './lib/chartjs/chart-meta-config'; | ||
export * from './lib/chartjs/legacy-meta-config'; | ||
export * from './lib/chartjs/promiscuous-meta-config'; | ||
export * from './lib/chartjs/linear-scale'; | ||
export * from './lib/chartjs/logarithmic-scale'; | ||
export * from './lib/chartjs/category-scale'; | ||
export * from './lib/chartjs/cartesian-scale'; | ||
export * from './lib/chartjs/radial-scale'; | ||
export * from './lib/chartjs/radial-linear-scale'; | ||
export * from './lib/chartjs/scale-union'; |
@@ -13,4 +13,2 @@ # ng2-charts [](http://badge.fury.io/js/ng2-charts) [](https://npmjs.org/ng2-charts)  [slack](https://ngx-home.slack.com) | ||
Sample using ng2-charts@2.0.3 | ||
https://valor-software.com/ng2-charts/ | ||
@@ -26,3 +24,3 @@ | ||
```bash | ||
npm install ng2-charts@2.0.3 --save | ||
npm install ng2-charts --save | ||
``` | ||
@@ -116,6 +114,6 @@ 2. You need to install and include `Chart.js` library in your application (it is a peer dependency of this library) (more info can be found in the official `chart.js` [documentation](http://www.chartjs.org/docs/#getting-started)) | ||
} | ||
this.themeService.setColorschemesOptions(options); | ||
this.themeService.setColorschemesOptions(overrides); | ||
} | ||
constructor(private themeService: ThemeService) { } | ||
constructor(private themeService: ThemeService<AppChartMetaConfig>) { } | ||
@@ -129,2 +127,20 @@ setCurrentTheme(theme: Theme) { | ||
## 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 | ||
@@ -131,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
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
831214
6
350
10198
154
2
- Removed@types/chart.js@^2.7.48
- Removed@types/chart.js@2.9.41(transitive)