@net7/components 3.8.5 → 3.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/bubble-chart/bubble-chart.mjs +131 -176
- package/esm2020/lib/components/input-text/input-text.mjs +3 -3
- package/esm2020/lib/components/input-textarea/input-textarea.mjs +21 -0
- package/esm2020/lib/components/input-textarea/input-textarea.mock.mjs +9 -0
- package/esm2020/lib/dv-components-lib.module.mjs +5 -1
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/net7-components.mjs +163 -179
- package/fesm2015/net7-components.mjs.map +1 -1
- package/fesm2020/net7-components.mjs +163 -178
- package/fesm2020/net7-components.mjs.map +1 -1
- package/lib/components/bubble-chart/bubble-chart.d.ts +17 -36
- package/lib/components/input-textarea/input-textarea.d.ts +31 -0
- package/lib/components/input-textarea/input-textarea.mock.d.ts +2 -0
- package/lib/dv-components-lib.module.d.ts +11 -10
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/src/lib/styles/_imports.scss +1 -0
- package/src/lib/styles/components/_input-textarea.scss +47 -0
|
@@ -7,22 +7,10 @@ import * as i1 from "@angular/common";
|
|
|
7
7
|
export class BubbleChartComponent {
|
|
8
8
|
constructor() {
|
|
9
9
|
this._loaded = false;
|
|
10
|
-
this.measureWidth = (text) => {
|
|
11
|
-
const context = document.createElement('canvas').getContext('2d');
|
|
12
|
-
// measure text with the correct font family and weight
|
|
13
|
-
if (this.data?.fontRendering?.label?.family && this.data?.fontRendering?.label?.weight) {
|
|
14
|
-
context.font = `${this.data.fontRendering.label.weight} ${this.data.fontRendering.label.family}`;
|
|
15
|
-
}
|
|
16
|
-
return context.measureText(text).width;
|
|
17
|
-
};
|
|
18
|
-
this.isValidNumber = (value) => !Number.isNaN(Number.parseFloat(value));
|
|
19
10
|
this.draw = () => {
|
|
20
11
|
const { d3 } = this;
|
|
21
12
|
const { containerId, data, height, width, selected, transition, colorMatch, shuffle, fontRendering } = this.data;
|
|
22
13
|
const closeIconPath = 'M -50,40 L-40,50 0,10 40,50 50,40 10,0 50,-40 40,-50 0,-10 -40,-50 -50,-40 -10,0 -50,40';
|
|
23
|
-
const defaultLineHeight = 13;
|
|
24
|
-
const ellipsisThreshold = 4; // words
|
|
25
|
-
const textScalingFactor = 0.95;
|
|
26
14
|
if (!Array.isArray(data)) {
|
|
27
15
|
// Check if it is possible to draw with the current dataset
|
|
28
16
|
console.warn('(n7-bubble-chart) The data object is not in the expected format!');
|
|
@@ -58,23 +46,19 @@ export class BubbleChartComponent {
|
|
|
58
46
|
const svg = d3
|
|
59
47
|
.select(`#${containerId}`)
|
|
60
48
|
.attr('viewBox', [0, 0, width, height])
|
|
61
|
-
|
|
62
|
-
// .attr('font-size', '10px')
|
|
63
|
-
.style('font', '10px Verdana, Geneva, sans-serif')
|
|
64
|
-
.style('height', 'auto')
|
|
65
|
-
.style('max-width', '100%')
|
|
49
|
+
.attr('font-family', 'Verdana, Geneva, sans-serif')
|
|
66
50
|
.attr('text-anchor', 'middle');
|
|
67
51
|
const leaf = svg.selectAll('g').data(root().leaves(), (d) => d.data.entity.id);
|
|
68
52
|
leaf
|
|
69
53
|
.transition(t) // update transition on <g>
|
|
70
54
|
.attr('fill-opacity', 1)
|
|
71
|
-
.attr('transform', (d) => `translate(${d.x + 1},${d.y + 1})`)
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
55
|
+
.attr('transform', (d) => `translate(${d.x + 1},${d.y + 1})`)
|
|
56
|
+
.attr('font-size', (d) => {
|
|
57
|
+
let size = d.r / 5.5;
|
|
58
|
+
size *= 1;
|
|
59
|
+
size += 1;
|
|
60
|
+
return `${Math.round(size)}px`;
|
|
61
|
+
});
|
|
78
62
|
leaf.selectAll('.close-icon').remove(); // clear all existing close icons
|
|
79
63
|
if (selected) {
|
|
80
64
|
leaf // render necessary close icons
|
|
@@ -95,8 +79,86 @@ export class BubbleChartComponent {
|
|
|
95
79
|
.transition(t) // update transition on <circle>
|
|
96
80
|
.attr('fill-opacity', 1)
|
|
97
81
|
.attr('r', (d) => d.r);
|
|
82
|
+
leaf
|
|
83
|
+
.select('text')
|
|
84
|
+
.attr('font-family', () => {
|
|
85
|
+
if (fontRendering && fontRendering.label && fontRendering.label.family) {
|
|
86
|
+
return fontRendering.label.family;
|
|
87
|
+
}
|
|
88
|
+
return 'inherit';
|
|
89
|
+
})
|
|
90
|
+
.attr('font-weight', () => {
|
|
91
|
+
if (fontRendering && fontRendering.label && fontRendering.label.weight) {
|
|
92
|
+
return fontRendering.label.weight;
|
|
93
|
+
}
|
|
94
|
+
return 'inherit';
|
|
95
|
+
})
|
|
96
|
+
.selectAll('tspan')
|
|
97
|
+
.data((d) => {
|
|
98
|
+
if (d.r / 4 > 4.5) {
|
|
99
|
+
// show text and number threshhold
|
|
100
|
+
let label = (d.data.entity.label.charAt(0).toUpperCase()
|
|
101
|
+
+ d.data.entity.label.slice(1)).split(/ +/g);
|
|
102
|
+
if (label.length > 3) {
|
|
103
|
+
label = label.slice(0, 3);
|
|
104
|
+
label[2] += '…';
|
|
105
|
+
}
|
|
106
|
+
return label;
|
|
107
|
+
}
|
|
108
|
+
if (d.r / 4 > 2.5) {
|
|
109
|
+
// show text threshhold
|
|
110
|
+
let label = (d.data.entity.label.charAt(0).toUpperCase()
|
|
111
|
+
+ d.data.entity.label.slice(1)).split(/ +/g);
|
|
112
|
+
if (label.length > 3) {
|
|
113
|
+
label = label.slice(0, 3);
|
|
114
|
+
label[2] += '…';
|
|
115
|
+
}
|
|
116
|
+
return label;
|
|
117
|
+
}
|
|
118
|
+
return '';
|
|
119
|
+
})
|
|
120
|
+
.join('tspan')
|
|
121
|
+
.attr('x', 0)
|
|
122
|
+
.attr('y', (d, i, nodes) => `${i - (nodes.length + 1) / 2 + 0.97}em`)
|
|
123
|
+
.attr('fill', 'white')
|
|
124
|
+
.text((d) => d);
|
|
125
|
+
leaf
|
|
126
|
+
.select('.label-count')
|
|
127
|
+
.attr('font-family', () => {
|
|
128
|
+
if (fontRendering && fontRendering.counter && fontRendering.counter.family) {
|
|
129
|
+
return fontRendering.counter.family;
|
|
130
|
+
}
|
|
131
|
+
return 'inherit';
|
|
132
|
+
})
|
|
133
|
+
.attr('font-weight', () => {
|
|
134
|
+
if (fontRendering && fontRendering.counter && fontRendering.counter.weight) {
|
|
135
|
+
return fontRendering.counter.weight;
|
|
136
|
+
}
|
|
137
|
+
return 'inherit';
|
|
138
|
+
})
|
|
139
|
+
.attr('fill', 'white')
|
|
140
|
+
.text((d) => {
|
|
141
|
+
if (d.r / 4 > 2.5) {
|
|
142
|
+
// show text and number threshhold
|
|
143
|
+
return d.data.count;
|
|
144
|
+
}
|
|
145
|
+
return '';
|
|
146
|
+
})
|
|
147
|
+
.attr('y', (d) => {
|
|
148
|
+
let labelLength = d.data.entity.label.split(/ +/g);
|
|
149
|
+
if (labelLength.length > 3) {
|
|
150
|
+
labelLength = labelLength.slice(0, 3);
|
|
151
|
+
}
|
|
152
|
+
return `${labelLength.length - (labelLength.length + 1) / 2 + 0.97}em`;
|
|
153
|
+
});
|
|
98
154
|
const g = leaf.enter().append('g');
|
|
99
155
|
g.attr('transform', (d) => `translate(${d.x + 1},${d.y + 1})`)
|
|
156
|
+
.attr('font-size', (d) => {
|
|
157
|
+
let size = d.r / 5.5;
|
|
158
|
+
size *= 1;
|
|
159
|
+
size += 1;
|
|
160
|
+
return `${Math.round(size)}px`;
|
|
161
|
+
})
|
|
100
162
|
.attr('cursor', 'pointer')
|
|
101
163
|
.on('click', (event, d) => {
|
|
102
164
|
this.onClick(d.data.entity.id);
|
|
@@ -113,88 +175,6 @@ export class BubbleChartComponent {
|
|
|
113
175
|
.attr('id', (d) => { d.clipUid = `Clip-${d.data.entity.id}`; })
|
|
114
176
|
.append('use')
|
|
115
177
|
.attr('xlink:href', (d) => d.leafUid.href);
|
|
116
|
-
// g.append('text')
|
|
117
|
-
// .attr('font-family', () => {
|
|
118
|
-
// if (fontRendering && fontRendering.label && fontRendering.label.family) {
|
|
119
|
-
// return fontRendering.label.family;
|
|
120
|
-
// }
|
|
121
|
-
// return 'inherit';
|
|
122
|
-
// })
|
|
123
|
-
// .attr('font-weight', () => {
|
|
124
|
-
// if (fontRendering && fontRendering
|
|
125
|
-
// && fontRendering.label && fontRendering.label.weight) {
|
|
126
|
-
// return fontRendering.label.weight;
|
|
127
|
-
// }
|
|
128
|
-
// return 'inherit';
|
|
129
|
-
// })
|
|
130
|
-
// .selectAll('tspan')
|
|
131
|
-
// .data((d) => {
|
|
132
|
-
// if (d.r / 4 > 4.5) {
|
|
133
|
-
// // show text and number threshhold
|
|
134
|
-
// let label = (
|
|
135
|
-
// d.data.entity.label.charAt(0).toUpperCase()
|
|
136
|
-
// + d.data.entity.label.slice(1)
|
|
137
|
-
// ).split(/ +/g);
|
|
138
|
-
// if (label.length > 3) {
|
|
139
|
-
// label = label.slice(0, 3);
|
|
140
|
-
// label[2] += '…';
|
|
141
|
-
// }
|
|
142
|
-
// return label;
|
|
143
|
-
// } if (d.r / 4 > 2.5) {
|
|
144
|
-
// // show text threshhold
|
|
145
|
-
// let label = (
|
|
146
|
-
// d.data.entity.label.charAt(0).toUpperCase()
|
|
147
|
-
// + d.data.entity.label.slice(1)
|
|
148
|
-
// ).split(/ +/g);
|
|
149
|
-
// if (label.length > 3) {
|
|
150
|
-
// label = label.slice(0, 3);
|
|
151
|
-
// label[2] += '…';
|
|
152
|
-
// }
|
|
153
|
-
// return label;
|
|
154
|
-
// }
|
|
155
|
-
// return '';
|
|
156
|
-
// })
|
|
157
|
-
// .join('tspan')
|
|
158
|
-
// .attr('x', 0)
|
|
159
|
-
// .attr('y', (d, i, nodes) => `${i - (nodes.length + 1) / 2 + 0.97}em`)
|
|
160
|
-
// .attr('fill', 'white')
|
|
161
|
-
// .text((d) => d)
|
|
162
|
-
// .attr('fill-opacity', 0)
|
|
163
|
-
// .transition(t) // enter() transition on <tspan>
|
|
164
|
-
// .attr('fill-opacity', 1);
|
|
165
|
-
// g.append('text') // Count label
|
|
166
|
-
// .attr('class', 'label-count')
|
|
167
|
-
// .attr('font-family', () => {
|
|
168
|
-
// if (fontRendering && fontRendering.counter && fontRendering.counter.family) {
|
|
169
|
-
// return fontRendering.counter.family;
|
|
170
|
-
// }
|
|
171
|
-
// return 'inherit';
|
|
172
|
-
// })
|
|
173
|
-
// .attr('font-weight', () => {
|
|
174
|
-
// if (fontRendering && fontRendering.counter && fontRendering.counter.weight) {
|
|
175
|
-
// return fontRendering.counter.weight;
|
|
176
|
-
// }
|
|
177
|
-
// return 'inherit';
|
|
178
|
-
// })
|
|
179
|
-
// .attr('fill', 'white')
|
|
180
|
-
// .text((d) => {
|
|
181
|
-
// if (d.r / 4 > 2.5) {
|
|
182
|
-
// // show text and number threshhold
|
|
183
|
-
// return d.data.count;
|
|
184
|
-
// }
|
|
185
|
-
// return '';
|
|
186
|
-
// })
|
|
187
|
-
// .attr('y', (d) => {
|
|
188
|
-
// let labelLength = d.data.entity.label.split(/ +/g);
|
|
189
|
-
// if (labelLength.length > 3) {
|
|
190
|
-
// labelLength = labelLength.slice(0, 3);
|
|
191
|
-
// }
|
|
192
|
-
// return `${labelLength.length - (labelLength.length + 1) / 2 + 0.97}em`;
|
|
193
|
-
// })
|
|
194
|
-
// .attr('fill-opacity', 0)
|
|
195
|
-
// .transition(t) // enter() transition on <text>
|
|
196
|
-
// .attr('fill-opacity', 1);
|
|
197
|
-
/** NEW TEXT LOGIC */
|
|
198
178
|
g.append('text')
|
|
199
179
|
.attr('font-family', () => {
|
|
200
180
|
if (fontRendering && fontRendering.label && fontRendering.label.family) {
|
|
@@ -208,83 +188,40 @@ export class BubbleChartComponent {
|
|
|
208
188
|
}
|
|
209
189
|
return 'inherit';
|
|
210
190
|
})
|
|
211
|
-
.
|
|
212
|
-
.
|
|
213
|
-
// Capitalize the first letter of the label
|
|
214
|
-
d.data.entity.label = d.data.entity
|
|
215
|
-
.label.charAt(0).toUpperCase()
|
|
216
|
-
+ d.data.entity.label.slice(1);
|
|
217
|
-
// 1. initialize meta object
|
|
218
|
-
if (!d._meta || typeof d._meta !== 'object')
|
|
219
|
-
d._meta = {};
|
|
220
|
-
// 2. tokenize label & count into words
|
|
221
|
-
const words = d.data.entity.label.split(/\s+/g); // To hyphenate: /\s+|(?<=-)/
|
|
222
|
-
// Truncate with ellipsis if the label is longer than the threshold
|
|
223
|
-
if (words.length > ellipsisThreshold) {
|
|
224
|
-
words.splice(ellipsisThreshold, words.length - ellipsisThreshold);
|
|
225
|
-
words[ellipsisThreshold - 1] += '…';
|
|
226
|
-
}
|
|
227
|
-
// add counter
|
|
228
|
-
if (d.r / 4 > 2.5) {
|
|
229
|
-
// show text threshold
|
|
230
|
-
if (!words[words.length - 1])
|
|
231
|
-
words.pop();
|
|
232
|
-
if (!words[0])
|
|
233
|
-
words.shift();
|
|
234
|
-
}
|
|
191
|
+
.selectAll('tspan')
|
|
192
|
+
.data((d) => {
|
|
235
193
|
if (d.r / 4 > 4.5) {
|
|
236
|
-
// show number
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
// 3. build lines of text
|
|
243
|
-
d._meta.lines = [];
|
|
244
|
-
let line;
|
|
245
|
-
let lineWidth0 = Infinity;
|
|
246
|
-
for (let i = 0, n = d._meta.words.length; i < n; i += 1) {
|
|
247
|
-
const lineText1 = (line ? `${line.text} ` : '') + words[i];
|
|
248
|
-
const lineWidth1 = this.measureWidth(lineText1);
|
|
249
|
-
if ((lineWidth0 + lineWidth1) / 2 < targetWidth && i !== n - 1) {
|
|
250
|
-
line.width = lineWidth0;
|
|
251
|
-
lineWidth0 = lineWidth1;
|
|
252
|
-
line.text = lineText1;
|
|
253
|
-
}
|
|
254
|
-
else {
|
|
255
|
-
// if line is too long or this is the last line (counter), push to next line
|
|
256
|
-
lineWidth0 = this.measureWidth(words[i]);
|
|
257
|
-
line = { width: lineWidth0, text: words[i] };
|
|
258
|
-
d._meta.lines.push(line);
|
|
194
|
+
// show text and number threshhold
|
|
195
|
+
let label = (d.data.entity.label.charAt(0).toUpperCase()
|
|
196
|
+
+ d.data.entity.label.slice(1)).split(/ +/g);
|
|
197
|
+
if (label.length > 3) {
|
|
198
|
+
label = label.slice(0, 3);
|
|
199
|
+
label[2] += '…';
|
|
259
200
|
}
|
|
201
|
+
return label;
|
|
260
202
|
}
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
203
|
+
if (d.r / 4 > 2.5) {
|
|
204
|
+
// show text threshhold
|
|
205
|
+
let label = (d.data.entity.label.charAt(0).toUpperCase()
|
|
206
|
+
+ d.data.entity.label.slice(1)).split(/ +/g);
|
|
207
|
+
if (label.length > 3) {
|
|
208
|
+
label = label.slice(0, 3);
|
|
209
|
+
label[2] += '…';
|
|
210
|
+
}
|
|
211
|
+
return label;
|
|
267
212
|
}
|
|
268
|
-
|
|
269
|
-
return d;
|
|
213
|
+
return '';
|
|
270
214
|
})
|
|
271
|
-
.
|
|
272
|
-
.filter((d) => (d.r / 4 > 2.5))
|
|
273
|
-
.selectAll('tspan')
|
|
274
|
-
.data((d) => d._meta.lines)
|
|
275
|
-
.enter()
|
|
276
|
-
.append('tspan')
|
|
215
|
+
.join('tspan')
|
|
277
216
|
.attr('x', 0)
|
|
278
|
-
.attr('y', (d, i,
|
|
279
|
-
.attr('
|
|
280
|
-
|
|
281
|
-
i === n.length - 1 && this.isValidNumber(d.text) ? 'label-counter' : 'label-text'))
|
|
282
|
-
.text((d) => d.text)
|
|
217
|
+
.attr('y', (d, i, nodes) => `${i - (nodes.length + 1) / 2 + 0.97}em`)
|
|
218
|
+
.attr('fill', 'white')
|
|
219
|
+
.text((d) => d)
|
|
283
220
|
.attr('fill-opacity', 0)
|
|
284
221
|
.transition(t) // enter() transition on <tspan>
|
|
285
222
|
.attr('fill-opacity', 1);
|
|
286
|
-
//
|
|
287
|
-
|
|
223
|
+
g.append('text') // Count label
|
|
224
|
+
.attr('class', 'label-count')
|
|
288
225
|
.attr('font-family', () => {
|
|
289
226
|
if (fontRendering && fontRendering.counter && fontRendering.counter.family) {
|
|
290
227
|
return fontRendering.counter.family;
|
|
@@ -296,7 +233,25 @@ export class BubbleChartComponent {
|
|
|
296
233
|
return fontRendering.counter.weight;
|
|
297
234
|
}
|
|
298
235
|
return 'inherit';
|
|
299
|
-
})
|
|
236
|
+
})
|
|
237
|
+
.attr('fill', 'white')
|
|
238
|
+
.text((d) => {
|
|
239
|
+
if (d.r / 4 > 2.5) {
|
|
240
|
+
// show text and number threshhold
|
|
241
|
+
return d.data.count;
|
|
242
|
+
}
|
|
243
|
+
return '';
|
|
244
|
+
})
|
|
245
|
+
.attr('y', (d) => {
|
|
246
|
+
let labelLength = d.data.entity.label.split(/ +/g);
|
|
247
|
+
if (labelLength.length > 3) {
|
|
248
|
+
labelLength = labelLength.slice(0, 3);
|
|
249
|
+
}
|
|
250
|
+
return `${labelLength.length - (labelLength.length + 1) / 2 + 0.97}em`;
|
|
251
|
+
})
|
|
252
|
+
.attr('fill-opacity', 0)
|
|
253
|
+
.transition(t) // enter() transition on <text>
|
|
254
|
+
.attr('fill-opacity', 1);
|
|
300
255
|
leaf
|
|
301
256
|
.exit() // EXIT CYCLE
|
|
302
257
|
.remove();
|
|
@@ -357,4 +312,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImpor
|
|
|
357
312
|
}], emit: [{
|
|
358
313
|
type: Input
|
|
359
314
|
}] } });
|
|
360
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bubble-chart.js","sourceRoot":"","sources":["../../../../../../projects/dv-components-lib/src/lib/components/bubble-chart/bubble-chart.ts","../../../../../../projects/dv-components-lib/src/lib/components/bubble-chart/bubble-chart.html"],"names":[],"mappings":"AAAA,6BAA6B;AAC7B,iBAAiB;AACjB,6BAA6B;AAC7B,OAAO,EAAE,SAAS,EAAE,KAAK,EAAuB,MAAM,eAAe,CAAC;;;AA0HtE,MAAM,OAAO,oBAAoB;IAJjC;QAWU,YAAO,GAAG,KAAK,CAAC;QA2BxB,iBAAY,GAAG,CAAC,IAAI,EAAE,EAAE;YACtB,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAClE,uDAAuD;YACvD,IAAI,IAAI,CAAC,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,IAAI,IAAI,CAAC,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE;gBACtF,OAAO,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;aAClG;YACD,OAAO,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC;QACzC,CAAC,CAAC;QAEF,kBAAa,GAAG,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;QAEnE,SAAI,GAAG,GAAG,EAAE;YACV,MAAM,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC;YACpB,MAAM,EACJ,WAAW,EAAE,IAAI,EAAE,MAAM,EACzB,KAAK,EAAE,QAAQ,EAAE,UAAU,EAC3B,UAAU,EAAE,OAAO,EACnB,aAAa,EACd,GAAG,IAAI,CAAC,IAAI,CAAC;YACd,MAAM,aAAa,GAAG,yFAAyF,CAAC;YAChH,MAAM,iBAAiB,GAAG,EAAE,CAAC;YAC7B,MAAM,iBAAiB,GAAG,CAAC,CAAC,CAAC,QAAQ;YACrC,MAAM,iBAAiB,GAAG,IAAI,CAAC;YAE/B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACxB,2DAA2D;gBAC3D,OAAO,CAAC,IAAI,CAAC,kEAAkE,CAAC,CAAC;gBACjF,OAAO;aACR;YAED,IAAI,CAAC,GAAG,EAAE;iBACP,UAAU,EAAE;iBACZ,QAAQ,CAAC,CAAC,CAAC,CAAC;YACf,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;gBAClC,CAAC,GAAG,EAAE;qBACH,UAAU,EAAE;qBACZ,QAAQ,CAAC,UAAU,CAAC;qBACpB,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;aAC5B;YAED,MAAM,QAAQ,GAAG,EAAE,CAAC,YAAY,EAAE;iBAC/B,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,OAAO,EAAE,gBAAgB,EAAE,eAAe,CAAC,CAAC;iBAChG,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;YAE7D,MAAM,SAAS,GAAG,EAAE,CAAC,kCAAkC;iBACpD,WAAW,EAAE;iBACb,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;iBAC1C,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAE7C,MAAM,IAAI,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,EAAE;iBAC1B,IAAI,EAAE;iBACN,IAAI,CAAC,CAAC,KAAK,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;iBAC7B,OAAO,CAAC,GAAG,CAAC,CACX,EAAE,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAC1D,CAAC;YAEJ,MAAM,IAAI,GAAG,GAAG,EAAE;gBAChB,IAAI,OAAO,OAAO,KAAK,WAAW,IAAI,OAAO,EAAE;oBAC7C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,iCAAiC;oBACjE,OAAO,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;iBACpC,CAAC,oDAAoD;gBACtD,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC;YACpB,CAAC,CAAC;YAEF,MAAM,GAAG,GAAG,EAAE;iBACX,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC;iBACzB,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;gBACvC,sDAAsD;gBACtD,6BAA6B;iBAC5B,KAAK,CAAC,MAAM,EAAE,kCAAkC,CAAC;iBACjD,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC;iBACvB,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC;iBAC1B,IAAI,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;YAEjC,MAAM,IAAI,GAAG,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YAC/E,IAAI;iBACD,UAAU,CAAC,CAAC,CAAC,CAAC,2BAA2B;iBACzC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;iBACvB,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAChE,8BAA8B;YAC9B,0BAA0B;YAC1B,eAAe;YACf,eAAe;YACf,oCAAoC;YACpC,MAAM;YAEN,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,iCAAiC;YACzE,IAAI,QAAQ,EAAE;gBACZ,IAAI,CAAC,+BAA+B;qBACjC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;qBAClD,MAAM,CAAC,MAAM,CAAC;qBACd,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC;qBAC3B,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC;qBACxB,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC;qBACpB,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE;oBACvB,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;wBACf,OAAO,2BAA2B,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;qBACpD;oBACD,OAAO,YAAY,CAAC;gBACtB,CAAC,CAAC,CAAC;aACN;YAED,IAAI;iBACD,MAAM,CAAC,QAAQ,CAAC;iBAChB,UAAU,CAAC,CAAC,CAAC,CAAC,gCAAgC;iBAC9C,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;iBACvB,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAEzB,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAEnC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC;iBAC3D,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC;iBACzB,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;gBACxB,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YACjC,CAAC,CAAC;iBACD,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC;iBAC1C,MAAM,CAAC,QAAQ,CAAC;iBAChB,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;iBACpD,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;iBACZ,UAAU,CAAC,CAAC,CAAC,CAAC,iCAAiC;iBAC/C,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;iBACvB,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;iBACzD,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAEzB,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC;iBACjB,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,OAAO,GAAG,QAAQ,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;iBAC9D,MAAM,CAAC,KAAK,CAAC;iBACb,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAE7C,mBAAmB;YACnB,iCAAiC;YACjC,gFAAgF;YAChF,2CAA2C;YAC3C,QAAQ;YACR,wBAAwB;YACxB,OAAO;YACP,iCAAiC;YACjC,yCAAyC;YACzC,kEAAkE;YAClE,2CAA2C;YAC3C,QAAQ;YACR,wBAAwB;YACxB,OAAO;YACP,wBAAwB;YACxB,mBAAmB;YACnB,2BAA2B;YAC3B,2CAA2C;YAC3C,sBAAsB;YACtB,sDAAsD;YACtD,yCAAyC;YACzC,wBAAwB;YACxB,gCAAgC;YAChC,qCAAqC;YACrC,2BAA2B;YAC3B,UAAU;YACV,sBAAsB;YACtB,6BAA6B;YAC7B,gCAAgC;YAChC,sBAAsB;YACtB,sDAAsD;YACtD,yCAAyC;YACzC,wBAAwB;YACxB,gCAAgC;YAChC,qCAAqC;YACrC,2BAA2B;YAC3B,UAAU;YACV,sBAAsB;YACtB,QAAQ;YACR,iBAAiB;YACjB,OAAO;YACP,mBAAmB;YACnB,kBAAkB;YAClB,0EAA0E;YAC1E,2BAA2B;YAC3B,oBAAoB;YACpB,6BAA6B;YAC7B,oDAAoD;YACpD,8BAA8B;YAE9B,kCAAkC;YAClC,kCAAkC;YAClC,iCAAiC;YACjC,oFAAoF;YACpF,6CAA6C;YAC7C,QAAQ;YACR,wBAAwB;YACxB,OAAO;YACP,iCAAiC;YACjC,oFAAoF;YACpF,6CAA6C;YAC7C,QAAQ;YACR,wBAAwB;YACxB,OAAO;YACP,2BAA2B;YAC3B,mBAAmB;YACnB,2BAA2B;YAC3B,2CAA2C;YAC3C,6BAA6B;YAC7B,QAAQ;YACR,iBAAiB;YACjB,OAAO;YACP,wBAAwB;YACxB,0DAA0D;YAC1D,oCAAoC;YACpC,+CAA+C;YAC/C,QAAQ;YACR,8EAA8E;YAC9E,OAAO;YACP,6BAA6B;YAC7B,mDAAmD;YACnD,8BAA8B;YAE9B,qBAAqB;YACrB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;iBACb,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE;gBACxB,IAAI,aAAa,IAAI,aAAa,CAAC,KAAK,IAAI,aAAa,CAAC,KAAK,CAAC,MAAM,EAAE;oBACtE,OAAO,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC;iBACnC;gBACD,OAAO,SAAS,CAAC;YACnB,CAAC,CAAC;iBACD,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE;gBACxB,IAAI,aAAa,IAAI,aAAa,IAAI,aAAa,CAAC,KAAK,IAAI,aAAa,CAAC,KAAK,CAAC,MAAM,EAAE;oBACvF,OAAO,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC;iBACnC;gBACD,OAAO,SAAS,CAAC;YACnB,CAAC,CAAC;iBACD,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC;iBACrB,IAAI,CAAC,CAAC,CAAa,EAAE,EAAE;gBACtB,2CAA2C;gBAC3C,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM;qBAChC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE;sBAC5B,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACjC,4BAA4B;gBAC5B,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,OAAO,CAAC,CAAC,KAAK,KAAK,QAAQ;oBAAE,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;gBAC1D,uCAAuC;gBACvC,MAAM,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,6BAA6B;gBAC9E,mEAAmE;gBACnE,IAAI,KAAK,CAAC,MAAM,GAAG,iBAAiB,EAAE;oBACpC,KAAK,CAAC,MAAM,CAAC,iBAAiB,EAAE,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC,CAAC;oBAClE,KAAK,CAAC,iBAAiB,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC;iBACrC;gBACD,cAAc;gBACd,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,EAAE;oBACjB,sBAAsB;oBACtB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;wBAAE,KAAK,CAAC,GAAG,EAAE,CAAC;oBAC1C,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;wBAAE,KAAK,CAAC,KAAK,EAAE,CAAC;iBAC9B;gBAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,EAAE;oBACnB,wBAAwB;oBACxB,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;iBAC/B;gBACD,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;gBACtB,CAAC,CAAC,KAAK,CAAC,UAAU,GAAG,iBAAiB,CAAC;gBACvC,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAC3B,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,iBAAiB,CACtE,CAAC;gBACF,yBAAyB;gBACzB,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;gBACnB,IAAI,IAAI,CAAC;gBACT,IAAI,UAAU,GAAG,QAAQ,CAAC;gBAC1B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE;oBACvD,MAAM,SAAS,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;oBAC3D,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;oBAChD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,GAAG,CAAC,GAAG,WAAW,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;wBAC9D,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC;wBACxB,UAAU,GAAG,UAAU,CAAC;wBACxB,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;qBACvB;yBAAM;wBACL,4EAA4E;wBAC5E,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;wBACzC,IAAI,GAAG,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;wBAC7C,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qBAC1B;iBACF;gBACD,iCAAiC;gBACjC,IAAI,MAAM,GAAG,CAAC,CAAC;gBACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE;oBACvD,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC;oBAC5D,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;oBACtC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;iBACzD;gBACD,CAAC,CAAC,KAAK,CAAC,UAAU,GAAG,MAAM,CAAC;gBAC5B,OAAO,CAAC,CAAC;YACX,CAAC,CAAC;iBACD,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,iBAAiB,GAAG,CAAC;iBACpF,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC;iBAC9B,SAAS,CAAC,OAAO,CAAC;iBAClB,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC;iBAC1B,KAAK,EAAE;iBACP,MAAM,CAAC,OAAO,CAAC;iBACf,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;iBACZ,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,iBAAiB,CAAC;iBACpE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC1B,6DAA6D;YAC7D,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,YAAY,CAClF,CAAC;iBACD,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;iBACnB,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;iBACvB,UAAU,CAAC,CAAC,CAAC,CAAC,gCAAgC;iBAC9C,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;YAE3B,+BAA+B;YAC/B,CAAC,CAAC,SAAS,CAAC,qBAAqB,CAAC;iBAC/B,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE;gBACxB,IAAI,aAAa,IAAI,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE;oBAC1E,OAAO,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC;iBACrC;gBACD,OAAO,SAAS,CAAC;YACnB,CAAC,CAAC;iBACD,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE;gBACxB,IAAI,aAAa,IAAI,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE;oBAC1E,OAAO,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC;iBACrC;gBACD,OAAO,SAAS,CAAC;YACnB,CAAC,CAAC,CAAC;YAEL,IAAI;iBACD,IAAI,EAAE,CAAC,aAAa;iBACpB,MAAM,EAAE,CAAC;YAEZ,IAAI,QAAQ,EAAE;gBACZ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,+CAA+C;qBAC1F,MAAM,CAAC,MAAM,CAAC;qBACd,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC;qBACxB,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC;qBAC3B,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE;oBAClB,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,EAAE;wBACjB,OAAO,MAAM,CAAC;qBACf;oBACD,OAAO,aAAa,CAAC;gBACvB,CAAC,CAAC;qBACD,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE;oBACvB,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;wBACf,OAAO,2BAA2B,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;qBACpD;oBACD,OAAO,YAAY,CAAC;gBACtB,CAAC,CAAC,CAAC;aACN;YAED,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,0BAA0B;QACtD,CAAC,CAAC;KACH;IA7WC,qBAAqB;QACnB;;;UAGE;QACF,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,IAAI,CAAC,OAAO;gBAAE,OAAO;YACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;oBAC3B,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC;oBACjB,IAAI,CAAC,IAAI,EAAE,CAAC;oBACZ,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;wBAClC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qBAC9B;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,OAAO,CAAC,OAAO;QACb,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,OAAO;QACvB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAC9B,CAAC;;iHAhCU,oBAAoB;qGAApB,oBAAoB,+FC7HjC,2IAEM;2FD2HO,oBAAoB;kBAJhC,SAAS;+BACE,iBAAiB;8BAIlB,IAAI;sBAAZ,KAAK;gBAEG,IAAI;sBAAZ,KAAK","sourcesContent":["//---------------------------\n// BUBBLECHART.ts\n//---------------------------\nimport { Component, Input, AfterContentChecked } from '@angular/core';\n\n/**\n * Interface for D3Chart's \"data\"\n *\n * @property entity (required)\n * - id (required)\n * - label (optional)\n * - typeOfEntity (optional)\n * @property count (required)\n*/\nexport interface BubbleChartDataItem {\n  entity: {\n    id: string;\n    label?: string;\n    typeOfEntity?: string;\n  };\n  count: number;\n}\n\n/**\n * Interface for a Circle's node data\n */\nexport interface CircleNode {\n  clipUid: string;\n  data: BubbleChartDataItem;\n  depth: number;\n  height: number;\n  leafUid: string;\n  parent: Node;\n  x: number;\n  y: number;\n  r: number;\n  value: number;\n  /** Dynamic data for internal logic */\n  _meta?: any;\n}\n\n/**\n * Interface for BubbleChartComponent's \"data\"\n *\n * @property containerId (required)\n * @property containerWidth (required)\n * @property containerHeight (required)\n * @property bubblesData (required)\n * @property isForceSimulationEnabled (required)\n * @property classes (optional)\n * @property reset (optional)\n*/\nexport interface BubbleChartData {\n  /**\n   * unique identifier for the bubble-chart\n   */\n  containerId: string;\n  /**\n   * total width for the bubble-chart\n   */\n  width: number;\n  /**\n   * total height for the bubble-chart\n   */\n  height: number;\n  /**\n   * data about the bubbles\n   */\n  data: BubbleChartDataItem[];\n  /**\n   * additional css classes\n   */\n  classes?: string;\n  /**\n   * list of ID's of selected items\n   * (selected items will render with a 'X' icon)\n   */\n  selected?: string[];\n  /**\n   * Specify a list of typeOfEntity types (domain),\n   * and a list of colors (range), which will be mapped together.\n   */\n  colorMatch?: {\n    domain: string[];\n    range: string[];\n  };\n  /**\n   * Define a max and min size for the bubbles\n   */\n  sizeRange: [number, number];\n  /**\n   * If defined, transition will be activated\n   * and the value will be used as duration\n   */\n  transition?: number;\n  /**\n   * If set to false, stops the shuffling of the data\n   * before rendering.\n   */\n  shuffle?: boolean;\n  /**\n   * Defines the font-family and the font-weight for each text group\n   */\n  fontRendering?: {\n    label?: {\n      family?: string;\n      weight?: string;\n    };\n    counter?: {\n      family?: string;\n      weight?: string;\n    };\n  };\n\n  /**\n   * expose the draw function outside of n7-frontend/components library\n   * this is needed to redraw bubble-chart-component on command\n   */\n  setDraw?: any;\n}\n\n@Component({\n  selector: 'n7-bubble-chart',\n  templateUrl: './bubble-chart.html'\n})\nexport class BubbleChartComponent implements AfterContentChecked {\n  @Input() data: BubbleChartData;\n\n  @Input() emit: any;\n\n  private d3;\n\n  private _loaded = false;\n\n  ngAfterContentChecked() {\n    /*\n     Waits for the dom to be loaded, then fires the draw function\n     that renders the chart.\n    */\n    if (this.data) {\n      if (this._loaded) return;\n      this._loaded = true;\n      setTimeout(() => {\n        import('d3').then((module) => {\n          this.d3 = module;\n          this.draw();\n          if (this.data && this.data.setDraw) {\n            this.data.setDraw(this.draw);\n          }\n        });\n      });\n    }\n  }\n\n  onClick(payload) {\n    if (!this.emit) return;\n    this.emit('click', payload);\n  }\n\n  measureWidth = (text) => {\n    const context = document.createElement('canvas').getContext('2d');\n    // measure text with the correct font family and weight\n    if (this.data?.fontRendering?.label?.family && this.data?.fontRendering?.label?.weight) {\n      context.font = `${this.data.fontRendering.label.weight} ${this.data.fontRendering.label.family}`;\n    }\n    return context.measureText(text).width;\n  };\n\n  isValidNumber = (value) => !Number.isNaN(Number.parseFloat(value));\n\n  draw = () => {\n    const { d3 } = this;\n    const {\n      containerId, data, height,\n      width, selected, transition,\n      colorMatch, shuffle,\n      fontRendering\n    } = this.data;\n    const closeIconPath = 'M -50,40 L-40,50 0,10 40,50 50,40 10,0 50,-40 40,-50 0,-10 -40,-50 -50,-40 -10,0 -50,40';\n    const defaultLineHeight = 13;\n    const ellipsisThreshold = 4; // words\n    const textScalingFactor = 0.95;\n\n    if (!Array.isArray(data)) {\n      // Check if it is possible to draw with the current dataset\n      console.warn('(n7-bubble-chart) The data object is not in the expected format!');\n      return;\n    }\n\n    let t = d3\n      .transition()\n      .duration(0);\n    if (typeof transition === 'number') {\n      t = d3\n        .transition()\n        .duration(transition)\n        .ease(d3.easeCubicInOut);\n    }\n\n    const colorMap = d3.scaleOrdinal()\n      .domain(colorMatch ? colorMatch.domain : ['persona', 'luogo', 'organizzazione', 'cosa notevole'])\n      .range(colorMatch ? colorMatch.range : d3.schemeTableau10);\n\n    const sizeScale = d3 // map entity count to bubble size\n      .scaleLinear()\n      .domain([0, d3.max(data, (d) => +d.count)])\n      .range([3, d3.max(data, (d) => +d.count)]);\n\n    const pack = (children) => d3\n      .pack()\n      .size([width - 2, height - 2])\n      .padding(1.5)(\n        d3.hierarchy({ children }).sum((d) => sizeScale(d.count))\n      );\n\n    const root = () => { // if shuffle is undefined or true, shuffle the data\n      if (typeof shuffle === 'undefined' || shuffle) {\n        const shuffData = data.slice(); // do not modify the source data!\n        return pack(d3.shuffle(shuffData));\n      } // if shuffle is set to false, skip the data shuffle\n      return pack(data);\n    };\n\n    const svg = d3\n      .select(`#${containerId}`)\n      .attr('viewBox', [0, 0, width, height])\n      // .attr('font-family', 'Verdana, Geneva, sans-serif')\n      // .attr('font-size', '10px')\n      .style('font', '10px Verdana, Geneva, sans-serif')\n      .style('height', 'auto')\n      .style('max-width', '100%')\n      .attr('text-anchor', 'middle');\n\n    const leaf = svg.selectAll('g').data(root().leaves(), (d) => d.data.entity.id);\n    leaf\n      .transition(t) // update transition on <g>\n      .attr('fill-opacity', 1)\n      .attr('transform', (d) => `translate(${d.x + 1},${d.y + 1})`);\n    // .attr('font-size', (d) => {\n    //   let size = d.r / 5.5;\n    //   size *= 1;\n    //   size += 1;\n    //   return `${Math.round(size)}px`;\n    // });\n\n    leaf.selectAll('.close-icon').remove(); // clear all existing close icons\n    if (selected) {\n      leaf // render necessary close icons\n        .filter((d) => selected.includes(d.data.entity.id))\n        .append('path')\n        .attr('class', 'close-icon')\n        .attr('d', closeIconPath)\n        .attr('fill', '#fff')\n        .attr('transform', (d) => {\n          if (d.r / 4 > 3) {\n            return `scale(.08) translate(0, ${d.r * 10 - 80})`;\n          }\n          return 'scale(.08)';\n        });\n    }\n\n    leaf\n      .select('circle')\n      .transition(t) // update transition on <circle>\n      .attr('fill-opacity', 1)\n      .attr('r', (d) => d.r);\n\n    const g = leaf.enter().append('g');\n\n    g.attr('transform', (d) => `translate(${d.x + 1},${d.y + 1})`)\n      .attr('cursor', 'pointer')\n      .on('click', (event, d) => {\n        this.onClick(d.data.entity.id);\n      })\n      .attr('id', (d) => `g_${d.data.entity.id}`)\n      .append('circle')\n      .attr('id', (d) => { d.leafUid = d.data.entity.id; })\n      .attr('r', 0)\n      .transition(t) // enter() transition on <circle>\n      .attr('fill-opacity', 1)\n      .attr('fill', (d) => colorMap(d.data.entity.typeOfEntity))\n      .attr('r', (d) => d.r);\n\n    g.append('clipPath')\n      .attr('id', (d) => { d.clipUid = `Clip-${d.data.entity.id}`; })\n      .append('use')\n      .attr('xlink:href', (d) => d.leafUid.href);\n\n    // g.append('text')\n    //   .attr('font-family', () => {\n    //     if (fontRendering && fontRendering.label && fontRendering.label.family) {\n    //       return fontRendering.label.family;\n    //     }\n    //     return 'inherit';\n    //   })\n    //   .attr('font-weight', () => {\n    //     if (fontRendering && fontRendering\n    //         && fontRendering.label && fontRendering.label.weight) {\n    //       return fontRendering.label.weight;\n    //     }\n    //     return 'inherit';\n    //   })\n    //   .selectAll('tspan')\n    //   .data((d) => {\n    //     if (d.r / 4 > 4.5) {\n    //       // show text and number threshhold\n    //       let label = (\n    //         d.data.entity.label.charAt(0).toUpperCase()\n    //         + d.data.entity.label.slice(1)\n    //       ).split(/ +/g);\n    //       if (label.length > 3) {\n    //         label = label.slice(0, 3);\n    //         label[2] += '…';\n    //       }\n    //       return label;\n    //     } if (d.r / 4 > 2.5) {\n    //       // show text threshhold\n    //       let label = (\n    //         d.data.entity.label.charAt(0).toUpperCase()\n    //         + d.data.entity.label.slice(1)\n    //       ).split(/ +/g);\n    //       if (label.length > 3) {\n    //         label = label.slice(0, 3);\n    //         label[2] += '…';\n    //       }\n    //       return label;\n    //     }\n    //     return '';\n    //   })\n    //   .join('tspan')\n    //   .attr('x', 0)\n    //   .attr('y', (d, i, nodes) => `${i - (nodes.length + 1) / 2 + 0.97}em`)\n    //   .attr('fill', 'white')\n    //   .text((d) => d)\n    //   .attr('fill-opacity', 0)\n    //   .transition(t) // enter() transition on <tspan>\n    //   .attr('fill-opacity', 1);\n\n    // g.append('text') // Count label\n    //   .attr('class', 'label-count')\n    //   .attr('font-family', () => {\n    //     if (fontRendering && fontRendering.counter && fontRendering.counter.family) {\n    //       return fontRendering.counter.family;\n    //     }\n    //     return 'inherit';\n    //   })\n    //   .attr('font-weight', () => {\n    //     if (fontRendering && fontRendering.counter && fontRendering.counter.weight) {\n    //       return fontRendering.counter.weight;\n    //     }\n    //     return 'inherit';\n    //   })\n    //   .attr('fill', 'white')\n    //   .text((d) => {\n    //     if (d.r / 4 > 2.5) {\n    //       // show text and number threshhold\n    //       return d.data.count;\n    //     }\n    //     return '';\n    //   })\n    //   .attr('y', (d) => {\n    //     let labelLength = d.data.entity.label.split(/ +/g);\n    //     if (labelLength.length > 3) {\n    //       labelLength = labelLength.slice(0, 3);\n    //     }\n    //     return `${labelLength.length - (labelLength.length + 1) / 2 + 0.97}em`;\n    //   })\n    //   .attr('fill-opacity', 0)\n    //   .transition(t) // enter() transition on <text>\n    //   .attr('fill-opacity', 1);\n\n    /** NEW TEXT LOGIC */\n    g.append('text')\n      .attr('font-family', () => {\n        if (fontRendering && fontRendering.label && fontRendering.label.family) {\n          return fontRendering.label.family;\n        }\n        return 'inherit';\n      })\n      .attr('font-weight', () => {\n        if (fontRendering && fontRendering && fontRendering.label && fontRendering.label.weight) {\n          return fontRendering.label.weight;\n        }\n        return 'inherit';\n      })\n      .attr('fill', 'white')\n      .each((d: CircleNode) => {\n        // Capitalize the first letter of the label\n        d.data.entity.label = d.data.entity\n          .label.charAt(0).toUpperCase()\n          + d.data.entity.label.slice(1);\n        // 1. initialize meta object\n        if (!d._meta || typeof d._meta !== 'object') d._meta = {};\n        // 2. tokenize label & count into words\n        const words = d.data.entity.label.split(/\\s+/g); // To hyphenate: /\\s+|(?<=-)/\n        // Truncate with ellipsis if the label is longer than the threshold\n        if (words.length > ellipsisThreshold) {\n          words.splice(ellipsisThreshold, words.length - ellipsisThreshold);\n          words[ellipsisThreshold - 1] += '…';\n        }\n        // add counter\n        if (d.r / 4 > 2.5) {\n          // show text threshold\n          if (!words[words.length - 1]) words.pop();\n          if (!words[0]) words.shift();\n        } if (d.r / 4 > 4.5) {\n          // show number threshold\n          words.push(`${d.data.count}`);\n        }\n        d._meta.words = words;\n        d._meta.lineHeight = defaultLineHeight;\n        const targetWidth = Math.sqrt(\n          this.measureWidth(d._meta.words.join(' ').trim()) * defaultLineHeight\n        );\n        // 3. build lines of text\n        d._meta.lines = [];\n        let line;\n        let lineWidth0 = Infinity;\n        for (let i = 0, n = d._meta.words.length; i < n; i += 1) {\n          const lineText1 = (line ? `${line.text} ` : '') + words[i];\n          const lineWidth1 = this.measureWidth(lineText1);\n          if ((lineWidth0 + lineWidth1) / 2 < targetWidth && i !== n - 1) {\n            line.width = lineWidth0;\n            lineWidth0 = lineWidth1;\n            line.text = lineText1;\n          } else {\n            // if line is too long or this is the last line (counter), push to next line\n            lineWidth0 = this.measureWidth(words[i]);\n            line = { width: lineWidth0, text: words[i] };\n            d._meta.lines.push(line);\n          }\n        }\n        // 4. compute the bounding radius\n        let radius = 0;\n        for (let i = 0, n = d._meta.lines.length; i < n; i += 1) {\n          const dy = (Math.abs(i - n / 2) + 0.8) * d._meta.lineHeight;\n          const dx = d._meta.lines[i].width / 2;\n          radius = Math.max(radius, Math.sqrt(dx * dx + dy * dy));\n        }\n        d._meta.textRadius = radius;\n        return d;\n      })\n      .attr('transform', (d) => `scale(${(d.r / d._meta.textRadius) * textScalingFactor})`)\n      .filter((d) => (d.r / 4 > 2.5))\n      .selectAll('tspan')\n      .data((d) => d._meta.lines)\n      .enter()\n      .append('tspan')\n      .attr('x', 0)\n      .attr('y', (d, i, n) => (i - n.length / 2 + 0.8) * defaultLineHeight)\n      .attr('class', (d, i, n) => (\n        // if it's the last label and a valid number, mark as counter\n        i === n.length - 1 && this.isValidNumber(d.text) ? 'label-counter' : 'label-text'\n      ))\n      .text((d) => d.text)\n      .attr('fill-opacity', 0)\n      .transition(t) // enter() transition on <tspan>\n      .attr('fill-opacity', 1);\n\n    // custom style for the counter\n    g.selectAll('tspan.label-counter')\n      .attr('font-family', () => {\n        if (fontRendering && fontRendering.counter && fontRendering.counter.family) {\n          return fontRendering.counter.family;\n        }\n        return 'inherit';\n      })\n      .attr('font-weight', () => {\n        if (fontRendering && fontRendering.counter && fontRendering.counter.weight) {\n          return fontRendering.counter.weight;\n        }\n        return 'inherit';\n      });\n\n    leaf\n      .exit() // EXIT CYCLE\n      .remove();\n\n    if (selected) {\n      g.filter((d) => selected.includes(d.leafUid)) // append 'X' icon // only for selected bubbles\n        .append('path')\n        .attr('d', closeIconPath)\n        .attr('class', 'close-icon')\n        .attr('fill', (d) => {\n          if (d.r / 4 > 2.5) {\n            return '#fff';\n          }\n          return 'transparent';\n        })\n        .attr('transform', (d) => {\n          if (d.r / 4 > 3) {\n            return `scale(.08) translate(0, ${d.r * 10 - 80})`;\n          }\n          return 'scale(.08)';\n        });\n    }\n\n    this.emit('d3end', data); // communicate end of draw\n  };\n}\n","<div *ngIf=\"data\" class=\"n7-bubble-chart {{ data.classes || '' }}\">\n    <svg #bubbleChart id=\"{{data.containerId}}\"></svg>\n</div>"]}
|
|
315
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bubble-chart.js","sourceRoot":"","sources":["../../../../../../projects/dv-components-lib/src/lib/components/bubble-chart/bubble-chart.ts","../../../../../../projects/dv-components-lib/src/lib/components/bubble-chart/bubble-chart.html"],"names":[],"mappings":"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","sourcesContent":["//---------------------------\n// BUBBLECHART.ts\n//---------------------------\nimport { Component, Input, AfterContentChecked } from '@angular/core';\n\n/**\n * Interface for BubbleChartComponent's \"data\"\n *\n * @property containerId (required)\n * @property containerWidth (required)\n * @property containerHeight (required)\n * @property bubblesData (required)\n * @property isForceSimulationEnabled (required)\n * @property classes (optional)\n * @property reset (optional)\n*/\nexport interface BubbleChartData {\n  /**\n   * unique identifier for the bubble-chart\n   */\n  containerId: string;\n  /**\n   * total width for the bubble-chart\n   */\n  width: number;\n  /**\n   * total height for the bubble-chart\n   */\n  height: number;\n  /**\n   * data about the bubbles\n   */\n  data: BubbleChartDataItem[];\n  /**\n   * additional css classes\n   */\n  classes?: string;\n  /**\n   * list of ID's of selected items\n   * (selected items will render with a 'X' icon)\n   */\n  selected?: string[];\n  /**\n   * Specify a list of typeOfEntity types (domain),\n   * and a list of colors (range), which will be mapped together.\n   */\n  colorMatch?: {\n    domain: string[];\n    range: string[];\n  };\n  /**\n   * Define a max and min size for the bubbles\n   */\n  sizeRange: [number, number];\n  /**\n   * If defined, transition will be activated\n   * and the value will be used as duration\n   */\n  transition?: number;\n  /**\n   * If set to false, stops the shuffling of the data\n   * before rendering.\n   */\n  shuffle?: boolean;\n  /**\n   * Defines the font-family and the font-weight for each text group\n   */\n  fontRendering?: {\n    label?: {\n      family?: string;\n      weight?: string;\n    };\n    counter?: {\n      family?: string;\n      weight?: string;\n    };\n  };\n\n  /**\n   * expose the draw function outside of n7-frontend/components library\n   * this is needed to redraw bubble-chart-component on command\n   */\n  setDraw?: any;\n}\n\n/**\n * Interface for D3Chart's \"data\"\n *\n * @property entity (required)\n * - id (required)\n * - label (optional)\n * - typeOfEntity (optional)\n * @property count (required)\n*/\nexport interface BubbleChartDataItem {\n  entity: {\n    id: string;\n    label?: string;\n    typeOfEntity?: string;\n  };\n  count: number;\n}\n\n@Component({\n  selector: 'n7-bubble-chart',\n  templateUrl: './bubble-chart.html'\n})\nexport class BubbleChartComponent implements AfterContentChecked {\n  @Input() data: BubbleChartData;\n\n  @Input() emit: any;\n\n  private d3;\n\n  private _loaded = false;\n\n  ngAfterContentChecked() {\n    /*\n     Waits for the dom to be loaded, then fires the draw function\n     that renders the chart.\n    */\n    if (this.data) {\n      if (this._loaded) return;\n      this._loaded = true;\n      setTimeout(() => {\n        import('d3').then((module) => {\n          this.d3 = module;\n          this.draw();\n          if (this.data && this.data.setDraw) {\n            this.data.setDraw(this.draw);\n          }\n        });\n      });\n    }\n  }\n\n  onClick(payload) {\n    if (!this.emit) return;\n    this.emit('click', payload);\n  }\n\n  draw = () => {\n    const { d3 } = this;\n    const {\n      containerId, data, height,\n      width, selected, transition,\n      colorMatch, shuffle,\n      fontRendering\n    } = this.data;\n    const closeIconPath = 'M -50,40 L-40,50 0,10 40,50 50,40 10,0 50,-40 40,-50 0,-10 -40,-50 -50,-40 -10,0 -50,40';\n\n    if (!Array.isArray(data)) {\n      // Check if it is possible to draw with the current dataset\n      console.warn('(n7-bubble-chart) The data object is not in the expected format!');\n      return;\n    }\n\n    let t = d3\n      .transition()\n      .duration(0);\n    if (typeof transition === 'number') {\n      t = d3\n        .transition()\n        .duration(transition)\n        .ease(d3.easeCubicInOut);\n    }\n\n    const colorMap = d3.scaleOrdinal()\n      .domain(colorMatch ? colorMatch.domain : ['persona', 'luogo', 'organizzazione', 'cosa notevole'])\n      .range(colorMatch ? colorMatch.range : d3.schemeTableau10);\n\n    const sizeScale = d3 // map entity count to bubble size\n      .scaleLinear()\n      .domain([0, d3.max(data, (d) => +d.count)])\n      .range([3, d3.max(data, (d) => +d.count)]);\n\n    const pack = (children) => d3\n      .pack()\n      .size([width - 2, height - 2])\n      .padding(1.5)(\n        d3.hierarchy({ children }).sum((d) => sizeScale(d.count))\n      );\n\n    const root = () => { // if shuffle is undefined or true, shuffle the data\n      if (typeof shuffle === 'undefined' || shuffle) {\n        const shuffData = data.slice(); // do not modify the source data!\n        return pack(d3.shuffle(shuffData));\n      } // if shuffle is set to false, skip the data shuffle\n      return pack(data);\n    };\n\n    const svg = d3\n      .select(`#${containerId}`)\n      .attr('viewBox', [0, 0, width, height])\n      .attr('font-family', 'Verdana, Geneva, sans-serif')\n      .attr('text-anchor', 'middle');\n\n    const leaf = svg.selectAll('g').data(root().leaves(), (d) => d.data.entity.id);\n    leaf\n      .transition(t) // update transition on <g>\n      .attr('fill-opacity', 1)\n      .attr('transform', (d) => `translate(${d.x + 1},${d.y + 1})`)\n      .attr('font-size', (d) => {\n        let size = d.r / 5.5;\n        size *= 1;\n        size += 1;\n        return `${Math.round(size)}px`;\n      });\n\n    leaf.selectAll('.close-icon').remove(); // clear all existing close icons\n    if (selected) {\n      leaf // render necessary close icons\n        .filter((d) => selected.includes(d.data.entity.id))\n        .append('path')\n        .attr('class', 'close-icon')\n        .attr('d', closeIconPath)\n        .attr('fill', '#fff')\n        .attr('transform', (d) => {\n          if (d.r / 4 > 3) {\n            return `scale(.08) translate(0, ${d.r * 10 - 80})`;\n          }\n          return 'scale(.08)';\n        });\n    }\n\n    leaf\n      .select('circle')\n      .transition(t) // update transition on <circle>\n      .attr('fill-opacity', 1)\n      .attr('r', (d) => d.r);\n\n    leaf\n      .select('text')\n      .attr('font-family', () => {\n        if (fontRendering && fontRendering.label && fontRendering.label.family) {\n          return fontRendering.label.family;\n        }\n        return 'inherit';\n      })\n      .attr('font-weight', () => {\n        if (fontRendering && fontRendering.label && fontRendering.label.weight) {\n          return fontRendering.label.weight;\n        }\n        return 'inherit';\n      })\n      .selectAll('tspan')\n      .data((d) => {\n        if (d.r / 4 > 4.5) {\n          // show text and number threshhold\n          let label = (\n            d.data.entity.label.charAt(0).toUpperCase()\n            + d.data.entity.label.slice(1)\n          ).split(/ +/g);\n          if (label.length > 3) {\n            label = label.slice(0, 3);\n            label[2] += '…';\n          }\n          return label;\n        } if (d.r / 4 > 2.5) {\n          // show text threshhold\n          let label = (\n            d.data.entity.label.charAt(0).toUpperCase()\n            + d.data.entity.label.slice(1)\n          ).split(/ +/g);\n          if (label.length > 3) {\n            label = label.slice(0, 3);\n            label[2] += '…';\n          }\n          return label;\n        }\n        return '';\n      })\n      .join('tspan')\n      .attr('x', 0)\n      .attr('y', (d, i, nodes) => `${i - (nodes.length + 1) / 2 + 0.97}em`)\n      .attr('fill', 'white')\n      .text((d) => d);\n\n    leaf\n      .select('.label-count')\n      .attr('font-family', () => {\n        if (fontRendering && fontRendering.counter && fontRendering.counter.family) {\n          return fontRendering.counter.family;\n        }\n        return 'inherit';\n      })\n      .attr('font-weight', () => {\n        if (fontRendering && fontRendering.counter && fontRendering.counter.weight) {\n          return fontRendering.counter.weight;\n        }\n        return 'inherit';\n      })\n      .attr('fill', 'white')\n      .text((d) => {\n        if (d.r / 4 > 2.5) {\n          // show text and number threshhold\n          return d.data.count;\n        }\n        return '';\n      })\n      .attr('y', (d) => {\n        let labelLength = d.data.entity.label.split(/ +/g);\n        if (labelLength.length > 3) {\n          labelLength = labelLength.slice(0, 3);\n        }\n        return `${labelLength.length - (labelLength.length + 1) / 2 + 0.97}em`;\n      });\n\n\n    const g = leaf.enter().append('g');\n\n    g.attr('transform', (d) => `translate(${d.x + 1},${d.y + 1})`)\n      .attr('font-size', (d) => {\n        let size = d.r / 5.5;\n        size *= 1;\n        size += 1;\n        return `${Math.round(size)}px`;\n      })\n      .attr('cursor', 'pointer')\n      .on('click', (event, d) => {\n        this.onClick(d.data.entity.id);\n      })\n      .attr('id', (d) => `g_${d.data.entity.id}`)\n      .append('circle')\n      .attr('id', (d) => { d.leafUid = d.data.entity.id; })\n      .attr('r', 0)\n      .transition(t) // enter() transition on <circle>\n      .attr('fill-opacity', 1)\n      .attr('fill', (d) => colorMap(d.data.entity.typeOfEntity))\n      .attr('r', (d) => d.r);\n\n    g.append('clipPath')\n      .attr('id', (d) => { d.clipUid = `Clip-${d.data.entity.id}`; })\n      .append('use')\n      .attr('xlink:href', (d) => d.leafUid.href);\n\n    g.append('text')\n      .attr('font-family', () => {\n        if (fontRendering && fontRendering.label && fontRendering.label.family) {\n          return fontRendering.label.family;\n        }\n        return 'inherit';\n      })\n      .attr('font-weight', () => {\n        if (fontRendering && fontRendering && fontRendering.label && fontRendering.label.weight) {\n          return fontRendering.label.weight;\n        }\n        return 'inherit';\n      })\n      .selectAll('tspan')\n      .data((d) => {\n        if (d.r / 4 > 4.5) {\n          // show text and number threshhold\n          let label = (\n            d.data.entity.label.charAt(0).toUpperCase()\n            + d.data.entity.label.slice(1)\n          ).split(/ +/g);\n          if (label.length > 3) {\n            label = label.slice(0, 3);\n            label[2] += '…';\n          }\n          return label;\n        } if (d.r / 4 > 2.5) {\n          // show text threshhold\n          let label = (\n            d.data.entity.label.charAt(0).toUpperCase()\n            + d.data.entity.label.slice(1)\n          ).split(/ +/g);\n          if (label.length > 3) {\n            label = label.slice(0, 3);\n            label[2] += '…';\n          }\n          return label;\n        }\n        return '';\n      })\n      .join('tspan')\n      .attr('x', 0)\n      .attr('y', (d, i, nodes) => `${i - (nodes.length + 1) / 2 + 0.97}em`)\n      .attr('fill', 'white')\n      .text((d) => d)\n      .attr('fill-opacity', 0)\n      .transition(t) // enter() transition on <tspan>\n      .attr('fill-opacity', 1);\n\n    g.append('text') // Count label\n      .attr('class', 'label-count')\n      .attr('font-family', () => {\n        if (fontRendering && fontRendering.counter && fontRendering.counter.family) {\n          return fontRendering.counter.family;\n        }\n        return 'inherit';\n      })\n      .attr('font-weight', () => {\n        if (fontRendering && fontRendering.counter && fontRendering.counter.weight) {\n          return fontRendering.counter.weight;\n        }\n        return 'inherit';\n      })\n      .attr('fill', 'white')\n      .text((d) => {\n        if (d.r / 4 > 2.5) {\n          // show text and number threshhold\n          return d.data.count;\n        }\n        return '';\n      })\n      .attr('y', (d) => {\n        let labelLength = d.data.entity.label.split(/ +/g);\n        if (labelLength.length > 3) {\n          labelLength = labelLength.slice(0, 3);\n        }\n        return `${labelLength.length - (labelLength.length + 1) / 2 + 0.97}em`;\n      })\n      .attr('fill-opacity', 0)\n      .transition(t) // enter() transition on <text>\n      .attr('fill-opacity', 1);\n\n    leaf\n      .exit() // EXIT CYCLE\n      .remove();\n\n    if (selected) {\n      g.filter((d) => selected.includes(d.leafUid)) // append 'X' icon // only for selected bubbles\n        .append('path')\n        .attr('d', closeIconPath)\n        .attr('class', 'close-icon')\n        .attr('fill', (d) => {\n          if (d.r / 4 > 2.5) {\n            return '#fff';\n          }\n          return 'transparent';\n        })\n        .attr('transform', (d) => {\n          if (d.r / 4 > 3) {\n            return `scale(.08) translate(0, ${d.r * 10 - 80})`;\n          }\n          return 'scale(.08)';\n        });\n    }\n\n    this.emit('d3end', data); // communicate end of draw\n  }\n}\n","<div *ngIf=\"data\" class=\"n7-bubble-chart {{ data.classes || '' }}\">\n    <svg #bubbleChart id=\"{{data.containerId}}\"></svg>\n</div>"]}
|
|
@@ -12,13 +12,13 @@ export class InputTextComponent {
|
|
|
12
12
|
}
|
|
13
13
|
}
|
|
14
14
|
InputTextComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: InputTextComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
-
InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: InputTextComponent, selector: "n7-input-text", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div *ngIf=\"data as input\"\n class=\"n7-input-text\">\n <label *ngIf=\"input.label\"\n class=\"n7-input-text__label\"\n for=\"{{ input.id }}\" [innerHTML]=\"input.label\">\n </label>\n <div class=\"n7-input-text__wrapper\"\n [ngClass]=\"{\n 'has-icon': !!input.icon\n }\">\n <input id=\"{{ input.id }}\"\n class=\"n7-input-text__text {{input.classes || ''}}\"\n placeholder=\"{{input.placeholder || ''}}\"\n [type]=\"input.type ? input.type : 'text'\"\n [value]=\"input.value || null\"\n [disabled]=\"input.disabled\"\n [min]=\"input.type === 'number' && (input.min || input.min === 0) ? input.min : ''\"\n [max]=\"input.type === 'number' && (input.max || input.max === 0) ? input.max : ''\"\n (input)=\"onChange(input.inputPayload, $event.target.value)\"\n (keyup.enter)=\"onChange(input.enterPayload, $event.target.value)\">\n <span *ngIf=\"input.icon\"\n class=\"n7-input-text__icon {{input.icon || ''}}\"\n (click)=\"onChange(input.iconPayload)\">\n </span
|
|
15
|
+
InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: InputTextComponent, selector: "n7-input-text", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div *ngIf=\"data as input\"\n class=\"n7-input-text\">\n <label *ngIf=\"input.label\"\n class=\"n7-input-text__label\"\n for=\"{{ input.id }}\" [innerHTML]=\"input.label\">\n </label>\n <div class=\"n7-input-text__wrapper\"\n [ngClass]=\"{\n 'has-icon': !!input.icon\n }\">\n <input id=\"{{ input.id }}\"\n class=\"n7-input-text__text {{input.classes || ''}}\"\n placeholder=\"{{input.placeholder || ''}}\"\n [type]=\"input.type ? input.type : 'text'\"\n [value]=\"input.value || null\"\n [disabled]=\"input.disabled\"\n [min]=\"input.type === 'number' && (input.min || input.min === 0) ? input.min : ''\"\n [max]=\"input.type === 'number' && (input.max || input.max === 0) ? input.max : ''\"\n (input)=\"onChange(input.inputPayload, $event.target.value)\"\n (keyup.enter)=\"onChange(input.enterPayload, $event.target.value)\">\n <span *ngIf=\"input.icon\"\n class=\"n7-input-text__icon {{input.icon || ''}}\"\n (click)=\"onChange(input.iconPayload)\">\n </span> \n </div>\n</div>\n", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
|
|
16
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: InputTextComponent, decorators: [{
|
|
17
17
|
type: Component,
|
|
18
|
-
args: [{ selector: 'n7-input-text', template: "<div *ngIf=\"data as input\"\n class=\"n7-input-text\">\n <label *ngIf=\"input.label\"\n class=\"n7-input-text__label\"\n for=\"{{ input.id }}\" [innerHTML]=\"input.label\">\n </label>\n <div class=\"n7-input-text__wrapper\"\n [ngClass]=\"{\n 'has-icon': !!input.icon\n }\">\n <input id=\"{{ input.id }}\"\n class=\"n7-input-text__text {{input.classes || ''}}\"\n placeholder=\"{{input.placeholder || ''}}\"\n [type]=\"input.type ? input.type : 'text'\"\n [value]=\"input.value || null\"\n [disabled]=\"input.disabled\"\n [min]=\"input.type === 'number' && (input.min || input.min === 0) ? input.min : ''\"\n [max]=\"input.type === 'number' && (input.max || input.max === 0) ? input.max : ''\"\n (input)=\"onChange(input.inputPayload, $event.target.value)\"\n (keyup.enter)=\"onChange(input.enterPayload, $event.target.value)\">\n <span *ngIf=\"input.icon\"\n class=\"n7-input-text__icon {{input.icon || ''}}\"\n (click)=\"onChange(input.iconPayload)\">\n </span
|
|
18
|
+
args: [{ selector: 'n7-input-text', template: "<div *ngIf=\"data as input\"\n class=\"n7-input-text\">\n <label *ngIf=\"input.label\"\n class=\"n7-input-text__label\"\n for=\"{{ input.id }}\" [innerHTML]=\"input.label\">\n </label>\n <div class=\"n7-input-text__wrapper\"\n [ngClass]=\"{\n 'has-icon': !!input.icon\n }\">\n <input id=\"{{ input.id }}\"\n class=\"n7-input-text__text {{input.classes || ''}}\"\n placeholder=\"{{input.placeholder || ''}}\"\n [type]=\"input.type ? input.type : 'text'\"\n [value]=\"input.value || null\"\n [disabled]=\"input.disabled\"\n [min]=\"input.type === 'number' && (input.min || input.min === 0) ? input.min : ''\"\n [max]=\"input.type === 'number' && (input.max || input.max === 0) ? input.max : ''\"\n (input)=\"onChange(input.inputPayload, $event.target.value)\"\n (keyup.enter)=\"onChange(input.enterPayload, $event.target.value)\">\n <span *ngIf=\"input.icon\"\n class=\"n7-input-text__icon {{input.icon || ''}}\"\n (click)=\"onChange(input.iconPayload)\">\n </span> \n </div>\n</div>\n" }]
|
|
19
19
|
}], propDecorators: { data: [{
|
|
20
20
|
type: Input
|
|
21
21
|
}], emit: [{
|
|
22
22
|
type: Input
|
|
23
23
|
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2R2LWNvbXBvbmVudHMtbGliL3NyYy9saWIvY29tcG9uZW50cy9pbnB1dC10ZXh0L2lucHV0LXRleHQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kdi1jb21wb25lbnRzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsNkJBQTZCO0FBQzdCLGdCQUFnQjtBQUNoQiw2QkFBNkI7QUFFN0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQWdGakQsTUFBTSxPQUFPLGtCQUFrQjtJQUs3QixRQUFRLENBQUMsWUFBWSxFQUFFLEtBQU07UUFDM0IsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJO1lBQUUsT0FBTztRQUN2QixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQy9DLENBQUM7OytHQVJVLGtCQUFrQjttR0FBbEIsa0JBQWtCLDZGQ3BGL0IsOHBDQTBCQTsyRkQwRGEsa0JBQWtCO2tCQUo5QixTQUFTOytCQUNFLGVBQWU7OEJBSWhCLElBQUk7c0JBQVosS0FBSztnQkFFRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuLy8gSU5QVVQtVEVYVC50c1xuLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEludGVyZmFjZSBmb3IgSW5wdXRUZXh0RGF0YVxuICpcbiAqIEBwcm9wZXJ0eSBpZCAocmVxdWlyZWQpXG4gKiBAcHJvcGVydHkgcGxhY2Vob2xkZXIgKG9wdGlvbmFsKVxuICogQHByb3BlcnR5IHZhbHVlIChvcHRpb25hbClcbiAqIEBwcm9wZXJ0eSBsYWJlbCAob3B0aW9uYWwpXG4gKiBAcHJvcGVydHkgZGlzYWJsZWQgKG9wdGlvbmFsKVxuICogQHByb3BlcnR5IGljb24gKG9wdGlvbmFsKVxuICogQHByb3BlcnR5IGlucHV0UGF5bG9hZCAob3B0aW9uYWwpXG4gKiBAcHJvcGVydHkgZW50ZXJQYXlsb2FkIChvcHRpb25hbClcbiAqIEBwcm9wZXJ0eSBpY29uUGF5bG9hZCAob3B0aW9uYWwpXG4gKiBAcHJvcGVydHkgY2xhc3NlcyAob3B0aW9uYWwpXG4gKiBAcHJvcGVydHkgX21ldGEgKG9wdGlvbmFsKVxuICovXG5leHBvcnQgaW50ZXJmYWNlIElucHV0VGV4dERhdGEge1xuICAvKipcbiAgICogVW5pcXVlIElEIGZvciB0aGUgdGV4dCBpbnB1dCBlbGVtZW50XG4gICAqL1xuICBpZDogc3RyaW5nO1xuICAvKipcbiAgICogSW5wdXQgdHlwZVxuICAgKi9cbiAgdHlwZT86ICd0ZXh0JyB8ICdudW1iZXInO1xuICAvKipcbiAgICogUGxhY2Vob2xkZXIgdGV4dCBpbnNpZGUgdGhlIGlucHV0IGJveFxuICAgKi9cbiAgcGxhY2Vob2xkZXI/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBEZWZhdWx0IHZhbHVlIG9mIHRoZSBpbnB1dCBib3hcbiAgICovXG4gIHZhbHVlPzogc3RyaW5nIHwgbnVtYmVyIHwgbnVsbDtcbiAgLyoqXG4gICAqIExhYmVsIGZvciB0aGUgaW5wdXQgYm94XG4gICAqL1xuICBsYWJlbD86IHN0cmluZztcbiAgLyoqXG4gICAqIFByZXZlbnRzIHRoZSB1c2VyIGZyb20gY2hhbmdpbmcgdGhlIGlucHV0J3MgdmFsdWVcbiAgICovXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIE9wdGlvbmFsIGljb24gdG8gcmVuZGVyIGluc2lkZSB0aGUgaW5wdXQgYm94IChlZy4gbjctaWNvbi1zZWFyY2gpXG4gICAqL1xuICBpY29uPzogc3RyaW5nO1xuICAvKipcbiAgICogUGF5bG9hZCB0aGF0IGlzIHNlbnQgd2hlbiB0aGUgdXNlciBjaGFuZ2VzIHRoZSB2YWx1ZVxuICAgKi9cbiAgaW5wdXRQYXlsb2FkPzogYW55O1xuICAvKipcbiAgICogUGF5bG9hZCB0aGF0IGlzIHNlbnQgd2hlbiB0aGUgdXNlciBwcmVzc2VzIHRoZSBcIkVudGVyXCIga2V5XG4gICAqL1xuICBlbnRlclBheWxvYWQ/OiBhbnk7XG4gIC8qKlxuICAgKiBQYXlsb2FkIHRoYXQgaXMgc2VudCB3aGVuIHRoZSB1c2VyIGNsaWNrcyBvbiB0aGUgaWNvblxuICAgKi9cbiAgaWNvblBheWxvYWQ/OiBhbnk7XG4gIC8qKlxuICAgKiBJbnB1dCBtaW5pbXVuIGFsbG93ZWQgdmFsdWUgKG9ubHkgZm9yIHR5cGU9bnVtYmVyKVxuICAgKi9cbiAgbWluPzogbnVtYmVyO1xuICAvKipcbiAgICogSW5wdXQgbWF4aW11biBhbGxvd2VkIHZhbHVlIChvbmx5IGZvciB0eXBlPW51bWJlcilcbiAgICovXG4gIG1heD86IG51bWJlcjtcbiAgLyoqXG4gICAqIEFkZGl0aW9uYWwgSFRNTCBDbGFzc2VzXG4gICAqL1xuICBjbGFzc2VzPzogYW55O1xuICAvKipcbiAgICogQWRkaXRpb25hbCBkYXRhIGZvciB0aGUgY29tcG9uZW50J3MgbG9naWNcbiAgICovXG4gIF9tZXRhPzogYW55O1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduNy1pbnB1dC10ZXh0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2lucHV0LXRleHQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgSW5wdXRUZXh0Q29tcG9uZW50IHtcbiAgQElucHV0KCkgZGF0YTogSW5wdXRUZXh0RGF0YTtcblxuICBASW5wdXQoKSBlbWl0OiBhbnk7XG5cbiAgb25DaGFuZ2UoaW5wdXRQYXlsb2FkLCB2YWx1ZT8pIHtcbiAgICBpZiAoIXRoaXMuZW1pdCkgcmV0dXJuO1xuICAgIHRoaXMuZW1pdCgnY2hhbmdlJywgeyBpbnB1dFBheWxvYWQsIHZhbHVlIH0pO1xuICB9XG59XG4iLCI8ZGl2ICpuZ0lmPVwiZGF0YSBhcyBpbnB1dFwiXG4gICAgIGNsYXNzPVwibjctaW5wdXQtdGV4dFwiPlxuICAgIDxsYWJlbCAqbmdJZj1cImlucHV0LmxhYmVsXCJcbiAgICAgICAgY2xhc3M9XCJuNy1pbnB1dC10ZXh0X19sYWJlbFwiXG4gICAgICAgIGZvcj1cInt7IGlucHV0LmlkIH19XCIgW2lubmVySFRNTF09XCJpbnB1dC5sYWJlbFwiPlxuICAgIDwvbGFiZWw+XG4gICAgPGRpdiBjbGFzcz1cIm43LWlucHV0LXRleHRfX3dyYXBwZXJcIlxuICAgICAgICBbbmdDbGFzc109XCJ7XG4gICAgICAgICAgICAnaGFzLWljb24nOiAhIWlucHV0Lmljb25cbiAgICAgICAgfVwiPlxuICAgICAgICA8aW5wdXQgaWQ9XCJ7eyBpbnB1dC5pZCB9fVwiXG4gICAgICAgICAgICBjbGFzcz1cIm43LWlucHV0LXRleHRfX3RleHQge3tpbnB1dC5jbGFzc2VzIHx8ICcnfX1cIlxuICAgICAgICAgICAgcGxhY2Vob2xkZXI9XCJ7e2lucHV0LnBsYWNlaG9sZGVyIHx8ICcnfX1cIlxuICAgICAgICAgICAgW3R5cGVdPVwiaW5wdXQudHlwZSA/IGlucHV0LnR5cGUgOiAndGV4dCdcIlxuICAgICAgICAgICAgW3ZhbHVlXT1cImlucHV0LnZhbHVlIHx8IG51bGxcIlxuICAgICAgICAgICAgW2Rpc2FibGVkXT1cImlucHV0LmRpc2FibGVkXCJcbiAgICAgICAgICAgIFttaW5dPVwiaW5wdXQudHlwZSA9PT0gJ251bWJlcicgJiYgKGlucHV0Lm1pbiB8fCBpbnB1dC5taW4gPT09IDApID8gaW5wdXQubWluIDogJydcIlxuICAgICAgICAgICAgW21heF09XCJpbnB1dC50eXBlID09PSAnbnVtYmVyJyAmJiAoaW5wdXQubWF4IHx8IGlucHV0Lm1heCA9PT0gMCkgPyBpbnB1dC5tYXggOiAnJ1wiXG4gICAgICAgICAgICAoaW5wdXQpPVwib25DaGFuZ2UoaW5wdXQuaW5wdXRQYXlsb2FkLCAkZXZlbnQudGFyZ2V0LnZhbHVlKVwiXG4gICAgICAgICAgICAoa2V5dXAuZW50ZXIpPVwib25DaGFuZ2UoaW5wdXQuZW50ZXJQYXlsb2FkLCAkZXZlbnQudGFyZ2V0LnZhbHVlKVwiPlxuICAgICAgICA8c3BhbiAqbmdJZj1cImlucHV0Lmljb25cIlxuICAgICAgICAgICAgY2xhc3M9XCJuNy1pbnB1dC10ZXh0X19pY29uIHt7aW5wdXQuaWNvbiB8fCAnJ319XCJcbiAgICAgICAgICAgIChjbGljayk9XCJvbkNoYW5nZShpbnB1dC5pY29uUGF5bG9hZClcIj5cbiAgICAgICAgPC9zcGFuPiBcbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class InputTextareaComponent {
|
|
5
|
+
onChange(inputPayload, value) {
|
|
6
|
+
if (!this.emit)
|
|
7
|
+
return;
|
|
8
|
+
this.emit('change', { inputPayload, value });
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
InputTextareaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: InputTextareaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
InputTextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: InputTextareaComponent, selector: "n7-frontend-components-input-textarea", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div *ngIf=\"data as input\"\n class=\"n7-input-textarea\">\n <label *ngIf=\"input.label\"\n class=\"n7-input-textarea__label\"\n for=\"{{ input.id }}\"\n [innerHTML]=\"input.label\">\n </label>\n <div class=\"n7-input-textarea__wrapper\"\n [ngClass]=\"{\n 'has-icon': !!input.icon\n }\">\n <textarea id=\"{{ input.id }}\"\n type=\"textarea\"\n class=\"n7-input-textarea__text {{input.classes || ''}}\"\n placeholder=\"{{input.placeholder || ''}}\"\n [value]=\"input.value || null\"\n [disabled]=\"input.disabled\"\n (input)=\"onChange(input.inputPayload, $event.target.value)\"\n (keyup.enter)=\"onChange(input.enterPayload, $event.target.value)\">\n </textarea>\n </div>\n</div>\n", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: InputTextareaComponent, decorators: [{
|
|
14
|
+
type: Component,
|
|
15
|
+
args: [{ selector: 'n7-frontend-components-input-textarea', template: "<div *ngIf=\"data as input\"\n class=\"n7-input-textarea\">\n <label *ngIf=\"input.label\"\n class=\"n7-input-textarea__label\"\n for=\"{{ input.id }}\"\n [innerHTML]=\"input.label\">\n </label>\n <div class=\"n7-input-textarea__wrapper\"\n [ngClass]=\"{\n 'has-icon': !!input.icon\n }\">\n <textarea id=\"{{ input.id }}\"\n type=\"textarea\"\n class=\"n7-input-textarea__text {{input.classes || ''}}\"\n placeholder=\"{{input.placeholder || ''}}\"\n [value]=\"input.value || null\"\n [disabled]=\"input.disabled\"\n (input)=\"onChange(input.inputPayload, $event.target.value)\"\n (keyup.enter)=\"onChange(input.enterPayload, $event.target.value)\">\n </textarea>\n </div>\n</div>\n" }]
|
|
16
|
+
}], propDecorators: { data: [{
|
|
17
|
+
type: Input
|
|
18
|
+
}], emit: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}] } });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dGFyZWEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kdi1jb21wb25lbnRzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvaW5wdXQtdGV4dGFyZWEvaW5wdXQtdGV4dGFyZWEudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kdi1jb21wb25lbnRzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvaW5wdXQtdGV4dGFyZWEvaW5wdXQtdGV4dGFyZWEuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBK0JqRCxNQUFNLE9BQU8sc0JBQXNCO0lBS2pDLFFBQVEsQ0FBQyxZQUFZLEVBQUUsS0FBTTtRQUMzQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUk7WUFBRSxPQUFPO1FBQ3ZCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDL0MsQ0FBQzs7bUhBUlUsc0JBQXNCO3VHQUF0QixzQkFBc0IscUhDL0JuQyxvMkJBc0JBOzJGRFNhLHNCQUFzQjtrQkFKbEMsU0FBUzsrQkFDRSx1Q0FBdUM7OEJBSXhDLElBQUk7c0JBQVosS0FBSztnQkFFRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCB0eXBlIElucHV0VGV4dGFyZWFEYXRhID0ge1xuICAvKiogVW5pcXVlIElEIGZvciB0aGUgdGV4dCBpbnB1dCBlbGVtZW50ICovXG4gIGlkOiBzdHJpbmc7XG4gIC8qKiBQbGFjZWhvbGRlciB0ZXh0IGluc2lkZSB0aGUgdGV4dGFyZWEgKi9cbiAgcGxhY2Vob2xkZXI/OiBzdHJpbmc7XG4gIC8qKiBEZWZhdWx0IHZhbHVlIG9mIHRoZSB0ZXh0YXJlYSAqL1xuICB2YWx1ZT86IHN0cmluZyB8IG51bWJlciB8IG51bGw7XG4gIC8qKiBMYWJlbCBmb3IgdGhlIHRleHRhcmVhICovXG4gIGxhYmVsPzogc3RyaW5nO1xuICAvKiogUHJldmVudHMgdGhlIHVzZXIgZnJvbSBjaGFuZ2luZyB0aGUgaW5wdXQncyB2YWx1ZSAqL1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKiBPcHRpb25hbCBpY29uIHRvIHJlbmRlciBpbnNpZGUgdGhlIHRleHRhcmVhIChlZy4gbjctaWNvbi1zZWFyY2gpICovXG4gIC8vIGljb24/OiBzdHJpbmc7XG4gIC8qKiBQYXlsb2FkIHRoYXQgaXMgc2VudCB3aGVuIHRoZSB1c2VyIGNoYW5nZXMgdGhlIHZhbHVlICovXG4gIGlucHV0UGF5bG9hZD86IGFueTtcbiAgLyoqIFBheWxvYWQgdGhhdCBpcyBzZW50IHdoZW4gdGhlIHVzZXIgcHJlc3NlcyB0aGUgXCJFbnRlclwiIGtleSAqL1xuICBlbnRlclBheWxvYWQ/OiBhbnk7XG4gIC8qKiBQYXlsb2FkIHRoYXQgaXMgc2VudCB3aGVuIHRoZSB1c2VyIGNsaWNrcyBvbiB0aGUgaWNvbiAqL1xuICBpY29uUGF5bG9hZD86IGFueTtcbiAgLyoqIEFkZGl0aW9uYWwgSFRNTCBDbGFzc2VzICovXG4gIGNsYXNzZXM/OiBhbnk7XG4gIC8qKiBBZGRpdGlvbmFsIGRhdGEgZm9yIHRoZSBjb21wb25lbnQncyBsb2dpYyAqL1xuICBfbWV0YT86IGFueTtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbjctZnJvbnRlbmQtY29tcG9uZW50cy1pbnB1dC10ZXh0YXJlYScsXG4gIHRlbXBsYXRlVXJsOiAnLi9pbnB1dC10ZXh0YXJlYS5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBJbnB1dFRleHRhcmVhQ29tcG9uZW50IHtcbiAgQElucHV0KCkgZGF0YTogSW5wdXRUZXh0YXJlYURhdGE7XG5cbiAgQElucHV0KCkgZW1pdDogKHR5cGU6IHN0cmluZywgcGF5bG9hZD86IHVua25vd24pID0+IHZvaWQ7XG5cbiAgb25DaGFuZ2UoaW5wdXRQYXlsb2FkLCB2YWx1ZT8pIHtcbiAgICBpZiAoIXRoaXMuZW1pdCkgcmV0dXJuO1xuICAgIHRoaXMuZW1pdCgnY2hhbmdlJywgeyBpbnB1dFBheWxvYWQsIHZhbHVlIH0pO1xuICB9XG59XG4iLCI8ZGl2ICpuZ0lmPVwiZGF0YSBhcyBpbnB1dFwiXG4gICAgIGNsYXNzPVwibjctaW5wdXQtdGV4dGFyZWFcIj5cbiAgICA8bGFiZWwgKm5nSWY9XCJpbnB1dC5sYWJlbFwiXG4gICAgICAgICAgIGNsYXNzPVwibjctaW5wdXQtdGV4dGFyZWFfX2xhYmVsXCJcbiAgICAgICAgICAgZm9yPVwie3sgaW5wdXQuaWQgfX1cIlxuICAgICAgICAgICBbaW5uZXJIVE1MXT1cImlucHV0LmxhYmVsXCI+XG4gICAgPC9sYWJlbD5cbiAgICA8ZGl2IGNsYXNzPVwibjctaW5wdXQtdGV4dGFyZWFfX3dyYXBwZXJcIlxuICAgICAgICAgW25nQ2xhc3NdPVwie1xuICAgICAgICAgICAgJ2hhcy1pY29uJzogISFpbnB1dC5pY29uXG4gICAgICAgIH1cIj5cbiAgICAgICAgPHRleHRhcmVhIGlkPVwie3sgaW5wdXQuaWQgfX1cIlxuICAgICAgICAgICAgICAgdHlwZT1cInRleHRhcmVhXCJcbiAgICAgICAgICAgICAgIGNsYXNzPVwibjctaW5wdXQtdGV4dGFyZWFfX3RleHQge3tpbnB1dC5jbGFzc2VzIHx8ICcnfX1cIlxuICAgICAgICAgICAgICAgcGxhY2Vob2xkZXI9XCJ7e2lucHV0LnBsYWNlaG9sZGVyIHx8ICcnfX1cIlxuICAgICAgICAgICAgICAgW3ZhbHVlXT1cImlucHV0LnZhbHVlIHx8IG51bGxcIlxuICAgICAgICAgICAgICAgW2Rpc2FibGVkXT1cImlucHV0LmRpc2FibGVkXCJcbiAgICAgICAgICAgICAgIChpbnB1dCk9XCJvbkNoYW5nZShpbnB1dC5pbnB1dFBheWxvYWQsICRldmVudC50YXJnZXQudmFsdWUpXCJcbiAgICAgICAgICAgICAgIChrZXl1cC5lbnRlcik9XCJvbkNoYW5nZShpbnB1dC5lbnRlclBheWxvYWQsICRldmVudC50YXJnZXQudmFsdWUpXCI+XG4gICAgICAgIDwvdGV4dGFyZWE+XG4gICAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|