@hestia-earth/ui-components 0.27.30 → 0.27.32

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/index.d.ts CHANGED
@@ -20,6 +20,7 @@ export { DrawerContainerComponent } from './drawer-container/drawer-container.co
20
20
  export { DropdownComponent } from './dropdown/dropdown.component';
21
21
  export { IssueConfirmComponent } from './issue-confirm/issue-confirm.component';
22
22
  export { LinkKeyValueComponent } from './link-key-value/link-key-value.component';
23
+ export { MapsDrawingComponent } from './maps-drawing/maps-drawing.component';
23
24
  export { MapsDrawingConfirmComponent } from './maps-drawing-confirm/maps-drawing-confirm.component';
24
25
  export * from './mobile-shell/mobile-shell.component';
25
26
  export * from './navigation-menu/navigation-menu.component';
@@ -11,9 +11,6 @@ export declare class IssueConfirmComponent {
11
11
  protected Template: typeof Template;
12
12
  protected repositories: import("@angular/core").Signal<Repository[]>;
13
13
  protected issueUrl: import("@angular/core").Signal<string>;
14
- protected selectedRepository: import("@angular/core").WritableSignal<Repository>;
15
- protected selectedTemplate: import("@angular/core").WritableSignal<Template>;
16
- constructor();
17
14
  protected close(): void;
18
15
  static ɵfac: i0.ɵɵFactoryDeclaration<IssueConfirmComponent, never>;
19
16
  static ɵcmp: i0.ɵɵComponentDeclaration<IssueConfirmComponent, "he-issue-confirm", never, { "title": { "alias": "title"; "required": false; "isSignal": true; }; "repository": { "alias": "repository"; "required": false; "isSignal": true; }; "template": { "alias": "template"; "required": false; "isSignal": true; }; "isCommunity": { "alias": "isCommunity"; "required": false; "isSignal": true; }; }, { "title": "titleChange"; "repository": "repositoryChange"; "template": "templateChange"; "isCommunity": "isCommunityChange"; "closed": "closed"; }, never, never, true, never>;
@@ -0,0 +1,32 @@
1
+ /// <reference types="google.maps" />
2
+ import { OnDestroy } from '@angular/core';
3
+ import { IFeature, IFeatureCollection } from '../maps-utils';
4
+ import * as i0 from "@angular/core";
5
+ export declare class MapsDrawingComponent implements OnDestroy {
6
+ private mapLoaded$;
7
+ protected mapLoaded: import("@angular/core").Signal<boolean>;
8
+ private map;
9
+ private listeners;
10
+ private shapes;
11
+ protected updated: import("@angular/core").OutputEmitterRef<string | google.maps.LatLngLiteral>;
12
+ protected value: import("@angular/core").InputSignal<string>;
13
+ protected modes: import("@angular/core").InputSignal<google.maps.drawing.OverlayType[]>;
14
+ protected center: import("@angular/core").InputSignal<{
15
+ lat: number;
16
+ lng: number;
17
+ }>;
18
+ protected zoom: import("@angular/core").InputSignal<number>;
19
+ protected options: import("@angular/core").WritableSignal<google.maps.MapOptions>;
20
+ feature: import("@angular/core").WritableSignal<IFeature | IFeatureCollection>;
21
+ coordinates: import("@angular/core").WritableSignal<google.maps.LatLngLiteral>;
22
+ data: import("@angular/core").Signal<string | google.maps.LatLngLiteral>;
23
+ constructor();
24
+ ngOnDestroy(): void;
25
+ private onPolygonAdded;
26
+ private onMarkerAdded;
27
+ private loadData;
28
+ protected mapInitialized(): void;
29
+ clear(): void;
30
+ static ɵfac: i0.ɵɵFactoryDeclaration<MapsDrawingComponent, never>;
31
+ static ɵcmp: i0.ɵɵComponentDeclaration<MapsDrawingComponent, "he-maps-drawing", never, { "value": { "alias": "value"; "required": false; "isSignal": true; }; "modes": { "alias": "modes"; "required": false; "isSignal": true; }; "center": { "alias": "center"; "required": false; "isSignal": true; }; "zoom": { "alias": "zoom"; "required": false; "isSignal": true; }; }, { "updated": "updated"; }, never, never, true, never>;
32
+ }
@@ -1,35 +1,14 @@
1
1
  /// <reference types="google.maps" />
2
- import { OnInit, OnDestroy } from '@angular/core';
3
2
  import * as i0 from "@angular/core";
4
- export declare class MapsDrawingConfirmComponent implements OnInit, OnDestroy {
5
- private destroyRef;
6
- protected mapLoaded$: import("rxjs").Observable<boolean>;
3
+ export declare class MapsDrawingConfirmComponent {
7
4
  private readonly activeModal;
8
5
  protected readonly faTimes: import("@fortawesome/fontawesome-common-types").IconDefinition;
9
- private listeners;
10
- private shapes;
11
- private feature?;
12
- private coordinates?;
13
- private map?;
14
- value?: string;
15
- modes?: google.maps.drawing.OverlayType[];
16
- center: {
17
- lat: number;
18
- lng: number;
19
- };
20
- zoom: number;
6
+ private map;
7
+ protected value: import("@angular/core").InputSignal<string>;
8
+ protected modes: import("@angular/core").InputSignal<google.maps.drawing.OverlayType[]>;
21
9
  protected closed: import("@angular/core").OutputEmitterRef<string | google.maps.LatLngLiteral>;
22
- protected options: import("@angular/core").WritableSignal<google.maps.MapOptions>;
23
- constructor();
24
- ngOnInit(): void;
25
- ngOnDestroy(): void;
26
- private onPolygonAdded;
27
- private onMarkerAdded;
28
- private loadData;
29
- protected mapInitialized(): void;
30
10
  protected confirm(): void;
31
- protected clear(): void;
32
- protected close(value: google.maps.LatLngLiteral | string): void;
11
+ protected close(value?: google.maps.LatLngLiteral | string): void;
33
12
  static ɵfac: i0.ɵɵFactoryDeclaration<MapsDrawingConfirmComponent, never>;
34
- static ɵcmp: i0.ɵɵComponentDeclaration<MapsDrawingConfirmComponent, "he-maps-drawing-confirm", never, { "value": { "alias": "value"; "required": false; }; "modes": { "alias": "modes"; "required": false; }; "center": { "alias": "center"; "required": false; }; "zoom": { "alias": "zoom"; "required": false; }; }, { "closed": "closed"; }, never, never, true, never>;
13
+ static ɵcmp: i0.ɵɵComponentDeclaration<MapsDrawingConfirmComponent, "he-maps-drawing-confirm", never, { "value": { "alias": "value"; "required": false; "isSignal": true; }; "modes": { "alias": "modes"; "required": false; "isSignal": true; }; }, { "closed": "closed"; }, never, never, true, never>;
35
14
  }
@@ -20,6 +20,7 @@ export { DrawerContainerComponent } from './drawer-container/drawer-container.co
20
20
  export { DropdownComponent } from './dropdown/dropdown.component';
21
21
  export { IssueConfirmComponent } from './issue-confirm/issue-confirm.component';
22
22
  export { LinkKeyValueComponent } from './link-key-value/link-key-value.component';
23
+ export { MapsDrawingComponent } from './maps-drawing/maps-drawing.component';
23
24
  export { MapsDrawingConfirmComponent } from './maps-drawing-confirm/maps-drawing-confirm.component';
24
25
  export * from './mobile-shell/mobile-shell.component';
25
26
  export * from './navigation-menu/navigation-menu.component';
@@ -58,4 +59,4 @@ export * from './sort-select/sort-select.component';
58
59
  export { ResponsiveService } from './responsive.service';
59
60
  export { ShelfDialogComponent } from './shelf-dialog/shelf-dialog.component';
60
61
  export { NavigationMenuComponent } from './navigation-menu/navigation-menu.component';
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFNBQVMsQ0FBQztBQUV4QixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUN4RixPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw2REFBNkQsQ0FBQztBQUM1RyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSwyREFBMkQsQ0FBQztBQUN6RyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN2RSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUN6RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNoRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNsRixPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQztBQUNwRyxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDdEYsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDakcsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDaEYsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNoRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNoRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ3JDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM5QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDdkMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELGNBQWMscUJBQXFCLENBQUM7QUFDcEMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUN6QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDNUMsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsdUJBQXVCLEVBQXVCLE1BQU0sNkNBQTZDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbG9yJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbW9uLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb3VuZCc7XG5leHBvcnQgKiBmcm9tICcuL3RvYXN0LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9kMy11dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL2RlbHRhLXV0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vbG9ncy11dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL21hcHMtdXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9ub2RlLXV0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vcGx1cmFsaXplJztcbmV4cG9ydCAqIGZyb20gJy4vcnhqcy11dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3Rob3VzYW5kcyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcblxuZXhwb3J0IHsgQmxhbmtOb2RlU3RhdGVDb21wb25lbnQgfSBmcm9tICcuL2JsYW5rLW5vZGUtc3RhdGUvYmxhbmstbm9kZS1zdGF0ZS5jb21wb25lbnQnO1xuZXhwb3J0IHsgQmxhbmtOb2RlU3RhdGVOb3RpY2VDb21wb25lbnQgfSBmcm9tICcuL2JsYW5rLW5vZGUtc3RhdGUtbm90aWNlL2JsYW5rLW5vZGUtc3RhdGUtbm90aWNlLmNvbXBvbmVudCc7XG5leHBvcnQgeyBCbGFua05vZGVWYWx1ZURlbHRhQ29tcG9uZW50IH0gZnJvbSAnLi9ibGFuay1ub2RlLXZhbHVlLWRlbHRhL2JsYW5rLW5vZGUtdmFsdWUtZGVsdGEuY29tcG9uZW50JztcbmV4cG9ydCB7IENsaXBib2FyZENvbXBvbmVudCB9IGZyb20gJy4vY2xpcGJvYXJkL2NsaXBib2FyZC5jb21wb25lbnQnO1xuZXhwb3J0IHsgRGF0YVRhYmxlQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRhLXRhYmxlL2RhdGEtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCB7IERyYXdlckNvbnRhaW5lckNvbXBvbmVudCB9IGZyb20gJy4vZHJhd2VyLWNvbnRhaW5lci9kcmF3ZXItY29udGFpbmVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBEcm9wZG93bkNvbXBvbmVudCB9IGZyb20gJy4vZHJvcGRvd24vZHJvcGRvd24uY29tcG9uZW50JztcbmV4cG9ydCB7IElzc3VlQ29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4vaXNzdWUtY29uZmlybS9pc3N1ZS1jb25maXJtLmNvbXBvbmVudCc7XG5leHBvcnQgeyBMaW5rS2V5VmFsdWVDb21wb25lbnQgfSBmcm9tICcuL2xpbmsta2V5LXZhbHVlL2xpbmsta2V5LXZhbHVlLmNvbXBvbmVudCc7XG5leHBvcnQgeyBNYXBzRHJhd2luZ0NvbmZpcm1Db21wb25lbnQgfSBmcm9tICcuL21hcHMtZHJhd2luZy1jb25maXJtL21hcHMtZHJhd2luZy1jb25maXJtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21vYmlsZS1zaGVsbC9tb2JpbGUtc2hlbGwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbmF2aWdhdGlvbi1tZW51L25hdmlnYXRpb24tbWVudS5jb21wb25lbnQnO1xuZXhwb3J0IHsgUG9wb3ZlckNvbXBvbmVudCB9IGZyb20gJy4vcG9wb3Zlci9wb3BvdmVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBQb3BvdmVyQ29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4vcG9wb3Zlci1jb25maXJtL3BvcG92ZXItY29uZmlybS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2NoZW1hVmVyc2lvbkxpbmtDb21wb25lbnQgfSBmcm9tICcuL3NjaGVtYS12ZXJzaW9uLWxpbmsvc2NoZW1hLXZlcnNpb24tbGluay5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2VhcmNoRXh0ZW5kQ29tcG9uZW50IH0gZnJvbSAnLi9zZWFyY2gtZXh0ZW5kL3NlYXJjaC1leHRlbmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2hlbGwvc2hlbGwuY29tcG9uZW50JztcbmV4cG9ydCB7IFNrZWxldG9uVGV4dENvbXBvbmVudCB9IGZyb20gJy4vc2tlbGV0b24tdGV4dC9za2VsZXRvbi10ZXh0LmNvbXBvbmVudCc7XG5leHBvcnQgeyBTb2NpYWxUYWdzQ29tcG9uZW50IH0gZnJvbSAnLi9zb2NpYWwtdGFncy9zb2NpYWwtdGFncy5jb21wb25lbnQnO1xuZXhwb3J0IHsgVG9hc3RDb21wb25lbnQgfSBmcm9tICcuL3RvYXN0L3RvYXN0LmNvbXBvbmVudCc7XG5leHBvcnQgeyBVbml0Q29udmVydGVyQ29tcG9uZW50IH0gZnJvbSAnLi91bml0LWNvbnZlcnRlci91bml0LWNvbnZlcnRlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgQXBwbHlQdXJlUGlwZSB9IGZyb20gJy4vYXBwbHktcHVyZS5waXBlJztcbmV4cG9ydCB7IFRob3VzYW5kU3VmZml4ZXNQaXBlIH0gZnJvbSAnLi90aG91c2FuZC1zdWZmaXhlcy5waXBlJztcbmV4cG9ydCB7IEJpbmRPbmNlRGlyZWN0aXZlIH0gZnJvbSAnLi9iaW5kLW9uY2UuZGlyZWN0aXZlJztcbmV4cG9ydCB7IENsaWNrT3V0c2lkZURpcmVjdGl2ZSB9IGZyb20gJy4vY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgQ29tcG91bmREaXJlY3RpdmUgfSBmcm9tICcuL2NvbXBvdW5kLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBDb21wb3VuZFBpcGUgfSBmcm9tICcuL2NvbXBvdW5kLnBpcGUnO1xuZXhwb3J0IHsgRGVmYXVsdFBpcGUgfSBmcm9tICcuL2RlZmF1bHQucGlwZSc7XG5leHBvcnQgeyBFbGxpcHNpc1BpcGUgfSBmcm9tICcuL2VsbGlwc2lzLnBpcGUnO1xuZXhwb3J0IHsgRmlsZVNpemVQaXBlIH0gZnJvbSAnLi9maWxlLXNpemUucGlwZSc7XG5leHBvcnQgeyBHZXRQaXBlIH0gZnJvbSAnLi9nZXQucGlwZSc7XG5leHBvcnQgeyBJc0FycmF5UGlwZSB9IGZyb20gJy4vaXMtYXJyYXkucGlwZSc7XG5leHBvcnQgeyBJc09iamVjdFBpcGUgfSBmcm9tICcuL2lzLW9iamVjdC5waXBlJztcbmV4cG9ydCB7IEtleVRvTGFiZWxQaXBlIH0gZnJvbSAnLi9rZXktdG8tbGFiZWwucGlwZSc7XG5leHBvcnQgeyBLZXlzUGlwZSB9IGZyb20gJy4va2V5cy5waXBlJztcbmV4cG9ydCB7IE5vRXh0UGlwZSB9IGZyb20gJy4vbm8tZXh0LnBpcGUnO1xuZXhwb3J0IHsgUGx1cmFsaXplUGlwZSB9IGZyb20gJy4vcGx1cmFsaXplLnBpcGUnO1xuZXhwb3J0IHsgUHJlY2lzaW9uUGlwZSB9IGZyb20gJy4vcHJlY2lzaW9uLnBpcGUnO1xuZXhwb3J0IHsgUmVtb3ZlTWFya2Rvd25QaXBlIH0gZnJvbSAnLi9yZW1vdmUtbWFya2Rvd24ucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL3Jlc2l6ZWQuZGlyZWN0aXZlJztcbmV4cG9ydCB7IFRhZ3NJbnB1dERpcmVjdGl2ZSB9IGZyb20gJy4vdGFncy1pbnB1dC5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgVGltZXNQaXBlIH0gZnJvbSAnLi90aW1lcy5waXBlJztcbmV4cG9ydCB7IFNvcnRCeVBpcGUgfSBmcm9tICcuL3NvcnQtYnkucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL3NvcnQtc2VsZWN0L3NvcnQtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgeyBSZXNwb25zaXZlU2VydmljZSB9IGZyb20gJy4vcmVzcG9uc2l2ZS5zZXJ2aWNlJztcbmV4cG9ydCB7IFNoZWxmRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9zaGVsZi1kaWFsb2cvc2hlbGYtZGlhbG9nLmNvbXBvbmVudCc7XG5leHBvcnQgeyBOYXZpZ2F0aW9uTWVudUNvbXBvbmVudCwgSU5hdmlnYXRpb25NZW51TGluayB9IGZyb20gJy4vbmF2aWdhdGlvbi1tZW51L25hdmlnYXRpb24tbWVudS5jb21wb25lbnQnO1xuIl19
62
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/index.ts"],"names":[],"mappings":"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","sourcesContent":["export * from './color';\nexport * from './common.service';\nexport * from './compound';\nexport * from './toast.service';\nexport * from './d3-utils';\nexport * from './delta-utils';\nexport * from './logs-utils';\nexport * from './maps-utils';\nexport * from './node-utils';\nexport * from './pluralize';\nexport * from './rxjs-utils';\nexport * from './thousands';\nexport * from './utils';\n\nexport { BlankNodeStateComponent } from './blank-node-state/blank-node-state.component';\nexport { BlankNodeStateNoticeComponent } from './blank-node-state-notice/blank-node-state-notice.component';\nexport { BlankNodeValueDeltaComponent } from './blank-node-value-delta/blank-node-value-delta.component';\nexport { ClipboardComponent } from './clipboard/clipboard.component';\nexport { DataTableComponent } from './data-table/data-table.component';\nexport { DrawerContainerComponent } from './drawer-container/drawer-container.component';\nexport { DropdownComponent } from './dropdown/dropdown.component';\nexport { IssueConfirmComponent } from './issue-confirm/issue-confirm.component';\nexport { LinkKeyValueComponent } from './link-key-value/link-key-value.component';\nexport { MapsDrawingComponent } from './maps-drawing/maps-drawing.component';\nexport { MapsDrawingConfirmComponent } from './maps-drawing-confirm/maps-drawing-confirm.component';\nexport * from './mobile-shell/mobile-shell.component';\nexport * from './navigation-menu/navigation-menu.component';\nexport { PopoverComponent } from './popover/popover.component';\nexport { PopoverConfirmComponent } from './popover-confirm/popover-confirm.component';\nexport { SchemaVersionLinkComponent } from './schema-version-link/schema-version-link.component';\nexport { SearchExtendComponent } from './search-extend/search-extend.component';\nexport * from './shell/shell.component';\nexport { SkeletonTextComponent } from './skeleton-text/skeleton-text.component';\nexport { SocialTagsComponent } from './social-tags/social-tags.component';\nexport { ToastComponent } from './toast/toast.component';\nexport { UnitConverterComponent } from './unit-converter/unit-converter.component';\nexport { ApplyPurePipe } from './apply-pure.pipe';\nexport { ThousandSuffixesPipe } from './thousand-suffixes.pipe';\nexport { BindOnceDirective } from './bind-once.directive';\nexport { ClickOutsideDirective } from './click-outside.directive';\nexport { CompoundDirective } from './compound.directive';\nexport { CompoundPipe } from './compound.pipe';\nexport { DefaultPipe } from './default.pipe';\nexport { EllipsisPipe } from './ellipsis.pipe';\nexport { FileSizePipe } from './file-size.pipe';\nexport { GetPipe } from './get.pipe';\nexport { IsArrayPipe } from './is-array.pipe';\nexport { IsObjectPipe } from './is-object.pipe';\nexport { KeyToLabelPipe } from './key-to-label.pipe';\nexport { KeysPipe } from './keys.pipe';\nexport { NoExtPipe } from './no-ext.pipe';\nexport { PluralizePipe } from './pluralize.pipe';\nexport { PrecisionPipe } from './precision.pipe';\nexport { RemoveMarkdownPipe } from './remove-markdown.pipe';\nexport * from './resized.directive';\nexport { TagsInputDirective } from './tags-input.directive';\nexport { TimesPipe } from './times.pipe';\nexport { SortByPipe } from './sort-by.pipe';\nexport * from './sort-select/sort-select.component';\nexport { ResponsiveService } from './responsive.service';\nexport { ShelfDialogComponent } from './shelf-dialog/shelf-dialog.component';\nexport { NavigationMenuComponent, INavigationMenuLink } from './navigation-menu/navigation-menu.component';\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, computed, effect, inject, model, output, signal } from '@angular/core';
1
+ import { Component, computed, inject, model, output } from '@angular/core';
2
2
  import { FormsModule } from '@angular/forms';
3
3
  import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
4
4
  import { Repository, Template, reportIssueUrl } from '../utils';
@@ -17,28 +17,16 @@ export class IssueConfirmComponent {
17
17
  this.Template = Template;
18
18
  this.repositories = computed(() => Object.values(Repository).filter(value => value !== Repository.community || this.isCommunity()));
19
19
  this.issueUrl = computed(() => this.repository() && this.template() ? reportIssueUrl(this.repository(), this.template()) : null);
20
- this.selectedRepository = signal(undefined);
21
- this.selectedTemplate = signal(undefined);
22
- effect(() => {
23
- if (!this.selectedRepository() && this.repository()) {
24
- this.selectedRepository.set(this.repository());
25
- }
26
- }, { allowSignalWrites: true });
27
- effect(() => {
28
- if (!this.selectedTemplate() && this.template()) {
29
- this.selectedTemplate.set(this.template());
30
- }
31
- }, { allowSignalWrites: true });
32
20
  }
33
21
  close() {
34
22
  this.closed.emit();
35
23
  this.activeModal?.close();
36
24
  }
37
25
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: IssueConfirmComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
38
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: IssueConfirmComponent, isStandalone: true, selector: "he-issue-confirm", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, repository: { classPropertyName: "repository", publicName: "repository", isSignal: true, isRequired: false, transformFunction: null }, template: { classPropertyName: "template", publicName: "template", isSignal: true, isRequired: false, transformFunction: null }, isCommunity: { classPropertyName: "isCommunity", publicName: "isCommunity", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { title: "titleChange", repository: "repositoryChange", template: "templateChange", isCommunity: "isCommunityChange", closed: "closed" }, ngImport: i0, template: "<div class=\"modal 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\">{{ title() }}</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"close()\"></button>\n </header>\n <section class=\"modal-card-body\">\n <p class=\"mb-2\">Please select the type of issue from the list below to start:</p>\n\n <div class=\"field is-horizontal my-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"repository\">Category</label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-multiple is-fullwidth\">\n <select\n [ngModel]=\"selectedRepository()\"\n (change)=\"selectedRepository.set($event.target.value)\"\n name=\"repository\"\n required>\n <option [ngValue]=\"undefined\">Select from the list</option>\n @for (repo of repositories(); track repo) {\n <option [value]=\"repo\">\n @switch (repo) {\n @case (Repository.glossary) {\n Glossary of terms / lookup issues\n }\n @case (Repository.models) {\n Calculation issues\n }\n @case (Repository.orchestrator) {\n Orchestration issues\n }\n @case (Repository.aggregation) {\n Aggregated Data issues\n }\n @case (Repository.community) {\n UI/UX or API issues\n }\n @case (Repository.poorenemeck) {\n Conversion from P&N Spreadsheet\n }\n @case (Repository.frontend) {\n Other issues\n }\n }\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n @if (repository()) {\n <div class=\"field is-horizontal my-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"template\">Issue</label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-multiple is-fullwidth\">\n <select\n [ngModel]=\"selectedTemplate()\"\n (change)=\"selectedTemplate.set($event.target.value)\"\n name=\"template\"\n required>\n <option [ngValue]=\"undefined\">Select from the list</option>\n @for (t of Template | keys; track t) {\n <option [value]=\"t.value\">\n @switch (t.value) {\n @case (Template.bug) {\n I found a bug\n }\n @case (Template.feature) {\n I would like a new feature\n }\n }\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n\n @if (issueUrl()) {\n <p>\n <span>Please report the issue on Gitlab using</span>\n <a class=\"pl-1\" [href]=\"issueUrl()\" target=\"_blank\">this link</a>\n .\n </p>\n }\n </section>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: KeysPipe, name: "keys" }] }); }
26
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: IssueConfirmComponent, isStandalone: true, selector: "he-issue-confirm", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, repository: { classPropertyName: "repository", publicName: "repository", isSignal: true, isRequired: false, transformFunction: null }, template: { classPropertyName: "template", publicName: "template", isSignal: true, isRequired: false, transformFunction: null }, isCommunity: { classPropertyName: "isCommunity", publicName: "isCommunity", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { title: "titleChange", repository: "repositoryChange", template: "templateChange", isCommunity: "isCommunityChange", closed: "closed" }, ngImport: i0, template: "<div class=\"modal 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\">{{ title() }}</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"close()\"></button>\n </header>\n <section class=\"modal-card-body\">\n <p class=\"mb-2\">Please select the type of issue from the list below to start:</p>\n\n <div class=\"field is-horizontal my-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"repository\">Category</label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-multiple is-fullwidth\">\n <select\n [ngModel]=\"repository()\"\n (change)=\"repository.set($event.target.value)\"\n name=\"repository\"\n required>\n <option [ngValue]=\"undefined\">Select from the list</option>\n @for (repo of repositories(); track repo) {\n <option [value]=\"repo\">\n @switch (repo) {\n @case (Repository.glossary) {\n Glossary of terms / lookup issues\n }\n @case (Repository.models) {\n Calculation issues\n }\n @case (Repository.orchestrator) {\n Orchestration issues\n }\n @case (Repository.aggregation) {\n Aggregated Data issues\n }\n @case (Repository.community) {\n UI/UX or API issues\n }\n @case (Repository.poorenemeck) {\n Conversion from P&N Spreadsheet\n }\n @case (Repository.schema) {\n Schema issues\n }\n @default {\n Other issues\n }\n }\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n @if (repository()) {\n <div class=\"field is-horizontal my-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"template\">Issue</label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-multiple is-fullwidth\">\n <select [ngModel]=\"template()\" (change)=\"template.set($event.target.value)\" name=\"template\" required>\n <option [value]=\"undefined\">Select from the list</option>\n @for (t of Template | keys; track t) {\n <option [value]=\"t.value\">\n @switch (t.value) {\n @case (Template.bug) {\n I found a bug\n }\n @case (Template.feature) {\n I would like a new feature\n }\n }\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n\n @if (repository() && template() && issueUrl()) {\n <p>\n <span>Please report the issue on Gitlab using</span>\n <a class=\"pl-1\" [href]=\"issueUrl()\" target=\"_blank\">this link</a>\n .\n </p>\n }\n </section>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: KeysPipe, name: "keys" }] }); }
39
27
  }
40
28
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: IssueConfirmComponent, decorators: [{
41
29
  type: Component,
42
- args: [{ selector: 'he-issue-confirm', standalone: true, imports: [FormsModule, KeysPipe], template: "<div class=\"modal 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\">{{ title() }}</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"close()\"></button>\n </header>\n <section class=\"modal-card-body\">\n <p class=\"mb-2\">Please select the type of issue from the list below to start:</p>\n\n <div class=\"field is-horizontal my-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"repository\">Category</label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-multiple is-fullwidth\">\n <select\n [ngModel]=\"selectedRepository()\"\n (change)=\"selectedRepository.set($event.target.value)\"\n name=\"repository\"\n required>\n <option [ngValue]=\"undefined\">Select from the list</option>\n @for (repo of repositories(); track repo) {\n <option [value]=\"repo\">\n @switch (repo) {\n @case (Repository.glossary) {\n Glossary of terms / lookup issues\n }\n @case (Repository.models) {\n Calculation issues\n }\n @case (Repository.orchestrator) {\n Orchestration issues\n }\n @case (Repository.aggregation) {\n Aggregated Data issues\n }\n @case (Repository.community) {\n UI/UX or API issues\n }\n @case (Repository.poorenemeck) {\n Conversion from P&N Spreadsheet\n }\n @case (Repository.frontend) {\n Other issues\n }\n }\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n @if (repository()) {\n <div class=\"field is-horizontal my-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"template\">Issue</label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-multiple is-fullwidth\">\n <select\n [ngModel]=\"selectedTemplate()\"\n (change)=\"selectedTemplate.set($event.target.value)\"\n name=\"template\"\n required>\n <option [ngValue]=\"undefined\">Select from the list</option>\n @for (t of Template | keys; track t) {\n <option [value]=\"t.value\">\n @switch (t.value) {\n @case (Template.bug) {\n I found a bug\n }\n @case (Template.feature) {\n I would like a new feature\n }\n }\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n\n @if (issueUrl()) {\n <p>\n <span>Please report the issue on Gitlab using</span>\n <a class=\"pl-1\" [href]=\"issueUrl()\" target=\"_blank\">this link</a>\n .\n </p>\n }\n </section>\n </div>\n</div>\n" }]
43
- }], ctorParameters: () => [] });
44
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"issue-confirm.component.js","sourceRoot":"","sources":["../../../../src/common/issue-confirm/issue-confirm.component.ts","../../../../src/common/issue-confirm/issue-confirm.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAChE,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;;;AASxC,MAAM,OAAO,qBAAqB;IAsBhC;QArBiB,gBAAW,GAAG,MAAM,CAAC,cAAc,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAEnE,UAAK,GAAG,KAAK,CAAC,iBAAiB,CAAC,CAAC;QACjC,eAAU,GAAG,KAAK,EAAc,CAAC;QACjC,aAAQ,GAAG,KAAK,EAAY,CAAC;QAC7B,gBAAW,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAExB,WAAM,GAAG,MAAM,EAAE,CAAC;QAElB,eAAU,GAAG,UAAU,CAAC;QACxB,aAAQ,GAAG,QAAQ,CAAC;QACpB,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE,CACrC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,UAAU,CAAC,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,CAChG,CAAC;QACQ,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CACjC,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CACjG,CAAC;QAEQ,uBAAkB,GAAG,MAAM,CAAa,SAAS,CAAC,CAAC;QACnD,qBAAgB,GAAG,MAAM,CAAW,SAAS,CAAC,CAAC;QAGvD,MAAM,CACJ,GAAG,EAAE;YACH,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;gBACpD,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;YACjD,CAAC;QACH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;QAEF,MAAM,CACJ,GAAG,EAAE;YACH,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBAChD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC7C,CAAC;QACH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;IACJ,CAAC;IAES,KAAK;QACb,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACnB,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC;IAC5B,CAAC;8GA7CU,qBAAqB;kGAArB,qBAAqB,qvBCdlC,o5HAuGA,yDD3FY,WAAW,k9BAAE,QAAQ;;2FAEpB,qBAAqB;kBAPjC,SAAS;+BACE,kBAAkB,cAGhB,IAAI,WACP,CAAC,WAAW,EAAE,QAAQ,CAAC","sourcesContent":["import { Component, computed, effect, inject, model, output, signal } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { Repository, Template, reportIssueUrl } from '../utils';\nimport { KeysPipe } from '../keys.pipe';\n\n@Component({\n  selector: 'he-issue-confirm',\n  templateUrl: './issue-confirm.component.html',\n  styleUrls: ['./issue-confirm.component.scss'],\n  standalone: true,\n  imports: [FormsModule, KeysPipe]\n})\nexport class IssueConfirmComponent {\n  private readonly activeModal = inject(NgbActiveModal, { optional: true });\n\n  public title = model('Submit Feedback');\n  public repository = model<Repository>();\n  public template = model<Template>();\n  public isCommunity = model(false);\n\n  protected closed = output();\n\n  protected Repository = Repository;\n  protected Template = Template;\n  protected repositories = computed(() =>\n    Object.values(Repository).filter(value => value !== Repository.community || this.isCommunity())\n  );\n  protected issueUrl = computed(() =>\n    this.repository() && this.template() ? reportIssueUrl(this.repository(), this.template()) : null\n  );\n\n  protected selectedRepository = signal<Repository>(undefined);\n  protected selectedTemplate = signal<Template>(undefined);\n\n  constructor() {\n    effect(\n      () => {\n        if (!this.selectedRepository() && this.repository()) {\n          this.selectedRepository.set(this.repository());\n        }\n      },\n      { allowSignalWrites: true }\n    );\n\n    effect(\n      () => {\n        if (!this.selectedTemplate() && this.template()) {\n          this.selectedTemplate.set(this.template());\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  protected close() {\n    this.closed.emit();\n    this.activeModal?.close();\n  }\n}\n","<div class=\"modal 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\">{{ title() }}</p>\n      <button class=\"delete\" aria-label=\"close\" (click)=\"close()\"></button>\n    </header>\n    <section class=\"modal-card-body\">\n      <p class=\"mb-2\">Please select the type of issue from the list below to start:</p>\n\n      <div class=\"field is-horizontal my-3\">\n        <div class=\"field-label is-normal\">\n          <label class=\"label\" for=\"repository\">Category</label>\n        </div>\n        <div class=\"field-body\">\n          <div class=\"field\">\n            <div class=\"control is-expanded\">\n              <div class=\"select is-multiple is-fullwidth\">\n                <select\n                  [ngModel]=\"selectedRepository()\"\n                  (change)=\"selectedRepository.set($event.target.value)\"\n                  name=\"repository\"\n                  required>\n                  <option [ngValue]=\"undefined\">Select from the list</option>\n                  @for (repo of repositories(); track repo) {\n                    <option [value]=\"repo\">\n                      @switch (repo) {\n                        @case (Repository.glossary) {\n                          Glossary of terms / lookup issues\n                        }\n                        @case (Repository.models) {\n                          Calculation issues\n                        }\n                        @case (Repository.orchestrator) {\n                          Orchestration issues\n                        }\n                        @case (Repository.aggregation) {\n                          Aggregated Data issues\n                        }\n                        @case (Repository.community) {\n                          UI/UX or API issues\n                        }\n                        @case (Repository.poorenemeck) {\n                          Conversion from P&N Spreadsheet\n                        }\n                        @case (Repository.frontend) {\n                          Other issues\n                        }\n                      }\n                    </option>\n                  }\n                </select>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n\n      @if (repository()) {\n        <div class=\"field is-horizontal my-3\">\n          <div class=\"field-label is-normal\">\n            <label class=\"label\" for=\"template\">Issue</label>\n          </div>\n          <div class=\"field-body\">\n            <div class=\"field\">\n              <div class=\"control is-expanded\">\n                <div class=\"select is-multiple is-fullwidth\">\n                  <select\n                    [ngModel]=\"selectedTemplate()\"\n                    (change)=\"selectedTemplate.set($event.target.value)\"\n                    name=\"template\"\n                    required>\n                    <option [ngValue]=\"undefined\">Select from the list</option>\n                    @for (t of Template | keys; track t) {\n                      <option [value]=\"t.value\">\n                        @switch (t.value) {\n                          @case (Template.bug) {\n                            I found a bug\n                          }\n                          @case (Template.feature) {\n                            I would like a new feature\n                          }\n                        }\n                      </option>\n                    }\n                  </select>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n      }\n\n      @if (issueUrl()) {\n        <p>\n          <span>Please report the issue on Gitlab using</span>\n          <a class=\"pl-1\" [href]=\"issueUrl()\" target=\"_blank\">this link</a>\n          .\n        </p>\n      }\n    </section>\n  </div>\n</div>\n"]}
30
+ args: [{ selector: 'he-issue-confirm', standalone: true, imports: [FormsModule, KeysPipe], template: "<div class=\"modal 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\">{{ title() }}</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"close()\"></button>\n </header>\n <section class=\"modal-card-body\">\n <p class=\"mb-2\">Please select the type of issue from the list below to start:</p>\n\n <div class=\"field is-horizontal my-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"repository\">Category</label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-multiple is-fullwidth\">\n <select\n [ngModel]=\"repository()\"\n (change)=\"repository.set($event.target.value)\"\n name=\"repository\"\n required>\n <option [ngValue]=\"undefined\">Select from the list</option>\n @for (repo of repositories(); track repo) {\n <option [value]=\"repo\">\n @switch (repo) {\n @case (Repository.glossary) {\n Glossary of terms / lookup issues\n }\n @case (Repository.models) {\n Calculation issues\n }\n @case (Repository.orchestrator) {\n Orchestration issues\n }\n @case (Repository.aggregation) {\n Aggregated Data issues\n }\n @case (Repository.community) {\n UI/UX or API issues\n }\n @case (Repository.poorenemeck) {\n Conversion from P&N Spreadsheet\n }\n @case (Repository.schema) {\n Schema issues\n }\n @default {\n Other issues\n }\n }\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n @if (repository()) {\n <div class=\"field is-horizontal my-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"template\">Issue</label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-multiple is-fullwidth\">\n <select [ngModel]=\"template()\" (change)=\"template.set($event.target.value)\" name=\"template\" required>\n <option [value]=\"undefined\">Select from the list</option>\n @for (t of Template | keys; track t) {\n <option [value]=\"t.value\">\n @switch (t.value) {\n @case (Template.bug) {\n I found a bug\n }\n @case (Template.feature) {\n I would like a new feature\n }\n }\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n\n @if (repository() && template() && issueUrl()) {\n <p>\n <span>Please report the issue on Gitlab using</span>\n <a class=\"pl-1\" [href]=\"issueUrl()\" target=\"_blank\">this link</a>\n .\n </p>\n }\n </section>\n </div>\n</div>\n" }]
31
+ }] });
32
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"issue-confirm.component.js","sourceRoot":"","sources":["../../../../src/common/issue-confirm/issue-confirm.component.ts","../../../../src/common/issue-confirm/issue-confirm.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAChE,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;;;AASxC,MAAM,OAAO,qBAAqB;IAPlC;QAQmB,gBAAW,GAAG,MAAM,CAAC,cAAc,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAEnE,UAAK,GAAG,KAAK,CAAC,iBAAiB,CAAC,CAAC;QACjC,eAAU,GAAG,KAAK,EAAc,CAAC;QACjC,aAAQ,GAAG,KAAK,EAAY,CAAC;QAC7B,gBAAW,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAExB,WAAM,GAAG,MAAM,EAAE,CAAC;QAElB,eAAU,GAAG,UAAU,CAAC;QACxB,aAAQ,GAAG,QAAQ,CAAC;QACpB,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE,CACrC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,UAAU,CAAC,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,CAChG,CAAC;QACQ,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CACjC,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CACjG,CAAC;KAMH;IAJW,KAAK;QACb,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACnB,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC;IAC5B,CAAC;8GAtBU,qBAAqB;kGAArB,qBAAqB,qvBCdlC,k6HAsGA,yDD1FY,WAAW,k9BAAE,QAAQ;;2FAEpB,qBAAqB;kBAPjC,SAAS;+BACE,kBAAkB,cAGhB,IAAI,WACP,CAAC,WAAW,EAAE,QAAQ,CAAC","sourcesContent":["import { Component, computed, inject, model, output } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { Repository, Template, reportIssueUrl } from '../utils';\nimport { KeysPipe } from '../keys.pipe';\n\n@Component({\n  selector: 'he-issue-confirm',\n  templateUrl: './issue-confirm.component.html',\n  styleUrls: ['./issue-confirm.component.scss'],\n  standalone: true,\n  imports: [FormsModule, KeysPipe]\n})\nexport class IssueConfirmComponent {\n  private readonly activeModal = inject(NgbActiveModal, { optional: true });\n\n  public title = model('Submit Feedback');\n  public repository = model<Repository>();\n  public template = model<Template>();\n  public isCommunity = model(false);\n\n  protected closed = output();\n\n  protected Repository = Repository;\n  protected Template = Template;\n  protected repositories = computed(() =>\n    Object.values(Repository).filter(value => value !== Repository.community || this.isCommunity())\n  );\n  protected issueUrl = computed(() =>\n    this.repository() && this.template() ? reportIssueUrl(this.repository(), this.template()) : null\n  );\n\n  protected close() {\n    this.closed.emit();\n    this.activeModal?.close();\n  }\n}\n","<div class=\"modal 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\">{{ title() }}</p>\n      <button class=\"delete\" aria-label=\"close\" (click)=\"close()\"></button>\n    </header>\n    <section class=\"modal-card-body\">\n      <p class=\"mb-2\">Please select the type of issue from the list below to start:</p>\n\n      <div class=\"field is-horizontal my-3\">\n        <div class=\"field-label is-normal\">\n          <label class=\"label\" for=\"repository\">Category</label>\n        </div>\n        <div class=\"field-body\">\n          <div class=\"field\">\n            <div class=\"control is-expanded\">\n              <div class=\"select is-multiple is-fullwidth\">\n                <select\n                  [ngModel]=\"repository()\"\n                  (change)=\"repository.set($event.target.value)\"\n                  name=\"repository\"\n                  required>\n                  <option [ngValue]=\"undefined\">Select from the list</option>\n                  @for (repo of repositories(); track repo) {\n                    <option [value]=\"repo\">\n                      @switch (repo) {\n                        @case (Repository.glossary) {\n                          Glossary of terms / lookup issues\n                        }\n                        @case (Repository.models) {\n                          Calculation issues\n                        }\n                        @case (Repository.orchestrator) {\n                          Orchestration issues\n                        }\n                        @case (Repository.aggregation) {\n                          Aggregated Data issues\n                        }\n                        @case (Repository.community) {\n                          UI/UX or API issues\n                        }\n                        @case (Repository.poorenemeck) {\n                          Conversion from P&N Spreadsheet\n                        }\n                        @case (Repository.schema) {\n                          Schema issues\n                        }\n                        @default {\n                          Other issues\n                        }\n                      }\n                    </option>\n                  }\n                </select>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n\n      @if (repository()) {\n        <div class=\"field is-horizontal my-3\">\n          <div class=\"field-label is-normal\">\n            <label class=\"label\" for=\"template\">Issue</label>\n          </div>\n          <div class=\"field-body\">\n            <div class=\"field\">\n              <div class=\"control is-expanded\">\n                <div class=\"select is-multiple is-fullwidth\">\n                  <select [ngModel]=\"template()\" (change)=\"template.set($event.target.value)\" name=\"template\" required>\n                    <option [value]=\"undefined\">Select from the list</option>\n                    @for (t of Template | keys; track t) {\n                      <option [value]=\"t.value\">\n                        @switch (t.value) {\n                          @case (Template.bug) {\n                            I found a bug\n                          }\n                          @case (Template.feature) {\n                            I would like a new feature\n                          }\n                        }\n                      </option>\n                    }\n                  </select>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n      }\n\n      @if (repository() && template() && issueUrl()) {\n        <p>\n          <span>Please report the issue on Gitlab using</span>\n          <a class=\"pl-1\" [href]=\"issueUrl()\" target=\"_blank\">this link</a>\n          .\n        </p>\n      }\n    </section>\n  </div>\n</div>\n"]}
@@ -0,0 +1,87 @@
1
+ import { Component, signal, inject, viewChild, effect, computed, input, output } from '@angular/core';
2
+ import { toSignal } from '@angular/core/rxjs-interop';
3
+ import { GoogleMap } from '@angular/google-maps';
4
+ import { isNumber } from '@hestia-earth/utils';
5
+ import { HE_MAP_LOADED, defaultFeature, addPolygonToFeature, polygonsFromFeature, strokeStyle } from '../maps-utils';
6
+ import * as i0 from "@angular/core";
7
+ export class MapsDrawingComponent {
8
+ constructor() {
9
+ this.mapLoaded$ = inject(HE_MAP_LOADED);
10
+ this.mapLoaded = toSignal(this.mapLoaded$);
11
+ this.map = viewChild(GoogleMap);
12
+ this.listeners = [];
13
+ this.shapes = [];
14
+ this.updated = output();
15
+ this.value = input();
16
+ this.modes = input();
17
+ this.center = input({ lat: 0, lng: 0 });
18
+ this.zoom = input(3);
19
+ this.options = signal({});
20
+ this.feature = signal(defaultFeature());
21
+ this.coordinates = signal(undefined);
22
+ this.data = computed(() => this.coordinates() || JSON.stringify(this.feature()) || '');
23
+ effect(() => {
24
+ if (this.mapLoaded()) {
25
+ this.options.set({
26
+ fullscreenControl: false,
27
+ mapTypeControl: true,
28
+ streetViewControl: false,
29
+ zoomControl: true,
30
+ zoomControlOptions: {
31
+ position: google.maps.ControlPosition.TOP_RIGHT
32
+ }
33
+ });
34
+ }
35
+ }, { allowSignalWrites: true });
36
+ effect(() => {
37
+ const feature = this.value() && !isNumber(this.value()) ? JSON.parse(this.value()) : this.feature();
38
+ this.feature.set(feature);
39
+ }, { allowSignalWrites: true });
40
+ }
41
+ ngOnDestroy() {
42
+ this.listeners.map(listener => google.maps.event.removeListener(listener));
43
+ }
44
+ onPolygonAdded(polygon) {
45
+ this.shapes.push(polygon);
46
+ this.feature.set(this.feature() || defaultFeature());
47
+ addPolygonToFeature(this.feature(), polygon);
48
+ this.updated.emit(this.data());
49
+ }
50
+ onMarkerAdded(marker) {
51
+ this.shapes.push(marker);
52
+ const position = marker.getPosition();
53
+ this.coordinates.set(position?.toJSON());
54
+ this.updated.emit(this.data());
55
+ }
56
+ loadData() {
57
+ this.shapes = polygonsFromFeature(this.feature());
58
+ this.shapes.forEach(polygon => polygon.setMap(this.map()?.googleMap));
59
+ const drawingManager = new google.maps.drawing.DrawingManager({
60
+ drawingControlOptions: {
61
+ position: google.maps.ControlPosition.TOP_CENTER,
62
+ drawingModes: this.modes() || [google.maps.drawing.OverlayType.POLYGON]
63
+ },
64
+ polygonOptions: strokeStyle
65
+ });
66
+ drawingManager.setMap(this.map()?.googleMap);
67
+ this.listeners.push(google.maps.event.addListener(drawingManager, 'polygoncomplete', polygon => this.onPolygonAdded(polygon)));
68
+ this.listeners.push(google.maps.event.addListener(drawingManager, 'markercomplete', marker => this.onMarkerAdded(marker)));
69
+ }
70
+ mapInitialized() {
71
+ setTimeout(() => this.loadData());
72
+ }
73
+ clear() {
74
+ this.shapes.forEach(shape => shape.setMap(null));
75
+ this.shapes = [];
76
+ this.coordinates.set(undefined);
77
+ this.feature.set(undefined);
78
+ this.updated.emit(undefined);
79
+ }
80
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: MapsDrawingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
81
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: MapsDrawingComponent, isStandalone: true, selector: "he-maps-drawing", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, modes: { classPropertyName: "modes", publicName: "modes", isSignal: true, isRequired: false, transformFunction: null }, center: { classPropertyName: "center", publicName: "center", isSignal: true, isRequired: false, transformFunction: null }, zoom: { classPropertyName: "zoom", publicName: "zoom", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { updated: "updated" }, viewQueries: [{ propertyName: "map", first: true, predicate: GoogleMap, descendants: true, isSignal: true }], ngImport: i0, template: "@if (mapLoaded()) {\n <google-map\n (mapInitialized)=\"mapInitialized()\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"zoom()\"\n [center]=\"center()\"\n [options]=\"options()\"></google-map>\n}\n", styles: [":host{display:block;max-height:calc(100vh - 146px);min-height:400px;position:relative}google-map{display:block;position:absolute;inset:0}\n"], dependencies: [{ kind: "component", type: GoogleMap, selector: "google-map", inputs: ["height", "width", "mapId", "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"] }] }); }
82
+ }
83
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: MapsDrawingComponent, decorators: [{
84
+ type: Component,
85
+ args: [{ selector: 'he-maps-drawing', standalone: true, imports: [GoogleMap], template: "@if (mapLoaded()) {\n <google-map\n (mapInitialized)=\"mapInitialized()\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"zoom()\"\n [center]=\"center()\"\n [options]=\"options()\"></google-map>\n}\n", styles: [":host{display:block;max-height:calc(100vh - 146px);min-height:400px;position:relative}google-map{display:block;position:absolute;inset:0}\n"] }]
86
+ }], ctorParameters: () => [] });
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"maps-drawing.component.js","sourceRoot":"","sources":["../../../../src/common/maps-drawing/maps-drawing.component.ts","../../../../src/common/maps-drawing/maps-drawing.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, signal, inject, viewChild, effect, computed, input, output } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { GoogleMap } from '@angular/google-maps';\nimport { isNumber } from '@hestia-earth/utils';\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',\n  standalone: true,\n  imports: [GoogleMap],\n  templateUrl: './maps-drawing.component.html',\n  styleUrl: './maps-drawing.component.scss'\n})\nexport class MapsDrawingComponent implements OnDestroy {\n  private mapLoaded$ = inject(HE_MAP_LOADED);\n\n  protected mapLoaded = toSignal(this.mapLoaded$);\n\n  private map = viewChild(GoogleMap);\n  private listeners: google.maps.MapsEventListener[] = [];\n  private shapes: (google.maps.Marker | google.maps.Polygon)[] = [];\n\n  protected updated = output<string | google.maps.LatLngLiteral>();\n\n  protected value = input<string>();\n  protected modes = input<google.maps.drawing.OverlayType[]>();\n  protected center = input({ lat: 0, lng: 0 });\n  protected zoom = input(3);\n\n  protected options = signal({} as google.maps.MapOptions);\n\n  public feature = signal<IFeature | IFeatureCollection>(defaultFeature());\n  public coordinates = signal<google.maps.LatLngLiteral>(undefined);\n  public data = computed(() => this.coordinates() || JSON.stringify(this.feature()) || '');\n\n  constructor() {\n    effect(\n      () => {\n        if (this.mapLoaded()) {\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      { allowSignalWrites: true }\n    );\n\n    effect(\n      () => {\n        const feature = this.value() && !isNumber(this.value()) ? JSON.parse(this.value()) : this.feature();\n        this.feature.set(feature);\n      },\n      { allowSignalWrites: true }\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.set(this.feature() || defaultFeature());\n    addPolygonToFeature(this.feature(), polygon);\n    this.updated.emit(this.data());\n  }\n\n  private onMarkerAdded(marker: google.maps.Marker) {\n    this.shapes.push(marker);\n    const position = marker.getPosition();\n    this.coordinates.set(position?.toJSON());\n    this.updated.emit(this.data());\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 clear() {\n    this.shapes.forEach(shape => shape.setMap(null));\n    this.shapes = [];\n    this.coordinates.set(undefined);\n    this.feature.set(undefined);\n    this.updated.emit(undefined);\n  }\n}\n","@if (mapLoaded()) {\n  <google-map\n    (mapInitialized)=\"mapInitialized()\"\n    height=\"100%\"\n    width=\"100%\"\n    [zoom]=\"zoom()\"\n    [center]=\"center()\"\n    [options]=\"options()\"></google-map>\n}\n"]}
@@ -1,100 +1,30 @@
1
- import { Component, Input, ViewChild, signal, DestroyRef, output, inject } from '@angular/core';
2
- import { AsyncPipe } from '@angular/common';
3
- import { GoogleMap } from '@angular/google-maps';
1
+ import { Component, output, inject, input, viewChild } from '@angular/core';
4
2
  import { FaIconComponent } from '@fortawesome/angular-fontawesome';
5
3
  import { faTimes } from '@fortawesome/free-solid-svg-icons';
6
- import { isNumber } from '@hestia-earth/utils';
7
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
8
4
  import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
9
- import { HE_MAP_LOADED, defaultFeature, addPolygonToFeature, polygonsFromFeature, strokeStyle } from '../maps-utils';
5
+ import { MapsDrawingComponent } from '../maps-drawing/maps-drawing.component';
10
6
  import * as i0 from "@angular/core";
11
7
  export class MapsDrawingConfirmComponent {
12
8
  constructor() {
13
- this.destroyRef = inject(DestroyRef);
14
- this.mapLoaded$ = inject(HE_MAP_LOADED);
15
9
  this.activeModal = inject(NgbActiveModal, { optional: true });
16
10
  this.faTimes = faTimes;
17
- this.listeners = [];
18
- this.shapes = [];
19
- this.feature = defaultFeature();
20
- this.center = { lat: 0, lng: 0 };
21
- this.zoom = 3;
11
+ this.map = viewChild.required(MapsDrawingComponent);
12
+ this.value = input();
13
+ this.modes = input();
22
14
  this.closed = output();
23
- this.options = signal({});
24
- this.mapLoaded$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
25
- this.options.set({
26
- fullscreenControl: false,
27
- mapTypeControl: true,
28
- streetViewControl: false,
29
- zoomControl: true,
30
- zoomControlOptions: {
31
- position: google.maps.ControlPosition.TOP_RIGHT
32
- }
33
- });
34
- });
35
- }
36
- ngOnInit() {
37
- this.feature = this.value && !isNumber(this.value) ? JSON.parse(this.value) : this.feature;
38
- }
39
- ngOnDestroy() {
40
- this.listeners.map(listener => google.maps.event.removeListener(listener));
41
- }
42
- onPolygonAdded(polygon) {
43
- this.shapes.push(polygon);
44
- this.feature = this.feature || defaultFeature();
45
- addPolygonToFeature(this.feature, polygon);
46
- }
47
- onMarkerAdded(marker) {
48
- this.shapes.push(marker);
49
- const position = marker.getPosition();
50
- this.coordinates = position?.toJSON();
51
- }
52
- loadData() {
53
- this.shapes = polygonsFromFeature(this.feature);
54
- this.shapes.forEach(polygon => polygon.setMap(this.map?.googleMap));
55
- const drawingManager = new google.maps.drawing.DrawingManager({
56
- drawingControlOptions: {
57
- position: google.maps.ControlPosition.TOP_CENTER,
58
- drawingModes: this.modes || [google.maps.drawing.OverlayType.POLYGON]
59
- },
60
- polygonOptions: strokeStyle
61
- });
62
- drawingManager.setMap(this.map?.googleMap);
63
- this.listeners.push(google.maps.event.addListener(drawingManager, 'polygoncomplete', polygon => this.onPolygonAdded(polygon)));
64
- this.listeners.push(google.maps.event.addListener(drawingManager, 'markercomplete', marker => this.onMarkerAdded(marker)));
65
- }
66
- mapInitialized() {
67
- setTimeout(() => this.loadData());
68
15
  }
69
16
  confirm() {
70
- this.close(this.coordinates || JSON.stringify(this.feature) || '');
71
- }
72
- clear() {
73
- this.shapes.forEach(shape => shape.setMap(null));
74
- this.shapes = [];
75
- this.coordinates = undefined;
76
- this.feature = undefined;
17
+ this.close(this.map().data());
77
18
  }
78
19
  close(value) {
79
20
  this.closed.emit(value);
80
21
  this.activeModal?.close(value);
81
22
  }
82
23
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: MapsDrawingConfirmComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
83
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: MapsDrawingConfirmComponent, isStandalone: true, 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)=\"close(value)\"></button>\n </header>\n <section class=\"modal-card-body p-0\">\n @if (mapLoaded$ | async) {\n <google-map\n (mapInitialized)=\"mapInitialized()\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"zoom\"\n [center]=\"center\"\n [options]=\"options()\"></google-map>\n }\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)=\"close(value)\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"clear()\">\n <fa-icon class=\"mr-2\" [icon]=\"faTimes\"></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: GoogleMap, selector: "google-map", inputs: ["height", "width", "mapId", "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: 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: AsyncPipe, name: "async" }] }); }
24
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "17.3.8", type: MapsDrawingConfirmComponent, isStandalone: true, selector: "he-maps-drawing-confirm", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, modes: { classPropertyName: "modes", publicName: "modes", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { closed: "closed" }, viewQueries: [{ propertyName: "map", first: true, predicate: MapsDrawingComponent, descendants: true, isSignal: 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)=\"close()\"></button>\n </header>\n <section class=\"modal-card-body p-0\">\n <he-maps-drawing #map [value]=\"value()\" [modes]=\"modes()\"></he-maps-drawing>\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)=\"close()\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"map.clear()\">\n <fa-icon class=\"mr-2\" [icon]=\"faTimes\"></fa-icon>\n <span>Clear</span>\n </button>\n </footer>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "component", type: MapsDrawingComponent, selector: "he-maps-drawing", inputs: ["value", "modes", "center", "zoom"], outputs: ["updated"] }] }); }
84
25
  }
85
26
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: MapsDrawingConfirmComponent, decorators: [{
86
27
  type: Component,
87
- args: [{ selector: 'he-maps-drawing-confirm', standalone: true, imports: [GoogleMap, FaIconComponent, AsyncPipe], 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)=\"close(value)\"></button>\n </header>\n <section class=\"modal-card-body p-0\">\n @if (mapLoaded$ | async) {\n <google-map\n (mapInitialized)=\"mapInitialized()\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"zoom\"\n [center]=\"center\"\n [options]=\"options()\"></google-map>\n }\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)=\"close(value)\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"clear()\">\n <fa-icon class=\"mr-2\" [icon]=\"faTimes\"></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"] }]
88
- }], ctorParameters: () => [], propDecorators: { map: [{
89
- type: ViewChild,
90
- args: [GoogleMap]
91
- }], value: [{
92
- type: Input
93
- }], modes: [{
94
- type: Input
95
- }], center: [{
96
- type: Input
97
- }], zoom: [{
98
- type: Input
99
- }] } });
100
- //# 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, OnDestroy, Input, ViewChild, signal, DestroyRef, output, inject } from '@angular/core';\nimport { AsyncPipe } from '@angular/common';\nimport { GoogleMap } from '@angular/google-maps';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faTimes } from '@fortawesome/free-solid-svg-icons';\nimport { isNumber } from '@hestia-earth/utils';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';\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  standalone: true,\n  imports: [GoogleMap, FaIconComponent, AsyncPipe]\n})\nexport class MapsDrawingConfirmComponent implements OnInit, OnDestroy {\n  private destroyRef = inject(DestroyRef);\n  protected mapLoaded$ = inject(HE_MAP_LOADED);\n  private readonly activeModal = inject(NgbActiveModal, { optional: true });\n\n  protected readonly faTimes = faTimes;\n\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  protected closed = output<google.maps.LatLngLiteral | string>();\n\n  protected options = signal({} as google.maps.MapOptions);\n\n  constructor() {\n    this.mapLoaded$.pipe(takeUntilDestroyed(this.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  protected confirm() {\n    this.close(this.coordinates || JSON.stringify(this.feature) || '');\n  }\n\n  protected clear() {\n    this.shapes.forEach(shape => shape.setMap(null));\n    this.shapes = [];\n    this.coordinates = undefined;\n    this.feature = undefined;\n  }\n\n  protected close(value: google.maps.LatLngLiteral | string) {\n    this.closed.emit(value);\n    this.activeModal?.close(value);\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)=\"close(value)\"></button>\n    </header>\n    <section class=\"modal-card-body p-0\">\n      @if (mapLoaded$ | async) {\n        <google-map\n          (mapInitialized)=\"mapInitialized()\"\n          height=\"100%\"\n          width=\"100%\"\n          [zoom]=\"zoom\"\n          [center]=\"center\"\n          [options]=\"options()\"></google-map>\n      }\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)=\"close(value)\">\n        <span>Close</span>\n      </button>\n      <button class=\"button is-danger\" (click)=\"clear()\">\n        <fa-icon class=\"mr-2\" [icon]=\"faTimes\"></fa-icon>\n        <span>Clear</span>\n      </button>\n    </footer>\n  </div>\n</div>\n"]}
28
+ args: [{ selector: 'he-maps-drawing-confirm', standalone: true, imports: [FaIconComponent, MapsDrawingComponent], 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)=\"close()\"></button>\n </header>\n <section class=\"modal-card-body p-0\">\n <he-maps-drawing #map [value]=\"value()\" [modes]=\"modes()\"></he-maps-drawing>\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)=\"close()\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"map.clear()\">\n <fa-icon class=\"mr-2\" [icon]=\"faTimes\"></fa-icon>\n <span>Clear</span>\n </button>\n </footer>\n </div>\n</div>\n" }]
29
+ }] });
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwcy1kcmF3aW5nLWNvbmZpcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbW1vbi9tYXBzLWRyYXdpbmctY29uZmlybS9tYXBzLWRyYXdpbmctY29uZmlybS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvY29tbW9uL21hcHMtZHJhd2luZy1jb25maXJtL21hcHMtZHJhd2luZy1jb25maXJtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDNUQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRTVELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdDQUF3QyxDQUFDOztBQVM5RSxNQUFNLE9BQU8sMkJBQTJCO0lBUHhDO1FBUW1CLGdCQUFXLEdBQUcsTUFBTSxDQUFDLGNBQWMsRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBRXZELFlBQU8sR0FBRyxPQUFPLENBQUM7UUFFN0IsUUFBRyxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUU3QyxVQUFLLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDeEIsVUFBSyxHQUFHLEtBQUssRUFBcUMsQ0FBQztRQUVuRCxXQUFNLEdBQUcsTUFBTSxFQUFzQyxDQUFDO0tBVWpFO0lBUlcsT0FBTztRQUNmLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVTLEtBQUssQ0FBQyxLQUEwQztRQUN4RCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN4QixJQUFJLENBQUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNqQyxDQUFDOzhHQW5CVSwyQkFBMkI7a0dBQTNCLDJCQUEyQixtWkFLTCxvQkFBb0IsZ0VDbkJ2RCw0NUJBd0JBLDBERFpZLGVBQWUsa1BBQUUsb0JBQW9COzsyRkFFcEMsMkJBQTJCO2tCQVB2QyxTQUFTOytCQUNFLHlCQUF5QixjQUd2QixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIG91dHB1dCwgaW5qZWN0LCBpbnB1dCwgdmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGYUljb25Db21wb25lbnQgfSBmcm9tICdAZm9ydGF3ZXNvbWUvYW5ndWxhci1mb250YXdlc29tZSc7XG5pbXBvcnQgeyBmYVRpbWVzIH0gZnJvbSAnQGZvcnRhd2Vzb21lL2ZyZWUtc29saWQtc3ZnLWljb25zJztcbmltcG9ydCB7IE5nYkFjdGl2ZU1vZGFsIH0gZnJvbSAnQG5nLWJvb3RzdHJhcC9uZy1ib290c3RyYXAnO1xuXG5pbXBvcnQgeyBNYXBzRHJhd2luZ0NvbXBvbmVudCB9IGZyb20gJy4uL21hcHMtZHJhd2luZy9tYXBzLWRyYXdpbmcuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaGUtbWFwcy1kcmF3aW5nLWNvbmZpcm0nLFxuICB0ZW1wbGF0ZVVybDogJy4vbWFwcy1kcmF3aW5nLWNvbmZpcm0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9tYXBzLWRyYXdpbmctY29uZmlybS5jb21wb25lbnQuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRmFJY29uQ29tcG9uZW50LCBNYXBzRHJhd2luZ0NvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgTWFwc0RyYXdpbmdDb25maXJtQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSByZWFkb25seSBhY3RpdmVNb2RhbCA9IGluamVjdChOZ2JBY3RpdmVNb2RhbCwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgZmFUaW1lcyA9IGZhVGltZXM7XG5cbiAgcHJpdmF0ZSBtYXAgPSB2aWV3Q2hpbGQucmVxdWlyZWQoTWFwc0RyYXdpbmdDb21wb25lbnQpO1xuXG4gIHByb3RlY3RlZCB2YWx1ZSA9IGlucHV0PHN0cmluZz4oKTtcbiAgcHJvdGVjdGVkIG1vZGVzID0gaW5wdXQ8Z29vZ2xlLm1hcHMuZHJhd2luZy5PdmVybGF5VHlwZVtdPigpO1xuXG4gIHByb3RlY3RlZCBjbG9zZWQgPSBvdXRwdXQ8Z29vZ2xlLm1hcHMuTGF0TG5nTGl0ZXJhbCB8IHN0cmluZz4oKTtcblxuICBwcm90ZWN0ZWQgY29uZmlybSgpIHtcbiAgICB0aGlzLmNsb3NlKHRoaXMubWFwKCkuZGF0YSgpKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBjbG9zZSh2YWx1ZT86IGdvb2dsZS5tYXBzLkxhdExuZ0xpdGVyYWwgfCBzdHJpbmcpIHtcbiAgICB0aGlzLmNsb3NlZC5lbWl0KHZhbHVlKTtcbiAgICB0aGlzLmFjdGl2ZU1vZGFsPy5jbG9zZSh2YWx1ZSk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJtb2RhbCBpcy1sYXJnZSBpcy1hY3RpdmVcIj5cbiAgPGRpdiBjbGFzcz1cIm1vZGFsLWJhY2tncm91bmRcIj48L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm1vZGFsLWNhcmRcIj5cbiAgICA8aGVhZGVyIGNsYXNzPVwibW9kYWwtY2FyZC1oZWFkXCI+XG4gICAgICA8cCBjbGFzcz1cIm1vZGFsLWNhcmQtdGl0bGVcIj5EcmF3IG9uIE1hcDwvcD5cbiAgICAgIDxidXR0b24gY2xhc3M9XCJkZWxldGVcIiBhcmlhLWxhYmVsPVwiY2xvc2VcIiAoY2xpY2spPVwiY2xvc2UoKVwiPjwvYnV0dG9uPlxuICAgIDwvaGVhZGVyPlxuICAgIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtY2FyZC1ib2R5IHAtMFwiPlxuICAgICAgPGhlLW1hcHMtZHJhd2luZyAjbWFwIFt2YWx1ZV09XCJ2YWx1ZSgpXCIgW21vZGVzXT1cIm1vZGVzKClcIj48L2hlLW1hcHMtZHJhd2luZz5cbiAgICA8L3NlY3Rpb24+XG4gICAgPGZvb3RlciBjbGFzcz1cIm1vZGFsLWNhcmQtZm9vdFwiPlxuICAgICAgPGJ1dHRvbiBjbGFzcz1cImJ1dHRvbiBpcy1wcmltYXJ5XCIgKGNsaWNrKT1cImNvbmZpcm0oKVwiPlxuICAgICAgICA8c3Bhbj5Db25maXJtPC9zcGFuPlxuICAgICAgPC9idXR0b24+XG4gICAgICA8YnV0dG9uIGNsYXNzPVwiYnV0dG9uIGlzLWdob3N0XCIgKGNsaWNrKT1cImNsb3NlKClcIj5cbiAgICAgICAgPHNwYW4+Q2xvc2U8L3NwYW4+XG4gICAgICA8L2J1dHRvbj5cbiAgICAgIDxidXR0b24gY2xhc3M9XCJidXR0b24gaXMtZGFuZ2VyXCIgKGNsaWNrKT1cIm1hcC5jbGVhcigpXCI+XG4gICAgICAgIDxmYS1pY29uIGNsYXNzPVwibXItMlwiIFtpY29uXT1cImZhVGltZXNcIj48L2ZhLWljb24+XG4gICAgICAgIDxzcGFuPkNsZWFyPC9zcGFuPlxuICAgICAgPC9idXR0b24+XG4gICAgPC9mb290ZXI+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=