geonetwork-ui 2.6.0-dev.d216c4dea → 2.6.0-dev.e291f381d
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/index.mjs +2 -1
- package/esm2022/libs/api/metadata-converter/src/lib/common/resource-types.mjs +17 -15
- package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +2 -1
- 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/table-view/table-view.component.mjs +25 -6
- package/esm2022/libs/feature/editor/src/index.mjs +2 -1
- package/esm2022/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.mjs +18 -0
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +3 -3
- package/esm2022/libs/feature/record/src/lib/data-view-share/data-view-share.component.mjs +3 -3
- package/esm2022/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.mjs +6 -3
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +3 -3
- package/esm2022/libs/feature/search/src/index.mjs +2 -2
- package/esm2022/libs/feature/search/src/lib/feature-search.module.mjs +12 -5
- package/esm2022/libs/feature/search/src/lib/results-hits/results-hits.container.component.mjs +41 -0
- package/esm2022/libs/feature/search/src/lib/utils/service/fields.mjs +70 -1
- package/esm2022/libs/feature/search/src/lib/utils/service/fields.service.mjs +4 -3
- 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/api-card/api-card.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/download-item/download-item.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +18 -7
- package/esm2022/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/kind-badge/kind-badge.component.mjs +51 -0
- package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/metadata-catalog/metadata-catalog.component.mjs +3 -3
- 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/metadata-quality/metadata-quality.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +10 -4
- package/esm2022/libs/ui/inputs/src/index.mjs +2 -1
- package/esm2022/libs/ui/inputs/src/lib/button/button.component.mjs +2 -2
- package/esm2022/libs/ui/inputs/src/lib/dropdown-multiselect/dropdown-multiselect.component.mjs +3 -3
- package/esm2022/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.mjs +3 -3
- package/esm2022/libs/ui/inputs/src/lib/inline-filter/inline-filter.component.mjs +42 -0
- package/esm2022/libs/ui/inputs/src/lib/inline-filter/inline-filter.model.mjs +2 -0
- package/esm2022/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.mjs +3 -3
- package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +8 -9
- package/esm2022/libs/ui/layout/src/index.mjs +2 -1
- package/esm2022/libs/ui/layout/src/lib/block-list/block-list.component.mjs +48 -11
- package/esm2022/libs/ui/layout/src/lib/carousel/carousel.component.mjs +3 -3
- package/esm2022/libs/ui/layout/src/lib/max-lines/max-lines.component.mjs +3 -3
- package/esm2022/libs/ui/layout/src/lib/previous-next-buttons/previous-next-buttons.component.mjs +6 -6
- package/esm2022/libs/ui/layout/src/lib/truncated-text/truncated-text.component.mjs +56 -0
- package/esm2022/libs/ui/layout/src/lib/ui-layout.module.mjs +4 -12
- package/esm2022/libs/ui/map/src/lib/components/feature-detail/feature-detail.component.mjs +29 -4
- package/esm2022/libs/ui/map/src/lib/components/spatial-extent/spatial-extent.component.mjs +2 -1
- package/esm2022/libs/ui/search/src/index.mjs +2 -1
- package/esm2022/libs/ui/search/src/lib/results-hits-number/results-hits-number.component.mjs +3 -3
- package/esm2022/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.mjs +53 -0
- package/esm2022/libs/ui/search/src/lib/ui-search.module.mjs +11 -3
- package/esm2022/libs/ui/widgets/src/lib/progress-bar/progress-bar.component.mjs +3 -3
- package/esm2022/translations/de.json +8 -1
- package/esm2022/translations/en.json +10 -1
- package/esm2022/translations/es.json +8 -1
- package/esm2022/translations/fr.json +11 -2
- package/esm2022/translations/it.json +8 -1
- package/esm2022/translations/nl.json +8 -1
- package/esm2022/translations/pt.json +8 -1
- package/fesm2022/geonetwork-ui.mjs +639 -169
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/metadata-converter/src/index.d.ts +1 -0
- package/libs/api/metadata-converter/src/index.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/common/resource-types.d.ts +21 -0
- package/libs/api/metadata-converter/src/lib/common/resource-types.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 +2 -0
- 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/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/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/multilingual-panel/multilingual-panel.component.d.ts +7 -0
- package/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.d.ts.map +1 -0
- package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts +2 -1
- package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts.map +1 -1
- package/libs/feature/search/src/index.d.ts +1 -1
- package/libs/feature/search/src/index.d.ts.map +1 -1
- package/libs/feature/search/src/lib/feature-search.module.d.ts +4 -2
- package/libs/feature/search/src/lib/feature-search.module.d.ts.map +1 -1
- package/libs/feature/search/src/lib/results-hits/results-hits.container.component.d.ts +21 -0
- package/libs/feature/search/src/lib/results-hits/results-hits.container.component.d.ts.map +1 -0
- package/libs/feature/search/src/lib/utils/service/fields.d.ts +21 -0
- package/libs/feature/search/src/lib/utils/service/fields.d.ts.map +1 -1
- package/libs/feature/search/src/lib/utils/service/fields.service.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/download-item/download-item.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +7 -1
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/kind-badge/kind-badge.component.d.ts +11 -0
- package/libs/ui/elements/src/lib/kind-badge/kind-badge.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -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/button/button.component.d.ts +1 -1
- package/libs/ui/inputs/src/lib/button/button.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/inline-filter/inline-filter.component.d.ts +14 -0
- package/libs/ui/inputs/src/lib/inline-filter/inline-filter.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/inline-filter/inline-filter.model.d.ts +6 -0
- package/libs/ui/inputs/src/lib/inline-filter/inline-filter.model.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +25 -24
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
- package/libs/ui/layout/src/index.d.ts +1 -0
- package/libs/ui/layout/src/index.d.ts.map +1 -1
- package/libs/ui/layout/src/lib/block-list/block-list.component.d.ts +9 -2
- package/libs/ui/layout/src/lib/block-list/block-list.component.d.ts.map +1 -1
- package/libs/ui/layout/src/lib/truncated-text/truncated-text.component.d.ts +18 -0
- package/libs/ui/layout/src/lib/truncated-text/truncated-text.component.d.ts.map +1 -0
- package/libs/ui/layout/src/lib/ui-layout.module.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/ui/map/src/lib/components/spatial-extent/spatial-extent.component.d.ts.map +1 -1
- package/libs/ui/search/src/index.d.ts +1 -0
- package/libs/ui/search/src/index.d.ts.map +1 -1
- package/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.d.ts +17 -0
- package/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.d.ts.map +1 -0
- package/libs/ui/search/src/lib/ui-search.module.d.ts +21 -19
- package/libs/ui/search/src/lib/ui-search.module.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/libs/api/metadata-converter/src/index.ts +1 -0
- package/src/libs/api/metadata-converter/src/lib/common/resource-types.ts +29 -15
- package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +1 -0
- package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +2 -2
- 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/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/editor/src/index.ts +1 -0
- package/src/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.html +14 -0
- package/src/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.ts +15 -0
- package/src/libs/feature/record/src/lib/data-view/data-view.component.html +16 -10
- package/src/libs/feature/record/src/lib/data-view-share/data-view-share.component.html +1 -1
- package/src/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.html +2 -2
- package/src/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.ts +1 -0
- package/src/libs/feature/record/src/lib/map-view/map-view.component.html +25 -16
- package/src/libs/feature/search/src/index.ts +1 -1
- package/src/libs/feature/search/src/lib/feature-search.module.ts +9 -2
- package/src/libs/feature/search/src/lib/results-hits/results-hits.container.component.css +0 -0
- package/src/libs/feature/search/src/lib/results-hits/results-hits.container.component.html +16 -0
- package/src/libs/feature/search/src/lib/results-hits/results-hits.container.component.ts +59 -0
- package/src/libs/feature/search/src/lib/utils/service/fields.service.ts +4 -5
- package/src/libs/feature/search/src/lib/utils/service/fields.ts +99 -0
- 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/api-card/api-card.component.html +4 -4
- package/src/libs/ui/elements/src/lib/download-item/download-item.component.html +8 -5
- package/src/libs/ui/elements/src/lib/download-item/download-item.component.ts +2 -2
- package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.html +38 -7
- package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +29 -2
- package/src/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.html +1 -1
- package/src/libs/ui/elements/src/lib/kind-badge/kind-badge.component.css +6 -0
- package/src/libs/ui/elements/src/lib/kind-badge/kind-badge.component.html +9 -0
- package/src/libs/ui/elements/src/lib/kind-badge/kind-badge.component.ts +51 -0
- package/src/libs/ui/elements/src/lib/link-card/link-card.component.html +5 -2
- package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +3 -7
- package/src/libs/ui/elements/src/lib/metadata-catalog/metadata-catalog.component.html +3 -5
- package/src/libs/ui/elements/src/lib/metadata-contact/metadata-contact.component.html +9 -9
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.css +1 -1
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +7 -3
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +2 -3
- package/src/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.html +1 -1
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +3 -0
- package/src/libs/ui/inputs/src/index.ts +1 -0
- package/src/libs/ui/inputs/src/lib/button/button.component.ts +2 -2
- package/src/libs/ui/inputs/src/lib/dropdown-multiselect/dropdown-multiselect.component.html +1 -1
- package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.html +1 -1
- package/src/libs/ui/inputs/src/lib/inline-filter/inline-filter.component.html +23 -0
- package/src/libs/ui/inputs/src/lib/inline-filter/inline-filter.component.ts +44 -0
- package/src/libs/ui/inputs/src/lib/inline-filter/inline-filter.model.ts +5 -0
- package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.ts +0 -0
- package/src/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.html +2 -2
- package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +3 -3
- package/src/libs/ui/layout/src/index.ts +1 -0
- package/src/libs/ui/layout/src/lib/block-list/block-list.component.css +22 -0
- package/src/libs/ui/layout/src/lib/block-list/block-list.component.html +2 -2
- package/src/libs/ui/layout/src/lib/block-list/block-list.component.ts +43 -5
- package/src/libs/ui/layout/src/lib/carousel/carousel.component.css +0 -1
- package/src/libs/ui/layout/src/lib/carousel/carousel.component.html +1 -1
- package/src/libs/ui/layout/src/lib/max-lines/max-lines.component.html +1 -1
- package/src/libs/ui/layout/src/lib/previous-next-buttons/previous-next-buttons.component.html +17 -5
- package/src/libs/ui/layout/src/lib/previous-next-buttons/previous-next-buttons.component.ts +3 -3
- package/src/libs/ui/layout/src/lib/truncated-text/truncated-text.component.html +46 -0
- package/src/libs/ui/layout/src/lib/truncated-text/truncated-text.component.ts +62 -0
- package/src/libs/ui/layout/src/lib/ui-layout.module.ts +1 -5
- 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/map/src/lib/components/spatial-extent/spatial-extent.component.ts +1 -0
- package/src/libs/ui/search/src/index.ts +1 -0
- package/src/libs/ui/search/src/lib/results-hits-number/results-hits-number.component.html +1 -1
- package/src/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.html +24 -0
- package/src/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.ts +53 -0
- package/src/libs/ui/search/src/lib/ui-search.module.ts +5 -0
- package/src/libs/ui/widgets/src/lib/progress-bar/progress-bar.component.html +2 -1
- package/tailwind.base.config.js +3 -0
- package/tailwind.base.css +1 -13
- package/translations/de.json +8 -1
- package/translations/en.json +10 -1
- package/translations/es.json +8 -1
- package/translations/fr.json +11 -2
- package/translations/it.json +8 -1
- package/translations/nl.json +8 -1
- package/translations/pt.json +8 -1
- package/translations/sk.json +8 -1
- package/esm2022/libs/feature/search/src/lib/results-hits-number/results-hits.container.component.mjs +0 -18
- package/libs/feature/search/src/lib/results-hits-number/results-hits.container.component.d.ts +0 -9
- package/libs/feature/search/src/lib/results-hits-number/results-hits.container.component.d.ts.map +0 -1
- package/src/libs/feature/search/src/lib/results-hits-number/results-hits.container.component.html +0 -4
- package/src/libs/feature/search/src/lib/results-hits-number/results-hits.container.component.ts +0 -10
|
@@ -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,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
|
}
|
|
@@ -11,3 +11,4 @@ export * from './lib/components/wizard/wizard.component'
|
|
|
11
11
|
export * from './lib/components/wizard-field/wizard-field.component'
|
|
12
12
|
export * from './lib/components/wizard-summarize/wizard-summarize.component'
|
|
13
13
|
export * from './lib/components/record-form/form-field'
|
|
14
|
+
export * from './lib/components/multilingual-panel/multilingual-panel.component'
|
|
File without changes
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
<div
|
|
2
|
+
class="flex flex-col h-full w-[302px] bg-neutral-100 border-l border-gray-300 py-9 px-3 gap-8"
|
|
3
|
+
>
|
|
4
|
+
<span class="text-3xl font-title text-black/80 px-2" translate
|
|
5
|
+
>editor.record.form.multilingual.title</span
|
|
6
|
+
>
|
|
7
|
+
<gn-ui-check-toggle
|
|
8
|
+
class="p-2"
|
|
9
|
+
[label]="'editor.record.form.multilingual.enable' | translate"
|
|
10
|
+
[color]="'primary'"
|
|
11
|
+
[value]="translationsEnabled"
|
|
12
|
+
(toggled)="translationsEnabled = $event"
|
|
13
|
+
></gn-ui-check-toggle>
|
|
14
|
+
</div>
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Component } from '@angular/core'
|
|
2
|
+
import { CommonModule } from '@angular/common'
|
|
3
|
+
import { CheckToggleComponent } from '../../../../../../../libs/ui/inputs/src'
|
|
4
|
+
import { TranslateModule } from '@ngx-translate/core'
|
|
5
|
+
|
|
6
|
+
@Component({
|
|
7
|
+
selector: 'gn-ui-multilingual-panel',
|
|
8
|
+
standalone: true,
|
|
9
|
+
imports: [CommonModule, CheckToggleComponent, TranslateModule],
|
|
10
|
+
templateUrl: './multilingual-panel.component.html',
|
|
11
|
+
styleUrl: './multilingual-panel.component.css',
|
|
12
|
+
})
|
|
13
|
+
export class MultilingualPanelComponent {
|
|
14
|
+
translationsEnabled = false
|
|
15
|
+
}
|
|
@@ -1,13 +1,17 @@
|
|
|
1
|
-
<div class="w-full h-full flex flex-col
|
|
2
|
-
<
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
1
|
+
<div class="w-full h-full flex flex-col gap-[13px]">
|
|
2
|
+
<div
|
|
3
|
+
class="w-full py-4 px-5 bg-white border border-color-border rounded-lg mt-6"
|
|
4
|
+
>
|
|
5
|
+
<gn-ui-dropdown-selector
|
|
6
|
+
*ngIf="dropdownChoices$ | async as choices"
|
|
7
|
+
[ngClass]="{ hidden: !displaySource }"
|
|
8
|
+
[title]="'table.select.data' | translate"
|
|
9
|
+
class="h-[44px] w-full"
|
|
10
|
+
extraBtnClass="font-sans font-bold"
|
|
11
|
+
[choices]="choices"
|
|
12
|
+
(selectValue)="selectLink($event)"
|
|
13
|
+
></gn-ui-dropdown-selector>
|
|
14
|
+
</div>
|
|
11
15
|
<ng-container *ngIf="hidePreview; else dataView">
|
|
12
16
|
<gn-ui-popup-alert
|
|
13
17
|
type="warning"
|
|
@@ -23,12 +27,14 @@
|
|
|
23
27
|
*ngIf="mode === 'table'"
|
|
24
28
|
[cacheActive]="cacheActive$ | async"
|
|
25
29
|
[link]="selectedLink$ | async"
|
|
30
|
+
[featureCatalog]="mdViewFacade.featureCatalog$ | async"
|
|
26
31
|
></gn-ui-table-view>
|
|
27
32
|
<gn-ui-chart-view
|
|
28
33
|
*ngIf="mode === 'chart'"
|
|
29
34
|
(chartConfig$)="setChartConfig($event)"
|
|
30
35
|
[cacheActive]="cacheActive$ | async"
|
|
31
36
|
[link]="selectedLink$ | async"
|
|
37
|
+
[featureCatalog]="mdViewFacade.featureCatalog$ | async"
|
|
32
38
|
></gn-ui-chart-view>
|
|
33
39
|
</div>
|
|
34
40
|
</ng-template>
|
package/src/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.html
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
<gn-ui-button
|
|
2
2
|
*ngIf="externalViewer"
|
|
3
3
|
(buttonClick)="openInExternalViewer()"
|
|
4
|
-
type="
|
|
4
|
+
type="primary"
|
|
5
5
|
[title]="'record.externalViewer.open' | translate"
|
|
6
|
-
extraClass="ms-2 !rounded-lg"
|
|
6
|
+
[extraClass]="extraClass + 'bg-primary ms-2 !rounded-lg'"
|
|
7
7
|
>
|
|
8
8
|
<ng-icon name="matOpenInNew"></ng-icon>
|
|
9
9
|
</gn-ui-button>
|
package/src/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.ts
CHANGED
|
@@ -36,6 +36,7 @@ export const EXTERNAL_VIEWER_OPEN_NEW_TAB = new InjectionToken<boolean>(
|
|
|
36
36
|
})
|
|
37
37
|
export class ExternalViewerButtonComponent {
|
|
38
38
|
@Input() link: DatasetOnlineResource
|
|
39
|
+
@Input() extraClass = ''
|
|
39
40
|
|
|
40
41
|
get externalViewer() {
|
|
41
42
|
return !!this.urlTemplate && !!this.supportedLinkLayerType
|
|
@@ -1,18 +1,24 @@
|
|
|
1
|
-
<div class="w-full h-full flex flex-col
|
|
2
|
-
<div
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
>
|
|
15
|
-
|
|
1
|
+
<div class="w-full h-full flex flex-col gap-[13px]">
|
|
2
|
+
<div
|
|
3
|
+
class="flex py-4 px-5 bg-white border border-color-border rounded-lg mt-6"
|
|
4
|
+
>
|
|
5
|
+
<div class="grow min-w-0">
|
|
6
|
+
<gn-ui-dropdown-selector
|
|
7
|
+
[ngClass]="{ hidden: !displaySource }"
|
|
8
|
+
class="w-full"
|
|
9
|
+
extraBtnClass="font-sans font-bold"
|
|
10
|
+
[title]="'map.select.layer' | translate"
|
|
11
|
+
[choices]="dropdownChoices$ | async"
|
|
12
|
+
(selectValue)="selectLinkToDisplay($event)"
|
|
13
|
+
></gn-ui-dropdown-selector>
|
|
14
|
+
</div>
|
|
15
|
+
<div class="self-end">
|
|
16
|
+
<gn-ui-external-viewer-button
|
|
17
|
+
extraClass="w-[44px] h-[44px]"
|
|
18
|
+
[link]="selectedLink$ | async"
|
|
19
|
+
>
|
|
20
|
+
</gn-ui-external-viewer-button>
|
|
21
|
+
</div>
|
|
16
22
|
</div>
|
|
17
23
|
<ng-container *ngIf="hidePreview; else mapView">
|
|
18
24
|
<gn-ui-popup-alert
|
|
@@ -49,7 +55,10 @@
|
|
|
49
55
|
>
|
|
50
56
|
<ng-icon name="matClose" class="align-middle text-sm"></ng-icon>
|
|
51
57
|
</gn-ui-button>
|
|
52
|
-
<gn-ui-feature-detail
|
|
58
|
+
<gn-ui-feature-detail
|
|
59
|
+
[featureCatalog]="mdViewFacade.featureCatalog$ | async"
|
|
60
|
+
[feature]="selection"
|
|
61
|
+
></gn-ui-feature-detail>
|
|
53
62
|
</div>
|
|
54
63
|
|
|
55
64
|
<div
|
|
@@ -17,7 +17,7 @@ export * from './lib/facets/facets.module'
|
|
|
17
17
|
export * from './lib/facets/facets-container/facets-container.component'
|
|
18
18
|
export * from './lib/records-metrics/records-metrics.component'
|
|
19
19
|
export * from './lib/favorites/favorite-star/favorite-star.component'
|
|
20
|
-
export * from './lib/results-hits
|
|
20
|
+
export * from './lib/results-hits/results-hits.container.component'
|
|
21
21
|
export * from './lib/results-layout/results-layout.component'
|
|
22
22
|
export * from './lib/sort-by/sort-by.component'
|
|
23
23
|
export * from './lib/state/container/search-state.container.directive'
|
|
@@ -4,6 +4,7 @@ import { UiSearchModule } from '../../../../../libs/ui/search/src'
|
|
|
4
4
|
import { EffectsModule } from '@ngrx/effects'
|
|
5
5
|
import { StoreModule } from '@ngrx/store'
|
|
6
6
|
import { TranslateModule } from '@ngx-translate/core'
|
|
7
|
+
import { NgIconsModule } from '@ng-icons/core'
|
|
7
8
|
import { FacetsModule } from './facets/facets.module'
|
|
8
9
|
import { FuzzySearchComponent } from './fuzzy-search/fuzzy-search.component'
|
|
9
10
|
import { RecordsMetricsComponent } from './records-metrics/records-metrics.component'
|
|
@@ -12,7 +13,7 @@ import { ResultsListContainerComponent } from './results-list/results-list.conta
|
|
|
12
13
|
import { SortByComponent } from './sort-by/sort-by.component'
|
|
13
14
|
import { SearchEffects } from './state/effects'
|
|
14
15
|
import { initialState, reducer, SEARCH_FEATURE_KEY } from './state/reducer'
|
|
15
|
-
import { ResultsHitsContainerComponent } from './results-hits
|
|
16
|
+
import { ResultsHitsContainerComponent } from './results-hits/results-hits.container.component'
|
|
16
17
|
import { SearchStateContainerDirective } from './state/container/search-state.container.directive'
|
|
17
18
|
import {
|
|
18
19
|
AutocompleteComponent,
|
|
@@ -20,7 +21,11 @@ import {
|
|
|
20
21
|
UiInputsModule,
|
|
21
22
|
} from '../../../../../libs/ui/inputs/src'
|
|
22
23
|
import { NgModule } from '@angular/core'
|
|
23
|
-
import {
|
|
24
|
+
import {
|
|
25
|
+
ErrorComponent,
|
|
26
|
+
KindBadgeComponent,
|
|
27
|
+
UiElementsModule,
|
|
28
|
+
} from '../../../../../libs/ui/elements/src'
|
|
24
29
|
import { FilterDropdownComponent } from './filter-dropdown/filter-dropdown.component'
|
|
25
30
|
import {
|
|
26
31
|
SpinningLoaderComponent,
|
|
@@ -58,6 +63,8 @@ import { FavoriteStarComponent } from './favorites/favorite-star/favorite-star.c
|
|
|
58
63
|
ErrorComponent,
|
|
59
64
|
FavoriteStarComponent,
|
|
60
65
|
DateRangeDropdownComponent,
|
|
66
|
+
NgIconsModule,
|
|
67
|
+
KindBadgeComponent,
|
|
61
68
|
],
|
|
62
69
|
exports: [
|
|
63
70
|
SortByComponent,
|
|
File without changes
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
<div
|
|
2
|
+
class="flex flex-col gap-3 sm:flex-row justify-between"
|
|
3
|
+
[ngClass]="{
|
|
4
|
+
'sm:items-center': (searchFacade.resultsHits$ | async) !== 0,
|
|
5
|
+
}"
|
|
6
|
+
>
|
|
7
|
+
<gn-ui-results-hits-number
|
|
8
|
+
[loading]="searchFacade.isLoading$ | async"
|
|
9
|
+
[hits]="searchFacade.resultsHits$ | async"
|
|
10
|
+
></gn-ui-results-hits-number>
|
|
11
|
+
<gn-ui-results-hits-search-kind
|
|
12
|
+
(selectionChanged)="onSelectionChanged($event)"
|
|
13
|
+
[choices]="filterChoices$ | async"
|
|
14
|
+
[selected]="selected$ | async"
|
|
15
|
+
></gn-ui-results-hits-search-kind>
|
|
16
|
+
</div>
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import {
|
|
2
|
+
catchError,
|
|
3
|
+
filter,
|
|
4
|
+
map,
|
|
5
|
+
Observable,
|
|
6
|
+
of,
|
|
7
|
+
startWith,
|
|
8
|
+
switchMap,
|
|
9
|
+
} from 'rxjs'
|
|
10
|
+
import { Component, OnInit } from '@angular/core'
|
|
11
|
+
import { marker } from '@biesbjerg/ngx-translate-extract-marker'
|
|
12
|
+
import { SearchFacade } from '../state/search.facade'
|
|
13
|
+
import { FieldAvailableValue, FieldValue } from '../utils/service/fields'
|
|
14
|
+
import { SearchService } from '../utils/service/search.service'
|
|
15
|
+
import { FieldsService } from '../utils/service/fields.service'
|
|
16
|
+
|
|
17
|
+
marker('search.filters.recordKind.all')
|
|
18
|
+
marker('search.filters.recordKind.dataset')
|
|
19
|
+
marker('search.filters.recordKind.service')
|
|
20
|
+
marker('search.filters.recordKind.reuse')
|
|
21
|
+
|
|
22
|
+
@Component({
|
|
23
|
+
selector: 'gn-ui-results-hits',
|
|
24
|
+
templateUrl: './results-hits.container.component.html',
|
|
25
|
+
styleUrls: ['./results-hits.container.component.css'],
|
|
26
|
+
})
|
|
27
|
+
export class ResultsHitsContainerComponent implements OnInit {
|
|
28
|
+
fieldName = 'recordKind'
|
|
29
|
+
filterChoices$: Observable<FieldAvailableValue[]>
|
|
30
|
+
selected$: Observable<FieldValue[]>
|
|
31
|
+
|
|
32
|
+
constructor(
|
|
33
|
+
protected searchFacade: SearchFacade,
|
|
34
|
+
private searchService: SearchService,
|
|
35
|
+
private fieldsService: FieldsService
|
|
36
|
+
) {}
|
|
37
|
+
|
|
38
|
+
ngOnInit() {
|
|
39
|
+
this.selected$ = this.searchFacade.searchFilters$.pipe(
|
|
40
|
+
switchMap((filters) =>
|
|
41
|
+
this.fieldsService.readFieldValuesFromFilters(filters)
|
|
42
|
+
),
|
|
43
|
+
map((fieldValues) => fieldValues[this.fieldName]),
|
|
44
|
+
filter((selected) => !!selected),
|
|
45
|
+
startWith([]),
|
|
46
|
+
catchError(() => of([]))
|
|
47
|
+
) as Observable<FieldValue[]>
|
|
48
|
+
|
|
49
|
+
this.filterChoices$ = <Observable<FieldAvailableValue[]>>(
|
|
50
|
+
this.fieldsService.getAvailableValues(this.fieldName)
|
|
51
|
+
)
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
onSelectionChanged(values: string[]) {
|
|
55
|
+
this.fieldsService
|
|
56
|
+
.buildFiltersFromFieldValues({ [this.fieldName]: values })
|
|
57
|
+
.subscribe((filters) => this.searchService.updateFilters(filters))
|
|
58
|
+
}
|
|
59
|
+
}
|
|
@@ -10,8 +10,10 @@ import {
|
|
|
10
10
|
MultilingualSearchField,
|
|
11
11
|
OrganizationSearchField,
|
|
12
12
|
OwnerSearchField,
|
|
13
|
+
ResourceTypeLegacyField,
|
|
13
14
|
SimpleSearchField,
|
|
14
15
|
TranslatedSearchField,
|
|
16
|
+
RecordKindField,
|
|
15
17
|
UserSearchField,
|
|
16
18
|
} from './fields'
|
|
17
19
|
import { forkJoin, Observable, of } from 'rxjs'
|
|
@@ -47,11 +49,8 @@ export class FieldsService {
|
|
|
47
49
|
protected fields = {
|
|
48
50
|
organization: new OrganizationSearchField(this.injector),
|
|
49
51
|
format: new SimpleSearchField('format', this.injector, 'asc'),
|
|
50
|
-
resourceType: new
|
|
51
|
-
|
|
52
|
-
this.injector,
|
|
53
|
-
'asc'
|
|
54
|
-
),
|
|
52
|
+
resourceType: new ResourceTypeLegacyField(this.injector), // Deprecated, use `recordKind` instead
|
|
53
|
+
recordKind: new RecordKindField(this.injector),
|
|
55
54
|
representationType: new TranslatedSearchField(
|
|
56
55
|
'cl_spatialRepresentationType.key',
|
|
57
56
|
this.injector,
|
|
@@ -22,6 +22,7 @@ import {
|
|
|
22
22
|
} from '../../../../../../../libs/api/repository/src'
|
|
23
23
|
import { LangService } from '../../../../../../../libs/util/i18n/src'
|
|
24
24
|
import { formatUserInfo } from '../../../../../../../libs/util/shared/src'
|
|
25
|
+
import { PossibleResourceTypes } from '../../../../../../../libs/api/metadata-converter/src'
|
|
25
26
|
|
|
26
27
|
export type FieldType = 'values' | 'dateRange'
|
|
27
28
|
|
|
@@ -29,6 +30,7 @@ export type FieldValue = string | number
|
|
|
29
30
|
export interface FieldAvailableValue {
|
|
30
31
|
value: FieldValue
|
|
31
32
|
label: string
|
|
33
|
+
count?: number
|
|
32
34
|
}
|
|
33
35
|
|
|
34
36
|
export abstract class AbstractSearchField {
|
|
@@ -80,6 +82,7 @@ export class SimpleSearchField implements AbstractSearchField {
|
|
|
80
82
|
const bucketPromises = buckets.map(async (bucket) => ({
|
|
81
83
|
label: `${await this.getBucketLabel(bucket)} (${bucket.count})`,
|
|
82
84
|
value: bucket.term.toString(),
|
|
85
|
+
count: bucket.count,
|
|
83
86
|
}))
|
|
84
87
|
return Promise.all(bucketPromises)
|
|
85
88
|
})
|
|
@@ -480,3 +483,99 @@ export class AvailableServicesField extends SimpleSearchField {
|
|
|
480
483
|
return of(values)
|
|
481
484
|
}
|
|
482
485
|
}
|
|
486
|
+
|
|
487
|
+
/**
|
|
488
|
+
* This class is meant to be used with the legacy filter on `resourceType` (now deprecated, the use of `recordKind` field is recommended).
|
|
489
|
+
* Since creating filters on the same ES field is not possible, in order to make the resource type filter still working,
|
|
490
|
+
* we create an ES on the fly: `resourceTypeLegacy` that references the `resourceType` under the hood.
|
|
491
|
+
* @deprecated Use `recordKind` field instead.
|
|
492
|
+
*/
|
|
493
|
+
export class ResourceTypeLegacyField extends TranslatedSearchField {
|
|
494
|
+
constructor(injector: Injector) {
|
|
495
|
+
super('resourceTypeLegacy', injector, 'asc')
|
|
496
|
+
|
|
497
|
+
// Ask ES to create a field on the fly: 'resourceTypeLegacy' that is in fact, 'resourceType'
|
|
498
|
+
this.esService.registerRuntimeField(
|
|
499
|
+
'resourceTypeLegacy',
|
|
500
|
+
`for (resourceType in doc.resourceType) { emit(resourceType) }`
|
|
501
|
+
)
|
|
502
|
+
}
|
|
503
|
+
}
|
|
504
|
+
|
|
505
|
+
export class RecordKindField extends SimpleSearchField {
|
|
506
|
+
TYPE_MAPPING = {
|
|
507
|
+
dataset: ['dataset', 'series', 'featureCatalog'],
|
|
508
|
+
service: ['service'],
|
|
509
|
+
reuse: Object.entries(PossibleResourceTypes)
|
|
510
|
+
.filter(([_, v]) => v === 'reuse')
|
|
511
|
+
.map(([k]) => k), // = ['application', 'map', 'staticMap', 'interactiveMap', ...]
|
|
512
|
+
}
|
|
513
|
+
|
|
514
|
+
constructor(injector: Injector) {
|
|
515
|
+
super('resourceType', injector, 'asc')
|
|
516
|
+
}
|
|
517
|
+
|
|
518
|
+
getAvailableValues(): Observable<FieldAvailableValue[]> {
|
|
519
|
+
return this.repository.aggregate(this.getAggregations()).pipe(
|
|
520
|
+
map(
|
|
521
|
+
(response) =>
|
|
522
|
+
(response[this.esFieldName] as AggregationBuckets).buckets || []
|
|
523
|
+
),
|
|
524
|
+
map((buckets: TermBucket[]) => {
|
|
525
|
+
const counts = buckets.reduce(
|
|
526
|
+
(acc, { term, count }) => {
|
|
527
|
+
const value = term.toString()
|
|
528
|
+
const key = this.TYPE_MAPPING.reuse.includes(value)
|
|
529
|
+
? 'reuse'
|
|
530
|
+
: this.TYPE_MAPPING.dataset.includes(value)
|
|
531
|
+
? 'dataset'
|
|
532
|
+
: value
|
|
533
|
+
|
|
534
|
+
acc[key] = (acc[key] || 0) + count
|
|
535
|
+
return acc
|
|
536
|
+
},
|
|
537
|
+
{} as Record<string, number>
|
|
538
|
+
)
|
|
539
|
+
|
|
540
|
+
return Object.keys(this.TYPE_MAPPING).map((type) => ({
|
|
541
|
+
label: type,
|
|
542
|
+
value: type,
|
|
543
|
+
count: counts[type] ?? 0,
|
|
544
|
+
}))
|
|
545
|
+
})
|
|
546
|
+
)
|
|
547
|
+
}
|
|
548
|
+
|
|
549
|
+
getFiltersForValues(values: FieldValue[]): Observable<FieldFilters> {
|
|
550
|
+
const filters = {
|
|
551
|
+
[this.esFieldName]: values.reduce((acc, value) => {
|
|
552
|
+
if (value === '') return { ...acc, [value]: true }
|
|
553
|
+
|
|
554
|
+
const keysToAdd = this.TYPE_MAPPING[value] || [value]
|
|
555
|
+
keysToAdd.forEach((key: string) => (acc[key] = true))
|
|
556
|
+
|
|
557
|
+
return acc
|
|
558
|
+
}, {}),
|
|
559
|
+
}
|
|
560
|
+
|
|
561
|
+
return of(filters)
|
|
562
|
+
}
|
|
563
|
+
|
|
564
|
+
getValuesForFilter(filters: FieldFilters): Observable<FieldValue[]> {
|
|
565
|
+
const filter = filters[this.esFieldName]
|
|
566
|
+
if (!filter) return of([])
|
|
567
|
+
|
|
568
|
+
const activeValues = Object.keys(filter).filter((v) => filter[v])
|
|
569
|
+
const activeTypes = Object.keys(this.TYPE_MAPPING).filter((type) =>
|
|
570
|
+
this.TYPE_MAPPING[type].every((t: string) => activeValues.includes(t))
|
|
571
|
+
)
|
|
572
|
+
|
|
573
|
+
// Allow unknown values eg. 'type=somethingnotexist' (for UI to select none)
|
|
574
|
+
const allTypes = [].concat(...Object.values(this.TYPE_MAPPING))
|
|
575
|
+
const unknownValues = activeValues.filter(
|
|
576
|
+
(value) => !allTypes.includes(value)
|
|
577
|
+
)
|
|
578
|
+
|
|
579
|
+
return of([...activeTypes, ...unknownValues])
|
|
580
|
+
}
|
|
581
|
+
}
|
|
@@ -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
|
],
|