geonetwork-ui 2.7.0-dev.dbe423d28 → 2.7.0-dev.f29e01b0d
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/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +18 -4
- package/esm2022/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +10 -2
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +31 -12
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +73 -26
- package/esm2022/libs/ui/dataviz/src/lib/data-table/data-table.component.mjs +4 -3
- package/esm2022/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.mjs +4 -4
- package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +21 -43
- package/esm2022/libs/util/app-config/src/lib/app-config.mjs +3 -1
- package/esm2022/libs/util/app-config/src/lib/model.mjs +1 -1
- package/esm2022/libs/util/shared/src/index.mjs +2 -2
- package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +9 -1
- package/esm2022/libs/util/shared/src/lib/record/index.mjs +3 -0
- package/esm2022/libs/util/shared/src/lib/record/quality-score.util.mjs +45 -0
- package/esm2022/libs/util/shared/src/lib/record/record.util.mjs +56 -0
- package/esm2022/translations/de.json +1 -1
- package/esm2022/translations/en.json +1 -1
- package/esm2022/translations/es.json +1 -1
- package/esm2022/translations/fr.json +1 -1
- package/esm2022/translations/it.json +1 -1
- package/esm2022/translations/nl.json +1 -1
- package/esm2022/translations/pt.json +1 -1
- package/esm2022/translations/sk.json +1 -1
- package/fesm2022/geonetwork-ui.mjs +213 -92
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +1 -0
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.d.ts +1 -0
- package/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/platform.service.interface.d.ts +1 -0
- package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts +3 -2
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/data-view/data-view.component.d.ts +8 -4
- package/libs/feature/record/src/lib/data-view/data-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +12 -5
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
- package/libs/ui/dataviz/src/lib/data-table/data-table.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts +7 -6
- package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts.map +1 -1
- package/libs/util/app-config/src/lib/app-config.d.ts.map +1 -1
- package/libs/util/app-config/src/lib/model.d.ts +1 -0
- package/libs/util/app-config/src/lib/model.d.ts.map +1 -1
- package/libs/util/shared/src/index.d.ts +1 -1
- package/libs/util/shared/src/index.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts +1 -0
- package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
- package/libs/util/shared/src/lib/record/index.d.ts +3 -0
- package/libs/util/shared/src/lib/record/index.d.ts.map +1 -0
- package/libs/util/shared/src/lib/record/quality-score.util.d.ts +13 -0
- package/libs/util/shared/src/lib/record/quality-score.util.d.ts.map +1 -0
- package/libs/util/shared/src/lib/record/record.util.d.ts +3 -0
- package/libs/util/shared/src/lib/record/record.util.d.ts.map +1 -0
- package/package.json +1 -1
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +25 -4
- package/src/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.ts +1 -0
- package/src/libs/common/domain/src/lib/platform.service.interface.ts +2 -0
- package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +10 -1
- package/src/libs/feature/record/src/lib/data-view/data-view.component.html +2 -0
- package/src/libs/feature/record/src/lib/data-view/data-view.component.ts +34 -15
- package/src/libs/feature/record/src/lib/map-view/map-view.component.html +2 -0
- package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +67 -22
- package/src/libs/ui/dataviz/src/lib/data-table/data-table.component.ts +6 -1
- package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.html +1 -0
- package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.ts +5 -1
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +1 -0
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.ts +21 -54
- package/src/libs/util/app-config/src/lib/app-config.ts +2 -0
- package/src/libs/util/app-config/src/lib/model.ts +1 -0
- package/src/libs/util/shared/src/index.ts +1 -1
- package/src/libs/util/shared/src/lib/links/link-utils.ts +9 -0
- package/src/libs/util/shared/src/lib/record/index.ts +2 -0
- package/src/libs/util/shared/src/lib/record/quality-score.util.ts +69 -0
- package/src/libs/util/shared/src/lib/{record.util.ts → record/record.util.ts} +1 -1
- package/translations/de.json +1 -1
- package/translations/en.json +1 -1
- package/translations/es.json +1 -1
- package/translations/fr.json +1 -1
- package/translations/it.json +1 -1
- package/translations/nl.json +1 -1
- package/translations/pt.json +1 -1
- package/translations/sk.json +1 -1
- package/esm2022/libs/util/shared/src/lib/record.util.mjs +0 -56
- package/libs/util/shared/src/lib/record.util.d.ts +0 -3
- package/libs/util/shared/src/lib/record.util.d.ts.map +0 -1
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { MapUtilsService } from '../../../../../../libs/feature/map/src';
|
|
3
|
-
import { getLinkLabel } from '../../../../../../libs/util/shared/src';
|
|
3
|
+
import { getLinkId, getLinkLabel } from '../../../../../../libs/util/shared/src';
|
|
4
4
|
import { BehaviorSubject, combineLatest, from, of, startWith, throwError, withLatestFrom, } from 'rxjs';
|
|
5
|
-
import { catchError, distinctUntilChanged, finalize, map, shareReplay, switchMap,
|
|
5
|
+
import { catchError, distinctUntilChanged, finalize, map, shareReplay, switchMap, tap, } from 'rxjs/operators';
|
|
6
6
|
import { MdViewFacade } from '../state/mdview.facade';
|
|
7
7
|
import { DataService } from '../../../../../../libs/feature/dataviz/src';
|
|
8
8
|
import { createViewFromLayer, } from '@geospatial-sdk/core';
|
|
@@ -31,17 +31,25 @@ export class MapViewComponent {
|
|
|
31
31
|
this.excludeWfs$.next(value);
|
|
32
32
|
}
|
|
33
33
|
set selectedView(value) {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
34
|
+
this.selectedView$.next(value);
|
|
35
|
+
}
|
|
36
|
+
set datavizConfig(value) {
|
|
37
|
+
if (value.view === 'map') {
|
|
38
|
+
this.selectedView$.next(value.view);
|
|
39
|
+
if (value.styleTMSIndex) {
|
|
40
|
+
this._styleFromConfig = value.styleTMSIndex;
|
|
41
|
+
}
|
|
42
|
+
if (value.source) {
|
|
43
|
+
this.linkFromConfig$.next(value.source);
|
|
44
|
+
}
|
|
38
45
|
}
|
|
39
46
|
}
|
|
40
|
-
selectLinkToDisplay(
|
|
41
|
-
this.
|
|
47
|
+
selectLinkToDisplay(id) {
|
|
48
|
+
this.selectedLinkId$.next(id);
|
|
42
49
|
}
|
|
43
50
|
selectStyleToDisplay(i) {
|
|
44
|
-
this.
|
|
51
|
+
this.selectedStyleId$.next(i);
|
|
52
|
+
this.styleSelected.emit(i);
|
|
45
53
|
}
|
|
46
54
|
toggleLegend() {
|
|
47
55
|
this.showLegend = !this.showLegend;
|
|
@@ -55,8 +63,13 @@ export class MapViewComponent {
|
|
|
55
63
|
this.dataService = dataService;
|
|
56
64
|
this.changeRef = changeRef;
|
|
57
65
|
this.translateService = translateService;
|
|
66
|
+
this.linkFromConfig$ = new BehaviorSubject(null);
|
|
67
|
+
this._selectedChoice = null;
|
|
68
|
+
this._styleFromConfig = null;
|
|
69
|
+
this.linkMap = new Map();
|
|
58
70
|
this.displaySource = true;
|
|
59
71
|
this.linkSelected = new EventEmitter();
|
|
72
|
+
this.styleSelected = new EventEmitter();
|
|
60
73
|
this.excludeWfs$ = new BehaviorSubject(false);
|
|
61
74
|
this.hidePreview = false;
|
|
62
75
|
this.showLegend = true;
|
|
@@ -70,22 +83,45 @@ export class MapViewComponent {
|
|
|
70
83
|
...mapApiLinks,
|
|
71
84
|
...geoDataLinksWithGeometry,
|
|
72
85
|
]), shareReplay(1));
|
|
73
|
-
this.dropdownChoices$ = this.compatibleMapLinks$.pipe(map((links) =>
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
86
|
+
this.dropdownChoices$ = this.compatibleMapLinks$.pipe(map((links) => {
|
|
87
|
+
this.linkMap.clear();
|
|
88
|
+
links.forEach((link) => this.linkMap.set(getLinkId(link), link));
|
|
89
|
+
return links.length
|
|
90
|
+
? links.map((link) => ({
|
|
91
|
+
label: getLinkLabel(link),
|
|
92
|
+
value: getLinkId(link),
|
|
93
|
+
}))
|
|
94
|
+
: [{ label: 'map.dropdown.placeholder', value: '' }];
|
|
95
|
+
}));
|
|
96
|
+
this.selectedView$ = new BehaviorSubject(null);
|
|
97
|
+
this.selectedLinkId$ = new BehaviorSubject(null);
|
|
98
|
+
this.selectedStyleId$ = new BehaviorSubject(null);
|
|
81
99
|
this.selectedSourceLink$ = combineLatest([
|
|
82
100
|
this.compatibleMapLinks$,
|
|
83
|
-
this.
|
|
101
|
+
this.linkFromConfig$,
|
|
102
|
+
this.selectedLinkId$.pipe(distinctUntilChanged()),
|
|
103
|
+
this.selectedView$,
|
|
84
104
|
]).pipe(tap(() => {
|
|
85
105
|
this.error = null;
|
|
86
|
-
}), map(([
|
|
87
|
-
|
|
88
|
-
|
|
106
|
+
}), map(([compatibleLinks, configLink, id, view]) => {
|
|
107
|
+
if (view === 'map') {
|
|
108
|
+
if (configLink &&
|
|
109
|
+
!id &&
|
|
110
|
+
compatibleLinks.some((link) => getLinkId(link) === getLinkId(configLink))) {
|
|
111
|
+
this._selectedChoice = getLinkId(configLink);
|
|
112
|
+
this.linkSelected.emit(configLink);
|
|
113
|
+
return configLink;
|
|
114
|
+
}
|
|
115
|
+
else if (id) {
|
|
116
|
+
this._selectedChoice = id;
|
|
117
|
+
this.linkSelected.emit(this.linkMap.get(id));
|
|
118
|
+
return this.linkMap.get(id);
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
this.linkSelected.emit(compatibleLinks[0]);
|
|
122
|
+
return compatibleLinks[0];
|
|
123
|
+
}
|
|
124
|
+
}
|
|
89
125
|
}));
|
|
90
126
|
this.styleLinks$ = this.selectedSourceLink$.pipe(switchMap((src) => {
|
|
91
127
|
if (src &&
|
|
@@ -104,7 +140,14 @@ export class MapViewComponent {
|
|
|
104
140
|
}));
|
|
105
141
|
}
|
|
106
142
|
return of([]);
|
|
107
|
-
}), tap(() =>
|
|
143
|
+
}), tap((styles) => {
|
|
144
|
+
if (this._styleFromConfig && this._styleFromConfig <= styles.length) {
|
|
145
|
+
this.selectedStyleId$.next(this._styleFromConfig);
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
this.selectedStyleId$.next(0);
|
|
149
|
+
}
|
|
150
|
+
}), shareReplay(1));
|
|
108
151
|
this.styleDropdownChoices$ = this.styleLinks$.pipe(map((links) => links.length
|
|
109
152
|
? links.map((link, index) => ({
|
|
110
153
|
label: getLinkLabel(link),
|
|
@@ -119,7 +162,7 @@ export class MapViewComponent {
|
|
|
119
162
|
this.selectedLink$ = combineLatest([
|
|
120
163
|
this.selectedSourceLink$,
|
|
121
164
|
this.styleLinks$,
|
|
122
|
-
this.
|
|
165
|
+
this.selectedStyleId$.pipe(distinctUntilChanged()),
|
|
123
166
|
]).pipe(map(([src, styles, styleIdx]) => (styles.length ? styles[styleIdx] : src)), shareReplay(1));
|
|
124
167
|
this.currentLayers$ = combineLatest([this.selectedLink$, this.excludeWfs$]).pipe(switchMap(([link, excludeWfs]) => {
|
|
125
168
|
if (!link) {
|
|
@@ -256,7 +299,7 @@ export class MapViewComponent {
|
|
|
256
299
|
this.changeRef.detectChanges();
|
|
257
300
|
}
|
|
258
301
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MapViewComponent, deps: [{ token: i1.MdViewFacade }, { token: i2.MapUtilsService }, { token: i3.DataService }, { token: i0.ChangeDetectorRef }, { token: i4.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
259
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MapViewComponent, isStandalone: true, selector: "gn-ui-map-view", inputs: { exceedsLimit: "exceedsLimit", selectedView: "selectedView", displaySource: "displaySource" }, outputs: { linkSelected: "linkSelected" }, viewQueries: [{ propertyName: "mapContainer", first: true, predicate: ["mapContainer"], descendants: true }], ngImport: i0, template: "<div class=\"w-full h-full flex flex-col gap-[13px]\">\n <div\n class=\"flex flex-col md:flex-row gap-4 py-4 px-5 bg-white border border-color-border rounded-lg mt-6\"\n >\n <gn-ui-dropdown-selector\n *ngIf=\"displaySource\"\n class=\"w-full md:flex-1 md:min-w-0\"\n extraBtnClass=\"font-sans font-bold\"\n [title]=\"'map.select.layer' | translate\"\n [choices]=\"dropdownChoices$ | async\"\n (selectValue)=\"selectLinkToDisplay($event)\"\n ></gn-ui-dropdown-selector>\n\n <ng-container *ngIf=\"(styleLinks$ | async)?.length > 0; else styleDisabled\">\n <gn-ui-dropdown-selector\n class=\"w-full md:flex-1 md:min-w-0\"\n extraBtnClass=\"font-sans font-bold\"\n [title]=\"'map.select.style' | translate\"\n [choices]=\"styleDropdownChoices$ | async\"\n (selectValue)=\"selectStyleToDisplay($event)\"\n ></gn-ui-dropdown-selector>\n </ng-container>\n <ng-template #styleDisabled>\n <gn-ui-dropdown-selector\n class=\"w-full md:flex-1 md:min-w-0 text-gray-400\"\n extraBtnClass=\"font-sans font-bold text-gray-400\"\n [title]=\"'map.select.style' | translate\"\n [choices]=\"styleDropdownChoices$ | async\"\n [disabled]=\"true\"\n ></gn-ui-dropdown-selector>\n </ng-template>\n\n <div class=\"self-end md:ml-2\">\n <gn-ui-external-viewer-button\n extraClass=\"w-[44px] h-[44px]\"\n [link]=\"selectedLink$ | async\"\n >\n </gn-ui-external-viewer-button>\n </div>\n </div>\n <ng-container *ngIf=\"hidePreview; else mapView\">\n <gn-ui-popup-alert\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"block h-12 p-1\"\n >\n <span translate>record.feature.limit</span>\n </gn-ui-popup-alert>\n </ng-container>\n <ng-template #mapView>\n <div\n class=\"relative w-full h-full bg-white border border-gray-300 rounded-lg overflow-hidden\"\n >\n <gn-ui-map-container\n #mapContainer\n [context]=\"mapContext$ | async\"\n (featuresClick)=\"onMapFeatureSelect($event)\"\n (sourceLoadError)=\"onSourceLoadError($event)\"\n ></gn-ui-map-container>\n <div\n class=\"top-[1em] right-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n [class.hidden]=\"!selection\"\n >\n <gn-ui-button\n type=\"light\"\n (buttonClick)=\"resetSelection()\"\n style=\"\n --gn-ui-button-padding: 0px;\n --gn-ui-button-width: 24px;\n --gn-ui-button-height: 24px;\n \"\n extraClass=\"absolute right-[0.5em] ml-[8px] mr-[10px]\"\n >\n <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n </gn-ui-button>\n <gn-ui-feature-detail\n [featureCatalog]=\"mdViewFacade.featureCatalog$ | async\"\n [feature]=\"selection\"\n ></gn-ui-feature-detail>\n </div>\n\n <div\n class=\"top-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n [ngClass]=\"{ 'right-[1em]': !selection, 'right-[16em]': selection }\"\n [hidden]=\"!showLegend || !legendExists\"\n >\n <div class=\"flex justify-between items-center mb-2\">\n <div class=\"text-primary font-bold\" translate>map.legend.title</div>\n <gn-ui-button\n type=\"light\"\n (buttonClick)=\"toggleLegend()\"\n style=\"\n --gn-ui-button-padding: 0px;\n --gn-ui-button-width: 24px;\n --gn-ui-button-height: 24px;\n \"\n extraClass=\"ml-[8px] mr-[10px]\"\n >\n <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n </gn-ui-button>\n </div>\n <gn-ui-map-legend\n [context]=\"mapContext$ | async\"\n (legendStatusChange)=\"onLegendStatusChange($event)\"\n ></gn-ui-map-legend>\n </div>\n\n <gn-ui-button\n *ngIf=\"!showLegend && legendExists && !selection\"\n type=\"outline\"\n (buttonClick)=\"toggleLegend()\"\n extraClass=\"absolute top-[1em] right-[1em] rounded p-1 text-xs bg-white\"\n translate\n >\n map.legend.title\n </gn-ui-button>\n\n <gn-ui-loading-mask\n *ngIf=\"loading\"\n class=\"absolute inset-0\"\n [message]=\"'map.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n </ng-template>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "component", type: DropdownSelectorComponent, selector: "gn-ui-dropdown-selector", inputs: ["title", "showTitle", "ariaName", "choices", "selected", "maxRows", "extraBtnClass", "minWidth", "disabled"], outputs: ["selectValue"] }, { kind: "component", type: MapContainerComponent, selector: "gn-ui-map-container", inputs: ["context"], outputs: ["featuresClick", "featuresHover", "mapClick", "sourceLoadError"] }, { kind: "component", type: FeatureDetailComponent, selector: "gn-ui-feature-detail", inputs: ["feature", "featureCatalog"] }, { kind: "component", type: PopupAlertComponent, selector: "gn-ui-popup-alert", inputs: ["icon", "type", "position"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: LoadingMaskComponent, selector: "gn-ui-loading-mask", inputs: ["message"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "component", type: ExternalViewerButtonComponent, selector: "gn-ui-external-viewer-button", inputs: ["link", "extraClass"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: MapLegendComponent, selector: "gn-ui-map-legend", inputs: ["context"], outputs: ["legendStatusChange"] }], viewProviders: [provideIcons({ matClose })], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
302
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MapViewComponent, isStandalone: true, selector: "gn-ui-map-view", inputs: { exceedsLimit: "exceedsLimit", selectedView: "selectedView", datavizConfig: "datavizConfig", displaySource: "displaySource" }, outputs: { linkSelected: "linkSelected", styleSelected: "styleSelected" }, viewQueries: [{ propertyName: "mapContainer", first: true, predicate: ["mapContainer"], descendants: true }], ngImport: i0, template: "<div class=\"w-full h-full flex flex-col gap-[13px]\">\n <div\n class=\"flex flex-col md:flex-row gap-4 py-4 px-5 bg-white border border-color-border rounded-lg mt-6\"\n >\n <gn-ui-dropdown-selector\n *ngIf=\"displaySource\"\n class=\"w-full md:flex-1 md:min-w-0\"\n extraBtnClass=\"font-sans font-bold\"\n [title]=\"'map.select.layer' | translate\"\n [choices]=\"dropdownChoices$ | async\"\n [selected]=\"_selectedChoice\"\n (selectValue)=\"selectLinkToDisplay($event)\"\n ></gn-ui-dropdown-selector>\n\n <ng-container *ngIf=\"(styleLinks$ | async)?.length > 0; else styleDisabled\">\n <gn-ui-dropdown-selector\n class=\"w-full md:flex-1 md:min-w-0\"\n extraBtnClass=\"font-sans font-bold\"\n [title]=\"'map.select.style' | translate\"\n [choices]=\"styleDropdownChoices$ | async\"\n [selected]=\"_styleFromConfig\"\n (selectValue)=\"selectStyleToDisplay($event)\"\n ></gn-ui-dropdown-selector>\n </ng-container>\n <ng-template #styleDisabled>\n <gn-ui-dropdown-selector\n class=\"w-full md:flex-1 md:min-w-0 text-gray-400\"\n extraBtnClass=\"font-sans font-bold text-gray-400\"\n [title]=\"'map.select.style' | translate\"\n [choices]=\"styleDropdownChoices$ | async\"\n [disabled]=\"true\"\n ></gn-ui-dropdown-selector>\n </ng-template>\n\n <div class=\"self-end md:ml-2\">\n <gn-ui-external-viewer-button\n extraClass=\"w-[44px] h-[44px]\"\n [link]=\"selectedLink$ | async\"\n >\n </gn-ui-external-viewer-button>\n </div>\n </div>\n <ng-container *ngIf=\"hidePreview; else mapView\">\n <gn-ui-popup-alert\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"block h-12 p-1\"\n >\n <span translate>record.feature.limit</span>\n </gn-ui-popup-alert>\n </ng-container>\n <ng-template #mapView>\n <div\n class=\"relative w-full h-full bg-white border border-gray-300 rounded-lg overflow-hidden\"\n >\n <gn-ui-map-container\n #mapContainer\n [context]=\"mapContext$ | async\"\n (featuresClick)=\"onMapFeatureSelect($event)\"\n (sourceLoadError)=\"onSourceLoadError($event)\"\n ></gn-ui-map-container>\n <div\n class=\"top-[1em] right-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n [class.hidden]=\"!selection\"\n >\n <gn-ui-button\n type=\"light\"\n (buttonClick)=\"resetSelection()\"\n style=\"\n --gn-ui-button-padding: 0px;\n --gn-ui-button-width: 24px;\n --gn-ui-button-height: 24px;\n \"\n extraClass=\"absolute right-[0.5em] ml-[8px] mr-[10px]\"\n >\n <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n </gn-ui-button>\n <gn-ui-feature-detail\n [featureCatalog]=\"mdViewFacade.featureCatalog$ | async\"\n [feature]=\"selection\"\n ></gn-ui-feature-detail>\n </div>\n\n <div\n class=\"top-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n [ngClass]=\"{ 'right-[1em]': !selection, 'right-[16em]': selection }\"\n [hidden]=\"!showLegend || !legendExists\"\n >\n <div class=\"flex justify-between items-center mb-2\">\n <div class=\"text-primary font-bold\" translate>map.legend.title</div>\n <gn-ui-button\n type=\"light\"\n (buttonClick)=\"toggleLegend()\"\n style=\"\n --gn-ui-button-padding: 0px;\n --gn-ui-button-width: 24px;\n --gn-ui-button-height: 24px;\n \"\n extraClass=\"ml-[8px] mr-[10px]\"\n >\n <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n </gn-ui-button>\n </div>\n <gn-ui-map-legend\n [context]=\"mapContext$ | async\"\n (legendStatusChange)=\"onLegendStatusChange($event)\"\n ></gn-ui-map-legend>\n </div>\n\n <gn-ui-button\n *ngIf=\"!showLegend && legendExists && !selection\"\n type=\"outline\"\n (buttonClick)=\"toggleLegend()\"\n extraClass=\"absolute top-[1em] right-[1em] rounded p-1 text-xs bg-white\"\n translate\n >\n map.legend.title\n </gn-ui-button>\n\n <gn-ui-loading-mask\n *ngIf=\"loading\"\n class=\"absolute inset-0\"\n [message]=\"'map.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n </ng-template>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "component", type: DropdownSelectorComponent, selector: "gn-ui-dropdown-selector", inputs: ["title", "showTitle", "ariaName", "choices", "selected", "maxRows", "extraBtnClass", "minWidth", "disabled"], outputs: ["selectValue"] }, { kind: "component", type: MapContainerComponent, selector: "gn-ui-map-container", inputs: ["context"], outputs: ["featuresClick", "featuresHover", "mapClick", "sourceLoadError"] }, { kind: "component", type: FeatureDetailComponent, selector: "gn-ui-feature-detail", inputs: ["feature", "featureCatalog"] }, { kind: "component", type: PopupAlertComponent, selector: "gn-ui-popup-alert", inputs: ["icon", "type", "position"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: LoadingMaskComponent, selector: "gn-ui-loading-mask", inputs: ["message"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "component", type: ExternalViewerButtonComponent, selector: "gn-ui-external-viewer-button", inputs: ["link", "extraClass"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: MapLegendComponent, selector: "gn-ui-map-legend", inputs: ["context"], outputs: ["legendStatusChange"] }], viewProviders: [provideIcons({ matClose })], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
260
303
|
}
|
|
261
304
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MapViewComponent, decorators: [{
|
|
262
305
|
type: Component,
|
|
@@ -273,17 +316,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
273
316
|
ExternalViewerButtonComponent,
|
|
274
317
|
ButtonComponent,
|
|
275
318
|
MapLegendComponent,
|
|
276
|
-
], viewProviders: [provideIcons({ matClose })], template: "<div class=\"w-full h-full flex flex-col gap-[13px]\">\n <div\n class=\"flex flex-col md:flex-row gap-4 py-4 px-5 bg-white border border-color-border rounded-lg mt-6\"\n >\n <gn-ui-dropdown-selector\n *ngIf=\"displaySource\"\n class=\"w-full md:flex-1 md:min-w-0\"\n extraBtnClass=\"font-sans font-bold\"\n [title]=\"'map.select.layer' | translate\"\n [choices]=\"dropdownChoices$ | async\"\n (selectValue)=\"selectLinkToDisplay($event)\"\n ></gn-ui-dropdown-selector>\n\n <ng-container *ngIf=\"(styleLinks$ | async)?.length > 0; else styleDisabled\">\n <gn-ui-dropdown-selector\n class=\"w-full md:flex-1 md:min-w-0\"\n extraBtnClass=\"font-sans font-bold\"\n [title]=\"'map.select.style' | translate\"\n [choices]=\"styleDropdownChoices$ | async\"\n (selectValue)=\"selectStyleToDisplay($event)\"\n ></gn-ui-dropdown-selector>\n </ng-container>\n <ng-template #styleDisabled>\n <gn-ui-dropdown-selector\n class=\"w-full md:flex-1 md:min-w-0 text-gray-400\"\n extraBtnClass=\"font-sans font-bold text-gray-400\"\n [title]=\"'map.select.style' | translate\"\n [choices]=\"styleDropdownChoices$ | async\"\n [disabled]=\"true\"\n ></gn-ui-dropdown-selector>\n </ng-template>\n\n <div class=\"self-end md:ml-2\">\n <gn-ui-external-viewer-button\n extraClass=\"w-[44px] h-[44px]\"\n [link]=\"selectedLink$ | async\"\n >\n </gn-ui-external-viewer-button>\n </div>\n </div>\n <ng-container *ngIf=\"hidePreview; else mapView\">\n <gn-ui-popup-alert\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"block h-12 p-1\"\n >\n <span translate>record.feature.limit</span>\n </gn-ui-popup-alert>\n </ng-container>\n <ng-template #mapView>\n <div\n class=\"relative w-full h-full bg-white border border-gray-300 rounded-lg overflow-hidden\"\n >\n <gn-ui-map-container\n #mapContainer\n [context]=\"mapContext$ | async\"\n (featuresClick)=\"onMapFeatureSelect($event)\"\n (sourceLoadError)=\"onSourceLoadError($event)\"\n ></gn-ui-map-container>\n <div\n class=\"top-[1em] right-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n [class.hidden]=\"!selection\"\n >\n <gn-ui-button\n type=\"light\"\n (buttonClick)=\"resetSelection()\"\n style=\"\n --gn-ui-button-padding: 0px;\n --gn-ui-button-width: 24px;\n --gn-ui-button-height: 24px;\n \"\n extraClass=\"absolute right-[0.5em] ml-[8px] mr-[10px]\"\n >\n <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n </gn-ui-button>\n <gn-ui-feature-detail\n [featureCatalog]=\"mdViewFacade.featureCatalog$ | async\"\n [feature]=\"selection\"\n ></gn-ui-feature-detail>\n </div>\n\n <div\n class=\"top-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n [ngClass]=\"{ 'right-[1em]': !selection, 'right-[16em]': selection }\"\n [hidden]=\"!showLegend || !legendExists\"\n >\n <div class=\"flex justify-between items-center mb-2\">\n <div class=\"text-primary font-bold\" translate>map.legend.title</div>\n <gn-ui-button\n type=\"light\"\n (buttonClick)=\"toggleLegend()\"\n style=\"\n --gn-ui-button-padding: 0px;\n --gn-ui-button-width: 24px;\n --gn-ui-button-height: 24px;\n \"\n extraClass=\"ml-[8px] mr-[10px]\"\n >\n <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n </gn-ui-button>\n </div>\n <gn-ui-map-legend\n [context]=\"mapContext$ | async\"\n (legendStatusChange)=\"onLegendStatusChange($event)\"\n ></gn-ui-map-legend>\n </div>\n\n <gn-ui-button\n *ngIf=\"!showLegend && legendExists && !selection\"\n type=\"outline\"\n (buttonClick)=\"toggleLegend()\"\n extraClass=\"absolute top-[1em] right-[1em] rounded p-1 text-xs bg-white\"\n translate\n >\n map.legend.title\n </gn-ui-button>\n\n <gn-ui-loading-mask\n *ngIf=\"loading\"\n class=\"absolute inset-0\"\n [message]=\"'map.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n </ng-template>\n</div>\n" }]
|
|
319
|
+
], viewProviders: [provideIcons({ matClose })], template: "<div class=\"w-full h-full flex flex-col gap-[13px]\">\n <div\n class=\"flex flex-col md:flex-row gap-4 py-4 px-5 bg-white border border-color-border rounded-lg mt-6\"\n >\n <gn-ui-dropdown-selector\n *ngIf=\"displaySource\"\n class=\"w-full md:flex-1 md:min-w-0\"\n extraBtnClass=\"font-sans font-bold\"\n [title]=\"'map.select.layer' | translate\"\n [choices]=\"dropdownChoices$ | async\"\n [selected]=\"_selectedChoice\"\n (selectValue)=\"selectLinkToDisplay($event)\"\n ></gn-ui-dropdown-selector>\n\n <ng-container *ngIf=\"(styleLinks$ | async)?.length > 0; else styleDisabled\">\n <gn-ui-dropdown-selector\n class=\"w-full md:flex-1 md:min-w-0\"\n extraBtnClass=\"font-sans font-bold\"\n [title]=\"'map.select.style' | translate\"\n [choices]=\"styleDropdownChoices$ | async\"\n [selected]=\"_styleFromConfig\"\n (selectValue)=\"selectStyleToDisplay($event)\"\n ></gn-ui-dropdown-selector>\n </ng-container>\n <ng-template #styleDisabled>\n <gn-ui-dropdown-selector\n class=\"w-full md:flex-1 md:min-w-0 text-gray-400\"\n extraBtnClass=\"font-sans font-bold text-gray-400\"\n [title]=\"'map.select.style' | translate\"\n [choices]=\"styleDropdownChoices$ | async\"\n [disabled]=\"true\"\n ></gn-ui-dropdown-selector>\n </ng-template>\n\n <div class=\"self-end md:ml-2\">\n <gn-ui-external-viewer-button\n extraClass=\"w-[44px] h-[44px]\"\n [link]=\"selectedLink$ | async\"\n >\n </gn-ui-external-viewer-button>\n </div>\n </div>\n <ng-container *ngIf=\"hidePreview; else mapView\">\n <gn-ui-popup-alert\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"block h-12 p-1\"\n >\n <span translate>record.feature.limit</span>\n </gn-ui-popup-alert>\n </ng-container>\n <ng-template #mapView>\n <div\n class=\"relative w-full h-full bg-white border border-gray-300 rounded-lg overflow-hidden\"\n >\n <gn-ui-map-container\n #mapContainer\n [context]=\"mapContext$ | async\"\n (featuresClick)=\"onMapFeatureSelect($event)\"\n (sourceLoadError)=\"onSourceLoadError($event)\"\n ></gn-ui-map-container>\n <div\n class=\"top-[1em] right-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n [class.hidden]=\"!selection\"\n >\n <gn-ui-button\n type=\"light\"\n (buttonClick)=\"resetSelection()\"\n style=\"\n --gn-ui-button-padding: 0px;\n --gn-ui-button-width: 24px;\n --gn-ui-button-height: 24px;\n \"\n extraClass=\"absolute right-[0.5em] ml-[8px] mr-[10px]\"\n >\n <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n </gn-ui-button>\n <gn-ui-feature-detail\n [featureCatalog]=\"mdViewFacade.featureCatalog$ | async\"\n [feature]=\"selection\"\n ></gn-ui-feature-detail>\n </div>\n\n <div\n class=\"top-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n [ngClass]=\"{ 'right-[1em]': !selection, 'right-[16em]': selection }\"\n [hidden]=\"!showLegend || !legendExists\"\n >\n <div class=\"flex justify-between items-center mb-2\">\n <div class=\"text-primary font-bold\" translate>map.legend.title</div>\n <gn-ui-button\n type=\"light\"\n (buttonClick)=\"toggleLegend()\"\n style=\"\n --gn-ui-button-padding: 0px;\n --gn-ui-button-width: 24px;\n --gn-ui-button-height: 24px;\n \"\n extraClass=\"ml-[8px] mr-[10px]\"\n >\n <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n </gn-ui-button>\n </div>\n <gn-ui-map-legend\n [context]=\"mapContext$ | async\"\n (legendStatusChange)=\"onLegendStatusChange($event)\"\n ></gn-ui-map-legend>\n </div>\n\n <gn-ui-button\n *ngIf=\"!showLegend && legendExists && !selection\"\n type=\"outline\"\n (buttonClick)=\"toggleLegend()\"\n extraClass=\"absolute top-[1em] right-[1em] rounded p-1 text-xs bg-white\"\n translate\n >\n map.legend.title\n </gn-ui-button>\n\n <gn-ui-loading-mask\n *ngIf=\"loading\"\n class=\"absolute inset-0\"\n [message]=\"'map.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n </ng-template>\n</div>\n" }]
|
|
277
320
|
}], ctorParameters: () => [{ type: i1.MdViewFacade }, { type: i2.MapUtilsService }, { type: i3.DataService }, { type: i0.ChangeDetectorRef }, { type: i4.TranslateService }], propDecorators: { exceedsLimit: [{
|
|
278
321
|
type: Input
|
|
279
322
|
}], selectedView: [{
|
|
280
323
|
type: Input
|
|
324
|
+
}], datavizConfig: [{
|
|
325
|
+
type: Input
|
|
281
326
|
}], displaySource: [{
|
|
282
327
|
type: Input
|
|
283
328
|
}], linkSelected: [{
|
|
284
329
|
type: Output
|
|
330
|
+
}], styleSelected: [{
|
|
331
|
+
type: Output
|
|
285
332
|
}], mapContainer: [{
|
|
286
333
|
type: ViewChild,
|
|
287
334
|
args: ['mapContainer']
|
|
288
335
|
}] } });
|
|
289
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-view.component.js","sourceRoot":"","sources":["../../../../../../../../libs/feature/record/src/lib/map-view/map-view.component.ts","../../../../../../../../libs/feature/record/src/lib/map-view/map-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MapUtilsService } from '../../../../../../libs/feature/map/src'\nimport { getLinkLabel } from '../../../../../../libs/util/shared/src'\nimport {\n  BehaviorSubject,\n  combineLatest,\n  from,\n  Observable,\n  of,\n  startWith,\n  throwError,\n  withLatestFrom,\n} from 'rxjs'\nimport {\n  catchError,\n  distinctUntilChanged,\n  finalize,\n  map,\n  shareReplay,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs/operators'\nimport { MdViewFacade } from '../state/mdview.facade'\nimport { DataService } from '../../../../../../libs/feature/dataviz/src'\nimport {\n  DatasetOnlineResource,\n  DatasetServiceDistribution,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  createViewFromLayer,\n  MapContext,\n  MapContextLayer,\n  SourceLoadErrorEvent,\n} from '@geospatial-sdk/core'\nimport {\n  FeatureDetailComponent,\n  MapContainerComponent,\n  MapLegendComponent,\n  prioritizePageScroll,\n} from '../../../../../../libs/ui/map/src'\nimport { Feature } from 'geojson'\nimport { NgIconComponent, provideIcons } from '@ng-icons/core'\nimport { matClose } from '@ng-icons/material-icons/baseline'\nimport { CommonModule } from '@angular/common'\nimport {\n  ButtonComponent,\n  DropdownSelectorComponent,\n} from '../../../../../../libs/ui/inputs/src'\nimport {\n  TranslateDirective,\n  TranslatePipe,\n  TranslateService,\n} from '@ngx-translate/core'\nimport { ExternalViewerButtonComponent } from '../external-viewer-button/external-viewer-button.component'\nimport {\n  LoadingMaskComponent,\n  PopupAlertComponent,\n} from '../../../../../../libs/ui/widgets/src'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { FetchError } from '../../../../../../libs/util/data-fetcher/src'\n\nmarker('map.dropdown.placeholder')\nmarker('wfs.feature.limit')\nmarker('dataset.error.restrictedAccess')\nmarker('map.select.style')\n\n@Component({\n  selector: 'gn-ui-map-view',\n  templateUrl: './map-view.component.html',\n  styleUrls: ['./map-view.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    DropdownSelectorComponent,\n    MapContainerComponent,\n    FeatureDetailComponent,\n    PopupAlertComponent,\n    TranslateDirective,\n    TranslatePipe,\n    LoadingMaskComponent,\n    NgIconComponent,\n    ExternalViewerButtonComponent,\n    ButtonComponent,\n    MapLegendComponent,\n  ],\n  viewProviders: [provideIcons({ matClose })],\n})\nexport class MapViewComponent implements AfterViewInit {\n  @Input() set exceedsLimit(value: boolean) {\n    this.excludeWfs$.next(value)\n  }\n  @Input() set selectedView(value: string) {\n    if (value === 'map') {\n      this.selectedLink$.pipe(take(1)).subscribe((link) => {\n        this.linkSelected.emit(link)\n      })\n    }\n  }\n  @Input() displaySource = true\n  @Output() linkSelected = new EventEmitter<DatasetOnlineResource>()\n  @ViewChild('mapContainer') mapContainer: MapContainerComponent\n\n  excludeWfs$ = new BehaviorSubject(false)\n  hidePreview = false\n  selection: Feature\n  showLegend = true\n  legendExists = false\n  loading = false\n  error = null\n\n  selectLinkToDisplay(i: number) {\n    this.selectedLinkIndex$.next(i)\n  }\n\n  selectStyleToDisplay(i: number) {\n    this.selectedStyleIndex$.next(i)\n  }\n\n  toggleLegend() {\n    this.showLegend = !this.showLegend\n  }\n  onLegendStatusChange(v: boolean) {\n    this.legendExists = v\n  }\n\n  compatibleMapLinks$ = combineLatest([\n    this.mdViewFacade.mapApiLinks$,\n    this.mdViewFacade.geoDataLinksWithGeometry$,\n  ]).pipe(\n    map(([mapApiLinks, geoDataLinksWithGeometry]) => [\n      ...mapApiLinks,\n      ...geoDataLinksWithGeometry,\n    ]),\n    shareReplay(1)\n  )\n\n  dropdownChoices$ = this.compatibleMapLinks$.pipe(\n    map((links) =>\n      links.length\n        ? links.map((link, index) => ({\n            label: getLinkLabel(link),\n            value: index,\n          }))\n        : [{ label: 'map.dropdown.placeholder', value: 0 }]\n    )\n  )\n\n  selectedLinkIndex$ = new BehaviorSubject(0)\n  private selectedStyleIndex$ = new BehaviorSubject(0)\n\n  selectedSourceLink$ = combineLatest([\n    this.compatibleMapLinks$,\n    this.selectedLinkIndex$.pipe(distinctUntilChanged()),\n  ]).pipe(\n    tap(() => {\n      this.error = null\n    }),\n    map(([links, index]) => {\n      this.linkSelected.emit(links[index])\n      return links[index]\n    })\n  )\n\n  styleLinks$ = this.selectedSourceLink$.pipe(\n    switchMap((src) => {\n      if (\n        src &&\n        src.type === 'service' &&\n        src.accessServiceProtocol === 'tms'\n      ) {\n        return from(\n          // WARNING: when using \"getGeodataLinksFromTms\", make sure to add error handling to prevent the rest of the logic from failing\n          // this may happen when TMS endpoint is in error\n          this.dataService.getGeodataLinksFromTms(\n            src as DatasetServiceDistribution,\n            false\n          )\n        ).pipe(\n          // We need to check for maplibre-style links because when a TMS service has no styles,\n          // getGeodataLinksFromTms returns the original TMS link, which isn't a maplibre-style link\n          map(\n            (links) =>\n              links?.filter(\n                (link) =>\n                  link.type === 'service' &&\n                  link.accessServiceProtocol === 'maplibre-style'\n              ) || []\n          ),\n          catchError((error) => {\n            this.handleError(error)\n            return of(src)\n          })\n        )\n      }\n      return of([])\n    }),\n    tap(() => this.selectedStyleIndex$.next(0)),\n    shareReplay(1)\n  )\n\n  styleDropdownChoices$ = this.styleLinks$.pipe(\n    map((links) =>\n      links.length\n        ? links.map((link, index) => ({\n            label: getLinkLabel(link),\n            value: index,\n          }))\n        : [\n            {\n              label: '\\u00A0\\u00A0\\u00A0\\u00A0',\n              value: 0,\n            },\n          ]\n    )\n  )\n\n  selectedLink$ = combineLatest([\n    this.selectedSourceLink$,\n    this.styleLinks$,\n    this.selectedStyleIndex$.pipe(distinctUntilChanged()),\n  ]).pipe(\n    map(([src, styles, styleIdx]) => (styles.length ? styles[styleIdx] : src)),\n    shareReplay(1)\n  )\n\n  currentLayers$ = combineLatest([this.selectedLink$, this.excludeWfs$]).pipe(\n    switchMap(([link, excludeWfs]) => {\n      if (!link) {\n        return of([])\n      }\n      if (excludeWfs && link.accessServiceProtocol === 'wfs') {\n        this.hidePreview = true\n        return of([])\n      }\n      this.hidePreview = false\n      this.loading = true\n      if (link.accessRestricted) {\n        this.handleError('dataset.error.restrictedAccess')\n        return of([])\n      }\n      return this.getLayerFromLink(link).pipe(\n        map((layer) => [layer]),\n        catchError((e) => {\n          this.handleError(e)\n          return of([])\n        }),\n        finalize(() => (this.loading = false))\n      )\n    })\n  )\n\n  mapContext$: Observable<MapContext> = this.currentLayers$.pipe(\n    switchMap((layers) =>\n      from(createViewFromLayer(layers[0])).pipe(\n        catchError(() => of(null)), // could not zoom on the layer: use the record extent\n        map((view) => ({\n          layers,\n          view,\n        })),\n        tap(() => {\n          this.resetSelection()\n        })\n      )\n    ),\n    startWith({\n      layers: [],\n      view: null,\n    }),\n    withLatestFrom(this.mdViewFacade.metadata$),\n    map(([context, metadata]) => {\n      if (context.view) return context\n      const extent = this.mapUtils.getRecordExtent(metadata)\n      const view = extent ? { extent } : null\n      return {\n        ...context,\n        view,\n      }\n    }),\n    shareReplay(1)\n  )\n\n  constructor(\n    private mdViewFacade: MdViewFacade,\n    private mapUtils: MapUtilsService,\n    private dataService: DataService,\n    private changeRef: ChangeDetectorRef,\n    private translateService: TranslateService\n  ) {}\n\n  async ngAfterViewInit() {\n    const map = await this.mapContainer.openlayersMap\n    prioritizePageScroll(map.getInteractions())\n  }\n\n  onMapFeatureSelect(features: Feature[]): void {\n    this.resetSelection()\n    this.selection = features?.length > 0 && features[0]\n    if (this.selection) {\n      // FIXME: restore styling of selected feature\n      // this.selection.setStyle(this.selectionStyle)\n    }\n    this.changeRef.detectChanges()\n  }\n\n  onSourceLoadError(error: SourceLoadErrorEvent) {\n    if (error.httpStatus === 403 || error.httpStatus === 401) {\n      this.error = this.translateService.instant(`dataset.error.forbidden`)\n    } else {\n      this.error = this.translateService.instant(`dataset.error.http`, {\n        info: error.httpStatus,\n      })\n    }\n  }\n\n  resetSelection(): void {\n    if (this.selection) {\n      // FIXME: restore styling of selected feature\n      // this.selection.setStyle(null)\n    }\n    this.selection = null\n  }\n\n  getLayerFromLink(link: DatasetOnlineResource): Observable<MapContextLayer> {\n    if (link.type === 'service' && link.accessServiceProtocol === 'wms') {\n      return of({\n        url: link.url.toString(),\n        type: 'wms',\n        name: link.name,\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'tms'\n    ) {\n      // FIXME: here we're assuming that the TMS serves vector tiles only; should be checked with ogc-client first\n      return of({\n        url: link.url.toString().replace(/\\/?$/, '/{z}/{x}/{y}.pbf'),\n        type: 'xyz',\n        tileFormat: 'application/vnd.mapbox-vector-tile',\n        name: link.name,\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'maplibre-style'\n    ) {\n      return of({\n        type: 'maplibre-style',\n        name: link.name,\n        styleUrl: link.url.toString(),\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'wmts'\n    ) {\n      return of({\n        url: link.url.toString(),\n        type: 'wmts',\n        name: link.name,\n      })\n    } else if (\n      (link.type === 'service' &&\n        (link.accessServiceProtocol === 'wfs' ||\n          link.accessServiceProtocol === 'esriRest' ||\n          link.accessServiceProtocol === 'ogcFeatures')) ||\n      link.type === 'download'\n    ) {\n      const cacheActive = true // TODO implement whether should be true or false\n      return this.dataService.readAsGeoJson(link, cacheActive).pipe(\n        map((data) => ({\n          type: 'geojson',\n          data,\n        }))\n      )\n    }\n    return throwError(() => 'protocol not supported')\n  }\n  handleError(error: FetchError | Error | string) {\n    if (error instanceof FetchError) {\n      this.error = this.translateService.instant(\n        `dataset.error.${error.type}`,\n        {\n          info: error.info,\n        }\n      )\n      console.warn(error.message)\n    } else if (error instanceof Error) {\n      this.error = this.translateService.instant(error.message)\n      console.warn(error.stack || error)\n    } else {\n      this.error = this.translateService.instant(error)\n      console.warn(error)\n    }\n    this.loading = false\n    this.changeRef.detectChanges()\n  }\n}\n","<div class=\"w-full h-full flex flex-col gap-[13px]\">\n  <div\n    class=\"flex flex-col md:flex-row gap-4 py-4 px-5 bg-white border border-color-border rounded-lg mt-6\"\n  >\n    <gn-ui-dropdown-selector\n      *ngIf=\"displaySource\"\n      class=\"w-full md:flex-1 md:min-w-0\"\n      extraBtnClass=\"font-sans font-bold\"\n      [title]=\"'map.select.layer' | translate\"\n      [choices]=\"dropdownChoices$ | async\"\n      (selectValue)=\"selectLinkToDisplay($event)\"\n    ></gn-ui-dropdown-selector>\n\n    <ng-container *ngIf=\"(styleLinks$ | async)?.length > 0; else styleDisabled\">\n      <gn-ui-dropdown-selector\n        class=\"w-full md:flex-1 md:min-w-0\"\n        extraBtnClass=\"font-sans font-bold\"\n        [title]=\"'map.select.style' | translate\"\n        [choices]=\"styleDropdownChoices$ | async\"\n        (selectValue)=\"selectStyleToDisplay($event)\"\n      ></gn-ui-dropdown-selector>\n    </ng-container>\n    <ng-template #styleDisabled>\n      <gn-ui-dropdown-selector\n        class=\"w-full md:flex-1 md:min-w-0 text-gray-400\"\n        extraBtnClass=\"font-sans font-bold text-gray-400\"\n        [title]=\"'map.select.style' | translate\"\n        [choices]=\"styleDropdownChoices$ | async\"\n        [disabled]=\"true\"\n      ></gn-ui-dropdown-selector>\n    </ng-template>\n\n    <div class=\"self-end md:ml-2\">\n      <gn-ui-external-viewer-button\n        extraClass=\"w-[44px] h-[44px]\"\n        [link]=\"selectedLink$ | async\"\n      >\n      </gn-ui-external-viewer-button>\n    </div>\n  </div>\n  <ng-container *ngIf=\"hidePreview; else mapView\">\n    <gn-ui-popup-alert\n      type=\"warning\"\n      icon=\"matErrorOutlineOutline\"\n      class=\"block h-12 p-1\"\n    >\n      <span translate>record.feature.limit</span>\n    </gn-ui-popup-alert>\n  </ng-container>\n  <ng-template #mapView>\n    <div\n      class=\"relative w-full h-full bg-white border border-gray-300 rounded-lg overflow-hidden\"\n    >\n      <gn-ui-map-container\n        #mapContainer\n        [context]=\"mapContext$ | async\"\n        (featuresClick)=\"onMapFeatureSelect($event)\"\n        (sourceLoadError)=\"onSourceLoadError($event)\"\n      ></gn-ui-map-container>\n      <div\n        class=\"top-[1em] right-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n        [class.hidden]=\"!selection\"\n      >\n        <gn-ui-button\n          type=\"light\"\n          (buttonClick)=\"resetSelection()\"\n          style=\"\n            --gn-ui-button-padding: 0px;\n            --gn-ui-button-width: 24px;\n            --gn-ui-button-height: 24px;\n          \"\n          extraClass=\"absolute right-[0.5em] ml-[8px] mr-[10px]\"\n        >\n          <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n        </gn-ui-button>\n        <gn-ui-feature-detail\n          [featureCatalog]=\"mdViewFacade.featureCatalog$ | async\"\n          [feature]=\"selection\"\n        ></gn-ui-feature-detail>\n      </div>\n\n      <div\n        class=\"top-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n        [ngClass]=\"{ 'right-[1em]': !selection, 'right-[16em]': selection }\"\n        [hidden]=\"!showLegend || !legendExists\"\n      >\n        <div class=\"flex justify-between items-center mb-2\">\n          <div class=\"text-primary font-bold\" translate>map.legend.title</div>\n          <gn-ui-button\n            type=\"light\"\n            (buttonClick)=\"toggleLegend()\"\n            style=\"\n              --gn-ui-button-padding: 0px;\n              --gn-ui-button-width: 24px;\n              --gn-ui-button-height: 24px;\n            \"\n            extraClass=\"ml-[8px] mr-[10px]\"\n          >\n            <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n          </gn-ui-button>\n        </div>\n        <gn-ui-map-legend\n          [context]=\"mapContext$ | async\"\n          (legendStatusChange)=\"onLegendStatusChange($event)\"\n        ></gn-ui-map-legend>\n      </div>\n\n      <gn-ui-button\n        *ngIf=\"!showLegend && legendExists && !selection\"\n        type=\"outline\"\n        (buttonClick)=\"toggleLegend()\"\n        extraClass=\"absolute top-[1em] right-[1em] rounded p-1 text-xs bg-white\"\n        translate\n      >\n        map.legend.title\n      </gn-ui-button>\n\n      <gn-ui-loading-mask\n        *ngIf=\"loading\"\n        class=\"absolute inset-0\"\n        [message]=\"'map.loading.data' | translate\"\n      ></gn-ui-loading-mask>\n      <gn-ui-popup-alert\n        *ngIf=\"error\"\n        type=\"warning\"\n        icon=\"matErrorOutlineOutline\"\n        class=\"absolute m-2 inset-0\"\n      >\n        <span translate>{{ error }}</span>\n      </gn-ui-popup-alert>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
336
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-view.component.js","sourceRoot":"","sources":["../../../../../../../../libs/feature/record/src/lib/map-view/map-view.component.ts","../../../../../../../../libs/feature/record/src/lib/map-view/map-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MapUtilsService } from '../../../../../../libs/feature/map/src'\nimport { getLinkId, getLinkLabel } from '../../../../../../libs/util/shared/src'\nimport {\n  BehaviorSubject,\n  combineLatest,\n  from,\n  Observable,\n  of,\n  startWith,\n  throwError,\n  withLatestFrom,\n} from 'rxjs'\nimport {\n  catchError,\n  distinctUntilChanged,\n  finalize,\n  map,\n  shareReplay,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs/operators'\nimport { MdViewFacade } from '../state/mdview.facade'\nimport { DataService } from '../../../../../../libs/feature/dataviz/src'\nimport {\n  DatasetOnlineResource,\n  DatasetServiceDistribution,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  createViewFromLayer,\n  MapContext,\n  MapContextLayer,\n  SourceLoadErrorEvent,\n} from '@geospatial-sdk/core'\nimport {\n  FeatureDetailComponent,\n  MapContainerComponent,\n  MapLegendComponent,\n  prioritizePageScroll,\n} from '../../../../../../libs/ui/map/src'\nimport { Feature } from 'geojson'\nimport { NgIconComponent, provideIcons } from '@ng-icons/core'\nimport { matClose } from '@ng-icons/material-icons/baseline'\nimport { CommonModule } from '@angular/common'\nimport {\n  ButtonComponent,\n  DropdownSelectorComponent,\n} from '../../../../../../libs/ui/inputs/src'\nimport {\n  TranslateDirective,\n  TranslatePipe,\n  TranslateService,\n} from '@ngx-translate/core'\nimport { ExternalViewerButtonComponent } from '../external-viewer-button/external-viewer-button.component'\nimport {\n  LoadingMaskComponent,\n  PopupAlertComponent,\n} from '../../../../../../libs/ui/widgets/src'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { FetchError } from '../../../../../../libs/util/data-fetcher/src'\n\nmarker('map.dropdown.placeholder')\nmarker('wfs.feature.limit')\nmarker('dataset.error.restrictedAccess')\nmarker('map.select.style')\n\n@Component({\n  selector: 'gn-ui-map-view',\n  templateUrl: './map-view.component.html',\n  styleUrls: ['./map-view.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    DropdownSelectorComponent,\n    MapContainerComponent,\n    FeatureDetailComponent,\n    PopupAlertComponent,\n    TranslateDirective,\n    TranslatePipe,\n    LoadingMaskComponent,\n    NgIconComponent,\n    ExternalViewerButtonComponent,\n    ButtonComponent,\n    MapLegendComponent,\n  ],\n  viewProviders: [provideIcons({ matClose })],\n})\nexport class MapViewComponent implements AfterViewInit {\n  @Input() set exceedsLimit(value: boolean) {\n    this.excludeWfs$.next(value)\n  }\n  linkFromConfig$ = new BehaviorSubject(null)\n  _selectedChoice = null\n  _styleFromConfig = null\n\n  linkMap: Map<string, DatasetOnlineResource> = new Map()\n  @Input() set selectedView(value: string) {\n    this.selectedView$.next(value)\n  }\n  @Input() set datavizConfig(value: any) {\n    if (value.view === 'map') {\n      this.selectedView$.next(value.view)\n      if (value.styleTMSIndex) {\n        this._styleFromConfig = value.styleTMSIndex\n      }\n      if (value.source) {\n        this.linkFromConfig$.next(value.source)\n      }\n    }\n  }\n  @Input() displaySource = true\n  @Output() linkSelected = new EventEmitter<DatasetOnlineResource>()\n  @Output() styleSelected = new EventEmitter<number>()\n  @ViewChild('mapContainer') mapContainer: MapContainerComponent\n\n  excludeWfs$ = new BehaviorSubject(false)\n  hidePreview = false\n  selection: Feature\n  showLegend = true\n  legendExists = false\n  loading = false\n  error = null\n\n  selectLinkToDisplay(id: string) {\n    this.selectedLinkId$.next(id)\n  }\n\n  selectStyleToDisplay(i: number) {\n    this.selectedStyleId$.next(i)\n    this.styleSelected.emit(i)\n  }\n\n  toggleLegend() {\n    this.showLegend = !this.showLegend\n  }\n  onLegendStatusChange(v: boolean) {\n    this.legendExists = v\n  }\n\n  compatibleMapLinks$ = combineLatest([\n    this.mdViewFacade.mapApiLinks$,\n    this.mdViewFacade.geoDataLinksWithGeometry$,\n  ]).pipe(\n    map(([mapApiLinks, geoDataLinksWithGeometry]) => [\n      ...mapApiLinks,\n      ...geoDataLinksWithGeometry,\n    ]),\n    shareReplay(1)\n  )\n\n  dropdownChoices$ = this.compatibleMapLinks$.pipe(\n    map((links) => {\n      this.linkMap.clear()\n      links.forEach((link: DatasetOnlineResource) =>\n        this.linkMap.set(getLinkId(link), link)\n      )\n      return links.length\n        ? links.map((link) => ({\n            label: getLinkLabel(link),\n            value: getLinkId(link),\n          }))\n        : [{ label: 'map.dropdown.placeholder', value: '' }]\n    })\n  )\n\n  selectedView$ = new BehaviorSubject(null)\n  selectedLinkId$ = new BehaviorSubject(null)\n  selectedStyleId$ = new BehaviorSubject(null)\n\n  selectedSourceLink$ = combineLatest([\n    this.compatibleMapLinks$,\n    this.linkFromConfig$,\n    this.selectedLinkId$.pipe(distinctUntilChanged()),\n    this.selectedView$,\n  ]).pipe(\n    tap(() => {\n      this.error = null\n    }),\n    map(([compatibleLinks, configLink, id, view]) => {\n      if (view === 'map') {\n        if (\n          configLink &&\n          !id &&\n          compatibleLinks.some(\n            (link) => getLinkId(link) === getLinkId(configLink)\n          )\n        ) {\n          this._selectedChoice = getLinkId(configLink)\n          this.linkSelected.emit(configLink)\n          return configLink\n        } else if (id) {\n          this._selectedChoice = id\n          this.linkSelected.emit(this.linkMap.get(id))\n          return this.linkMap.get(id)\n        } else {\n          this.linkSelected.emit(compatibleLinks[0])\n          return compatibleLinks[0]\n        }\n      }\n    })\n  )\n\n  styleLinks$ = this.selectedSourceLink$.pipe(\n    switchMap((src) => {\n      if (\n        src &&\n        src.type === 'service' &&\n        src.accessServiceProtocol === 'tms'\n      ) {\n        return from(\n          // WARNING: when using \"getGeodataLinksFromTms\", make sure to add error handling to prevent the rest of the logic from failing\n          // this may happen when TMS endpoint is in error\n          this.dataService.getGeodataLinksFromTms(\n            src as DatasetServiceDistribution,\n            false\n          )\n        ).pipe(\n          // We need to check for maplibre-style links because when a TMS service has no styles,\n          // getGeodataLinksFromTms returns the original TMS link, which isn't a maplibre-style link\n          map(\n            (links) =>\n              links?.filter(\n                (link) =>\n                  link.type === 'service' &&\n                  link.accessServiceProtocol === 'maplibre-style'\n              ) || []\n          ),\n          catchError((error) => {\n            this.handleError(error)\n            return of(src)\n          })\n        )\n      }\n      return of([])\n    }),\n    tap((styles) => {\n      if (this._styleFromConfig && this._styleFromConfig <= styles.length) {\n        this.selectedStyleId$.next(this._styleFromConfig)\n      } else {\n        this.selectedStyleId$.next(0)\n      }\n    }),\n    shareReplay(1)\n  )\n\n  styleDropdownChoices$ = this.styleLinks$.pipe(\n    map((links) =>\n      links.length\n        ? links.map((link, index) => ({\n            label: getLinkLabel(link),\n            value: index,\n          }))\n        : [\n            {\n              label: '\\u00A0\\u00A0\\u00A0\\u00A0',\n              value: 0,\n            },\n          ]\n    )\n  )\n\n  selectedLink$ = combineLatest([\n    this.selectedSourceLink$,\n    this.styleLinks$,\n    this.selectedStyleId$.pipe(distinctUntilChanged()),\n  ]).pipe(\n    map(([src, styles, styleIdx]) => (styles.length ? styles[styleIdx] : src)),\n    shareReplay(1)\n  )\n\n  currentLayers$ = combineLatest([this.selectedLink$, this.excludeWfs$]).pipe(\n    switchMap(([link, excludeWfs]) => {\n      if (!link) {\n        return of([])\n      }\n      if (excludeWfs && link.accessServiceProtocol === 'wfs') {\n        this.hidePreview = true\n        return of([])\n      }\n      this.hidePreview = false\n      this.loading = true\n      if (link.accessRestricted) {\n        this.handleError('dataset.error.restrictedAccess')\n        return of([])\n      }\n      return this.getLayerFromLink(link).pipe(\n        map((layer) => [layer]),\n        catchError((e) => {\n          this.handleError(e)\n          return of([])\n        }),\n        finalize(() => (this.loading = false))\n      )\n    })\n  )\n\n  mapContext$: Observable<MapContext> = this.currentLayers$.pipe(\n    switchMap((layers) =>\n      from(createViewFromLayer(layers[0])).pipe(\n        catchError(() => of(null)), // could not zoom on the layer: use the record extent\n        map((view) => ({\n          layers,\n          view,\n        })),\n        tap(() => {\n          this.resetSelection()\n        })\n      )\n    ),\n    startWith({\n      layers: [],\n      view: null,\n    }),\n    withLatestFrom(this.mdViewFacade.metadata$),\n    map(([context, metadata]) => {\n      if (context.view) return context\n      const extent = this.mapUtils.getRecordExtent(metadata)\n      const view = extent ? { extent } : null\n      return {\n        ...context,\n        view,\n      }\n    }),\n    shareReplay(1)\n  )\n\n  constructor(\n    private mdViewFacade: MdViewFacade,\n    private mapUtils: MapUtilsService,\n    private dataService: DataService,\n    private changeRef: ChangeDetectorRef,\n    private translateService: TranslateService\n  ) {}\n\n  async ngAfterViewInit() {\n    const map = await this.mapContainer.openlayersMap\n    prioritizePageScroll(map.getInteractions())\n  }\n\n  onMapFeatureSelect(features: Feature[]): void {\n    this.resetSelection()\n    this.selection = features?.length > 0 && features[0]\n    if (this.selection) {\n      // FIXME: restore styling of selected feature\n      // this.selection.setStyle(this.selectionStyle)\n    }\n    this.changeRef.detectChanges()\n  }\n\n  onSourceLoadError(error: SourceLoadErrorEvent) {\n    if (error.httpStatus === 403 || error.httpStatus === 401) {\n      this.error = this.translateService.instant(`dataset.error.forbidden`)\n    } else {\n      this.error = this.translateService.instant(`dataset.error.http`, {\n        info: error.httpStatus,\n      })\n    }\n  }\n\n  resetSelection(): void {\n    if (this.selection) {\n      // FIXME: restore styling of selected feature\n      // this.selection.setStyle(null)\n    }\n    this.selection = null\n  }\n\n  getLayerFromLink(link: DatasetOnlineResource): Observable<MapContextLayer> {\n    if (link.type === 'service' && link.accessServiceProtocol === 'wms') {\n      return of({\n        url: link.url.toString(),\n        type: 'wms',\n        name: link.name,\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'tms'\n    ) {\n      // FIXME: here we're assuming that the TMS serves vector tiles only; should be checked with ogc-client first\n      return of({\n        url: link.url.toString().replace(/\\/?$/, '/{z}/{x}/{y}.pbf'),\n        type: 'xyz',\n        tileFormat: 'application/vnd.mapbox-vector-tile',\n        name: link.name,\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'maplibre-style'\n    ) {\n      return of({\n        type: 'maplibre-style',\n        name: link.name,\n        styleUrl: link.url.toString(),\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'wmts'\n    ) {\n      return of({\n        url: link.url.toString(),\n        type: 'wmts',\n        name: link.name,\n      })\n    } else if (\n      (link.type === 'service' &&\n        (link.accessServiceProtocol === 'wfs' ||\n          link.accessServiceProtocol === 'esriRest' ||\n          link.accessServiceProtocol === 'ogcFeatures')) ||\n      link.type === 'download'\n    ) {\n      const cacheActive = true // TODO implement whether should be true or false\n      return this.dataService.readAsGeoJson(link, cacheActive).pipe(\n        map((data) => ({\n          type: 'geojson',\n          data,\n        }))\n      )\n    }\n    return throwError(() => 'protocol not supported')\n  }\n  handleError(error: FetchError | Error | string) {\n    if (error instanceof FetchError) {\n      this.error = this.translateService.instant(\n        `dataset.error.${error.type}`,\n        {\n          info: error.info,\n        }\n      )\n      console.warn(error.message)\n    } else if (error instanceof Error) {\n      this.error = this.translateService.instant(error.message)\n      console.warn(error.stack || error)\n    } else {\n      this.error = this.translateService.instant(error)\n      console.warn(error)\n    }\n    this.loading = false\n    this.changeRef.detectChanges()\n  }\n}\n","<div class=\"w-full h-full flex flex-col gap-[13px]\">\n  <div\n    class=\"flex flex-col md:flex-row gap-4 py-4 px-5 bg-white border border-color-border rounded-lg mt-6\"\n  >\n    <gn-ui-dropdown-selector\n      *ngIf=\"displaySource\"\n      class=\"w-full md:flex-1 md:min-w-0\"\n      extraBtnClass=\"font-sans font-bold\"\n      [title]=\"'map.select.layer' | translate\"\n      [choices]=\"dropdownChoices$ | async\"\n      [selected]=\"_selectedChoice\"\n      (selectValue)=\"selectLinkToDisplay($event)\"\n    ></gn-ui-dropdown-selector>\n\n    <ng-container *ngIf=\"(styleLinks$ | async)?.length > 0; else styleDisabled\">\n      <gn-ui-dropdown-selector\n        class=\"w-full md:flex-1 md:min-w-0\"\n        extraBtnClass=\"font-sans font-bold\"\n        [title]=\"'map.select.style' | translate\"\n        [choices]=\"styleDropdownChoices$ | async\"\n        [selected]=\"_styleFromConfig\"\n        (selectValue)=\"selectStyleToDisplay($event)\"\n      ></gn-ui-dropdown-selector>\n    </ng-container>\n    <ng-template #styleDisabled>\n      <gn-ui-dropdown-selector\n        class=\"w-full md:flex-1 md:min-w-0 text-gray-400\"\n        extraBtnClass=\"font-sans font-bold text-gray-400\"\n        [title]=\"'map.select.style' | translate\"\n        [choices]=\"styleDropdownChoices$ | async\"\n        [disabled]=\"true\"\n      ></gn-ui-dropdown-selector>\n    </ng-template>\n\n    <div class=\"self-end md:ml-2\">\n      <gn-ui-external-viewer-button\n        extraClass=\"w-[44px] h-[44px]\"\n        [link]=\"selectedLink$ | async\"\n      >\n      </gn-ui-external-viewer-button>\n    </div>\n  </div>\n  <ng-container *ngIf=\"hidePreview; else mapView\">\n    <gn-ui-popup-alert\n      type=\"warning\"\n      icon=\"matErrorOutlineOutline\"\n      class=\"block h-12 p-1\"\n    >\n      <span translate>record.feature.limit</span>\n    </gn-ui-popup-alert>\n  </ng-container>\n  <ng-template #mapView>\n    <div\n      class=\"relative w-full h-full bg-white border border-gray-300 rounded-lg overflow-hidden\"\n    >\n      <gn-ui-map-container\n        #mapContainer\n        [context]=\"mapContext$ | async\"\n        (featuresClick)=\"onMapFeatureSelect($event)\"\n        (sourceLoadError)=\"onSourceLoadError($event)\"\n      ></gn-ui-map-container>\n      <div\n        class=\"top-[1em] right-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n        [class.hidden]=\"!selection\"\n      >\n        <gn-ui-button\n          type=\"light\"\n          (buttonClick)=\"resetSelection()\"\n          style=\"\n            --gn-ui-button-padding: 0px;\n            --gn-ui-button-width: 24px;\n            --gn-ui-button-height: 24px;\n          \"\n          extraClass=\"absolute right-[0.5em] ml-[8px] mr-[10px]\"\n        >\n          <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n        </gn-ui-button>\n        <gn-ui-feature-detail\n          [featureCatalog]=\"mdViewFacade.featureCatalog$ | async\"\n          [feature]=\"selection\"\n        ></gn-ui-feature-detail>\n      </div>\n\n      <div\n        class=\"top-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n        [ngClass]=\"{ 'right-[1em]': !selection, 'right-[16em]': selection }\"\n        [hidden]=\"!showLegend || !legendExists\"\n      >\n        <div class=\"flex justify-between items-center mb-2\">\n          <div class=\"text-primary font-bold\" translate>map.legend.title</div>\n          <gn-ui-button\n            type=\"light\"\n            (buttonClick)=\"toggleLegend()\"\n            style=\"\n              --gn-ui-button-padding: 0px;\n              --gn-ui-button-width: 24px;\n              --gn-ui-button-height: 24px;\n            \"\n            extraClass=\"ml-[8px] mr-[10px]\"\n          >\n            <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n          </gn-ui-button>\n        </div>\n        <gn-ui-map-legend\n          [context]=\"mapContext$ | async\"\n          (legendStatusChange)=\"onLegendStatusChange($event)\"\n        ></gn-ui-map-legend>\n      </div>\n\n      <gn-ui-button\n        *ngIf=\"!showLegend && legendExists && !selection\"\n        type=\"outline\"\n        (buttonClick)=\"toggleLegend()\"\n        extraClass=\"absolute top-[1em] right-[1em] rounded p-1 text-xs bg-white\"\n        translate\n      >\n        map.legend.title\n      </gn-ui-button>\n\n      <gn-ui-loading-mask\n        *ngIf=\"loading\"\n        class=\"absolute inset-0\"\n        [message]=\"'map.loading.data' | translate\"\n      ></gn-ui-loading-mask>\n      <gn-ui-popup-alert\n        *ngIf=\"error\"\n        type=\"warning\"\n        icon=\"matErrorOutlineOutline\"\n        class=\"absolute m-2 inset-0\"\n      >\n        <span translate>{{ error }}</span>\n      </gn-ui-popup-alert>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
@@ -2,7 +2,7 @@ import { ScrollingModule } from '@angular/cdk/scrolling';
|
|
|
2
2
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
3
3
|
import { MatSort, MatSortModule } from '@angular/material/sort';
|
|
4
4
|
import { MatTableModule } from '@angular/material/table';
|
|
5
|
-
import { TranslatePipe, TranslateService } from '@ngx-translate/core';
|
|
5
|
+
import { TranslateDirective, TranslatePipe, TranslateService, } from '@ngx-translate/core';
|
|
6
6
|
import { DataTableDataSource } from './data-table.data.source';
|
|
7
7
|
import { BaseReader, FetchError } from '../../../../../../libs/util/data-fetcher/src';
|
|
8
8
|
import { MatPaginator, MatPaginatorIntl, MatPaginatorModule, } from '@angular/material/paginator';
|
|
@@ -105,7 +105,7 @@ export class DataTableComponent {
|
|
|
105
105
|
}
|
|
106
106
|
}
|
|
107
107
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
108
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DataTableComponent, isStandalone: true, selector: "gn-ui-data-table", inputs: { featureAttributes: "featureAttributes", dataset: "dataset", activeId: "activeId" }, outputs: { selected: "selected" }, providers: [{ provide: MatPaginatorIntl, useClass: CustomMatPaginatorIntl }], viewQueries: [{ propertyName: "sort", first: true, predicate: MatSort, descendants: true }, { propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col border border-gray-300 rounded-lg bg-white h-full\">\n <div class=\"flex-1 overflow-y-hidden overflow-x-auto rounded-lg relative\">\n <table\n mat-table\n [dataSource]=\"dataSource\"\n matSort\n (matSortChange)=\"setSort($event)\"\n [matSortDisableClear]=\"true\"\n *ngrxLet=\"properties$ as properties\"\n >\n <ng-container\n *ngFor=\"let attr of _featureAttributes\"\n [matColumnDef]=\"attr.value\"\n >\n <th\n mat-header-cell\n *matHeaderCellDef\n mat-sort-header\n class=\"text-sm text-black bg-white\"\n >\n {{ attr.label }}\n </th>\n <td\n mat-cell\n *matCellDef=\"let element\"\n class=\"whitespace-nowrap pr-1 truncate\"\n >\n {{ element[attr.value] }}\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"properties; sticky: true\"></tr>\n <tr\n [id]=\"getRowEltId(row.id)\"\n mat-row\n *matRowDef=\"let row; columns: properties\"\n (click)=\"selected.emit(row)\"\n [class.active]=\"\n activeId !== undefined && activeId !== null && row.id === activeId\n \"\n ></tr>\n </table>\n <gn-ui-loading-mask\n *ngIf=\"loading$ | async\"\n class=\"sticky inset-0\"\n [message]=\"'table.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0 z-[100]\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n <div class=\"flex justify-between items-center overflow-hidden\">\n <div class=\"text-gray-900 px-4 py-2 text-sm\">\n <span class=\"count font-extrabold text-primary\">{{ count }}</span\n > <span translate>table.object.count</span>.\n </div>\n\n <mat-paginator\n class=\"my-[-16px]\"\n (page)=\"setPagination()\"\n [length]=\"count\"\n [pageSize]=\"10\"\n [showFirstLastButtons]=\"true\"\n [hidePageSize]=\"true\"\n ></mat-paginator>\n </div>\n</div>\n", styles: ["table{width:100%;background:#fff}th.mat-mdc-header-cell,td.mat-mdc-cell,td.mat-mdc-footer-cell{padding-right:20px}tr.mat-mdc-row,tr.mat-mdc-footer-row{height:36px}tr:hover{background:#f5f5f5}tr.mat-mdc-header-row{height:48px}[mat-header-cell]{color:#0000008a;font-size:12px;font-weight:500}tr{cursor:pointer}.active .mat-mdc-cell{color:var(--color-primary)}.mat-mdc-paginator{background:none}\n"], dependencies: [{ kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i2.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatSortModule }, { kind: "directive", type: i3.MatSort, selector: "[matSort]", inputs: ["matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear", "matSortDisabled"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i3.MatSortHeader, selector: "[mat-sort-header]", inputs: ["mat-sort-header", "arrowPosition", "start", "disabled", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i4.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "ngmodule", type: ScrollingModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "component", type: LoadingMaskComponent, selector: "gn-ui-loading-mask", inputs: ["message"] }, { kind: "component", type: PopupAlertComponent, selector: "gn-ui-popup-alert", inputs: ["icon", "type", "position"] }, { kind: "directive", type: LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet", "ngrxLetSuspenseTpl"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
108
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DataTableComponent, isStandalone: true, selector: "gn-ui-data-table", inputs: { featureAttributes: "featureAttributes", dataset: "dataset", activeId: "activeId" }, outputs: { selected: "selected" }, providers: [{ provide: MatPaginatorIntl, useClass: CustomMatPaginatorIntl }], viewQueries: [{ propertyName: "sort", first: true, predicate: MatSort, descendants: true }, { propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col border border-gray-300 rounded-lg bg-white h-full\">\n <div class=\"flex-1 overflow-y-hidden overflow-x-auto rounded-lg relative\">\n <table\n mat-table\n [dataSource]=\"dataSource\"\n matSort\n (matSortChange)=\"setSort($event)\"\n [matSortDisableClear]=\"true\"\n *ngrxLet=\"properties$ as properties\"\n >\n <ng-container\n *ngFor=\"let attr of _featureAttributes\"\n [matColumnDef]=\"attr.value\"\n >\n <th\n mat-header-cell\n *matHeaderCellDef\n mat-sort-header\n class=\"text-sm text-black bg-white\"\n >\n {{ attr.label }}\n </th>\n <td\n mat-cell\n *matCellDef=\"let element\"\n class=\"whitespace-nowrap pr-1 truncate\"\n >\n {{ element[attr.value] }}\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"properties; sticky: true\"></tr>\n <tr\n [id]=\"getRowEltId(row.id)\"\n mat-row\n *matRowDef=\"let row; columns: properties\"\n (click)=\"selected.emit(row)\"\n [class.active]=\"\n activeId !== undefined && activeId !== null && row.id === activeId\n \"\n ></tr>\n </table>\n <gn-ui-loading-mask\n *ngIf=\"loading$ | async\"\n class=\"sticky inset-0\"\n [message]=\"'table.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0 z-[100]\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n <div class=\"flex justify-between items-center overflow-hidden\">\n <div class=\"text-gray-900 px-4 py-2 text-sm\">\n <span class=\"count font-extrabold text-primary\">{{ count }}</span\n > <span translate>table.object.count</span>.\n </div>\n\n <mat-paginator\n class=\"my-[-16px]\"\n (page)=\"setPagination()\"\n [length]=\"count\"\n [pageSize]=\"10\"\n [showFirstLastButtons]=\"true\"\n [hidePageSize]=\"true\"\n ></mat-paginator>\n </div>\n</div>\n", styles: ["table{width:100%;background:#fff}th.mat-mdc-header-cell,td.mat-mdc-cell,td.mat-mdc-footer-cell{padding-right:20px}tr.mat-mdc-row,tr.mat-mdc-footer-row{height:36px}tr:hover{background:#f5f5f5}tr.mat-mdc-header-row{height:48px}[mat-header-cell]{color:#0000008a;font-size:12px;font-weight:500}tr{cursor:pointer}.active .mat-mdc-cell{color:var(--color-primary)}.mat-mdc-paginator{background:none}\n"], dependencies: [{ kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i2.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatSortModule }, { kind: "directive", type: i3.MatSort, selector: "[matSort]", inputs: ["matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear", "matSortDisabled"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i3.MatSortHeader, selector: "[mat-sort-header]", inputs: ["mat-sort-header", "arrowPosition", "start", "disabled", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i4.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "ngmodule", type: ScrollingModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "component", type: LoadingMaskComponent, selector: "gn-ui-loading-mask", inputs: ["message"] }, { kind: "component", type: PopupAlertComponent, selector: "gn-ui-popup-alert", inputs: ["icon", "type", "position"] }, { kind: "directive", type: LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet", "ngrxLetSuspenseTpl"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
109
109
|
}
|
|
110
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableComponent, decorators: [{
|
|
111
111
|
type: Component,
|
|
@@ -119,6 +119,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
119
119
|
PopupAlertComponent,
|
|
120
120
|
LetDirective,
|
|
121
121
|
TranslatePipe,
|
|
122
|
+
TranslateDirective,
|
|
122
123
|
], providers: [{ provide: MatPaginatorIntl, useClass: CustomMatPaginatorIntl }], selector: 'gn-ui-data-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex flex-col border border-gray-300 rounded-lg bg-white h-full\">\n <div class=\"flex-1 overflow-y-hidden overflow-x-auto rounded-lg relative\">\n <table\n mat-table\n [dataSource]=\"dataSource\"\n matSort\n (matSortChange)=\"setSort($event)\"\n [matSortDisableClear]=\"true\"\n *ngrxLet=\"properties$ as properties\"\n >\n <ng-container\n *ngFor=\"let attr of _featureAttributes\"\n [matColumnDef]=\"attr.value\"\n >\n <th\n mat-header-cell\n *matHeaderCellDef\n mat-sort-header\n class=\"text-sm text-black bg-white\"\n >\n {{ attr.label }}\n </th>\n <td\n mat-cell\n *matCellDef=\"let element\"\n class=\"whitespace-nowrap pr-1 truncate\"\n >\n {{ element[attr.value] }}\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"properties; sticky: true\"></tr>\n <tr\n [id]=\"getRowEltId(row.id)\"\n mat-row\n *matRowDef=\"let row; columns: properties\"\n (click)=\"selected.emit(row)\"\n [class.active]=\"\n activeId !== undefined && activeId !== null && row.id === activeId\n \"\n ></tr>\n </table>\n <gn-ui-loading-mask\n *ngIf=\"loading$ | async\"\n class=\"sticky inset-0\"\n [message]=\"'table.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0 z-[100]\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n <div class=\"flex justify-between items-center overflow-hidden\">\n <div class=\"text-gray-900 px-4 py-2 text-sm\">\n <span class=\"count font-extrabold text-primary\">{{ count }}</span\n > <span translate>table.object.count</span>.\n </div>\n\n <mat-paginator\n class=\"my-[-16px]\"\n (page)=\"setPagination()\"\n [length]=\"count\"\n [pageSize]=\"10\"\n [showFirstLastButtons]=\"true\"\n [hidePageSize]=\"true\"\n ></mat-paginator>\n </div>\n</div>\n", styles: ["table{width:100%;background:#fff}th.mat-mdc-header-cell,td.mat-mdc-cell,td.mat-mdc-footer-cell{padding-right:20px}tr.mat-mdc-row,tr.mat-mdc-footer-row{height:36px}tr:hover{background:#f5f5f5}tr.mat-mdc-header-row{height:48px}[mat-header-cell]{color:#0000008a;font-size:12px;font-weight:500}tr{cursor:pointer}.active .mat-mdc-cell{color:var(--color-primary)}.mat-mdc-paginator{background:none}\n"] }]
|
|
123
124
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.TranslateService }], propDecorators: { featureAttributes: [{
|
|
124
125
|
type: Input
|
|
@@ -135,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
135
136
|
type: ViewChild,
|
|
136
137
|
args: [MatPaginator]
|
|
137
138
|
}] } });
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/dataviz/src/lib/data-table/data-table.component.ts","../../../../../../../../libs/ui/dataviz/src/lib/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ScrollingModule } from '@angular/cdk/scrolling'\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MatSort, MatSortModule } from '@angular/material/sort'\nimport { MatTableModule } from '@angular/material/table'\nimport { TranslatePipe, TranslateService } from '@ngx-translate/core'\nimport { DataTableDataSource } from './data-table.data.source'\nimport { BaseReader, FetchError } from '../../../../../../libs/util/data-fetcher/src'\nimport {\n  MatPaginator,\n  MatPaginatorIntl,\n  MatPaginatorModule,\n} from '@angular/material/paginator'\nimport { CustomMatPaginatorIntl } from './custom.mat.paginator.intl'\nimport { CommonModule } from '@angular/common'\nimport { BehaviorSubject, filter, firstValueFrom } from 'rxjs'\nimport {\n  LoadingMaskComponent,\n  PopupAlertComponent,\n} from '../../../../../../libs/ui/widgets/src'\nimport { LetDirective } from '@ngrx/component'\n\nconst rowIdPrefix = 'table-item-'\n\nexport type TableItemId = string | number\ntype TableItemType = string | number | Date\n\nexport interface TableItemModel {\n  id: TableItemId\n  [key: string]: TableItemType\n}\n\n@Component({\n  standalone: true,\n  imports: [\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    ScrollingModule,\n    CommonModule,\n    LoadingMaskComponent,\n    PopupAlertComponent,\n    LetDirective,\n    TranslatePipe,\n  ],\n  providers: [{ provide: MatPaginatorIntl, useClass: CustomMatPaginatorIntl }],\n  selector: 'gn-ui-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent implements OnInit, AfterViewInit, OnChanges {\n  _featureAttributes = []\n  @Input() set featureAttributes(value: { value: string; label: string }[]) {\n    this._featureAttributes = value\n    this.properties$.next(value.map((attr) => attr.value))\n  }\n  @Input() set dataset(value: BaseReader) {\n    this.dataset_ = value\n    this.dataset_.load()\n    this.dataset_.info.then((info) => (this.count = info.itemsCount))\n  }\n  @Input() activeId: TableItemId\n  @Output() selected = new EventEmitter<any>()\n\n  @ViewChild(MatSort) sort: MatSort\n  @ViewChild(MatPaginator) paginator: MatPaginator\n\n  dataset_: BaseReader\n  properties$ = new BehaviorSubject<string[]>(null)\n  dataSource: DataTableDataSource\n  headerHeight: number\n  count: number\n  loading$ = new BehaviorSubject<boolean>(false)\n  error = null\n\n  constructor(\n    private eltRef: ElementRef,\n    private cdr: ChangeDetectorRef,\n    private translateService: TranslateService\n  ) {}\n\n  ngOnInit() {\n    this.dataSource = new DataTableDataSource()\n  }\n\n  ngAfterViewInit() {\n    this.headerHeight =\n      this.eltRef.nativeElement.querySelector('thead').offsetHeight\n    this.setPagination()\n    this.cdr.detectChanges()\n  }\n\n  ngOnChanges() {\n    this.setPagination()\n  }\n\n  setSort(sort: MatSort) {\n    if (!this.dataset_) return\n    if (!sort.active) {\n      this.dataset_.orderBy()\n    } else {\n      this.dataset_.orderBy([sort.direction || 'asc', sort.active])\n    }\n    this.readData()\n  }\n\n  setPagination() {\n    if (!this.paginator) return\n    if (!this.dataset_) return\n    this.dataset_.limit(\n      this.paginator.pageIndex * this.paginator.pageSize,\n      this.paginator.pageSize\n    )\n    this.readData()\n  }\n\n  async readData() {\n    this.loading$.next(true)\n    // wait for properties to be read\n    const properties = await firstValueFrom(\n      this.properties$.pipe(filter((p) => !!p))\n    )\n    const propsWithoutGeom = properties.filter(\n      (p) => !p.toLowerCase().startsWith('geom')\n    )\n    this.dataset_.select(...propsWithoutGeom)\n    try {\n      await this.dataSource.showData(this.dataset_.read())\n      this.error = null\n    } catch (error) {\n      this.handleError(error as FetchError | Error)\n    }\n    this.loading$.next(false)\n  }\n\n  scrollToItem(itemId: TableItemId): void {\n    const row = this.eltRef.nativeElement.querySelector(\n      `#${this.getRowEltId(itemId)}`\n    )\n    this.eltRef.nativeElement.scrollTop = row.offsetTop - this.headerHeight\n  }\n\n  public getRowEltId(id: TableItemId): string {\n    return rowIdPrefix + id\n  }\n\n  handleError(error: FetchError | Error) {\n    this.dataSource.clearData()\n    if (error instanceof FetchError) {\n      this.error = this.translateService.instant(\n        `dataset.error.${error.type}`,\n        {\n          info: error.info,\n        }\n      )\n      console.warn(error.message)\n    } else {\n      this.error = this.translateService.instant(error.message)\n      console.warn(error.stack || error)\n    }\n  }\n}\n","<div class=\"flex flex-col border border-gray-300 rounded-lg bg-white h-full\">\n  <div class=\"flex-1 overflow-y-hidden overflow-x-auto rounded-lg relative\">\n    <table\n      mat-table\n      [dataSource]=\"dataSource\"\n      matSort\n      (matSortChange)=\"setSort($event)\"\n      [matSortDisableClear]=\"true\"\n      *ngrxLet=\"properties$ as properties\"\n    >\n      <ng-container\n        *ngFor=\"let attr of _featureAttributes\"\n        [matColumnDef]=\"attr.value\"\n      >\n        <th\n          mat-header-cell\n          *matHeaderCellDef\n          mat-sort-header\n          class=\"text-sm text-black bg-white\"\n        >\n          {{ attr.label }}\n        </th>\n        <td\n          mat-cell\n          *matCellDef=\"let element\"\n          class=\"whitespace-nowrap pr-1 truncate\"\n        >\n          {{ element[attr.value] }}\n        </td>\n      </ng-container>\n\n      <tr mat-header-row *matHeaderRowDef=\"properties; sticky: true\"></tr>\n      <tr\n        [id]=\"getRowEltId(row.id)\"\n        mat-row\n        *matRowDef=\"let row; columns: properties\"\n        (click)=\"selected.emit(row)\"\n        [class.active]=\"\n          activeId !== undefined && activeId !== null && row.id === activeId\n        \"\n      ></tr>\n    </table>\n    <gn-ui-loading-mask\n      *ngIf=\"loading$ | async\"\n      class=\"sticky inset-0\"\n      [message]=\"'table.loading.data' | translate\"\n    ></gn-ui-loading-mask>\n    <gn-ui-popup-alert\n      *ngIf=\"error\"\n      type=\"warning\"\n      icon=\"matErrorOutlineOutline\"\n      class=\"absolute m-2 inset-0 z-[100]\"\n    >\n      <span translate>{{ error }}</span>\n    </gn-ui-popup-alert>\n  </div>\n  <div class=\"flex justify-between items-center overflow-hidden\">\n    <div class=\"text-gray-900 px-4 py-2 text-sm\">\n      <span class=\"count font-extrabold text-primary\">{{ count }}</span\n      >&nbsp;<span translate>table.object.count</span>.\n    </div>\n\n    <mat-paginator\n      class=\"my-[-16px]\"\n      (page)=\"setPagination()\"\n      [length]=\"count\"\n      [pageSize]=\"10\"\n      [showFirstLastButtons]=\"true\"\n      [hidePageSize]=\"true\"\n    ></mat-paginator>\n  </div>\n</div>\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/dataviz/src/lib/data-table/data-table.component.ts","../../../../../../../../libs/ui/dataviz/src/lib/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ScrollingModule } from '@angular/cdk/scrolling'\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MatSort, MatSortModule } from '@angular/material/sort'\nimport { MatTableModule } from '@angular/material/table'\nimport {\n  TranslateDirective,\n  TranslatePipe,\n  TranslateService,\n} from '@ngx-translate/core'\nimport { DataTableDataSource } from './data-table.data.source'\nimport { BaseReader, FetchError } from '../../../../../../libs/util/data-fetcher/src'\nimport {\n  MatPaginator,\n  MatPaginatorIntl,\n  MatPaginatorModule,\n} from '@angular/material/paginator'\nimport { CustomMatPaginatorIntl } from './custom.mat.paginator.intl'\nimport { CommonModule } from '@angular/common'\nimport { BehaviorSubject, filter, firstValueFrom } from 'rxjs'\nimport {\n  LoadingMaskComponent,\n  PopupAlertComponent,\n} from '../../../../../../libs/ui/widgets/src'\nimport { LetDirective } from '@ngrx/component'\n\nconst rowIdPrefix = 'table-item-'\n\nexport type TableItemId = string | number\ntype TableItemType = string | number | Date\n\nexport interface TableItemModel {\n  id: TableItemId\n  [key: string]: TableItemType\n}\n\n@Component({\n  standalone: true,\n  imports: [\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    ScrollingModule,\n    CommonModule,\n    LoadingMaskComponent,\n    PopupAlertComponent,\n    LetDirective,\n    TranslatePipe,\n    TranslateDirective,\n  ],\n  providers: [{ provide: MatPaginatorIntl, useClass: CustomMatPaginatorIntl }],\n  selector: 'gn-ui-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent implements OnInit, AfterViewInit, OnChanges {\n  _featureAttributes = []\n  @Input() set featureAttributes(value: { value: string; label: string }[]) {\n    this._featureAttributes = value\n    this.properties$.next(value.map((attr) => attr.value))\n  }\n  @Input() set dataset(value: BaseReader) {\n    this.dataset_ = value\n    this.dataset_.load()\n    this.dataset_.info.then((info) => (this.count = info.itemsCount))\n  }\n  @Input() activeId: TableItemId\n  @Output() selected = new EventEmitter<any>()\n\n  @ViewChild(MatSort) sort: MatSort\n  @ViewChild(MatPaginator) paginator: MatPaginator\n\n  dataset_: BaseReader\n  properties$ = new BehaviorSubject<string[]>(null)\n  dataSource: DataTableDataSource\n  headerHeight: number\n  count: number\n  loading$ = new BehaviorSubject<boolean>(false)\n  error = null\n\n  constructor(\n    private eltRef: ElementRef,\n    private cdr: ChangeDetectorRef,\n    private translateService: TranslateService\n  ) {}\n\n  ngOnInit() {\n    this.dataSource = new DataTableDataSource()\n  }\n\n  ngAfterViewInit() {\n    this.headerHeight =\n      this.eltRef.nativeElement.querySelector('thead').offsetHeight\n    this.setPagination()\n    this.cdr.detectChanges()\n  }\n\n  ngOnChanges() {\n    this.setPagination()\n  }\n\n  setSort(sort: MatSort) {\n    if (!this.dataset_) return\n    if (!sort.active) {\n      this.dataset_.orderBy()\n    } else {\n      this.dataset_.orderBy([sort.direction || 'asc', sort.active])\n    }\n    this.readData()\n  }\n\n  setPagination() {\n    if (!this.paginator) return\n    if (!this.dataset_) return\n    this.dataset_.limit(\n      this.paginator.pageIndex * this.paginator.pageSize,\n      this.paginator.pageSize\n    )\n    this.readData()\n  }\n\n  async readData() {\n    this.loading$.next(true)\n    // wait for properties to be read\n    const properties = await firstValueFrom(\n      this.properties$.pipe(filter((p) => !!p))\n    )\n    const propsWithoutGeom = properties.filter(\n      (p) => !p.toLowerCase().startsWith('geom')\n    )\n    this.dataset_.select(...propsWithoutGeom)\n    try {\n      await this.dataSource.showData(this.dataset_.read())\n      this.error = null\n    } catch (error) {\n      this.handleError(error as FetchError | Error)\n    }\n    this.loading$.next(false)\n  }\n\n  scrollToItem(itemId: TableItemId): void {\n    const row = this.eltRef.nativeElement.querySelector(\n      `#${this.getRowEltId(itemId)}`\n    )\n    this.eltRef.nativeElement.scrollTop = row.offsetTop - this.headerHeight\n  }\n\n  public getRowEltId(id: TableItemId): string {\n    return rowIdPrefix + id\n  }\n\n  handleError(error: FetchError | Error) {\n    this.dataSource.clearData()\n    if (error instanceof FetchError) {\n      this.error = this.translateService.instant(\n        `dataset.error.${error.type}`,\n        {\n          info: error.info,\n        }\n      )\n      console.warn(error.message)\n    } else {\n      this.error = this.translateService.instant(error.message)\n      console.warn(error.stack || error)\n    }\n  }\n}\n","<div class=\"flex flex-col border border-gray-300 rounded-lg bg-white h-full\">\n  <div class=\"flex-1 overflow-y-hidden overflow-x-auto rounded-lg relative\">\n    <table\n      mat-table\n      [dataSource]=\"dataSource\"\n      matSort\n      (matSortChange)=\"setSort($event)\"\n      [matSortDisableClear]=\"true\"\n      *ngrxLet=\"properties$ as properties\"\n    >\n      <ng-container\n        *ngFor=\"let attr of _featureAttributes\"\n        [matColumnDef]=\"attr.value\"\n      >\n        <th\n          mat-header-cell\n          *matHeaderCellDef\n          mat-sort-header\n          class=\"text-sm text-black bg-white\"\n        >\n          {{ attr.label }}\n        </th>\n        <td\n          mat-cell\n          *matCellDef=\"let element\"\n          class=\"whitespace-nowrap pr-1 truncate\"\n        >\n          {{ element[attr.value] }}\n        </td>\n      </ng-container>\n\n      <tr mat-header-row *matHeaderRowDef=\"properties; sticky: true\"></tr>\n      <tr\n        [id]=\"getRowEltId(row.id)\"\n        mat-row\n        *matRowDef=\"let row; columns: properties\"\n        (click)=\"selected.emit(row)\"\n        [class.active]=\"\n          activeId !== undefined && activeId !== null && row.id === activeId\n        \"\n      ></tr>\n    </table>\n    <gn-ui-loading-mask\n      *ngIf=\"loading$ | async\"\n      class=\"sticky inset-0\"\n      [message]=\"'table.loading.data' | translate\"\n    ></gn-ui-loading-mask>\n    <gn-ui-popup-alert\n      *ngIf=\"error\"\n      type=\"warning\"\n      icon=\"matErrorOutlineOutline\"\n      class=\"absolute m-2 inset-0 z-[100]\"\n    >\n      <span translate>{{ error }}</span>\n    </gn-ui-popup-alert>\n  </div>\n  <div class=\"flex justify-between items-center overflow-hidden\">\n    <div class=\"text-gray-900 px-4 py-2 text-sm\">\n      <span class=\"count font-extrabold text-primary\">{{ count }}</span\n      >&nbsp;<span translate>table.object.count</span>.\n    </div>\n\n    <mat-paginator\n      class=\"my-[-16px]\"\n      (page)=\"setPagination()\"\n      [length]=\"count\"\n      [pageSize]=\"10\"\n      [showFirstLastButtons]=\"true\"\n      [hidePageSize]=\"true\"\n    ></mat-paginator>\n  </div>\n</div>\n"]}
|