@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 +1 -0
- package/common/issue-confirm/issue-confirm.component.d.ts +0 -3
- package/common/maps-drawing/maps-drawing.component.d.ts +32 -0
- package/common/maps-drawing-confirm/maps-drawing-confirm.component.d.ts +6 -27
- package/esm2022/common/index.mjs +2 -1
- package/esm2022/common/issue-confirm/issue-confirm.component.mjs +5 -17
- package/esm2022/common/maps-drawing/maps-drawing.component.mjs +87 -0
- package/esm2022/common/maps-drawing-confirm/maps-drawing-confirm.component.mjs +10 -80
- package/esm2022/common/utils.mjs +4 -6
- package/esm2022/files/files-form-editable/files-form-editable.component.mjs +2 -2
- package/fesm2022/hestia-earth-ui-components.mjs +71 -70
- package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
- package/package.json +1 -1
- package/styles.scss +32 -0
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
|
|
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
|
|
10
|
-
|
|
11
|
-
|
|
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
|
|
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;
|
|
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
|
}
|
package/esm2022/common/index.mjs
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';
|
|
@@ -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,
|
|
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,
|
|
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]=\"
|
|
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]=\"
|
|
43
|
-
}]
|
|
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,
|
|
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 {
|
|
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.
|
|
18
|
-
this.
|
|
19
|
-
this.
|
|
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.
|
|
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.
|
|
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: [
|
|
88
|
-
}]
|
|
89
|
-
|
|
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=
|