@net7/components 3.1.0 → 3.1.1

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.
Files changed (49) hide show
  1. package/esm2020/lib/components/advanced-autocomplete/advanced-autocomplete.mjs +3 -3
  2. package/esm2020/lib/components/alert/alert.mjs +3 -3
  3. package/esm2020/lib/components/anchor-wrapper/anchor-wrapper.mjs +3 -3
  4. package/esm2020/lib/components/breadcrumbs/breadcrumbs.mjs +3 -3
  5. package/esm2020/lib/components/bubble-chart/bubble-chart.mjs +179 -134
  6. package/esm2020/lib/components/carousel/carousel.mjs +3 -3
  7. package/esm2020/lib/components/chart/chart.mjs +3 -3
  8. package/esm2020/lib/components/content-placeholder/content-placeholder.mjs +3 -3
  9. package/esm2020/lib/components/data-widget/data-widget.mjs +3 -3
  10. package/esm2020/lib/components/datepicker/datepicker.mjs +3 -3
  11. package/esm2020/lib/components/facet/facet.mjs +3 -3
  12. package/esm2020/lib/components/facet-header/facet-header.mjs +3 -3
  13. package/esm2020/lib/components/facet-year-range/facet-year-range.mjs +3 -3
  14. package/esm2020/lib/components/footer/footer.mjs +3 -3
  15. package/esm2020/lib/components/header/header.mjs +3 -3
  16. package/esm2020/lib/components/hero/hero.mjs +3 -3
  17. package/esm2020/lib/components/histogram-range/histogram-range.mjs +3 -3
  18. package/esm2020/lib/components/image-viewer/image-viewer.mjs +3 -3
  19. package/esm2020/lib/components/image-viewer-tools/image-viewer-tools.mjs +5 -5
  20. package/esm2020/lib/components/inner-title/inner-title.mjs +3 -3
  21. package/esm2020/lib/components/input-checkbox/input-checkbox.mjs +5 -5
  22. package/esm2020/lib/components/input-link/input-link.mjs +3 -3
  23. package/esm2020/lib/components/input-select/input-select.mjs +5 -5
  24. package/esm2020/lib/components/input-text/input-text.mjs +5 -5
  25. package/esm2020/lib/components/item-preview/item-preview.mjs +3 -3
  26. package/esm2020/lib/components/loader/loader.mjs +3 -3
  27. package/esm2020/lib/components/map/map.mjs +3 -3
  28. package/esm2020/lib/components/metadata-viewer/metadata-viewer.mjs +3 -3
  29. package/esm2020/lib/components/nav/nav.mjs +3 -3
  30. package/esm2020/lib/components/pagination/pagination.mjs +3 -3
  31. package/esm2020/lib/components/progress-line/progress-line.mjs +3 -3
  32. package/esm2020/lib/components/sidebar-header/sidebar-header.mjs +3 -3
  33. package/esm2020/lib/components/signup/signup.mjs +3 -3
  34. package/esm2020/lib/components/simple-autocomplete/simple-autocomplete.mjs +3 -3
  35. package/esm2020/lib/components/table/table.mjs +3 -3
  36. package/esm2020/lib/components/tag/tag.mjs +3 -3
  37. package/esm2020/lib/components/text-viewer/text-viewer.mjs +3 -3
  38. package/esm2020/lib/components/timeline/timeline.mjs +3 -3
  39. package/esm2020/lib/components/toast/toast.mjs +3 -3
  40. package/esm2020/lib/components/tooltip-content/tooltip-content.mjs +3 -3
  41. package/esm2020/lib/components/tree/tree.mjs +3 -3
  42. package/esm2020/lib/components/wizard/wizard.mjs +3 -3
  43. package/esm2020/lib/dv-components-lib.module.mjs +4 -4
  44. package/fesm2015/net7-components.mjs +310 -264
  45. package/fesm2015/net7-components.mjs.map +1 -1
  46. package/fesm2020/net7-components.mjs +309 -264
  47. package/fesm2020/net7-components.mjs.map +1 -1
  48. package/lib/components/bubble-chart/bubble-chart.d.ts +36 -17
  49. package/package.json +1 -1
@@ -7,10 +7,22 @@ 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));
10
19
  this.draw = () => {
11
20
  const { d3 } = this;
12
21
  const { containerId, data, height, width, selected, transition, colorMatch, shuffle, fontRendering } = this.data;
13
22
  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;
14
26
  if (!Array.isArray(data)) {
15
27
  // Check if it is possible to draw with the current dataset
16
28
  console.warn('(n7-bubble-chart) The data object is not in the expected format!');
@@ -46,19 +58,23 @@ export class BubbleChartComponent {
46
58
  const svg = d3
47
59
  .select(`#${containerId}`)
48
60
  .attr('viewBox', [0, 0, width, height])
49
- .attr('font-family', 'Verdana, Geneva, sans-serif')
61
+ // .attr('font-family', 'Verdana, Geneva, sans-serif')
62
+ // .attr('font-size', '10px')
63
+ .style('font', '10px Verdana, Geneva, sans-serif')
64
+ .style('height', 'auto')
65
+ .style('max-width', '100%')
50
66
  .attr('text-anchor', 'middle');
51
67
  const leaf = svg.selectAll('g').data(root().leaves(), (d) => d.data.entity.id);
52
68
  leaf
53
69
  .transition(t) // update transition on <g>
54
70
  .attr('fill-opacity', 1)
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
- });
71
+ .attr('transform', (d) => `translate(${d.x + 1},${d.y + 1})`);
72
+ // .attr('font-size', (d) => {
73
+ // let size = d.r / 5.5;
74
+ // size *= 1;
75
+ // size += 1;
76
+ // return `${Math.round(size)}px`;
77
+ // });
62
78
  leaf.selectAll('.close-icon').remove(); // clear all existing close icons
63
79
  if (selected) {
64
80
  leaf // render necessary close icons
@@ -79,86 +95,8 @@ export class BubbleChartComponent {
79
95
  .transition(t) // update transition on <circle>
80
96
  .attr('fill-opacity', 1)
81
97
  .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
- });
154
98
  const g = leaf.enter().append('g');
155
99
  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
- })
162
100
  .attr('cursor', 'pointer')
163
101
  .on('click', (event, d) => {
164
102
  this.onClick(d.data.entity.id);
@@ -175,6 +113,88 @@ export class BubbleChartComponent {
175
113
  .attr('id', (d) => { d.clipUid = `Clip-${d.data.entity.id}`; })
176
114
  .append('use')
177
115
  .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 */
178
198
  g.append('text')
179
199
  .attr('font-family', () => {
180
200
  if (fontRendering && fontRendering.label && fontRendering.label.family) {
@@ -188,40 +208,83 @@ export class BubbleChartComponent {
188
208
  }
189
209
  return 'inherit';
190
210
  })
191
- .selectAll('tspan')
192
- .data((d) => {
193
- if (d.r / 4 > 4.5) {
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] += '…';
200
- }
201
- return label;
211
+ .attr('fill', 'white')
212
+ .each((d) => {
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] += '…';
202
226
  }
227
+ // add counter
203
228
  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] += '…';
229
+ // show text threshold
230
+ if (!words[words.length - 1])
231
+ words.pop();
232
+ if (!words[0])
233
+ words.shift();
234
+ }
235
+ if (d.r / 4 > 4.5) {
236
+ // show number threshold
237
+ words.push(`${d.data.count}`);
238
+ }
239
+ d._meta.words = words;
240
+ d._meta.lineHeight = defaultLineHeight;
241
+ const targetWidth = Math.sqrt(this.measureWidth(d._meta.words.join(' ').trim()) * defaultLineHeight);
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;
210
253
  }
211
- return label;
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);
259
+ }
260
+ }
261
+ // 4. compute the bounding radius
262
+ let radius = 0;
263
+ for (let i = 0, n = d._meta.lines.length; i < n; i += 1) {
264
+ const dy = (Math.abs(i - n / 2) + 0.8) * d._meta.lineHeight;
265
+ const dx = d._meta.lines[i].width / 2;
266
+ radius = Math.max(radius, Math.sqrt(dx * dx + dy * dy));
212
267
  }
213
- return '';
268
+ d._meta.textRadius = radius;
269
+ return d;
214
270
  })
215
- .join('tspan')
271
+ .attr('transform', (d) => `scale(${(d.r / d._meta.textRadius) * textScalingFactor})`)
272
+ .filter((d) => (d.r / 4 > 2.5))
273
+ .selectAll('tspan')
274
+ .data((d) => d._meta.lines)
275
+ .enter()
276
+ .append('tspan')
216
277
  .attr('x', 0)
217
- .attr('y', (d, i, nodes) => `${i - (nodes.length + 1) / 2 + 0.97}em`)
218
- .attr('fill', 'white')
219
- .text((d) => d)
278
+ .attr('y', (d, i, n) => (i - n.length / 2 + 0.8) * defaultLineHeight)
279
+ .attr('class', (d, i, n) => (
280
+ // if it's the last label and a valid number, mark as counter
281
+ i === n.length - 1 && this.isValidNumber(d.text) ? 'label-counter' : 'label-text'))
282
+ .text((d) => d.text)
220
283
  .attr('fill-opacity', 0)
221
284
  .transition(t) // enter() transition on <tspan>
222
285
  .attr('fill-opacity', 1);
223
- g.append('text') // Count label
224
- .attr('class', 'label-count')
286
+ // custom style for the counter
287
+ g.selectAll('tspan.label-counter')
225
288
  .attr('font-family', () => {
226
289
  if (fontRendering && fontRendering.counter && fontRendering.counter.family) {
227
290
  return fontRendering.counter.family;
@@ -233,25 +296,7 @@ export class BubbleChartComponent {
233
296
  return fontRendering.counter.weight;
234
297
  }
235
298
  return 'inherit';
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);
299
+ });
255
300
  leaf
256
301
  .exit() // EXIT CYCLE
257
302
  .remove();
@@ -302,9 +347,9 @@ export class BubbleChartComponent {
302
347
  this.emit('click', payload);
303
348
  }
304
349
  }
305
- BubbleChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: BubbleChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
306
- BubbleChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: BubbleChartComponent, selector: "n7-bubble-chart", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div *ngIf=\"data\" class=\"n7-bubble-chart {{ data.classes || '' }}\">\n <svg #bubbleChart id=\"{{data.containerId}}\"></svg>\n</div>", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
307
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: BubbleChartComponent, decorators: [{
350
+ BubbleChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: BubbleChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
351
+ BubbleChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: BubbleChartComponent, selector: "n7-bubble-chart", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div *ngIf=\"data\" class=\"n7-bubble-chart {{ data.classes || '' }}\">\n <svg #bubbleChart id=\"{{data.containerId}}\"></svg>\n</div>", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
352
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: BubbleChartComponent, decorators: [{
308
353
  type: Component,
309
354
  args: [{ selector: 'n7-bubble-chart', template: "<div *ngIf=\"data\" class=\"n7-bubble-chart {{ data.classes || '' }}\">\n <svg #bubbleChart id=\"{{data.containerId}}\"></svg>\n</div>" }]
310
355
  }], propDecorators: { data: [{
@@ -312,4 +357,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
312
357
  }], emit: [{
313
358
  type: Input
314
359
  }] } });
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>"]}
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":"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","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>"]}
@@ -76,9 +76,9 @@ export class CarouselComponent {
76
76
  });
77
77
  }
78
78
  }
79
- CarouselComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CarouselComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
80
- CarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: CarouselComponent, selector: "n7-carousel", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<button *ngIf=\"data && data.classes === 'demo'\"\n class=\"n7-btn\"\n (click)=\"api.load.videos()\">api.load.videos()</button>\n\n<div *ngIf=\"data\"\n class=\"n7-carousel {{ data.classes || '' }}\">\n <!-- Warning: Do not style div.latte-carousel -->\n <div id=\"{{data.containerId}}\"\n class=\"latte-carousel\">\n <ng-container *ngFor=\"let slide of data.slides; let index = index;\">\n <ng-container *ngTemplateOutlet=\"carouselSlide; context:{slide: slide, index: index}\"></ng-container>\n </ng-container>\n </div>\n</div>\n\n<!-- ===== SLIDE WRAPPER ===== -->\n<ng-template #carouselSlide\n let-slide=\"slide\"\n let-slideID=\"index\">\n <!-- Warning: Do not style div.latte-item -->\n <div class=\"latte-item\">\n <div class=\"n7-carousel__slide {{ slide.classes || ''}}\"\n [ngClass]=\"{ 'has-image' : slide.background.image, 'has-video': slide.background.video }\"\n [style.background-color]=\"slide.background.color ? slide.background.color : ''\"\n [style.background-image]=\"slide.background.image ? 'url('+slide.background.image+')' : ''\">\n <div class=\"n7-carousel__slide-content-wrapper\">\n <div class=\"n7-carousel__slide-content\">\n <div class=\"n7-carousel__slide-content-left\">\n <ng-container *ngTemplateOutlet=\"slideForeground; context:{items: slide.items, slideID: slideID}\">\n </ng-container>\n </div>\n <div class=\"n7-carousel__slide-content-right\"\n *ngIf=\"slide.action\">\n <n7-anchor-wrapper [data]=\"slide.action.anchor\"\n (clicked)=\"onClick($event)\">\n <!-- Button ID's are used to dynamically reattach events after loading the carousel -->\n <button id=\"{{data.containerId}}-{{slideID}}\"\n class=\"n7-hero__btn n7-btn n7-btn-cta n7-btn-l\">\n {{slide.action.text}}\n </button>\n </n7-anchor-wrapper>\n </div>\n </div>\n </div>\n <ng-container *ngIf=\"slide.background\">\n <ng-container *ngTemplateOutlet=\"slideBackground; context:{$implicit: slide.background}\">\n </ng-container>\n </ng-container>\n </div>\n </div>\n</ng-template>\n\n<!-- ===== SLIDE FOREGROUND ===== -->\n<ng-template #slideForeground\n let-items=\"items\"\n let-slideID=\"slideID\">\n <ng-container *ngFor=\"let el of items; let itemID = index\">\n <h1 class=\"n7-carousel__slide-title\"\n *ngIf=\"el.title\">{{el.title}}</h1>\n <div class=\"n7-carousel__slide-text\"\n *ngIf=\"el.text\" [innerHTML]=\"el.text\"></div>\n <div class=\"n7-carousel__slide-metadata-wrapper\"\n *ngIf=\"el.metadata\">\n <ng-container *ngFor=\"let m of el.metadata\">\n <div class=\"n7-carousel__slide-metadata\">\n <span class=\"n7-carousel__slide-metadata-label\"\n *ngIf=\"m.key\">{{m.key}}</span>\n <span class=\"n7-carousel__slide-metadata-value\"\n *ngIf=\"m.value\">{{m.value}}</span>\n </div>\n </ng-container>\n </div>\n </ng-container>\n</ng-template>\n\n<!-- ===== VIDEO BACKGROUND ===== -->\n<ng-template #slideBackground\n let-bg>\n <ng-container *ngIf=\"bg.video as v\">\n <video #video\n class=\"n7-carousel__slide-video\"\n [poster]=\"v.poster\"\n [height]=\"v.height\"\n [width]=\"v.width\"\n loop\n muted\n autoplay\n playsinline>\n <source #source\n class=\"lazy\"\n [attr.data-src]=\"v.url\"\n type=\"video/mp4\">\n </video>\n <div class=\"n7-carousel__slide-video-overlay\">\n\n </div>\n </ng-container>\n</ng-template>\n", components: [{ type: i1.AnchorWrapperComponent, selector: "n7-anchor-wrapper", inputs: ["data", "classes"], outputs: ["clicked"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
81
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CarouselComponent, decorators: [{
79
+ CarouselComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: CarouselComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
80
+ CarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: CarouselComponent, selector: "n7-carousel", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<button *ngIf=\"data && data.classes === 'demo'\"\n class=\"n7-btn\"\n (click)=\"api.load.videos()\">api.load.videos()</button>\n\n<div *ngIf=\"data\"\n class=\"n7-carousel {{ data.classes || '' }}\">\n <!-- Warning: Do not style div.latte-carousel -->\n <div id=\"{{data.containerId}}\"\n class=\"latte-carousel\">\n <ng-container *ngFor=\"let slide of data.slides; let index = index;\">\n <ng-container *ngTemplateOutlet=\"carouselSlide; context:{slide: slide, index: index}\"></ng-container>\n </ng-container>\n </div>\n</div>\n\n<!-- ===== SLIDE WRAPPER ===== -->\n<ng-template #carouselSlide\n let-slide=\"slide\"\n let-slideID=\"index\">\n <!-- Warning: Do not style div.latte-item -->\n <div class=\"latte-item\">\n <div class=\"n7-carousel__slide {{ slide.classes || ''}}\"\n [ngClass]=\"{ 'has-image' : slide.background.image, 'has-video': slide.background.video }\"\n [style.background-color]=\"slide.background.color ? slide.background.color : ''\"\n [style.background-image]=\"slide.background.image ? 'url('+slide.background.image+')' : ''\">\n <div class=\"n7-carousel__slide-content-wrapper\">\n <div class=\"n7-carousel__slide-content\">\n <div class=\"n7-carousel__slide-content-left\">\n <ng-container *ngTemplateOutlet=\"slideForeground; context:{items: slide.items, slideID: slideID}\">\n </ng-container>\n </div>\n <div class=\"n7-carousel__slide-content-right\"\n *ngIf=\"slide.action\">\n <n7-anchor-wrapper [data]=\"slide.action.anchor\"\n (clicked)=\"onClick($event)\">\n <!-- Button ID's are used to dynamically reattach events after loading the carousel -->\n <button id=\"{{data.containerId}}-{{slideID}}\"\n class=\"n7-hero__btn n7-btn n7-btn-cta n7-btn-l\">\n {{slide.action.text}}\n </button>\n </n7-anchor-wrapper>\n </div>\n </div>\n </div>\n <ng-container *ngIf=\"slide.background\">\n <ng-container *ngTemplateOutlet=\"slideBackground; context:{$implicit: slide.background}\">\n </ng-container>\n </ng-container>\n </div>\n </div>\n</ng-template>\n\n<!-- ===== SLIDE FOREGROUND ===== -->\n<ng-template #slideForeground\n let-items=\"items\"\n let-slideID=\"slideID\">\n <ng-container *ngFor=\"let el of items; let itemID = index\">\n <h1 class=\"n7-carousel__slide-title\"\n *ngIf=\"el.title\">{{el.title}}</h1>\n <div class=\"n7-carousel__slide-text\"\n *ngIf=\"el.text\" [innerHTML]=\"el.text\"></div>\n <div class=\"n7-carousel__slide-metadata-wrapper\"\n *ngIf=\"el.metadata\">\n <ng-container *ngFor=\"let m of el.metadata\">\n <div class=\"n7-carousel__slide-metadata\">\n <span class=\"n7-carousel__slide-metadata-label\"\n *ngIf=\"m.key\">{{m.key}}</span>\n <span class=\"n7-carousel__slide-metadata-value\"\n *ngIf=\"m.value\">{{m.value}}</span>\n </div>\n </ng-container>\n </div>\n </ng-container>\n</ng-template>\n\n<!-- ===== VIDEO BACKGROUND ===== -->\n<ng-template #slideBackground\n let-bg>\n <ng-container *ngIf=\"bg.video as v\">\n <video #video\n class=\"n7-carousel__slide-video\"\n [poster]=\"v.poster\"\n [height]=\"v.height\"\n [width]=\"v.width\"\n loop\n muted\n autoplay\n playsinline>\n <source #source\n class=\"lazy\"\n [attr.data-src]=\"v.url\"\n type=\"video/mp4\">\n </video>\n <div class=\"n7-carousel__slide-video-overlay\">\n\n </div>\n </ng-container>\n</ng-template>\n", components: [{ type: i1.AnchorWrapperComponent, selector: "n7-anchor-wrapper", inputs: ["data", "classes"], outputs: ["clicked"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
81
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: CarouselComponent, decorators: [{
82
82
  type: Component,
83
83
  args: [{ selector: 'n7-carousel', template: "<button *ngIf=\"data && data.classes === 'demo'\"\n class=\"n7-btn\"\n (click)=\"api.load.videos()\">api.load.videos()</button>\n\n<div *ngIf=\"data\"\n class=\"n7-carousel {{ data.classes || '' }}\">\n <!-- Warning: Do not style div.latte-carousel -->\n <div id=\"{{data.containerId}}\"\n class=\"latte-carousel\">\n <ng-container *ngFor=\"let slide of data.slides; let index = index;\">\n <ng-container *ngTemplateOutlet=\"carouselSlide; context:{slide: slide, index: index}\"></ng-container>\n </ng-container>\n </div>\n</div>\n\n<!-- ===== SLIDE WRAPPER ===== -->\n<ng-template #carouselSlide\n let-slide=\"slide\"\n let-slideID=\"index\">\n <!-- Warning: Do not style div.latte-item -->\n <div class=\"latte-item\">\n <div class=\"n7-carousel__slide {{ slide.classes || ''}}\"\n [ngClass]=\"{ 'has-image' : slide.background.image, 'has-video': slide.background.video }\"\n [style.background-color]=\"slide.background.color ? slide.background.color : ''\"\n [style.background-image]=\"slide.background.image ? 'url('+slide.background.image+')' : ''\">\n <div class=\"n7-carousel__slide-content-wrapper\">\n <div class=\"n7-carousel__slide-content\">\n <div class=\"n7-carousel__slide-content-left\">\n <ng-container *ngTemplateOutlet=\"slideForeground; context:{items: slide.items, slideID: slideID}\">\n </ng-container>\n </div>\n <div class=\"n7-carousel__slide-content-right\"\n *ngIf=\"slide.action\">\n <n7-anchor-wrapper [data]=\"slide.action.anchor\"\n (clicked)=\"onClick($event)\">\n <!-- Button ID's are used to dynamically reattach events after loading the carousel -->\n <button id=\"{{data.containerId}}-{{slideID}}\"\n class=\"n7-hero__btn n7-btn n7-btn-cta n7-btn-l\">\n {{slide.action.text}}\n </button>\n </n7-anchor-wrapper>\n </div>\n </div>\n </div>\n <ng-container *ngIf=\"slide.background\">\n <ng-container *ngTemplateOutlet=\"slideBackground; context:{$implicit: slide.background}\">\n </ng-container>\n </ng-container>\n </div>\n </div>\n</ng-template>\n\n<!-- ===== SLIDE FOREGROUND ===== -->\n<ng-template #slideForeground\n let-items=\"items\"\n let-slideID=\"slideID\">\n <ng-container *ngFor=\"let el of items; let itemID = index\">\n <h1 class=\"n7-carousel__slide-title\"\n *ngIf=\"el.title\">{{el.title}}</h1>\n <div class=\"n7-carousel__slide-text\"\n *ngIf=\"el.text\" [innerHTML]=\"el.text\"></div>\n <div class=\"n7-carousel__slide-metadata-wrapper\"\n *ngIf=\"el.metadata\">\n <ng-container *ngFor=\"let m of el.metadata\">\n <div class=\"n7-carousel__slide-metadata\">\n <span class=\"n7-carousel__slide-metadata-label\"\n *ngIf=\"m.key\">{{m.key}}</span>\n <span class=\"n7-carousel__slide-metadata-value\"\n *ngIf=\"m.value\">{{m.value}}</span>\n </div>\n </ng-container>\n </div>\n </ng-container>\n</ng-template>\n\n<!-- ===== VIDEO BACKGROUND ===== -->\n<ng-template #slideBackground\n let-bg>\n <ng-container *ngIf=\"bg.video as v\">\n <video #video\n class=\"n7-carousel__slide-video\"\n [poster]=\"v.poster\"\n [height]=\"v.height\"\n [width]=\"v.width\"\n loop\n muted\n autoplay\n playsinline>\n <source #source\n class=\"lazy\"\n [attr.data-src]=\"v.url\"\n type=\"video/mp4\">\n </video>\n <div class=\"n7-carousel__slide-video-overlay\">\n\n </div>\n </ng-container>\n</ng-template>\n" }]
84
84
  }], propDecorators: { data: [{
@@ -24,9 +24,9 @@ export class ChartComponent {
24
24
  });
25
25
  }
26
26
  }
27
- ChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
28
- ChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: ChartComponent, selector: "n7-chart", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div *ngIf=\"data\" class=\"n7-chart {{ data.classes || '' }}\">\n <div id=\"{{ data.containerId }}\"></div>\n</div>", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
29
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ChartComponent, decorators: [{
27
+ ChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
28
+ ChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: ChartComponent, selector: "n7-chart", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div *ngIf=\"data\" class=\"n7-chart {{ data.classes || '' }}\">\n <div id=\"{{ data.containerId }}\"></div>\n</div>", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ChartComponent, decorators: [{
30
30
  type: Component,
31
31
  args: [{ selector: 'n7-chart', template: "<div *ngIf=\"data\" class=\"n7-chart {{ data.classes || '' }}\">\n <div id=\"{{ data.containerId }}\"></div>\n</div>" }]
32
32
  }], propDecorators: { data: [{