axidio-styleguide-library1-v2 0.2.24 → 0.2.26
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/group-chart/group-chart.component.mjs +189 -2
- package/esm2022/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.mjs +1081 -519
- package/esm2022/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.mjs +348 -314
- package/fesm2022/axidio-styleguide-library1-v2.mjs +1767 -984
- package/fesm2022/axidio-styleguide-library1-v2.mjs.map +1 -1
- package/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.d.ts +12 -74
- package/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.d.ts +10 -0
- package/package.json +1 -1
package/esm2022/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.mjs
CHANGED
|
@@ -18,18 +18,6 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
|
|
|
18
18
|
this.isTopCaptionVisible = true;
|
|
19
19
|
this.uniqueId = this.getUniqueId();
|
|
20
20
|
this.isTransparentBackground = false;
|
|
21
|
-
this.isCC = false;
|
|
22
|
-
this.isZoomedOut = true;
|
|
23
|
-
this.TICK_LENGTHS = {
|
|
24
|
-
short: 4,
|
|
25
|
-
long: 16,
|
|
26
|
-
shortBg: 5,
|
|
27
|
-
longBg: 30,
|
|
28
|
-
};
|
|
29
|
-
this.SPACING = {
|
|
30
|
-
rightSvgWidth: 60,
|
|
31
|
-
leftAndRight: 50,
|
|
32
|
-
};
|
|
33
21
|
this.defaultConfiguration = {
|
|
34
22
|
margin: { top: 20, right: 20, bottom: 20, left: 40 },
|
|
35
23
|
svgHeight: 70,
|
|
@@ -45,38 +33,83 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
|
|
|
45
33
|
forComparison: true,
|
|
46
34
|
headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,
|
|
47
35
|
yAxisGrid: false,
|
|
36
|
+
isHeaderVisible: undefined,
|
|
37
|
+
isTransparentBackground: undefined,
|
|
38
|
+
isTopCaptionVisible: undefined,
|
|
39
|
+
isMultiChartGridLine: undefined,
|
|
40
|
+
isFullScreen: undefined,
|
|
41
|
+
customYscale: undefined,
|
|
42
|
+
isXaxisLabelHidden: undefined,
|
|
43
|
+
isYaxisLabelHidden: undefined,
|
|
44
|
+
isYaxisHidden: undefined,
|
|
45
|
+
isYaxisDashed: undefined,
|
|
46
|
+
isXaxisColor: undefined,
|
|
47
|
+
textFormatter: undefined,
|
|
48
|
+
showTotalOnTop: undefined,
|
|
49
|
+
backendFormatterHasPriority: undefined,
|
|
50
|
+
showAngledLabels: undefined,
|
|
51
|
+
isNoAlternateXaxisText: undefined,
|
|
52
|
+
isXgridBetweenLabels: undefined,
|
|
53
|
+
showXaxisTop: undefined,
|
|
54
|
+
xAxisGrid: undefined,
|
|
55
|
+
xLabelsOnSameLine: undefined,
|
|
56
|
+
hideXaxisTick: undefined,
|
|
57
|
+
isDrilldownChart: undefined,
|
|
58
|
+
isTargetLine: undefined,
|
|
59
|
+
displayTitleOnTop: undefined,
|
|
60
|
+
isToggleVisible: undefined,
|
|
61
|
+
isTitleHidden: undefined,
|
|
48
62
|
};
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
ngOnChanges(changes) {
|
|
52
|
-
this.redrawChart();
|
|
53
|
-
}
|
|
54
|
-
onResized(event) {
|
|
55
|
-
setTimeout(() => this.redrawChart(), 10);
|
|
63
|
+
this.isCC = false;
|
|
64
|
+
this.isZoomedOut = true;
|
|
56
65
|
}
|
|
57
66
|
isZoomOutSelected(isZoomOut) {
|
|
58
67
|
this.isZoomedOut = isZoomOut;
|
|
59
|
-
this.
|
|
68
|
+
this.ngOnChanges();
|
|
60
69
|
}
|
|
61
|
-
|
|
62
|
-
|
|
70
|
+
ngOnChanges() {
|
|
71
|
+
let self = this;
|
|
72
|
+
d3.select('#' + self.uniqueId).remove();
|
|
63
73
|
this.initializeStackedChart();
|
|
64
74
|
}
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
};
|
|
75
|
+
onResized(event) {
|
|
76
|
+
let self = this;
|
|
77
|
+
setTimeout(function () {
|
|
78
|
+
d3.select('#' + self.uniqueId).remove();
|
|
79
|
+
self.initializeStackedChart();
|
|
80
|
+
}.bind(self), 10);
|
|
72
81
|
}
|
|
73
|
-
|
|
74
|
-
|
|
82
|
+
ngOnInit() { }
|
|
83
|
+
initializeStackedChart() {
|
|
84
|
+
var self = this;
|
|
85
|
+
let data = [];
|
|
86
|
+
let metaData = null;
|
|
87
|
+
let keyList = null;
|
|
88
|
+
let lineData = null;
|
|
89
|
+
let colors = null;
|
|
90
|
+
var alternate_text = false;
|
|
91
|
+
var alternate_label = false;
|
|
92
|
+
var short_tick_length = 4;
|
|
93
|
+
var long_tick_length = 16;
|
|
94
|
+
var short_tick_length_bg = 5;
|
|
95
|
+
var long_tick_length_bg = 30;
|
|
96
|
+
var formatFromBackend;
|
|
97
|
+
var formatForHugeNumbers;
|
|
98
|
+
var tempObjectHolder = {};
|
|
99
|
+
var rightSvgWidth = 60;
|
|
100
|
+
var leftAndRightSpaces = 50;
|
|
101
|
+
let isria = this.customChartConfiguration.isRia;
|
|
102
|
+
// Responsive breakpoints
|
|
103
|
+
const isMobile = window.innerWidth < 576;
|
|
104
|
+
const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;
|
|
105
|
+
const isDesktop = window.innerWidth >= 992;
|
|
106
|
+
// Adjust margins and font sizes based on device
|
|
107
|
+
if (isMobile) {
|
|
75
108
|
this.chartConfiguration.margin = { top: 20, right: 10, bottom: 40, left: 30 };
|
|
76
109
|
this.chartConfiguration.numberOfYTicks = 4;
|
|
77
110
|
this.chartConfiguration.svgHeight = 60;
|
|
78
111
|
}
|
|
79
|
-
else if (
|
|
112
|
+
else if (isTablet) {
|
|
80
113
|
this.chartConfiguration.margin = { top: 25, right: 20, bottom: 45, left: 40 };
|
|
81
114
|
this.chartConfiguration.numberOfYTicks = 6;
|
|
82
115
|
this.chartConfiguration.svgHeight = 70;
|
|
@@ -86,199 +119,102 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
|
|
|
86
119
|
this.chartConfiguration.numberOfYTicks = 7;
|
|
87
120
|
this.chartConfiguration.svgHeight = 80;
|
|
88
121
|
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
prepareMetaData(metaData) {
|
|
96
|
-
if (!metaData.unit)
|
|
122
|
+
for (var i in this.defaultConfiguration) {
|
|
123
|
+
this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(i, this.defaultConfiguration, this.customChartConfiguration);
|
|
124
|
+
}
|
|
125
|
+
data = this.chartData.data;
|
|
126
|
+
metaData = this.chartData.metaData;
|
|
127
|
+
if (metaData.unit == undefined)
|
|
97
128
|
metaData.unit = '';
|
|
98
|
-
if (metaData.isCC)
|
|
129
|
+
if (metaData.isCC) {
|
|
99
130
|
this.isCC = metaData.isCC;
|
|
100
|
-
|
|
101
|
-
|
|
131
|
+
}
|
|
132
|
+
if (metaData.barWithoutClick && metaData.barWithoutClick.length) {
|
|
133
|
+
metaData.barWithoutClick = metaData.barWithoutClick.map((ele) => ele.toLowerCase());
|
|
102
134
|
}
|
|
103
135
|
else {
|
|
104
136
|
metaData.barWithoutClick = [];
|
|
105
137
|
}
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
if (isNaN(parsedNum))
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
let width = containerWidth - margin.left - margin.right;
|
|
120
|
-
let height = containerHeight * (this.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;
|
|
121
|
-
// Adjust width for zoom levels
|
|
122
|
-
const dataLength = this.chartData.data.length;
|
|
123
|
-
if (dataLength > 30 && this.isZoomedOut) {
|
|
124
|
-
const minWidth = dataLength * (device.isMobile ? 15 : 25);
|
|
125
|
-
width = Math.max(width, minWidth);
|
|
138
|
+
lineData = this.chartData.lineData;
|
|
139
|
+
colors = metaData.colors;
|
|
140
|
+
keyList = metaData.keyList;
|
|
141
|
+
var chartContainer = d3.select(this.containerElt.nativeElement);
|
|
142
|
+
var verticalstackedcontainer = d3.select(this.verticalstackedcontainerElt.nativeElement);
|
|
143
|
+
let parsedNum = parseFloat(this.chartData?.targetLineData?.target);
|
|
144
|
+
if (!isNaN(parsedNum)) {
|
|
145
|
+
if (Number.isInteger(parsedNum)) {
|
|
146
|
+
parsedNum = parseInt(this.chartData.targetLineData.target);
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
parsedNum = parseFloat(this.chartData.targetLineData.target);
|
|
150
|
+
}
|
|
126
151
|
}
|
|
127
|
-
|
|
128
|
-
|
|
152
|
+
var margin = this.chartConfiguration.margin;
|
|
153
|
+
// Responsive width and height
|
|
154
|
+
var containerWidth = chartContainer.node().getBoundingClientRect().width;
|
|
155
|
+
var containerHeight = verticalstackedcontainer.node().getBoundingClientRect().height;
|
|
156
|
+
var width = containerWidth - margin.left - margin.right;
|
|
157
|
+
var height = containerHeight * (self.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;
|
|
158
|
+
// Adjust width for large datasets and zoom
|
|
159
|
+
if (this.chartData.data.length > 30 && this.isZoomedOut) {
|
|
160
|
+
width = width > this.chartData.data.length * (isMobile ? 15 : 25)
|
|
161
|
+
? width
|
|
162
|
+
: this.chartData.data.length * (isMobile ? 15 : 25);
|
|
129
163
|
}
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
height = this.chartConfiguration.svgHeight;
|
|
164
|
+
if (this.chartData.data.length > 8 && !this.isZoomedOut) {
|
|
165
|
+
width = this.chartData.data.length * (isMobile ? 60 : 130);
|
|
133
166
|
}
|
|
134
|
-
|
|
135
|
-
|
|
167
|
+
// Fullscreen and drilldown adjustments
|
|
168
|
+
if (this.chartConfiguration.isFullScreen != undefined && this.chartConfiguration.isFullScreen) {
|
|
169
|
+
height = this.chartConfiguration.svgHeight != 80
|
|
170
|
+
? this.chartConfiguration.svgHeight
|
|
171
|
+
: containerHeight;
|
|
136
172
|
}
|
|
137
173
|
if (this.chartConfiguration.isDrilldownChart) {
|
|
138
|
-
height = containerHeight - margin.top - margin.bottom - (
|
|
139
|
-
}
|
|
140
|
-
return { width, height };
|
|
141
|
-
}
|
|
142
|
-
calculateBarDimensions(width, dataLength, device) {
|
|
143
|
-
let barWidth;
|
|
144
|
-
let barPadding;
|
|
145
|
-
let requiredSvgWidth;
|
|
146
|
-
if (device.isMobile) {
|
|
147
|
-
const minBarWidth = 32;
|
|
148
|
-
barWidth = minBarWidth;
|
|
149
|
-
barPadding = 12;
|
|
150
|
-
requiredSvgWidth = Math.max(width - this.SPACING.rightSvgWidth, (barWidth + barPadding) * dataLength + this.SPACING.leftAndRight * 2 +
|
|
151
|
-
this.SPACING.rightSvgWidth - barPadding);
|
|
174
|
+
height = containerHeight - margin.top - margin.bottom - (isMobile ? 60 : 130);
|
|
152
175
|
}
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
}
|
|
160
|
-
createScales(data, height, width, device) {
|
|
161
|
-
const xScale = d3
|
|
162
|
-
.scaleBand()
|
|
163
|
-
.rangeRound([
|
|
164
|
-
this.SPACING.leftAndRight,
|
|
165
|
-
width - this.SPACING.rightSvgWidth - this.SPACING.leftAndRight
|
|
166
|
-
])
|
|
167
|
-
.domain(data.map(d => d.name).reverse())
|
|
168
|
-
.padding(device.isMobile ? 0.2 : 0.5);
|
|
169
|
-
const yScale = d3.scaleLinear().rangeRound([height, 0]);
|
|
170
|
-
return { xScale, yScale };
|
|
171
|
-
}
|
|
172
|
-
calculateYScaleDomain(layers, targetValue) {
|
|
173
|
-
let maxValue = d3.max(layers, (d) => d3.max(d, (d) => d[1])) || 0;
|
|
174
|
-
if (maxValue === 0) {
|
|
175
|
-
maxValue = targetValue ? targetValue + 20 : 100;
|
|
176
|
-
}
|
|
177
|
-
if (this.chartConfiguration.customYscale) {
|
|
178
|
-
maxValue *= this.chartConfiguration.customYscale;
|
|
179
|
-
}
|
|
180
|
-
if (targetValue && maxValue < targetValue) {
|
|
181
|
-
maxValue = maxValue < 10 && targetValue < 10
|
|
182
|
-
? targetValue + 3
|
|
183
|
-
: targetValue + 20;
|
|
184
|
-
}
|
|
185
|
-
return maxValue;
|
|
186
|
-
}
|
|
187
|
-
shouldShowTargetLineColor(d, targetValue) {
|
|
188
|
-
return !!(!isNaN(d[0]) &&
|
|
189
|
-
!isNaN(d[1]) &&
|
|
190
|
-
this.chartData.targetLineData &&
|
|
191
|
-
targetValue &&
|
|
192
|
-
parseFloat(d[1]) - parseFloat(d[0]) >= targetValue);
|
|
193
|
-
}
|
|
194
|
-
getBarFillColor(d, key, metaData, targetValue) {
|
|
195
|
-
if (this.shouldShowTargetLineColor(d, targetValue)) {
|
|
196
|
-
return this.chartData.targetLineData?.barAboveTargetColor || metaData.colors[key];
|
|
197
|
-
}
|
|
198
|
-
return metaData.colors[key];
|
|
199
|
-
}
|
|
200
|
-
isAcronym(label) {
|
|
201
|
-
const alphaOnly = label.replace(/[^A-Za-z]/g, '');
|
|
202
|
-
return (label.length <= 4 && /^[A-Z]+$/.test(label)) ||
|
|
203
|
-
(label === label.toUpperCase() && /[A-Z]/.test(label));
|
|
204
|
-
}
|
|
205
|
-
formatAxisLabel(text) {
|
|
206
|
-
const isAcr = this.isAcronym(text);
|
|
207
|
-
return {
|
|
208
|
-
formatted: isAcr ? text.toUpperCase() : text.toLowerCase(),
|
|
209
|
-
isAcronym: isAcr
|
|
210
|
-
};
|
|
211
|
-
}
|
|
212
|
-
initializeStackedChart() {
|
|
213
|
-
const device = this.getDeviceBreakpoints();
|
|
214
|
-
this.applyResponsiveConfig(device);
|
|
215
|
-
this.mergeConfigurations();
|
|
216
|
-
const { data, metaData, lineData } = this.chartData;
|
|
217
|
-
const preparedMetaData = this.prepareMetaData(metaData);
|
|
218
|
-
const targetValue = this.parseTargetValue(this.chartData.targetLineData);
|
|
219
|
-
const chartContainer = d3.select(this.containerElt.nativeElement);
|
|
220
|
-
const verticalstackedcontainer = d3.select(this.verticalstackedcontainerElt.nativeElement);
|
|
221
|
-
const margin = this.chartConfiguration.margin;
|
|
222
|
-
const containerWidth = chartContainer.node().getBoundingClientRect().width;
|
|
223
|
-
const containerHeight = verticalstackedcontainer.node().getBoundingClientRect().height;
|
|
224
|
-
const { width, height } = this.calculateDimensions(containerWidth, containerHeight, margin, device);
|
|
225
|
-
// Apply visibility configurations
|
|
226
|
-
if (this.chartConfiguration.isHeaderVisible !== undefined) {
|
|
176
|
+
// ...existing code...
|
|
177
|
+
/**
|
|
178
|
+
* for hiding header
|
|
179
|
+
* used by weekly charts
|
|
180
|
+
*/
|
|
181
|
+
if (this.chartConfiguration.isHeaderVisible != undefined) {
|
|
227
182
|
this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
|
|
228
183
|
}
|
|
229
|
-
|
|
184
|
+
/**
|
|
185
|
+
* for hiding legends
|
|
186
|
+
* used by weekly charts
|
|
187
|
+
*/
|
|
188
|
+
if (this.chartConfiguration.isTopCaptionVisible != undefined) {
|
|
189
|
+
//UPDATENAME
|
|
230
190
|
this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;
|
|
231
191
|
}
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
|
|
240
|
-
// Create SVG containers
|
|
241
|
-
const { barWidth, barPadding, requiredSvgWidth } = this.calculateBarDimensions(width, data.length, device);
|
|
242
|
-
const outerContainer = this.createOuterContainer(chartContainer, height, margin);
|
|
243
|
-
const { svgYAxisLeft, svgYAxisRight } = this.createAxisContainers(outerContainer, height, margin);
|
|
244
|
-
const { innerContainer, svg } = this.createInnerContainer(outerContainer, requiredSvgWidth, height, margin, device);
|
|
245
|
-
// Create scales
|
|
246
|
-
const { xScale, yScale } = this.createScales(data, height, width, device);
|
|
247
|
-
// Stack data
|
|
248
|
-
const stack = d3
|
|
249
|
-
.stack()
|
|
250
|
-
.keys(preparedMetaData.keyList)
|
|
251
|
-
.offset(d3.stackOffsetNone);
|
|
252
|
-
const layers = stack(data);
|
|
253
|
-
// Set Y scale domain
|
|
254
|
-
const maxValue = this.calculateYScaleDomain(layers, targetValue || undefined);
|
|
255
|
-
yScale.domain([0, maxValue]).nice();
|
|
256
|
-
// Render chart elements
|
|
257
|
-
this.renderGrids(svg, xScale, yScale, height, width);
|
|
258
|
-
this.renderBars(svg, layers, xScale, yScale, preparedMetaData, device, barWidth, barPadding, targetValue, formatFromBackend, formatForHugeNumbers);
|
|
259
|
-
this.renderAxes(svg, svgYAxisLeft, svgYAxisRight, xScale, yScale, data, height, width, device);
|
|
260
|
-
this.renderLabels(svg, svgYAxisLeft, preparedMetaData, height, width, margin);
|
|
261
|
-
if (this.chartData.targetLineData && targetValue) {
|
|
262
|
-
this.renderTargetLine(svg, svgYAxisRight, yScale, width, targetValue, preparedMetaData);
|
|
192
|
+
/**
|
|
193
|
+
* for removing background color so that it can take parents color
|
|
194
|
+
*
|
|
195
|
+
*/
|
|
196
|
+
if (this.chartConfiguration.isTransparentBackground != undefined) {
|
|
197
|
+
this.isTransparentBackground =
|
|
198
|
+
this.chartConfiguration.isTransparentBackground;
|
|
263
199
|
}
|
|
264
|
-
|
|
265
|
-
|
|
200
|
+
/**
|
|
201
|
+
* format data values based on configuration received
|
|
202
|
+
*/
|
|
203
|
+
if (this.chartConfiguration.textFormatter != undefined) {
|
|
204
|
+
formatFromBackend = ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter);
|
|
205
|
+
formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
|
|
266
206
|
}
|
|
267
|
-
|
|
268
|
-
createOuterContainer(chartContainer, height, margin) {
|
|
269
|
-
return chartContainer
|
|
207
|
+
var outerContainer = chartContainer
|
|
270
208
|
.append('div')
|
|
271
|
-
.attr('id',
|
|
209
|
+
.attr('id', self.uniqueId)
|
|
272
210
|
.attr('class', 'outer-container')
|
|
273
211
|
.style('width', '100%')
|
|
274
212
|
.style('height', height)
|
|
275
213
|
.style('overflow-x', 'hidden')
|
|
276
214
|
.style('padding-left', `${margin.left}px`)
|
|
277
215
|
.style('margin-left', '10px')
|
|
278
|
-
.style('padding-right', `${
|
|
279
|
-
|
|
280
|
-
createAxisContainers(outerContainer, height, margin) {
|
|
281
|
-
const svgYAxisLeft = outerContainer
|
|
216
|
+
.style('padding-right', `${rightSvgWidth}px`);
|
|
217
|
+
var svgYAxisLeft = outerContainer
|
|
282
218
|
.append('svg')
|
|
283
219
|
.attr('width', '80')
|
|
284
220
|
.attr('height', height + margin.top + margin.bottom)
|
|
@@ -286,414 +222,1039 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
|
|
|
286
222
|
.style('left', '0')
|
|
287
223
|
.style('z-index', 1)
|
|
288
224
|
.append('g')
|
|
289
|
-
.attr('transform',
|
|
290
|
-
|
|
225
|
+
.attr('transform', 'translate(' + (margin.left + 10) + ',' + margin.top + ')');
|
|
226
|
+
var svgYAxisRight = outerContainer
|
|
291
227
|
.append('svg')
|
|
292
|
-
.attr('width',
|
|
228
|
+
.attr('width', rightSvgWidth)
|
|
293
229
|
.attr('height', height + margin.top + margin.bottom)
|
|
294
230
|
.style('position', 'absolute')
|
|
295
231
|
.style('right', '2px')
|
|
296
232
|
.style('z-index', 1)
|
|
297
233
|
.append('g')
|
|
298
|
-
.attr('transform',
|
|
299
|
-
|
|
300
|
-
}
|
|
301
|
-
createInnerContainer(outerContainer, requiredSvgWidth, height, margin, device) {
|
|
302
|
-
const innerContainer = outerContainer
|
|
234
|
+
.attr('transform', 'translate(' + 0 + ',' + margin.top + ')');
|
|
235
|
+
var innerContainer = outerContainer
|
|
303
236
|
.append('div')
|
|
304
237
|
.attr('class', 'inner-container')
|
|
305
238
|
.style('width', '100%')
|
|
306
|
-
.style('overflow-x',
|
|
307
|
-
|
|
239
|
+
.style('overflow-x', 'auto');
|
|
240
|
+
// Calculate bar width and padding for mobile to avoid overlap and add space between bars
|
|
241
|
+
let barWidth;
|
|
242
|
+
let barPadding = 12; // px, space between bars on mobile
|
|
243
|
+
let requiredSvgWidth;
|
|
244
|
+
if (isMobile) {
|
|
245
|
+
// Use a minimum width per bar and add padding between bars
|
|
246
|
+
const minBarWidth = 32; // px, can adjust as needed
|
|
247
|
+
barWidth = minBarWidth;
|
|
248
|
+
requiredSvgWidth = Math.max(width - rightSvgWidth, (barWidth + barPadding) * data.length + leftAndRightSpaces * 2 + rightSvgWidth - barPadding // no padding after last bar
|
|
249
|
+
);
|
|
250
|
+
innerContainer.style('overflow-x', 'auto');
|
|
251
|
+
}
|
|
252
|
+
else {
|
|
253
|
+
barWidth = Math.max(40, (width - rightSvgWidth - leftAndRightSpaces * 2) / data.length);
|
|
254
|
+
barPadding = 0;
|
|
255
|
+
requiredSvgWidth = width - rightSvgWidth;
|
|
256
|
+
}
|
|
257
|
+
var svg = innerContainer
|
|
308
258
|
.append('svg')
|
|
309
259
|
.attr('width', requiredSvgWidth)
|
|
310
260
|
.attr('height', height + margin.top + margin.bottom + 30)
|
|
311
261
|
.append('g')
|
|
312
|
-
.attr('transform',
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
262
|
+
.attr('transform', 'translate(' + 0 + ',' + margin.top + ')');
|
|
263
|
+
let stackKey = keyList;
|
|
264
|
+
var stack = d3
|
|
265
|
+
.stack()
|
|
266
|
+
.keys(stackKey)
|
|
267
|
+
/*.order(d3.stackOrder)*/
|
|
268
|
+
.offset(d3.stackOffsetNone);
|
|
269
|
+
var layers = stack(data);
|
|
270
|
+
data.sort(function (a, b) {
|
|
271
|
+
return b.total - a.total;
|
|
272
|
+
});
|
|
273
|
+
let lineYscale;
|
|
274
|
+
if (lineData != null) {
|
|
275
|
+
lineYscale = d3
|
|
276
|
+
.scaleLinear()
|
|
277
|
+
.domain([
|
|
278
|
+
0,
|
|
279
|
+
d3.max(lineData, function (d) {
|
|
280
|
+
return +d.value;
|
|
281
|
+
}),
|
|
282
|
+
])
|
|
283
|
+
.range([height, 0]);
|
|
284
|
+
}
|
|
285
|
+
// Calculate bar width for mobile to avoid overlap
|
|
286
|
+
// ...barWidth is now calculated above, remove duplicate...
|
|
287
|
+
var xScale = d3
|
|
288
|
+
.scaleBand()
|
|
289
|
+
.rangeRound([
|
|
290
|
+
leftAndRightSpaces,
|
|
291
|
+
width - rightSvgWidth - leftAndRightSpaces
|
|
292
|
+
])
|
|
293
|
+
.domain(data.map(function (d) {
|
|
294
|
+
return d.name;
|
|
295
|
+
}).reverse())
|
|
296
|
+
.padding(isMobile ? 0.2 : 0.5);
|
|
297
|
+
var xScaleFromOrigin = d3
|
|
298
|
+
.scaleBand()
|
|
299
|
+
.rangeRound([width - rightSvgWidth, 0])
|
|
300
|
+
.domain(data.map(function (d) {
|
|
301
|
+
return d.name;
|
|
302
|
+
}).reverse());
|
|
303
|
+
// ...existing code...
|
|
304
|
+
/**
|
|
305
|
+
* draw second x axis on top
|
|
306
|
+
*/
|
|
307
|
+
if (self.chartConfiguration.showXaxisTop) {
|
|
308
|
+
svg
|
|
309
|
+
.append('g')
|
|
310
|
+
.attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')
|
|
311
|
+
.attr('style', self.chartConfiguration.xAxisCustomTextStyles)
|
|
312
|
+
.call(d3.axisBottom(xScale).tickSize(0));
|
|
313
|
+
svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');
|
|
314
|
+
}
|
|
315
|
+
/**
|
|
316
|
+
* draw second x axis on top
|
|
317
|
+
*/
|
|
318
|
+
// if (self.chartConfiguration.showXaxisAtTarget) {
|
|
319
|
+
// svg
|
|
320
|
+
// .append('g')
|
|
321
|
+
// .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')
|
|
322
|
+
// .attr('style', self.chartConfiguration.xAxisCustomTextStyles)
|
|
323
|
+
// .call(d3.axisBottom(xScale).tickSize(0));
|
|
324
|
+
// svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');
|
|
325
|
+
// }
|
|
326
|
+
if (this.chartConfiguration.xAxisGrid) {
|
|
327
|
+
for (var j = 0; j < this.chartConfiguration.xAxisGrid.length; j++) {
|
|
328
|
+
svg
|
|
329
|
+
.append('g')
|
|
330
|
+
.attr('class', `x${j + 2} axis${j + 2}`)
|
|
331
|
+
.style('color', 'var(--chart-grid-color)') // Use CSS variable instead of hardcoded
|
|
332
|
+
.attr('transform', 'translate(0,' + height * this.chartConfiguration.xAxisGrid[j] + ')')
|
|
333
|
+
.call(d3.axisBottom(xScale).tickSize(0).ticks(5).tickFormat(''))
|
|
334
|
+
.style('fill', 'var(--chart-text-color)');
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
let yScale = d3.scaleLinear().rangeRound([height, 0]);
|
|
338
|
+
/**
|
|
339
|
+
* update max vakues so that the vakue wont exceed the max limit
|
|
340
|
+
* used by weekly charts
|
|
341
|
+
*/
|
|
342
|
+
var maxValue = d3.max(layers, (d) => d3.max(d, (d) => d[1]));
|
|
343
|
+
if (maxValue == 0) {
|
|
344
|
+
if (this.chartData.targetLineData) {
|
|
345
|
+
maxValue = this.chartData.targetLineData.target + 20;
|
|
346
|
+
}
|
|
347
|
+
else {
|
|
348
|
+
maxValue = 100;
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
if (this.chartConfiguration.customYscale) {
|
|
352
|
+
maxValue = maxValue * this.chartConfiguration.customYscale;
|
|
353
|
+
}
|
|
354
|
+
if (this.chartData.targetLineData &&
|
|
355
|
+
maxValue < this.chartData.targetLineData.target) {
|
|
356
|
+
maxValue =
|
|
357
|
+
maxValue < 10 && this.chartData.targetLineData.target < 10
|
|
358
|
+
? this.chartData.targetLineData.target + 3
|
|
359
|
+
: this.chartData.targetLineData.target + 20;
|
|
360
|
+
}
|
|
361
|
+
yScale.domain([0, maxValue]).nice();
|
|
362
|
+
let xAxis = d3
|
|
363
|
+
.axisBottom(xScale)
|
|
364
|
+
.tickSize(0)
|
|
365
|
+
.tickFormat(self.chartConfiguration.xAxisLabelFomatter);
|
|
366
|
+
let yAxis = d3
|
|
367
|
+
.axisLeft(yScale)
|
|
368
|
+
.ticks(self.chartConfiguration.numberOfYTicks)
|
|
369
|
+
.tickSize(0)
|
|
370
|
+
.tickFormat(self.chartConfiguration.yAxisLabelFomatter);
|
|
371
|
+
let yLineAxis;
|
|
372
|
+
if (lineYscale != null) {
|
|
373
|
+
yLineAxis = d3
|
|
374
|
+
.axisRight(lineYscale)
|
|
375
|
+
.ticks(self.chartConfiguration.numberOfYTicks)
|
|
376
|
+
.tickSize(0)
|
|
377
|
+
.tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);
|
|
378
|
+
}
|
|
379
|
+
/**
|
|
380
|
+
* between x-axis label used by weekly charts
|
|
381
|
+
* isXgridBetweenLabels will be undefined for dashboard charts
|
|
382
|
+
*/
|
|
383
|
+
if (self.chartConfiguration.isXgridBetweenLabels) {
|
|
317
384
|
svg
|
|
318
385
|
.append('g')
|
|
319
386
|
.attr('class', 'grid')
|
|
320
|
-
.attr('transform',
|
|
387
|
+
.attr('transform', 'translate(' + xScale.bandwidth() / 2 + ',' + height + ')')
|
|
321
388
|
.call(d3.axisBottom(xScale).tickSize(-height).tickFormat(''))
|
|
322
389
|
.style('stroke-dasharray', '5 5')
|
|
323
390
|
.style('color', '#999999')
|
|
391
|
+
// .style("opacity", "0.5")
|
|
324
392
|
.call((g) => g.select('.domain').remove());
|
|
325
393
|
}
|
|
326
|
-
|
|
394
|
+
/**
|
|
395
|
+
* used to draw y-axis grid
|
|
396
|
+
*/
|
|
397
|
+
if (self.chartConfiguration.yAxisGrid) {
|
|
327
398
|
svg
|
|
328
399
|
.append('g')
|
|
329
400
|
.attr('class', 'grid')
|
|
330
401
|
.call(d3
|
|
331
402
|
.axisLeft(yScale)
|
|
332
|
-
.ticks(
|
|
403
|
+
.ticks(self.chartConfiguration.numberOfYTicks)
|
|
333
404
|
.tickSize(-width)
|
|
334
405
|
.tickFormat(''))
|
|
406
|
+
// Remove hardcoded colors and use CSS variables
|
|
335
407
|
.style('color', 'var(--chart-grid-color)')
|
|
336
408
|
.style('opacity', '1');
|
|
409
|
+
// .call((g) => g.select('.domain').remove());
|
|
337
410
|
}
|
|
338
|
-
|
|
339
|
-
this.chartConfiguration.xAxisGrid.forEach((gridPos, index) => {
|
|
340
|
-
svg
|
|
341
|
-
.append('g')
|
|
342
|
-
.attr('class', `x${index + 2} axis${index + 2}`)
|
|
343
|
-
.style('color', 'var(--chart-grid-color)')
|
|
344
|
-
.attr('transform', `translate(0,${height * gridPos})`)
|
|
345
|
-
.call(d3.axisBottom(xScale).tickSize(0).ticks(5).tickFormat(''))
|
|
346
|
-
.style('fill', 'var(--chart-text-color)');
|
|
347
|
-
});
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
renderBars(svg, layers, xScale, yScale, metaData, device, barWidth, barPadding, targetValue, formatFromBackend, formatForHugeNumbers) {
|
|
351
|
-
const layer = svg
|
|
411
|
+
var layer = svg
|
|
352
412
|
.selectAll('.layer')
|
|
353
413
|
.data(layers)
|
|
354
414
|
.enter()
|
|
355
415
|
.append('g')
|
|
356
416
|
.attr('class', 'layer')
|
|
357
|
-
.style('fill', (d)
|
|
358
|
-
|
|
417
|
+
.style('fill', function (d, i) {
|
|
418
|
+
return metaData.colors[d.key];
|
|
419
|
+
});
|
|
420
|
+
var rect = layer
|
|
421
|
+
.selectAll('rect')
|
|
422
|
+
.data(function (d) {
|
|
423
|
+
return d;
|
|
424
|
+
})
|
|
425
|
+
.enter();
|
|
359
426
|
rect
|
|
360
427
|
.append('rect')
|
|
361
|
-
.on('click', (d)
|
|
362
|
-
if (!
|
|
363
|
-
if (!metaData.barWithoutClick
|
|
364
|
-
|
|
365
|
-
|
|
428
|
+
.on('click', function (d) {
|
|
429
|
+
if (!lineData || self.chartConfiguration.forComparison) {
|
|
430
|
+
if (!metaData.barWithoutClick ||
|
|
431
|
+
!metaData.barWithoutClick.length ||
|
|
432
|
+
!metaData.barWithoutClick.includes(d.data.name.toLowerCase()))
|
|
433
|
+
self.handleClick(d.data.name);
|
|
366
434
|
}
|
|
367
435
|
})
|
|
368
|
-
.attr('y', (d)
|
|
436
|
+
.attr('y', function (d) {
|
|
369
437
|
if (!isNaN(d[0]) && !isNaN(d[1])) {
|
|
370
438
|
const actualHeight = yScale(d[0]) - yScale(d[1]);
|
|
371
439
|
return actualHeight < 3 ? yScale(d[0]) - 3 : yScale(d[1]);
|
|
372
440
|
}
|
|
373
441
|
return 0;
|
|
374
442
|
})
|
|
375
|
-
.attr('x', (d, i)
|
|
376
|
-
if (
|
|
377
|
-
|
|
443
|
+
.attr('x', function (d, i) {
|
|
444
|
+
if (isMobile) {
|
|
445
|
+
// On mobile, position bars with padding
|
|
446
|
+
return leftAndRightSpaces + i * (barWidth + barPadding);
|
|
378
447
|
}
|
|
379
|
-
if (
|
|
448
|
+
if (self.chartConfiguration.isMultiChartGridLine == undefined) {
|
|
380
449
|
return xScale(d.data.name);
|
|
381
450
|
}
|
|
382
|
-
|
|
383
|
-
|
|
451
|
+
else {
|
|
452
|
+
if (self.chartConfiguration.isDrilldownChart &&
|
|
453
|
+
self.chartData.data.length <= 3) {
|
|
454
|
+
return xScale(d.data.name) + xScale.bandwidth() / 2 - 35;
|
|
455
|
+
}
|
|
456
|
+
return xScale(d.data.name) + xScale.bandwidth() * 0.1;
|
|
384
457
|
}
|
|
385
|
-
return xScale(d.data.name) + xScale.bandwidth() * 0.1;
|
|
386
458
|
})
|
|
387
|
-
.attr('height', (d)
|
|
459
|
+
.attr('height', function (d) {
|
|
388
460
|
if (!isNaN(d[0]) && !isNaN(d[1])) {
|
|
389
461
|
const actualHeight = yScale(d[0]) - yScale(d[1]);
|
|
390
462
|
return actualHeight < 3 ? 3 : actualHeight;
|
|
391
463
|
}
|
|
392
464
|
return 0;
|
|
393
465
|
})
|
|
394
|
-
.attr('width', (d)
|
|
395
|
-
|
|
466
|
+
.attr('width', function (d) {
|
|
467
|
+
// Use calculated barWidth for mobile, otherwise scale
|
|
468
|
+
if (isMobile) {
|
|
396
469
|
return barWidth;
|
|
397
|
-
if (this.chartConfiguration.isMultiChartGridLine === undefined) {
|
|
398
|
-
return xScale.bandwidth();
|
|
399
470
|
}
|
|
400
|
-
return
|
|
401
|
-
?
|
|
402
|
-
:
|
|
471
|
+
return self.chartConfiguration.isMultiChartGridLine == undefined
|
|
472
|
+
? xScale.bandwidth()
|
|
473
|
+
: self.chartConfiguration.isDrilldownChart &&
|
|
474
|
+
self.chartData.data.length <= 3
|
|
475
|
+
? 70
|
|
476
|
+
: xScale.bandwidth() * 0.8;
|
|
403
477
|
})
|
|
404
|
-
.style('cursor',
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
478
|
+
// .style('cursor', 'pointer');
|
|
479
|
+
.style('cursor', function (d) {
|
|
480
|
+
if (metaData.hasDrillDown) {
|
|
481
|
+
if (metaData.barWithoutClick.length > 0 &&
|
|
482
|
+
metaData.barWithoutClick.includes(d.data.name.toLowerCase())) {
|
|
483
|
+
return 'default';
|
|
484
|
+
}
|
|
485
|
+
return 'pointer';
|
|
409
486
|
}
|
|
410
|
-
|
|
487
|
+
else
|
|
488
|
+
return 'default';
|
|
411
489
|
})
|
|
412
|
-
.style('fill', (d)
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
490
|
+
.style('fill', function (d) {
|
|
491
|
+
if (!isNaN(d[0]) &&
|
|
492
|
+
!isNaN(d[1]) &&
|
|
493
|
+
self.chartData.targetLineData &&
|
|
494
|
+
parseFloat(d[1]) - parseFloat(d[0]) >=
|
|
495
|
+
parseFloat(self.chartData.targetLineData.target))
|
|
496
|
+
return self.chartData?.targetLineData?.barAboveTargetColor;
|
|
497
|
+
return metaData.colors[d.key];
|
|
498
|
+
});
|
|
499
|
+
/**
|
|
500
|
+
* do not show valus on hover as its alreay dislayed
|
|
501
|
+
*/
|
|
502
|
+
if (!this.isCC && !self.chartConfiguration.isMultiChartGridLine) {
|
|
503
|
+
rect
|
|
504
|
+
.append('svg:title') // TITLE APPENDED HERE
|
|
505
|
+
.text(function (d) {
|
|
506
|
+
return d[1] - d[0];
|
|
507
|
+
});
|
|
416
508
|
}
|
|
417
|
-
this.
|
|
418
|
-
}
|
|
419
|
-
addBarLabels(rect, xScale, yScale, metaData, formatFromBackend, formatForHugeNumbers) {
|
|
420
|
-
if (this.chartConfiguration.showTotalOnTop) {
|
|
509
|
+
if (this.isCC) {
|
|
421
510
|
rect
|
|
422
511
|
.append('text')
|
|
423
|
-
.attr('x',
|
|
512
|
+
.attr('x', function (d) {
|
|
513
|
+
return xScale(d.data.name);
|
|
514
|
+
})
|
|
515
|
+
.attr('text-anchor', function (d) {
|
|
516
|
+
if (!d[0]) {
|
|
517
|
+
return 'end';
|
|
518
|
+
}
|
|
519
|
+
else {
|
|
520
|
+
return 'start';
|
|
521
|
+
}
|
|
522
|
+
})
|
|
523
|
+
.attr('class', 'verticalbar__text')
|
|
524
|
+
.attr('y', function (d) {
|
|
525
|
+
if (!d[0]) {
|
|
526
|
+
return yScale(d[1]);
|
|
527
|
+
}
|
|
528
|
+
else {
|
|
529
|
+
return yScale(d[1]) - 7;
|
|
530
|
+
}
|
|
531
|
+
})
|
|
532
|
+
// .attr("y", function (d) { return yScale(d[0]) - yScale(d[1]); })
|
|
533
|
+
.attr('dy', function (d) {
|
|
534
|
+
return d.class;
|
|
535
|
+
})
|
|
536
|
+
.text(function (d) {
|
|
537
|
+
if (!d[0]) {
|
|
538
|
+
if (!isNaN(d[1] - d[0])) {
|
|
539
|
+
return Math.round((d[1] - d[0]) * 100) / 100;
|
|
540
|
+
}
|
|
541
|
+
else
|
|
542
|
+
return;
|
|
543
|
+
}
|
|
544
|
+
else {
|
|
545
|
+
if (!isNaN(d[1])) {
|
|
546
|
+
return Math.round(d[1] * 100) / 100;
|
|
547
|
+
}
|
|
548
|
+
else
|
|
549
|
+
return;
|
|
550
|
+
}
|
|
551
|
+
});
|
|
552
|
+
}
|
|
553
|
+
/**
|
|
554
|
+
svg
|
|
555
|
+
.append('foreignObject')
|
|
556
|
+
.attr('transform', 'translate(' + 0 + ',' + (yZero - 25) + ')')
|
|
557
|
+
.attr('width', width)
|
|
558
|
+
.attr('height', 30)
|
|
559
|
+
.append('xhtml:div')
|
|
560
|
+
.attr('class', 'target-display')
|
|
561
|
+
.style('color', this.chartData.targetLineData.color)
|
|
562
|
+
*/
|
|
563
|
+
/**
|
|
564
|
+
* on hover, display title on top
|
|
565
|
+
*/
|
|
566
|
+
function handleMouseOver(d, i) {
|
|
567
|
+
if (!self.chartConfiguration.displayTitleOnTop) {
|
|
568
|
+
return;
|
|
569
|
+
}
|
|
570
|
+
svg
|
|
571
|
+
.selectAll('rect')
|
|
572
|
+
.filter(function (data) {
|
|
573
|
+
return data == d;
|
|
574
|
+
})
|
|
575
|
+
.style('fill', function (d) {
|
|
576
|
+
if (!isNaN(d[0]) &&
|
|
577
|
+
!isNaN(d[1]) &&
|
|
578
|
+
self.chartData.targetLineData &&
|
|
579
|
+
parseFloat(d[1]) - parseFloat(d[0]) >=
|
|
580
|
+
parseFloat(self.chartData.targetLineData.target))
|
|
581
|
+
return self.chartData.targetLineData.barAboveTargetHoverColor
|
|
582
|
+
? self.chartData.targetLineData.barAboveTargetHoverColor
|
|
583
|
+
: self.chartData?.targetLineData?.barAboveTargetColor
|
|
584
|
+
? self.chartData?.targetLineData?.barAboveTargetColor
|
|
585
|
+
: '';
|
|
586
|
+
return metaData.hoverColor ? metaData.hoverColor : '';
|
|
587
|
+
});
|
|
588
|
+
svg
|
|
589
|
+
.append('foreignObject')
|
|
590
|
+
.attr('x', function () {
|
|
591
|
+
if (xScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
|
|
592
|
+
return (xScale(d.data.name) -
|
|
593
|
+
leftAndRightSpaces +
|
|
594
|
+
(xScale.bandwidth() + leftAndRightSpaces * 2 - 180) / 2);
|
|
595
|
+
}
|
|
596
|
+
return xScale(d.data.name) - leftAndRightSpaces;
|
|
597
|
+
})
|
|
598
|
+
.attr('class', 'lib-verticalstack-title-ontop')
|
|
599
|
+
.attr('y', function () {
|
|
600
|
+
// Increase the gap between the bar and the tooltip (was -1 - 40)
|
|
601
|
+
return yScale(d[1]) - 1 - 50; // 10px more gap
|
|
602
|
+
})
|
|
603
|
+
.attr('dy', function () {
|
|
604
|
+
return d.class;
|
|
605
|
+
})
|
|
606
|
+
.attr('width', function () {
|
|
607
|
+
if (d.data.name && /week/i.test(d.data.name) && /\d{4}-\d{2}-\d{2}/.test(d.data.name)) {
|
|
608
|
+
return '250px'; // increase for week + date
|
|
609
|
+
}
|
|
610
|
+
if (xScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
|
|
611
|
+
return '180px';
|
|
612
|
+
}
|
|
613
|
+
return xScale.bandwidth() + leftAndRightSpaces * 2;
|
|
614
|
+
})
|
|
615
|
+
.attr('height', 40)
|
|
616
|
+
.append('xhtml:div')
|
|
617
|
+
.attr('class', 'title')
|
|
618
|
+
.style('z-index', 99)
|
|
619
|
+
.html(function () {
|
|
620
|
+
// Tooltip content without any arrow mark
|
|
621
|
+
if (!isNaN(d[1] - d[0])) {
|
|
622
|
+
if (d[1] - d[0] === 0) {
|
|
623
|
+
return '<span class="title-top-text">0</span>';
|
|
624
|
+
}
|
|
625
|
+
var dataType = metaData.dataType ? metaData.dataType : '';
|
|
626
|
+
var desiredText = '';
|
|
627
|
+
// Always show the full x-axis label (category name) in the tooltip
|
|
628
|
+
desiredText =
|
|
629
|
+
'<span class="title-bar-name">' +
|
|
630
|
+
(d.data.name ? d.data.name : '') +
|
|
631
|
+
'</span>';
|
|
632
|
+
desiredText += metaData.unit
|
|
633
|
+
? '<span class="title-top-text">' +
|
|
634
|
+
metaData.unit +
|
|
635
|
+
(d[1] - d[0]) + ' ' +
|
|
636
|
+
dataType +
|
|
637
|
+
'</span>'
|
|
638
|
+
: '<span class="title-top-text">' +
|
|
639
|
+
(d[1] - d[0]) + ' ' +
|
|
640
|
+
dataType +
|
|
641
|
+
'</span>';
|
|
642
|
+
// No arrow mark or arrow HTML/CSS in tooltip
|
|
643
|
+
return desiredText;
|
|
644
|
+
}
|
|
645
|
+
else
|
|
646
|
+
return;
|
|
647
|
+
});
|
|
648
|
+
}
|
|
649
|
+
function handleMouseOut(d, i) {
|
|
650
|
+
if (!self.chartConfiguration.displayTitleOnTop) {
|
|
651
|
+
return;
|
|
652
|
+
}
|
|
653
|
+
// svg.selectAll('rect').style('fill', metaData.colors[d.key]);
|
|
654
|
+
svg.selectAll('rect').style('fill', function (d) {
|
|
655
|
+
if (!isNaN(d[0]) &&
|
|
656
|
+
!isNaN(d[1]) &&
|
|
657
|
+
self.chartData.targetLineData &&
|
|
658
|
+
parseFloat(d[1]) - parseFloat(d[0]) >=
|
|
659
|
+
parseFloat(self.chartData.targetLineData.target))
|
|
660
|
+
return self.chartData?.targetLineData?.barAboveTargetColor;
|
|
661
|
+
return metaData.colors[d.key];
|
|
662
|
+
});
|
|
663
|
+
svg.selectAll('.lib-verticalstack-title-ontop').remove();
|
|
664
|
+
}
|
|
665
|
+
/**
|
|
666
|
+
* used to show value on top of the bars
|
|
667
|
+
* need to be used by bar charts only(one bar should contain one value)
|
|
668
|
+
* used by weekly charts
|
|
669
|
+
*/
|
|
670
|
+
if (this.chartConfiguration.showTotalOnTop != undefined) {
|
|
671
|
+
rect
|
|
672
|
+
.append('text')
|
|
673
|
+
.attr('x', function (d) {
|
|
674
|
+
return xScale(d.data.name) + xScale.bandwidth() / 2;
|
|
675
|
+
})
|
|
424
676
|
.attr('class', 'lib-verticalstack-labels-ontop-weklycharts')
|
|
425
|
-
.attr('y',
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
677
|
+
.attr('y', function (d) {
|
|
678
|
+
return yScale(d[1]) - 3;
|
|
679
|
+
})
|
|
680
|
+
.attr('dy', function (d) {
|
|
681
|
+
return d.class;
|
|
682
|
+
})
|
|
683
|
+
.text(function (d) {
|
|
684
|
+
if (!isNaN(d[1] - d[0])) {
|
|
685
|
+
if (d[1] - d[0] == 0) {
|
|
686
|
+
return;
|
|
687
|
+
}
|
|
688
|
+
if (d[1] - d[0] <= 999)
|
|
689
|
+
return metaData.unit
|
|
690
|
+
? metaData.unit + formatFromBackend(d[1] - d[0])
|
|
691
|
+
: formatFromBackend(d[1] - d[0]);
|
|
692
|
+
else
|
|
693
|
+
return metaData.unit
|
|
694
|
+
? metaData.unit + formatForHugeNumbers(d[1] - d[0])
|
|
695
|
+
: formatForHugeNumbers(d[1] - d[0]);
|
|
431
696
|
}
|
|
697
|
+
else
|
|
698
|
+
return;
|
|
432
699
|
});
|
|
433
700
|
}
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
701
|
+
/**
|
|
702
|
+
* used to show angled values on top of the bars
|
|
703
|
+
* used by weekly charts
|
|
704
|
+
*/
|
|
705
|
+
if (this.chartConfiguration.showAngledLabels != undefined) {
|
|
706
|
+
rect
|
|
707
|
+
.append('text')
|
|
708
|
+
.attr('x', 0)
|
|
709
|
+
.attr('fill', function (d, i) {
|
|
710
|
+
return metaData.colors[d.key];
|
|
711
|
+
})
|
|
712
|
+
.attr('class', 'lib-data-labels-angled-weeklycharts')
|
|
713
|
+
.attr('y', 0)
|
|
714
|
+
.attr('dy', function (d) {
|
|
715
|
+
return d.class;
|
|
716
|
+
})
|
|
717
|
+
.text(function (d) {
|
|
718
|
+
if (!isNaN(d[1] - d[0]) && d[1] - d[0] > 0) {
|
|
719
|
+
if (d[1] - d[0] <= 999)
|
|
720
|
+
return metaData.unit
|
|
721
|
+
? metaData.unit + formatFromBackend(d[1] - d[0])
|
|
722
|
+
: formatFromBackend(d[1] - d[0]);
|
|
723
|
+
else
|
|
724
|
+
return metaData.unit + formatForHugeNumbers(d[1] - d[0]);
|
|
725
|
+
}
|
|
726
|
+
else
|
|
727
|
+
return;
|
|
728
|
+
})
|
|
729
|
+
.attr('transform', function (d) {
|
|
730
|
+
if (!isNaN(d[1] - d[0]) && d[1] - d[0] > 0) {
|
|
731
|
+
var total = 0;
|
|
732
|
+
var incrementer = 1;
|
|
733
|
+
metaData.keyList.forEach((key) => {
|
|
734
|
+
if (d.data[key])
|
|
735
|
+
total = total + d.data[key];
|
|
736
|
+
else
|
|
737
|
+
incrementer = 2;
|
|
738
|
+
});
|
|
739
|
+
if (tempObjectHolder[d.data.name] == undefined) {
|
|
740
|
+
tempObjectHolder[d.data.name] = 1;
|
|
741
|
+
}
|
|
742
|
+
else {
|
|
743
|
+
tempObjectHolder[d.data.name] =
|
|
744
|
+
tempObjectHolder[d.data.name] + incrementer;
|
|
745
|
+
}
|
|
746
|
+
switch (tempObjectHolder[d.data.name]) {
|
|
747
|
+
case 1:
|
|
748
|
+
return ('translate(' +
|
|
749
|
+
(xScale(d.data.name) + xScale.bandwidth() / 3) +
|
|
750
|
+
',' +
|
|
751
|
+
(yScale(total) - 3) +
|
|
752
|
+
') rotate(270)');
|
|
753
|
+
case 2:
|
|
754
|
+
return ('translate(' +
|
|
755
|
+
(xScale(d.data.name) + xScale.bandwidth() / 2 + 2) +
|
|
756
|
+
',' +
|
|
757
|
+
(yScale(total) - 3) +
|
|
758
|
+
') rotate(270)');
|
|
759
|
+
default:
|
|
760
|
+
return ('translate(' +
|
|
761
|
+
(xScale(d.data.name) + (xScale.bandwidth() * 3) / 4) +
|
|
762
|
+
',' +
|
|
763
|
+
(yScale(total) - 3) +
|
|
764
|
+
') rotate(270)');
|
|
765
|
+
}
|
|
766
|
+
}
|
|
767
|
+
return 'rotate(0)';
|
|
768
|
+
});
|
|
769
|
+
}
|
|
770
|
+
if (this.chartConfiguration.isMultiChartGridLine == undefined) {
|
|
771
|
+
if (isMobile) {
|
|
772
|
+
// Custom x-axis label rendering for mobile: evenly distribute under each bar
|
|
773
|
+
svg.selectAll('.custom-x-label').remove();
|
|
774
|
+
data.forEach(function (d, i) {
|
|
775
|
+
const xVal = leftAndRightSpaces + i * (barWidth + barPadding) + barWidth / 2;
|
|
776
|
+
svg.append('text')
|
|
777
|
+
.attr('class', 'custom-x-label')
|
|
778
|
+
.attr('x', 0)
|
|
779
|
+
.attr('y', height + 18)
|
|
780
|
+
.attr('text-anchor', 'middle')
|
|
781
|
+
.attr('transform', 'translate(' + (xVal + 20) + ',0)') // current value + 20
|
|
782
|
+
.style('font-size', '10px')
|
|
783
|
+
.style('fill', 'var(--chart-text-color)')
|
|
784
|
+
.style('writing-mode', 'sideways-lr') // writing mode for mobile
|
|
785
|
+
.text(d.name.substring(0, 3));
|
|
786
|
+
});
|
|
787
|
+
}
|
|
788
|
+
else {
|
|
789
|
+
svg
|
|
790
|
+
.append('g')
|
|
791
|
+
.attr('transform', 'translate(0,' + height + ')')
|
|
792
|
+
.attr('class', 'lib-stacked-x-axis-text')
|
|
793
|
+
.call(xAxis)
|
|
794
|
+
.selectAll('text')
|
|
795
|
+
.style('fill', 'var(--chart-text-color)')
|
|
796
|
+
.style('font-size', '12px')
|
|
797
|
+
.attr('text-anchor', 'middle')
|
|
798
|
+
.attr('dx', '0')
|
|
799
|
+
.attr('dy', '0.71em')
|
|
800
|
+
.attr('transform', null)
|
|
801
|
+
.text(function (d) {
|
|
802
|
+
return d;
|
|
803
|
+
});
|
|
804
|
+
}
|
|
805
|
+
svg
|
|
806
|
+
.append('g')
|
|
807
|
+
.attr('class', 'lib-stacked-y-axis-text')
|
|
808
|
+
.attr('style', self.chartConfiguration.yAxisCustomTextStyles)
|
|
809
|
+
.attr('transform', 'translate(0,0)')
|
|
810
|
+
.call(yAxis)
|
|
811
|
+
.selectAll('text')
|
|
812
|
+
.style('fill', 'var(--chart-text-color)');
|
|
448
813
|
}
|
|
449
814
|
else if (this.chartConfiguration.isDrilldownChart) {
|
|
450
|
-
|
|
815
|
+
svg
|
|
816
|
+
.append('g')
|
|
817
|
+
.attr('transform', 'translate(0,' + height + ')')
|
|
818
|
+
.attr('class', 'lib-stacked-x-axis-text multichart1')
|
|
819
|
+
.call(xAxis)
|
|
820
|
+
.style('display', 'none');
|
|
821
|
+
svgYAxisLeft
|
|
822
|
+
.append('g')
|
|
823
|
+
.attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
|
|
824
|
+
.attr('style', self.chartConfiguration.yAxisCustomTextStyles)
|
|
825
|
+
.attr('transform', 'translate(0,0)')
|
|
826
|
+
.call(yAxis)
|
|
827
|
+
.selectAll('text')
|
|
828
|
+
.style('fill', 'var(--chart-text-color)');
|
|
829
|
+
svgYAxisRight
|
|
830
|
+
.append('g')
|
|
831
|
+
.attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
|
|
832
|
+
.attr('style', self.chartConfiguration.yAxisCustomTextStyles)
|
|
833
|
+
.attr('transform', 'translate(0,0)')
|
|
834
|
+
.call(yAxis)
|
|
835
|
+
.style('display', 'none');
|
|
451
836
|
}
|
|
452
837
|
else {
|
|
453
|
-
|
|
838
|
+
svg
|
|
839
|
+
.append('g')
|
|
840
|
+
.attr('transform', 'translate(0,' + height + ')')
|
|
841
|
+
.attr('class', 'lib-stacked-x-axis-text multichart')
|
|
842
|
+
.attr('transform', 'translate(0,' + height + ')')
|
|
843
|
+
.call(xAxis)
|
|
844
|
+
.selectAll('text')
|
|
845
|
+
.style('fill', 'var(--chart-text-color)');
|
|
846
|
+
svg
|
|
847
|
+
.append('g')
|
|
848
|
+
.attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
|
|
849
|
+
.attr('style', self.chartConfiguration.yAxisCustomTextStyles)
|
|
850
|
+
.attr('transform', 'translate(0,0)')
|
|
851
|
+
.call(yAxis)
|
|
852
|
+
.selectAll('text')
|
|
853
|
+
.style('fill', 'var(--chart-text-color)');
|
|
454
854
|
}
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
855
|
+
/**
|
|
856
|
+
* for existing charts, place xaxis labels nearer to xaxis
|
|
857
|
+
* used by existing charts
|
|
858
|
+
*/
|
|
859
|
+
if (this.chartConfiguration.isMultiChartGridLine == undefined) {
|
|
860
|
+
d3.selectAll('g.lib-stacked-x-axis-text g.tick text').attr('y', function () {
|
|
861
|
+
if (alternate_text) {
|
|
862
|
+
alternate_text = false;
|
|
863
|
+
return long_tick_length + 1;
|
|
864
|
+
}
|
|
865
|
+
else {
|
|
866
|
+
alternate_text = true;
|
|
867
|
+
return short_tick_length + 1;
|
|
868
|
+
}
|
|
869
|
+
});
|
|
460
870
|
}
|
|
461
871
|
else {
|
|
872
|
+
d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');
|
|
873
|
+
}
|
|
874
|
+
/**
|
|
875
|
+
* based of the flag, hide or show xaxis texts
|
|
876
|
+
* used by weekly charts
|
|
877
|
+
*/
|
|
878
|
+
if (this.chartConfiguration.isXaxisLabelHidden != undefined &&
|
|
879
|
+
this.chartConfiguration.isXaxisLabelHidden) {
|
|
880
|
+
d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');
|
|
881
|
+
}
|
|
882
|
+
else if (this.chartConfiguration.isXaxisLabelHidden != undefined) {
|
|
462
883
|
svg
|
|
463
884
|
.append('g')
|
|
464
|
-
.attr('
|
|
465
|
-
.attr('
|
|
466
|
-
.
|
|
467
|
-
.
|
|
468
|
-
.
|
|
469
|
-
|
|
470
|
-
.
|
|
885
|
+
.attr('class', 'x1 axis1')
|
|
886
|
+
.attr('transform', 'translate(0,' + height + ')')
|
|
887
|
+
.style('color', '#000')
|
|
888
|
+
.call(d3.axisBottom(xScale).tickSize(0))
|
|
889
|
+
.call((g) => g.select('.domain').attr('fill', 'none'));
|
|
890
|
+
svg
|
|
891
|
+
.append('g')
|
|
892
|
+
.attr('class', 'x2 axis2')
|
|
893
|
+
.attr('transform', 'translate(0,' + height + ')')
|
|
894
|
+
.style('color', '#000')
|
|
895
|
+
.call(d3.axisBottom(xScaleFromOrigin).tickSize(0))
|
|
896
|
+
.call((g) => g.select('.domain').attr('fill', 'none'));
|
|
897
|
+
svg.selectAll('.axis2 > g > text').attr('class', 'lib-display-hidden');
|
|
898
|
+
// svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');
|
|
899
|
+
svg.selectAll('.x1.axis1 .tick line').attr('y2', function () {
|
|
900
|
+
if (self.chartConfiguration.hideXaxisTick) {
|
|
901
|
+
return 0;
|
|
902
|
+
}
|
|
903
|
+
/**
|
|
904
|
+
* isNoAlternateXaxisText is used to prevent x-axis label to be displayed in alternate fashion
|
|
905
|
+
* for future use
|
|
906
|
+
*/
|
|
907
|
+
if (alternate_text &&
|
|
908
|
+
self.chartConfiguration.isNoAlternateXaxisText == undefined) {
|
|
909
|
+
alternate_text = false;
|
|
910
|
+
return long_tick_length_bg - 7;
|
|
911
|
+
}
|
|
912
|
+
else {
|
|
913
|
+
alternate_text = true;
|
|
914
|
+
return short_tick_length_bg - 4;
|
|
915
|
+
}
|
|
916
|
+
});
|
|
917
|
+
/**
|
|
918
|
+
* reset the flag so that texts also follow the pattern of ticks
|
|
919
|
+
* used by weekly charts
|
|
920
|
+
*/
|
|
921
|
+
alternate_text = false;
|
|
922
|
+
svg
|
|
923
|
+
.selectAll('g.x1.axis1 g.tick text')
|
|
924
|
+
// .attr('class', 'lib-xaxis-labels-texts-weeklycharts')
|
|
925
|
+
.attr('class', function () {
|
|
926
|
+
if (self.chartConfiguration.isDrilldownChart) {
|
|
927
|
+
if (data && data.length > 8) {
|
|
928
|
+
return 'lib-xaxis-labels-texts-drilldown-alt';
|
|
929
|
+
}
|
|
930
|
+
return 'lib-xaxis-labels-texts-drilldown';
|
|
931
|
+
}
|
|
932
|
+
else
|
|
933
|
+
return 'lib-xaxis-labels-texts-weeklycharts';
|
|
934
|
+
})
|
|
935
|
+
.attr('y', function () {
|
|
936
|
+
if (alternate_text) {
|
|
937
|
+
alternate_text = false;
|
|
938
|
+
return long_tick_length_bg;
|
|
939
|
+
}
|
|
940
|
+
else {
|
|
941
|
+
alternate_text = true;
|
|
942
|
+
return short_tick_length_bg;
|
|
943
|
+
}
|
|
944
|
+
});
|
|
471
945
|
}
|
|
472
|
-
|
|
473
|
-
.append('g')
|
|
474
|
-
.attr('class', 'lib-stacked-y-axis-text')
|
|
475
|
-
.call(yAxis)
|
|
476
|
-
.selectAll('text')
|
|
477
|
-
.style('fill', 'var(--chart-text-color)');
|
|
478
|
-
}
|
|
479
|
-
renderMobileXAxis(svg, data, height, device) {
|
|
480
|
-
const barWidth = 32;
|
|
481
|
-
const barPadding = 12;
|
|
482
|
-
svg.selectAll('.custom-x-label').remove();
|
|
483
|
-
data.forEach((d, i) => {
|
|
484
|
-
const xVal = this.SPACING.leftAndRight + i * (barWidth + barPadding) + barWidth / 2;
|
|
946
|
+
if (self.chartConfiguration.xLabelsOnSameLine) {
|
|
485
947
|
svg
|
|
948
|
+
.selectAll('g.x1.axis1 g.tick text')
|
|
949
|
+
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
950
|
+
.attr('y', short_tick_length_bg)
|
|
951
|
+
.text(function (d, i) {
|
|
952
|
+
if (isMobile) {
|
|
953
|
+
// If label has more than one word, show only first 3 letters of first word
|
|
954
|
+
var firstWord = d.split(' ')[0];
|
|
955
|
+
return firstWord.substring(0, 3);
|
|
956
|
+
}
|
|
957
|
+
if (d.trim().indexOf(' ') > -1) {
|
|
958
|
+
return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
|
|
959
|
+
}
|
|
960
|
+
return d.toLowerCase();
|
|
961
|
+
})
|
|
962
|
+
.attr('transform', function (d, i) {
|
|
963
|
+
if (isMobile) {
|
|
964
|
+
var totalBars = 0;
|
|
965
|
+
if (this.parentNode && this.parentNode.parentNode) {
|
|
966
|
+
totalBars = d3.select(this.parentNode.parentNode).selectAll('g.tick').size();
|
|
967
|
+
}
|
|
968
|
+
if (totalBars === 2) {
|
|
969
|
+
return 'translate(0,0)';
|
|
970
|
+
}
|
|
971
|
+
else {
|
|
972
|
+
return 'translate(' + (i * 30) + ',0)';
|
|
973
|
+
}
|
|
974
|
+
}
|
|
975
|
+
return null;
|
|
976
|
+
});
|
|
977
|
+
svg
|
|
978
|
+
.selectAll('g.x1.axis1 g.tick')
|
|
486
979
|
.append('text')
|
|
487
|
-
.attr('class', '
|
|
488
|
-
.attr('
|
|
489
|
-
.attr('
|
|
490
|
-
.
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
.append('g')
|
|
507
|
-
.attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
|
|
508
|
-
.call(yAxis)
|
|
509
|
-
.selectAll('text')
|
|
510
|
-
.style('fill', 'var(--chart-text-color)');
|
|
511
|
-
svgYAxisRight
|
|
512
|
-
.append('g')
|
|
513
|
-
.attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
|
|
514
|
-
.call(yAxis)
|
|
515
|
-
.style('display', 'none');
|
|
516
|
-
}
|
|
517
|
-
renderMultiChartAxes(svg, xAxis, yAxis, height) {
|
|
518
|
-
svg
|
|
519
|
-
.append('g')
|
|
520
|
-
.attr('transform', `translate(0,${height})`)
|
|
521
|
-
.attr('class', 'lib-stacked-x-axis-text multichart')
|
|
522
|
-
.call(xAxis)
|
|
523
|
-
.selectAll('text')
|
|
524
|
-
.style('fill', 'var(--chart-text-color)');
|
|
525
|
-
svg
|
|
526
|
-
.append('g')
|
|
527
|
-
.attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
|
|
528
|
-
.call(yAxis)
|
|
529
|
-
.selectAll('text')
|
|
530
|
-
.style('fill', 'var(--chart-text-color)');
|
|
531
|
-
}
|
|
532
|
-
styleAxisDomains(svg, svgYAxisLeft, svgYAxisRight) {
|
|
533
|
-
const axisStyle = {
|
|
534
|
-
stroke: 'var(--chart-axis-color)',
|
|
535
|
-
'stroke-width': '1px'
|
|
536
|
-
};
|
|
537
|
-
[svg, svgYAxisLeft, svgYAxisRight].forEach(element => {
|
|
538
|
-
element.selectAll('.domain')
|
|
539
|
-
.style('stroke', axisStyle.stroke)
|
|
540
|
-
.style('stroke-width', axisStyle['stroke-width']);
|
|
541
|
-
});
|
|
542
|
-
}
|
|
543
|
-
renderLabels(svg, svgYAxisLeft, metaData, height, width, margin) {
|
|
544
|
-
if (metaData.yLabel) {
|
|
545
|
-
this.renderYAxisLabel(svgYAxisLeft, metaData.yLabel, height, margin);
|
|
980
|
+
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
981
|
+
.attr('y', long_tick_length_bg)
|
|
982
|
+
.attr('fill', 'currentColor')
|
|
983
|
+
.text(function (d) {
|
|
984
|
+
// For mobile, do not print the second word at all
|
|
985
|
+
if (isMobile) {
|
|
986
|
+
return '';
|
|
987
|
+
}
|
|
988
|
+
if (d.trim().indexOf(' ') > -1) {
|
|
989
|
+
return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();
|
|
990
|
+
}
|
|
991
|
+
return '';
|
|
992
|
+
})
|
|
993
|
+
.attr('transform', function (d, i) {
|
|
994
|
+
if (isMobile && i === 0) {
|
|
995
|
+
return 'translate(20,0)';
|
|
996
|
+
}
|
|
997
|
+
return null;
|
|
998
|
+
});
|
|
546
999
|
}
|
|
547
|
-
|
|
548
|
-
|
|
1000
|
+
/**
|
|
1001
|
+
* hide yaxis values
|
|
1002
|
+
* used by weekly charts
|
|
1003
|
+
*/
|
|
1004
|
+
if (this.chartConfiguration.isYaxisLabelHidden != undefined &&
|
|
1005
|
+
this.chartConfiguration.isYaxisLabelHidden) {
|
|
1006
|
+
svg
|
|
1007
|
+
.selectAll('.yaxis-dashed > g > text')
|
|
1008
|
+
.attr('class', 'lib-display-hidden');
|
|
549
1009
|
}
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
let labelClass = 'lib-axis-group-label font-size-1';
|
|
557
|
-
if (this.chartConfiguration.isDrilldownChart) {
|
|
558
|
-
labelClass += ' lib-ylabel-drilldowncharts';
|
|
1010
|
+
/** hide y axis labels
|
|
1011
|
+
* config is there for future use
|
|
1012
|
+
*/
|
|
1013
|
+
if (this.chartConfiguration.isYaxisHidden != undefined &&
|
|
1014
|
+
this.chartConfiguration.isYaxisHidden) {
|
|
1015
|
+
d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');
|
|
559
1016
|
}
|
|
560
|
-
|
|
561
|
-
|
|
1017
|
+
/**
|
|
1018
|
+
* dashed y axis
|
|
1019
|
+
* used by weekly charts
|
|
1020
|
+
*/
|
|
1021
|
+
if (this.chartConfiguration.isYaxisDashed != undefined &&
|
|
1022
|
+
this.chartConfiguration.isYaxisDashed) {
|
|
1023
|
+
d3.selectAll('.yaxis-dashed')
|
|
1024
|
+
.style('stroke-dasharray', '5 5')
|
|
1025
|
+
.style('color', 'var(--chart-grid-color)'); // Use CSS variable
|
|
562
1026
|
}
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
.
|
|
569
|
-
.attr('style', this.chartConfiguration.yAxisCustomlabelStyles)
|
|
570
|
-
.attr('transform', 'rotate(-90)')
|
|
571
|
-
.attr('y', yPosition)
|
|
572
|
-
.attr('x', -height / 2)
|
|
573
|
-
.attr('dy', '1em')
|
|
574
|
-
.style('text-anchor', 'middle')
|
|
575
|
-
.style('fill', 'var(--chart-text-color)')
|
|
576
|
-
.text(formatted)
|
|
577
|
-
.style('text-transform', isAcronym ? 'none' : 'capitalize');
|
|
578
|
-
}
|
|
579
|
-
renderXAxisLabel(svg, xLabel, height, width, margin) {
|
|
580
|
-
const { formatted, isAcronym } = this.formatAxisLabel(xLabel);
|
|
581
|
-
const isRia = this.customChartConfiguration?.isRia;
|
|
582
|
-
const xPosition = isRia
|
|
583
|
-
? height + margin.top + margin.bottom
|
|
584
|
-
: height + margin.top + margin.bottom + 10;
|
|
585
|
-
let labelClass = 'lib-axis-group-label font-size-1';
|
|
586
|
-
if (this.chartConfiguration.isDrilldownChart) {
|
|
587
|
-
labelClass += ' lib-xlabel-drilldowncharts';
|
|
1027
|
+
/**
|
|
1028
|
+
* x axis color
|
|
1029
|
+
* used by weekly charts
|
|
1030
|
+
*/
|
|
1031
|
+
if (this.chartConfiguration.isXaxisColor != undefined) {
|
|
1032
|
+
d3.selectAll('.multichart').style('color', this.chartConfiguration.isXaxisColor || 'var(--chart-text-color)');
|
|
588
1033
|
}
|
|
589
|
-
|
|
590
|
-
|
|
1034
|
+
/**
|
|
1035
|
+
* used to display y label
|
|
1036
|
+
*/
|
|
1037
|
+
if (this.isZoomedOut && this.chartData.data.length > 9) {
|
|
1038
|
+
svg
|
|
1039
|
+
.selectAll('.lib-xaxis-labels-texts-drilldown')
|
|
1040
|
+
.attr('transform', 'rotate(-90)')
|
|
1041
|
+
.attr('text-anchor', 'end')
|
|
1042
|
+
.attr('x', '-5')
|
|
1043
|
+
.attr('dy', null);
|
|
591
1044
|
}
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
.
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
.
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
.
|
|
610
|
-
.
|
|
611
|
-
.
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
.domain([0, d3.max(lineData, (d) => +d.value) || 0])
|
|
636
|
-
.range([height, 0]);
|
|
637
|
-
const dataGroup = d3
|
|
638
|
-
.nest()
|
|
639
|
-
.key((d) => d.category)
|
|
640
|
-
.entries(lineData);
|
|
641
|
-
const lineGen = d3
|
|
642
|
-
.line()
|
|
643
|
-
.x((d) => xScale(d.name) + xScale.bandwidth() / 2)
|
|
644
|
-
.y((d) => lineYscale(d.value));
|
|
645
|
-
dataGroup.forEach((group) => {
|
|
646
|
-
// Draw line
|
|
1045
|
+
function styleAxisDomain() {
|
|
1046
|
+
svg.selectAll('.domain')
|
|
1047
|
+
.style('stroke', 'var(--chart-axis-color)')
|
|
1048
|
+
.style('stroke-width', '1px');
|
|
1049
|
+
svgYAxisLeft.selectAll('.domain')
|
|
1050
|
+
.style('stroke', 'var(--chart-axis-color)')
|
|
1051
|
+
.style('stroke-width', '1px');
|
|
1052
|
+
svgYAxisRight.selectAll('.domain')
|
|
1053
|
+
.style('stroke', 'var(--chart-axis-color)')
|
|
1054
|
+
.style('stroke-width', '1px');
|
|
1055
|
+
}
|
|
1056
|
+
styleAxisDomain();
|
|
1057
|
+
if (metaData.yLabel) {
|
|
1058
|
+
svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();
|
|
1059
|
+
function isAcronym(label) {
|
|
1060
|
+
return (label.length <= 4 && /^[A-Z]+$/.test(label)) || (label === label.toUpperCase() && /[A-Z]/.test(label));
|
|
1061
|
+
}
|
|
1062
|
+
const yLabelText = metaData.yLabel;
|
|
1063
|
+
const isAcr = isAcronym(yLabelText.replace(/[^A-Za-z]/g, ''));
|
|
1064
|
+
const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;
|
|
1065
|
+
svgYAxisLeft
|
|
1066
|
+
.append('text')
|
|
1067
|
+
.attr('class', function () {
|
|
1068
|
+
let baseClass = 'lib-axis-group-label font-size-1';
|
|
1069
|
+
if (self.chartConfiguration.isDrilldownChart)
|
|
1070
|
+
return baseClass + ' lib-ylabel-drilldowncharts';
|
|
1071
|
+
if (self.chartConfiguration.isMultiChartGridLine != undefined)
|
|
1072
|
+
return baseClass + ' lib-ylabel-weeklyCharts';
|
|
1073
|
+
return baseClass + ' lib-axis-waterfall-label';
|
|
1074
|
+
})
|
|
1075
|
+
.attr('style', self.chartConfiguration.yAxisCustomlabelStyles)
|
|
1076
|
+
.attr('transform', 'rotate(-90)')
|
|
1077
|
+
.attr('y', yPosition)
|
|
1078
|
+
.attr('x', 0 - height / 2)
|
|
1079
|
+
.attr('dy', '1em')
|
|
1080
|
+
.style('text-anchor', 'middle')
|
|
1081
|
+
.style('fill', 'var(--chart-text-color)')
|
|
1082
|
+
.style('color', 'var(--chart-text-color)')
|
|
1083
|
+
.text(isAcr ? yLabelText.toUpperCase() : yLabelText.toLowerCase())
|
|
1084
|
+
.style('text-transform', isAcr ? 'none' : 'capitalize');
|
|
1085
|
+
}
|
|
1086
|
+
if (this.chartData.targetLineData) {
|
|
1087
|
+
const yZero = yScale(parsedNum);
|
|
647
1088
|
svg
|
|
648
|
-
.append('
|
|
649
|
-
.
|
|
650
|
-
.attr('
|
|
651
|
-
.attr('
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
1089
|
+
.append('line')
|
|
1090
|
+
.attr('x1', 0)
|
|
1091
|
+
.attr('x2', width)
|
|
1092
|
+
.attr('y1', yZero)
|
|
1093
|
+
.attr('y2', yZero)
|
|
1094
|
+
.style('stroke-dasharray', '5 5')
|
|
1095
|
+
.style('stroke', this.chartData.targetLineData.color);
|
|
1096
|
+
// svgYAxisRight
|
|
1097
|
+
// .append('line')
|
|
1098
|
+
// .attr('x1', 0)
|
|
1099
|
+
// .attr('x2', rightSvgWidth)
|
|
1100
|
+
// .attr('y1', yZero)
|
|
1101
|
+
// .attr('y2', yZero)
|
|
1102
|
+
// .style('stroke', this.chartData.targetLineData.color);
|
|
1103
|
+
svgYAxisRight
|
|
1104
|
+
.append('foreignObject')
|
|
1105
|
+
// .attr('transform', 'translate(' + 0 + ',' + (yZero - 30) + ')')
|
|
1106
|
+
.attr('transform', 'translate(' + 0 + ',' + (yZero - 13) + ')')
|
|
1107
|
+
.attr('width', rightSvgWidth)
|
|
1108
|
+
.attr('height', 50)
|
|
1109
|
+
.append('xhtml:div')
|
|
1110
|
+
.attr('class', 'target-display')
|
|
1111
|
+
.style('color', 'var(--chart-text-color)')
|
|
1112
|
+
.html(function (d, i) {
|
|
1113
|
+
let dataTypeTemp = '';
|
|
1114
|
+
let targetLineName = 'target';
|
|
1115
|
+
if (metaData.dataType) {
|
|
1116
|
+
dataTypeTemp = metaData.dataType;
|
|
1117
|
+
}
|
|
1118
|
+
if (self.chartData.targetLineData &&
|
|
1119
|
+
self.chartData.targetLineData.targetName) {
|
|
1120
|
+
targetLineName = self.chartData.targetLineData.targetName;
|
|
1121
|
+
}
|
|
1122
|
+
return (`<div>${targetLineName}</div>` +
|
|
1123
|
+
'<div>' +
|
|
1124
|
+
self.chartData.targetLineData.target +
|
|
1125
|
+
'' +
|
|
1126
|
+
dataTypeTemp +
|
|
1127
|
+
'</div>');
|
|
1128
|
+
});
|
|
1129
|
+
}
|
|
1130
|
+
rect
|
|
1131
|
+
.selectAll('rect')
|
|
1132
|
+
.on('mouseenter', handleMouseOver)
|
|
1133
|
+
.on('mouseout', handleMouseOut);
|
|
1134
|
+
if (metaData.lineyLabel) {
|
|
1135
|
+
svg
|
|
1136
|
+
.append('text')
|
|
1137
|
+
.attr('class', 'lib-axis-group-label lib-line-axis')
|
|
1138
|
+
.attr('style', self.chartConfiguration.yAxisCustomlabelStyles)
|
|
1139
|
+
.attr('transform', 'translate(' + (width - 20) + ',0) rotate(90)')
|
|
1140
|
+
.attr('y', 0 - margin.right * 3)
|
|
1141
|
+
.attr('x', height / 2)
|
|
1142
|
+
.attr('dy', '5em')
|
|
1143
|
+
.style('text-anchor', 'middle')
|
|
1144
|
+
.text(metaData.lineyLabel);
|
|
1145
|
+
}
|
|
1146
|
+
if (metaData.xLabel) {
|
|
1147
|
+
function isAcronym(label) {
|
|
1148
|
+
return ((label.length <= 4 && /^[A-Z]+$/.test(label)) ||
|
|
1149
|
+
(label === label.toUpperCase() && /[A-Z]/.test(label)));
|
|
1150
|
+
}
|
|
1151
|
+
const xLabelText = metaData.xLabel;
|
|
1152
|
+
const isAcr = isAcronym(xLabelText.replace(/[^A-Za-z]/g, ''));
|
|
1153
|
+
const xPosition = isria ? (height + margin.top + margin.bottom) : (height + margin.top + margin.bottom + 10);
|
|
1154
|
+
svg
|
|
1155
|
+
.append('text')
|
|
1156
|
+
.attr('class', function () {
|
|
1157
|
+
let baseClass = 'lib-axis-group-label font-size-1';
|
|
1158
|
+
if (self.chartConfiguration.isDrilldownChart)
|
|
1159
|
+
return baseClass + ' lib-xlabel-drilldowncharts';
|
|
1160
|
+
if (self.chartConfiguration.isMultiChartGridLine != undefined)
|
|
1161
|
+
return baseClass + ' lib-xlabel-weeklyCharts';
|
|
1162
|
+
return baseClass + ' lib-axis-waterfall-label';
|
|
656
1163
|
})
|
|
657
|
-
.attr('
|
|
658
|
-
.attr('
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
.
|
|
662
|
-
.
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
.
|
|
668
|
-
|
|
669
|
-
if ('category' in d) {
|
|
670
|
-
return colors[d.category];
|
|
671
|
-
}
|
|
672
|
-
return this.chartConfiguration.lineGraphColor;
|
|
1164
|
+
.attr('style', self.chartConfiguration.xAxisCustomlabelStyles)
|
|
1165
|
+
.attr('transform', 'translate(' + width / 2 + ' ,' + xPosition + ')')
|
|
1166
|
+
.style('text-anchor', 'middle')
|
|
1167
|
+
.style('fill', 'var(--chart-text-color)')
|
|
1168
|
+
.text(isAcr ? xLabelText.toUpperCase() : xLabelText.toLowerCase())
|
|
1169
|
+
.style('text-transform', isAcr ? 'none' : 'capitalize');
|
|
1170
|
+
}
|
|
1171
|
+
if (lineData && colors) {
|
|
1172
|
+
var dataGroup = d3
|
|
1173
|
+
.nest()
|
|
1174
|
+
.key(function (d) {
|
|
1175
|
+
return d.category;
|
|
673
1176
|
})
|
|
674
|
-
.
|
|
675
|
-
|
|
676
|
-
.
|
|
677
|
-
.
|
|
678
|
-
.
|
|
679
|
-
|
|
680
|
-
|
|
1177
|
+
.entries(lineData);
|
|
1178
|
+
var lineGen = d3
|
|
1179
|
+
.line()
|
|
1180
|
+
.x(function (d) {
|
|
1181
|
+
return xScale(d.name) + xScale.bandwidth() / 2;
|
|
1182
|
+
})
|
|
1183
|
+
.y(function (d) {
|
|
1184
|
+
return lineYscale(d.value);
|
|
1185
|
+
});
|
|
1186
|
+
var calculateCX = (d) => {
|
|
1187
|
+
return xScale(d.name) + xScale.bandwidth() / 2;
|
|
1188
|
+
};
|
|
1189
|
+
var calculateCY = (d) => {
|
|
1190
|
+
return lineYscale(d.value);
|
|
1191
|
+
};
|
|
1192
|
+
dataGroup.forEach(function (d, i) {
|
|
1193
|
+
svg
|
|
1194
|
+
.append('path')
|
|
1195
|
+
.datum(d.values)
|
|
1196
|
+
.attr('fill', 'none')
|
|
1197
|
+
.attr('stroke', function (d) {
|
|
1198
|
+
if ('category' in d[0]) {
|
|
1199
|
+
return colors[d[0].category];
|
|
1200
|
+
}
|
|
1201
|
+
else {
|
|
1202
|
+
return self.chartConfiguration.lineGraphColor;
|
|
1203
|
+
}
|
|
1204
|
+
})
|
|
1205
|
+
.attr('stroke-width', 2.5) /**line thinkness */
|
|
1206
|
+
.attr('d', lineGen(d.values));
|
|
1207
|
+
var dot = svg
|
|
1208
|
+
.selectAll('myCircles')
|
|
1209
|
+
.data(d.values)
|
|
1210
|
+
.enter()
|
|
1211
|
+
.append('g')
|
|
1212
|
+
.on('click', function (d) {
|
|
1213
|
+
self.handleClick(d);
|
|
1214
|
+
});
|
|
681
1215
|
dot
|
|
682
|
-
.append('
|
|
683
|
-
.attr('
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
1216
|
+
.append('circle')
|
|
1217
|
+
.attr('fill', function (d) {
|
|
1218
|
+
if ('category' in d) {
|
|
1219
|
+
return colors[d.category];
|
|
1220
|
+
}
|
|
1221
|
+
else {
|
|
1222
|
+
return self.chartConfiguration.lineGraphColor;
|
|
1223
|
+
}
|
|
1224
|
+
})
|
|
1225
|
+
.attr('stroke', 'none')
|
|
1226
|
+
.attr('cx', function (d, i) {
|
|
1227
|
+
return xScale(d.name) + xScale.bandwidth() / 2;
|
|
1228
|
+
})
|
|
1229
|
+
.attr('cy', function (d, i) {
|
|
1230
|
+
return lineYscale(d.value);
|
|
1231
|
+
})
|
|
1232
|
+
.attr('r', 3) /**radius of circle=5 */
|
|
1233
|
+
.style('cursor', 'pointer');
|
|
1234
|
+
if (self.chartConfiguration.lineGraphColor) {
|
|
1235
|
+
dot
|
|
1236
|
+
.append('text')
|
|
1237
|
+
.attr('class', 'dots')
|
|
1238
|
+
.attr('fill', self.chartConfiguration.lineGraphColor)
|
|
1239
|
+
.attr('style', 'font-size: ' + '.85em;' + 'font-weight:' + 'bold')
|
|
1240
|
+
.attr('x', function (d, i) {
|
|
1241
|
+
return xScale(d.name) + xScale.bandwidth() / 2;
|
|
1242
|
+
})
|
|
1243
|
+
.attr('y', function (d, i) {
|
|
1244
|
+
return lineYscale(d.value);
|
|
1245
|
+
})
|
|
1246
|
+
.attr('dy', '-1em')
|
|
1247
|
+
.text(function (d, i) {
|
|
1248
|
+
return self.chartConfiguration.labelFormatter(d.value);
|
|
1249
|
+
});
|
|
1250
|
+
}
|
|
1251
|
+
});
|
|
696
1252
|
}
|
|
1253
|
+
// svg.attr('width', 150).style('max-width', 150).style('overflow-x', 'auto');
|
|
1254
|
+
}
|
|
1255
|
+
handleClick(d) {
|
|
1256
|
+
if (this.chartData?.metaData?.hasDrillDown || d?.toggleFrom)
|
|
1257
|
+
this.clickEvent.emit(d);
|
|
697
1258
|
}
|
|
698
1259
|
handleHeaderMenuClick(id) {
|
|
699
1260
|
this.headerMenuclickEvent.emit(id);
|
|
@@ -702,14 +1263,15 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
|
|
|
702
1263
|
this.clickEvent.emit(event);
|
|
703
1264
|
}
|
|
704
1265
|
handleZoominZoomoutClick({ isZoomOut, event }) {
|
|
1266
|
+
// this.isZoomOutSelected(isZoomOut, event);
|
|
705
1267
|
this.isZoomOutSelected(isZoomOut);
|
|
706
1268
|
}
|
|
707
1269
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HorizontalBarsWithScrollZoomComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
708
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: HorizontalBarsWithScrollZoomComponent, selector: "lib-horizontal-bars-with-scroll-zoom", inputs: { chartData: "chartData", customChartConfiguration: "customChartConfiguration" }, outputs: { clickEvent: "clickEvent", headerMenuclickEvent: "headerMenuclickEvent" }, viewQueries: [{ propertyName: "containerElt", first: true, predicate: ["verticalstackedchartcontainer"], descendants: true, static: true }, { propertyName: "verticalstackedcontainerElt", first: true, predicate: ["verticalstackedcontainer"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<meta http-equiv=\"CACHE-CONTROL\" content=\"NO-CACHE\" />\r\n<meta http-equiv=\"EXPIRES\" content=\"Sat, 01 Jun 2004 11:12:01 GMT\" />\r\n<div\r\n #verticalstackedcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n style=\"background-color: var(--card-bg);\"\r\n\r\n (resized)=\"onResized($event)\"\r\n>\r\n <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n </div>\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"verticalstackedchartcontainer\"\r\n #verticalstackedchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:1.2em}.lib-axis-group-label{font-size:.85em;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:40px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title-top-text{color:var(--font-color)!important;font-size:14px;font-weight:600}.title-bar-name{color:var(--font-color)!important;font-size:17px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:var(--font-color)!important;font-size:12px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}@media (max-width: 575px){.lib-xaxis-labels-texts-drilldown{writing-mode:sideways-lr}}@media screen and (min-width: 1024px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1366px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1920px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 2560px) and (min-height: 500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background){background-color:#2e3640}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background) .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ResizedDirective, selector: "[resized]", outputs: ["resized"] }, { kind: "component", type: i3.ChartHeaderV2Component, selector: "lib-chart-header-v2", inputs: ["chartData", "chartConfiguration"], outputs: ["clickEvent", "zoomInZoomOutClick"] }, { kind: "component", type: i4.ChartHeaderV3Component, selector: "lib-chart-header-v3", inputs: ["chartData", "chartConfiguration"], outputs: ["compareByFilterSelection", "zoomInZoomOutClick"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
1270
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: HorizontalBarsWithScrollZoomComponent, selector: "lib-horizontal-bars-with-scroll-zoom", inputs: { chartData: "chartData", customChartConfiguration: "customChartConfiguration" }, outputs: { clickEvent: "clickEvent", headerMenuclickEvent: "headerMenuclickEvent" }, viewQueries: [{ propertyName: "containerElt", first: true, predicate: ["verticalstackedchartcontainer"], descendants: true, static: true }, { propertyName: "verticalstackedcontainerElt", first: true, predicate: ["verticalstackedcontainer"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<meta http-equiv=\"CACHE-CONTROL\" content=\"NO-CACHE\" />\r\n<meta http-equiv=\"EXPIRES\" content=\"Sat, 01 Jun 2004 11:12:01 GMT\" />\r\n<div\r\n #verticalstackedcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n style=\"background-color: var(--card-bg);\"\r\n\r\n (resized)=\"onResized($event)\"\r\n>\r\n <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n\r\n <!-- <span *ngIf=\"chartConfiguration.isComparebyDropdownVisible\">\r\n <lib-dropdown></lib-dropdown>\r\n </span> -->\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n </div>\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"verticalstackedchartcontainer\"\r\n #verticalstackedchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:1.2em}.lib-axis-group-label{font-size:.85em;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:40px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title-top-text{color:var(--font-color)!important;font-size:14px;font-weight:600}.title-bar-name{color:var(--font-color)!important;font-size:17px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:var(--font-color)!important;font-size:12px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}@media (max-width: 575px){.lib-xaxis-labels-texts-drilldown{writing-mode:sideways-lr}}@media screen and (min-width: 1024px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1366px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1920px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 2560px) and (min-height: 500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background){background-color:#2e3640}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background) .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ResizedDirective, selector: "[resized]", outputs: ["resized"] }, { kind: "component", type: i3.ChartHeaderV2Component, selector: "lib-chart-header-v2", inputs: ["chartData", "chartConfiguration"], outputs: ["clickEvent", "zoomInZoomOutClick"] }, { kind: "component", type: i4.ChartHeaderV3Component, selector: "lib-chart-header-v3", inputs: ["chartData", "chartConfiguration"], outputs: ["compareByFilterSelection", "zoomInZoomOutClick"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
709
1271
|
}
|
|
710
1272
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HorizontalBarsWithScrollZoomComponent, decorators: [{
|
|
711
1273
|
type: Component,
|
|
712
|
-
args: [{ selector: 'lib-horizontal-bars-with-scroll-zoom', encapsulation: ViewEncapsulation.None, template: "<meta http-equiv=\"CACHE-CONTROL\" content=\"NO-CACHE\" />\r\n<meta http-equiv=\"EXPIRES\" content=\"Sat, 01 Jun 2004 11:12:01 GMT\" />\r\n<div\r\n #verticalstackedcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n style=\"background-color: var(--card-bg);\"\r\n\r\n (resized)=\"onResized($event)\"\r\n>\r\n <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n </div>\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"verticalstackedchartcontainer\"\r\n #verticalstackedchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:1.2em}.lib-axis-group-label{font-size:.85em;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:40px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title-top-text{color:var(--font-color)!important;font-size:14px;font-weight:600}.title-bar-name{color:var(--font-color)!important;font-size:17px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:var(--font-color)!important;font-size:12px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}@media (max-width: 575px){.lib-xaxis-labels-texts-drilldown{writing-mode:sideways-lr}}@media screen and (min-width: 1024px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1366px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1920px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 2560px) and (min-height: 500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background){background-color:#2e3640}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background) .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"] }]
|
|
1274
|
+
args: [{ selector: 'lib-horizontal-bars-with-scroll-zoom', encapsulation: ViewEncapsulation.None, template: "<meta http-equiv=\"CACHE-CONTROL\" content=\"NO-CACHE\" />\r\n<meta http-equiv=\"EXPIRES\" content=\"Sat, 01 Jun 2004 11:12:01 GMT\" />\r\n<div\r\n #verticalstackedcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n style=\"background-color: var(--card-bg);\"\r\n\r\n (resized)=\"onResized($event)\"\r\n>\r\n <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n\r\n <!-- <span *ngIf=\"chartConfiguration.isComparebyDropdownVisible\">\r\n <lib-dropdown></lib-dropdown>\r\n </span> -->\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n </div>\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"verticalstackedchartcontainer\"\r\n #verticalstackedchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:1.2em}.lib-axis-group-label{font-size:.85em;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:40px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title-top-text{color:var(--font-color)!important;font-size:14px;font-weight:600}.title-bar-name{color:var(--font-color)!important;font-size:17px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:var(--font-color)!important;font-size:12px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}@media (max-width: 575px){.lib-xaxis-labels-texts-drilldown{writing-mode:sideways-lr}}@media screen and (min-width: 1024px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1366px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1920px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 2560px) and (min-height: 500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background){background-color:#2e3640}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background) .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"] }]
|
|
713
1275
|
}], ctorParameters: () => [], propDecorators: { containerElt: [{
|
|
714
1276
|
type: ViewChild,
|
|
715
1277
|
args: ['verticalstackedchartcontainer', { static: true }]
|
|
@@ -725,4 +1287,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
725
1287
|
}], headerMenuclickEvent: [{
|
|
726
1288
|
type: Output
|
|
727
1289
|
}] } });
|
|
728
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"horizontal-bars-with-scroll-zoom.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.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  OnChanges,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport { ComponentUniqueId } from '../unique-id';\r\nimport ChartHelper from '../chart-helper';\r\nimport * as d3 from 'd3';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport HeaderConfigHelper from '../header-config';\r\n\r\ninterface ChartData {\r\n  data: any[];\r\n  metaData: ChartMetaData;\r\n  lineData?: any[];\r\n  targetLineData?: TargetLineData;\r\n}\r\n\r\ninterface ChartMetaData {\r\n  colors: { [key: string]: string };\r\n  keyList: string[];\r\n  unit?: string;\r\n  isCC?: boolean;\r\n  barWithoutClick?: string[];\r\n  hasDrillDown?: boolean;\r\n  hoverColor?: string;\r\n  dataType?: string;\r\n  yLabel?: string;\r\n  lineyLabel?: string;\r\n  xLabel?: string;\r\n}\r\n\r\ninterface TargetLineData {\r\n  target: number | string;\r\n  targetName?: string;\r\n  color: string;\r\n  barAboveTargetColor?: string;\r\n  barAboveTargetHoverColor?: string;\r\n}\r\n\r\ninterface DeviceBreakpoints {\r\n  isMobile: boolean;\r\n  isTablet: boolean;\r\n  isDesktop: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'lib-horizontal-bars-with-scroll-zoom',\r\n  templateUrl: './horizontal-bars-with-scroll-zoom.component.html',\r\n  styleUrls: [\r\n    './horizontal-bars-with-scroll-zoom.component.less',\r\n    '../common-styles.less',\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HorizontalBarsWithScrollZoomComponent\r\n  extends ComponentUniqueId\r\n  implements OnInit, OnChanges {\r\n  \r\n  @ViewChild('verticalstackedchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('verticalstackedcontainer', { static: true })\r\n  verticalstackedcontainerElt!: ElementRef;\r\n\r\n  @Input() chartData!: ChartData;\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  isHeaderVisible = true;\r\n  isTopCaptionVisible = true;\r\n  uniqueId: string = this.getUniqueId();\r\n  isTransparentBackground = false;\r\n  isCC = false;\r\n  isZoomedOut = true;\r\n\r\n  private readonly TICK_LENGTHS = {\r\n    short: 4,\r\n    long: 16,\r\n    shortBg: 5,\r\n    longBg: 30,\r\n  };\r\n\r\n  private readonly SPACING = {\r\n    rightSvgWidth: 60,\r\n    leftAndRight: 50,\r\n  };\r\n\r\n  private readonly defaultConfiguration = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    svgHeight: 70,\r\n    legendHeight: '10%',\r\n    numberOfYTicks: 5,\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    xAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showLegend: false,\r\n    forComparison: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    yAxisGrid: false,\r\n  };\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.redrawChart();\r\n  }\r\n\r\n  onResized(event: ResizedEvent): void {\r\n    setTimeout(() => this.redrawChart(), 10);\r\n  }\r\n\r\n  isZoomOutSelected(isZoomOut: boolean): void {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.redrawChart();\r\n  }\r\n\r\n  private redrawChart(): void {\r\n    d3.select('#' + this.uniqueId).remove();\r\n    this.initializeStackedChart();\r\n  }\r\n\r\n  private getDeviceBreakpoints(): DeviceBreakpoints {\r\n    const width = window.innerWidth;\r\n    return {\r\n      isMobile: width < 576,\r\n      isTablet: width >= 576 && width < 992,\r\n      isDesktop: width >= 992,\r\n    };\r\n  }\r\n\r\n  private applyResponsiveConfig(device: DeviceBreakpoints): void {\r\n    if (device.isMobile) {\r\n      this.chartConfiguration.margin = { top: 20, right: 10, bottom: 40, left: 30 };\r\n      this.chartConfiguration.numberOfYTicks = 4;\r\n      this.chartConfiguration.svgHeight = 60;\r\n    } else if (device.isTablet) {\r\n      this.chartConfiguration.margin = { top: 25, right: 20, bottom: 45, left: 40 };\r\n      this.chartConfiguration.numberOfYTicks = 6;\r\n      this.chartConfiguration.svgHeight = 70;\r\n    } else {\r\n      this.chartConfiguration.margin = { top: 30, right: 30, bottom: 50, left: 60 };\r\n      this.chartConfiguration.numberOfYTicks = 7;\r\n      this.chartConfiguration.svgHeight = 80;\r\n    }\r\n  }\r\n\r\n  private mergeConfigurations(): void {\r\n    Object.keys(this.defaultConfiguration).forEach((key) => {\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 prepareMetaData(metaData: ChartMetaData): ChartMetaData {\r\n    if (!metaData.unit) metaData.unit = '';\r\n    if (metaData.isCC) this.isCC = metaData.isCC;\r\n    \r\n    if (metaData.barWithoutClick?.length) {\r\n      metaData.barWithoutClick = metaData.barWithoutClick.map(el => el.toLowerCase());\r\n    } else {\r\n      metaData.barWithoutClick = [];\r\n    }\r\n    \r\n    return metaData;\r\n  }\r\n\r\n  private parseTargetValue(targetLineData?: TargetLineData): number | null {\r\n    if (!targetLineData?.target) return null;\r\n    \r\n    const parsedNum = parseFloat(String(targetLineData.target));\r\n    if (isNaN(parsedNum)) return null;\r\n    \r\n    return Number.isInteger(parsedNum) \r\n      ? parseInt(String(targetLineData.target)) \r\n      : parsedNum;\r\n  }\r\n\r\n  private calculateDimensions(\r\n    containerWidth: number,\r\n    containerHeight: number,\r\n    margin: any,\r\n    device: DeviceBreakpoints\r\n  ): { width: number; height: number } {\r\n    let width = containerWidth - margin.left - margin.right;\r\n    let height = containerHeight * (this.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;\r\n\r\n    // Adjust width for zoom levels\r\n    const dataLength = this.chartData.data.length;\r\n    if (dataLength > 30 && this.isZoomedOut) {\r\n      const minWidth = dataLength * (device.isMobile ? 15 : 25);\r\n      width = Math.max(width, minWidth);\r\n    }\r\n    if (dataLength > 8 && !this.isZoomedOut) {\r\n      width = dataLength * (device.isMobile ? 60 : 130);\r\n    }\r\n\r\n    // Apply special height configurations\r\n    if (this.chartConfiguration.isFullScreen && this.chartConfiguration.svgHeight !== 80) {\r\n      height = this.chartConfiguration.svgHeight;\r\n    } else if (this.chartConfiguration.isFullScreen) {\r\n      height = containerHeight;\r\n    }\r\n\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      height = containerHeight - margin.top - margin.bottom - (device.isMobile ? 60 : 130);\r\n    }\r\n\r\n    return { width, height };\r\n  }\r\n\r\n  private calculateBarDimensions(\r\n    width: number,\r\n    dataLength: number,\r\n    device: DeviceBreakpoints\r\n  ): { barWidth: number; barPadding: number; requiredSvgWidth: number } {\r\n    let barWidth: number;\r\n    let barPadding: number;\r\n    let requiredSvgWidth: number;\r\n\r\n    if (device.isMobile) {\r\n      const minBarWidth = 32;\r\n      barWidth = minBarWidth;\r\n      barPadding = 12;\r\n      requiredSvgWidth = Math.max(\r\n        width - this.SPACING.rightSvgWidth,\r\n        (barWidth + barPadding) * dataLength + this.SPACING.leftAndRight * 2 + \r\n        this.SPACING.rightSvgWidth - barPadding\r\n      );\r\n    } else {\r\n      barWidth = Math.max(\r\n        40,\r\n        (width - this.SPACING.rightSvgWidth - this.SPACING.leftAndRight * 2) / dataLength\r\n      );\r\n      barPadding = 0;\r\n      requiredSvgWidth = width - this.SPACING.rightSvgWidth;\r\n    }\r\n\r\n    return { barWidth, barPadding, requiredSvgWidth };\r\n  }\r\n\r\n  private createScales(data: any[], height: number, width: number, device: DeviceBreakpoints) {\r\n    const xScale = d3\r\n      .scaleBand()\r\n      .rangeRound([\r\n        this.SPACING.leftAndRight,\r\n        width - this.SPACING.rightSvgWidth - this.SPACING.leftAndRight\r\n      ])\r\n      .domain(data.map(d => d.name).reverse())\r\n      .padding(device.isMobile ? 0.2 : 0.5);\r\n\r\n    const yScale = d3.scaleLinear().rangeRound([height, 0]);\r\n\r\n    return { xScale, yScale };\r\n  }\r\n\r\n  private calculateYScaleDomain(layers: any[], targetValue?: number): number {\r\n    let maxValue = d3.max(layers, (d: any) => d3.max(d, (d: any) => d[1])) || 0;\r\n\r\n    if (maxValue === 0) {\r\n      maxValue = targetValue ? targetValue + 20 : 100;\r\n    }\r\n\r\n    if (this.chartConfiguration.customYscale) {\r\n      maxValue *= this.chartConfiguration.customYscale;\r\n    }\r\n\r\n    if (targetValue && maxValue < targetValue) {\r\n      maxValue = maxValue < 10 && targetValue < 10 \r\n        ? targetValue + 3 \r\n        : targetValue + 20;\r\n    }\r\n\r\n    return maxValue;\r\n  }\r\n\r\n  private shouldShowTargetLineColor(d: any, targetValue?: number): boolean {\r\n    return !!(\r\n      !isNaN(d[0]) &&\r\n      !isNaN(d[1]) &&\r\n      this.chartData.targetLineData &&\r\n      targetValue &&\r\n      parseFloat(d[1]) - parseFloat(d[0]) >= targetValue\r\n    );\r\n  }\r\n\r\n  private getBarFillColor(d: any, key: string, metaData: ChartMetaData, targetValue?: number): string {\r\n    if (this.shouldShowTargetLineColor(d, targetValue)) {\r\n      return this.chartData.targetLineData?.barAboveTargetColor || metaData.colors[key];\r\n    }\r\n    return metaData.colors[key];\r\n  }\r\n\r\n  private isAcronym(label: string): boolean {\r\n    const alphaOnly = label.replace(/[^A-Za-z]/g, '');\r\n    return (label.length <= 4 && /^[A-Z]+$/.test(label)) || \r\n           (label === label.toUpperCase() && /[A-Z]/.test(label));\r\n  }\r\n\r\n  private formatAxisLabel(text: string): { formatted: string; isAcronym: boolean } {\r\n    const isAcr = this.isAcronym(text);\r\n    return {\r\n      formatted: isAcr ? text.toUpperCase() : text.toLowerCase(),\r\n      isAcronym: isAcr\r\n    };\r\n  }\r\n\r\n  initializeStackedChart(): void {\r\n    const device = this.getDeviceBreakpoints();\r\n    this.applyResponsiveConfig(device);\r\n    this.mergeConfigurations();\r\n\r\n    const { data, metaData, lineData } = this.chartData;\r\n    const preparedMetaData = this.prepareMetaData(metaData);\r\n    const targetValue = this.parseTargetValue(this.chartData.targetLineData);\r\n\r\n    const chartContainer = d3.select(this.containerElt.nativeElement);\r\n    const verticalstackedcontainer = d3.select(this.verticalstackedcontainerElt.nativeElement);\r\n\r\n    const margin = this.chartConfiguration.margin;\r\n    const containerWidth = chartContainer.node().getBoundingClientRect().width;\r\n    const containerHeight = verticalstackedcontainer.node().getBoundingClientRect().height;\r\n\r\n    const { width, height } = this.calculateDimensions(\r\n      containerWidth,\r\n      containerHeight,\r\n      margin,\r\n      device\r\n    );\r\n\r\n    // Apply visibility configurations\r\n    if (this.chartConfiguration.isHeaderVisible !== undefined) {\r\n      this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n    }\r\n    if (this.chartConfiguration.isTopCaptionVisible !== undefined) {\r\n      this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;\r\n    }\r\n    if (this.chartConfiguration.isTransparentBackground !== undefined) {\r\n      this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;\r\n    }\r\n\r\n    // Create formatters\r\n    const formatFromBackend = this.chartConfiguration.textFormatter\r\n      ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)\r\n      : null;\r\n    const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n\r\n    // Create SVG containers\r\n    const { barWidth, barPadding, requiredSvgWidth } = this.calculateBarDimensions(\r\n      width,\r\n      data.length,\r\n      device\r\n    );\r\n\r\n    const outerContainer = this.createOuterContainer(chartContainer, height, margin);\r\n    const { svgYAxisLeft, svgYAxisRight } = this.createAxisContainers(\r\n      outerContainer,\r\n      height,\r\n      margin\r\n    );\r\n    const { innerContainer, svg } = this.createInnerContainer(\r\n      outerContainer,\r\n      requiredSvgWidth,\r\n      height,\r\n      margin,\r\n      device\r\n    );\r\n\r\n    // Create scales\r\n    const { xScale, yScale } = this.createScales(data, height, width, device);\r\n    \r\n    // Stack data\r\n    const stack: any = d3\r\n      .stack()\r\n      .keys(preparedMetaData.keyList)\r\n      .offset(d3.stackOffsetNone);\r\n    const layers: any = stack(data);\r\n\r\n    // Set Y scale domain\r\n    const maxValue = this.calculateYScaleDomain(layers, targetValue || undefined);\r\n    yScale.domain([0, maxValue]).nice();\r\n\r\n    // Render chart elements\r\n    this.renderGrids(svg, xScale, yScale, height, width);\r\n    this.renderBars(\r\n      svg,\r\n      layers,\r\n      xScale,\r\n      yScale,\r\n      preparedMetaData,\r\n      device,\r\n      barWidth,\r\n      barPadding,\r\n      targetValue,\r\n      formatFromBackend,\r\n      formatForHugeNumbers\r\n    );\r\n    this.renderAxes(svg, svgYAxisLeft, svgYAxisRight, xScale, yScale, data, height, width, device);\r\n    this.renderLabels(svg, svgYAxisLeft, preparedMetaData, height, width, margin);\r\n    \r\n    if (this.chartData.targetLineData && targetValue) {\r\n      this.renderTargetLine(svg, svgYAxisRight, yScale, width, targetValue, preparedMetaData);\r\n    }\r\n\r\n    if (lineData) {\r\n      this.renderLineChart(svg, lineData, xScale, height, preparedMetaData.colors);\r\n    }\r\n  }\r\n\r\n  private createOuterContainer(chartContainer: any, height: number, margin: any): any {\r\n    return chartContainer\r\n      .append('div')\r\n      .attr('id', this.uniqueId)\r\n      .attr('class', 'outer-container')\r\n      .style('width', '100%')\r\n      .style('height', height)\r\n      .style('overflow-x', 'hidden')\r\n      .style('padding-left', `${margin.left}px`)\r\n      .style('margin-left', '10px')\r\n      .style('padding-right', `${this.SPACING.rightSvgWidth}px`);\r\n  }\r\n\r\n  private createAxisContainers(outerContainer: any, height: number, margin: any): any {\r\n    const svgYAxisLeft = outerContainer\r\n      .append('svg')\r\n      .attr('width', '80')\r\n      .attr('height', height + margin.top + margin.bottom)\r\n      .style('position', 'absolute')\r\n      .style('left', '0')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', `translate(${margin.left + 10},${margin.top})`);\r\n\r\n    const svgYAxisRight = outerContainer\r\n      .append('svg')\r\n      .attr('width', this.SPACING.rightSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom)\r\n      .style('position', 'absolute')\r\n      .style('right', '2px')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', `translate(0,${margin.top})`);\r\n\r\n    return { svgYAxisLeft, svgYAxisRight };\r\n  }\r\n\r\n  private createInnerContainer(\r\n    outerContainer: any,\r\n    requiredSvgWidth: number,\r\n    height: number,\r\n    margin: any,\r\n    device: DeviceBreakpoints\r\n  ): any {\r\n    const innerContainer = outerContainer\r\n      .append('div')\r\n      .attr('class', 'inner-container')\r\n      .style('width', '100%')\r\n      .style('overflow-x', device.isMobile ? 'auto' : 'auto');\r\n\r\n    const svg = innerContainer\r\n      .append('svg')\r\n      .attr('width', requiredSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom + 30)\r\n      .append('g')\r\n      .attr('transform', `translate(0,${margin.top})`);\r\n\r\n    return { innerContainer, svg };\r\n  }\r\n\r\n  private renderGrids(svg: any, xScale: any, yScale: any, height: number, width: number): void {\r\n    if (this.chartConfiguration.isXgridBetweenLabels) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'grid')\r\n        .attr('transform', `translate(${xScale.bandwidth() / 2},${height})`)\r\n        .call(d3.axisBottom(xScale).tickSize(-height).tickFormat(''))\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('color', '#999999')\r\n        .call((g: any) => g.select('.domain').remove());\r\n    }\r\n\r\n    if (this.chartConfiguration.yAxisGrid) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'grid')\r\n        .call(\r\n          d3\r\n            .axisLeft(yScale)\r\n            .ticks(this.chartConfiguration.numberOfYTicks)\r\n            .tickSize(-width)\r\n            .tickFormat('')\r\n        )\r\n        .style('color', 'var(--chart-grid-color)')\r\n        .style('opacity', '1');\r\n    }\r\n\r\n    if (this.chartConfiguration.xAxisGrid) {\r\n      this.chartConfiguration.xAxisGrid.forEach((gridPos: number, index: number) => {\r\n        svg\r\n          .append('g')\r\n          .attr('class', `x${index + 2} axis${index + 2}`)\r\n          .style('color', 'var(--chart-grid-color)')\r\n          .attr('transform', `translate(0,${height * gridPos})`)\r\n          .call(d3.axisBottom(xScale).tickSize(0).ticks(5).tickFormat(''))\r\n          .style('fill', 'var(--chart-text-color)');\r\n      });\r\n    }\r\n  }\r\n\r\n  private renderBars(\r\n    svg: any,\r\n    layers: any,\r\n    xScale: any,\r\n    yScale: any,\r\n    metaData: ChartMetaData,\r\n    device: DeviceBreakpoints,\r\n    barWidth: number,\r\n    barPadding: number,\r\n    targetValue: number | null,\r\n    formatFromBackend: any,\r\n    formatForHugeNumbers: any\r\n  ): void {\r\n    const layer = svg\r\n      .selectAll('.layer')\r\n      .data(layers)\r\n      .enter()\r\n      .append('g')\r\n      .attr('class', 'layer')\r\n      .style('fill', (d: any) => metaData.colors[d.key]);\r\n\r\n    const rect = layer.selectAll('rect').data((d: any) => d).enter();\r\n\r\n    rect\r\n      .append('rect')\r\n      .on('click', (d: any) => {\r\n        if (!this.chartData.lineData || this.chartConfiguration.forComparison) {\r\n          if (!metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {\r\n            this.handleClick(d.data.name);\r\n          }\r\n        }\r\n      })\r\n      .attr('y', (d: any) => {\r\n        if (!isNaN(d[0]) && !isNaN(d[1])) {\r\n          const actualHeight = yScale(d[0]) - yScale(d[1]);\r\n          return actualHeight < 3 ? yScale(d[0]) - 3 : yScale(d[1]);\r\n        }\r\n        return 0;\r\n      })\r\n      .attr('x', (d: any, i: number) => {\r\n        if (device.isMobile) {\r\n          return this.SPACING.leftAndRight + i * (barWidth + barPadding);\r\n        }\r\n        if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n          return xScale(d.data.name);\r\n        }\r\n        if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {\r\n          return xScale(d.data.name) + xScale.bandwidth() / 2 - 35;\r\n        }\r\n        return xScale(d.data.name) + xScale.bandwidth() * 0.1;\r\n      })\r\n      .attr('height', (d: any) => {\r\n        if (!isNaN(d[0]) && !isNaN(d[1])) {\r\n          const actualHeight = yScale(d[0]) - yScale(d[1]);\r\n          return actualHeight < 3 ? 3 : actualHeight;\r\n        }\r\n        return 0;\r\n      })\r\n      .attr('width', (d: any) => {\r\n        if (device.isMobile) return barWidth;\r\n        \r\n        if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n          return xScale.bandwidth();\r\n        }\r\n        return this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3\r\n          ? 70\r\n          : xScale.bandwidth() * 0.8;\r\n      })\r\n      .style('cursor', (d: any) => {\r\n        if (!metaData.hasDrillDown) return 'default';\r\n        if (metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {\r\n          return 'default';\r\n        }\r\n        return 'pointer';\r\n      })\r\n      .style('fill', (d: any) => this.getBarFillColor(d, d.key, metaData, targetValue || undefined));\r\n\r\n    // Add tooltips and labels\r\n    if (!this.isCC && !this.chartConfiguration.isMultiChartGridLine) {\r\n      rect.append('svg:title').text((d: any) => d[1] - d[0]);\r\n    }\r\n\r\n    this.addBarLabels(rect, xScale, yScale, metaData, formatFromBackend, formatForHugeNumbers);\r\n  }\r\n\r\n  private addBarLabels(\r\n    rect: any,\r\n    xScale: any,\r\n    yScale: any,\r\n    metaData: ChartMetaData,\r\n    formatFromBackend: any,\r\n    formatForHugeNumbers: any\r\n  ): void {\r\n    if (this.chartConfiguration.showTotalOnTop) {\r\n      rect\r\n        .append('text')\r\n        .attr('x', (d: any) => xScale(d.data.name) + xScale.bandwidth() / 2)\r\n        .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')\r\n        .attr('y', (d: any) => yScale(d[1]) - 3)\r\n        .text((d: any) => {\r\n          if (!isNaN(d[1] - d[0]) && d[1] - d[0] !== 0) {\r\n            const value = d[1] - d[0];\r\n            const formatter = value <= 999 ? formatFromBackend : formatForHugeNumbers;\r\n            return metaData.unit ? metaData.unit + formatter(value) : formatter(value);\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  private renderAxes(\r\n    svg: any,\r\n    svgYAxisLeft: any,\r\n    svgYAxisRight: any,\r\n    xScale: any,\r\n    yScale: any,\r\n    data: any[],\r\n    height: number,\r\n    width: number,\r\n    device: DeviceBreakpoints\r\n  ): void {\r\n    const xAxis = d3\r\n      .axisBottom(xScale)\r\n      .tickSize(0)\r\n      .tickFormat(this.chartConfiguration.xAxisLabelFomatter);\r\n\r\n    const yAxis = d3\r\n      .axisLeft(yScale)\r\n      .ticks(this.chartConfiguration.numberOfYTicks)\r\n      .tickSize(0)\r\n      .tickFormat(this.chartConfiguration.yAxisLabelFomatter);\r\n\r\n    // Render based on chart type\r\n    if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n      this.renderStandardAxes(svg, xAxis, yAxis, data, height, device);\r\n    } else if (this.chartConfiguration.isDrilldownChart) {\r\n      this.renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, xAxis, yAxis, height);\r\n    } else {\r\n      this.renderMultiChartAxes(svg, xAxis, yAxis, height);\r\n    }\r\n\r\n    this.styleAxisDomains(svg, svgYAxisLeft, svgYAxisRight);\r\n  }\r\n\r\n  private renderStandardAxes(\r\n    svg: any,\r\n    xAxis: any,\r\n    yAxis: any,\r\n    data: any[],\r\n    height: number,\r\n    device: DeviceBreakpoints\r\n  ): void {\r\n    if (device.isMobile) {\r\n      this.renderMobileXAxis(svg, data, height, device);\r\n    } else {\r\n      svg\r\n        .append('g')\r\n        .attr('transform', `translate(0,${height})`)\r\n        .attr('class', 'lib-stacked-x-axis-text')\r\n        .call(xAxis)\r\n        .selectAll('text')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('font-size', '12px')\r\n        .attr('text-anchor', 'middle');\r\n    }\r\n\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text')\r\n      .call(yAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n  }\r\n\r\n  private renderMobileXAxis(svg: any, data: any[], height: number, device: DeviceBreakpoints): void {\r\n    const barWidth = 32;\r\n    const barPadding = 12;\r\n    \r\n    svg.selectAll('.custom-x-label').remove();\r\n    data.forEach((d: any, i: number) => {\r\n      const xVal = this.SPACING.leftAndRight + i * (barWidth + barPadding) + barWidth / 2;\r\n      svg\r\n        .append('text')\r\n        .attr('class', 'custom-x-label')\r\n        .attr('x', 0)\r\n        .attr('y', height + 18)\r\n        .attr('text-anchor', 'middle')\r\n        .attr('transform', `translate(${xVal + 20},0)`)\r\n        .style('font-size', '10px')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('writing-mode', 'sideways-lr')\r\n        .text(d.name.substring(0, 3));\r\n    });\r\n  }\r\n\r\n  private renderDrilldownAxes(\r\n    svg: any,\r\n    svgYAxisLeft: any,\r\n    svgYAxisRight: any,\r\n    xAxis: any,\r\n    yAxis: any,\r\n    height: number\r\n  ): void {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', `translate(0,${height})`)\r\n      .attr('class', 'lib-stacked-x-axis-text multichart1')\r\n      .call(xAxis)\r\n      .style('display', 'none');\r\n\r\n    svgYAxisLeft\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .call(yAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n\r\n    svgYAxisRight\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .call(yAxis)\r\n      .style('display', 'none');\r\n  }\r\n\r\n  private renderMultiChartAxes(svg: any, xAxis: any, yAxis: any, height: number): void {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', `translate(0,${height})`)\r\n      .attr('class', 'lib-stacked-x-axis-text multichart')\r\n      .call(xAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n      .call(yAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n  }\r\n\r\n  private styleAxisDomains(svg: any, svgYAxisLeft: any, svgYAxisRight: any): void {\r\n    const axisStyle = {\r\n      stroke: 'var(--chart-axis-color)',\r\n      'stroke-width': '1px'\r\n    };\r\n\r\n    [svg, svgYAxisLeft, svgYAxisRight].forEach(element => {\r\n      element.selectAll('.domain')\r\n        .style('stroke', axisStyle.stroke)\r\n        .style('stroke-width', axisStyle['stroke-width']);\r\n    });\r\n  }\r\n\r\n  private renderLabels(\r\n    svg: any,\r\n    svgYAxisLeft: any,\r\n    metaData: ChartMetaData,\r\n    height: number,\r\n    width: number,\r\n    margin: any\r\n  ): void {\r\n    if (metaData.yLabel) {\r\n      this.renderYAxisLabel(svgYAxisLeft, metaData.yLabel, height, margin);\r\n    }\r\n\r\n    if (metaData.xLabel) {\r\n      this.renderXAxisLabel(svg, metaData.xLabel, height, width, margin);\r\n    }\r\n  }\r\n\r\n  private renderYAxisLabel(\r\n    svgYAxisLeft: any,\r\n    yLabel: string,\r\n    height: number,\r\n    margin: any\r\n  ): void {\r\n    svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();\r\n    \r\n    const { formatted, isAcronym } = this.formatAxisLabel(yLabel);\r\n    const isRia = this.customChartConfiguration?.isRia;\r\n    const yPosition = isRia ? -margin.left / 2 - 30 : -margin.left / 2 - 40;\r\n\r\n    let labelClass = 'lib-axis-group-label font-size-1';\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      labelClass += ' lib-ylabel-drilldowncharts';\r\n    } else if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      labelClass += ' lib-ylabel-weeklyCharts';\r\n    } else {\r\n      labelClass += ' lib-axis-waterfall-label';\r\n    }\r\n\r\n    svgYAxisLeft\r\n      .append('text')\r\n      .attr('class', labelClass)\r\n      .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)\r\n      .attr('transform', 'rotate(-90)')\r\n      .attr('y', yPosition)\r\n      .attr('x', -height / 2)\r\n      .attr('dy', '1em')\r\n      .style('text-anchor', 'middle')\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .text(formatted)\r\n      .style('text-transform', isAcronym ? 'none' : 'capitalize');\r\n  }\r\n\r\n  private renderXAxisLabel(\r\n    svg: any,\r\n    xLabel: string,\r\n    height: number,\r\n    width: number,\r\n    margin: any\r\n  ): void {\r\n    const { formatted, isAcronym } = this.formatAxisLabel(xLabel);\r\n    const isRia = this.customChartConfiguration?.isRia;\r\n    const xPosition = isRia \r\n      ? height + margin.top + margin.bottom \r\n      : height + margin.top + margin.bottom + 10;\r\n\r\n    let labelClass = 'lib-axis-group-label font-size-1';\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      labelClass += ' lib-xlabel-drilldowncharts';\r\n    } else if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      labelClass += ' lib-xlabel-weeklyCharts';\r\n    } else {\r\n      labelClass += ' lib-axis-waterfall-label';\r\n    }\r\n\r\n    svg\r\n      .append('text')\r\n      .attr('class', labelClass)\r\n      .attr('style', this.chartConfiguration.xAxisCustomlabelStyles)\r\n      .attr('transform', `translate(${width / 2},${xPosition})`)\r\n      .style('text-anchor', 'middle')\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .text(formatted)\r\n      .style('text-transform', isAcronym ? 'none' : 'capitalize');\r\n  }\r\n\r\n  private renderTargetLine(\r\n    svg: any,\r\n    svgYAxisRight: any,\r\n    yScale: any,\r\n    width: number,\r\n    targetValue: number,\r\n    metaData: ChartMetaData\r\n  ): void {\r\n    const yZero = yScale(targetValue);\r\n    \r\n    // Draw target line\r\n    svg\r\n      .append('line')\r\n      .attr('x1', 0)\r\n      .attr('x2', width)\r\n      .attr('y1', yZero)\r\n      .attr('y2', yZero)\r\n      .style('stroke-dasharray', '5 5')\r\n      .style('stroke', this.chartData.targetLineData!.color);\r\n\r\n    // Add target label\r\n    const targetLineName = this.chartData.targetLineData?.targetName || 'target';\r\n    const dataType = metaData.dataType || '';\r\n\r\n    svgYAxisRight\r\n      .append('foreignObject')\r\n      .attr('transform', `translate(0,${yZero - 13})`)\r\n      .attr('width', this.SPACING.rightSvgWidth)\r\n      .attr('height', 50)\r\n      .append('xhtml:div')\r\n      .attr('class', 'target-display')\r\n      .style('color', 'var(--chart-text-color)')\r\n      .html(`\r\n        <div>${targetLineName}</div>\r\n        <div>${targetValue}${dataType}</div>\r\n      `);\r\n  }\r\n\r\n  private renderLineChart(\r\n    svg: any,\r\n    lineData: any[],\r\n    xScale: any,\r\n    height: number,\r\n    colors: { [key: string]: string }\r\n  ): void {\r\n    const lineYscale = d3\r\n      .scaleLinear()\r\n      .domain([0, d3.max(lineData, (d: any) => +d.value) || 0])\r\n      .range([height, 0]);\r\n\r\n    const dataGroup = d3\r\n      .nest()\r\n      .key((d: any) => d.category)\r\n      .entries(lineData);\r\n\r\n    const lineGen = d3\r\n      .line()\r\n      .x((d: any) => xScale(d.name) + xScale.bandwidth() / 2)\r\n      .y((d: any) => lineYscale(d.value));\r\n\r\n    dataGroup.forEach((group: any) => {\r\n      // Draw line\r\n      svg\r\n        .append('path')\r\n        .datum(group.values)\r\n        .attr('fill', 'none')\r\n        .attr('stroke', (d: any) => {\r\n          if (d[0] && 'category' in d[0]) {\r\n            return colors[d[0].category];\r\n          }\r\n          return this.chartConfiguration.lineGraphColor;\r\n        })\r\n        .attr('stroke-width', 2.5)\r\n        .attr('d', lineGen(group.values));\r\n\r\n      // Draw dots\r\n      const dot = svg\r\n        .selectAll('myCircles')\r\n        .data(group.values)\r\n        .enter()\r\n        .append('g')\r\n        .on('click', (d: any) => this.handleClick(d));\r\n\r\n      dot\r\n        .append('circle')\r\n        .attr('fill', (d: any) => {\r\n          if ('category' in d) {\r\n            return colors[d.category];\r\n          }\r\n          return this.chartConfiguration.lineGraphColor;\r\n        })\r\n        .attr('stroke', 'none')\r\n        .attr('cx', (d: any) => xScale(d.name) + xScale.bandwidth() / 2)\r\n        .attr('cy', (d: any) => lineYscale(d.value))\r\n        .attr('r', 3)\r\n        .style('cursor', 'pointer');\r\n\r\n      // Add labels if configured\r\n      if (this.chartConfiguration.lineGraphColor) {\r\n        dot\r\n          .append('text')\r\n          .attr('class', 'dots')\r\n          .attr('fill', this.chartConfiguration.lineGraphColor)\r\n          .attr('style', 'font-size: 0.85em; font-weight: bold')\r\n          .attr('x', (d: any) => xScale(d.name) + xScale.bandwidth() / 2)\r\n          .attr('y', (d: any) => lineYscale(d.value))\r\n          .attr('dy', '-1em')\r\n          .text((d: any) => this.chartConfiguration.labelFormatter(d.value));\r\n      }\r\n    });\r\n  }\r\n\r\n  handleClick(data: any): void {\r\n    if (this.chartData?.metaData?.hasDrillDown || data?.toggleFrom) {\r\n      this.clickEvent.emit(data);\r\n    }\r\n  }\r\n\r\n  handleHeaderMenuClick(id: string): void {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n\r\n  handleCompareByFilterSelection(event: any): void {\r\n    this.clickEvent.emit(event);\r\n  }\r\n\r\n  handleZoominZoomoutClick({ isZoomOut, event }: { isZoomOut: boolean; event: any }): void {\r\n    this.isZoomOutSelected(isZoomOut);\r\n  }\r\n}","<meta http-equiv=\"CACHE-CONTROL\" content=\"NO-CACHE\" />\r\n<meta http-equiv=\"EXPIRES\" content=\"Sat, 01 Jun 2004 11:12:01 GMT\" />\r\n<div\r\n  #verticalstackedcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n    style=\"background-color: var(--card-bg);\"\r\n\r\n  (resized)=\"onResized($event)\"\r\n>\r\n  <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n    <lib-chart-header-v2\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (clickEvent)=\"handleClick($event)\"\r\n    ></lib-chart-header-v2>\r\n\r\n    <lib-chart-header-v3\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n      (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n    ></lib-chart-header-v3>\r\n  </div>\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"verticalstackedchartcontainer\"\r\n    #verticalstackedchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}
|
|
1290
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"horizontal-bars-with-scroll-zoom.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.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 { ComponentUniqueId } from '../unique-id';\r\nimport ChartHelper from '../chart-helper';\r\nimport * as d3 from 'd3';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport HeaderConfigHelper from '../header-config';\r\n\r\n@Component({\r\n  selector: 'lib-horizontal-bars-with-scroll-zoom',\r\n  templateUrl: './horizontal-bars-with-scroll-zoom.component.html',\r\n  styleUrls: [\r\n    './horizontal-bars-with-scroll-zoom.component.less',\r\n    '../common-styles.less',\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HorizontalBarsWithScrollZoomComponent\r\n  extends ComponentUniqueId\r\n  implements OnInit {\r\n  @ViewChild('verticalstackedchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('verticalstackedcontainer', { static: true })\r\n  verticalstackedcontainerElt!: 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  chartConfiguration: any = {};\r\n  isHeaderVisible: boolean = true;\r\n  isTopCaptionVisible: boolean = true;\r\n  uniqueId: any = this.getUniqueId();\r\n  isTransparentBackground: boolean = false;\r\n  defaultConfiguration: any = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    svgHeight: 70,\r\n    legendHeight: '10%',\r\n    numberOfYTicks: 5,\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    xAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showLegend: false,\r\n    forComparison: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    yAxisGrid: false,\r\n    isHeaderVisible: undefined,\r\n    isTransparentBackground: undefined,\r\n    isTopCaptionVisible: undefined,\r\n    isMultiChartGridLine: undefined,\r\n    isFullScreen: undefined,\r\n    customYscale: undefined,\r\n    isXaxisLabelHidden: undefined,\r\n    isYaxisLabelHidden: undefined,\r\n    isYaxisHidden: undefined,\r\n    isYaxisDashed: undefined,\r\n    isXaxisColor: undefined,\r\n    textFormatter: undefined,\r\n    showTotalOnTop: undefined,\r\n    backendFormatterHasPriority: undefined,\r\n    showAngledLabels: undefined,\r\n    isNoAlternateXaxisText: undefined,\r\n    isXgridBetweenLabels: undefined,\r\n    showXaxisTop: undefined,\r\n    xAxisGrid: undefined,\r\n    xLabelsOnSameLine: undefined,\r\n    hideXaxisTick: undefined,\r\n    isDrilldownChart: undefined,\r\n    isTargetLine: undefined,\r\n    displayTitleOnTop: undefined,\r\n    isToggleVisible: undefined,\r\n    isTitleHidden: undefined,\r\n  };\r\n  isCC: boolean = false;\r\n  isZoomedOut: boolean = true;\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n  isZoomOutSelected(isZoomOut) {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.ngOnChanges();\r\n  }\r\n  ngOnChanges() {\r\n    let self = this;\r\n    d3.select('#' + self.uniqueId).remove();\r\n    this.initializeStackedChart();\r\n  }\r\n  onResized(event: ResizedEvent) {\r\n    let self = this;\r\n    setTimeout(\r\n      function () {\r\n        d3.select('#' + self.uniqueId).remove();\r\n        self.initializeStackedChart();\r\n      }.bind(self),\r\n      10\r\n    );\r\n  }\r\n  ngOnInit() { }\r\n\r\n  initializeStackedChart() {\r\n    var self = this;\r\n    let data: any = [];\r\n    let metaData: any = null;\r\n    let keyList = null;\r\n    let lineData = null;\r\n    let colors: any = null;\r\n    var alternate_text = false;\r\n    var alternate_label = false;\r\n    var short_tick_length = 4;\r\n    var long_tick_length = 16;\r\n    var short_tick_length_bg = 5;\r\n    var long_tick_length_bg = 30;\r\n    var formatFromBackend;\r\n    var formatForHugeNumbers;\r\n    var tempObjectHolder = {};\r\n    var rightSvgWidth = 60;\r\n    var leftAndRightSpaces = 50;\r\n\r\n       let isria = this.customChartConfiguration.isRia\r\n\r\n    // Responsive breakpoints\r\n    const isMobile = window.innerWidth < 576;\r\n    const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;\r\n    const isDesktop = window.innerWidth >= 992;\r\n\r\n    // Adjust margins and font sizes based on device\r\n    if (isMobile) {\r\n      this.chartConfiguration.margin = { top: 20, right: 10, bottom: 40, left: 30 };\r\n      this.chartConfiguration.numberOfYTicks = 4;\r\n      this.chartConfiguration.svgHeight = 60;\r\n    } else if (isTablet) {\r\n      this.chartConfiguration.margin = { top: 25, right: 20, bottom: 45, left: 40 };\r\n      this.chartConfiguration.numberOfYTicks = 6;\r\n      this.chartConfiguration.svgHeight = 70;\r\n    } else {\r\n      this.chartConfiguration.margin = { top: 30, right: 30, bottom: 50, left: 60 };\r\n      this.chartConfiguration.numberOfYTicks = 7;\r\n      this.chartConfiguration.svgHeight = 80;\r\n    }\r\n\r\n    for (var i in this.defaultConfiguration) {\r\n      this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(\r\n        i,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n    data = this.chartData.data;\r\n    metaData = this.chartData.metaData;\r\n    if (metaData.unit == undefined) metaData.unit = '';\r\n    if (metaData.isCC) {\r\n      this.isCC = metaData.isCC;\r\n    }\r\n    if (metaData.barWithoutClick && metaData.barWithoutClick.length) {\r\n      metaData.barWithoutClick = metaData.barWithoutClick.map((ele) =>\r\n        ele.toLowerCase()\r\n      );\r\n    } else {\r\n      metaData.barWithoutClick = [];\r\n    }\r\n    lineData = this.chartData.lineData;\r\n    colors = metaData.colors;\r\n    keyList = metaData.keyList;\r\n\r\n    var chartContainer = d3.select(this.containerElt.nativeElement);\r\n    var verticalstackedcontainer = d3.select(\r\n      this.verticalstackedcontainerElt.nativeElement\r\n    );\r\n\r\n    let parsedNum = parseFloat(this.chartData?.targetLineData?.target);\r\n    if (!isNaN(parsedNum)) {\r\n      if (Number.isInteger(parsedNum)) {\r\n        parsedNum = parseInt(this.chartData.targetLineData.target);\r\n      } else {\r\n        parsedNum = parseFloat(this.chartData.targetLineData.target);\r\n      }\r\n    }\r\n    var margin = this.chartConfiguration.margin;\r\n\r\n    // Responsive width and height\r\n    var containerWidth = chartContainer.node().getBoundingClientRect().width;\r\n    var containerHeight = verticalstackedcontainer.node().getBoundingClientRect().height;\r\n    var width = containerWidth - margin.left - margin.right;\r\n    var height = containerHeight * (self.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;\r\n\r\n    // Adjust width for large datasets and zoom\r\n    if (this.chartData.data.length > 30 && this.isZoomedOut) {\r\n      width = width > this.chartData.data.length * (isMobile ? 15 : 25)\r\n        ? width\r\n        : this.chartData.data.length * (isMobile ? 15 : 25);\r\n    }\r\n    if (this.chartData.data.length > 8 && !this.isZoomedOut) {\r\n      width = this.chartData.data.length * (isMobile ? 60 : 130);\r\n    }\r\n\r\n    // Fullscreen and drilldown adjustments\r\n    if (this.chartConfiguration.isFullScreen != undefined && this.chartConfiguration.isFullScreen) {\r\n      height = this.chartConfiguration.svgHeight != 80\r\n        ? this.chartConfiguration.svgHeight\r\n        : containerHeight;\r\n    }\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      height = containerHeight - margin.top - margin.bottom - (isMobile ? 60 : 130);\r\n    }\r\n\r\n    // ...existing code...\r\n    /**\r\n     * for hiding header\r\n     * used by weekly charts\r\n     */\r\n    if (this.chartConfiguration.isHeaderVisible != undefined) {\r\n      this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n    }\r\n    /**\r\n     * for hiding legends\r\n     * used by weekly charts\r\n     */\r\n    if (this.chartConfiguration.isTopCaptionVisible != undefined) {\r\n      //UPDATENAME\r\n      this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;\r\n    }\r\n    /**\r\n     * for removing background color so that it can take parents color\r\n     *\r\n     */\r\n    if (this.chartConfiguration.isTransparentBackground != undefined) {\r\n      this.isTransparentBackground =\r\n        this.chartConfiguration.isTransparentBackground;\r\n    }\r\n    /**\r\n     * format data values based on configuration received\r\n     */\r\n    if (this.chartConfiguration.textFormatter != undefined) {\r\n      formatFromBackend = ChartHelper.dataValueFormatter(\r\n        this.chartConfiguration.textFormatter\r\n      );\r\n      formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n    }\r\n    var outerContainer = chartContainer\r\n      .append('div')\r\n      .attr('id', self.uniqueId)\r\n      .attr('class', 'outer-container')\r\n      .style('width', '100%')\r\n      .style('height', height)\r\n\r\n      .style('overflow-x', 'hidden')\r\n      .style('padding-left', `${margin.left}px`)\r\n      .style('margin-left', '10px')\r\n      .style('padding-right', `${rightSvgWidth}px`);\r\n\r\n    var svgYAxisLeft = outerContainer\r\n      .append('svg')\r\n      .attr('width', '80')\r\n      .attr('height', height + margin.top + margin.bottom)\r\n      .style('position', 'absolute')\r\n      .style('left', '0')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', 'translate(' + (margin.left + 10) + ',' + margin.top + ')');\r\n\r\n    var svgYAxisRight = outerContainer\r\n      .append('svg')\r\n      .attr('width', rightSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom)\r\n      .style('position', 'absolute')\r\n      .style('right', '2px')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');\r\n\r\n    var innerContainer = outerContainer\r\n      .append('div')\r\n      .attr('class', 'inner-container')\r\n      .style('width', '100%')\r\n      .style('overflow-x', 'auto');\r\n\r\n\r\n    // Calculate bar width and padding for mobile to avoid overlap and add space between bars\r\n    let barWidth;\r\n    let barPadding = 12; // px, space between bars on mobile\r\n    let requiredSvgWidth;\r\n    if (isMobile) {\r\n      // Use a minimum width per bar and add padding between bars\r\n      const minBarWidth = 32; // px, can adjust as needed\r\n      barWidth = minBarWidth;\r\n      requiredSvgWidth = Math.max(\r\n        width - rightSvgWidth,\r\n        (barWidth + barPadding) * data.length + leftAndRightSpaces * 2 + rightSvgWidth - barPadding // no padding after last bar\r\n      );\r\n      innerContainer.style('overflow-x', 'auto');\r\n    } else {\r\n      barWidth = Math.max(40, (width - rightSvgWidth - leftAndRightSpaces * 2) / data.length);\r\n      barPadding = 0;\r\n      requiredSvgWidth = width - rightSvgWidth;\r\n    }\r\n\r\n    var svg = innerContainer\r\n      .append('svg')\r\n      .attr('width', requiredSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom + 30)\r\n      .append('g')\r\n      .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');\r\n\r\n    let stackKey = keyList;\r\n    var stack: any = d3\r\n      .stack()\r\n      .keys(stackKey)\r\n      /*.order(d3.stackOrder)*/\r\n      .offset(d3.stackOffsetNone);\r\n    var layers: any = stack(data);\r\n    data.sort(function (a, b) {\r\n      return b.total - a.total;\r\n    });\r\n    let lineYscale;\r\n    if (lineData != null) {\r\n      lineYscale = d3\r\n        .scaleLinear()\r\n        .domain([\r\n          0,\r\n          d3.max(lineData, function (d) {\r\n            return +d.value;\r\n          }),\r\n        ])\r\n        .range([height, 0]);\r\n    }\r\n\r\n    // Calculate bar width for mobile to avoid overlap\r\n    // ...barWidth is now calculated above, remove duplicate...\r\n\r\n    var xScale = d3\r\n      .scaleBand()\r\n      .rangeRound([\r\n        leftAndRightSpaces,\r\n        width - rightSvgWidth - leftAndRightSpaces\r\n      ])\r\n      .domain(\r\n        data.map(function (d) {\r\n          return d.name;\r\n        }).reverse()\r\n      )\r\n      .padding(isMobile ? 0.2 : 0.5);\r\n\r\n    var xScaleFromOrigin = d3\r\n      .scaleBand()\r\n      .rangeRound([width - rightSvgWidth, 0])\r\n      .domain(\r\n        data.map(function (d) {\r\n          return d.name;\r\n        }).reverse()\r\n      );\r\n    // ...existing code...\r\n    /**\r\n     * draw second x axis on top\r\n     */\r\n    if (self.chartConfiguration.showXaxisTop) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')\r\n        .attr('style', self.chartConfiguration.xAxisCustomTextStyles)\r\n        .call(d3.axisBottom(xScale).tickSize(0));\r\n      svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');\r\n    }\r\n    /**\r\n     * draw second x axis on top\r\n     */\r\n    // if (self.chartConfiguration.showXaxisAtTarget) {\r\n    //   svg\r\n    //     .append('g')\r\n    //     .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')\r\n    //     .attr('style', self.chartConfiguration.xAxisCustomTextStyles)\r\n    //     .call(d3.axisBottom(xScale).tickSize(0));\r\n    //   svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');\r\n    // }\r\nif (this.chartConfiguration.xAxisGrid) {\r\n  for (var j = 0; j < this.chartConfiguration.xAxisGrid.length; j++) {\r\n    svg\r\n      .append('g')\r\n      .attr('class', `x${j + 2} axis${j + 2}`)\r\n      .style('color', 'var(--chart-grid-color)') // Use CSS variable instead of hardcoded\r\n      .attr(\r\n        'transform',\r\n        'translate(0,' + height * this.chartConfiguration.xAxisGrid[j] + ')'\r\n      )\r\n      .call(d3.axisBottom(xScale).tickSize(0).ticks(5).tickFormat(''))\r\n      .style('fill', 'var(--chart-text-color)');\r\n  }\r\n}\r\n\r\n    let yScale = d3.scaleLinear().rangeRound([height, 0]);\r\n    /**\r\n     * update max vakues so that the vakue wont exceed the max limit\r\n     * used by weekly charts\r\n     */\r\n    var maxValue = d3.max(layers, (d) => d3.max(d, (d) => d[1]));\r\n    if (maxValue == 0) {\r\n      if (this.chartData.targetLineData) {\r\n        maxValue = this.chartData.targetLineData.target + 20;\r\n      } else {\r\n        maxValue = 100;\r\n      }\r\n    }\r\n    if (this.chartConfiguration.customYscale) {\r\n      maxValue = maxValue * this.chartConfiguration.customYscale;\r\n    }\r\n    if (\r\n      this.chartData.targetLineData &&\r\n      maxValue < this.chartData.targetLineData.target\r\n    ) {\r\n      maxValue =\r\n        maxValue < 10 && this.chartData.targetLineData.target < 10\r\n          ? this.chartData.targetLineData.target + 3\r\n          : this.chartData.targetLineData.target + 20;\r\n    }\r\n    yScale.domain([0, maxValue]).nice();\r\n\r\n    let xAxis = d3\r\n      .axisBottom(xScale)\r\n      .tickSize(0)\r\n      .tickFormat(self.chartConfiguration.xAxisLabelFomatter);\r\n\r\n    let yAxis = d3\r\n      .axisLeft(yScale)\r\n      .ticks(self.chartConfiguration.numberOfYTicks)\r\n      .tickSize(0)\r\n      .tickFormat(self.chartConfiguration.yAxisLabelFomatter);\r\n\r\n    let yLineAxis;\r\n    if (lineYscale != null) {\r\n      yLineAxis = d3\r\n        .axisRight(lineYscale)\r\n        .ticks(self.chartConfiguration.numberOfYTicks)\r\n        .tickSize(0)\r\n        .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);\r\n    }\r\n    /**\r\n     * between x-axis label used by weekly charts\r\n     * isXgridBetweenLabels will be undefined for dashboard charts\r\n     */\r\n    if (self.chartConfiguration.isXgridBetweenLabels) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'grid')\r\n        .attr(\r\n          'transform',\r\n          'translate(' + xScale.bandwidth() / 2 + ',' + height + ')'\r\n        )\r\n        .call(d3.axisBottom(xScale).tickSize(-height).tickFormat(''))\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('color', '#999999')\r\n        // .style(\"opacity\", \"0.5\")\r\n        .call((g) => g.select('.domain').remove());\r\n    }\r\n    /**\r\n     * used to draw y-axis grid\r\n     */\r\nif (self.chartConfiguration.yAxisGrid) {\r\n  svg\r\n    .append('g')\r\n    .attr('class', 'grid')\r\n    .call(\r\n      d3\r\n        .axisLeft(yScale)\r\n        .ticks(self.chartConfiguration.numberOfYTicks)\r\n        .tickSize(-width)\r\n        .tickFormat('')\r\n    )\r\n    // Remove hardcoded colors and use CSS variables\r\n    .style('color', 'var(--chart-grid-color)')\r\n    .style('opacity', '1')\r\n    // .call((g) => g.select('.domain').remove());\r\n}\r\n\r\n\r\n    var layer = svg\r\n      .selectAll('.layer')\r\n      .data(layers)\r\n      .enter()\r\n      .append('g')\r\n      .attr('class', 'layer')\r\n      .style('fill', function (d, i) {\r\n        return metaData.colors[d.key];\r\n      });\r\n\r\n    var rect = layer\r\n      .selectAll('rect')\r\n      .data(function (d) {\r\n        return d;\r\n      })\r\n      .enter();\r\n\r\n    rect\r\n      .append('rect')\r\n      .on('click', function (d) {\r\n        if (!lineData || self.chartConfiguration.forComparison) {\r\n          if (\r\n            !metaData.barWithoutClick ||\r\n            !metaData.barWithoutClick.length ||\r\n            !metaData.barWithoutClick.includes(d.data.name.toLowerCase())\r\n          )\r\n            self.handleClick(d.data.name);\r\n        }\r\n      })\r\n      .attr('y', function (d) {\r\n        if (!isNaN(d[0]) && !isNaN(d[1])) {\r\n          const actualHeight = yScale(d[0]) - yScale(d[1]);\r\n          return actualHeight < 3 ? yScale(d[0]) - 3 : yScale(d[1]);\r\n        }\r\n        return 0;\r\n      })\r\n      .attr('x', function (d, i) {\r\n        if (isMobile) {\r\n          // On mobile, position bars with padding\r\n          return leftAndRightSpaces + i * (barWidth + barPadding);\r\n        }\r\n        if (self.chartConfiguration.isMultiChartGridLine == undefined) {\r\n          return xScale(d.data.name);\r\n        } else {\r\n          if (\r\n            self.chartConfiguration.isDrilldownChart &&\r\n            self.chartData.data.length <= 3\r\n          ) {\r\n            return xScale(d.data.name) + xScale.bandwidth() / 2 - 35;\r\n          }\r\n          return xScale(d.data.name) + xScale.bandwidth() * 0.1;\r\n        }\r\n      })\r\n      .attr('height', function (d) {\r\n        if (!isNaN(d[0]) && !isNaN(d[1])) {\r\n          const actualHeight = yScale(d[0]) - yScale(d[1]);\r\n          return actualHeight < 3 ? 3 : actualHeight;\r\n        }\r\n        return 0;\r\n      })\r\n      .attr('width', function (d) {\r\n        // Use calculated barWidth for mobile, otherwise scale\r\n        if (isMobile) {\r\n          return barWidth;\r\n        }\r\n        return self.chartConfiguration.isMultiChartGridLine == undefined\r\n          ? xScale.bandwidth()\r\n          : self.chartConfiguration.isDrilldownChart &&\r\n            self.chartData.data.length <= 3\r\n            ? 70\r\n            : xScale.bandwidth() * 0.8;\r\n      })\r\n      // .style('cursor', 'pointer');\r\n      .style('cursor', function (d) {\r\n        if (metaData.hasDrillDown) {\r\n          if (\r\n            metaData.barWithoutClick.length > 0 &&\r\n            metaData.barWithoutClick.includes(d.data.name.toLowerCase())\r\n          ) {\r\n            return 'default';\r\n          }\r\n          return 'pointer';\r\n        } else return 'default';\r\n      })\r\n      .style('fill', function (d) {\r\n        if (\r\n          !isNaN(d[0]) &&\r\n          !isNaN(d[1]) &&\r\n          self.chartData.targetLineData &&\r\n          parseFloat(d[1]) - parseFloat(d[0]) >=\r\n          parseFloat(self.chartData.targetLineData.target)\r\n        )\r\n          return self.chartData?.targetLineData?.barAboveTargetColor;\r\n\r\n        return metaData.colors[d.key];\r\n      });\r\n    /**\r\n     * do not show valus on hover as its alreay dislayed\r\n     */\r\n    if (!this.isCC && !self.chartConfiguration.isMultiChartGridLine) {\r\n      rect\r\n        .append('svg:title') // TITLE APPENDED HERE\r\n        .text(function (d) {\r\n          return d[1] - d[0];\r\n        });\r\n    }\r\n    if (this.isCC) {\r\n      rect\r\n        .append('text')\r\n        .attr('x', function (d) {\r\n          return xScale(d.data.name);\r\n        })\r\n        .attr('text-anchor', function (d) {\r\n          if (!d[0]) {\r\n            return 'end';\r\n          } else {\r\n            return 'start';\r\n          }\r\n        })\r\n        .attr('class', 'verticalbar__text')\r\n        .attr('y', function (d) {\r\n          if (!d[0]) {\r\n            return yScale(d[1]);\r\n          } else {\r\n            return yScale(d[1]) - 7;\r\n          }\r\n        })\r\n        // .attr(\"y\", function (d) { return yScale(d[0]) - yScale(d[1]); })\r\n        .attr('dy', function (d) {\r\n          return d.class;\r\n        })\r\n        .text(function (d) {\r\n          if (!d[0]) {\r\n            if (!isNaN(d[1] - d[0])) {\r\n              return Math.round((d[1] - d[0]) * 100) / 100;\r\n            } else return;\r\n          } else {\r\n            if (!isNaN(d[1])) {\r\n              return Math.round(d[1] * 100) / 100;\r\n            } else return;\r\n          }\r\n        });\r\n    }\r\n\r\n    /**\r\n       svg\r\n        .append('foreignObject')\r\n        .attr('transform', 'translate(' + 0 + ',' + (yZero - 25) + ')')\r\n        .attr('width', width)\r\n        .attr('height', 30)\r\n        .append('xhtml:div')\r\n        .attr('class', 'target-display')\r\n        .style('color', this.chartData.targetLineData.color)\r\n */\r\n\r\n    /**\r\n     * on hover, display title on top\r\n     */\r\n    function handleMouseOver(d, i) {\r\n      if (!self.chartConfiguration.displayTitleOnTop) {\r\n        return;\r\n      }\r\n      svg\r\n        .selectAll('rect')\r\n        .filter(function (data) {\r\n          return data == d;\r\n        })\r\n        .style('fill', function (d) {\r\n          if (\r\n            !isNaN(d[0]) &&\r\n            !isNaN(d[1]) &&\r\n            self.chartData.targetLineData &&\r\n            parseFloat(d[1]) - parseFloat(d[0]) >=\r\n            parseFloat(self.chartData.targetLineData.target)\r\n          )\r\n            return self.chartData.targetLineData.barAboveTargetHoverColor\r\n              ? self.chartData.targetLineData.barAboveTargetHoverColor\r\n              : self.chartData?.targetLineData?.barAboveTargetColor\r\n                ? self.chartData?.targetLineData?.barAboveTargetColor\r\n                : '';\r\n\r\n          return metaData.hoverColor ? metaData.hoverColor : '';\r\n        });\r\n\r\n      svg\r\n        .append('foreignObject')\r\n        .attr('x', function () {\r\n          if (xScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n            return (\r\n              xScale(d.data.name) -\r\n              leftAndRightSpaces +\r\n              (xScale.bandwidth() + leftAndRightSpaces * 2 - 180) / 2\r\n            );\r\n          }\r\n          return xScale(d.data.name) - leftAndRightSpaces;\r\n        })\r\n        .attr('class', 'lib-verticalstack-title-ontop')\r\n        .attr('y', function () {\r\n          // Increase the gap between the bar and the tooltip (was -1 - 40)\r\n          return yScale(d[1]) - 1 - 50; // 10px more gap\r\n        })\r\n        .attr('dy', function () {\r\n          return d.class;\r\n        })\r\n        .attr('width', function () {\r\n            if (d.data.name && /week/i.test(d.data.name) && /\\d{4}-\\d{2}-\\d{2}/.test(d.data.name)) {\r\n                 return '250px'; // increase for week + date\r\n         }\r\n\r\n          if (xScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n            return '180px';\r\n          }\r\n          return xScale.bandwidth() + leftAndRightSpaces * 2;\r\n        })\r\n        .attr('height', 40)\r\n        .append('xhtml:div')\r\n        .attr('class', 'title')\r\n        .style('z-index', 99)\r\n        .html(function () {\r\n          // Tooltip content without any arrow mark\r\n          if (!isNaN(d[1] - d[0])) {\r\n            if (d[1] - d[0] === 0) {\r\n              return '<span class=\"title-top-text\">0</span>';\r\n            }\r\n            var dataType = metaData.dataType ? metaData.dataType : '';\r\n            var desiredText = '';\r\n            // Always show the full x-axis label (category name) in the tooltip\r\n            desiredText =\r\n              '<span class=\"title-bar-name\">' +\r\n              (d.data.name ? d.data.name : '') +\r\n              '</span>';\r\n\r\n            desiredText += metaData.unit\r\n              ? '<span class=\"title-top-text\">' +\r\n              metaData.unit +\r\n              (d[1] - d[0]) + ' ' +\r\n              dataType +\r\n              '</span>'\r\n              : '<span class=\"title-top-text\">' +\r\n              (d[1] - d[0]) + ' ' +\r\n              dataType +\r\n              '</span>';\r\n\r\n            // No arrow mark or arrow HTML/CSS in tooltip\r\n            return desiredText;\r\n          } else return;\r\n        });\r\n\r\n    }\r\n    function handleMouseOut(d, i) {\r\n      if (!self.chartConfiguration.displayTitleOnTop) {\r\n        return;\r\n      }\r\n      // svg.selectAll('rect').style('fill', metaData.colors[d.key]);\r\n      svg.selectAll('rect').style('fill', function (d) {\r\n        if (\r\n          !isNaN(d[0]) &&\r\n          !isNaN(d[1]) &&\r\n          self.chartData.targetLineData &&\r\n          parseFloat(d[1]) - parseFloat(d[0]) >=\r\n          parseFloat(self.chartData.targetLineData.target)\r\n        )\r\n          return self.chartData?.targetLineData?.barAboveTargetColor;\r\n\r\n        return metaData.colors[d.key];\r\n      });\r\n      svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n    }\r\n\r\n    /**\r\n     * used to show value on top of the bars\r\n     * need to be used by bar charts only(one bar should contain one value)\r\n     * used by weekly charts\r\n     */\r\n    if (this.chartConfiguration.showTotalOnTop != undefined) {\r\n      rect\r\n        .append('text')\r\n        .attr('x', function (d) {\r\n          return xScale(d.data.name) + xScale.bandwidth() / 2;\r\n        })\r\n        .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')\r\n        .attr('y', function (d) {\r\n          return yScale(d[1]) - 3;\r\n        })\r\n        .attr('dy', function (d) {\r\n          return d.class;\r\n        })\r\n        .text(function (d) {\r\n          if (!isNaN(d[1] - d[0])) {\r\n            if (d[1] - d[0] == 0) {\r\n              return;\r\n            }\r\n            if (d[1] - d[0] <= 999)\r\n              return metaData.unit\r\n                ? metaData.unit + formatFromBackend(d[1] - d[0])\r\n                : formatFromBackend(d[1] - d[0]);\r\n            else\r\n              return metaData.unit\r\n                ? metaData.unit + formatForHugeNumbers(d[1] - d[0])\r\n                : formatForHugeNumbers(d[1] - d[0]);\r\n          } else return;\r\n        });\r\n    }\r\n    /**\r\n     * used to show angled values on top of the bars\r\n     * used by weekly charts\r\n     */\r\n    if (this.chartConfiguration.showAngledLabels != undefined) {\r\n      rect\r\n        .append('text')\r\n        .attr('x', 0)\r\n        .attr('fill', function (d, i) {\r\n          return metaData.colors[d.key];\r\n        })\r\n        .attr('class', 'lib-data-labels-angled-weeklycharts')\r\n        .attr('y', 0)\r\n        .attr('dy', function (d) {\r\n          return d.class;\r\n        })\r\n        .text(function (d) {\r\n          if (!isNaN(d[1] - d[0]) && d[1] - d[0] > 0) {\r\n            if (d[1] - d[0] <= 999)\r\n              return metaData.unit\r\n                ? metaData.unit + formatFromBackend(d[1] - d[0])\r\n                : formatFromBackend(d[1] - d[0]);\r\n            else return metaData.unit + formatForHugeNumbers(d[1] - d[0]);\r\n          } else return;\r\n        })\r\n        .attr('transform', function (d) {\r\n          if (!isNaN(d[1] - d[0]) && d[1] - d[0] > 0) {\r\n            var total = 0;\r\n            var incrementer: number = 1;\r\n            metaData.keyList.forEach((key) => {\r\n              if (d.data[key]) total = total + d.data[key];\r\n              else incrementer = 2;\r\n            });\r\n            if (tempObjectHolder[d.data.name] == undefined) {\r\n              tempObjectHolder[d.data.name] = 1;\r\n            } else {\r\n              tempObjectHolder[d.data.name] =\r\n                tempObjectHolder[d.data.name] + incrementer;\r\n            }\r\n            switch (tempObjectHolder[d.data.name]) {\r\n              case 1:\r\n                return (\r\n                  'translate(' +\r\n                  (xScale(d.data.name) + xScale.bandwidth() / 3) +\r\n                  ',' +\r\n                  (yScale(total) - 3) +\r\n                  ') rotate(270)'\r\n                );\r\n              case 2:\r\n                return (\r\n                  'translate(' +\r\n                  (xScale(d.data.name) + xScale.bandwidth() / 2 + 2) +\r\n                  ',' +\r\n                  (yScale(total) - 3) +\r\n                  ') rotate(270)'\r\n                );\r\n              default:\r\n                return (\r\n                  'translate(' +\r\n                  (xScale(d.data.name) + (xScale.bandwidth() * 3) / 4) +\r\n                  ',' +\r\n                  (yScale(total) - 3) +\r\n                  ') rotate(270)'\r\n                );\r\n            }\r\n          }\r\n          return 'rotate(0)';\r\n        });\r\n    }\r\nif (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n  if (isMobile) {\r\n    // Custom x-axis label rendering for mobile: evenly distribute under each bar\r\n    svg.selectAll('.custom-x-label').remove();\r\n    data.forEach(function (d, i) {\r\n      const xVal = leftAndRightSpaces + i * (barWidth + barPadding) + barWidth / 2;\r\n      svg.append('text')\r\n        .attr('class', 'custom-x-label')\r\n        .attr('x', 0)\r\n        .attr('y', height + 18)\r\n        .attr('text-anchor', 'middle')\r\n        .attr('transform', 'translate(' + (xVal + 20) + ',0)') // current value + 20\r\n        .style('font-size', '10px')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('writing-mode', 'sideways-lr') // writing mode for mobile\r\n        .text(d.name.substring(0, 3));\r\n    });\r\n  } else {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', 'translate(0,' + height + ')')\r\n      .attr('class', 'lib-stacked-x-axis-text')\r\n      .call(xAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .style('font-size', '12px')\r\n      .attr('text-anchor', 'middle')\r\n      .attr('dx', '0')\r\n      .attr('dy', '0.71em')\r\n      .attr('transform', null)\r\n      .text(function (d) {\r\n        return d;\r\n      });\r\n  }\r\n\r\n  svg\r\n    .append('g')\r\n    .attr('class', 'lib-stacked-y-axis-text')\r\n    .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n    .attr('transform', 'translate(0,0)')\r\n    .call(yAxis)\r\n    .selectAll('text')\r\n  .style('fill', 'var(--chart-text-color)');\r\n}else if (this.chartConfiguration.isDrilldownChart) {\r\n  svg\r\n    .append('g')\r\n    .attr('transform', 'translate(0,' + height + ')')\r\n    .attr('class', 'lib-stacked-x-axis-text multichart1')\r\n    .call(xAxis)\r\n    .style('display', 'none')\r\n\r\n  svgYAxisLeft\r\n    .append('g')\r\n    .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n    .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n    .attr('transform', 'translate(0,0)')\r\n    .call(yAxis)\r\n      .selectAll('text')\r\n  .style('fill', 'var(--chart-text-color)');\r\n    \r\n  svgYAxisRight\r\n    .append('g')\r\n    .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n    .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n    .attr('transform', 'translate(0,0)')\r\n    .call(yAxis)\r\n    .style('display', 'none')\r\n}\r\nelse {\r\n  svg\r\n    .append('g')\r\n    .attr('transform', 'translate(0,' + height + ')')\r\n    .attr('class', 'lib-stacked-x-axis-text multichart')\r\n    .attr('transform', 'translate(0,' + height + ')')\r\n    .call(xAxis)\r\n    .selectAll('text')\r\n  .style('fill', 'var(--chart-text-color)');\r\n\r\n  svg\r\n    .append('g')\r\n    .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n    .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n    .attr('transform', 'translate(0,0)')\r\n    .call(yAxis)\r\n      .selectAll('text')\r\n  .style('fill', 'var(--chart-text-color)');\r\n}\r\n    /**\r\n     * for existing charts, place xaxis labels nearer to xaxis\r\n     * used by existing charts\r\n     */\r\n    if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n      d3.selectAll('g.lib-stacked-x-axis-text g.tick text').attr(\r\n        'y',\r\n        function () {\r\n          if (alternate_text) {\r\n            alternate_text = false;\r\n            return long_tick_length + 1;\r\n          } else {\r\n            alternate_text = true;\r\n            return short_tick_length + 1;\r\n          }\r\n        }\r\n      );\r\n    } else {\r\n      d3.selectAll('.multichart > g > text').attr(\r\n        'class',\r\n        'lib-display-hidden'\r\n      );\r\n    }\r\n    /**\r\n     * based of the flag, hide or show xaxis texts\r\n     * used by weekly charts\r\n     */\r\n    if (\r\n      this.chartConfiguration.isXaxisLabelHidden != undefined &&\r\n      this.chartConfiguration.isXaxisLabelHidden\r\n    ) {\r\n      d3.selectAll('.multichart > g > text').attr(\r\n        'class',\r\n        'lib-display-hidden'\r\n      );\r\n    } else if (this.chartConfiguration.isXaxisLabelHidden != undefined) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'x1 axis1')\r\n        .attr('transform', 'translate(0,' + height + ')')\r\n        .style('color', '#000')\r\n\r\n        .call(d3.axisBottom(xScale).tickSize(0))\r\n        .call((g) => g.select('.domain').attr('fill', 'none'));\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'x2 axis2')\r\n        .attr('transform', 'translate(0,' + height + ')')\r\n        .style('color', '#000')\r\n\r\n        .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))\r\n        .call((g) => g.select('.domain').attr('fill', 'none'));\r\n      svg.selectAll('.axis2 > g > text').attr('class', 'lib-display-hidden');\r\n      // svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');\r\n      svg.selectAll('.x1.axis1 .tick line').attr('y2', function () {\r\n        if (self.chartConfiguration.hideXaxisTick) {\r\n          return 0;\r\n        }\r\n        /**\r\n         * isNoAlternateXaxisText is used to prevent x-axis label to be displayed in alternate fashion\r\n         * for future use\r\n         */\r\n        if (\r\n          alternate_text &&\r\n          self.chartConfiguration.isNoAlternateXaxisText == undefined\r\n        ) {\r\n          alternate_text = false;\r\n          return long_tick_length_bg - 7;\r\n        } else {\r\n          alternate_text = true;\r\n          return short_tick_length_bg - 4;\r\n        }\r\n      });\r\n      /**\r\n       * reset the flag so that texts also follow the pattern of ticks\r\n       * used by weekly charts\r\n       */\r\n      alternate_text = false;\r\n      svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        // .attr('class', 'lib-xaxis-labels-texts-weeklycharts')\r\n        .attr('class', function () {\r\n          if (self.chartConfiguration.isDrilldownChart) {\r\n            if (data && data.length > 8) {\r\n              return 'lib-xaxis-labels-texts-drilldown-alt';\r\n            }\r\n            return 'lib-xaxis-labels-texts-drilldown';\r\n          } else return 'lib-xaxis-labels-texts-weeklycharts';\r\n        })\r\n        .attr('y', function () {\r\n          if (alternate_text) {\r\n            alternate_text = false;\r\n            return long_tick_length_bg;\r\n          } else {\r\n            alternate_text = true;\r\n            return short_tick_length_bg;\r\n          }\r\n        });\r\n    }\r\n    if (self.chartConfiguration.xLabelsOnSameLine) {\r\n      svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n        .attr('y', short_tick_length_bg)\r\n        .text(function (d, i) {\r\n          if (isMobile) {\r\n            // If label has more than one word, show only first 3 letters of first word\r\n            var firstWord = d.split(' ')[0];\r\n            return firstWord.substring(0, 3);\r\n          }\r\n          if (d.trim().indexOf(' ') > -1) {\r\n            return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n          }\r\n          return d.toLowerCase();\r\n        })\r\n        .attr('transform', function(this: SVGTextElement, d, i) {\r\n          if (isMobile) {\r\n            var totalBars = 0;\r\n            if (this.parentNode && this.parentNode.parentNode) {\r\n              totalBars = d3.select(this.parentNode.parentNode).selectAll('g.tick').size();\r\n            }\r\n            if (totalBars === 2) {\r\n              return 'translate(0,0)';\r\n            } else {\r\n              return 'translate(' + (i * 30) + ',0)';\r\n            }\r\n          }\r\n          return null;\r\n        });\r\n      svg\r\n        .selectAll('g.x1.axis1 g.tick')\r\n        .append('text')\r\n        .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n        .attr('y', long_tick_length_bg)\r\n        .attr('fill', 'currentColor')\r\n        .text(function (d) {\r\n          // For mobile, do not print the second word at all\r\n          if (isMobile) {\r\n            return '';\r\n          }\r\n          if (d.trim().indexOf(' ') > -1) {\r\n            return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();\r\n          }\r\n          return '';\r\n        })\r\n        .attr('transform', function(d, i) {\r\n          if (isMobile && i === 0) {\r\n            return 'translate(20,0)';\r\n          }\r\n          return null;\r\n        });\r\n    }\r\n    /**\r\n     * hide yaxis values\r\n     * used by weekly charts\r\n     */\r\n    if (\r\n      this.chartConfiguration.isYaxisLabelHidden != undefined &&\r\n      this.chartConfiguration.isYaxisLabelHidden\r\n    ) {\r\n      svg\r\n        .selectAll('.yaxis-dashed > g > text')\r\n        .attr('class', 'lib-display-hidden');\r\n    }\r\n    /** hide y axis labels\r\n     * config is there for future use\r\n     */\r\n    if (\r\n      this.chartConfiguration.isYaxisHidden != undefined &&\r\n      this.chartConfiguration.isYaxisHidden\r\n    ) {\r\n      d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');\r\n    }\r\n    /**\r\n     * dashed y axis\r\n     * used by weekly charts\r\n     */\r\nif (\r\n  this.chartConfiguration.isYaxisDashed != undefined &&\r\n  this.chartConfiguration.isYaxisDashed\r\n) {\r\n  d3.selectAll('.yaxis-dashed')\r\n    .style('stroke-dasharray', '5 5')\r\n    .style('color', 'var(--chart-grid-color)'); // Use CSS variable\r\n}\r\n    /**\r\n     * x axis color\r\n     * used by weekly charts\r\n     */\r\nif (this.chartConfiguration.isXaxisColor != undefined) {\r\n  d3.selectAll('.multichart').style(\r\n    'color',\r\n    this.chartConfiguration.isXaxisColor || 'var(--chart-text-color)'\r\n  );\r\n}\r\n    /**\r\n     * used to display y label\r\n     */\r\nif (this.isZoomedOut && this.chartData.data.length > 9) {\r\n  svg\r\n    .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n    .attr('transform', 'rotate(-90)')\r\n    .attr('text-anchor', 'end')\r\n    .attr('x', '-5')\r\n    .attr('dy', null);\r\n}\r\n\r\nfunction styleAxisDomain() {\r\n  svg.selectAll('.domain')\r\n    .style('stroke', 'var(--chart-axis-color)')\r\n    .style('stroke-width', '1px');\r\n  \r\n  svgYAxisLeft.selectAll('.domain')\r\n    .style('stroke', 'var(--chart-axis-color)')\r\n    .style('stroke-width', '1px');\r\n    \r\n  svgYAxisRight.selectAll('.domain')\r\n    .style('stroke', 'var(--chart-axis-color)')\r\n    .style('stroke-width', '1px');\r\n}\r\n\r\nstyleAxisDomain();\r\n\r\n    if (metaData.yLabel) {\r\n      svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();\r\n      function isAcronym(label) {\r\n        return (label.length <= 4 && /^[A-Z]+$/.test(label)) || (label === label.toUpperCase() && /[A-Z]/.test(label));\r\n      }\r\n      const yLabelText = metaData.yLabel;\r\n      const isAcr = isAcronym(yLabelText.replace(/[^A-Za-z]/g, ''));\r\n\r\n     const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;\r\n\r\n      svgYAxisLeft\r\n        .append('text')\r\n\r\n                .attr('class', function () {\r\n          let baseClass = 'lib-axis-group-label font-size-1';\r\n          if (self.chartConfiguration.isDrilldownChart)\r\n            return baseClass + ' lib-ylabel-drilldowncharts';\r\n          if (self.chartConfiguration.isMultiChartGridLine != undefined)\r\n            return baseClass + ' lib-ylabel-weeklyCharts';\r\n          return baseClass + ' lib-axis-waterfall-label';\r\n        })\r\n        .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n        .attr('transform', 'rotate(-90)')\r\n        .attr('y', yPosition)\r\n        .attr('x', 0 - height / 2)\r\n        .attr('dy', '1em')\r\n        .style('text-anchor', 'middle')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('color', 'var(--chart-text-color)')\r\n        .text(isAcr ? yLabelText.toUpperCase() : yLabelText.toLowerCase())\r\n        .style('text-transform', isAcr ? 'none' : 'capitalize');\r\n    }\r\n    if (this.chartData.targetLineData) {\r\n      const yZero = yScale(parsedNum);\r\n      svg\r\n        .append('line')\r\n        .attr('x1', 0)\r\n        .attr('x2', width)\r\n        .attr('y1', yZero)\r\n        .attr('y2', yZero)\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('stroke', this.chartData.targetLineData.color);\r\n      // svgYAxisRight\r\n      //   .append('line')\r\n      //   .attr('x1', 0)\r\n      //   .attr('x2', rightSvgWidth)\r\n      //   .attr('y1', yZero)\r\n      //   .attr('y2', yZero)\r\n      //   .style('stroke', this.chartData.targetLineData.color);\r\n      svgYAxisRight\r\n        .append('foreignObject')\r\n        // .attr('transform', 'translate(' + 0 + ',' + (yZero - 30) + ')')\r\n        .attr('transform', 'translate(' + 0 + ',' + (yZero - 13) + ')')\r\n        .attr('width', rightSvgWidth)\r\n        .attr('height', 50)\r\n        .append('xhtml:div')\r\n        .attr('class', 'target-display')\r\n        .style('color', 'var(--chart-text-color)')\r\n\r\n        .html(function (d, i) {\r\n          let dataTypeTemp = '';\r\n          let targetLineName = 'target';\r\n          if (metaData.dataType) {\r\n            dataTypeTemp = metaData.dataType;\r\n          }\r\n          if (\r\n            self.chartData.targetLineData &&\r\n            self.chartData.targetLineData.targetName\r\n          ) {\r\n            targetLineName = self.chartData.targetLineData.targetName;\r\n          }\r\n          return (\r\n            `<div>${targetLineName}</div>` +\r\n            '<div>' +\r\n            self.chartData.targetLineData.target +\r\n            '' +\r\n            dataTypeTemp +\r\n            '</div>'\r\n          );\r\n        });\r\n    }\r\n    rect\r\n      .selectAll('rect')\r\n      .on('mouseenter', handleMouseOver)\r\n      .on('mouseout', handleMouseOut);\r\n    if (metaData.lineyLabel) {\r\n      svg\r\n        .append('text')\r\n        .attr('class', 'lib-axis-group-label lib-line-axis')\r\n        .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n        .attr('transform', 'translate(' + (width - 20) + ',0) rotate(90)')\r\n        .attr('y', 0 - margin.right * 3)\r\n        .attr('x', height / 2)\r\n        .attr('dy', '5em')\r\n        .style('text-anchor', 'middle')\r\n        .text(metaData.lineyLabel);\r\n    }\r\n\r\n        if (metaData.xLabel) {\r\n      function isAcronym(label) {\r\n        return (\r\n          (label.length <= 4 && /^[A-Z]+$/.test(label)) ||\r\n          (label === label.toUpperCase() && /[A-Z]/.test(label))\r\n        );\r\n      }\r\n      const xLabelText = metaData.xLabel;\r\n      const isAcr = isAcronym(xLabelText.replace(/[^A-Za-z]/g, ''));\r\n\r\n        const xPosition = isria ? (height + margin.top + margin.bottom) : (height + margin.top + margin.bottom + 10);\r\n\r\n      svg\r\n        .append('text')\r\n        .attr('class', function () {\r\n          let baseClass = 'lib-axis-group-label font-size-1';\r\n          if (self.chartConfiguration.isDrilldownChart)\r\n            return baseClass + ' lib-xlabel-drilldowncharts';\r\n          if (self.chartConfiguration.isMultiChartGridLine != undefined)\r\n            return baseClass + ' lib-xlabel-weeklyCharts';\r\n          return baseClass + ' lib-axis-waterfall-label';\r\n        })\r\n        .attr('style', self.chartConfiguration.xAxisCustomlabelStyles)\r\n        .attr(\r\n          'transform',\r\n          'translate(' + width / 2 + ' ,' + xPosition + ')'\r\n        )\r\n        .style('text-anchor', 'middle')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .text(isAcr ? xLabelText.toUpperCase() : xLabelText.toLowerCase())\r\n        .style('text-transform', isAcr ? 'none' : 'capitalize');\r\n    }\r\n    \r\n    if (lineData && colors) {\r\n      var dataGroup = d3\r\n        .nest()\r\n        .key(function (d) {\r\n          return d.category;\r\n        })\r\n        .entries(lineData);\r\n\r\n      var lineGen = d3\r\n        .line()\r\n        .x(function (d) {\r\n          return xScale(d.name) + xScale.bandwidth() / 2;\r\n        })\r\n        .y(function (d) {\r\n          return lineYscale(d.value);\r\n        });\r\n\r\n      var calculateCX = (d) => {\r\n        return xScale(d.name) + xScale.bandwidth() / 2;\r\n      };\r\n\r\n      var calculateCY = (d) => {\r\n        return lineYscale(d.value);\r\n      };\r\n\r\n      dataGroup.forEach(function (d, i) {\r\n        svg\r\n          .append('path')\r\n          .datum(d.values)\r\n          .attr('fill', 'none')\r\n          .attr('stroke', function (d) {\r\n            if ('category' in d[0]) {\r\n              return colors[d[0].category];\r\n            } else {\r\n              return self.chartConfiguration.lineGraphColor;\r\n            }\r\n          })\r\n          .attr('stroke-width', 2.5) /**line thinkness */\r\n          .attr('d', lineGen(d.values));\r\n\r\n        var dot = svg\r\n          .selectAll('myCircles')\r\n          .data(d.values)\r\n          .enter()\r\n          .append('g')\r\n          .on('click', function (d) {\r\n            self.handleClick(d);\r\n          });\r\n\r\n        dot\r\n          .append('circle')\r\n          .attr('fill', function (d) {\r\n            if ('category' in d) {\r\n              return colors[d.category];\r\n            } else {\r\n              return self.chartConfiguration.lineGraphColor;\r\n            }\r\n          })\r\n          .attr('stroke', 'none')\r\n          .attr('cx', function (d, i) {\r\n            return xScale(d.name) + xScale.bandwidth() / 2;\r\n          })\r\n          .attr('cy', function (d, i) {\r\n            return lineYscale(d.value);\r\n          })\r\n          .attr('r', 3) /**radius of circle=5 */\r\n          .style('cursor', 'pointer');\r\n\r\n        if (self.chartConfiguration.lineGraphColor) {\r\n          dot\r\n            .append('text')\r\n            .attr('class', 'dots')\r\n            .attr('fill', self.chartConfiguration.lineGraphColor)\r\n            .attr('style', 'font-size: ' + '.85em;' + 'font-weight:' + 'bold')\r\n            .attr('x', function (d, i) {\r\n              return xScale(d.name) + xScale.bandwidth() / 2;\r\n            })\r\n            .attr('y', function (d, i) {\r\n              return lineYscale(d.value);\r\n            })\r\n            .attr('dy', '-1em')\r\n            .text(function (d, i) {\r\n              return self.chartConfiguration.labelFormatter(d.value);\r\n            });\r\n        }\r\n      });\r\n    }\r\n    // svg.attr('width', 150).style('max-width', 150).style('overflow-x', 'auto');\r\n  }\r\n  handleClick(d: any) {\r\n    if (this.chartData?.metaData?.hasDrillDown || d?.toggleFrom)\r\n      this.clickEvent.emit(d);\r\n  }\r\n  handleHeaderMenuClick(id) {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n  handleCompareByFilterSelection(event) {\r\n    this.clickEvent.emit(event);\r\n  }\r\n  handleZoominZoomoutClick({ isZoomOut, event }) {\r\n    // this.isZoomOutSelected(isZoomOut, event);\r\n    this.isZoomOutSelected(isZoomOut);\r\n  }\r\n}\r\n","<meta http-equiv=\"CACHE-CONTROL\" content=\"NO-CACHE\" />\r\n<meta http-equiv=\"EXPIRES\" content=\"Sat, 01 Jun 2004 11:12:01 GMT\" />\r\n<div\r\n  #verticalstackedcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n    style=\"background-color: var(--card-bg);\"\r\n\r\n  (resized)=\"onResized($event)\"\r\n>\r\n  <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n    <lib-chart-header-v2\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (clickEvent)=\"handleClick($event)\"\r\n    ></lib-chart-header-v2>\r\n\r\n    <!-- <span *ngIf=\"chartConfiguration.isComparebyDropdownVisible\">\r\n      <lib-dropdown></lib-dropdown>\r\n    </span> -->\r\n    <lib-chart-header-v3\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n      (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n    ></lib-chart-header-v3>\r\n  </div>\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"verticalstackedchartcontainer\"\r\n    #verticalstackedchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}
|