angular-sunburst-radar-chart
Version:
A Sunburst Radar chart with SVG,No Dependencies
408 lines • 65.7 kB
JavaScript
import { __decorate } from "tslib";
import { Component, Input } from '@angular/core';
import { createCircle, createLine, createPath } from './utils/elements';
import { createArcToWriteText, getTextForAngle, writeTextOnArc } from './utils/textelement';
import { createInnerChartBarWithInArc, createOuterChartBarWithInArc } from './utils/arc-bar-charts';
import { calculatePointBetween, getGlobalPositions } from './utils/positions';
import { distanceBetweenTwoPoints, polarToCartesian } from './utils/trignometry';
import { createLegends, createLegendWithOptions } from './utils/legend';
import { formatItems, generateRandomColor, getFormattedAngle, getOptionsOrEmpty, hashCode } from './utils/utils';
import { getAllAnglesBasedOnChild, getAllAnglesBasedOnParent, getPointsOnCircleAtAngels, positionsOnAngles } from './utils/angels';
import { createSvgHandlerWithSelector } from './utils/svg-rotator';
let AngularSunburstRadarChartComponent = class AngularSunburstRadarChartComponent {
constructor() {
this.componentDisplayed = false;
this.showToolTip = false;
this.tooltipTopInPx = '0px';
this.tooltipLeftInPx = '0px';
this.tooltipText = '';
this.svgId = null;
this.svgGroupId = null;
this.svgHandler = null;
this.currentRotationAngle = 10;
this.svgCursor = 'default';
this.initialized = false;
this.innerBorderHeight = 30;
this.outerBorderHeight = 30;
this.elements = [];
this.hasChildren = false;
this.outerBorderCircleRef = 'outerBorderCircle';
this.error = null;
this.hasError = false;
this.startRotation = false;
}
showError(msg) {
this.error = msg;
this.hasError = true;
}
hideError() {
this.error = null;
this.hasError = false;
}
appendToSvg(element) {
this.elements.push(element);
}
ngOnChanges(changes) {
this.hideError();
const isFirstChange = Object.values(changes).some(c => c.isFirstChange());
this.modifyOnFirstChange(isFirstChange);
}
modifyOnFirstChange(isFirstChange) {
if (!isFirstChange) {
this.initialize();
}
}
ngOnInit() {
this.hideError();
this.initialize();
}
initialize() {
const defaults = { size: 300, maxScore: 100, animateChart: true, splitBasedOnChildren: true, legendAxisLinePosition: 1 };
const options = Object.assign(Object.assign({}, defaults), (getOptionsOrEmpty(this.options)));
this.size = options.size;
this.maxScore = options.maxScore;
this.animateChart = options.animateChart;
this.splitBasedOnChildren = options.splitBasedOnChildren;
this.legendAxisLinePosition = options.legendAxisLinePosition;
if (!this.hasValidParameters()) {
this.showError('Input Values not set or Items was improper');
return;
}
this.initialized = false;
this.svgId = 'svg' + hashCode(this.items);
this.svgGroupId = 'svg-group' + hashCode(this.items);
this.viewBox = '0 0 ' + this.size + ' ' + this.size;
this.innerCircleRadius = Math.abs(this.size / 5.33);
this.innerBorderHeight = this.innerCircleRadius / 5;
this.outerBorderHeight = this.innerCircleRadius / 5;
this.globalPosition = getGlobalPositions({
size: this.size,
maxScore: this.maxScore,
items: this.items
});
this.hasChildren = this.items.filter(item => !!item.children).length > 0;
this.drawLayout();
const { innerRadius, innerTextRadius, textSize, outerTextSize, outerRadiusBorder, outerTextRadius, center } = this.globalPosition;
const [centerX, centerY] = [center.x, center.y];
let items = this.items;
let allAngels = [];
const hasChildren = this.hasChildren;
if (this.splitBasedOnChildren) {
// Cannot have no children
items = formatItems(items);
allAngels = getAllAnglesBasedOnChild(items);
}
else {
allAngels = getAllAnglesBasedOnParent(items);
}
const angleDifference = 360 / items.length;
const angles = allAngels.map(value => value.startDegree);
const middleAngles = allAngels.map(value => value.middleDegree);
const points = positionsOnAngles(centerX, centerY, this.chartBorder, angles);
const lines = [];
let elements = [];
let nextLevelElements = [];
for (let i = 0; i < points.length; i++) {
const { x, y } = points[i];
let endAngleIndex = i + 1;
if (endAngleIndex >= points.length) {
endAngleIndex = 0;
}
const endAngle = angles[endAngleIndex];
const startAngle = angles[i];
const middleAngle = middleAngles[i];
let item = items[i];
if (!!item.color === false) {
const colorDefaults = {
color: generateRandomColor()
};
item = Object.assign(Object.assign({}, colorDefaults), item);
}
if (this.hasChildren && item.children && item.children.length > 0) {
const childAngels = allAngels[i].children;
nextLevelElements = nextLevelElements.concat(this.drawOnLevel({
items: item.children,
totalDegrees: angleDifference,
childAngels,
color: item.color
}));
}
lines.push(createLine({ x1: centerX, y1: centerY, x2: x, y2: y, width: 2 }));
// Create Arc for inner values
const barWithinArc = createInnerChartBarWithInArc({
startPoint: center,
item,
radius: innerRadius,
startAngle,
endAngle,
maxScore: this.maxScore
});
elements.push(barWithinArc);
const innerTextElements = this.addArcText({
arcForTextId: 'arc-text-inner' + this.getUniqueCode() + '-' + i,
radius: innerTextRadius,
fontSize: textSize,
startAngle,
endAngle,
perAngle: angleDifference,
item
});
elements = elements.concat(innerTextElements);
if (hasChildren) {
elements.push(this.drawOuterBackgroundWithMiddle({ item, startAngle, middleAngle, endAngle }));
const outerBackgroundTextElements = this.addArcText({
arcForTextId: 'arc-text-outer' + this.getUniqueCode() + '-' + i,
radius: outerTextRadius,
fontSize: outerTextSize,
perAngle: angleDifference,
startAngle,
endAngle,
item
});
elements = elements.concat(outerBackgroundTextElements);
}
}
nextLevelElements.forEach(line => {
this.appendToSvg(line);
});
this.drawInnerBorders();
elements.forEach(line => {
this.appendToSvg(line);
});
lines.forEach(line => {
this.appendToSvg(line);
});
const legendAxisIndex = this.getLegendAxisIndex(angles);
this.drawLegends(angles[legendAxisIndex]);
this.addSmallCirclesAtCenter(centerX, centerY);
this.initialized = true;
this.currentRotationAngle = 10;
this.rotationPoint = getFormattedAngle(this.currentRotationAngle, center);
}
getLegendAxisIndex(angles) {
let legendAxisIndex = this.legendAxisLinePosition - 1;
if (legendAxisIndex < 0 || legendAxisIndex >= angles.length) {
legendAxisIndex = 0;
}
return legendAxisIndex;
}
hasValidParameters() {
return this.items && this.items.length > 1;
}
drawOuterBackgroundWithMiddle({ item, startAngle, middleAngle, endAngle }) {
const color = item.color;
const { outerTextRadius, center } = this.globalPosition;
const [centerX, centerY] = [center.x, center.y];
const middleCircle = calculatePointBetween({ centerX, centerY, startAngle, middleAngle, endAngle, radius: outerTextRadius });
const d = [
'M', middleCircle.start.x, middleCircle.start.y,
'A', outerTextRadius, outerTextRadius, 0, 0, 1, middleCircle.end.x, middleCircle.end.y
];
const title = item.name + '-' + item.value;
const strokeWidth = 0.0775 * this.size;
return createPath({ d: d.join(' '), stroke: color, 'stroke-width': strokeWidth, title });
}
drawOnLevel({ items, totalDegrees, childAngels, color }) {
const { innerRadiusBorder, middleRadius, textSize, middleTextRadius, center } = this.globalPosition;
const [centerX, centerY] = [center.x, center.y];
const angles = childAngels.map(item => item.startDegree);
const middleAngles = childAngels.map(item => item.middleDegree);
const endAngles = childAngels.map(item => item.endDegree);
const perAngle = totalDegrees / items.length;
const pointsOnInnerRadiusBorder = getPointsOnCircleAtAngels(centerX, centerY, innerRadiusBorder, angles);
const pointsOnMiddle = getPointsOnCircleAtAngels(centerX, centerY, middleRadius, angles);
let elements = [];
const lines = [];
let currentDegree = angles[0];
for (let i = 0; i < pointsOnInnerRadiusBorder.length; i++) {
const pointOnInnerRadiusBorder = pointsOnInnerRadiusBorder[i];
const pointOnMiddle = pointsOnMiddle[i];
lines.push(createLine({
x1: pointOnInnerRadiusBorder.x, y1: pointOnInnerRadiusBorder.y,
x2: pointOnMiddle.x, y2: pointOnMiddle.y, width: 0.5
}));
const startAngle = angles[i];
const middleAngle = middleAngles[i];
const endAngle = endAngles[i];
const item = items[i];
const params = {
startPoint: pointOnInnerRadiusBorder,
item,
startAngle,
endAngle,
middleAngle,
middleRadius,
innerRadiusBorder,
center,
maxScore: this.maxScore,
color,
index: i
};
const arcForChart = createOuterChartBarWithInArc(params);
elements.push(arcForChart);
const middleTextElements = this.addArcText({
arcForTextId: 'arc-text-middle' + this.getUniqueCode() + '-' + startAngle + i,
radius: middleTextRadius,
fontSize: textSize,
perAngle,
startAngle,
endAngle,
item
});
elements = elements.concat(middleTextElements);
currentDegree = currentDegree + perAngle;
}
lines.forEach(line => {
elements.push(line);
});
return elements;
}
getUniqueCode() {
return hashCode(this.items) + '-' + this.size;
}
drawInnerBorders() {
const { innerRadius, innerRadiusBorder, center } = this.globalPosition;
const [centerX, centerY] = [center.x, center.y];
const innerContainer = createCircle({
x: centerX,
y: centerY,
radius: innerRadius,
fillColor: 'none'
});
const innerBorderContainer = createCircle({
x: centerX,
y: centerY,
radius: innerRadiusBorder,
fillColor: '#FFFFFF'
});
this.appendToSvg(innerBorderContainer);
this.appendToSvg(innerContainer);
}
addSmallCirclesAtCenter(centerX, centerY) {
const outerRadius = 0.0025 * 2 * this.size;
const innerRadius = 0.0005 * 2 * this.size;
this.appendToSvg(createCircle({
x: centerX,
y: centerY,
radius: outerRadius,
fillColor: '#FFFFFF'
}));
this.appendToSvg(createCircle({
x: centerX,
y: centerY,
radius: innerRadius,
fillColor: '#FFFFFF'
}));
}
drawLegends(degreeToBeDrawn) {
const { innerRadius, innerRadiusBorder, middleRadius, center } = this.globalPosition;
const [centerX, centerY] = [center.x, center.y];
const maxScore = this.maxScore;
let legends = createLegends({ startPoint: center, radius: innerRadius, degreeToBeDrawn, maxScore });
const startFrom = polarToCartesian(centerX, centerY, innerRadiusBorder, degreeToBeDrawn);
if (this.hasChildren) {
const nextLevelLegends = createLegendWithOptions({
startPoint: startFrom,
center,
startRadius: innerRadiusBorder,
endRadius: middleRadius,
maxScore,
degreeToBeDrawn
});
legends = legends.concat(nextLevelLegends);
}
legends.forEach(elem => {
this.appendToSvg(elem);
});
}
addArcText({ arcForTextId, radius, startAngle, fontSize, endAngle, perAngle, item }) {
const elements = [];
const { center } = this.globalPosition;
const [centerX, centerY] = [center.x, center.y];
const arcForText = createArcToWriteText({ id: arcForTextId, startPoint: center, radius, startAngle, endAngle });
elements.push(arcForText);
const distance = distanceBetweenTwoPoints(centerX, centerY, radius, startAngle, endAngle);
const label = getTextForAngle(item.name, distance, fontSize);
elements.push(writeTextOnArc({ label, text: item.name, pathId: arcForTextId, 'font-size': fontSize + 'px' }));
return elements;
}
drawLayout() {
const { innerRadius, innerRadiusBorder, middleRadius, middleRadiusBorder, outerRadius, outerRadiusBorder, center } = this.globalPosition;
const [centerX, centerY] = [center.x, center.y];
let innerRadiusEnd = innerRadius;
let innerRadiusBorderEnd = innerRadiusBorder;
this.chartBorder = innerRadiusBorder;
if (this.hasChildren) {
const outerBorderCircle = createCircle({
x: centerX,
y: centerY,
radius: outerRadiusBorder,
fillColor: 'none',
'stroke-width': '5',
ref: this.outerBorderCircleRef
});
this.appendToSvg(outerBorderCircle);
const outerCircle = createCircle({
x: centerX,
y: centerY,
radius: outerRadius,
fillColor: 'none'
});
this.appendToSvg(outerCircle);
innerRadiusEnd = middleRadius;
innerRadiusBorderEnd = middleRadiusBorder;
this.chartBorder = outerRadiusBorder;
}
this.appendToSvg(createCircle({ x: centerX, y: centerY, radius: innerRadiusEnd }));
this.appendToSvg(createCircle({ x: centerX, y: centerY, radius: innerRadiusBorderEnd }));
}
hideTooltip() {
this.showToolTip = false;
}
showTooltipText($event, text) {
this.tooltipLeftInPx = $event.pageX + 10 + 'px';
this.tooltipTopInPx = $event.pageY + 10 + 'px';
this.tooltipText = text;
this.showToolTip = true;
}
onOutOfComponent() {
this.hideTooltip();
this.stopRotate();
}
stopRotate() {
this.svgCursor = 'default';
this.startRotation = false;
}
startRotate($event) {
this.startRotation = true;
this.svgCursor = 'grab';
const { outerRadiusBorder, center } = this.globalPosition;
this.svgHandler = createSvgHandlerWithSelector('#' + this.svgId, center);
this.svgHandler.startDrag($event, this.currentRotationAngle);
$event.preventDefault();
}
rotateChart($event) {
if (this.startRotation == false) {
return;
}
this.svgCursor = 'grabbing';
const { center } = this.globalPosition;
this.currentRotationAngle = this.svgHandler.getRotationAngle($event);
this.rotationPoint = getFormattedAngle(Math.round(this.currentRotationAngle), center);
}
};
__decorate([
Input()
], AngularSunburstRadarChartComponent.prototype, "items", void 0);
__decorate([
Input()
], AngularSunburstRadarChartComponent.prototype, "options", void 0);
AngularSunburstRadarChartComponent = __decorate([
Component({
selector: 'lib-sunburst-radar-chart',
template: "<ng-container (mouseout)=\"onOutOfComponent();\">\n\n\n <div *ngIf=\"hasError\" style=\" color: #a94442;\n background-color: #f2dede;\n border-color: #ebccd1;\n margin-top: 5px;\npadding: 15px;\n margin-bottom: 20px;\n border: 1px solid transparent;\n border-radius: 4px;\n\">\n <strong>Error!</strong> {{error}}\n </div>\n\n\n\n<div class=\"app-tooltip\" *ngIf=\"showToolTip\" style=\"position: absolute; display: block;background: cornsilk; border: 1px solid black; border-radius: 5px; padding: 5px; z-index: 1002;\"\n\n [style.left]=\"tooltipLeftInPx\" [style.top]=\"tooltipTopInPx\" >\n {{tooltipText}}\n</div>\n\n<svg [attr.id]=\"svgId\"\n [attr.height]=\"size\"\n [attr.width]=\"size\"\n [attr.viewBox]=\"viewBox\"\n [style.cursor]=\"svgCursor\"\n xmlns=\"http://www.w3.org/2000/svg\">\n\n\n\n\n <animateTransform\n *ngIf=\"animateChart\"\n attributeName=\"transform\"\n begin=\"4s\"\n dur=\"500ms\"\n type=\"rotate\"\n from=\"0\"\n to=\"10\"\n\n additive=\"sum\"\n fill=\"freeze\"\n repeatCount=\"1\"\n />\n\n\n<g\n (mousemove)=\"rotateChart($event);\"\n (mousedown)=\"startRotate($event)\"\n (mouseup)=\"stopRotate()\"\n (touchmove)=\"rotateChart($event);\"\n (touchstart)=\"startRotate($event)\"\n (touchend)=\"stopRotate()\"\n [attr.transform]=\"rotationPoint\"\n [attr.id]=\"svgGroupId\"\n\n\n >\n <ng-container *ngFor=\"let element of elements\" >\n\n\n\n <ng-container [ngSwitch]=\"element.name\" >\n\n\n <circle *ngSwitchCase=\"'circle'\" [attr.cx]=\"element.options.x\" [attr.cy]=[element.options.y]\n [attr.r]=\"element.options.radius\"\n [attr.stroke-width]=\"element.options['stroke-width']\"\n [attr.stroke]=\"element.options['stroke']\"\n [attr.stroke-dasharray]=\"element.options['stroke-dasharray']\"\n [attr.stroke-opacity]=\"element.options['stroke-opacity']\"\n [attr.fill]=\"element.options['fillColor']\"\n >\n\n\n\n\n </circle>\n\n <path *ngSwitchCase=\"'path'\" [attr.d]=\"element.options.d\" [attr.fill]=[element.options.fill]\n\n [attr.stroke]=\"element.options['stroke']\"\n [attr.stroke-width]=\"element.options['stroke-width']\"\n [attr.id]=\"element.options['id']\"\n (mousemove)=\"showTooltipText($event, element.options['title']);\"\n (mouseout)=\"hideTooltip()\" >\n\n\n\n\n\n </path>\n\n<g *ngSwitchCase=\"'path-bar'\" >\n\n\n\n <path [attr.d]=\"element.options.d\"\n [attr.fill]=[element.options.fill]\n\n [attr.stroke]=\"element.options['stroke']\"\n [attr.stroke-width]=\"element.options['stroke-width']\"\n [attr.stroke-opacity]=\"element.options['stroke-opacity']\"\n [attr.fill-opacity]=\"element.options['fill-opacity']\"\n [attr.id]=\"element.options['id']\"\n (mousemove)=\"showTooltipText($event, element.options['title']);\" (mouseout)=\"hideTooltip()\" >\n\n\n\n\n <ng-container\n\n *ngIf=\"animateChart\"\n >\n\n <animate\n attributeName=\"fill\"\n [attr.from]=\"element.options['fill']\"\n to=\"transparent\"\n dur=\"1ms\"\n fill=\"freeze\" />\n <animate\n attributeName=\"stroke\"\n [attr.from]=\"element.options['fill']\"\n [attr.to]=\"element.options['fill']\"\n dur=\"1ms\"\n fill=\"freeze\" />\n <animate\n attributeName=\"stroke-width\"\n from=\"8\"\n to=\"8\"\n dur=\"1ms\"\n fill=\"freeze\" />\n <animate\n attributeName=\"stroke-dasharray\"\n from=\"1000\"\n to=\"1000\"\n dur=\"1ms\"\n fill=\"freeze\" />\n\n\n <animate\n attributeName=\"fill\"\n from=\"#FFFFFF\"\n [attr.to]=\"element.options['fill']\"\n begin=\"2s\"\n dur=\"3s\"\n fill=\"freeze\" />\n\n <animate\n attributeName=\"stroke-dashoffset\"\n from=\"1000\"\n to=\"0\"\n begin=\"1ms\"\n dur=\"3s\"\n fill=\"freeze\" />\n\n <animate\n attributeName=\"stroke-width\"\n from=\"8\"\n [attr.to]=\"element.options['stroke']\"\n begin=\"3s\"\n dur=\"1s\"\n fill=\"freeze\" />\n </ng-container>\n </path>\n\n\n\n\n</g>\n\n <text *ngSwitchCase=\"'text-on-arc'\"\n [attr.font-size]=\"element.options['font-size']\"\n\n >\n <textPath\n [attr.href]=\"element.options.href\"\n [attr.startOffset]=\"element.options.startOffset\"\n [attr.text-anchor]=\"element.options['text-anchor']\"\n >{{element.options['label']}}</textPath>\n <title>{{element.options['title']}}</title>\n\n </text>\n\n\n <line *ngSwitchCase=\"'line'\"\n [attr.x1]=\"element.options.x1\"\n [attr.y1]=\"element.options.y1\"\n [attr.x2]=\"element.options.x2\"\n [attr.y2]=\"element.options.y2\"\n [attr.stroke-width]=\"element.options.width\"\n\n [attr.stroke]=\"element.options['color']\" >\n <title>{{element.options['title']}}</title>\n </line>\n\n\n <text *ngSwitchCase=\"'text'\"\n [attr.x]=\"element.options.x\"\n [attr.y]=\"element.options.y\"\n [attr.stroke]=\"element.options.stroke\"\n [attr.stroke-width]=\"element.options['stroke-width']\"\n [attr.font-size]=\"element.options['font-size']\"\n [attr.text-anchor]=\"element.options['text-anchor']\"\n >{{element.options.content}}\n <title>{{element.options['content']}}</title>\n </text>\n\n </ng-container>\n\n\n\n </ng-container>\n\n\n </g>\n</svg>\n</ng-container>\n",
styles: [".app-tooltip{background:#fff8dc;border:1px solid #000;border-radius:5px;padding:5px;z-index:1002}.growAnimation{-moz-transition:transform 2s ease-in-out;-webkit-transition:transform 2s ease-in-out;-o-transition:transform 2s ease-in-out;transform:scale(1)}.growAnimation:active{transform:scale(.5)}"]
})
], AngularSunburstRadarChartComponent);
export { AngularSunburstRadarChartComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-sunburst-radar-chart.component.js","sourceRoot":"ng://angular-sunburst-radar-chart/","sources":["lib/angular-sunburst-radar-chart.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAgB,SAAS,EAAE,KAAK,EAAmC,MAAM,eAAe,CAAC;AAChG,OAAO,EAAC,YAAY,EAAE,UAAU,EAAE,UAAU,EAAC,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAC,oBAAoB,EAAE,eAAe,EAAE,cAAc,EAAC,MAAM,qBAAqB,CAAC;AAC1F,OAAO,EAAC,4BAA4B,EAAE,4BAA4B,EAAC,MAAM,wBAAwB,CAAC;AAClG,OAAO,EAAC,qBAAqB,EAAE,kBAAkB,EAAiB,MAAM,mBAAmB,CAAC;AAC5F,OAAO,EAAC,wBAAwB,EAAE,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AAC/E,OAAO,EAAC,aAAa,EAAE,uBAAuB,EAAC,MAAM,gBAAgB,CAAC;AACtE,OAAO,EAAC,WAAW,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AAC/G,OAAO,EAAC,wBAAwB,EAAE,yBAAyB,EAAE,yBAAyB,EAAE,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AAGjI,OAAO,EAAC,4BAA4B,EAAC,MAAM,qBAAqB,CAAC;AAQjE,IAAa,kCAAkC,GAA/C,MAAa,kCAAkC;IAI7C;QAIA,uBAAkB,GAAC,KAAK,CAAC;QACzB,gBAAW,GAAG,KAAK,CAAC;QACpB,mBAAc,GAAG,KAAK,CAAC;QACvB,oBAAe,GAAG,KAAK,CAAC;QACxB,gBAAW,GAAG,EAAE,CAAC;QACjB,UAAK,GAAG,IAAI,CAAC;QACb,eAAU,GAAG,IAAI,CAAC;QAElB,eAAU,GAAG,IAAI,CAAC;QAElB,yBAAoB,GAAG,EAAE,CAAC;QAE1B,cAAS,GAAG,SAAS,CAAC;QAsBtB,gBAAW,GAAG,KAAK,CAAC;QAGpB,sBAAiB,GAAG,EAAE,CAAC;QACvB,sBAAiB,GAAG,EAAE,CAAC;QAGvB,aAAQ,GAAwB,EAAE,CAAC;QAEnC,gBAAW,GAAG,KAAK,CAAC;QAEpB,yBAAoB,GAAG,mBAAmB,CAAC;QAC3C,UAAK,GAAQ,IAAI,CAAC;QAClB,aAAQ,GAAG,KAAK,CAAC;QAEjB,kBAAa,GAAG,KAAK,CAAC;IApDtB,CAAC;IAsDD,SAAS,CAAC,GAAG;QAEX,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACvB,CAAC;IAED,SAAS;QAEP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,WAAW,CAAC,OAA0B;QAEpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAGD,WAAW,CAAC,OAAsB;QAGhC,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC;QAC1E,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,CAAC;IAG1C,CAAC;IAED,mBAAmB,CAAC,aAAsB;QACxC,IAAI,CAAC,aAAa,EAAE;YAElB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAGD,UAAU;QAGR,MAAM,QAAQ,GAAG,EAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,YAAY,EAAE,IAAI,EAAE,oBAAoB,EAAE,IAAI,EAAE,sBAAsB,EAAE,CAAC,EAAC,CAAC;QACvH,MAAM,OAAO,mCAAO,QAAQ,GAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAEpE,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;QACzB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;QACzC,IAAI,CAAC,oBAAoB,GAAG,OAAO,CAAC,oBAAoB,CAAC;QACzD,IAAI,CAAC,sBAAsB,GAAG,OAAO,CAAC,sBAAsB,CAAC;QAG7D,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,EAAE;YAE9B,IAAI,CAAC,SAAS,CAAC,4CAA4C,CAAC,CAAC;YAC7D,OAAO;SACR;QACD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,CAAC,UAAU,GAAG,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAGrD,IAAI,CAAC,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC;QAGpD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QAEpD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;QACpD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;QAEpD,IAAI,CAAC,cAAc,GAAG,kBAAkB,CAAC;YACvC,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,KAAK,EAAE,IAAI,CAAC,KAAK;SAElB,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;QAGzE,IAAI,CAAC,UAAU,EAAE,CAAC;QAGlB,MAAM,EAAC,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,aAAa,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QAChI,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QAEhD,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACvB,IAAI,SAAS,GAAG,EAAE,CAAC;QACnB,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QAErC,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAE7B,0BAA0B;YAC1B,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;YAC3B,SAAS,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;SAC7C;aAAM;YACL,SAAS,GAAG,yBAAyB,CAAC,KAAK,CAAC,CAAC;SAC9C;QAGD,MAAM,eAAe,GAAG,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC;QAE3C,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QACzD,MAAM,YAAY,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAChE,MAAM,MAAM,GAAG,iBAAiB,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;QAE7E,MAAM,KAAK,GAAG,EAAE,CAAC;QAEjB,IAAI,QAAQ,GAAG,EAAE,CAAC;QAClB,IAAI,iBAAiB,GAAG,EAAE,CAAC;QAG3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAEtC,MAAM,EAAC,CAAC,EAAE,CAAC,EAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YAEzB,IAAI,aAAa,GAAG,CAAC,GAAG,CAAC,CAAC;YAC1B,IAAI,aAAa,IAAI,MAAM,CAAC,MAAM,EAAE;gBAClC,aAAa,GAAG,CAAC,CAAC;aACnB;YAGD,MAAM,QAAQ,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;YACvC,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YAC7B,MAAM,WAAW,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;YAEpC,IAAI,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAGpB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;gBAG1B,MAAM,aAAa,GAAG;oBACpB,KAAK,EAAE,mBAAmB,EAAE;iBAC7B,CAAC;gBACF,IAAI,mCAAO,aAAa,GAAK,IAAI,CAAC,CAAC;aAEpC;YAGD,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gBAEjE,MAAM,WAAW,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;gBAG1C,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC;oBAC5D,KAAK,EAAE,IAAI,CAAC,QAAQ;oBACpB,YAAY,EAAE,eAAe;oBAC7B,WAAW;oBACX,KAAK,EAAE,IAAI,CAAC,KAAK;iBAClB,CAAC,CAAC,CAAC;aAEL;YAGD,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,EAAC,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC,CAAC;YAG3E,8BAA8B;YAC9B,MAAM,YAAY,GAAG,4BAA4B,CAAC;gBAChD,UAAU,EAAE,MAAM;gBAClB,IAAI;gBACJ,MAAM,EAAE,WAAW;gBACnB,UAAU;gBACV,QAAQ;gBACR,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC,CAAC;YACH,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAG5B,MAAM,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC;gBACxC,YAAY,EAAE,gBAAgB,GAAG,IAAI,CAAC,aAAa,EAAE,GAAG,GAAG,GAAG,CAAC;gBAC/D,MAAM,EAAE,eAAe;gBACvB,QAAQ,EAAE,QAAQ;gBAClB,UAAU;gBACV,QAAQ;gBACR,QAAQ,EAAE,eAAe;gBACzB,IAAI;aACL,CAAC,CAAC;YACH,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAG9C,IAAI,WAAW,EAAE;gBAEf,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,6BAA6B,CAAC,EAAC,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,EAAC,CAAC,CAAC,CAAC;gBAC7F,MAAM,2BAA2B,GAAG,IAAI,CAAC,UAAU,CACjD;oBACE,YAAY,EAAE,gBAAgB,GAAG,IAAI,CAAC,aAAa,EAAE,GAAG,GAAG,GAAG,CAAC;oBAC/D,MAAM,EAAE,eAAe;oBACvB,QAAQ,EAAE,aAAa;oBACvB,QAAQ,EAAE,eAAe;oBACzB,UAAU;oBACV,QAAQ;oBACR,IAAI;iBACL,CAAC,CAAC;gBACL,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,2BAA2B,CAAC,CAAC;aACzD;SAGF;QAGD,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEzB,CAAC,CAAC,CAAC;QAGH,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAGxB,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACtB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEzB,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEzB,CAAC,CAAC,CAAC;QACH,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAExD,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,uBAAuB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAE/C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAGxB,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC,IAAI,CAAC,oBAAoB,EAAE,MAAM,CAAC,CAAC;IAE5E,CAAC;IAMD,kBAAkB,CAAC,MAAa;QAC9B,IAAI,eAAe,GAAG,IAAI,CAAC,sBAAsB,GAAG,CAAC,CAAC;QACtD,IAAI,eAAe,GAAG,CAAC,IAAI,eAAe,IAAI,MAAM,CAAC,MAAM,EAAE;YAC3D,eAAe,GAAG,CAAC,CAAC;SACrB;QACD,OAAO,eAAe,CAAC;IACzB,CAAC;IAED,kBAAkB;QAEhB,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;IAC7C,CAAC;IAGD,6BAA6B,CAAC,EAAC,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,EAAC;QAGrE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QAEzB,MAAM,EAAC,eAAe,EAAE,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QAEtD,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QAGhD,MAAM,YAAY,GAAG,qBAAqB,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,EAAE,eAAe,EAAC,CAAC,CAAC;QAG3H,MAAM,CAAC,GAAG;YAER,GAAG,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC;YAC/C,GAAG,EAAE,eAAe,EAAE,eAAe,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;SAGvF,CAAC;QAEF,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC;QAE3C,MAAM,WAAW,GAAG,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC;QACvC,OAAO,UAAU,CAAC,EAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,KAAK,EAAC,CAAC,CAAC;IAEzF,CAAC;IAGD,WAAW,CAAC,EAAC,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAC;QAGnD,MAAM,EAAC,iBAAiB,EAAE,YAAY,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QAClG,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QAGhD,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACzD,MAAM,YAAY,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAChE,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1D,MAAM,QAAQ,GAAG,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC;QAE7C,MAAM,yBAAyB,GAAG,yBAAyB,CAAC,OAAO,EAAE,OAAO,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;QAGzG,MAAM,cAAc,GAAG,yBAAyB,CAAC,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;QAGzF,IAAI,QAAQ,GAAG,EAAE,CAAC;QAClB,MAAM,KAAK,GAAG,EAAE,CAAC;QAGjB,IAAI,aAAa,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAE9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,yBAAyB,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAEzD,MAAM,wBAAwB,GAAG,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAC9D,MAAM,aAAa,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;YAGxC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC;gBACpB,EAAE,EAAE,wBAAwB,CAAC,CAAC,EAAE,EAAE,EAAE,wBAAwB,CAAC,CAAC;gBAC9D,EAAE,EAAE,aAAa,CAAC,CAAC,EAAE,EAAE,EAAE,aAAa,CAAC,CAAC,EAAE,KAAK,EAAE,GAAG;aACrD,CAAC,CAAC,CAAC;YAGJ,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YAC7B,MAAM,WAAW,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;YACpC,MAAM,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;YAG9B,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAGtB,MAAM,MAAM,GAAG;gBACb,UAAU,EAAE,wBAAwB;gBACpC,IAAI;gBACJ,UAAU;gBACV,QAAQ;gBACR,WAAW;gBACX,YAAY;gBACZ,iBAAiB;gBACjB,MAAM;gBACN,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK;gBACL,KAAK,EAAE,CAAC;aACT,CAAC;YAGF,MAAM,WAAW,GAAG,4BAA4B,CAAC,MAAM,CAAC,CAAC;YAEzD,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAG3B,MAAM,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC;gBACzC,YAAY,EAAE,iBAAiB,GAAG,IAAI,CAAC,aAAa,EAAE,GAAG,GAAG,GAAG,UAAU,GAAG,CAAC;gBAC7E,MAAM,EAAE,gBAAgB;gBACxB,QAAQ,EAAE,QAAQ;gBAClB,QAAQ;gBACR,UAAU;gBACV,QAAQ;gBACR,IAAI;aACL,CAAC,CAAC;YAEH,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC;YAG/C,aAAa,GAAG,aAAa,GAAG,QAAQ,CAAC;SAE1C;QAGD,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEtB,CAAC,CAAC,CAAC;QAGH,OAAO,QAAQ,CAAC;IAElB,CAAC;IAED,aAAa;QAEX,OAAO,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC;IAEhD,CAAC;IAED,gBAAgB;QAEd,MAAM,EAAC,WAAW,EAAE,iBAAiB,EAAE,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QACrE,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QAEhD,MAAM,cAAc,GAAG,YAAY,CAAC;YAClC,CAAC,EAAE,OAAO;YACV,CAAC,EAAE,OAAO;YACV,MAAM,EAAE,WAAW;YACnB,SAAS,EAAE,MAAM;SAClB,CAAC,CAAC;QAGH,MAAM,oBAAoB,GAAG,YAAY,CAAC;YACxC,CAAC,EAAE,OAAO;YACV,CAAC,EAAE,OAAO;YACV,MAAM,EAAE,iBAAiB;YACzB,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAAC;QACvC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IACnC,CAAC;IAED,uBAAuB,CAAC,OAAe,EAAE,OAAe;QAEtD,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;QAC3C,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;QAC3C,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC;YAC5B,CAAC,EAAE,OAAO;YACV,CAAC,EAAE,OAAO;YACV,MAAM,EAAE,WAAW;YACnB,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC;YAC5B,CAAC,EAAE,OAAO;YACV,CAAC,EAAE,OAAO;YACV,MAAM,EAAE,WAAW;YACnB,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC,CAAC;IAEN,CAAC;IAED,WAAW,CAAC,eAAe;QAEzB,MAAM,EAAC,WAAW,EAAE,iBAAiB,EAAE,YAAY,EAAE,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QAGnF,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE/B,IAAI,OAAO,GAAG,aAAa,CAAC,EAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAC,CAAC,CAAC;QAGlG,MAAM,SAAS,GAAG,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,iBAAiB,EAAE,eAAe,CAAC,CAAC;QAEzF,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,MAAM,gBAAgB,GAAG,uBAAuB,CAAC;gBAC/C,UAAU,EAAE,SAAS;gBACrB,MAAM;gBACN,WAAW,EAAE,iBAAiB;gBAC9B,SAAS,EAAE,YAAY;gBACvB,QAAQ;gBACR,eAAe;aAChB,CAAC,CAAC;YAEH,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;SAC5C;QACD,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC,CAAC;IAEL,CAAC;IAGD,UAAU,CAAC,EAAC,YAAY,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAC;QAC/E,MAAM,QAAQ,GAAG,EAAE,CAAC;QACpB,MAAM,EAAC,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QACrC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,UAAU,GAAG,oBAAoB,CAAC,EAAC,EAAE,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAC,CAAC,CAAC;QAC9G,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC1B,MAAM,QAAQ,GAAG,wBAAwB,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QAG1F,MAAM,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC7D,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,EAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,QAAQ,GAAG,IAAI,EAAC,CAAC,CAAC,CAAC;QAC5G,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,UAAU;QAER,MAAM,EAAC,WAAW,EAAE,iBAAiB,EAAE,YAAY,EAAE,kBAAkB,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QAEvI,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QAGhD,IAAI,cAAc,GAAG,WAAW,CAAC;QACjC,IAAI,oBAAoB,GAAG,iBAAiB,CAAC;QAC7C,IAAI,CAAC,WAAW,GAAG,iBAAiB,CAAC;QAErC,IAAI,IAAI,CAAC,WAAW,EAAE;YAEpB,MAAM,iBAAiB,GAAG,YAAY,CAAC;gBACrC,CAAC,EAAE,OAAO;gBACV,CAAC,EAAE,OAAO;gBACV,MAAM,EAAE,iBAAiB;gBACzB,SAAS,EAAE,MAAM;gBACjB,cAAc,EAAE,GAAG;gBACnB,GAAG,EAAE,IAAI,CAAC,oBAAoB;aAE/B,CAAC,CAAC;YACH,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;YACpC,MAAM,WAAW,GAAG,YAAY,CAAC;gBAC/B,CAAC,EAAE,OAAO;gBACV,CAAC,EAAE,OAAO;gBACV,MAAM,EAAE,WAAW;gBACnB,SAAS,EAAE,MAAM;aAClB,CAAC,CAAC;YACH,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;YAE9B,cAAc,GAAG,YAAY,CAAC;YAC9B,oBAAoB,GAAG,kBAAkB,CAAC;YAC1C,IAAI,CAAC,WAAW,GAAG,iBAAiB,CAAC;SACtC;QAED,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,EAAC,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,cAAc,EAAC,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,EAAC,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,oBAAoB,EAAC,CAAC,CAAC,CAAC;IACzF,CAAC;IAED,WAAW;QACT,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,eAAe,CAAC,MAAW,EAAE,IAAS;QACpC,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,KAAK,GAAG,EAAE,GAAG,IAAI,CAAC;QAChD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,KAAK,GAAG,EAAE,GAAG,IAAI,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAExB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAG1B,CAAC;IAGD,gBAAgB;QAEd,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,UAAU;QACR,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,MAAW;QAErB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;QACxB,MAAM,EAAC,iBAAiB,EAAE,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QAExD,IAAI,CAAC,UAAU,GAAG,4BAA4B,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACzE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAE7D,MAAM,CAAC,cAAc,EAAE,CAAC;IAE1B,CAAC;IAGD,WAAW,CAAC,MAAW;QAGrB,IAAI,IAAI,CAAC,aAAa,IAAI,KAAK,EAAE;YAC/B,OAAO;SACR;QACD,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC;QAC5B,MAAM,EAAC,MAAM,EAAC,GAAG,IAAI,CAAC,cAAc,CAAC;QAErC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAGrE,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC,CAAC;IAGxF,CAAC;CAEF,CAAA;AA1lBC;IADC,KAAK,EAAE;iEACF;AAGN;IADC,KAAK,EAAE;mEACA;AA3BG,kCAAkC;IAL9C,SAAS,CAAC;QACT,QAAQ,EAAE,0BAA0B;QACpC,qmMAA4D;;KAE7D,CAAC;GACW,kCAAkC,CAknB9C;SAlnBY,kCAAkC","sourcesContent":["import {AfterViewInit, Component, Input, OnChanges, OnInit, SimpleChanges} from '@angular/core';\nimport {createCircle, createLine, createPath} from './utils/elements';\nimport {createArcToWriteText, getTextForAngle, writeTextOnArc} from './utils/textelement';\nimport {createInnerChartBarWithInArc, createOuterChartBarWithInArc} from './utils/arc-bar-charts';\nimport {calculatePointBetween, getGlobalPositions, GlobalPosition} from './utils/positions';\nimport {distanceBetweenTwoPoints, polarToCartesian} from './utils/trignometry';\nimport {createLegends, createLegendWithOptions} from './utils/legend';\nimport {formatItems, generateRandomColor, getFormattedAngle, getOptionsOrEmpty, hashCode} from './utils/utils';\nimport {getAllAnglesBasedOnChild, getAllAnglesBasedOnParent, getPointsOnCircleAtAngels, positionsOnAngles} from './utils/angels';\nimport {AngularSvgElement} from './utils/models';\n\nimport {createSvgHandlerWithSelector} from './utils/svg-rotator';\n\n\n@Component({\n  selector: 'lib-sunburst-radar-chart',\n  templateUrl: './angular-sunburst-radar-chart.component.html',\n  styleUrls: ['./angular-sunburst-radar-chart.component.scss']\n})\nexport class AngularSunburstRadarChartComponent implements OnInit, OnChanges {\n\n\n\n  constructor() {\n  }\n\n\n  componentDisplayed=false;\n  showToolTip = false;\n  tooltipTopInPx = '0px';\n  tooltipLeftInPx = '0px';\n  tooltipText = '';\n  svgId = null;\n  svgGroupId = null;\n\n  svgHandler = null;\n\n  currentRotationAngle = 10;\n  rotationPoint;\n  svgCursor = 'default';\n\n\n  @Input()\n  items;\n\n  @Input()\n  options;\n\n  size: number;\n\n\n  maxScore: number;\n\n  legendAxisLinePosition: number;\n\n  animateChart;\n\n  splitBasedOnChildren;\n\n  viewBox;\n\n  initialized = false;\n  innerCircleRadius;\n\n  innerBorderHeight = 30;\n  outerBorderHeight = 30;\n\n\n  elements: AngularSvgElement[] = [];\n  globalPosition: GlobalPosition;\n  hasChildren = false;\n  chartBorder;\n  outerBorderCircleRef = 'outerBorderCircle';\n  error: any = null;\n  hasError = false;\n\n  startRotation = false;\n\n  showError(msg) {\n\n    this.error = msg;\n    this.hasError = true;\n  }\n\n  hideError() {\n\n    this.error = null;\n    this.hasError = false;\n  }\n\n  appendToSvg(element: AngularSvgElement) {\n\n    this.elements.push(element);\n  }\n\n\n  ngOnChanges(changes: SimpleChanges) {\n\n\n    this.hideError();\n    const isFirstChange = Object.values(changes).some(c => c.isFirstChange());\n    this.modifyOnFirstChange(isFirstChange);\n\n\n  }\n\n  modifyOnFirstChange(isFirstChange: boolean) {\n    if (!isFirstChange) {\n\n      this.initialize();\n    }\n  }\n\n  ngOnInit(): void {\n    this.hideError();\n    this.initialize();\n  }\n\n\n  initialize(): void {\n\n\n    const defaults = {size: 300, maxScore: 100, animateChart: true, splitBasedOnChildren: true, legendAxisLinePosition: 1};\n    const options = {...defaults, ...(getOptionsOrEmpty(this.options))};\n\n    this.size = options.size;\n    this.maxScore = options.maxScore;\n    this.animateChart = options.animateChart;\n    this.splitBasedOnChildren = options.splitBasedOnChildren;\n    this.legendAxisLinePosition = options.legendAxisLinePosition;\n\n\n    if (!this.hasValidParameters()) {\n\n      this.showError('Input Values not set or Items was improper');\n      return;\n    }\n    this.initialized = false;\n    this.svgId = 'svg' + hashCode(this.items);\n    this.svgGroupId = 'svg-group' + hashCode(this.items);\n\n\n    this.viewBox = '0 0 ' + this.size + ' ' + this.size;\n\n\n    this.innerCircleRadius = Math.abs(this.size / 5.33);\n\n    this.innerBorderHeight = this.innerCircleRadius / 5;\n    this.outerBorderHeight = this.innerCircleRadius / 5;\n\n    this.globalPosition = getGlobalPositions({\n      size: this.size,\n      maxScore: this.maxScore,\n      items: this.items\n\n    });\n\n    this.hasChildren = this.items.filter(item => !!item.children).length > 0;\n\n\n    this.drawLayout();\n\n\n    const {innerRadius, innerTextRadius, textSize, outerTextSize, outerRadiusBorder, outerTextRadius, center} = this.globalPosition;\n    const [centerX, centerY] = [center.x, center