geonetwork-ui 2.5.0-dev.22c177ea1 → 2.5.0-dev.4e621e7b5
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/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +11 -1
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.mjs +1 -1
- package/esm2022/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.mjs +20 -17
- package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +22 -2
- package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/repository/records-repository.interface.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +7 -4
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +23 -15
- package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +7 -4
- package/esm2022/libs/feature/editor/src/lib/components/constraint-card/constraint-card.component.mjs +3 -3
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.mjs +2 -1
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +2 -2
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +2 -2
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +4 -3
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +3 -2
- package/esm2022/libs/feature/record/src/lib/state/mdview.actions.mjs +4 -1
- package/esm2022/libs/feature/record/src/lib/state/mdview.effects.mjs +7 -2
- package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +9 -1
- package/esm2022/libs/feature/record/src/lib/state/mdview.reducer.mjs +19 -1
- package/esm2022/libs/feature/record/src/lib/state/mdview.selectors.mjs +6 -1
- package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +1 -1
- package/esm2022/libs/ui/elements/src/index.mjs +2 -1
- package/esm2022/libs/ui/elements/src/lib/application-banner/application-banner.component.mjs +78 -0
- package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +2 -1
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +10 -4
- package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +7 -2
- package/esm2022/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.mjs +14 -4
- package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +10 -3
- package/esm2022/libs/util/data-fetcher/src/lib/data-fetcher.mjs +5 -4
- package/esm2022/libs/util/data-fetcher/src/lib/readers/base-cache.mjs +12 -0
- package/esm2022/libs/util/data-fetcher/src/lib/readers/base-file.mjs +3 -3
- package/esm2022/libs/util/data-fetcher/src/lib/readers/base.mjs +1 -1
- package/esm2022/libs/util/data-fetcher/src/lib/readers/csv.mjs +2 -2
- package/esm2022/libs/util/data-fetcher/src/lib/readers/excel.mjs +2 -2
- package/esm2022/libs/util/data-fetcher/src/lib/readers/geojson.mjs +2 -2
- package/esm2022/libs/util/data-fetcher/src/lib/readers/gml.mjs +5 -3
- package/esm2022/libs/util/data-fetcher/src/lib/readers/json.mjs +2 -2
- package/esm2022/libs/util/data-fetcher/src/lib/readers/wfs.mjs +19 -11
- package/esm2022/libs/util/data-fetcher/src/lib/utils.mjs +9 -7
- package/esm2022/translations/de.json +3 -4
- package/esm2022/translations/en.json +4 -13
- package/esm2022/translations/es.json +3 -4
- package/esm2022/translations/fr.json +15 -16
- package/esm2022/translations/it.json +20 -20
- package/esm2022/translations/nl.json +3 -4
- package/esm2022/translations/pt.json +3 -4
- package/fesm2022/geonetwork-ui.mjs +407 -207
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.d.ts +3 -0
- package/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.d.ts +1 -0
- package/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +2 -1
- package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +6 -0
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +2 -1
- package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts +2 -1
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts +2 -2
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts +2 -1
- package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/data-view/data-view.component.d.ts +1 -0
- 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.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.actions.d.ts +16 -1
- package/libs/feature/record/src/lib/state/mdview.actions.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.effects.d.ts +5 -0
- package/libs/feature/record/src/lib/state/mdview.effects.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts +2 -0
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.reducer.d.ts +4 -1
- package/libs/feature/record/src/lib/state/mdview.reducer.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.selectors.d.ts +2 -0
- package/libs/feature/record/src/lib/state/mdview.selectors.d.ts.map +1 -1
- package/libs/ui/elements/src/index.d.ts +1 -0
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/application-banner/application-banner.component.d.ts +16 -0
- package/libs/ui/elements/src/lib/application-banner/application-banner.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts +4 -2
- package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts.map +1 -1
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +3 -1
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/lib/data-fetcher.d.ts +2 -2
- package/libs/util/data-fetcher/src/lib/data-fetcher.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/lib/readers/base-cache.d.ts +8 -0
- package/libs/util/data-fetcher/src/lib/readers/base-cache.d.ts.map +1 -0
- package/libs/util/data-fetcher/src/lib/readers/base-file.d.ts +2 -2
- package/libs/util/data-fetcher/src/lib/readers/base-file.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/lib/readers/base.d.ts +2 -2
- package/libs/util/data-fetcher/src/lib/readers/base.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/lib/readers/gml.d.ts +5 -3
- package/libs/util/data-fetcher/src/lib/readers/gml.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/lib/readers/wfs.d.ts +7 -4
- package/libs/util/data-fetcher/src/lib/readers/wfs.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/lib/utils.d.ts +2 -2
- package/libs/util/data-fetcher/src/lib/utils.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +25 -0
- package/src/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.ts +4 -0
- package/src/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.ts +22 -16
- package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +41 -2
- package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +3 -1
- package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +4 -1
- package/src/libs/common/fixtures/src/lib/records.fixtures.ts +75 -0
- package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +4 -1
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +42 -21
- package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.ts +2 -1
- package/src/libs/feature/editor/src/lib/components/constraint-card/constraint-card.component.html +1 -1
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.ts +1 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +1 -1
- package/src/libs/feature/editor/src/lib/fields.config.ts +1 -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 +3 -0
- package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +2 -1
- package/src/libs/feature/record/src/lib/state/mdview.actions.ts +16 -0
- package/src/libs/feature/record/src/lib/state/mdview.effects.ts +21 -2
- package/src/libs/feature/record/src/lib/state/mdview.facade.ts +15 -0
- package/src/libs/feature/record/src/lib/state/mdview.reducer.ts +30 -1
- package/src/libs/feature/record/src/lib/state/mdview.selectors.ts +12 -0
- package/src/libs/ui/elements/src/index.ts +1 -0
- package/src/libs/ui/elements/src/lib/application-banner/application-banner.component.css +0 -0
- package/src/libs/ui/elements/src/lib/application-banner/application-banner.component.html +25 -0
- package/src/libs/ui/elements/src/lib/application-banner/application-banner.component.ts +70 -0
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +2 -0
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +3 -0
- package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +6 -0
- package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html +37 -1
- package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.ts +8 -2
- package/src/libs/ui/search/src/lib/results-table/results-table.component.html +2 -0
- package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +6 -0
- package/src/libs/util/data-fetcher/src/lib/data-fetcher.ts +13 -4
- package/src/libs/util/data-fetcher/src/lib/readers/base-cache.ts +14 -0
- package/src/libs/util/data-fetcher/src/lib/readers/base-file.ts +2 -1
- package/src/libs/util/data-fetcher/src/lib/readers/base.ts +2 -2
- package/src/libs/util/data-fetcher/src/lib/readers/csv.ts +1 -1
- package/src/libs/util/data-fetcher/src/lib/readers/excel.ts +1 -1
- package/src/libs/util/data-fetcher/src/lib/readers/geojson.ts +1 -1
- package/src/libs/util/data-fetcher/src/lib/readers/gml.ts +7 -7
- package/src/libs/util/data-fetcher/src/lib/readers/json.ts +1 -1
- package/src/libs/util/data-fetcher/src/lib/readers/wfs.ts +34 -11
- package/src/libs/util/data-fetcher/src/lib/utils.ts +36 -32
- package/translations/de.json +3 -4
- package/translations/en.json +4 -13
- package/translations/es.json +3 -4
- package/translations/fr.json +15 -16
- package/translations/it.json +20 -20
- package/translations/nl.json +3 -4
- package/translations/pt.json +3 -4
- package/translations/sk.json +3 -4
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { NgIconComponent, provideIcons, provideNgIconsConfig, } from '@ng-icons/core';
|
|
4
|
+
import { matCloseOutline, matInfoOutline, matWarningAmberOutline, } from '@ng-icons/material-icons/outline';
|
|
5
|
+
import { matWarning } from '@ng-icons/material-icons/baseline';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
export class ApplicationBannerComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.closeEnabled = false;
|
|
11
|
+
this.extraClass = '';
|
|
12
|
+
this.icon = '';
|
|
13
|
+
this.msgClass = '';
|
|
14
|
+
this.bannerOpen = true;
|
|
15
|
+
}
|
|
16
|
+
set type(value) {
|
|
17
|
+
switch (value) {
|
|
18
|
+
case 'primary':
|
|
19
|
+
this.msgClass = 'bg-primary-darkest border-primary text-white';
|
|
20
|
+
this.icon = 'matWarning';
|
|
21
|
+
break;
|
|
22
|
+
case 'light':
|
|
23
|
+
this.msgClass =
|
|
24
|
+
'bg-primary-opacity-10 border-primary-lightest text-black';
|
|
25
|
+
this.icon = 'matInfoOutline';
|
|
26
|
+
break;
|
|
27
|
+
case 'secondary':
|
|
28
|
+
default:
|
|
29
|
+
this.msgClass = 'bg-primary-opacity-50 border-primary-darker text-black';
|
|
30
|
+
this.icon = 'matWarningAmberOutline';
|
|
31
|
+
break;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
get classList() {
|
|
35
|
+
if (this.message.length > 200) {
|
|
36
|
+
return `${this.msgClass} ${this.extraClass} overflow-y-scroll items-start`;
|
|
37
|
+
}
|
|
38
|
+
return `${this.msgClass} ${this.extraClass} items-center`;
|
|
39
|
+
}
|
|
40
|
+
closeMessage() {
|
|
41
|
+
this.bannerOpen = false;
|
|
42
|
+
}
|
|
43
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApplicationBannerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ApplicationBannerComponent, isStandalone: true, selector: "gn-ui-application-banner", inputs: { message: "message", title: "title", closeEnabled: "closeEnabled", extraClass: "extraClass", icon: "icon", type: "type" }, providers: [
|
|
45
|
+
provideIcons({
|
|
46
|
+
matWarningAmberOutline,
|
|
47
|
+
matInfoOutline,
|
|
48
|
+
matCloseOutline,
|
|
49
|
+
matWarning,
|
|
50
|
+
}),
|
|
51
|
+
provideNgIconsConfig({ size: '1.5em' }),
|
|
52
|
+
], ngImport: i0, template: "<div\n *ngIf=\"message && bannerOpen\"\n class=\"absolute left-0 right-0 text-wrap bg-white mt-4 max-h-24\"\n>\n <div\n class=\"flex flex-row py-2.5 px-5 gap-5 justify-start border max-h-20\"\n [ngClass]=\"classList\"\n >\n <div [ngClass]=\"message.length > 200 ? 'pt-5' : 'pt-1'\">\n <ng-icon [name]=\"icon\"></ng-icon>\n </div>\n <div class=\"flex flex-col justify-start gap-2.5\">\n <span *ngIf=\"title\" class=\"font-bold\">{{ title }}</span>\n <span class=\"font-medium max-w-2xl\" [innerHTML]=\"message\"></span>\n </div>\n <button\n *ngIf=\"closeEnabled\"\n class=\"self-start\"\n type=\"button\"\n (click)=\"closeMessage()\"\n >\n <ng-icon name=\"matCloseOutline\"> </ng-icon>\n </button>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
53
|
+
}
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApplicationBannerComponent, decorators: [{
|
|
55
|
+
type: Component,
|
|
56
|
+
args: [{ selector: 'gn-ui-application-banner', standalone: true, imports: [CommonModule, NgIconComponent], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
57
|
+
provideIcons({
|
|
58
|
+
matWarningAmberOutline,
|
|
59
|
+
matInfoOutline,
|
|
60
|
+
matCloseOutline,
|
|
61
|
+
matWarning,
|
|
62
|
+
}),
|
|
63
|
+
provideNgIconsConfig({ size: '1.5em' }),
|
|
64
|
+
], template: "<div\n *ngIf=\"message && bannerOpen\"\n class=\"absolute left-0 right-0 text-wrap bg-white mt-4 max-h-24\"\n>\n <div\n class=\"flex flex-row py-2.5 px-5 gap-5 justify-start border max-h-20\"\n [ngClass]=\"classList\"\n >\n <div [ngClass]=\"message.length > 200 ? 'pt-5' : 'pt-1'\">\n <ng-icon [name]=\"icon\"></ng-icon>\n </div>\n <div class=\"flex flex-col justify-start gap-2.5\">\n <span *ngIf=\"title\" class=\"font-bold\">{{ title }}</span>\n <span class=\"font-medium max-w-2xl\" [innerHTML]=\"message\"></span>\n </div>\n <button\n *ngIf=\"closeEnabled\"\n class=\"self-start\"\n type=\"button\"\n (click)=\"closeMessage()\"\n >\n <ng-icon name=\"matCloseOutline\"> </ng-icon>\n </button>\n </div>\n</div>\n" }]
|
|
65
|
+
}], propDecorators: { message: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], title: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}], closeEnabled: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}], extraClass: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}], icon: [{
|
|
74
|
+
type: Input
|
|
75
|
+
}], type: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}] } });
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi9hcHBsaWNhdGlvbi1iYW5uZXIvYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi9hcHBsaWNhdGlvbi1iYW5uZXIvYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3pFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQ0wsZUFBZSxFQUNmLFlBQVksRUFDWixvQkFBb0IsR0FDckIsTUFBTSxnQkFBZ0IsQ0FBQTtBQUN2QixPQUFPLEVBQ0wsZUFBZSxFQUNmLGNBQWMsRUFDZCxzQkFBc0IsR0FDdkIsTUFBTSxrQ0FBa0MsQ0FBQTtBQUN6QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sbUNBQW1DLENBQUE7OztBQW1COUQsTUFBTSxPQUFPLDBCQUEwQjtJQWpCdkM7UUFvQlcsaUJBQVksR0FBRyxLQUFLLENBQUE7UUFDcEIsZUFBVSxHQUFHLEVBQUUsQ0FBQTtRQUNmLFNBQUksR0FBRyxFQUFFLENBQUE7UUFDbEIsYUFBUSxHQUFHLEVBQUUsQ0FBQTtRQUNiLGVBQVUsR0FBRyxJQUFJLENBQUE7S0ErQmxCO0lBN0JDLElBQWEsSUFBSSxDQUFDLEtBQXdDO1FBQ3hELFFBQVEsS0FBSyxFQUFFLENBQUM7WUFDZCxLQUFLLFNBQVM7Z0JBQ1osSUFBSSxDQUFDLFFBQVEsR0FBRyw4Q0FBOEMsQ0FBQTtnQkFDOUQsSUFBSSxDQUFDLElBQUksR0FBRyxZQUFZLENBQUE7Z0JBQ3hCLE1BQUs7WUFDUCxLQUFLLE9BQU87Z0JBQ1YsSUFBSSxDQUFDLFFBQVE7b0JBQ1gsMERBQTBELENBQUE7Z0JBQzVELElBQUksQ0FBQyxJQUFJLEdBQUcsZ0JBQWdCLENBQUE7Z0JBQzVCLE1BQUs7WUFDUCxLQUFLLFdBQVcsQ0FBQztZQUNqQjtnQkFDRSxJQUFJLENBQUMsUUFBUSxHQUFHLHdEQUF3RCxDQUFBO2dCQUN4RSxJQUFJLENBQUMsSUFBSSxHQUFHLHdCQUF3QixDQUFBO2dCQUNwQyxNQUFLO1FBQ1QsQ0FBQztJQUNILENBQUM7SUFFRCxJQUFJLFNBQVM7UUFDWCxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxHQUFHLEdBQUcsRUFBRSxDQUFDO1lBQzlCLE9BQU8sR0FBRyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxVQUFVLGdDQUFnQyxDQUFBO1FBQzVFLENBQUM7UUFDRCxPQUFPLEdBQUcsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsVUFBVSxlQUFlLENBQUE7SUFDM0QsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQTtJQUN6QixDQUFDOytHQXJDVSwwQkFBMEI7bUdBQTFCLDBCQUEwQiwyTUFWMUI7WUFDVCxZQUFZLENBQUM7Z0JBQ1gsc0JBQXNCO2dCQUN0QixjQUFjO2dCQUNkLGVBQWU7Z0JBQ2YsVUFBVTthQUNYLENBQUM7WUFDRixvQkFBb0IsQ0FBQyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQztTQUN4QywwQkM3QkgscXhCQXlCQSx5RERSWSxZQUFZLGlPQUFFLGVBQWU7OzRGQWM1QiwwQkFBMEI7a0JBakJ0QyxTQUFTOytCQUNFLDBCQUEwQixjQUN4QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLG1CQUN2Qix1QkFBdUIsQ0FBQyxNQUFNLGFBR3BDO3dCQUNULFlBQVksQ0FBQzs0QkFDWCxzQkFBc0I7NEJBQ3RCLGNBQWM7NEJBQ2QsZUFBZTs0QkFDZixVQUFVO3lCQUNYLENBQUM7d0JBQ0Ysb0JBQW9CLENBQUMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUM7cUJBQ3hDOzhCQUdRLE9BQU87c0JBQWYsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFJTyxJQUFJO3NCQUFoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHtcbiAgTmdJY29uQ29tcG9uZW50LFxuICBwcm92aWRlSWNvbnMsXG4gIHByb3ZpZGVOZ0ljb25zQ29uZmlnLFxufSBmcm9tICdAbmctaWNvbnMvY29yZSdcbmltcG9ydCB7XG4gIG1hdENsb3NlT3V0bGluZSxcbiAgbWF0SW5mb091dGxpbmUsXG4gIG1hdFdhcm5pbmdBbWJlck91dGxpbmUsXG59IGZyb20gJ0BuZy1pY29ucy9tYXRlcmlhbC1pY29ucy9vdXRsaW5lJ1xuaW1wb3J0IHsgbWF0V2FybmluZyB9IGZyb20gJ0BuZy1pY29ucy9tYXRlcmlhbC1pY29ucy9iYXNlbGluZSdcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ24tdWktYXBwbGljYXRpb24tYmFubmVyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmdJY29uQ29tcG9uZW50XSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHRlbXBsYXRlVXJsOiAnLi9hcHBsaWNhdGlvbi1iYW5uZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudC5jc3MnLFxuICBwcm92aWRlcnM6IFtcbiAgICBwcm92aWRlSWNvbnMoe1xuICAgICAgbWF0V2FybmluZ0FtYmVyT3V0bGluZSxcbiAgICAgIG1hdEluZm9PdXRsaW5lLFxuICAgICAgbWF0Q2xvc2VPdXRsaW5lLFxuICAgICAgbWF0V2FybmluZyxcbiAgICB9KSxcbiAgICBwcm92aWRlTmdJY29uc0NvbmZpZyh7IHNpemU6ICcxLjVlbScgfSksXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEFwcGxpY2F0aW9uQmFubmVyQ29tcG9uZW50IHtcbiAgQElucHV0KCkgbWVzc2FnZTogc3RyaW5nXG4gIEBJbnB1dCgpIHRpdGxlOiBzdHJpbmdcbiAgQElucHV0KCkgY2xvc2VFbmFibGVkID0gZmFsc2VcbiAgQElucHV0KCkgZXh0cmFDbGFzcyA9ICcnXG4gIEBJbnB1dCgpIGljb24gPSAnJ1xuICBtc2dDbGFzcyA9ICcnXG4gIGJhbm5lck9wZW4gPSB0cnVlXG5cbiAgQElucHV0KCkgc2V0IHR5cGUodmFsdWU6ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ2xpZ2h0Jykge1xuICAgIHN3aXRjaCAodmFsdWUpIHtcbiAgICAgIGNhc2UgJ3ByaW1hcnknOlxuICAgICAgICB0aGlzLm1zZ0NsYXNzID0gJ2JnLXByaW1hcnktZGFya2VzdCBib3JkZXItcHJpbWFyeSB0ZXh0LXdoaXRlJ1xuICAgICAgICB0aGlzLmljb24gPSAnbWF0V2FybmluZydcbiAgICAgICAgYnJlYWtcbiAgICAgIGNhc2UgJ2xpZ2h0JzpcbiAgICAgICAgdGhpcy5tc2dDbGFzcyA9XG4gICAgICAgICAgJ2JnLXByaW1hcnktb3BhY2l0eS0xMCBib3JkZXItcHJpbWFyeS1saWdodGVzdCB0ZXh0LWJsYWNrJ1xuICAgICAgICB0aGlzLmljb24gPSAnbWF0SW5mb091dGxpbmUnXG4gICAgICAgIGJyZWFrXG4gICAgICBjYXNlICdzZWNvbmRhcnknOlxuICAgICAgZGVmYXVsdDpcbiAgICAgICAgdGhpcy5tc2dDbGFzcyA9ICdiZy1wcmltYXJ5LW9wYWNpdHktNTAgYm9yZGVyLXByaW1hcnktZGFya2VyIHRleHQtYmxhY2snXG4gICAgICAgIHRoaXMuaWNvbiA9ICdtYXRXYXJuaW5nQW1iZXJPdXRsaW5lJ1xuICAgICAgICBicmVha1xuICAgIH1cbiAgfVxuXG4gIGdldCBjbGFzc0xpc3QoKSB7XG4gICAgaWYgKHRoaXMubWVzc2FnZS5sZW5ndGggPiAyMDApIHtcbiAgICAgIHJldHVybiBgJHt0aGlzLm1zZ0NsYXNzfSAke3RoaXMuZXh0cmFDbGFzc30gb3ZlcmZsb3cteS1zY3JvbGwgaXRlbXMtc3RhcnRgXG4gICAgfVxuICAgIHJldHVybiBgJHt0aGlzLm1zZ0NsYXNzfSAke3RoaXMuZXh0cmFDbGFzc30gaXRlbXMtY2VudGVyYFxuICB9XG5cbiAgY2xvc2VNZXNzYWdlKCkge1xuICAgIHRoaXMuYmFubmVyT3BlbiA9IGZhbHNlXG4gIH1cbn1cbiIsIjxkaXZcbiAgKm5nSWY9XCJtZXNzYWdlICYmIGJhbm5lck9wZW5cIlxuICBjbGFzcz1cImFic29sdXRlIGxlZnQtMCByaWdodC0wIHRleHQtd3JhcCBiZy13aGl0ZSBtdC00IG1heC1oLTI0XCJcbj5cbiAgPGRpdlxuICAgIGNsYXNzPVwiZmxleCBmbGV4LXJvdyBweS0yLjUgcHgtNSBnYXAtNSBqdXN0aWZ5LXN0YXJ0IGJvcmRlciBtYXgtaC0yMFwiXG4gICAgW25nQ2xhc3NdPVwiY2xhc3NMaXN0XCJcbiAgPlxuICAgIDxkaXYgW25nQ2xhc3NdPVwibWVzc2FnZS5sZW5ndGggPiAyMDAgPyAncHQtNScgOiAncHQtMSdcIj5cbiAgICAgIDxuZy1pY29uIFtuYW1lXT1cImljb25cIj48L25nLWljb24+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1jb2wganVzdGlmeS1zdGFydCBnYXAtMi41XCI+XG4gICAgICA8c3BhbiAqbmdJZj1cInRpdGxlXCIgY2xhc3M9XCJmb250LWJvbGRcIj57eyB0aXRsZSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuIGNsYXNzPVwiZm9udC1tZWRpdW0gbWF4LXctMnhsXCIgW2lubmVySFRNTF09XCJtZXNzYWdlXCI+PC9zcGFuPlxuICAgIDwvZGl2PlxuICAgIDxidXR0b25cbiAgICAgICpuZ0lmPVwiY2xvc2VFbmFibGVkXCJcbiAgICAgIGNsYXNzPVwic2VsZi1zdGFydFwiXG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIChjbGljayk9XCJjbG9zZU1lc3NhZ2UoKVwiXG4gICAgPlxuICAgICAgPG5nLWljb24gbmFtZT1cIm1hdENsb3NlT3V0bGluZVwiPiA8L25nLWljb24+XG4gICAgPC9idXR0b24+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -110,6 +110,7 @@ export class RecordApiFormComponent {
|
|
|
110
110
|
maxFeatures: limit !== '-1' ? Number(limit) : undefined,
|
|
111
111
|
limit: limit !== '-1' ? Number(limit) : -1,
|
|
112
112
|
offset: offset !== '' ? Number(offset) : undefined,
|
|
113
|
+
outputCrs: format === ('application/json' || 'geojson') ? 'EPSG:4326' : undefined,
|
|
113
114
|
};
|
|
114
115
|
if (this.endpoint instanceof WfsEndpoint) {
|
|
115
116
|
delete options.limit;
|
|
@@ -135,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
135
136
|
}], propDecorators: { apiLink: [{
|
|
136
137
|
type: Input
|
|
137
138
|
}] } });
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-api-form.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts","../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core'\nimport { MimeType, OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client'\nimport {\n  DatasetServiceDistribution,\n  ServiceProtocol,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { mimeTypeToFormat } from '../../../../../../libs/util/shared/src'\nimport { BehaviorSubject, combineLatest, filter, map, switchMap } from 'rxjs'\nimport {\n  CopyTextButtonComponent,\n  DropdownChoice,\n  DropdownSelectorComponent,\n  TextInputComponent,\n} from '../../../../../../libs/ui/inputs/src'\nimport { CommonModule } from '@angular/common'\nimport { TranslateModule } from '@ngx-translate/core'\n\nconst DEFAULT_PARAMS = {\n  OFFSET: '',\n  LIMIT: '-1',\n  FORMAT: 'application/json',\n}\n\n@Component({\n  selector: 'gn-ui-record-api-form',\n  templateUrl: './record-api-form.component.html',\n  styleUrls: ['./record-api-form.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TextInputComponent,\n    DropdownSelectorComponent,\n    CopyTextButtonComponent,\n    TranslateModule,\n  ],\n})\nexport class RecordApiFormComponent {\n  @Input() set apiLink(value: DatasetServiceDistribution) {\n    this.outputFormats = [{ value: 'application/json', label: 'JSON' }]\n    this.accessServiceProtocol = value ? value.accessServiceProtocol : undefined\n    this.apiFeatureType = value ? value.name : undefined\n    if (value) {\n      this.apiBaseUrl = value.url.href\n      this.createEndpoint().then(() => this.parseOutputFormats())\n    }\n    this.resetUrl()\n  }\n\n  offset$ = new BehaviorSubject(DEFAULT_PARAMS.OFFSET)\n  limit$ = new BehaviorSubject(DEFAULT_PARAMS.LIMIT)\n  format$ = new BehaviorSubject(DEFAULT_PARAMS.FORMAT)\n  endpoint$ = new BehaviorSubject<WfsEndpoint | OgcApiEndpoint | undefined>(\n    undefined\n  )\n  apiBaseUrl: string\n  apiFeatureType: string\n  supportOffset = true\n  accessServiceProtocol: ServiceProtocol | undefined\n  outputFormats: DropdownChoice[] = [\n    { value: 'application/json', label: 'JSON' },\n  ]\n  endpoint: WfsEndpoint | OgcApiEndpoint | undefined\n\n  apiQueryUrl$ = combineLatest([\n    this.offset$,\n    this.limit$,\n    this.format$,\n    // only compute the url if the endpoint was created\n    this.endpoint$.pipe(filter((endpoint) => !!endpoint)),\n  ]).pipe(\n    switchMap(([offset, limit, format]) =>\n      this.generateApiQueryUrl(offset, limit, format)\n    )\n  )\n\n  noLimitChecked$ = this.limit$.pipe(\n    map((limit) => limit === '-1' || limit === '')\n  )\n  displayLimit$ = this.limit$.pipe(\n    map((limit) => (limit !== '-1' ? limit : ''))\n  )\n\n  setOffset(value: string) {\n    this.offset$.next(value)\n  }\n\n  setLimit(value: string) {\n    this.limit$.next(value === '' ? '-1' : value)\n  }\n\n  setFormat(value: string | unknown) {\n    this.format$.next(String(value))\n  }\n\n  resetUrl() {\n    this.offset$.next(DEFAULT_PARAMS.OFFSET)\n    this.limit$.next(DEFAULT_PARAMS.LIMIT)\n    this.format$.next(DEFAULT_PARAMS.FORMAT)\n  }\n\n  async parseOutputFormats() {\n    if (!this.endpoint) return\n    const outputFormats = (await this.getOutputFormats()).map(\n      this.mimeTypeToFormatName\n    )\n\n    this.outputFormats = this.outputFormats\n      .concat(outputFormats.filter(Boolean))\n      .filter(\n        (format, index, self) =>\n          index === self.findIndex((t) => t.value === format.value)\n      )\n      .sort((a, b) => a.label.localeCompare(b.label))\n  }\n\n  mimeTypeToFormatName(mimeType: MimeType): DropdownChoice | null {\n    const formatName = mimeTypeToFormat(mimeType)\n    return formatName\n      ? { label: formatName.toUpperCase(), value: mimeType }\n      : null\n  }\n\n  async getOutputFormats(): Promise<MimeType[]> {\n    if (!this.endpoint) return []\n    if (this.endpoint instanceof WfsEndpoint) {\n      this.supportOffset = this.endpoint.supportsStartIndex()\n      return this.endpoint.getServiceInfo().outputFormats\n    } else {\n      return (await this.endpoint.getCollectionInfo(this.apiFeatureType))\n        .itemFormats\n    }\n  }\n\n  async createEndpoint() {\n    if (!this.apiBaseUrl || !this.accessServiceProtocol) return\n    if (this.accessServiceProtocol === 'wfs') {\n      this.endpoint = new WfsEndpoint(this.apiBaseUrl)\n      await (this.endpoint as WfsEndpoint).isReady()\n    } else {\n      this.endpoint = new OgcApiEndpoint(this.apiBaseUrl)\n      const collections = await this.endpoint.allCollections\n      // if there's only one collection, use this instead of the name given in the link.\n      if (collections.length === 1) {\n        this.apiFeatureType = collections[0].name\n      }\n    }\n    this.endpoint$.next(this.endpoint)\n  }\n\n  async generateApiQueryUrl(\n    offset: string,\n    limit: string,\n    format: string\n  ): Promise<string> {\n    if (!this.apiBaseUrl || !this.endpoint || !this.apiFeatureType) return ''\n\n    const options = {\n      outputFormat: format,\n      startIndex: offset ? Number(offset) : undefined,\n      maxFeatures: limit !== '-1' ? Number(limit) : undefined,\n      limit: limit !== '-1' ? Number(limit) : -1,\n      offset: offset !== '' ? Number(offset) : undefined,\n    }\n\n    if (this.endpoint instanceof WfsEndpoint) {\n      delete options.limit\n      options.maxFeatures = limit !== '-1' ? Number(limit) : undefined\n      return this.endpoint.getFeatureUrl(this.apiFeatureType, options)\n    } else {\n      return await this.endpoint.getCollectionItemsUrl(\n        this.apiFeatureType,\n        options\n      )\n    }\n  }\n}\n","<div class=\"flex flex-col gap-8\">\n  <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n    <div class=\"flex flex-row\">\n      <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n        record.metadata.api.form.create\n      </div>\n      <button\n        (click)=\"resetUrl()\"\n        class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n      >\n        <p class=\"text-[13px] uppercase\" translate>\n          record.metadata.api.form.reset\n        </p>\n      </button>\n    </div>\n    <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n        <div class=\"flex flex-row items-center gap-2\">\n          <gn-ui-text-input\n            class=\"mr-2 w-20\"\n            (valueChange)=\"setLimit($event)\"\n            [value]=\"displayLimit$ | async\"\n            placeholder=\"\"\n          >\n          </gn-ui-text-input>\n          <div class=\"flex items-center\">\n            <input\n              class=\"mr-2 cursor-pointer\"\n              type=\"checkbox\"\n              [checked]=\"noLimitChecked$ | async\"\n              (change)=\"setLimit('-1')\"\n            />\n            <span class=\"text-sm\" translate\n              >record.metadata.api.form.limit.all</span\n            >\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3 relative\">\n        <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n          record.metadata.api.form.offset\n        </p>\n        <div class=\"flex items-center\">\n          <gn-ui-text-input\n            class=\"w-20\"\n            [value]=\"offset$ | async\"\n            [disabled]=\"!supportOffset\"\n            (valueChange)=\"supportOffset ? setOffset($event) : null\"\n            placeholder=\"\"\n          >\n          </gn-ui-text-input>\n          <div\n            *ngIf=\"!supportOffset\"\n            class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n          >\n            <span\n              class=\"material-symbols-outlined\"\n              matTooltip=\"Not supported on this service\"\n            >\n              warning\n            </span>\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n        <gn-ui-dropdown-selector\n          #dropdown\n          [title]=\"''\"\n          extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n          [showTitle]=\"false\"\n          class=\"text-black\"\n          [choices]=\"outputFormats\"\n          (selectValue)=\"setFormat($event)\"\n          [selected]=\"format$ | async\"\n        ></gn-ui-dropdown-selector>\n      </div>\n    </div>\n  </div>\n  <div class=\"flex flex-col gap-3 mb-3\">\n    <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n      record.metadata.api.form.customUrl\n    </div>\n    <div class=\"bg-white rounded-lg\">\n      <gn-ui-copy-text-button\n        [text]=\"apiQueryUrl$ | async\"\n      ></gn-ui-copy-text-button>\n    </div>\n  </div>\n</div>\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-api-form.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts","../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core'\nimport { MimeType, OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client'\nimport {\n  DatasetServiceDistribution,\n  ServiceProtocol,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { mimeTypeToFormat } from '../../../../../../libs/util/shared/src'\nimport { BehaviorSubject, combineLatest, filter, map, switchMap } from 'rxjs'\nimport {\n  CopyTextButtonComponent,\n  DropdownChoice,\n  DropdownSelectorComponent,\n  TextInputComponent,\n} from '../../../../../../libs/ui/inputs/src'\nimport { CommonModule } from '@angular/common'\nimport { TranslateModule } from '@ngx-translate/core'\n\nconst DEFAULT_PARAMS = {\n  OFFSET: '',\n  LIMIT: '-1',\n  FORMAT: 'application/json',\n}\n\n@Component({\n  selector: 'gn-ui-record-api-form',\n  templateUrl: './record-api-form.component.html',\n  styleUrls: ['./record-api-form.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TextInputComponent,\n    DropdownSelectorComponent,\n    CopyTextButtonComponent,\n    TranslateModule,\n  ],\n})\nexport class RecordApiFormComponent {\n  @Input() set apiLink(value: DatasetServiceDistribution) {\n    this.outputFormats = [{ value: 'application/json', label: 'JSON' }]\n    this.accessServiceProtocol = value ? value.accessServiceProtocol : undefined\n    this.apiFeatureType = value ? value.name : undefined\n    if (value) {\n      this.apiBaseUrl = value.url.href\n      this.createEndpoint().then(() => this.parseOutputFormats())\n    }\n    this.resetUrl()\n  }\n\n  offset$ = new BehaviorSubject(DEFAULT_PARAMS.OFFSET)\n  limit$ = new BehaviorSubject(DEFAULT_PARAMS.LIMIT)\n  format$ = new BehaviorSubject(DEFAULT_PARAMS.FORMAT)\n  endpoint$ = new BehaviorSubject<WfsEndpoint | OgcApiEndpoint | undefined>(\n    undefined\n  )\n  apiBaseUrl: string\n  apiFeatureType: string\n  supportOffset = true\n  accessServiceProtocol: ServiceProtocol | undefined\n  outputFormats: DropdownChoice[] = [\n    { value: 'application/json', label: 'JSON' },\n  ]\n  endpoint: WfsEndpoint | OgcApiEndpoint | undefined\n\n  apiQueryUrl$ = combineLatest([\n    this.offset$,\n    this.limit$,\n    this.format$,\n    // only compute the url if the endpoint was created\n    this.endpoint$.pipe(filter((endpoint) => !!endpoint)),\n  ]).pipe(\n    switchMap(([offset, limit, format]) =>\n      this.generateApiQueryUrl(offset, limit, format)\n    )\n  )\n\n  noLimitChecked$ = this.limit$.pipe(\n    map((limit) => limit === '-1' || limit === '')\n  )\n  displayLimit$ = this.limit$.pipe(\n    map((limit) => (limit !== '-1' ? limit : ''))\n  )\n\n  setOffset(value: string) {\n    this.offset$.next(value)\n  }\n\n  setLimit(value: string) {\n    this.limit$.next(value === '' ? '-1' : value)\n  }\n\n  setFormat(value: string | unknown) {\n    this.format$.next(String(value))\n  }\n\n  resetUrl() {\n    this.offset$.next(DEFAULT_PARAMS.OFFSET)\n    this.limit$.next(DEFAULT_PARAMS.LIMIT)\n    this.format$.next(DEFAULT_PARAMS.FORMAT)\n  }\n\n  async parseOutputFormats() {\n    if (!this.endpoint) return\n    const outputFormats = (await this.getOutputFormats()).map(\n      this.mimeTypeToFormatName\n    )\n\n    this.outputFormats = this.outputFormats\n      .concat(outputFormats.filter(Boolean))\n      .filter(\n        (format, index, self) =>\n          index === self.findIndex((t) => t.value === format.value)\n      )\n      .sort((a, b) => a.label.localeCompare(b.label))\n  }\n\n  mimeTypeToFormatName(mimeType: MimeType): DropdownChoice | null {\n    const formatName = mimeTypeToFormat(mimeType)\n    return formatName\n      ? { label: formatName.toUpperCase(), value: mimeType }\n      : null\n  }\n\n  async getOutputFormats(): Promise<MimeType[]> {\n    if (!this.endpoint) return []\n    if (this.endpoint instanceof WfsEndpoint) {\n      this.supportOffset = this.endpoint.supportsStartIndex()\n      return this.endpoint.getServiceInfo().outputFormats\n    } else {\n      return (await this.endpoint.getCollectionInfo(this.apiFeatureType))\n        .itemFormats\n    }\n  }\n\n  async createEndpoint() {\n    if (!this.apiBaseUrl || !this.accessServiceProtocol) return\n    if (this.accessServiceProtocol === 'wfs') {\n      this.endpoint = new WfsEndpoint(this.apiBaseUrl)\n      await (this.endpoint as WfsEndpoint).isReady()\n    } else {\n      this.endpoint = new OgcApiEndpoint(this.apiBaseUrl)\n      const collections = await this.endpoint.allCollections\n      // if there's only one collection, use this instead of the name given in the link.\n      if (collections.length === 1) {\n        this.apiFeatureType = collections[0].name\n      }\n    }\n    this.endpoint$.next(this.endpoint)\n  }\n\n  async generateApiQueryUrl(\n    offset: string,\n    limit: string,\n    format: string\n  ): Promise<string> {\n    if (!this.apiBaseUrl || !this.endpoint || !this.apiFeatureType) return ''\n\n    const options = {\n      outputFormat: format,\n      startIndex: offset ? Number(offset) : undefined,\n      maxFeatures: limit !== '-1' ? Number(limit) : undefined,\n      limit: limit !== '-1' ? Number(limit) : -1,\n      offset: offset !== '' ? Number(offset) : undefined,\n      outputCrs:\n        format === ('application/json' || 'geojson') ? 'EPSG:4326' : undefined,\n    }\n\n    if (this.endpoint instanceof WfsEndpoint) {\n      delete options.limit\n      options.maxFeatures = limit !== '-1' ? Number(limit) : undefined\n      return this.endpoint.getFeatureUrl(this.apiFeatureType, options)\n    } else {\n      return await this.endpoint.getCollectionItemsUrl(\n        this.apiFeatureType,\n        options\n      )\n    }\n  }\n}\n","<div class=\"flex flex-col gap-8\">\n  <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n    <div class=\"flex flex-row\">\n      <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n        record.metadata.api.form.create\n      </div>\n      <button\n        (click)=\"resetUrl()\"\n        class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n      >\n        <p class=\"text-[13px] uppercase\" translate>\n          record.metadata.api.form.reset\n        </p>\n      </button>\n    </div>\n    <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n        <div class=\"flex flex-row items-center gap-2\">\n          <gn-ui-text-input\n            class=\"mr-2 w-20\"\n            (valueChange)=\"setLimit($event)\"\n            [value]=\"displayLimit$ | async\"\n            placeholder=\"\"\n          >\n          </gn-ui-text-input>\n          <div class=\"flex items-center\">\n            <input\n              class=\"mr-2 cursor-pointer\"\n              type=\"checkbox\"\n              [checked]=\"noLimitChecked$ | async\"\n              (change)=\"setLimit('-1')\"\n            />\n            <span class=\"text-sm\" translate\n              >record.metadata.api.form.limit.all</span\n            >\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3 relative\">\n        <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n          record.metadata.api.form.offset\n        </p>\n        <div class=\"flex items-center\">\n          <gn-ui-text-input\n            class=\"w-20\"\n            [value]=\"offset$ | async\"\n            [disabled]=\"!supportOffset\"\n            (valueChange)=\"supportOffset ? setOffset($event) : null\"\n            placeholder=\"\"\n          >\n          </gn-ui-text-input>\n          <div\n            *ngIf=\"!supportOffset\"\n            class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n          >\n            <span\n              class=\"material-symbols-outlined\"\n              matTooltip=\"Not supported on this service\"\n            >\n              warning\n            </span>\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n        <gn-ui-dropdown-selector\n          #dropdown\n          [title]=\"''\"\n          extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n          [showTitle]=\"false\"\n          class=\"text-black\"\n          [choices]=\"outputFormats\"\n          (selectValue)=\"setFormat($event)\"\n          [selected]=\"format$ | async\"\n        ></gn-ui-dropdown-selector>\n      </div>\n    </div>\n  </div>\n  <div class=\"flex flex-col gap-3 mb-3\">\n    <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n      record.metadata.api.form.customUrl\n    </div>\n    <div class=\"bg-white rounded-lg\">\n      <gn-ui-copy-text-button\n        [text]=\"apiQueryUrl$ | async\"\n      ></gn-ui-copy-text-button>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -15,6 +15,7 @@ import { MarkdownParserComponent } from './markdown-parser/markdown-parser.compo
|
|
|
15
15
|
import { ThumbnailComponent } from './thumbnail/thumbnail.component';
|
|
16
16
|
import { TimeSincePipe } from './user-feedback-item/time-since.pipe';
|
|
17
17
|
import { UserPreviewComponent } from './user-preview/user-preview.component';
|
|
18
|
+
import { ApplicationBannerComponent } from './application-banner/application-banner.component';
|
|
18
19
|
import * as i0 from "@angular/core";
|
|
19
20
|
import * as i1 from "@ngx-translate/core";
|
|
20
21
|
export class UiElementsModule {
|
|
@@ -34,11 +35,13 @@ export class UiElementsModule {
|
|
|
34
35
|
BadgeComponent,
|
|
35
36
|
MaxLinesComponent,
|
|
36
37
|
TextInputComponent,
|
|
37
|
-
ImageInputComponent
|
|
38
|
+
ImageInputComponent,
|
|
39
|
+
ApplicationBannerComponent], exports: [ThumbnailComponent,
|
|
38
40
|
AvatarComponent,
|
|
39
41
|
UserPreviewComponent,
|
|
40
42
|
MarkdownParserComponent,
|
|
41
|
-
ImageInputComponent
|
|
43
|
+
ImageInputComponent,
|
|
44
|
+
ApplicationBannerComponent] }); }
|
|
42
45
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiElementsModule, providers: [
|
|
43
46
|
provideNgIconsConfig({
|
|
44
47
|
size: '1.5em',
|
|
@@ -57,7 +60,8 @@ export class UiElementsModule {
|
|
|
57
60
|
BadgeComponent,
|
|
58
61
|
MaxLinesComponent,
|
|
59
62
|
TextInputComponent,
|
|
60
|
-
ImageInputComponent
|
|
63
|
+
ImageInputComponent,
|
|
64
|
+
ApplicationBannerComponent] }); }
|
|
61
65
|
}
|
|
62
66
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiElementsModule, decorators: [{
|
|
63
67
|
type: NgModule,
|
|
@@ -81,6 +85,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
81
85
|
MaxLinesComponent,
|
|
82
86
|
TextInputComponent,
|
|
83
87
|
ImageInputComponent,
|
|
88
|
+
ApplicationBannerComponent,
|
|
84
89
|
],
|
|
85
90
|
providers: [
|
|
86
91
|
provideNgIconsConfig({
|
|
@@ -94,7 +99,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
94
99
|
UserPreviewComponent,
|
|
95
100
|
MarkdownParserComponent,
|
|
96
101
|
ImageInputComponent,
|
|
102
|
+
ApplicationBannerComponent,
|
|
97
103
|
],
|
|
98
104
|
}]
|
|
99
105
|
}] });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZWxlbWVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9lbGVtZW50cy9zcmMvbGliL3VpLWVsZW1lbnRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDaEUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFDNUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUE7QUFDNUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFDTCxjQUFjLEVBQ2Qsa0JBQWtCLEVBQ2xCLGNBQWMsR0FDZixNQUFNLG1DQUFtQyxDQUFBO0FBQzFDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxjQUFjLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQTtBQUNyRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0NBQW9DLENBQUE7QUFDdEYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUNBQXFDLENBQUE7QUFDdEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFDckQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3JELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQTtBQUMzRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQTtBQUN6RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQTtBQUNyRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQTtBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0NBQXNDLENBQUE7QUFDcEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUE7QUFDNUUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sbURBQW1ELENBQUE7OztBQXVDOUYsTUFBTSxPQUFPLGdCQUFnQjsrR0FBaEIsZ0JBQWdCO2dIQUFoQixnQkFBZ0IsaUJBVlosZUFBZSxFQUFFLG9CQUFvQixhQXpCbEQsWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixlQUFlO1lBQ2YsY0FBYyxzQkFFZCxnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLGNBQWM7WUFDZCxXQUFXO1lBQ1gsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUNoQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixjQUFjO1lBQ2QsaUJBQWlCO1lBQ2pCLGtCQUFrQjtZQUNsQixtQkFBbUI7WUFDbkIsMEJBQTBCLGFBUzFCLGtCQUFrQjtZQUNsQixlQUFlO1lBQ2Ysb0JBQW9CO1lBQ3BCLHVCQUF1QjtZQUN2QixtQkFBbUI7WUFDbkIsMEJBQTBCO2dIQUdqQixnQkFBZ0IsYUFmaEI7WUFDVCxvQkFBb0IsQ0FBQztnQkFDbkIsSUFBSSxFQUFFLE9BQU87YUFDZCxDQUFDO1NBQ0gsWUF4QkMsWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixlQUFlO1lBQ2YsY0FBYztZQUNkLGVBQWUsQ0FBQyxRQUFRLEVBQUU7WUFDMUIsZ0JBQWdCO1lBQ2hCLFlBQVk7WUFDWixjQUFjO1lBQ2QsV0FBVztZQUVYLGdCQUFnQjtZQUVoQixrQkFBa0I7WUFFbEIsY0FBYztZQUNkLGlCQUFpQjtZQUNqQixrQkFBa0I7WUFDbEIsbUJBQW1CO1lBQ25CLDBCQUEwQjs7NEZBaUJqQixnQkFBZ0I7a0JBckM1QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsZUFBZTt3QkFDZixjQUFjO3dCQUNkLGVBQWUsQ0FBQyxRQUFRLEVBQUU7d0JBQzFCLGdCQUFnQjt3QkFDaEIsWUFBWTt3QkFDWixjQUFjO3dCQUNkLFdBQVc7d0JBQ1gsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLHVCQUF1Qjt3QkFDdkIsa0JBQWtCO3dCQUNsQixhQUFhO3dCQUNiLGNBQWM7d0JBQ2QsaUJBQWlCO3dCQUNqQixrQkFBa0I7d0JBQ2xCLG1CQUFtQjt3QkFDbkIsMEJBQTBCO3FCQUMzQjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1Qsb0JBQW9CLENBQUM7NEJBQ25CLElBQUksRUFBRSxPQUFPO3lCQUNkLENBQUM7cUJBQ0g7b0JBQ0QsWUFBWSxFQUFFLENBQUMsZUFBZSxFQUFFLG9CQUFvQixDQUFDO29CQUNyRCxPQUFPLEVBQUU7d0JBQ1Asa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLG9CQUFvQjt3QkFDcEIsdUJBQXVCO3dCQUN2QixtQkFBbUI7d0JBQ25CLDBCQUEwQjtxQkFDM0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUsIE5nT3B0aW1pemVkSW1hZ2UgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJ1xuaW1wb3J0IHsgTWF0VG9vbHRpcE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXAnXG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInXG5pbXBvcnQge1xuICBCYWRnZUNvbXBvbmVudCxcbiAgVGV4dElucHV0Q29tcG9uZW50LFxuICBVaUlucHV0c01vZHVsZSxcbn0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vbGlicy91aS9pbnB1dHMvc3JjJ1xuaW1wb3J0IHsgTWF4TGluZXNDb21wb25lbnQsIFVpTGF5b3V0TW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vbGlicy91aS9sYXlvdXQvc3JjJ1xuaW1wb3J0IHsgUG9wb3ZlckNvbXBvbmVudCwgVWlXaWRnZXRzTW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vbGlicy91aS93aWRnZXRzL3NyYydcbmltcG9ydCB7IFV0aWxTaGFyZWRNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9saWJzL3V0aWwvc2hhcmVkL3NyYydcbmltcG9ydCB7IHByb3ZpZGVOZ0ljb25zQ29uZmlnIH0gZnJvbSAnQG5nLWljb25zL2NvcmUnXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJ1xuaW1wb3J0IHsgQXZhdGFyQ29tcG9uZW50IH0gZnJvbSAnLi9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudCdcbmltcG9ydCB7IEltYWdlSW5wdXRDb21wb25lbnQgfSBmcm9tICcuL2ltYWdlLWlucHV0L2ltYWdlLWlucHV0LmNvbXBvbmVudCdcbmltcG9ydCB7IE1hcmtkb3duUGFyc2VyQ29tcG9uZW50IH0gZnJvbSAnLi9tYXJrZG93bi1wYXJzZXIvbWFya2Rvd24tcGFyc2VyLmNvbXBvbmVudCdcbmltcG9ydCB7IFRodW1ibmFpbENvbXBvbmVudCB9IGZyb20gJy4vdGh1bWJuYWlsL3RodW1ibmFpbC5jb21wb25lbnQnXG5pbXBvcnQgeyBUaW1lU2luY2VQaXBlIH0gZnJvbSAnLi91c2VyLWZlZWRiYWNrLWl0ZW0vdGltZS1zaW5jZS5waXBlJ1xuaW1wb3J0IHsgVXNlclByZXZpZXdDb21wb25lbnQgfSBmcm9tICcuL3VzZXItcHJldmlldy91c2VyLXByZXZpZXcuY29tcG9uZW50J1xuaW1wb3J0IHsgQXBwbGljYXRpb25CYW5uZXJDb21wb25lbnQgfSBmcm9tICcuL2FwcGxpY2F0aW9uLWJhbm5lci9hcHBsaWNhdGlvbi1iYW5uZXIuY29tcG9uZW50J1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE1hdFRvb2x0aXBNb2R1bGUsXG4gICAgVWlXaWRnZXRzTW9kdWxlLFxuICAgIFVpTGF5b3V0TW9kdWxlLFxuICAgIFRyYW5zbGF0ZU1vZHVsZS5mb3JDaGlsZCgpLFxuICAgIFV0aWxTaGFyZWRNb2R1bGUsXG4gICAgUm91dGVyTW9kdWxlLFxuICAgIFVpSW5wdXRzTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIE5nT3B0aW1pemVkSW1hZ2UsXG4gICAgUG9wb3ZlckNvbXBvbmVudCxcbiAgICBNYXJrZG93blBhcnNlckNvbXBvbmVudCxcbiAgICBUaHVtYm5haWxDb21wb25lbnQsXG4gICAgVGltZVNpbmNlUGlwZSxcbiAgICBCYWRnZUNvbXBvbmVudCxcbiAgICBNYXhMaW5lc0NvbXBvbmVudCxcbiAgICBUZXh0SW5wdXRDb21wb25lbnQsXG4gICAgSW1hZ2VJbnB1dENvbXBvbmVudCxcbiAgICBBcHBsaWNhdGlvbkJhbm5lckNvbXBvbmVudCxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAgcHJvdmlkZU5nSWNvbnNDb25maWcoe1xuICAgICAgc2l6ZTogJzEuNWVtJyxcbiAgICB9KSxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbQXZhdGFyQ29tcG9uZW50LCBVc2VyUHJldmlld0NvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtcbiAgICBUaHVtYm5haWxDb21wb25lbnQsXG4gICAgQXZhdGFyQ29tcG9uZW50LFxuICAgIFVzZXJQcmV2aWV3Q29tcG9uZW50LFxuICAgIE1hcmtkb3duUGFyc2VyQ29tcG9uZW50LFxuICAgIEltYWdlSW5wdXRDb21wb25lbnQsXG4gICAgQXBwbGljYXRpb25CYW5uZXJDb21wb25lbnQsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFVpRWxlbWVudHNNb2R1bGUge31cbiJdfQ==
|
|
@@ -58,7 +58,12 @@ export class AutocompleteComponent {
|
|
|
58
58
|
const suggestionsFromAction = merge(newValue$.pipe(filter((value) => value.length >= this.minCharacterCount)), externalValueChange$).pipe(tap(() => {
|
|
59
59
|
this.searching = true;
|
|
60
60
|
this.error = null;
|
|
61
|
-
}), switchMap((value) => this.action(value)),
|
|
61
|
+
}), switchMap((value) => this.action(value)), tap((suggestions) => {
|
|
62
|
+
// forcing the panel to open if there are suggestions
|
|
63
|
+
if (suggestions.length > 0) {
|
|
64
|
+
this.triggerRef?.openPanel();
|
|
65
|
+
}
|
|
66
|
+
}), catchError((error) => {
|
|
62
67
|
this.error = error.message;
|
|
63
68
|
return of([]);
|
|
64
69
|
}), finalize(() => (this.searching = false)));
|
|
@@ -199,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
199
204
|
}], displayWithFn: [{
|
|
200
205
|
type: Input
|
|
201
206
|
}] } });
|
|
202
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts","../../../../../../../../libs/ui/inputs/src/lib/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core'\nimport { ReactiveFormsModule, UntypedFormControl } from '@angular/forms'\nimport {\n  MatAutocomplete,\n  MatAutocompleteModule,\n  MatAutocompleteSelectedEvent,\n  MatAutocompleteTrigger,\n} from '@angular/material/autocomplete'\nimport { first, merge, Observable, of, ReplaySubject, Subscription } from 'rxjs'\nimport {\n  catchError,\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  finalize,\n  map,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs/operators'\nimport { PopupAlertComponent } from '../../../../../../libs/ui/widgets/src'\nimport { CommonModule } from '@angular/common'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { ButtonComponent } from '../button/button.component'\nimport {\n  NgIconComponent,\n  provideIcons,\n  provideNgIconsConfig,\n} from '@ng-icons/core'\nimport { iconoirSearch } from '@ng-icons/iconoir'\nimport { matClose } from '@ng-icons/material-icons/baseline'\n\nexport type AutocompleteItem = unknown\n\n@Component({\n  selector: 'gn-ui-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    PopupAlertComponent,\n    MatAutocompleteModule,\n    CommonModule,\n    TranslateModule,\n    ReactiveFormsModule,\n    ButtonComponent,\n    NgIconComponent,\n  ],\n  providers: [\n    provideIcons({\n      iconoirSearch,\n      matClose,\n    }),\n    provideNgIconsConfig({\n      size: '1.5rem',\n    }),\n  ],\n})\nexport class AutocompleteComponent\n  implements OnInit, AfterViewInit, OnDestroy, OnChanges\n{\n  @Input() placeholder: string\n  @Input() action: (value: string) => Observable<AutocompleteItem[]>\n  @Input() value?: AutocompleteItem\n  @Input() clearOnSelection = false\n  @Input() preventCompleteOnSelection = false\n  @Input() autoFocus = false\n  @Input() minCharacterCount? = 3\n  // this will show a submit button next to the input; if false, a search icon will appear on the left\n  @Input() allowSubmit = false\n  @Output() itemSelected = new EventEmitter<AutocompleteItem>()\n  @Output() inputSubmitted = new EventEmitter<string>()\n  @Output() inputCleared = new EventEmitter<void>()\n  @ViewChild(MatAutocompleteTrigger) triggerRef: MatAutocompleteTrigger\n  @ViewChild(MatAutocomplete) autocomplete: MatAutocomplete\n  @ViewChild('searchInput') inputRef: ElementRef<HTMLInputElement>\n\n  searching: boolean\n  control = new UntypedFormControl()\n  cancelEnter = true\n  selectionSubject = new ReplaySubject<MatAutocompleteSelectedEvent>(1)\n  lastInputValue$ = new ReplaySubject<string>(1)\n  error: string | null = null\n  suggestions$: Observable<AutocompleteItem[]>\n  subscription = new Subscription()\n\n  @Input() displayWithFn: (item: AutocompleteItem) => string = (item) =>\n    item.toString()\n\n  displayWithFnInternal = (item?: AutocompleteItem) => {\n    if (item === null || item === undefined) return null\n    return this.displayWithFn(item)\n  }\n\n  constructor(private cdRef: ChangeDetectorRef) {}\n  ngOnChanges(changes: SimpleChanges): void {\n    const { value } = changes\n    if (value) {\n      const previousTextValue = this.displayWithFnInternal(value.previousValue)\n      const currentTextValue = this.displayWithFnInternal(value.currentValue)\n      if (previousTextValue !== currentTextValue) {\n        this.updateInputValue(value.currentValue)\n      }\n    }\n  }\n\n  ngOnInit(): void {\n    const newValue$ = merge(\n      of(''),\n      this.inputCleared.pipe(map(() => '')),\n      this.control.valueChanges.pipe(\n        filter((value) => typeof value === 'string'),\n        distinctUntilChanged(),\n        debounceTime(400)\n      )\n    )\n\n    const externalValueChange$ = this.control.valueChanges.pipe(\n      filter((value) => typeof value === 'object' && value.title),\n      map((item) => item.title)\n    )\n\n    // this observable emits arrays of suggestions loaded using the given action\n    const suggestionsFromAction = merge(\n      newValue$.pipe(\n        filter((value: string) => value.length >= this.minCharacterCount)\n      ),\n      externalValueChange$\n    ).pipe(\n      tap(() => {\n        this.searching = true\n        this.error = null\n      }),\n      switchMap((value) => this.action(value)),\n      catchError((error: Error) => {\n        this.error = error.message\n        return of([])\n      }),\n      finalize(() => (this.searching = false))\n    )\n\n    this.suggestions$ = merge(\n      suggestionsFromAction,\n      // if a new value is under the min char count, clear suggestions\n      newValue$.pipe(\n        filter((value: string) => value.length < this.minCharacterCount),\n        map(() => [])\n      )\n    )\n\n    // close the panel whenever suggestions are cleared\n    this.subscription.add(\n      this.suggestions$\n        .pipe(filter((suggestions) => suggestions.length === 0))\n        .subscribe(() => {\n          this.triggerRef?.closePanel()\n        })\n    )\n\n    this.subscription.add(\n      this.control.valueChanges.subscribe((any) => {\n        if (any !== '') {\n          this.cancelEnter = false\n        }\n      })\n    )\n\n    this.control.valueChanges\n      .pipe(filter((value) => typeof value === 'string'))\n      .subscribe(this.lastInputValue$)\n  }\n\n  ngAfterViewInit(): void {\n    this.autocomplete.optionSelected.subscribe(this.selectionSubject)\n    if (this.autoFocus) {\n      this.inputRef.nativeElement.focus()\n      this.cdRef.detectChanges()\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscription?.unsubscribe()\n  }\n\n  updateInputValue(value: AutocompleteItem) {\n    if (value) {\n      this.control.setValue(value)\n    }\n    if (this.inputRef) {\n      this.inputRef.nativeElement.value = (value as any)?.title || ''\n    }\n  }\n\n  clear(): void {\n    this.inputRef.nativeElement.value = ''\n    this.inputCleared.emit()\n    this.selectionSubject\n      .pipe(take(1))\n      .subscribe((selection) => selection && selection.option.deselect())\n    this.inputRef.nativeElement.focus()\n  }\n\n  handleEnter(any: string) {\n    if (!this.cancelEnter && this.allowSubmit) {\n      this.inputSubmitted.emit(any)\n    }\n  }\n\n  handleClickSearch() {\n    this.inputSubmitted.emit(this.inputRef.nativeElement.value)\n  }\n\n  /**\n   * This function is triggered when an item is selected in the list of displayed items.\n   * If preventCompleteOnSelection is true then the input will be left as entered by the user.\n   * If preventCompleteOnSelection is false (by default) then the input will be completed with the item selected by the user.\n   * If clearOnSelection is true then the input will be cleared upon selection.\n   * @param event\n   */\n  handleSelection(event: MatAutocompleteSelectedEvent) {\n    this.cancelEnter = true\n    this.itemSelected.emit(event.option.value)\n    if (this.preventCompleteOnSelection) {\n      this.lastInputValue$.pipe(first()).subscribe((lastInputValue) => {\n        this.inputRef.nativeElement.value = lastInputValue\n      })\n      return\n    }\n    if (this.clearOnSelection) {\n      this.inputRef.nativeElement.value = ''\n      this.control.setValue('')\n    }\n  }\n}\n","<span class=\"w-full inline-block relative\">\n  <div\n    class=\"absolute inset-y-[--icon-padding] left-[--icon-padding] w-[--icon-width] pointer-events-none\"\n    *ngIf=\"!allowSubmit\"\n  >\n    <ng-icon name=\"iconoirSearch\" class=\"text-primary search\"></ng-icon>\n  </div>\n  <input\n    #searchInput\n    type=\"text\"\n    class=\"gn-ui-text-input\"\n    [ngClass]=\"{\n      'px-[--icon-width]': !allowSubmit,\n    }\"\n    [placeholder]=\"placeholder\"\n    [formControl]=\"control\"\n    [matAutocomplete]=\"auto\"\n    (keyup.enter)=\"handleEnter(searchInput.value)\"\n  />\n  <gn-ui-button\n    type=\"light\"\n    extraClass=\"border-0 text-primary-lightest hover:text-primary focus:text-primary absolute inset-y-[--icon-padding] {{\n      allowSubmit\n        ? 'right-[calc(var(--icon-width)+var(--icon-padding))]'\n        : 'right-[--icon-padding]'\n    }}\"\n    data-test=\"clear-btn\"\n    *ngIf=\"searchInput.value\"\n    aria-label=\"Clear\"\n    (buttonClick)=\"clear()\"\n  >\n    <ng-icon name=\"matClose\"></ng-icon>\n  </gn-ui-button>\n  <gn-ui-button\n    type=\"light\"\n    extraClass=\"border-0 border-l-[1px] border-gray-300 hover:border-gray-500 text-primary hover:text-primary-darkest focus:text-primary-darkest absolute inset-y-[--icon-padding] right-[--icon-padding]\"\n    aria-label=\"Trigger search\"\n    *ngIf=\"allowSubmit\"\n    data-test=\"autocomplete-submit-btn\"\n    (buttonClick)=\"handleClickSearch()\"\n  >\n    <ng-icon name=\"iconoirSearch\"></ng-icon>\n  </gn-ui-button>\n\n  <gn-ui-popup-alert\n    *ngIf=\"error\"\n    class=\"absolute mt-2 w-full top-[100%] left-0\"\n    icon=\"matErrorOutlineOutline\"\n    position=\"top\"\n    type=\"warning\"\n  >\n    <span translate>search.autocomplete.error</span>\n    {{ error }}\n  </gn-ui-popup-alert>\n</span>\n\n<mat-autocomplete\n  #auto=\"matAutocomplete\"\n  (optionSelected)=\"handleSelection($event)\"\n  [displayWith]=\"displayWithFnInternal\"\n>\n  <mat-option\n    *ngFor=\"let suggestion of suggestions$ | async\"\n    [value]=\"suggestion\"\n    class=\"p-2 suggestion\"\n  >\n    {{ displayWithFnInternal(suggestion) }}\n  </mat-option>\n</mat-autocomplete>\n"]}
|
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts","../../../../../../../../libs/ui/inputs/src/lib/autocomplete/autocomplete.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EAIL,MAAM,EAEN,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AACxE,OAAO,EACL,eAAe,EACf,qBAAqB,EAErB,sBAAsB,GACvB,MAAM,gCAAgC,CAAA;AACvC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAc,EAAE,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAChF,OAAO,EACL,UAAU,EACV,YAAY,EACZ,oBAAoB,EACpB,MAAM,EACN,QAAQ,EACR,GAAG,EACH,SAAS,EACT,IAAI,EACJ,GAAG,GACJ,MAAM,gBAAgB,CAAA;AACvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAA;AAC3E,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EACL,eAAe,EACf,YAAY,EACZ,oBAAoB,GACrB,MAAM,gBAAgB,CAAA;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAA;;;;;;;AA6B5D,MAAM,OAAO,qBAAqB;IAoChC,YAAoB,KAAwB;QAAxB,UAAK,GAAL,KAAK,CAAmB;QA9BnC,qBAAgB,GAAG,KAAK,CAAA;QACxB,+BAA0B,GAAG,KAAK,CAAA;QAClC,cAAS,GAAG,KAAK,CAAA;QACjB,sBAAiB,GAAI,CAAC,CAAA;QAC/B,oGAAoG;QAC3F,gBAAW,GAAG,KAAK,CAAA;QAClB,iBAAY,GAAG,IAAI,YAAY,EAAoB,CAAA;QACnD,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAA;QAC3C,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAA;QAMjD,YAAO,GAAG,IAAI,kBAAkB,EAAE,CAAA;QAClC,gBAAW,GAAG,IAAI,CAAA;QAClB,qBAAgB,GAAG,IAAI,aAAa,CAA+B,CAAC,CAAC,CAAA;QACrE,oBAAe,GAAG,IAAI,aAAa,CAAS,CAAC,CAAC,CAAA;QAC9C,UAAK,GAAkB,IAAI,CAAA;QAE3B,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAA;QAExB,kBAAa,GAAuC,CAAC,IAAI,EAAE,EAAE,CACpE,IAAI,CAAC,QAAQ,EAAE,CAAA;QAEjB,0BAAqB,GAAG,CAAC,IAAuB,EAAE,EAAE;YAClD,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS;gBAAE,OAAO,IAAI,CAAA;YACpD,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAA;QACjC,CAAC,CAAA;IAE8C,CAAC;IAChD,WAAW,CAAC,OAAsB;QAChC,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAA;QACzB,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,iBAAiB,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;YACzE,MAAM,gBAAgB,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;YACvE,IAAI,iBAAiB,KAAK,gBAAgB,EAAE,CAAC;gBAC3C,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;YAC3C,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ;QACN,MAAM,SAAS,GAAG,KAAK,CACrB,EAAE,CAAC,EAAE,CAAC,EACN,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,EACrC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAC5B,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC,EAC5C,oBAAoB,EAAE,EACtB,YAAY,CAAC,GAAG,CAAC,CAClB,CACF,CAAA;QAED,MAAM,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CACzD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,KAAK,CAAC,EAC3D,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAC1B,CAAA;QAED,4EAA4E;QAC5E,MAAM,qBAAqB,GAAG,KAAK,CACjC,SAAS,CAAC,IAAI,CACZ,MAAM,CAAC,CAAC,KAAa,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAClE,EACD,oBAAoB,CACrB,CAAC,IAAI,CACJ,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,SAAS,GAAG,IAAI,CAAA;YACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;QACnB,CAAC,CAAC,EACF,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EACxC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE;YAClB,qDAAqD;YACrD,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC3B,IAAI,CAAC,UAAU,EAAE,SAAS,EAAE,CAAA;YAC9B,CAAC;QACH,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAY,EAAE,EAAE;YAC1B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAA;YAC1B,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;QACf,CAAC,CAAC,EACF,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CACzC,CAAA;QAED,IAAI,CAAC,YAAY,GAAG,KAAK,CACvB,qBAAqB;QACrB,gEAAgE;QAChE,SAAS,CAAC,IAAI,CACZ,MAAM,CAAC,CAAC,KAAa,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,EAChE,GAAG,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CACd,CACF,CAAA;QAED,mDAAmD;QACnD,IAAI,CAAC,YAAY,CAAC,GAAG,CACnB,IAAI,CAAC,YAAY;aACd,IAAI,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;aACvD,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,UAAU,EAAE,UAAU,EAAE,CAAA;QAC/B,CAAC,CAAC,CACL,CAAA;QAED,IAAI,CAAC,YAAY,CAAC,GAAG,CACnB,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YAC1C,IAAI,GAAG,KAAK,EAAE,EAAE,CAAC;gBACf,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;YAC1B,CAAC;QACH,CAAC,CAAC,CACH,CAAA;QAED,IAAI,CAAC,OAAO,CAAC,YAAY;aACtB,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC;aAClD,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAA;IACpC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;QACjE,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAA;YACnC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAA;QAC5B,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,EAAE,WAAW,EAAE,CAAA;IAClC,CAAC;IAED,gBAAgB,CAAC,KAAuB;QACtC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QAC9B,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,GAAI,KAAa,EAAE,KAAK,IAAI,EAAE,CAAA;QACjE,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAA;QACtC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAA;QACxB,IAAI,CAAC,gBAAgB;aAClB,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACb,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,IAAI,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAA;QACrE,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAA;IACrC,CAAC;IAED,WAAW,CAAC,GAAW;QACrB,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YAC1C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC/B,CAAC;IACH,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;IAC7D,CAAC;IAED;;;;;;OAMG;IACH,eAAe,CAAC,KAAmC;QACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAC1C,IAAI,IAAI,CAAC,0BAA0B,EAAE,CAAC;YACpC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,cAAc,EAAE,EAAE;gBAC9D,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,GAAG,cAAc,CAAA;YACpD,CAAC,CAAC,CAAA;YACF,OAAM;QACR,CAAC;QACD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAA;YACtC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAC3B,CAAC;IACH,CAAC;+GApLU,qBAAqB;mGAArB,qBAAqB,kdAVrB;YACT,YAAY,CAAC;gBACX,aAAa;gBACb,QAAQ;aACT,CAAC;YACF,oBAAoB,CAAC;gBACnB,IAAI,EAAE,QAAQ;aACf,CAAC;SACH,sEAiBU,sBAAsB,+EACtB,eAAe,+JCzF5B,soEAqEA,4sBDdI,mBAAmB,mGACnB,qBAAqB,w1BACrB,YAAY,kZACZ,eAAe,qKACf,mBAAmB,0kBACnB,eAAe,+HACf,eAAe;;4FAYN,qBAAqB;kBAzBjC,SAAS;+BACE,oBAAoB,mBAGb,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,mBAAmB;wBACnB,qBAAqB;wBACrB,YAAY;wBACZ,eAAe;wBACf,mBAAmB;wBACnB,eAAe;wBACf,eAAe;qBAChB,aACU;wBACT,YAAY,CAAC;4BACX,aAAa;4BACb,QAAQ;yBACT,CAAC;wBACF,oBAAoB,CAAC;4BACnB,IAAI,EAAE,QAAQ;yBACf,CAAC;qBACH;sFAKQ,WAAW;sBAAnB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,0BAA0B;sBAAlC,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBACI,YAAY;sBAArB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBAC4B,UAAU;sBAA5C,SAAS;uBAAC,sBAAsB;gBACL,YAAY;sBAAvC,SAAS;uBAAC,eAAe;gBACA,QAAQ;sBAAjC,SAAS;uBAAC,aAAa;gBAWf,aAAa;sBAArB,KAAK","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core'\nimport { ReactiveFormsModule, UntypedFormControl } from '@angular/forms'\nimport {\n  MatAutocomplete,\n  MatAutocompleteModule,\n  MatAutocompleteSelectedEvent,\n  MatAutocompleteTrigger,\n} from '@angular/material/autocomplete'\nimport { first, merge, Observable, of, ReplaySubject, Subscription } from 'rxjs'\nimport {\n  catchError,\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  finalize,\n  map,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs/operators'\nimport { PopupAlertComponent } from '../../../../../../libs/ui/widgets/src'\nimport { CommonModule } from '@angular/common'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { ButtonComponent } from '../button/button.component'\nimport {\n  NgIconComponent,\n  provideIcons,\n  provideNgIconsConfig,\n} from '@ng-icons/core'\nimport { iconoirSearch } from '@ng-icons/iconoir'\nimport { matClose } from '@ng-icons/material-icons/baseline'\n\nexport type AutocompleteItem = unknown\n\n@Component({\n  selector: 'gn-ui-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    PopupAlertComponent,\n    MatAutocompleteModule,\n    CommonModule,\n    TranslateModule,\n    ReactiveFormsModule,\n    ButtonComponent,\n    NgIconComponent,\n  ],\n  providers: [\n    provideIcons({\n      iconoirSearch,\n      matClose,\n    }),\n    provideNgIconsConfig({\n      size: '1.5rem',\n    }),\n  ],\n})\nexport class AutocompleteComponent\n  implements OnInit, AfterViewInit, OnDestroy, OnChanges\n{\n  @Input() placeholder: string\n  @Input() action: (value: string) => Observable<AutocompleteItem[]>\n  @Input() value?: AutocompleteItem\n  @Input() clearOnSelection = false\n  @Input() preventCompleteOnSelection = false\n  @Input() autoFocus = false\n  @Input() minCharacterCount? = 3\n  // this will show a submit button next to the input; if false, a search icon will appear on the left\n  @Input() allowSubmit = false\n  @Output() itemSelected = new EventEmitter<AutocompleteItem>()\n  @Output() inputSubmitted = new EventEmitter<string>()\n  @Output() inputCleared = new EventEmitter<void>()\n  @ViewChild(MatAutocompleteTrigger) triggerRef: MatAutocompleteTrigger\n  @ViewChild(MatAutocomplete) autocomplete: MatAutocomplete\n  @ViewChild('searchInput') inputRef: ElementRef<HTMLInputElement>\n\n  searching: boolean\n  control = new UntypedFormControl()\n  cancelEnter = true\n  selectionSubject = new ReplaySubject<MatAutocompleteSelectedEvent>(1)\n  lastInputValue$ = new ReplaySubject<string>(1)\n  error: string | null = null\n  suggestions$: Observable<AutocompleteItem[]>\n  subscription = new Subscription()\n\n  @Input() displayWithFn: (item: AutocompleteItem) => string = (item) =>\n    item.toString()\n\n  displayWithFnInternal = (item?: AutocompleteItem) => {\n    if (item === null || item === undefined) return null\n    return this.displayWithFn(item)\n  }\n\n  constructor(private cdRef: ChangeDetectorRef) {}\n  ngOnChanges(changes: SimpleChanges): void {\n    const { value } = changes\n    if (value) {\n      const previousTextValue = this.displayWithFnInternal(value.previousValue)\n      const currentTextValue = this.displayWithFnInternal(value.currentValue)\n      if (previousTextValue !== currentTextValue) {\n        this.updateInputValue(value.currentValue)\n      }\n    }\n  }\n\n  ngOnInit(): void {\n    const newValue$ = merge(\n      of(''),\n      this.inputCleared.pipe(map(() => '')),\n      this.control.valueChanges.pipe(\n        filter((value) => typeof value === 'string'),\n        distinctUntilChanged(),\n        debounceTime(400)\n      )\n    )\n\n    const externalValueChange$ = this.control.valueChanges.pipe(\n      filter((value) => typeof value === 'object' && value.title),\n      map((item) => item.title)\n    )\n\n    // this observable emits arrays of suggestions loaded using the given action\n    const suggestionsFromAction = merge(\n      newValue$.pipe(\n        filter((value: string) => value.length >= this.minCharacterCount)\n      ),\n      externalValueChange$\n    ).pipe(\n      tap(() => {\n        this.searching = true\n        this.error = null\n      }),\n      switchMap((value) => this.action(value)),\n      tap((suggestions) => {\n        // forcing the panel to open if there are suggestions\n        if (suggestions.length > 0) {\n          this.triggerRef?.openPanel()\n        }\n      }),\n      catchError((error: Error) => {\n        this.error = error.message\n        return of([])\n      }),\n      finalize(() => (this.searching = false))\n    )\n\n    this.suggestions$ = merge(\n      suggestionsFromAction,\n      // if a new value is under the min char count, clear suggestions\n      newValue$.pipe(\n        filter((value: string) => value.length < this.minCharacterCount),\n        map(() => [])\n      )\n    )\n\n    // close the panel whenever suggestions are cleared\n    this.subscription.add(\n      this.suggestions$\n        .pipe(filter((suggestions) => suggestions.length === 0))\n        .subscribe(() => {\n          this.triggerRef?.closePanel()\n        })\n    )\n\n    this.subscription.add(\n      this.control.valueChanges.subscribe((any) => {\n        if (any !== '') {\n          this.cancelEnter = false\n        }\n      })\n    )\n\n    this.control.valueChanges\n      .pipe(filter((value) => typeof value === 'string'))\n      .subscribe(this.lastInputValue$)\n  }\n\n  ngAfterViewInit(): void {\n    this.autocomplete.optionSelected.subscribe(this.selectionSubject)\n    if (this.autoFocus) {\n      this.inputRef.nativeElement.focus()\n      this.cdRef.detectChanges()\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscription?.unsubscribe()\n  }\n\n  updateInputValue(value: AutocompleteItem) {\n    if (value) {\n      this.control.setValue(value)\n    }\n    if (this.inputRef) {\n      this.inputRef.nativeElement.value = (value as any)?.title || ''\n    }\n  }\n\n  clear(): void {\n    this.inputRef.nativeElement.value = ''\n    this.inputCleared.emit()\n    this.selectionSubject\n      .pipe(take(1))\n      .subscribe((selection) => selection && selection.option.deselect())\n    this.inputRef.nativeElement.focus()\n  }\n\n  handleEnter(any: string) {\n    if (!this.cancelEnter && this.allowSubmit) {\n      this.inputSubmitted.emit(any)\n    }\n  }\n\n  handleClickSearch() {\n    this.inputSubmitted.emit(this.inputRef.nativeElement.value)\n  }\n\n  /**\n   * This function is triggered when an item is selected in the list of displayed items.\n   * If preventCompleteOnSelection is true then the input will be left as entered by the user.\n   * If preventCompleteOnSelection is false (by default) then the input will be completed with the item selected by the user.\n   * If clearOnSelection is true then the input will be cleared upon selection.\n   * @param event\n   */\n  handleSelection(event: MatAutocompleteSelectedEvent) {\n    this.cancelEnter = true\n    this.itemSelected.emit(event.option.value)\n    if (this.preventCompleteOnSelection) {\n      this.lastInputValue$.pipe(first()).subscribe((lastInputValue) => {\n        this.inputRef.nativeElement.value = lastInputValue\n      })\n      return\n    }\n    if (this.clearOnSelection) {\n      this.inputRef.nativeElement.value = ''\n      this.control.setValue('')\n    }\n  }\n}\n","<span class=\"w-full inline-block relative\">\n  <div\n    class=\"absolute inset-y-[--icon-padding] left-[--icon-padding] w-[--icon-width] pointer-events-none\"\n    *ngIf=\"!allowSubmit\"\n  >\n    <ng-icon name=\"iconoirSearch\" class=\"text-primary search\"></ng-icon>\n  </div>\n  <input\n    #searchInput\n    type=\"text\"\n    class=\"gn-ui-text-input\"\n    [ngClass]=\"{\n      'px-[--icon-width]': !allowSubmit,\n    }\"\n    [placeholder]=\"placeholder\"\n    [formControl]=\"control\"\n    [matAutocomplete]=\"auto\"\n    (keyup.enter)=\"handleEnter(searchInput.value)\"\n  />\n  <gn-ui-button\n    type=\"light\"\n    extraClass=\"border-0 text-primary-lightest hover:text-primary focus:text-primary absolute inset-y-[--icon-padding] {{\n      allowSubmit\n        ? 'right-[calc(var(--icon-width)+var(--icon-padding))]'\n        : 'right-[--icon-padding]'\n    }}\"\n    data-test=\"clear-btn\"\n    *ngIf=\"searchInput.value\"\n    aria-label=\"Clear\"\n    (buttonClick)=\"clear()\"\n  >\n    <ng-icon name=\"matClose\"></ng-icon>\n  </gn-ui-button>\n  <gn-ui-button\n    type=\"light\"\n    extraClass=\"border-0 border-l-[1px] border-gray-300 hover:border-gray-500 text-primary hover:text-primary-darkest focus:text-primary-darkest absolute inset-y-[--icon-padding] right-[--icon-padding]\"\n    aria-label=\"Trigger search\"\n    *ngIf=\"allowSubmit\"\n    data-test=\"autocomplete-submit-btn\"\n    (buttonClick)=\"handleClickSearch()\"\n  >\n    <ng-icon name=\"iconoirSearch\"></ng-icon>\n  </gn-ui-button>\n\n  <gn-ui-popup-alert\n    *ngIf=\"error\"\n    class=\"absolute mt-2 w-full top-[100%] left-0\"\n    icon=\"matErrorOutlineOutline\"\n    position=\"top\"\n    type=\"warning\"\n  >\n    <span translate>search.autocomplete.error</span>\n    {{ error }}\n  </gn-ui-popup-alert>\n</span>\n\n<mat-autocomplete\n  #auto=\"matAutocomplete\"\n  (optionSelected)=\"handleSelection($event)\"\n  [displayWith]=\"displayWithFnInternal\"\n>\n  <mat-option\n    *ngFor=\"let suggestion of suggestions$ | async\"\n    [value]=\"suggestion\"\n    class=\"p-2 suggestion\"\n  >\n    {{ displayWithFnInternal(suggestion) }}\n  </mat-option>\n</mat-autocomplete>\n"]}
|
|
@@ -16,6 +16,7 @@ export class ActionMenuComponent {
|
|
|
16
16
|
this.duplicate = new EventEmitter();
|
|
17
17
|
this.delete = new EventEmitter();
|
|
18
18
|
this.closeActionMenu = new EventEmitter();
|
|
19
|
+
this.rollback = new EventEmitter();
|
|
19
20
|
this.sectionDisplayed = 'mainMenu';
|
|
20
21
|
}
|
|
21
22
|
openMenu() {
|
|
@@ -26,11 +27,16 @@ export class ActionMenuComponent {
|
|
|
26
27
|
this.cdr.markForCheck();
|
|
27
28
|
}
|
|
28
29
|
displayDeleteMenu() {
|
|
29
|
-
this.
|
|
30
|
+
if (this.isDraftPage) {
|
|
31
|
+
this.sectionDisplayed = 'rollbackMenu';
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
this.sectionDisplayed = 'deleteMenu';
|
|
35
|
+
}
|
|
30
36
|
this.cdr.markForCheck();
|
|
31
37
|
}
|
|
32
38
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionMenuComponent, deps: [{ token: i1.MatDialog }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
33
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ActionMenuComponent, isStandalone: true, selector: "gn-ui-action-menu", inputs: { canDuplicate: "canDuplicate", canDelete: "canDelete" }, outputs: { duplicate: "duplicate", delete: "delete", closeActionMenu: "closeActionMenu" }, viewQueries: [{ propertyName: "trigger", first: true, predicate: MatMenuTrigger, descendants: true }], ngImport: i0, template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"mainMenuSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <gn-ui-button\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"duplicate.emit()\"\n [disabled]=\"!canDuplicate\"\n data-test=\"record-menu-duplicate-button\"\n >\n <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n <span *ngIf=\"!canDuplicate\" translate\n >record.action.duplicating</span\n ></gn-ui-button\n >\n <gn-ui-button\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"displayDeleteMenu()\"\n [disabled]=\"!canDelete\"\n data-test=\"record-menu-delete-button\"\n ><span translate>record.action.delete</span></gn-ui-button\n >\n </ul>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'deleteMenu'\">\n <div\n data-test=\"deleteMenuSection\"\n class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.delete.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.delete.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"delete.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'100px'\"\n >{{\n 'editor.record.delete.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'100px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.delete.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: MatDialogModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }] }); }
|
|
39
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ActionMenuComponent, isStandalone: true, selector: "gn-ui-action-menu", inputs: { canDuplicate: "canDuplicate", canDelete: "canDelete", isDraftPage: "isDraftPage" }, outputs: { duplicate: "duplicate", delete: "delete", closeActionMenu: "closeActionMenu", rollback: "rollback" }, viewQueries: [{ propertyName: "trigger", first: true, predicate: MatMenuTrigger, descendants: true }], ngImport: i0, template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"mainMenuSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <gn-ui-button\n *ngIf=\"!isDraftPage\"\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"duplicate.emit()\"\n [disabled]=\"!canDuplicate\"\n data-test=\"record-menu-duplicate-button\"\n >\n <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n <span *ngIf=\"!canDuplicate\" translate\n >record.action.duplicating</span\n ></gn-ui-button\n >\n <gn-ui-button\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"displayDeleteMenu()\"\n [disabled]=\"!canDelete\"\n data-test=\"record-menu-delete-button\"\n ><span *ngIf=\"!isDraftPage\" translate>record.action.delete</span>\n <span *ngIf=\"isDraftPage\" translate\n >record.action.rollback</span\n ></gn-ui-button\n >\n </ul>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'deleteMenu'\">\n <div\n data-test=\"deleteMenuSection\"\n class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.delete.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.delete.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"delete.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'100px'\"\n >{{\n 'editor.record.delete.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'100px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.delete.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'rollbackMenu'\">\n <div\n data-test=\"rollbackMenuSection\"\n class=\"w-80 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.undo.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.undo.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"rollback.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'120px'\"\n >{{\n 'editor.record.undo.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'120px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.undo.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: MatDialogModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }] }); }
|
|
34
40
|
}
|
|
35
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionMenuComponent, decorators: [{
|
|
36
42
|
type: Component,
|
|
@@ -41,19 +47,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
41
47
|
MatDialogModule,
|
|
42
48
|
ConfirmationDialogComponent,
|
|
43
49
|
TranslateModule,
|
|
44
|
-
], template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"mainMenuSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <gn-ui-button\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"duplicate.emit()\"\n [disabled]=\"!canDuplicate\"\n data-test=\"record-menu-duplicate-button\"\n >\n <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n <span *ngIf=\"!canDuplicate\" translate\n >record.action.duplicating</span\n ></gn-ui-button\n >\n <gn-ui-button\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"displayDeleteMenu()\"\n [disabled]=\"!canDelete\"\n data-test=\"record-menu-delete-button\"\n ><span translate>record.action.delete</span></gn-ui-button\n >\n </ul>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'deleteMenu'\">\n <div\n data-test=\"deleteMenuSection\"\n class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.delete.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.delete.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"delete.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'100px'\"\n >{{\n 'editor.record.delete.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'100px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.delete.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n</ng-container>\n" }]
|
|
50
|
+
], template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"mainMenuSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <gn-ui-button\n *ngIf=\"!isDraftPage\"\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"duplicate.emit()\"\n [disabled]=\"!canDuplicate\"\n data-test=\"record-menu-duplicate-button\"\n >\n <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n <span *ngIf=\"!canDuplicate\" translate\n >record.action.duplicating</span\n ></gn-ui-button\n >\n <gn-ui-button\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"displayDeleteMenu()\"\n [disabled]=\"!canDelete\"\n data-test=\"record-menu-delete-button\"\n ><span *ngIf=\"!isDraftPage\" translate>record.action.delete</span>\n <span *ngIf=\"isDraftPage\" translate\n >record.action.rollback</span\n ></gn-ui-button\n >\n </ul>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'deleteMenu'\">\n <div\n data-test=\"deleteMenuSection\"\n class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.delete.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.delete.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"delete.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'100px'\"\n >{{\n 'editor.record.delete.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'100px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.delete.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'rollbackMenu'\">\n <div\n data-test=\"rollbackMenuSection\"\n class=\"w-80 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.undo.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.undo.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"rollback.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'120px'\"\n >{{\n 'editor.record.undo.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'120px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.undo.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n</ng-container>\n" }]
|
|
45
51
|
}], ctorParameters: () => [{ type: i1.MatDialog }, { type: i0.ChangeDetectorRef }], propDecorators: { canDuplicate: [{
|
|
46
52
|
type: Input
|
|
47
53
|
}], canDelete: [{
|
|
48
54
|
type: Input
|
|
55
|
+
}], isDraftPage: [{
|
|
56
|
+
type: Input
|
|
49
57
|
}], duplicate: [{
|
|
50
58
|
type: Output
|
|
51
59
|
}], delete: [{
|
|
52
60
|
type: Output
|
|
53
61
|
}], closeActionMenu: [{
|
|
54
62
|
type: Output
|
|
63
|
+
}], rollback: [{
|
|
64
|
+
type: Output
|
|
55
65
|
}], trigger: [{
|
|
56
66
|
type: ViewChild,
|
|
57
67
|
args: [MatMenuTrigger]
|
|
58
68
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-menu.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/ui/search/src/lib/results-table/action-menu/action-menu.component.ts","../../../../../../../../../libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAA;AACrE,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACtE,OAAO,EAAE,2BAA2B,EAAE,MAAM,2CAA2C,CAAA;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,yCAAyC,CAAA;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;;;;;AAkBrD,MAAM,OAAO,mBAAmB;IAa9B,YACS,MAAiB,EAChB,GAAsB;QADvB,WAAM,GAAN,MAAM,CAAW;QAChB,QAAG,GAAH,GAAG,CAAmB;QAXtB,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAA;QACpC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAA;QACjC,oBAAe,GAAG,IAAI,YAAY,EAAQ,CAAA;QAC1C,aAAQ,GAAG,IAAI,YAAY,EAAQ,CAAA;QAI7C,qBAAgB,GAAmB,UAAU,CAAA;IAK1C,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAA;IACzB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAA;QAClC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAA;IACzB,CAAC;IAED,iBAAiB;QACf,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,gBAAgB,GAAG,cAAc,CAAA;QACxC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAA;QACtC,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAA;IACzB,CAAC;+GAlCU,mBAAmB;mGAAnB,mBAAmB,qUASnB,cAAc,gDCxC3B,qmHAmGA,yDD5EI,YAAY,+TACZ,eAAe,8HACf,aAAa,8BACb,eAAe,8BAEf,eAAe;;4FAGN,mBAAmB;kBAd/B,SAAS;+BACE,mBAAmB,cAGjB,IAAI,WACP;wBACP,YAAY;wBACZ,eAAe;wBACf,aAAa;wBACb,eAAe;wBACf,2BAA2B;wBAC3B,eAAe;qBAChB;8GAGQ,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,SAAS;sBAAlB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBAEoB,OAAO;sBAAjC,SAAS;uBAAC,cAAc","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MatDialog, MatDialogModule } from '@angular/material/dialog'\nimport { MatMenuModule, MatMenuTrigger } from '@angular/material/menu'\nimport { ConfirmationDialogComponent } from '../../../../../../../libs/ui/elements/src'\nimport { ButtonComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { TranslateModule } from '@ngx-translate/core'\n\ntype ActionMenuPage = 'mainMenu' | 'deleteMenu' | 'rollbackMenu'\n\n@Component({\n  selector: 'gn-ui-action-menu',\n  templateUrl: './action-menu.component.html',\n  styleUrls: ['./action-menu.component.css'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    MatMenuModule,\n    MatDialogModule,\n    ConfirmationDialogComponent,\n    TranslateModule,\n  ],\n})\nexport class ActionMenuComponent {\n  @Input() canDuplicate: boolean\n  @Input() canDelete: boolean\n  @Input() isDraftPage: boolean\n  @Output() duplicate = new EventEmitter<void>()\n  @Output() delete = new EventEmitter<void>()\n  @Output() closeActionMenu = new EventEmitter<void>()\n  @Output() rollback = new EventEmitter<void>()\n\n  @ViewChild(MatMenuTrigger) trigger: MatMenuTrigger\n\n  sectionDisplayed: ActionMenuPage = 'mainMenu'\n\n  constructor(\n    public dialog: MatDialog,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  openMenu() {\n    this.trigger.openMenu()\n  }\n\n  displayMainMenu() {\n    this.sectionDisplayed = 'mainMenu'\n    this.cdr.markForCheck()\n  }\n\n  displayDeleteMenu() {\n    if (this.isDraftPage) {\n      this.sectionDisplayed = 'rollbackMenu'\n    } else {\n      this.sectionDisplayed = 'deleteMenu'\n    }\n    this.cdr.markForCheck()\n  }\n}\n","<ng-container [ngSwitch]=\"sectionDisplayed\">\n  <ng-container *ngSwitchCase=\"'mainMenu'\">\n    <div\n      data-test=\"mainMenuSection\"\n      class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n    >\n      <ul class=\"flex flex-col gap-2 w-full\">\n        <gn-ui-button\n          *ngIf=\"!isDraftPage\"\n          type=\"light\"\n          extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n          (buttonClick)=\"duplicate.emit()\"\n          [disabled]=\"!canDuplicate\"\n          data-test=\"record-menu-duplicate-button\"\n        >\n          <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n          <span *ngIf=\"!canDuplicate\" translate\n            >record.action.duplicating</span\n          ></gn-ui-button\n        >\n        <gn-ui-button\n          type=\"light\"\n          extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n          (buttonClick)=\"displayDeleteMenu()\"\n          [disabled]=\"!canDelete\"\n          data-test=\"record-menu-delete-button\"\n          ><span *ngIf=\"!isDraftPage\" translate>record.action.delete</span>\n          <span *ngIf=\"isDraftPage\" translate\n            >record.action.rollback</span\n          ></gn-ui-button\n        >\n      </ul>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'deleteMenu'\">\n    <div\n      data-test=\"deleteMenuSection\"\n      class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n    >\n      <span class=\"text-lg font-bold text-center\">{{\n        'editor.record.delete.confirmation.title' | translate\n      }}</span>\n      <span class=\"text-center\">{{\n        'editor.record.delete.confirmation.message' | translate\n      }}</span>\n      <div class=\"flex flex-row gap-8 justify-center\">\n        <gn-ui-button\n          (buttonClick)=\"delete.emit()\"\n          cdkFocusInitial\n          type=\"primary\"\n          data-cy=\"confirm-button\"\n          [style.--gn-ui-button-width]=\"'100px'\"\n          >{{\n            'editor.record.delete.confirmation.confirmText' | translate\n          }}</gn-ui-button\n        >\n        <gn-ui-button\n          [style.--gn-ui-button-width]=\"'100px'\"\n          (buttonClick)=\"closeActionMenu.emit()\"\n          >{{\n            'editor.record.delete.confirmation.cancelText' | translate\n          }}</gn-ui-button\n        >\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'rollbackMenu'\">\n    <div\n      data-test=\"rollbackMenuSection\"\n      class=\"w-80 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n    >\n      <span class=\"text-lg font-bold text-center\">{{\n        'editor.record.undo.confirmation.title' | translate\n      }}</span>\n      <span class=\"text-center\">{{\n        'editor.record.undo.confirmation.message' | translate\n      }}</span>\n      <div class=\"flex flex-row gap-8 justify-center\">\n        <gn-ui-button\n          (buttonClick)=\"rollback.emit()\"\n          cdkFocusInitial\n          type=\"primary\"\n          data-cy=\"confirm-button\"\n          [style.--gn-ui-button-width]=\"'120px'\"\n          >{{\n            'editor.record.undo.confirmation.confirmText' | translate\n          }}</gn-ui-button\n        >\n        <gn-ui-button\n          [style.--gn-ui-button-width]=\"'120px'\"\n          (buttonClick)=\"closeActionMenu.emit()\"\n          >{{\n            'editor.record.undo.confirmation.cancelText' | translate\n          }}</gn-ui-button\n        >\n      </div>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
|