@unovis/angular 1.0.0-beta.8 → 1.0.0-beta.8.patch.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.
@@ -50,7 +50,7 @@ export declare class VisTopoJSONMapComponent<AreaDatum, PointDatum, LinkDatum> i
50
50
  [attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);
51
51
  };
52
52
  };
53
- /** MapProjection (or D3's GeoProjection) instance. Default: `MapProjection.Mercator()` */
53
+ /** MapProjection (aka D3's GeoProjection) instance. Default: `MapProjection.Kavrayskiy7()` */
54
54
  projection?: GeoProjection;
55
55
  /** Map data in the TopoJSON topology format. Default: `undefined` */
56
56
  topojson?: TopoJSON.Topology;
@@ -108,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
108
108
  }], data: [{
109
109
  type: Input
110
110
  }] } });
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 (or D3's GeoProjection) instance. Default: `MapProjection.Mercator()` */\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: `[1, 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<AreaDatum>\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<AreaDatum>\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"]}
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: `[1, 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<AreaDatum>\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<AreaDatum>\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"]}
@@ -24,7 +24,7 @@ export class VisLeafletMapComponent {
24
24
  }
25
25
  }
26
26
  VisLeafletMapComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VisLeafletMapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
27
- VisLeafletMapComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: VisLeafletMapComponent, selector: "vis-leaflet-map", inputs: { width: "width", height: "height", duration: "duration", events: "events", attributes: "attributes", flyToDuration: "flyToDuration", fitViewPadding: "fitViewPadding", zoomDuration: "zoomDuration", initialBounds: "initialBounds", fitBoundsOnUpdate: "fitBoundsOnUpdate", fitViewOnInit: "fitViewOnInit", fitViewOnUpdate: "fitViewOnUpdate", style: "style", styleDarkTheme: "styleDarkTheme", accessToken: "accessToken", attribution: "attribution", onMapInitialized: "onMapInitialized", onMapMoveZoom: "onMapMoveZoom", onMapMoveStart: "onMapMoveStart", onMapMoveEnd: "onMapMoveEnd", onMapZoomStart: "onMapZoomStart", onMapZoomEnd: "onMapZoomEnd", onMapClick: "onMapClick", pointLongitude: "pointLongitude", pointLatitude: "pointLatitude", pointId: "pointId", pointShape: "pointShape", pointColor: "pointColor", pointRadius: "pointRadius", pointLabel: "pointLabel", pointBottomLabel: "pointBottomLabel", pointCursor: "pointCursor", selectedPointId: "selectedPointId", clusterColor: "clusterColor", clusterRadius: "clusterRadius", clusterLabel: "clusterLabel", clusterBottomLabel: "clusterBottomLabel", clusterRingWidth: "clusterRingWidth", clusterBackground: "clusterBackground", clusterExpandOnClick: "clusterExpandOnClick", clusteringDistance: "clusteringDistance", colorMap: "colorMap", topoJSONLayer: "topoJSONLayer", tooltip: "tooltip", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisLeafletMapComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: '<div #container class="unovis-leaflet-map-container"></div>', isInline: true, styles: [".unovis-leaflet-map-container { width: 100%; height: 100%; position: relative; }"] });
27
+ VisLeafletMapComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: VisLeafletMapComponent, selector: "vis-leaflet-map", inputs: { width: "width", height: "height", duration: "duration", events: "events", attributes: "attributes", flyToDuration: "flyToDuration", fitViewPadding: "fitViewPadding", zoomDuration: "zoomDuration", initialBounds: "initialBounds", fitBoundsOnUpdate: "fitBoundsOnUpdate", fitViewOnInit: "fitViewOnInit", fitViewOnUpdate: "fitViewOnUpdate", style: "style", styleDarkTheme: "styleDarkTheme", accessToken: "accessToken", attribution: "attribution", renderer: "renderer", onMapInitialized: "onMapInitialized", onMapMoveZoom: "onMapMoveZoom", onMapMoveStart: "onMapMoveStart", onMapMoveEnd: "onMapMoveEnd", onMapZoomStart: "onMapZoomStart", onMapZoomEnd: "onMapZoomEnd", onMapClick: "onMapClick", pointLongitude: "pointLongitude", pointLatitude: "pointLatitude", pointId: "pointId", pointShape: "pointShape", pointColor: "pointColor", pointRadius: "pointRadius", pointLabel: "pointLabel", pointBottomLabel: "pointBottomLabel", pointCursor: "pointCursor", selectedPointId: "selectedPointId", clusterColor: "clusterColor", clusterRadius: "clusterRadius", clusterLabel: "clusterLabel", clusterBottomLabel: "clusterBottomLabel", clusterRingWidth: "clusterRingWidth", clusterBackground: "clusterBackground", clusterExpandOnClick: "clusterExpandOnClick", clusteringDistance: "clusteringDistance", colorMap: "colorMap", topoJSONLayer: "topoJSONLayer", tooltip: "tooltip", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisLeafletMapComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: '<div #container class="unovis-leaflet-map-container"></div>', isInline: true, styles: [".unovis-leaflet-map-container { width: 100%; height: 100%; position: relative; }"] });
28
28
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VisLeafletMapComponent, decorators: [{
29
29
  type: Component,
30
30
  args: [{
@@ -69,6 +69,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
69
69
  type: Input
70
70
  }], attribution: [{
71
71
  type: Input
72
+ }], renderer: [{
73
+ type: Input
72
74
  }], onMapInitialized: [{
73
75
  type: Input
74
76
  }], onMapMoveZoom: [{
@@ -128,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
128
130
  }], data: [{
129
131
  type: Input
130
132
  }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaflet-map.component.js","sourceRoot":"","sources":["../../../../../src/html-components/leaflet-map/leaflet-map.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAiB,KAAK,EAAiB,SAAS,EAAc,MAAM,eAAe,CAAA;AACrG,OAAO,EACL,UAAU,GAaX,MAAM,YAAY,CAAA;AAEnB,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;;AAS7C,MAAM,OAAO,sBAAsB;IA4MjC,eAAe;QACb,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;QAC/B,IAAI,CAAC,SAAS,GAAG,IAAI,UAAU,CAAQ,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;IAC5F,CAAC;IAED,WAAW,CAAE,OAAsB;;QACjC,IAAI,OAAO,CAAC,IAAI,EAAE;YAChB,MAAA,IAAI,CAAC,SAAS,0CAAE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;SACnC;QACD,MAAA,IAAI,CAAC,SAAS,0CAAE,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;IAC7C,CAAC;IAEO,SAAS;QACf,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,EAAE,YAAY,EAAE,aAAa,EAAE,iBAAiB,EAAE,aAAa,EAAE,eAAe,EAAE,WAAW,EAAE,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,gBAAgB,EAAE,aAAa,EAAE,cAAc,EAAE,YAAY,EAAE,cAAc,EAAE,YAAY,EAAE,UAAU,EAAE,cAAc,EAAE,aAAa,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,gBAAgB,EAAE,WAAW,EAAE,eAAe,EAAE,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,QAAQ,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,IAAI,CAAA;QAC9nB,MAAM,MAAM,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,EAAE,YAAY,EAAE,aAAa,EAAE,iBAAiB,EAAE,aAAa,EAAE,eAAe,EAAE,WAAW,EAAE,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,gBAAgB,EAAE,aAAa,EAAE,cAAc,EAAE,YAAY,EAAE,cAAc,EAAE,YAAY,EAAE,UAAU,EAAE,cAAc,EAAE,aAAa,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,gBAAgB,EAAE,WAAW,EAAE,eAAe,EAAE,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,QAAQ,EAAE,aAAa,EAAE,OAAO,EAAE,CAAA;QAChoB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAA+C,CAAA;QAC9E,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,SAAS;YAAE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAE1E,OAAO,MAAM,CAAA;IACf,CAAC;;oHA/NU,sBAAsB;wGAAtB,sBAAsB,03CAFtB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,sBAAsB,EAAE,CAAC,0JAHrE,6DAA6D;4FAK5D,sBAAsB;kBAPlC,SAAS;mBAAC;oBACT,QAAQ,EAAE,iBAAiB;oBAC3B,QAAQ,EAAE,6DAA6D;oBACvE,MAAM,EAAE,CAAC,kFAAkF,CAAC;oBAC5F,gDAAgD;oBAChD,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,wBAAwB,EAAE,CAAC;iBAChF;8BAE4C,YAAY;sBAAtD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAGhC,KAAK;sBAAb,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAmBG,MAAM;sBAAd,KAAK;gBAwBG,UAAU;sBAAlB,KAAK;gBAOG,aAAa;sBAArB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,iBAAiB;sBAAzB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAGG,gBAAgB;sBAAxB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,gBAAgB;sBAAxB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,kBAAkB;sBAA1B,KAAK;gBAGG,gBAAgB;sBAAxB,KAAK;gBAGG,iBAAiB;sBAAzB,KAAK;gBAGG,oBAAoB;sBAA5B,KAAK;gBAGG,kBAAkB;sBAA1B,KAAK;gBAmBG,QAAQ;sBAAhB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAWG,OAAO;sBAAf,KAAK;gBAGG,IAAI;sBAAZ,KAAK","sourcesContent":["import { Component, AfterViewInit, Input, SimpleChanges, ViewChild, ElementRef } from '@angular/core'\nimport {\n  LeafletMap,\n  LeafletMapConfigInterface,\n  VisEventType,\n  VisEventCallback,\n  Bounds,\n  MapZoomState,\n  NumericAccessor,\n  StringAccessor,\n  ColorAccessor,\n  LeafletMapPointDatum,\n  LeafletMapPointStyles,\n  Tooltip,\n  LeafletMapClusterDatum,\n} from '@unovis/ts'\nimport { StyleSpecification } from 'maplibre-gl'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-leaflet-map',\n  template: '<div #container class=\"unovis-leaflet-map-container\"></div>',\n  styles: ['.unovis-leaflet-map-container { width: 100%; height: 100%; position: relative; }'],\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisLeafletMapComponent }],\n})\nexport class VisLeafletMapComponent<Datum> implements LeafletMapConfigInterface<Datum>, AfterViewInit {\n  @ViewChild('container', { static: false }) containerRef: ElementRef\n\n  /** Width in pixels or in CSS units. By default, the map will automatically fit to the size of the parent element. Default: `undefined`. */\n  @Input() width?: number | string\n  /** Height in pixels or in CSS units. By default, the map will automatically fit to the size of the parent element. Default: `undefined`. */\n  @Input() height?: number | string\n\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  /** Animation duration when the map is automatically panning or zooming to a point or area. Default: `1500` ms */\n  @Input() flyToDuration?: number\n\n  /** Padding to be used when the `fitView` function has been called. The value is in pixels. Default: `[150, 150]` */\n  @Input() fitViewPadding?: [number, number]\n\n  /** Animation duration for the `setZoom` function. Default: `800` ms */\n  @Input() zoomDuration?: number\n\n  /** Default bounds that will be applied on the first map render if the bounds property is not set. Default: `undefined` */\n  @Input() initialBounds?: Bounds\n\n  /** Force set map bounds on config and data updates. Default: `undefined` */\n  @Input() fitBoundsOnUpdate?: Bounds\n\n  /** Fit the view to contain the data points on map initialization. Default: `true` */\n  @Input() fitViewOnInit?: boolean\n\n  /** Fit the view to contain the data points on map config and data updates. Default: `false` */\n  @Input() fitViewOnUpdate?: boolean\n\n  /** MapLibre StyleSpecification settings. Default: `MapLibreArcticLight` */\n  @Input() style: StyleSpecification | string\n\n  /** MapLibre StyleSpecification settings for dark theme. Default: `undefined` */\n  @Input() styleDarkTheme?: StyleSpecification | string\n\n  /** Tile server access token or API key. Default: `''` */\n  @Input() accessToken?: string\n\n  /** Array of attribution labels. Default: `['<a href=\"https://www.openstreetmap.org/copyright\" target=\"_blank\">OpenStreetMap contributors</a>']` */\n  @Input() attribution?: string[]\n\n  /** Function to be called after the map's async initialization is done. Default: `undefined` */\n  @Input() onMapInitialized?: (() => void)\n\n  /** Map Move / Zoom unified callback function. Default: `undefined` */\n  @Input() onMapMoveZoom?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Move Start callback function. Default: `undefined` */\n  @Input() onMapMoveStart?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Move End callback function. Default: `undefined` */\n  @Input() onMapMoveEnd?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Zoom Start callback function. Default: `undefined` */\n  @Input() onMapZoomStart?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Zoom End callback function. Default: `undefined` */\n  @Input() onMapZoomEnd?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Zoom End callback function. Default: `undefined` */\n  @Input() onMapClick?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Point longitude accessor function. Default: `d => d.longitude` */\n  @Input() pointLongitude?: NumericAccessor<Datum>\n\n  /** Point latitude accessor function. Default: `d => d.latitude` */\n  @Input() pointLatitude?: NumericAccessor<Datum>\n\n  /** Point id accessor function or constant value. Default: `d => d.id` */\n  @Input() pointId?: StringAccessor<Datum>\n\n  /** Point shape accessor function or constant value. Default: `d => d.shape` */\n  @Input() pointShape?: StringAccessor<Datum>\n\n  /** Point color accessor function or constant value. Default: `d => d.color` */\n  @Input() pointColor?: ColorAccessor<Datum>\n\n  /** Point radius accessor function or constant value. Default: `undefined` */\n  @Input() pointRadius?: NumericAccessor<LeafletMapPointDatum<Datum>>\n\n  /** Point inner label accessor function. Default: `d => d.point_count ?? ''` */\n  @Input() pointLabel?: StringAccessor<LeafletMapPointDatum<Datum>>\n\n  /** Point bottom label accessor function. Default: `''` */\n  @Input() pointBottomLabel?: StringAccessor<LeafletMapPointDatum<Datum>>\n\n  /** Point cursor value or accessor function. Default: `null` */\n  @Input() pointCursor?: StringAccessor<LeafletMapPointDatum<Datum>>\n\n  /** Set selected point by its unique id. Default: `undefined` */\n  @Input() selectedPointId?: string\n\n  /** Cluster color accessor function or constant value. Default: `undefined`  */\n  @Input() clusterColor?: ColorAccessor<Datum>\n\n  /** Cluster radius accessor function or constant value. Default: `undefined`  */\n  @Input() clusterRadius?: NumericAccessor<LeafletMapClusterDatum<Datum>>\n\n  /** Cluster inner label accessor function. Default: `d => d.point_count`  */\n  @Input() clusterLabel?: StringAccessor<LeafletMapClusterDatum<Datum>>\n\n  /** Cluster bottom label accessor function. Default: `''` */\n  @Input() clusterBottomLabel?: StringAccessor<LeafletMapClusterDatum<Datum>>\n\n  /** The width of the cluster point outline. Default: `1.25` */\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. This value will be passed to Supercluster as the `radius` property https://github.com/mapbox/supercluster. Default: `55` */\n  @Input() clusteringDistance?: number\n\n  /** A single map point can have multiple properties displayed as a small pie chart (or a donut chart for a cluster of points).\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 Datum]?: { color: string, className?: string }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\healthy: { color: 'green' },\n   * \\warning: { color: 'orange' },\n   * \\danger: { color: 'red' }\n   * }\n   * ```\n   * where every data point has the `healthy`, `warning` and `danger` numerical or boolean property. */\n  @Input() colorMap?: LeafletMapPointStyles<Datum>\n\n  /** A TopoJSON Geometry layer to be displayed on top of the map. Supports fill and stroke */\n  @Input() topoJSONLayer?: {\n    sources: any;\n    featureName?: string;\n    fillProperty?: string;\n    strokeProperty?: string;\n    fillOpacity?: number;\n    strokeOpacity?: number;\n    strokeWidth?: number;\n  }\n\n  /** Tooltip component. Default: `undefined` */\n  @Input() tooltip?: Tooltip\n\n  /** Data */\n  @Input() data?: Datum[]\n\n  component: LeafletMap<Datum> | undefined\n\n  ngAfterViewInit (): void {\n    const config = this.getConfig()\n    this.component = new LeafletMap<Datum>(this.containerRef.nativeElement, config, this.data)\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    if (changes.data) {\n      this.component?.setData(this.data)\n    }\n    this.component?.setConfig(this.getConfig())\n  }\n\n  private getConfig (): LeafletMapConfigInterface<Datum> {\n    const { width, height, duration, events, attributes, flyToDuration, fitViewPadding, zoomDuration, initialBounds, fitBoundsOnUpdate, fitViewOnInit, fitViewOnUpdate, accessToken, style, styleDarkTheme, attribution, onMapInitialized, onMapMoveZoom, onMapMoveStart, onMapMoveEnd, onMapZoomStart, onMapZoomEnd, onMapClick, pointLongitude, pointLatitude, pointId, pointShape, pointColor, pointRadius, pointLabel, pointBottomLabel, pointCursor, selectedPointId, clusterColor, clusterRadius, clusterLabel, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, colorMap, topoJSONLayer, tooltip } = this\n    const config = { width, height, duration, events, attributes, flyToDuration, fitViewPadding, zoomDuration, initialBounds, fitBoundsOnUpdate, fitViewOnInit, fitViewOnUpdate, accessToken, style, styleDarkTheme, attribution, onMapInitialized, onMapMoveZoom, onMapMoveStart, onMapMoveEnd, onMapZoomStart, onMapZoomEnd, onMapClick, pointLongitude, pointLatitude, pointId, pointShape, pointColor, pointRadius, pointLabel, pointBottomLabel, pointCursor, selectedPointId, clusterColor, clusterRadius, clusterLabel, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, colorMap, topoJSONLayer, tooltip }\n    const keys = Object.keys(config) as (keyof LeafletMapConfigInterface<Datum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaflet-map.component.js","sourceRoot":"","sources":["../../../../../src/html-components/leaflet-map/leaflet-map.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, AfterViewInit, Input, SimpleChanges, ViewChild, ElementRef } from '@angular/core'\nimport {\n  LeafletMap,\n  LeafletMapConfigInterface,\n  VisEventType,\n  VisEventCallback,\n  Bounds,\n  MapZoomState,\n  NumericAccessor,\n  StringAccessor,\n  ColorAccessor,\n  LeafletMapPointDatum,\n  LeafletMapPointStyles,\n  Tooltip,\n  LeafletMapClusterDatum,\n  LeafletMapRenderer,\n} from '@unovis/ts'\nimport { StyleSpecification } from 'maplibre-gl'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-leaflet-map',\n  template: '<div #container class=\"unovis-leaflet-map-container\"></div>',\n  styles: ['.unovis-leaflet-map-container { width: 100%; height: 100%; position: relative; }'],\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisLeafletMapComponent }],\n})\nexport class VisLeafletMapComponent<Datum> implements LeafletMapConfigInterface<Datum>, AfterViewInit {\n  @ViewChild('container', { static: false }) containerRef: ElementRef\n\n  /** Width in pixels or in CSS units. By default, the map will automatically fit to the size of the parent element. Default: `undefined`. */\n  @Input() width?: number | string\n  /** Height in pixels or in CSS units. By default, the map will automatically fit to the size of the parent element. Default: `undefined`. */\n  @Input() height?: number | string\n\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  /** Animation duration when the map is automatically panning or zooming to a point or area. Default: `1500` ms */\n  @Input() flyToDuration?: number\n\n  /** Padding to be used when the `fitView` function has been called. The value is in pixels. Default: `[150, 150]` */\n  @Input() fitViewPadding?: [number, number]\n\n  /** Animation duration for the `setZoom` function. Default: `800` ms */\n  @Input() zoomDuration?: number\n\n  /** Default bounds that will be applied on the first map render if the bounds property is not set. Default: `undefined` */\n  @Input() initialBounds?: Bounds\n\n  /** Force set map bounds on config and data updates. Default: `undefined` */\n  @Input() fitBoundsOnUpdate?: Bounds\n\n  /** Fit the view to contain the data points on map initialization. Default: `true` */\n  @Input() fitViewOnInit?: boolean\n\n  /** Fit the view to contain the data points on map config and data updates. Default: `false` */\n  @Input() fitViewOnUpdate?: boolean\n\n  /** MapLibre StyleSpecification settings. Default: `MapLibreArcticLight` */\n  @Input() style: StyleSpecification | string\n\n  /** MapLibre StyleSpecification settings for dark theme. Default: `undefined` */\n  @Input() styleDarkTheme?: StyleSpecification | string\n\n  /** Tile server access token or API key. Default: `''` */\n  @Input() accessToken?: string\n\n  /** Array of attribution labels. Default: `['<a href=\"https://www.openstreetmap.org/copyright\" target=\"_blank\">OpenStreetMap contributors</a>']` */\n  @Input() attribution?: string[]\n\n  /** Rendering mode for map's tile layer. For raster files, use `LeafletMapRenderer.Raster`. Default: `LeafletMapRenderer.MapLibre` */\n  @Input() renderer?: LeafletMapRenderer | string\n\n  /** Function to be called after the map's async initialization is done. Default: `undefined` */\n  @Input() onMapInitialized?: (() => void)\n\n  /** Map Move / Zoom unified callback function. Default: `undefined` */\n  @Input() onMapMoveZoom?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Move Start callback function. Default: `undefined` */\n  @Input() onMapMoveStart?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Move End callback function. Default: `undefined` */\n  @Input() onMapMoveEnd?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Zoom Start callback function. Default: `undefined` */\n  @Input() onMapZoomStart?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Zoom End callback function. Default: `undefined` */\n  @Input() onMapZoomEnd?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Map Zoom End callback function. Default: `undefined` */\n  @Input() onMapClick?: (({ mapCenter, zoomLevel, bounds }: MapZoomState) => void)\n\n  /** Point longitude accessor function. Default: `d => d.longitude` */\n  @Input() pointLongitude?: NumericAccessor<Datum>\n\n  /** Point latitude accessor function. Default: `d => d.latitude` */\n  @Input() pointLatitude?: NumericAccessor<Datum>\n\n  /** Point id accessor function or constant value. Default: `d => d.id` */\n  @Input() pointId?: StringAccessor<Datum>\n\n  /** Point shape accessor function or constant value. Default: `d => d.shape` */\n  @Input() pointShape?: StringAccessor<Datum>\n\n  /** Point color accessor function or constant value. Default: `d => d.color` */\n  @Input() pointColor?: ColorAccessor<Datum>\n\n  /** Point radius accessor function or constant value. Default: `undefined` */\n  @Input() pointRadius?: NumericAccessor<LeafletMapPointDatum<Datum>>\n\n  /** Point inner label accessor function. Default: `d => d.point_count ?? ''` */\n  @Input() pointLabel?: StringAccessor<LeafletMapPointDatum<Datum>>\n\n  /** Point bottom label accessor function. Default: `''` */\n  @Input() pointBottomLabel?: StringAccessor<LeafletMapPointDatum<Datum>>\n\n  /** Point cursor value or accessor function. Default: `null` */\n  @Input() pointCursor?: StringAccessor<LeafletMapPointDatum<Datum>>\n\n  /** Set selected point by its unique id. Default: `undefined` */\n  @Input() selectedPointId?: string\n\n  /** Cluster color accessor function or constant value. Default: `undefined`  */\n  @Input() clusterColor?: ColorAccessor<Datum>\n\n  /** Cluster radius accessor function or constant value. Default: `undefined`  */\n  @Input() clusterRadius?: NumericAccessor<LeafletMapClusterDatum<Datum>>\n\n  /** Cluster inner label accessor function. Default: `d => d.point_count`  */\n  @Input() clusterLabel?: StringAccessor<LeafletMapClusterDatum<Datum>>\n\n  /** Cluster bottom label accessor function. Default: `''` */\n  @Input() clusterBottomLabel?: StringAccessor<LeafletMapClusterDatum<Datum>>\n\n  /** The width of the cluster point outline. Default: `1.25` */\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. This value will be passed to Supercluster as the `radius` property https://github.com/mapbox/supercluster. Default: `55` */\n  @Input() clusteringDistance?: number\n\n  /** A single map point can have multiple properties displayed as a small pie chart (or a donut chart for a cluster of points).\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 Datum]?: { color: string, className?: string }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\healthy: { color: 'green' },\n   * \\warning: { color: 'orange' },\n   * \\danger: { color: 'red' }\n   * }\n   * ```\n   * where every data point has the `healthy`, `warning` and `danger` numerical or boolean property. */\n  @Input() colorMap?: LeafletMapPointStyles<Datum>\n\n  /** A TopoJSON Geometry layer to be displayed on top of the map. Supports fill and stroke */\n  @Input() topoJSONLayer?: {\n    sources: any;\n    featureName?: string;\n    fillProperty?: string;\n    strokeProperty?: string;\n    fillOpacity?: number;\n    strokeOpacity?: number;\n    strokeWidth?: number;\n  }\n\n  /** Tooltip component. Default: `undefined` */\n  @Input() tooltip?: Tooltip\n\n  /** Data */\n  @Input() data?: Datum[]\n\n  component: LeafletMap<Datum> | undefined\n\n  ngAfterViewInit (): void {\n    const config = this.getConfig()\n    this.component = new LeafletMap<Datum>(this.containerRef.nativeElement, config, this.data)\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    if (changes.data) {\n      this.component?.setData(this.data)\n    }\n    this.component?.setConfig(this.getConfig())\n  }\n\n  private getConfig (): LeafletMapConfigInterface<Datum> {\n    const { width, height, duration, events, attributes, flyToDuration, fitViewPadding, zoomDuration, initialBounds, fitBoundsOnUpdate, fitViewOnInit, fitViewOnUpdate, accessToken, style, styleDarkTheme, attribution, onMapInitialized, onMapMoveZoom, onMapMoveStart, onMapMoveEnd, onMapZoomStart, onMapZoomEnd, onMapClick, pointLongitude, pointLatitude, pointId, pointShape, pointColor, pointRadius, pointLabel, pointBottomLabel, pointCursor, selectedPointId, clusterColor, clusterRadius, clusterLabel, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, colorMap, topoJSONLayer, tooltip } = this\n    const config = { width, height, duration, events, attributes, flyToDuration, fitViewPadding, zoomDuration, initialBounds, fitBoundsOnUpdate, fitViewOnInit, fitViewOnUpdate, accessToken, style, styleDarkTheme, attribution, onMapInitialized, onMapMoveZoom, onMapMoveStart, onMapMoveEnd, onMapZoomStart, onMapZoomEnd, onMapClick, pointLongitude, pointLatitude, pointId, pointShape, pointColor, pointRadius, pointLabel, pointBottomLabel, pointCursor, selectedPointId, clusterColor, clusterRadius, clusterLabel, clusterBottomLabel, clusterRingWidth, clusterBackground, clusterExpandOnClick, clusteringDistance, colorMap, topoJSONLayer, tooltip }\n    const keys = Object.keys(config) as (keyof LeafletMapConfigInterface<Datum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
@@ -1916,7 +1916,7 @@ class VisLeafletMapComponent {
1916
1916
  }
1917
1917
  }
1918
1918
  VisLeafletMapComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VisLeafletMapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1919
- VisLeafletMapComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: VisLeafletMapComponent, selector: "vis-leaflet-map", inputs: { width: "width", height: "height", duration: "duration", events: "events", attributes: "attributes", flyToDuration: "flyToDuration", fitViewPadding: "fitViewPadding", zoomDuration: "zoomDuration", initialBounds: "initialBounds", fitBoundsOnUpdate: "fitBoundsOnUpdate", fitViewOnInit: "fitViewOnInit", fitViewOnUpdate: "fitViewOnUpdate", style: "style", styleDarkTheme: "styleDarkTheme", accessToken: "accessToken", attribution: "attribution", onMapInitialized: "onMapInitialized", onMapMoveZoom: "onMapMoveZoom", onMapMoveStart: "onMapMoveStart", onMapMoveEnd: "onMapMoveEnd", onMapZoomStart: "onMapZoomStart", onMapZoomEnd: "onMapZoomEnd", onMapClick: "onMapClick", pointLongitude: "pointLongitude", pointLatitude: "pointLatitude", pointId: "pointId", pointShape: "pointShape", pointColor: "pointColor", pointRadius: "pointRadius", pointLabel: "pointLabel", pointBottomLabel: "pointBottomLabel", pointCursor: "pointCursor", selectedPointId: "selectedPointId", clusterColor: "clusterColor", clusterRadius: "clusterRadius", clusterLabel: "clusterLabel", clusterBottomLabel: "clusterBottomLabel", clusterRingWidth: "clusterRingWidth", clusterBackground: "clusterBackground", clusterExpandOnClick: "clusterExpandOnClick", clusteringDistance: "clusteringDistance", colorMap: "colorMap", topoJSONLayer: "topoJSONLayer", tooltip: "tooltip", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisLeafletMapComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: '<div #container class="unovis-leaflet-map-container"></div>', isInline: true, styles: [".unovis-leaflet-map-container { width: 100%; height: 100%; position: relative; }"] });
1919
+ VisLeafletMapComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: VisLeafletMapComponent, selector: "vis-leaflet-map", inputs: { width: "width", height: "height", duration: "duration", events: "events", attributes: "attributes", flyToDuration: "flyToDuration", fitViewPadding: "fitViewPadding", zoomDuration: "zoomDuration", initialBounds: "initialBounds", fitBoundsOnUpdate: "fitBoundsOnUpdate", fitViewOnInit: "fitViewOnInit", fitViewOnUpdate: "fitViewOnUpdate", style: "style", styleDarkTheme: "styleDarkTheme", accessToken: "accessToken", attribution: "attribution", renderer: "renderer", onMapInitialized: "onMapInitialized", onMapMoveZoom: "onMapMoveZoom", onMapMoveStart: "onMapMoveStart", onMapMoveEnd: "onMapMoveEnd", onMapZoomStart: "onMapZoomStart", onMapZoomEnd: "onMapZoomEnd", onMapClick: "onMapClick", pointLongitude: "pointLongitude", pointLatitude: "pointLatitude", pointId: "pointId", pointShape: "pointShape", pointColor: "pointColor", pointRadius: "pointRadius", pointLabel: "pointLabel", pointBottomLabel: "pointBottomLabel", pointCursor: "pointCursor", selectedPointId: "selectedPointId", clusterColor: "clusterColor", clusterRadius: "clusterRadius", clusterLabel: "clusterLabel", clusterBottomLabel: "clusterBottomLabel", clusterRingWidth: "clusterRingWidth", clusterBackground: "clusterBackground", clusterExpandOnClick: "clusterExpandOnClick", clusteringDistance: "clusteringDistance", colorMap: "colorMap", topoJSONLayer: "topoJSONLayer", tooltip: "tooltip", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisLeafletMapComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: '<div #container class="unovis-leaflet-map-container"></div>', isInline: true, styles: [".unovis-leaflet-map-container { width: 100%; height: 100%; position: relative; }"] });
1920
1920
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VisLeafletMapComponent, decorators: [{
1921
1921
  type: Component,
1922
1922
  args: [{
@@ -1961,6 +1961,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
1961
1961
  type: Input
1962
1962
  }], attribution: [{
1963
1963
  type: Input
1964
+ }], renderer: [{
1965
+ type: Input
1964
1966
  }], onMapInitialized: [{
1965
1967
  type: Input
1966
1968
  }], onMapMoveZoom: [{