geonetwork-ui 2.6.0-dev.c4b99cdef → 2.6.0-dev.d8333ac5d
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/common/distribution.mapper.mjs +3 -1
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +2 -1
- package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +5 -2
- package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +45 -9
- package/esm2022/libs/feature/dataviz/src/lib/geo-table-view/geo-table-view.component.mjs +2 -2
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +32 -2
- package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +25 -6
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +3 -3
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +33 -7
- package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +11 -13
- package/esm2022/libs/ui/dataviz/src/lib/chart/chart.component.mjs +5 -3
- package/esm2022/libs/ui/dataviz/src/lib/data-table/data-table.component.mjs +11 -6
- package/esm2022/libs/ui/elements/src/index.mjs +2 -1
- package/esm2022/libs/ui/elements/src/lib/metadata-contact/metadata-contact.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/record-feature-catalog/feature-catalog-list/feature-catalog-list.component.mjs +51 -0
- package/esm2022/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.mjs +12 -4
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +1 -1
- package/esm2022/libs/ui/inputs/src/index.mjs +2 -1
- package/esm2022/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.mjs +68 -0
- package/esm2022/libs/ui/layout/src/lib/expandable-panel/expandable-panel.component.mjs +34 -13
- package/esm2022/libs/ui/layout/src/lib/truncated-text/truncated-text.component.mjs +65 -14
- package/esm2022/libs/ui/map/src/lib/components/feature-detail/feature-detail.component.mjs +29 -4
- package/esm2022/libs/ui/search/src/lib/results-list/results-list.component.mjs +3 -3
- package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +4 -1
- package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +4 -1
- package/esm2022/translations/de.json +5 -0
- package/esm2022/translations/en.json +5 -2
- package/esm2022/translations/es.json +5 -0
- package/esm2022/translations/fr.json +5 -2
- package/esm2022/translations/it.json +38 -33
- package/esm2022/translations/nl.json +5 -0
- package/esm2022/translations/pt.json +5 -0
- package/fesm2022/geonetwork-ui.mjs +473 -110
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- 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/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +4 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts +12 -8
- 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 +1 -0
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts +5 -2
- package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts +26 -21
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
- package/libs/ui/dataviz/src/lib/chart/chart.component.d.ts +2 -1
- package/libs/ui/dataviz/src/lib/chart/chart.component.d.ts.map +1 -1
- package/libs/ui/dataviz/src/lib/data-table/data-table.component.d.ts +6 -1
- package/libs/ui/dataviz/src/lib/data-table/data-table.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/record-feature-catalog/feature-catalog-list/feature-catalog-list.component.d.ts +16 -0
- package/libs/ui/elements/src/lib/record-feature-catalog/feature-catalog-list/feature-catalog-list.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.d.ts +1 -0
- package/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
- package/libs/ui/inputs/src/index.d.ts +1 -0
- package/libs/ui/inputs/src/index.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.d.ts +17 -0
- package/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.d.ts.map +1 -0
- package/libs/ui/layout/src/lib/expandable-panel/expandable-panel.component.d.ts +15 -8
- package/libs/ui/layout/src/lib/expandable-panel/expandable-panel.component.d.ts.map +1 -1
- package/libs/ui/layout/src/lib/truncated-text/truncated-text.component.d.ts +15 -6
- package/libs/ui/layout/src/lib/truncated-text/truncated-text.component.d.ts.map +1 -1
- package/libs/ui/map/src/lib/components/feature-detail/feature-detail.component.d.ts +6 -2
- package/libs/ui/map/src/lib/components/feature-detail/feature-detail.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.map +1 -1
- package/package.json +2 -2
- package/src/libs/api/metadata-converter/src/lib/common/distribution.mapper.ts +1 -0
- package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +1 -0
- package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +4 -1
- package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +9 -2
- package/src/libs/common/fixtures/src/lib/elasticsearch/metadata-links.fixtures.ts +10 -0
- package/src/libs/common/fixtures/src/lib/link.fixtures.ts +14 -0
- package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.html +12 -9
- package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +54 -10
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +37 -0
- package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.html +1 -0
- package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.ts +27 -1
- package/src/libs/feature/record/src/lib/data-view/data-view.component.html +2 -0
- package/src/libs/feature/record/src/lib/map-view/map-view.component.html +4 -1
- package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +35 -4
- package/src/libs/feature/record/src/lib/state/mdview.facade.ts +18 -15
- package/src/libs/ui/dataviz/src/lib/chart/chart.component.ts +2 -1
- package/src/libs/ui/dataviz/src/lib/data-table/data-table.component.html +6 -3
- package/src/libs/ui/dataviz/src/lib/data-table/data-table.component.ts +5 -4
- package/src/libs/ui/elements/src/index.ts +1 -0
- package/src/libs/ui/elements/src/lib/metadata-contact/metadata-contact.component.html +6 -3
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +4 -0
- package/src/libs/ui/elements/src/lib/record-feature-catalog/feature-catalog-list/feature-catalog-list.component.html +48 -0
- package/src/libs/ui/elements/src/lib/record-feature-catalog/feature-catalog-list/feature-catalog-list.component.ts +52 -0
- package/src/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.html +15 -1
- package/src/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.ts +9 -1
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +0 -1
- package/src/libs/ui/inputs/src/index.ts +1 -0
- package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.css +0 -0
- package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.html +43 -0
- package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.ts +77 -0
- package/src/libs/ui/layout/src/lib/expandable-panel/expandable-panel.component.html +24 -8
- package/src/libs/ui/layout/src/lib/expandable-panel/expandable-panel.component.ts +36 -10
- package/src/libs/ui/layout/src/lib/truncated-text/truncated-text.component.html +8 -10
- package/src/libs/ui/layout/src/lib/truncated-text/truncated-text.component.ts +75 -7
- package/src/libs/ui/map/src/lib/components/feature-detail/feature-detail.component.html +3 -3
- package/src/libs/ui/map/src/lib/components/feature-detail/feature-detail.component.ts +27 -3
- package/src/libs/ui/search/src/lib/results-list/results-list.component.html +1 -0
- package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +3 -0
- package/src/libs/util/shared/src/lib/links/link-utils.ts +3 -0
- package/translations/de.json +5 -0
- package/translations/en.json +5 -2
- package/translations/es.json +5 -0
- package/translations/fr.json +5 -2
- package/translations/it.json +38 -33
- package/translations/nl.json +5 -0
- package/translations/pt.json +5 -0
- package/translations/sk.json +5 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"link-utils.d.ts","sourceRoot":"","sources":["../../../../../../src/libs/util/shared/src/lib/links/link-utils.ts"],"names":[],"mappings":"AACA,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,eAAe,EAChB,MAAM,2DAA2D,CAAA;AAUlE,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgHV,CAAA;AAEV,MAAM,MAAM,UAAU,GAAG,MAAM,OAAO,OAAO,CAAA;AAE7C,wBAAgB,iBAAiB,CAAC,UAAU,EAAE,UAAU,GAAG,MAAM,CAUhE;AAED,wBAAgB,eAAe,CAC7B,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,GAClD,MAAM,CAER;AAED,wBAAgB,8BAA8B,CAC5C,aAAa,EAAE,MAAM,GACpB,UAAU,GAAG,IAAI,CAgBnB;AAED,wBAAgB,aAAa,CAC3B,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,GAClD,UAAU,CAcZ;AAED,wBAAgB,oBAAoB,CAClC,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,EACnD,KAAK,EAAE,MAAM,GACZ,OAAO,CAQT;AAED,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,UAAU,CAO7D;AAED,wBAAgB,eAAe,CAC7B,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,EACnD,MAAM,EAAE,UAAU,GACjB,OAAO,CAQT;AAED,wBAAgB,aAAa,CAAC,UAAU,EAAE,UAAU,GAAG,MAAM,CAQ5D;AAED,wBAAgB,YAAY,CAC1B,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,GAClD,MAAM,
|
|
1
|
+
{"version":3,"file":"link-utils.d.ts","sourceRoot":"","sources":["../../../../../../src/libs/util/shared/src/lib/links/link-utils.ts"],"names":[],"mappings":"AACA,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,eAAe,EAChB,MAAM,2DAA2D,CAAA;AAUlE,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgHV,CAAA;AAEV,MAAM,MAAM,UAAU,GAAG,MAAM,OAAO,OAAO,CAAA;AAE7C,wBAAgB,iBAAiB,CAAC,UAAU,EAAE,UAAU,GAAG,MAAM,CAUhE;AAED,wBAAgB,eAAe,CAC7B,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,GAClD,MAAM,CAER;AAED,wBAAgB,8BAA8B,CAC5C,aAAa,EAAE,MAAM,GACpB,UAAU,GAAG,IAAI,CAgBnB;AAED,wBAAgB,aAAa,CAC3B,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,GAClD,UAAU,CAcZ;AAED,wBAAgB,oBAAoB,CAClC,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,EACnD,KAAK,EAAE,MAAM,GACZ,OAAO,CAQT;AAED,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,UAAU,CAO7D;AAED,wBAAgB,eAAe,CAC7B,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,EACnD,MAAM,EAAE,UAAU,GACjB,OAAO,CAQT;AAED,wBAAgB,aAAa,CAAC,UAAU,EAAE,UAAU,GAAG,MAAM,CAQ5D;AAED,wBAAgB,YAAY,CAC1B,IAAI,EAAE,qBAAqB,GAAG,qBAAqB,GAClD,MAAM,CA6BR;AAED,wBAAsB,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,eAAe,EAAE,eAAe;;;;;;8JAmC5E;AAED,wBAAgB,eAAe,CAAC,SAAS,KAAA,SAUxC;AAED,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,UAAU,GAAG,MAAM,GAAG,IAAI,CAEtE"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "geonetwork-ui",
|
|
3
|
-
"version": "2.6.0-dev.
|
|
3
|
+
"version": "2.6.0-dev.d8333ac5d",
|
|
4
4
|
"engines": {
|
|
5
5
|
"node": ">=20"
|
|
6
6
|
},
|
|
@@ -62,7 +62,7 @@
|
|
|
62
62
|
"@nx/angular": "20.2.2",
|
|
63
63
|
"@rgrove/parse-xml": "4.2.0",
|
|
64
64
|
"alasql": "4.6.0",
|
|
65
|
-
"axios": "1.
|
|
65
|
+
"axios": "1.8.2",
|
|
66
66
|
"basiclightbox": "^5.0.4",
|
|
67
67
|
"chart.js": "4.4.7",
|
|
68
68
|
"chroma-js": "3.1.2",
|
|
@@ -4,6 +4,7 @@ export function matchProtocol(protocol: string): ServiceProtocol {
|
|
|
4
4
|
if (/wms/i.test(protocol)) return 'wms'
|
|
5
5
|
if (/wfs/i.test(protocol)) return 'wfs'
|
|
6
6
|
if (/wmts/i.test(protocol)) return 'wmts'
|
|
7
|
+
if (/tms/i.test(protocol)) return 'tms'
|
|
7
8
|
if (/wps/i.test(protocol)) return 'wps'
|
|
8
9
|
if (/ogc\W*api\W*features/i.test(protocol)) return 'ogcFeatures'
|
|
9
10
|
if (/esri/i.test(protocol)) return 'esriRest'
|
|
@@ -430,6 +430,7 @@ export class Gn4FieldMapper {
|
|
|
430
430
|
/^OGC:WMS/.test(protocol) ||
|
|
431
431
|
/^OGC:WFS/.test(protocol) ||
|
|
432
432
|
/^OGC:WMTS/.test(protocol) ||
|
|
433
|
+
/TMS/i.test(protocol) ||
|
|
433
434
|
/ogc\W*api\W*features/i.test(protocol) ||
|
|
434
435
|
(/^WWW:DOWNLOAD-/.test(protocol) && /data.geopf.fr/.test(url)) // TO DO : change with the good protocol when decided
|
|
435
436
|
) {
|
|
@@ -152,7 +152,9 @@ export class Gn4Repository implements RecordsRepositoryInterface {
|
|
|
152
152
|
attributes: Array.isArray(featureType.attributeTable)
|
|
153
153
|
? featureType.attributeTable.map((attr) => ({
|
|
154
154
|
name: attr.name,
|
|
155
|
+
code: attr.code,
|
|
155
156
|
title: attr.definition,
|
|
157
|
+
type: attr.type,
|
|
156
158
|
}))
|
|
157
159
|
: [],
|
|
158
160
|
})),
|
|
@@ -164,7 +166,8 @@ export class Gn4Repository implements RecordsRepositoryInterface {
|
|
|
164
166
|
): Observable<DatasetFeatureCatalog | null> {
|
|
165
167
|
if (
|
|
166
168
|
record.extras?.['featureTypes'] &&
|
|
167
|
-
Array.isArray(record.extras['featureTypes'])
|
|
169
|
+
Array.isArray(record.extras['featureTypes']) &&
|
|
170
|
+
record.extras['featureTypes'].length > 0
|
|
168
171
|
) {
|
|
169
172
|
return of(this.mapEmbeddedFeatureCatalog(record.extras['featureTypes']))
|
|
170
173
|
}
|
|
@@ -152,6 +152,8 @@ export type ServiceProtocol =
|
|
|
152
152
|
| 'esriRest'
|
|
153
153
|
| 'ogcFeatures'
|
|
154
154
|
| 'GPFDL'
|
|
155
|
+
| 'tms'
|
|
156
|
+
| 'maplibre-style'
|
|
155
157
|
| 'other'
|
|
156
158
|
|
|
157
159
|
export type OnlineResourceType = 'service' | 'download' | 'link' | 'endpoint'
|
|
@@ -235,7 +237,7 @@ export type DatasetFeatureCatalog = {
|
|
|
235
237
|
featureTypes: Array<{
|
|
236
238
|
name: string
|
|
237
239
|
definition: string
|
|
238
|
-
attributes: Array<{ name: string; title: string }>
|
|
240
|
+
attributes: Array<{ name: string; title: string; code: string }>
|
|
239
241
|
}>
|
|
240
242
|
}
|
|
241
243
|
|
|
@@ -272,7 +274,12 @@ export interface DatasetFeatureType {
|
|
|
272
274
|
isAbstract: string
|
|
273
275
|
typeName: string
|
|
274
276
|
definition: string
|
|
275
|
-
attributeTable: Array<{
|
|
277
|
+
attributeTable: Array<{
|
|
278
|
+
name: string
|
|
279
|
+
definition: string
|
|
280
|
+
type: string
|
|
281
|
+
code: string
|
|
282
|
+
}>
|
|
276
283
|
}
|
|
277
284
|
|
|
278
285
|
export type ReuseType = 'application' | 'map' | 'other'
|
|
@@ -144,4 +144,14 @@ export const elasticLinkFixture = (): Record<string, unknown> => ({
|
|
|
144
144
|
name: 'ogcapi features layer',
|
|
145
145
|
url: 'https://mel.integration.apps.gs-fr-prod.camptocamp.com/data/ogcapi/collections/comptages_velo/items?',
|
|
146
146
|
},
|
|
147
|
+
maplayerTms: {
|
|
148
|
+
accessServiceProtocol: 'TMS',
|
|
149
|
+
name: 'mytmslayer',
|
|
150
|
+
url: 'https://my.tms.server/MapServer',
|
|
151
|
+
},
|
|
152
|
+
maplayerTms2: {
|
|
153
|
+
accessServiceProtocol: 'OSGeo:TMS',
|
|
154
|
+
name: 'myothertmslayer',
|
|
155
|
+
url: 'https://my.tms.server/MapServer',
|
|
156
|
+
},
|
|
147
157
|
})
|
|
@@ -185,6 +185,20 @@ export const aSetOfLinksFixture = () => ({
|
|
|
185
185
|
url: new URL('https://my.ogc.server/wms'),
|
|
186
186
|
accessServiceProtocol: 'wms',
|
|
187
187
|
}) as DatasetServiceDistribution,
|
|
188
|
+
geodataTms: () =>
|
|
189
|
+
({
|
|
190
|
+
name: 'mytmslayer',
|
|
191
|
+
type: 'service',
|
|
192
|
+
url: new URL('https://my.ogc.server/tms'),
|
|
193
|
+
accessServiceProtocol: 'tms',
|
|
194
|
+
}) as DatasetServiceDistribution,
|
|
195
|
+
geodataAsMaplibreStyle: () =>
|
|
196
|
+
({
|
|
197
|
+
name: 'mytmslayerAsMaplibreJson',
|
|
198
|
+
type: 'service',
|
|
199
|
+
url: new URL('https://my.ogc.server/tms/layer/style.json'),
|
|
200
|
+
accessServiceProtocol: 'maplibre-style',
|
|
201
|
+
}) as DatasetServiceDistribution,
|
|
188
202
|
geodataWfs2: () =>
|
|
189
203
|
({
|
|
190
204
|
name: 'myotherlayer',
|
|
@@ -18,15 +18,17 @@
|
|
|
18
18
|
[selected]="xProperty$.value"
|
|
19
19
|
[title]="'chart.dropdown.xProperty' | translate"
|
|
20
20
|
></gn-ui-dropdown-selector>
|
|
21
|
-
<
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
21
|
+
<ng-container *ngIf="yChoices$ | async as yChoices">
|
|
22
|
+
<gn-ui-dropdown-selector
|
|
23
|
+
class="basis-1/4"
|
|
24
|
+
*ngIf="!isCountAggregation"
|
|
25
|
+
[choices]="yChoices"
|
|
26
|
+
(selectValue)="yProperty$.next($event)"
|
|
27
|
+
[selected]="yProperty$.value"
|
|
28
|
+
[title]="'chart.dropdown.yProperty' | translate"
|
|
29
|
+
class="select-y-prop"
|
|
30
|
+
></gn-ui-dropdown-selector>
|
|
31
|
+
</ng-container>
|
|
30
32
|
<gn-ui-dropdown-selector
|
|
31
33
|
class="basis-1/4"
|
|
32
34
|
[choices]="aggregationChoices"
|
|
@@ -43,6 +45,7 @@
|
|
|
43
45
|
*ngIf="!error"
|
|
44
46
|
[data]="chartData$ | async"
|
|
45
47
|
[type]="chartType$.value"
|
|
48
|
+
[prettyLabel]="prettyLabel$ | async"
|
|
46
49
|
[labelProperty]="labelProperty"
|
|
47
50
|
[valueProperty]="valueProperty"
|
|
48
51
|
></gn-ui-chart>
|
|
@@ -2,9 +2,7 @@ import {
|
|
|
2
2
|
ChangeDetectionStrategy,
|
|
3
3
|
ChangeDetectorRef,
|
|
4
4
|
Component,
|
|
5
|
-
Inject,
|
|
6
5
|
Input,
|
|
7
|
-
Optional,
|
|
8
6
|
Output,
|
|
9
7
|
} from '@angular/core'
|
|
10
8
|
import { marker } from '@biesbjerg/ngx-translate-extract-marker'
|
|
@@ -13,6 +11,7 @@ import {
|
|
|
13
11
|
FetchError,
|
|
14
12
|
FieldAggregation,
|
|
15
13
|
getJsonDataItemsProxy,
|
|
14
|
+
PropertyInfo,
|
|
16
15
|
} from '../../../../../../libs/util/data-fetcher/src'
|
|
17
16
|
import {
|
|
18
17
|
DropdownChoice,
|
|
@@ -30,7 +29,10 @@ import {
|
|
|
30
29
|
} from 'rxjs/operators'
|
|
31
30
|
import { DataService } from '../service/data.service'
|
|
32
31
|
import { InputChartType } from '../../../../../../libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model'
|
|
33
|
-
import {
|
|
32
|
+
import {
|
|
33
|
+
DatasetFeatureCatalog,
|
|
34
|
+
DatasetOnlineResource,
|
|
35
|
+
} from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
34
36
|
import { TranslateModule, TranslateService } from '@ngx-translate/core'
|
|
35
37
|
import { CommonModule } from '@angular/common'
|
|
36
38
|
import { ChartComponent } from '../../../../../../libs/ui/dataviz/src'
|
|
@@ -67,9 +69,18 @@ marker('chart.aggregation.count')
|
|
|
67
69
|
standalone: true,
|
|
68
70
|
})
|
|
69
71
|
export class ChartViewComponent {
|
|
72
|
+
public featureCatalog$ = new BehaviorSubject<DatasetFeatureCatalog | null>(
|
|
73
|
+
null
|
|
74
|
+
)
|
|
75
|
+
@Input() set featureCatalog(value: DatasetFeatureCatalog) {
|
|
76
|
+
this.featureCatalog$.next(value)
|
|
77
|
+
}
|
|
70
78
|
@Input() cacheActive = true
|
|
71
79
|
@Input() set link(value: DatasetOnlineResource) {
|
|
72
80
|
this.currentLink$.next(value)
|
|
81
|
+
if (value) {
|
|
82
|
+
this.aggregation$.next('sum')
|
|
83
|
+
}
|
|
73
84
|
}
|
|
74
85
|
private currentLink$ = new BehaviorSubject<DatasetOnlineResource>(null)
|
|
75
86
|
|
|
@@ -150,13 +161,8 @@ export class ChartViewComponent {
|
|
|
150
161
|
}),
|
|
151
162
|
shareReplay(1)
|
|
152
163
|
)
|
|
153
|
-
properties$ = this.dataset
|
|
154
|
-
switchMap((dataset) =>
|
|
155
|
-
dataset.properties.catch((error) => {
|
|
156
|
-
this.handleError(error)
|
|
157
|
-
return []
|
|
158
|
-
})
|
|
159
|
-
),
|
|
164
|
+
properties$ = combineLatest([this.dataset$, this.featureCatalog$]).pipe(
|
|
165
|
+
switchMap(([dataset, catalog]) => this.setProperties(dataset, catalog)),
|
|
160
166
|
shareReplay(1)
|
|
161
167
|
)
|
|
162
168
|
yChoices$ = this.properties$.pipe(
|
|
@@ -197,6 +203,7 @@ export class ChartViewComponent {
|
|
|
197
203
|
this.yProperty$.pipe(filter((value) => value !== undefined)),
|
|
198
204
|
this.aggregation$,
|
|
199
205
|
]).pipe(
|
|
206
|
+
filter(([_, x, y]) => !!x || !!y),
|
|
200
207
|
switchMap(([dataset, xProp, yProp, aggregation]) => {
|
|
201
208
|
const fieldAgg: FieldAggregation =
|
|
202
209
|
aggregation === 'count' ? ['count'] : [aggregation, yProp]
|
|
@@ -217,6 +224,18 @@ export class ChartViewComponent {
|
|
|
217
224
|
shareReplay(1)
|
|
218
225
|
)
|
|
219
226
|
|
|
227
|
+
prettyLabel$ = combineLatest([
|
|
228
|
+
this.aggregation$,
|
|
229
|
+
this.properties$,
|
|
230
|
+
this.yProperty$,
|
|
231
|
+
]).pipe(
|
|
232
|
+
map(([aggregation, properties, yProperty]) => {
|
|
233
|
+
if (aggregation === 'count') return 'count()'
|
|
234
|
+
const prop = properties.find((p) => p.name === yProperty)
|
|
235
|
+
return prop ? `${aggregation}(${prop.label})` : ''
|
|
236
|
+
})
|
|
237
|
+
)
|
|
238
|
+
|
|
220
239
|
get labelProperty() {
|
|
221
240
|
if (!this.xProperty$.value) return ''
|
|
222
241
|
return `distinct(${this.xProperty$.value})`
|
|
@@ -235,6 +254,31 @@ export class ChartViewComponent {
|
|
|
235
254
|
private translateService: TranslateService
|
|
236
255
|
) {}
|
|
237
256
|
|
|
257
|
+
setProperties(
|
|
258
|
+
dataset: BaseReader,
|
|
259
|
+
catalog: DatasetFeatureCatalog
|
|
260
|
+
): Promise<PropertyInfo[]> {
|
|
261
|
+
return dataset.properties
|
|
262
|
+
.then((properties) => {
|
|
263
|
+
return properties.map((p) => {
|
|
264
|
+
if (catalog) {
|
|
265
|
+
const featureAttributes = catalog?.featureTypes[0]?.attributes ?? []
|
|
266
|
+
const matchingAttribute = featureAttributes.find(
|
|
267
|
+
(attr) => attr.name === p.label
|
|
268
|
+
)
|
|
269
|
+
if (matchingAttribute?.code) {
|
|
270
|
+
return { ...p, label: matchingAttribute.code }
|
|
271
|
+
}
|
|
272
|
+
return p
|
|
273
|
+
}
|
|
274
|
+
return p
|
|
275
|
+
})
|
|
276
|
+
})
|
|
277
|
+
.catch((error) => {
|
|
278
|
+
this.handleError(error)
|
|
279
|
+
return []
|
|
280
|
+
})
|
|
281
|
+
}
|
|
238
282
|
handleError(error: FetchError | Error | string) {
|
|
239
283
|
if (error instanceof FetchError) {
|
|
240
284
|
this.error = this.translateService.instant(
|
|
@@ -6,6 +6,7 @@ import {
|
|
|
6
6
|
OgcApiRecord,
|
|
7
7
|
WfsEndpoint,
|
|
8
8
|
WfsVersion,
|
|
9
|
+
TmsEndpoint,
|
|
9
10
|
} from '@camptocamp/ogc-client'
|
|
10
11
|
import {
|
|
11
12
|
BaseReader,
|
|
@@ -231,6 +232,42 @@ export class DataService {
|
|
|
231
232
|
})
|
|
232
233
|
}
|
|
233
234
|
|
|
235
|
+
async getGeodataLinksFromTms(
|
|
236
|
+
tmsLink: DatasetServiceDistribution,
|
|
237
|
+
keepOriginalLink = false
|
|
238
|
+
): Promise<DatasetServiceDistribution[]> {
|
|
239
|
+
const endpoint = new TmsEndpoint(tmsLink.url.toString())
|
|
240
|
+
const tileMaps = await endpoint.allTileMaps
|
|
241
|
+
if (!tileMaps?.length) return null
|
|
242
|
+
|
|
243
|
+
// TODO: at some point use the identifierInService field if more that one layers in the TMS service
|
|
244
|
+
const tileMapInfo = await endpoint.getTileMapInfo(tileMaps[0].href)
|
|
245
|
+
|
|
246
|
+
// case 1: no styles; return a plain TMS link
|
|
247
|
+
if (!tileMapInfo?.metadata?.length) return [tmsLink]
|
|
248
|
+
|
|
249
|
+
// case 2: styles present; return each as a separate link
|
|
250
|
+
const styleLinks = tileMapInfo.metadata
|
|
251
|
+
.filter((meta) => meta.href)
|
|
252
|
+
.map((meta) => {
|
|
253
|
+
const fileName = meta.href.split('/').pop() || ''
|
|
254
|
+
const linkName =
|
|
255
|
+
tmsLink.description || ('name' in tmsLink ? tmsLink.name : '')
|
|
256
|
+
const styleName = fileName.split('.')[0]
|
|
257
|
+
const name = `${linkName} - ${styleName}`
|
|
258
|
+
return {
|
|
259
|
+
type: 'service',
|
|
260
|
+
url: new URL(meta.href),
|
|
261
|
+
name,
|
|
262
|
+
accessServiceProtocol: 'maplibre-style',
|
|
263
|
+
} as DatasetServiceDistribution
|
|
264
|
+
})
|
|
265
|
+
if (keepOriginalLink) {
|
|
266
|
+
styleLinks.unshift(tmsLink)
|
|
267
|
+
}
|
|
268
|
+
return styleLinks
|
|
269
|
+
}
|
|
270
|
+
|
|
234
271
|
getDownloadLinksFromEsriRest(
|
|
235
272
|
esriRestLink: DatasetServiceDistribution
|
|
236
273
|
): DatasetOnlineResource[] {
|
|
@@ -6,11 +6,15 @@ import {
|
|
|
6
6
|
shareReplay,
|
|
7
7
|
startWith,
|
|
8
8
|
switchMap,
|
|
9
|
+
tap,
|
|
9
10
|
} from 'rxjs/operators'
|
|
10
11
|
import { BaseReader, FetchError } from '../../../../../../libs/util/data-fetcher/src'
|
|
11
12
|
import { DataService } from '../service/data.service'
|
|
12
13
|
import { DataTableComponent } from '../../../../../../libs/ui/dataviz/src'
|
|
13
|
-
import {
|
|
14
|
+
import {
|
|
15
|
+
DatasetFeatureCatalog,
|
|
16
|
+
DatasetOnlineResource,
|
|
17
|
+
} from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
14
18
|
import { TranslateModule, TranslateService } from '@ngx-translate/core'
|
|
15
19
|
import {
|
|
16
20
|
LoadingMaskComponent,
|
|
@@ -33,6 +37,8 @@ import { CommonModule } from '@angular/common'
|
|
|
33
37
|
standalone: true,
|
|
34
38
|
})
|
|
35
39
|
export class TableViewComponent {
|
|
40
|
+
featureAttributes = []
|
|
41
|
+
@Input() featureCatalog: DatasetFeatureCatalog
|
|
36
42
|
@Input() cacheActive = true
|
|
37
43
|
@Input() set link(value: DatasetOnlineResource) {
|
|
38
44
|
this.currentLink$.next(value)
|
|
@@ -52,6 +58,7 @@ export class TableViewComponent {
|
|
|
52
58
|
}
|
|
53
59
|
this.loading = true
|
|
54
60
|
return this.getDatasetReader(link).pipe(
|
|
61
|
+
tap((dataset: BaseReader) => this.setProperties(dataset)),
|
|
55
62
|
catchError((error) => {
|
|
56
63
|
this.handleError(error)
|
|
57
64
|
return of(undefined)
|
|
@@ -96,4 +103,23 @@ export class TableViewComponent {
|
|
|
96
103
|
}
|
|
97
104
|
this.loading = false
|
|
98
105
|
}
|
|
106
|
+
|
|
107
|
+
setProperties(dataset: BaseReader) {
|
|
108
|
+
dataset.properties.then((properties) => {
|
|
109
|
+
const updatedProperties = properties.map((p) => {
|
|
110
|
+
let label = p.name
|
|
111
|
+
if (this.featureCatalog) {
|
|
112
|
+
const attributes = this.featureCatalog.featureTypes[0].attributes
|
|
113
|
+
const matchingAttribute = attributes.find(
|
|
114
|
+
(attr) => attr.name === p.name
|
|
115
|
+
)
|
|
116
|
+
if (matchingAttribute && matchingAttribute.code) {
|
|
117
|
+
label = matchingAttribute.code
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
return { value: p.name, label }
|
|
121
|
+
})
|
|
122
|
+
this.featureAttributes = updatedProperties
|
|
123
|
+
})
|
|
124
|
+
}
|
|
99
125
|
}
|
|
@@ -27,12 +27,14 @@
|
|
|
27
27
|
*ngIf="mode === 'table'"
|
|
28
28
|
[cacheActive]="cacheActive$ | async"
|
|
29
29
|
[link]="selectedLink$ | async"
|
|
30
|
+
[featureCatalog]="mdViewFacade.featureCatalog$ | async"
|
|
30
31
|
></gn-ui-table-view>
|
|
31
32
|
<gn-ui-chart-view
|
|
32
33
|
*ngIf="mode === 'chart'"
|
|
33
34
|
(chartConfig$)="setChartConfig($event)"
|
|
34
35
|
[cacheActive]="cacheActive$ | async"
|
|
35
36
|
[link]="selectedLink$ | async"
|
|
37
|
+
[featureCatalog]="mdViewFacade.featureCatalog$ | async"
|
|
36
38
|
></gn-ui-chart-view>
|
|
37
39
|
</div>
|
|
38
40
|
</ng-template>
|
|
@@ -55,7 +55,10 @@
|
|
|
55
55
|
>
|
|
56
56
|
<ng-icon name="matClose" class="align-middle text-sm"></ng-icon>
|
|
57
57
|
</gn-ui-button>
|
|
58
|
-
<gn-ui-feature-detail
|
|
58
|
+
<gn-ui-feature-detail
|
|
59
|
+
[featureCatalog]="mdViewFacade.featureCatalog$ | async"
|
|
60
|
+
[feature]="selection"
|
|
61
|
+
></gn-ui-feature-detail>
|
|
59
62
|
</div>
|
|
60
63
|
|
|
61
64
|
<div
|
|
@@ -39,8 +39,8 @@ import {
|
|
|
39
39
|
import {
|
|
40
40
|
FeatureDetailComponent,
|
|
41
41
|
MapContainerComponent,
|
|
42
|
-
prioritizePageScroll,
|
|
43
42
|
MapLegendComponent,
|
|
43
|
+
prioritizePageScroll,
|
|
44
44
|
} from '../../../../../../libs/ui/map/src'
|
|
45
45
|
import { Feature } from 'geojson'
|
|
46
46
|
import { NgIconComponent, provideIcons } from '@ng-icons/core'
|
|
@@ -109,9 +109,20 @@ export class MapViewComponent implements AfterViewInit {
|
|
|
109
109
|
this.mdViewFacade.mapApiLinks$,
|
|
110
110
|
this.mdViewFacade.geoDataLinksWithGeometry$,
|
|
111
111
|
]).pipe(
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
112
|
+
switchMap(async ([mapApiLinks, geoDataLinksWithGeometry]) => {
|
|
113
|
+
// looking for TMS links to process
|
|
114
|
+
let processedMapApiLinks = await Promise.all(
|
|
115
|
+
mapApiLinks.map((link) => {
|
|
116
|
+
if (link.type === 'service' && link.accessServiceProtocol === 'tms') {
|
|
117
|
+
return this.dataService.getGeodataLinksFromTms(link)
|
|
118
|
+
}
|
|
119
|
+
return link
|
|
120
|
+
})
|
|
121
|
+
)
|
|
122
|
+
processedMapApiLinks = processedMapApiLinks.flat()
|
|
123
|
+
return [...processedMapApiLinks, ...geoDataLinksWithGeometry]
|
|
124
|
+
}),
|
|
125
|
+
shareReplay(1)
|
|
115
126
|
)
|
|
116
127
|
|
|
117
128
|
dropdownChoices$ = this.compatibleMapLinks$.pipe(
|
|
@@ -239,6 +250,26 @@ export class MapViewComponent implements AfterViewInit {
|
|
|
239
250
|
type: 'wms',
|
|
240
251
|
name: link.name,
|
|
241
252
|
})
|
|
253
|
+
} else if (
|
|
254
|
+
link.type === 'service' &&
|
|
255
|
+
link.accessServiceProtocol === 'tms'
|
|
256
|
+
) {
|
|
257
|
+
// FIXME: here we're assuming that the TMS serves vector tiles only; should be checked with ogc-client first
|
|
258
|
+
return of({
|
|
259
|
+
url: link.url.toString().replace(/\/?$/, '/{z}/{x}/{y}.pbf'),
|
|
260
|
+
type: 'xyz',
|
|
261
|
+
tileFormat: 'application/vnd.mapbox-vector-tile',
|
|
262
|
+
name: link.name,
|
|
263
|
+
})
|
|
264
|
+
} else if (
|
|
265
|
+
link.type === 'service' &&
|
|
266
|
+
link.accessServiceProtocol === 'maplibre-style'
|
|
267
|
+
) {
|
|
268
|
+
return of({
|
|
269
|
+
type: 'maplibre-style',
|
|
270
|
+
name: link.name,
|
|
271
|
+
styleUrl: link.url.toString(),
|
|
272
|
+
})
|
|
242
273
|
} else if (
|
|
243
274
|
link.type === 'service' &&
|
|
244
275
|
link.accessServiceProtocol === 'wmts'
|
|
@@ -6,6 +6,7 @@ import {
|
|
|
6
6
|
filter,
|
|
7
7
|
map,
|
|
8
8
|
mergeMap,
|
|
9
|
+
shareReplay,
|
|
9
10
|
switchMap,
|
|
10
11
|
toArray,
|
|
11
12
|
} from 'rxjs/operators'
|
|
@@ -15,13 +16,11 @@ import { LinkClassifierService, LinkUsage } from '../../../../../../libs/util/sh
|
|
|
15
16
|
import { DatavizConfigurationModel } from '../../../../../../libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model'
|
|
16
17
|
import {
|
|
17
18
|
CatalogRecord,
|
|
18
|
-
DatasetServiceDistribution,
|
|
19
|
-
ServiceEndpoint,
|
|
20
19
|
UserFeedback,
|
|
21
20
|
} from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
22
21
|
import { AvatarServiceInterface } from '../../../../../../libs/api/repository/src'
|
|
23
22
|
import { OgcApiRecord } from '@camptocamp/ogc-client'
|
|
24
|
-
import { from, of } from 'rxjs'
|
|
23
|
+
import { from, of, Observable } from 'rxjs'
|
|
25
24
|
import { DataService } from '../../../../../../libs/feature/dataviz/src'
|
|
26
25
|
|
|
27
26
|
@Injectable()
|
|
@@ -80,21 +79,17 @@ export class MdViewFacade {
|
|
|
80
79
|
chartConfig$ = this.store.pipe(select(MdViewSelectors.getChartConfig))
|
|
81
80
|
|
|
82
81
|
allLinks$ = this.metadata$.pipe(
|
|
83
|
-
map((record) =>
|
|
82
|
+
map((record) =>
|
|
83
|
+
'onlineResources' in record ? record.onlineResources : []
|
|
84
|
+
),
|
|
85
|
+
shareReplay(1)
|
|
84
86
|
)
|
|
85
87
|
|
|
86
88
|
apiLinks$ = this.allLinks$.pipe(
|
|
87
89
|
map((links) =>
|
|
88
|
-
links
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
.sort((dd1, dd2) => {
|
|
92
|
-
return (dd2 as DatasetServiceDistribution | ServiceEndpoint)
|
|
93
|
-
.accessServiceProtocol === 'GPFDL'
|
|
94
|
-
? 1
|
|
95
|
-
: undefined // do not change the sorting otherwise
|
|
96
|
-
})
|
|
97
|
-
)
|
|
90
|
+
links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.API))
|
|
91
|
+
),
|
|
92
|
+
shareReplay(1)
|
|
98
93
|
)
|
|
99
94
|
|
|
100
95
|
mapApiLinks$ = this.allLinks$.pipe(
|
|
@@ -102,7 +97,8 @@ export class MdViewFacade {
|
|
|
102
97
|
links.filter((link) =>
|
|
103
98
|
this.linkClassifier.hasUsage(link, LinkUsage.MAP_API)
|
|
104
99
|
)
|
|
105
|
-
)
|
|
100
|
+
),
|
|
101
|
+
shareReplay(1)
|
|
106
102
|
)
|
|
107
103
|
|
|
108
104
|
downloadLinks$ = this.allLinks$.pipe(
|
|
@@ -216,4 +212,11 @@ export class MdViewFacade {
|
|
|
216
212
|
loadUserFeedbacks(datasetUuid: string) {
|
|
217
213
|
this.store.dispatch(MdViewActions.loadUserFeedbacks({ datasetUuid }))
|
|
218
214
|
}
|
|
215
|
+
|
|
216
|
+
/**
|
|
217
|
+
* loadFeatureCatalog
|
|
218
|
+
*/
|
|
219
|
+
loadFeatureCatalog(metadata: CatalogRecord) {
|
|
220
|
+
this.store.dispatch(MdViewActions.loadFeatureCatalog({ metadata }))
|
|
221
|
+
}
|
|
219
222
|
}
|
|
@@ -57,6 +57,7 @@ export class ChartComponent implements OnChanges, AfterViewInit {
|
|
|
57
57
|
this.dataRaw = value
|
|
58
58
|
}
|
|
59
59
|
@Input() labelProperty: string
|
|
60
|
+
@Input() prettyLabel: string
|
|
60
61
|
@Input() valueProperty: string
|
|
61
62
|
@Input() secondaryValueProperty: string
|
|
62
63
|
@Input() type: InputChartType = 'bar'
|
|
@@ -95,7 +96,7 @@ export class ChartComponent implements OnChanges, AfterViewInit {
|
|
|
95
96
|
labels: this.getDataProxy(this.labelProperty) as string[],
|
|
96
97
|
datasets: [
|
|
97
98
|
{
|
|
98
|
-
label: this.
|
|
99
|
+
label: this.prettyLabel,
|
|
99
100
|
data,
|
|
100
101
|
},
|
|
101
102
|
],
|
|
@@ -8,21 +8,24 @@
|
|
|
8
8
|
[matSortDisableClear]="true"
|
|
9
9
|
*ngrxLet="properties$ as properties"
|
|
10
10
|
>
|
|
11
|
-
<ng-container
|
|
11
|
+
<ng-container
|
|
12
|
+
*ngFor="let attr of _featureAttributes"
|
|
13
|
+
[matColumnDef]="attr.value"
|
|
14
|
+
>
|
|
12
15
|
<th
|
|
13
16
|
mat-header-cell
|
|
14
17
|
*matHeaderCellDef
|
|
15
18
|
mat-sort-header
|
|
16
19
|
class="text-sm text-black bg-white"
|
|
17
20
|
>
|
|
18
|
-
{{
|
|
21
|
+
{{ attr.label }}
|
|
19
22
|
</th>
|
|
20
23
|
<td
|
|
21
24
|
mat-cell
|
|
22
25
|
*matCellDef="let element"
|
|
23
26
|
class="whitespace-nowrap pr-1 truncate"
|
|
24
27
|
>
|
|
25
|
-
{{ element[
|
|
28
|
+
{{ element[attr.value] }}
|
|
26
29
|
</td>
|
|
27
30
|
</ng-container>
|
|
28
31
|
|
|
@@ -61,13 +61,14 @@ export interface TableItemModel {
|
|
|
61
61
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
62
62
|
})
|
|
63
63
|
export class DataTableComponent implements OnInit, AfterViewInit, OnChanges {
|
|
64
|
+
_featureAttributes = []
|
|
65
|
+
@Input() set featureAttributes(value: { value: string; label: string }[]) {
|
|
66
|
+
this._featureAttributes = value
|
|
67
|
+
this.properties$.next(value.map((attr) => attr.value))
|
|
68
|
+
}
|
|
64
69
|
@Input() set dataset(value: BaseReader) {
|
|
65
|
-
this.properties$.next(null)
|
|
66
70
|
this.dataset_ = value
|
|
67
71
|
this.dataset_.load()
|
|
68
|
-
this.dataset_.properties.then((properties) =>
|
|
69
|
-
this.properties$.next(properties.map((p) => p.name))
|
|
70
|
-
)
|
|
71
72
|
this.dataset_.info.then((info) => (this.count = info.itemsCount))
|
|
72
73
|
}
|
|
73
74
|
@Input() activeId: TableItemId
|
|
@@ -26,3 +26,4 @@ export * from './lib/user-preview/user-preview.component'
|
|
|
26
26
|
export * from './lib/application-banner/application-banner.component'
|
|
27
27
|
export * from './lib/internal-link-card/internal-link-card.component'
|
|
28
28
|
export * from './lib/service-capabilities/service-capabilities.component'
|
|
29
|
+
export * from './lib/record-feature-catalog/feature-catalog-list/feature-catalog-list.component'
|
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
<div
|
|
2
|
-
|
|
1
|
+
<div
|
|
2
|
+
class="py-5 px-5 rounded bg-gray-100 text-black"
|
|
3
|
+
data-cy="metadata-organization"
|
|
4
|
+
>
|
|
5
|
+
<div class="grid gap-3 overflow-hidden">
|
|
3
6
|
<div>
|
|
4
7
|
<p class="text-base font-medium" translate>record.metadata.contact</p>
|
|
5
8
|
</div>
|
|
@@ -18,7 +21,7 @@
|
|
|
18
21
|
<div
|
|
19
22
|
class="font-title text-21 mr-2 cursor-pointer hover:underline"
|
|
20
23
|
(click)="onOrganizationClick()"
|
|
21
|
-
data-cy="organization-name"
|
|
24
|
+
data-cy="organization-name-link"
|
|
22
25
|
>
|
|
23
26
|
{{ shownOrganization?.name }}
|
|
24
27
|
</div>
|