@hestia-earth/ui-components 0.23.21 → 0.23.22

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,26 +1,30 @@
1
1
  /// <reference types="google.maps" />
2
- import { OnInit, AfterViewInit, OnDestroy, EventEmitter } from '@angular/core';
2
+ import { OnInit, OnDestroy, EventEmitter, DestroyRef } from '@angular/core';
3
+ import { Observable } from 'rxjs';
3
4
  import * as i0 from "@angular/core";
4
- export declare class MapsDrawingConfirmComponent implements OnInit, AfterViewInit, OnDestroy {
5
+ export declare class MapsDrawingConfirmComponent implements OnInit, OnDestroy {
6
+ protected mapLoaded$: Observable<boolean>;
5
7
  private listeners;
6
8
  private shapes;
7
9
  private feature?;
8
10
  private coordinates?;
9
11
  private map?;
10
12
  value?: string;
11
- modes: google.maps.drawing.OverlayType[];
13
+ modes?: google.maps.drawing.OverlayType[];
12
14
  center: {
13
15
  lat: number;
14
16
  lng: number;
15
17
  };
16
18
  zoom: number;
17
19
  closed: EventEmitter<string | google.maps.LatLngLiteral>;
18
- options: google.maps.MapOptions;
20
+ protected options: import("@angular/core").WritableSignal<google.maps.MapOptions>;
21
+ constructor(destroyRef: DestroyRef, mapLoaded$: Observable<boolean>);
19
22
  ngOnInit(): void;
20
- ngAfterViewInit(): void;
21
23
  ngOnDestroy(): void;
22
24
  private onPolygonAdded;
23
25
  private onMarkerAdded;
26
+ private loadData;
27
+ protected mapInitialized(): void;
24
28
  confirm(): void;
25
29
  clear(): void;
26
30
  static ɵfac: i0.ɵɵFactoryDeclaration<MapsDrawingConfirmComponent, never>;
@@ -1,4 +1,3 @@
1
- import { OnChanges, SimpleChanges } from '@angular/core';
2
1
  import { IsActiveMatchOptions } from '@angular/router';
3
2
  import { NavigationMenuService } from '../navigation-menu.service';
4
3
  import { ResponsiveService } from '../responsive.service';
@@ -12,15 +11,15 @@ export interface INavigationMenuLink {
12
11
  [key: string]: string;
13
12
  };
14
13
  fragment?: string;
14
+ expanded?: boolean;
15
15
  }
16
- export declare class NavigationMenuComponent implements OnChanges {
16
+ export declare class NavigationMenuComponent {
17
17
  private service;
18
18
  protected responsiveService: ResponsiveService;
19
19
  protected sticky: boolean;
20
20
  protected collapsible: boolean;
21
21
  protected links: INavigationMenuLink[];
22
22
  protected routerLinkMatchOptions: IsActiveMatchOptions;
23
- protected listExpanded: string[];
24
23
  collapsed: boolean;
25
24
  opened: boolean;
26
25
  protected classes: string;
@@ -28,10 +27,10 @@ export declare class NavigationMenuComponent implements OnChanges {
28
27
  constructor(service: NavigationMenuService, responsiveService: ResponsiveService);
29
28
  get maxHeight(): string;
30
29
  get withPrimaryIcons(): boolean;
31
- ngOnChanges(changes: SimpleChanges): void;
32
30
  toggle(): void;
33
- onExpandableItemClick(title: string, index: number): void;
34
- listActiveLinkChange(title: string, index: number, isActive: boolean): string;
31
+ private collapseOtherLinks;
32
+ toggleLinks(item: INavigationMenuLink, index: number): void;
33
+ listActiveLinkChange(item: INavigationMenuLink): void;
35
34
  static ɵfac: i0.ɵɵFactoryDeclaration<NavigationMenuComponent, never>;
36
35
  static ɵcmp: i0.ɵɵComponentDeclaration<NavigationMenuComponent, "he-navigation-menu", never, { "sticky": { "alias": "sticky"; "required": false; }; "collapsible": { "alias": "collapsible"; "required": false; }; "links": { "alias": "links"; "required": false; }; "routerLinkMatchOptions": { "alias": "routerLinkMatchOptions"; "required": false; }; }, {}, never, ["[outer-content]", "[inner-content]"], false, never>;
37
36
  }
@@ -1,46 +1,38 @@
1
- import { Component, Output, EventEmitter, Input, ViewChild } from '@angular/core';
1
+ import { Component, Output, EventEmitter, Input, ViewChild, Inject, signal } from '@angular/core';
2
2
  import { GoogleMap } from '@angular/google-maps';
3
3
  import { isNumber } from '@hestia-earth/utils';
4
- import { defaultFeature, addPolygonToFeature, polygonsFromFeature, strokeStyle } from '../maps-utils';
4
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
5
+ import { HE_MAP_LOADED, defaultFeature, addPolygonToFeature, polygonsFromFeature, strokeStyle } from '../maps-utils';
5
6
  import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/google-maps";
7
- import * as i2 from "@fortawesome/angular-fontawesome";
7
+ import * as i1 from "@angular/common";
8
+ import * as i2 from "@angular/google-maps";
9
+ import * as i3 from "@fortawesome/angular-fontawesome";
10
+ import * as i4 from "rxjs";
8
11
  export class MapsDrawingConfirmComponent {
9
- constructor() {
12
+ constructor(destroyRef, mapLoaded$) {
13
+ this.mapLoaded$ = mapLoaded$;
10
14
  this.listeners = [];
11
15
  this.shapes = [];
12
16
  this.feature = defaultFeature();
13
- this.modes = [google.maps.drawing.OverlayType.POLYGON];
14
17
  this.center = { lat: 0, lng: 0 };
15
18
  this.zoom = 3;
16
19
  this.closed = new EventEmitter();
17
- this.options = {
18
- fullscreenControl: false,
19
- mapTypeControl: true,
20
- streetViewControl: false,
21
- zoomControl: true,
22
- zoomControlOptions: {
23
- position: google.maps.ControlPosition.TOP_RIGHT
24
- }
25
- };
20
+ this.options = signal({});
21
+ mapLoaded$.pipe(takeUntilDestroyed(destroyRef)).subscribe(() => {
22
+ this.options.set({
23
+ fullscreenControl: false,
24
+ mapTypeControl: true,
25
+ streetViewControl: false,
26
+ zoomControl: true,
27
+ zoomControlOptions: {
28
+ position: google.maps.ControlPosition.TOP_RIGHT
29
+ }
30
+ });
31
+ });
26
32
  }
27
33
  ngOnInit() {
28
34
  this.feature = this.value && !isNumber(this.value) ? JSON.parse(this.value) : this.feature;
29
35
  }
30
- ngAfterViewInit() {
31
- this.shapes = polygonsFromFeature(this.feature);
32
- this.shapes.forEach(polygon => polygon.setMap(this.map?.googleMap));
33
- const drawingManager = new google.maps.drawing.DrawingManager({
34
- drawingControlOptions: {
35
- position: google.maps.ControlPosition.TOP_CENTER,
36
- drawingModes: this.modes
37
- },
38
- polygonOptions: strokeStyle
39
- });
40
- drawingManager.setMap(this.map?.googleMap);
41
- this.listeners.push(google.maps.event.addListener(drawingManager, 'polygoncomplete', polygon => this.onPolygonAdded(polygon)));
42
- this.listeners.push(google.maps.event.addListener(drawingManager, 'markercomplete', marker => this.onMarkerAdded(marker)));
43
- }
44
36
  ngOnDestroy() {
45
37
  this.listeners.map(listener => google.maps.event.removeListener(listener));
46
38
  }
@@ -54,6 +46,23 @@ export class MapsDrawingConfirmComponent {
54
46
  const position = marker.getPosition();
55
47
  this.coordinates = position?.toJSON();
56
48
  }
49
+ loadData() {
50
+ this.shapes = polygonsFromFeature(this.feature);
51
+ this.shapes.forEach(polygon => polygon.setMap(this.map?.googleMap));
52
+ const drawingManager = new google.maps.drawing.DrawingManager({
53
+ drawingControlOptions: {
54
+ position: google.maps.ControlPosition.TOP_CENTER,
55
+ drawingModes: this.modes || [google.maps.drawing.OverlayType.POLYGON]
56
+ },
57
+ polygonOptions: strokeStyle
58
+ });
59
+ drawingManager.setMap(this.map?.googleMap);
60
+ this.listeners.push(google.maps.event.addListener(drawingManager, 'polygoncomplete', polygon => this.onPolygonAdded(polygon)));
61
+ this.listeners.push(google.maps.event.addListener(drawingManager, 'markercomplete', marker => this.onMarkerAdded(marker)));
62
+ }
63
+ mapInitialized() {
64
+ setTimeout(() => this.loadData());
65
+ }
57
66
  confirm() {
58
67
  this.closed.next(this.coordinates || JSON.stringify(this.feature) || '');
59
68
  }
@@ -63,13 +72,16 @@ export class MapsDrawingConfirmComponent {
63
72
  this.coordinates = undefined;
64
73
  this.feature = undefined;
65
74
  }
66
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.8", ngImport: i0, type: MapsDrawingConfirmComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
67
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.8", type: MapsDrawingConfirmComponent, selector: "he-maps-drawing-confirm", inputs: { value: "value", modes: "modes", center: "center", zoom: "zoom" }, outputs: { closed: "closed" }, viewQueries: [{ propertyName: "map", first: true, predicate: GoogleMap, descendants: true }], ngImport: i0, template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Draw on Map</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"closed.next(value)\"></button>\n </header>\n <section class=\"modal-card-body p-0\">\n <google-map height=\"100%\" width=\"100%\" [zoom]=\"zoom\" [center]=\"center\" [options]=\"options\"></google-map>\n </section>\n <footer class=\"modal-card-foot\">\n <button class=\"button is-primary\" (click)=\"confirm()\">\n <span>Confirm</span>\n </button>\n <button class=\"button is-ghost\" (click)=\"closed.next(value)\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"clear()\">\n <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n <span>Clear</span>\n </button>\n </footer>\n </div>\n</div>\n", styles: ["google-map{display:block;height:100%;max-height:calc(100vh - 146px);min-height:500px}\n"], dependencies: [{ kind: "component", type: i1.GoogleMap, selector: "google-map", inputs: ["height", "width", "mapTypeId", "center", "zoom", "options"], outputs: ["mapInitialized", "authFailure", "boundsChanged", "centerChanged", "mapClick", "mapDblclick", "mapDrag", "mapDragend", "mapDragstart", "headingChanged", "idle", "maptypeidChanged", "mapMousemove", "mapMouseout", "mapMouseover", "projectionChanged", "mapRightclick", "tilesloaded", "tiltChanged", "zoomChanged"], exportAs: ["googleMap"] }, { kind: "component", type: i2.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }] }); }
75
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.8", ngImport: i0, type: MapsDrawingConfirmComponent, deps: [{ token: i0.DestroyRef }, { token: HE_MAP_LOADED }], target: i0.ɵɵFactoryTarget.Component }); }
76
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.8", type: MapsDrawingConfirmComponent, selector: "he-maps-drawing-confirm", inputs: { value: "value", modes: "modes", center: "center", zoom: "zoom" }, outputs: { closed: "closed" }, viewQueries: [{ propertyName: "map", first: true, predicate: GoogleMap, descendants: true }], ngImport: i0, template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Draw on Map</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"closed.next(value)\"></button>\n </header>\n <section class=\"modal-card-body p-0\">\n <google-map\n *ngIf=\"mapLoaded$ | async\"\n (mapInitialized)=\"mapInitialized()\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"zoom\"\n [center]=\"center\"\n [options]=\"options()\"></google-map>\n </section>\n <footer class=\"modal-card-foot\">\n <button class=\"button is-primary\" (click)=\"confirm()\">\n <span>Confirm</span>\n </button>\n <button class=\"button is-ghost\" (click)=\"closed.next(value)\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"clear()\">\n <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n <span>Clear</span>\n </button>\n </footer>\n </div>\n</div>\n", styles: ["google-map{display:block;height:100%;max-height:calc(100vh - 146px);min-height:500px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.GoogleMap, selector: "google-map", inputs: ["height", "width", "mapTypeId", "center", "zoom", "options"], outputs: ["mapInitialized", "authFailure", "boundsChanged", "centerChanged", "mapClick", "mapDblclick", "mapDrag", "mapDragend", "mapDragstart", "headingChanged", "idle", "maptypeidChanged", "mapMousemove", "mapMouseout", "mapMouseover", "projectionChanged", "mapRightclick", "tilesloaded", "tiltChanged", "zoomChanged"], exportAs: ["googleMap"] }, { kind: "component", type: i3.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] }); }
68
77
  }
69
78
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.8", ngImport: i0, type: MapsDrawingConfirmComponent, decorators: [{
70
79
  type: Component,
71
- args: [{ selector: 'he-maps-drawing-confirm', template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Draw on Map</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"closed.next(value)\"></button>\n </header>\n <section class=\"modal-card-body p-0\">\n <google-map height=\"100%\" width=\"100%\" [zoom]=\"zoom\" [center]=\"center\" [options]=\"options\"></google-map>\n </section>\n <footer class=\"modal-card-foot\">\n <button class=\"button is-primary\" (click)=\"confirm()\">\n <span>Confirm</span>\n </button>\n <button class=\"button is-ghost\" (click)=\"closed.next(value)\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"clear()\">\n <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n <span>Clear</span>\n </button>\n </footer>\n </div>\n</div>\n", styles: ["google-map{display:block;height:100%;max-height:calc(100vh - 146px);min-height:500px}\n"] }]
72
- }], propDecorators: { map: [{
80
+ args: [{ selector: 'he-maps-drawing-confirm', template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Draw on Map</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"closed.next(value)\"></button>\n </header>\n <section class=\"modal-card-body p-0\">\n <google-map\n *ngIf=\"mapLoaded$ | async\"\n (mapInitialized)=\"mapInitialized()\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"zoom\"\n [center]=\"center\"\n [options]=\"options()\"></google-map>\n </section>\n <footer class=\"modal-card-foot\">\n <button class=\"button is-primary\" (click)=\"confirm()\">\n <span>Confirm</span>\n </button>\n <button class=\"button is-ghost\" (click)=\"closed.next(value)\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"clear()\">\n <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n <span>Clear</span>\n </button>\n </footer>\n </div>\n</div>\n", styles: ["google-map{display:block;height:100%;max-height:calc(100vh - 146px);min-height:500px}\n"] }]
81
+ }], ctorParameters: function () { return [{ type: i0.DestroyRef }, { type: i4.Observable, decorators: [{
82
+ type: Inject,
83
+ args: [HE_MAP_LOADED]
84
+ }] }]; }, propDecorators: { map: [{
73
85
  type: ViewChild,
74
86
  args: [GoogleMap]
75
87
  }], value: [{
@@ -83,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.8", ngImpor
83
95
  }], closed: [{
84
96
  type: Output
85
97
  }] } });
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"maps-drawing-confirm.component.js","sourceRoot":"","sources":["../../../../src/common/maps-drawing-confirm/maps-drawing-confirm.component.ts","../../../../src/common/maps-drawing-confirm/maps-drawing-confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, OnDestroy, Output, EventEmitter, Input, ViewChild } from '@angular/core';\nimport { GoogleMap } from '@angular/google-maps';\nimport { isNumber } from '@hestia-earth/utils';\n\nimport {\n  IFeature,\n  IFeatureCollection,\n  defaultFeature,\n  addPolygonToFeature,\n  polygonsFromFeature,\n  strokeStyle\n} from '../maps-utils';\n\n@Component({\n  selector: 'he-maps-drawing-confirm',\n  templateUrl: './maps-drawing-confirm.component.html',\n  styleUrls: ['./maps-drawing-confirm.component.scss']\n})\nexport class MapsDrawingConfirmComponent implements OnInit, AfterViewInit, OnDestroy {\n  private listeners: google.maps.MapsEventListener[] = [];\n  private shapes: (google.maps.Marker | google.maps.Polygon)[] = [];\n\n  private feature?: IFeature | IFeatureCollection = defaultFeature();\n  private coordinates?: google.maps.LatLngLiteral;\n\n  @ViewChild(GoogleMap)\n  private map?: GoogleMap;\n\n  @Input()\n  public value?: string;\n  @Input()\n  public modes: google.maps.drawing.OverlayType[] = [google.maps.drawing.OverlayType.POLYGON];\n  @Input()\n  public center = { lat: 0, lng: 0 };\n  @Input()\n  public zoom = 3;\n\n  @Output()\n  public closed = new EventEmitter<google.maps.LatLngLiteral | string>();\n\n  public options: google.maps.MapOptions = {\n    fullscreenControl: false,\n    mapTypeControl: true,\n    streetViewControl: false,\n    zoomControl: true,\n    zoomControlOptions: {\n      position: google.maps.ControlPosition.TOP_RIGHT\n    }\n  };\n\n  ngOnInit() {\n    this.feature = this.value && !isNumber(this.value) ? JSON.parse(this.value) : this.feature;\n  }\n\n  ngAfterViewInit() {\n    this.shapes = polygonsFromFeature(this.feature);\n    this.shapes.forEach(polygon => polygon.setMap(this.map?.googleMap));\n    const drawingManager = new google.maps.drawing.DrawingManager({\n      drawingControlOptions: {\n        position: google.maps.ControlPosition.TOP_CENTER,\n        drawingModes: this.modes\n      },\n      polygonOptions: strokeStyle\n    });\n    drawingManager.setMap(this.map?.googleMap);\n    this.listeners.push(\n      google.maps.event.addListener(drawingManager, 'polygoncomplete', polygon => this.onPolygonAdded(polygon))\n    );\n    this.listeners.push(\n      google.maps.event.addListener(drawingManager, 'markercomplete', marker => this.onMarkerAdded(marker))\n    );\n  }\n\n  ngOnDestroy() {\n    this.listeners.map(listener => google.maps.event.removeListener(listener));\n  }\n\n  private onPolygonAdded(polygon: google.maps.Polygon) {\n    this.shapes.push(polygon);\n    this.feature = this.feature || defaultFeature();\n    addPolygonToFeature(this.feature, polygon);\n  }\n\n  private onMarkerAdded(marker: google.maps.Marker) {\n    this.shapes.push(marker);\n    const position = marker.getPosition();\n    this.coordinates = position?.toJSON();\n  }\n\n  public confirm() {\n    this.closed.next(this.coordinates || JSON.stringify(this.feature) || '');\n  }\n\n  public clear() {\n    this.shapes.forEach(shape => shape.setMap(null));\n    this.shapes = [];\n    this.coordinates = undefined;\n    this.feature = undefined;\n  }\n}\n","<div class=\"modal is-large is-active\">\n  <div class=\"modal-background\"></div>\n  <div class=\"modal-card\">\n    <header class=\"modal-card-head\">\n      <p class=\"modal-card-title\">Draw on Map</p>\n      <button class=\"delete\" aria-label=\"close\" (click)=\"closed.next(value)\"></button>\n    </header>\n    <section class=\"modal-card-body p-0\">\n      <google-map height=\"100%\" width=\"100%\" [zoom]=\"zoom\" [center]=\"center\" [options]=\"options\"></google-map>\n    </section>\n    <footer class=\"modal-card-foot\">\n      <button class=\"button is-primary\" (click)=\"confirm()\">\n        <span>Confirm</span>\n      </button>\n      <button class=\"button is-ghost\" (click)=\"closed.next(value)\">\n        <span>Close</span>\n      </button>\n      <button class=\"button is-danger\" (click)=\"clear()\">\n        <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n        <span>Clear</span>\n      </button>\n    </footer>\n  </div>\n</div>\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"maps-drawing-confirm.component.js","sourceRoot":"","sources":["../../../../src/common/maps-drawing-confirm/maps-drawing-confirm.component.ts","../../../../src/common/maps-drawing-confirm/maps-drawing-confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnDestroy,\n  Output,\n  EventEmitter,\n  Input,\n  ViewChild,\n  Inject,\n  signal,\n  DestroyRef\n} from '@angular/core';\nimport { GoogleMap } from '@angular/google-maps';\nimport { isNumber } from '@hestia-earth/utils';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Observable } from 'rxjs';\n\nimport {\n  HE_MAP_LOADED,\n  IFeature,\n  IFeatureCollection,\n  defaultFeature,\n  addPolygonToFeature,\n  polygonsFromFeature,\n  strokeStyle\n} from '../maps-utils';\n\n@Component({\n  selector: 'he-maps-drawing-confirm',\n  templateUrl: './maps-drawing-confirm.component.html',\n  styleUrls: ['./maps-drawing-confirm.component.scss']\n})\nexport class MapsDrawingConfirmComponent implements OnInit, OnDestroy {\n  private listeners: google.maps.MapsEventListener[] = [];\n  private shapes: (google.maps.Marker | google.maps.Polygon)[] = [];\n\n  private feature?: IFeature | IFeatureCollection = defaultFeature();\n  private coordinates?: google.maps.LatLngLiteral;\n\n  @ViewChild(GoogleMap)\n  private map?: GoogleMap;\n\n  @Input()\n  public value?: string;\n  @Input()\n  public modes?: google.maps.drawing.OverlayType[];\n  @Input()\n  public center = { lat: 0, lng: 0 };\n  @Input()\n  public zoom = 3;\n\n  @Output()\n  public closed = new EventEmitter<google.maps.LatLngLiteral | string>();\n\n  protected options = signal({} as google.maps.MapOptions);\n\n  constructor(\n    destroyRef: DestroyRef,\n    @Inject(HE_MAP_LOADED) protected mapLoaded$: Observable<boolean>\n  ) {\n    mapLoaded$.pipe(takeUntilDestroyed(destroyRef)).subscribe(() => {\n      this.options.set({\n        fullscreenControl: false,\n        mapTypeControl: true,\n        streetViewControl: false,\n        zoomControl: true,\n        zoomControlOptions: {\n          position: google.maps.ControlPosition.TOP_RIGHT\n        }\n      });\n    });\n  }\n\n  ngOnInit() {\n    this.feature = this.value && !isNumber(this.value) ? JSON.parse(this.value) : this.feature;\n  }\n\n  ngOnDestroy() {\n    this.listeners.map(listener => google.maps.event.removeListener(listener));\n  }\n\n  private onPolygonAdded(polygon: google.maps.Polygon) {\n    this.shapes.push(polygon);\n    this.feature = this.feature || defaultFeature();\n    addPolygonToFeature(this.feature, polygon);\n  }\n\n  private onMarkerAdded(marker: google.maps.Marker) {\n    this.shapes.push(marker);\n    const position = marker.getPosition();\n    this.coordinates = position?.toJSON();\n  }\n\n  private loadData() {\n    this.shapes = polygonsFromFeature(this.feature);\n    this.shapes.forEach(polygon => polygon.setMap(this.map?.googleMap));\n    const drawingManager = new google.maps.drawing.DrawingManager({\n      drawingControlOptions: {\n        position: google.maps.ControlPosition.TOP_CENTER,\n        drawingModes: this.modes || [google.maps.drawing.OverlayType.POLYGON]\n      },\n      polygonOptions: strokeStyle\n    });\n    drawingManager.setMap(this.map?.googleMap);\n    this.listeners.push(\n      google.maps.event.addListener(drawingManager, 'polygoncomplete', polygon => this.onPolygonAdded(polygon))\n    );\n    this.listeners.push(\n      google.maps.event.addListener(drawingManager, 'markercomplete', marker => this.onMarkerAdded(marker))\n    );\n  }\n\n  protected mapInitialized() {\n    setTimeout(() => this.loadData());\n  }\n\n  public confirm() {\n    this.closed.next(this.coordinates || JSON.stringify(this.feature) || '');\n  }\n\n  public clear() {\n    this.shapes.forEach(shape => shape.setMap(null));\n    this.shapes = [];\n    this.coordinates = undefined;\n    this.feature = undefined;\n  }\n}\n","<div class=\"modal is-large is-active\">\n  <div class=\"modal-background\"></div>\n  <div class=\"modal-card\">\n    <header class=\"modal-card-head\">\n      <p class=\"modal-card-title\">Draw on Map</p>\n      <button class=\"delete\" aria-label=\"close\" (click)=\"closed.next(value)\"></button>\n    </header>\n    <section class=\"modal-card-body p-0\">\n      <google-map\n        *ngIf=\"mapLoaded$ | async\"\n        (mapInitialized)=\"mapInitialized()\"\n        height=\"100%\"\n        width=\"100%\"\n        [zoom]=\"zoom\"\n        [center]=\"center\"\n        [options]=\"options()\"></google-map>\n    </section>\n    <footer class=\"modal-card-foot\">\n      <button class=\"button is-primary\" (click)=\"confirm()\">\n        <span>Confirm</span>\n      </button>\n      <button class=\"button is-ghost\" (click)=\"closed.next(value)\">\n        <span>Close</span>\n      </button>\n      <button class=\"button is-danger\" (click)=\"clear()\">\n        <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n        <span>Clear</span>\n      </button>\n    </footer>\n  </div>\n</div>\n"]}