@hestia-earth/ui-components 0.23.21 → 0.23.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/common/maps-drawing-confirm/maps-drawing-confirm.component.d.ts +9 -5
- package/common/navigation-menu/navigation-menu.component.d.ts +5 -6
- package/esm2022/common/maps-drawing-confirm/maps-drawing-confirm.component.mjs +46 -34
- package/esm2022/common/navigation-menu/navigation-menu.component.mjs +14 -14
- package/esm2022/files/files-error.model.mjs +15 -8
- package/fesm2022/hestia-earth-ui-components.mjs +73 -57
- package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
- package/files/files-error.model.d.ts +1 -1
- package/package.json +1 -1
- package/svg-icons/bug.svg +13 -0
- package/svg-icons/checkmark.svg +6 -0
- package/svg-icons/copy.svg +6 -0
- package/svg-icons/csv.svg +3 -0
- package/svg-icons/cycle.svg +20 -0
- package/svg-icons/far-circle-info.svg +6 -7
- package/svg-icons/filter.svg +5 -0
- package/svg-icons/glossary.svg +7 -7
- package/svg-icons/icons.json +74 -34
- package/svg-icons/map-pin.svg +11 -0
- package/svg-icons/map.svg +7 -0
- package/svg-icons/paper.svg +10 -0
- package/svg-icons/schema.svg +10 -8
- package/svg-icons/search-large.svg +5 -0
- package/svg-icons/search-small.svg +5 -0
- package/svg-icons/far-info-circle.svg +0 -5
|
@@ -1,26 +1,30 @@
|
|
|
1
1
|
/// <reference types="google.maps" />
|
|
2
|
-
import { OnInit,
|
|
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,
|
|
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
|
|
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
|
|
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
|
-
|
|
34
|
-
|
|
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 {
|
|
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/
|
|
7
|
-
import * as i2 from "@
|
|
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
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
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%\"
|
|
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%\"
|
|
72
|
-
}],
|
|
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"]}
|