UNPKG

@opitzconsulting/pie-chart

Version:
902 lines (901 loc) 85.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Component, Input, ElementRef, Output, EventEmitter } from '@angular/core'; import * as d3 from 'd3'; /** * chart item properties * @record */ export function PieChartData() { } function PieChartData_tsickle_Closure_declarations() { /** * value of item * @type {?} */ PieChartData.prototype.value; /** * caption of item (must be unique) * @type {?} */ PieChartData.prototype.caption; /** * optional color of item (if not set, generated automatically) * @type {?|undefined} */ PieChartData.prototype.color; } /** * internal chart item properties * @record */ export function InternalPieChartData() { } function InternalPieChartData_tsickle_Closure_declarations() { /** * svg path for item * @type {?|undefined} */ InternalPieChartData.prototype.path; /** * delete flag for removing after transition * @type {?|undefined} */ InternalPieChartData.prototype.deleted; } var PieChartComponent = /** @class */ (function () { /** * constructor * @param element */ function PieChartComponent(element) { this.element = element; /** * chart data, which should be displayed */ this.data = []; /** * chart width in pixel */ this.width = 250; /** * chart height in pixel */ this.height = 250; /** * duration of animation transition */ this.duration = 1000; /** * inner spacing in pixel, if greater than 0 it defines the radius of the empty circle in the middle */ this.innerSpacing = 0; /** * outer spacing in pixel */ this.outerSpacing = 1; /** * fired when user clicks on a chart entry */ this.chartClick = new EventEmitter(); /** * fired when user hovers a chart entry */ this.chartHover = new EventEmitter(); /** * current chart data with angle and path definitions, it will be consistent to the representation */ this.curData = []; /** * end chart data with angle and path definitions, it will representate the end state and used only for interpolation */ this.endData = []; /** * copy of last processed data, used to identify changes in ngDoCheck that Angular overlooked */ this.lastData = []; /** * Function for interrupt a running chart animation. Necessary because if transition is still active * when a new transition is started, tween factory function from previos transition will still be fired * until end of transition is reached. For entries which have a started transition the tween factory * function will be fired multiple times with different tween interpolation range! */ this.interrupt = undefined; } /** * Creates a deep copy of an variable. Do not use this function with recursive objects or * browser objects like window or document. * ToDo: should be outsourced. * @param v */ /** * Creates a deep copy of an variable. Do not use this function with recursive objects or * browser objects like window or document. * ToDo: should be outsourced. * @template T * @param {?} v * @return {?} */ PieChartComponent.prototype.deepCopy = /** * Creates a deep copy of an variable. Do not use this function with recursive objects or * browser objects like window or document. * ToDo: should be outsourced. * @template T * @param {?} v * @return {?} */ function (v) { return JSON.parse(JSON.stringify(v)); }; ; ; /** * @return {?} */ PieChartComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.tooltip = /** @type {?} */ (this.element.nativeElement.querySelector('div.pie-chart-tooltip')); }; /** * Fired when Angular (re-)sets data-bound properties. This function does not fire when changed data in bound objects or arrays. * Angular only checks references. * @param changes */ /** * Fired when Angular (re-)sets data-bound properties. This function does not fire when changed data in bound objects or arrays. * Angular only checks references. * @param {?} changes * @return {?} */ PieChartComponent.prototype.ngOnChanges = /** * Fired when Angular (re-)sets data-bound properties. This function does not fire when changed data in bound objects or arrays. * Angular only checks references. * @param {?} changes * @return {?} */ function (changes) { // check if entries in bound data property has changed this.detectDataChange(); }; ; /** * Fired during every change detection run to detect and act upon changes that Angular can't or won't detect on its own. */ /** * Fired during every change detection run to detect and act upon changes that Angular can't or won't detect on its own. * @return {?} */ PieChartComponent.prototype.ngDoCheck = /** * Fired during every change detection run to detect and act upon changes that Angular can't or won't detect on its own. * @return {?} */ function () { // check if entries in bound data property has changed this.detectDataChange(); }; ; /** * Checks whether the data property has changed. This function also check whether only an item property has * changed. In case of change the chart will be rendered. */ /** * Checks whether the data property has changed. This function also check whether only an item property has * changed. In case of change the chart will be rendered. * @return {?} */ PieChartComponent.prototype.detectDataChange = /** * Checks whether the data property has changed. This function also check whether only an item property has * changed. In case of change the chart will be rendered. * @return {?} */ function () { // fast check: if items were added or removed var /** @type {?} */ dataChanged = (this.data.length !== this.lastData.length); // detail check: if (dataChanged === false) { // loop all items for (var /** @type {?} */ idx = 0; idx < this.data.length; ++idx) { var /** @type {?} */ a = this.data[idx]; var /** @type {?} */ b = this.lastData[idx]; // check internal item properties dataChanged = dataChanged || (a.caption !== b.caption || a.color !== b.color || a.value !== b.value); // for optimization, stop if change detected if (dataChanged) break; } } // if change detected if (dataChanged) { // render chart this.render(); // copy current data to identify changes this.lastData = this.deepCopy(this.data); } }; ; /** * Generates a random color for a chart item. */ /** * Generates a random color for a chart item. * @param {?} value * @return {?} */ PieChartComponent.prototype.generateRandomColor = /** * Generates a random color for a chart item. * @param {?} value * @return {?} */ function (value) { var /** @type {?} */ hue2rgb = function (p, q, t) { if (t < 0) t += 1; if (t > 1) t -= 1; if (t < 1 / 6) return p + (q - p) * 6 * t; if (t < 1 / 2) return q; if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6; return p; }; // make sure, generated color does not exists yet in data array var /** @type {?} */ color; var /** @type {?} */ uniqueColorGenerated = false; while (uniqueColorGenerated === false) { var /** @type {?} */ h = (Math.random() + 0.618033988749895) % 1; var /** @type {?} */ s = .5; var /** @type {?} */ l = .6; var /** @type {?} */ q = l + s - l * s; var /** @type {?} */ p = 2 * l - q; var /** @type {?} */ r = hue2rgb(p, q, h + 1 / 3); var /** @type {?} */ g = hue2rgb(p, q, h); var /** @type {?} */ b = hue2rgb(p, q, h - 1 / 3); color = '#' + Math.round(r * 255).toString(16) + Math.round(g * 255).toString(16) + Math.round(b * 255).toString(16); uniqueColorGenerated = (this.data.map(function (d) { return d.color; }).filter(function (d) { return d === color; }).length === 0); } return color; }; ; /** * generates a pie chart item definition * @param item * @param index * @param value * @param startAngle * @param endAngle */ /** * generates a pie chart item definition * @param {?} item * @param {?} index * @param {?} value * @param {?} startAngle * @param {?} endAngle * @return {?} */ PieChartComponent.prototype.generatePieArcData = /** * generates a pie chart item definition * @param {?} item * @param {?} index * @param {?} value * @param {?} startAngle * @param {?} endAngle * @return {?} */ function (item, index, value, startAngle, endAngle) { // generate definition var /** @type {?} */ result = { data: item, index: index, value: value, startAngle: startAngle, endAngle: endAngle, padAngle: 0, innerRadius: this.radius - 40, outerRadius: this.radius }; // generate svg path d-attribute from definition (/** @type {?} */ (result.data)).path = this.pathGenerator(result); // return definition return result; }; ; /** * Checks whether items were deleted and initiate delete transition for these items. */ /** * Checks whether items were deleted and initiate delete transition for these items. * @return {?} */ PieChartComponent.prototype.detectDeletedEntries = /** * Checks whether items were deleted and initiate delete transition for these items. * @return {?} */ function () { var _this = this; // loop current state entries this.curData.forEach(function (curItem, idx) { // only check if current entry is not marked as deleted if (curItem.data.deleted !== true) { // check if entry not exists anymore var /** @type {?} */ isDeleted = (_this.data.filter(function (item) { return item.caption === curItem.data.caption; }).length === 0); // if entry is deleted if (isDeleted) { // mark entry in current state as deleted // mark entry in current state as deleted _this.curData[idx].data.deleted = true; // mark entry in end state as deleted and set value to 0 for transtion // mark entry in end state as deleted and set value to 0 for transtion _this.endData[idx].data.deleted = true; _this.endData[idx].value = 0; } } }); }; ; /** * Checks whether items were inserted and initiate insert transition for these items. */ /** * Checks whether items were inserted and initiate insert transition for these items. * @return {?} */ PieChartComponent.prototype.detectInsertedEntries = /** * Checks whether items were inserted and initiate insert transition for these items. * @return {?} */ function () { var _this = this; // loop given data array this.data.forEach(function (item, idx) { // check if entry is new var /** @type {?} */ isInserted = (_this.curData.filter(function (curItem) { return curItem.data.deleted !== true && curItem.data.caption === item.caption; }).length === 0); // if entry is new if (isInserted) { { var /** @type {?} */ d = _this.generatePieArcData(_this.deepCopy(item), idx, 0, -1, -1); _this.curData.splice(idx, 0, d); } { var /** @type {?} */ d = _this.generatePieArcData(_this.deepCopy(item), idx, item.value, -1, -1); _this.endData.splice(idx, 0, d); } } }); }; ; /** * Checks whether items were moved and initiate transition for these items. */ /** * Checks whether items were moved and initiate transition for these items. * @return {?} */ PieChartComponent.prototype.detectMovedEntries = /** * Checks whether items were moved and initiate transition for these items. * @return {?} */ function () { // separate index in current state array var /** @type {?} */ curIndex = 0; // loop data array for (var /** @type {?} */ index = 0; index < this.data.length; ++index) { // find next index in current state array, skip items marked as deleted while (this.curData[curIndex].data.deleted) ++curIndex; // check if item is moved by comparing captions if (this.data[index].caption !== this.curData[curIndex].data.caption) { { // mark item in current state array as deleted this.curData[curIndex].data.deleted = true; // mark item in end state array as deleted and set value to 0 for transition this.endData[curIndex].data.deleted = true; this.endData[curIndex].value = 0; } { var /** @type {?} */ item = this.deepCopy(this.data[index]); var /** @type {?} */ d = this.generatePieArcData(item, -1, 0, -1, -1); this.curData.splice(curIndex, 0, d); } { var /** @type {?} */ item = this.deepCopy(this.data[index]); var /** @type {?} */ d = this.generatePieArcData(item, -1, item.value, -1, -1); this.endData.splice(curIndex, 0, d); } // because of inserting item to the array's, increment index twice ++curIndex; } ++curIndex; } }; ; /** * Synchronize state arrays (curData / endData) with given items (data). */ /** * Synchronize state arrays (curData / endData) with given items (data). * @return {?} */ PieChartComponent.prototype.syncItems = /** * Synchronize state arrays (curData / endData) with given items (data). * @return {?} */ function () { var _this = this; // sync values and colors this.data.forEach(function (item, index) { // find item index in state array's var /** @type {?} */ curIndex = 0; for (var /** @type {?} */ i = 0; i < _this.curData.length; ++i) { if (!_this.curData[i].data.deleted && _this.curData[i].data.caption === item.caption) { curIndex = i; break; } } // update value in state entries // update value in state entries _this.curData[curIndex].data.value = item.value; _this.endData[curIndex].data.value = item.value; // update value in end state entry for transition // update value in end state entry for transition _this.endData[curIndex].value = item.value; // update color in end state entry for transition // update color in end state entry for transition _this.endData[curIndex].data.color = item.color; }); }; ; /** * will be triggerd to animate chart changes. * important! this method musst be called within a setTimeout function because of angulars * rendering cycle. */ /** * will be triggerd to animate chart changes. * important! this method musst be called within a setTimeout function because of angulars * rendering cycle. * @return {?} */ PieChartComponent.prototype.animateChanges = /** * will be triggerd to animate chart changes. * important! this method musst be called within a setTimeout function because of angulars * rendering cycle. * @return {?} */ function () { var _this = this; // get svg element reference var /** @type {?} */ svg = (/** @type {?} */ (this.element.nativeElement.querySelector('svg'))); // reference all path elements in svg element var /** @type {?} */ paths = d3.select(svg).selectAll('path'); // define interruption function to stop running animations this.interrupt = function () { // call paths interrupt method paths.interrupt(); // delete interupt definition delete _this.interrupt; }; // start path animation paths .transition() .duration(this.duration) .attrTween('pie-tween-dummy', function (arg0, idx, nodeList) { // create interpolation functions to calculate step values var /** @type {?} */ iValue = d3.interpolate(_this.curData[idx].value, _this.endData[idx].value); var /** @type {?} */ iStartAngle = d3.interpolate(_this.curData[idx].startAngle, _this.endData[idx].startAngle); var /** @type {?} */ iEndAngle = d3.interpolate(_this.curData[idx].endAngle, _this.endData[idx].endAngle); var /** @type {?} */ iColor = d3.interpolate(_this.curData[idx].data.color, _this.endData[idx].data.color); // return factory function for animation steps return function (t) { // interpolate values by given transition value // interpolate values by given transition value _this.curData[idx].value = iValue(t); _this.curData[idx].startAngle = iStartAngle(t); _this.curData[idx].endAngle = iEndAngle(t); _this.curData[idx].data.color = iColor(t); // generate new path // generate new path _this.curData[idx].data.path = _this.pathGenerator(_this.curData[idx]); // return empty string. This is only necessary for typescript compiler. Nothing should be changed here. return ''; }; }) .on('end', function (arg0, idx, nodeList) { // when transition is complete for the last item if (idx === nodeList.length - 1) { // remove as deleted marked entries // remove as deleted marked entries _this.cleanStateItems(); // Delete interupt definition, because everything has finished and nothing can be interrupted. delete _this.interrupt; } }); }; ; /** * Must be called after transition ends to remove entries in curData and endData which are marked * as deleted. */ /** * Must be called after transition ends to remove entries in curData and endData which are marked * as deleted. * @return {?} */ PieChartComponent.prototype.cleanStateItems = /** * Must be called after transition ends to remove entries in curData and endData which are marked * as deleted. * @return {?} */ function () { // clean current state array for (var /** @type {?} */ i = this.curData.length - 1; i >= 0; --i) { if (this.curData[i].data.deleted === true) { this.curData.splice(i, 1); } } // clean end state array for (var /** @type {?} */ i = this.endData.length - 1; i >= 0; --i) { if (this.endData[i].data.deleted === true) { this.endData.splice(i, 1); } } }; ; /** * Checks whether all items have assigned color values and if necessary completes colors in given data array. */ /** * Checks whether all items have assigned color values and if necessary completes colors in given data array. * @return {?} */ PieChartComponent.prototype.initColors = /** * Checks whether all items have assigned color values and if necessary completes colors in given data array. * @return {?} */ function () { var _this = this; // loop all entries this.data.forEach(function (item) { // if no color is assigned if (!item.color) { // generate random color for item item.color = _this.generateRandomColor(item.value); } }); }; ; /** * Returns maximal angle of current state items. */ /** * Returns maximal angle of current state items. * @return {?} */ PieChartComponent.prototype.getMaxAngle = /** * Returns maximal angle of current state items. * @return {?} */ function () { var /** @type {?} */ maxAngle = 0; this.curData.forEach(function (curItem) { if (curItem.endAngle > maxAngle) { maxAngle = curItem.endAngle; } }); return maxAngle; }; ; /** * Calculates angles for current and end state items. * @param maxAngle last maximal angle in current state to avoid "jumping" transitions */ /** * Calculates angles for current and end state items. * @param {?} maxAngle last maximal angle in current state to avoid "jumping" transitions * @return {?} */ PieChartComponent.prototype.calculateAngles = /** * Calculates angles for current and end state items. * @param {?} maxAngle last maximal angle in current state to avoid "jumping" transitions * @return {?} */ function (maxAngle) { var _this = this; { // calculate sum of values var /** @type {?} */ total_1 = this.curData.reduce(function (p, c) { return p + c.value; }, 0); // loop items and calculate start and end angles, initialize rendering var /** @type {?} */ lastAngle_1 = 0; this.curData.forEach(function (item, idx) { // calculate angles by last used maximal angle. without data (total=0) simulate 0 values, so draw items in clockwise direction. var /** @type {?} */ nextAngle = lastAngle_1 + ((maxAngle) / ((total_1 === 0) ? 1 : total_1)) * item.value; item.startAngle = lastAngle_1; item.endAngle = nextAngle; item.index = idx; item.data.path = _this.pathGenerator(item); lastAngle_1 = nextAngle; }); } { // calculate sum of values var /** @type {?} */ total_2 = this.endData.reduce(function (p, c) { return p + c.value; }, 0); // loop items and calculate start and end angles, initialize rendering var /** @type {?} */ lastAngle_2 = 0; this.endData.forEach(function (item, idx) { // calculate angles with circumference. without data (total=0) simulate 0 values, so draw items in anti-clockwise direction. var /** @type {?} */ nextAngle = lastAngle_2 + ((2 * Math.PI) / ((total_2 === 0) ? 1 : total_2)) * item.value; item.startAngle = lastAngle_2; item.endAngle = nextAngle; item.index = idx; item.data.path = _this.pathGenerator(item); lastAngle_2 = nextAngle; }); } }; ; /** * fired when mouse enters a pie chart path element and shows tooltip * @param {?} event * @return {?} */ PieChartComponent.prototype.overPath = /** * fired when mouse enters a pie chart path element and shows tooltip * @param {?} event * @return {?} */ function (event) { // get tooltip-text of path element var /** @type {?} */ txt = (/** @type {?} */ (event.target)).getAttribute('tooltip'); // show tooltip and assign text d3.select(this.tooltip) .html(txt) .style('display', 'block') .transition() .duration(250) .style('opacity', 1); // get index var /** @type {?} */ idx = parseInt((/** @type {?} */ (event.target)).getAttribute('idx'), 10); // get caption of element var /** @type {?} */ caption = this.curData[idx].data.caption; // get original data by caption var /** @type {?} */ item = this.data.filter(function (d) { return d.caption === caption; })[0]; // if data found then emit chart click event if (item) { this.chartHover.emit(item); } }; ; /** * fired when mouse moves over a pie chart path element and adjusts tooltip * @param {?} event * @return {?} */ PieChartComponent.prototype.movePath = /** * fired when mouse moves over a pie chart path element and adjusts tooltip * @param {?} event * @return {?} */ function (event) { // aggregate scroll positions, because event.page* properties are relative to top left corner of document var /** @type {?} */ offsetX = 0; var /** @type {?} */ offsetY = 0; var /** @type {?} */ element = (/** @type {?} */ (this.tooltip.parentElement)); while (element) { offsetX += element.scrollLeft; offsetY += element.scrollTop; element = element.parentElement; } // adjust tooltip d3.select(this.tooltip) .style('top', (event.pageY - offsetY + 10) + 'px') .style('left', (event.pageX - offsetX + 10) + 'px'); }; ; /** * fired when mouse leaves a pie chart path element and hides tooltip * @param {?} event * @return {?} */ PieChartComponent.prototype.outPath = /** * fired when mouse leaves a pie chart path element and hides tooltip * @param {?} event * @return {?} */ function (event) { var _this = this; // hide tooltip d3.select(this.tooltip) .transition() .duration(250) .style('opacity', 0) .on('end', function () { d3.select(_this.tooltip).style('display', 'none'); }); }; ; /** * fired when user clicks on a pie chart path element * @param {?} event * @return {?} */ PieChartComponent.prototype.clickPath = /** * fired when user clicks on a pie chart path element * @param {?} event * @return {?} */ function (event) { // get index var /** @type {?} */ idx = parseInt((/** @type {?} */ (event.target)).getAttribute('idx'), 10); // get caption of element var /** @type {?} */ caption = this.curData[idx].data.caption; // get original data by caption var /** @type {?} */ item = this.data.filter(function (d) { return d.caption === caption; })[0]; // if data found then emit chart click event if (item) { this.chartClick.emit(item); } }; ; /** * main rendering function */ /** * main rendering function * @return {?} */ PieChartComponent.prototype.render = /** * main rendering function * @return {?} */ function () { var _this = this; // interrupt possible running animations if (this.interrupt) this.interrupt(); // initialize chart colors this.initColors(); // calculate radius this.radius = Math.min(this.width, this.height) / 2; // calculate middle of chart this.center = "translate(" + this.width / 2 + ", " + this.height / 2 + ")"; // create path generator this.pathGenerator = d3.arc().outerRadius(this.radius - this.outerSpacing).innerRadius(this.innerSpacing); // get current maximal angle, necessary to avoid "jumping" transitions var /** @type {?} */ maxAngle = this.getMaxAngle(); // check data array for deleted entries and assign transition configuration this.detectDeletedEntries(); // check data array for inserted entries and assign transition configuration this.detectInsertedEntries(); // check data array for moved entries and assign transition configuration this.detectMovedEntries(); // synchronize data entries with current and end state entries this.syncItems(); // calculate angles for current and end state entries this.calculateAngles(maxAngle); // important! use setTimeout because angular first must exec change detection setTimeout(function () { // start change animations // start change animations _this.animateChanges(); }, 0); }; ; PieChartComponent.decorators = [ { type: Component, args: [{ selector: 'oc-pie-chart', template: "<div class=\"pie-chart-tooltip\"></div>\n<svg [attr.width]=\"width\" [attr.height]=\"height\">\n <g [attr.transform]=\"center\">\n <path *ngFor=\"let d of curData; let idx = index;\" [attr.idx]=\"idx\" \n [attr.fill]=\"d.data.color\" [attr.d]=\"d.data.path\" [attr.tooltip]=\"d.data.caption\"\n (mouseover)=\"overPath($event)\" (mousemove)=\"movePath($event);\" (mouseout)=\"outPath($event)\" (click)=\"clickPath($event)\" />\n </g>\n</svg>", styles: ["div.pie-chart-tooltip{position:fixed;display:none;opacity:0;font:12px sans-serif;color:#fff;background-color:rgba(35,47,52,.8);padding:5px}path{opacity:.7;stroke:#fff;stroke-width:2px}path:hover{opacity:1;stroke:#e3e3e3}"] },] }, ]; /** @nocollapse */ PieChartComponent.ctorParameters = function () { return [ { type: ElementRef } ]; }; PieChartComponent.propDecorators = { data: [{ type: Input }], width: [{ type: Input }], height: [{ type: Input }], duration: [{ type: Input }], innerSpacing: [{ type: Input }], outerSpacing: [{ type: Input }], chartClick: [{ type: Output }], chartHover: [{ type: Output }] }; return PieChartComponent; }()); export { PieChartComponent }; function PieChartComponent_tsickle_Closure_declarations() { /** * chart data, which should be displayed * @type {?} */ PieChartComponent.prototype.data; /** * chart width in pixel * @type {?} */ PieChartComponent.prototype.width; /** * chart height in pixel * @type {?} */ PieChartComponent.prototype.height; /** * duration of animation transition * @type {?} */ PieChartComponent.prototype.duration; /** * inner spacing in pixel, if greater than 0 it defines the radius of the empty circle in the middle * @type {?} */ PieChartComponent.prototype.innerSpacing; /** * outer spacing in pixel * @type {?} */ PieChartComponent.prototype.outerSpacing; /** * fired when user clicks on a chart entry * @type {?} */ PieChartComponent.prototype.chartClick; /** * fired when user hovers a chart entry * @type {?} */ PieChartComponent.prototype.chartHover; /** * pie chart radius in pixel * @type {?} */ PieChartComponent.prototype.radius; /** * transform-attribute to center chart vertical and horizontal * @type {?} */ PieChartComponent.prototype.center; /** * current chart data with angle and path definitions, it will be consistent to the representation * @type {?} */ PieChartComponent.prototype.curData; /** * end chart data with angle and path definitions, it will representate the end state and used only for interpolation * @type {?} */ PieChartComponent.prototype.endData; /** * path generator function (internal use only) * @type {?} */ PieChartComponent.prototype.pathGenerator; /** * copy of last processed data, used to identify changes in ngDoCheck that Angular overlooked * @type {?} */ PieChartComponent.prototype.lastData; /** * Function for interrupt a running chart animation. Necessary because if transition is still active * when a new transition is started, tween factory function from previos transition will still be fired * until end of transition is reached. For entries which have a started transition the tween factory * function will be fired multiple times with different tween interpolation range! * @type {?} */ PieChartComponent.prototype.interrupt; /** * reference to tooltip div element * @type {?} */ PieChartComponent.prototype.tooltip; /** @type {?} */ PieChartComponent.prototype.element; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pie-chart.component.js","sourceRoot":"ng://@opitzconsulting/pie-chart/","sources":["lib/pie-chart.component.ts"],"names":[],"mappings":"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