geonetwork-ui 2.4.1-dev.a1ec7cf5a → 2.4.1-dev.b217f2e40
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/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.mjs +80 -10
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.mjs +4 -3
- package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +5 -3
- package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +7 -2
- package/esm2022/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.mjs +3 -3
- package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +6 -3
- package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +37 -1
- package/esm2022/translations/de.json +3 -0
- package/esm2022/translations/en.json +3 -0
- package/esm2022/translations/es.json +3 -0
- package/esm2022/translations/fr.json +3 -0
- package/esm2022/translations/it.json +3 -0
- package/esm2022/translations/nl.json +3 -0
- package/esm2022/translations/pt.json +3 -0
- package/fesm2022/geonetwork-ui.mjs +153 -18
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.d.ts +44 -5
- package/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.d.ts +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.d.ts.map +1 -1
- package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +2 -1
- package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +1 -1
- package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts +3 -2
- package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts.map +1 -1
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +2 -1
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts +2 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.html +39 -7
- package/src/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.ts +100 -4
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.html +11 -9
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.ts +3 -2
- package/src/libs/feature/search/src/lib/results-table/results-table-container.component.html +1 -0
- package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +1 -0
- package/src/libs/ui/inputs/src/lib/url-input/url-input.component.ts +9 -1
- package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html +5 -1
- package/src/libs/ui/search/src/lib/results-table/results-table.component.html +1 -1
- package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +1 -0
- package/src/libs/util/shared/src/lib/links/link-utils.ts +48 -1
- package/translations/de.json +3 -0
- package/translations/en.json +3 -0
- package/translations/es.json +3 -0
- package/translations/fr.json +3 -0
- package/translations/it.json +3 -0
- package/translations/nl.json +3 -0
- package/translations/pt.json +3 -0
- package/translations/sk.json +3 -0
|
@@ -1,13 +1,15 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
4
|
import { MatRadioModule } from '@angular/material/radio';
|
|
5
5
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
6
6
|
import { marker } from '@biesbjerg/ngx-translate-extract-marker';
|
|
7
|
-
import { ButtonComponent, TextInputComponent, UrlInputComponent, } from '../../../../../../../libs/ui/inputs/src';
|
|
7
|
+
import { AutocompleteComponent, ButtonComponent, TextInputComponent, UrlInputComponent, } from '../../../../../../../libs/ui/inputs/src';
|
|
8
8
|
import { TranslateModule } from '@ngx-translate/core';
|
|
9
9
|
import { NgIconComponent, provideIcons, provideNgIconsConfig, } from '@ng-icons/core';
|
|
10
10
|
import { iconoirCloudUpload } from '@ng-icons/iconoir';
|
|
11
|
+
import { createFuzzyFilter, getLayers } from '../../../../../../../libs/util/shared/src';
|
|
12
|
+
import { BehaviorSubject, debounceTime, distinctUntilChanged, switchMap, } from 'rxjs';
|
|
11
13
|
import * as i0 from "@angular/core";
|
|
12
14
|
import * as i1 from "@angular/common";
|
|
13
15
|
import * as i2 from "@angular/forms";
|
|
@@ -15,10 +17,16 @@ import * as i3 from "@angular/material/tooltip";
|
|
|
15
17
|
import * as i4 from "@angular/material/radio";
|
|
16
18
|
import * as i5 from "@ngx-translate/core";
|
|
17
19
|
export class OnlineServiceResourceInputComponent {
|
|
18
|
-
constructor() {
|
|
20
|
+
constructor(cdr) {
|
|
21
|
+
this.cdr = cdr;
|
|
19
22
|
this.disabled = false;
|
|
23
|
+
this.modifyMode = false;
|
|
20
24
|
this.urlChange = new EventEmitter();
|
|
21
25
|
this.identifierSubmit = new EventEmitter();
|
|
26
|
+
this.errorMessage = false;
|
|
27
|
+
this.url = '';
|
|
28
|
+
this.layersSubject = new BehaviorSubject([]);
|
|
29
|
+
this.layers$ = this.layersSubject.asObservable();
|
|
22
30
|
this.protocolOptions = [
|
|
23
31
|
{
|
|
24
32
|
label: 'OGC API',
|
|
@@ -49,13 +57,58 @@ export class OnlineServiceResourceInputComponent {
|
|
|
49
57
|
value: 'other',
|
|
50
58
|
},
|
|
51
59
|
];
|
|
60
|
+
/**
|
|
61
|
+
* gn-ui-autocomplete
|
|
62
|
+
*/
|
|
63
|
+
this.autoCompleteAction = (query) => {
|
|
64
|
+
const fuzzyFilter = createFuzzyFilter(query);
|
|
65
|
+
return this.layers$.pipe(switchMap((layers) => [
|
|
66
|
+
layers.filter((layer) => fuzzyFilter(layer.name)),
|
|
67
|
+
]), debounceTime(100), distinctUntilChanged());
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
get activeLayerSuggestion() {
|
|
71
|
+
return !['wps', 'GPFDL', 'esriRest', 'other'].includes(this.service.accessServiceProtocol);
|
|
52
72
|
}
|
|
53
73
|
ngOnChanges() {
|
|
54
74
|
this.selectedProtocol =
|
|
55
75
|
this.protocolOptions.find((option) => option.value === this.service.accessServiceProtocol)?.value ?? 'other';
|
|
56
76
|
}
|
|
57
|
-
|
|
77
|
+
ngOnInit() {
|
|
78
|
+
if (this.service.url) {
|
|
79
|
+
this.url = this.service.url.toString();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
handleUrlValueChange(url) {
|
|
58
83
|
this.url = url;
|
|
84
|
+
this.service.url = url ? new URL(url) : undefined;
|
|
85
|
+
this.resetLayersSuggestion();
|
|
86
|
+
this.urlChange.emit(this.url);
|
|
87
|
+
}
|
|
88
|
+
async handleUploadClick(url) {
|
|
89
|
+
this.url = url;
|
|
90
|
+
try {
|
|
91
|
+
const layers = await getLayers(url, this.service.accessServiceProtocol);
|
|
92
|
+
if (layers.length === 0) {
|
|
93
|
+
throw new Error('No layers found');
|
|
94
|
+
}
|
|
95
|
+
this.layersSubject.next([...layers]);
|
|
96
|
+
}
|
|
97
|
+
catch (e) {
|
|
98
|
+
this.errorMessage = true;
|
|
99
|
+
this.layersSubject.next([]);
|
|
100
|
+
}
|
|
101
|
+
this.cdr.detectChanges();
|
|
102
|
+
}
|
|
103
|
+
resetAllFormFields() {
|
|
104
|
+
this.url = '';
|
|
105
|
+
this.service.url = null;
|
|
106
|
+
this.resetLayersSuggestion();
|
|
107
|
+
}
|
|
108
|
+
resetLayersSuggestion() {
|
|
109
|
+
this.errorMessage = false;
|
|
110
|
+
this.layersSubject.next([]);
|
|
111
|
+
this.service.identifierInService = null;
|
|
59
112
|
}
|
|
60
113
|
submitIdentifier(identifier) {
|
|
61
114
|
if (!identifier)
|
|
@@ -69,17 +122,32 @@ export class OnlineServiceResourceInputComponent {
|
|
|
69
122
|
? `${baseKey}.wps`
|
|
70
123
|
: baseKey;
|
|
71
124
|
}
|
|
72
|
-
|
|
73
|
-
|
|
125
|
+
/**
|
|
126
|
+
* gn-ui-autocomplete
|
|
127
|
+
*/
|
|
128
|
+
displayWithFn(item) {
|
|
129
|
+
return item.title
|
|
130
|
+
? `${item.title} ${item.name ? `(${item.name})` : ''}`
|
|
131
|
+
: item.name;
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* gn-ui-autocomplete
|
|
135
|
+
*/
|
|
136
|
+
handleSelectValue(val) {
|
|
137
|
+
this.service.identifierInService = val.name;
|
|
138
|
+
}
|
|
139
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OnlineServiceResourceInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
140
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: OnlineServiceResourceInputComponent, isStandalone: true, selector: "gn-ui-online-service-resource-input", inputs: { service: "service", protocolHint: "protocolHint", disabled: "disabled", modifyMode: "modifyMode" }, outputs: { urlChange: "urlChange", identifierSubmit: "identifierSubmit" }, providers: [
|
|
74
141
|
provideIcons({ iconoirCloudUpload }),
|
|
75
142
|
provideNgIconsConfig({
|
|
76
143
|
size: '1.5em',
|
|
77
144
|
}),
|
|
78
|
-
], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-row justify-between\">\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.protocol\n </h3>\n <span\n *ngIf=\"protocolHint\"\n class=\"material-symbols-outlined m-2 gn-ui-icon-small\"\n [matTooltip]=\"protocolHint\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n</div>\n<div class=\"flex flex-row items-center gap-4 h-[48px]\">\n <mat-radio-group\n aria-labelledby=\"example-radio-group-label\"\n class=\"flex flex-row gap-[8px]\"\n [(ngModel)]=\"service.accessServiceProtocol\"\n [disabled]=\"disabled\"\n >\n <mat-radio-button\n *ngFor=\"let protocolOption of protocolOptions\"\n [value]=\"protocolOption.value\"\n >\n {{ protocolOption.label | translate }}\n </mat-radio-button>\n </mat-radio-group>\n</div>\n\n<div class=\"flex flex-col gap-4\">\n <gn-ui-url-input\n class=\"w-full\"\n (valueChange)=\"
|
|
145
|
+
], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-row justify-between\">\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.protocol\n </h3>\n <span\n *ngIf=\"protocolHint\"\n class=\"material-symbols-outlined m-2 gn-ui-icon-small\"\n [matTooltip]=\"protocolHint\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n</div>\n<div class=\"flex flex-row items-center gap-4 h-[48px]\">\n <mat-radio-group\n aria-labelledby=\"example-radio-group-label\"\n class=\"flex flex-row gap-[8px]\"\n [(ngModel)]=\"service.accessServiceProtocol\"\n [disabled]=\"disabled\"\n (change)=\"resetAllFormFields()\"\n >\n <mat-radio-button\n *ngFor=\"let protocolOption of protocolOptions\"\n [value]=\"protocolOption.value\"\n >\n {{ protocolOption.label | translate }}\n </mat-radio-button>\n </mat-radio-group>\n</div>\n\n<div class=\"flex flex-col gap-4\">\n <gn-ui-url-input\n class=\"w-full\"\n (uploadClick)=\"handleUploadClick($event)\"\n (valueChange)=\"handleUrlValueChange($event)\"\n [disabled]=\"disabled\"\n [value]=\"url\"\n [showValidateButton]=\"activeLayerSuggestion\"\n >\n <ng-content *ngIf=\"activeLayerSuggestion\">\n <ng-icon name=\"iconoirCloudUpload\"></ng-icon>\n </ng-content>\n </gn-ui-url-input>\n\n <p class=\"text-sm text-red-500 pl-4\" *ngIf=\"errorMessage\" translate>\n editor.record.form.field.onlineResource.edit.identifier.error\n </p>\n\n <gn-ui-text-input\n class=\"grow border-b border-gray-300 pb-4\"\n [(value)]=\"service.identifierInService\"\n [placeholder]=\"getIdentifierPlaceholder() | translate\"\n data-cy=\"identifier-in-service\"\n [disabled]=\"disabled\"\n *ngIf=\"\n !activeLayerSuggestion ||\n (url && errorMessage) ||\n (modifyMode && (layers$ | async).length === 0)\n \"\n ></gn-ui-text-input>\n <gn-ui-autocomplete\n class=\"border-b border-gray-300 pb-4\"\n [placeholder]=\"\n 'editor.record.form.field.onlineResource.edit.identifier.select.label'\n | translate\n \"\n [action]=\"autoCompleteAction\"\n (itemSelected)=\"handleSelectValue($event)\"\n [displayWithFn]=\"displayWithFn\"\n [minCharacterCount]=\"0\"\n [clearOnSelection]=\"false\"\n *ngIf=\"activeLayerSuggestion && (layers$ | async)?.length > 0\"\n >\n </gn-ui-autocomplete>\n <gn-ui-button\n (buttonClick)=\"submitIdentifier(service.identifierInService)\"\n [disabled]=\"disabled || !service.identifierInService\"\n type=\"primary\"\n *ngIf=\"\n !modifyMode &&\n ((activeLayerSuggestion && (layers$ | async)) ||\n !activeLayerSuggestion ||\n (url && errorMessage))\n \"\n >\n <span class=\"text-white font-bold\" translate>\n editor.record.form.field.onlineResource.edit.identifier.submit</span\n >\n </gn-ui-button>\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: AutocompleteComponent, selector: "gn-ui-autocomplete", inputs: ["placeholder", "action", "value", "clearOnSelection", "preventCompleteOnSelection", "autoFocus", "minCharacterCount", "allowSubmit", "displayWithFn"], outputs: ["itemSelected", "inputSubmitted", "inputCleared"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatRadioModule }, { kind: "directive", type: i4.MatRadioGroup, selector: "mat-radio-group", inputs: ["color", "name", "labelPosition", "value", "selected", "disabled", "required", "disabledInteractive"], outputs: ["change"], exportAs: ["matRadioGroup"] }, { kind: "component", type: i4.MatRadioButton, selector: "mat-radio-button", inputs: ["id", "name", "aria-label", "aria-labelledby", "aria-describedby", "disableRipple", "tabIndex", "checked", "value", "labelPosition", "disabled", "required", "color", "disabledInteractive"], outputs: ["change"], exportAs: ["matRadioButton"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "component", type: TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "placeholder", "required", "disabled"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "directive", type: i5.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled", "showValidateButton"], outputs: ["valueChange", "uploadClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
79
146
|
}
|
|
80
147
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OnlineServiceResourceInputComponent, decorators: [{
|
|
81
148
|
type: Component,
|
|
82
149
|
args: [{ selector: 'gn-ui-online-service-resource-input', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
150
|
+
AutocompleteComponent,
|
|
83
151
|
ButtonComponent,
|
|
84
152
|
CommonModule,
|
|
85
153
|
FormsModule,
|
|
@@ -94,16 +162,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
94
162
|
provideNgIconsConfig({
|
|
95
163
|
size: '1.5em',
|
|
96
164
|
}),
|
|
97
|
-
], template: "<div class=\"flex flex-row justify-between\">\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.protocol\n </h3>\n <span\n *ngIf=\"protocolHint\"\n class=\"material-symbols-outlined m-2 gn-ui-icon-small\"\n [matTooltip]=\"protocolHint\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n</div>\n<div class=\"flex flex-row items-center gap-4 h-[48px]\">\n <mat-radio-group\n aria-labelledby=\"example-radio-group-label\"\n class=\"flex flex-row gap-[8px]\"\n [(ngModel)]=\"service.accessServiceProtocol\"\n [disabled]=\"disabled\"\n >\n <mat-radio-button\n *ngFor=\"let protocolOption of protocolOptions\"\n [value]=\"protocolOption.value\"\n >\n {{ protocolOption.label | translate }}\n </mat-radio-button>\n </mat-radio-group>\n</div>\n\n<div class=\"flex flex-col gap-4\">\n <gn-ui-url-input\n class=\"w-full\"\n (valueChange)=\"
|
|
98
|
-
}], propDecorators: { service: [{
|
|
165
|
+
], template: "<div class=\"flex flex-row justify-between\">\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.protocol\n </h3>\n <span\n *ngIf=\"protocolHint\"\n class=\"material-symbols-outlined m-2 gn-ui-icon-small\"\n [matTooltip]=\"protocolHint\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n</div>\n<div class=\"flex flex-row items-center gap-4 h-[48px]\">\n <mat-radio-group\n aria-labelledby=\"example-radio-group-label\"\n class=\"flex flex-row gap-[8px]\"\n [(ngModel)]=\"service.accessServiceProtocol\"\n [disabled]=\"disabled\"\n (change)=\"resetAllFormFields()\"\n >\n <mat-radio-button\n *ngFor=\"let protocolOption of protocolOptions\"\n [value]=\"protocolOption.value\"\n >\n {{ protocolOption.label | translate }}\n </mat-radio-button>\n </mat-radio-group>\n</div>\n\n<div class=\"flex flex-col gap-4\">\n <gn-ui-url-input\n class=\"w-full\"\n (uploadClick)=\"handleUploadClick($event)\"\n (valueChange)=\"handleUrlValueChange($event)\"\n [disabled]=\"disabled\"\n [value]=\"url\"\n [showValidateButton]=\"activeLayerSuggestion\"\n >\n <ng-content *ngIf=\"activeLayerSuggestion\">\n <ng-icon name=\"iconoirCloudUpload\"></ng-icon>\n </ng-content>\n </gn-ui-url-input>\n\n <p class=\"text-sm text-red-500 pl-4\" *ngIf=\"errorMessage\" translate>\n editor.record.form.field.onlineResource.edit.identifier.error\n </p>\n\n <gn-ui-text-input\n class=\"grow border-b border-gray-300 pb-4\"\n [(value)]=\"service.identifierInService\"\n [placeholder]=\"getIdentifierPlaceholder() | translate\"\n data-cy=\"identifier-in-service\"\n [disabled]=\"disabled\"\n *ngIf=\"\n !activeLayerSuggestion ||\n (url && errorMessage) ||\n (modifyMode && (layers$ | async).length === 0)\n \"\n ></gn-ui-text-input>\n <gn-ui-autocomplete\n class=\"border-b border-gray-300 pb-4\"\n [placeholder]=\"\n 'editor.record.form.field.onlineResource.edit.identifier.select.label'\n | translate\n \"\n [action]=\"autoCompleteAction\"\n (itemSelected)=\"handleSelectValue($event)\"\n [displayWithFn]=\"displayWithFn\"\n [minCharacterCount]=\"0\"\n [clearOnSelection]=\"false\"\n *ngIf=\"activeLayerSuggestion && (layers$ | async)?.length > 0\"\n >\n </gn-ui-autocomplete>\n <gn-ui-button\n (buttonClick)=\"submitIdentifier(service.identifierInService)\"\n [disabled]=\"disabled || !service.identifierInService\"\n type=\"primary\"\n *ngIf=\"\n !modifyMode &&\n ((activeLayerSuggestion && (layers$ | async)) ||\n !activeLayerSuggestion ||\n (url && errorMessage))\n \"\n >\n <span class=\"text-white font-bold\" translate>\n editor.record.form.field.onlineResource.edit.identifier.submit</span\n >\n </gn-ui-button>\n</div>\n" }]
|
|
166
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { service: [{
|
|
99
167
|
type: Input
|
|
100
168
|
}], protocolHint: [{
|
|
101
169
|
type: Input
|
|
102
170
|
}], disabled: [{
|
|
103
171
|
type: Input
|
|
172
|
+
}], modifyMode: [{
|
|
173
|
+
type: Input
|
|
104
174
|
}], urlChange: [{
|
|
105
175
|
type: Output
|
|
106
176
|
}], identifierSubmit: [{
|
|
107
177
|
type: Output
|
|
108
178
|
}] } });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"online-service-resource-input.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.ts","../../../../../../../../../libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n} from '@angular/core'\nimport { FormsModule } from '@angular/forms'\nimport { MatRadioModule } from '@angular/material/radio'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport {\n  DatasetServiceDistribution,\n  ServiceProtocol,\n} from '../../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  ButtonComponent,\n  TextInputComponent,\n  UrlInputComponent,\n} from '../../../../../../../libs/ui/inputs/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport {\n  NgIconComponent,\n  provideIcons,\n  provideNgIconsConfig,\n} from '@ng-icons/core'\nimport { iconoirCloudUpload } from '@ng-icons/iconoir'\n\n@Component({\n  selector: 'gn-ui-online-service-resource-input',\n  templateUrl: './online-service-resource-input.component.html',\n  styleUrls: ['./online-service-resource-input.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    ButtonComponent,\n    CommonModule,\n    FormsModule,\n    MatTooltipModule,\n    MatRadioModule,\n    NgIconComponent,\n    TextInputComponent,\n    TranslateModule,\n    UrlInputComponent,\n  ],\n  providers: [\n    provideIcons({ iconoirCloudUpload }),\n    provideNgIconsConfig({\n      size: '1.5em',\n    }),\n  ],\n})\nexport class OnlineServiceResourceInputComponent implements OnChanges {\n  @Input() service: Omit<DatasetServiceDistribution, 'url'>\n  @Input() protocolHint?: string\n  @Input() disabled? = false\n  @Output() urlChange: EventEmitter<string> = new EventEmitter()\n  @Output() identifierSubmit: EventEmitter<{\n    url: string\n    identifier: string\n  }> = new EventEmitter()\n\n  selectedProtocol: ServiceProtocol\n  url: string\n\n  protocolOptions: {\n    label: string\n    value: ServiceProtocol\n  }[] = [\n    {\n      label: 'OGC API',\n      value: 'ogcFeatures',\n    },\n    {\n      label: 'WFS',\n      value: 'wfs',\n    },\n    {\n      label: 'WMS',\n      value: 'wms',\n    },\n    {\n      label: 'WMTS',\n      value: 'wmts',\n    },\n    {\n      label: 'WPS',\n      value: 'wps',\n    },\n    {\n      label: 'ESRI REST',\n      value: 'esriRest',\n    },\n    {\n      label: marker('editor.record.onlineResource.protocol.other'),\n      value: 'other',\n    },\n  ]\n\n  ngOnChanges() {\n    this.selectedProtocol =\n      this.protocolOptions.find(\n        (option) => option.value === this.service.accessServiceProtocol\n      )?.value ?? 'other'\n  }\n\n  handleUrlChange(url: string) {\n    this.url = url\n  }\n\n  submitIdentifier(identifier: string) {\n    if (!identifier) return\n    this.identifierSubmit.emit({ url: this.url, identifier })\n    this.service.identifierInService = null\n  }\n\n  getIdentifierPlaceholder(): string {\n    const baseKey =\n      'editor.record.form.field.onlineResource.edit.identifier.placeholder'\n    return this.service.accessServiceProtocol === 'wps'\n      ? `${baseKey}.wps`\n      : baseKey\n  }\n}\n","<div class=\"flex flex-row justify-between\">\n  <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n    editor.record.form.field.onlineResource.edit.protocol\n  </h3>\n  <span\n    *ngIf=\"protocolHint\"\n    class=\"material-symbols-outlined m-2 gn-ui-icon-small\"\n    [matTooltip]=\"protocolHint\"\n    matTooltipPosition=\"above\"\n  >\n    help\n  </span>\n</div>\n<div class=\"flex flex-row items-center gap-4 h-[48px]\">\n  <mat-radio-group\n    aria-labelledby=\"example-radio-group-label\"\n    class=\"flex flex-row gap-[8px]\"\n    [(ngModel)]=\"service.accessServiceProtocol\"\n    [disabled]=\"disabled\"\n  >\n    <mat-radio-button\n      *ngFor=\"let protocolOption of protocolOptions\"\n      [value]=\"protocolOption.value\"\n    >\n      {{ protocolOption.label | translate }}\n    </mat-radio-button>\n  </mat-radio-group>\n</div>\n\n<div class=\"flex flex-col gap-4\">\n  <gn-ui-url-input\n    class=\"w-full\"\n    (valueChange)=\"handleUrlChange($event)\"\n    [disabled]=\"disabled\"\n    [value]=\"url\"\n    [showValidateButton]=\"false\"\n  >\n    <ng-icon name=\"iconoirCloudUpload\"></ng-icon>\n  </gn-ui-url-input>\n\n  <gn-ui-text-input\n    class=\"grow border-b border-gray-300 pb-4\"\n    [(value)]=\"service.identifierInService\"\n    [placeholder]=\"getIdentifierPlaceholder() | translate\"\n    data-cy=\"identifier-in-service\"\n    [disabled]=\"disabled\"\n  ></gn-ui-text-input>\n\n  <gn-ui-button\n    (buttonClick)=\"submitIdentifier(service.identifierInService)\"\n    [disabled]=\"disabled || !service.identifierInService || !url\"\n    type=\"primary\"\n  >\n    <span class=\"text-white font-bold\" translate\n      >editor.record.form.field.onlineResource.edit.identifier.submit</span\n    >\n  </gn-ui-button>\n</div>\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"online-service-resource-input.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.ts","../../../../../../../../../libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n} from '@angular/core'\nimport { FormsModule } from '@angular/forms'\nimport { MatRadioModule } from '@angular/material/radio'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport {\n  DatasetServiceDistribution,\n  ServiceProtocol,\n} from '../../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  AutocompleteComponent,\n  ButtonComponent,\n  TextInputComponent,\n  UrlInputComponent,\n} from '../../../../../../../libs/ui/inputs/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport {\n  NgIconComponent,\n  provideIcons,\n  provideNgIconsConfig,\n} from '@ng-icons/core'\nimport { iconoirCloudUpload } from '@ng-icons/iconoir'\nimport { createFuzzyFilter, getLayers } from '../../../../../../../libs/util/shared/src'\nimport {\n  BehaviorSubject,\n  debounceTime,\n  distinctUntilChanged,\n  map,\n  Observable,\n  switchMap,\n} from 'rxjs'\n\n@Component({\n  selector: 'gn-ui-online-service-resource-input',\n  templateUrl: './online-service-resource-input.component.html',\n  styleUrls: ['./online-service-resource-input.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    AutocompleteComponent,\n    ButtonComponent,\n    CommonModule,\n    FormsModule,\n    MatTooltipModule,\n    MatRadioModule,\n    NgIconComponent,\n    TextInputComponent,\n    TranslateModule,\n    UrlInputComponent,\n  ],\n  providers: [\n    provideIcons({ iconoirCloudUpload }),\n    provideNgIconsConfig({\n      size: '1.5em',\n    }),\n  ],\n})\nexport class OnlineServiceResourceInputComponent implements OnChanges, OnInit {\n  @Input() service: DatasetServiceDistribution\n  @Input() protocolHint?: string\n  @Input() disabled? = false\n  @Input() modifyMode? = false\n  @Output() urlChange: EventEmitter<string> = new EventEmitter()\n  @Output() identifierSubmit: EventEmitter<{\n    url: string\n    identifier: string\n  }> = new EventEmitter()\n\n  errorMessage = false\n  selectedProtocol: ServiceProtocol\n  url = ''\n  layersSubject = new BehaviorSubject<{ name: string; title: string }[]>([])\n  layers$: Observable<{ name: string; title: string }[]> =\n    this.layersSubject.asObservable()\n\n  protocolOptions: {\n    label: string\n    value: ServiceProtocol\n  }[] = [\n    {\n      label: 'OGC API',\n      value: 'ogcFeatures',\n    },\n    {\n      label: 'WFS',\n      value: 'wfs',\n    },\n    {\n      label: 'WMS',\n      value: 'wms',\n    },\n    {\n      label: 'WMTS',\n      value: 'wmts',\n    },\n    {\n      label: 'WPS',\n      value: 'wps',\n    },\n    {\n      label: 'ESRI REST',\n      value: 'esriRest',\n    },\n    {\n      label: marker('editor.record.onlineResource.protocol.other'),\n      value: 'other',\n    },\n  ]\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  get activeLayerSuggestion() {\n    return !['wps', 'GPFDL', 'esriRest', 'other'].includes(\n      this.service.accessServiceProtocol\n    )\n  }\n\n  ngOnChanges() {\n    this.selectedProtocol =\n      this.protocolOptions.find(\n        (option) => option.value === this.service.accessServiceProtocol\n      )?.value ?? 'other'\n  }\n\n  ngOnInit() {\n    if (this.service.url) {\n      this.url = this.service.url.toString()\n    }\n  }\n\n  handleUrlValueChange(url: string) {\n    this.url = url\n    this.service.url = url ? new URL(url) : undefined\n    this.resetLayersSuggestion()\n    this.urlChange.emit(this.url)\n  }\n\n  async handleUploadClick(url: string) {\n    this.url = url\n\n    try {\n      const layers = await getLayers(url, this.service.accessServiceProtocol)\n\n      if (layers.length === 0) {\n        throw new Error('No layers found')\n      }\n\n      this.layersSubject.next([...layers])\n    } catch (e) {\n      this.errorMessage = true\n      this.layersSubject.next([])\n    }\n\n    this.cdr.detectChanges()\n  }\n\n  resetAllFormFields() {\n    this.url = ''\n    this.service.url = null\n    this.resetLayersSuggestion()\n  }\n\n  resetLayersSuggestion() {\n    this.errorMessage = false\n    this.layersSubject.next([])\n    this.service.identifierInService = null\n  }\n\n  submitIdentifier(identifier: string) {\n    if (!identifier) return\n    this.identifierSubmit.emit({ url: this.url, identifier })\n    this.service.identifierInService = null\n  }\n\n  getIdentifierPlaceholder(): string {\n    const baseKey =\n      'editor.record.form.field.onlineResource.edit.identifier.placeholder'\n    return this.service.accessServiceProtocol === 'wps'\n      ? `${baseKey}.wps`\n      : baseKey\n  }\n\n  /**\n   * gn-ui-autocomplete\n   */\n  displayWithFn(item: { name: string; title: string }) {\n    return item.title\n      ? `${item.title} ${item.name ? `(${item.name})` : ''}`\n      : item.name\n  }\n\n  /**\n   * gn-ui-autocomplete\n   */\n  autoCompleteAction = (query: string) => {\n    const fuzzyFilter = createFuzzyFilter(query)\n    return this.layers$.pipe(\n      switchMap((layers) => [\n        layers.filter((layer) => fuzzyFilter(layer.name)),\n      ]),\n      debounceTime(100),\n      distinctUntilChanged()\n    )\n  }\n\n  /**\n   * gn-ui-autocomplete\n   */\n  handleSelectValue(val: { name: string; title: string }) {\n    this.service.identifierInService = val.name\n  }\n}\n","<div class=\"flex flex-row justify-between\">\n  <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n    editor.record.form.field.onlineResource.edit.protocol\n  </h3>\n  <span\n    *ngIf=\"protocolHint\"\n    class=\"material-symbols-outlined m-2 gn-ui-icon-small\"\n    [matTooltip]=\"protocolHint\"\n    matTooltipPosition=\"above\"\n  >\n    help\n  </span>\n</div>\n<div class=\"flex flex-row items-center gap-4 h-[48px]\">\n  <mat-radio-group\n    aria-labelledby=\"example-radio-group-label\"\n    class=\"flex flex-row gap-[8px]\"\n    [(ngModel)]=\"service.accessServiceProtocol\"\n    [disabled]=\"disabled\"\n    (change)=\"resetAllFormFields()\"\n  >\n    <mat-radio-button\n      *ngFor=\"let protocolOption of protocolOptions\"\n      [value]=\"protocolOption.value\"\n    >\n      {{ protocolOption.label | translate }}\n    </mat-radio-button>\n  </mat-radio-group>\n</div>\n\n<div class=\"flex flex-col gap-4\">\n  <gn-ui-url-input\n    class=\"w-full\"\n    (uploadClick)=\"handleUploadClick($event)\"\n    (valueChange)=\"handleUrlValueChange($event)\"\n    [disabled]=\"disabled\"\n    [value]=\"url\"\n    [showValidateButton]=\"activeLayerSuggestion\"\n  >\n    <ng-content *ngIf=\"activeLayerSuggestion\">\n      <ng-icon name=\"iconoirCloudUpload\"></ng-icon>\n    </ng-content>\n  </gn-ui-url-input>\n\n  <p class=\"text-sm text-red-500 pl-4\" *ngIf=\"errorMessage\" translate>\n    editor.record.form.field.onlineResource.edit.identifier.error\n  </p>\n\n  <gn-ui-text-input\n    class=\"grow border-b border-gray-300 pb-4\"\n    [(value)]=\"service.identifierInService\"\n    [placeholder]=\"getIdentifierPlaceholder() | translate\"\n    data-cy=\"identifier-in-service\"\n    [disabled]=\"disabled\"\n    *ngIf=\"\n      !activeLayerSuggestion ||\n      (url && errorMessage) ||\n      (modifyMode && (layers$ | async).length === 0)\n    \"\n  ></gn-ui-text-input>\n  <gn-ui-autocomplete\n    class=\"border-b border-gray-300 pb-4\"\n    [placeholder]=\"\n      'editor.record.form.field.onlineResource.edit.identifier.select.label'\n        | translate\n    \"\n    [action]=\"autoCompleteAction\"\n    (itemSelected)=\"handleSelectValue($event)\"\n    [displayWithFn]=\"displayWithFn\"\n    [minCharacterCount]=\"0\"\n    [clearOnSelection]=\"false\"\n    *ngIf=\"activeLayerSuggestion && (layers$ | async)?.length > 0\"\n  >\n  </gn-ui-autocomplete>\n  <gn-ui-button\n    (buttonClick)=\"submitIdentifier(service.identifierInService)\"\n    [disabled]=\"disabled || !service.identifierInService\"\n    type=\"primary\"\n    *ngIf=\"\n      !modifyMode &&\n      ((activeLayerSuggestion && (layers$ | async)) ||\n        !activeLayerSuggestion ||\n        (url && errorMessage))\n    \"\n  >\n    <span class=\"text-white font-bold\" translate>\n      editor.record.form.field.onlineResource.edit.identifier.submit</span\n    >\n  </gn-ui-button>\n</div>\n"]}
|
|
@@ -49,6 +49,7 @@ export class FormFieldOnlineResourcesComponent {
|
|
|
49
49
|
type: 'service',
|
|
50
50
|
accessServiceProtocol: 'ogcFeatures',
|
|
51
51
|
identifierInService: '',
|
|
52
|
+
url: undefined,
|
|
52
53
|
};
|
|
53
54
|
this.MAX_UPLOAD_SIZE_MB = MAX_UPLOAD_SIZE_MB;
|
|
54
55
|
}
|
|
@@ -171,7 +172,7 @@ export class FormFieldOnlineResourcesComponent {
|
|
|
171
172
|
});
|
|
172
173
|
}
|
|
173
174
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldOnlineResourcesComponent, deps: [{ token: i1.NotificationsService }, { token: i2.TranslateService }, { token: i3.PlatformServiceInterface }, { token: i0.ChangeDetectorRef }, { token: i4.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
174
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormFieldOnlineResourcesComponent, isStandalone: true, selector: "gn-ui-form-field-online-resources", inputs: { metadataUuid: "metadataUuid", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["dialogTemplate"], descendants: true }], ngImport: i0, template: "<div class=\"flex flex-col\">\n <gn-ui-switch-toggle\n [options]=\"typeOptions\"\n (selectedValue)=\"onSelectedTypeChange($event.value)\"\n extraClasses=\"grow text-sm\"\n data-cy=\"online-resources-type\"\n ></gn-ui-switch-toggle>\n <div class=\"h-[8px]\"></div>\n <gn-ui-file-input\n *ngIf=\"selectedType === 'download'\"\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleDownloadUrlChange($event)\"\n ></gn-ui-file-input>\n <div\n *ngIf=\"selectedType === 'service'\"\n class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n >\n <gn-ui-online-service-resource-input\n [service]=\"newService\"\n [disabled]=\"disabled$ | async\"\n (
|
|
175
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormFieldOnlineResourcesComponent, isStandalone: true, selector: "gn-ui-form-field-online-resources", inputs: { metadataUuid: "metadataUuid", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["dialogTemplate"], descendants: true }], ngImport: i0, template: "<div class=\"flex flex-col\">\n <gn-ui-switch-toggle\n [options]=\"typeOptions\"\n (selectedValue)=\"onSelectedTypeChange($event.value)\"\n extraClasses=\"grow text-sm\"\n data-cy=\"online-resources-type\"\n ></gn-ui-switch-toggle>\n <div class=\"h-[8px]\"></div>\n <gn-ui-file-input\n *ngIf=\"selectedType === 'download'\"\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleDownloadUrlChange($event)\"\n ></gn-ui-file-input>\n <div\n *ngIf=\"selectedType === 'service'\"\n class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n >\n <gn-ui-online-service-resource-input\n [service]=\"newService\"\n [disabled]=\"disabled$ | async\"\n (identifierSubmit)=\"handleIdentifierSubmit($event)\"\n ></gn-ui-online-service-resource-input>\n </div>\n <div class=\"h-[8px]\"></div>\n <gn-ui-sortable-list\n [items]=\"notLinkResources\"\n (itemsOrderChange)=\"handleResourcesChange($event)\"\n [elementTemplate]=\"template\"\n >\n </gn-ui-sortable-list>\n <ng-template #template let-onlineResource let-index=\"index\">\n <gn-ui-online-resource-card\n [onlineResource]=\"onlineResource\"\n (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n ></gn-ui-online-resource-card>\n </ng-template>\n\n <ng-template #dialogTemplate let-onlineResource>\n <div class=\"flex flex-col gap-[16px]\">\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.title\n </h3>\n <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n </div>\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.description\n </h3>\n <gn-ui-text-area\n [(value)]=\"onlineResource.description\"\n ></gn-ui-text-area>\n </div>\n <ng-container *ngIf=\"onlineResource.type === 'service'; else urlInput\">\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-online-service-resource-input\n [service]=\"onlineResource\"\n [modifyMode]=\"true\"\n ></gn-ui-online-service-resource-input>\n </ng-container>\n <ng-template #urlInput>\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-url-input\n class=\"w-full\"\n [disabled]=\"true\"\n [value]=\"onlineResource.url\"\n [showValidateButton]=\"false\"\n ></gn-ui-url-input>\n </ng-template>\n </div>\n </ng-template>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "component", type: SwitchToggleComponent, selector: "gn-ui-switch-toggle", inputs: ["options", "ariaLabel", "extraClasses", "disabled"], outputs: ["selectedValue"] }, { kind: "component", type: FileInputComponent, selector: "gn-ui-file-input", inputs: ["maxSizeMB", "uploadProgress", "disabled"], outputs: ["fileChange", "urlChange", "uploadCancel"] }, { kind: "component", type: OnlineServiceResourceInputComponent, selector: "gn-ui-online-service-resource-input", inputs: ["service", "protocolHint", "disabled", "modifyMode"], outputs: ["urlChange", "identifierSubmit"] }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled", "showValidateButton"], outputs: ["valueChange", "uploadClick"] }, { kind: "component", type: SortableListComponent, selector: "gn-ui-sortable-list", inputs: ["elementTemplate", "items"], outputs: ["itemsOrderChange"] }, { kind: "component", type: OnlineResourceCardComponent, selector: "gn-ui-online-resource-card", inputs: ["onlineResource"], outputs: ["modifyClick"] }, { kind: "component", type: TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "placeholder", "required", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: TextAreaComponent, selector: "gn-ui-text-area", inputs: ["value", "disabled", "extraClass", "placeholder", "required"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
175
176
|
}
|
|
176
177
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldOnlineResourcesComponent, decorators: [{
|
|
177
178
|
type: Component,
|
|
@@ -186,7 +187,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
186
187
|
TextInputComponent,
|
|
187
188
|
TextAreaComponent,
|
|
188
189
|
TranslateModule,
|
|
189
|
-
], template: "<div class=\"flex flex-col\">\n <gn-ui-switch-toggle\n [options]=\"typeOptions\"\n (selectedValue)=\"onSelectedTypeChange($event.value)\"\n extraClasses=\"grow text-sm\"\n data-cy=\"online-resources-type\"\n ></gn-ui-switch-toggle>\n <div class=\"h-[8px]\"></div>\n <gn-ui-file-input\n *ngIf=\"selectedType === 'download'\"\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleDownloadUrlChange($event)\"\n ></gn-ui-file-input>\n <div\n *ngIf=\"selectedType === 'service'\"\n class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n >\n <gn-ui-online-service-resource-input\n [service]=\"newService\"\n [disabled]=\"disabled$ | async\"\n (
|
|
190
|
+
], template: "<div class=\"flex flex-col\">\n <gn-ui-switch-toggle\n [options]=\"typeOptions\"\n (selectedValue)=\"onSelectedTypeChange($event.value)\"\n extraClasses=\"grow text-sm\"\n data-cy=\"online-resources-type\"\n ></gn-ui-switch-toggle>\n <div class=\"h-[8px]\"></div>\n <gn-ui-file-input\n *ngIf=\"selectedType === 'download'\"\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleDownloadUrlChange($event)\"\n ></gn-ui-file-input>\n <div\n *ngIf=\"selectedType === 'service'\"\n class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n >\n <gn-ui-online-service-resource-input\n [service]=\"newService\"\n [disabled]=\"disabled$ | async\"\n (identifierSubmit)=\"handleIdentifierSubmit($event)\"\n ></gn-ui-online-service-resource-input>\n </div>\n <div class=\"h-[8px]\"></div>\n <gn-ui-sortable-list\n [items]=\"notLinkResources\"\n (itemsOrderChange)=\"handleResourcesChange($event)\"\n [elementTemplate]=\"template\"\n >\n </gn-ui-sortable-list>\n <ng-template #template let-onlineResource let-index=\"index\">\n <gn-ui-online-resource-card\n [onlineResource]=\"onlineResource\"\n (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n ></gn-ui-online-resource-card>\n </ng-template>\n\n <ng-template #dialogTemplate let-onlineResource>\n <div class=\"flex flex-col gap-[16px]\">\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.title\n </h3>\n <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n </div>\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.description\n </h3>\n <gn-ui-text-area\n [(value)]=\"onlineResource.description\"\n ></gn-ui-text-area>\n </div>\n <ng-container *ngIf=\"onlineResource.type === 'service'; else urlInput\">\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-online-service-resource-input\n [service]=\"onlineResource\"\n [modifyMode]=\"true\"\n ></gn-ui-online-service-resource-input>\n </ng-container>\n <ng-template #urlInput>\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-url-input\n class=\"w-full\"\n [disabled]=\"true\"\n [value]=\"onlineResource.url\"\n [showValidateButton]=\"false\"\n ></gn-ui-url-input>\n </ng-template>\n </div>\n </ng-template>\n</div>\n" }]
|
|
190
191
|
}], ctorParameters: () => [{ type: i1.NotificationsService }, { type: i2.TranslateService }, { type: i3.PlatformServiceInterface }, { type: i0.ChangeDetectorRef }, { type: i4.MatDialog }], propDecorators: { metadataUuid: [{
|
|
191
192
|
type: Input
|
|
192
193
|
}], value: [{
|
|
@@ -197,4 +198,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
197
198
|
type: ViewChild,
|
|
198
199
|
args: ['dialogTemplate']
|
|
199
200
|
}] } });
|
|
200
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field-online-resources.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.ts","../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { MatDialog } from '@angular/material/dialog'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport {\n  DatasetDownloadDistribution,\n  DatasetServiceDistribution,\n  OnlineResource,\n  ServiceEndpoint,\n} from '../../../../../../../../../libs/common/domain/src/lib/model/record'\nimport { PlatformServiceInterface } from '../../../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { NotificationsService } from '../../../../../../../../../libs/feature/notifications/src'\nimport {\n  FileInputComponent,\n  SwitchToggleComponent,\n  SwitchToggleOption,\n  TextAreaComponent,\n  TextInputComponent,\n  UrlInputComponent,\n} from '../../../../../../../../../libs/ui/inputs/src'\nimport {\n  ModalDialogComponent,\n  SortableListComponent,\n} from '../../../../../../../../../libs/ui/layout/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { Subscription } from 'rxjs'\nimport { MAX_UPLOAD_SIZE_MB } from '../../../../fields.config'\nimport { OnlineResourceCardComponent } from '../../../online-resource-card/online-resource-card.component'\nimport { OnlineServiceResourceInputComponent } from '../../../online-service-resource-input/online-service-resource-input.component'\n\ntype OnlineNotLinkResource =\n  | DatasetDownloadDistribution\n  | DatasetServiceDistribution\n  | ServiceEndpoint\n\n@Component({\n  selector: 'gn-ui-form-field-online-resources',\n  templateUrl: './form-field-online-resources.component.html',\n  styleUrls: ['./form-field-online-resources.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    SwitchToggleComponent,\n    FileInputComponent,\n    OnlineServiceResourceInputComponent,\n    UrlInputComponent,\n    SortableListComponent,\n    OnlineResourceCardComponent,\n    TextInputComponent,\n    TextAreaComponent,\n    TranslateModule,\n  ],\n})\nexport class FormFieldOnlineResourcesComponent {\n  @Input() metadataUuid: string\n  @Input() set value(onlineResources: Array<OnlineResource>) {\n    this.allResources = onlineResources\n    this.notLinkResources = onlineResources.filter(\n      (res): res is OnlineNotLinkResource => res.type !== 'link'\n    )\n  }\n  @Output() valueChange: EventEmitter<Array<OnlineResource>> =\n    new EventEmitter()\n\n  @ViewChild('dialogTemplate') dialogTemplate: TemplateRef<OnlineResource>\n\n  typeOptions: SwitchToggleOption[] = [\n    {\n      label: marker('editor.record.form.field.onlineResource.toggle.dataset'),\n      value: 'download',\n      checked: true,\n    },\n    {\n      label: marker('editor.record.form.field.onlineResource.toggle.service'),\n      value: 'service',\n      checked: false,\n    },\n  ]\n  selectedType: 'download' | 'service' = 'download'\n\n  private allResources: OnlineResource[] = []\n  notLinkResources: OnlineNotLinkResource[] = []\n  uploadProgress = undefined\n  uploadSubscription: Subscription = null\n  newService = {\n    type: 'service',\n    accessServiceProtocol: 'ogcFeatures',\n    identifierInService: '',\n  } as Omit<DatasetServiceDistribution, 'url'>\n\n  protected MAX_UPLOAD_SIZE_MB = MAX_UPLOAD_SIZE_MB\n\n  constructor(\n    private notificationsService: NotificationsService,\n    private translateService: TranslateService,\n    private platformService: PlatformServiceInterface,\n    private cd: ChangeDetectorRef,\n    private dialog: MatDialog\n  ) {}\n\n  onSelectedTypeChange(selectedType: unknown) {\n    this.selectedType = selectedType as 'download' | 'service'\n  }\n\n  handleFileChange(file: File) {\n    this.uploadProgress = 0\n    this.uploadSubscription = this.platformService\n      .attachFileToRecord(this.metadataUuid, file)\n      .subscribe({\n        next: (event) => {\n          if (event.type === 'progress') {\n            this.uploadProgress = event.progress\n            this.cd.detectChanges()\n          } else if (event.type === 'success') {\n            this.uploadProgress = undefined\n            this.cd.detectChanges()\n            const newResource: DatasetDownloadDistribution = {\n              type: 'download',\n              url: new URL(event.attachment.url),\n              name: event.attachment.fileName,\n              sizeBytes: event.sizeBytes, // WARNING: this is the only time that sizeBytes is set\n            }\n            this.valueChange.emit([...this.allResources, newResource])\n          }\n        },\n        error: (error: Error) => this.handleError(error),\n      })\n  }\n\n  handleUploadCancel() {\n    if (this.uploadSubscription) {\n      this.uploadProgress = undefined\n      this.uploadSubscription.unsubscribe()\n    }\n  }\n\n  handleDownloadUrlChange(url: string) {\n    try {\n      const name = url.split('/').pop()\n      const newLink: DatasetDownloadDistribution = {\n        type: 'download',\n        url: new URL(url),\n        name,\n      }\n      this.valueChange.emit([...this.allResources, newLink])\n    } catch (e) {\n      this.handleError(e as Error)\n    }\n  }\n\n  handleServiceUrlChange(url: string) {\n    this.valueChange.emit([\n      ...this.allResources,\n      {\n        ...this.newService,\n        url: new URL(url),\n      },\n    ])\n  }\n\n  handleIdentifierSubmit(payload: { url: string; identifier: string }) {\n    this.valueChange.emit([\n      ...this.allResources,\n      {\n        ...this.newService,\n        url: new URL(payload.url),\n      },\n    ])\n  }\n\n  handleServiceModify(\n    oldService: DatasetServiceDistribution,\n    newService: DatasetServiceDistribution\n  ) {\n    oldService.accessServiceProtocol = newService.accessServiceProtocol\n    oldService.identifierInService = newService.identifierInService\n    oldService.url = newService.url\n  }\n\n  handleResourcesChange(items: unknown[]) {\n    const notLinks = items as OnlineNotLinkResource[]\n    const newResources = [\n      ...this.allResources.filter((r) => r.type === 'link'),\n      ...notLinks,\n    ]\n    this.valueChange.emit(newResources)\n  }\n\n  handleResourceModify(resource: OnlineNotLinkResource, index: number) {\n    this.openEditDialog(resource, index)\n  }\n\n  private handleError(error: Error) {\n    this.uploadProgress = undefined\n    this.notificationsService.showNotification(\n      {\n        type: 'error',\n        title: this.translateService.instant(\n          'editor.record.onlineResourceError.title'\n        ),\n        text: `${this.translateService.instant(\n          'editor.record.onlineResourceError.body'\n        )} ${error.message}`,\n        closeMessage: this.translateService.instant(\n          'editor.record.onlineResourceError.closeMessage'\n        ),\n      },\n      undefined,\n      error\n    )\n  }\n\n  private openEditDialog(resource: OnlineNotLinkResource, index: number) {\n    const resourceCopy = {\n      ...resource,\n    }\n    this.dialog\n      .open(ModalDialogComponent, {\n        width: '800px',\n        data: {\n          title: this.translateService.instant(\n            'editor.record.form.field.onlineResource.dialogTitle'\n          ),\n          body: this.dialogTemplate,\n          bodyContext: resourceCopy,\n          confirmText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.confirm'\n          ),\n          cancelText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.cancel'\n          ),\n        },\n      })\n      .afterClosed()\n      .subscribe((confirmed: boolean) => {\n        if (!confirmed) return\n        const newNotLinks = [...this.notLinkResources]\n        newNotLinks.splice(index, 1, resourceCopy)\n        this.valueChange.emit([\n          ...this.allResources.filter((r) => r.type === 'link'),\n          ...newNotLinks,\n        ])\n      })\n  }\n}\n","<div class=\"flex flex-col\">\n  <gn-ui-switch-toggle\n    [options]=\"typeOptions\"\n    (selectedValue)=\"onSelectedTypeChange($event.value)\"\n    extraClasses=\"grow text-sm\"\n    data-cy=\"online-resources-type\"\n  ></gn-ui-switch-toggle>\n  <div class=\"h-[8px]\"></div>\n  <gn-ui-file-input\n    *ngIf=\"selectedType === 'download'\"\n    [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n    (fileChange)=\"handleFileChange($event)\"\n    (uploadCancel)=\"handleUploadCancel()\"\n    [uploadProgress]=\"uploadProgress\"\n    (urlChange)=\"handleDownloadUrlChange($event)\"\n  ></gn-ui-file-input>\n  <div\n    *ngIf=\"selectedType === 'service'\"\n    class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n  >\n    <gn-ui-online-service-resource-input\n      [service]=\"newService\"\n      [disabled]=\"disabled$ | async\"\n      (urlChange)=\"handleServiceUrlChange($event)\"\n      (identifierSubmit)=\"handleIdentifierSubmit($event)\"\n    ></gn-ui-online-service-resource-input>\n  </div>\n  <div class=\"h-[8px]\"></div>\n  <gn-ui-sortable-list\n    [items]=\"notLinkResources\"\n    (itemsOrderChange)=\"handleResourcesChange($event)\"\n    [elementTemplate]=\"template\"\n  >\n  </gn-ui-sortable-list>\n  <ng-template #template let-onlineResource let-index=\"index\">\n    <gn-ui-online-resource-card\n      [onlineResource]=\"onlineResource\"\n      (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n    ></gn-ui-online-resource-card>\n  </ng-template>\n\n  <ng-template #dialogTemplate let-onlineResource>\n    <div class=\"flex flex-col gap-[16px]\">\n      <div>\n        <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n          editor.record.form.field.onlineResource.edit.title\n        </h3>\n        <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n      </div>\n      <div>\n        <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n          editor.record.form.field.onlineResource.edit.description\n        </h3>\n        <gn-ui-text-area\n          [(value)]=\"onlineResource.description\"\n        ></gn-ui-text-area>\n      </div>\n      <ng-container *ngIf=\"onlineResource.type === 'service'\">\n        <span class=\"w-full border-b border-gray-300\"></span>\n        <gn-ui-online-service-resource-input\n          [service]=\"onlineResource\"\n        ></gn-ui-online-service-resource-input>\n      </ng-container>\n      <span class=\"w-full border-b border-gray-300\"></span>\n      <gn-ui-url-input\n        class=\"w-full\"\n        [disabled]=\"true\"\n        [value]=\"onlineResource.url\"\n        [showValidateButton]=\"false\"\n      ></gn-ui-url-input>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field-online-resources.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.ts","../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { MatDialog } from '@angular/material/dialog'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport {\n  DatasetDownloadDistribution,\n  DatasetServiceDistribution,\n  OnlineResource,\n  ServiceEndpoint,\n} from '../../../../../../../../../libs/common/domain/src/lib/model/record'\nimport { PlatformServiceInterface } from '../../../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { NotificationsService } from '../../../../../../../../../libs/feature/notifications/src'\nimport {\n  FileInputComponent,\n  SwitchToggleComponent,\n  SwitchToggleOption,\n  TextAreaComponent,\n  TextInputComponent,\n  UrlInputComponent,\n} from '../../../../../../../../../libs/ui/inputs/src'\nimport {\n  ModalDialogComponent,\n  SortableListComponent,\n} from '../../../../../../../../../libs/ui/layout/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { Subscription } from 'rxjs'\nimport { MAX_UPLOAD_SIZE_MB } from '../../../../fields.config'\nimport { OnlineResourceCardComponent } from '../../../online-resource-card/online-resource-card.component'\nimport { OnlineServiceResourceInputComponent } from '../../../online-service-resource-input/online-service-resource-input.component'\n\ntype OnlineNotLinkResource =\n  | DatasetDownloadDistribution\n  | DatasetServiceDistribution\n  | ServiceEndpoint\n\n@Component({\n  selector: 'gn-ui-form-field-online-resources',\n  templateUrl: './form-field-online-resources.component.html',\n  styleUrls: ['./form-field-online-resources.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    SwitchToggleComponent,\n    FileInputComponent,\n    OnlineServiceResourceInputComponent,\n    UrlInputComponent,\n    SortableListComponent,\n    OnlineResourceCardComponent,\n    TextInputComponent,\n    TextAreaComponent,\n    TranslateModule,\n  ],\n})\nexport class FormFieldOnlineResourcesComponent {\n  @Input() metadataUuid: string\n  @Input() set value(onlineResources: Array<OnlineResource>) {\n    this.allResources = onlineResources\n    this.notLinkResources = onlineResources.filter(\n      (res): res is OnlineNotLinkResource => res.type !== 'link'\n    )\n  }\n  @Output() valueChange: EventEmitter<Array<OnlineResource>> =\n    new EventEmitter()\n\n  @ViewChild('dialogTemplate') dialogTemplate: TemplateRef<OnlineResource>\n\n  typeOptions: SwitchToggleOption[] = [\n    {\n      label: marker('editor.record.form.field.onlineResource.toggle.dataset'),\n      value: 'download',\n      checked: true,\n    },\n    {\n      label: marker('editor.record.form.field.onlineResource.toggle.service'),\n      value: 'service',\n      checked: false,\n    },\n  ]\n  selectedType: 'download' | 'service' = 'download'\n\n  private allResources: OnlineResource[] = []\n  notLinkResources: OnlineNotLinkResource[] = []\n  uploadProgress = undefined\n  uploadSubscription: Subscription = null\n  newService = <DatasetServiceDistribution>{\n    type: 'service',\n    accessServiceProtocol: 'ogcFeatures',\n    identifierInService: '',\n    url: undefined,\n  }\n\n  protected MAX_UPLOAD_SIZE_MB = MAX_UPLOAD_SIZE_MB\n\n  constructor(\n    private notificationsService: NotificationsService,\n    private translateService: TranslateService,\n    private platformService: PlatformServiceInterface,\n    private cd: ChangeDetectorRef,\n    private dialog: MatDialog\n  ) {}\n\n  onSelectedTypeChange(selectedType: unknown) {\n    this.selectedType = selectedType as 'download' | 'service'\n  }\n\n  handleFileChange(file: File) {\n    this.uploadProgress = 0\n    this.uploadSubscription = this.platformService\n      .attachFileToRecord(this.metadataUuid, file)\n      .subscribe({\n        next: (event) => {\n          if (event.type === 'progress') {\n            this.uploadProgress = event.progress\n            this.cd.detectChanges()\n          } else if (event.type === 'success') {\n            this.uploadProgress = undefined\n            this.cd.detectChanges()\n            const newResource: DatasetDownloadDistribution = {\n              type: 'download',\n              url: new URL(event.attachment.url),\n              name: event.attachment.fileName,\n              sizeBytes: event.sizeBytes, // WARNING: this is the only time that sizeBytes is set\n            }\n            this.valueChange.emit([...this.allResources, newResource])\n          }\n        },\n        error: (error: Error) => this.handleError(error),\n      })\n  }\n\n  handleUploadCancel() {\n    if (this.uploadSubscription) {\n      this.uploadProgress = undefined\n      this.uploadSubscription.unsubscribe()\n    }\n  }\n\n  handleDownloadUrlChange(url: string) {\n    try {\n      const name = url.split('/').pop()\n      const newLink: DatasetDownloadDistribution = {\n        type: 'download',\n        url: new URL(url),\n        name,\n      }\n      this.valueChange.emit([...this.allResources, newLink])\n    } catch (e) {\n      this.handleError(e as Error)\n    }\n  }\n\n  handleServiceUrlChange(url: string) {\n    this.valueChange.emit([\n      ...this.allResources,\n      {\n        ...this.newService,\n        url: new URL(url),\n      },\n    ])\n  }\n\n  handleIdentifierSubmit(payload: { url: string; identifier: string }) {\n    this.valueChange.emit([\n      ...this.allResources,\n      {\n        ...this.newService,\n        url: new URL(payload.url),\n      },\n    ])\n  }\n\n  handleServiceModify(\n    oldService: DatasetServiceDistribution,\n    newService: DatasetServiceDistribution\n  ) {\n    oldService.accessServiceProtocol = newService.accessServiceProtocol\n    oldService.identifierInService = newService.identifierInService\n    oldService.url = newService.url\n  }\n\n  handleResourcesChange(items: unknown[]) {\n    const notLinks = items as OnlineNotLinkResource[]\n    const newResources = [\n      ...this.allResources.filter((r) => r.type === 'link'),\n      ...notLinks,\n    ]\n    this.valueChange.emit(newResources)\n  }\n\n  handleResourceModify(resource: OnlineNotLinkResource, index: number) {\n    this.openEditDialog(resource, index)\n  }\n\n  private handleError(error: Error) {\n    this.uploadProgress = undefined\n    this.notificationsService.showNotification(\n      {\n        type: 'error',\n        title: this.translateService.instant(\n          'editor.record.onlineResourceError.title'\n        ),\n        text: `${this.translateService.instant(\n          'editor.record.onlineResourceError.body'\n        )} ${error.message}`,\n        closeMessage: this.translateService.instant(\n          'editor.record.onlineResourceError.closeMessage'\n        ),\n      },\n      undefined,\n      error\n    )\n  }\n\n  private openEditDialog(resource: OnlineNotLinkResource, index: number) {\n    const resourceCopy = {\n      ...resource,\n    }\n    this.dialog\n      .open(ModalDialogComponent, {\n        width: '800px',\n        data: {\n          title: this.translateService.instant(\n            'editor.record.form.field.onlineResource.dialogTitle'\n          ),\n          body: this.dialogTemplate,\n          bodyContext: resourceCopy,\n          confirmText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.confirm'\n          ),\n          cancelText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.cancel'\n          ),\n        },\n      })\n      .afterClosed()\n      .subscribe((confirmed: boolean) => {\n        if (!confirmed) return\n        const newNotLinks = [...this.notLinkResources]\n        newNotLinks.splice(index, 1, resourceCopy)\n        this.valueChange.emit([\n          ...this.allResources.filter((r) => r.type === 'link'),\n          ...newNotLinks,\n        ])\n      })\n  }\n}\n","<div class=\"flex flex-col\">\n  <gn-ui-switch-toggle\n    [options]=\"typeOptions\"\n    (selectedValue)=\"onSelectedTypeChange($event.value)\"\n    extraClasses=\"grow text-sm\"\n    data-cy=\"online-resources-type\"\n  ></gn-ui-switch-toggle>\n  <div class=\"h-[8px]\"></div>\n  <gn-ui-file-input\n    *ngIf=\"selectedType === 'download'\"\n    [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n    (fileChange)=\"handleFileChange($event)\"\n    (uploadCancel)=\"handleUploadCancel()\"\n    [uploadProgress]=\"uploadProgress\"\n    (urlChange)=\"handleDownloadUrlChange($event)\"\n  ></gn-ui-file-input>\n  <div\n    *ngIf=\"selectedType === 'service'\"\n    class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n  >\n    <gn-ui-online-service-resource-input\n      [service]=\"newService\"\n      [disabled]=\"disabled$ | async\"\n      (identifierSubmit)=\"handleIdentifierSubmit($event)\"\n    ></gn-ui-online-service-resource-input>\n  </div>\n  <div class=\"h-[8px]\"></div>\n  <gn-ui-sortable-list\n    [items]=\"notLinkResources\"\n    (itemsOrderChange)=\"handleResourcesChange($event)\"\n    [elementTemplate]=\"template\"\n  >\n  </gn-ui-sortable-list>\n  <ng-template #template let-onlineResource let-index=\"index\">\n    <gn-ui-online-resource-card\n      [onlineResource]=\"onlineResource\"\n      (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n    ></gn-ui-online-resource-card>\n  </ng-template>\n\n  <ng-template #dialogTemplate let-onlineResource>\n    <div class=\"flex flex-col gap-[16px]\">\n      <div>\n        <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n          editor.record.form.field.onlineResource.edit.title\n        </h3>\n        <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n      </div>\n      <div>\n        <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n          editor.record.form.field.onlineResource.edit.description\n        </h3>\n        <gn-ui-text-area\n          [(value)]=\"onlineResource.description\"\n        ></gn-ui-text-area>\n      </div>\n      <ng-container *ngIf=\"onlineResource.type === 'service'; else urlInput\">\n        <span class=\"w-full border-b border-gray-300\"></span>\n        <gn-ui-online-service-resource-input\n          [service]=\"onlineResource\"\n          [modifyMode]=\"true\"\n        ></gn-ui-online-service-resource-input>\n      </ng-container>\n      <ng-template #urlInput>\n        <span class=\"w-full border-b border-gray-300\"></span>\n        <gn-ui-url-input\n          class=\"w-full\"\n          [disabled]=\"true\"\n          [value]=\"onlineResource.url\"\n          [showValidateButton]=\"false\"\n        ></gn-ui-url-input>\n      </ng-template>\n    </div>\n  </ng-template>\n</div>\n"]}
|
package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs
CHANGED
|
@@ -76,18 +76,20 @@ export class ResultsTableContainerComponent {
|
|
|
76
76
|
this.subscription.unsubscribe();
|
|
77
77
|
}
|
|
78
78
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ResultsTableContainerComponent, deps: [{ token: i1.SearchFacade }, { token: i2.SearchService }, { token: i3.SelectionService }, { token: i4.RecordsRepositoryInterface }, { token: i5.NotificationsService }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ResultsTableContainerComponent, isStandalone: true, selector: "gn-ui-results-table-container", inputs: { canDuplicate: "canDuplicate", canDelete: "canDelete" }, outputs: { recordClick: "recordClick", duplicateRecord: "duplicateRecord" }, ngImport: i0, template: "<gn-ui-results-table\n *ngIf=\"searchFacade.results$ | async as records\"\n [records]=\"records\"\n [hasDraft]=\"hasDraft\"\n [selectedRecordsIdentifiers]=\"selectedRecords$ | async\"\n [sortOrder]=\"sortBy$ | async\"\n [canDelete]=\"canDelete\"\n [canDuplicate]=\"canDuplicate\"\n (recordClick)=\"handleRecordClick($event)\"\n (duplicateRecord)=\"handleDuplicateRecord($event)\"\n (deleteRecord)=\"handleDeleteRecord($event)\"\n (recordsSelectedChange)=\"handleRecordsSelectedChange($event[0], $event[1])\"\n (sortByChange)=\"handleSortByChange($event[0], $event[1])\"\n></gn-ui-results-table>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "component", type: ResultsTableComponent, selector: "gn-ui-results-table", inputs: ["records", "selectedRecordsIdentifiers", "sortOrder", "hasDraft", "canDuplicate", "canDelete", "isDraftPage"], outputs: ["sortByChange", "recordClick", "duplicateRecord", "deleteRecord", "recordsSelectedChange"] }] }); }
|
|
79
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ResultsTableContainerComponent, isStandalone: true, selector: "gn-ui-results-table-container", inputs: { canDuplicate: "canDuplicate", canDelete: "canDelete", isDuplicating: "isDuplicating" }, outputs: { recordClick: "recordClick", duplicateRecord: "duplicateRecord" }, ngImport: i0, template: "<gn-ui-results-table\n *ngIf=\"searchFacade.results$ | async as records\"\n [records]=\"records\"\n [hasDraft]=\"hasDraft\"\n [selectedRecordsIdentifiers]=\"selectedRecords$ | async\"\n [sortOrder]=\"sortBy$ | async\"\n [canDelete]=\"canDelete\"\n [canDuplicate]=\"canDuplicate\"\n [isDuplicating]=\"isDuplicating\"\n (recordClick)=\"handleRecordClick($event)\"\n (duplicateRecord)=\"handleDuplicateRecord($event)\"\n (deleteRecord)=\"handleDeleteRecord($event)\"\n (recordsSelectedChange)=\"handleRecordsSelectedChange($event[0], $event[1])\"\n (sortByChange)=\"handleSortByChange($event[0], $event[1])\"\n></gn-ui-results-table>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "component", type: ResultsTableComponent, selector: "gn-ui-results-table", inputs: ["records", "selectedRecordsIdentifiers", "sortOrder", "hasDraft", "canDuplicate", "canDelete", "isDraftPage", "isDuplicating"], outputs: ["sortByChange", "recordClick", "duplicateRecord", "deleteRecord", "recordsSelectedChange"] }] }); }
|
|
80
80
|
}
|
|
81
81
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ResultsTableContainerComponent, decorators: [{
|
|
82
82
|
type: Component,
|
|
83
|
-
args: [{ selector: 'gn-ui-results-table-container', standalone: true, imports: [CommonModule, ResultsTableComponent], template: "<gn-ui-results-table\n *ngIf=\"searchFacade.results$ | async as records\"\n [records]=\"records\"\n [hasDraft]=\"hasDraft\"\n [selectedRecordsIdentifiers]=\"selectedRecords$ | async\"\n [sortOrder]=\"sortBy$ | async\"\n [canDelete]=\"canDelete\"\n [canDuplicate]=\"canDuplicate\"\n (recordClick)=\"handleRecordClick($event)\"\n (duplicateRecord)=\"handleDuplicateRecord($event)\"\n (deleteRecord)=\"handleDeleteRecord($event)\"\n (recordsSelectedChange)=\"handleRecordsSelectedChange($event[0], $event[1])\"\n (sortByChange)=\"handleSortByChange($event[0], $event[1])\"\n></gn-ui-results-table>\n" }]
|
|
83
|
+
args: [{ selector: 'gn-ui-results-table-container', standalone: true, imports: [CommonModule, ResultsTableComponent], template: "<gn-ui-results-table\n *ngIf=\"searchFacade.results$ | async as records\"\n [records]=\"records\"\n [hasDraft]=\"hasDraft\"\n [selectedRecordsIdentifiers]=\"selectedRecords$ | async\"\n [sortOrder]=\"sortBy$ | async\"\n [canDelete]=\"canDelete\"\n [canDuplicate]=\"canDuplicate\"\n [isDuplicating]=\"isDuplicating\"\n (recordClick)=\"handleRecordClick($event)\"\n (duplicateRecord)=\"handleDuplicateRecord($event)\"\n (deleteRecord)=\"handleDeleteRecord($event)\"\n (recordsSelectedChange)=\"handleRecordsSelectedChange($event[0], $event[1])\"\n (sortByChange)=\"handleSortByChange($event[0], $event[1])\"\n></gn-ui-results-table>\n" }]
|
|
84
84
|
}], ctorParameters: () => [{ type: i1.SearchFacade }, { type: i2.SearchService }, { type: i3.SelectionService }, { type: i4.RecordsRepositoryInterface }, { type: i5.NotificationsService }, { type: i6.TranslateService }], propDecorators: { canDuplicate: [{
|
|
85
85
|
type: Input
|
|
86
86
|
}], canDelete: [{
|
|
87
87
|
type: Input
|
|
88
|
+
}], isDuplicating: [{
|
|
89
|
+
type: Input
|
|
88
90
|
}], recordClick: [{
|
|
89
91
|
type: Output
|
|
90
92
|
}], duplicateRecord: [{
|
|
91
93
|
type: Output
|
|
92
94
|
}] } });
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"results-table-container.component.js","sourceRoot":"","sources":["../../../../../../../../libs/feature/search/src/lib/results-table/results-table-container.component.ts","../../../../../../../../libs/feature/search/src/lib/results-table/results-table-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n} from '@angular/core'\nimport { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { SearchFacade } from '../state/search.facade'\nimport { SelectionService } from '../../../../../../libs/api/repository/src'\nimport { SearchService } from '../utils/service/search.service'\nimport { RecordsRepositoryInterface } from '../../../../../../libs/common/domain/src/lib/repository/records-repository.interface'\nimport { ResultsTableComponent } from '../../../../../../libs/ui/search/src'\nimport { CommonModule } from '@angular/common'\nimport { Subscription } from 'rxjs'\nimport { NotificationsService } from '../../../../../../libs/feature/notifications/src'\nimport { TranslateService } from '@ngx-translate/core'\n\n@Component({\n  selector: 'gn-ui-results-table-container',\n  templateUrl: './results-table-container.component.html',\n  styleUrls: ['./results-table-container.component.css'],\n  standalone: true,\n  imports: [CommonModule, ResultsTableComponent],\n})\nexport class ResultsTableContainerComponent implements OnDestroy {\n  @Input() canDuplicate: (record: CatalogRecord) => boolean = () => true\n  @Input() canDelete: (record: CatalogRecord) => boolean = () => true\n\n  @Output() recordClick = new EventEmitter<CatalogRecord>()\n  @Output() duplicateRecord = new EventEmitter<CatalogRecord>()\n\n  subscription = new Subscription()\n\n  selectedRecords$ = this.selectionService.selectedRecordsIdentifiers$\n  sortBy$ = this.searchFacade.sortBy$\n\n  hasDraft = (record: CatalogRecord): boolean =>\n    this.recordsRepository.recordHasDraft(record.uniqueIdentifier)\n\n  constructor(\n    protected searchFacade: SearchFacade,\n    private searchService: SearchService,\n    private selectionService: SelectionService,\n    private recordsRepository: RecordsRepositoryInterface,\n    private notificationsService: NotificationsService,\n    private translateService: TranslateService\n  ) {}\n\n  handleRecordClick(item: unknown) {\n    this.recordClick.emit(item as CatalogRecord)\n  }\n\n  handleDuplicateRecord(item: unknown) {\n    this.duplicateRecord.emit(item as CatalogRecord)\n  }\n\n  async handleDeleteRecord(item: unknown) {\n    const uniqueIdentifier = (item as CatalogRecord).uniqueIdentifier\n    this.subscription.add(\n      this.recordsRepository.deleteRecord(uniqueIdentifier).subscribe({\n        next: () => {\n          this.recordsRepository.clearRecordDraft(uniqueIdentifier)\n          this.searchFacade.requestNewResults()\n          this.notificationsService.showNotification(\n            {\n              type: 'success',\n              title: this.translateService.instant(\n                'editor.record.deleteSuccess.title'\n              ),\n              text: `${this.translateService.instant(\n                'editor.record.deleteSuccess.body'\n              )}`,\n            },\n            2500\n          )\n        },\n        error: (error) => {\n          this.notificationsService.showNotification(\n            {\n              type: 'error',\n              title: this.translateService.instant(\n                'editor.record.deleteError.title'\n              ),\n              text: `${this.translateService.instant(\n                'editor.record.deleteError.body'\n              )} ${error}`,\n              closeMessage: this.translateService.instant(\n                'editor.record.deleteError.closeMessage'\n              ),\n            },\n            undefined,\n            error\n          )\n        },\n      })\n    )\n  }\n\n  handleSortByChange(col: string, order: 'asc' | 'desc') {\n    this.searchService.setSortBy([order, col])\n  }\n\n  handleRecordsSelectedChange(records: CatalogRecord[], selected: boolean) {\n    if (!selected) {\n      this.selectionService.deselectRecords(records)\n    } else {\n      this.selectionService.selectRecords(records)\n    }\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe()\n  }\n}\n","<gn-ui-results-table\n  *ngIf=\"searchFacade.results$ | async as records\"\n  [records]=\"records\"\n  [hasDraft]=\"hasDraft\"\n  [selectedRecordsIdentifiers]=\"selectedRecords$ | async\"\n  [sortOrder]=\"sortBy$ | async\"\n  [canDelete]=\"canDelete\"\n  [canDuplicate]=\"canDuplicate\"\n  (recordClick)=\"handleRecordClick($event)\"\n  (duplicateRecord)=\"handleDuplicateRecord($event)\"\n  (deleteRecord)=\"handleDeleteRecord($event)\"\n  (recordsSelectedChange)=\"handleRecordsSelectedChange($event[0], $event[1])\"\n  (sortByChange)=\"handleSortByChange($event[0], $event[1])\"\n></gn-ui-results-table>\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"results-table-container.component.js","sourceRoot":"","sources":["../../../../../../../../libs/feature/search/src/lib/results-table/results-table-container.component.ts","../../../../../../../../libs/feature/search/src/lib/results-table/results-table-container.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,GACP,MAAM,eAAe,CAAA;AAEtB,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAA;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAA;AAC/D,OAAO,EAAE,0BAA0B,EAAE,MAAM,sFAAsF,CAAA;AACjI,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAA;AAC5E,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AACnC,OAAO,EAAE,oBAAoB,EAAE,MAAM,kDAAkD,CAAA;AACvF,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;;;;;;;;;AAStD,MAAM,OAAO,8BAA8B;IAgBzC,YACY,YAA0B,EAC5B,aAA4B,EAC5B,gBAAkC,EAClC,iBAA6C,EAC7C,oBAA0C,EAC1C,gBAAkC;QALhC,iBAAY,GAAZ,YAAY,CAAc;QAC5B,kBAAa,GAAb,aAAa,CAAe;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,sBAAiB,GAAjB,iBAAiB,CAA4B;QAC7C,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,qBAAgB,GAAhB,gBAAgB,CAAkB;QArBnC,iBAAY,GAAuC,GAAG,EAAE,CAAC,IAAI,CAAA;QAC7D,cAAS,GAAuC,GAAG,EAAE,CAAC,IAAI,CAAA;QAGzD,gBAAW,GAAG,IAAI,YAAY,EAAiB,CAAA;QAC/C,oBAAe,GAAG,IAAI,YAAY,EAAiB,CAAA;QAE7D,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAA;QAEjC,qBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,2BAA2B,CAAA;QACpE,YAAO,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAA;QAEnC,aAAQ,GAAG,CAAC,MAAqB,EAAW,EAAE,CAC5C,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAS7D,CAAC;IAEJ,iBAAiB,CAAC,IAAa;QAC7B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAqB,CAAC,CAAA;IAC9C,CAAC;IAED,qBAAqB,CAAC,IAAa;QACjC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAqB,CAAC,CAAA;IAClD,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,IAAa;QACpC,MAAM,gBAAgB,GAAI,IAAsB,CAAC,gBAAgB,CAAA;QACjE,IAAI,CAAC,YAAY,CAAC,GAAG,CACnB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC;YAC9D,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAA;gBACzD,IAAI,CAAC,YAAY,CAAC,iBAAiB,EAAE,CAAA;gBACrC,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CACxC;oBACE,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAClC,mCAAmC,CACpC;oBACD,IAAI,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CACpC,kCAAkC,CACnC,EAAE;iBACJ,EACD,IAAI,CACL,CAAA;YACH,CAAC;YACD,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBACf,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CACxC;oBACE,IAAI,EAAE,OAAO;oBACb,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAClC,iCAAiC,CAClC;oBACD,IAAI,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CACpC,gCAAgC,CACjC,IAAI,KAAK,EAAE;oBACZ,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CACzC,wCAAwC,CACzC;iBACF,EACD,SAAS,EACT,KAAK,CACN,CAAA;YACH,CAAC;SACF,CAAC,CACH,CAAA;IACH,CAAC;IAED,kBAAkB,CAAC,GAAW,EAAE,KAAqB;QACnD,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAA;IAC5C,CAAC;IAED,2BAA2B,CAAC,OAAwB,EAAE,QAAiB;QACrE,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;QAChD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,OAAO,CAAC,CAAA;QAC9C,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAA;IACjC,CAAC;+GAzFU,8BAA8B;mGAA9B,8BAA8B,wQCzB3C,uoBAeA,yDDQY,YAAY,wLAAE,qBAAqB;;4FAElC,8BAA8B;kBAP1C,SAAS;+BACE,+BAA+B,cAG7B,IAAI,WACP,CAAC,YAAY,EAAE,qBAAqB,CAAC;uPAGrC,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBACG,eAAe;sBAAxB,MAAM","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n} from '@angular/core'\nimport { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { SearchFacade } from '../state/search.facade'\nimport { SelectionService } from '../../../../../../libs/api/repository/src'\nimport { SearchService } from '../utils/service/search.service'\nimport { RecordsRepositoryInterface } from '../../../../../../libs/common/domain/src/lib/repository/records-repository.interface'\nimport { ResultsTableComponent } from '../../../../../../libs/ui/search/src'\nimport { CommonModule } from '@angular/common'\nimport { Subscription } from 'rxjs'\nimport { NotificationsService } from '../../../../../../libs/feature/notifications/src'\nimport { TranslateService } from '@ngx-translate/core'\n\n@Component({\n  selector: 'gn-ui-results-table-container',\n  templateUrl: './results-table-container.component.html',\n  styleUrls: ['./results-table-container.component.css'],\n  standalone: true,\n  imports: [CommonModule, ResultsTableComponent],\n})\nexport class ResultsTableContainerComponent implements OnDestroy {\n  @Input() canDuplicate: (record: CatalogRecord) => boolean = () => true\n  @Input() canDelete: (record: CatalogRecord) => boolean = () => true\n  @Input() isDuplicating: false\n\n  @Output() recordClick = new EventEmitter<CatalogRecord>()\n  @Output() duplicateRecord = new EventEmitter<CatalogRecord>()\n\n  subscription = new Subscription()\n\n  selectedRecords$ = this.selectionService.selectedRecordsIdentifiers$\n  sortBy$ = this.searchFacade.sortBy$\n\n  hasDraft = (record: CatalogRecord): boolean =>\n    this.recordsRepository.recordHasDraft(record.uniqueIdentifier)\n\n  constructor(\n    protected searchFacade: SearchFacade,\n    private searchService: SearchService,\n    private selectionService: SelectionService,\n    private recordsRepository: RecordsRepositoryInterface,\n    private notificationsService: NotificationsService,\n    private translateService: TranslateService\n  ) {}\n\n  handleRecordClick(item: unknown) {\n    this.recordClick.emit(item as CatalogRecord)\n  }\n\n  handleDuplicateRecord(item: unknown) {\n    this.duplicateRecord.emit(item as CatalogRecord)\n  }\n\n  async handleDeleteRecord(item: unknown) {\n    const uniqueIdentifier = (item as CatalogRecord).uniqueIdentifier\n    this.subscription.add(\n      this.recordsRepository.deleteRecord(uniqueIdentifier).subscribe({\n        next: () => {\n          this.recordsRepository.clearRecordDraft(uniqueIdentifier)\n          this.searchFacade.requestNewResults()\n          this.notificationsService.showNotification(\n            {\n              type: 'success',\n              title: this.translateService.instant(\n                'editor.record.deleteSuccess.title'\n              ),\n              text: `${this.translateService.instant(\n                'editor.record.deleteSuccess.body'\n              )}`,\n            },\n            2500\n          )\n        },\n        error: (error) => {\n          this.notificationsService.showNotification(\n            {\n              type: 'error',\n              title: this.translateService.instant(\n                'editor.record.deleteError.title'\n              ),\n              text: `${this.translateService.instant(\n                'editor.record.deleteError.body'\n              )} ${error}`,\n              closeMessage: this.translateService.instant(\n                'editor.record.deleteError.closeMessage'\n              ),\n            },\n            undefined,\n            error\n          )\n        },\n      })\n    )\n  }\n\n  handleSortByChange(col: string, order: 'asc' | 'desc') {\n    this.searchService.setSortBy([order, col])\n  }\n\n  handleRecordsSelectedChange(records: CatalogRecord[], selected: boolean) {\n    if (!selected) {\n      this.selectionService.deselectRecords(records)\n    } else {\n      this.selectionService.selectRecords(records)\n    }\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe()\n  }\n}\n","<gn-ui-results-table\n  *ngIf=\"searchFacade.results$ | async as records\"\n  [records]=\"records\"\n  [hasDraft]=\"hasDraft\"\n  [selectedRecordsIdentifiers]=\"selectedRecords$ | async\"\n  [sortOrder]=\"sortBy$ | async\"\n  [canDelete]=\"canDelete\"\n  [canDuplicate]=\"canDuplicate\"\n  [isDuplicating]=\"isDuplicating\"\n  (recordClick)=\"handleRecordClick($event)\"\n  (duplicateRecord)=\"handleDuplicateRecord($event)\"\n  (deleteRecord)=\"handleDeleteRecord($event)\"\n  (recordsSelectedChange)=\"handleRecordsSelectedChange($event[0], $event[1])\"\n  (sortByChange)=\"handleSortByChange($event[0], $event[1])\"\n></gn-ui-results-table>\n"]}
|
|
@@ -29,6 +29,11 @@ export class UrlInputComponent {
|
|
|
29
29
|
this.uploadClick = new EventEmitter();
|
|
30
30
|
this.inputValue = '';
|
|
31
31
|
}
|
|
32
|
+
ngOnChanges(changes) {
|
|
33
|
+
if (changes['value']) {
|
|
34
|
+
this.inputValue = changes['value'].currentValue;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
32
37
|
handleInput(event) {
|
|
33
38
|
const value = event.target.value;
|
|
34
39
|
this.inputValue = value;
|
|
@@ -60,7 +65,7 @@ export class UrlInputComponent {
|
|
|
60
65
|
provideNgIconsConfig({
|
|
61
66
|
size: '1.5em',
|
|
62
67
|
}),
|
|
63
|
-
], ngImport: i0, template: "<span class=\"w-full inline-block relative\">\n <input\n #input\n class=\"gn-ui-text-input gn-ui-url-input px-[var(--text-padding)]\"\n [ngClass]=\"extraClass\"\n type=\"url\"\n [value]=\"inputValue\"\n (input)=\"handleInput($event)\"\n (keydown.enter)=\"handleUpload(input)\"\n [placeholder]=\"placeholder\"\n [attr.aria-label]=\"placeholder\"\n [disabled]=\"disabled\"\n />\n <div\n class=\"absolute inset-y-[var(--side-padding)] left-[var(--2x-side-padding)] grid justify-center items-center pointer-events-none\"\n [ngClass]=\"{\n 'text-primary': !disabled,\n 'text-primary-lightest': disabled,\n }\"\n >\n <ng-icon name=\"iconoirLink\"></ng-icon>\n </div>\n <gn-ui-button\n *ngIf=\"showValidateButton\"\n extraClass=\"absolute inset-y-[var(--side-padding)] right-[var(--side-padding)]\"\n type=\"primary\"\n [disabled]=\"disabled || input.value === '' || !isValidUrl(input.value)\"\n (buttonClick)=\"handleUpload(input)\"\n >\n <ng-content>\n <ng-icon name=\"iconoirArrowUp\"></ng-icon>\n </ng-content>\n </gn-ui-button>\n</span>\n", styles: [":host{--gn-ui-button-rounded: 8px;--gn-ui-button-width: 32px;--gn-ui-button-padding: 0;--side-padding: calc(var(--gn-ui-text-input-padding, .6rem) - 6px);--2x-side-padding: calc(var(--side-padding) * 2);--text-padding: calc(var(--side-padding) + 40px)}\n"], 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: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
68
|
+
], usesOnChanges: true, ngImport: i0, template: "<span class=\"w-full inline-block relative\">\n <input\n #input\n class=\"gn-ui-text-input gn-ui-url-input px-[var(--text-padding)]\"\n [ngClass]=\"extraClass\"\n type=\"url\"\n [value]=\"inputValue\"\n (input)=\"handleInput($event)\"\n (keydown.enter)=\"handleUpload(input)\"\n [placeholder]=\"placeholder\"\n [attr.aria-label]=\"placeholder\"\n [disabled]=\"disabled\"\n />\n <div\n class=\"absolute inset-y-[var(--side-padding)] left-[var(--2x-side-padding)] grid justify-center items-center pointer-events-none\"\n [ngClass]=\"{\n 'text-primary': !disabled,\n 'text-primary-lightest': disabled,\n }\"\n >\n <ng-icon name=\"iconoirLink\"></ng-icon>\n </div>\n <gn-ui-button\n *ngIf=\"showValidateButton\"\n extraClass=\"absolute inset-y-[var(--side-padding)] right-[var(--side-padding)]\"\n type=\"primary\"\n [disabled]=\"disabled || input.value === '' || !isValidUrl(input.value)\"\n (buttonClick)=\"handleUpload(input)\"\n >\n <ng-content>\n <ng-icon name=\"iconoirArrowUp\"></ng-icon>\n </ng-content>\n </gn-ui-button>\n</span>\n", styles: [":host{--gn-ui-button-rounded: 8px;--gn-ui-button-width: 32px;--gn-ui-button-padding: 0;--side-padding: calc(var(--gn-ui-text-input-padding, .6rem) - 6px);--2x-side-padding: calc(var(--side-padding) * 2);--text-padding: calc(var(--side-padding) + 40px)}\n"], 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: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
64
69
|
}
|
|
65
70
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UrlInputComponent, decorators: [{
|
|
66
71
|
type: Component,
|
|
@@ -85,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
85
90
|
}], uploadClick: [{
|
|
86
91
|
type: Output
|
|
87
92
|
}] } });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"url-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/url-input/url-input.component.ts","../../../../../../../../libs/ui/inputs/src/lib/url-input/url-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n} from '@angular/core'\nimport { CommonModule } from '@angular/common'\nimport { ButtonComponent } from '../button/button.component'\nimport {\n  NgIconComponent,\n  provideIcons,\n  provideNgIconsConfig,\n} from '@ng-icons/core'\nimport { iconoirArrowUp, iconoirLink } from '@ng-icons/iconoir'\n\n@Component({\n  selector: 'gn-ui-url-input',\n  templateUrl: './url-input.component.html',\n  styleUrls: ['./url-input.component.css'],\n  standalone: true,\n  imports: [CommonModule, ButtonComponent, NgIconComponent],\n  providers: [\n    provideIcons({ iconoirLink, iconoirArrowUp }),\n    provideNgIconsConfig({\n      size: '1.5em',\n    }),\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class UrlInputComponent implements OnChanges {\n  @Input() set value(v: string) {\n    // we're making sure to only update the input if the URL representation of it has changed; otherwise we keep it identical\n    // to avoid glitches when starting to write a URL and having some characters added/replaced automatically\n    if (!v || !this.isValidUrl(v)) return\n    if (\n      this.isValidUrl(this.inputValue) &&\n      new URL(v).toString() === new URL(this.inputValue).toString()\n    )\n      return\n    this.inputValue = v\n    this.cd.markForCheck()\n  }\n  @Input() extraClass = ''\n  @Input() placeholder = 'https://'\n  @Input() disabled: boolean\n  @Input() showValidateButton = true\n\n  /**\n   * This will emit null if the field is emptied\n   */\n  @Output() valueChange = new EventEmitter<string | null>()\n  @Output() uploadClick = new EventEmitter<string>()\n\n  inputValue = ''\n\n  constructor(private cd: ChangeDetectorRef) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['value']) {\n      this.inputValue = changes['value'].currentValue\n    }\n  }\n\n  handleInput(event: Event) {\n    const value = (event.target as HTMLInputElement).value\n    this.inputValue = value\n    if (!value || !this.isValidUrl(value)) {\n      this.valueChange.next(null)\n      return\n    }\n    this.cd.markForCheck()\n    this.valueChange.next(value)\n  }\n\n  handleUpload(element: HTMLInputElement) {\n    const value = element.value\n    if (!value || !this.isValidUrl(value)) return\n    this.uploadClick.next(value)\n  }\n\n  isValidUrl(url: string): boolean {\n    try {\n      new URL(url)\n      return true\n    } catch (e) {\n      return false\n    }\n  }\n}\n","<span class=\"w-full inline-block relative\">\n  <input\n    #input\n    class=\"gn-ui-text-input gn-ui-url-input px-[var(--text-padding)]\"\n    [ngClass]=\"extraClass\"\n    type=\"url\"\n    [value]=\"inputValue\"\n    (input)=\"handleInput($event)\"\n    (keydown.enter)=\"handleUpload(input)\"\n    [placeholder]=\"placeholder\"\n    [attr.aria-label]=\"placeholder\"\n    [disabled]=\"disabled\"\n  />\n  <div\n    class=\"absolute inset-y-[var(--side-padding)] left-[var(--2x-side-padding)] grid justify-center items-center pointer-events-none\"\n    [ngClass]=\"{\n      'text-primary': !disabled,\n      'text-primary-lightest': disabled,\n    }\"\n  >\n    <ng-icon name=\"iconoirLink\"></ng-icon>\n  </div>\n  <gn-ui-button\n    *ngIf=\"showValidateButton\"\n    extraClass=\"absolute inset-y-[var(--side-padding)] right-[var(--side-padding)]\"\n    type=\"primary\"\n    [disabled]=\"disabled || input.value === '' || !isValidUrl(input.value)\"\n    (buttonClick)=\"handleUpload(input)\"\n  >\n    <ng-content>\n      <ng-icon name=\"iconoirArrowUp\"></ng-icon>\n    </ng-content>\n  </gn-ui-button>\n</span>\n"]}
|