axidio-styleguide-library1-v2 0.2.7 → 0.2.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/guage-chart/guage-chart.component.mjs +191 -146
- package/esm2022/lib/plain-trend/plain-trend.component.mjs +4 -4
- package/fesm2022/axidio-styleguide-library1-v2.mjs +195 -150
- package/fesm2022/axidio-styleguide-library1-v2.mjs.map +1 -1
- package/lib/guage-chart/guage-chart.component.d.ts +29 -77
- package/package.json +1 -1
|
@@ -53,210 +53,255 @@ export class GuageChartComponent extends ComponentUniqueId {
|
|
|
53
53
|
}
|
|
54
54
|
ngOnInit() { }
|
|
55
55
|
ngOnChanges() {
|
|
56
|
-
this.
|
|
57
|
-
|
|
58
|
-
onResized(_event) {
|
|
59
|
-
this.redrawChart();
|
|
56
|
+
d3.select('#' + this.uniqueId).remove();
|
|
57
|
+
this.initializeLineChart();
|
|
60
58
|
}
|
|
61
|
-
|
|
62
|
-
* Clears the previous SVG and redraws chart
|
|
63
|
-
*/
|
|
64
|
-
redrawChart() {
|
|
59
|
+
onResized(event) {
|
|
65
60
|
d3.select('#' + this.uniqueId).remove();
|
|
66
61
|
this.initializeLineChart();
|
|
67
62
|
}
|
|
68
|
-
/**
|
|
69
|
-
*
|
|
70
|
-
|
|
63
|
+
/** -------------------------------
|
|
64
|
+
* Main Initialization Function
|
|
65
|
+
* ------------------------------*/
|
|
71
66
|
initializeLineChart() {
|
|
72
|
-
this
|
|
73
|
-
const { data, metaData
|
|
74
|
-
const
|
|
75
|
-
this.
|
|
76
|
-
this.
|
|
77
|
-
this.
|
|
78
|
-
this.
|
|
67
|
+
const self = this;
|
|
68
|
+
const { data, metaData } = this.chartData;
|
|
69
|
+
const isRia = this.customChartConfiguration.isRia;
|
|
70
|
+
this.setupChartConfiguration();
|
|
71
|
+
const { colorMaps } = this.getColorMap(metaData);
|
|
72
|
+
this.configureDataType(metaData);
|
|
73
|
+
const data_ready = this.calculateDataReady(data);
|
|
74
|
+
const { chartContainer, guagecontainer, width, height } = this.setupContainer();
|
|
75
|
+
this.isHeaderVisible =
|
|
76
|
+
this.chartConfiguration.isHeaderVisible ?? this.isHeaderVisible;
|
|
77
|
+
const svg = this.createSvg(chartContainer, width, height);
|
|
78
|
+
const radius = this.adjustDimensionsAndRadius(width, height);
|
|
79
|
+
const angleValue = this.computeAngles(data_ready, data);
|
|
80
|
+
const arc = this.createArc(radius, angleValue, data_ready);
|
|
81
|
+
this.drawGaugeArcs(svg, arc, data_ready, colorMaps, metaData, isRia, data);
|
|
82
|
+
this.drawPointer(svg, radius, metaData, data);
|
|
83
|
+
this.drawLabels(svg, radius, data_ready, data, metaData);
|
|
84
|
+
this.drawCenterTexts(svg, radius, metaData);
|
|
85
|
+
this.centerSvg(svg, chartContainer, width, height);
|
|
79
86
|
}
|
|
80
|
-
/**
|
|
81
|
-
*
|
|
82
|
-
|
|
83
|
-
|
|
87
|
+
/** -------------------------------
|
|
88
|
+
* Modular Helper Functions
|
|
89
|
+
* ------------------------------*/
|
|
90
|
+
setupChartConfiguration() {
|
|
84
91
|
for (const key in this.defaultConfiguration) {
|
|
85
92
|
this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(key, this.defaultConfiguration, this.customChartConfiguration);
|
|
86
93
|
}
|
|
87
|
-
if (this.chartConfiguration.isHeaderVisible !== undefined)
|
|
88
|
-
this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
|
|
89
94
|
}
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
*/
|
|
93
|
-
processChartData() {
|
|
94
|
-
const metaData = this.chartData.metaData;
|
|
95
|
-
const data = this.chartData.data;
|
|
96
|
-
const colorType = metaData.colorType || 'high';
|
|
95
|
+
getColorMap(metaData) {
|
|
96
|
+
const colorType = metaData.colorType;
|
|
97
97
|
const colorMaps = colorType === 'low'
|
|
98
98
|
? this.chartConfiguration.low_colorMap
|
|
99
99
|
: this.chartConfiguration.high_colorMap;
|
|
100
|
+
return { colorMaps };
|
|
101
|
+
}
|
|
102
|
+
configureDataType(metaData) {
|
|
100
103
|
if (metaData.dataType) {
|
|
101
|
-
this.dataType = metaData.dataType
|
|
102
|
-
this.
|
|
104
|
+
this.dataType = metaData.dataType;
|
|
105
|
+
if (this.dataType === 'USD') {
|
|
106
|
+
this.datatype_status = true;
|
|
107
|
+
this.dataType = '$ ';
|
|
108
|
+
}
|
|
103
109
|
}
|
|
104
|
-
const data_ready = data.slice(0, -1).map((v, i) => data[i + 1] - v);
|
|
105
|
-
const total = d3.sum(data_ready);
|
|
106
|
-
const angleValue = data_ready.reduce((acc, curr, i) => {
|
|
107
|
-
const prev = acc[i - 1] || 0;
|
|
108
|
-
acc.push(prev + (curr / total) * 180);
|
|
109
|
-
return acc;
|
|
110
|
-
}, []);
|
|
111
|
-
const width = parseInt(d3.select(this.containerElt.nativeElement).style('width')) -
|
|
112
|
-
this.chartConfiguration.margin.left -
|
|
113
|
-
this.chartConfiguration.margin.right;
|
|
114
|
-
const height = parseInt(d3.select(this.guagecontainerElt.nativeElement).style('height')) -
|
|
115
|
-
this.chartConfiguration.margin.top -
|
|
116
|
-
this.chartConfiguration.margin.bottom -
|
|
117
|
-
56;
|
|
118
|
-
const radius = Math.min(width, height) / 2;
|
|
119
|
-
return { data, metaData, colorMaps, data_ready, angleValue, radius };
|
|
120
110
|
}
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
111
|
+
calculateDataReady(data) {
|
|
112
|
+
const data_ready = [];
|
|
113
|
+
data.forEach((_, i) => {
|
|
114
|
+
if (i < data.length - 1) {
|
|
115
|
+
data_ready.push(data[i + 1] - data[i]);
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
return data_ready;
|
|
119
|
+
}
|
|
120
|
+
setupContainer() {
|
|
126
121
|
const chartContainer = d3.select(this.containerElt.nativeElement);
|
|
127
|
-
const
|
|
128
|
-
const
|
|
129
|
-
const
|
|
122
|
+
const guagecontainer = d3.select(this.guagecontainerElt.nativeElement);
|
|
123
|
+
const margin = this.chartConfiguration.margin;
|
|
124
|
+
const width = parseInt(chartContainer.style('width')) - margin.left - margin.right;
|
|
125
|
+
const height = parseInt(guagecontainer.style('height')) -
|
|
126
|
+
margin.top -
|
|
127
|
+
margin.bottom -
|
|
128
|
+
56; // chart header height
|
|
129
|
+
return { chartContainer, guagecontainer, width, height };
|
|
130
|
+
}
|
|
131
|
+
createSvg(chartContainer, width, height) {
|
|
132
|
+
const margin = this.chartConfiguration.margin;
|
|
133
|
+
return chartContainer
|
|
130
134
|
.append('svg')
|
|
131
135
|
.attr('id', this.uniqueId)
|
|
132
|
-
.attr('width', width)
|
|
133
|
-
.attr('height', height)
|
|
136
|
+
.attr('width', width + margin.left + margin.right)
|
|
137
|
+
.attr('height', height + margin.top + margin.bottom)
|
|
134
138
|
.call(ChartHelper.responsivefy)
|
|
135
|
-
.append('g')
|
|
136
|
-
|
|
137
|
-
|
|
139
|
+
.append('g');
|
|
140
|
+
}
|
|
141
|
+
adjustDimensionsAndRadius(width, height) {
|
|
142
|
+
const radius = Math.min(width, height) / 2;
|
|
143
|
+
if (this.chartConfiguration.isDrilldownChart) {
|
|
144
|
+
this.chartConfiguration.currentValueWidthScaleFactor += 40;
|
|
145
|
+
this.chartConfiguration.currentValueHeightScaleFactor += 20;
|
|
146
|
+
}
|
|
147
|
+
else if (window.innerWidth > 1400) {
|
|
148
|
+
this.chartConfiguration.currentValueHeightScaleFactor += 15;
|
|
149
|
+
this.chartConfiguration.currentValueWidthScaleFactor *= 2;
|
|
150
|
+
}
|
|
151
|
+
return radius;
|
|
152
|
+
}
|
|
153
|
+
computeAngles(data_ready, data) {
|
|
154
|
+
const total = data_ready.reduce((sum, val) => sum + val, 0);
|
|
155
|
+
const tempArray = [];
|
|
156
|
+
data_ready.forEach((unit, i) => {
|
|
157
|
+
const angle = (unit / total) * 180;
|
|
158
|
+
tempArray.push(i === 0 ? angle : tempArray[i - 1] + angle);
|
|
159
|
+
});
|
|
160
|
+
return tempArray;
|
|
138
161
|
}
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
const arc = d3
|
|
162
|
+
createArc(radius, angleValue, data_ready) {
|
|
163
|
+
const self = this;
|
|
164
|
+
const deg2rad = (deg) => (deg * Math.PI) / 180;
|
|
165
|
+
return d3
|
|
144
166
|
.arc()
|
|
145
|
-
.innerRadius(
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
.outerRadius(
|
|
149
|
-
.startAngle((_, i) =>
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
167
|
+
.innerRadius(radius -
|
|
168
|
+
self.chartConfiguration.ringWidth -
|
|
169
|
+
self.chartConfiguration.ringInset)
|
|
170
|
+
.outerRadius(radius)
|
|
171
|
+
.startAngle((_, i) => deg2rad(i === 0
|
|
172
|
+
? self.chartConfiguration.minAngle
|
|
173
|
+
: self.chartConfiguration.minAngle + angleValue[i - 1]))
|
|
174
|
+
.endAngle((_, i) => deg2rad(i === data_ready.length - 1
|
|
175
|
+
? self.chartConfiguration.maxAngle
|
|
176
|
+
: self.chartConfiguration.minAngle + angleValue[i]));
|
|
177
|
+
}
|
|
178
|
+
drawGaugeArcs(svg, arc, data_ready, colorMaps, metaData, isRia, data) {
|
|
179
|
+
const self = this;
|
|
180
|
+
const arcs = svg
|
|
153
181
|
.append('g')
|
|
154
182
|
.attr('class', 'arc')
|
|
183
|
+
.attr('transform', this.centerTranslation(arc.outerRadius()()));
|
|
184
|
+
arcs
|
|
155
185
|
.selectAll('path')
|
|
156
186
|
.data(data_ready)
|
|
157
187
|
.enter()
|
|
158
188
|
.append('path')
|
|
159
189
|
.attr('fill', (_, i) => colorMaps[i])
|
|
190
|
+
.style('cursor', () => metaData.currentValue > 0 && metaData.hasDrillDown && !isRia
|
|
191
|
+
? 'pointer'
|
|
192
|
+
: 'default')
|
|
160
193
|
.attr('d', arc)
|
|
161
|
-
.
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
194
|
+
.on('click', (d) => {
|
|
195
|
+
if (!metaData.hasDrillDown || metaData.currentValue === 0)
|
|
196
|
+
return;
|
|
197
|
+
const range = `${data[0]} and ${data[data.length - 1]}`;
|
|
198
|
+
self.handleClick(range);
|
|
165
199
|
});
|
|
166
200
|
}
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
drawPointer(svg, metaData, data_ready, radius) {
|
|
171
|
-
const pointerValue = metaData.currentValue - this.chartData.data[0];
|
|
172
|
-
const range = this.chartData.data[this.chartData.data.length - 1] -
|
|
173
|
-
this.chartData.data[0];
|
|
174
|
-
const pointerAngle = this.chartConfiguration.minAngle + (pointerValue / range) * 180;
|
|
175
|
-
const pointerHeadLength = Math.round(radius * this.chartConfiguration.pointerHeadLengthPercent);
|
|
201
|
+
drawPointer(svg, radius, metaData, data) {
|
|
202
|
+
const self = this;
|
|
203
|
+
const pointerHeadLength = Math.round(radius * self.chartConfiguration.pointerHeadLengthPercent);
|
|
176
204
|
const lineData = [
|
|
177
|
-
[
|
|
205
|
+
[self.chartConfiguration.pointerWidth / 2, 0],
|
|
178
206
|
[0, -pointerHeadLength],
|
|
179
|
-
[-
|
|
180
|
-
[0,
|
|
181
|
-
[
|
|
207
|
+
[-(self.chartConfiguration.pointerWidth / 2), 0],
|
|
208
|
+
[0, self.chartConfiguration.pointerTailLength],
|
|
209
|
+
[self.chartConfiguration.pointerWidth / 2, 0],
|
|
182
210
|
];
|
|
183
|
-
|
|
211
|
+
const pointerLine = d3.line();
|
|
212
|
+
const pg = svg
|
|
184
213
|
.append('g')
|
|
214
|
+
.data([lineData])
|
|
185
215
|
.attr('class', 'pointer')
|
|
186
|
-
.
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
216
|
+
.attr('transform', this.centerTranslation(radius));
|
|
217
|
+
const pointerValue = metaData.currentValue - data[0];
|
|
218
|
+
const range = data[data.length - 1] - data[0];
|
|
219
|
+
const pointerAngle = self.chartConfiguration.minAngle + (pointerValue / range) * 180;
|
|
220
|
+
pg.append('path')
|
|
221
|
+
.attr('d', pointerLine)
|
|
222
|
+
.attr('fill', self.chartConfiguration.pointerColor)
|
|
223
|
+
.attr('transform', `rotate(${pointerAngle}) translate(0,${-radius + self.chartConfiguration.ringWidth + pointerHeadLength})`);
|
|
192
224
|
}
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
*/
|
|
196
|
-
drawLabels(svg, data_ready, radius, metaData) {
|
|
197
|
-
const data = this.chartData.data;
|
|
225
|
+
drawLabels(svg, radius, data_ready, data, metaData) {
|
|
226
|
+
const self = this;
|
|
198
227
|
const range = data[data.length - 1] - data[0];
|
|
199
|
-
const labelArray =
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
const labelGroup = svg.append('g').attr('class', 'labels');
|
|
206
|
-
labelGroup
|
|
207
|
-
.selectAll('text')
|
|
228
|
+
const labelArray = this.buildLabelArray(data_ready, data);
|
|
229
|
+
const lg = svg
|
|
230
|
+
.append('g')
|
|
231
|
+
.attr('class', 'label')
|
|
232
|
+
.attr('transform', this.centerTranslation(radius));
|
|
233
|
+
lg.selectAll('.bubble')
|
|
208
234
|
.data(labelArray)
|
|
209
235
|
.enter()
|
|
210
|
-
.append('
|
|
236
|
+
.append('g')
|
|
211
237
|
.attr('transform', (d) => {
|
|
212
|
-
const newAngle =
|
|
213
|
-
return `rotate(${newAngle}) translate(0
|
|
238
|
+
const newAngle = self.chartConfiguration.minAngle + (d.value / range) * 180;
|
|
239
|
+
return `rotate(${newAngle}) translate(0,${self.chartConfiguration.labelInset - radius - 20})`;
|
|
214
240
|
})
|
|
241
|
+
.append('text')
|
|
215
242
|
.attr('fill', 'var(--chart-text-color)')
|
|
216
|
-
.style('font-size', '14px')
|
|
243
|
+
.style('font-size', window.innerWidth < 1400 ? '12px' : '14px')
|
|
217
244
|
.style('font-weight', '600')
|
|
218
|
-
.text((d) => metaData.dataType ?
|
|
245
|
+
.text((d) => (metaData.dataType ? d.name + metaData.dataType : d.name));
|
|
246
|
+
}
|
|
247
|
+
buildLabelArray(data_ready, data) {
|
|
248
|
+
const labelArray = [{ name: data[0], value: 0 }];
|
|
249
|
+
let count = 0;
|
|
250
|
+
data_ready.forEach((unit, i) => {
|
|
251
|
+
count += unit;
|
|
252
|
+
labelArray.push({ name: data[i + 1], value: count });
|
|
253
|
+
});
|
|
254
|
+
return labelArray;
|
|
219
255
|
}
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
const
|
|
225
|
-
|
|
226
|
-
const bottomY = midY + this.chartConfiguration.currentValueHeightScaleFactor;
|
|
256
|
+
drawCenterTexts(svg, radius, metaData) {
|
|
257
|
+
const self = this;
|
|
258
|
+
const top = radius / 2 - 10;
|
|
259
|
+
const mid = top + self.chartConfiguration.currentValueHeightScaleFactor;
|
|
260
|
+
const bottom = mid + self.chartConfiguration.currentValueHeightScaleFactor;
|
|
261
|
+
// current value
|
|
227
262
|
svg
|
|
228
263
|
.append('foreignObject')
|
|
229
|
-
.attr('transform', `translate(${radius -
|
|
230
|
-
.attr('width',
|
|
231
|
-
.attr('height',
|
|
264
|
+
.attr('transform', `translate(${radius - this.chartConfiguration.currentValueWidthScaleFactor / 2},${top})`)
|
|
265
|
+
.attr('width', this.chartConfiguration.currentValueWidthScaleFactor + 8)
|
|
266
|
+
.attr('height', this.chartConfiguration.currentValueHeightScaleFactor)
|
|
232
267
|
.append('xhtml:div')
|
|
233
268
|
.attr('class', 'value-display')
|
|
234
|
-
.html(
|
|
269
|
+
.html(metaData.currentValue + metaData.dataType);
|
|
270
|
+
// status
|
|
235
271
|
if (metaData.status) {
|
|
272
|
+
const widthTemp = metaData.status.length > 4 ? 210 : 120;
|
|
236
273
|
svg
|
|
237
274
|
.append('foreignObject')
|
|
238
|
-
.attr('transform', `translate(${radius -
|
|
239
|
-
.attr('width',
|
|
240
|
-
.attr('height', 40)
|
|
275
|
+
.attr('transform', `translate(${radius - widthTemp / 2},${mid})`)
|
|
276
|
+
.attr('width', widthTemp)
|
|
241
277
|
.append('xhtml:div')
|
|
242
278
|
.attr('class', 'status-display')
|
|
243
279
|
.html(metaData.status);
|
|
244
280
|
}
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
281
|
+
// date range
|
|
282
|
+
svg
|
|
283
|
+
.append('foreignObject')
|
|
284
|
+
.attr('transform', `translate(${radius - 105},${bottom})`)
|
|
285
|
+
.attr('width', 210)
|
|
286
|
+
.append('xhtml:div')
|
|
287
|
+
.attr('class', 'daterange-display')
|
|
288
|
+
.html(metaData.dateRange
|
|
289
|
+
? `<span class="marginright-3"><i class="fa fa-calendar"></i></span><span>${metaData.dateRange}</span>`
|
|
290
|
+
: '');
|
|
255
291
|
}
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
292
|
+
centerTranslation(radius) {
|
|
293
|
+
return `translate(${radius},${radius})`;
|
|
294
|
+
}
|
|
295
|
+
centerSvg(svg, chartContainer, width, height) {
|
|
296
|
+
const margin = this.chartConfiguration.margin;
|
|
297
|
+
const containerMidWidth = parseInt(chartContainer.style('width')) / 2;
|
|
298
|
+
const nodeHalfWidth = svg.node().getBoundingClientRect().width / 2;
|
|
299
|
+
const updatedStartingPoint = containerMidWidth - nodeHalfWidth;
|
|
300
|
+
svg.attr('transform', `translate(${updatedStartingPoint + margin.left},${margin.top})`);
|
|
259
301
|
}
|
|
302
|
+
/** -------------------------------
|
|
303
|
+
* Event Handlers
|
|
304
|
+
* ------------------------------*/
|
|
260
305
|
handleClick(d) {
|
|
261
306
|
this.clickEvent.emit(d);
|
|
262
307
|
}
|
|
@@ -284,4 +329,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
284
329
|
}], headerMenuclickEvent: [{
|
|
285
330
|
type: Output
|
|
286
331
|
}] } });
|
|
287
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guage-chart.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/guage-chart/guage-chart.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/guage-chart/guage-chart.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,SAAS,EAET,KAAK,EACL,MAAM,EACN,YAAY,EACZ,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,WAAW,MAAM,iBAAiB,CAAC;AAE1C,OAAO,kBAAkB,MAAM,kBAAkB,CAAC;;;;;;AAQlD,MAAM,OAAO,mBAAoB,SAAQ,iBAAiB;IA6CxD;QACE,KAAK,EAAE,CAAC;QAxCA,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,yBAAoB,GAAG,IAAI,YAAY,EAAO,CAAC;QAEzD,uBAAkB,GAAQ,EAAE,CAAC;QAC7B,aAAQ,GAAG,EAAE,CAAC;QACd,oBAAe,GAAG,KAAK,CAAC;QACxB,aAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAC9B,oBAAe,GAAG,IAAI,CAAC;QAEvB,yBAAoB,GAAG;YACrB,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;YACpD,QAAQ,EAAE,CAAC,EAAE;YACb,QAAQ,EAAE,EAAE;YACZ,SAAS,EAAE,EAAE;YACb,SAAS,EAAE,EAAE;YACb,UAAU,EAAE,CAAC;YACb,SAAS,EAAE,EAAE;YACb,YAAY,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC;YAC/C,aAAa,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC;YAChD,eAAe,EAAE,SAAS;YAC1B,YAAY,EAAE,EAAE;YAChB,iBAAiB,EAAE,CAAC;YACpB,wBAAwB,EAAE,GAAG;YAC7B,UAAU,EAAE,EAAE;YACd,eAAe,EAAE,KAAK;YACtB,eAAe,EAAE,SAAS;YAC1B,gBAAgB,EAAE,SAAS;YAC3B,eAAe,EAAE,CAAC;YAClB,wBAAwB,EAAE,CAAC;YAC3B,4BAA4B,EAAE,EAAE;YAChC,6BAA6B,EAAE,EAAE;YACjC,YAAY,EAAE,SAAS;YACvB,eAAe,EAAE,SAAS;YAC1B,kBAAkB,EAAE,SAAS;YAC7B,kBAAkB,EAAE,SAAS;YAC7B,aAAa,EAAE,SAAS;YACxB,iBAAiB,EAAE,kBAAkB,CAAC,YAAY,CAAC,iBAAiB;SACrE,CAAC;IAIF,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,kBAAkB,EAAE,iBAAiB,EAAE,IAAI,CACrD,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,WAAW,CACtC,CAAC;IACJ,CAAC;IAED,QAAQ,KAAI,CAAC;IAEb,WAAW;QACT,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,SAAS,CAAC,MAAoB;QAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED;;OAEG;IACK,WAAW;QACjB,EAAE,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,CAAC;QACxC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED;;OAEG;IACK,mBAAmB;QACzB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,GACjE,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAE1B,MAAM,GAAG,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;QACpD,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;QACpD,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;QACnD,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IACxC,CAAC;IAED;;OAEG;IACK,oBAAoB;QAC1B,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5C,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,2BAA2B,CACpE,GAAG,EACH,IAAI,CAAC,oBAAoB,EACzB,IAAI,CAAC,wBAAwB,CAC9B,CAAC;QACJ,CAAC;QAED,IAAI,IAAI,CAAC,kBAAkB,CAAC,eAAe,KAAK,SAAS;YACvD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC;IACnE,CAAC;IAED;;OAEG;IACK,gBAAgB;QACtB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;QACzC,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;QACjC,MAAM,SAAS,GAAG,QAAQ,CAAC,SAAS,IAAI,MAAM,CAAC;QAC/C,MAAM,SAAS,GACb,SAAS,KAAK,KAAK;YACjB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY;YACtC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC;QAE5C,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC;YACtB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;YACvE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC9B,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACpE,MAAM,KAAK,GAAG,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACjC,MAAM,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC,EAAE,EAAE;YACpD,MAAM,IAAI,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;YAC7B,GAAG,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC;YACtC,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAc,CAAC,CAAC;QAEnB,MAAM,KAAK,GACT,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACnE,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI;YACnC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC;QACvC,MAAM,MAAM,GACV,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACzE,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG;YAClC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,MAAM;YACrC,EAAE,CAAC;QAEL,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;QAE3C,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC;IACvE,CAAC;IAED;;OAEG;IACK,kBAAkB,CAAC,MAAc;QACvC,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;QAC9C,MAAM,cAAc,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QAClE,MAAM,KAAK,GAAG,QAAQ,CAAC,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;QAExD,MAAM,GAAG,GAAG,cAAc;aACvB,MAAM,CAAC,KAAK,CAAC;aACb,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC;aACzB,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC;aACpB,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC;aACtB,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC;aAC9B,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CACH,WAAW,EACX,aAAa,MAAM,CAAC,IAAI,GAAG,MAAM,KAAK,MAAM,CAAC,GAAG,GAAG,MAAM,GAAG,CAC7D,CAAC;QAEJ,OAAO,GAAG,CAAC;IACb,CAAC;IAED;;OAEG;IACK,QAAQ,CAAC,GAAG,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ;QACnD,MAAM,GAAG,GAAG,EAAE;aACX,GAAG,EAAE;aACL,WAAW,CACV,IAAI,CAAC,kBAAkB,CAAC,SAAS;YAC/B,IAAI,CAAC,kBAAkB,CAAC,SAAS;YACjC,EAAE,CACL;aACA,WAAW,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,GAAG,EAAE,CAAC;aACnD,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACvF,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QAErF,MAAM,WAAW,GAAG,QAAQ,CAAC,YAAY,IAAI,QAAQ,CAAC,YAAY,GAAG,CAAC,CAAC;QAEvE,GAAG;aACA,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC;aACpB,SAAS,CAAC,MAAM,CAAC;aACjB,IAAI,CAAC,UAAU,CAAC;aAChB,KAAK,EAAE;aACP,MAAM,CAAC,MAAM,CAAC;aACd,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;aACpC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC;aACd,KAAK,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;aACpD,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;YACxB,IAAI,WAAW;gBAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM;QACnD,MAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpE,MAAM,KAAK,GACT,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YACnD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,YAAY,GAChB,IAAI,CAAC,kBAAkB,CAAC,QAAQ,GAAG,CAAC,YAAY,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC;QAElE,MAAM,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAClC,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,wBAAwB,CAC1D,CAAC;QAEF,MAAM,QAAQ,GAAG;YACf,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,GAAG,CAAC,EAAE,CAAC,CAAC;YAC7C,CAAC,CAAC,EAAE,CAAC,iBAAiB,CAAC;YACvB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,GAAG,CAAC,EAAE,CAAC,CAAC;YAC9C,CAAC,CAAC,EAAE,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC;YAC9C,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,GAAG,CAAC,EAAE,CAAC,CAAC;SAC9C,CAAC;QAEF,GAAG;aACA,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC;aACxB,MAAM,CAAC,MAAM,CAAC;aACd,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,CAAC;aAC9B,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC;aAClD,IAAI,CACH,WAAW,EACX,UAAU,YAAY,kBACpB,CAAC,MAAM;YACP,IAAI,CAAC,kBAAkB,CAAC,SAAS;YACjC,iBACF,GAAG,CACJ,CAAC;IACN,CAAC;IAED;;OAEG;IACK,UAAU,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ;QAClD,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;QACjC,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,UAAU,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QACjD,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;YAChC,MAAM,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC;YACzB,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;YACtD,OAAO,MAAM,CAAC;QAChB,CAAC,EAAE,CAAC,CAAC,CAAC;QAEN,MAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC3D,UAAU;aACP,SAAS,CAAC,MAAM,CAAC;aACjB,IAAI,CAAC,UAAU,CAAC;aAChB,KAAK,EAAE;aACP,MAAM,CAAC,MAAM,CAAC;aACd,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE;YACvB,MAAM,QAAQ,GACZ,IAAI,CAAC,kBAAkB,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC;YAC7D,OAAO,UAAU,QAAQ,kBACvB,IAAI,CAAC,kBAAkB,CAAC,UAAU,GAAG,MAAM,GAAG,EAChD,GAAG,CAAC;QACN,CAAC,CAAC;aACD,IAAI,CAAC,MAAM,EAAE,yBAAyB,CAAC;aACvC,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC;aAC1B,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC;aAC3B,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CACV,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAC7D,CAAC;IACN,CAAC;IAED;;OAEG;IACK,SAAS,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM;QACrC,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,GAAG,EAAE,CAAC;QAC7B,MAAM,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,6BAA6B,CAAC;QAC1E,MAAM,OAAO,GACX,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,6BAA6B,CAAC;QAE/D,GAAG;aACA,MAAM,CAAC,eAAe,CAAC;aACvB,IAAI,CAAC,WAAW,EAAE,aAAa,MAAM,GAAG,EAAE,KAAK,IAAI,GAAG,CAAC;aACvD,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC;aAClB,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;aAClB,MAAM,CAAC,WAAW,CAAC;aACnB,IAAI,CAAC,OAAO,EAAE,eAAe,CAAC;aAC9B,IAAI,CAAC,GAAG,QAAQ,CAAC,YAAY,GAAG,QAAQ,CAAC,QAAQ,IAAI,EAAE,EAAE,CAAC,CAAC;QAE9D,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACpB,GAAG;iBACA,MAAM,CAAC,eAAe,CAAC;iBACvB,IAAI,CAAC,WAAW,EAAE,aAAa,MAAM,GAAG,EAAE,KAAK,IAAI,GAAG,CAAC;iBACvD,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC;iBAClB,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;iBAClB,MAAM,CAAC,WAAW,CAAC;iBACnB,IAAI,CAAC,OAAO,EAAE,gBAAgB,CAAC;iBAC/B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC3B,CAAC;QAED,IAAI,QAAQ,CAAC,SAAS,EAAE,CAAC;YACvB,GAAG;iBACA,MAAM,CAAC,eAAe,CAAC;iBACvB,IAAI,CAAC,WAAW,EAAE,aAAa,MAAM,GAAG,GAAG,KAAK,OAAO,GAAG,CAAC;iBAC3D,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC;iBAClB,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;iBAClB,MAAM,CAAC,WAAW,CAAC;iBACnB,IAAI,CAAC,OAAO,EAAE,mBAAmB,CAAC;iBAClC,IAAI,CACH,oEAAoE,QAAQ,CAAC,SAAS,EAAE,CACzF,CAAC;QACN,CAAC;IACH,CAAC;IAED,iCAAiC;IACzB,OAAO,CAAC,GAAW;QACzB,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;IAC/B,CAAC;IAED,WAAW,CAAC,CAAM;QAChB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IAED,qBAAqB,CAAC,EAAU;QAC9B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACrC,CAAC;+GAvUU,mBAAmB;mGAAnB,mBAAmB,ygBCtBhC,sgCAYM;;4FDUO,mBAAmB;kBAN/B,SAAS;+BACE,iBAAiB,iBAGZ,iBAAiB,CAAC,IAAI;wDAGe,YAAY;sBAA/D,SAAS;uBAAC,qBAAqB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACH,iBAAiB;sBAA/D,SAAS;uBAAC,gBAAgB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAEpC,SAAS;sBAAjB,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACI,UAAU;sBAAnB,MAAM;gBACG,oBAAoB;sBAA7B,MAAM","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewChild,\r\n  ElementRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport * as d3 from 'd3';\r\nimport { ComponentUniqueId } from '../unique-id';\r\nimport ChartHelper from '../chart-helper';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport HeaderConfigHelper from '../header-config';\r\n\r\n@Component({\r\n  selector: 'lib-guage-chart',\r\n  templateUrl: './guage-chart.component.html',\r\n  styleUrls: ['./guage-chart.component.less', '../common-styles.less'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class GuageChartComponent extends ComponentUniqueId implements OnInit {\r\n  @ViewChild('guagechartcontainer', { static: true }) containerElt!: ElementRef;\r\n  @ViewChild('guagecontainer', { static: true }) guagecontainerElt!: ElementRef;\r\n\r\n  @Input() chartData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n\r\n  chartConfiguration: any = {};\r\n  dataType = '';\r\n  datatype_status = false;\r\n  uniqueId = this.getUniqueId();\r\n  isHeaderVisible = true;\r\n\r\n  defaultConfiguration = {\r\n    margin: { top: 40, right: 20, bottom: 20, left: 20 },\r\n    minAngle: -90,\r\n    maxAngle: 90,\r\n    ringInset: 20,\r\n    ringWidth: 20,\r\n    majorTicks: 3,\r\n    svgHeight: 80,\r\n    low_colorMap: ['#43CC00', '#FFEF0C', '#FF4E0C'],\r\n    high_colorMap: ['#FF4E0C', '#FFEF0C', '#43CC00'],\r\n    isHeaderVisible: undefined,\r\n    pointerWidth: 10,\r\n    pointerTailLength: 5,\r\n    pointerHeadLengthPercent: 0.7,\r\n    labelInset: 10,\r\n    legendJustified: false,\r\n    backgroundColor: '#FFFFFF',\r\n    isDrilldownChart: undefined,\r\n    ringScaleFactor: 0,\r\n    textsAtCenterScaleFactor: 0,\r\n    currentValueWidthScaleFactor: 60,\r\n    currentValueHeightScaleFactor: 30,\r\n    pointerColor: '#686868',\r\n    isToggleVisible: undefined,\r\n    selectedKpiTooltop: undefined,\r\n    isValueLableAdjust: undefined,\r\n    isTitleHidden: undefined,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n  };\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  get isAlertEnabled(): boolean {\r\n    return this.chartConfiguration?.headerMenuOptions?.some(\r\n      (option) => option.id === 'editAlert'\r\n    );\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  ngOnChanges() {\r\n    this.redrawChart();\r\n  }\r\n\r\n  onResized(_event: ResizedEvent) {\r\n    this.redrawChart();\r\n  }\r\n\r\n  /** \r\n   * Clears the previous SVG and redraws chart \r\n   */\r\n  private redrawChart(): void {\r\n    d3.select('#' + this.uniqueId).remove();\r\n    this.initializeLineChart();\r\n  }\r\n\r\n  /** \r\n   * Main entry point for chart rendering \r\n   */\r\n  private initializeLineChart(): void {\r\n    this.prepareConfiguration();\r\n    const { data, metaData, colorMaps, data_ready, angleValue, radius } =\r\n      this.processChartData();\r\n\r\n    const svg = this.createSvgContainer(radius);\r\n    this.drawArcs(svg, data_ready, colorMaps, metaData);\r\n    this.drawPointer(svg, metaData, data_ready, radius);\r\n    this.drawLabels(svg, data_ready, radius, metaData);\r\n    this.drawTexts(svg, metaData, radius);\r\n  }\r\n\r\n  /** \r\n   * Prepare chart configuration \r\n   */\r\n  private prepareConfiguration(): void {\r\n    for (const key in this.defaultConfiguration) {\r\n      this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(\r\n        key,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n\r\n    if (this.chartConfiguration.isHeaderVisible !== undefined)\r\n      this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n  }\r\n\r\n  /** \r\n   * Process data, calculate colors and angles \r\n   */\r\n  private processChartData() {\r\n    const metaData = this.chartData.metaData;\r\n    const data = this.chartData.data;\r\n    const colorType = metaData.colorType || 'high';\r\n    const colorMaps =\r\n      colorType === 'low'\r\n        ? this.chartConfiguration.low_colorMap\r\n        : this.chartConfiguration.high_colorMap;\r\n\r\n    if (metaData.dataType) {\r\n      this.dataType = metaData.dataType === 'USD' ? '$ ' : metaData.dataType;\r\n      this.datatype_status = true;\r\n    }\r\n\r\n    const data_ready = data.slice(0, -1).map((v, i) => data[i + 1] - v);\r\n    const total = d3.sum(data_ready);\r\n    const angleValue = data_ready.reduce((acc, curr, i) => {\r\n      const prev = acc[i - 1] || 0;\r\n      acc.push(prev + (curr / total) * 180);\r\n      return acc;\r\n    }, [] as number[]);\r\n\r\n    const width =\r\n      parseInt(d3.select(this.containerElt.nativeElement).style('width')) -\r\n      this.chartConfiguration.margin.left -\r\n      this.chartConfiguration.margin.right;\r\n    const height =\r\n      parseInt(d3.select(this.guagecontainerElt.nativeElement).style('height')) -\r\n      this.chartConfiguration.margin.top -\r\n      this.chartConfiguration.margin.bottom -\r\n      56;\r\n\r\n    const radius = Math.min(width, height) / 2;\r\n\r\n    return { data, metaData, colorMaps, data_ready, angleValue, radius };\r\n  }\r\n\r\n  /** \r\n   * Create SVG base container \r\n   */\r\n  private createSvgContainer(radius: number) {\r\n    const margin = this.chartConfiguration.margin;\r\n    const chartContainer = d3.select(this.containerElt.nativeElement);\r\n    const width = parseInt(chartContainer.style('width'));\r\n    const height = parseInt(chartContainer.style('height'));\r\n\r\n    const svg = chartContainer\r\n      .append('svg')\r\n      .attr('id', this.uniqueId)\r\n      .attr('width', width)\r\n      .attr('height', height)\r\n      .call(ChartHelper.responsivefy)\r\n      .append('g')\r\n      .attr(\r\n        'transform',\r\n        `translate(${margin.left + radius}, ${margin.top + radius})`\r\n      );\r\n\r\n    return svg;\r\n  }\r\n\r\n  /** \r\n   * Draw gauge arcs \r\n   */\r\n  private drawArcs(svg, data_ready, colorMaps, metaData) {\r\n    const arc = d3\r\n      .arc()\r\n      .innerRadius(\r\n        this.chartConfiguration.ringWidth +\r\n          this.chartConfiguration.ringInset -\r\n          20\r\n      )\r\n      .outerRadius(this.chartConfiguration.ringWidth + 40)\r\n      .startAngle((_, i) => this.deg2rad(this.chartConfiguration.minAngle + (i ? i * 60 : 0)))\r\n      .endAngle((_, i) => this.deg2rad(this.chartConfiguration.minAngle + (i + 1) * 60));\r\n\r\n    const isClickable = metaData.hasDrillDown && metaData.currentValue > 0;\r\n\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'arc')\r\n      .selectAll('path')\r\n      .data(data_ready)\r\n      .enter()\r\n      .append('path')\r\n      .attr('fill', (_, i) => colorMaps[i])\r\n      .attr('d', arc)\r\n      .style('cursor', isClickable ? 'pointer' : 'default')\r\n      .on('click', (event, d) => {\r\n        if (isClickable) this.handleClick(d);\r\n      });\r\n  }\r\n\r\n  /** \r\n   * Draw the pointer/needle \r\n   */\r\n  private drawPointer(svg, metaData, data_ready, radius) {\r\n    const pointerValue = metaData.currentValue - this.chartData.data[0];\r\n    const range =\r\n      this.chartData.data[this.chartData.data.length - 1] -\r\n      this.chartData.data[0];\r\n    const pointerAngle =\r\n      this.chartConfiguration.minAngle + (pointerValue / range) * 180;\r\n\r\n    const pointerHeadLength = Math.round(\r\n      radius * this.chartConfiguration.pointerHeadLengthPercent\r\n    );\r\n\r\n    const lineData = [\r\n      [this.chartConfiguration.pointerWidth / 2, 0],\r\n      [0, -pointerHeadLength],\r\n      [-this.chartConfiguration.pointerWidth / 2, 0],\r\n      [0, this.chartConfiguration.pointerTailLength],\r\n      [this.chartConfiguration.pointerWidth / 2, 0],\r\n    ];\r\n\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'pointer')\r\n      .append('path')\r\n      .attr('d', d3.line()(lineData))\r\n      .attr('fill', this.chartConfiguration.pointerColor)\r\n      .attr(\r\n        'transform',\r\n        `rotate(${pointerAngle}) translate(0, ${\r\n          -radius +\r\n          this.chartConfiguration.ringWidth +\r\n          pointerHeadLength\r\n        })`\r\n      );\r\n  }\r\n\r\n  /** \r\n   * Draw numeric labels around gauge \r\n   */\r\n  private drawLabels(svg, data_ready, radius, metaData) {\r\n    const data = this.chartData.data;\r\n    const range = data[data.length - 1] - data[0];\r\n    const labelArray = [{ name: data[0], value: 0 }];\r\n    data_ready.reduce((sum, val, i) => {\r\n      const newSum = sum + val;\r\n      labelArray.push({ name: data[i + 1], value: newSum });\r\n      return newSum;\r\n    }, 0);\r\n\r\n    const labelGroup = svg.append('g').attr('class', 'labels');\r\n    labelGroup\r\n      .selectAll('text')\r\n      .data(labelArray)\r\n      .enter()\r\n      .append('text')\r\n      .attr('transform', (d) => {\r\n        const newAngle =\r\n          this.chartConfiguration.minAngle + (d.value / range) * 180;\r\n        return `rotate(${newAngle}) translate(0, ${\r\n          this.chartConfiguration.labelInset - radius - 20\r\n        })`;\r\n      })\r\n      .attr('fill', 'var(--chart-text-color)')\r\n      .style('font-size', '14px')\r\n      .style('font-weight', '600')\r\n      .text((d) =>\r\n        metaData.dataType ? `${d.name}${metaData.dataType}` : d.name\r\n      );\r\n  }\r\n\r\n  /** \r\n   * Draw texts (value, status, date) \r\n   */\r\n  private drawTexts(svg, metaData, radius) {\r\n    const topY = radius / 2 - 10;\r\n    const midY = topY + this.chartConfiguration.currentValueHeightScaleFactor;\r\n    const bottomY =\r\n      midY + this.chartConfiguration.currentValueHeightScaleFactor;\r\n\r\n    svg\r\n      .append('foreignObject')\r\n      .attr('transform', `translate(${radius - 50}, ${topY})`)\r\n      .attr('width', 100)\r\n      .attr('height', 40)\r\n      .append('xhtml:div')\r\n      .attr('class', 'value-display')\r\n      .html(`${metaData.currentValue}${metaData.dataType || ''}`);\r\n\r\n    if (metaData.status) {\r\n      svg\r\n        .append('foreignObject')\r\n        .attr('transform', `translate(${radius - 60}, ${midY})`)\r\n        .attr('width', 120)\r\n        .attr('height', 40)\r\n        .append('xhtml:div')\r\n        .attr('class', 'status-display')\r\n        .html(metaData.status);\r\n    }\r\n\r\n    if (metaData.dateRange) {\r\n      svg\r\n        .append('foreignObject')\r\n        .attr('transform', `translate(${radius - 105}, ${bottomY})`)\r\n        .attr('width', 210)\r\n        .attr('height', 40)\r\n        .append('xhtml:div')\r\n        .attr('class', 'daterange-display')\r\n        .html(\r\n          `<span class=\"marginright-3\"><i class=\"fa fa-calendar\"></i></span>${metaData.dateRange}`\r\n        );\r\n    }\r\n  }\r\n\r\n  /** Convert degrees to radians */\r\n  private deg2rad(deg: number): number {\r\n    return (deg * Math.PI) / 180;\r\n  }\r\n\r\n  handleClick(d: any) {\r\n    this.clickEvent.emit(d);\r\n  }\r\n\r\n  handleHeaderMenuClick(id: string) {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n}\r\n","<div #guagecontainer class=\"lib-chart-wrapper\" style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\">\r\n  <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n    <lib-chart-header-v2 [chartData]=\"chartData\" [chartConfiguration]=\"chartConfiguration\"\r\n      (clickEvent)=\"handleClick($event)\"></lib-chart-header-v2>\r\n  </div>\r\n  <lib-chart-header-v1 [title]=\"chartData.metaData.title\" [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n    [isEditEnabled]=\"chartData.metaData.isEditEnabled\" [isria]=\"customChartConfiguration.isRia\" [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n    [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\" (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n    [isAlertEnabled]=\"isAlertEnabled\" *ngIf=\"isHeaderVisible\"></lib-chart-header-v1>\r\n  <div [style.height]=\"chartConfiguration.svgHeight\" id=\"guagechartcontainer\" #guagechartcontainer\r\n    class=\"lib-chart-svg guagecontainer\"></div>\r\n</div>"]}
|
|
332
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guage-chart.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/guage-chart/guage-chart.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/guage-chart/guage-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewChild,\r\n  ElementRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport * as d3 from 'd3';\r\nimport { ComponentUniqueId } from '../unique-id';\r\nimport ChartHelper from '../chart-helper';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport HeaderConfigHelper from '../header-config';\r\n\r\n@Component({\r\n  selector: 'lib-guage-chart',\r\n  templateUrl: './guage-chart.component.html',\r\n  styleUrls: ['./guage-chart.component.less', '../common-styles.less'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class GuageChartComponent extends ComponentUniqueId implements OnInit {\r\n  @ViewChild('guagechartcontainer', { static: true }) containerElt!: ElementRef;\r\n  @ViewChild('guagecontainer', { static: true }) guagecontainerElt!: ElementRef;\r\n\r\n  @Input() chartData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n\r\n  chartConfiguration: any = {};\r\n  dataType: any = '';\r\n  datatype_status: boolean = false;\r\n  uniqueId: any = this.getUniqueId();\r\n  isHeaderVisible: boolean = true;\r\n\r\n  defaultConfiguration: any = {\r\n    margin: { top: 40, right: 20, bottom: 20, left: 20 },\r\n    minAngle: -90,\r\n    maxAngle: 90,\r\n    ringInset: 20,\r\n    ringWidth: 20,\r\n    majorTicks: 3,\r\n    svgHeight: 80,\r\n    low_colorMap: ['#43CC00', '#FFEF0C', '#FF4E0C'],\r\n    high_colorMap: ['#FF4E0C', '#FFEF0C', '#43CC00'],\r\n    isHeaderVisible: undefined,\r\n    pointerWidth: 10,\r\n    pointerTailLength: 5,\r\n    pointerHeadLengthPercent: 0.7,\r\n    labelInset: 10,\r\n    legendJustified: false,\r\n    backgroundColor: '#FFFFFF',\r\n    isDrilldownChart: undefined,\r\n    ringScaleFactor: 0,\r\n    textsAtCenterScaleFactor: 0,\r\n    currentValueWidthScaleFactor: 60,\r\n    currentValueHeightScaleFactor: 30,\r\n    pointerColor: '#686868',\r\n    isToggleVisible: undefined,\r\n    selectedKpiTooltop: undefined,\r\n    isValueLableAdjust: undefined,\r\n    isTitleHidden: undefined,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n  };\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  get isAlertEnabled(): boolean {\r\n    return this.chartConfiguration?.headerMenuOptions?.some(\r\n      (option) => option.id === 'editAlert'\r\n    );\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  ngOnChanges() {\r\n    d3.select('#' + this.uniqueId).remove();\r\n    this.initializeLineChart();\r\n  }\r\n\r\n  onResized(event: ResizedEvent) {\r\n    d3.select('#' + this.uniqueId).remove();\r\n    this.initializeLineChart();\r\n  }\r\n\r\n  /** -------------------------------\r\n   *  Main Initialization Function\r\n   *  ------------------------------*/\r\n  initializeLineChart() {\r\n    const self = this;\r\n    const { data, metaData } = this.chartData;\r\n    const isRia = this.customChartConfiguration.isRia;\r\n\r\n    this.setupChartConfiguration();\r\n    const { colorMaps } = this.getColorMap(metaData);\r\n    this.configureDataType(metaData);\r\n\r\n    const data_ready = this.calculateDataReady(data);\r\n    const { chartContainer, guagecontainer, width, height } =\r\n      this.setupContainer();\r\n\r\n    this.isHeaderVisible =\r\n      this.chartConfiguration.isHeaderVisible ?? this.isHeaderVisible;\r\n\r\n    const svg = this.createSvg(chartContainer, width, height);\r\n    const radius = this.adjustDimensionsAndRadius(width, height);\r\n\r\n    const angleValue = this.computeAngles(data_ready, data);\r\n    const arc = this.createArc(radius, angleValue, data_ready);\r\n\r\n    this.drawGaugeArcs(svg, arc, data_ready, colorMaps, metaData, isRia, data);\r\n    this.drawPointer(svg, radius, metaData, data);\r\n    this.drawLabels(svg, radius, data_ready, data, metaData);\r\n    this.drawCenterTexts(svg, radius, metaData);\r\n\r\n    this.centerSvg(svg, chartContainer, width, height);\r\n  }\r\n\r\n  /** -------------------------------\r\n   *  Modular Helper Functions\r\n   *  ------------------------------*/\r\n\r\n  private setupChartConfiguration() {\r\n    for (const key in this.defaultConfiguration) {\r\n      this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(\r\n        key,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n  }\r\n\r\n  private getColorMap(metaData: any) {\r\n    const colorType = metaData.colorType;\r\n    const colorMaps =\r\n      colorType === 'low'\r\n        ? this.chartConfiguration.low_colorMap\r\n        : this.chartConfiguration.high_colorMap;\r\n    return { colorMaps };\r\n  }\r\n\r\n  private configureDataType(metaData: any) {\r\n    if (metaData.dataType) {\r\n      this.dataType = metaData.dataType;\r\n      if (this.dataType === 'USD') {\r\n        this.datatype_status = true;\r\n        this.dataType = '$ ';\r\n      }\r\n    }\r\n  }\r\n\r\n  private calculateDataReady(data: any[]): number[] {\r\n    const data_ready: number[] = [];\r\n    data.forEach((_, i) => {\r\n      if (i < data.length - 1) {\r\n        data_ready.push(data[i + 1] - data[i]);\r\n      }\r\n    });\r\n    return data_ready;\r\n  }\r\n\r\n  private setupContainer() {\r\n    const chartContainer = d3.select(this.containerElt.nativeElement);\r\n    const guagecontainer = d3.select(this.guagecontainerElt.nativeElement);\r\n    const margin = this.chartConfiguration.margin;\r\n\r\n    const width =\r\n      parseInt(chartContainer.style('width')) - margin.left - margin.right;\r\n    const height =\r\n      parseInt(guagecontainer.style('height')) -\r\n      margin.top -\r\n      margin.bottom -\r\n      56; // chart header height\r\n\r\n    return { chartContainer, guagecontainer, width, height };\r\n  }\r\n\r\n  private createSvg(chartContainer, width, height) {\r\n    const margin = this.chartConfiguration.margin;\r\n    return chartContainer\r\n      .append('svg')\r\n      .attr('id', this.uniqueId)\r\n      .attr('width', width + margin.left + margin.right)\r\n      .attr('height', height + margin.top + margin.bottom)\r\n      .call(ChartHelper.responsivefy)\r\n      .append('g');\r\n  }\r\n\r\n  private adjustDimensionsAndRadius(width: number, height: number): number {\r\n    const radius = Math.min(width, height) / 2;\r\n\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      this.chartConfiguration.currentValueWidthScaleFactor += 40;\r\n      this.chartConfiguration.currentValueHeightScaleFactor += 20;\r\n    } else if (window.innerWidth > 1400) {\r\n      this.chartConfiguration.currentValueHeightScaleFactor += 15;\r\n      this.chartConfiguration.currentValueWidthScaleFactor *= 2;\r\n    }\r\n\r\n    return radius;\r\n  }\r\n\r\n  private computeAngles(data_ready: number[], data: any[]): number[] {\r\n    const total = data_ready.reduce((sum, val) => sum + val, 0);\r\n    const tempArray: number[] = [];\r\n\r\n    data_ready.forEach((unit, i) => {\r\n      const angle = (unit / total) * 180;\r\n      tempArray.push(i === 0 ? angle : tempArray[i - 1] + angle);\r\n    });\r\n\r\n    return tempArray;\r\n  }\r\n\r\n\r\n  private createArc(radius: number, angleValue: number[], data_ready: number[]) {\r\n    const self = this;\r\n    const deg2rad = (deg: number) => (deg * Math.PI) / 180;\r\n\r\n    return d3\r\n      .arc()\r\n      .innerRadius(\r\n        radius -\r\n          self.chartConfiguration.ringWidth -\r\n          self.chartConfiguration.ringInset\r\n      )\r\n      .outerRadius(radius)\r\n      .startAngle((_, i) =>\r\n        deg2rad(\r\n          i === 0\r\n            ? self.chartConfiguration.minAngle\r\n            : self.chartConfiguration.minAngle + angleValue[i - 1]\r\n        )\r\n      )\r\n      .endAngle((_, i) =>\r\n        deg2rad(\r\n          i === data_ready.length - 1\r\n            ? self.chartConfiguration.maxAngle\r\n            : self.chartConfiguration.minAngle + angleValue[i]\r\n        )\r\n      );\r\n  }\r\n\r\n  private drawGaugeArcs(svg, arc, data_ready, colorMaps, metaData, isRia, data) {\r\n    const self = this;\r\n    const arcs = svg\r\n      .append('g')\r\n      .attr('class', 'arc')\r\n      .attr('transform', this.centerTranslation(arc.outerRadius()()));\r\n\r\n    arcs\r\n      .selectAll('path')\r\n      .data(data_ready)\r\n      .enter()\r\n      .append('path')\r\n      .attr('fill', (_, i) => colorMaps[i])\r\n      .style('cursor', () =>\r\n        metaData.currentValue > 0 && metaData.hasDrillDown && !isRia\r\n          ? 'pointer'\r\n          : 'default'\r\n      )\r\n      .attr('d', arc)\r\n      .on('click', (d) => {\r\n        if (!metaData.hasDrillDown || metaData.currentValue === 0) return;\r\n        const range = `${data[0]} and ${data[data.length - 1]}`;\r\n        self.handleClick(range);\r\n      });\r\n  }\r\n\r\n  private drawPointer(svg, radius, metaData, data) {\r\n    const self = this;\r\n    const pointerHeadLength = Math.round(\r\n      radius * self.chartConfiguration.pointerHeadLengthPercent\r\n    );\r\n\r\n    const lineData = [\r\n      [self.chartConfiguration.pointerWidth / 2, 0],\r\n      [0, -pointerHeadLength],\r\n      [-(self.chartConfiguration.pointerWidth / 2), 0],\r\n      [0, self.chartConfiguration.pointerTailLength],\r\n      [self.chartConfiguration.pointerWidth / 2, 0],\r\n    ];\r\n\r\n    const pointerLine = d3.line();\r\n    const pg = svg\r\n      .append('g')\r\n      .data([lineData])\r\n      .attr('class', 'pointer')\r\n      .attr('transform', this.centerTranslation(radius));\r\n\r\n    const pointerValue = metaData.currentValue - data[0];\r\n    const range = data[data.length - 1] - data[0];\r\n    const pointerAngle =\r\n      self.chartConfiguration.minAngle + (pointerValue / range) * 180;\r\n\r\n    pg.append('path')\r\n      .attr('d', pointerLine)\r\n      .attr('fill', self.chartConfiguration.pointerColor)\r\n      .attr(\r\n        'transform',\r\n        `rotate(${pointerAngle}) translate(0,${\r\n          -radius + self.chartConfiguration.ringWidth + pointerHeadLength\r\n        })`\r\n      );\r\n  }\r\n\r\n  private drawLabels(svg, radius, data_ready, data, metaData) {\r\n    const self = this;\r\n    const range = data[data.length - 1] - data[0];\r\n    const labelArray = this.buildLabelArray(data_ready, data);\r\n\r\n    const lg = svg\r\n      .append('g')\r\n      .attr('class', 'label')\r\n      .attr('transform', this.centerTranslation(radius));\r\n\r\n    lg.selectAll('.bubble')\r\n      .data(labelArray)\r\n      .enter()\r\n      .append('g')\r\n      .attr('transform', (d) => {\r\n        const newAngle =\r\n          self.chartConfiguration.minAngle + (d.value / range) * 180;\r\n        return `rotate(${newAngle}) translate(0,${\r\n          self.chartConfiguration.labelInset - radius - 20\r\n        })`;\r\n      })\r\n      .append('text')\r\n      .attr('fill', 'var(--chart-text-color)')\r\n      .style('font-size', window.innerWidth < 1400 ? '12px' : '14px')\r\n      .style('font-weight', '600')\r\n      .text((d) => (metaData.dataType ? d.name + metaData.dataType : d.name));\r\n  }\r\n\r\n  private buildLabelArray(data_ready: number[], data: any[]) {\r\n    const labelArray = [{ name: data[0], value: 0 }];\r\n    let count = 0;\r\n    data_ready.forEach((unit, i) => {\r\n      count += unit;\r\n      labelArray.push({ name: data[i + 1], value: count });\r\n    });\r\n    return labelArray;\r\n  }\r\n\r\n  private drawCenterTexts(svg, radius, metaData) {\r\n    const self = this;\r\n    const top = radius / 2 - 10;\r\n    const mid = top + self.chartConfiguration.currentValueHeightScaleFactor;\r\n    const bottom = mid + self.chartConfiguration.currentValueHeightScaleFactor;\r\n\r\n    // current value\r\n    svg\r\n      .append('foreignObject')\r\n      .attr(\r\n        'transform',\r\n        `translate(${radius - this.chartConfiguration.currentValueWidthScaleFactor / 2},${top})`\r\n      )\r\n      .attr('width', this.chartConfiguration.currentValueWidthScaleFactor + 8)\r\n      .attr('height', this.chartConfiguration.currentValueHeightScaleFactor)\r\n      .append('xhtml:div')\r\n      .attr('class', 'value-display')\r\n      .html(metaData.currentValue + metaData.dataType);\r\n\r\n    // status\r\n    if (metaData.status) {\r\n      const widthTemp = metaData.status.length > 4 ? 210 : 120;\r\n      svg\r\n        .append('foreignObject')\r\n        .attr('transform', `translate(${radius - widthTemp / 2},${mid})`)\r\n        .attr('width', widthTemp)\r\n        .append('xhtml:div')\r\n        .attr('class', 'status-display')\r\n        .html(metaData.status);\r\n    }\r\n\r\n    // date range\r\n    svg\r\n      .append('foreignObject')\r\n      .attr('transform', `translate(${radius - 105},${bottom})`)\r\n      .attr('width', 210)\r\n      .append('xhtml:div')\r\n      .attr('class', 'daterange-display')\r\n      .html(\r\n        metaData.dateRange\r\n          ? `<span class=\"marginright-3\"><i class=\"fa fa-calendar\"></i></span><span>${metaData.dateRange}</span>`\r\n          : ''\r\n      );\r\n  }\r\n\r\n  private centerTranslation(radius: number) {\r\n    return `translate(${radius},${radius})`;\r\n  }\r\n\r\n  private centerSvg(svg, chartContainer, width, height) {\r\n    const margin = this.chartConfiguration.margin;\r\n    const containerMidWidth = parseInt(chartContainer.style('width')) / 2;\r\n    const nodeHalfWidth = svg.node().getBoundingClientRect().width / 2;\r\n    const updatedStartingPoint = containerMidWidth - nodeHalfWidth;\r\n\r\n    svg.attr(\r\n      'transform',\r\n      `translate(${updatedStartingPoint + margin.left},${margin.top})`\r\n    );\r\n  }\r\n\r\n  /** -------------------------------\r\n   *  Event Handlers\r\n   *  ------------------------------*/\r\n  handleClick(d: any) {\r\n    this.clickEvent.emit(d);\r\n  }\r\n\r\n  handleHeaderMenuClick(id) {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n}\r\n","<div #guagecontainer class=\"lib-chart-wrapper\" style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\">\r\n  <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n    <lib-chart-header-v2 [chartData]=\"chartData\" [chartConfiguration]=\"chartConfiguration\"\r\n      (clickEvent)=\"handleClick($event)\"></lib-chart-header-v2>\r\n  </div>\r\n  <lib-chart-header-v1 [title]=\"chartData.metaData.title\" [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n    [isEditEnabled]=\"chartData.metaData.isEditEnabled\" [isria]=\"customChartConfiguration.isRia\" [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n    [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\" (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n    [isAlertEnabled]=\"isAlertEnabled\" *ngIf=\"isHeaderVisible\"></lib-chart-header-v1>\r\n  <div [style.height]=\"chartConfiguration.svgHeight\" id=\"guagechartcontainer\" #guagechartcontainer\r\n    class=\"lib-chart-svg guagecontainer\"></div>\r\n</div>"]}
|