geonetwork-ui 2.7.0-dev.30c4f9cfa → 2.7.0-dev.3914f8b7e
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/status.mapper.mjs +4 -1
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +5 -1
- package/esm2022/libs/api/repository/src/lib/gn4/elasticsearch/constant.mjs +4 -6
- package/esm2022/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.mjs +47 -3
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +32 -4
- 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 +15 -1
- package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +10 -2
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +2 -2
- package/esm2022/libs/feature/editor/src/index.mjs +2 -1
- package/esm2022/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.mjs +80 -0
- package/esm2022/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.mjs +3 -3
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +1 -3
- package/esm2022/libs/feature/map/src/lib/utils/map-utils.service.mjs +3 -5
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +31 -12
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +76 -27
- package/esm2022/libs/feature/record/src/lib/state/mdview.effects.mjs +4 -2
- package/esm2022/libs/feature/search/src/lib/state/reducer.mjs +5 -2
- package/esm2022/libs/ui/dataviz/src/lib/data-table/data-table.component.mjs +4 -3
- package/esm2022/libs/ui/elements/src/lib/api-card/api-card.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +5 -4
- package/esm2022/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.mjs +5 -4
- package/esm2022/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.mjs +4 -4
- package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +21 -43
- package/esm2022/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.mjs +5 -4
- package/esm2022/libs/ui/map/src/lib/components/map-legend/map-legend.component.mjs +2 -2
- package/esm2022/libs/util/app-config/src/lib/app-config.mjs +5 -1
- package/esm2022/libs/util/app-config/src/lib/model.mjs +1 -1
- package/esm2022/libs/util/shared/src/index.mjs +2 -2
- package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +12 -2
- package/esm2022/libs/util/shared/src/lib/record/index.mjs +3 -0
- package/esm2022/libs/util/shared/src/lib/record/quality-score.util.mjs +45 -0
- package/esm2022/libs/util/shared/src/lib/record/record.util.mjs +56 -0
- package/esm2022/libs/util/shared/src/lib/utils/geojson.mjs +58 -1
- package/esm2022/libs/util/shared/src/lib/utils/index.mjs +2 -1
- package/esm2022/libs/util/shared/src/lib/utils/mobile-screen.mjs +9 -0
- package/esm2022/translations/de.json +19 -1
- package/esm2022/translations/en.json +19 -1
- package/esm2022/translations/es.json +19 -1
- package/esm2022/translations/fr.json +20 -2
- package/esm2022/translations/it.json +19 -1
- package/esm2022/translations/nl.json +19 -1
- package/esm2022/translations/pt.json +19 -1
- package/esm2022/translations/sk.json +19 -1
- package/fesm2022/geonetwork-ui.mjs +2812 -2327
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/utils/status.mapper.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/elasticsearch/constant.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.d.ts +1 -1
- package/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +3 -0
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.d.ts +1 -0
- package/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/platform.service.interface.d.ts +1 -0
- package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts +3 -2
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/editor/src/index.d.ts +1 -0
- package/libs/feature/editor/src/index.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.d.ts +19 -0
- package/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
- package/libs/feature/map/src/lib/utils/map-utils.service.d.ts +2 -2
- package/libs/feature/map/src/lib/utils/map-utils.service.d.ts.map +1 -1
- package/libs/feature/record/src/lib/data-view/data-view.component.d.ts +8 -4
- package/libs/feature/record/src/lib/data-view/data-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +12 -5
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.effects.d.ts.map +1 -1
- package/libs/feature/search/src/lib/state/reducer.d.ts.map +1 -1
- package/libs/ui/dataviz/src/lib/data-table/data-table.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -0
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.d.ts +1 -0
- package/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts +7 -6
- package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.d.ts +1 -0
- package/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.d.ts.map +1 -1
- package/libs/util/app-config/src/lib/app-config.d.ts.map +1 -1
- package/libs/util/app-config/src/lib/model.d.ts +2 -0
- package/libs/util/app-config/src/lib/model.d.ts.map +1 -1
- package/libs/util/shared/src/index.d.ts +1 -1
- package/libs/util/shared/src/index.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts +2 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
- package/libs/util/shared/src/lib/record/index.d.ts +3 -0
- package/libs/util/shared/src/lib/record/index.d.ts.map +1 -0
- package/libs/util/shared/src/lib/record/quality-score.util.d.ts +13 -0
- package/libs/util/shared/src/lib/record/quality-score.util.d.ts.map +1 -0
- package/libs/util/shared/src/lib/record/record.util.d.ts +3 -0
- package/libs/util/shared/src/lib/record/record.util.d.ts.map +1 -0
- package/libs/util/shared/src/lib/utils/geojson.d.ts +7 -2
- package/libs/util/shared/src/lib/utils/geojson.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/index.d.ts +1 -0
- package/libs/util/shared/src/lib/utils/index.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/mobile-screen.d.ts +2 -0
- package/libs/util/shared/src/lib/utils/mobile-screen.d.ts.map +1 -0
- package/package.json +11 -10
- package/src/libs/api/metadata-converter/src/lib/dcat-ap/utils/status.mapper.ts +3 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/utils/status.mapper.ts +3 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +4 -0
- package/src/libs/api/repository/src/lib/gn4/elasticsearch/constant.ts +3 -5
- package/src/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.ts +50 -3
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +38 -4
- package/src/libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model.ts +1 -0
- package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +15 -0
- package/src/libs/common/domain/src/lib/platform.service.interface.ts +2 -0
- package/src/libs/common/fixtures/src/lib/editor/editor.fixtures.ts +0 -3
- package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +10 -1
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +3 -1
- package/src/libs/feature/editor/src/index.ts +1 -0
- package/src/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.html +37 -0
- package/src/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.ts +90 -0
- package/src/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.html +2 -1
- package/src/libs/feature/editor/src/lib/fields.config.ts +0 -2
- package/src/libs/feature/map/src/lib/utils/map-utils.service.ts +8 -8
- package/src/libs/feature/record/src/lib/data-view/data-view.component.html +2 -0
- package/src/libs/feature/record/src/lib/data-view/data-view.component.ts +34 -15
- package/src/libs/feature/record/src/lib/map-view/map-view.component.html +5 -2
- package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +70 -23
- package/src/libs/feature/record/src/lib/state/mdview.effects.ts +5 -1
- package/src/libs/feature/search/src/lib/state/reducer.ts +4 -1
- package/src/libs/ui/dataviz/src/lib/data-table/data-table.component.ts +6 -1
- package/src/libs/ui/elements/src/lib/api-card/api-card.component.html +4 -1
- package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.html +12 -11
- package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +7 -1
- package/src/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.html +4 -1
- package/src/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.ts +7 -1
- package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.html +1 -0
- package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.ts +5 -1
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +1 -0
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.ts +21 -54
- package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.html +7 -1
- package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.ts +3 -1
- package/src/libs/ui/map/src/lib/components/map-legend/map-legend.component.ts +1 -1
- package/src/libs/util/app-config/src/lib/app-config.ts +4 -0
- package/src/libs/util/app-config/src/lib/model.ts +2 -0
- package/src/libs/util/shared/src/index.ts +1 -1
- package/src/libs/util/shared/src/lib/links/link-utils.ts +11 -1
- package/src/libs/util/shared/src/lib/record/index.ts +2 -0
- package/src/libs/util/shared/src/lib/record/quality-score.util.ts +69 -0
- package/src/libs/util/shared/src/lib/{record.util.ts → record/record.util.ts} +1 -1
- package/src/libs/util/shared/src/lib/utils/geojson.ts +72 -2
- package/src/libs/util/shared/src/lib/utils/index.ts +1 -0
- package/src/libs/util/shared/src/lib/utils/mobile-screen.ts +14 -0
- package/translations/de.json +19 -1
- package/translations/en.json +19 -1
- package/translations/es.json +19 -1
- package/translations/fr.json +20 -2
- package/translations/it.json +19 -1
- package/translations/nl.json +19 -1
- package/translations/pt.json +19 -1
- package/translations/sk.json +19 -1
- package/esm2022/libs/util/shared/src/lib/record.util.mjs +0 -56
- package/libs/util/shared/src/lib/record.util.d.ts +0 -3
- package/libs/util/shared/src/lib/record.util.d.ts.map +0 -1
package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.html
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
<div
|
|
2
2
|
class="flex items-center justify-between p-3 mt-8 bg-white rounded-lg border-b solid border-gray-300"
|
|
3
|
+
*ngIf="
|
|
4
|
+
(isMobile$ | async) === false || featureCatalog?.featureTypes?.length > 1
|
|
5
|
+
"
|
|
3
6
|
>
|
|
4
7
|
<div
|
|
5
8
|
class="relative shrink-0"
|
|
@@ -17,7 +20,10 @@
|
|
|
17
20
|
name="iconoirSearch"
|
|
18
21
|
></ng-icon>
|
|
19
22
|
</div>
|
|
20
|
-
<div
|
|
23
|
+
<div
|
|
24
|
+
*ngIf="(isMobile$ | async) === false"
|
|
25
|
+
class="text-sm px-1 ml-auto inline"
|
|
26
|
+
>
|
|
21
27
|
<ng-container *ngIf="featureCatalog?.featureTypes?.length > 1">
|
|
22
28
|
<span
|
|
23
29
|
class="text-sm font-medium text-gray-900"
|
package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.ts
CHANGED
|
@@ -6,7 +6,7 @@ import { DatasetFeatureCatalog } from '../../../../../../libs/common/domain/src/
|
|
|
6
6
|
import { FormsModule } from '@angular/forms'
|
|
7
7
|
import { of } from 'rxjs'
|
|
8
8
|
import { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators'
|
|
9
|
-
import { createFuzzyFilter } from '../../../../../../libs/util/shared/src'
|
|
9
|
+
import { createFuzzyFilter, getIsMobile } from '../../../../../../libs/util/shared/src'
|
|
10
10
|
import { iconoirSearch } from '@ng-icons/iconoir'
|
|
11
11
|
|
|
12
12
|
@Component({
|
|
@@ -39,6 +39,8 @@ export class SearchFeatureCatalogComponent {
|
|
|
39
39
|
return this._featureCatalog
|
|
40
40
|
}
|
|
41
41
|
|
|
42
|
+
isMobile$ = getIsMobile()
|
|
43
|
+
|
|
42
44
|
@Output() filteredFeatureCatalogChange =
|
|
43
45
|
new EventEmitter<DatasetFeatureCatalog>()
|
|
44
46
|
filteredFeatureCatalog: DatasetFeatureCatalog
|
|
@@ -27,7 +27,7 @@ export class MapLegendComponent implements OnChanges {
|
|
|
27
27
|
async ngOnChanges(changes: SimpleChanges) {
|
|
28
28
|
if ('context' in changes) {
|
|
29
29
|
const mapContext = changes['context'].currentValue
|
|
30
|
-
if (mapContext
|
|
30
|
+
if (mapContext?.layers && mapContext.layers.length > 0) {
|
|
31
31
|
const mapContextLayer = mapContext.layers[0]
|
|
32
32
|
this.legendHTML = await createLegendFromLayer(mapContextLayer)
|
|
33
33
|
if (this.legendHTML) {
|
|
@@ -102,6 +102,7 @@ export function loadAppConfig() {
|
|
|
102
102
|
'web_component_embedder_url',
|
|
103
103
|
'languages',
|
|
104
104
|
'contact_email',
|
|
105
|
+
'reuse_form_url',
|
|
105
106
|
],
|
|
106
107
|
warnings,
|
|
107
108
|
errors
|
|
@@ -131,6 +132,7 @@ export function loadAppConfig() {
|
|
|
131
132
|
parsedGlobalSection.web_component_embedder_url,
|
|
132
133
|
LANGUAGES: parsedGlobalSection.languages,
|
|
133
134
|
CONTACT_EMAIL: parsedGlobalSection.contact_email,
|
|
135
|
+
REUSE_FORM_URL: parsedGlobalSection.reuse_form_url,
|
|
134
136
|
} as GlobalConfig)
|
|
135
137
|
|
|
136
138
|
const parsedLayersSections = parseMultiConfigSection(
|
|
@@ -229,6 +231,7 @@ export function loadAppConfig() {
|
|
|
229
231
|
'filter_geometry_url',
|
|
230
232
|
'search_preset',
|
|
231
233
|
'advanced_filters',
|
|
234
|
+
'limit',
|
|
232
235
|
],
|
|
233
236
|
warnings,
|
|
234
237
|
errors
|
|
@@ -255,6 +258,7 @@ export function loadAppConfig() {
|
|
|
255
258
|
filters: param.filters,
|
|
256
259
|
})),
|
|
257
260
|
ADVANCED_FILTERS: parsedSearchSection.advanced_filters,
|
|
261
|
+
LIMIT: parsedSearchSection.limit,
|
|
258
262
|
} as SearchConfig)
|
|
259
263
|
|
|
260
264
|
const parsedMetadataQualitySection = parseConfigSection(
|
|
@@ -11,6 +11,7 @@ export interface GlobalConfig {
|
|
|
11
11
|
WEB_COMPONENT_EMBEDDER_URL?: string
|
|
12
12
|
LANGUAGES?: string[]
|
|
13
13
|
CONTACT_EMAIL?: string
|
|
14
|
+
REUSE_FORM_URL?: string
|
|
14
15
|
}
|
|
15
16
|
|
|
16
17
|
export interface LayerConfig {
|
|
@@ -59,6 +60,7 @@ export interface SearchConfig {
|
|
|
59
60
|
FILTER_GEOMETRY_DATA?: string
|
|
60
61
|
SEARCH_PRESET?: SearchPreset[]
|
|
61
62
|
ADVANCED_FILTERS?: []
|
|
63
|
+
LIMIT?: number
|
|
62
64
|
}
|
|
63
65
|
|
|
64
66
|
export interface MetadataQualityConfig {
|
|
@@ -23,8 +23,8 @@ export const FORMATS = {
|
|
|
23
23
|
excel: {
|
|
24
24
|
extensions: [
|
|
25
25
|
'excel',
|
|
26
|
-
'xls',
|
|
27
26
|
'xlsx',
|
|
27
|
+
'xls',
|
|
28
28
|
'ms-excel',
|
|
29
29
|
'openxmlformats-officedocument',
|
|
30
30
|
],
|
|
@@ -190,6 +190,7 @@ export function isFormatInQueryParam(
|
|
|
190
190
|
alias: string
|
|
191
191
|
): boolean {
|
|
192
192
|
const queryParams = link.url.searchParams
|
|
193
|
+
if (!queryParams) return false
|
|
193
194
|
for (const [key, value] of queryParams.entries()) {
|
|
194
195
|
if (key === 'format' || key === 'f') {
|
|
195
196
|
return value === alias
|
|
@@ -230,6 +231,15 @@ export function getBadgeColor(linkFormat: FileFormat): string {
|
|
|
230
231
|
return 'var(--color-gray-700)' // Default color ?
|
|
231
232
|
}
|
|
232
233
|
|
|
234
|
+
export function getLinkId(link: DatasetOnlineResource): string {
|
|
235
|
+
const href = link.url.href ?? link.url
|
|
236
|
+
return `${getLinkLabel(link)
|
|
237
|
+
.replace(/é/g, 'e')
|
|
238
|
+
.replace(/è/g, 'e')
|
|
239
|
+
.normalize('NFD')
|
|
240
|
+
.replace(/[\u0300-\u036f]/g, '')}-${href}`
|
|
241
|
+
}
|
|
242
|
+
|
|
233
243
|
export function getLinkLabel(
|
|
234
244
|
link: DatasetOnlineResource | ServiceOnlineResource
|
|
235
245
|
): string {
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CatalogRecord,
|
|
3
|
+
RecordKind,
|
|
4
|
+
} from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
5
|
+
|
|
6
|
+
type TValidatorMapper = {
|
|
7
|
+
[key: string]: (metadata: Partial<CatalogRecord>) => boolean
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
const ValidatorMapper: TValidatorMapper = {
|
|
11
|
+
title: (record) => !!record?.title,
|
|
12
|
+
abstract: (record) => !!record?.abstract,
|
|
13
|
+
keywords: (record) => (record?.keywords?.length ?? 0) > 0,
|
|
14
|
+
legalConstraints: (record) => (record?.legalConstraints?.length ?? 0) > 0,
|
|
15
|
+
contacts: (record) => !!record?.contacts?.[0]?.email,
|
|
16
|
+
updateFrequency: (record) => !!record?.updateFrequency,
|
|
17
|
+
topics: (record) => (record?.topics?.length ?? 0) > 0,
|
|
18
|
+
organisation: (record) => !!record?.contacts?.[0]?.organization?.name,
|
|
19
|
+
capabilities: (record) =>
|
|
20
|
+
record?.onlineResources?.some((resource) =>
|
|
21
|
+
resource?.url?.href.toLowerCase().includes('capabilities')
|
|
22
|
+
),
|
|
23
|
+
source: (record) => !!record?.extras?.sourcesIdentifiers,
|
|
24
|
+
} as const
|
|
25
|
+
|
|
26
|
+
export type ValidatorMapperKeys = keyof typeof ValidatorMapper & string
|
|
27
|
+
|
|
28
|
+
export function getAllKeysValidator() {
|
|
29
|
+
return Object.keys(ValidatorMapper)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
function getMappersFromKind(kind: RecordKind) {
|
|
33
|
+
let kindKeys = <ValidatorMapperKeys[]>[]
|
|
34
|
+
const commonsKeys = <ValidatorMapperKeys[]>[
|
|
35
|
+
'title',
|
|
36
|
+
'abstract',
|
|
37
|
+
'keywords',
|
|
38
|
+
'legalConstraints',
|
|
39
|
+
'contacts',
|
|
40
|
+
]
|
|
41
|
+
|
|
42
|
+
switch (kind) {
|
|
43
|
+
case 'service':
|
|
44
|
+
kindKeys = ['capabilities']
|
|
45
|
+
break
|
|
46
|
+
case 'reuse':
|
|
47
|
+
kindKeys = ['topics', 'organisation', 'source']
|
|
48
|
+
break
|
|
49
|
+
case 'dataset':
|
|
50
|
+
default:
|
|
51
|
+
kindKeys = ['updateFrequency', 'topics', 'organisation']
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return [...commonsKeys, ...kindKeys]
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
export function getQualityValidators(
|
|
58
|
+
record: Partial<CatalogRecord>,
|
|
59
|
+
propsToValidate: ValidatorMapperKeys[]
|
|
60
|
+
) {
|
|
61
|
+
const filteredProps = propsToValidate.filter((prop) =>
|
|
62
|
+
getMappersFromKind(record.kind).includes(prop)
|
|
63
|
+
)
|
|
64
|
+
|
|
65
|
+
return filteredProps.map((name) => ({
|
|
66
|
+
name,
|
|
67
|
+
validator: () => ValidatorMapper[name](record),
|
|
68
|
+
}))
|
|
69
|
+
}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
|
-
import { Feature, FeatureCollection, Geometry } from 'geojson'
|
|
1
|
+
import type { Feature, FeatureCollection, Geometry, Position } from 'geojson'
|
|
2
2
|
|
|
3
|
+
/**
|
|
4
|
+
* @returns The geometry if available, otherwise null.
|
|
5
|
+
*/
|
|
3
6
|
export function getGeometryFromGeoJSON(
|
|
4
7
|
data: FeatureCollection | Feature | Geometry
|
|
5
|
-
): Geometry {
|
|
8
|
+
): Geometry | null {
|
|
6
9
|
if (data.type === 'FeatureCollection') {
|
|
7
10
|
return data?.features?.[0]?.geometry || null
|
|
8
11
|
}
|
|
@@ -24,3 +27,70 @@ export function getGeometryFromGeoJSON(
|
|
|
24
27
|
}
|
|
25
28
|
return null
|
|
26
29
|
}
|
|
30
|
+
|
|
31
|
+
// FIXME: this type should be more generic across the project
|
|
32
|
+
export type BoundingBox = [number, number, number, number]
|
|
33
|
+
|
|
34
|
+
export function getGeometryBoundingBox(geometry: Geometry): BoundingBox {
|
|
35
|
+
// use the bounding box if specified in the GeoJSON object
|
|
36
|
+
if (geometry.bbox) {
|
|
37
|
+
return geometry.bbox.length > 4
|
|
38
|
+
? [geometry.bbox[0], geometry.bbox[1], geometry.bbox[3], geometry.bbox[4]]
|
|
39
|
+
: (geometry.bbox as BoundingBox)
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
const coordinatesReducer = (prev: BoundingBox, coords: Position) =>
|
|
43
|
+
[
|
|
44
|
+
Math.min(prev[0], coords[0]),
|
|
45
|
+
Math.min(prev[1], coords[1]),
|
|
46
|
+
Math.max(prev[2], coords[0]),
|
|
47
|
+
Math.max(prev[3], coords[1]),
|
|
48
|
+
] as BoundingBox
|
|
49
|
+
const coordinatesArrayReducer = (
|
|
50
|
+
prev: BoundingBox,
|
|
51
|
+
coordsArray: Position[]
|
|
52
|
+
) => {
|
|
53
|
+
const bbox = coordsArray.reduce(coordinatesReducer, emptyExtent)
|
|
54
|
+
return [
|
|
55
|
+
Math.min(prev[0], bbox[0]),
|
|
56
|
+
Math.min(prev[1], bbox[1]),
|
|
57
|
+
Math.max(prev[2], bbox[2]),
|
|
58
|
+
Math.max(prev[3], bbox[3]),
|
|
59
|
+
] as BoundingBox
|
|
60
|
+
}
|
|
61
|
+
const emptyExtent = [Infinity, Infinity, -Infinity, -Infinity] as BoundingBox
|
|
62
|
+
|
|
63
|
+
switch (geometry.type) {
|
|
64
|
+
case 'MultiPolygon':
|
|
65
|
+
return geometry.coordinates.reduce((prev, polygonCoords) => {
|
|
66
|
+
const bbox = polygonCoords.reduce(coordinatesArrayReducer, emptyExtent)
|
|
67
|
+
return [
|
|
68
|
+
Math.min(prev[0], bbox[0]),
|
|
69
|
+
Math.min(prev[1], bbox[1]),
|
|
70
|
+
Math.max(prev[2], bbox[2]),
|
|
71
|
+
Math.max(prev[3], bbox[3]),
|
|
72
|
+
] as BoundingBox
|
|
73
|
+
}, emptyExtent)
|
|
74
|
+
case 'GeometryCollection':
|
|
75
|
+
return geometry.geometries.reduce((prev, geom) => {
|
|
76
|
+
const bbox = getGeometryBoundingBox(geom)
|
|
77
|
+
return [
|
|
78
|
+
Math.min(prev[0], bbox[0]),
|
|
79
|
+
Math.min(prev[1], bbox[1]),
|
|
80
|
+
Math.max(prev[2], bbox[2]),
|
|
81
|
+
Math.max(prev[3], bbox[3]),
|
|
82
|
+
] as BoundingBox
|
|
83
|
+
}, emptyExtent)
|
|
84
|
+
case 'Polygon':
|
|
85
|
+
case 'MultiLineString':
|
|
86
|
+
return geometry.coordinates.reduce(coordinatesArrayReducer, emptyExtent)
|
|
87
|
+
case 'LineString':
|
|
88
|
+
case 'MultiPoint':
|
|
89
|
+
return geometry.coordinates.reduce<BoundingBox>(
|
|
90
|
+
coordinatesReducer,
|
|
91
|
+
emptyExtent
|
|
92
|
+
)
|
|
93
|
+
case 'Point':
|
|
94
|
+
return coordinatesReducer(emptyExtent, geometry.coordinates)
|
|
95
|
+
}
|
|
96
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { fromEvent, startWith, map, shareReplay } from 'rxjs'
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* This returns true when the screen size is under 768px, which is the mobile threshold.
|
|
5
|
+
*/
|
|
6
|
+
const MOBILE_MAX_WIDTH = 768
|
|
7
|
+
|
|
8
|
+
export function getIsMobile() {
|
|
9
|
+
return fromEvent(window, 'resize').pipe(
|
|
10
|
+
startWith(window.innerWidth),
|
|
11
|
+
map(() => window.innerWidth < MOBILE_MAX_WIDTH),
|
|
12
|
+
shareReplay({ bufferSize: 1, refCount: true })
|
|
13
|
+
)
|
|
14
|
+
}
|
package/translations/de.json
CHANGED
|
@@ -86,7 +86,9 @@
|
|
|
86
86
|
"domain.record.status.completed": "Abgeschlossen",
|
|
87
87
|
"domain.record.status.deprecated": "Veraltet",
|
|
88
88
|
"domain.record.status.ongoing": "Kontinuierliche Aktualisierung",
|
|
89
|
+
"domain.record.status.planned": "",
|
|
89
90
|
"domain.record.status.removed": "Entfernt",
|
|
91
|
+
"domain.record.status.required": "",
|
|
90
92
|
"domain.record.status.under_development": "In Erstellung",
|
|
91
93
|
"domain.record.updateFrequency.annually": "Daten werden jedes Jahr aktualisiert",
|
|
92
94
|
"domain.record.updateFrequency.asNeeded": "Daten werden nach Bedarf aktualisiert",
|
|
@@ -142,6 +144,7 @@
|
|
|
142
144
|
"editor.record.form.draft.updateAlert": "",
|
|
143
145
|
"editor.record.form.field.abstract": "Kurzbeschreibung",
|
|
144
146
|
"editor.record.form.field.constraintsShortcuts": "",
|
|
147
|
+
"editor.record.form.field.contacts": "Ansprechpartner - Email",
|
|
145
148
|
"editor.record.form.field.contacts.noContact": "",
|
|
146
149
|
"editor.record.form.field.contacts.placeholder": "",
|
|
147
150
|
"editor.record.form.field.contactsForResource.noContact": "",
|
|
@@ -166,6 +169,7 @@
|
|
|
166
169
|
"editor.record.form.field.onlineResource.toggle.dataset": "",
|
|
167
170
|
"editor.record.form.field.onlineResource.toggle.service": "",
|
|
168
171
|
"editor.record.form.field.onlineResources": "",
|
|
172
|
+
"editor.record.form.field.organisation": "Ansprechpartner - Organisation",
|
|
169
173
|
"editor.record.form.field.otherConstraints": "Allgemeine Einschränkung",
|
|
170
174
|
"editor.record.form.field.overviews": "",
|
|
171
175
|
"editor.record.form.field.recordUpdated": "Datensatz zuletzt aktualisiert",
|
|
@@ -177,6 +181,7 @@
|
|
|
177
181
|
"editor.record.form.field.temporalExtents": "Zeitlicher Umfang",
|
|
178
182
|
"editor.record.form.field.title": "Metadaten-Titel",
|
|
179
183
|
"editor.record.form.field.title.placeholder": "Geben Sie einen Titel ein",
|
|
184
|
+
"editor.record.form.field.topics": "Kategorien",
|
|
180
185
|
"editor.record.form.field.uniqueIdentifier": "Eindeutige Kennung (ID)",
|
|
181
186
|
"editor.record.form.field.updateFrequency": "Aktualisierungshäufigkeit",
|
|
182
187
|
"editor.record.form.keywords.place.placeholder": "",
|
|
@@ -191,6 +196,8 @@
|
|
|
191
196
|
"editor.record.form.license.odc-by": "",
|
|
192
197
|
"editor.record.form.license.pddl": "",
|
|
193
198
|
"editor.record.form.license.unknown": "",
|
|
199
|
+
"editor.record.form.metadataQuality.open": "Öffnen Sie das Panel zur Metadatenqualität",
|
|
200
|
+
"editor.record.form.metadataQuality.title": "Vollständigkeit",
|
|
194
201
|
"editor.record.form.multilingual.activate": "",
|
|
195
202
|
"editor.record.form.multilingual.default": "",
|
|
196
203
|
"editor.record.form.multilingual.enable": "",
|
|
@@ -340,6 +347,7 @@
|
|
|
340
347
|
"map.layer.add": "Hinzufügen",
|
|
341
348
|
"map.layers.available": "Verfügbare Layer",
|
|
342
349
|
"map.layers.list": "Ebenen",
|
|
350
|
+
"map.legend.title": "Legende",
|
|
343
351
|
"map.loading.data": "Kartendaten werden geladen...",
|
|
344
352
|
"map.loading.service": "Dienst wird geladen...",
|
|
345
353
|
"map.navigation.message": "Bitte verwenden Sie STRG + Maus (oder zwei Finger auf einem Mobilgerät), um die Karte zu navigieren",
|
|
@@ -373,7 +381,6 @@
|
|
|
373
381
|
"record.action.rollback": "",
|
|
374
382
|
"record.action.switchLang": "",
|
|
375
383
|
"record.action.view": "Anzeigen",
|
|
376
|
-
"record.card.metadata.contact": "",
|
|
377
384
|
"record.externalViewer.open": "In externem Kartenviewer öffnen",
|
|
378
385
|
"record.feature.catalog.number.total.attribute": "",
|
|
379
386
|
"record.feature.catalog.number.total.object": "",
|
|
@@ -383,6 +390,16 @@
|
|
|
383
390
|
"record.kind.service": "",
|
|
384
391
|
"record.metadata.about": "Beschreibung",
|
|
385
392
|
"record.metadata.api": "API",
|
|
393
|
+
"record.metadata.api.accessServiceProtocol.GPFDL": "",
|
|
394
|
+
"record.metadata.api.accessServiceProtocol.esriRest": "",
|
|
395
|
+
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
396
|
+
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
397
|
+
"record.metadata.api.accessServiceProtocol.other": "",
|
|
398
|
+
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
399
|
+
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
400
|
+
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
401
|
+
"record.metadata.api.accessServiceProtocol.wmts": "",
|
|
402
|
+
"record.metadata.api.accessServiceProtocol.wps": "",
|
|
386
403
|
"record.metadata.api.form.closeButton": "Schließen",
|
|
387
404
|
"record.metadata.api.form.closeForm": "Formular schließen",
|
|
388
405
|
"record.metadata.api.form.create": "Ihre Anfrage erstellen",
|
|
@@ -579,6 +596,7 @@
|
|
|
579
596
|
"service.metadata.filter.noLayers": "",
|
|
580
597
|
"service.metadata.other": "",
|
|
581
598
|
"service.metadata.question": "",
|
|
599
|
+
"service.metadata.reuse": "",
|
|
582
600
|
"service.metadata.search": "",
|
|
583
601
|
"service.metadata.search.clear": "",
|
|
584
602
|
"service.metadata.spatialExtent": "",
|
package/translations/en.json
CHANGED
|
@@ -86,7 +86,9 @@
|
|
|
86
86
|
"domain.record.status.completed": "Completed",
|
|
87
87
|
"domain.record.status.deprecated": "Deprecated",
|
|
88
88
|
"domain.record.status.ongoing": "Ongoing",
|
|
89
|
+
"domain.record.status.planned": "Planned",
|
|
89
90
|
"domain.record.status.removed": "Removed",
|
|
91
|
+
"domain.record.status.required": "Required",
|
|
90
92
|
"domain.record.status.under_development": "Under development",
|
|
91
93
|
"domain.record.updateFrequency.annually": "Data is updated every year",
|
|
92
94
|
"domain.record.updateFrequency.asNeeded": "Data is updated as deemed necessary",
|
|
@@ -142,6 +144,7 @@
|
|
|
142
144
|
"editor.record.form.draft.updateAlert": "Since you created this draft, the dataset has been updated on { date } by { user }. Publishing your draft might erase their edits. To avoid this, you need to either cancel your changes or knowingly publish your own version.",
|
|
143
145
|
"editor.record.form.field.abstract": "Abstract",
|
|
144
146
|
"editor.record.form.field.constraintsShortcuts": "",
|
|
147
|
+
"editor.record.form.field.contacts": "Point of contact - Email",
|
|
145
148
|
"editor.record.form.field.contacts.noContact": "Please provide at least one point of contact.",
|
|
146
149
|
"editor.record.form.field.contacts.placeholder": "Choose a contact",
|
|
147
150
|
"editor.record.form.field.contactsForResource.noContact": "Please provide at least one point of contact responsible for the data.",
|
|
@@ -166,6 +169,7 @@
|
|
|
166
169
|
"editor.record.form.field.onlineResource.toggle.dataset": "Link to a file",
|
|
167
170
|
"editor.record.form.field.onlineResource.toggle.service": "Link to a service",
|
|
168
171
|
"editor.record.form.field.onlineResources": "Distribution",
|
|
172
|
+
"editor.record.form.field.organisation": "Point of contact - Organization",
|
|
169
173
|
"editor.record.form.field.otherConstraints": "Other constraint",
|
|
170
174
|
"editor.record.form.field.overviews": "Overview",
|
|
171
175
|
"editor.record.form.field.recordUpdated": "Record updated",
|
|
@@ -177,6 +181,7 @@
|
|
|
177
181
|
"editor.record.form.field.temporalExtents": "Temporal extents",
|
|
178
182
|
"editor.record.form.field.title": "Metadata title",
|
|
179
183
|
"editor.record.form.field.title.placeholder": "Enter a title",
|
|
184
|
+
"editor.record.form.field.topics": "Categories",
|
|
180
185
|
"editor.record.form.field.uniqueIdentifier": "Unique identifier",
|
|
181
186
|
"editor.record.form.field.updateFrequency": "Update frequency",
|
|
182
187
|
"editor.record.form.keywords.place.placeholder": "Search for place keywords",
|
|
@@ -191,6 +196,8 @@
|
|
|
191
196
|
"editor.record.form.license.odc-by": "Open Data Commons ODC-By",
|
|
192
197
|
"editor.record.form.license.pddl": "Open Data Commons PDDL",
|
|
193
198
|
"editor.record.form.license.unknown": "Unknown or absent",
|
|
199
|
+
"editor.record.form.metadataQuality.open": "Open the metadata quality panel",
|
|
200
|
+
"editor.record.form.metadataQuality.title": "Completeness",
|
|
194
201
|
"editor.record.form.multilingual.activate": "Activate the languages",
|
|
195
202
|
"editor.record.form.multilingual.default": "Default",
|
|
196
203
|
"editor.record.form.multilingual.enable": "Multilingual Mode",
|
|
@@ -340,6 +347,7 @@
|
|
|
340
347
|
"map.layer.add": "Add",
|
|
341
348
|
"map.layers.available": "Available Layers",
|
|
342
349
|
"map.layers.list": "Layers",
|
|
350
|
+
"map.legend.title": "Legend",
|
|
343
351
|
"map.loading.data": "Loading map data...",
|
|
344
352
|
"map.loading.service": "Loading service...",
|
|
345
353
|
"map.navigation.message": "Please use CTRL + mouse (or two fingers on mobile) to navigate the map",
|
|
@@ -373,7 +381,6 @@
|
|
|
373
381
|
"record.action.rollback": "Rollback",
|
|
374
382
|
"record.action.switchLang": "Switch to default",
|
|
375
383
|
"record.action.view": "View",
|
|
376
|
-
"record.card.metadata.contact": "Metadata Contact",
|
|
377
384
|
"record.externalViewer.open": "Open in the external map viewer",
|
|
378
385
|
"record.feature.catalog.number.total.attribute": "Total amount of objects",
|
|
379
386
|
"record.feature.catalog.number.total.object": "Total amount of attributes",
|
|
@@ -383,6 +390,16 @@
|
|
|
383
390
|
"record.kind.service": "Service",
|
|
384
391
|
"record.metadata.about": "Description",
|
|
385
392
|
"record.metadata.api": "API",
|
|
393
|
+
"record.metadata.api.accessServiceProtocol.GPFDL": "GPFDL",
|
|
394
|
+
"record.metadata.api.accessServiceProtocol.esriRest": "esriRest",
|
|
395
|
+
"record.metadata.api.accessServiceProtocol.maplibre-style": "maplibre-style",
|
|
396
|
+
"record.metadata.api.accessServiceProtocol.ogcFeatures": "ogcFeatures",
|
|
397
|
+
"record.metadata.api.accessServiceProtocol.other": "other",
|
|
398
|
+
"record.metadata.api.accessServiceProtocol.tms": "tms",
|
|
399
|
+
"record.metadata.api.accessServiceProtocol.wfs": "wfs",
|
|
400
|
+
"record.metadata.api.accessServiceProtocol.wms": "wms",
|
|
401
|
+
"record.metadata.api.accessServiceProtocol.wmts": "wmts",
|
|
402
|
+
"record.metadata.api.accessServiceProtocol.wps": "wps",
|
|
386
403
|
"record.metadata.api.form.closeButton": "Close",
|
|
387
404
|
"record.metadata.api.form.closeForm": "Close the form",
|
|
388
405
|
"record.metadata.api.form.create": "Create your request",
|
|
@@ -579,6 +596,7 @@
|
|
|
579
596
|
"service.metadata.filter.noLayers": "No layer matches your search",
|
|
580
597
|
"service.metadata.other": "Other information",
|
|
581
598
|
"service.metadata.question": "Ask a question",
|
|
599
|
+
"service.metadata.reuse": "Declare a reuse",
|
|
582
600
|
"service.metadata.search": "Search through the layer list",
|
|
583
601
|
"service.metadata.search.clear": "Clear the layer search",
|
|
584
602
|
"service.metadata.spatialExtent": "Spatial extent",
|
package/translations/es.json
CHANGED
|
@@ -86,7 +86,9 @@
|
|
|
86
86
|
"domain.record.status.completed": "",
|
|
87
87
|
"domain.record.status.deprecated": "",
|
|
88
88
|
"domain.record.status.ongoing": "",
|
|
89
|
+
"domain.record.status.planned": "",
|
|
89
90
|
"domain.record.status.removed": "",
|
|
91
|
+
"domain.record.status.required": "",
|
|
90
92
|
"domain.record.status.under_development": "",
|
|
91
93
|
"domain.record.updateFrequency.annually": "Los datos se actualizan cada año",
|
|
92
94
|
"domain.record.updateFrequency.asNeeded": "Los datos se actualizan según sea necesario",
|
|
@@ -142,6 +144,7 @@
|
|
|
142
144
|
"editor.record.form.draft.updateAlert": "",
|
|
143
145
|
"editor.record.form.field.abstract": "",
|
|
144
146
|
"editor.record.form.field.constraintsShortcuts": "",
|
|
147
|
+
"editor.record.form.field.contacts": "Punto de contacto - Correo ",
|
|
145
148
|
"editor.record.form.field.contacts.noContact": "",
|
|
146
149
|
"editor.record.form.field.contacts.placeholder": "",
|
|
147
150
|
"editor.record.form.field.contactsForResource.noContact": "",
|
|
@@ -166,6 +169,7 @@
|
|
|
166
169
|
"editor.record.form.field.onlineResource.toggle.dataset": "",
|
|
167
170
|
"editor.record.form.field.onlineResource.toggle.service": "",
|
|
168
171
|
"editor.record.form.field.onlineResources": "",
|
|
172
|
+
"editor.record.form.field.organisation": "Punto de contacto - Organización",
|
|
169
173
|
"editor.record.form.field.otherConstraints": "",
|
|
170
174
|
"editor.record.form.field.overviews": "",
|
|
171
175
|
"editor.record.form.field.recordUpdated": "",
|
|
@@ -177,6 +181,7 @@
|
|
|
177
181
|
"editor.record.form.field.temporalExtents": "",
|
|
178
182
|
"editor.record.form.field.title": "",
|
|
179
183
|
"editor.record.form.field.title.placeholder": "Introduzca un título",
|
|
184
|
+
"editor.record.form.field.topics": "Categorías",
|
|
180
185
|
"editor.record.form.field.uniqueIdentifier": "",
|
|
181
186
|
"editor.record.form.field.updateFrequency": "",
|
|
182
187
|
"editor.record.form.keywords.place.placeholder": "",
|
|
@@ -191,6 +196,8 @@
|
|
|
191
196
|
"editor.record.form.license.odc-by": "",
|
|
192
197
|
"editor.record.form.license.pddl": "",
|
|
193
198
|
"editor.record.form.license.unknown": "",
|
|
199
|
+
"editor.record.form.metadataQuality.open": "Abrir el panel de calidad de los metadatos",
|
|
200
|
+
"editor.record.form.metadataQuality.title": "Completitud",
|
|
194
201
|
"editor.record.form.multilingual.activate": "",
|
|
195
202
|
"editor.record.form.multilingual.default": "",
|
|
196
203
|
"editor.record.form.multilingual.enable": "",
|
|
@@ -340,6 +347,7 @@
|
|
|
340
347
|
"map.layer.add": "",
|
|
341
348
|
"map.layers.available": "",
|
|
342
349
|
"map.layers.list": "",
|
|
350
|
+
"map.legend.title": "",
|
|
343
351
|
"map.loading.data": "",
|
|
344
352
|
"map.loading.service": "",
|
|
345
353
|
"map.navigation.message": "",
|
|
@@ -373,7 +381,6 @@
|
|
|
373
381
|
"record.action.rollback": "",
|
|
374
382
|
"record.action.switchLang": "",
|
|
375
383
|
"record.action.view": "",
|
|
376
|
-
"record.card.metadata.contact": "",
|
|
377
384
|
"record.externalViewer.open": "",
|
|
378
385
|
"record.feature.catalog.number.total.attribute": "",
|
|
379
386
|
"record.feature.catalog.number.total.object": "",
|
|
@@ -383,6 +390,16 @@
|
|
|
383
390
|
"record.kind.service": "",
|
|
384
391
|
"record.metadata.about": "",
|
|
385
392
|
"record.metadata.api": "",
|
|
393
|
+
"record.metadata.api.accessServiceProtocol.GPFDL": "",
|
|
394
|
+
"record.metadata.api.accessServiceProtocol.esriRest": "",
|
|
395
|
+
"record.metadata.api.accessServiceProtocol.maplibre-style": "",
|
|
396
|
+
"record.metadata.api.accessServiceProtocol.ogcFeatures": "",
|
|
397
|
+
"record.metadata.api.accessServiceProtocol.other": "",
|
|
398
|
+
"record.metadata.api.accessServiceProtocol.tms": "",
|
|
399
|
+
"record.metadata.api.accessServiceProtocol.wfs": "",
|
|
400
|
+
"record.metadata.api.accessServiceProtocol.wms": "",
|
|
401
|
+
"record.metadata.api.accessServiceProtocol.wmts": "",
|
|
402
|
+
"record.metadata.api.accessServiceProtocol.wps": "",
|
|
386
403
|
"record.metadata.api.form.closeButton": "",
|
|
387
404
|
"record.metadata.api.form.closeForm": "",
|
|
388
405
|
"record.metadata.api.form.create": "",
|
|
@@ -579,6 +596,7 @@
|
|
|
579
596
|
"service.metadata.filter.noLayers": "",
|
|
580
597
|
"service.metadata.other": "",
|
|
581
598
|
"service.metadata.question": "",
|
|
599
|
+
"service.metadata.reuse": "",
|
|
582
600
|
"service.metadata.search": "",
|
|
583
601
|
"service.metadata.search.clear": "",
|
|
584
602
|
"service.metadata.spatialExtent": "",
|