@hestia-earth/ui-components 0.26.0 → 0.26.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.d.ts +21 -28
- package/common/click-outside.directive.d.ts +8 -9
- package/common/issue-confirm/issue-confirm.component.d.ts +14 -13
- package/common/maps-drawing-confirm/maps-drawing-confirm.component.d.ts +8 -8
- package/common/node-utils.d.ts +4 -3
- package/common/popover/popover.component.d.ts +1 -1
- package/common/popover-confirm/popover-confirm.component.d.ts +15 -13
- package/common/resized.directive.d.ts +3 -3
- package/common/responsive.service.d.ts +1 -1
- package/common/search-extend/search-extend.component.d.ts +1 -1
- package/cycles/cycles-nodes/cycles-nodes.component.d.ts +26 -25
- package/engine/engine.service.d.ts +0 -1
- package/esm2022/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.mjs +47 -63
- package/esm2022/common/blank-node-state/blank-node-state.component.mjs +3 -3
- package/esm2022/common/blank-node-state-notice/blank-node-state-notice.component.mjs +3 -4
- package/esm2022/common/blank-node-value-delta/blank-node-value-delta.component.mjs +5 -5
- package/esm2022/common/click-outside.directive.mjs +13 -17
- package/esm2022/common/issue-confirm/issue-confirm.component.mjs +26 -28
- package/esm2022/common/link-key-value/link-key-value.component.mjs +3 -3
- package/esm2022/common/maps-drawing-confirm/maps-drawing-confirm.component.mjs +9 -11
- package/esm2022/common/mobile-shell/mobile-shell.component.mjs +3 -3
- package/esm2022/common/navigation-menu/navigation-menu.component.mjs +3 -3
- package/esm2022/common/node-utils.mjs +1 -1
- package/esm2022/common/popover/popover.component.mjs +6 -6
- package/esm2022/common/popover-confirm/popover-confirm.component.mjs +13 -25
- package/esm2022/common/resized.directive.mjs +8 -10
- package/esm2022/common/schema-version-link/schema-version-link.component.mjs +5 -6
- package/esm2022/common/search-extend/search-extend.component.mjs +8 -11
- package/esm2022/common/shell/shell.component.mjs +3 -3
- package/esm2022/common/toast/toast.component.mjs +3 -4
- package/esm2022/common/unit-converter/unit-converter.component.mjs +6 -7
- package/esm2022/common/utils.mjs +2 -2
- package/esm2022/cycles/cycles-completeness/cycles-completeness.component.mjs +12 -13
- package/esm2022/cycles/cycles-emissions-chart/cycles-emissions-chart.component.mjs +4 -5
- package/esm2022/cycles/cycles-functional-unit-measure/cycles-functional-unit-measure.component.mjs +3 -4
- package/esm2022/cycles/cycles-nodes/cycles-nodes.component.mjs +6 -3
- package/esm2022/cycles/cycles-nodes-timeline/cycles-nodes-timeline.component.mjs +5 -5
- package/esm2022/engine/engine-models-stage/engine-models-stage.component.mjs +3 -4
- package/esm2022/engine/engine-models-version-link/engine-models-version-link.component.mjs +3 -3
- package/esm2022/engine/engine-orchestrator-edit/engine-orchestrator-edit.component.mjs +3 -3
- package/esm2022/engine/engine-requirements-form/engine-requirements-form.component.mjs +7 -8
- package/esm2022/engine/engine.service.mjs +1 -6
- package/esm2022/files/files-error.model.mjs +2 -1
- package/esm2022/files/files-form/files-form.component.mjs +5 -11
- package/esm2022/impact-assessments/impact-assessments-graph/impact-assessments-graph.component.mjs +6 -7
- package/esm2022/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.mjs +5 -6
- package/esm2022/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.mjs +4 -5
- package/esm2022/impact-assessments/impact-assessments-products/impact-assessments-products.component.mjs +22 -23
- package/esm2022/node/node-csv-export-confirm/node-csv-export-confirm.component.mjs +32 -57
- package/esm2022/node/node-csv-select-headers/node-csv-select-headers.component.mjs +130 -88
- package/esm2022/node/node-diffs/node-diffs.component.mjs +43 -38
- package/esm2022/node/node-icon/node-icon.component.mjs +4 -5
- package/esm2022/node/node-link/node-link.component.mjs +3 -3
- package/esm2022/node/node-logs-file/node-logs-file.component.mjs +8 -8
- package/esm2022/node/node-logs-models/node-logs-models.component.mjs +3 -3
- package/esm2022/node/node-logs-models/node-logs-models.model.mjs +1 -1
- package/esm2022/node/node-missing-lookup-factors/node-missing-lookup-factors.component.mjs +4 -5
- package/esm2022/node/node-recommendations/node-recommendations.component.mjs +35 -51
- package/esm2022/node/node-value-details/node-value-details.component.mjs +5 -7
- package/esm2022/node/node.module.mjs +5 -4
- package/esm2022/schema/schema-info/schema-info.component.mjs +6 -7
- package/esm2022/schema/schema.service.mjs +3 -9
- package/esm2022/sites/sites-maps/sites-maps.component.mjs +5 -5
- package/esm2022/sites/sites-nodes/sites-nodes.component.mjs +21 -20
- package/esm2022/sites/sites.model.mjs +2 -3
- package/esm2022/terms/terms-property-content/terms-property-content.component.mjs +3 -3
- package/esm2022/terms/terms-sub-class-of-content/terms-sub-class-of-content.component.mjs +5 -6
- package/esm2022/terms/terms-units-description/terms-units-description.component.mjs +3 -3
- package/fesm2022/hestia-earth-ui-components.mjs +441 -494
- package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
- package/files/files-form/files-form.component.d.ts +7 -3
- package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +1 -1
- package/node/node-csv-export-confirm/node-csv-export-confirm.component.d.ts +18 -24
- package/node/node-csv-select-headers/node-csv-select-headers.component.d.ts +36 -33
- package/node/node-diffs/node-diffs.component.d.ts +16 -17
- package/node/node-link/node-link.component.d.ts +1 -1
- package/node/node-logs-models/node-logs-models.model.d.ts +7 -6
- package/node/node-recommendations/node-recommendations.component.d.ts +24 -18
- package/node/node.module.d.ts +4 -3
- package/package.json +1 -1
- package/schema/schema.service.d.ts +1 -1
- package/sites/sites-maps/sites-maps.component.d.ts +1 -1
- package/sites/sites-nodes/sites-nodes.component.d.ts +1 -0
- package/styles.scss +2 -2
|
@@ -1,39 +1,37 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, computed, effect, input, output, signal } from '@angular/core';
|
|
2
2
|
import { Repository, Template, reportIssueUrl } from '../utils';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/
|
|
5
|
-
import * as i2 from "
|
|
6
|
-
import * as i3 from "../keys.pipe";
|
|
4
|
+
import * as i1 from "@angular/forms";
|
|
5
|
+
import * as i2 from "../keys.pipe";
|
|
7
6
|
export class IssueConfirmComponent {
|
|
8
7
|
constructor() {
|
|
9
|
-
this.title = 'Submit Feedback';
|
|
10
|
-
this.
|
|
11
|
-
this.
|
|
8
|
+
this.title = input('Submit Feedback');
|
|
9
|
+
this.repository = input();
|
|
10
|
+
this.template = input();
|
|
11
|
+
this.isCommunity = input(false);
|
|
12
|
+
this.closed = output();
|
|
12
13
|
this.Repository = Repository;
|
|
13
14
|
this.Template = Template;
|
|
14
|
-
this.repositories = Object.values(Repository);
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
this.
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
15
|
+
this.repositories = computed(() => Object.values(Repository).filter(value => value !== Repository.community || this.isCommunity()));
|
|
16
|
+
this.issueUrl = computed(() => this.repository() && this.template() ? reportIssueUrl(this.repository(), this.template()) : null);
|
|
17
|
+
this.selectedRepository = signal(undefined);
|
|
18
|
+
this.selectedTemplate = signal(undefined);
|
|
19
|
+
effect(() => {
|
|
20
|
+
if (!this.selectedRepository() && this.repository()) {
|
|
21
|
+
this.selectedRepository.set(this.repository());
|
|
22
|
+
}
|
|
23
|
+
}, { allowSignalWrites: true });
|
|
24
|
+
effect(() => {
|
|
25
|
+
if (!this.selectedTemplate() && this.template()) {
|
|
26
|
+
this.selectedTemplate.set(this.template());
|
|
27
|
+
}
|
|
28
|
+
}, { allowSignalWrites: true });
|
|
21
29
|
}
|
|
22
30
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: IssueConfirmComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
31
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: IssueConfirmComponent, 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: { 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)=\"closed.emit(false)\"></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: "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: i2.KeysPipe, name: "keys" }] }); }
|
|
24
32
|
}
|
|
25
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: IssueConfirmComponent, decorators: [{
|
|
26
34
|
type: Component,
|
|
27
|
-
args: [{ selector: 'he-issue-confirm', 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)=\"closed.
|
|
28
|
-
}],
|
|
29
|
-
|
|
30
|
-
}], repository: [{
|
|
31
|
-
type: Input
|
|
32
|
-
}], template: [{
|
|
33
|
-
type: Input
|
|
34
|
-
}], isCommunity: [{
|
|
35
|
-
type: Input
|
|
36
|
-
}], closed: [{
|
|
37
|
-
type: Output
|
|
38
|
-
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNzdWUtY29uZmlybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tbW9uL2lzc3VlLWNvbmZpcm0vaXNzdWUtY29uZmlybS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvY29tbW9uL2lzc3VlLWNvbmZpcm0vaXNzdWUtY29uZmlybS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWxGLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLGNBQWMsRUFBRSxNQUFNLFVBQVUsQ0FBQzs7Ozs7QUFPaEUsTUFBTSxPQUFPLHFCQUFxQjtJQUxsQztRQU9TLFVBQUssR0FBRyxpQkFBaUIsQ0FBQztRQU0xQixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUdwQixXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUVyQyxlQUFVLEdBQUcsVUFBVSxDQUFDO1FBQ3hCLGFBQVEsR0FBRyxRQUFRLENBQUM7UUFDcEIsaUJBQVksR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0tBU2pEO0lBUEMsV0FBVztRQUNULElBQUksQ0FBQyxZQUFZLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLEtBQUssVUFBVSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDcEgsQ0FBQztJQUVELElBQVcsUUFBUTtRQUNqQixPQUFPLElBQUksQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDbEcsQ0FBQzs4R0F2QlUscUJBQXFCO2tHQUFyQixxQkFBcUIsb05DVGxDLHEzR0F1RUE7OzJGRDlEYSxxQkFBcUI7a0JBTGpDLFNBQVM7K0JBQ0Usa0JBQWtCOzhCQU1yQixLQUFLO3NCQURYLEtBQUs7Z0JBR0MsVUFBVTtzQkFEaEIsS0FBSztnQkFHQyxRQUFRO3NCQURkLEtBQUs7Z0JBR0MsV0FBVztzQkFEakIsS0FBSztnQkFJQyxNQUFNO3NCQURaLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uQ2hhbmdlcywgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFJlcG9zaXRvcnksIFRlbXBsYXRlLCByZXBvcnRJc3N1ZVVybCB9IGZyb20gJy4uL3V0aWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaGUtaXNzdWUtY29uZmlybScsXG4gIHRlbXBsYXRlVXJsOiAnLi9pc3N1ZS1jb25maXJtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vaXNzdWUtY29uZmlybS5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIElzc3VlQ29uZmlybUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyB0aXRsZSA9ICdTdWJtaXQgRmVlZGJhY2snO1xuICBASW5wdXQoKVxuICBwdWJsaWMgcmVwb3NpdG9yeT86IFJlcG9zaXRvcnk7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyB0ZW1wbGF0ZT86IFRlbXBsYXRlO1xuICBASW5wdXQoKVxuICBwdWJsaWMgaXNDb21tdW5pdHkgPSBmYWxzZTtcblxuICBAT3V0cHV0KClcbiAgcHVibGljIGNsb3NlZCA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcblxuICBwdWJsaWMgUmVwb3NpdG9yeSA9IFJlcG9zaXRvcnk7XG4gIHB1YmxpYyBUZW1wbGF0ZSA9IFRlbXBsYXRlO1xuICBwdWJsaWMgcmVwb3NpdG9yaWVzID0gT2JqZWN0LnZhbHVlcyhSZXBvc2l0b3J5KTtcblxuICBuZ09uQ2hhbmdlcygpIHtcbiAgICB0aGlzLnJlcG9zaXRvcmllcyA9IE9iamVjdC52YWx1ZXMoUmVwb3NpdG9yeSkuZmlsdGVyKHZhbHVlID0+IHZhbHVlICE9PSBSZXBvc2l0b3J5LmNvbW11bml0eSB8fCB0aGlzLmlzQ29tbXVuaXR5KTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgaXNzdWVVcmwoKSB7XG4gICAgcmV0dXJuIHRoaXMucmVwb3NpdG9yeSAmJiB0aGlzLnRlbXBsYXRlID8gcmVwb3J0SXNzdWVVcmwodGhpcy5yZXBvc2l0b3J5LCB0aGlzLnRlbXBsYXRlKSA6IG51bGw7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJtb2RhbCBpcy1hY3RpdmVcIj5cbiAgPGRpdiBjbGFzcz1cIm1vZGFsLWJhY2tncm91bmRcIj48L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm1vZGFsLWNhcmRcIj5cbiAgICA8aGVhZGVyIGNsYXNzPVwibW9kYWwtY2FyZC1oZWFkXCI+XG4gICAgICA8cCBjbGFzcz1cIm1vZGFsLWNhcmQtdGl0bGVcIj57eyB0aXRsZSB9fTwvcD5cbiAgICAgIDxidXR0b24gY2xhc3M9XCJkZWxldGVcIiBhcmlhLWxhYmVsPVwiY2xvc2VcIiAoY2xpY2spPVwiY2xvc2VkLm5leHQoZmFsc2UpXCI+PC9idXR0b24+XG4gICAgPC9oZWFkZXI+XG4gICAgPHNlY3Rpb24gY2xhc3M9XCJtb2RhbC1jYXJkLWJvZHlcIj5cbiAgICAgIDxwIGNsYXNzPVwibWItMlwiPlBsZWFzZSBzZWxlY3QgdGhlIHR5cGUgb2YgaXNzdWUgZnJvbSB0aGUgbGlzdCBiZWxvdyB0byBzdGFydDo8L3A+XG5cbiAgICAgIDxkaXYgY2xhc3M9XCJmaWVsZCBpcy1ob3Jpem9udGFsIG15LTNcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImZpZWxkLWxhYmVsIGlzLW5vcm1hbFwiPlxuICAgICAgICAgIDxsYWJlbCBjbGFzcz1cImxhYmVsXCIgZm9yPVwicmVwb3NpdG9yeVwiPkNhdGVnb3J5PC9sYWJlbD5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJmaWVsZC1ib2R5XCI+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cImZpZWxkXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY29udHJvbCBpcy1leHBhbmRlZFwiPlxuICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwic2VsZWN0IGlzLW11bHRpcGxlIGlzLWZ1bGx3aWR0aFwiPlxuICAgICAgICAgICAgICAgIDxzZWxlY3QgWyhuZ01vZGVsKV09XCJyZXBvc2l0b3J5XCIgbmFtZT1cInJlcG9zaXRvcnlcIiByZXF1aXJlZD5cbiAgICAgICAgICAgICAgICAgIDxvcHRpb24gW25nVmFsdWVdPVwidW5kZWZpbmVkXCI+U2VsZWN0IGZyb20gdGhlIGxpc3Q8L29wdGlvbj5cbiAgICAgICAgICAgICAgICAgIDxvcHRpb24gKm5nRm9yPVwibGV0IHJlcG8gb2YgcmVwb3NpdG9yaWVzXCIgW3ZhbHVlXT1cInJlcG9cIj5cbiAgICAgICAgICAgICAgICAgICAgPG5nLWNvbnRhaW5lciBbbmdTd2l0Y2hdPVwicmVwb1wiPlxuICAgICAgICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIlJlcG9zaXRvcnkuZ2xvc3NhcnlcIj5HbG9zc2FyeSBvZiB0ZXJtcyAvIGxvb2t1cCBpc3N1ZXM8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJSZXBvc2l0b3J5Lm1vZGVsc1wiPkNhbGN1bGF0aW9uIGlzc3VlczwvbmctY29udGFpbmVyPlxuICAgICAgICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIlJlcG9zaXRvcnkub3JjaGVzdHJhdG9yXCI+T3JjaGVzdHJhdGlvbiBpc3N1ZXM8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJSZXBvc2l0b3J5LmFnZ3JlZ2F0aW9uXCI+QWdncmVnYXRlZCBEYXRhIGlzc3VlczwvbmctY29udGFpbmVyPlxuICAgICAgICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIlJlcG9zaXRvcnkuY29tbXVuaXR5XCI+VUkvVVggb3IgQVBJIGlzc3VlczwvbmctY29udGFpbmVyPlxuICAgICAgICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIlJlcG9zaXRvcnkucG9vcmVuZW1lY2tcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgIENvbnZlcnNpb24gZnJvbSBQJk4gU3ByZWFkc2hlZXRcbiAgICAgICAgICAgICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJSZXBvc2l0b3J5LmZyb250ZW5kXCI+T3RoZXIgaXNzdWVzPC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICAgICAgICAgICAgPC9vcHRpb24+XG4gICAgICAgICAgICAgICAgPC9zZWxlY3Q+XG4gICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG5cbiAgICAgIDxkaXYgKm5nSWY9XCJyZXBvc2l0b3J5XCIgY2xhc3M9XCJmaWVsZCBpcy1ob3Jpem9udGFsIG15LTNcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImZpZWxkLWxhYmVsIGlzLW5vcm1hbFwiPlxuICAgICAgICAgIDxsYWJlbCBjbGFzcz1cImxhYmVsXCIgZm9yPVwidGVtcGxhdGVcIj5Jc3N1ZTwvbGFiZWw+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZmllbGQtYm9keVwiPlxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJmaWVsZFwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbnRyb2wgaXMtZXhwYW5kZWRcIj5cbiAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInNlbGVjdCBpcy1tdWx0aXBsZSBpcy1mdWxsd2lkdGhcIj5cbiAgICAgICAgICAgICAgICA8c2VsZWN0IFsobmdNb2RlbCldPVwidGVtcGxhdGVcIiBuYW1lPVwidGVtcGxhdGVcIiByZXF1aXJlZD5cbiAgICAgICAgICAgICAgICAgIDxvcHRpb24gW25nVmFsdWVdPVwidW5kZWZpbmVkXCI+U2VsZWN0IGZyb20gdGhlIGxpc3Q8L29wdGlvbj5cbiAgICAgICAgICAgICAgICAgIDxvcHRpb24gKm5nRm9yPVwibGV0IHQgb2YgVGVtcGxhdGUgfCBrZXlzXCIgW3ZhbHVlXT1cInQudmFsdWVcIj5cbiAgICAgICAgICAgICAgICAgICAgPG5nLWNvbnRhaW5lciBbbmdTd2l0Y2hdPVwidC52YWx1ZVwiPlxuICAgICAgICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIlRlbXBsYXRlLmJ1Z1wiPkkgZm91bmQgYSBidWc8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJUZW1wbGF0ZS5mZWF0dXJlXCI+SSB3b3VsZCBsaWtlIGEgbmV3IGZlYXR1cmU8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICAgICAgICA8L29wdGlvbj5cbiAgICAgICAgICAgICAgICA8L3NlbGVjdD5cbiAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cblxuICAgICAgPHAgKm5nSWY9XCJpc3N1ZVVybFwiPlxuICAgICAgICA8c3Bhbj5QbGVhc2UgcmVwb3J0IHRoZSBpc3N1ZSBvbiBHaXRsYWIgdXNpbmc8L3NwYW4+XG4gICAgICAgIDxhIGNsYXNzPVwicGwtMVwiIFtocmVmXT1cImlzc3VlVXJsXCIgdGFyZ2V0PVwiX2JsYW5rXCI+dGhpcyBsaW5rPC9hPlxuICAgICAgICAuXG4gICAgICA8L3A+XG4gICAgPC9zZWN0aW9uPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
35
|
+
args: [{ selector: 'he-issue-confirm', 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)=\"closed.emit(false)\"></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" }]
|
|
36
|
+
}], ctorParameters: () => [] });
|
|
37
|
+
//# 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,MAAM,eAAe,CAAC;AAEnF,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;;;;AAOhE,MAAM,OAAO,qBAAqB;IAoBhC;QAnBU,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;QAE3B,WAAM,GAAG,MAAM,EAAW,CAAC;QAE3B,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;8GAtCU,qBAAqB;kGAArB,qBAAqB,6mBCTlC,+5HAuGA;;2FD9Fa,qBAAqB;kBALjC,SAAS;+BACE,kBAAkB","sourcesContent":["import { Component, computed, effect, input, output, signal } from '@angular/core';\n\nimport { Repository, Template, reportIssueUrl } from '../utils';\n\n@Component({\n  selector: 'he-issue-confirm',\n  templateUrl: './issue-confirm.component.html',\n  styleUrls: ['./issue-confirm.component.scss']\n})\nexport class IssueConfirmComponent {\n  protected title = input('Submit Feedback');\n  protected repository = input<Repository>();\n  protected template = input<Template>();\n  protected isCommunity = input(false);\n\n  protected closed = output<boolean>();\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","<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)=\"closed.emit(false)\"></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"]}
|
|
@@ -54,11 +54,11 @@ export class LinkKeyValueComponent {
|
|
|
54
54
|
return isExpandable(value) && 'term' in value;
|
|
55
55
|
}
|
|
56
56
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: LinkKeyValueComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
57
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
57
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: LinkKeyValueComponent, selector: "he-link-key-value", inputs: { node: "node", nodeType: "nodeType", dataKey: "dataKey", key: "key", defaultValue: "defaultValue", dataState: "dataState" }, host: { properties: { "class.is-inline-block": "this.isInlineBlock" } }, ngImport: i0, template: "@if (!isUndefined(value)) {\n <ng-container *bindOnce=\"node\">\n <a class=\"is-dark\" [href]=\"baseUrl + '/schema/' + type + '#' + key\" target=\"_blank\">\n <b>{{ key }}</b>\n </a>\n <span class=\"pr-2\">:</span>\n @if (isArray) {\n <div class=\"array-container is-pl-2\">\n @for (v of value; track v) {\n @if (isBlankNode(v)) {\n <div>\n <a class=\"is-dark\" [href]=\"valueLink(v.term)\">{{ v.term.name || v.term['@id'] }}</a>\n <span>:</span>\n @if (!isUndefined(v.value)) {\n <span class=\"is-pl-2\">\n <ng-container *ngTemplateOutlet=\"valueContent; context: { value: v.value }\"></ng-container>\n </span>\n }\n @if (!isUndefined(v.min) || !isUndefined(v.max)) {\n <small class=\"is-pl-1\">({{ minMaxValue(v.min, v.max) }})</small>\n }\n <he-blank-node-state\n class=\"pl-1\"\n [node]=\"v\"\n [nodeType]=\"nodeType\"\n [dataState]=\"dataState\"\n [dataKey]=\"dataKey\"\n key=\"value\"\n linkClass=\"is-dark\"></he-blank-node-state>\n </div>\n } @else {\n <p>\n <ng-container *ngTemplateOutlet=\"valueContent; context: { value: v }\"></ng-container>\n </p>\n }\n }\n </div>\n } @else {\n <ng-container *ngTemplateOutlet=\"valueContent; context: { value }\"></ng-container>\n <he-blank-node-state\n class=\"pl-1\"\n [node]=\"node\"\n [nodeType]=\"nodeType\"\n [dataState]=\"dataState\"\n [dataKey]=\"dataKey\"\n [key]=\"key\"\n linkClass=\"is-dark\"></he-blank-node-state>\n }\n </ng-container>\n} @else if (!!defaultValue) {\n <span>{{ defaultValue }}</span>\n}\n\n<ng-template #valueContent let-v=\"value\">\n <span class=\"is-inline-block is-nowrap\" [innerHtml]=\"toString(v)\"></span>\n</ng-template>\n", styles: [":host{display:block}:host a.has-text-white:hover,:host a.has-text-white.is-hovered{text-decoration:underline}.array-container{max-height:100px;overflow-y:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.BindOnceDirective, selector: "[bindOnce]", inputs: ["bindOnce"] }, { kind: "component", type: i3.BlankNodeStateComponent, selector: "he-blank-node-state", inputs: ["dataState", "nodeType", "dataKey", "key", "node", "state", "linkClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
58
58
|
}
|
|
59
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: LinkKeyValueComponent, decorators: [{
|
|
60
60
|
type: Component,
|
|
61
|
-
args: [{ selector: 'he-link-key-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "
|
|
61
|
+
args: [{ selector: 'he-link-key-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (!isUndefined(value)) {\n <ng-container *bindOnce=\"node\">\n <a class=\"is-dark\" [href]=\"baseUrl + '/schema/' + type + '#' + key\" target=\"_blank\">\n <b>{{ key }}</b>\n </a>\n <span class=\"pr-2\">:</span>\n @if (isArray) {\n <div class=\"array-container is-pl-2\">\n @for (v of value; track v) {\n @if (isBlankNode(v)) {\n <div>\n <a class=\"is-dark\" [href]=\"valueLink(v.term)\">{{ v.term.name || v.term['@id'] }}</a>\n <span>:</span>\n @if (!isUndefined(v.value)) {\n <span class=\"is-pl-2\">\n <ng-container *ngTemplateOutlet=\"valueContent; context: { value: v.value }\"></ng-container>\n </span>\n }\n @if (!isUndefined(v.min) || !isUndefined(v.max)) {\n <small class=\"is-pl-1\">({{ minMaxValue(v.min, v.max) }})</small>\n }\n <he-blank-node-state\n class=\"pl-1\"\n [node]=\"v\"\n [nodeType]=\"nodeType\"\n [dataState]=\"dataState\"\n [dataKey]=\"dataKey\"\n key=\"value\"\n linkClass=\"is-dark\"></he-blank-node-state>\n </div>\n } @else {\n <p>\n <ng-container *ngTemplateOutlet=\"valueContent; context: { value: v }\"></ng-container>\n </p>\n }\n }\n </div>\n } @else {\n <ng-container *ngTemplateOutlet=\"valueContent; context: { value }\"></ng-container>\n <he-blank-node-state\n class=\"pl-1\"\n [node]=\"node\"\n [nodeType]=\"nodeType\"\n [dataState]=\"dataState\"\n [dataKey]=\"dataKey\"\n [key]=\"key\"\n linkClass=\"is-dark\"></he-blank-node-state>\n }\n </ng-container>\n} @else if (!!defaultValue) {\n <span>{{ defaultValue }}</span>\n}\n\n<ng-template #valueContent let-v=\"value\">\n <span class=\"is-inline-block is-nowrap\" [innerHtml]=\"toString(v)\"></span>\n</ng-template>\n", styles: [":host{display:block}:host a.has-text-white:hover,:host a.has-text-white.is-hovered{text-decoration:underline}.array-container{max-height:100px;overflow-y:auto}\n"] }]
|
|
62
62
|
}], propDecorators: { node: [{
|
|
63
63
|
type: Input
|
|
64
64
|
}], nodeType: [{
|
|
@@ -75,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
75
75
|
type: HostBinding,
|
|
76
76
|
args: ['class.is-inline-block']
|
|
77
77
|
}] } });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-key-value.component.js","sourceRoot":"","sources":["../../../../src/common/link-key-value/link-key-value.component.ts","../../../../src/common/link-key-value/link-key-value.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, HostBinding, Input } from '@angular/core';\nimport { DataState } from '@hestia-earth/api';\nimport { isExpandable, NodeType } from '@hestia-earth/schema';\nimport { isUndefined, toPrecision } from '@hestia-earth/utils';\nimport get from 'lodash.get';\n\nimport { baseUrl } from '../utils';\n\nconst valueLink = (value: any) =>\n  isExpandable(value) && value['@id'] ? [baseUrl(), value['@type'].toLowerCase(), value['@id']].join('/') : null;\n\nconst valueLinkRef = (value: any, href?: string) =>\n  href ? `<a class=\"is-dark\" href=\"${href}\">${value.name || value['@id']}</a>` : null;\n\nconst valueValue = (value: any) => (Array.isArray(value) ? value.map(valueValue).join(', ') : toPrecision(value));\n\nconst minMaxValue = (min?: number, max?: number) =>\n  [isUndefined(min) ? '' : `Min: ${valueValue(min)}`, isUndefined(max) ? '' : `Max: ${valueValue(max)}`].join('; ');\n\nconst blankNodeValue = ({\n  term,\n  value,\n  min,\n  max\n}: {\n  term: any;\n  value?: number | boolean;\n  min?: number;\n  max?: number;\n}) =>\n  [\n    [valueLinkRef(term, valueLink(term)), isUndefined(value) ? '' : valueValue(value)].join(': '),\n    [isUndefined(min) ? '' : `Min: ${valueValue(min)}`, isUndefined(max) ? '' : `Max: ${valueValue(max)}`].join('; ')\n  ].join(' - ');\n\nconst stringMapper: {\n  [type: string]: (value?: any) => string;\n} = {\n  number: (value: number) => `${toPrecision(value, 3)}`,\n  undefined: () => '',\n  blankNode: value =>\n    'term' in value ? blankNodeValue(value) : valueLinkRef(value, valueLink(value)) || value.name || value['@id'],\n  object: value =>\n    Array.isArray(value)\n      ? value.map(toString).join(', ')\n      : value instanceof Date\n        ? value.toJSON()\n        : isExpandable(value)\n          ? stringMapper.blankNode(value)\n          : JSON.stringify(value, null, 2)\n};\n\nconst toString = (value: any) =>\n  (typeof value) in stringMapper ? stringMapper[typeof value](value) : value.toString();\n\n@Component({\n  selector: 'he-link-key-value',\n  templateUrl: './link-key-value.component.html',\n  styleUrls: ['./link-key-value.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LinkKeyValueComponent {\n  @Input()\n  protected node: any;\n  @Input()\n  protected nodeType?: NodeType;\n  @Input()\n  protected dataKey?: string;\n  @Input()\n  protected key: string;\n  @Input()\n  protected defaultValue?: any = '';\n  @Input()\n  protected dataState?: DataState;\n\n  public isExpandable = isExpandable;\n  public valueLink = valueLink;\n  public isUndefined = isUndefined;\n  public minMaxValue = minMaxValue;\n\n  @HostBinding('class.is-inline-block')\n  get isInlineBlock() {\n    return this.isArray;\n  }\n\n  public baseUrl = baseUrl();\n  public toString = toString;\n\n  public get type() {\n    return this.node['@type'] || this.node.type;\n  }\n\n  public get value() {\n    return get(this.node, this.key);\n  }\n\n  public get isArray() {\n    return Array.isArray(this.value) && [this.value.length > 1, isExpandable(this.value[0])].some(Boolean);\n  }\n\n  public isBlankNode(value: any) {\n    return isExpandable(value) && 'term' in value;\n  }\n}\n","<ng-container *ngIf=\"!isUndefined(value); else showDefault\">\n  <ng-container *bindOnce=\"node\">\n    <a class=\"is-dark\" [href]=\"baseUrl + '/schema/' + type + '#' + key\" target=\"_blank\">\n      <b>{{ key }}</b>\n    </a>\n    <span class=\"pr-2\">:</span>\n\n    <ng-container *ngIf=\"isArray; else singleValue\">\n      <div class=\"array-container is-pl-2\">\n        <ng-container *ngFor=\"let v of value\">\n          <ng-template #nonBlankNodeValue>\n            <p>\n              <ng-container *ngTemplateOutlet=\"valueContent; context: { value: v }\"></ng-container>\n            </p>\n          </ng-template>\n\n          <ng-container *ngIf=\"isBlankNode(v); else nonBlankNodeValue\">\n            <div>\n              <a class=\"is-dark\" [href]=\"valueLink(v.term)\">{{ v.term.name || v.term['@id'] }}</a>\n              <span>:</span>\n              <span class=\"is-pl-2\" *ngIf=\"!isUndefined(v.value)\">\n                <ng-container *ngTemplateOutlet=\"valueContent; context: { value: v.value }\"></ng-container>\n              </span>\n\n              <ng-container *ngIf=\"!isUndefined(v.min) || !isUndefined(v.max)\">\n                <small class=\"is-pl-1\">({{ minMaxValue(v.min, v.max) }})</small>\n              </ng-container>\n\n              <he-blank-node-state\n                class=\"pl-1\"\n                [node]=\"v\"\n                [nodeType]=\"nodeType\"\n                [dataState]=\"dataState\"\n                [dataKey]=\"dataKey\"\n                key=\"value\"\n                linkClass=\"is-dark\"></he-blank-node-state>\n            </div>\n          </ng-container>\n        </ng-container>\n      </div>\n    </ng-container>\n  </ng-container>\n</ng-container>\n\n<ng-template #valueContent let-v=\"value\">\n  <span class=\"is-inline-block is-nowrap\" [innerHtml]=\"toString(v)\"></span>\n</ng-template>\n\n<ng-template #singleValue>\n  <ng-container *ngTemplateOutlet=\"valueContent; context: { value }\"></ng-container>\n\n  <he-blank-node-state\n    class=\"pl-1\"\n    [node]=\"node\"\n    [nodeType]=\"nodeType\"\n    [dataState]=\"dataState\"\n    [dataKey]=\"dataKey\"\n    [key]=\"key\"\n    linkClass=\"is-dark\"></he-blank-node-state>\n</ng-template>\n\n<ng-template #showDefault>\n  <span *ngIf=\"!!defaultValue\">{{ defaultValue }}</span>\n</ng-template>\n"]}
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-key-value.component.js","sourceRoot":"","sources":["../../../../src/common/link-key-value/link-key-value.component.ts","../../../../src/common/link-key-value/link-key-value.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEvF,OAAO,EAAE,YAAY,EAAY,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC/D,OAAO,GAAG,MAAM,YAAY,CAAC;AAE7B,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;;;;;AAEnC,MAAM,SAAS,GAAG,CAAC,KAAU,EAAE,EAAE,CAC/B,YAAY,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AAEjH,MAAM,YAAY,GAAG,CAAC,KAAU,EAAE,IAAa,EAAE,EAAE,CACjD,IAAI,CAAC,CAAC,CAAC,4BAA4B,IAAI,KAAK,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC;AAEtF,MAAM,UAAU,GAAG,CAAC,KAAU,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;AAElH,MAAM,WAAW,GAAG,CAAC,GAAY,EAAE,GAAY,EAAE,EAAE,CACjD,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,UAAU,CAAC,GAAG,CAAC,EAAE,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAEpH,MAAM,cAAc,GAAG,CAAC,EACtB,IAAI,EACJ,KAAK,EACL,GAAG,EACH,GAAG,EAMJ,EAAE,EAAE,CACH;IACE,CAAC,YAAY,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;IAC7F,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,UAAU,CAAC,GAAG,CAAC,EAAE,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;CAClH,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAEhB,MAAM,YAAY,GAEd;IACF,MAAM,EAAE,CAAC,KAAa,EAAE,EAAE,CAAC,GAAG,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE;IACrD,SAAS,EAAE,GAAG,EAAE,CAAC,EAAE;IACnB,SAAS,EAAE,KAAK,CAAC,EAAE,CACjB,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,KAAK,CAAC;IAC/G,MAAM,EAAE,KAAK,CAAC,EAAE,CACd,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;QAClB,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;QAChC,CAAC,CAAC,KAAK,YAAY,IAAI;YACrB,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE;YAChB,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC;gBACnB,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC;gBAC/B,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;CACzC,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAC,KAAU,EAAE,EAAE,CAC9B,CAAC,OAAO,KAAK,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;AAQxF,MAAM,OAAO,qBAAqB;IANlC;QAgBY,iBAAY,GAAS,EAAE,CAAC;QAI3B,iBAAY,GAAG,YAAY,CAAC;QAC5B,cAAS,GAAG,SAAS,CAAC;QACtB,gBAAW,GAAG,WAAW,CAAC;QAC1B,gBAAW,GAAG,WAAW,CAAC;QAO1B,YAAO,GAAG,OAAO,EAAE,CAAC;QACpB,aAAQ,GAAG,QAAQ,CAAC;KAiB5B;IAvBC,IACI,aAAa;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAKD,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;IAC9C,CAAC;IAED,IAAW,KAAK;QACd,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;IAClC,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACzG,CAAC;IAEM,WAAW,CAAC,KAAU;QAC3B,OAAO,YAAY,CAAC,KAAK,CAAC,IAAI,MAAM,IAAI,KAAK,CAAC;IAChD,CAAC;8GAzCU,qBAAqB;kGAArB,qBAAqB,wQC7DlC,ihEAwDA;;2FDKa,qBAAqB;kBANjC,SAAS;+BACE,mBAAmB,mBAGZ,uBAAuB,CAAC,MAAM;8BAIrC,IAAI;sBADb,KAAK;gBAGI,QAAQ;sBADjB,KAAK;gBAGI,OAAO;sBADhB,KAAK;gBAGI,GAAG;sBADZ,KAAK;gBAGI,YAAY;sBADrB,KAAK;gBAGI,SAAS;sBADlB,KAAK;gBASF,aAAa;sBADhB,WAAW;uBAAC,uBAAuB","sourcesContent":["import { ChangeDetectionStrategy, Component, HostBinding, Input } from '@angular/core';\nimport { DataState } from '@hestia-earth/api';\nimport { isExpandable, NodeType } from '@hestia-earth/schema';\nimport { isUndefined, toPrecision } from '@hestia-earth/utils';\nimport get from 'lodash.get';\n\nimport { baseUrl } from '../utils';\n\nconst valueLink = (value: any) =>\n  isExpandable(value) && value['@id'] ? [baseUrl(), value['@type'].toLowerCase(), value['@id']].join('/') : null;\n\nconst valueLinkRef = (value: any, href?: string) =>\n  href ? `<a class=\"is-dark\" href=\"${href}\">${value.name || value['@id']}</a>` : null;\n\nconst valueValue = (value: any) => (Array.isArray(value) ? value.map(valueValue).join(', ') : toPrecision(value));\n\nconst minMaxValue = (min?: number, max?: number) =>\n  [isUndefined(min) ? '' : `Min: ${valueValue(min)}`, isUndefined(max) ? '' : `Max: ${valueValue(max)}`].join('; ');\n\nconst blankNodeValue = ({\n  term,\n  value,\n  min,\n  max\n}: {\n  term: any;\n  value?: number | boolean;\n  min?: number;\n  max?: number;\n}) =>\n  [\n    [valueLinkRef(term, valueLink(term)), isUndefined(value) ? '' : valueValue(value)].join(': '),\n    [isUndefined(min) ? '' : `Min: ${valueValue(min)}`, isUndefined(max) ? '' : `Max: ${valueValue(max)}`].join('; ')\n  ].join(' - ');\n\nconst stringMapper: {\n  [type: string]: (value?: any) => string;\n} = {\n  number: (value: number) => `${toPrecision(value, 3)}`,\n  undefined: () => '',\n  blankNode: value =>\n    'term' in value ? blankNodeValue(value) : valueLinkRef(value, valueLink(value)) || value.name || value['@id'],\n  object: value =>\n    Array.isArray(value)\n      ? value.map(toString).join(', ')\n      : value instanceof Date\n        ? value.toJSON()\n        : isExpandable(value)\n          ? stringMapper.blankNode(value)\n          : JSON.stringify(value, null, 2)\n};\n\nconst toString = (value: any) =>\n  (typeof value) in stringMapper ? stringMapper[typeof value](value) : value.toString();\n\n@Component({\n  selector: 'he-link-key-value',\n  templateUrl: './link-key-value.component.html',\n  styleUrls: ['./link-key-value.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LinkKeyValueComponent {\n  @Input()\n  protected node: any;\n  @Input()\n  protected nodeType?: NodeType;\n  @Input()\n  protected dataKey?: string;\n  @Input()\n  protected key: string;\n  @Input()\n  protected defaultValue?: any = '';\n  @Input()\n  protected dataState?: DataState;\n\n  public isExpandable = isExpandable;\n  public valueLink = valueLink;\n  public isUndefined = isUndefined;\n  public minMaxValue = minMaxValue;\n\n  @HostBinding('class.is-inline-block')\n  get isInlineBlock() {\n    return this.isArray;\n  }\n\n  public baseUrl = baseUrl();\n  public toString = toString;\n\n  public get type() {\n    return this.node['@type'] || this.node.type;\n  }\n\n  public get value() {\n    return get(this.node, this.key);\n  }\n\n  public get isArray() {\n    return Array.isArray(this.value) && [this.value.length > 1, isExpandable(this.value[0])].some(Boolean);\n  }\n\n  public isBlankNode(value: any) {\n    return isExpandable(value) && 'term' in value;\n  }\n}\n","@if (!isUndefined(value)) {\n  <ng-container *bindOnce=\"node\">\n    <a class=\"is-dark\" [href]=\"baseUrl + '/schema/' + type + '#' + key\" target=\"_blank\">\n      <b>{{ key }}</b>\n    </a>\n    <span class=\"pr-2\">:</span>\n    @if (isArray) {\n      <div class=\"array-container is-pl-2\">\n        @for (v of value; track v) {\n          @if (isBlankNode(v)) {\n            <div>\n              <a class=\"is-dark\" [href]=\"valueLink(v.term)\">{{ v.term.name || v.term['@id'] }}</a>\n              <span>:</span>\n              @if (!isUndefined(v.value)) {\n                <span class=\"is-pl-2\">\n                  <ng-container *ngTemplateOutlet=\"valueContent; context: { value: v.value }\"></ng-container>\n                </span>\n              }\n              @if (!isUndefined(v.min) || !isUndefined(v.max)) {\n                <small class=\"is-pl-1\">({{ minMaxValue(v.min, v.max) }})</small>\n              }\n              <he-blank-node-state\n                class=\"pl-1\"\n                [node]=\"v\"\n                [nodeType]=\"nodeType\"\n                [dataState]=\"dataState\"\n                [dataKey]=\"dataKey\"\n                key=\"value\"\n                linkClass=\"is-dark\"></he-blank-node-state>\n            </div>\n          } @else {\n            <p>\n              <ng-container *ngTemplateOutlet=\"valueContent; context: { value: v }\"></ng-container>\n            </p>\n          }\n        }\n      </div>\n    } @else {\n      <ng-container *ngTemplateOutlet=\"valueContent; context: { value }\"></ng-container>\n      <he-blank-node-state\n        class=\"pl-1\"\n        [node]=\"node\"\n        [nodeType]=\"nodeType\"\n        [dataState]=\"dataState\"\n        [dataKey]=\"dataKey\"\n        [key]=\"key\"\n        linkClass=\"is-dark\"></he-blank-node-state>\n    }\n  </ng-container>\n} @else if (!!defaultValue) {\n  <span>{{ defaultValue }}</span>\n}\n\n<ng-template #valueContent let-v=\"value\">\n  <span class=\"is-inline-block is-nowrap\" [innerHtml]=\"toString(v)\"></span>\n</ng-template>\n"]}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, Input, ViewChild, Inject, signal, output } from '@angular/core';
|
|
2
2
|
import { GoogleMap } from '@angular/google-maps';
|
|
3
3
|
import { isNumber } from '@hestia-earth/utils';
|
|
4
4
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
5
|
import { HE_MAP_LOADED, defaultFeature, addPolygonToFeature, polygonsFromFeature, strokeStyle } from '../maps-utils';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/
|
|
8
|
-
import * as i2 from "@angular
|
|
9
|
-
import * as i3 from "@
|
|
7
|
+
import * as i1 from "@angular/google-maps";
|
|
8
|
+
import * as i2 from "@fortawesome/angular-fontawesome";
|
|
9
|
+
import * as i3 from "@angular/common";
|
|
10
10
|
import * as i4 from "rxjs";
|
|
11
11
|
export class MapsDrawingConfirmComponent {
|
|
12
12
|
constructor(destroyRef, mapLoaded$) {
|
|
@@ -16,7 +16,7 @@ export class MapsDrawingConfirmComponent {
|
|
|
16
16
|
this.feature = defaultFeature();
|
|
17
17
|
this.center = { lat: 0, lng: 0 };
|
|
18
18
|
this.zoom = 3;
|
|
19
|
-
this.closed =
|
|
19
|
+
this.closed = output();
|
|
20
20
|
this.options = signal({});
|
|
21
21
|
mapLoaded$.pipe(takeUntilDestroyed(destroyRef)).subscribe(() => {
|
|
22
22
|
this.options.set({
|
|
@@ -64,7 +64,7 @@ export class MapsDrawingConfirmComponent {
|
|
|
64
64
|
setTimeout(() => this.loadData());
|
|
65
65
|
}
|
|
66
66
|
confirm() {
|
|
67
|
-
this.closed.
|
|
67
|
+
this.closed.emit(this.coordinates || JSON.stringify(this.feature) || '');
|
|
68
68
|
}
|
|
69
69
|
clear() {
|
|
70
70
|
this.shapes.forEach(shape => shape.setMap(null));
|
|
@@ -73,11 +73,11 @@ export class MapsDrawingConfirmComponent {
|
|
|
73
73
|
this.feature = undefined;
|
|
74
74
|
}
|
|
75
75
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: MapsDrawingConfirmComponent, deps: [{ token: i0.DestroyRef }, { token: HE_MAP_LOADED }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
76
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
76
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: MapsDrawingConfirmComponent, selector: "he-maps-drawing-confirm", inputs: { value: "value", modes: "modes", center: "center", zoom: "zoom" }, outputs: { closed: "closed" }, viewQueries: [{ propertyName: "map", first: true, predicate: GoogleMap, descendants: true }], ngImport: i0, template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Draw on Map</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"closed.emit(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)=\"closed.emit(value)\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"clear()\">\n <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n <span>Clear</span>\n </button>\n </footer>\n </div>\n</div>\n", styles: ["google-map{display:block;height:100%;max-height:calc(100vh - 146px);min-height:500px}\n"], dependencies: [{ kind: "component", type: i1.GoogleMap, selector: "google-map", inputs: ["height", "width", "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: i2.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: i3.AsyncPipe, name: "async" }] }); }
|
|
77
77
|
}
|
|
78
78
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: MapsDrawingConfirmComponent, decorators: [{
|
|
79
79
|
type: Component,
|
|
80
|
-
args: [{ selector: 'he-maps-drawing-confirm', template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Draw on Map</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"closed.
|
|
80
|
+
args: [{ selector: 'he-maps-drawing-confirm', template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Draw on Map</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"closed.emit(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)=\"closed.emit(value)\">\n <span>Close</span>\n </button>\n <button class=\"button is-danger\" (click)=\"clear()\">\n <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n <span>Clear</span>\n </button>\n </footer>\n </div>\n</div>\n", styles: ["google-map{display:block;height:100%;max-height:calc(100vh - 146px);min-height:500px}\n"] }]
|
|
81
81
|
}], ctorParameters: () => [{ type: i0.DestroyRef }, { type: i4.Observable, decorators: [{
|
|
82
82
|
type: Inject,
|
|
83
83
|
args: [HE_MAP_LOADED]
|
|
@@ -92,7 +92,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
92
92
|
type: Input
|
|
93
93
|
}], zoom: [{
|
|
94
94
|
type: Input
|
|
95
|
-
}], closed: [{
|
|
96
|
-
type: Output
|
|
97
95
|
}] } });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"maps-drawing-confirm.component.js","sourceRoot":"","sources":["../../../../src/common/maps-drawing-confirm/maps-drawing-confirm.component.ts","../../../../src/common/maps-drawing-confirm/maps-drawing-confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnDestroy,\n  Output,\n  EventEmitter,\n  Input,\n  ViewChild,\n  Inject,\n  signal,\n  DestroyRef\n} from '@angular/core';\nimport { GoogleMap } from '@angular/google-maps';\nimport { isNumber } from '@hestia-earth/utils';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Observable } from 'rxjs';\n\nimport {\n  HE_MAP_LOADED,\n  IFeature,\n  IFeatureCollection,\n  defaultFeature,\n  addPolygonToFeature,\n  polygonsFromFeature,\n  strokeStyle\n} from '../maps-utils';\n\n@Component({\n  selector: 'he-maps-drawing-confirm',\n  templateUrl: './maps-drawing-confirm.component.html',\n  styleUrls: ['./maps-drawing-confirm.component.scss']\n})\nexport class MapsDrawingConfirmComponent implements OnInit, OnDestroy {\n  private listeners: google.maps.MapsEventListener[] = [];\n  private shapes: (google.maps.Marker | google.maps.Polygon)[] = [];\n\n  private feature?: IFeature | IFeatureCollection = defaultFeature();\n  private coordinates?: google.maps.LatLngLiteral;\n\n  @ViewChild(GoogleMap)\n  private map?: GoogleMap;\n\n  @Input()\n  public value?: string;\n  @Input()\n  public modes?: google.maps.drawing.OverlayType[];\n  @Input()\n  public center = { lat: 0, lng: 0 };\n  @Input()\n  public zoom = 3;\n\n  @Output()\n  public closed = new EventEmitter<google.maps.LatLngLiteral | string>();\n\n  protected options = signal({} as google.maps.MapOptions);\n\n  constructor(\n    destroyRef: DestroyRef,\n    @Inject(HE_MAP_LOADED) protected mapLoaded$: Observable<boolean>\n  ) {\n    mapLoaded$.pipe(takeUntilDestroyed(destroyRef)).subscribe(() => {\n      this.options.set({\n        fullscreenControl: false,\n        mapTypeControl: true,\n        streetViewControl: false,\n        zoomControl: true,\n        zoomControlOptions: {\n          position: google.maps.ControlPosition.TOP_RIGHT\n        }\n      });\n    });\n  }\n\n  ngOnInit() {\n    this.feature = this.value && !isNumber(this.value) ? JSON.parse(this.value) : this.feature;\n  }\n\n  ngOnDestroy() {\n    this.listeners.map(listener => google.maps.event.removeListener(listener));\n  }\n\n  private onPolygonAdded(polygon: google.maps.Polygon) {\n    this.shapes.push(polygon);\n    this.feature = this.feature || defaultFeature();\n    addPolygonToFeature(this.feature, polygon);\n  }\n\n  private onMarkerAdded(marker: google.maps.Marker) {\n    this.shapes.push(marker);\n    const position = marker.getPosition();\n    this.coordinates = position?.toJSON();\n  }\n\n  private loadData() {\n    this.shapes = polygonsFromFeature(this.feature);\n    this.shapes.forEach(polygon => polygon.setMap(this.map?.googleMap));\n    const drawingManager = new google.maps.drawing.DrawingManager({\n      drawingControlOptions: {\n        position: google.maps.ControlPosition.TOP_CENTER,\n        drawingModes: this.modes || [google.maps.drawing.OverlayType.POLYGON]\n      },\n      polygonOptions: strokeStyle\n    });\n    drawingManager.setMap(this.map?.googleMap);\n    this.listeners.push(\n      google.maps.event.addListener(drawingManager, 'polygoncomplete', polygon => this.onPolygonAdded(polygon))\n    );\n    this.listeners.push(\n      google.maps.event.addListener(drawingManager, 'markercomplete', marker => this.onMarkerAdded(marker))\n    );\n  }\n\n  protected mapInitialized() {\n    setTimeout(() => this.loadData());\n  }\n\n  public confirm() {\n    this.closed.next(this.coordinates || JSON.stringify(this.feature) || '');\n  }\n\n  public clear() {\n    this.shapes.forEach(shape => shape.setMap(null));\n    this.shapes = [];\n    this.coordinates = undefined;\n    this.feature = undefined;\n  }\n}\n","<div class=\"modal is-large is-active\">\n  <div class=\"modal-background\"></div>\n  <div class=\"modal-card\">\n    <header class=\"modal-card-head\">\n      <p class=\"modal-card-title\">Draw on Map</p>\n      <button class=\"delete\" aria-label=\"close\" (click)=\"closed.next(value)\"></button>\n    </header>\n    <section class=\"modal-card-body p-0\">\n      <google-map\n        *ngIf=\"mapLoaded$ | async\"\n        (mapInitialized)=\"mapInitialized()\"\n        height=\"100%\"\n        width=\"100%\"\n        [zoom]=\"zoom\"\n        [center]=\"center\"\n        [options]=\"options()\"></google-map>\n    </section>\n    <footer class=\"modal-card-foot\">\n      <button class=\"button is-primary\" (click)=\"confirm()\">\n        <span>Confirm</span>\n      </button>\n      <button class=\"button is-ghost\" (click)=\"closed.next(value)\">\n        <span>Close</span>\n      </button>\n      <button class=\"button is-danger\" (click)=\"clear()\">\n        <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n        <span>Clear</span>\n      </button>\n    </footer>\n  </div>\n</div>\n"]}
|
|
96
|
+
//# 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, Inject, signal, DestroyRef, output } from '@angular/core';\nimport { GoogleMap } from '@angular/google-maps';\nimport { isNumber } from '@hestia-earth/utils';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Observable } from 'rxjs';\n\nimport {\n  HE_MAP_LOADED,\n  IFeature,\n  IFeatureCollection,\n  defaultFeature,\n  addPolygonToFeature,\n  polygonsFromFeature,\n  strokeStyle\n} from '../maps-utils';\n\n@Component({\n  selector: 'he-maps-drawing-confirm',\n  templateUrl: './maps-drawing-confirm.component.html',\n  styleUrls: ['./maps-drawing-confirm.component.scss']\n})\nexport class MapsDrawingConfirmComponent implements OnInit, OnDestroy {\n  private listeners: google.maps.MapsEventListener[] = [];\n  private shapes: (google.maps.Marker | google.maps.Polygon)[] = [];\n\n  private feature?: IFeature | IFeatureCollection = defaultFeature();\n  private coordinates?: google.maps.LatLngLiteral;\n\n  @ViewChild(GoogleMap)\n  private map?: GoogleMap;\n\n  @Input()\n  protected value?: string;\n  @Input()\n  protected modes?: google.maps.drawing.OverlayType[];\n  @Input()\n  protected center = { lat: 0, lng: 0 };\n  @Input()\n  protected zoom = 3;\n\n  protected closed = output<google.maps.LatLngLiteral | string>();\n\n  protected options = signal({} as google.maps.MapOptions);\n\n  constructor(\n    destroyRef: DestroyRef,\n    @Inject(HE_MAP_LOADED) protected mapLoaded$: Observable<boolean>\n  ) {\n    mapLoaded$.pipe(takeUntilDestroyed(destroyRef)).subscribe(() => {\n      this.options.set({\n        fullscreenControl: false,\n        mapTypeControl: true,\n        streetViewControl: false,\n        zoomControl: true,\n        zoomControlOptions: {\n          position: google.maps.ControlPosition.TOP_RIGHT\n        }\n      });\n    });\n  }\n\n  ngOnInit() {\n    this.feature = this.value && !isNumber(this.value) ? JSON.parse(this.value) : this.feature;\n  }\n\n  ngOnDestroy() {\n    this.listeners.map(listener => google.maps.event.removeListener(listener));\n  }\n\n  private onPolygonAdded(polygon: google.maps.Polygon) {\n    this.shapes.push(polygon);\n    this.feature = this.feature || defaultFeature();\n    addPolygonToFeature(this.feature, polygon);\n  }\n\n  private onMarkerAdded(marker: google.maps.Marker) {\n    this.shapes.push(marker);\n    const position = marker.getPosition();\n    this.coordinates = position?.toJSON();\n  }\n\n  private loadData() {\n    this.shapes = polygonsFromFeature(this.feature);\n    this.shapes.forEach(polygon => polygon.setMap(this.map?.googleMap));\n    const drawingManager = new google.maps.drawing.DrawingManager({\n      drawingControlOptions: {\n        position: google.maps.ControlPosition.TOP_CENTER,\n        drawingModes: this.modes || [google.maps.drawing.OverlayType.POLYGON]\n      },\n      polygonOptions: strokeStyle\n    });\n    drawingManager.setMap(this.map?.googleMap);\n    this.listeners.push(\n      google.maps.event.addListener(drawingManager, 'polygoncomplete', polygon => this.onPolygonAdded(polygon))\n    );\n    this.listeners.push(\n      google.maps.event.addListener(drawingManager, 'markercomplete', marker => this.onMarkerAdded(marker))\n    );\n  }\n\n  protected mapInitialized() {\n    setTimeout(() => this.loadData());\n  }\n\n  protected confirm() {\n    this.closed.emit(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","<div class=\"modal is-large is-active\">\n  <div class=\"modal-background\"></div>\n  <div class=\"modal-card\">\n    <header class=\"modal-card-head\">\n      <p class=\"modal-card-title\">Draw on Map</p>\n      <button class=\"delete\" aria-label=\"close\" (click)=\"closed.emit(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)=\"closed.emit(value)\">\n        <span>Close</span>\n      </button>\n      <button class=\"button is-danger\" (click)=\"clear()\">\n        <fa-icon class=\"mr-2\" icon=\"times\"></fa-icon>\n        <span>Clear</span>\n      </button>\n    </footer>\n  </div>\n</div>\n"]}
|
|
@@ -66,11 +66,11 @@ export class MobileShellComponent {
|
|
|
66
66
|
button.onClick?.();
|
|
67
67
|
}
|
|
68
68
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: MobileShellComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
69
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
69
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: MobileShellComponent, selector: "he-mobile-shell", inputs: { menuButtons: "menuButtons", defaultActiveButtonId: "defaultActiveButtonId" }, outputs: { menuShown: "menuShown" }, queries: [{ propertyName: "iconTemplate", first: true, predicate: ["iconTemplate"], descendants: true }], ngImport: i0, template: "<div class=\"shell-content\">\n <div [class.menu-expanded]=\"expanded()\" class=\"shell__content--body | h-100\">\n <ng-content></ng-content>\n </div>\n</div>\n\n<aside class=\"shell-footer | is-flex is-justify-content-space-between\">\n @for (button of buttons(); track button) {\n <a (click)=\"onMenuButtonClick(button)\" class=\"button menu-button is-secondary\">\n <ng-container\n *ngTemplateOutlet=\"\n iconTemplate ?? defaultIconTemplate;\n context: { $implicit: button, isActive: button.isActive }\n \"></ng-container>\n @if (button.isActive && button.label) {\n <span class=\"menu-button-label\">{{ button.label }}</span>\n }\n </a>\n }\n</aside>\n\n<div [class.expanded]=\"expanded()\" class=\"shell-menu | is-absolute w-100 h-100\">\n <ng-template [ngTemplateOutlet]=\"menuRef()\"></ng-template>\n</div>\n\n<ng-template #defaultIconTemplate let-button>\n <fa-icon [icon]=\"button.icon\"></fa-icon>\n</ng-template>\n", styles: [":host{position:relative;display:grid;grid-template-rows:1fr auto;width:100%;height:100%;overflow:hidden;--menu-height: 2.875em}.shell-footer{background:#193957;z-index:10}.shell-menu{bottom:0;left:0;background:#fefaef;transform:translateY(100%);transition:transform .1s ease-out;padding-bottom:var(--menu-height)}.shell-menu.expanded{transform:translateY(0)}.menu-button-label{font-size:.5rem;line-height:normal;letter-spacing:-.01rem}.shell-content{overflow:auto}.menu-button{box-shadow:none;display:flex;flex-direction:column;align-items:center;height:3.5em;width:2em}.menu-button:hover{background-color:initial}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }] }); }
|
|
70
70
|
}
|
|
71
71
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: MobileShellComponent, decorators: [{
|
|
72
72
|
type: Component,
|
|
73
|
-
args: [{ selector: 'he-mobile-shell', template: "<div class=\"shell-content\">\n <div [class.menu-expanded]=\"expanded()\" class=\"shell__content--body | h-100\">\n <ng-content></ng-content>\n </div>\n</div>\n\n<aside class=\"shell-footer | is-flex is-justify-content-space-between\">\n <a (click)=\"onMenuButtonClick(button)\"
|
|
73
|
+
args: [{ selector: 'he-mobile-shell', template: "<div class=\"shell-content\">\n <div [class.menu-expanded]=\"expanded()\" class=\"shell__content--body | h-100\">\n <ng-content></ng-content>\n </div>\n</div>\n\n<aside class=\"shell-footer | is-flex is-justify-content-space-between\">\n @for (button of buttons(); track button) {\n <a (click)=\"onMenuButtonClick(button)\" class=\"button menu-button is-secondary\">\n <ng-container\n *ngTemplateOutlet=\"\n iconTemplate ?? defaultIconTemplate;\n context: { $implicit: button, isActive: button.isActive }\n \"></ng-container>\n @if (button.isActive && button.label) {\n <span class=\"menu-button-label\">{{ button.label }}</span>\n }\n </a>\n }\n</aside>\n\n<div [class.expanded]=\"expanded()\" class=\"shell-menu | is-absolute w-100 h-100\">\n <ng-template [ngTemplateOutlet]=\"menuRef()\"></ng-template>\n</div>\n\n<ng-template #defaultIconTemplate let-button>\n <fa-icon [icon]=\"button.icon\"></fa-icon>\n</ng-template>\n", styles: [":host{position:relative;display:grid;grid-template-rows:1fr auto;width:100%;height:100%;overflow:hidden;--menu-height: 2.875em}.shell-footer{background:#193957;z-index:10}.shell-menu{bottom:0;left:0;background:#fefaef;transform:translateY(100%);transition:transform .1s ease-out;padding-bottom:var(--menu-height)}.shell-menu.expanded{transform:translateY(0)}.menu-button-label{font-size:.5rem;line-height:normal;letter-spacing:-.01rem}.shell-content{overflow:auto}.menu-button{box-shadow:none;display:flex;flex-direction:column;align-items:center;height:3.5em;width:2em}.menu-button:hover{background-color:initial}\n"] }]
|
|
74
74
|
}], propDecorators: { iconTemplate: [{
|
|
75
75
|
type: ContentChild,
|
|
76
76
|
args: ['iconTemplate']
|
|
@@ -81,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
81
81
|
}], menuShown: [{
|
|
82
82
|
type: Output
|
|
83
83
|
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mobile-shell.component.js","sourceRoot":"","sources":["../../../../src/common/mobile-shell/mobile-shell.component.ts","../../../../src/common/mobile-shell/mobile-shell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  computed,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  signal,\n  TemplateRef,\n  WritableSignal\n} from '@angular/core';\nimport { IShellMenuButton } from '../shell/shell.component';\n\nexport interface IMobileShellMenuButton {\n  id?: string;\n  icon?: any;\n  label?: string;\n  onClick: () => void;\n  menuRef?: TemplateRef<any>;\n  iconPath?: string;\n}\n\n@Component({\n  selector: 'he-mobile-shell',\n  templateUrl: './mobile-shell.component.html',\n  styleUrls: ['./mobile-shell.component.scss']\n})\nexport class MobileShellComponent {\n  private _shelfButtons: WritableSignal<IMobileShellMenuButton[]> = signal([]);\n  private _defaultActiveButtonId: WritableSignal<string | null> = signal(null);\n\n  protected clickedButton: WritableSignal<string | null> = signal(null);\n  protected expanded = signal(false);\n  protected menuRef = signal(null as TemplateRef<any> | null);\n\n  @ContentChild('iconTemplate') iconTemplate: TemplateRef<any> | null = null;\n\n  @Input() set menuButtons(value: IMobileShellMenuButton[]) {\n    this._shelfButtons.set(value);\n  }\n\n  @Input() set defaultActiveButtonId(value: string | null) {\n    this._defaultActiveButtonId.set(value);\n  }\n\n  @Output() menuShown = new EventEmitter();\n\n  protected activeButton: IMobileShellMenuButton | null;\n\n  buttons = computed(() =>\n    this._shelfButtons()\n      .map((button, index) => ({\n        ...button,\n        id: button.id || index.toString()\n      }))\n      .map(button => {\n        const activeMenuId = this.activeMenuId();\n        return { ...button, isActive: button.id === (activeMenuId || this.activeButtonId()) };\n      })\n  );\n\n  activeButtonId = computed(() => {\n    return this.clickedButton() || this._defaultActiveButtonId();\n  });\n\n  activeMenuId = computed(() => {\n    if (this.expanded() && this.menuRef()) {\n      return this._shelfButtons()\n        .findIndex(button => button.menuRef === this.menuRef())\n        ?.toString();\n    }\n  });\n\n  hideMenu() {\n    this.expanded.set(false);\n    this.clickedButton.set(null);\n  }\n\n  showMenu(templateRef?: TemplateRef<any>) {\n    if (templateRef) {\n      this.menuRef.set(templateRef);\n    }\n    this.expanded.set(true);\n    this.menuShown.emit();\n  }\n\n  protected onMenuButtonClick(button: IShellMenuButton) {\n    if (button.id === this.clickedButton()) {\n      this.hideMenu();\n      return;\n    }\n\n    if (button.menuRef) {\n      this.menuRef.set(button.menuRef);\n      this.showMenu();\n    } else {\n      this.hideMenu();\n    }\n\n    if (!button.activeDisabled) {\n      this.clickedButton.set(button.id);\n    }\n\n    button.onClick?.();\n  }\n}\n","<div class=\"shell-content\">\n  <div [class.menu-expanded]=\"expanded()\" class=\"shell__content--body | h-100\">\n    <ng-content></ng-content>\n  </div>\n</div>\n\n<aside class=\"shell-footer | is-flex is-justify-content-space-between\">\n  @for (button of buttons(); track button) {\n    <a (click)=\"onMenuButtonClick(button)\" class=\"button menu-button is-secondary\">\n      <ng-container\n        *ngTemplateOutlet=\"\n          iconTemplate ?? defaultIconTemplate;\n          context: { $implicit: button, isActive: button.isActive }\n        \"></ng-container>\n      @if (button.isActive && button.label) {\n        <span class=\"menu-button-label\">{{ button.label }}</span>\n      }\n    </a>\n  }\n</aside>\n\n<div [class.expanded]=\"expanded()\" class=\"shell-menu | is-absolute w-100 h-100\">\n  <ng-template [ngTemplateOutlet]=\"menuRef()\"></ng-template>\n</div>\n\n<ng-template #defaultIconTemplate let-button>\n  <fa-icon [icon]=\"button.icon\"></fa-icon>\n</ng-template>\n"]}
|