geonetwork-ui 2.3.0-dev.a26c0b88 → 2.3.0-dev.aef43725
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +2 -2
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +2 -2
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +9 -7
- package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +14 -2
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +1 -1
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +104 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +8 -3
- package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +1 -1
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +8 -1
- package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +1 -1
- package/esm2022/libs/feature/map/src/lib/map-context/map-context.model.mjs +1 -1
- package/esm2022/libs/feature/map/src/lib/map-context/map-context.service.mjs +30 -10
- package/esm2022/libs/feature/map/src/lib/utils/map-utils.service.mjs +7 -3
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +1 -1
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +11 -7
- package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +34 -5
- package/esm2022/libs/feature/record/src/lib/state/mdview.reducer.mjs +1 -3
- package/esm2022/libs/feature/search/src/index.mjs +2 -1
- package/esm2022/libs/feature/search/src/lib/results-layout/results-layout.component.mjs +1 -1
- package/esm2022/libs/feature/search/src/lib/results-list/results-list.container.component.mjs +4 -4
- package/esm2022/libs/feature/search/src/lib/sort-by/sort-by.component.mjs +1 -1
- package/esm2022/libs/ui/catalog/src/lib/language-switcher/language-switcher.component.mjs +1 -1
- package/esm2022/libs/ui/catalog/src/lib/organisations-filter/organisations-filter.component.mjs +1 -1
- package/esm2022/libs/ui/elements/src/index.mjs +2 -2
- package/esm2022/libs/ui/elements/src/lib/error/error.component.mjs +30 -0
- package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +69 -69
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +6 -6
- package/esm2022/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.mjs +3 -5
- package/esm2022/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.mjs +4 -3
- package/esm2022/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.mjs +5 -3
- package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +6 -5
- package/esm2022/libs/util/app-config/src/lib/app-config.mjs +3 -1
- package/esm2022/libs/util/app-config/src/lib/fixtures.mjs +2 -1
- package/esm2022/libs/util/app-config/src/lib/model.mjs +1 -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 +445 -245
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts +2 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +21 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
- package/libs/feature/map/src/lib/map-context/map-context.model.d.ts +6 -0
- package/libs/feature/map/src/lib/map-context/map-context.model.d.ts.map +1 -1
- package/libs/feature/map/src/lib/map-context/map-context.service.d.ts +1 -1
- package/libs/feature/map/src/lib/map-context/map-context.service.d.ts.map +1 -1
- package/libs/feature/map/src/lib/utils/map-utils.service.d.ts.map +1 -1
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +2 -2
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts +5 -2
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.reducer.d.ts.map +1 -1
- package/libs/feature/search/src/index.d.ts +1 -0
- package/libs/feature/search/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/index.d.ts +1 -1
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/error/error.component.d.ts +16 -0
- package/libs/ui/elements/src/lib/error/error.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +14 -3
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -2
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts +1 -2
- package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.d.ts +1 -1
- package/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts +2 -1
- package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +27 -27
- package/libs/util/app-config/src/lib/app-config.d.ts.map +1 -1
- package/libs/util/app-config/src/lib/fixtures.d.ts.map +1 -1
- package/libs/util/app-config/src/lib/model.d.ts +1 -0
- package/libs/util/app-config/src/lib/model.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +1 -4
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +16 -10
- package/src/libs/common/fixtures/src/lib/records.fixtures.ts +8 -0
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +15 -1
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.html +14 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +143 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +5 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +5 -0
- package/src/libs/feature/editor/src/lib/fields.config.ts +7 -0
- package/src/libs/feature/map/src/lib/map-context/map-context.model.ts +6 -0
- package/src/libs/feature/map/src/lib/map-context/map-context.service.ts +31 -9
- package/src/libs/feature/map/src/lib/utils/map-utils.service.ts +6 -2
- package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +10 -8
- package/src/libs/feature/record/src/lib/state/mdview.facade.ts +40 -3
- package/src/libs/feature/record/src/lib/state/mdview.reducer.ts +0 -2
- package/src/libs/feature/search/src/index.ts +1 -0
- package/src/libs/feature/search/src/lib/results-list/results-list.container.component.html +4 -4
- package/src/libs/ui/elements/src/index.ts +1 -1
- package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.html → error/error.component.html} +18 -3
- package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.ts → error/error.component.ts} +5 -4
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +95 -79
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +3 -4
- package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.html +1 -1
- package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.ts +0 -1
- package/src/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.ts +3 -0
- package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.html +1 -0
- package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.ts +1 -0
- package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +1 -1
- package/src/libs/util/app-config/src/lib/app-config.ts +2 -0
- package/src/libs/util/app-config/src/lib/fixtures.ts +1 -0
- package/src/libs/util/app-config/src/lib/model.ts +1 -0
- 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
- package/esm2022/libs/ui/elements/src/lib/search-results-error/search-results-error.component.mjs +0 -29
- package/libs/ui/elements/src/lib/search-results-error/search-results-error.component.d.ts +0 -15
- package/libs/ui/elements/src/lib/search-results-error/search-results-error.component.d.ts.map +0 -1
- /package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.css → error/error.component.css} +0 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
2
|
import { OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client';
|
|
3
3
|
import { mimeTypeToFormat } from '../../../../../../libs/util/shared/src';
|
|
4
|
-
import { BehaviorSubject, combineLatest, map, switchMap } from 'rxjs';
|
|
4
|
+
import { BehaviorSubject, combineLatest, filter, map, switchMap } from 'rxjs';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
7
7
|
import * as i2 from "@angular/material/tooltip";
|
|
@@ -16,41 +16,19 @@ const DEFAULT_PARAMS = {
|
|
|
16
16
|
};
|
|
17
17
|
export class RecordApiFormComponent {
|
|
18
18
|
constructor() {
|
|
19
|
-
this.offset$ = new BehaviorSubject(
|
|
20
|
-
this.limit$ = new BehaviorSubject(
|
|
21
|
-
this.format$ = new BehaviorSubject(
|
|
19
|
+
this.offset$ = new BehaviorSubject(DEFAULT_PARAMS.OFFSET);
|
|
20
|
+
this.limit$ = new BehaviorSubject(DEFAULT_PARAMS.LIMIT);
|
|
21
|
+
this.format$ = new BehaviorSubject(DEFAULT_PARAMS.FORMAT);
|
|
22
|
+
this.endpoint$ = new BehaviorSubject(undefined);
|
|
22
23
|
this.supportOffset = true;
|
|
23
24
|
this.outputFormats = [{ value: 'json', label: 'JSON' }];
|
|
24
|
-
this.apiQueryUrl$ = combineLatest([
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
url.searchParams.set(key, value);
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
url.searchParams.delete(key);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
outputUrl = url.toString();
|
|
38
|
-
}
|
|
39
|
-
if (this.accessServiceProtocol === 'wfs') {
|
|
40
|
-
const wfsEndpoint = new WfsEndpoint(this.apiBaseUrl);
|
|
41
|
-
if (await wfsEndpoint.isReady()) {
|
|
42
|
-
const options = {
|
|
43
|
-
outputFormat: format,
|
|
44
|
-
startIndex: Number(offset),
|
|
45
|
-
};
|
|
46
|
-
if (limit !== '-1') {
|
|
47
|
-
options['maxFeatures'] = Number(limit);
|
|
48
|
-
}
|
|
49
|
-
outputUrl = wfsEndpoint.getFeatureUrl(this.apiFeatureType, options);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
return outputUrl;
|
|
53
|
-
}));
|
|
25
|
+
this.apiQueryUrl$ = combineLatest([
|
|
26
|
+
this.offset$,
|
|
27
|
+
this.limit$,
|
|
28
|
+
this.format$,
|
|
29
|
+
// only compute the url if the endpoint was created
|
|
30
|
+
this.endpoint$.pipe(filter((endpoint) => !!endpoint)),
|
|
31
|
+
]).pipe(switchMap(([offset, limit, format]) => this.generateApiQueryUrl(offset, limit, format)));
|
|
54
32
|
this.noLimitChecked$ = this.limit$.pipe(map((limit) => limit === '-1' || limit === ''));
|
|
55
33
|
this.displayLimit$ = this.limit$.pipe(map((limit) => (limit !== '-1' ? limit : '')));
|
|
56
34
|
}
|
|
@@ -60,7 +38,7 @@ export class RecordApiFormComponent {
|
|
|
60
38
|
this.apiFeatureType = value ? value.name : undefined;
|
|
61
39
|
if (value) {
|
|
62
40
|
this.apiBaseUrl = value.url.href;
|
|
63
|
-
this.parseOutputFormats();
|
|
41
|
+
this.createEndpoint().then(() => this.parseOutputFormats());
|
|
64
42
|
}
|
|
65
43
|
this.resetUrl();
|
|
66
44
|
}
|
|
@@ -68,8 +46,7 @@ export class RecordApiFormComponent {
|
|
|
68
46
|
this.offset$.next(value);
|
|
69
47
|
}
|
|
70
48
|
setLimit(value) {
|
|
71
|
-
|
|
72
|
-
this.limit$.next(newLimit);
|
|
49
|
+
this.limit$.next(value === '' ? '-1' : value);
|
|
73
50
|
}
|
|
74
51
|
setFormat(value) {
|
|
75
52
|
this.format$.next(String(value));
|
|
@@ -79,50 +56,73 @@ export class RecordApiFormComponent {
|
|
|
79
56
|
this.limit$.next(DEFAULT_PARAMS.LIMIT);
|
|
80
57
|
this.format$.next(DEFAULT_PARAMS.FORMAT);
|
|
81
58
|
}
|
|
82
|
-
parseOutputFormats() {
|
|
83
|
-
|
|
59
|
+
async parseOutputFormats() {
|
|
60
|
+
if (!this.endpoint)
|
|
61
|
+
return;
|
|
62
|
+
const apiUrl = this.apiBaseUrl.endsWith('?')
|
|
84
63
|
? this.apiBaseUrl.slice(0, -1)
|
|
85
64
|
: this.apiBaseUrl;
|
|
86
|
-
this.getOutputFormats(apiUrl
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
this.outputFormats = this.outputFormats.concat(formatsList.filter(Boolean));
|
|
95
|
-
this.outputFormats = this.outputFormats
|
|
96
|
-
.filter((format, index, self) => index === self.findIndex((t) => t.value === format.value))
|
|
97
|
-
.sort((a, b) => a.label.localeCompare(b.label));
|
|
98
|
-
});
|
|
65
|
+
const outputFormats = await this.getOutputFormats(apiUrl);
|
|
66
|
+
const formatsList = outputFormats.itemFormats
|
|
67
|
+
? this.mapFormats(outputFormats.itemFormats)
|
|
68
|
+
: this.mapFormats(outputFormats.outputFormats || []);
|
|
69
|
+
this.outputFormats = this.outputFormats
|
|
70
|
+
.concat(formatsList.filter(Boolean))
|
|
71
|
+
.filter((format, index, self) => index === self.findIndex((t) => t.value === format.value))
|
|
72
|
+
.sort((a, b) => a.label.localeCompare(b.label));
|
|
99
73
|
}
|
|
100
74
|
mapFormats(formats) {
|
|
101
75
|
return formats.map((format) => {
|
|
102
76
|
const normalizedFormat = mimeTypeToFormat(format);
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
value: normalizedFormat,
|
|
107
|
-
};
|
|
108
|
-
}
|
|
109
|
-
return null;
|
|
77
|
+
return normalizedFormat
|
|
78
|
+
? { label: normalizedFormat.toUpperCase(), value: normalizedFormat }
|
|
79
|
+
: null;
|
|
110
80
|
});
|
|
111
81
|
}
|
|
112
|
-
async getOutputFormats(url
|
|
113
|
-
if (
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
82
|
+
async getOutputFormats(url) {
|
|
83
|
+
if (!this.endpoint)
|
|
84
|
+
return {};
|
|
85
|
+
if (this.endpoint instanceof WfsEndpoint) {
|
|
86
|
+
this.supportOffset = this.endpoint.supportsStartIndex();
|
|
87
|
+
return this.endpoint.getServiceInfo();
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
return (await this.endpoint.getCollectionInfo(this.firstCollection));
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
async createEndpoint() {
|
|
94
|
+
if (!this.apiBaseUrl || !this.accessServiceProtocol)
|
|
95
|
+
return;
|
|
96
|
+
if (this.accessServiceProtocol === 'wfs') {
|
|
97
|
+
this.endpoint = new WfsEndpoint(this.apiBaseUrl);
|
|
98
|
+
await this.endpoint.isReady();
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
this.endpoint = new OgcApiEndpoint(this.apiBaseUrl);
|
|
102
|
+
this.firstCollection = (await this.endpoint.allCollections)[0].name;
|
|
103
|
+
}
|
|
104
|
+
this.endpoint$.next(this.endpoint);
|
|
105
|
+
}
|
|
106
|
+
async generateApiQueryUrl(offset, limit, format) {
|
|
107
|
+
if (!this.apiBaseUrl || !this.endpoint || !this.apiFeatureType)
|
|
108
|
+
return '';
|
|
109
|
+
const options = {
|
|
110
|
+
outputFormat: format,
|
|
111
|
+
startIndex: offset ? Number(offset) : undefined,
|
|
112
|
+
maxFeatures: limit !== '-1' ? Number(limit) : undefined,
|
|
113
|
+
limit: limit !== '-1' ? Number(limit) : limit === '-1' ? -1 : undefined,
|
|
114
|
+
offset: offset !== '' ? Number(offset) : undefined,
|
|
115
|
+
};
|
|
116
|
+
if (this.endpoint instanceof WfsEndpoint) {
|
|
117
|
+
options.maxFeatures = limit !== '-1' ? Number(limit) : undefined;
|
|
118
|
+
return this.endpoint.getFeatureUrl(this.apiFeatureType, options);
|
|
117
119
|
}
|
|
118
120
|
else {
|
|
119
|
-
|
|
120
|
-
const firstCollection = (await endpoint.featureCollections)[0];
|
|
121
|
-
return endpoint.getCollectionInfo(firstCollection);
|
|
121
|
+
return await this.endpoint.getCollectionItemsUrl(this.firstCollection, options);
|
|
122
122
|
}
|
|
123
123
|
}
|
|
124
124
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: RecordApiFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
125
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: RecordApiFormComponent, selector: "gn-ui-record-api-form", inputs: { apiLink: "apiLink" }, ngImport: i0, template: "<div class=\"flex flex-col gap-8\">\n <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n <div class=\"flex flex-row\">\n <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n record.metadata.api.form.create\n </div>\n <button\n (click)=\"resetUrl()\"\n class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n >\n <p class=\"text-[13px] uppercase\" translate>\n record.metadata.api.form.reset\n </p>\n </button>\n </div>\n <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n <div class=\"flex flex-col gap-3\">\n <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n <div class=\"flex flex-row items-center gap-2\">\n <gn-ui-text-input\n class=\"mr-2 w-20\"\n (valueChange)=\"setLimit($event)\"\n [value]=\"displayLimit$ | async\"\n hint=\"\"\n >\n </gn-ui-text-input>\n <div class=\"flex items-center\">\n <input\n class=\"mr-2 cursor-pointer\"\n type=\"checkbox\"\n [checked]=\"noLimitChecked$ | async\"\n (change)=\"setLimit('-1')\"\n />\n <span class=\"text-sm\" translate\n >record.metadata.api.form.limit.all</span\n >\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3 relative\">\n <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n record.metadata.api.form.offset\n </p>\n <div class=\"flex items-center\">\n <gn-ui-text-input\n class=\"w-20\"\n [value]=\"offset$ | async\"\n [disabled]=\"!supportOffset\"\n (valueChange)=\"supportOffset ? setOffset($event) : null\"\n hint=\"\"\n >\n </gn-ui-text-input>\n <div\n *ngIf=\"!supportOffset\"\n class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n >\n <span\n class=\"material-symbols-outlined\"\n matTooltip=\"Not supported on this service\"\n >\n warning\n </span>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3\">\n <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n <gn-ui-dropdown-selector\n #dropdown\n [title]=\"''\"\n extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n [showTitle]=\"false\"\n class=\"text-black\"\n [choices]=\"outputFormats\"\n (selectValue)=\"setFormat($event)\"\n [selected]=\"format$ | async\"\n ></gn-ui-dropdown-selector>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3 mb-3\">\n <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n record.metadata.api.form.customUrl\n </div>\n <div class=\"bg-white rounded-lg\">\n <gn-ui-copy-text-button\n [text]=\"apiQueryUrl$ | async\"\n ></gn-ui-copy-text-button>\n </div>\n </div>\n</div>\n", styles: [":host ::ng-deep input{color:#000;opacity:1}:host ::ng-deep gn-ui-copy-text-button input[type=text]{color:#000;background-color:#fff}:host ::ng-deep gn-ui-copy-text-button button,host ::ng-deep gn-ui-copy-text-button button:hover{background-color:var(--color-secondary)!important}:host ::ng-deep gn-ui-copy-text-button button mat-icon{color:#fff!important;opacity:1!important}:host ::ng-deep gn-ui-copy-text-button button:hover mat-icon{color:#d3d3d3!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.DropdownSelectorComponent, selector: "gn-ui-dropdown-selector", inputs: ["title", "showTitle", "ariaName", "choices", "selected", "maxRows", "extraBtnClass", "minWidth"], outputs: ["selectValue"] }, { kind: "component", type: i5.TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "hint", "required", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: i6.CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
125
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: RecordApiFormComponent, selector: "gn-ui-record-api-form", inputs: { apiLink: "apiLink" }, ngImport: i0, template: "<div class=\"flex flex-col gap-8\">\n <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n <div class=\"flex flex-row\">\n <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n record.metadata.api.form.create\n </div>\n <button\n (click)=\"resetUrl()\"\n class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n >\n <p class=\"text-[13px] uppercase\" translate>\n record.metadata.api.form.reset\n </p>\n </button>\n </div>\n <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n <div class=\"flex flex-col gap-3\">\n <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n <div class=\"flex flex-row items-center gap-2\">\n <gn-ui-text-input\n class=\"mr-2 w-20\"\n (valueChange)=\"setLimit($event)\"\n [value]=\"displayLimit$ | async\"\n hint=\"\"\n >\n </gn-ui-text-input>\n <div class=\"flex items-center\">\n <input\n class=\"mr-2 cursor-pointer\"\n type=\"checkbox\"\n [checked]=\"noLimitChecked$ | async\"\n (change)=\"setLimit('-1')\"\n />\n <span class=\"text-sm\" translate\n >record.metadata.api.form.limit.all</span\n >\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3 relative\">\n <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n record.metadata.api.form.offset\n </p>\n <div class=\"flex items-center\">\n <gn-ui-text-input\n class=\"w-20\"\n [value]=\"offset$ | async\"\n [disabled]=\"!supportOffset\"\n (valueChange)=\"supportOffset ? setOffset($event) : null\"\n hint=\"\"\n >\n </gn-ui-text-input>\n <div\n *ngIf=\"!supportOffset\"\n class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n >\n <span\n class=\"material-symbols-outlined\"\n matTooltip=\"Not supported on this service\"\n >\n warning\n </span>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3\">\n <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n <gn-ui-dropdown-selector\n #dropdown\n [title]=\"''\"\n extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n [showTitle]=\"false\"\n class=\"text-black\"\n [choices]=\"outputFormats\"\n (selectValue)=\"setFormat($event)\"\n [selected]=\"format$ | async\"\n ></gn-ui-dropdown-selector>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3 mb-3\">\n <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n record.metadata.api.form.customUrl\n </div>\n <div class=\"bg-white rounded-lg\">\n <gn-ui-copy-text-button\n [text]=\"apiQueryUrl$ | async\"\n ></gn-ui-copy-text-button>\n </div>\n </div>\n</div>\n", styles: [":host ::ng-deep input{color:#000;opacity:1}:host ::ng-deep gn-ui-copy-text-button input[type=text]{color:#000;background-color:#fff}:host ::ng-deep gn-ui-copy-text-button button,host ::ng-deep gn-ui-copy-text-button button:hover{background-color:var(--color-secondary)!important}:host ::ng-deep gn-ui-copy-text-button button mat-icon{color:#fff!important;opacity:1!important}:host ::ng-deep gn-ui-copy-text-button button:hover mat-icon{color:#d3d3d3!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.DropdownSelectorComponent, selector: "gn-ui-dropdown-selector", inputs: ["title", "showTitle", "ariaName", "choices", "selected", "maxRows", "extraBtnClass", "minWidth", "disabled"], outputs: ["selectValue"] }, { kind: "component", type: i5.TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "hint", "required", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: i6.CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
126
126
|
}
|
|
127
127
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: RecordApiFormComponent, decorators: [{
|
|
128
128
|
type: Component,
|
|
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
130
130
|
}], propDecorators: { apiLink: [{
|
|
131
131
|
type: Input
|
|
132
132
|
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-api-form.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts","../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core'\nimport { OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client'\nimport {\n  DatasetServiceDistribution,\n  ServiceProtocol,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { mimeTypeToFormat } from '../../../../../../libs/util/shared/src'\nimport { BehaviorSubject, combineLatest, map, switchMap } from 'rxjs'\n\nconst DEFAULT_PARAMS = {\n  OFFSET: '',\n  LIMIT: '-1',\n  FORMAT: 'json',\n}\n@Component({\n  selector: 'gn-ui-record-api-form',\n  templateUrl: './record-api-form.component.html',\n  styleUrls: ['./record-api-form.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RecordApiFormComponent {\n  @Input() set apiLink(value: DatasetServiceDistribution) {\n    this.outputFormats = [{ value: 'json', label: 'JSON' }]\n    this.accessServiceProtocol = value ? value.accessServiceProtocol : undefined\n    this.apiFeatureType = value ? value.name : undefined\n    if (value) {\n      this.apiBaseUrl = value.url.href\n      this.parseOutputFormats()\n    }\n    this.resetUrl()\n  }\n\n  offset$ = new BehaviorSubject('')\n  limit$ = new BehaviorSubject('')\n  format$ = new BehaviorSubject('')\n  apiBaseUrl: string\n  apiFeatureType: string\n  supportOffset = true\n  accessServiceProtocol: ServiceProtocol | undefined\n  outputFormats = [{ value: 'json', label: 'JSON' }]\n\n  apiQueryUrl$ = combineLatest([this.offset$, this.limit$, this.format$]).pipe(\n    switchMap(async ([offset, limit, format]) => {\n      let outputUrl\n      if (this.apiBaseUrl) {\n        const url = new URL(this.apiBaseUrl)\n        const params = { offset: offset, limit: limit, f: format }\n        for (const [key, value] of Object.entries(params)) {\n          if (value && value !== '0') {\n            url.searchParams.set(key, value)\n          } else {\n            url.searchParams.delete(key)\n          }\n        }\n        outputUrl = url.toString()\n      }\n\n      if (this.accessServiceProtocol === 'wfs') {\n        const wfsEndpoint = new WfsEndpoint(this.apiBaseUrl)\n        if (await wfsEndpoint.isReady()) {\n          const options = {\n            outputFormat: format,\n            startIndex: Number(offset),\n          }\n          if (limit !== '-1') {\n            options['maxFeatures'] = Number(limit)\n          }\n          outputUrl = wfsEndpoint.getFeatureUrl(this.apiFeatureType, options)\n        }\n      }\n      return outputUrl\n    })\n  )\n  noLimitChecked$ = this.limit$.pipe(\n    map((limit) => limit === '-1' || limit === '')\n  )\n\n  displayLimit$ = this.limit$.pipe(\n    map((limit) => (limit !== '-1' ? limit : ''))\n  )\n\n  setOffset(value: string) {\n    this.offset$.next(value)\n  }\n\n  setLimit(value: string) {\n    const newLimit = value === '' ? '-1' : value\n    this.limit$.next(newLimit)\n  }\n\n  setFormat(value: string | unknown) {\n    this.format$.next(String(value))\n  }\n\n  resetUrl() {\n    this.offset$.next(DEFAULT_PARAMS.OFFSET)\n    this.limit$.next(DEFAULT_PARAMS.LIMIT)\n    this.format$.next(DEFAULT_PARAMS.FORMAT)\n  }\n\n  parseOutputFormats() {\n    const apiUrl =\n      this.apiBaseUrl.slice(-1) === '?'\n        ? this.apiBaseUrl.slice(0, -1)\n        : this.apiBaseUrl\n\n    this.getOutputFormats(apiUrl, this.accessServiceProtocol).then(\n      (outputFormats) => {\n        let formatsList = []\n        if ('itemFormats' in outputFormats) {\n          formatsList = this.mapFormats(outputFormats.itemFormats)\n        } else if ('outputFormats' in outputFormats) {\n          formatsList = this.mapFormats(outputFormats.outputFormats)\n        }\n        this.outputFormats = this.outputFormats.concat(\n          formatsList.filter(Boolean)\n        )\n        this.outputFormats = this.outputFormats\n          .filter(\n            (format, index, self) =>\n              index === self.findIndex((t) => t.value === format.value)\n          )\n          .sort((a, b) => a.label.localeCompare(b.label))\n      }\n    )\n  }\n\n  mapFormats(formats: any[]) {\n    return formats.map((format) => {\n      const normalizedFormat = mimeTypeToFormat(format)\n      if (normalizedFormat) {\n        return {\n          label: normalizedFormat.toUpperCase(),\n          value: normalizedFormat,\n        }\n      }\n      return null\n    })\n  }\n\n  async getOutputFormats(url: string, accessServiceProtocol: string) {\n    if (accessServiceProtocol === 'wfs') {\n      const endpoint = await new WfsEndpoint(url).isReady()\n      this.supportOffset = endpoint.supportsStartIndex()\n      return endpoint.getServiceInfo()\n    } else {\n      const endpoint = await new OgcApiEndpoint(url)\n      const firstCollection = (await endpoint.featureCollections)[0]\n      return endpoint.getCollectionInfo(firstCollection)\n    }\n  }\n}\n","<div class=\"flex flex-col gap-8\">\n  <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n    <div class=\"flex flex-row\">\n      <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n        record.metadata.api.form.create\n      </div>\n      <button\n        (click)=\"resetUrl()\"\n        class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n      >\n        <p class=\"text-[13px] uppercase\" translate>\n          record.metadata.api.form.reset\n        </p>\n      </button>\n    </div>\n    <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n        <div class=\"flex flex-row items-center gap-2\">\n          <gn-ui-text-input\n            class=\"mr-2 w-20\"\n            (valueChange)=\"setLimit($event)\"\n            [value]=\"displayLimit$ | async\"\n            hint=\"\"\n          >\n          </gn-ui-text-input>\n          <div class=\"flex items-center\">\n            <input\n              class=\"mr-2 cursor-pointer\"\n              type=\"checkbox\"\n              [checked]=\"noLimitChecked$ | async\"\n              (change)=\"setLimit('-1')\"\n            />\n            <span class=\"text-sm\" translate\n              >record.metadata.api.form.limit.all</span\n            >\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3 relative\">\n        <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n          record.metadata.api.form.offset\n        </p>\n        <div class=\"flex items-center\">\n          <gn-ui-text-input\n            class=\"w-20\"\n            [value]=\"offset$ | async\"\n            [disabled]=\"!supportOffset\"\n            (valueChange)=\"supportOffset ? setOffset($event) : null\"\n            hint=\"\"\n          >\n          </gn-ui-text-input>\n          <div\n            *ngIf=\"!supportOffset\"\n            class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n          >\n            <span\n              class=\"material-symbols-outlined\"\n              matTooltip=\"Not supported on this service\"\n            >\n              warning\n            </span>\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n        <gn-ui-dropdown-selector\n          #dropdown\n          [title]=\"''\"\n          extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n          [showTitle]=\"false\"\n          class=\"text-black\"\n          [choices]=\"outputFormats\"\n          (selectValue)=\"setFormat($event)\"\n          [selected]=\"format$ | async\"\n        ></gn-ui-dropdown-selector>\n      </div>\n    </div>\n  </div>\n  <div class=\"flex flex-col gap-3 mb-3\">\n    <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n      record.metadata.api.form.customUrl\n    </div>\n    <div class=\"bg-white rounded-lg\">\n      <gn-ui-copy-text-button\n        [text]=\"apiQueryUrl$ | async\"\n      ></gn-ui-copy-text-button>\n    </div>\n  </div>\n</div>\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-api-form.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts","../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core'\nimport { OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client'\nimport {\n  DatasetServiceDistribution,\n  ServiceProtocol,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { mimeTypeToFormat } from '../../../../../../libs/util/shared/src'\nimport { BehaviorSubject, combineLatest, filter, map, switchMap } from 'rxjs'\n\nconst DEFAULT_PARAMS = {\n  OFFSET: '',\n  LIMIT: '-1',\n  FORMAT: 'json',\n}\n\ninterface OutputFormats {\n  itemFormats?: any[]\n  outputFormats?: any[]\n}\n\n@Component({\n  selector: 'gn-ui-record-api-form',\n  templateUrl: './record-api-form.component.html',\n  styleUrls: ['./record-api-form.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RecordApiFormComponent {\n  @Input() set apiLink(value: DatasetServiceDistribution) {\n    this.outputFormats = [{ value: 'json', label: 'JSON' }]\n    this.accessServiceProtocol = value ? value.accessServiceProtocol : undefined\n    this.apiFeatureType = value ? value.name : undefined\n    if (value) {\n      this.apiBaseUrl = value.url.href\n      this.createEndpoint().then(() => this.parseOutputFormats())\n    }\n    this.resetUrl()\n  }\n\n  offset$ = new BehaviorSubject(DEFAULT_PARAMS.OFFSET)\n  limit$ = new BehaviorSubject(DEFAULT_PARAMS.LIMIT)\n  format$ = new BehaviorSubject(DEFAULT_PARAMS.FORMAT)\n  endpoint$ = new BehaviorSubject<WfsEndpoint | OgcApiEndpoint | undefined>(\n    undefined\n  )\n  apiBaseUrl: string\n  apiFeatureType: string\n  supportOffset = true\n  accessServiceProtocol: ServiceProtocol | undefined\n  outputFormats = [{ value: 'json', label: 'JSON' }]\n  endpoint: WfsEndpoint | OgcApiEndpoint | undefined\n  firstCollection: string | undefined\n\n  apiQueryUrl$ = combineLatest([\n    this.offset$,\n    this.limit$,\n    this.format$,\n    // only compute the url if the endpoint was created\n    this.endpoint$.pipe(filter((endpoint) => !!endpoint)),\n  ]).pipe(\n    switchMap(([offset, limit, format]) =>\n      this.generateApiQueryUrl(offset, limit, format)\n    )\n  )\n\n  noLimitChecked$ = this.limit$.pipe(\n    map((limit) => limit === '-1' || limit === '')\n  )\n  displayLimit$ = this.limit$.pipe(\n    map((limit) => (limit !== '-1' ? limit : ''))\n  )\n\n  setOffset(value: string) {\n    this.offset$.next(value)\n  }\n\n  setLimit(value: string) {\n    this.limit$.next(value === '' ? '-1' : value)\n  }\n\n  setFormat(value: string | unknown) {\n    this.format$.next(String(value))\n  }\n\n  resetUrl() {\n    this.offset$.next(DEFAULT_PARAMS.OFFSET)\n    this.limit$.next(DEFAULT_PARAMS.LIMIT)\n    this.format$.next(DEFAULT_PARAMS.FORMAT)\n  }\n\n  async parseOutputFormats() {\n    if (!this.endpoint) return\n    const apiUrl = this.apiBaseUrl.endsWith('?')\n      ? this.apiBaseUrl.slice(0, -1)\n      : this.apiBaseUrl\n    const outputFormats = await this.getOutputFormats(apiUrl)\n\n    const formatsList = outputFormats.itemFormats\n      ? this.mapFormats(outputFormats.itemFormats)\n      : this.mapFormats(outputFormats.outputFormats || [])\n\n    this.outputFormats = this.outputFormats\n      .concat(formatsList.filter(Boolean))\n      .filter(\n        (format, index, self) =>\n          index === self.findIndex((t) => t.value === format.value)\n      )\n      .sort((a, b) => a.label.localeCompare(b.label))\n  }\n\n  mapFormats(formats: any[]) {\n    return formats.map((format) => {\n      const normalizedFormat = mimeTypeToFormat(format)\n      return normalizedFormat\n        ? { label: normalizedFormat.toUpperCase(), value: normalizedFormat }\n        : null\n    })\n  }\n\n  async getOutputFormats(url: string): Promise<OutputFormats> {\n    if (!this.endpoint) return {}\n    if (this.endpoint instanceof WfsEndpoint) {\n      this.supportOffset = this.endpoint.supportsStartIndex()\n      return this.endpoint.getServiceInfo() as OutputFormats\n    } else {\n      return (await this.endpoint.getCollectionInfo(\n        this.firstCollection\n      )) as OutputFormats\n    }\n  }\n\n  async createEndpoint() {\n    if (!this.apiBaseUrl || !this.accessServiceProtocol) return\n    if (this.accessServiceProtocol === 'wfs') {\n      this.endpoint = new WfsEndpoint(this.apiBaseUrl)\n      await (this.endpoint as WfsEndpoint).isReady()\n    } else {\n      this.endpoint = new OgcApiEndpoint(this.apiBaseUrl)\n      this.firstCollection = (await this.endpoint.allCollections)[0].name\n    }\n    this.endpoint$.next(this.endpoint)\n  }\n\n  async generateApiQueryUrl(\n    offset: string,\n    limit: string,\n    format: string\n  ): Promise<string> {\n    if (!this.apiBaseUrl || !this.endpoint || !this.apiFeatureType) return ''\n\n    const options = {\n      outputFormat: format,\n      startIndex: offset ? Number(offset) : undefined,\n      maxFeatures: limit !== '-1' ? Number(limit) : undefined,\n      limit: limit !== '-1' ? Number(limit) : limit === '-1' ? -1 : undefined,\n      offset: offset !== '' ? Number(offset) : undefined,\n    }\n\n    if (this.endpoint instanceof WfsEndpoint) {\n      options.maxFeatures = limit !== '-1' ? Number(limit) : undefined\n      return this.endpoint.getFeatureUrl(this.apiFeatureType, options)\n    } else {\n      return await this.endpoint.getCollectionItemsUrl(\n        this.firstCollection,\n        options\n      )\n    }\n  }\n}\n","<div class=\"flex flex-col gap-8\">\n  <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n    <div class=\"flex flex-row\">\n      <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n        record.metadata.api.form.create\n      </div>\n      <button\n        (click)=\"resetUrl()\"\n        class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n      >\n        <p class=\"text-[13px] uppercase\" translate>\n          record.metadata.api.form.reset\n        </p>\n      </button>\n    </div>\n    <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n        <div class=\"flex flex-row items-center gap-2\">\n          <gn-ui-text-input\n            class=\"mr-2 w-20\"\n            (valueChange)=\"setLimit($event)\"\n            [value]=\"displayLimit$ | async\"\n            hint=\"\"\n          >\n          </gn-ui-text-input>\n          <div class=\"flex items-center\">\n            <input\n              class=\"mr-2 cursor-pointer\"\n              type=\"checkbox\"\n              [checked]=\"noLimitChecked$ | async\"\n              (change)=\"setLimit('-1')\"\n            />\n            <span class=\"text-sm\" translate\n              >record.metadata.api.form.limit.all</span\n            >\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3 relative\">\n        <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n          record.metadata.api.form.offset\n        </p>\n        <div class=\"flex items-center\">\n          <gn-ui-text-input\n            class=\"w-20\"\n            [value]=\"offset$ | async\"\n            [disabled]=\"!supportOffset\"\n            (valueChange)=\"supportOffset ? setOffset($event) : null\"\n            hint=\"\"\n          >\n          </gn-ui-text-input>\n          <div\n            *ngIf=\"!supportOffset\"\n            class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n          >\n            <span\n              class=\"material-symbols-outlined\"\n              matTooltip=\"Not supported on this service\"\n            >\n              warning\n            </span>\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n        <gn-ui-dropdown-selector\n          #dropdown\n          [title]=\"''\"\n          extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n          [showTitle]=\"false\"\n          class=\"text-black\"\n          [choices]=\"outputFormats\"\n          (selectValue)=\"setFormat($event)\"\n          [selected]=\"format$ | async\"\n        ></gn-ui-dropdown-selector>\n      </div>\n    </div>\n  </div>\n  <div class=\"flex flex-col gap-3 mb-3\">\n    <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n      record.metadata.api.form.customUrl\n    </div>\n    <div class=\"bg-white rounded-lg\">\n      <gn-ui-copy-text-button\n        [text]=\"apiQueryUrl$ | async\"\n      ></gn-ui-copy-text-button>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -17,7 +17,7 @@ import { MetadataContactComponent } from './metadata-contact/metadata-contact.co
|
|
|
17
17
|
import { MetadataCatalogComponent } from './metadata-catalog/metadata-catalog.component';
|
|
18
18
|
import { MetadataQualityComponent } from './metadata-quality/metadata-quality.component';
|
|
19
19
|
import { MetadataQualityItemComponent } from './metadata-quality-item/metadata-quality-item.component';
|
|
20
|
-
import {
|
|
20
|
+
import { ErrorComponent } from './error/error.component';
|
|
21
21
|
import { PaginationComponent } from './pagination/pagination.component';
|
|
22
22
|
import { ThumbnailComponent } from './thumbnail/thumbnail.component';
|
|
23
23
|
import { UiInputsModule } from '../../../../../libs/ui/inputs/src';
|
|
@@ -46,7 +46,7 @@ export class UiElementsModule {
|
|
|
46
46
|
MetadataCatalogComponent,
|
|
47
47
|
MetadataQualityComponent,
|
|
48
48
|
MetadataQualityItemComponent,
|
|
49
|
-
|
|
49
|
+
ErrorComponent,
|
|
50
50
|
PaginationComponent,
|
|
51
51
|
AvatarComponent,
|
|
52
52
|
UserPreviewComponent,
|
|
@@ -76,7 +76,7 @@ export class UiElementsModule {
|
|
|
76
76
|
MetadataCatalogComponent,
|
|
77
77
|
MetadataQualityComponent,
|
|
78
78
|
MetadataQualityItemComponent,
|
|
79
|
-
|
|
79
|
+
ErrorComponent,
|
|
80
80
|
PaginationComponent,
|
|
81
81
|
ThumbnailComponent,
|
|
82
82
|
AvatarComponent,
|
|
@@ -129,7 +129,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
129
129
|
MetadataCatalogComponent,
|
|
130
130
|
MetadataQualityComponent,
|
|
131
131
|
MetadataQualityItemComponent,
|
|
132
|
-
|
|
132
|
+
ErrorComponent,
|
|
133
133
|
PaginationComponent,
|
|
134
134
|
AvatarComponent,
|
|
135
135
|
UserPreviewComponent,
|
|
@@ -151,7 +151,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
151
151
|
MetadataCatalogComponent,
|
|
152
152
|
MetadataQualityComponent,
|
|
153
153
|
MetadataQualityItemComponent,
|
|
154
|
-
|
|
154
|
+
ErrorComponent,
|
|
155
155
|
PaginationComponent,
|
|
156
156
|
ThumbnailComponent,
|
|
157
157
|
AvatarComponent,
|
|
@@ -165,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
165
165
|
],
|
|
166
166
|
}]
|
|
167
167
|
}] });
|
|
168
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-elements.module.js","sourceRoot":"","sources":["../../../../../../../libs/ui/elements/src/lib/ui-elements.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core'\nimport { CommonModule, NgOptimizedImage } from '@angular/common'\nimport { RouterModule } from '@angular/router'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { UtilSharedModule } from '../../../../../libs/util/shared/src'\nimport { MetadataInfoComponent } from './metadata-info/metadata-info.component'\nimport { ContentGhostComponent } from './content-ghost/content-ghost.component'\nimport { DownloadItemComponent } from './download-item/download-item.component'\nimport { DownloadsListComponent } from './downloads-list/downloads-list.component'\nimport { ApiCardComponent } from './api-card/api-card.component'\nimport { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'\nimport { UiLayoutModule } from '../../../../../libs/ui/layout/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { LinkCardComponent } from './link-card/link-card.component'\nimport { RelatedRecordCardComponent } from './related-record-card/related-record-card.component'\nimport { MetadataContactComponent } from './metadata-contact/metadata-contact.component'\nimport { MetadataCatalogComponent } from './metadata-catalog/metadata-catalog.component'\nimport { MetadataQualityComponent } from './metadata-quality/metadata-quality.component'\nimport { MetadataQualityItemComponent } from './metadata-quality-item/metadata-quality-item.component'\nimport { SearchResultsErrorComponent } from './search-results-error/search-results-error.component'\nimport { PaginationComponent } from './pagination/pagination.component'\nimport { ThumbnailComponent } from './thumbnail/thumbnail.component'\nimport { UiInputsModule } from '../../../../../libs/ui/inputs/src'\nimport { FormsModule } from '@angular/forms'\nimport { AvatarComponent } from './avatar/avatar.component'\nimport { UserPreviewComponent } from './user-preview/user-preview.component'\nimport { GnUiLinkifyDirective } from './metadata-info/linkify.directive'\nimport { PaginationButtonsComponent } from './pagination-buttons/pagination-buttons.component'\nimport { MaxLinesComponent } from './max-lines/max-lines.component'\nimport { RecordApiFormComponent } from './record-api-form/record-api-form.component'\nimport { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'\nimport { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'\nimport { UserFeedbackItemComponent } from './user-feedback-item/user-feedback-item.component'\nimport { TimeSincePipe } from './user-feedback-item/time-since.pipe'\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatIconModule,\n    MatTooltipModule,\n    UiWidgetsModule,\n    UiLayoutModule,\n    TranslateModule.forChild(),\n    UtilSharedModule,\n    RouterModule,\n    UiInputsModule,\n    FormsModule,\n    NgOptimizedImage,\n    MarkdownParserComponent,\n    ThumbnailComponent,\n    TimeSincePipe,\n  ],\n  declarations: [\n    MetadataInfoComponent,\n    ContentGhostComponent,\n    DownloadItemComponent,\n    DownloadsListComponent,\n    ApiCardComponent,\n    RelatedRecordCardComponent,\n    MetadataContactComponent,\n    MetadataCatalogComponent,\n    MetadataQualityComponent,\n    MetadataQualityItemComponent,\n    SearchResultsErrorComponent,\n    PaginationComponent,\n    AvatarComponent,\n    UserPreviewComponent,\n    GnUiLinkifyDirective,\n    PaginationButtonsComponent,\n    MaxLinesComponent,\n    RecordApiFormComponent,\n    UserFeedbackItemComponent,\n    ImageOverlayPreviewComponent,\n  ],\n  exports: [\n    MetadataInfoComponent,\n    ContentGhostComponent,\n    DownloadItemComponent,\n    DownloadsListComponent,\n    ApiCardComponent,\n    RelatedRecordCardComponent,\n    MetadataContactComponent,\n    MetadataCatalogComponent,\n    MetadataQualityComponent,\n    MetadataQualityItemComponent,\n    SearchResultsErrorComponent,\n    PaginationComponent,\n    ThumbnailComponent,\n    AvatarComponent,\n    UserPreviewComponent,\n    PaginationButtonsComponent,\n    MaxLinesComponent,\n    RecordApiFormComponent,\n    MarkdownParserComponent,\n    UserFeedbackItemComponent,\n    ImageOverlayPreviewComponent,\n  ],\n})\nexport class UiElementsModule {}\n"]}
|
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-elements.module.js","sourceRoot":"","sources":["../../../../../../../libs/ui/elements/src/lib/ui-elements.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core'\nimport { CommonModule, NgOptimizedImage } from '@angular/common'\nimport { RouterModule } from '@angular/router'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { UtilSharedModule } from '../../../../../libs/util/shared/src'\nimport { MetadataInfoComponent } from './metadata-info/metadata-info.component'\nimport { ContentGhostComponent } from './content-ghost/content-ghost.component'\nimport { DownloadItemComponent } from './download-item/download-item.component'\nimport { DownloadsListComponent } from './downloads-list/downloads-list.component'\nimport { ApiCardComponent } from './api-card/api-card.component'\nimport { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'\nimport { UiLayoutModule } from '../../../../../libs/ui/layout/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { RelatedRecordCardComponent } from './related-record-card/related-record-card.component'\nimport { MetadataContactComponent } from './metadata-contact/metadata-contact.component'\nimport { MetadataCatalogComponent } from './metadata-catalog/metadata-catalog.component'\nimport { MetadataQualityComponent } from './metadata-quality/metadata-quality.component'\nimport { MetadataQualityItemComponent } from './metadata-quality-item/metadata-quality-item.component'\nimport { ErrorComponent } from './error/error.component'\nimport { PaginationComponent } from './pagination/pagination.component'\nimport { ThumbnailComponent } from './thumbnail/thumbnail.component'\nimport { UiInputsModule } from '../../../../../libs/ui/inputs/src'\nimport { FormsModule } from '@angular/forms'\nimport { AvatarComponent } from './avatar/avatar.component'\nimport { UserPreviewComponent } from './user-preview/user-preview.component'\nimport { GnUiLinkifyDirective } from './metadata-info/linkify.directive'\nimport { PaginationButtonsComponent } from './pagination-buttons/pagination-buttons.component'\nimport { MaxLinesComponent } from './max-lines/max-lines.component'\nimport { RecordApiFormComponent } from './record-api-form/record-api-form.component'\nimport { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'\nimport { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'\nimport { UserFeedbackItemComponent } from './user-feedback-item/user-feedback-item.component'\nimport { TimeSincePipe } from './user-feedback-item/time-since.pipe'\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatIconModule,\n    MatTooltipModule,\n    UiWidgetsModule,\n    UiLayoutModule,\n    TranslateModule.forChild(),\n    UtilSharedModule,\n    RouterModule,\n    UiInputsModule,\n    FormsModule,\n    NgOptimizedImage,\n    MarkdownParserComponent,\n    ThumbnailComponent,\n    TimeSincePipe,\n  ],\n  declarations: [\n    MetadataInfoComponent,\n    ContentGhostComponent,\n    DownloadItemComponent,\n    DownloadsListComponent,\n    ApiCardComponent,\n    RelatedRecordCardComponent,\n    MetadataContactComponent,\n    MetadataCatalogComponent,\n    MetadataQualityComponent,\n    MetadataQualityItemComponent,\n    ErrorComponent,\n    PaginationComponent,\n    AvatarComponent,\n    UserPreviewComponent,\n    GnUiLinkifyDirective,\n    PaginationButtonsComponent,\n    MaxLinesComponent,\n    RecordApiFormComponent,\n    UserFeedbackItemComponent,\n    ImageOverlayPreviewComponent,\n  ],\n  exports: [\n    MetadataInfoComponent,\n    ContentGhostComponent,\n    DownloadItemComponent,\n    DownloadsListComponent,\n    ApiCardComponent,\n    RelatedRecordCardComponent,\n    MetadataContactComponent,\n    MetadataCatalogComponent,\n    MetadataQualityComponent,\n    MetadataQualityItemComponent,\n    ErrorComponent,\n    PaginationComponent,\n    ThumbnailComponent,\n    AvatarComponent,\n    UserPreviewComponent,\n    PaginationButtonsComponent,\n    MaxLinesComponent,\n    RecordApiFormComponent,\n    MarkdownParserComponent,\n    UserFeedbackItemComponent,\n    ImageOverlayPreviewComponent,\n  ],\n})\nexport class UiElementsModule {}\n"]}
|
package/esm2022/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.mjs
CHANGED
|
@@ -39,17 +39,15 @@ export class UserFeedbackItemComponent {
|
|
|
39
39
|
this.onNewAnswerValueChange();
|
|
40
40
|
}
|
|
41
41
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: UserFeedbackItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: UserFeedbackItemComponent, selector: "gn-ui-user-feedback-item", inputs: { userFeedbackParent: "userFeedbackParent", userFeedBacksAnswers: "userFeedBacksAnswers",
|
|
42
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: UserFeedbackItemComponent, selector: "gn-ui-user-feedback-item", inputs: { userFeedbackParent: "userFeedbackParent", userFeedBacksAnswers: "userFeedBacksAnswers", activeUser: "activeUser", isLastComment: "isLastComment", isAddUserFeedbackLoading: "isAddUserFeedbackLoading" }, outputs: { newUserFeedbackAnswer: "newUserFeedbackAnswer" }, ngImport: i0, template: "<div\n *ngIf=\"userFeedbackParent.published\"\n class=\"flex flex-col bg-white rounded w-full\"\n [ngClass]=\"[isAnAnswer ? 'ps-4 ' : 'p-4']\"\n>\n <div class=\"flex flex-row\">\n <div class=\"avatar\">\n <img\n class=\"rounded-full\"\n [src]=\"userFeedbackParent.avatarUrl\"\n alt=\"avatar\"\n />\n </div>\n <div class=\"p-4 flex flex-col\">\n <span>{{ userFeedbackParent.authorName }}</span>\n <span> {{ userFeedbackParent.date | timeSince }}</span>\n </div>\n </div>\n <div data-cy=\"commentText\" class=\"mt-4 whitespace-pre-line\">\n {{ userFeedbackParent.comment }}\n </div>\n <div\n class=\"w-full\"\n *ngFor=\"let userFeedBacksAnswer of userFeedBacksAnswers; let last = last\"\n >\n <hr class=\"-mx-4 my-6\" />\n <gn-ui-user-feedback-item\n [userFeedbackParent]=\"userFeedBacksAnswer\"\n [isLastComment]=\"last\"\n ></gn-ui-user-feedback-item>\n </div>\n\n <div *ngIf=\"activeUser\" class=\"mt-2 flex flex-col\">\n <hr class=\"-mx-4 my-4\" />\n <div\n id=\"new-comment-buttons\"\n class=\"flex flex-row gap-2 items-center justify-end\"\n >\n <gn-ui-text-area\n [disabled]=\"isAddUserFeedbackLoading\"\n [(value)]=\"newAnswer\"\n (valueChange)=\"onNewAnswerValueChange()\"\n (keyup.control.enter)=\"publishNewAnswer()\"\n [placeholder]=\"\n 'record.metadata.userFeedbacks.newAnswer.placeholder' | translate\n \"\n class=\"grow\"\n extraClass=\"bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9\"\n ></gn-ui-text-area>\n <div *ngIf=\"!isAnswerEmpty\" class=\"flex flex-row justify-end\">\n <gn-ui-button\n [disabled]=\"isAddUserFeedbackLoading\"\n [type]=\"'outline'\"\n (buttonClick)=\"publishNewAnswer()\"\n [title]=\"\n 'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate\n \"\n extraClass=\"!p-[0.5em] text-primary-darker border-primary-darker h-9\"\n >\n <mat-icon\n class=\"material-symbols-outlined\"\n *ngIf=\"!isAddUserFeedbackLoading\"\n >\n send\n </mat-icon>\n <ng-container *ngIf=\"isAddUserFeedbackLoading\">\n <div class=\"flex justify-center w-full\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n </gn-ui-button>\n </div>\n </div>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.SpinningLoaderComponent, selector: "gn-ui-spinning-loader" }, { kind: "component", type: i4.ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: i5.TextAreaComponent, selector: "gn-ui-text-area", inputs: ["value", "disabled", "extraClass", "placeholder", "required"], outputs: ["valueChange"] }, { kind: "component", type: UserFeedbackItemComponent, selector: "gn-ui-user-feedback-item", inputs: ["userFeedbackParent", "userFeedBacksAnswers", "activeUser", "isLastComment", "isAddUserFeedbackLoading"], outputs: ["newUserFeedbackAnswer"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.TimeSincePipe, name: "timeSince" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
43
43
|
}
|
|
44
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: UserFeedbackItemComponent, decorators: [{
|
|
45
45
|
type: Component,
|
|
46
|
-
args: [{ selector: 'gn-ui-user-feedback-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"userFeedbackParent.published\"\n class=\"flex flex-col bg-white rounded w-full\"\n [ngClass]=\"[isAnAnswer ? 'ps-4 ' : 'p-4']\"\n>\n <div class=\"flex flex-row\">\n <div class=\"avatar\">\n <img\n class=\"rounded-full\"\n [src]=\"userFeedbackParent.avatarUrl\"\n alt=\"avatar\"\n />\n </div>\n <div class=\"p-4 flex flex-col\">\n <span>{{ userFeedbackParent.authorName }}</span>\n <span> {{ userFeedbackParent.date | timeSince }}</span>\n </div>\n </div>\n <div data-cy=\"commentText\" class=\"mt-4 whitespace-pre-line\">\n {{ userFeedbackParent.comment }}\n </div>\n <div\n class=\"w-full\"\n *ngFor=\"let userFeedBacksAnswer of userFeedBacksAnswers; let last = last\"\n >\n <hr class=\"-mx-4 my-6\" />\n <gn-ui-user-feedback-item\n [userFeedbackParent]=\"userFeedBacksAnswer\"\n [isLastComment]=\"last\"\n ></gn-ui-user-feedback-item>\n </div>\n\n <div *ngIf=\"
|
|
46
|
+
args: [{ selector: 'gn-ui-user-feedback-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"userFeedbackParent.published\"\n class=\"flex flex-col bg-white rounded w-full\"\n [ngClass]=\"[isAnAnswer ? 'ps-4 ' : 'p-4']\"\n>\n <div class=\"flex flex-row\">\n <div class=\"avatar\">\n <img\n class=\"rounded-full\"\n [src]=\"userFeedbackParent.avatarUrl\"\n alt=\"avatar\"\n />\n </div>\n <div class=\"p-4 flex flex-col\">\n <span>{{ userFeedbackParent.authorName }}</span>\n <span> {{ userFeedbackParent.date | timeSince }}</span>\n </div>\n </div>\n <div data-cy=\"commentText\" class=\"mt-4 whitespace-pre-line\">\n {{ userFeedbackParent.comment }}\n </div>\n <div\n class=\"w-full\"\n *ngFor=\"let userFeedBacksAnswer of userFeedBacksAnswers; let last = last\"\n >\n <hr class=\"-mx-4 my-6\" />\n <gn-ui-user-feedback-item\n [userFeedbackParent]=\"userFeedBacksAnswer\"\n [isLastComment]=\"last\"\n ></gn-ui-user-feedback-item>\n </div>\n\n <div *ngIf=\"activeUser\" class=\"mt-2 flex flex-col\">\n <hr class=\"-mx-4 my-4\" />\n <div\n id=\"new-comment-buttons\"\n class=\"flex flex-row gap-2 items-center justify-end\"\n >\n <gn-ui-text-area\n [disabled]=\"isAddUserFeedbackLoading\"\n [(value)]=\"newAnswer\"\n (valueChange)=\"onNewAnswerValueChange()\"\n (keyup.control.enter)=\"publishNewAnswer()\"\n [placeholder]=\"\n 'record.metadata.userFeedbacks.newAnswer.placeholder' | translate\n \"\n class=\"grow\"\n extraClass=\"bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9\"\n ></gn-ui-text-area>\n <div *ngIf=\"!isAnswerEmpty\" class=\"flex flex-row justify-end\">\n <gn-ui-button\n [disabled]=\"isAddUserFeedbackLoading\"\n [type]=\"'outline'\"\n (buttonClick)=\"publishNewAnswer()\"\n [title]=\"\n 'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate\n \"\n extraClass=\"!p-[0.5em] text-primary-darker border-primary-darker h-9\"\n >\n <mat-icon\n class=\"material-symbols-outlined\"\n *ngIf=\"!isAddUserFeedbackLoading\"\n >\n send\n </mat-icon>\n <ng-container *ngIf=\"isAddUserFeedbackLoading\">\n <div class=\"flex justify-center w-full\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n </gn-ui-button>\n </div>\n </div>\n </div>\n</div>\n" }]
|
|
47
47
|
}], propDecorators: { userFeedbackParent: [{
|
|
48
48
|
type: Input
|
|
49
49
|
}], userFeedBacksAnswers: [{
|
|
50
50
|
type: Input
|
|
51
|
-
}], isActiveUserEditor: [{
|
|
52
|
-
type: Input
|
|
53
51
|
}], activeUser: [{
|
|
54
52
|
type: Input
|
|
55
53
|
}], isLastComment: [{
|
|
@@ -59,4 +57,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
59
57
|
}], newUserFeedbackAnswer: [{
|
|
60
58
|
type: Output
|
|
61
59
|
}] } });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi91c2VyLWZlZWRiYWNrLWl0ZW0vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi91c2VyLWZlZWRiYWNrLWl0ZW0vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBRUwsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFBOzs7Ozs7Ozs7QUFhdEIsTUFBTSxPQUFPLHlCQUF5QjtJQU50QztRQWFZLDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFnQixDQUFBO1FBRWxFLGVBQVUsR0FBRyxLQUFLLENBQUE7UUFDbEIsY0FBUyxHQUFHLEVBQUUsQ0FBQTtRQUNkLGtCQUFhLEdBQUcsSUFBSSxDQUFBO0tBOEJyQjtJQTVCQyxRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFVBQVUsQ0FBQTtJQUN4RCxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFBO0lBQ2xELENBQUM7SUFFRCxnQkFBZ0I7UUFDZCxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRTtZQUFFLE9BQU07UUFFeEMsTUFBTSxTQUFTLEdBQWlCO1lBQzlCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQjtZQUMxQixJQUFJLEVBQUUsU0FBUztZQUNmLFNBQVMsRUFBRSxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUksQ0FBQyxTQUFTO1lBQ3ZCLFVBQVUsRUFBRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSTtZQUN4QyxZQUFZLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ2pDLFdBQVcsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUs7WUFDbkMsSUFBSSxFQUFFLElBQUksSUFBSSxFQUFFO1lBQ2hCLFVBQVUsRUFBRSxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFO1NBQ25FLENBQUE7UUFFRCxJQUFJLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFBO1FBRTFDLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFBO1FBQ25CLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFBO0lBQy9CLENBQUM7OEdBeENVLHlCQUF5QjtrR0FBekIseUJBQXlCLGlWQ3BCdEMsaS9FQTJFQSw2NkJEdkRhLHlCQUF5Qjs7MkZBQXpCLHlCQUF5QjtrQkFOckMsU0FBUzsrQkFDRSwwQkFBMEIsbUJBR25CLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDRyxvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLHdCQUF3QjtzQkFBaEMsS0FBSztnQkFFSSxxQkFBcUI7c0JBQTlCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPbkluaXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7XG4gIFVzZXJGZWVkYmFjayxcbiAgVXNlckZlZWRiYWNrVmlld01vZGVsLFxufSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC9yZWNvcmQnXG5pbXBvcnQgeyBVc2VyTW9kZWwgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC91c2VyJ1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdnbi11aS11c2VyLWZlZWRiYWNrLWl0ZW0nLFxuICB0ZW1wbGF0ZVVybDogJy4vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5jc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJGZWVkYmFja0l0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSB1c2VyRmVlZGJhY2tQYXJlbnQ6IFVzZXJGZWVkYmFja1ZpZXdNb2RlbFxuICBASW5wdXQoKSB1c2VyRmVlZEJhY2tzQW5zd2VyczogVXNlckZlZWRiYWNrVmlld01vZGVsW11cbiAgQElucHV0KCkgYWN0aXZlVXNlcjogVXNlck1vZGVsXG4gIEBJbnB1dCgpIGlzTGFzdENvbW1lbnQ6IGJvb2xlYW5cbiAgQElucHV0KCkgaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nOiBib29sZWFuXG5cbiAgQE91dHB1dCgpIG5ld1VzZXJGZWVkYmFja0Fuc3dlciA9IG5ldyBFdmVudEVtaXR0ZXI8VXNlckZlZWRiYWNrPigpXG5cbiAgaXNBbkFuc3dlciA9IGZhbHNlXG4gIG5ld0Fuc3dlciA9ICcnXG4gIGlzQW5zd2VyRW1wdHkgPSB0cnVlXG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5pc0FuQW5zd2VyID0gISF0aGlzLnVzZXJGZWVkYmFja1BhcmVudC5wYXJlbnRVdWlkXG4gIH1cblxuICBvbk5ld0Fuc3dlclZhbHVlQ2hhbmdlKCkge1xuICAgIHRoaXMuaXNBbnN3ZXJFbXB0eSA9IHRoaXMubmV3QW5zd2VyLmxlbmd0aCA9PT0gMFxuICB9XG5cbiAgcHVibGlzaE5ld0Fuc3dlcigpIHtcbiAgICBpZiAodGhpcy5uZXdBbnN3ZXIudHJpbSgpID09PSAnJykgcmV0dXJuXG5cbiAgICBjb25zdCBuZXdBbnN3ZXI6IFVzZXJGZWVkYmFjayA9IHtcbiAgICAgIC4uLnRoaXMudXNlckZlZWRiYWNrUGFyZW50LFxuICAgICAgdXVpZDogdW5kZWZpbmVkLFxuICAgICAgcHVibGlzaGVkOiB0cnVlLFxuICAgICAgY29tbWVudDogdGhpcy5uZXdBbnN3ZXIsXG4gICAgICBwYXJlbnRVdWlkOiB0aGlzLnVzZXJGZWVkYmFja1BhcmVudC51dWlkLFxuICAgICAgYXV0aG9yVXNlcklkOiB0aGlzLmFjdGl2ZVVzZXI/LmlkLFxuICAgICAgYXV0aG9yRW1haWw6IHRoaXMuYWN0aXZlVXNlcj8uZW1haWwsXG4gICAgICBkYXRlOiBuZXcgRGF0ZSgpLFxuICAgICAgYXV0aG9yTmFtZTogYCR7dGhpcy5hY3RpdmVVc2VyPy5uYW1lfSAke3RoaXMuYWN0aXZlVXNlcj8uc3VybmFtZX1gLFxuICAgIH1cblxuICAgIHRoaXMubmV3VXNlckZlZWRiYWNrQW5zd2VyLmVtaXQobmV3QW5zd2VyKVxuXG4gICAgdGhpcy5uZXdBbnN3ZXIgPSAnJ1xuICAgIHRoaXMub25OZXdBbnN3ZXJWYWx1ZUNoYW5nZSgpXG4gIH1cbn1cbiIsIjxkaXZcbiAgKm5nSWY9XCJ1c2VyRmVlZGJhY2tQYXJlbnQucHVibGlzaGVkXCJcbiAgY2xhc3M9XCJmbGV4IGZsZXgtY29sIGJnLXdoaXRlIHJvdW5kZWQgdy1mdWxsXCJcbiAgW25nQ2xhc3NdPVwiW2lzQW5BbnN3ZXIgPyAncHMtNCAnIDogJ3AtNCddXCJcbj5cbiAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1yb3dcIj5cbiAgICA8ZGl2IGNsYXNzPVwiYXZhdGFyXCI+XG4gICAgICA8aW1nXG4gICAgICAgIGNsYXNzPVwicm91bmRlZC1mdWxsXCJcbiAgICAgICAgW3NyY109XCJ1c2VyRmVlZGJhY2tQYXJlbnQuYXZhdGFyVXJsXCJcbiAgICAgICAgYWx0PVwiYXZhdGFyXCJcbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cInAtNCBmbGV4IGZsZXgtY29sXCI+XG4gICAgICA8c3Bhbj57eyB1c2VyRmVlZGJhY2tQYXJlbnQuYXV0aG9yTmFtZSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuPiB7eyB1c2VyRmVlZGJhY2tQYXJlbnQuZGF0ZSB8IHRpbWVTaW5jZSB9fTwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXYgZGF0YS1jeT1cImNvbW1lbnRUZXh0XCIgY2xhc3M9XCJtdC00IHdoaXRlc3BhY2UtcHJlLWxpbmVcIj5cbiAgICB7eyB1c2VyRmVlZGJhY2tQYXJlbnQuY29tbWVudCB9fVxuICA8L2Rpdj5cbiAgPGRpdlxuICAgIGNsYXNzPVwidy1mdWxsXCJcbiAgICAqbmdGb3I9XCJsZXQgdXNlckZlZWRCYWNrc0Fuc3dlciBvZiB1c2VyRmVlZEJhY2tzQW5zd2VyczsgbGV0IGxhc3QgPSBsYXN0XCJcbiAgPlxuICAgIDxociBjbGFzcz1cIi1teC00IG15LTZcIiAvPlxuICAgIDxnbi11aS11c2VyLWZlZWRiYWNrLWl0ZW1cbiAgICAgIFt1c2VyRmVlZGJhY2tQYXJlbnRdPVwidXNlckZlZWRCYWNrc0Fuc3dlclwiXG4gICAgICBbaXNMYXN0Q29tbWVudF09XCJsYXN0XCJcbiAgICA+PC9nbi11aS11c2VyLWZlZWRiYWNrLWl0ZW0+XG4gIDwvZGl2PlxuXG4gIDxkaXYgKm5nSWY9XCJhY3RpdmVVc2VyXCIgY2xhc3M9XCJtdC0yIGZsZXggZmxleC1jb2xcIj5cbiAgICA8aHIgY2xhc3M9XCItbXgtNCBteS00XCIgLz5cbiAgICA8ZGl2XG4gICAgICBpZD1cIm5ldy1jb21tZW50LWJ1dHRvbnNcIlxuICAgICAgY2xhc3M9XCJmbGV4IGZsZXgtcm93IGdhcC0yIGl0ZW1zLWNlbnRlciBqdXN0aWZ5LWVuZFwiXG4gICAgPlxuICAgICAgPGduLXVpLXRleHQtYXJlYVxuICAgICAgICBbZGlzYWJsZWRdPVwiaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nXCJcbiAgICAgICAgWyh2YWx1ZSldPVwibmV3QW5zd2VyXCJcbiAgICAgICAgKHZhbHVlQ2hhbmdlKT1cIm9uTmV3QW5zd2VyVmFsdWVDaGFuZ2UoKVwiXG4gICAgICAgIChrZXl1cC5jb250cm9sLmVudGVyKT1cInB1Ymxpc2hOZXdBbnN3ZXIoKVwiXG4gICAgICAgIFtwbGFjZWhvbGRlcl09XCJcbiAgICAgICAgICAncmVjb3JkLm1ldGFkYXRhLnVzZXJGZWVkYmFja3MubmV3QW5zd2VyLnBsYWNlaG9sZGVyJyB8IHRyYW5zbGF0ZVxuICAgICAgICBcIlxuICAgICAgICBjbGFzcz1cImdyb3dcIlxuICAgICAgICBleHRyYUNsYXNzPVwiYmctdHJhbnNwYXJlbnQgYm9yZGVyLTAgcGxhY2Vob2xkZXItcHJpbWFyeS1kYXJrZXIgdGV4dC1wcmltYXJ5LWRhcmtlciBoLTlcIlxuICAgICAgPjwvZ24tdWktdGV4dC1hcmVhPlxuICAgICAgPGRpdiAqbmdJZj1cIiFpc0Fuc3dlckVtcHR5XCIgY2xhc3M9XCJmbGV4IGZsZXgtcm93IGp1c3RpZnktZW5kXCI+XG4gICAgICAgIDxnbi11aS1idXR0b25cbiAgICAgICAgICBbZGlzYWJsZWRdPVwiaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nXCJcbiAgICAgICAgICBbdHlwZV09XCInb3V0bGluZSdcIlxuICAgICAgICAgIChidXR0b25DbGljayk9XCJwdWJsaXNoTmV3QW5zd2VyKClcIlxuICAgICAgICAgIFt0aXRsZV09XCJcbiAgICAgICAgICAgICdyZWNvcmQubWV0YWRhdGEudXNlckZlZWRiYWNrcy5uZXdBbnN3ZXIuYnV0dG9uVGl0bGUnIHwgdHJhbnNsYXRlXG4gICAgICAgICAgXCJcbiAgICAgICAgICBleHRyYUNsYXNzPVwiIXAtWzAuNWVtXSB0ZXh0LXByaW1hcnktZGFya2VyIGJvcmRlci1wcmltYXJ5LWRhcmtlciBoLTlcIlxuICAgICAgICA+XG4gICAgICAgICAgPG1hdC1pY29uXG4gICAgICAgICAgICBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWRcIlxuICAgICAgICAgICAgKm5nSWY9XCIhaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nXCJcbiAgICAgICAgICA+XG4gICAgICAgICAgICBzZW5kXG4gICAgICAgICAgPC9tYXQtaWNvbj5cbiAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZmxleCBqdXN0aWZ5LWNlbnRlciB3LWZ1bGxcIj5cbiAgICAgICAgICAgICAgPGduLXVpLXNwaW5uaW5nLWxvYWRlcj48L2duLXVpLXNwaW5uaW5nLWxvYWRlcj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICA8L2duLXVpLWJ1dHRvbj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
+
import { FormsModule } from '@angular/forms';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
import * as i1 from "@angular/forms";
|
|
4
5
|
export class CheckToggleComponent {
|
|
@@ -10,11 +11,11 @@ export class CheckToggleComponent {
|
|
|
10
11
|
this.toggled.emit(event);
|
|
11
12
|
}
|
|
12
13
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: CheckToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: CheckToggleComponent, selector: "gn-ui-check-toggle", inputs: { title: "title", label: "label", value: "value", color: "color" }, outputs: { toggled: "toggled" }, ngImport: i0, template: "<label class=\"inline-flex relative items-start cursor-pointer\" [title]=\"title\">\n <span class=\"shrink-0\">\n <input\n type=\"checkbox\"\n class=\"sr-only peer\"\n [ngModel]=\"value\"\n (ngModelChange)=\"toggle($event)\"\n />\n <div\n class=\"w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-2 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all\"\n [class]=\"\n color === 'secondary'\n ? 'peer-focus:ring-secondary-lighter peer-checked:bg-secondary'\n : 'peer-focus:ring-primary-lighter peer-checked:bg-primary'\n \"\n ></div>\n </span>\n <span class=\"ml-3 mt-[2px] text-sm font-medium\">{{ label }}</span>\n</label>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
14
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: CheckToggleComponent, isStandalone: true, selector: "gn-ui-check-toggle", inputs: { title: "title", label: "label", value: "value", color: "color" }, outputs: { toggled: "toggled" }, ngImport: i0, template: "<label class=\"inline-flex relative items-start cursor-pointer\" [title]=\"title\">\n <span class=\"shrink-0\">\n <input\n type=\"checkbox\"\n class=\"sr-only peer\"\n [ngModel]=\"value\"\n (ngModelChange)=\"toggle($event)\"\n />\n <div\n class=\"w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-2 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all\"\n [class]=\"\n color === 'secondary'\n ? 'peer-focus:ring-secondary-lighter peer-checked:bg-secondary'\n : 'peer-focus:ring-primary-lighter peer-checked:bg-primary'\n \"\n ></div>\n </span>\n <span class=\"ml-3 mt-[2px] text-sm font-medium\">{{ label }}</span>\n</label>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
14
15
|
}
|
|
15
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: CheckToggleComponent, decorators: [{
|
|
16
17
|
type: Component,
|
|
17
|
-
args: [{ selector: 'gn-ui-check-toggle', changeDetection: ChangeDetectionStrategy.OnPush, template: "<label class=\"inline-flex relative items-start cursor-pointer\" [title]=\"title\">\n <span class=\"shrink-0\">\n <input\n type=\"checkbox\"\n class=\"sr-only peer\"\n [ngModel]=\"value\"\n (ngModelChange)=\"toggle($event)\"\n />\n <div\n class=\"w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-2 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all\"\n [class]=\"\n color === 'secondary'\n ? 'peer-focus:ring-secondary-lighter peer-checked:bg-secondary'\n : 'peer-focus:ring-primary-lighter peer-checked:bg-primary'\n \"\n ></div>\n </span>\n <span class=\"ml-3 mt-[2px] text-sm font-medium\">{{ label }}</span>\n</label>\n" }]
|
|
18
|
+
args: [{ selector: 'gn-ui-check-toggle', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [FormsModule], template: "<label class=\"inline-flex relative items-start cursor-pointer\" [title]=\"title\">\n <span class=\"shrink-0\">\n <input\n type=\"checkbox\"\n class=\"sr-only peer\"\n [ngModel]=\"value\"\n (ngModelChange)=\"toggle($event)\"\n />\n <div\n class=\"w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-2 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all\"\n [class]=\"\n color === 'secondary'\n ? 'peer-focus:ring-secondary-lighter peer-checked:bg-secondary'\n : 'peer-focus:ring-primary-lighter peer-checked:bg-primary'\n \"\n ></div>\n </span>\n <span class=\"ml-3 mt-[2px] text-sm font-medium\">{{ label }}</span>\n</label>\n" }]
|
|
18
19
|
}], propDecorators: { title: [{
|
|
19
20
|
type: Input
|
|
20
21
|
}], label: [{
|
|
@@ -26,4 +27,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
26
27
|
}], toggled: [{
|
|
27
28
|
type: Output
|
|
28
29
|
}] } });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2stdG9nZ2xlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvaW5wdXRzL3NyYy9saWIvY2hlY2stdG9nZ2xlL2NoZWNrLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvbGliL2NoZWNrLXRvZ2dsZS9jaGVjay10b2dnbGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUE7QUFDdEIsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFBOzs7QUFVNUMsTUFBTSxPQUFPLG9CQUFvQjtJQVJqQztRQVlXLFVBQUssR0FBNEIsU0FBUyxDQUFBO1FBQ3pDLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFBO0tBS3ZDO0lBSEMsTUFBTSxDQUFDLEtBQVk7UUFDakIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDMUIsQ0FBQzs4R0FUVSxvQkFBb0I7a0dBQXBCLG9CQUFvQiwyTENqQmpDLHU1QkFtQkEseURESlksV0FBVzs7MkZBRVYsb0JBQW9CO2tCQVJoQyxTQUFTOytCQUNFLG9CQUFvQixtQkFHYix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFDLFdBQVcsQ0FBQzs4QkFHYixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0ksT0FBTztzQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLWNoZWNrLXRvZ2dsZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaGVjay10b2dnbGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaGVjay10b2dnbGUuY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0Zvcm1zTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2hlY2tUb2dnbGVDb21wb25lbnQge1xuICBASW5wdXQoKSB0aXRsZTogc3RyaW5nXG4gIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmdcbiAgQElucHV0KCkgdmFsdWU6IGJvb2xlYW5cbiAgQElucHV0KCkgY29sb3I6ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknID0gJ3ByaW1hcnknXG4gIEBPdXRwdXQoKSB0b2dnbGVkID0gbmV3IEV2ZW50RW1pdHRlcigpXG5cbiAgdG9nZ2xlKGV2ZW50OiBFdmVudCkge1xuICAgIHRoaXMudG9nZ2xlZC5lbWl0KGV2ZW50KVxuICB9XG59XG4iLCI8bGFiZWwgY2xhc3M9XCJpbmxpbmUtZmxleCByZWxhdGl2ZSBpdGVtcy1zdGFydCBjdXJzb3ItcG9pbnRlclwiIFt0aXRsZV09XCJ0aXRsZVwiPlxuICA8c3BhbiBjbGFzcz1cInNocmluay0wXCI+XG4gICAgPGlucHV0XG4gICAgICB0eXBlPVwiY2hlY2tib3hcIlxuICAgICAgY2xhc3M9XCJzci1vbmx5IHBlZXJcIlxuICAgICAgW25nTW9kZWxdPVwidmFsdWVcIlxuICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwidG9nZ2xlKCRldmVudClcIlxuICAgIC8+XG4gICAgPGRpdlxuICAgICAgY2xhc3M9XCJ3LTExIGgtNiBiZy1ncmF5LTIwMCBwZWVyLWZvY3VzOm91dGxpbmUtbm9uZSBwZWVyLWZvY3VzOnJpbmctMiByb3VuZGVkLWZ1bGwgcGVlci1jaGVja2VkOmFmdGVyOnRyYW5zbGF0ZS14LWZ1bGwgcGVlci1jaGVja2VkOmFmdGVyOmJvcmRlci13aGl0ZSBhZnRlcjpjb250ZW50LVsnJ10gYWZ0ZXI6YWJzb2x1dGUgYWZ0ZXI6dG9wLVsycHhdIGFmdGVyOmxlZnQtWzJweF0gYWZ0ZXI6Ymctd2hpdGUgYWZ0ZXI6Ym9yZGVyLWdyYXktMzAwIGFmdGVyOmJvcmRlciBhZnRlcjpyb3VuZGVkLWZ1bGwgYWZ0ZXI6aC01IGFmdGVyOnctNSBhZnRlcjp0cmFuc2l0aW9uLWFsbFwiXG4gICAgICBbY2xhc3NdPVwiXG4gICAgICAgIGNvbG9yID09PSAnc2Vjb25kYXJ5J1xuICAgICAgICAgID8gJ3BlZXItZm9jdXM6cmluZy1zZWNvbmRhcnktbGlnaHRlciBwZWVyLWNoZWNrZWQ6Ymctc2Vjb25kYXJ5J1xuICAgICAgICAgIDogJ3BlZXItZm9jdXM6cmluZy1wcmltYXJ5LWxpZ2h0ZXIgcGVlci1jaGVja2VkOmJnLXByaW1hcnknXG4gICAgICBcIlxuICAgID48L2Rpdj5cbiAgPC9zcGFuPlxuICA8c3BhbiBjbGFzcz1cIm1sLTMgbXQtWzJweF0gdGV4dC1zbSBmb250LW1lZGl1bVwiPnt7IGxhYmVsIH19PC9zcGFuPlxuPC9sYWJlbD5cbiJdfQ==
|