@unovis/angular 1.6.4 → 1.6.5-topojson.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.
@@ -1,5 +1,5 @@
1
1
  import { AfterViewInit, SimpleChanges } from '@angular/core';
2
- import { TopoJSONMap, TopoJSONMapConfigInterface, ContainerCore, VisEventType, VisEventCallback, NumericAccessor, ColorAccessor, StringAccessor, MapPointLabelPosition } from '@unovis/ts';
2
+ import { TopoJSONMap, TopoJSONMapConfigInterface, ContainerCore, VisEventType, VisEventCallback, NumericAccessor, ColorAccessor, StringAccessor, MapPointLabelPosition, TopoJSONMapClusterDatum, TopoJSONMapPointStyles } from '@unovis/ts';
3
3
  import { GeoProjection } from 'd3-geo';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class VisTopoJSONMapComponent<AreaDatum, PointDatum, LinkDatum> implements TopoJSONMapConfigInterface<AreaDatum, PointDatum, LinkDatum>, AfterViewInit {
@@ -78,38 +78,119 @@ export declare class VisTopoJSONMapComponent<AreaDatum, PointDatum, LinkDatum> i
78
78
  linkSource?: ((l: LinkDatum) => number | string | PointDatum);
79
79
  /** Link target accessor function. Default: `d => d.target` */
80
80
  linkTarget?: ((l: LinkDatum) => number | string | PointDatum);
81
+ /** Flow source point longitude accessor function or value. Default: `f => f.sourceLongitude` */
82
+ sourceLongitude?: NumericAccessor<LinkDatum>;
83
+ /** Flow source point latitude accessor function or value. Default: `f => f.sourceLatitude` */
84
+ sourceLatitude?: NumericAccessor<LinkDatum>;
85
+ /** Flow target point longitude accessor function or value. Default: `f => f.targetLongitude` */
86
+ targetLongitude?: NumericAccessor<LinkDatum>;
87
+ /** Flow target point latitude accessor function or value. Default: `f => f.targetLatitude` */
88
+ targetLatitude?: NumericAccessor<LinkDatum>;
89
+ /** Flow source point radius accessor function or value. Default: `3` */
90
+ sourcePointRadius?: NumericAccessor<LinkDatum>;
91
+ /** Source point color accessor function or value. Default: `'#88919f'` */
92
+ sourcePointColor?: ColorAccessor<LinkDatum>;
93
+ /** Flow particle color accessor function or value. Default: `'#949dad'` */
94
+ flowParticleColor?: ColorAccessor<LinkDatum>;
95
+ /** Flow particle radius accessor function or value. Default: `1.1` */
96
+ flowParticleRadius?: NumericAccessor<LinkDatum>;
97
+ /** Flow particle speed accessor function or value. The unit is arbitrary, recommended range is 0 – 0.2. Default: `0.07` */
98
+ flowParticleSpeed?: NumericAccessor<LinkDatum>;
99
+ /** Flow particle density accessor function or value on the range of [0, 1]. Default: `0.6` */
100
+ flowParticleDensity?: NumericAccessor<LinkDatum>;
101
+ /** Enable flow animations. When true, shows animated particles along links. Default: `false` */
102
+ enableFlowAnimation?: boolean;
103
+ /** Flow source point click callback function. Default: `undefined` */
104
+ onSourcePointClick?: (f: LinkDatum, x: number, y: number, event: MouseEvent) => void;
105
+ /** Flow source point mouse over callback function. Default: `undefined` */
106
+ onSourcePointMouseEnter?: (f: LinkDatum, x: number, y: number, event: MouseEvent) => void;
107
+ /** Flow source point mouse leave callback function. Default: `undefined` */
108
+ onSourcePointMouseLeave?: (f: LinkDatum, event: MouseEvent) => void;
81
109
  /** Area id accessor function corresponding to the feature id from TopoJSON. Default: `d => d.id ?? ''` */
82
110
  areaId?: StringAccessor<AreaDatum>;
83
111
  /** Area color value or accessor function. Default: `d => d.color ?? null` */
84
112
  areaColor?: ColorAccessor<AreaDatum>;
85
113
  /** Area cursor value or accessor function. Default: `null` */
86
114
  areaCursor?: StringAccessor<AreaDatum>;
115
+ /** Area label accessor function. Default: `undefined` */
116
+ areaLabel?: StringAccessor<AreaDatum>;
87
117
  /** Point color accessor. Default: `d => d.color ?? null` */
88
118
  pointColor?: ColorAccessor<PointDatum>;
89
119
  /** Point radius accessor. Default: `d => d.radius ?? 8` */
90
120
  pointRadius?: NumericAccessor<PointDatum>;
91
121
  /** Point stroke width accessor. Default: `d => d.strokeWidth ?? null` */
92
122
  pointStrokeWidth?: NumericAccessor<PointDatum>;
123
+ /** Point shape accessor. Default: `TopoJSONMapPointShape.Circle` */
124
+ pointShape?: StringAccessor<PointDatum>;
125
+ /** Point ring width for ring-shaped points. Default: `2` */
126
+ pointRingWidth?: NumericAccessor<PointDatum>;
93
127
  /** Point cursor constant value or accessor function. Default: `null` */
94
128
  pointCursor?: StringAccessor<PointDatum>;
95
129
  /** Point longitude accessor function. Default: `d => d.longitude ?? null` */
96
130
  longitude?: NumericAccessor<PointDatum>;
97
131
  /** Point latitude accessor function. Default: `d => d.latitude ?? null` */
98
132
  latitude?: NumericAccessor<PointDatum>;
99
- /** Point label accessor function. Default: `undefined` */
133
+ /** Point inner label accessor function. Default: `undefined` */
100
134
  pointLabel?: StringAccessor<PointDatum>;
101
- /** Point label position. Default: `Position.Bottom` */
135
+ /** Point inner label color accessor function or constant value.
136
+ * By default, the label color will be set, depending on the point brightness, either to
137
+ * `--vis-map-point-label-text-color-dark` or to `--vis-map-point-label-text-color-light` CSS variable.
138
+ * Default: `undefined` */
139
+ pointLabelColor?: ColorAccessor<PointDatum>;
140
+ /** Point label position. Default: `MapPointLabelPosition.Center` */
102
141
  pointLabelPosition?: MapPointLabelPosition;
142
+ /** Point bottom label accessor function. Default: `undefined` */
143
+ pointBottomLabel?: StringAccessor<PointDatum>;
103
144
  /** Point color brightness ratio for switching between dark and light text label color. Default: `0.65` */
104
145
  pointLabelTextBrightnessRatio?: number;
105
146
  /** Point id accessor function. Default: `d => d.id` */
106
147
  pointId?: ((d: PointDatum, i: number) => string);
148
+ /** Cluster color accessor function or constant value. Default: `undefined` */
149
+ clusterColor?: ColorAccessor<TopoJSONMapClusterDatum<PointDatum>>;
150
+ /** Cluster radius accessor function or constant value. Default: `undefined` */
151
+ clusterRadius?: NumericAccessor<TopoJSONMapClusterDatum<PointDatum>>;
152
+ /** Cluster inner label accessor function. Default: `d => d.pointCount` */
153
+ clusterLabel?: StringAccessor<TopoJSONMapClusterDatum<PointDatum>>;
154
+ /** Cluster inner label color accessor function or constant value. Default: `undefined` */
155
+ clusterLabelColor?: StringAccessor<TopoJSONMapClusterDatum<PointDatum>>;
156
+ /** Cluster bottom label accessor function. Default: `''` */
157
+ clusterBottomLabel?: StringAccessor<TopoJSONMapClusterDatum<PointDatum>>;
158
+ /** The width of the cluster point ring. Default: `2` */
159
+ clusterRingWidth?: number;
160
+ /** When cluster is expanded, show a background circle to better separate points from the base map. Default: `true` */
161
+ clusterBackground?: boolean;
162
+ /** Defines whether the cluster should expand on click or not. Default: `true` */
163
+ clusterExpandOnClick?: boolean;
164
+ /** Clustering distance in pixels. Default: `55` */
165
+ clusteringDistance?: number;
166
+ /** Enable point clustering. Default: `false` */
167
+ clustering?: boolean;
107
168
  /** Enables blur and blending between neighbouring points. Default: `false` */
108
169
  heatmapMode?: boolean;
109
170
  /** Heatmap blur filter stdDeviation value. Default: `10` */
110
171
  heatmapModeBlurStdDeviation?: number;
111
172
  /** Zoom level at which the heatmap mode will be disabled. Default: `2.5` */
112
173
  heatmapModeZoomLevelThreshold?: number;
174
+ /** A single map point can have multiple properties displayed as a small pie chart.
175
+ * By setting the colorMap configuration you can specify data properties that should be mapped to various pie / donut segments.
176
+ *
177
+ * ```
178
+ * {
179
+ * [key in keyof PointDatum]?: { color: string, className?: string }
180
+ * }
181
+ * ```
182
+ * e.g.:
183
+ * ```
184
+ * {
185
+ * healthy: { color: 'green' },
186
+ * warning: { color: 'orange' },
187
+ * critical: { color: 'red' }
188
+ * }
189
+ * ```
190
+ * where every data point has the `healthy`, `warning` and `critical` numerical or boolean property.
191
+ * Note: Properties with 0 or falsy values will not be displayed in the pie chart.
192
+ * Default: `{}` */
193
+ colorMap?: TopoJSONMapPointStyles<PointDatum>;
113
194
  data: {
114
195
  areas?: AreaDatum[];
115
196
  points?: PointDatum[];
@@ -121,5 +202,5 @@ export declare class VisTopoJSONMapComponent<AreaDatum, PointDatum, LinkDatum> i
121
202
  ngOnChanges(changes: SimpleChanges): void;
122
203
  private getConfig;
123
204
  static ɵfac: i0.ɵɵFactoryDeclaration<VisTopoJSONMapComponent<any, any, any>, never>;
124
- static ɵcmp: i0.ɵɵComponentDeclaration<VisTopoJSONMapComponent<any, any, any>, "vis-topojson-map", never, { "duration": "duration"; "events": "events"; "attributes": "attributes"; "projection": "projection"; "topojson": "topojson"; "mapFeatureName": "mapFeatureName"; "mapFitToPoints": "mapFitToPoints"; "zoomFactor": "zoomFactor"; "disableZoom": "disableZoom"; "zoomExtent": "zoomExtent"; "zoomDuration": "zoomDuration"; "linkWidth": "linkWidth"; "linkColor": "linkColor"; "linkCursor": "linkCursor"; "linkId": "linkId"; "linkSource": "linkSource"; "linkTarget": "linkTarget"; "areaId": "areaId"; "areaColor": "areaColor"; "areaCursor": "areaCursor"; "pointColor": "pointColor"; "pointRadius": "pointRadius"; "pointStrokeWidth": "pointStrokeWidth"; "pointCursor": "pointCursor"; "longitude": "longitude"; "latitude": "latitude"; "pointLabel": "pointLabel"; "pointLabelPosition": "pointLabelPosition"; "pointLabelTextBrightnessRatio": "pointLabelTextBrightnessRatio"; "pointId": "pointId"; "heatmapMode": "heatmapMode"; "heatmapModeBlurStdDeviation": "heatmapModeBlurStdDeviation"; "heatmapModeZoomLevelThreshold": "heatmapModeZoomLevelThreshold"; "data": "data"; }, {}, never, never>;
205
+ static ɵcmp: i0.ɵɵComponentDeclaration<VisTopoJSONMapComponent<any, any, any>, "vis-topojson-map", never, { "duration": "duration"; "events": "events"; "attributes": "attributes"; "projection": "projection"; "topojson": "topojson"; "mapFeatureName": "mapFeatureName"; "mapFitToPoints": "mapFitToPoints"; "zoomFactor": "zoomFactor"; "disableZoom": "disableZoom"; "zoomExtent": "zoomExtent"; "zoomDuration": "zoomDuration"; "linkWidth": "linkWidth"; "linkColor": "linkColor"; "linkCursor": "linkCursor"; "linkId": "linkId"; "linkSource": "linkSource"; "linkTarget": "linkTarget"; "sourceLongitude": "sourceLongitude"; "sourceLatitude": "sourceLatitude"; "targetLongitude": "targetLongitude"; "targetLatitude": "targetLatitude"; "sourcePointRadius": "sourcePointRadius"; "sourcePointColor": "sourcePointColor"; "flowParticleColor": "flowParticleColor"; "flowParticleRadius": "flowParticleRadius"; "flowParticleSpeed": "flowParticleSpeed"; "flowParticleDensity": "flowParticleDensity"; "enableFlowAnimation": "enableFlowAnimation"; "onSourcePointClick": "onSourcePointClick"; "onSourcePointMouseEnter": "onSourcePointMouseEnter"; "onSourcePointMouseLeave": "onSourcePointMouseLeave"; "areaId": "areaId"; "areaColor": "areaColor"; "areaCursor": "areaCursor"; "areaLabel": "areaLabel"; "pointColor": "pointColor"; "pointRadius": "pointRadius"; "pointStrokeWidth": "pointStrokeWidth"; "pointShape": "pointShape"; "pointRingWidth": "pointRingWidth"; "pointCursor": "pointCursor"; "longitude": "longitude"; "latitude": "latitude"; "pointLabel": "pointLabel"; "pointLabelColor": "pointLabelColor"; "pointLabelPosition": "pointLabelPosition"; "pointBottomLabel": "pointBottomLabel"; "pointLabelTextBrightnessRatio": "pointLabelTextBrightnessRatio"; "pointId": "pointId"; "clusterColor": "clusterColor"; "clusterRadius": "clusterRadius"; "clusterLabel": "clusterLabel"; "clusterLabelColor": "clusterLabelColor"; "clusterBottomLabel": "clusterBottomLabel"; "clusterRingWidth": "clusterRingWidth"; "clusterBackground": "clusterBackground"; "clusterExpandOnClick": "clusterExpandOnClick"; "clusteringDistance": "clusteringDistance"; "clustering": "clustering"; "heatmapMode": "heatmapMode"; "heatmapModeBlurStdDeviation": "heatmapModeBlurStdDeviation"; "heatmapModeZoomLevelThreshold": "heatmapModeZoomLevelThreshold"; "colorMap": "colorMap"; "data": "data"; }, {}, never, never>;
125
206
  }
@@ -21,8 +21,8 @@ export class VisTopoJSONMapComponent {
21
21
  (_c = this.componentContainer) === null || _c === void 0 ? void 0 : _c.render();
22
22
  }
23
23
  getConfig() {
24
- const { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, areaId, areaColor, areaCursor, pointColor, pointRadius, pointStrokeWidth, pointCursor, longitude, latitude, pointLabel, pointLabelPosition, pointLabelTextBrightnessRatio, pointId, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold } = this;
25
- const config = { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, areaId, areaColor, areaCursor, pointColor, pointRadius, pointStrokeWidth, pointCursor, longitude, latitude, pointLabel, pointLabelPosition, pointLabelTextBrightnessRatio, pointId, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold };
24
+ const { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, sourceLongitude, sourceLatitude, targetLongitude, targetLatitude, sourcePointRadius, sourcePointColor, flowParticleColor, flowParticleRadius, flowParticleSpeed, flowParticleDensity, enableFlowAnimation, onSourcePointClick, onSourcePointMouseEnter, onSourcePointMouseLeave, areaId, areaColor, areaCursor, areaLabel, pointColor, pointRadius, pointStrokeWidth, pointShape, pointRingWidth, pointCursor, longitude, latitude, pointLabel, pointLabelColor, pointLabelPosition, pointBottomLabel, pointLabelTextBrightnessRatio, pointId, clusterColor, clusterRadius, clusterLabel, clusterLabelColor, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, clustering, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold, colorMap } = this;
25
+ const config = { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, sourceLongitude, sourceLatitude, targetLongitude, targetLatitude, sourcePointRadius, sourcePointColor, flowParticleColor, flowParticleRadius, flowParticleSpeed, flowParticleDensity, enableFlowAnimation, onSourcePointClick, onSourcePointMouseEnter, onSourcePointMouseLeave, areaId, areaColor, areaCursor, areaLabel, pointColor, pointRadius, pointStrokeWidth, pointShape, pointRingWidth, pointCursor, longitude, latitude, pointLabel, pointLabelColor, pointLabelPosition, pointBottomLabel, pointLabelTextBrightnessRatio, pointId, clusterColor, clusterRadius, clusterLabel, clusterLabelColor, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, clustering, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold, colorMap };
26
26
  const keys = Object.keys(config);
27
27
  keys.forEach(key => { if (config[key] === undefined)
28
28
  delete config[key]; });
@@ -30,7 +30,7 @@ export class VisTopoJSONMapComponent {
30
30
  }
31
31
  }
32
32
  VisTopoJSONMapComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisTopoJSONMapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
33
- VisTopoJSONMapComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisTopoJSONMapComponent, selector: "vis-topojson-map", inputs: { duration: "duration", events: "events", attributes: "attributes", projection: "projection", topojson: "topojson", mapFeatureName: "mapFeatureName", mapFitToPoints: "mapFitToPoints", zoomFactor: "zoomFactor", disableZoom: "disableZoom", zoomExtent: "zoomExtent", zoomDuration: "zoomDuration", linkWidth: "linkWidth", linkColor: "linkColor", linkCursor: "linkCursor", linkId: "linkId", linkSource: "linkSource", linkTarget: "linkTarget", areaId: "areaId", areaColor: "areaColor", areaCursor: "areaCursor", pointColor: "pointColor", pointRadius: "pointRadius", pointStrokeWidth: "pointStrokeWidth", pointCursor: "pointCursor", longitude: "longitude", latitude: "latitude", pointLabel: "pointLabel", pointLabelPosition: "pointLabelPosition", pointLabelTextBrightnessRatio: "pointLabelTextBrightnessRatio", pointId: "pointId", heatmapMode: "heatmapMode", heatmapModeBlurStdDeviation: "heatmapModeBlurStdDeviation", heatmapModeZoomLevelThreshold: "heatmapModeZoomLevelThreshold", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisTopoJSONMapComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
33
+ VisTopoJSONMapComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisTopoJSONMapComponent, selector: "vis-topojson-map", inputs: { duration: "duration", events: "events", attributes: "attributes", projection: "projection", topojson: "topojson", mapFeatureName: "mapFeatureName", mapFitToPoints: "mapFitToPoints", zoomFactor: "zoomFactor", disableZoom: "disableZoom", zoomExtent: "zoomExtent", zoomDuration: "zoomDuration", linkWidth: "linkWidth", linkColor: "linkColor", linkCursor: "linkCursor", linkId: "linkId", linkSource: "linkSource", linkTarget: "linkTarget", sourceLongitude: "sourceLongitude", sourceLatitude: "sourceLatitude", targetLongitude: "targetLongitude", targetLatitude: "targetLatitude", sourcePointRadius: "sourcePointRadius", sourcePointColor: "sourcePointColor", flowParticleColor: "flowParticleColor", flowParticleRadius: "flowParticleRadius", flowParticleSpeed: "flowParticleSpeed", flowParticleDensity: "flowParticleDensity", enableFlowAnimation: "enableFlowAnimation", onSourcePointClick: "onSourcePointClick", onSourcePointMouseEnter: "onSourcePointMouseEnter", onSourcePointMouseLeave: "onSourcePointMouseLeave", areaId: "areaId", areaColor: "areaColor", areaCursor: "areaCursor", areaLabel: "areaLabel", pointColor: "pointColor", pointRadius: "pointRadius", pointStrokeWidth: "pointStrokeWidth", pointShape: "pointShape", pointRingWidth: "pointRingWidth", pointCursor: "pointCursor", longitude: "longitude", latitude: "latitude", pointLabel: "pointLabel", pointLabelColor: "pointLabelColor", pointLabelPosition: "pointLabelPosition", pointBottomLabel: "pointBottomLabel", pointLabelTextBrightnessRatio: "pointLabelTextBrightnessRatio", pointId: "pointId", clusterColor: "clusterColor", clusterRadius: "clusterRadius", clusterLabel: "clusterLabel", clusterLabelColor: "clusterLabelColor", clusterBottomLabel: "clusterBottomLabel", clusterRingWidth: "clusterRingWidth", clusterBackground: "clusterBackground", clusterExpandOnClick: "clusterExpandOnClick", clusteringDistance: "clusteringDistance", clustering: "clustering", heatmapMode: "heatmapMode", heatmapModeBlurStdDeviation: "heatmapModeBlurStdDeviation", heatmapModeZoomLevelThreshold: "heatmapModeZoomLevelThreshold", colorMap: "colorMap", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisTopoJSONMapComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
34
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisTopoJSONMapComponent, decorators: [{
35
35
  type: Component,
36
36
  args: [{
@@ -73,18 +73,52 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
73
73
  type: Input
74
74
  }], linkTarget: [{
75
75
  type: Input
76
+ }], sourceLongitude: [{
77
+ type: Input
78
+ }], sourceLatitude: [{
79
+ type: Input
80
+ }], targetLongitude: [{
81
+ type: Input
82
+ }], targetLatitude: [{
83
+ type: Input
84
+ }], sourcePointRadius: [{
85
+ type: Input
86
+ }], sourcePointColor: [{
87
+ type: Input
88
+ }], flowParticleColor: [{
89
+ type: Input
90
+ }], flowParticleRadius: [{
91
+ type: Input
92
+ }], flowParticleSpeed: [{
93
+ type: Input
94
+ }], flowParticleDensity: [{
95
+ type: Input
96
+ }], enableFlowAnimation: [{
97
+ type: Input
98
+ }], onSourcePointClick: [{
99
+ type: Input
100
+ }], onSourcePointMouseEnter: [{
101
+ type: Input
102
+ }], onSourcePointMouseLeave: [{
103
+ type: Input
76
104
  }], areaId: [{
77
105
  type: Input
78
106
  }], areaColor: [{
79
107
  type: Input
80
108
  }], areaCursor: [{
81
109
  type: Input
110
+ }], areaLabel: [{
111
+ type: Input
82
112
  }], pointColor: [{
83
113
  type: Input
84
114
  }], pointRadius: [{
85
115
  type: Input
86
116
  }], pointStrokeWidth: [{
87
117
  type: Input
118
+ }], pointShape: [{
119
+ type: Input
120
+ }], pointRingWidth: [{
121
+ type: Input
88
122
  }], pointCursor: [{
89
123
  type: Input
90
124
  }], longitude: [{
@@ -93,19 +127,45 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
93
127
  type: Input
94
128
  }], pointLabel: [{
95
129
  type: Input
130
+ }], pointLabelColor: [{
131
+ type: Input
96
132
  }], pointLabelPosition: [{
97
133
  type: Input
134
+ }], pointBottomLabel: [{
135
+ type: Input
98
136
  }], pointLabelTextBrightnessRatio: [{
99
137
  type: Input
100
138
  }], pointId: [{
101
139
  type: Input
140
+ }], clusterColor: [{
141
+ type: Input
142
+ }], clusterRadius: [{
143
+ type: Input
144
+ }], clusterLabel: [{
145
+ type: Input
146
+ }], clusterLabelColor: [{
147
+ type: Input
148
+ }], clusterBottomLabel: [{
149
+ type: Input
150
+ }], clusterRingWidth: [{
151
+ type: Input
152
+ }], clusterBackground: [{
153
+ type: Input
154
+ }], clusterExpandOnClick: [{
155
+ type: Input
156
+ }], clusteringDistance: [{
157
+ type: Input
158
+ }], clustering: [{
159
+ type: Input
102
160
  }], heatmapMode: [{
103
161
  type: Input
104
162
  }], heatmapModeBlurStdDeviation: [{
105
163
  type: Input
106
164
  }], heatmapModeZoomLevelThreshold: [{
107
165
  type: Input
166
+ }], colorMap: [{
167
+ type: Input
108
168
  }], data: [{
109
169
  type: Input
110
170
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"topojson-map.component.js","sourceRoot":"","sources":["../../../../../src/components/topojson-map/topojson-map.component.ts"],"names":[],"mappings":"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","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  TopoJSONMap,\n  TopoJSONMapConfigInterface,\n  ContainerCore,\n  VisEventType,\n  VisEventCallback,\n  NumericAccessor,\n  ColorAccessor,\n  StringAccessor,\n  MapPointLabelPosition,\n} from '@unovis/ts'\nimport { GeoProjection } from 'd3-geo'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-topojson-map',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisTopoJSONMapComponent }],\n})\nexport class VisTopoJSONMapComponent<AreaDatum, PointDatum, LinkDatum> implements TopoJSONMapConfigInterface<AreaDatum, PointDatum, LinkDatum>, AfterViewInit {\n  /** Animation duration of the data update transitions in milliseconds. Default: `600` */\n  @Input() duration?: number\n\n  /** Events configuration. An object containing properties in the following format:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[eventType]: callbackFunction\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    click: (d) => console.log(\"Clicked Area\", d)\n   *  }\n   * }\n   * ``` */\n  @Input() events?: {\n    [selector: string]: {\n      [eventType in VisEventType]?: VisEventCallback\n    };\n  }\n\n  /** You can set every SVG and HTML visualization object to have a custom DOM attributes, which is useful\n   * when you want to do unit or end-to-end testing. Attributes configuration object has the following structure:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[attributeName]: attribute constant value or accessor function\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    \"test-value\": d => d.value\n   *  }\n   * }\n   * ``` */\n  @Input() attributes?: {\n    [selector: string]: {\n      [attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);\n    };\n  }\n\n  /** MapProjection (aka D3's GeoProjection) instance. Default: `MapProjection.Kavrayskiy7()` */\n  @Input() projection?: GeoProjection\n\n  /** Map data in the TopoJSON topology format. Default: `undefined` */\n  @Input() topojson?: TopoJSON.Topology\n\n  /** Name of the map features to be displayed, e.g. 'countries' or 'counties'. Default: `countries` */\n  @Input() mapFeatureName?: string\n\n  /** Set initial map fit to points instead of topojson features. Default: `false` */\n  @Input() mapFitToPoints?: boolean\n\n  /** Initial zoom level. Default: `undefined` */\n  @Input() zoomFactor?: number\n\n  /** Disable pan / zoom interactions. Default: `false` */\n  @Input() disableZoom?: boolean\n\n  /** Zoom extent. Default: `[0.5, 6]` */\n  @Input() zoomExtent?: number[]\n\n  /** Zoom animation duration. Default: `400` */\n  @Input() zoomDuration?: number\n\n  /** Link width value or accessor function. Default: `d => d.width ?? 1` */\n  @Input() linkWidth?: NumericAccessor<LinkDatum>\n\n  /** Link color value or accessor function. Default: `d => d.color ?? null` */\n  @Input() linkColor?: ColorAccessor<LinkDatum>\n\n  /** Link cursor value or accessor function. Default: `null` */\n  @Input() linkCursor?: StringAccessor<LinkDatum>\n\n  /** Link id accessor function. Default: `d => d.id` */\n  @Input() linkId?: StringAccessor<LinkDatum>\n\n  /** Link source accessor function. Default: `d => d.source` */\n  @Input() linkSource?: ((l: LinkDatum) => number | string | PointDatum)\n\n  /** Link target accessor function. Default: `d => d.target` */\n  @Input() linkTarget?: ((l: LinkDatum) => number | string | PointDatum)\n\n  /** Area id accessor function corresponding to the feature id from TopoJSON. Default: `d => d.id ?? ''` */\n  @Input() areaId?: StringAccessor<AreaDatum>\n\n  /** Area color value or accessor function. Default: `d => d.color ?? null` */\n  @Input() areaColor?: ColorAccessor<AreaDatum>\n\n  /** Area cursor value or accessor function. Default: `null` */\n  @Input() areaCursor?: StringAccessor<AreaDatum>\n\n  /** Point color accessor. Default: `d => d.color ?? null` */\n  @Input() pointColor?: ColorAccessor<PointDatum>\n\n  /** Point radius accessor. Default: `d => d.radius ?? 8` */\n  @Input() pointRadius?: NumericAccessor<PointDatum>\n\n  /** Point stroke width accessor. Default: `d => d.strokeWidth ?? null` */\n  @Input() pointStrokeWidth?: NumericAccessor<PointDatum>\n\n  /** Point cursor constant value or accessor function. Default: `null` */\n  @Input() pointCursor?: StringAccessor<PointDatum>\n\n  /** Point longitude accessor function. Default: `d => d.longitude ?? null` */\n  @Input() longitude?: NumericAccessor<PointDatum>\n\n  /** Point latitude accessor function. Default: `d => d.latitude ?? null` */\n  @Input() latitude?: NumericAccessor<PointDatum>\n\n  /** Point label accessor function. Default: `undefined` */\n  @Input() pointLabel?: StringAccessor<PointDatum>\n\n  /** Point label position. Default: `Position.Bottom` */\n  @Input() pointLabelPosition?: MapPointLabelPosition\n\n  /** Point color brightness ratio for switching between dark and light text label color. Default: `0.65` */\n  @Input() pointLabelTextBrightnessRatio?: number\n\n  /** Point id accessor function. Default: `d => d.id` */\n  @Input() pointId?: ((d: PointDatum, i: number) => string)\n\n  /** Enables blur and blending between neighbouring points. Default: `false` */\n  @Input() heatmapMode?: boolean\n\n  /** Heatmap blur filter stdDeviation value. Default: `10` */\n  @Input() heatmapModeBlurStdDeviation?: number\n\n  /** Zoom level at which the heatmap mode will be disabled. Default: `2.5` */\n  @Input() heatmapModeZoomLevelThreshold?: number\n  @Input() data: {areas?: AreaDatum[]; points?: PointDatum[]; links?: LinkDatum[]}\n\n  component: TopoJSONMap<AreaDatum, PointDatum, LinkDatum> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new TopoJSONMap<AreaDatum, PointDatum, LinkDatum>(this.getConfig())\n\n    if (this.data) {\n      this.component.setData(this.data)\n      this.componentContainer?.render()\n    }\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    if (changes.data) { this.component?.setData(this.data) }\n    this.component?.setConfig(this.getConfig())\n    this.componentContainer?.render()\n  }\n\n  private getConfig (): TopoJSONMapConfigInterface<AreaDatum, PointDatum, LinkDatum> {\n    const { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, areaId, areaColor, areaCursor, pointColor, pointRadius, pointStrokeWidth, pointCursor, longitude, latitude, pointLabel, pointLabelPosition, pointLabelTextBrightnessRatio, pointId, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold } = this\n    const config = { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, areaId, areaColor, areaCursor, pointColor, pointRadius, pointStrokeWidth, pointCursor, longitude, latitude, pointLabel, pointLabelPosition, pointLabelTextBrightnessRatio, pointId, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold }\n    const keys = Object.keys(config) as (keyof TopoJSONMapConfigInterface<AreaDatum, PointDatum, LinkDatum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"topojson-map.component.js","sourceRoot":"","sources":["../../../../../src/components/topojson-map/topojson-map.component.ts"],"names":[],"mappings":"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","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  TopoJSONMap,\n  TopoJSONMapConfigInterface,\n  ContainerCore,\n  VisEventType,\n  VisEventCallback,\n  NumericAccessor,\n  ColorAccessor,\n  StringAccessor,\n  MapPointLabelPosition,\n  TopoJSONMapClusterDatum,\n  TopoJSONMapPointStyles,\n} from '@unovis/ts'\nimport { GeoProjection } from 'd3-geo'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-topojson-map',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisTopoJSONMapComponent }],\n})\nexport class VisTopoJSONMapComponent<AreaDatum, PointDatum, LinkDatum> implements TopoJSONMapConfigInterface<AreaDatum, PointDatum, LinkDatum>, AfterViewInit {\n  /** Animation duration of the data update transitions in milliseconds. Default: `600` */\n  @Input() duration?: number\n\n  /** Events configuration. An object containing properties in the following format:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[eventType]: callbackFunction\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    click: (d) => console.log(\"Clicked Area\", d)\n   *  }\n   * }\n   * ``` */\n  @Input() events?: {\n    [selector: string]: {\n      [eventType in VisEventType]?: VisEventCallback\n    };\n  }\n\n  /** You can set every SVG and HTML visualization object to have a custom DOM attributes, which is useful\n   * when you want to do unit or end-to-end testing. Attributes configuration object has the following structure:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[attributeName]: attribute constant value or accessor function\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    \"test-value\": d => d.value\n   *  }\n   * }\n   * ``` */\n  @Input() attributes?: {\n    [selector: string]: {\n      [attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);\n    };\n  }\n\n  /** MapProjection (aka D3's GeoProjection) instance. Default: `MapProjection.Kavrayskiy7()` */\n  @Input() projection?: GeoProjection\n\n  /** Map data in the TopoJSON topology format. Default: `undefined` */\n  @Input() topojson?: TopoJSON.Topology\n\n  /** Name of the map features to be displayed, e.g. 'countries' or 'counties'. Default: `countries` */\n  @Input() mapFeatureName?: string\n\n  /** Set initial map fit to points instead of topojson features. Default: `false` */\n  @Input() mapFitToPoints?: boolean\n\n  /** Initial zoom level. Default: `undefined` */\n  @Input() zoomFactor?: number\n\n  /** Disable pan / zoom interactions. Default: `false` */\n  @Input() disableZoom?: boolean\n\n  /** Zoom extent. Default: `[0.5, 6]` */\n  @Input() zoomExtent?: number[]\n\n  /** Zoom animation duration. Default: `400` */\n  @Input() zoomDuration?: number\n\n  /** Link width value or accessor function. Default: `d => d.width ?? 1` */\n  @Input() linkWidth?: NumericAccessor<LinkDatum>\n\n  /** Link color value or accessor function. Default: `d => d.color ?? null` */\n  @Input() linkColor?: ColorAccessor<LinkDatum>\n\n  /** Link cursor value or accessor function. Default: `null` */\n  @Input() linkCursor?: StringAccessor<LinkDatum>\n\n  /** Link id accessor function. Default: `d => d.id` */\n  @Input() linkId?: StringAccessor<LinkDatum>\n\n  /** Link source accessor function. Default: `d => d.source` */\n  @Input() linkSource?: ((l: LinkDatum) => number | string | PointDatum)\n\n  /** Link target accessor function. Default: `d => d.target` */\n  @Input() linkTarget?: ((l: LinkDatum) => number | string | PointDatum)\n\n  /** Flow source point longitude accessor function or value. Default: `f => f.sourceLongitude` */\n  @Input() sourceLongitude?: NumericAccessor<LinkDatum>\n\n  /** Flow source point latitude accessor function or value. Default: `f => f.sourceLatitude` */\n  @Input() sourceLatitude?: NumericAccessor<LinkDatum>\n\n  /** Flow target point longitude accessor function or value. Default: `f => f.targetLongitude` */\n  @Input() targetLongitude?: NumericAccessor<LinkDatum>\n\n  /** Flow target point latitude accessor function or value. Default: `f => f.targetLatitude` */\n  @Input() targetLatitude?: NumericAccessor<LinkDatum>\n\n  /** Flow source point radius accessor function or value. Default: `3` */\n  @Input() sourcePointRadius?: NumericAccessor<LinkDatum>\n\n  /** Source point color accessor function or value. Default: `'#88919f'` */\n  @Input() sourcePointColor?: ColorAccessor<LinkDatum>\n\n  /** Flow particle color accessor function or value. Default: `'#949dad'` */\n  @Input() flowParticleColor?: ColorAccessor<LinkDatum>\n\n  /** Flow particle radius accessor function or value. Default: `1.1` */\n  @Input() flowParticleRadius?: NumericAccessor<LinkDatum>\n\n  /** Flow particle speed accessor function or value. The unit is arbitrary, recommended range is 0 – 0.2. Default: `0.07` */\n  @Input() flowParticleSpeed?: NumericAccessor<LinkDatum>\n\n  /** Flow particle density accessor function or value on the range of [0, 1]. Default: `0.6` */\n  @Input() flowParticleDensity?: NumericAccessor<LinkDatum>\n\n  /** Enable flow animations. When true, shows animated particles along links. Default: `false` */\n  @Input() enableFlowAnimation?: boolean\n\n  /** Flow source point click callback function. Default: `undefined` */\n  @Input() onSourcePointClick?: (f: LinkDatum, x: number, y: number, event: MouseEvent) => void\n\n  /** Flow source point mouse over callback function. Default: `undefined` */\n  @Input() onSourcePointMouseEnter?: (f: LinkDatum, x: number, y: number, event: MouseEvent) => void\n\n  /** Flow source point mouse leave callback function. Default: `undefined` */\n  @Input() onSourcePointMouseLeave?: (f: LinkDatum, event: MouseEvent) => void\n\n  /** Area id accessor function corresponding to the feature id from TopoJSON. Default: `d => d.id ?? ''` */\n  @Input() areaId?: StringAccessor<AreaDatum>\n\n  /** Area color value or accessor function. Default: `d => d.color ?? null` */\n  @Input() areaColor?: ColorAccessor<AreaDatum>\n\n  /** Area cursor value or accessor function. Default: `null` */\n  @Input() areaCursor?: StringAccessor<AreaDatum>\n\n  /** Area label accessor function. Default: `undefined` */\n  @Input() areaLabel?: StringAccessor<AreaDatum>\n\n  /** Point color accessor. Default: `d => d.color ?? null` */\n  @Input() pointColor?: ColorAccessor<PointDatum>\n\n  /** Point radius accessor. Default: `d => d.radius ?? 8` */\n  @Input() pointRadius?: NumericAccessor<PointDatum>\n\n  /** Point stroke width accessor. Default: `d => d.strokeWidth ?? null` */\n  @Input() pointStrokeWidth?: NumericAccessor<PointDatum>\n\n  /** Point shape accessor. Default: `TopoJSONMapPointShape.Circle` */\n  @Input() pointShape?: StringAccessor<PointDatum>\n\n  /** Point ring width for ring-shaped points. Default: `2` */\n  @Input() pointRingWidth?: NumericAccessor<PointDatum>\n\n  /** Point cursor constant value or accessor function. Default: `null` */\n  @Input() pointCursor?: StringAccessor<PointDatum>\n\n  /** Point longitude accessor function. Default: `d => d.longitude ?? null` */\n  @Input() longitude?: NumericAccessor<PointDatum>\n\n  /** Point latitude accessor function. Default: `d => d.latitude ?? null` */\n  @Input() latitude?: NumericAccessor<PointDatum>\n\n  /** Point inner label accessor function. Default: `undefined` */\n  @Input() pointLabel?: StringAccessor<PointDatum>\n\n  /** Point inner label color accessor function or constant value.\n   * By default, the label color will be set, depending on the point brightness, either to\n   * `--vis-map-point-label-text-color-dark` or to `--vis-map-point-label-text-color-light` CSS variable.\n   * Default: `undefined` */\n  @Input() pointLabelColor?: ColorAccessor<PointDatum>\n\n  /** Point label position. Default: `MapPointLabelPosition.Center` */\n  @Input() pointLabelPosition?: MapPointLabelPosition\n\n  /** Point bottom label accessor function. Default: `undefined` */\n  @Input() pointBottomLabel?: StringAccessor<PointDatum>\n\n  /** Point color brightness ratio for switching between dark and light text label color. Default: `0.65` */\n  @Input() pointLabelTextBrightnessRatio?: number\n\n  /** Point id accessor function. Default: `d => d.id` */\n  @Input() pointId?: ((d: PointDatum, i: number) => string)\n\n  /** Cluster color accessor function or constant value. Default: `undefined` */\n  @Input() clusterColor?: ColorAccessor<TopoJSONMapClusterDatum<PointDatum>>\n\n  /** Cluster radius accessor function or constant value. Default: `undefined` */\n  @Input() clusterRadius?: NumericAccessor<TopoJSONMapClusterDatum<PointDatum>>\n\n  /** Cluster inner label accessor function. Default: `d => d.pointCount` */\n  @Input() clusterLabel?: StringAccessor<TopoJSONMapClusterDatum<PointDatum>>\n\n  /** Cluster inner label color accessor function or constant value. Default: `undefined` */\n  @Input() clusterLabelColor?: StringAccessor<TopoJSONMapClusterDatum<PointDatum>>\n\n  /** Cluster bottom label accessor function. Default: `''` */\n  @Input() clusterBottomLabel?: StringAccessor<TopoJSONMapClusterDatum<PointDatum>>\n\n  /** The width of the cluster point ring. Default: `2` */\n  @Input() clusterRingWidth?: number\n\n  /** When cluster is expanded, show a background circle to better separate points from the base map. Default: `true` */\n  @Input() clusterBackground?: boolean\n\n  /** Defines whether the cluster should expand on click or not. Default: `true` */\n  @Input() clusterExpandOnClick?: boolean\n\n  /** Clustering distance in pixels. Default: `55` */\n  @Input() clusteringDistance?: number\n\n  /** Enable point clustering. Default: `false` */\n  @Input() clustering?: boolean\n\n  /** Enables blur and blending between neighbouring points. Default: `false` */\n  @Input() heatmapMode?: boolean\n\n  /** Heatmap blur filter stdDeviation value. Default: `10` */\n  @Input() heatmapModeBlurStdDeviation?: number\n\n  /** Zoom level at which the heatmap mode will be disabled. Default: `2.5` */\n  @Input() heatmapModeZoomLevelThreshold?: number\n\n  /** A single map point can have multiple properties displayed as a small pie chart.\n   * By setting the colorMap configuration you can specify data properties that should be mapped to various pie / donut segments.\n   *\n   * ```\n   * {\n   *  [key in keyof PointDatum]?: { color: string, className?: string }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   *  healthy: { color: 'green' },\n   *  warning: { color: 'orange' },\n   *  critical: { color: 'red' }\n   * }\n   * ```\n   * where every data point has the `healthy`, `warning` and `critical` numerical or boolean property.\n   * Note: Properties with 0 or falsy values will not be displayed in the pie chart.\n   * Default: `{}` */\n  @Input() colorMap?: TopoJSONMapPointStyles<PointDatum>\n  @Input() data: {areas?: AreaDatum[]; points?: PointDatum[]; links?: LinkDatum[]}\n\n  component: TopoJSONMap<AreaDatum, PointDatum, LinkDatum> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new TopoJSONMap<AreaDatum, PointDatum, LinkDatum>(this.getConfig())\n\n    if (this.data) {\n      this.component.setData(this.data)\n      this.componentContainer?.render()\n    }\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    if (changes.data) { this.component?.setData(this.data) }\n    this.component?.setConfig(this.getConfig())\n    this.componentContainer?.render()\n  }\n\n  private getConfig (): TopoJSONMapConfigInterface<AreaDatum, PointDatum, LinkDatum> {\n    const { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, sourceLongitude, sourceLatitude, targetLongitude, targetLatitude, sourcePointRadius, sourcePointColor, flowParticleColor, flowParticleRadius, flowParticleSpeed, flowParticleDensity, enableFlowAnimation, onSourcePointClick, onSourcePointMouseEnter, onSourcePointMouseLeave, areaId, areaColor, areaCursor, areaLabel, pointColor, pointRadius, pointStrokeWidth, pointShape, pointRingWidth, pointCursor, longitude, latitude, pointLabel, pointLabelColor, pointLabelPosition, pointBottomLabel, pointLabelTextBrightnessRatio, pointId, clusterColor, clusterRadius, clusterLabel, clusterLabelColor, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, clustering, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold, colorMap } = this\n    const config = { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, sourceLongitude, sourceLatitude, targetLongitude, targetLatitude, sourcePointRadius, sourcePointColor, flowParticleColor, flowParticleRadius, flowParticleSpeed, flowParticleDensity, enableFlowAnimation, onSourcePointClick, onSourcePointMouseEnter, onSourcePointMouseLeave, areaId, areaColor, areaCursor, areaLabel, pointColor, pointRadius, pointStrokeWidth, pointShape, pointRingWidth, pointCursor, longitude, latitude, pointLabel, pointLabelColor, pointLabelPosition, pointBottomLabel, pointLabelTextBrightnessRatio, pointId, clusterColor, clusterRadius, clusterLabel, clusterLabelColor, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, clustering, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold, colorMap }\n    const keys = Object.keys(config) as (keyof TopoJSONMapConfigInterface<AreaDatum, PointDatum, LinkDatum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
@@ -2296,8 +2296,8 @@ class VisTopoJSONMapComponent {
2296
2296
  (_c = this.componentContainer) === null || _c === void 0 ? void 0 : _c.render();
2297
2297
  }
2298
2298
  getConfig() {
2299
- const { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, areaId, areaColor, areaCursor, pointColor, pointRadius, pointStrokeWidth, pointCursor, longitude, latitude, pointLabel, pointLabelPosition, pointLabelTextBrightnessRatio, pointId, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold } = this;
2300
- const config = { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, areaId, areaColor, areaCursor, pointColor, pointRadius, pointStrokeWidth, pointCursor, longitude, latitude, pointLabel, pointLabelPosition, pointLabelTextBrightnessRatio, pointId, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold };
2299
+ const { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, sourceLongitude, sourceLatitude, targetLongitude, targetLatitude, sourcePointRadius, sourcePointColor, flowParticleColor, flowParticleRadius, flowParticleSpeed, flowParticleDensity, enableFlowAnimation, onSourcePointClick, onSourcePointMouseEnter, onSourcePointMouseLeave, areaId, areaColor, areaCursor, areaLabel, pointColor, pointRadius, pointStrokeWidth, pointShape, pointRingWidth, pointCursor, longitude, latitude, pointLabel, pointLabelColor, pointLabelPosition, pointBottomLabel, pointLabelTextBrightnessRatio, pointId, clusterColor, clusterRadius, clusterLabel, clusterLabelColor, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, clustering, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold, colorMap } = this;
2300
+ const config = { duration, events, attributes, projection, topojson, mapFeatureName, mapFitToPoints, zoomFactor, disableZoom, zoomExtent, zoomDuration, linkWidth, linkColor, linkCursor, linkId, linkSource, linkTarget, sourceLongitude, sourceLatitude, targetLongitude, targetLatitude, sourcePointRadius, sourcePointColor, flowParticleColor, flowParticleRadius, flowParticleSpeed, flowParticleDensity, enableFlowAnimation, onSourcePointClick, onSourcePointMouseEnter, onSourcePointMouseLeave, areaId, areaColor, areaCursor, areaLabel, pointColor, pointRadius, pointStrokeWidth, pointShape, pointRingWidth, pointCursor, longitude, latitude, pointLabel, pointLabelColor, pointLabelPosition, pointBottomLabel, pointLabelTextBrightnessRatio, pointId, clusterColor, clusterRadius, clusterLabel, clusterLabelColor, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, clustering, heatmapMode, heatmapModeBlurStdDeviation, heatmapModeZoomLevelThreshold, colorMap };
2301
2301
  const keys = Object.keys(config);
2302
2302
  keys.forEach(key => { if (config[key] === undefined)
2303
2303
  delete config[key]; });
@@ -2305,7 +2305,7 @@ class VisTopoJSONMapComponent {
2305
2305
  }
2306
2306
  }
2307
2307
  VisTopoJSONMapComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisTopoJSONMapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2308
- VisTopoJSONMapComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisTopoJSONMapComponent, selector: "vis-topojson-map", inputs: { duration: "duration", events: "events", attributes: "attributes", projection: "projection", topojson: "topojson", mapFeatureName: "mapFeatureName", mapFitToPoints: "mapFitToPoints", zoomFactor: "zoomFactor", disableZoom: "disableZoom", zoomExtent: "zoomExtent", zoomDuration: "zoomDuration", linkWidth: "linkWidth", linkColor: "linkColor", linkCursor: "linkCursor", linkId: "linkId", linkSource: "linkSource", linkTarget: "linkTarget", areaId: "areaId", areaColor: "areaColor", areaCursor: "areaCursor", pointColor: "pointColor", pointRadius: "pointRadius", pointStrokeWidth: "pointStrokeWidth", pointCursor: "pointCursor", longitude: "longitude", latitude: "latitude", pointLabel: "pointLabel", pointLabelPosition: "pointLabelPosition", pointLabelTextBrightnessRatio: "pointLabelTextBrightnessRatio", pointId: "pointId", heatmapMode: "heatmapMode", heatmapModeBlurStdDeviation: "heatmapModeBlurStdDeviation", heatmapModeZoomLevelThreshold: "heatmapModeZoomLevelThreshold", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisTopoJSONMapComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
2308
+ VisTopoJSONMapComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisTopoJSONMapComponent, selector: "vis-topojson-map", inputs: { duration: "duration", events: "events", attributes: "attributes", projection: "projection", topojson: "topojson", mapFeatureName: "mapFeatureName", mapFitToPoints: "mapFitToPoints", zoomFactor: "zoomFactor", disableZoom: "disableZoom", zoomExtent: "zoomExtent", zoomDuration: "zoomDuration", linkWidth: "linkWidth", linkColor: "linkColor", linkCursor: "linkCursor", linkId: "linkId", linkSource: "linkSource", linkTarget: "linkTarget", sourceLongitude: "sourceLongitude", sourceLatitude: "sourceLatitude", targetLongitude: "targetLongitude", targetLatitude: "targetLatitude", sourcePointRadius: "sourcePointRadius", sourcePointColor: "sourcePointColor", flowParticleColor: "flowParticleColor", flowParticleRadius: "flowParticleRadius", flowParticleSpeed: "flowParticleSpeed", flowParticleDensity: "flowParticleDensity", enableFlowAnimation: "enableFlowAnimation", onSourcePointClick: "onSourcePointClick", onSourcePointMouseEnter: "onSourcePointMouseEnter", onSourcePointMouseLeave: "onSourcePointMouseLeave", areaId: "areaId", areaColor: "areaColor", areaCursor: "areaCursor", areaLabel: "areaLabel", pointColor: "pointColor", pointRadius: "pointRadius", pointStrokeWidth: "pointStrokeWidth", pointShape: "pointShape", pointRingWidth: "pointRingWidth", pointCursor: "pointCursor", longitude: "longitude", latitude: "latitude", pointLabel: "pointLabel", pointLabelColor: "pointLabelColor", pointLabelPosition: "pointLabelPosition", pointBottomLabel: "pointBottomLabel", pointLabelTextBrightnessRatio: "pointLabelTextBrightnessRatio", pointId: "pointId", clusterColor: "clusterColor", clusterRadius: "clusterRadius", clusterLabel: "clusterLabel", clusterLabelColor: "clusterLabelColor", clusterBottomLabel: "clusterBottomLabel", clusterRingWidth: "clusterRingWidth", clusterBackground: "clusterBackground", clusterExpandOnClick: "clusterExpandOnClick", clusteringDistance: "clusteringDistance", clustering: "clustering", heatmapMode: "heatmapMode", heatmapModeBlurStdDeviation: "heatmapModeBlurStdDeviation", heatmapModeZoomLevelThreshold: "heatmapModeZoomLevelThreshold", colorMap: "colorMap", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisTopoJSONMapComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
2309
2309
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisTopoJSONMapComponent, decorators: [{
2310
2310
  type: Component,
2311
2311
  args: [{
@@ -2348,18 +2348,52 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
2348
2348
  type: Input
2349
2349
  }], linkTarget: [{
2350
2350
  type: Input
2351
+ }], sourceLongitude: [{
2352
+ type: Input
2353
+ }], sourceLatitude: [{
2354
+ type: Input
2355
+ }], targetLongitude: [{
2356
+ type: Input
2357
+ }], targetLatitude: [{
2358
+ type: Input
2359
+ }], sourcePointRadius: [{
2360
+ type: Input
2361
+ }], sourcePointColor: [{
2362
+ type: Input
2363
+ }], flowParticleColor: [{
2364
+ type: Input
2365
+ }], flowParticleRadius: [{
2366
+ type: Input
2367
+ }], flowParticleSpeed: [{
2368
+ type: Input
2369
+ }], flowParticleDensity: [{
2370
+ type: Input
2371
+ }], enableFlowAnimation: [{
2372
+ type: Input
2373
+ }], onSourcePointClick: [{
2374
+ type: Input
2375
+ }], onSourcePointMouseEnter: [{
2376
+ type: Input
2377
+ }], onSourcePointMouseLeave: [{
2378
+ type: Input
2351
2379
  }], areaId: [{
2352
2380
  type: Input
2353
2381
  }], areaColor: [{
2354
2382
  type: Input
2355
2383
  }], areaCursor: [{
2356
2384
  type: Input
2385
+ }], areaLabel: [{
2386
+ type: Input
2357
2387
  }], pointColor: [{
2358
2388
  type: Input
2359
2389
  }], pointRadius: [{
2360
2390
  type: Input
2361
2391
  }], pointStrokeWidth: [{
2362
2392
  type: Input
2393
+ }], pointShape: [{
2394
+ type: Input
2395
+ }], pointRingWidth: [{
2396
+ type: Input
2363
2397
  }], pointCursor: [{
2364
2398
  type: Input
2365
2399
  }], longitude: [{
@@ -2368,18 +2402,44 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
2368
2402
  type: Input
2369
2403
  }], pointLabel: [{
2370
2404
  type: Input
2405
+ }], pointLabelColor: [{
2406
+ type: Input
2371
2407
  }], pointLabelPosition: [{
2372
2408
  type: Input
2409
+ }], pointBottomLabel: [{
2410
+ type: Input
2373
2411
  }], pointLabelTextBrightnessRatio: [{
2374
2412
  type: Input
2375
2413
  }], pointId: [{
2376
2414
  type: Input
2415
+ }], clusterColor: [{
2416
+ type: Input
2417
+ }], clusterRadius: [{
2418
+ type: Input
2419
+ }], clusterLabel: [{
2420
+ type: Input
2421
+ }], clusterLabelColor: [{
2422
+ type: Input
2423
+ }], clusterBottomLabel: [{
2424
+ type: Input
2425
+ }], clusterRingWidth: [{
2426
+ type: Input
2427
+ }], clusterBackground: [{
2428
+ type: Input
2429
+ }], clusterExpandOnClick: [{
2430
+ type: Input
2431
+ }], clusteringDistance: [{
2432
+ type: Input
2433
+ }], clustering: [{
2434
+ type: Input
2377
2435
  }], heatmapMode: [{
2378
2436
  type: Input
2379
2437
  }], heatmapModeBlurStdDeviation: [{
2380
2438
  type: Input
2381
2439
  }], heatmapModeZoomLevelThreshold: [{
2382
2440
  type: Input
2441
+ }], colorMap: [{
2442
+ type: Input
2383
2443
  }], data: [{
2384
2444
  type: Input
2385
2445
  }] } });