geonetwork-ui 2.8.0-dev.c06b26576 → 2.8.0-dev.cba2fd2eb
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/index.mjs +2 -1
- package/esm2022/libs/api/metadata-converter/src/lib/common/distribution.mapper.mjs +5 -1
- package/esm2022/libs/api/metadata-converter/src/lib/dcat-ap/dcat-ap.converter.mjs +3 -3
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +26 -1
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +7 -7
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +3 -2
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +4 -3
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +10 -10
- package/esm2022/libs/api/repository/src/lib/gn4/settings/gn4-settings.service.mjs +3 -2
- package/esm2022/libs/common/domain/src/index.mjs +3 -0
- package/esm2022/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +3 -1
- package/esm2022/libs/common/domain/src/lib/model/search/sort-by.model.mjs +6 -1
- package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/index.mjs +2 -1
- package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +3 -1
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +18 -7
- package/esm2022/libs/feature/dataviz/src/lib/stac-view/stac-view.component.mjs +51 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +23 -3
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +2 -2
- package/esm2022/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.mjs +13 -4
- package/esm2022/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.mjs +23 -8
- package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +14 -1
- package/esm2022/libs/feature/router/src/lib/default/router.service.mjs +5 -1
- package/esm2022/libs/feature/router/src/lib/default/state/router.effects.mjs +9 -7
- package/esm2022/libs/feature/search/src/lib/sort-by/sort-by.component.mjs +8 -12
- package/esm2022/libs/ui/elements/src/index.mjs +2 -1
- package/esm2022/libs/ui/elements/src/lib/external-link-card/external-link-card.component.mjs +11 -4
- package/esm2022/libs/ui/elements/src/lib/metadata-doi/metadata-doi.component.mjs +37 -0
- package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
- package/esm2022/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.mjs +2 -3
- package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +5 -1
- package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +12 -1
- package/esm2022/libs/util/shared/src/lib/services/proxy.service.mjs +9 -11
- package/esm2022/libs/util/shared/src/lib/utils/sort-by.mjs +9 -6
- package/esm2022/translations/de.json +16 -3
- package/esm2022/translations/en.json +16 -4
- package/esm2022/translations/es.json +15 -2
- package/esm2022/translations/fr.json +16 -3
- package/esm2022/translations/it.json +17 -4
- package/esm2022/translations/nl.json +15 -2
- package/esm2022/translations/pt.json +15 -2
- package/esm2022/translations/sk.json +16 -3
- package/fesm2022/geonetwork-ui.mjs +397 -95
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/index.d.ts.map +1 -1
- package/index.ts +1 -0
- package/libs/api/metadata-converter/src/lib/common/distribution.mapper.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +5 -1
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.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 +7 -7
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/settings/gn4-settings.service.d.ts.map +1 -1
- package/libs/common/domain/src/index.d.ts +3 -0
- package/libs/common/domain/src/index.d.ts.map +1 -0
- package/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.d.ts +1 -1
- package/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +7 -2
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/search/sort-by.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/platform.service.interface.d.ts +1 -1
- package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
- package/libs/feature/dataviz/src/index.d.ts +1 -0
- package/libs/feature/dataviz/src/index.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/stac-view/stac-view.component.d.ts +16 -0
- package/libs/feature/dataviz/src/lib/stac-view/stac-view.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +2 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.d.ts +3 -2
- package/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.d.ts +3 -2
- package/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts +28 -24
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
- package/libs/feature/router/src/lib/default/router.service.d.ts +2 -0
- package/libs/feature/router/src/lib/default/router.service.d.ts.map +1 -1
- package/libs/feature/router/src/lib/default/state/router.effects.d.ts +3 -1
- package/libs/feature/router/src/lib/default/state/router.effects.d.ts.map +1 -1
- package/libs/feature/search/src/lib/sort-by/sort-by.component.d.ts +4 -3
- package/libs/feature/search/src/lib/sort-by/sort-by.component.d.ts.map +1 -1
- package/libs/ui/elements/src/index.d.ts +1 -0
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/external-link-card/external-link-card.component.d.ts +3 -2
- package/libs/ui/elements/src/lib/external-link-card/external-link-card.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/metadata-doi/metadata-doi.component.d.ts +8 -0
- package/libs/ui/elements/src/lib/metadata-doi/metadata-doi.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-classifier.service.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts +6 -0
- package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
- package/libs/util/shared/src/lib/services/proxy.service.d.ts +5 -4
- package/libs/util/shared/src/lib/services/proxy.service.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/sort-by.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/api/metadata-converter/src/lib/common/distribution.mapper.ts +2 -0
- package/src/libs/api/metadata-converter/src/lib/dcat-ap/dcat-ap.converter.ts +2 -2
- package/src/libs/api/metadata-converter/src/lib/fixtures/generic.records.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.service+eaux-usees.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +5 -2
- package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/georhena.records.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +2 -2
- package/src/libs/api/metadata-converter/src/lib/fixtures/wallonie.records.reuse.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/wallonie.records.service+napitswallonia.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +28 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +13 -6
- package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +6 -2
- package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +4 -2
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +37 -36
- package/src/libs/api/repository/src/lib/gn4/settings/gn4-settings.service.ts +3 -2
- package/src/libs/common/domain/src/index.ts +2 -0
- package/src/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.ts +1 -1
- package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +12 -1
- package/src/libs/common/domain/src/lib/model/search/sort-by.model.ts +5 -0
- package/src/libs/common/domain/src/lib/platform.service.interface.ts +1 -1
- package/src/libs/common/fixtures/src/lib/elasticsearch/metadata-links.fixtures.ts +5 -0
- package/src/libs/common/fixtures/src/lib/link.fixtures.ts +19 -0
- package/src/libs/feature/dataviz/src/index.ts +1 -0
- package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +1 -0
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +16 -5
- package/src/libs/feature/dataviz/src/lib/stac-view/stac-view.component.css +0 -0
- package/src/libs/feature/dataviz/src/lib/stac-view/stac-view.component.html +40 -0
- package/src/libs/feature/dataviz/src/lib/stac-view/stac-view.component.ts +62 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +3 -3
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +30 -0
- package/src/libs/feature/editor/src/lib/fields.config.ts +1 -1
- package/src/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.ts +7 -1
- package/src/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.ts +23 -4
- package/src/libs/feature/record/src/lib/state/mdview.facade.ts +30 -1
- package/src/libs/feature/router/src/lib/default/router.service.ts +8 -0
- package/src/libs/feature/router/src/lib/default/state/router.effects.ts +6 -7
- package/src/libs/feature/search/src/lib/sort-by/sort-by.component.ts +8 -12
- package/src/libs/ui/elements/src/index.ts +1 -0
- package/src/libs/ui/elements/src/lib/external-link-card/external-link-card.component.html +43 -22
- package/src/libs/ui/elements/src/lib/external-link-card/external-link-card.component.ts +12 -3
- package/src/libs/ui/elements/src/lib/metadata-doi/metadata-doi.component.css +0 -0
- package/src/libs/ui/elements/src/lib/metadata-doi/metadata-doi.component.html +31 -0
- package/src/libs/ui/elements/src/lib/metadata-doi/metadata-doi.component.ts +30 -0
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +56 -14
- package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.ts +4 -2
- package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +4 -0
- package/src/libs/util/shared/src/lib/links/link-utils.ts +11 -0
- package/src/libs/util/shared/src/lib/services/proxy.service.ts +6 -2
- package/src/libs/util/shared/src/lib/utils/sort-by.ts +8 -5
- package/translations/de.json +16 -3
- package/translations/en.json +16 -4
- package/translations/es.json +15 -2
- package/translations/fr.json +16 -3
- package/translations/it.json +17 -4
- package/translations/nl.json +15 -2
- package/translations/pt.json +15 -2
- package/translations/sk.json +16 -3
- package/src/libs/common/domain/src/lib/index.ts +0 -2
|
@@ -15,7 +15,7 @@ import { TranslateCompiler, TranslateLoader, TranslateDefaultParser, TranslatePa
|
|
|
15
15
|
import { TranslateMessageFormatCompiler } from 'ngx-translate-messageformat-compiler';
|
|
16
16
|
import { TranslateHttpLoader } from '@ngx-translate/http-loader';
|
|
17
17
|
import { map as map$1, shareReplay as shareReplay$1, catchError, tap as tap$1, filter as filter$1, startWith as startWith$1, withLatestFrom, switchMap as switchMap$1, take, mergeMap, delay, distinctUntilChanged, debounceTime, finalize, throttleTime, first as first$1, pairwise as pairwise$1, share, defaultIfEmpty, toArray } from 'rxjs/operators';
|
|
18
|
-
import { of, map as map$2, lastValueFrom, fromEvent, startWith, shareReplay, filter, pairwise,
|
|
18
|
+
import { of, map as map$2, lastValueFrom, fromEvent, startWith, shareReplay, filter, pairwise, switchMap, Subject, combineLatest, from, exhaustMap, throwError, forkJoin, takeLast, firstValueFrom, merge, BehaviorSubject, timer, ReplaySubject, Subscription, first, distinctUntilChanged as distinctUntilChanged$1, animationFrameScheduler, debounceTime as debounceTime$1, Observable, buffer, tap as tap$2, combineLatestWith, take as take$1, catchError as catchError$1, takeUntil, EMPTY, mergeMap as mergeMap$1, withLatestFrom as withLatestFrom$1 } from 'rxjs';
|
|
19
19
|
import { lt, valid, coerce, satisfies, ltr } from 'semver';
|
|
20
20
|
import chroma from 'chroma-js';
|
|
21
21
|
import * as i1$2 from '@angular/common';
|
|
@@ -31,7 +31,7 @@ import { queryDataGouvFr, queryGeonames, queryGeoadmin } from '@geospatial-sdk/g
|
|
|
31
31
|
import { FeaturesClickEventType, FeaturesHoverEventType, MapClickEventType, SourceLoadErrorType, computeMapContextDiff, createViewFromLayer } from '@geospatial-sdk/core';
|
|
32
32
|
import { listen, createMapFromContext, applyContextDiffToMap } from '@geospatial-sdk/openlayers';
|
|
33
33
|
import { provideIcons, provideNgIconsConfig, NgIconComponent, NgIcon } from '@ng-icons/core';
|
|
34
|
-
import { matSwipeOutline, matErrorOutlineOutline, matComputerOutline, matLocationSearchingOutline, matCallOutline, matLocationOnOutline, matMailOutline as matMailOutline$1, matInfoOutline, matWarningAmberOutline, matCloseOutline, matSendOutline, matMapOutline, matCloudDownloadOutline, matHomeWorkOutline, matLayersOutline, matAddCircleOutlineOutline, matMoreHorizOutline } from '@ng-icons/material-icons/outline';
|
|
34
|
+
import { matSwipeOutline, matErrorOutlineOutline, matComputerOutline, matLocationSearchingOutline, matCallOutline, matLocationOnOutline, matMailOutline as matMailOutline$1, matInfoOutline, matWarningAmberOutline, matCloseOutline, matSendOutline, matMapOutline, matCloudDownloadOutline, matHomeWorkOutline, matLayersOutline, matAddCircleOutlineOutline, matDeleteOutline, matMoreHorizOutline } from '@ng-icons/material-icons/outline';
|
|
35
35
|
import { createLegendFromLayer } from '@geospatial-sdk/legend';
|
|
36
36
|
import { defaults, DragPan, MouseWheelZoom } from 'ol/interaction';
|
|
37
37
|
import { mouseOnly, noModifierKeys, primaryAction, platformModifierKeyOnly } from 'ol/events/condition';
|
|
@@ -666,6 +666,10 @@ function matchProtocol(protocol) {
|
|
|
666
666
|
return 'esriRest';
|
|
667
667
|
if (/DOWNLOAD-1/i.test(protocol))
|
|
668
668
|
return 'GPFDL';
|
|
669
|
+
if (/DB:POSTGIS/i.test(protocol))
|
|
670
|
+
return 'postgis';
|
|
671
|
+
if (/stac\W*items/i.test(protocol))
|
|
672
|
+
return 'stac';
|
|
669
673
|
return 'other';
|
|
670
674
|
}
|
|
671
675
|
function matchMimeType(format) {
|
|
@@ -914,6 +918,8 @@ marker('record.metadata.api.accessServiceProtocol.ogcFeatures');
|
|
|
914
918
|
marker('record.metadata.api.accessServiceProtocol.GPFDL');
|
|
915
919
|
marker('record.metadata.api.accessServiceProtocol.tms');
|
|
916
920
|
marker('record.metadata.api.accessServiceProtocol.maplibre-style');
|
|
921
|
+
marker('record.metadata.api.accessServiceProtocol.postgis');
|
|
922
|
+
marker('record.metadata.api.accessServiceProtocol.stac');
|
|
917
923
|
marker('record.metadata.api.accessServiceProtocol.other');
|
|
918
924
|
|
|
919
925
|
function getUpdateFrequencyFromFrequencyCode(frequencyCode) {
|
|
@@ -1574,7 +1580,8 @@ function readDefaultLanguage$2(rootEl) {
|
|
|
1574
1580
|
return pipe(findChildElement('gmd:language', false), findChildElement('lan:LanguageCode'), readAttribute('codeListValue'), map((lang) => (lang ? toLang2(lang.toLowerCase()) : null)))(rootEl);
|
|
1575
1581
|
}
|
|
1576
1582
|
function readResourceIdentifier(rootEl) {
|
|
1577
|
-
|
|
1583
|
+
const code = pipe(findIdentification(), findNestedElement('gmd:citation', 'gmd:CI_Citation', 'gmd:identifier', 'gmd:MD_Identifier', 'gmd:code'), extractCharacterString())(rootEl);
|
|
1584
|
+
return code ? [{ code }] : [];
|
|
1578
1585
|
}
|
|
1579
1586
|
|
|
1580
1587
|
function writeLocalizedElement(writeFn, text, translations, defaultLanguage) {
|
|
@@ -2080,8 +2087,9 @@ function writeDefaultLanguage$1(record, rootEl) {
|
|
|
2080
2087
|
return pipe(findNestedChildOrCreate('gmd:language', 'gmd:LanguageCode'), writeAttribute('codeList', 'http://www.loc.gov/standards/iso639-2/'), writeAttribute('codeListValue', lang3))(rootEl);
|
|
2081
2088
|
}
|
|
2082
2089
|
function writeResourceIdentifier(record, rootEl) {
|
|
2083
|
-
|
|
2084
|
-
|
|
2090
|
+
const firstIdentifier = record.resourceIdentifiers?.[0]?.code;
|
|
2091
|
+
pipe(findOrCreateIdentification(), findNestedChildOrCreate('gmd:citation', 'gmd:CI_Citation'), removeChildrenByName('gmd:identifier'), firstIdentifier
|
|
2092
|
+
? pipe(createNestedChild('gmd:identifier', 'gmd:MD_Identifier', 'gmd:code'), writeCharacterString(firstIdentifier))
|
|
2085
2093
|
: noop)(rootEl);
|
|
2086
2094
|
}
|
|
2087
2095
|
|
|
@@ -2095,7 +2103,7 @@ class Iso19139Converter extends BaseConverter {
|
|
|
2095
2103
|
recordUpdated: readRecordUpdated$2,
|
|
2096
2104
|
recordCreated: () => undefined, // not supported in ISO19139
|
|
2097
2105
|
recordPublished: () => undefined, // not supported in ISO19139
|
|
2098
|
-
|
|
2106
|
+
resourceIdentifiers: readResourceIdentifier,
|
|
2099
2107
|
resourceUpdated: readResourceUpdated$1,
|
|
2100
2108
|
resourceCreated: readResourceCreated$1,
|
|
2101
2109
|
resourcePublished: readResourcePublished,
|
|
@@ -2132,7 +2140,7 @@ class Iso19139Converter extends BaseConverter {
|
|
|
2132
2140
|
recordUpdated: writeRecordUpdated$1,
|
|
2133
2141
|
recordCreated: () => undefined, // not supported in ISO19139
|
|
2134
2142
|
recordPublished: () => undefined, // not supported in ISO19139
|
|
2135
|
-
|
|
2143
|
+
resourceIdentifiers: writeResourceIdentifier,
|
|
2136
2144
|
resourceUpdated: writeResourceUpdated$1,
|
|
2137
2145
|
resourceCreated: writeResourceCreated$1,
|
|
2138
2146
|
resourcePublished: writeResourcePublished$1,
|
|
@@ -2233,11 +2241,11 @@ class Iso19139Converter extends BaseConverter {
|
|
|
2233
2241
|
const onlineResources = this.readers['onlineResources'](rootEl, tr);
|
|
2234
2242
|
const otherLanguages = this.readers['otherLanguages'](rootEl, tr);
|
|
2235
2243
|
const defaultLanguage = this.readers['defaultLanguage'](rootEl, tr);
|
|
2236
|
-
const
|
|
2244
|
+
const resourceIdentifiers = this.readers['resourceIdentifiers'](rootEl, tr);
|
|
2237
2245
|
const spatialExtents = this.readers['spatialExtents'](rootEl, tr);
|
|
2238
2246
|
return {
|
|
2239
2247
|
uniqueIdentifier,
|
|
2240
|
-
...(
|
|
2248
|
+
...(resourceIdentifiers?.length > 0 && { resourceIdentifiers }),
|
|
2241
2249
|
kind,
|
|
2242
2250
|
otherLanguages,
|
|
2243
2251
|
defaultLanguage,
|
|
@@ -2365,8 +2373,8 @@ class Iso19139Converter extends BaseConverter {
|
|
|
2365
2373
|
this.writers['otherConstraints'](record, rootEl);
|
|
2366
2374
|
fieldChanged('onlineResources') &&
|
|
2367
2375
|
this.writers['onlineResources'](record, rootEl);
|
|
2368
|
-
fieldChanged('
|
|
2369
|
-
this.writers['
|
|
2376
|
+
fieldChanged('resourceIdentifiers') &&
|
|
2377
|
+
this.writers['resourceIdentifiers'](record, rootEl);
|
|
2370
2378
|
if (record.kind === 'dataset') {
|
|
2371
2379
|
fieldChanged('status') && this.writers['status'](record, rootEl);
|
|
2372
2380
|
fieldChanged('updateFrequency') &&
|
|
@@ -3313,7 +3321,7 @@ class DcatApConverter extends BaseConverter {
|
|
|
3313
3321
|
spatialExtents: readSpatialExtents,
|
|
3314
3322
|
keywords: readKeywords,
|
|
3315
3323
|
topics: readTopics,
|
|
3316
|
-
|
|
3324
|
+
resourceIdentifiers: () => undefined,
|
|
3317
3325
|
recordUpdated: readRecordUpdated,
|
|
3318
3326
|
recordCreated: readRecordCreated,
|
|
3319
3327
|
resourceUpdated: readResourceUpdated,
|
|
@@ -3349,7 +3357,7 @@ class DcatApConverter extends BaseConverter {
|
|
|
3349
3357
|
recordUpdated: () => undefined,
|
|
3350
3358
|
recordCreated: () => undefined,
|
|
3351
3359
|
recordPublished: () => undefined,
|
|
3352
|
-
|
|
3360
|
+
resourceIdentifiers: () => undefined,
|
|
3353
3361
|
resourceUpdated: () => undefined,
|
|
3354
3362
|
resourceCreated: () => undefined,
|
|
3355
3363
|
resourcePublished: () => undefined,
|
|
@@ -19159,6 +19167,8 @@ var de = {
|
|
|
19159
19167
|
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
19160
19168
|
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
19161
19169
|
"record.metadata.api.accessServiceProtocol.other": "",
|
|
19170
|
+
"record.metadata.api.accessServiceProtocol.postgis": "",
|
|
19171
|
+
"record.metadata.api.accessServiceProtocol.stac": "",
|
|
19162
19172
|
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
19163
19173
|
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
19164
19174
|
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
@@ -19200,13 +19210,16 @@ var de = {
|
|
|
19200
19210
|
"record.metadata.contact": "Kontakt",
|
|
19201
19211
|
"record.metadata.creation": "Erstellungsdatum",
|
|
19202
19212
|
"record.metadata.details": "Über die Daten",
|
|
19213
|
+
"record.metadata.doi.copy": "",
|
|
19214
|
+
"record.metadata.doi.open": "",
|
|
19203
19215
|
"record.metadata.download": "Downloads",
|
|
19204
19216
|
"record.metadata.feature.catalog": "",
|
|
19205
19217
|
"record.metadata.formats": "Formate",
|
|
19206
19218
|
"record.metadata.isGeographical": "Geographischer Datensatz",
|
|
19207
19219
|
"record.metadata.keywords": "Stichworte",
|
|
19208
19220
|
"record.metadata.languages": "Sprachen",
|
|
19209
|
-
"record.metadata.
|
|
19221
|
+
"record.metadata.link.postgis.table": "",
|
|
19222
|
+
"record.metadata.link.postgis.tooltip": "",
|
|
19210
19223
|
"record.metadata.linked.datasets": "Verknüpfte Datensätze",
|
|
19211
19224
|
"record.metadata.linked.records": "Verknüpfte Inhalte",
|
|
19212
19225
|
"record.metadata.linked.reuses": "Verknüpfte Wiederverwendungen",
|
|
@@ -19247,6 +19260,9 @@ var de = {
|
|
|
19247
19260
|
"record.metadata.quality.updateFrequency.failed": "Aktualisierungsfrequenz nicht angegeben",
|
|
19248
19261
|
"record.metadata.quality.updateFrequency.success": "Aktualisierungsfrequenz angegeben",
|
|
19249
19262
|
"record.metadata.related": "Entdecken Sie den Katalog",
|
|
19263
|
+
"record.metadata.resourceCreated": "Erstellt am {date}",
|
|
19264
|
+
"record.metadata.resourcePublished": "Veröffentlicht am {date}",
|
|
19265
|
+
"record.metadata.resourceUpdated": "Zuletzt aktualisiert am {date}",
|
|
19250
19266
|
"record.metadata.ressources.and.links": "Ressourcen und Links",
|
|
19251
19267
|
"record.metadata.sheet": "Weitere Informationen verfügbar unter:",
|
|
19252
19268
|
"record.metadata.status": "Status",
|
|
@@ -19259,8 +19275,9 @@ var de = {
|
|
|
19259
19275
|
"record.metadata.title": "Titel",
|
|
19260
19276
|
"record.metadata.topics": "Kategorien",
|
|
19261
19277
|
"record.metadata.uniqueId": "Eindeutige Kennung",
|
|
19278
|
+
"record.metadata.update": "Aktualisierungsdatum",
|
|
19262
19279
|
"record.metadata.updateFrequency": "Aktualisierungsfrequenz der Daten",
|
|
19263
|
-
"record.metadata.updatedOn": "
|
|
19280
|
+
"record.metadata.updatedOn": "Informationen geändert am",
|
|
19264
19281
|
"record.metadata.usage": "Nutzung und Einschränkungen",
|
|
19265
19282
|
"record.metadata.userFeedbacks": "",
|
|
19266
19283
|
"record.metadata.userFeedbacks.anonymousUser": "",
|
|
@@ -19275,6 +19292,7 @@ var de = {
|
|
|
19275
19292
|
"record.tab.chart": "Diagramm",
|
|
19276
19293
|
"record.tab.data": "Tabelle",
|
|
19277
19294
|
"record.tab.map": "Karte",
|
|
19295
|
+
"record.tab.stac": "",
|
|
19278
19296
|
"record.was.created.time": "erstellte diesen Ressource {time}",
|
|
19279
19297
|
records: records$7,
|
|
19280
19298
|
"results.layout.selectOne": "Layout auswählen",
|
|
@@ -19283,7 +19301,6 @@ var de = {
|
|
|
19283
19301
|
"results.records.hits.found": "{hits, plural, =0{Keine Ressource entsprechen der angegebenen Suche.} one{1 Ressource gefunden.} other{{hits} Ressourcen gefunden.}}",
|
|
19284
19302
|
"results.records.hits.selected": "{ amount } ausgewählt",
|
|
19285
19303
|
"results.showMore": "Mehr Ergebnisse anzeigen...",
|
|
19286
|
-
"results.sortBy.changeDate": "",
|
|
19287
19304
|
"results.sortBy.dateStamp": "Neueste",
|
|
19288
19305
|
"results.sortBy.popularity": "Beliebtheit",
|
|
19289
19306
|
"results.sortBy.qualityScore": "Fertigstellungsanzeige",
|
|
@@ -19367,6 +19384,10 @@ var de = {
|
|
|
19367
19384
|
"service.metadata.spatialExtent": "",
|
|
19368
19385
|
"share.tab.permalink": "Teilen",
|
|
19369
19386
|
"share.tab.webComponent": "Integrieren",
|
|
19387
|
+
"stac.filter.from": "",
|
|
19388
|
+
"stac.filter.period": "",
|
|
19389
|
+
"stac.filter.reset": "",
|
|
19390
|
+
"stac.filter.to": "",
|
|
19370
19391
|
"table.loading.data": "Daten werden geladen...",
|
|
19371
19392
|
"table.object.count": "Objekte in diesem Datensatz",
|
|
19372
19393
|
"table.paginator.firstPage": "Erste Seite",
|
|
@@ -19634,7 +19655,6 @@ var en = {
|
|
|
19634
19655
|
"editor.record.form.topics.inspire.intelligence": "Intelligence / Military",
|
|
19635
19656
|
"editor.record.form.topics.inspire.location": "Location",
|
|
19636
19657
|
"editor.record.form.topics.inspire.oceans": "Oceans",
|
|
19637
|
-
"editor.record.form.topics.inspire.placeholder": "Select an INSPIRE theme",
|
|
19638
19658
|
"editor.record.form.topics.inspire.planning": "Planning / Cadastre",
|
|
19639
19659
|
"editor.record.form.topics.inspire.society": "Society",
|
|
19640
19660
|
"editor.record.form.topics.inspire.structure": "Structure",
|
|
@@ -19812,6 +19832,8 @@ var en = {
|
|
|
19812
19832
|
"record.metadata.api.accessServiceProtocol.maplibre-style": "maplibre-style",
|
|
19813
19833
|
"record.metadata.api.accessServiceProtocol.ogcFeatures": "ogcFeatures",
|
|
19814
19834
|
"record.metadata.api.accessServiceProtocol.other": "other",
|
|
19835
|
+
"record.metadata.api.accessServiceProtocol.postgis": "PostGIS",
|
|
19836
|
+
"record.metadata.api.accessServiceProtocol.stac": "STAC",
|
|
19815
19837
|
"record.metadata.api.accessServiceProtocol.tms": "tms",
|
|
19816
19838
|
"record.metadata.api.accessServiceProtocol.wfs": "wfs",
|
|
19817
19839
|
"record.metadata.api.accessServiceProtocol.wms": "wms",
|
|
@@ -19853,13 +19875,16 @@ var en = {
|
|
|
19853
19875
|
"record.metadata.contact": "Contact",
|
|
19854
19876
|
"record.metadata.creation": "Date of creation",
|
|
19855
19877
|
"record.metadata.details": "About the data",
|
|
19878
|
+
"record.metadata.doi.copy": "Copy DOI",
|
|
19879
|
+
"record.metadata.doi.open": "Open DOI link",
|
|
19856
19880
|
"record.metadata.download": "Downloads",
|
|
19857
19881
|
"record.metadata.feature.catalog": "Feature catalog",
|
|
19858
19882
|
"record.metadata.formats": "Formats",
|
|
19859
19883
|
"record.metadata.isGeographical": "Geographical dataset",
|
|
19860
19884
|
"record.metadata.keywords": "Keywords",
|
|
19861
19885
|
"record.metadata.languages": "Languages",
|
|
19862
|
-
"record.metadata.
|
|
19886
|
+
"record.metadata.link.postgis.table": "table :",
|
|
19887
|
+
"record.metadata.link.postgis.tooltip": "PostGIS resources do not have access links",
|
|
19863
19888
|
"record.metadata.linked.datasets": "Associated datasets",
|
|
19864
19889
|
"record.metadata.linked.records": "Associated content",
|
|
19865
19890
|
"record.metadata.linked.reuses": "Associated reuses",
|
|
@@ -19900,6 +19925,9 @@ var en = {
|
|
|
19900
19925
|
"record.metadata.quality.updateFrequency.failed": "Update frequency is not specified",
|
|
19901
19926
|
"record.metadata.quality.updateFrequency.success": "Update frequency is specified",
|
|
19902
19927
|
"record.metadata.related": "Explore the catalog",
|
|
19928
|
+
"record.metadata.resourceCreated": "Created on {date}",
|
|
19929
|
+
"record.metadata.resourcePublished": "Published on {date}",
|
|
19930
|
+
"record.metadata.resourceUpdated": "Last updated on {date}",
|
|
19903
19931
|
"record.metadata.ressources.and.links": "Resources and links",
|
|
19904
19932
|
"record.metadata.sheet": "Original metadata",
|
|
19905
19933
|
"record.metadata.status": "Status",
|
|
@@ -19912,8 +19940,9 @@ var en = {
|
|
|
19912
19940
|
"record.metadata.title": "Title",
|
|
19913
19941
|
"record.metadata.topics": "Categories",
|
|
19914
19942
|
"record.metadata.uniqueId": "Unique Identifier",
|
|
19943
|
+
"record.metadata.update": "Date of update",
|
|
19915
19944
|
"record.metadata.updateFrequency": "Data Update Frequency",
|
|
19916
|
-
"record.metadata.updatedOn": "
|
|
19945
|
+
"record.metadata.updatedOn": "Metadata modified on",
|
|
19917
19946
|
"record.metadata.usage": "License and Conditions",
|
|
19918
19947
|
"record.metadata.userFeedbacks": "Questions / Answers",
|
|
19919
19948
|
"record.metadata.userFeedbacks.anonymousUser": "In order to leave a comment, please log in.",
|
|
@@ -19928,6 +19957,7 @@ var en = {
|
|
|
19928
19957
|
"record.tab.chart": "Chart",
|
|
19929
19958
|
"record.tab.data": "Table",
|
|
19930
19959
|
"record.tab.map": "Map",
|
|
19960
|
+
"record.tab.stac": "STAC",
|
|
19931
19961
|
"record.was.created.time": "created this record {time}",
|
|
19932
19962
|
records: records$6,
|
|
19933
19963
|
"results.layout.selectOne": "Results layout",
|
|
@@ -19936,7 +19966,6 @@ var en = {
|
|
|
19936
19966
|
"results.records.hits.found": "{hits, plural, =0{No record match the specified search.} one{1 record found.} other{{hits} records found.}}",
|
|
19937
19967
|
"results.records.hits.selected": "{ amount } selected",
|
|
19938
19968
|
"results.showMore": "Show more results...",
|
|
19939
|
-
"results.sortBy.changeDate": "Last modification",
|
|
19940
19969
|
"results.sortBy.dateStamp": "Newest",
|
|
19941
19970
|
"results.sortBy.popularity": "Popularity",
|
|
19942
19971
|
"results.sortBy.qualityScore": "Completion score",
|
|
@@ -20020,6 +20049,10 @@ var en = {
|
|
|
20020
20049
|
"service.metadata.spatialExtent": "Spatial extent",
|
|
20021
20050
|
"share.tab.permalink": "Share",
|
|
20022
20051
|
"share.tab.webComponent": "Integrate",
|
|
20052
|
+
"stac.filter.from": "From",
|
|
20053
|
+
"stac.filter.period": "Period",
|
|
20054
|
+
"stac.filter.reset": "Reset filters",
|
|
20055
|
+
"stac.filter.to": "To",
|
|
20023
20056
|
"table.loading.data": "Loading data...",
|
|
20024
20057
|
"table.object.count": "Objects in this dataset",
|
|
20025
20058
|
"table.paginator.firstPage": "First page",
|
|
@@ -20464,6 +20497,8 @@ var es = {
|
|
|
20464
20497
|
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
20465
20498
|
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
20466
20499
|
"record.metadata.api.accessServiceProtocol.other": "",
|
|
20500
|
+
"record.metadata.api.accessServiceProtocol.postgis": "",
|
|
20501
|
+
"record.metadata.api.accessServiceProtocol.stac": "",
|
|
20467
20502
|
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
20468
20503
|
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
20469
20504
|
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
@@ -20505,13 +20540,16 @@ var es = {
|
|
|
20505
20540
|
"record.metadata.contact": "",
|
|
20506
20541
|
"record.metadata.creation": "",
|
|
20507
20542
|
"record.metadata.details": "",
|
|
20543
|
+
"record.metadata.doi.copy": "",
|
|
20544
|
+
"record.metadata.doi.open": "",
|
|
20508
20545
|
"record.metadata.download": "",
|
|
20509
20546
|
"record.metadata.feature.catalog": "",
|
|
20510
20547
|
"record.metadata.formats": "",
|
|
20511
20548
|
"record.metadata.isGeographical": "",
|
|
20512
20549
|
"record.metadata.keywords": "",
|
|
20513
20550
|
"record.metadata.languages": "",
|
|
20514
|
-
"record.metadata.
|
|
20551
|
+
"record.metadata.link.postgis.table": "",
|
|
20552
|
+
"record.metadata.link.postgis.tooltip": "",
|
|
20515
20553
|
"record.metadata.linked.datasets": "",
|
|
20516
20554
|
"record.metadata.linked.records": "",
|
|
20517
20555
|
"record.metadata.linked.reuses": "",
|
|
@@ -20552,6 +20590,9 @@ var es = {
|
|
|
20552
20590
|
"record.metadata.quality.updateFrequency.failed": "",
|
|
20553
20591
|
"record.metadata.quality.updateFrequency.success": "",
|
|
20554
20592
|
"record.metadata.related": "",
|
|
20593
|
+
"record.metadata.resourceCreated": "",
|
|
20594
|
+
"record.metadata.resourcePublished": "",
|
|
20595
|
+
"record.metadata.resourceUpdated": "",
|
|
20555
20596
|
"record.metadata.ressources.and.links": "Recursos y enlaces",
|
|
20556
20597
|
"record.metadata.sheet": "",
|
|
20557
20598
|
"record.metadata.status": "",
|
|
@@ -20564,6 +20605,7 @@ var es = {
|
|
|
20564
20605
|
"record.metadata.title": "",
|
|
20565
20606
|
"record.metadata.topics": "",
|
|
20566
20607
|
"record.metadata.uniqueId": "",
|
|
20608
|
+
"record.metadata.update": "",
|
|
20567
20609
|
"record.metadata.updateFrequency": "",
|
|
20568
20610
|
"record.metadata.updatedOn": "",
|
|
20569
20611
|
"record.metadata.usage": "",
|
|
@@ -20580,6 +20622,7 @@ var es = {
|
|
|
20580
20622
|
"record.tab.chart": "",
|
|
20581
20623
|
"record.tab.data": "",
|
|
20582
20624
|
"record.tab.map": "",
|
|
20625
|
+
"record.tab.stac": "",
|
|
20583
20626
|
"record.was.created.time": "",
|
|
20584
20627
|
records: records$5,
|
|
20585
20628
|
"results.layout.selectOne": "",
|
|
@@ -20588,7 +20631,6 @@ var es = {
|
|
|
20588
20631
|
"results.records.hits.found": "",
|
|
20589
20632
|
"results.records.hits.selected": "",
|
|
20590
20633
|
"results.showMore": "",
|
|
20591
|
-
"results.sortBy.changeDate": "",
|
|
20592
20634
|
"results.sortBy.dateStamp": "",
|
|
20593
20635
|
"results.sortBy.popularity": "",
|
|
20594
20636
|
"results.sortBy.qualityScore": "",
|
|
@@ -20672,6 +20714,10 @@ var es = {
|
|
|
20672
20714
|
"service.metadata.spatialExtent": "",
|
|
20673
20715
|
"share.tab.permalink": "",
|
|
20674
20716
|
"share.tab.webComponent": "",
|
|
20717
|
+
"stac.filter.from": "",
|
|
20718
|
+
"stac.filter.period": "",
|
|
20719
|
+
"stac.filter.reset": "",
|
|
20720
|
+
"stac.filter.to": "",
|
|
20675
20721
|
"table.loading.data": "",
|
|
20676
20722
|
"table.object.count": "",
|
|
20677
20723
|
"table.paginator.firstPage": "Primera página",
|
|
@@ -21116,6 +21162,8 @@ var fr = {
|
|
|
21116
21162
|
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
21117
21163
|
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
21118
21164
|
"record.metadata.api.accessServiceProtocol.other": "autre",
|
|
21165
|
+
"record.metadata.api.accessServiceProtocol.postgis": "PostGIS",
|
|
21166
|
+
"record.metadata.api.accessServiceProtocol.stac": "STAC",
|
|
21119
21167
|
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
21120
21168
|
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
21121
21169
|
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
@@ -21157,13 +21205,16 @@ var fr = {
|
|
|
21157
21205
|
"record.metadata.contact": "Contact",
|
|
21158
21206
|
"record.metadata.creation": "Date de création",
|
|
21159
21207
|
"record.metadata.details": "À propos de la donnée",
|
|
21208
|
+
"record.metadata.doi.copy": "Copier le DOI",
|
|
21209
|
+
"record.metadata.doi.open": "Ouvrir le lien DOI",
|
|
21160
21210
|
"record.metadata.download": "Téléchargements",
|
|
21161
21211
|
"record.metadata.feature.catalog": "Catalogue d'attributs",
|
|
21162
21212
|
"record.metadata.formats": "Formats",
|
|
21163
21213
|
"record.metadata.isGeographical": "Donnée géographique",
|
|
21164
21214
|
"record.metadata.keywords": "Mots-clés",
|
|
21165
21215
|
"record.metadata.languages": "Langues",
|
|
21166
|
-
"record.metadata.
|
|
21216
|
+
"record.metadata.link.postgis.table": "table :",
|
|
21217
|
+
"record.metadata.link.postgis.tooltip": "Les ressources de type PostGIS n'ont pas de lien d'accès",
|
|
21167
21218
|
"record.metadata.linked.datasets": "Jeux de données associés",
|
|
21168
21219
|
"record.metadata.linked.records": "Contenus associés",
|
|
21169
21220
|
"record.metadata.linked.reuses": "Réutilisations associées",
|
|
@@ -21204,6 +21255,9 @@ var fr = {
|
|
|
21204
21255
|
"record.metadata.quality.updateFrequency.failed": "La fréquence de mise à jour n'est pas renseignée",
|
|
21205
21256
|
"record.metadata.quality.updateFrequency.success": "La fréquence de mise à jour est renseignée",
|
|
21206
21257
|
"record.metadata.related": "Explorez le catalogue",
|
|
21258
|
+
"record.metadata.resourceCreated": "Créé le {date}",
|
|
21259
|
+
"record.metadata.resourcePublished": "Publié le {date}",
|
|
21260
|
+
"record.metadata.resourceUpdated": "Mis à jour le {date}",
|
|
21207
21261
|
"record.metadata.ressources.and.links": "Ressources et liens",
|
|
21208
21262
|
"record.metadata.sheet": "Fiche de métadonnées d'origine",
|
|
21209
21263
|
"record.metadata.status": "Statut",
|
|
@@ -21216,8 +21270,9 @@ var fr = {
|
|
|
21216
21270
|
"record.metadata.title": "Intitulé",
|
|
21217
21271
|
"record.metadata.topics": "Catégories",
|
|
21218
21272
|
"record.metadata.uniqueId": "Identificateur de ressource unique",
|
|
21273
|
+
"record.metadata.update": "Date de mise à jour",
|
|
21219
21274
|
"record.metadata.updateFrequency": "Fréquence de mise à jour des données",
|
|
21220
|
-
"record.metadata.updatedOn": "
|
|
21275
|
+
"record.metadata.updatedOn": "Fiche de métadonnées modifiée le",
|
|
21221
21276
|
"record.metadata.usage": "Licences et conditions d'utilisation",
|
|
21222
21277
|
"record.metadata.userFeedbacks": "Questions / Réponses",
|
|
21223
21278
|
"record.metadata.userFeedbacks.anonymousUser": "Pour rédiger un commentaire, veuillez vous identifier.",
|
|
@@ -21232,6 +21287,7 @@ var fr = {
|
|
|
21232
21287
|
"record.tab.chart": "Graphique",
|
|
21233
21288
|
"record.tab.data": "Tableau",
|
|
21234
21289
|
"record.tab.map": "Carte",
|
|
21290
|
+
"record.tab.stac": "STAC",
|
|
21235
21291
|
"record.was.created.time": "a créé cette ressource {time}",
|
|
21236
21292
|
records: records$4,
|
|
21237
21293
|
"results.layout.selectOne": "Affichage des résultats",
|
|
@@ -21240,7 +21296,6 @@ var fr = {
|
|
|
21240
21296
|
"results.records.hits.found": "{hits, plural, =0{Aucune correspondance.} one{1 ressource trouvée.} other{{hits} ressources.}}",
|
|
21241
21297
|
"results.records.hits.selected": "{amount, plural, one{1 selectionné} other{{ amount } sélectionnés}}",
|
|
21242
21298
|
"results.showMore": "Plus de résultats...",
|
|
21243
|
-
"results.sortBy.changeDate": "Dernière modification",
|
|
21244
21299
|
"results.sortBy.dateStamp": "Plus récent",
|
|
21245
21300
|
"results.sortBy.popularity": "Popularité",
|
|
21246
21301
|
"results.sortBy.qualityScore": "Indicateur de complétion",
|
|
@@ -21324,6 +21379,10 @@ var fr = {
|
|
|
21324
21379
|
"service.metadata.spatialExtent": "Etendue spatiale",
|
|
21325
21380
|
"share.tab.permalink": "Partager",
|
|
21326
21381
|
"share.tab.webComponent": "Intégrer",
|
|
21382
|
+
"stac.filter.from": "Du",
|
|
21383
|
+
"stac.filter.period": "Choix de la période",
|
|
21384
|
+
"stac.filter.reset": "Réinitialiser les filtres",
|
|
21385
|
+
"stac.filter.to": "Au",
|
|
21327
21386
|
"table.loading.data": "Chargement des données...",
|
|
21328
21387
|
"table.object.count": "enregistrements dans ce jeu de données",
|
|
21329
21388
|
"table.paginator.firstPage": "Première page",
|
|
@@ -21768,6 +21827,8 @@ var it = {
|
|
|
21768
21827
|
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
21769
21828
|
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
21770
21829
|
"record.metadata.api.accessServiceProtocol.other": "",
|
|
21830
|
+
"record.metadata.api.accessServiceProtocol.postgis": "",
|
|
21831
|
+
"record.metadata.api.accessServiceProtocol.stac": "",
|
|
21771
21832
|
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
21772
21833
|
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
21773
21834
|
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
@@ -21809,13 +21870,16 @@ var it = {
|
|
|
21809
21870
|
"record.metadata.contact": "Contatto",
|
|
21810
21871
|
"record.metadata.creation": "Data di creazione",
|
|
21811
21872
|
"record.metadata.details": "A proposito del dati",
|
|
21873
|
+
"record.metadata.doi.copy": "",
|
|
21874
|
+
"record.metadata.doi.open": "",
|
|
21812
21875
|
"record.metadata.download": "Download",
|
|
21813
21876
|
"record.metadata.feature.catalog": "Catalogo dei oggetti",
|
|
21814
21877
|
"record.metadata.formats": "Formati",
|
|
21815
21878
|
"record.metadata.isGeographical": "Dati geografici",
|
|
21816
21879
|
"record.metadata.keywords": "Parole chiave",
|
|
21817
21880
|
"record.metadata.languages": "Lingue",
|
|
21818
|
-
"record.metadata.
|
|
21881
|
+
"record.metadata.link.postgis.table": "",
|
|
21882
|
+
"record.metadata.link.postgis.tooltip": "",
|
|
21819
21883
|
"record.metadata.linked.datasets": "",
|
|
21820
21884
|
"record.metadata.linked.records": "",
|
|
21821
21885
|
"record.metadata.linked.reuses": "",
|
|
@@ -21856,8 +21920,11 @@ var it = {
|
|
|
21856
21920
|
"record.metadata.quality.updateFrequency.failed": "La frequenza di aggiornamento non è specificata",
|
|
21857
21921
|
"record.metadata.quality.updateFrequency.success": "La frequenza di aggiornamento è specificata",
|
|
21858
21922
|
"record.metadata.related": "Vedi anche",
|
|
21923
|
+
"record.metadata.resourceCreated": "Creato il {date}",
|
|
21924
|
+
"record.metadata.resourcePublished": "Pubblicato il {date}",
|
|
21925
|
+
"record.metadata.resourceUpdated": "Ultimo aggiornamento il {date}",
|
|
21859
21926
|
"record.metadata.ressources.and.links": "Risorse e collegamenti",
|
|
21860
|
-
"record.metadata.sheet": "Origine
|
|
21927
|
+
"record.metadata.sheet": "Origine dei metadati",
|
|
21861
21928
|
"record.metadata.status": "Stato",
|
|
21862
21929
|
"record.metadata.status.notPublished": "Non pubblicato",
|
|
21863
21930
|
"record.metadata.status.published": "Pubblicato",
|
|
@@ -21868,8 +21935,9 @@ var it = {
|
|
|
21868
21935
|
"record.metadata.title": "Titolo",
|
|
21869
21936
|
"record.metadata.topics": "Categorie",
|
|
21870
21937
|
"record.metadata.uniqueId": "Identificatore unico di risorsa",
|
|
21938
|
+
"record.metadata.update": "Data di aggiornamento",
|
|
21871
21939
|
"record.metadata.updateFrequency": "Frequenza di aggiornamento dei dati",
|
|
21872
|
-
"record.metadata.updatedOn": "
|
|
21940
|
+
"record.metadata.updatedOn": "Metadati modificati il",
|
|
21873
21941
|
"record.metadata.usage": "Licenze e limiti di utilizzo",
|
|
21874
21942
|
"record.metadata.userFeedbacks": "Domande / Risposte",
|
|
21875
21943
|
"record.metadata.userFeedbacks.anonymousUser": "Per pubblicare un commento, effettua il login.",
|
|
@@ -21884,6 +21952,7 @@ var it = {
|
|
|
21884
21952
|
"record.tab.chart": "Grafico",
|
|
21885
21953
|
"record.tab.data": "Tabella",
|
|
21886
21954
|
"record.tab.map": "Mappa",
|
|
21955
|
+
"record.tab.stac": "",
|
|
21887
21956
|
"record.was.created.time": "ha creato questi dati {time}",
|
|
21888
21957
|
records: records$3,
|
|
21889
21958
|
"results.layout.selectOne": "Mostra risultati",
|
|
@@ -21892,7 +21961,6 @@ var it = {
|
|
|
21892
21961
|
"results.records.hits.found": "{hits, plural, =0{Nessuna corrispondenza.} one{1 record trovato.} other{{hits} risultati.}}",
|
|
21893
21962
|
"results.records.hits.selected": "{amount, plural, one{1 selezionato} other{{ amount } selezionati}}",
|
|
21894
21963
|
"results.showMore": "Altri risultati...",
|
|
21895
|
-
"results.sortBy.changeDate": "Ultima modifica",
|
|
21896
21964
|
"results.sortBy.dateStamp": "Più recente",
|
|
21897
21965
|
"results.sortBy.popularity": "Popolarità",
|
|
21898
21966
|
"results.sortBy.qualityScore": "Indicatore di completamento",
|
|
@@ -21976,6 +22044,10 @@ var it = {
|
|
|
21976
22044
|
"service.metadata.spatialExtent": "Estensione spaziale",
|
|
21977
22045
|
"share.tab.permalink": "Condividere",
|
|
21978
22046
|
"share.tab.webComponent": "Incorporare",
|
|
22047
|
+
"stac.filter.from": "",
|
|
22048
|
+
"stac.filter.period": "",
|
|
22049
|
+
"stac.filter.reset": "",
|
|
22050
|
+
"stac.filter.to": "",
|
|
21979
22051
|
"table.loading.data": "Caricamento dei dati...",
|
|
21980
22052
|
"table.object.count": "record in questi dati",
|
|
21981
22053
|
"table.paginator.firstPage": "Prima pagina",
|
|
@@ -22420,6 +22492,8 @@ var nl = {
|
|
|
22420
22492
|
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
22421
22493
|
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
22422
22494
|
"record.metadata.api.accessServiceProtocol.other": "",
|
|
22495
|
+
"record.metadata.api.accessServiceProtocol.postgis": "",
|
|
22496
|
+
"record.metadata.api.accessServiceProtocol.stac": "",
|
|
22423
22497
|
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
22424
22498
|
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
22425
22499
|
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
@@ -22461,13 +22535,16 @@ var nl = {
|
|
|
22461
22535
|
"record.metadata.contact": "",
|
|
22462
22536
|
"record.metadata.creation": "",
|
|
22463
22537
|
"record.metadata.details": "",
|
|
22538
|
+
"record.metadata.doi.copy": "",
|
|
22539
|
+
"record.metadata.doi.open": "",
|
|
22464
22540
|
"record.metadata.download": "",
|
|
22465
22541
|
"record.metadata.feature.catalog": "",
|
|
22466
22542
|
"record.metadata.formats": "",
|
|
22467
22543
|
"record.metadata.isGeographical": "",
|
|
22468
22544
|
"record.metadata.keywords": "",
|
|
22469
22545
|
"record.metadata.languages": "",
|
|
22470
|
-
"record.metadata.
|
|
22546
|
+
"record.metadata.link.postgis.table": "",
|
|
22547
|
+
"record.metadata.link.postgis.tooltip": "",
|
|
22471
22548
|
"record.metadata.linked.datasets": "",
|
|
22472
22549
|
"record.metadata.linked.records": "",
|
|
22473
22550
|
"record.metadata.linked.reuses": "",
|
|
@@ -22508,6 +22585,9 @@ var nl = {
|
|
|
22508
22585
|
"record.metadata.quality.updateFrequency.failed": "",
|
|
22509
22586
|
"record.metadata.quality.updateFrequency.success": "",
|
|
22510
22587
|
"record.metadata.related": "",
|
|
22588
|
+
"record.metadata.resourceCreated": "",
|
|
22589
|
+
"record.metadata.resourcePublished": "",
|
|
22590
|
+
"record.metadata.resourceUpdated": "",
|
|
22511
22591
|
"record.metadata.ressources.and.links": "Bronnen en links",
|
|
22512
22592
|
"record.metadata.sheet": "",
|
|
22513
22593
|
"record.metadata.status": "",
|
|
@@ -22520,6 +22600,7 @@ var nl = {
|
|
|
22520
22600
|
"record.metadata.title": "",
|
|
22521
22601
|
"record.metadata.topics": "",
|
|
22522
22602
|
"record.metadata.uniqueId": "",
|
|
22603
|
+
"record.metadata.update": "",
|
|
22523
22604
|
"record.metadata.updateFrequency": "",
|
|
22524
22605
|
"record.metadata.updatedOn": "",
|
|
22525
22606
|
"record.metadata.usage": "",
|
|
@@ -22536,6 +22617,7 @@ var nl = {
|
|
|
22536
22617
|
"record.tab.chart": "",
|
|
22537
22618
|
"record.tab.data": "",
|
|
22538
22619
|
"record.tab.map": "",
|
|
22620
|
+
"record.tab.stac": "",
|
|
22539
22621
|
"record.was.created.time": "",
|
|
22540
22622
|
records: records$2,
|
|
22541
22623
|
"results.layout.selectOne": "",
|
|
@@ -22544,7 +22626,6 @@ var nl = {
|
|
|
22544
22626
|
"results.records.hits.found": "",
|
|
22545
22627
|
"results.records.hits.selected": "",
|
|
22546
22628
|
"results.showMore": "",
|
|
22547
|
-
"results.sortBy.changeDate": "",
|
|
22548
22629
|
"results.sortBy.dateStamp": "",
|
|
22549
22630
|
"results.sortBy.popularity": "",
|
|
22550
22631
|
"results.sortBy.qualityScore": "",
|
|
@@ -22628,6 +22709,10 @@ var nl = {
|
|
|
22628
22709
|
"service.metadata.spatialExtent": "",
|
|
22629
22710
|
"share.tab.permalink": "",
|
|
22630
22711
|
"share.tab.webComponent": "",
|
|
22712
|
+
"stac.filter.from": "",
|
|
22713
|
+
"stac.filter.period": "",
|
|
22714
|
+
"stac.filter.reset": "",
|
|
22715
|
+
"stac.filter.to": "",
|
|
22631
22716
|
"table.loading.data": "",
|
|
22632
22717
|
"table.object.count": "",
|
|
22633
22718
|
"table.paginator.firstPage": "",
|
|
@@ -23072,6 +23157,8 @@ var pt = {
|
|
|
23072
23157
|
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
23073
23158
|
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
23074
23159
|
"record.metadata.api.accessServiceProtocol.other": "",
|
|
23160
|
+
"record.metadata.api.accessServiceProtocol.postgis": "",
|
|
23161
|
+
"record.metadata.api.accessServiceProtocol.stac": "",
|
|
23075
23162
|
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
23076
23163
|
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
23077
23164
|
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
@@ -23113,13 +23200,16 @@ var pt = {
|
|
|
23113
23200
|
"record.metadata.contact": "",
|
|
23114
23201
|
"record.metadata.creation": "",
|
|
23115
23202
|
"record.metadata.details": "",
|
|
23203
|
+
"record.metadata.doi.copy": "",
|
|
23204
|
+
"record.metadata.doi.open": "",
|
|
23116
23205
|
"record.metadata.download": "",
|
|
23117
23206
|
"record.metadata.feature.catalog": "",
|
|
23118
23207
|
"record.metadata.formats": "",
|
|
23119
23208
|
"record.metadata.isGeographical": "",
|
|
23120
23209
|
"record.metadata.keywords": "",
|
|
23121
23210
|
"record.metadata.languages": "",
|
|
23122
|
-
"record.metadata.
|
|
23211
|
+
"record.metadata.link.postgis.table": "",
|
|
23212
|
+
"record.metadata.link.postgis.tooltip": "",
|
|
23123
23213
|
"record.metadata.linked.datasets": "",
|
|
23124
23214
|
"record.metadata.linked.records": "",
|
|
23125
23215
|
"record.metadata.linked.reuses": "",
|
|
@@ -23160,6 +23250,9 @@ var pt = {
|
|
|
23160
23250
|
"record.metadata.quality.updateFrequency.failed": "",
|
|
23161
23251
|
"record.metadata.quality.updateFrequency.success": "",
|
|
23162
23252
|
"record.metadata.related": "",
|
|
23253
|
+
"record.metadata.resourceCreated": "",
|
|
23254
|
+
"record.metadata.resourcePublished": "",
|
|
23255
|
+
"record.metadata.resourceUpdated": "",
|
|
23163
23256
|
"record.metadata.ressources.and.links": "Recursos e links",
|
|
23164
23257
|
"record.metadata.sheet": "",
|
|
23165
23258
|
"record.metadata.status": "",
|
|
@@ -23172,6 +23265,7 @@ var pt = {
|
|
|
23172
23265
|
"record.metadata.title": "",
|
|
23173
23266
|
"record.metadata.topics": "",
|
|
23174
23267
|
"record.metadata.uniqueId": "",
|
|
23268
|
+
"record.metadata.update": "",
|
|
23175
23269
|
"record.metadata.updateFrequency": "",
|
|
23176
23270
|
"record.metadata.updatedOn": "",
|
|
23177
23271
|
"record.metadata.usage": "",
|
|
@@ -23188,6 +23282,7 @@ var pt = {
|
|
|
23188
23282
|
"record.tab.chart": "",
|
|
23189
23283
|
"record.tab.data": "",
|
|
23190
23284
|
"record.tab.map": "",
|
|
23285
|
+
"record.tab.stac": "",
|
|
23191
23286
|
"record.was.created.time": "",
|
|
23192
23287
|
records: records$1,
|
|
23193
23288
|
"results.layout.selectOne": "",
|
|
@@ -23196,7 +23291,6 @@ var pt = {
|
|
|
23196
23291
|
"results.records.hits.found": "",
|
|
23197
23292
|
"results.records.hits.selected": "",
|
|
23198
23293
|
"results.showMore": "",
|
|
23199
|
-
"results.sortBy.changeDate": "",
|
|
23200
23294
|
"results.sortBy.dateStamp": "",
|
|
23201
23295
|
"results.sortBy.popularity": "",
|
|
23202
23296
|
"results.sortBy.qualityScore": "",
|
|
@@ -23280,6 +23374,10 @@ var pt = {
|
|
|
23280
23374
|
"service.metadata.spatialExtent": "",
|
|
23281
23375
|
"share.tab.permalink": "",
|
|
23282
23376
|
"share.tab.webComponent": "",
|
|
23377
|
+
"stac.filter.from": "",
|
|
23378
|
+
"stac.filter.period": "",
|
|
23379
|
+
"stac.filter.reset": "",
|
|
23380
|
+
"stac.filter.to": "",
|
|
23283
23381
|
"table.loading.data": "",
|
|
23284
23382
|
"table.object.count": "",
|
|
23285
23383
|
"table.paginator.firstPage": "",
|
|
@@ -23724,6 +23822,8 @@ var sk = {
|
|
|
23724
23822
|
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
23725
23823
|
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
23726
23824
|
"record.metadata.api.accessServiceProtocol.other": "",
|
|
23825
|
+
"record.metadata.api.accessServiceProtocol.postgis": "",
|
|
23826
|
+
"record.metadata.api.accessServiceProtocol.stac": "",
|
|
23727
23827
|
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
23728
23828
|
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
23729
23829
|
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
@@ -23765,13 +23865,16 @@ var sk = {
|
|
|
23765
23865
|
"record.metadata.contact": "Kontakt",
|
|
23766
23866
|
"record.metadata.creation": "",
|
|
23767
23867
|
"record.metadata.details": "Detaily",
|
|
23868
|
+
"record.metadata.doi.copy": "",
|
|
23869
|
+
"record.metadata.doi.open": "",
|
|
23768
23870
|
"record.metadata.download": "Sťahovania",
|
|
23769
23871
|
"record.metadata.feature.catalog": "",
|
|
23770
23872
|
"record.metadata.formats": "Formáty",
|
|
23771
23873
|
"record.metadata.isGeographical": "Súbor geografických údajov",
|
|
23772
23874
|
"record.metadata.keywords": "Kľúčové slová",
|
|
23773
23875
|
"record.metadata.languages": "",
|
|
23774
|
-
"record.metadata.
|
|
23876
|
+
"record.metadata.link.postgis.table": "",
|
|
23877
|
+
"record.metadata.link.postgis.tooltip": "",
|
|
23775
23878
|
"record.metadata.linked.datasets": "",
|
|
23776
23879
|
"record.metadata.linked.records": "",
|
|
23777
23880
|
"record.metadata.linked.reuses": "",
|
|
@@ -23812,6 +23915,9 @@ var sk = {
|
|
|
23812
23915
|
"record.metadata.quality.updateFrequency.failed": "Frekvencia aktualizácie nie je určená",
|
|
23813
23916
|
"record.metadata.quality.updateFrequency.success": "Frekvencia aktualizácie je určená",
|
|
23814
23917
|
"record.metadata.related": "Súvisiace záznamy",
|
|
23918
|
+
"record.metadata.resourceCreated": "",
|
|
23919
|
+
"record.metadata.resourcePublished": "",
|
|
23920
|
+
"record.metadata.resourceUpdated": "",
|
|
23815
23921
|
"record.metadata.ressources.and.links": "Prostředky a odkazy",
|
|
23816
23922
|
"record.metadata.sheet": "Ďalšie metadáta sú k dispozícii na:",
|
|
23817
23923
|
"record.metadata.status": "Stav",
|
|
@@ -23824,8 +23930,9 @@ var sk = {
|
|
|
23824
23930
|
"record.metadata.title": "Názov",
|
|
23825
23931
|
"record.metadata.topics": "",
|
|
23826
23932
|
"record.metadata.uniqueId": "Jedinečný identifikátor",
|
|
23933
|
+
"record.metadata.update": "Dátum aktualizácie",
|
|
23827
23934
|
"record.metadata.updateFrequency": "Frekvencia aktualizácie metadát",
|
|
23828
|
-
"record.metadata.updatedOn": "
|
|
23935
|
+
"record.metadata.updatedOn": "Metadáta zmenené dňa",
|
|
23829
23936
|
"record.metadata.usage": "Použitie a obmedzenia",
|
|
23830
23937
|
"record.metadata.userFeedbacks": "",
|
|
23831
23938
|
"record.metadata.userFeedbacks.anonymousUser": "",
|
|
@@ -23840,6 +23947,7 @@ var sk = {
|
|
|
23840
23947
|
"record.tab.chart": "Graf",
|
|
23841
23948
|
"record.tab.data": "Tabuľka",
|
|
23842
23949
|
"record.tab.map": "Mapa",
|
|
23950
|
+
"record.tab.stac": "",
|
|
23843
23951
|
"record.was.created.time": "vytvoril tento dataset o {time}",
|
|
23844
23952
|
records: records,
|
|
23845
23953
|
"results.layout.selectOne": "Rozmiestnenie výsledkov",
|
|
@@ -23848,7 +23956,6 @@ var sk = {
|
|
|
23848
23956
|
"results.records.hits.found": "{hits, plural, =0{Žiadne dokumenty nezodpovedajú zadanému vyhľadávaniu.} one{1 záznam nájdený.} other{{hits} záznamov nájdených.}}",
|
|
23849
23957
|
"results.records.hits.selected": "{ amount } označených",
|
|
23850
23958
|
"results.showMore": "Zobraziť viac výsledkov...",
|
|
23851
|
-
"results.sortBy.changeDate": "",
|
|
23852
23959
|
"results.sortBy.dateStamp": "Najnovšie",
|
|
23853
23960
|
"results.sortBy.popularity": "Popularita",
|
|
23854
23961
|
"results.sortBy.qualityScore": "Indikátor dokončenia",
|
|
@@ -23932,6 +24039,10 @@ var sk = {
|
|
|
23932
24039
|
"service.metadata.spatialExtent": "",
|
|
23933
24040
|
"share.tab.permalink": "Zdieľať",
|
|
23934
24041
|
"share.tab.webComponent": "Integrovať",
|
|
24042
|
+
"stac.filter.from": "",
|
|
24043
|
+
"stac.filter.period": "",
|
|
24044
|
+
"stac.filter.reset": "",
|
|
24045
|
+
"stac.filter.to": "",
|
|
23935
24046
|
"table.loading.data": "Načítanie údajov...",
|
|
23936
24047
|
"table.object.count": "objekty v tomto súbore údajov",
|
|
23937
24048
|
"table.paginator.firstPage": "",
|
|
@@ -24229,6 +24340,29 @@ class Gn4FieldMapper {
|
|
|
24229
24340
|
}),
|
|
24230
24341
|
};
|
|
24231
24342
|
},
|
|
24343
|
+
resourceIdentifier: (output, source) => {
|
|
24344
|
+
const identifiers = getAsArray(selectField(source, 'resourceIdentifier'));
|
|
24345
|
+
if (!identifiers.length)
|
|
24346
|
+
return output;
|
|
24347
|
+
const mappedIdentifiers = identifiers
|
|
24348
|
+
.map((id) => {
|
|
24349
|
+
const code = selectField(id, 'code');
|
|
24350
|
+
const codeSpace = selectField(id, 'codeSpace');
|
|
24351
|
+
const link = selectField(id, 'link');
|
|
24352
|
+
return {
|
|
24353
|
+
code,
|
|
24354
|
+
...(codeSpace && { codeSpace }),
|
|
24355
|
+
...(link && { url: link }),
|
|
24356
|
+
};
|
|
24357
|
+
})
|
|
24358
|
+
.filter((id) => id !== null);
|
|
24359
|
+
if (!mappedIdentifiers.length)
|
|
24360
|
+
return output;
|
|
24361
|
+
return {
|
|
24362
|
+
...output,
|
|
24363
|
+
resourceIdentifiers: mappedIdentifiers,
|
|
24364
|
+
};
|
|
24365
|
+
},
|
|
24232
24366
|
};
|
|
24233
24367
|
this.genericField = (output) => output;
|
|
24234
24368
|
this.constraintField = (type, output, constraintArray) => {
|
|
@@ -24337,6 +24471,8 @@ class Gn4FieldMapper {
|
|
|
24337
24471
|
/^OGC:WMTS/.test(protocol) ||
|
|
24338
24472
|
/TMS/i.test(protocol) ||
|
|
24339
24473
|
/ogc\W*api\W*features/i.test(protocol) ||
|
|
24474
|
+
/^DB:POSTGIS/i.test(protocol) ||
|
|
24475
|
+
/stac\W*items/i.test(protocol) ||
|
|
24340
24476
|
(/^WWW:DOWNLOAD-/.test(protocol) && /data.geopf.fr/.test(url)) // TO DO : change with the good protocol when decided
|
|
24341
24477
|
) {
|
|
24342
24478
|
return 'service';
|
|
@@ -24607,8 +24743,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
24607
24743
|
|
|
24608
24744
|
const PROXY_PATH = new InjectionToken('proxyPath');
|
|
24609
24745
|
class ProxyService {
|
|
24610
|
-
|
|
24611
|
-
this.
|
|
24746
|
+
get proxyPath() {
|
|
24747
|
+
return this.injector.get(PROXY_PATH, null);
|
|
24748
|
+
}
|
|
24749
|
+
constructor(injector, location) {
|
|
24750
|
+
this.injector = injector;
|
|
24612
24751
|
this.location = location;
|
|
24613
24752
|
}
|
|
24614
24753
|
/**
|
|
@@ -24631,7 +24770,7 @@ class ProxyService {
|
|
|
24631
24770
|
return url;
|
|
24632
24771
|
return new URL(`${this.proxyPath}${encodeURIComponent(url)}`, window.location.href).toString();
|
|
24633
24772
|
}
|
|
24634
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProxyService, deps: [{ token:
|
|
24773
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProxyService, deps: [{ token: i0.Injector }, { token: i1$2.Location }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
24635
24774
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProxyService, providedIn: 'root' }); }
|
|
24636
24775
|
}
|
|
24637
24776
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProxyService, decorators: [{
|
|
@@ -24639,12 +24778,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
24639
24778
|
args: [{
|
|
24640
24779
|
providedIn: 'root',
|
|
24641
24780
|
}]
|
|
24642
|
-
}], ctorParameters: () => [{ type:
|
|
24643
|
-
type: Optional
|
|
24644
|
-
}, {
|
|
24645
|
-
type: Inject,
|
|
24646
|
-
args: [PROXY_PATH]
|
|
24647
|
-
}] }, { type: i1$2.Location }] });
|
|
24781
|
+
}], ctorParameters: () => [{ type: i0.Injector }, { type: i1$2.Location }] });
|
|
24648
24782
|
|
|
24649
24783
|
class DateService {
|
|
24650
24784
|
constructor(translateService) {
|
|
@@ -24983,13 +25117,16 @@ function sortByToStrings(sortBy) {
|
|
|
24983
25117
|
return array.map((param) => `${param[0] === 'desc' ? '-' : ''}${param[1]}`);
|
|
24984
25118
|
}
|
|
24985
25119
|
function sortByToString(sortBy) {
|
|
24986
|
-
return sortByToStrings(sortBy)
|
|
25120
|
+
return sortByToStrings(sortBy).join(',');
|
|
24987
25121
|
}
|
|
24988
25122
|
function sortByFromString(sortByString) {
|
|
24989
|
-
|
|
24990
|
-
|
|
24991
|
-
|
|
24992
|
-
|
|
25123
|
+
const fields = sortByString
|
|
25124
|
+
.split(',')
|
|
25125
|
+
.map((field) => [
|
|
25126
|
+
field.startsWith('-') ? 'desc' : 'asc',
|
|
25127
|
+
field.startsWith('-') ? field.substring(1) : field,
|
|
25128
|
+
]);
|
|
25129
|
+
return fields.length > 1 ? fields : fields[0];
|
|
24993
25130
|
}
|
|
24994
25131
|
|
|
24995
25132
|
const stripHtml = function (html) {
|
|
@@ -25187,6 +25324,12 @@ const FORMATS = {
|
|
|
25187
25324
|
color: '#5A9E6F',
|
|
25188
25325
|
mimeTypes: ['image/webp'],
|
|
25189
25326
|
},
|
|
25327
|
+
postgis: {
|
|
25328
|
+
extensions: ['postgis'],
|
|
25329
|
+
priority: 18,
|
|
25330
|
+
color: '#336791',
|
|
25331
|
+
mimeTypes: [],
|
|
25332
|
+
},
|
|
25190
25333
|
};
|
|
25191
25334
|
function getFormatPriority(linkFormat) {
|
|
25192
25335
|
for (const format in FORMATS) {
|
|
@@ -25217,6 +25360,11 @@ function getFileFormatFromServiceOutput(serviceOutput) {
|
|
|
25217
25360
|
return null;
|
|
25218
25361
|
}
|
|
25219
25362
|
function getFileFormat(link) {
|
|
25363
|
+
if ('accessServiceProtocol' in link) {
|
|
25364
|
+
if (link.accessServiceProtocol in FORMATS) {
|
|
25365
|
+
return link.accessServiceProtocol;
|
|
25366
|
+
}
|
|
25367
|
+
}
|
|
25220
25368
|
if ('mimeType' in link) {
|
|
25221
25369
|
const mimeTypeFormat = mimeTypeToFormat(link.mimeType);
|
|
25222
25370
|
if (mimeTypeFormat !== null) {
|
|
@@ -25382,6 +25530,10 @@ class LinkClassifierService {
|
|
|
25382
25530
|
return [LinkUsage.API, LinkUsage.DOWNLOAD, LinkUsage.GEODATA];
|
|
25383
25531
|
case 'GPFDL':
|
|
25384
25532
|
return [LinkUsage.API];
|
|
25533
|
+
case 'postgis':
|
|
25534
|
+
return [LinkUsage.UNKNOWN];
|
|
25535
|
+
case 'stac':
|
|
25536
|
+
return [LinkUsage.API];
|
|
25385
25537
|
default:
|
|
25386
25538
|
return [LinkUsage.UNKNOWN];
|
|
25387
25539
|
}
|
|
@@ -25445,7 +25597,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
25445
25597
|
}] } });
|
|
25446
25598
|
|
|
25447
25599
|
var name = "geonetwork-ui";
|
|
25448
|
-
var version = "2.8.0-dev.
|
|
25600
|
+
var version = "2.8.0-dev.cba2fd2eb";
|
|
25449
25601
|
var engines = {
|
|
25450
25602
|
node: ">=20"
|
|
25451
25603
|
};
|
|
@@ -26197,7 +26349,7 @@ class Gn4SettingsService {
|
|
|
26197
26349
|
this.apiVersion$ = this.getSettingsSetValueByKey('system/platform/version');
|
|
26198
26350
|
}
|
|
26199
26351
|
getSettingsSetValueByKey(key) {
|
|
26200
|
-
return this.siteApiService.getSettingsSet(null, [key])
|
|
26352
|
+
return of(true).pipe(switchMap(() => this.siteApiService.getSettingsSet(null, [key])), map$1((v) => v[key]), shareReplay$1({ bufferSize: 1, refCount: true }));
|
|
26201
26353
|
}
|
|
26202
26354
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: Gn4SettingsService, deps: [{ token: SiteApiService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
26203
26355
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: Gn4SettingsService, providedIn: 'root' }); }
|
|
@@ -27136,6 +27288,9 @@ class Gn4PlatformService {
|
|
|
27136
27288
|
console.warn('Error while loading gnui language package');
|
|
27137
27289
|
return of({});
|
|
27138
27290
|
}), shareReplay$1(1));
|
|
27291
|
+
this.me$ = this.disableAuth
|
|
27292
|
+
? of(null)
|
|
27293
|
+
: of(true).pipe(switchMap(() => this.meApi.getMe()), switchMap((apiUser) => this.mapper.userFromMeApi(apiUser)), shareReplay$1({ bufferSize: 1, refCount: true }));
|
|
27139
27294
|
/**
|
|
27140
27295
|
* A map of already loaded thesauri (groups of keywords); the key is a URI
|
|
27141
27296
|
* @private
|
|
@@ -27146,9 +27301,6 @@ class Gn4PlatformService {
|
|
|
27146
27301
|
.pipe(map$1((thesaurus) => {
|
|
27147
27302
|
return thesaurus[0];
|
|
27148
27303
|
}), shareReplay$1(1));
|
|
27149
|
-
this.me$ = this.disableAuth
|
|
27150
|
-
? of(null)
|
|
27151
|
-
: this.meApi.getMe().pipe(switchMap((apiUser) => this.mapper.userFromMeApi(apiUser)), shareReplay$1({ bufferSize: 1, refCount: true }));
|
|
27152
27304
|
this.isUserAnonymous$ = this.me$.pipe(map$1((user) => !user || !('id' in user)));
|
|
27153
27305
|
this.users$ = this.usersApi.getUsers().pipe(map$1((users) => users.map((user) => this.mapper.userFromApi(user))), shareReplay$1());
|
|
27154
27306
|
}
|
|
@@ -29761,8 +29913,7 @@ class DropdownSelectorComponent {
|
|
|
29761
29913
|
];
|
|
29762
29914
|
}
|
|
29763
29915
|
get selectedChoice() {
|
|
29764
|
-
return (this.choices.find((choice) => choice.value === this.selected) ??
|
|
29765
|
-
this.choices[0]);
|
|
29916
|
+
return (this.choices.find((choice) => JSON.stringify(choice.value) === JSON.stringify(this.selected)) ?? this.choices[0]);
|
|
29766
29917
|
}
|
|
29767
29918
|
get id() {
|
|
29768
29919
|
return this.title.toLowerCase().replace(/[^a-z]+/g, '-');
|
|
@@ -33739,7 +33890,7 @@ class ExternalLinkCardComponent {
|
|
|
33739
33890
|
}
|
|
33740
33891
|
set size(value) {
|
|
33741
33892
|
this._size = value;
|
|
33742
|
-
this.cardClass = this.sizeClassMap[value]
|
|
33893
|
+
this.cardClass = `group flex flex-row justify-between card-shadow rounded overflow-hidden ${this.sizeClassMap[value]}`;
|
|
33743
33894
|
}
|
|
33744
33895
|
get size() {
|
|
33745
33896
|
return this._size;
|
|
@@ -33750,6 +33901,10 @@ class ExternalLinkCardComponent {
|
|
|
33750
33901
|
}
|
|
33751
33902
|
return this.link.name || this.link.description || '';
|
|
33752
33903
|
}
|
|
33904
|
+
get isDatabase() {
|
|
33905
|
+
return (this.link.type === 'service' &&
|
|
33906
|
+
this.link.accessServiceProtocol === 'postgis');
|
|
33907
|
+
}
|
|
33753
33908
|
getLinkFormat(link) {
|
|
33754
33909
|
return getFileFormat(link);
|
|
33755
33910
|
}
|
|
@@ -33760,18 +33915,20 @@ class ExternalLinkCardComponent {
|
|
|
33760
33915
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ExternalLinkCardComponent, isStandalone: true, selector: "gn-ui-external-link-card", inputs: { link: "link", size: "size" }, providers: [
|
|
33761
33916
|
provideIcons({
|
|
33762
33917
|
matOpenInNew,
|
|
33918
|
+
iconoirDatabase,
|
|
33763
33919
|
}),
|
|
33764
33920
|
provideNgIconsConfig({ size: '1.5em' }),
|
|
33765
|
-
], ngImport: i0, template: "<
|
|
33921
|
+
], ngImport: i0, template: "<ng-container *ngIf=\"isDatabase; else clickableLink\">\n <div [ngClass]=\"cardClass\" [title]=\"title\">\n <ng-container *ngTemplateOutlet=\"cardContent\"></ng-container>\n <div\n class=\"flex min-w-[32px]\"\n [ngClass]=\"size === 'S' ? 'items-end' : 'items-center'\"\n >\n <div\n class=\"gn-ui-card-icon\"\n [title]=\"'record.metadata.link.postgis.tooltip' | translate\"\n >\n <ng-icon\n class=\"inline-block card-icon align-middle\"\n name=\"iconoirDatabase\"\n ></ng-icon>\n </div>\n </div>\n </div>\n</ng-container>\n\n<ng-template #clickableLink>\n <a [href]=\"link.url\" target=\"_blank\" [ngClass]=\"cardClass\" [title]=\"title\">\n <ng-container *ngTemplateOutlet=\"cardContent\"></ng-container>\n <div\n class=\"flex min-w-[32px]\"\n [ngClass]=\"size === 'S' ? 'items-end' : 'items-center'\"\n >\n <div class=\"gn-ui-card-icon\">\n <ng-icon\n class=\"inline-block card-icon align-middle\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </div>\n </div>\n </a>\n</ng-template>\n<ng-template #cardContent>\n <div class=\"flex flex-col justify-between flex-1 min-w-0\">\n <div class=\"gn-ui-card-title\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n <ng-container *ngIf=\"isDatabase\">\n {{ 'record.metadata.link.postgis.table' | translate }}\n </ng-container>\n {{ link.name }}\n </div>\n <p *ngIf=\"!link.name && !link.description\" class=\"gn-ui-card-title\">\n {{ link.url }}\n </p>\n <div class=\"pt-1\">\n <span\n class=\"inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded transition-opacity opacity-70 group-hover:opacity-100\"\n [style.background-color]=\"getLinkColor(link)\"\n data-cy=\"download-format\"\n >\n {{ getLinkFormat(link) || ('downloads.format.unknown' | translate) }}\n </span>\n </div>\n </div>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
33766
33922
|
}
|
|
33767
33923
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ExternalLinkCardComponent, decorators: [{
|
|
33768
33924
|
type: Component,
|
|
33769
33925
|
args: [{ selector: 'gn-ui-external-link-card', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, NgIconComponent, TranslatePipe], providers: [
|
|
33770
33926
|
provideIcons({
|
|
33771
33927
|
matOpenInNew,
|
|
33928
|
+
iconoirDatabase,
|
|
33772
33929
|
}),
|
|
33773
33930
|
provideNgIconsConfig({ size: '1.5em' }),
|
|
33774
|
-
], template: "<
|
|
33931
|
+
], template: "<ng-container *ngIf=\"isDatabase; else clickableLink\">\n <div [ngClass]=\"cardClass\" [title]=\"title\">\n <ng-container *ngTemplateOutlet=\"cardContent\"></ng-container>\n <div\n class=\"flex min-w-[32px]\"\n [ngClass]=\"size === 'S' ? 'items-end' : 'items-center'\"\n >\n <div\n class=\"gn-ui-card-icon\"\n [title]=\"'record.metadata.link.postgis.tooltip' | translate\"\n >\n <ng-icon\n class=\"inline-block card-icon align-middle\"\n name=\"iconoirDatabase\"\n ></ng-icon>\n </div>\n </div>\n </div>\n</ng-container>\n\n<ng-template #clickableLink>\n <a [href]=\"link.url\" target=\"_blank\" [ngClass]=\"cardClass\" [title]=\"title\">\n <ng-container *ngTemplateOutlet=\"cardContent\"></ng-container>\n <div\n class=\"flex min-w-[32px]\"\n [ngClass]=\"size === 'S' ? 'items-end' : 'items-center'\"\n >\n <div class=\"gn-ui-card-icon\">\n <ng-icon\n class=\"inline-block card-icon align-middle\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </div>\n </div>\n </a>\n</ng-template>\n<ng-template #cardContent>\n <div class=\"flex flex-col justify-between flex-1 min-w-0\">\n <div class=\"gn-ui-card-title\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n <ng-container *ngIf=\"isDatabase\">\n {{ 'record.metadata.link.postgis.table' | translate }}\n </ng-container>\n {{ link.name }}\n </div>\n <p *ngIf=\"!link.name && !link.description\" class=\"gn-ui-card-title\">\n {{ link.url }}\n </p>\n <div class=\"pt-1\">\n <span\n class=\"inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded transition-opacity opacity-70 group-hover:opacity-100\"\n [style.background-color]=\"getLinkColor(link)\"\n data-cy=\"download-format\"\n >\n {{ getLinkFormat(link) || ('downloads.format.unknown' | translate) }}\n </span>\n </div>\n </div>\n</ng-template>\n" }]
|
|
33775
33932
|
}], propDecorators: { link: [{
|
|
33776
33933
|
type: Input
|
|
33777
33934
|
}], size: [{
|
|
@@ -33891,6 +34048,33 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
33891
34048
|
type: Output
|
|
33892
34049
|
}] } });
|
|
33893
34050
|
|
|
34051
|
+
class MetadataDoiComponent {
|
|
34052
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MetadataDoiComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34053
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MetadataDoiComponent, isStandalone: true, selector: "gn-ui-metadata-doi", inputs: { code: "code", link: "link" }, ngImport: i0, template: "<div\n class=\"border border-gray-300 rounded-lg py-4 px-5 text-black flex justify-between items-center gap-4\"\n>\n <div class=\"overflow-hidden flex-1\">\n <p class=\"text-base font-medium mb-3\">DOI</p>\n <p\n class=\"text-base font-medium overflow-hidden text-ellipsis whitespace-nowrap\"\n [title]=\"code\"\n >\n {{ code }}\n </p>\n </div>\n <div class=\"flex gap-2 items-start\">\n <gn-ui-copy-text-button\n [text]=\"code\"\n [displayText]=\"false\"\n [tooltipText]=\"'record.metadata.doi.copy' | translate\"\n class=\"[&>div]:flex [&>div]:items-center [&>div]:justify-center [&_button]:w-[40px] [&_button]:h-[32px] [&_button]:flex [&_button]:items-center [&_button]:justify-center [&_button]:hover:bg-gray-100 [&_button]:rounded-lg [&_button]:transition-colors [&_button]:border [&_button]:border-gray-300 [&_button]:px-2 [&_button]:py-1 [&_ng-icon]:w-5 [&_ng-icon]:h-5\"\n ></gn-ui-copy-text-button>\n <a\n *ngIf=\"link\"\n [href]=\"link\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"w-[40px] h-[32px] flex items-center justify-center hover:bg-gray-100 rounded-lg transition-colors border border-gray-300 px-2 py-1\"\n [matTooltip]=\"'record.metadata.doi.open' | translate\"\n >\n <ng-icon name=\"matOpenInNew\" size=\"20\"></ng-icon>\n </a>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2$2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }], viewProviders: [
|
|
34054
|
+
provideIcons({
|
|
34055
|
+
matOpenInNew,
|
|
34056
|
+
}),
|
|
34057
|
+
] }); }
|
|
34058
|
+
}
|
|
34059
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MetadataDoiComponent, decorators: [{
|
|
34060
|
+
type: Component,
|
|
34061
|
+
args: [{ selector: 'gn-ui-metadata-doi', standalone: true, imports: [
|
|
34062
|
+
CommonModule,
|
|
34063
|
+
MatTooltipModule,
|
|
34064
|
+
NgIcon,
|
|
34065
|
+
TranslatePipe,
|
|
34066
|
+
CopyTextButtonComponent,
|
|
34067
|
+
], viewProviders: [
|
|
34068
|
+
provideIcons({
|
|
34069
|
+
matOpenInNew,
|
|
34070
|
+
}),
|
|
34071
|
+
], template: "<div\n class=\"border border-gray-300 rounded-lg py-4 px-5 text-black flex justify-between items-center gap-4\"\n>\n <div class=\"overflow-hidden flex-1\">\n <p class=\"text-base font-medium mb-3\">DOI</p>\n <p\n class=\"text-base font-medium overflow-hidden text-ellipsis whitespace-nowrap\"\n [title]=\"code\"\n >\n {{ code }}\n </p>\n </div>\n <div class=\"flex gap-2 items-start\">\n <gn-ui-copy-text-button\n [text]=\"code\"\n [displayText]=\"false\"\n [tooltipText]=\"'record.metadata.doi.copy' | translate\"\n class=\"[&>div]:flex [&>div]:items-center [&>div]:justify-center [&_button]:w-[40px] [&_button]:h-[32px] [&_button]:flex [&_button]:items-center [&_button]:justify-center [&_button]:hover:bg-gray-100 [&_button]:rounded-lg [&_button]:transition-colors [&_button]:border [&_button]:border-gray-300 [&_button]:px-2 [&_button]:py-1 [&_ng-icon]:w-5 [&_ng-icon]:h-5\"\n ></gn-ui-copy-text-button>\n <a\n *ngIf=\"link\"\n [href]=\"link\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"w-[40px] h-[32px] flex items-center justify-center hover:bg-gray-100 rounded-lg transition-colors border border-gray-300 px-2 py-1\"\n [matTooltip]=\"'record.metadata.doi.open' | translate\"\n >\n <ng-icon name=\"matOpenInNew\" size=\"20\"></ng-icon>\n </a>\n </div>\n</div>\n" }]
|
|
34072
|
+
}], propDecorators: { code: [{
|
|
34073
|
+
type: Input
|
|
34074
|
+
}], link: [{
|
|
34075
|
+
type: Input
|
|
34076
|
+
}] } });
|
|
34077
|
+
|
|
33894
34078
|
/* eslint-disable @angular-eslint/directive-selector */
|
|
33895
34079
|
class GnUiLinkifyDirective {
|
|
33896
34080
|
constructor(el, renderer) {
|
|
@@ -34041,7 +34225,7 @@ class MetadataInfoComponent {
|
|
|
34041
34225
|
return this.dateService.formatDateTime(date);
|
|
34042
34226
|
}
|
|
34043
34227
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MetadataInfoComponent, deps: [{ token: DateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34044
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MetadataInfoComponent, isStandalone: true, selector: "gn-ui-metadata-info", inputs: { metadata: "metadata", incomplete: "incomplete" }, outputs: { keyword: "keyword" }, ngImport: i0, template: "<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n <gn-ui-content-ghost\n ghostClass=\"h-[178px]\"\n [showContent]=\"fieldReady('abstract')\"\n >\n <gn-ui-max-lines [maxLines]=\"6\" *ngIf=\"metadata.abstract\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n [textContent]=\"metadata.abstract\"\n ></gn-ui-markdown-parser>\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n\n <p\n class=\"mt-6 mb-3 font-medium text-black text-sm\"\n translate\n *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n >\n record.metadata.keywords\n </p>\n\n <gn-ui-content-ghost\n ghostClass=\"h-[31px] w-3/4\"\n [showContent]=\"fieldReady('keywords')\"\n >\n <gn-ui-max-lines [maxLines]=\"7\" *ngIf=\"metadata.keywords?.length\">\n <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n <gn-ui-badge\n class=\"inline-block lowercase\"\n (click)=\"onKeywordClick(keyword)\"\n [clickable]=\"true\"\n *ngFor=\"let keyword of metadata.keywords\"\n >{{ keyword.label }}</gn-ui-badge\n >\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.licenses ||\n metadata.legalConstraints ||\n metadata.securityConstraints ||\n metadata.otherConstraints\n \"\n [title]=\"'record.metadata.usage' | translate\"\n data-test=\"usage-panel\"\n>\n <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n <ng-container *ngFor=\"let license of licenses\">\n <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n <a\n [href]=\"license.url\"\n target=\"_blank\"\n class=\"cursor-pointer hover:underline transition-all\"\n >\n {{ license.text }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <ng-template #noUrl>\n <div class=\"text-primary\" gnUiLinkify>\n {{ license.text }}\n </div>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"legalConstraints.length\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n *ngFor=\"let constraint of legalConstraints\"\n [textContent]=\"constraint\"\n >\n </gn-ui-markdown-parser>\n </div>\n </ng-container>\n <ng-container *ngIf=\"otherConstraints.length\">\n <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n <span\n translate\n class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n >\n record.metadata.otherConstraints\n </span>\n <div class=\"mb-6\">\n <gn-ui-markdown-parser [textContent]=\"constraint\">\n </gn-ui-markdown-parser>\n </div>\n </div>\n </ng-container>\n\n <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n {{ 'record.metadata.noUsage' | translate }}\n </span>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n (metadata.kind === 'dataset' && metadata.lineage) ||\n metadata.resourceUpdated ||\n metadata.updateFrequency ||\n (metadata.kind === 'dataset' && metadata.status)\n \"\n [title]=\"'record.metadata.details' | translate\"\n data-test=\"details-panel\"\n>\n <div *ngIf=\"metadata.lineage\" class=\"text-gray-900 flex flex-col mt-4 gap-2\">\n <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n {{ metadata.lineage }}\n </p>\n </div>\n <div class=\"flex flex-row gap-6 mt-5 mb-8\" *ngIf=\"resourceContact\">\n <div\n *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n >\n <gn-ui-thumbnail\n class=\"relative h-full w-full\"\n [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n fit=\"contain\"\n ></gn-ui-thumbnail>\n </div>\n <div class=\"flex flex-col gap-1\">\n <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n <div\n class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n data-cy=\"organization-name\"\n >\n {{ resourceContact.organization?.name }}\n </div>\n <div *ngIf=\"resourceContact.organization?.website\">\n <a\n [href]=\"resourceContact.organization.website\"\n target=\"_blank\"\n class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n >{{ resourceContact.organization.website }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n <div class=\"flex\">\n <ng-icon\n class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n name=\"matMailOutline\"\n ></ng-icon>\n <a\n *ngIf=\"resourceContact.email\"\n [href]=\"'mailto:' + resourceContact.email\"\n class=\"text-sm hover:underline ml-2\"\n target=\"_blank\"\n data-cy=\"contact-email\"\n >{{ resourceContact?.email }}</a\n >\n </div>\n </div>\n </div>\n </div>\n <div\n class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n >\n <div *ngIf=\"metadata.resourceCreated\">\n <p class=\"text-sm\" translate>record.metadata.creation</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourceCreated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.resourcePublished\">\n <p class=\"text-sm\" translate>record.metadata.publication</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourcePublished) }}\n </p>\n </div>\n <div *ngIf=\"updateFrequency\">\n <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n <p\n class=\"text-primary font-medium mt-1 updateFrequency\"\n translate\n [translateParams]=\"{ count: updatedTimes }\"\n >\n {{ updateFrequency }}\n </p>\n </div>\n <div *ngIf=\"metadata.otherLanguages?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n <div class=\"flex flex-row gap-1 flex-wrap\">\n <p\n class=\"text-primary font-medium\"\n translate\n *ngFor=\"let language of metadata.otherLanguages\"\n >\n language.{{ language }}\n </p>\n </div>\n </div>\n <div *ngIf=\"temporalExtent\">\n <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n <div class=\"flex flex-row gap-1 mb-1 text-primary font-medium\">\n <p\n *ngIf=\"temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{\n start: temporalExtent.start,\n end: temporalExtent.end,\n }\"\n >\n record.metadata.temporalExtent.fromDateToDate\n </p>\n <p\n *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n translate\n [translateParams]=\"{ start: temporalExtent.start }\"\n >\n record.metadata.temporalExtent.sinceDate\n </p>\n <p\n *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{ end: temporalExtent.end }\"\n >\n record.metadata.temporalExtent.untilDate\n </p>\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.kind !== 'dataset' &&\n metadata.spatialExtents &&\n metadata.spatialExtents.length\n \"\n [title]=\"'service.metadata.spatialExtent' | translate\"\n data-test=\"spatial-extent-panel\"\n>\n <gn-ui-spatial-extent\n class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n [spatialExtents]=\"metadata.spatialExtents\"\n ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.landingPage\"\n [title]=\"'service.metadata.other' | translate\"\n data-test=\"other-panel\"\n>\n <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n <div *ngIf=\"metadata.recordUpdated\">\n <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.landingPage\">\n <p class=\"text-sm\" translate>record.metadata.sheet</p>\n <p class=\"text-primary font-medium\" translate>\n <a [href]=\"metadata.landingPage\" target=\"_blank\">\n <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n </a>\n </p>\n </div>\n <div *ngIf=\"metadata.ownerOrganization\">\n <p class=\"text-sm\" translate>record.metadata.owner</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.ownerOrganization.name }}\n </p>\n </div>\n <div *ngIf=\"metadata.uniqueIdentifier\">\n <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n <div class=\"flex flex-row content-align items-end gap-1\">\n <gn-ui-copy-text-button\n [text]=\"metadata.uniqueIdentifier\"\n [tooltipText]=\"'tooltip.id.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <p class=\"text-primary font-medium\">\n {{ metadata.uniqueIdentifier }}\n </p>\n </div>\n </div>\n <div *ngIf=\"metadata.topics?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n <div class=\"sm:pb-4 sm:pr-16\">\n <gn-ui-badge\n [clickable]=\"false\"\n class=\"inline-block mr-2 mb-2 lowercase\"\n *ngFor=\"let topic of metadata.topics\"\n >{{ topic }}</gn-ui-badge\n >\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n", styles: [".md-description ::ng-deep a{@apply underline text-blue-600 hover:text-blue-800;}.info-grid>:nth-last-child(n+3){padding-bottom:10px;@apply border-b border-gray-300;}:host ::ng-deep gn-ui-copy-text-button button ng-icon{transform:scale(.8)}:host{--gn-ui-badge-background-color: var(--color-primary-white);--gn-ui-badge-text-color: var(--color-primary-darkest)}:host .metadata-info-keywords ::ng-deep gn-ui-badge:hover{--gn-ui-badge-text-color: white}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: MarkdownParserComponent, selector: "gn-ui-markdown-parser", inputs: ["textContent", "whitoutStyles"] }, { kind: "component", type: ExpandablePanelComponent, selector: "gn-ui-expandable-panel", inputs: ["title", "iconColor", "collapsed"] }, { kind: "component", type: BadgeComponent, selector: "gn-ui-badge", inputs: ["clickable", "removable"], outputs: ["badgeRemoveClicked"] }, { kind: "component", type: ContentGhostComponent, selector: "gn-ui-content-ghost", inputs: ["showContent", "ghostClass"] }, { kind: "component", type: ThumbnailComponent, selector: "gn-ui-thumbnail", inputs: ["thumbnailUrl", "fit"], outputs: ["placeholderShown"] }, { kind: "component", type: MaxLinesComponent, selector: "gn-ui-max-lines", inputs: ["maxLines"] }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: GnUiLinkifyDirective, selector: "[gnUiLinkify]" }, { kind: "component", type: SpatialExtentComponent, selector: "gn-ui-spatial-extent", inputs: ["spatialExtents"] }], viewProviders: [
|
|
34228
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MetadataInfoComponent, isStandalone: true, selector: "gn-ui-metadata-info", inputs: { metadata: "metadata", incomplete: "incomplete" }, outputs: { keyword: "keyword" }, ngImport: i0, template: "<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n <gn-ui-content-ghost\n ghostClass=\"h-[178px]\"\n [showContent]=\"fieldReady('abstract')\"\n >\n <gn-ui-max-lines\n [maxLines]=\"6\"\n *ngIf=\"metadata.abstract\"\n data-test=\"metadata-info-abstract\"\n >\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n [textContent]=\"metadata.abstract\"\n ></gn-ui-markdown-parser>\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n\n <p\n class=\"mt-6 mb-3 font-medium text-black text-sm\"\n translate\n *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n >\n record.metadata.keywords\n </p>\n\n <gn-ui-content-ghost\n ghostClass=\"h-[31px] w-3/4\"\n [showContent]=\"fieldReady('keywords')\"\n >\n <gn-ui-max-lines [maxLines]=\"7\" *ngIf=\"metadata.keywords?.length\">\n <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n <gn-ui-badge\n class=\"inline-block lowercase\"\n (click)=\"onKeywordClick(keyword)\"\n [clickable]=\"true\"\n *ngFor=\"let keyword of metadata.keywords\"\n >{{ keyword.label }}</gn-ui-badge\n >\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.licenses ||\n metadata.legalConstraints ||\n metadata.securityConstraints ||\n metadata.otherConstraints\n \"\n [title]=\"'record.metadata.usage' | translate\"\n data-test=\"usage-panel\"\n>\n <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n <ng-container *ngFor=\"let license of licenses\">\n <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n <a\n [href]=\"license.url\"\n target=\"_blank\"\n class=\"cursor-pointer hover:underline transition-all\"\n >\n {{ license.text }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <ng-template #noUrl>\n <div class=\"text-primary\" gnUiLinkify>\n {{ license.text }}\n </div>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"legalConstraints.length\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n *ngFor=\"let constraint of legalConstraints\"\n [textContent]=\"constraint\"\n >\n </gn-ui-markdown-parser>\n </div>\n </ng-container>\n <ng-container *ngIf=\"otherConstraints.length\">\n <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n <span\n translate\n class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n >\n record.metadata.otherConstraints\n </span>\n <div class=\"mb-6\">\n <gn-ui-markdown-parser [textContent]=\"constraint\">\n </gn-ui-markdown-parser>\n </div>\n </div>\n </ng-container>\n\n <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n {{ 'record.metadata.noUsage' | translate }}\n </span>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n (metadata.kind === 'dataset' && metadata.lineage) ||\n resourceContact ||\n metadata.resourceCreated ||\n metadata.resourcePublished ||\n metadata.resourceUpdated ||\n (metadata.kind === 'dataset' && metadata.updateFrequency) ||\n metadata.otherLanguages?.length ||\n (metadata.kind === 'dataset' && temporalExtent)\n \"\n [title]=\"'record.metadata.details' | translate\"\n data-test=\"details-panel\"\n>\n <div\n *ngIf=\"metadata.kind === 'dataset' && metadata.lineage\"\n class=\"text-gray-900 flex flex-col mt-4 gap-2\"\n data-test=\"details-panel-lineage\"\n >\n <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n {{ metadata.lineage }}\n </p>\n </div>\n <div\n class=\"flex flex-row gap-6 mt-5 mb-8 resource-contact\"\n *ngIf=\"resourceContact\"\n data-test=\"details-panel-resource-contact\"\n >\n <div\n *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n >\n <gn-ui-thumbnail\n class=\"relative h-full w-full\"\n [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n fit=\"contain\"\n ></gn-ui-thumbnail>\n </div>\n <div class=\"flex flex-col gap-1\">\n <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n <div\n class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n data-cy=\"organization-name\"\n >\n {{ resourceContact.organization?.name }}\n </div>\n <div *ngIf=\"resourceContact.organization?.website\">\n <a\n [href]=\"resourceContact.organization.website\"\n target=\"_blank\"\n class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n >{{ resourceContact.organization.website }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n <div class=\"flex\">\n <ng-icon\n class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n name=\"matMailOutline\"\n ></ng-icon>\n <a\n *ngIf=\"resourceContact.email\"\n [href]=\"'mailto:' + resourceContact.email\"\n class=\"text-sm hover:underline ml-2\"\n target=\"_blank\"\n data-cy=\"contact-email\"\n >{{ resourceContact?.email }}</a\n >\n </div>\n </div>\n </div>\n </div>\n <div\n class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n >\n <div\n *ngIf=\"metadata.resourceCreated\"\n data-test=\"details-panel-resource-created\"\n >\n <p class=\"text-sm\" translate>record.metadata.creation</p>\n <p class=\"text-primary font-medium mt-1 resource-created\">\n {{ formatDate(metadata.resourceCreated) }}\n </p>\n </div>\n <div\n *ngIf=\"metadata.resourcePublished\"\n data-test=\"details-panel-resource-published\"\n >\n <p class=\"text-sm\" translate>record.metadata.publication</p>\n <p class=\"text-primary font-medium mt-1 resource-published\">\n {{ formatDate(metadata.resourcePublished) }}\n </p>\n </div>\n <div\n *ngIf=\"metadata.resourceUpdated\"\n data-test=\"details-panel-resource-updated\"\n >\n <p class=\"text-sm\" translate>record.metadata.update</p>\n <p class=\"text-primary font-medium mt-1 resource-updated\">\n {{ formatDate(metadata.resourceUpdated) }}\n </p>\n </div>\n <div\n *ngIf=\"metadata.kind === 'dataset' && metadata.updateFrequency\"\n data-test=\"details-panel-update-frequency\"\n >\n <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n <p\n class=\"text-primary font-medium mt-1 updateFrequency\"\n translate\n [translateParams]=\"{ count: updatedTimes }\"\n >\n {{ updateFrequency }}\n </p>\n </div>\n <div\n *ngIf=\"metadata.otherLanguages?.length\"\n data-test=\"details-panel-other-languages\"\n >\n <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n <div class=\"flex flex-row gap-1 flex-wrap\">\n <p\n class=\"text-primary font-medium other-languages\"\n translate\n *ngFor=\"let language of metadata.otherLanguages\"\n >\n language.{{ language }}\n </p>\n </div>\n </div>\n <div\n *ngIf=\"metadata.kind === 'dataset' && temporalExtent\"\n data-test=\"details-panel-temporal-extent\"\n >\n <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n <div\n class=\"flex flex-row gap-1 mb-1 text-primary font-medium temporal-extent\"\n >\n <p\n *ngIf=\"temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{\n start: temporalExtent.start,\n end: temporalExtent.end,\n }\"\n >\n record.metadata.temporalExtent.fromDateToDate\n </p>\n <p\n *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n translate\n [translateParams]=\"{ start: temporalExtent.start }\"\n >\n record.metadata.temporalExtent.sinceDate\n </p>\n <p\n *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{ end: temporalExtent.end }\"\n >\n record.metadata.temporalExtent.untilDate\n </p>\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.kind !== 'dataset' &&\n metadata.spatialExtents &&\n metadata.spatialExtents.length\n \"\n [title]=\"'service.metadata.spatialExtent' | translate\"\n data-test=\"spatial-extent-panel\"\n>\n <gn-ui-spatial-extent\n class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n [spatialExtents]=\"metadata.spatialExtents\"\n ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.landingPage\"\n [title]=\"'service.metadata.other' | translate\"\n data-test=\"other-panel\"\n>\n <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n <div *ngIf=\"metadata.recordUpdated\">\n <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.landingPage\">\n <p class=\"text-sm\" translate>record.metadata.sheet</p>\n <p class=\"text-primary font-medium\" translate>\n <a [href]=\"metadata.landingPage\" target=\"_blank\">\n <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n </a>\n </p>\n </div>\n <div *ngIf=\"metadata.ownerOrganization\">\n <p class=\"text-sm\" translate>record.metadata.owner</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.ownerOrganization.name }}\n </p>\n </div>\n <div *ngIf=\"metadata.uniqueIdentifier\">\n <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n <div class=\"flex flex-row content-align items-end gap-1\">\n <gn-ui-copy-text-button\n [text]=\"metadata.uniqueIdentifier\"\n [tooltipText]=\"'tooltip.id.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <p class=\"text-primary font-medium\">\n {{ metadata.uniqueIdentifier }}\n </p>\n </div>\n </div>\n <div *ngIf=\"metadata.topics?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n <div class=\"sm:pb-4 sm:pr-16\">\n <gn-ui-badge\n [clickable]=\"false\"\n class=\"inline-block mr-2 mb-2 lowercase\"\n *ngFor=\"let topic of metadata.topics\"\n >{{ topic }}</gn-ui-badge\n >\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n", styles: [".md-description ::ng-deep a{@apply underline text-blue-600 hover:text-blue-800;}.info-grid>:nth-last-child(n+3){padding-bottom:10px;@apply border-b border-gray-300;}:host ::ng-deep gn-ui-copy-text-button button ng-icon{transform:scale(.8)}:host{--gn-ui-badge-background-color: var(--color-primary-white);--gn-ui-badge-text-color: var(--color-primary-darkest)}:host .metadata-info-keywords ::ng-deep gn-ui-badge:hover{--gn-ui-badge-text-color: white}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: MarkdownParserComponent, selector: "gn-ui-markdown-parser", inputs: ["textContent", "whitoutStyles"] }, { kind: "component", type: ExpandablePanelComponent, selector: "gn-ui-expandable-panel", inputs: ["title", "iconColor", "collapsed"] }, { kind: "component", type: BadgeComponent, selector: "gn-ui-badge", inputs: ["clickable", "removable"], outputs: ["badgeRemoveClicked"] }, { kind: "component", type: ContentGhostComponent, selector: "gn-ui-content-ghost", inputs: ["showContent", "ghostClass"] }, { kind: "component", type: ThumbnailComponent, selector: "gn-ui-thumbnail", inputs: ["thumbnailUrl", "fit"], outputs: ["placeholderShown"] }, { kind: "component", type: MaxLinesComponent, selector: "gn-ui-max-lines", inputs: ["maxLines"] }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: GnUiLinkifyDirective, selector: "[gnUiLinkify]" }, { kind: "component", type: SpatialExtentComponent, selector: "gn-ui-spatial-extent", inputs: ["spatialExtents"] }], viewProviders: [
|
|
34045
34229
|
provideIcons({
|
|
34046
34230
|
matOpenInNew,
|
|
34047
34231
|
matMailOutline: matMailOutline$1,
|
|
@@ -34069,7 +34253,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
34069
34253
|
matOpenInNew,
|
|
34070
34254
|
matMailOutline: matMailOutline$1,
|
|
34071
34255
|
}),
|
|
34072
|
-
], template: "<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n <gn-ui-content-ghost\n ghostClass=\"h-[178px]\"\n [showContent]=\"fieldReady('abstract')\"\n >\n <gn-ui-max-lines [maxLines]=\"6\" *ngIf=\"metadata.abstract\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n [textContent]=\"metadata.abstract\"\n ></gn-ui-markdown-parser>\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n\n <p\n class=\"mt-6 mb-3 font-medium text-black text-sm\"\n translate\n *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n >\n record.metadata.keywords\n </p>\n\n <gn-ui-content-ghost\n ghostClass=\"h-[31px] w-3/4\"\n [showContent]=\"fieldReady('keywords')\"\n >\n <gn-ui-max-lines [maxLines]=\"7\" *ngIf=\"metadata.keywords?.length\">\n <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n <gn-ui-badge\n class=\"inline-block lowercase\"\n (click)=\"onKeywordClick(keyword)\"\n [clickable]=\"true\"\n *ngFor=\"let keyword of metadata.keywords\"\n >{{ keyword.label }}</gn-ui-badge\n >\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.licenses ||\n metadata.legalConstraints ||\n metadata.securityConstraints ||\n metadata.otherConstraints\n \"\n [title]=\"'record.metadata.usage' | translate\"\n data-test=\"usage-panel\"\n>\n <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n <ng-container *ngFor=\"let license of licenses\">\n <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n <a\n [href]=\"license.url\"\n target=\"_blank\"\n class=\"cursor-pointer hover:underline transition-all\"\n >\n {{ license.text }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <ng-template #noUrl>\n <div class=\"text-primary\" gnUiLinkify>\n {{ license.text }}\n </div>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"legalConstraints.length\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n *ngFor=\"let constraint of legalConstraints\"\n [textContent]=\"constraint\"\n >\n </gn-ui-markdown-parser>\n </div>\n </ng-container>\n <ng-container *ngIf=\"otherConstraints.length\">\n <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n <span\n translate\n class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n >\n record.metadata.otherConstraints\n </span>\n <div class=\"mb-6\">\n <gn-ui-markdown-parser [textContent]=\"constraint\">\n </gn-ui-markdown-parser>\n </div>\n </div>\n </ng-container>\n\n <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n {{ 'record.metadata.noUsage' | translate }}\n </span>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n (metadata.kind === 'dataset' && metadata.lineage) ||\n metadata.resourceUpdated ||\n metadata.updateFrequency ||\n (metadata.kind === 'dataset' && metadata.status)\n \"\n [title]=\"'record.metadata.details' | translate\"\n data-test=\"details-panel\"\n>\n <div *ngIf=\"metadata.lineage\" class=\"text-gray-900 flex flex-col mt-4 gap-2\">\n <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n {{ metadata.lineage }}\n </p>\n </div>\n <div class=\"flex flex-row gap-6 mt-5 mb-8\" *ngIf=\"resourceContact\">\n <div\n *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n >\n <gn-ui-thumbnail\n class=\"relative h-full w-full\"\n [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n fit=\"contain\"\n ></gn-ui-thumbnail>\n </div>\n <div class=\"flex flex-col gap-1\">\n <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n <div\n class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n data-cy=\"organization-name\"\n >\n {{ resourceContact.organization?.name }}\n </div>\n <div *ngIf=\"resourceContact.organization?.website\">\n <a\n [href]=\"resourceContact.organization.website\"\n target=\"_blank\"\n class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n >{{ resourceContact.organization.website }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n <div class=\"flex\">\n <ng-icon\n class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n name=\"matMailOutline\"\n ></ng-icon>\n <a\n *ngIf=\"resourceContact.email\"\n [href]=\"'mailto:' + resourceContact.email\"\n class=\"text-sm hover:underline ml-2\"\n target=\"_blank\"\n data-cy=\"contact-email\"\n >{{ resourceContact?.email }}</a\n >\n </div>\n </div>\n </div>\n </div>\n <div\n class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n >\n <div *ngIf=\"metadata.resourceCreated\">\n <p class=\"text-sm\" translate>record.metadata.creation</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourceCreated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.resourcePublished\">\n <p class=\"text-sm\" translate>record.metadata.publication</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourcePublished) }}\n </p>\n </div>\n <div *ngIf=\"updateFrequency\">\n <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n <p\n class=\"text-primary font-medium mt-1 updateFrequency\"\n translate\n [translateParams]=\"{ count: updatedTimes }\"\n >\n {{ updateFrequency }}\n </p>\n </div>\n <div *ngIf=\"metadata.otherLanguages?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n <div class=\"flex flex-row gap-1 flex-wrap\">\n <p\n class=\"text-primary font-medium\"\n translate\n *ngFor=\"let language of metadata.otherLanguages\"\n >\n language.{{ language }}\n </p>\n </div>\n </div>\n <div *ngIf=\"temporalExtent\">\n <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n <div class=\"flex flex-row gap-1 mb-1 text-primary font-medium\">\n <p\n *ngIf=\"temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{\n start: temporalExtent.start,\n end: temporalExtent.end,\n }\"\n >\n record.metadata.temporalExtent.fromDateToDate\n </p>\n <p\n *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n translate\n [translateParams]=\"{ start: temporalExtent.start }\"\n >\n record.metadata.temporalExtent.sinceDate\n </p>\n <p\n *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{ end: temporalExtent.end }\"\n >\n record.metadata.temporalExtent.untilDate\n </p>\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.kind !== 'dataset' &&\n metadata.spatialExtents &&\n metadata.spatialExtents.length\n \"\n [title]=\"'service.metadata.spatialExtent' | translate\"\n data-test=\"spatial-extent-panel\"\n>\n <gn-ui-spatial-extent\n class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n [spatialExtents]=\"metadata.spatialExtents\"\n ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.landingPage\"\n [title]=\"'service.metadata.other' | translate\"\n data-test=\"other-panel\"\n>\n <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n <div *ngIf=\"metadata.recordUpdated\">\n <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.landingPage\">\n <p class=\"text-sm\" translate>record.metadata.sheet</p>\n <p class=\"text-primary font-medium\" translate>\n <a [href]=\"metadata.landingPage\" target=\"_blank\">\n <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n </a>\n </p>\n </div>\n <div *ngIf=\"metadata.ownerOrganization\">\n <p class=\"text-sm\" translate>record.metadata.owner</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.ownerOrganization.name }}\n </p>\n </div>\n <div *ngIf=\"metadata.uniqueIdentifier\">\n <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n <div class=\"flex flex-row content-align items-end gap-1\">\n <gn-ui-copy-text-button\n [text]=\"metadata.uniqueIdentifier\"\n [tooltipText]=\"'tooltip.id.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <p class=\"text-primary font-medium\">\n {{ metadata.uniqueIdentifier }}\n </p>\n </div>\n </div>\n <div *ngIf=\"metadata.topics?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n <div class=\"sm:pb-4 sm:pr-16\">\n <gn-ui-badge\n [clickable]=\"false\"\n class=\"inline-block mr-2 mb-2 lowercase\"\n *ngFor=\"let topic of metadata.topics\"\n >{{ topic }}</gn-ui-badge\n >\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n", styles: [".md-description ::ng-deep a{@apply underline text-blue-600 hover:text-blue-800;}.info-grid>:nth-last-child(n+3){padding-bottom:10px;@apply border-b border-gray-300;}:host ::ng-deep gn-ui-copy-text-button button ng-icon{transform:scale(.8)}:host{--gn-ui-badge-background-color: var(--color-primary-white);--gn-ui-badge-text-color: var(--color-primary-darkest)}:host .metadata-info-keywords ::ng-deep gn-ui-badge:hover{--gn-ui-badge-text-color: white}\n"] }]
|
|
34256
|
+
], template: "<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n <gn-ui-content-ghost\n ghostClass=\"h-[178px]\"\n [showContent]=\"fieldReady('abstract')\"\n >\n <gn-ui-max-lines\n [maxLines]=\"6\"\n *ngIf=\"metadata.abstract\"\n data-test=\"metadata-info-abstract\"\n >\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n [textContent]=\"metadata.abstract\"\n ></gn-ui-markdown-parser>\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n\n <p\n class=\"mt-6 mb-3 font-medium text-black text-sm\"\n translate\n *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n >\n record.metadata.keywords\n </p>\n\n <gn-ui-content-ghost\n ghostClass=\"h-[31px] w-3/4\"\n [showContent]=\"fieldReady('keywords')\"\n >\n <gn-ui-max-lines [maxLines]=\"7\" *ngIf=\"metadata.keywords?.length\">\n <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n <gn-ui-badge\n class=\"inline-block lowercase\"\n (click)=\"onKeywordClick(keyword)\"\n [clickable]=\"true\"\n *ngFor=\"let keyword of metadata.keywords\"\n >{{ keyword.label }}</gn-ui-badge\n >\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.licenses ||\n metadata.legalConstraints ||\n metadata.securityConstraints ||\n metadata.otherConstraints\n \"\n [title]=\"'record.metadata.usage' | translate\"\n data-test=\"usage-panel\"\n>\n <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n <ng-container *ngFor=\"let license of licenses\">\n <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n <a\n [href]=\"license.url\"\n target=\"_blank\"\n class=\"cursor-pointer hover:underline transition-all\"\n >\n {{ license.text }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <ng-template #noUrl>\n <div class=\"text-primary\" gnUiLinkify>\n {{ license.text }}\n </div>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"legalConstraints.length\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n *ngFor=\"let constraint of legalConstraints\"\n [textContent]=\"constraint\"\n >\n </gn-ui-markdown-parser>\n </div>\n </ng-container>\n <ng-container *ngIf=\"otherConstraints.length\">\n <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n <span\n translate\n class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n >\n record.metadata.otherConstraints\n </span>\n <div class=\"mb-6\">\n <gn-ui-markdown-parser [textContent]=\"constraint\">\n </gn-ui-markdown-parser>\n </div>\n </div>\n </ng-container>\n\n <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n {{ 'record.metadata.noUsage' | translate }}\n </span>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n (metadata.kind === 'dataset' && metadata.lineage) ||\n resourceContact ||\n metadata.resourceCreated ||\n metadata.resourcePublished ||\n metadata.resourceUpdated ||\n (metadata.kind === 'dataset' && metadata.updateFrequency) ||\n metadata.otherLanguages?.length ||\n (metadata.kind === 'dataset' && temporalExtent)\n \"\n [title]=\"'record.metadata.details' | translate\"\n data-test=\"details-panel\"\n>\n <div\n *ngIf=\"metadata.kind === 'dataset' && metadata.lineage\"\n class=\"text-gray-900 flex flex-col mt-4 gap-2\"\n data-test=\"details-panel-lineage\"\n >\n <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n {{ metadata.lineage }}\n </p>\n </div>\n <div\n class=\"flex flex-row gap-6 mt-5 mb-8 resource-contact\"\n *ngIf=\"resourceContact\"\n data-test=\"details-panel-resource-contact\"\n >\n <div\n *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n >\n <gn-ui-thumbnail\n class=\"relative h-full w-full\"\n [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n fit=\"contain\"\n ></gn-ui-thumbnail>\n </div>\n <div class=\"flex flex-col gap-1\">\n <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n <div\n class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n data-cy=\"organization-name\"\n >\n {{ resourceContact.organization?.name }}\n </div>\n <div *ngIf=\"resourceContact.organization?.website\">\n <a\n [href]=\"resourceContact.organization.website\"\n target=\"_blank\"\n class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n >{{ resourceContact.organization.website }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n <div class=\"flex\">\n <ng-icon\n class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n name=\"matMailOutline\"\n ></ng-icon>\n <a\n *ngIf=\"resourceContact.email\"\n [href]=\"'mailto:' + resourceContact.email\"\n class=\"text-sm hover:underline ml-2\"\n target=\"_blank\"\n data-cy=\"contact-email\"\n >{{ resourceContact?.email }}</a\n >\n </div>\n </div>\n </div>\n </div>\n <div\n class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n >\n <div\n *ngIf=\"metadata.resourceCreated\"\n data-test=\"details-panel-resource-created\"\n >\n <p class=\"text-sm\" translate>record.metadata.creation</p>\n <p class=\"text-primary font-medium mt-1 resource-created\">\n {{ formatDate(metadata.resourceCreated) }}\n </p>\n </div>\n <div\n *ngIf=\"metadata.resourcePublished\"\n data-test=\"details-panel-resource-published\"\n >\n <p class=\"text-sm\" translate>record.metadata.publication</p>\n <p class=\"text-primary font-medium mt-1 resource-published\">\n {{ formatDate(metadata.resourcePublished) }}\n </p>\n </div>\n <div\n *ngIf=\"metadata.resourceUpdated\"\n data-test=\"details-panel-resource-updated\"\n >\n <p class=\"text-sm\" translate>record.metadata.update</p>\n <p class=\"text-primary font-medium mt-1 resource-updated\">\n {{ formatDate(metadata.resourceUpdated) }}\n </p>\n </div>\n <div\n *ngIf=\"metadata.kind === 'dataset' && metadata.updateFrequency\"\n data-test=\"details-panel-update-frequency\"\n >\n <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n <p\n class=\"text-primary font-medium mt-1 updateFrequency\"\n translate\n [translateParams]=\"{ count: updatedTimes }\"\n >\n {{ updateFrequency }}\n </p>\n </div>\n <div\n *ngIf=\"metadata.otherLanguages?.length\"\n data-test=\"details-panel-other-languages\"\n >\n <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n <div class=\"flex flex-row gap-1 flex-wrap\">\n <p\n class=\"text-primary font-medium other-languages\"\n translate\n *ngFor=\"let language of metadata.otherLanguages\"\n >\n language.{{ language }}\n </p>\n </div>\n </div>\n <div\n *ngIf=\"metadata.kind === 'dataset' && temporalExtent\"\n data-test=\"details-panel-temporal-extent\"\n >\n <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n <div\n class=\"flex flex-row gap-1 mb-1 text-primary font-medium temporal-extent\"\n >\n <p\n *ngIf=\"temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{\n start: temporalExtent.start,\n end: temporalExtent.end,\n }\"\n >\n record.metadata.temporalExtent.fromDateToDate\n </p>\n <p\n *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n translate\n [translateParams]=\"{ start: temporalExtent.start }\"\n >\n record.metadata.temporalExtent.sinceDate\n </p>\n <p\n *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{ end: temporalExtent.end }\"\n >\n record.metadata.temporalExtent.untilDate\n </p>\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.kind !== 'dataset' &&\n metadata.spatialExtents &&\n metadata.spatialExtents.length\n \"\n [title]=\"'service.metadata.spatialExtent' | translate\"\n data-test=\"spatial-extent-panel\"\n>\n <gn-ui-spatial-extent\n class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n [spatialExtents]=\"metadata.spatialExtents\"\n ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.landingPage\"\n [title]=\"'service.metadata.other' | translate\"\n data-test=\"other-panel\"\n>\n <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n <div *ngIf=\"metadata.recordUpdated\">\n <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.landingPage\">\n <p class=\"text-sm\" translate>record.metadata.sheet</p>\n <p class=\"text-primary font-medium\" translate>\n <a [href]=\"metadata.landingPage\" target=\"_blank\">\n <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n </a>\n </p>\n </div>\n <div *ngIf=\"metadata.ownerOrganization\">\n <p class=\"text-sm\" translate>record.metadata.owner</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.ownerOrganization.name }}\n </p>\n </div>\n <div *ngIf=\"metadata.uniqueIdentifier\">\n <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n <div class=\"flex flex-row content-align items-end gap-1\">\n <gn-ui-copy-text-button\n [text]=\"metadata.uniqueIdentifier\"\n [tooltipText]=\"'tooltip.id.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <p class=\"text-primary font-medium\">\n {{ metadata.uniqueIdentifier }}\n </p>\n </div>\n </div>\n <div *ngIf=\"metadata.topics?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n <div class=\"sm:pb-4 sm:pr-16\">\n <gn-ui-badge\n [clickable]=\"false\"\n class=\"inline-block mr-2 mb-2 lowercase\"\n *ngFor=\"let topic of metadata.topics\"\n >{{ topic }}</gn-ui-badge\n >\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n", styles: [".md-description ::ng-deep a{@apply underline text-blue-600 hover:text-blue-800;}.info-grid>:nth-last-child(n+3){padding-bottom:10px;@apply border-b border-gray-300;}:host ::ng-deep gn-ui-copy-text-button button ng-icon{transform:scale(.8)}:host{--gn-ui-badge-background-color: var(--color-primary-white);--gn-ui-badge-text-color: var(--color-primary-darkest)}:host .metadata-info-keywords ::ng-deep gn-ui-badge:hover{--gn-ui-badge-text-color: white}\n"] }]
|
|
34073
34257
|
}], ctorParameters: () => [{ type: DateService }], propDecorators: { metadata: [{
|
|
34074
34258
|
type: Input
|
|
34075
34259
|
}], incomplete: [{
|
|
@@ -36457,6 +36641,11 @@ const SortByEnum = {
|
|
|
36457
36641
|
RELEVANCY: ['desc', '_score'],
|
|
36458
36642
|
QUALITY_SCORE: ['desc', 'qualityScore'],
|
|
36459
36643
|
CHANGE_DATE: ['desc', 'changeDate'],
|
|
36644
|
+
RESOURCE_DATES: [
|
|
36645
|
+
['desc', 'revisionDateForResource'],
|
|
36646
|
+
['desc', 'publicationDateForResource'],
|
|
36647
|
+
['desc', 'creationDateForResource'],
|
|
36648
|
+
],
|
|
36460
36649
|
};
|
|
36461
36650
|
|
|
36462
36651
|
class SortByComponent {
|
|
@@ -36466,33 +36655,29 @@ class SortByComponent {
|
|
|
36466
36655
|
this.choices = [
|
|
36467
36656
|
{
|
|
36468
36657
|
label: marker('results.sortBy.relevancy'),
|
|
36469
|
-
value: SortByEnum.RELEVANCY
|
|
36658
|
+
value: SortByEnum.RELEVANCY,
|
|
36470
36659
|
},
|
|
36471
36660
|
{
|
|
36472
36661
|
label: marker('results.sortBy.dateStamp'),
|
|
36473
|
-
value: SortByEnum.
|
|
36474
|
-
},
|
|
36475
|
-
{
|
|
36476
|
-
label: marker('results.sortBy.changeDate'),
|
|
36477
|
-
value: SortByEnum.CHANGE_DATE.join(','),
|
|
36662
|
+
value: SortByEnum.RESOURCE_DATES,
|
|
36478
36663
|
},
|
|
36479
36664
|
{
|
|
36480
36665
|
label: marker('results.sortBy.popularity'),
|
|
36481
|
-
value: SortByEnum.POPULARITY
|
|
36666
|
+
value: SortByEnum.POPULARITY,
|
|
36482
36667
|
},
|
|
36483
36668
|
];
|
|
36484
|
-
this.currentSortBy$ = this.facade.sortBy$.pipe(filter$1((sortBy) => !!sortBy), map$1((sortBy) => sortBy
|
|
36669
|
+
this.currentSortBy$ = this.facade.sortBy$.pipe(filter$1((sortBy) => !!sortBy), map$1((sortBy) => sortBy));
|
|
36485
36670
|
}
|
|
36486
36671
|
ngOnInit() {
|
|
36487
36672
|
if (this.isQualitySortable) {
|
|
36488
36673
|
this.choices.push({
|
|
36489
36674
|
label: marker('results.sortBy.qualityScore'),
|
|
36490
|
-
value: SortByEnum.QUALITY_SCORE
|
|
36675
|
+
value: SortByEnum.QUALITY_SCORE,
|
|
36491
36676
|
});
|
|
36492
36677
|
}
|
|
36493
36678
|
}
|
|
36494
|
-
changeSortBy(
|
|
36495
|
-
this.searchService.setSortBy(
|
|
36679
|
+
changeSortBy(criteria) {
|
|
36680
|
+
this.searchService.setSortBy(criteria);
|
|
36496
36681
|
}
|
|
36497
36682
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SortByComponent, deps: [{ token: SearchFacade }, { token: SearchService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
36498
36683
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SortByComponent, isStandalone: true, selector: "gn-ui-sort-by", inputs: { isQualitySortable: "isQualitySortable" }, ngImport: i0, template: "<gn-ui-dropdown-selector\n [title]=\"'search.field.sortBy' | translate\"\n [choices]=\"choices\"\n (selectValue)=\"changeSortBy($event)\"\n [selected]=\"currentSortBy$ | async\"\n ariaName=\"search-sort-by\"\n></gn-ui-dropdown-selector>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1$2.AsyncPipe, name: "async" }, { kind: "component", type: DropdownSelectorComponent, selector: "gn-ui-dropdown-selector", inputs: ["title", "showTitle", "ariaName", "choices", "selected", "maxRows", "extraBtnClass", "minWidth", "disabled"], outputs: ["selectValue"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
|
|
@@ -38175,13 +38360,24 @@ class DataService {
|
|
|
38175
38360
|
if (!featureType) {
|
|
38176
38361
|
throw new Error('wfs.featuretype.notfound');
|
|
38177
38362
|
}
|
|
38363
|
+
const wfsVersion = endpoint.getVersion();
|
|
38364
|
+
const addSrsName = wfsVersion === '1.1.0' || wfsVersion === '2.0.0';
|
|
38365
|
+
const defaultCrs = featureType.defaultCrs;
|
|
38366
|
+
const shouldAddOutputCrs = addSrsName && defaultCrs;
|
|
38178
38367
|
return {
|
|
38179
|
-
all: featureType.outputFormats.reduce((prev, curr) =>
|
|
38180
|
-
|
|
38181
|
-
|
|
38182
|
-
|
|
38183
|
-
|
|
38184
|
-
|
|
38368
|
+
all: featureType.outputFormats.reduce((prev, curr) => {
|
|
38369
|
+
const isJsonFormat = curr.toLowerCase().includes('json');
|
|
38370
|
+
return {
|
|
38371
|
+
...prev,
|
|
38372
|
+
[curr]: endpoint.getFeatureUrl(featureType.name, {
|
|
38373
|
+
outputFormat: curr,
|
|
38374
|
+
...(shouldAddOutputCrs &&
|
|
38375
|
+
!isJsonFormat && {
|
|
38376
|
+
outputCrs: defaultCrs,
|
|
38377
|
+
}),
|
|
38378
|
+
}),
|
|
38379
|
+
};
|
|
38380
|
+
}, {}),
|
|
38185
38381
|
geojson: endpoint.supportsJson(featureType.name)
|
|
38186
38382
|
? endpoint.getFeatureUrl(featureType.name, {
|
|
38187
38383
|
asJson: true,
|
|
@@ -38856,6 +39052,8 @@ class ChartViewComponent {
|
|
|
38856
39052
|
this.chartType$.next(value);
|
|
38857
39053
|
}
|
|
38858
39054
|
set userChartConfig(config) {
|
|
39055
|
+
if (!config)
|
|
39056
|
+
return;
|
|
38859
39057
|
this.aggregation$.next(config.aggregation);
|
|
38860
39058
|
this.xProperty$.next(config.xProperty);
|
|
38861
39059
|
this.yProperty$.next(config.yProperty);
|
|
@@ -39293,6 +39491,49 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
39293
39491
|
type: Input
|
|
39294
39492
|
}] } });
|
|
39295
39493
|
|
|
39494
|
+
class StacViewComponent {
|
|
39495
|
+
constructor() {
|
|
39496
|
+
this.currentTemporalExtent = null;
|
|
39497
|
+
this.isTemporalFilterModified = false;
|
|
39498
|
+
}
|
|
39499
|
+
onStartDateChange(date) {
|
|
39500
|
+
this.currentTemporalExtent = {
|
|
39501
|
+
...this.currentTemporalExtent,
|
|
39502
|
+
start: date,
|
|
39503
|
+
};
|
|
39504
|
+
this.isTemporalFilterModified = true;
|
|
39505
|
+
}
|
|
39506
|
+
onEndDateChange(date) {
|
|
39507
|
+
this.currentTemporalExtent = {
|
|
39508
|
+
...this.currentTemporalExtent,
|
|
39509
|
+
end: date,
|
|
39510
|
+
};
|
|
39511
|
+
this.isTemporalFilterModified = true;
|
|
39512
|
+
}
|
|
39513
|
+
onResetFilters() {
|
|
39514
|
+
this.currentTemporalExtent = this.initialTemporalExtent;
|
|
39515
|
+
this.isTemporalFilterModified = false;
|
|
39516
|
+
}
|
|
39517
|
+
ngOnInit() {
|
|
39518
|
+
this.currentTemporalExtent = this.initialTemporalExtent;
|
|
39519
|
+
}
|
|
39520
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StacViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39521
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: StacViewComponent, isStandalone: true, selector: "gn-ui-stac-view", inputs: { link: "link", initialTemporalExtent: "initialTemporalExtent" }, ngImport: i0, template: "<div\n class=\"w-full h-full flex flex-row mt-6 bg-white border border-gray-300 rounded-lg overflow-hidden\"\n>\n <div class=\"flex-1 flex flex-col\">\n <div class=\"m-8\">\n <p class=\"mb-4\" translate>stac.filter.period</p>\n <p translate>stac.filter.from</p>\n <gn-ui-date-picker\n id=\"start-date-picker\"\n [date]=\"currentTemporalExtent?.start\"\n (dateChange)=\"onStartDateChange($event)\"\n />\n <p class=\"mt-4\" translate>stac.filter.to</p>\n <gn-ui-date-picker\n id=\"end-date-picker\"\n [date]=\"currentTemporalExtent?.end\"\n (dateChange)=\"onEndDateChange($event)\"\n />\n </div>\n\n <div class=\"mt-auto mb-8 mx-8\" *ngIf=\"isTemporalFilterModified\">\n <button\n id=\"reset-filters-button\"\n type=\"button\"\n class=\"flex items-center\"\n (click)=\"onResetFilters()\"\n >\n <span translate>stac.filter.reset</span>\n <ng-icon\n name=\"matDeleteOutline\"\n class=\"pointer-events-none ml-2\"\n ></ng-icon>\n </button>\n </div>\n </div>\n\n <div class=\"w-[655px] flex-shrink-0 flex items-center justify-center\">\n <span>Map...</span>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: DatePickerComponent, selector: "gn-ui-date-picker", inputs: ["date"], outputs: ["dateChange"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], viewProviders: [provideIcons({ matDeleteOutline })], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
39522
|
+
}
|
|
39523
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StacViewComponent, decorators: [{
|
|
39524
|
+
type: Component,
|
|
39525
|
+
args: [{ selector: 'gn-ui-stac-view', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
39526
|
+
CommonModule,
|
|
39527
|
+
DatePickerComponent,
|
|
39528
|
+
NgIconComponent,
|
|
39529
|
+
TranslateDirective,
|
|
39530
|
+
], viewProviders: [provideIcons({ matDeleteOutline })], template: "<div\n class=\"w-full h-full flex flex-row mt-6 bg-white border border-gray-300 rounded-lg overflow-hidden\"\n>\n <div class=\"flex-1 flex flex-col\">\n <div class=\"m-8\">\n <p class=\"mb-4\" translate>stac.filter.period</p>\n <p translate>stac.filter.from</p>\n <gn-ui-date-picker\n id=\"start-date-picker\"\n [date]=\"currentTemporalExtent?.start\"\n (dateChange)=\"onStartDateChange($event)\"\n />\n <p class=\"mt-4\" translate>stac.filter.to</p>\n <gn-ui-date-picker\n id=\"end-date-picker\"\n [date]=\"currentTemporalExtent?.end\"\n (dateChange)=\"onEndDateChange($event)\"\n />\n </div>\n\n <div class=\"mt-auto mb-8 mx-8\" *ngIf=\"isTemporalFilterModified\">\n <button\n id=\"reset-filters-button\"\n type=\"button\"\n class=\"flex items-center\"\n (click)=\"onResetFilters()\"\n >\n <span translate>stac.filter.reset</span>\n <ng-icon\n name=\"matDeleteOutline\"\n class=\"pointer-events-none ml-2\"\n ></ng-icon>\n </button>\n </div>\n </div>\n\n <div class=\"w-[655px] flex-shrink-0 flex items-center justify-center\">\n <span>Map...</span>\n </div>\n</div>\n" }]
|
|
39531
|
+
}], propDecorators: { link: [{
|
|
39532
|
+
type: Input
|
|
39533
|
+
}], initialTemporalExtent: [{
|
|
39534
|
+
type: Input
|
|
39535
|
+
}] } });
|
|
39536
|
+
|
|
39296
39537
|
/**
|
|
39297
39538
|
* The Metadata View Facade is used to render complete metadata records.
|
|
39298
39539
|
* Supply it with an incomplete record (at least containing the uuid) and the
|
|
@@ -39323,8 +39564,21 @@ class MdViewFacade {
|
|
|
39323
39564
|
this.sourceOf$ = this.store.pipe(select(getSourceOf));
|
|
39324
39565
|
this.chartConfig$ = this.store.pipe(select(getChartConfig));
|
|
39325
39566
|
this.allLinks$ = this.metadata$.pipe(map$1((record) => 'onlineResources' in record ? record.onlineResources : []), shareReplay$1(1));
|
|
39567
|
+
this.resourceDoi$ = this.metadata$.pipe(map$1((record) => {
|
|
39568
|
+
if (!record?.resourceIdentifiers?.length)
|
|
39569
|
+
return null;
|
|
39570
|
+
const doiIdentifier = record.resourceIdentifiers.find((id) => id.codeSpace?.toLowerCase().includes('doi.org') ||
|
|
39571
|
+
id.code.startsWith('10.'));
|
|
39572
|
+
if (!doiIdentifier)
|
|
39573
|
+
return null;
|
|
39574
|
+
return {
|
|
39575
|
+
code: doiIdentifier.code,
|
|
39576
|
+
url: doiIdentifier.url ? doiIdentifier.url : null,
|
|
39577
|
+
};
|
|
39578
|
+
}), shareReplay$1(1));
|
|
39326
39579
|
this.apiLinks$ = this.allLinks$.pipe(map$1((links) => links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.API))), shareReplay$1(1));
|
|
39327
39580
|
this.mapApiLinks$ = this.allLinks$.pipe(map$1((links) => links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.MAP_API))), shareReplay$1(1));
|
|
39581
|
+
this.stacLinks$ = this.allLinks$.pipe(map$1((links) => links.filter((link) => link.type === 'service' && link.accessServiceProtocol === 'stac')), shareReplay$1(1));
|
|
39328
39582
|
this.downloadLinks$ = this.allLinks$.pipe(map$1((links) => links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.DOWNLOAD))));
|
|
39329
39583
|
this.dataLinks$ = this.allLinks$.pipe(map$1((links) => links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.DATA))));
|
|
39330
39584
|
this.geoDataLinks$ = this.allLinks$.pipe(map$1((links) => links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.GEODATA))));
|
|
@@ -39482,8 +39736,9 @@ class DataViewPermalinkComponent {
|
|
|
39482
39736
|
set viewType(value) {
|
|
39483
39737
|
this.viewType$.next(value);
|
|
39484
39738
|
}
|
|
39485
|
-
constructor(config, wcEmbedderBaseUrl, facade) {
|
|
39739
|
+
constructor(config, proxyPath, wcEmbedderBaseUrl, facade) {
|
|
39486
39740
|
this.config = config;
|
|
39741
|
+
this.proxyPath = proxyPath;
|
|
39487
39742
|
this.wcEmbedderBaseUrl = wcEmbedderBaseUrl;
|
|
39488
39743
|
this.facade = facade;
|
|
39489
39744
|
this.viewType$ = new BehaviorSubject('map');
|
|
@@ -39516,6 +39771,9 @@ class DataViewPermalinkComponent {
|
|
|
39516
39771
|
url.searchParams.append('e', `gn-dataset-view-map`);
|
|
39517
39772
|
}
|
|
39518
39773
|
url.searchParams.append('a', `api-url=${this.config.basePath}`);
|
|
39774
|
+
if (this.proxyPath) {
|
|
39775
|
+
url.searchParams.append('a', `proxy-path=${this.proxyPath}`);
|
|
39776
|
+
}
|
|
39519
39777
|
url.searchParams.append('a', `dataset-id=${metadata.uniqueIdentifier}`);
|
|
39520
39778
|
url.searchParams.append('a', `primary-color=#0f4395`);
|
|
39521
39779
|
url.searchParams.append('a', `secondary-color=#8bc832`);
|
|
@@ -39524,7 +39782,7 @@ class DataViewPermalinkComponent {
|
|
|
39524
39782
|
return url.toString();
|
|
39525
39783
|
}));
|
|
39526
39784
|
}
|
|
39527
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataViewPermalinkComponent, deps: [{ token: Configuration }, { token: WEB_COMPONENT_EMBEDDER_URL, optional: true }, { token: MdViewFacade }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39785
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataViewPermalinkComponent, deps: [{ token: Configuration }, { token: PROXY_PATH, optional: true }, { token: WEB_COMPONENT_EMBEDDER_URL, optional: true }, { token: MdViewFacade }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39528
39786
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DataViewPermalinkComponent, isStandalone: true, selector: "gn-ui-data-view-permalink", inputs: { viewType: "viewType" }, ngImport: i0, template: "<gn-ui-copy-text-button\n *ngIf=\"wcEmbedderBaseUrl\"\n [text]=\"permalinkUrl$ | async\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n></gn-ui-copy-text-button>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1$2.AsyncPipe, name: "async" }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
39529
39787
|
}
|
|
39530
39788
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataViewPermalinkComponent, decorators: [{
|
|
@@ -39535,6 +39793,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
39535
39793
|
args: [Configuration]
|
|
39536
39794
|
}] }, { type: undefined, decorators: [{
|
|
39537
39795
|
type: Optional
|
|
39796
|
+
}, {
|
|
39797
|
+
type: Inject,
|
|
39798
|
+
args: [PROXY_PATH]
|
|
39799
|
+
}] }, { type: undefined, decorators: [{
|
|
39800
|
+
type: Optional
|
|
39538
39801
|
}, {
|
|
39539
39802
|
type: Inject,
|
|
39540
39803
|
args: [WEB_COMPONENT_EMBEDDER_URL]
|
|
@@ -39643,8 +39906,9 @@ class DataViewWebComponentComponent {
|
|
|
39643
39906
|
set viewType(value) {
|
|
39644
39907
|
this.viewType$.next(value);
|
|
39645
39908
|
}
|
|
39646
|
-
constructor(config, facade) {
|
|
39909
|
+
constructor(config, proxyPath, facade) {
|
|
39647
39910
|
this.config = config;
|
|
39911
|
+
this.proxyPath = proxyPath;
|
|
39648
39912
|
this.facade = facade;
|
|
39649
39913
|
this.viewType$ = new BehaviorSubject('map');
|
|
39650
39914
|
this.webComponentHtml$ = combineLatest(this.viewType$, this.facade.chartConfig$, this.facade.metadata$).pipe(map$2(([viewType, config, metadata]) => {
|
|
@@ -39653,7 +39917,10 @@ class DataViewWebComponentComponent {
|
|
|
39653
39917
|
const { aggregation, xProperty, yProperty, chartType } = config;
|
|
39654
39918
|
return `<script src="https://cdn.jsdelivr.net/gh/geonetwork/geonetwork-ui@wc-dist-${GEONETWORK_UI_TAG_NAME}/gn-wc.js"></script>
|
|
39655
39919
|
<gn-dataset-view-chart
|
|
39656
|
-
api-url="${new URL(this.config.basePath, window.location.origin).toString()}"
|
|
39920
|
+
api-url="${new URL(this.config.basePath, window.location.origin).toString()}"${this.proxyPath
|
|
39921
|
+
? `
|
|
39922
|
+
proxy-path="${this.proxyPath}"`
|
|
39923
|
+
: ''}
|
|
39657
39924
|
dataset-id="${metadata.uniqueIdentifier}"
|
|
39658
39925
|
aggregation="${aggregation}"
|
|
39659
39926
|
x-property="${xProperty}"
|
|
@@ -39672,7 +39939,10 @@ class DataViewWebComponentComponent {
|
|
|
39672
39939
|
else if (viewType === 'table') {
|
|
39673
39940
|
return `<script src="https://cdn.jsdelivr.net/gh/geonetwork/geonetwork-ui@wc-dist-${GEONETWORK_UI_TAG_NAME}/gn-wc.js"></script>
|
|
39674
39941
|
<gn-dataset-view-table
|
|
39675
|
-
api-url="${new URL(this.config.basePath, window.location.origin).toString()}"
|
|
39942
|
+
api-url="${new URL(this.config.basePath, window.location.origin).toString()}"${this.proxyPath
|
|
39943
|
+
? `
|
|
39944
|
+
proxy-path="${this.proxyPath}"`
|
|
39945
|
+
: ''}
|
|
39676
39946
|
dataset-id="${metadata.uniqueIdentifier}"
|
|
39677
39947
|
primary-color="#0f4395"
|
|
39678
39948
|
secondary-color="#8bc832"
|
|
@@ -39685,7 +39955,10 @@ class DataViewWebComponentComponent {
|
|
|
39685
39955
|
else {
|
|
39686
39956
|
return `<script src="https://cdn.jsdelivr.net/gh/geonetwork/geonetwork-ui@wc-dist-${GEONETWORK_UI_TAG_NAME}/gn-wc.js"></script>
|
|
39687
39957
|
<gn-dataset-view-map
|
|
39688
|
-
api-url="${new URL(this.config.basePath, window.location.origin).toString()}"
|
|
39958
|
+
api-url="${new URL(this.config.basePath, window.location.origin).toString()}"${this.proxyPath
|
|
39959
|
+
? `
|
|
39960
|
+
proxy-path="${this.proxyPath}"`
|
|
39961
|
+
: ''}
|
|
39689
39962
|
dataset-id="${metadata.uniqueIdentifier}"
|
|
39690
39963
|
primary-color="#0f4395"
|
|
39691
39964
|
secondary-color="#8bc832"
|
|
@@ -39697,7 +39970,7 @@ class DataViewWebComponentComponent {
|
|
|
39697
39970
|
}
|
|
39698
39971
|
}));
|
|
39699
39972
|
}
|
|
39700
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataViewWebComponentComponent, deps: [{ token: Configuration }, { token: MdViewFacade }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39973
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataViewWebComponentComponent, deps: [{ token: Configuration }, { token: PROXY_PATH, optional: true }, { token: MdViewFacade }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39701
39974
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DataViewWebComponentComponent, isStandalone: true, selector: "gn-ui-data-view-web-component", inputs: { viewType: "viewType" }, ngImport: i0, template: "<gn-ui-copy-text-button\n [text]=\"webComponentHtml$ | async\"\n [rows]=\"3\"\n [tooltipText]=\"'tooltip.html.copy' | translate\"\n></gn-ui-copy-text-button>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1$2.AsyncPipe, name: "async" }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
39702
39975
|
}
|
|
39703
39976
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataViewWebComponentComponent, decorators: [{
|
|
@@ -39706,6 +39979,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
39706
39979
|
}], ctorParameters: () => [{ type: Configuration, decorators: [{
|
|
39707
39980
|
type: Inject,
|
|
39708
39981
|
args: [Configuration]
|
|
39982
|
+
}] }, { type: undefined, decorators: [{
|
|
39983
|
+
type: Optional
|
|
39984
|
+
}, {
|
|
39985
|
+
type: Inject,
|
|
39986
|
+
args: [PROXY_PATH]
|
|
39709
39987
|
}] }, { type: MdViewFacade }], propDecorators: { viewType: [{
|
|
39710
39988
|
type: Input
|
|
39711
39989
|
}] } });
|
|
@@ -40826,7 +41104,7 @@ const RECORD_RESOURCE_CREATED_FIELD = {
|
|
|
40826
41104
|
gridColumnSpan: 1,
|
|
40827
41105
|
};
|
|
40828
41106
|
const RESOURCE_IDENTIFIER_FIELD = {
|
|
40829
|
-
model: '
|
|
41107
|
+
model: 'resourceIdentifiers',
|
|
40830
41108
|
formFieldConfig: {
|
|
40831
41109
|
labelKey: marker('editor.record.form.field.resourceIdentifier'),
|
|
40832
41110
|
},
|
|
@@ -43340,8 +43618,28 @@ class FormFieldComponent {
|
|
|
43340
43618
|
get valueAsOnlineResources() {
|
|
43341
43619
|
return this.value;
|
|
43342
43620
|
}
|
|
43621
|
+
get valueAsResourceIdentifierCode() {
|
|
43622
|
+
const identifiers = this.value;
|
|
43623
|
+
return identifiers?.[0]?.code || '';
|
|
43624
|
+
}
|
|
43625
|
+
handleResourceIdentifierChange(code) {
|
|
43626
|
+
const identifiers = this.value;
|
|
43627
|
+
if (!code) {
|
|
43628
|
+
this.valueChange.emit(identifiers?.slice(1) || []);
|
|
43629
|
+
return;
|
|
43630
|
+
}
|
|
43631
|
+
if (identifiers?.[0]) {
|
|
43632
|
+
this.valueChange.emit([
|
|
43633
|
+
{ ...identifiers[0], code },
|
|
43634
|
+
...identifiers.slice(1),
|
|
43635
|
+
]);
|
|
43636
|
+
}
|
|
43637
|
+
else {
|
|
43638
|
+
this.valueChange.emit([{ code }]);
|
|
43639
|
+
}
|
|
43640
|
+
}
|
|
43343
43641
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
43344
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormFieldComponent, isStandalone: true, selector: "gn-ui-form-field", inputs: { uniqueIdentifier: "uniqueIdentifier", model: "model", modelSpecifier: "modelSpecifier", componentName: "componentName", config: "config", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "titleInput", first: true, predicate: ["titleInput"], descendants: true }], ngImport: i0, template: "<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"toggleIsOpenData($event)\"\n ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <textarea\n #titleInput\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal overflow-hidden text-black/80\"\n (change)=\"valueChange.emit($event.target.value)\"\n [placeholder]=\"\n 'editor.record.form.field.title.placeholder' | translate\n \"\n >{{ valueAsString }}</textarea\n >\n <div class=\"flex flex-row justify-between self-start mt-0.5\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n *ngIf=\"config.hintKey\"\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceIdentifier'\">\n <gn-ui-form-field-simple\n [type]=\"'text'\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceCreated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'topics'\">\n <gn-ui-form-field-topics\n [value]=\"valueAsTopics\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-topics>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [recordLicences]=\"valueAsConstraints\"\n (recordLicencesChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'legalConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'securityConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'otherConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n ></ng-container>\n <ng-template #formFieldConstraints>\n <gn-ui-form-field-constraints\n [label]=\"config.labelKey\"\n [value]=\"valueAsConstraints\"\n [constraintType]=\"model\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-constraints\n ></ng-template>\n\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!model\">\n <ng-container [ngSwitch]=\"componentName\">\n <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n </ng-container>\n </ng-container>\n </ng-container>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1$2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1$2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2$2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: FormFieldWrapperComponent, selector: "gn-ui-form-field-wrapper", inputs: ["label", "hint"] }, { kind: "component", type: FormFieldLicenseComponent, selector: "gn-ui-form-field-license", inputs: ["label", "recordLicences"], outputs: ["recordLicencesChange"] }, { kind: "component", type: FormFieldDateComponent, selector: "gn-ui-form-field-date", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldUpdateFrequencyComponent, selector: "gn-ui-form-field-update-frequency", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldTemporalExtentsComponent, selector: "gn-ui-form-field-temporal-extents", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSimpleComponent, selector: "gn-ui-form-field-simple", inputs: ["type", "readonly", "invalid", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldRichComponent, selector: "gn-ui-form-field-rich", inputs: ["label", "hint", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSpatialExtentComponent, selector: "gn-ui-form-field-spatial-extent" }, { kind: "component", type: FormFieldKeywordsComponent, selector: "gn-ui-form-field-keywords", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOverviewsComponent, selector: "gn-ui-form-field-overviews", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsForResourceComponent, selector: "gn-ui-form-field-contacts-for-resource", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineResourcesComponent, selector: "gn-ui-form-field-online-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineLinkResourcesComponent, selector: "gn-ui-form-field-online-link-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsComponent, selector: "gn-ui-form-field-contacts", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldConstraintsComponent, selector: "gn-ui-form-field-constraints", inputs: ["label", "value", "constraintType"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldConstraintsShortcutsComponent, selector: "gn-ui-form-field-constraints-shortcuts" }, { kind: "component", type: FormFieldSpatialToggleComponent, selector: "gn-ui-form-field-spatial-toggle" }, { kind: "component", type: FormFieldTopicsComponent, selector: "gn-ui-form-field-topics", inputs: ["value"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TextFieldModule }, { kind: "directive", type: i3$1.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
43642
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormFieldComponent, isStandalone: true, selector: "gn-ui-form-field", inputs: { uniqueIdentifier: "uniqueIdentifier", model: "model", modelSpecifier: "modelSpecifier", componentName: "componentName", config: "config", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "titleInput", first: true, predicate: ["titleInput"], descendants: true }], ngImport: i0, template: "<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"toggleIsOpenData($event)\"\n ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <textarea\n #titleInput\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal overflow-hidden text-black/80\"\n (change)=\"valueChange.emit($event.target.value)\"\n [placeholder]=\"\n 'editor.record.form.field.title.placeholder' | translate\n \"\n >{{ valueAsString }}</textarea\n >\n <div class=\"flex flex-row justify-between self-start mt-0.5\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n *ngIf=\"config.hintKey\"\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceIdentifiers'\">\n <gn-ui-form-field-simple\n [type]=\"'text'\"\n [value]=\"valueAsResourceIdentifierCode\"\n (valueChange)=\"handleResourceIdentifierChange($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceCreated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'topics'\">\n <gn-ui-form-field-topics\n [value]=\"valueAsTopics\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-topics>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [recordLicences]=\"valueAsConstraints\"\n (recordLicencesChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'legalConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'securityConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'otherConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n ></ng-container>\n <ng-template #formFieldConstraints>\n <gn-ui-form-field-constraints\n [label]=\"config.labelKey\"\n [value]=\"valueAsConstraints\"\n [constraintType]=\"model\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-constraints\n ></ng-template>\n\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!model\">\n <ng-container [ngSwitch]=\"componentName\">\n <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n </ng-container>\n </ng-container>\n </ng-container>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1$2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1$2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2$2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: FormFieldWrapperComponent, selector: "gn-ui-form-field-wrapper", inputs: ["label", "hint"] }, { kind: "component", type: FormFieldLicenseComponent, selector: "gn-ui-form-field-license", inputs: ["label", "recordLicences"], outputs: ["recordLicencesChange"] }, { kind: "component", type: FormFieldDateComponent, selector: "gn-ui-form-field-date", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldUpdateFrequencyComponent, selector: "gn-ui-form-field-update-frequency", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldTemporalExtentsComponent, selector: "gn-ui-form-field-temporal-extents", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSimpleComponent, selector: "gn-ui-form-field-simple", inputs: ["type", "readonly", "invalid", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldRichComponent, selector: "gn-ui-form-field-rich", inputs: ["label", "hint", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSpatialExtentComponent, selector: "gn-ui-form-field-spatial-extent" }, { kind: "component", type: FormFieldKeywordsComponent, selector: "gn-ui-form-field-keywords", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOverviewsComponent, selector: "gn-ui-form-field-overviews", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsForResourceComponent, selector: "gn-ui-form-field-contacts-for-resource", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineResourcesComponent, selector: "gn-ui-form-field-online-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineLinkResourcesComponent, selector: "gn-ui-form-field-online-link-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsComponent, selector: "gn-ui-form-field-contacts", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldConstraintsComponent, selector: "gn-ui-form-field-constraints", inputs: ["label", "value", "constraintType"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldConstraintsShortcutsComponent, selector: "gn-ui-form-field-constraints-shortcuts" }, { kind: "component", type: FormFieldSpatialToggleComponent, selector: "gn-ui-form-field-spatial-toggle" }, { kind: "component", type: FormFieldTopicsComponent, selector: "gn-ui-form-field-topics", inputs: ["value"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TextFieldModule }, { kind: "directive", type: i3$1.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
43345
43643
|
}
|
|
43346
43644
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldComponent, decorators: [{
|
|
43347
43645
|
type: Component,
|
|
@@ -43368,7 +43666,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
43368
43666
|
FormFieldSpatialToggleComponent,
|
|
43369
43667
|
FormFieldTopicsComponent,
|
|
43370
43668
|
TextFieldModule,
|
|
43371
|
-
], template: "<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"toggleIsOpenData($event)\"\n ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <textarea\n #titleInput\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal overflow-hidden text-black/80\"\n (change)=\"valueChange.emit($event.target.value)\"\n [placeholder]=\"\n 'editor.record.form.field.title.placeholder' | translate\n \"\n >{{ valueAsString }}</textarea\n >\n <div class=\"flex flex-row justify-between self-start mt-0.5\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n *ngIf=\"config.hintKey\"\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'
|
|
43669
|
+
], template: "<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"toggleIsOpenData($event)\"\n ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <textarea\n #titleInput\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal overflow-hidden text-black/80\"\n (change)=\"valueChange.emit($event.target.value)\"\n [placeholder]=\"\n 'editor.record.form.field.title.placeholder' | translate\n \"\n >{{ valueAsString }}</textarea\n >\n <div class=\"flex flex-row justify-between self-start mt-0.5\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n *ngIf=\"config.hintKey\"\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceIdentifiers'\">\n <gn-ui-form-field-simple\n [type]=\"'text'\"\n [value]=\"valueAsResourceIdentifierCode\"\n (valueChange)=\"handleResourceIdentifierChange($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceCreated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'topics'\">\n <gn-ui-form-field-topics\n [value]=\"valueAsTopics\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-topics>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [recordLicences]=\"valueAsConstraints\"\n (recordLicencesChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'legalConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'securityConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'otherConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n ></ng-container>\n <ng-template #formFieldConstraints>\n <gn-ui-form-field-constraints\n [label]=\"config.labelKey\"\n [value]=\"valueAsConstraints\"\n [constraintType]=\"model\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-constraints\n ></ng-template>\n\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!model\">\n <ng-container [ngSwitch]=\"componentName\">\n <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n </ng-container>\n </ng-container>\n </ng-container>\n</ng-template>\n" }]
|
|
43372
43670
|
}], propDecorators: { uniqueIdentifier: [{
|
|
43373
43671
|
type: Input
|
|
43374
43672
|
}], model: [{
|
|
@@ -43793,6 +44091,9 @@ class RouterService {
|
|
|
43793
44091
|
getOrganizationPageRoute() {
|
|
43794
44092
|
return ROUTER_ROUTE_ORGANIZATION;
|
|
43795
44093
|
}
|
|
44094
|
+
getDefaultSort() {
|
|
44095
|
+
return SortByEnum.RESOURCE_DATES;
|
|
44096
|
+
}
|
|
43796
44097
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RouterService, deps: [{ token: ROUTER_CONFIG }, { token: i1$d.Router }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
43797
44098
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RouterService, providedIn: 'root' }); }
|
|
43798
44099
|
}
|
|
@@ -43953,13 +44254,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
43953
44254
|
}], ctorParameters: () => [{ type: i1$3.Store }, { type: RouterService }] });
|
|
43954
44255
|
|
|
43955
44256
|
class RouterEffects {
|
|
43956
|
-
constructor(_actions$, _router, _location, facade, routerConfig, fieldsService) {
|
|
44257
|
+
constructor(_actions$, _router, _location, facade, routerConfig, fieldsService, routerService) {
|
|
43957
44258
|
this._actions$ = _actions$;
|
|
43958
44259
|
this._router = _router;
|
|
43959
44260
|
this._location = _location;
|
|
43960
44261
|
this.facade = facade;
|
|
43961
44262
|
this.routerConfig = routerConfig;
|
|
43962
44263
|
this.fieldsService = fieldsService;
|
|
44264
|
+
this.routerService = routerService;
|
|
43963
44265
|
this.navigate$ = createEffect(() => this._actions$.pipe(ofType(goAction), tap$1(({ path, query: queryParams, queryParamsHandling }) => {
|
|
43964
44266
|
this._router.navigate([path], {
|
|
43965
44267
|
queryParams,
|
|
@@ -43971,14 +44273,14 @@ class RouterEffects {
|
|
|
43971
44273
|
.pipe(map$1((filters) => [searchParams, filters]))), startWith([null, {}]), pairwise(), map$1(([[oldParams, oldFilters], [newParams, newFilters]]) => {
|
|
43972
44274
|
let sortBy = ROUTE_PARAMS.SORT in newParams
|
|
43973
44275
|
? sortByFromString(newParams[ROUTE_PARAMS.SORT])
|
|
43974
|
-
:
|
|
44276
|
+
: this.routerService.getDefaultSort();
|
|
43975
44277
|
let pageNumber = ROUTE_PARAMS.PAGE in newParams
|
|
43976
44278
|
? parseInt(newParams[ROUTE_PARAMS.PAGE])
|
|
43977
44279
|
: 1;
|
|
43978
44280
|
if (oldParams !== null) {
|
|
43979
44281
|
const oldSort = ROUTE_PARAMS.SORT in oldParams
|
|
43980
44282
|
? sortByFromString(oldParams[ROUTE_PARAMS.SORT])
|
|
43981
|
-
:
|
|
44283
|
+
: this.routerService.getDefaultSort();
|
|
43982
44284
|
if (JSON.stringify(sortBy) === JSON.stringify(oldSort)) {
|
|
43983
44285
|
sortBy = null;
|
|
43984
44286
|
}
|
|
@@ -44035,7 +44337,7 @@ class RouterEffects {
|
|
|
44035
44337
|
this.navigateBack$ = createEffect(() => this._actions$.pipe(ofType(backAction), tap$1(() => this._location.back())), { dispatch: false });
|
|
44036
44338
|
this.navigateForward$ = createEffect(() => this._actions$.pipe(ofType(forwardAction), tap$1(() => this._location.forward())), { dispatch: false });
|
|
44037
44339
|
}
|
|
44038
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RouterEffects, deps: [{ token: i1$c.Actions }, { token: i1$d.Router }, { token: i1$2.Location }, { token: RouterFacade }, { token: ROUTER_CONFIG }, { token: FieldsService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
44340
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RouterEffects, deps: [{ token: i1$c.Actions }, { token: i1$d.Router }, { token: i1$2.Location }, { token: RouterFacade }, { token: ROUTER_CONFIG }, { token: FieldsService }, { token: RouterService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
44039
44341
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RouterEffects }); }
|
|
44040
44342
|
}
|
|
44041
44343
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RouterEffects, decorators: [{
|
|
@@ -44043,7 +44345,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
44043
44345
|
}], ctorParameters: () => [{ type: i1$c.Actions }, { type: i1$d.Router }, { type: i1$2.Location }, { type: RouterFacade }, { type: undefined, decorators: [{
|
|
44044
44346
|
type: Inject,
|
|
44045
44347
|
args: [ROUTER_CONFIG]
|
|
44046
|
-
}] }, { type: FieldsService }] });
|
|
44348
|
+
}] }, { type: FieldsService }, { type: RouterService }] });
|
|
44047
44349
|
|
|
44048
44350
|
class DefaultRouterModule {
|
|
44049
44351
|
constructor(routerService) {
|
|
@@ -44181,5 +44483,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
44181
44483
|
* Generated bundle index. Do not edit.
|
|
44182
44484
|
*/
|
|
44183
44485
|
|
|
44184
|
-
export { ADD_RESULTS, ADD_SEARCH, AbstractAction, AbstractSearchField, ActionMenuComponent, AddLayerFromCatalogComponent, AddLayerRecordPreviewComponent, AddResults, AddSearch, AnchorLinkDirective, ApiCardComponent, ApplicationBannerComponent, AuthService, AutocompleteComponent, AvailableServicesField, AvatarComponent, AvatarServiceInterface, BASEMAP_LAYERS, BadgeComponent, BaseConverter, BaseFileReader, BaseReader, BlockListComponent, ButtonComponent, CLEAR_ERROR, CLEAR_RESULTS, CarouselComponent, CatalogTitleComponent, CellPopinComponent, ChartComponent, ChartViewComponent, CheckToggleComponent, CheckboxComponent, ClearError, ClearResults, ColorScaleComponent, ConfirmationDialogComponent, ContentGhostComponent, CopyTextButtonComponent, DEFAULT_GN4_LOGIN_URL, DEFAULT_GN4_LOGOUT_URL, DEFAULT_GN4_SETTINGS_URL, DEFAULT_LANG, DEFAULT_PAGE_SIZE, DEFAULT_RESULTS_LAYOUT_CONFIG, DEFAULT_SEARCH_KEY, DISABLE_AUTH, DO_NOT_USE_DEFAULT_BASEMAP, DataService, DataTableComponent, DataViewComponent, DataViewPermalinkComponent, DataViewShareComponent, DataViewWebComponentComponent, DatePickerComponent, DateRangeDropdownComponent, DateRangePickerComponent, DateRangeSearchField, DateService, DcatApConverter, DefaultRouterModule, DownloadItemComponent, DownloadsListComponent, DragAndDropFileInputComponent, DropdownMultiselectComponent, DropdownSelectorComponent, EDITOR_FEATURE_KEY, ES_QUERY_FIELDS_PRIORITY, ES_RESOURCES_VALUES, ES_SOURCE_SUMMARY, EXTERNAL_VIEWER_OPEN_NEW_TAB, EXTERNAL_VIEWER_URL_TEMPLATE, EditableLabelDirective, EditorFacade, EditorService, ElasticsearchService, EmbeddedTranslateLoader, ErrorComponent, ErrorType, ExpandablePanelButtonComponent, ExpandablePanelComponent, ExternalLinkCardComponent, ExternalViewerButtonComponent, FIELDS_BRIEF, FIELDS_SUMMARY, FILTER_GEOMETRY, FILTER_SUMMARY_IGNORE_LIST, FORMATS, FacetBlockComponent, FacetItemComponent, FacetListComponent, FacetsContainerComponent, FavoriteStarComponent, FavoritesService, FeatureCatalogListComponent, FeatureDetailComponent, FeatureEditorModule, FeatureMapModule, FeatureRecordModule, FeatureSearchModule, FetchError, FieldsService, FigureComponent, FigureContainerComponent, FileInputComponent, FileTranslateLoader, FilesDropDirective, FilterDropdownComponent, FormFieldArrayComponent, FormFieldComponent, FormFieldDateComponent, FormFieldFileComponent, FormFieldKeywordsComponent, FormFieldLicenseComponent, FormFieldObjectComponent, FormFieldRichComponent, FormFieldSimpleComponent, FormFieldSpatialExtentComponent, FormFieldTemporalExtentsComponent, FormFieldTopicsComponent, FormFieldWrapperComponent, FullTextSearchField, FuzzySearchComponent, GEONETWORK_UI_TAG_NAME, GEONETWORK_UI_VERSION, GeoDataBadgeComponent, GeoTableViewComponent, GeocodingComponent, GeojsonReader, Gn4Converter, Gn4PlatformMapper, Gn4PlatformService, Gn4Repository, Gn4SettingsService, GpfApiDlComponent, GravatarService, HttpLoaderFactory, I18nInterceptor, ImageFallbackDirective, ImageInputComponent, ImageOverlayPreviewComponent, ImportRecordComponent, InlineFilterComponent, InteractiveTableColumnComponent, InteractiveTableComponent, InternalLinkCardComponent, IsSpatialSearchField, Iso191153Converter, Iso19139Converter, KindBadgeComponent, LANGUAGES_LIST, LANGUAGE_NAMES, LANGUAGE_STORAGE_KEY, LANG_2_TO_3_MAPPER, LOGIN_URL, LOGOUT_URL, LONLAT_CRS_CODES, LanguageSwitcherComponent, LayersPanelComponent, LicenseSearchField, LinkClassifierService, LinkUsage, LoadingMaskComponent, LogService, MAP_FEATURE_KEY, MAP_VIEW_CONSTRAINTS, METADATA_LANGUAGE, MapContainerComponent, MapFacade, MapLegendComponent, MapStateContainerComponent, MapStyleService, MapUtilsService, MapViewComponent, MarkdownEditorComponent, MarkdownParserComponent, MaxLinesComponent, mdview_actions as MdViewActions, MdViewFacade, MetadataCatalogComponent, MetadataContactComponent, MetadataInfoComponent, MetadataLinkType, MetadataMapperContext, MetadataQualityComponent, MetadataQualityItemComponent, MetadataQualityPanelComponent, ModalDialogComponent, MultilingualPanelComponent, MultilingualSearchField, MyOrgService, NAMESPACES, NOT_APPLICABLE_CONSTRAINT, NOT_KNOWN_CONSTRAINT, NotificationComponent, NotificationsContainerComponent, NotificationsService, ORGANIZATIONS_STRATEGY, ORGANIZATION_PAGE_URL_TOKEN, ORGANIZATION_URL_TOKEN, OrganisationPreviewComponent, OrganisationsComponent, OrganisationsFilterComponent, OrganisationsResultComponent, OrganizationSearchField, OrganizationsFromGroupsService, OrganizationsFromMetadataService, OwnerSearchField, PAGINATE, PARSE_DELIMITER, PATCH_RESULTS_AGGREGATIONS, PROXY_PATH, Paginate, PaginationButtonsComponent, PaginationComponent, PaginationDotsComponent, PatchResultsAggregations, PopoverComponent, PopupAlertComponent, PossibleResourceTypes, PossibleResourceTypesDefinition, PreviousNextButtonsComponent, ProgressBarComponent, ProxyService, QUERY_FIELDS, RECORD_DATASET_URL_TOKEN, RECORD_REUSE_URL_TOKEN, RECORD_SERVICE_URL_TOKEN, REQUEST_MORE_ON_AGGREGATION, REQUEST_MORE_RESULTS, REQUEST_NEW_RESULTS, RESULTS_LAYOUT_CONFIG, ROUTER_CONFIG, ROUTER_ROUTE_DATASET, ROUTER_ROUTE_ORGANIZATION, ROUTER_ROUTE_REUSE, ROUTER_ROUTE_SEARCH, ROUTER_ROUTE_SERVICE, ROUTER_STATE_KEY, ROUTE_PARAMS, RecordApiFormComponent, RecordFormComponent, RecordKindField, RecordMetaComponent, RecordMetricComponent, RecordPreviewCardComponent, RecordPreviewComponent, RecordPreviewFeedComponent, RecordPreviewListComponent, RecordPreviewRowComponent, RecordPreviewTextComponent, RecordPreviewTitleComponent, RecordsMetricsComponent, RecordsService, RequestMoreOnAggregation, RequestMoreResults, RequestNewResults, ResourceTypeLegacyField, ResultsHitsContainerComponent, ResultsHitsNumberComponent, ResultsHitsSearchKindComponent, ResultsLayoutComponent, ResultsLayoutConfigItem, ResultsListComponent, ResultsListContainerComponent, ResultsListItemComponent, ResultsTableComponent, ResultsTableContainerComponent, RouterEffects, RouterFacade, RouterService, SEARCH_FEATURE_KEY, SETTINGS_URL, SET_CONFIG_AGGREGATIONS, SET_CONFIG_FILTERS, SET_CONFIG_REQUEST_FIELDS, SET_ERROR, SET_FAVORITES_ONLY, SET_FILTERS, SET_INCLUDE_ON_AGGREGATION, SET_PAGE_SIZE, SET_RESULTS_AGGREGATIONS, SET_RESULTS_HITS, SET_RESULTS_LAYOUT, SET_SEARCH, SET_SORT_BY, SET_SPATIAL_FILTER_ENABLED, SearchEffects, SearchFacade, SearchFeatureCatalogComponent, SearchFiltersSummaryComponent, SearchFiltersSummaryItemComponent, SearchInputComponent, SearchRouterContainerDirective, SearchService, SearchStateContainerDirective, SelectionService, ServiceCapabilitiesComponent, SetConfigAggregations, SetConfigFilters, SetConfigRequestFields, SetError, SetFavoritesOnly, SetFilters, SetIncludeOnAggregation, SetPageSize, SetResultsAggregations, SetResultsHits, SetResultsLayout, SetSearch, SetSortBy, SetSpatialFilterEnabled, SimpleSearchField, SiteTitleComponent, SortByComponent, SortableListComponent, SourceLabelComponent, SourcesService, SpatialExtentComponent, SpinningLoaderComponent, StarToggleComponent, StickyHeaderComponent, SupportedTypes, SwitchToggleComponent, THUMBNAIL_PLACEHOLDER, TRANSLATE_DEBUG_CONFIG, TRANSLATE_DEFAULT_CONFIG, TRANSLATE_WITH_OVERRIDES_CONFIG, TableViewComponent, TextAreaComponent, TextInputComponent, ThemeService, ThumbnailComponent, TranslatedSearchField, TruncatedTextComponent, UPDATE_CONFIG_AGGREGATIONS, UPDATE_FILTERS, UPDATE_REQUEST_AGGREGATION_TERM, UpdateConfigAggregations, UpdateFilters, UrlInputComponent, UserFeedbackItemComponent, UserPreviewComponent, UserSearchField, VECTOR_STYLE_DEFAULT, ViewportIntersectorComponent, WEB_COMPONENT_EMBEDDER_URL, XmlParseError, _reset, allChildrenElement, appConfigWithTranslationFixture, appendChildTree, appendChildren, assertValidXml, blockModelFixture, bytesToMegabytes, canEditRecord, checkFileFormat, clearSelectedFeatures, createChild, createDocument, createElement, createFuzzyFilter, createNestedChild, createNestedElement, currentPage, defaultMapStyleFixture, defaultMapStyleHlFixture, downgradeImage, downsizeImage, draftSaveSuccess, dragPanCondition, dropEmptyTranslations, editorReducer, emptyBlockModelFixture, findChildElement, findChildOrCreate, findChildrenElement, findConverterForDocument, findNestedChildOrCreate, findNestedElement, findNestedElements, findParent, firstChildElement, formatDate, formatUserInfo, getAllKeysValidator, getArrayItem, getAsArray, getAsUrl, getBadgeColor, getCustomTranslations, getError, getFavoritesOnly, getFileFormat, getFileFormatFromServiceOutput, getFirstValue, getFormatPriority, getGeometryBoundingBox, getGeometryFromGeoJSON, getGlobalConfig, getIsMobile, getJsonDataItemsProxy, getLayers, getLinkId, getLinkLabel, getLinkPriority, getMapContext, getMapContextLayerFromConfig, getMapState, getMetadataQualityConfig, getMimeTypeForFormat, getNamespace, getOptionalMapConfig, getOptionalSearchConfig, getPageSize, getQualityValidators, getResourceType, getReuseType, getRootElement, getSearchConfigAggregations, getSearchFilters, getSearchResults, getSearchResultsAggregations, getSearchResultsHits, getSearchResultsLayout, getSearchResultsLoading, getSearchSortBy, getSearchState, getSearchStateSearch, getSelectedFeatures, getSpatialFilterEnabled, getTemporalRangeUnion, getThemeConfig, handleScrollOnNavigation, hasRecordChangedSinceDraft, hasRecordChangedSinceDraftSuccess, initSearch, initialEditorState, initialMapState, initialState, isConfigLoaded, isDateRange, isFormatInQueryParam, isPublished, itemModelFixture, kindToCodeListValue, loadAppConfig, malformedConfigFixture, mapConfigFixture, mapContact, mapKeywords, mapLogo, mapOrganization, mapReducer, markRecordAsChanged, matchesNoApplicableConstraint, matchesNoKnownConstraint, megabytesToBytes, mimeTypeToFormat, minimalAppConfigFixture, missingMandatoryConfigFixture, mouseWheelZoomCondition, noDuplicateFileName, okAppConfigFixture, openDataset, openRecord, organizationsServiceFactory, parse, parseXmlString, placeholder, prioritizePageScroll, propagateToDocumentOnly, provideGn4, provideI18n, provideRepositoryUrl, readAttribute, readDataset, readDatasetHeaders, readText, reducer$2 as reducer, reducerSearch, removeAllChildren, removeChildren, removeChildrenByName, removeSearchParams, removeWhitespace, renameElements, saveRecord, saveRecordFailure, saveRecordSuccess, selectCanEditRecord, selectCurrentPage, selectEditorConfig, selectEditorState, selectFallback, selectFallbackFields, selectField, selectHasRecordChanged, selectIsPublished, selectRecord, selectRecordChangedSinceSave, selectRecordSaveError, selectRecordSaving, selectRecordSections, selectRecordSource, selectTranslatedField, selectTranslatedValue, setContext, setCurrentPage, setFieldVisibility, setSelectedFeatures, setTextContent, someHabTableItemFixture, sortByFromString, sortByToString, sortByToStrings, stripHtml, stripNamespace, tableItemsFixture, toDate, toLang2, toLang3, totalPages, undoRecordDraft, unrecognizedKeysConfigFixture, updateLanguages, updateRecordField, updateRecordLanguages, wmsLayerFlatten, writeAttribute, wrongLanguageCodeConfigFixture, xmlToString };
|
|
44486
|
+
export { ADD_RESULTS, ADD_SEARCH, AbstractAction, AbstractSearchField, ActionMenuComponent, AddLayerFromCatalogComponent, AddLayerRecordPreviewComponent, AddResults, AddSearch, AnchorLinkDirective, ApiCardComponent, ApplicationBannerComponent, AuthService, AutocompleteComponent, AvailableServicesField, AvatarComponent, AvatarServiceInterface, BASEMAP_LAYERS, BadgeComponent, BaseConverter, BaseFileReader, BaseReader, BlockListComponent, ButtonComponent, CLEAR_ERROR, CLEAR_RESULTS, CarouselComponent, CatalogTitleComponent, CellPopinComponent, ChartComponent, ChartViewComponent, CheckToggleComponent, CheckboxComponent, ClearError, ClearResults, ColorScaleComponent, ConfirmationDialogComponent, ContentGhostComponent, CopyTextButtonComponent, DEFAULT_GN4_LOGIN_URL, DEFAULT_GN4_LOGOUT_URL, DEFAULT_GN4_SETTINGS_URL, DEFAULT_LANG, DEFAULT_PAGE_SIZE, DEFAULT_RESULTS_LAYOUT_CONFIG, DEFAULT_SEARCH_KEY, DISABLE_AUTH, DO_NOT_USE_DEFAULT_BASEMAP, DataService, DataTableComponent, DataViewComponent, DataViewPermalinkComponent, DataViewShareComponent, DataViewWebComponentComponent, DatePickerComponent, DateRangeDropdownComponent, DateRangePickerComponent, DateRangeSearchField, DateService, DcatApConverter, DefaultRouterModule, DownloadItemComponent, DownloadsListComponent, DragAndDropFileInputComponent, DropdownMultiselectComponent, DropdownSelectorComponent, EDITOR_FEATURE_KEY, ES_QUERY_FIELDS_PRIORITY, ES_RESOURCES_VALUES, ES_SOURCE_SUMMARY, EXTERNAL_VIEWER_OPEN_NEW_TAB, EXTERNAL_VIEWER_URL_TEMPLATE, EditableLabelDirective, EditorFacade, EditorService, ElasticsearchService, EmbeddedTranslateLoader, ErrorComponent, ErrorType, ExpandablePanelButtonComponent, ExpandablePanelComponent, ExternalLinkCardComponent, ExternalViewerButtonComponent, FIELDS_BRIEF, FIELDS_SUMMARY, FILTER_GEOMETRY, FILTER_SUMMARY_IGNORE_LIST, FORMATS, FacetBlockComponent, FacetItemComponent, FacetListComponent, FacetsContainerComponent, FavoriteStarComponent, FavoritesService, FeatureCatalogListComponent, FeatureDetailComponent, FeatureEditorModule, FeatureMapModule, FeatureRecordModule, FeatureSearchModule, FetchError, FieldsService, FigureComponent, FigureContainerComponent, FileInputComponent, FileTranslateLoader, FilesDropDirective, FilterDropdownComponent, FormFieldArrayComponent, FormFieldComponent, FormFieldDateComponent, FormFieldFileComponent, FormFieldKeywordsComponent, FormFieldLicenseComponent, FormFieldObjectComponent, FormFieldRichComponent, FormFieldSimpleComponent, FormFieldSpatialExtentComponent, FormFieldTemporalExtentsComponent, FormFieldTopicsComponent, FormFieldWrapperComponent, FullTextSearchField, FuzzySearchComponent, GEONETWORK_UI_TAG_NAME, GEONETWORK_UI_VERSION, GeoDataBadgeComponent, GeoTableViewComponent, GeocodingComponent, GeojsonReader, Gn4Converter, Gn4PlatformMapper, Gn4PlatformService, Gn4Repository, Gn4SettingsService, GpfApiDlComponent, GravatarService, HttpLoaderFactory, I18nInterceptor, ImageFallbackDirective, ImageInputComponent, ImageOverlayPreviewComponent, ImportRecordComponent, InlineFilterComponent, InteractiveTableColumnComponent, InteractiveTableComponent, InternalLinkCardComponent, IsSpatialSearchField, Iso191153Converter, Iso19139Converter, KindBadgeComponent, LANGUAGES_LIST, LANGUAGE_NAMES, LANGUAGE_STORAGE_KEY, LANG_2_TO_3_MAPPER, LOGIN_URL, LOGOUT_URL, LONLAT_CRS_CODES, LanguageSwitcherComponent, LayersPanelComponent, LicenseSearchField, LinkClassifierService, LinkUsage, LoadingMaskComponent, LogService, MAP_FEATURE_KEY, MAP_VIEW_CONSTRAINTS, METADATA_LANGUAGE, MapContainerComponent, MapFacade, MapLegendComponent, MapStateContainerComponent, MapStyleService, MapUtilsService, MapViewComponent, MarkdownEditorComponent, MarkdownParserComponent, MaxLinesComponent, mdview_actions as MdViewActions, MdViewFacade, MetadataCatalogComponent, MetadataContactComponent, MetadataDoiComponent, MetadataInfoComponent, MetadataLinkType, MetadataMapperContext, MetadataQualityComponent, MetadataQualityItemComponent, MetadataQualityPanelComponent, ModalDialogComponent, MultilingualPanelComponent, MultilingualSearchField, MyOrgService, NAMESPACES, NOT_APPLICABLE_CONSTRAINT, NOT_KNOWN_CONSTRAINT, NotificationComponent, NotificationsContainerComponent, NotificationsService, ORGANIZATIONS_STRATEGY, ORGANIZATION_PAGE_URL_TOKEN, ORGANIZATION_URL_TOKEN, OrganisationPreviewComponent, OrganisationsComponent, OrganisationsFilterComponent, OrganisationsResultComponent, OrganizationSearchField, OrganizationsFromGroupsService, OrganizationsFromMetadataService, OrganizationsServiceInterface, OwnerSearchField, PAGINATE, PARSE_DELIMITER, PATCH_RESULTS_AGGREGATIONS, PROXY_PATH, Paginate, PaginationButtonsComponent, PaginationComponent, PaginationDotsComponent, PatchResultsAggregations, PlatformServiceInterface, PopoverComponent, PopupAlertComponent, PossibleResourceTypes, PossibleResourceTypesDefinition, PreviousNextButtonsComponent, ProgressBarComponent, ProxyService, QUERY_FIELDS, RECORD_DATASET_URL_TOKEN, RECORD_REUSE_URL_TOKEN, RECORD_SERVICE_URL_TOKEN, REQUEST_MORE_ON_AGGREGATION, REQUEST_MORE_RESULTS, REQUEST_NEW_RESULTS, RESULTS_LAYOUT_CONFIG, ROUTER_CONFIG, ROUTER_ROUTE_DATASET, ROUTER_ROUTE_ORGANIZATION, ROUTER_ROUTE_REUSE, ROUTER_ROUTE_SEARCH, ROUTER_ROUTE_SERVICE, ROUTER_STATE_KEY, ROUTE_PARAMS, RecordApiFormComponent, RecordFormComponent, RecordKindField, RecordMetaComponent, RecordMetricComponent, RecordPreviewCardComponent, RecordPreviewComponent, RecordPreviewFeedComponent, RecordPreviewListComponent, RecordPreviewRowComponent, RecordPreviewTextComponent, RecordPreviewTitleComponent, RecordsMetricsComponent, RecordsService, RequestMoreOnAggregation, RequestMoreResults, RequestNewResults, ResourceTypeLegacyField, ResultsHitsContainerComponent, ResultsHitsNumberComponent, ResultsHitsSearchKindComponent, ResultsLayoutComponent, ResultsLayoutConfigItem, ResultsListComponent, ResultsListContainerComponent, ResultsListItemComponent, ResultsTableComponent, ResultsTableContainerComponent, RouterEffects, RouterFacade, RouterService, SEARCH_FEATURE_KEY, SETTINGS_URL, SET_CONFIG_AGGREGATIONS, SET_CONFIG_FILTERS, SET_CONFIG_REQUEST_FIELDS, SET_ERROR, SET_FAVORITES_ONLY, SET_FILTERS, SET_INCLUDE_ON_AGGREGATION, SET_PAGE_SIZE, SET_RESULTS_AGGREGATIONS, SET_RESULTS_HITS, SET_RESULTS_LAYOUT, SET_SEARCH, SET_SORT_BY, SET_SPATIAL_FILTER_ENABLED, SearchEffects, SearchFacade, SearchFeatureCatalogComponent, SearchFiltersSummaryComponent, SearchFiltersSummaryItemComponent, SearchInputComponent, SearchRouterContainerDirective, SearchService, SearchStateContainerDirective, SelectionService, ServiceCapabilitiesComponent, SetConfigAggregations, SetConfigFilters, SetConfigRequestFields, SetError, SetFavoritesOnly, SetFilters, SetIncludeOnAggregation, SetPageSize, SetResultsAggregations, SetResultsHits, SetResultsLayout, SetSearch, SetSortBy, SetSpatialFilterEnabled, SimpleSearchField, SiteTitleComponent, SortByComponent, SortableListComponent, SourceLabelComponent, SourcesService, SpatialExtentComponent, SpinningLoaderComponent, StacViewComponent, StarToggleComponent, StickyHeaderComponent, SupportedTypes, SwitchToggleComponent, THUMBNAIL_PLACEHOLDER, TRANSLATE_DEBUG_CONFIG, TRANSLATE_DEFAULT_CONFIG, TRANSLATE_WITH_OVERRIDES_CONFIG, TableViewComponent, TextAreaComponent, TextInputComponent, ThemeService, ThumbnailComponent, TranslatedSearchField, TruncatedTextComponent, UPDATE_CONFIG_AGGREGATIONS, UPDATE_FILTERS, UPDATE_REQUEST_AGGREGATION_TERM, UpdateConfigAggregations, UpdateFilters, UrlInputComponent, UserFeedbackItemComponent, UserPreviewComponent, UserSearchField, VECTOR_STYLE_DEFAULT, ViewportIntersectorComponent, WEB_COMPONENT_EMBEDDER_URL, XmlParseError, _reset, allChildrenElement, appConfigWithTranslationFixture, appendChildTree, appendChildren, assertValidXml, blockModelFixture, bytesToMegabytes, canEditRecord, checkFileFormat, clearSelectedFeatures, createChild, createDocument, createElement, createFuzzyFilter, createNestedChild, createNestedElement, currentPage, defaultMapStyleFixture, defaultMapStyleHlFixture, downgradeImage, downsizeImage, draftSaveSuccess, dragPanCondition, dropEmptyTranslations, editorReducer, emptyBlockModelFixture, findChildElement, findChildOrCreate, findChildrenElement, findConverterForDocument, findNestedChildOrCreate, findNestedElement, findNestedElements, findParent, firstChildElement, formatDate, formatUserInfo, getAllKeysValidator, getArrayItem, getAsArray, getAsUrl, getBadgeColor, getCustomTranslations, getError, getFavoritesOnly, getFileFormat, getFileFormatFromServiceOutput, getFirstValue, getFormatPriority, getGeometryBoundingBox, getGeometryFromGeoJSON, getGlobalConfig, getIsMobile, getJsonDataItemsProxy, getLayers, getLinkId, getLinkLabel, getLinkPriority, getMapContext, getMapContextLayerFromConfig, getMapState, getMetadataQualityConfig, getMimeTypeForFormat, getNamespace, getOptionalMapConfig, getOptionalSearchConfig, getPageSize, getQualityValidators, getResourceType, getReuseType, getRootElement, getSearchConfigAggregations, getSearchFilters, getSearchResults, getSearchResultsAggregations, getSearchResultsHits, getSearchResultsLayout, getSearchResultsLoading, getSearchSortBy, getSearchState, getSearchStateSearch, getSelectedFeatures, getSpatialFilterEnabled, getTemporalRangeUnion, getThemeConfig, handleScrollOnNavigation, hasRecordChangedSinceDraft, hasRecordChangedSinceDraftSuccess, initSearch, initialEditorState, initialMapState, initialState, isConfigLoaded, isDateRange, isFormatInQueryParam, isPublished, itemModelFixture, kindToCodeListValue, loadAppConfig, malformedConfigFixture, mapConfigFixture, mapContact, mapKeywords, mapLogo, mapOrganization, mapReducer, markRecordAsChanged, matchesNoApplicableConstraint, matchesNoKnownConstraint, megabytesToBytes, mimeTypeToFormat, minimalAppConfigFixture, missingMandatoryConfigFixture, mouseWheelZoomCondition, noDuplicateFileName, okAppConfigFixture, openDataset, openRecord, organizationsServiceFactory, parse, parseXmlString, placeholder, prioritizePageScroll, propagateToDocumentOnly, provideGn4, provideI18n, provideRepositoryUrl, readAttribute, readDataset, readDatasetHeaders, readText, reducer$2 as reducer, reducerSearch, removeAllChildren, removeChildren, removeChildrenByName, removeSearchParams, removeWhitespace, renameElements, saveRecord, saveRecordFailure, saveRecordSuccess, selectCanEditRecord, selectCurrentPage, selectEditorConfig, selectEditorState, selectFallback, selectFallbackFields, selectField, selectHasRecordChanged, selectIsPublished, selectRecord, selectRecordChangedSinceSave, selectRecordSaveError, selectRecordSaving, selectRecordSections, selectRecordSource, selectTranslatedField, selectTranslatedValue, setContext, setCurrentPage, setFieldVisibility, setSelectedFeatures, setTextContent, someHabTableItemFixture, sortByFromString, sortByToString, sortByToStrings, stripHtml, stripNamespace, tableItemsFixture, toDate, toLang2, toLang3, totalPages, undoRecordDraft, unrecognizedKeysConfigFixture, updateLanguages, updateRecordField, updateRecordLanguages, wmsLayerFlatten, writeAttribute, wrongLanguageCodeConfigFixture, xmlToString };
|
|
44185
44487
|
//# sourceMappingURL=geonetwork-ui.mjs.map
|