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