geonetwork-ui 2.3.0-dev.f736344f → 2.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/index.mjs +2 -1
- package/esm2022/libs/api/metadata-converter/src/index.mjs +5 -5
- package/esm2022/libs/api/metadata-converter/src/lib/base.converter.mjs +14 -0
- package/esm2022/libs/api/metadata-converter/src/lib/find-converter.mjs +15 -0
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/atomic-operations.mjs +3 -3
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.converter.mjs +52 -0
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +8 -4
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/index.mjs +4 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/index.mjs +2 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.mjs +123 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.mjs +116 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.mjs +138 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/index.mjs +2 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +244 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +76 -65
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/individual-name.mjs +18 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/keyword.mapper.mjs +14 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/role.mapper.mjs +48 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/status.mapper.mjs +18 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/update-frequency.mapper.mjs +64 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +89 -61
- package/esm2022/libs/api/metadata-converter/src/lib/xml-utils.mjs +76 -14
- package/esm2022/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.mjs +1 -1
- package/esm2022/libs/api/repository/src/lib/gn4/auth/gravatar.service.mjs +12 -1
- package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +4 -4
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +36 -3
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +21 -7
- package/esm2022/libs/common/domain/src/lib/model/record/index.mjs +2 -1
- package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/model/record/user-feedbacks.model.mjs +2 -0
- package/esm2022/libs/common/domain/src/lib/model/user/index.mjs +2 -0
- package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
- package/esm2022/libs/data-access/gn4/src/openapi/api/records.api.service.mjs +35 -7
- package/esm2022/libs/data-access/gn4/src/openapi/model/models.mjs +1 -2
- package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +48 -3
- package/esm2022/libs/feature/editor/src/index.mjs +2 -2
- package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +6 -2
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-array/form-field-array.component.mjs +11 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-file/form-field-file.component.mjs +28 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +64 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-object/form-field-object.component.mjs +11 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.mjs +15 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +45 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.mjs +50 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +11 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extent/form-field-temporal-extent.component.mjs +11 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +104 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +126 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.mjs +2 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/index.mjs +10 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +29 -0
- package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +1 -1
- package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +10 -10
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +23 -1
- package/esm2022/libs/feature/editor/src/lib/models/fields.model.mjs +1 -1
- package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +8 -8
- package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.mjs +6 -2
- package/esm2022/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.mjs +3 -3
- package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +125 -0
- package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +1 -1
- package/esm2022/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.mjs +1 -1
- package/esm2022/libs/feature/map/src/lib/feature-map.module.mjs +7 -3
- package/esm2022/libs/feature/map/src/lib/layers-panel/layers-panel.component.mjs +12 -7
- package/esm2022/libs/feature/map/src/lib/map-context/map-context.model.mjs +2 -1
- package/esm2022/libs/feature/map/src/lib/map-context/map-context.service.mjs +100 -32
- package/esm2022/libs/feature/map/src/lib/utils/map-utils.service.mjs +18 -51
- package/esm2022/libs/feature/notifications/src/index.mjs +4 -0
- package/esm2022/libs/feature/notifications/src/lib/feature-notifications.module.mjs +18 -0
- package/esm2022/libs/feature/notifications/src/lib/notification.model.mjs +2 -0
- package/esm2022/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.mjs +49 -0
- package/esm2022/libs/feature/notifications/src/lib/notifications.service.mjs +29 -0
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +1 -1
- package/esm2022/libs/feature/record/src/lib/feature-record.module.mjs +4 -4
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +22 -10
- package/esm2022/libs/feature/record/src/lib/state/mdview.actions.mjs +22 -4
- package/esm2022/libs/feature/record/src/lib/state/mdview.effects.mjs +37 -10
- package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +52 -8
- package/esm2022/libs/feature/record/src/lib/state/mdview.reducer.mjs +50 -17
- package/esm2022/libs/feature/record/src/lib/state/mdview.selectors.mjs +18 -3
- package/esm2022/libs/feature/router/src/lib/default/state/router.effects.mjs +2 -2
- package/esm2022/libs/feature/search/src/index.mjs +2 -1
- package/esm2022/libs/feature/search/src/lib/results-layout/results-layout.component.mjs +1 -1
- package/esm2022/libs/feature/search/src/lib/results-list/results-list.container.component.mjs +4 -4
- package/esm2022/libs/feature/search/src/lib/results-table/results-table.component.mjs +3 -3
- package/esm2022/libs/feature/search/src/lib/sort-by/sort-by.component.mjs +1 -1
- package/esm2022/libs/feature/search/src/lib/utils/service/fields.service.mjs +1 -1
- package/esm2022/libs/ui/catalog/src/lib/language-switcher/language-switcher.component.mjs +1 -1
- package/esm2022/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.mjs +3 -3
- package/esm2022/libs/ui/catalog/src/lib/organisations-filter/organisations-filter.component.mjs +1 -1
- package/esm2022/libs/ui/elements/src/index.mjs +16 -16
- package/esm2022/libs/ui/elements/src/lib/api-card/api-card.component.mjs +3 -2
- package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +2 -2
- package/esm2022/libs/ui/elements/src/lib/error/error.component.mjs +30 -0
- package/esm2022/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.mjs +5 -5
- package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +16 -3
- package/esm2022/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.mjs +45 -0
- package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/notification/notification.component.mjs +34 -0
- package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +98 -36
- package/esm2022/libs/ui/elements/src/lib/thumbnail/thumbnail.component.mjs +4 -3
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +19 -15
- package/esm2022/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.mjs +59 -0
- package/esm2022/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.mjs +60 -0
- package/esm2022/libs/ui/inputs/src/index.mjs +16 -16
- package/esm2022/libs/ui/inputs/src/lib/button/button.component.mjs +2 -1
- package/esm2022/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.mjs +4 -3
- package/esm2022/libs/ui/inputs/src/lib/date-picker/date-picker.component.mjs +22 -0
- package/esm2022/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.mjs +7 -5
- package/esm2022/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.mjs +19 -8
- package/esm2022/libs/ui/inputs/src/lib/files-drop/files-drop.directive.mjs +59 -0
- package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +183 -0
- package/esm2022/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.mjs +29 -0
- package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +27 -4
- package/esm2022/libs/ui/inputs/src/lib/text-input/text-input.component.mjs +21 -3
- package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +21 -31
- package/esm2022/libs/ui/layout/src/index.mjs +7 -5
- package/esm2022/libs/ui/layout/src/lib/block-list/block-list.component.mjs +76 -0
- package/esm2022/libs/ui/layout/src/lib/carousel/carousel.component.mjs +42 -18
- package/esm2022/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.mjs +18 -0
- package/esm2022/libs/ui/layout/src/lib/ui-layout.module.mjs +3 -8
- package/esm2022/libs/util/app-config/src/lib/app-config.mjs +3 -1
- package/esm2022/libs/util/app-config/src/lib/fixtures.mjs +2 -1
- package/esm2022/libs/util/app-config/src/lib/model.mjs +1 -1
- package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +2 -2
- package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +22 -1
- package/esm2022/libs/util/shared/src/lib/utils/bytes-convert.mjs +4 -0
- package/esm2022/libs/util/shared/src/lib/utils/image-resize.mjs +60 -0
- package/esm2022/libs/util/shared/src/lib/utils/index.mjs +8 -6
- package/esm2022/translations/de.json +44 -0
- package/esm2022/translations/en.json +44 -0
- package/esm2022/translations/es.json +44 -0
- package/esm2022/translations/fr.json +44 -0
- package/esm2022/translations/it.json +44 -0
- package/esm2022/translations/nl.json +44 -0
- package/esm2022/translations/pt.json +44 -0
- package/fesm2022/geonetwork-ui.mjs +6088 -3676
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/index.d.ts.map +1 -1
- package/index.ts +1 -0
- package/libs/api/metadata-converter/src/index.d.ts +4 -4
- package/libs/api/metadata-converter/src/index.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/{metadata-base.mapper.d.ts → base.converter.d.ts} +3 -3
- package/libs/api/metadata-converter/src/lib/base.converter.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/find-converter.d.ts +3 -0
- package/libs/api/metadata-converter/src/lib/find-converter.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/gn4/{gn4.metadata.mapper.d.ts → gn4.converter.d.ts} +5 -5
- package/libs/api/metadata-converter/src/lib/gn4/gn4.converter.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/index.d.ts +4 -0
- package/libs/api/metadata-converter/src/lib/gn4/index.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/index.d.ts +2 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/index.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.d.ts +9 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts +20 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts +21 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/index.d.ts +2 -0
- package/libs/api/metadata-converter/src/lib/iso19139/index.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts +11 -0
- package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +38 -7
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/utils/individual-name.d.ts +8 -0
- package/libs/api/metadata-converter/src/lib/iso19139/utils/individual-name.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/utils/keyword.mapper.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/utils/role.mapper.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/utils/status.mapper.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/utils/update-frequency.mapper.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +40 -3
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/xml-utils.d.ts +14 -1
- package/libs/api/metadata-converter/src/lib/xml-utils.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.d.ts +1 -0
- package/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/auth/gravatar.service.d.ts +1 -0
- package/libs/api/repository/src/lib/gn4/auth/gravatar.service.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +2 -2
- package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts +6 -2
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +9 -6
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/index.d.ts +1 -0
- package/libs/common/domain/src/lib/model/record/index.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +9 -7
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/user-feedbacks.model.d.ts +15 -0
- package/libs/common/domain/src/lib/model/record/user-feedbacks.model.d.ts.map +1 -0
- package/libs/common/domain/src/lib/model/user/index.d.ts +2 -0
- package/libs/common/domain/src/lib/model/user/index.d.ts.map +1 -0
- package/libs/common/domain/src/lib/platform.service.interface.d.ts +3 -0
- package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
- package/libs/data-access/gn4/src/openapi/api/records.api.service.d.ts +9 -5
- package/libs/data-access/gn4/src/openapi/api/records.api.service.d.ts.map +1 -1
- package/libs/data-access/gn4/src/openapi/model/models.d.ts +0 -1
- package/libs/data-access/gn4/src/openapi/model/models.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts +4 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/editor/src/index.d.ts +1 -1
- package/libs/feature/editor/src/index.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +8 -5
- package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
- package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-array/form-field-array.component.d.ts +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-array/form-field-array.component.d.ts.map +1 -0
- package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-file/form-field-file.component.d.ts +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-file/form-field-file.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts +39 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts.map +1 -0
- package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-object/form-field-object.component.d.ts +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-object/form-field-object.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts +8 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts +16 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -0
- package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-simple/form-field-simple.component.d.ts +2 -2
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts.map +1 -0
- package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts.map +1 -0
- package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-temporal-extent/form-field-temporal-extent.component.d.ts +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extent/form-field-temporal-extent.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +21 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts.map +1 -0
- package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field.component.d.ts +13 -4
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/{record-form → components/record-form}/record-form.component.d.ts +3 -3
- package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/feature-editor.module.d.ts +1 -1
- package/libs/feature/editor/src/lib/feature-editor.module.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/models/fields.model.d.ts +1 -1
- package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts +28 -0
- package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts.map +1 -0
- package/libs/feature/map/src/lib/feature-map.module.d.ts +2 -1
- package/libs/feature/map/src/lib/feature-map.module.d.ts.map +1 -1
- package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts +2 -0
- package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/map-context/map-context.model.d.ts +17 -5
- package/libs/feature/map/src/lib/map-context/map-context.model.d.ts.map +1 -1
- package/libs/feature/map/src/lib/map-context/map-context.service.d.ts +1 -1
- package/libs/feature/map/src/lib/map-context/map-context.service.d.ts.map +1 -1
- package/libs/feature/map/src/lib/utils/map-utils.service.d.ts +2 -3
- package/libs/feature/map/src/lib/utils/map-utils.service.d.ts.map +1 -1
- package/libs/feature/notifications/src/index.d.ts +4 -0
- package/libs/feature/notifications/src/index.d.ts.map +1 -0
- package/libs/feature/notifications/src/lib/feature-notifications.module.d.ts +7 -0
- package/libs/feature/notifications/src/lib/feature-notifications.module.d.ts.map +1 -0
- package/libs/feature/notifications/src/lib/notification.model.d.ts +7 -0
- package/libs/feature/notifications/src/lib/notification.model.d.ts.map +1 -0
- package/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.d.ts +12 -0
- package/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.d.ts.map +1 -0
- package/libs/feature/notifications/src/lib/notifications.service.d.ts +15 -0
- package/libs/feature/notifications/src/lib/notifications.service.d.ts.map +1 -0
- package/libs/feature/record/src/lib/feature-record.module.d.ts.map +1 -1
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +2 -2
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.actions.d.ts +40 -6
- package/libs/feature/record/src/lib/state/mdview.actions.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.effects.d.ts +24 -4
- package/libs/feature/record/src/lib/state/mdview.effects.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts +18 -5
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.reducer.d.ts +8 -5
- package/libs/feature/record/src/lib/state/mdview.reducer.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.selectors.d.ts +12 -9
- package/libs/feature/record/src/lib/state/mdview.selectors.d.ts.map +1 -1
- package/libs/feature/search/src/index.d.ts +1 -0
- package/libs/feature/search/src/index.d.ts.map +1 -1
- package/libs/feature/search/src/lib/utils/service/fields.service.d.ts +3 -3
- package/libs/feature/search/src/lib/utils/service/fields.service.d.ts.map +1 -1
- package/libs/ui/elements/src/index.d.ts +15 -15
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/api-card/api-card.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/error/error.component.d.ts +16 -0
- package/libs/ui/elements/src/lib/error/error.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +3 -1
- package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.d.ts +13 -0
- package/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/notification/notification.component.d.ts +13 -0
- package/libs/ui/elements/src/lib/notification/notification.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +24 -4
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/thumbnail/thumbnail.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/thumbnail/thumbnail.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +29 -28
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.d.ts +11 -0
- package/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts +21 -0
- package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/index.d.ts +15 -15
- package/libs/ui/inputs/src/index.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/button/button.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.d.ts +1 -1
- package/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/date-picker/date-picker.component.d.ts +9 -0
- package/libs/ui/inputs/src/lib/date-picker/date-picker.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.d.ts +1 -1
- package/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts +2 -1
- package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/files-drop/files-drop.directive.d.ts +14 -0
- package/libs/ui/inputs/src/lib/files-drop/files-drop.directive.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +44 -0
- package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.d.ts +12 -0
- package/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +7 -1
- package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts +5 -1
- package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +35 -42
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
- package/libs/ui/layout/src/index.d.ts +6 -4
- package/libs/ui/layout/src/index.d.ts.map +1 -1
- package/libs/ui/layout/src/lib/block-list/block-list.component.d.ts +25 -0
- package/libs/ui/layout/src/lib/block-list/block-list.component.d.ts.map +1 -0
- package/libs/ui/layout/src/lib/carousel/carousel.component.d.ts +13 -6
- package/libs/ui/layout/src/lib/carousel/carousel.component.d.ts.map +1 -1
- package/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.d.ts +8 -0
- package/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.d.ts.map +1 -0
- package/libs/ui/layout/src/lib/ui-layout.module.d.ts +4 -5
- package/libs/ui/layout/src/lib/ui-layout.module.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/fixtures.d.ts.map +1 -1
- package/libs/util/app-config/src/lib/model.d.ts +1 -0
- package/libs/util/app-config/src/lib/model.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts +18 -0
- package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/bytes-convert.d.ts +2 -0
- package/libs/util/shared/src/lib/utils/bytes-convert.d.ts.map +1 -0
- package/libs/util/shared/src/lib/utils/image-resize.d.ts +3 -0
- package/libs/util/shared/src/lib/utils/image-resize.d.ts.map +1 -0
- package/libs/util/shared/src/lib/utils/index.d.ts +7 -5
- package/libs/util/shared/src/lib/utils/index.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/libs/api/metadata-converter/src/index.ts +4 -4
- package/src/libs/api/metadata-converter/src/lib/{metadata-base.mapper.ts → base.converter.ts} +2 -2
- package/src/libs/api/metadata-converter/src/lib/find-converter.ts +16 -0
- package/src/libs/api/metadata-converter/src/lib/fixtures/generic.records.ts +41 -6
- package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +11 -4
- package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +33 -7
- package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +580 -0
- package/src/libs/api/metadata-converter/src/lib/gn4/atomic-operations.ts +2 -2
- package/src/libs/api/metadata-converter/src/lib/gn4/{gn4.metadata.mapper.ts → gn4.converter.ts} +2 -2
- package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +9 -3
- package/src/libs/api/metadata-converter/src/lib/gn4/index.ts +3 -0
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/index.ts +1 -0
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.ts +176 -0
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.ts +329 -0
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.ts +513 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/index.ts +1 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +331 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +185 -94
- package/src/libs/api/metadata-converter/src/lib/iso19139/utils/individual-name.ts +20 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +246 -111
- package/src/libs/api/metadata-converter/src/lib/xml-utils.ts +84 -16
- package/src/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.ts +1 -0
- package/src/libs/api/repository/src/lib/gn4/auth/gravatar.service.ts +12 -1
- package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +2 -2
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +51 -1
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +40 -7
- package/src/libs/common/domain/src/lib/model/record/index.ts +1 -0
- package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +12 -7
- package/src/libs/common/domain/src/lib/model/record/user-feedbacks.model.ts +15 -0
- package/src/libs/common/domain/src/lib/platform.service.interface.ts +3 -0
- package/src/libs/common/fixtures/src/index.ts +8 -6
- package/src/libs/common/fixtures/src/lib/link.fixtures.ts +8 -0
- package/src/libs/common/fixtures/src/lib/records.fixtures.ts +11 -3
- package/src/libs/common/fixtures/src/lib/user-feedbacks.fixtures.ts +83 -0
- package/src/libs/data-access/gn4/src/openapi/api/records.api.service.ts +43 -12
- package/src/libs/data-access/gn4/src/openapi/model/models.ts +0 -1
- package/src/libs/data-access/gn4/src/spec.yaml +1 -1
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +66 -2
- package/src/libs/feature/editor/src/index.ts +1 -1
- package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +8 -1
- package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +8 -0
- package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +70 -0
- package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-array/form-field-array.component.ts +1 -0
- package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-file/form-field-file.component.ts +4 -1
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.html +8 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.ts +64 -0
- package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-object/form-field-object.component.ts +1 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.html +4 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.ts +15 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.html +20 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +44 -0
- package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-simple/form-field-simple.component.ts +4 -1
- package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-spatial-extent/form-field-spatial-extent.component.ts +1 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extent/form-field-temporal-extent.component.css +0 -0
- package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-temporal-extent/form-field-temporal-extent.component.ts +1 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.html +14 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +143 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +97 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +142 -0
- package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.css +0 -0
- package/src/libs/feature/editor/src/lib/{record-form → components/record-form}/record-form.component.html +1 -0
- package/src/libs/feature/editor/src/lib/{record-form → components/record-form}/record-form.component.ts +4 -4
- package/src/libs/feature/editor/src/lib/feature-editor.module.ts +9 -9
- package/src/libs/feature/editor/src/lib/fields.config.ts +22 -0
- package/src/libs/feature/editor/src/lib/models/fields.model.ts +1 -1
- package/src/libs/feature/editor/src/lib/services/editor.service.ts +27 -16
- package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.ts +5 -1
- package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.html +1 -1
- package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.css +7 -0
- package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.html +50 -0
- package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.ts +135 -0
- package/src/libs/feature/map/src/lib/feature-map.module.ts +2 -0
- package/src/libs/feature/map/src/lib/layers-panel/layers-panel.component.html +8 -0
- package/src/libs/feature/map/src/lib/layers-panel/layers-panel.component.ts +5 -0
- package/src/libs/feature/map/src/lib/map-context/map-context.model.ts +17 -3
- package/src/libs/feature/map/src/lib/map-context/map-context.service.ts +108 -40
- package/src/libs/feature/map/src/lib/utils/map-utils.service.ts +23 -63
- package/src/libs/feature/notifications/src/index.ts +3 -0
- package/src/libs/feature/notifications/src/lib/feature-notifications.module.ts +10 -0
- package/src/libs/feature/notifications/src/lib/notification.model.ts +6 -0
- package/src/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.css +0 -0
- package/src/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.html +17 -0
- package/src/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.ts +44 -0
- package/src/libs/feature/notifications/src/lib/notifications.service.ts +27 -0
- package/src/libs/feature/record/src/lib/feature-record.module.ts +5 -2
- package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +22 -10
- package/src/libs/feature/record/src/lib/state/mdview.actions.ts +51 -6
- package/src/libs/feature/record/src/lib/state/mdview.effects.ts +82 -7
- package/src/libs/feature/record/src/lib/state/mdview.facade.ts +86 -9
- package/src/libs/feature/record/src/lib/state/mdview.reducer.ts +79 -24
- package/src/libs/feature/record/src/lib/state/mdview.selectors.ts +40 -10
- package/src/libs/feature/router/src/lib/default/state/router.effects.ts +2 -2
- package/src/libs/feature/search/src/index.ts +1 -0
- package/src/libs/feature/search/src/lib/results-list/results-list.container.component.html +4 -4
- package/src/libs/feature/search/src/lib/results-table/results-table.component.html +3 -3
- package/src/libs/feature/search/src/lib/utils/service/fields.service.ts +2 -2
- package/src/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.html +5 -5
- package/src/libs/ui/elements/src/index.ts +15 -15
- package/src/libs/ui/elements/src/lib/api-card/api-card.component.ts +2 -1
- package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +1 -1
- package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.html → error/error.component.html} +18 -3
- package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.ts → error/error.component.ts} +5 -4
- package/src/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.html +1 -1
- package/src/libs/ui/elements/src/lib/link-card/link-card.component.html +38 -20
- package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +12 -0
- package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.css +0 -5
- package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.html +0 -21
- package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.ts +1 -14
- package/src/libs/ui/elements/src/lib/notification/notification.component.css +0 -0
- package/src/libs/ui/elements/src/lib/notification/notification.component.html +52 -0
- package/src/libs/ui/elements/src/lib/notification/notification.component.ts +31 -0
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +27 -11
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +125 -30
- package/src/libs/ui/elements/src/lib/thumbnail/thumbnail.component.ts +5 -3
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +9 -7
- package/src/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.ts +54 -0
- package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.css +0 -0
- package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.html +75 -0
- package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.ts +62 -0
- package/src/libs/ui/inputs/src/index.ts +15 -15
- package/src/libs/ui/inputs/src/lib/button/button.component.ts +1 -1
- package/src/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.ts +3 -0
- package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.css +3 -0
- package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.html +11 -0
- package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.ts +16 -0
- package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.ts +8 -1
- package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.html +1 -0
- package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.ts +14 -0
- package/src/libs/ui/inputs/src/lib/files-drop/files-drop.directive.ts +45 -0
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.css +0 -0
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +146 -0
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +193 -0
- package/src/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.css +6 -0
- package/src/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.html +26 -0
- package/src/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.ts +32 -0
- package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +2 -1
- package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +29 -0
- package/src/libs/ui/inputs/src/lib/text-input/text-input.component.html +2 -1
- package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +17 -1
- package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +6 -22
- package/src/libs/ui/layout/src/index.ts +6 -4
- package/src/libs/ui/layout/src/lib/block-list/block-list.component.css +23 -0
- package/src/libs/ui/layout/src/lib/block-list/block-list.component.html +20 -0
- package/src/libs/ui/layout/src/lib/block-list/block-list.component.ts +84 -0
- package/src/libs/ui/layout/src/lib/carousel/carousel.component.css +8 -4
- package/src/libs/ui/layout/src/lib/carousel/carousel.component.html +4 -4
- package/src/libs/ui/layout/src/lib/carousel/carousel.component.ts +45 -15
- package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.css +0 -0
- package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.html +18 -0
- package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.ts +16 -0
- package/src/libs/ui/layout/src/lib/ui-layout.module.ts +0 -2
- package/src/libs/util/app-config/src/lib/app-config.ts +2 -0
- package/src/libs/util/app-config/src/lib/fixtures.ts +1 -0
- package/src/libs/util/app-config/src/lib/model.ts +1 -0
- package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +1 -1
- package/src/libs/util/shared/src/lib/links/link-utils.ts +21 -0
- package/src/libs/util/shared/src/lib/utils/bytes-convert.ts +3 -0
- package/src/libs/util/shared/src/lib/utils/image-resize.ts +72 -0
- package/src/libs/util/shared/src/lib/utils/index.ts +7 -5
- package/tailwind.base.css +36 -0
- package/translations/de.json +44 -0
- package/translations/en.json +44 -0
- package/translations/es.json +44 -0
- package/translations/fr.json +44 -0
- package/translations/it.json +44 -0
- package/translations/nl.json +44 -0
- package/translations/pt.json +44 -0
- package/translations/sk.json +44 -0
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.metadata.mapper.mjs +0 -52
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/codelists/keyword.mapper.mjs +0 -14
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/codelists/role.mapper.mjs +0 -48
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/codelists/status.mapper.mjs +0 -18
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/codelists/update-frequency.mapper.mjs +0 -64
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/converter.mjs +0 -130
- package/esm2022/libs/api/metadata-converter/src/lib/metadata-base.mapper.mjs +0 -14
- package/esm2022/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.mjs +0 -13
- package/esm2022/libs/feature/editor/src/lib/record-form/record-form.component.mjs +0 -30
- package/esm2022/libs/ui/elements/src/lib/search-results-error/search-results-error.component.mjs +0 -29
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-array/form-field-array.component.mjs +0 -11
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-file/form-field-file.component.mjs +0 -27
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-object/form-field-object.component.mjs +0 -11
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.mjs +0 -27
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-simple/form-field-simple.component.mjs +0 -49
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +0 -11
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-temporal-extent/form-field-temporal-extent.component.mjs +0 -11
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field.component.mjs +0 -76
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field.model.mjs +0 -2
- package/esm2022/libs/ui/inputs/src/lib/form-field/index.mjs +0 -10
- package/libs/api/metadata-converter/src/lib/gn4/gn4.metadata.mapper.d.ts.map +0 -1
- package/libs/api/metadata-converter/src/lib/iso19139/codelists/keyword.mapper.d.ts.map +0 -1
- package/libs/api/metadata-converter/src/lib/iso19139/codelists/role.mapper.d.ts.map +0 -1
- package/libs/api/metadata-converter/src/lib/iso19139/codelists/status.mapper.d.ts.map +0 -1
- package/libs/api/metadata-converter/src/lib/iso19139/codelists/update-frequency.mapper.d.ts.map +0 -1
- package/libs/api/metadata-converter/src/lib/iso19139/converter.d.ts +0 -4
- package/libs/api/metadata-converter/src/lib/iso19139/converter.d.ts.map +0 -1
- package/libs/api/metadata-converter/src/lib/metadata-base.mapper.d.ts.map +0 -1
- package/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.d.ts +0 -18
- package/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.d.ts.map +0 -1
- package/libs/feature/editor/src/lib/record-form/record-form.component.d.ts.map +0 -1
- package/libs/ui/elements/src/lib/search-results-error/search-results-error.component.d.ts +0 -15
- package/libs/ui/elements/src/lib/search-results-error/search-results-error.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field-array/form-field-array.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field-file/form-field-file.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field-object/form-field-object.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.d.ts +0 -11
- package/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field-simple/form-field-simple.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field-temporal-extent/form-field-temporal-extent.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field.component.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field.model.d.ts.map +0 -1
- package/libs/ui/inputs/src/lib/form-field/index.d.ts.map +0 -1
- package/src/libs/api/metadata-converter/src/lib/iso19139/converter.ts +0 -196
- package/src/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.ts +0 -18
- package/src/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.html +0 -11
- package/src/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.ts +0 -15
- package/src/libs/ui/inputs/src/lib/form-field/form-field.component.html +0 -68
- package/src/libs/ui/inputs/src/lib/form-field/form-field.component.ts +0 -80
- /package/libs/api/metadata-converter/src/lib/iso19139/{codelists → utils}/keyword.mapper.d.ts +0 -0
- /package/libs/api/metadata-converter/src/lib/iso19139/{codelists → utils}/role.mapper.d.ts +0 -0
- /package/libs/api/metadata-converter/src/lib/iso19139/{codelists → utils}/status.mapper.d.ts +0 -0
- /package/libs/api/metadata-converter/src/lib/iso19139/{codelists → utils}/update-frequency.mapper.d.ts +0 -0
- /package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field.model.d.ts +0 -0
- /package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/index.d.ts +0 -0
- /package/src/libs/api/metadata-converter/src/lib/iso19139/{codelists → utils}/keyword.mapper.ts +0 -0
- /package/src/libs/api/metadata-converter/src/lib/iso19139/{codelists → utils}/role.mapper.ts +0 -0
- /package/src/libs/api/metadata-converter/src/lib/iso19139/{codelists → utils}/status.mapper.ts +0 -0
- /package/src/libs/api/metadata-converter/src/lib/iso19139/{codelists → utils}/update-frequency.mapper.ts +0 -0
- /package/src/libs/feature/editor/src/lib/{record-form/record-form.component.css → components/overview-upload/overview-upload.component.css} +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-array/form-field-array.component.css +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-array/form-field-array.component.html +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-file/form-field-file.component.css +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-file/form-field-file.component.html +0 -0
- /package/src/libs/{ui/inputs/src/lib/form-field/form-field-object/form-field-object.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.css} +0 -0
- /package/src/libs/{ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-object/form-field-object.component.css} +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-object/form-field-object.component.html +0 -0
- /package/src/libs/{ui/inputs/src/lib/form-field/form-field-simple/form-field-simple.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.css} +0 -0
- /package/src/libs/{ui/inputs/src/lib/form-field/form-field-spatial-extent/form-field-spatial-extent.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.css} +0 -0
- /package/src/libs/{ui/inputs/src/lib/form-field/form-field-temporal-extent/form-field-temporal-extent.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.css} +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-simple/form-field-simple.component.html +0 -0
- /package/src/libs/{ui/inputs/src/lib/form-field/form-field.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.css} +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-temporal-extent/form-field-temporal-extent.component.html +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field.model.ts +0 -0
- /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/index.ts +0 -0
- /package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.css → error/error.component.css} +0 -0
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core'
|
|
2
|
+
import { NotificationContent } from './notification.model'
|
|
3
|
+
import { BehaviorSubject } from 'rxjs'
|
|
4
|
+
|
|
5
|
+
type NotificationWithIdentity = NotificationContent & { id: number }
|
|
6
|
+
|
|
7
|
+
@Injectable({
|
|
8
|
+
providedIn: 'root',
|
|
9
|
+
})
|
|
10
|
+
export class NotificationsService {
|
|
11
|
+
notifications$ = new BehaviorSubject<NotificationWithIdentity[]>([])
|
|
12
|
+
|
|
13
|
+
showNotification(content: NotificationContent, timeoutMs?: number) {
|
|
14
|
+
const id = Math.floor(Math.random() * 1000000)
|
|
15
|
+
this.notifications$.next([...this.notifications$.value, { ...content, id }])
|
|
16
|
+
if (typeof timeoutMs === 'undefined') return
|
|
17
|
+
setTimeout(() => {
|
|
18
|
+
this.removeNotificationById(id)
|
|
19
|
+
}, timeoutMs)
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
removeNotificationById(id: number) {
|
|
23
|
+
this.notifications$.next(
|
|
24
|
+
this.notifications$.value.filter((n) => n.id !== id)
|
|
25
|
+
)
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -11,7 +11,10 @@ import { MdViewFacade } from './state'
|
|
|
11
11
|
import { MdViewEffects } from './state/mdview.effects'
|
|
12
12
|
import { MapViewComponent } from './map-view/map-view.component'
|
|
13
13
|
import { DataViewComponent } from './data-view/data-view.component'
|
|
14
|
-
import {
|
|
14
|
+
import {
|
|
15
|
+
METADATA_VIEW_FEATURE_STATE_KEY,
|
|
16
|
+
reducer,
|
|
17
|
+
} from './state/mdview.reducer'
|
|
15
18
|
import { MatTabsModule } from '@angular/material/tabs'
|
|
16
19
|
import { MatIconModule } from '@angular/material/icon'
|
|
17
20
|
import { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'
|
|
@@ -35,7 +38,7 @@ import { DataViewShareComponent } from './data-view-share/data-view-share.compon
|
|
|
35
38
|
],
|
|
36
39
|
imports: [
|
|
37
40
|
CommonModule,
|
|
38
|
-
StoreModule.forFeature(
|
|
41
|
+
StoreModule.forFeature(METADATA_VIEW_FEATURE_STATE_KEY, reducer),
|
|
39
42
|
EffectsModule.forFeature([MdViewEffects]),
|
|
40
43
|
UiLayoutModule,
|
|
41
44
|
FeatureMapModule,
|
|
@@ -15,7 +15,7 @@ import {
|
|
|
15
15
|
MapUtilsService,
|
|
16
16
|
} from '../../../../../../libs/feature/map/src'
|
|
17
17
|
import { getOptionalMapConfig, MapConfig } from '../../../../../../libs/util/app-config/src'
|
|
18
|
-
import { getLinkLabel
|
|
18
|
+
import { getLinkLabel } from '../../../../../../libs/util/shared/src'
|
|
19
19
|
import Feature from 'ol/Feature'
|
|
20
20
|
import { Geometry } from 'ol/geom'
|
|
21
21
|
import { StyleLike } from 'ol/style/Style'
|
|
@@ -23,10 +23,8 @@ import {
|
|
|
23
23
|
BehaviorSubject,
|
|
24
24
|
combineLatest,
|
|
25
25
|
from,
|
|
26
|
-
lastValueFrom,
|
|
27
26
|
Observable,
|
|
28
27
|
of,
|
|
29
|
-
startWith,
|
|
30
28
|
Subscription,
|
|
31
29
|
throwError,
|
|
32
30
|
withLatestFrom,
|
|
@@ -36,6 +34,7 @@ import {
|
|
|
36
34
|
distinctUntilChanged,
|
|
37
35
|
finalize,
|
|
38
36
|
map,
|
|
37
|
+
startWith,
|
|
39
38
|
switchMap,
|
|
40
39
|
tap,
|
|
41
40
|
} from 'rxjs/operators'
|
|
@@ -57,9 +56,11 @@ export class MapViewComponent implements OnInit, OnDestroy {
|
|
|
57
56
|
|
|
58
57
|
compatibleMapLinks$ = combineLatest([
|
|
59
58
|
this.mdViewFacade.mapApiLinks$,
|
|
60
|
-
this.mdViewFacade.
|
|
59
|
+
this.mdViewFacade.geoDataLinksWithGeometry$,
|
|
61
60
|
]).pipe(
|
|
62
|
-
map(([mapApiLinks,
|
|
61
|
+
map(([mapApiLinks, geoDataLinksWithGeometry]) => {
|
|
62
|
+
return [...mapApiLinks, ...geoDataLinksWithGeometry]
|
|
63
|
+
})
|
|
63
64
|
)
|
|
64
65
|
|
|
65
66
|
dropdownChoices$ = this.compatibleMapLinks$.pipe(
|
|
@@ -104,8 +105,8 @@ export class MapViewComponent implements OnInit, OnDestroy {
|
|
|
104
105
|
mapContext$ = this.currentLayers$.pipe(
|
|
105
106
|
switchMap((layers) =>
|
|
106
107
|
from(this.mapUtils.getLayerExtent(layers[0])).pipe(
|
|
107
|
-
catchError((
|
|
108
|
-
|
|
108
|
+
catchError(() => {
|
|
109
|
+
this.error = 'The layer has no extent'
|
|
109
110
|
return of(undefined)
|
|
110
111
|
}),
|
|
111
112
|
map(
|
|
@@ -117,9 +118,15 @@ export class MapViewComponent implements OnInit, OnDestroy {
|
|
|
117
118
|
},
|
|
118
119
|
} as MapContextModel)
|
|
119
120
|
),
|
|
120
|
-
tap(() =>
|
|
121
|
+
tap((res) => {
|
|
122
|
+
this.resetSelection()
|
|
123
|
+
})
|
|
121
124
|
)
|
|
122
125
|
),
|
|
126
|
+
startWith({
|
|
127
|
+
layers: [],
|
|
128
|
+
view: {},
|
|
129
|
+
} as MapContextModel),
|
|
123
130
|
withLatestFrom(this.mdViewFacade.metadata$),
|
|
124
131
|
map(([context, metadata]) => {
|
|
125
132
|
if (context.view.extent) return context
|
|
@@ -188,11 +195,16 @@ export class MapViewComponent implements OnInit, OnDestroy {
|
|
|
188
195
|
link.type === 'service' &&
|
|
189
196
|
link.accessServiceProtocol === 'wmts'
|
|
190
197
|
) {
|
|
191
|
-
return
|
|
198
|
+
return of({
|
|
199
|
+
url: link.url.toString(),
|
|
200
|
+
type: MapContextLayerTypeEnum.WMTS,
|
|
201
|
+
name: link.name,
|
|
202
|
+
})
|
|
192
203
|
} else if (
|
|
193
204
|
(link.type === 'service' &&
|
|
194
205
|
(link.accessServiceProtocol === 'wfs' ||
|
|
195
|
-
link.accessServiceProtocol === 'esriRest'
|
|
206
|
+
link.accessServiceProtocol === 'esriRest' ||
|
|
207
|
+
link.accessServiceProtocol === 'ogcFeatures')) ||
|
|
196
208
|
link.type === 'download'
|
|
197
209
|
) {
|
|
198
210
|
return this.dataService.readAsGeoJson(link).pipe(
|
|
@@ -1,7 +1,13 @@
|
|
|
1
1
|
import { DatavizConfigurationModel } from '../../../../../../libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model'
|
|
2
2
|
import { createAction, props } from '@ngrx/store'
|
|
3
|
-
import {
|
|
3
|
+
import {
|
|
4
|
+
CatalogRecord,
|
|
5
|
+
UserFeedback,
|
|
6
|
+
} from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
4
7
|
|
|
8
|
+
/*
|
|
9
|
+
Metadata actions
|
|
10
|
+
*/
|
|
5
11
|
export const loadFullMetadata = createAction(
|
|
6
12
|
'[Metadata view] Load full metadata',
|
|
7
13
|
props<{ uuid: string }>()
|
|
@@ -12,24 +18,63 @@ export const setIncompleteMetadata = createAction(
|
|
|
12
18
|
props<{ incomplete: Partial<CatalogRecord> }>()
|
|
13
19
|
)
|
|
14
20
|
|
|
15
|
-
export const
|
|
16
|
-
'[Metadata view] Load full success',
|
|
21
|
+
export const loadFullMetadataSuccess = createAction(
|
|
22
|
+
'[Metadata view] Load full metadata success',
|
|
17
23
|
props<{ full: CatalogRecord }>()
|
|
18
24
|
)
|
|
19
25
|
|
|
20
|
-
export const
|
|
21
|
-
'[Metadata view] Load full failure',
|
|
26
|
+
export const loadFullMetadataFailure = createAction(
|
|
27
|
+
'[Metadata view] Load full metadata failure',
|
|
22
28
|
props<{ otherError?: string; notFound?: boolean }>()
|
|
23
29
|
)
|
|
24
30
|
|
|
31
|
+
export const closeMetadata = createAction('[Metadata view] close')
|
|
32
|
+
|
|
33
|
+
/*
|
|
34
|
+
Related actions
|
|
35
|
+
*/
|
|
25
36
|
export const setRelated = createAction(
|
|
26
37
|
'[Metadata view] Set related records',
|
|
27
38
|
props<{ related: CatalogRecord[] }>()
|
|
28
39
|
)
|
|
29
40
|
|
|
41
|
+
/*
|
|
42
|
+
ChartConfig actions
|
|
43
|
+
*/
|
|
30
44
|
export const setChartConfig = createAction(
|
|
31
45
|
'[Metadata view] Set chart config',
|
|
32
46
|
props<{ chartConfig: DatavizConfigurationModel }>()
|
|
33
47
|
)
|
|
34
48
|
|
|
35
|
-
|
|
49
|
+
/*
|
|
50
|
+
User Feedbacks actions
|
|
51
|
+
*/
|
|
52
|
+
export const addUserFeedback = createAction(
|
|
53
|
+
'[Metadata view] Add UserFeedback',
|
|
54
|
+
props<{ userFeedback: UserFeedback }>()
|
|
55
|
+
)
|
|
56
|
+
|
|
57
|
+
export const addUserFeedbackSuccess = createAction(
|
|
58
|
+
'[Metadata view] Add UserFeedback Success',
|
|
59
|
+
props<{ datasetUuid: string }>()
|
|
60
|
+
)
|
|
61
|
+
|
|
62
|
+
export const addUserFeedbackFailure = createAction(
|
|
63
|
+
'[Metadata view] Add UserFeedback Failure',
|
|
64
|
+
props<{ otherError?: string; notFound?: boolean }>()
|
|
65
|
+
)
|
|
66
|
+
|
|
67
|
+
export const loadUserFeedbacks = createAction(
|
|
68
|
+
'[Metadata view] Load UserFeedbacks',
|
|
69
|
+
props<{ datasetUuid: string }>()
|
|
70
|
+
)
|
|
71
|
+
|
|
72
|
+
export const loadUserFeedbacksSuccess = createAction(
|
|
73
|
+
'[Metadata view] Load UserFeedbacks Success',
|
|
74
|
+
props<{ userFeedbacks: UserFeedback[] }>()
|
|
75
|
+
)
|
|
76
|
+
|
|
77
|
+
export const loadUserFeedbacksFailure = createAction(
|
|
78
|
+
'[Metadata view] Load UserFeedbacks Failure',
|
|
79
|
+
props<{ otherError?: string; notFound?: boolean }>()
|
|
80
|
+
)
|
|
@@ -1,18 +1,23 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core'
|
|
2
2
|
import { Actions, createEffect, ofType } from '@ngrx/effects'
|
|
3
|
-
import { of } from 'rxjs'
|
|
3
|
+
import { exhaustMap, mergeMap, of } from 'rxjs'
|
|
4
4
|
import { catchError, map, switchMap } from 'rxjs/operators'
|
|
5
5
|
import * as MdViewActions from './mdview.actions'
|
|
6
6
|
import { RecordsRepositoryInterface } from '../../../../../../libs/common/domain/src/lib/repository/records-repository.interface'
|
|
7
|
+
import { PlatformServiceInterface } from '../../../../../../libs/common/domain/src/lib/platform.service.interface'
|
|
7
8
|
|
|
8
9
|
@Injectable()
|
|
9
10
|
export class MdViewEffects {
|
|
10
11
|
constructor(
|
|
11
12
|
private actions$: Actions,
|
|
12
|
-
private recordsRepository: RecordsRepositoryInterface
|
|
13
|
+
private recordsRepository: RecordsRepositoryInterface,
|
|
14
|
+
private platformServiceInterface: PlatformServiceInterface
|
|
13
15
|
) {}
|
|
14
16
|
|
|
15
|
-
|
|
17
|
+
/*
|
|
18
|
+
Metadata effects
|
|
19
|
+
*/
|
|
20
|
+
loadFullMetadata$ = createEffect(() =>
|
|
16
21
|
this.actions$.pipe(
|
|
17
22
|
ofType(MdViewActions.loadFullMetadata),
|
|
18
23
|
switchMap(({ uuid }) =>
|
|
@@ -20,19 +25,22 @@ export class MdViewEffects {
|
|
|
20
25
|
),
|
|
21
26
|
map((record) => {
|
|
22
27
|
if (record === null) {
|
|
23
|
-
return MdViewActions.
|
|
28
|
+
return MdViewActions.loadFullMetadataFailure({ notFound: true })
|
|
24
29
|
}
|
|
25
|
-
return MdViewActions.
|
|
30
|
+
return MdViewActions.loadFullMetadataSuccess({ full: record })
|
|
26
31
|
}),
|
|
27
32
|
catchError((error) =>
|
|
28
|
-
of(MdViewActions.
|
|
33
|
+
of(MdViewActions.loadFullMetadataFailure({ otherError: error.message }))
|
|
29
34
|
)
|
|
30
35
|
)
|
|
31
36
|
)
|
|
32
37
|
|
|
38
|
+
/*
|
|
39
|
+
Related effects
|
|
40
|
+
*/
|
|
33
41
|
loadRelatedRecords$ = createEffect(() =>
|
|
34
42
|
this.actions$.pipe(
|
|
35
|
-
ofType(MdViewActions.
|
|
43
|
+
ofType(MdViewActions.loadFullMetadataSuccess),
|
|
36
44
|
switchMap(({ full }) => this.recordsRepository.getSimilarRecords(full)),
|
|
37
45
|
map((related) => {
|
|
38
46
|
return MdViewActions.setRelated({ related })
|
|
@@ -40,4 +48,71 @@ export class MdViewEffects {
|
|
|
40
48
|
catchError((error) => of(MdViewActions.setRelated({ related: null })))
|
|
41
49
|
)
|
|
42
50
|
)
|
|
51
|
+
|
|
52
|
+
/*
|
|
53
|
+
UserFeedback effects
|
|
54
|
+
*/
|
|
55
|
+
loadUserFeedbacks$ = createEffect(() =>
|
|
56
|
+
this.actions$.pipe(
|
|
57
|
+
ofType(MdViewActions.loadUserFeedbacks),
|
|
58
|
+
exhaustMap(({ datasetUuid }) =>
|
|
59
|
+
this.platformServiceInterface.getUserFeedbacks(datasetUuid).pipe(
|
|
60
|
+
map((userFeedbacks) =>
|
|
61
|
+
MdViewActions.loadUserFeedbacksSuccess({ userFeedbacks })
|
|
62
|
+
),
|
|
63
|
+
catchError((error) =>
|
|
64
|
+
of(
|
|
65
|
+
MdViewActions.loadUserFeedbacksFailure({
|
|
66
|
+
otherError: error.message,
|
|
67
|
+
})
|
|
68
|
+
)
|
|
69
|
+
)
|
|
70
|
+
)
|
|
71
|
+
)
|
|
72
|
+
)
|
|
73
|
+
)
|
|
74
|
+
|
|
75
|
+
reloadUserFeedbacks$ = createEffect(() =>
|
|
76
|
+
this.actions$.pipe(
|
|
77
|
+
ofType(MdViewActions.addUserFeedbackSuccess),
|
|
78
|
+
exhaustMap(({ datasetUuid }) =>
|
|
79
|
+
this.platformServiceInterface.getUserFeedbacks(datasetUuid).pipe(
|
|
80
|
+
map((userFeedbacks) =>
|
|
81
|
+
MdViewActions.loadUserFeedbacksSuccess({ userFeedbacks })
|
|
82
|
+
),
|
|
83
|
+
catchError((error) =>
|
|
84
|
+
of(
|
|
85
|
+
MdViewActions.loadUserFeedbacksFailure({
|
|
86
|
+
otherError: error.message,
|
|
87
|
+
})
|
|
88
|
+
)
|
|
89
|
+
)
|
|
90
|
+
)
|
|
91
|
+
)
|
|
92
|
+
)
|
|
93
|
+
)
|
|
94
|
+
|
|
95
|
+
addUserFeedback$ = createEffect(() =>
|
|
96
|
+
this.actions$.pipe(
|
|
97
|
+
ofType(MdViewActions.addUserFeedback),
|
|
98
|
+
mergeMap((action) =>
|
|
99
|
+
this.platformServiceInterface
|
|
100
|
+
.postUserFeedbacks(action.userFeedback)
|
|
101
|
+
.pipe(
|
|
102
|
+
map(() =>
|
|
103
|
+
MdViewActions.addUserFeedbackSuccess({
|
|
104
|
+
datasetUuid: action.userFeedback.metadataUUID,
|
|
105
|
+
})
|
|
106
|
+
),
|
|
107
|
+
catchError((error) => {
|
|
108
|
+
return of(
|
|
109
|
+
MdViewActions.addUserFeedbackFailure({
|
|
110
|
+
otherError: error.message,
|
|
111
|
+
})
|
|
112
|
+
)
|
|
113
|
+
})
|
|
114
|
+
)
|
|
115
|
+
)
|
|
116
|
+
)
|
|
117
|
+
)
|
|
43
118
|
}
|
|
@@ -1,11 +1,18 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core'
|
|
2
2
|
import { select, Store } from '@ngrx/store'
|
|
3
|
-
import { filter, map } from 'rxjs/operators'
|
|
3
|
+
import { defaultIfEmpty, filter, map, mergeMap, scan } from 'rxjs/operators'
|
|
4
4
|
import * as MdViewActions from './mdview.actions'
|
|
5
5
|
import * as MdViewSelectors from './mdview.selectors'
|
|
6
6
|
import { LinkClassifierService, LinkUsage } from '../../../../../../libs/util/shared/src'
|
|
7
7
|
import { DatavizConfigurationModel } from '../../../../../../libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model'
|
|
8
|
-
import {
|
|
8
|
+
import {
|
|
9
|
+
CatalogRecord,
|
|
10
|
+
UserFeedback,
|
|
11
|
+
} from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
12
|
+
import { AvatarServiceInterface } from '../../../../../../libs/api/repository/src'
|
|
13
|
+
import { OgcApiRecord } from '@camptocamp/ogc-client'
|
|
14
|
+
import { from, of } from 'rxjs'
|
|
15
|
+
import { DataService } from '../../../../../../libs/feature/dataviz/src'
|
|
9
16
|
|
|
10
17
|
@Injectable()
|
|
11
18
|
/**
|
|
@@ -15,19 +22,32 @@ import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/mode
|
|
|
15
22
|
* To clear the current record use the `close()` method.
|
|
16
23
|
*/
|
|
17
24
|
export class MdViewFacade {
|
|
25
|
+
constructor(
|
|
26
|
+
private store: Store,
|
|
27
|
+
public linkClassifier: LinkClassifierService,
|
|
28
|
+
private avatarService: AvatarServiceInterface,
|
|
29
|
+
public dataService: DataService
|
|
30
|
+
) {}
|
|
31
|
+
|
|
18
32
|
isPresent$ = this.store.pipe(
|
|
19
33
|
select(MdViewSelectors.getMetadataUuid),
|
|
20
34
|
map((uuid) => !!uuid)
|
|
21
35
|
)
|
|
22
|
-
|
|
36
|
+
|
|
37
|
+
isMetadataLoading$ = this.store.pipe(
|
|
38
|
+
select(MdViewSelectors.getMetadataIsLoading)
|
|
39
|
+
)
|
|
40
|
+
|
|
23
41
|
metadata$ = this.store.pipe(
|
|
24
42
|
select(MdViewSelectors.getMetadata),
|
|
25
43
|
filter((md) => !!md)
|
|
26
44
|
)
|
|
45
|
+
|
|
27
46
|
isIncomplete$ = this.store.pipe(
|
|
28
47
|
select(MdViewSelectors.getMetadataIsIncomplete),
|
|
29
48
|
filter((incomplete) => incomplete !== null)
|
|
30
49
|
)
|
|
50
|
+
|
|
31
51
|
error$ = this.store.pipe(select(MdViewSelectors.getMetadataError))
|
|
32
52
|
|
|
33
53
|
related$ = this.store.pipe(select(MdViewSelectors.getRelated))
|
|
@@ -37,11 +57,13 @@ export class MdViewFacade {
|
|
|
37
57
|
allLinks$ = this.metadata$.pipe(
|
|
38
58
|
map((record) => ('distributions' in record ? record.distributions : []))
|
|
39
59
|
)
|
|
60
|
+
|
|
40
61
|
apiLinks$ = this.allLinks$.pipe(
|
|
41
62
|
map((links) =>
|
|
42
63
|
links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.API))
|
|
43
64
|
)
|
|
44
65
|
)
|
|
66
|
+
|
|
45
67
|
mapApiLinks$ = this.allLinks$.pipe(
|
|
46
68
|
map((links) =>
|
|
47
69
|
links.filter((link) =>
|
|
@@ -49,6 +71,7 @@ export class MdViewFacade {
|
|
|
49
71
|
)
|
|
50
72
|
)
|
|
51
73
|
)
|
|
74
|
+
|
|
52
75
|
downloadLinks$ = this.allLinks$.pipe(
|
|
53
76
|
map((links) =>
|
|
54
77
|
links.filter((link) =>
|
|
@@ -56,11 +79,13 @@ export class MdViewFacade {
|
|
|
56
79
|
)
|
|
57
80
|
)
|
|
58
81
|
)
|
|
82
|
+
|
|
59
83
|
dataLinks$ = this.allLinks$.pipe(
|
|
60
84
|
map((links) =>
|
|
61
85
|
links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.DATA))
|
|
62
86
|
)
|
|
63
87
|
)
|
|
88
|
+
|
|
64
89
|
geoDataLinks$ = this.allLinks$.pipe(
|
|
65
90
|
map((links) =>
|
|
66
91
|
links.filter((link) =>
|
|
@@ -68,9 +93,44 @@ export class MdViewFacade {
|
|
|
68
93
|
)
|
|
69
94
|
)
|
|
70
95
|
)
|
|
96
|
+
|
|
97
|
+
geoDataLinksWithGeometry$ = this.allLinks$.pipe(
|
|
98
|
+
mergeMap((links) => {
|
|
99
|
+
return from(links)
|
|
100
|
+
}),
|
|
101
|
+
mergeMap((link) => {
|
|
102
|
+
if (this.linkClassifier.hasUsage(link, LinkUsage.GEODATA)) {
|
|
103
|
+
if (
|
|
104
|
+
link.type === 'service' &&
|
|
105
|
+
link.accessServiceProtocol === 'ogcFeatures'
|
|
106
|
+
) {
|
|
107
|
+
return from(this.dataService.getItemsFromOgcApi(link.url.href)).pipe(
|
|
108
|
+
map((collectionRecords: OgcApiRecord) => {
|
|
109
|
+
return collectionRecords && collectionRecords.geometry
|
|
110
|
+
? link
|
|
111
|
+
: null
|
|
112
|
+
}),
|
|
113
|
+
defaultIfEmpty(null)
|
|
114
|
+
)
|
|
115
|
+
} else {
|
|
116
|
+
return of(link)
|
|
117
|
+
}
|
|
118
|
+
} else {
|
|
119
|
+
return of(null)
|
|
120
|
+
}
|
|
121
|
+
}),
|
|
122
|
+
scan((acc, val) => {
|
|
123
|
+
if (val !== null && !acc.includes(val)) {
|
|
124
|
+
acc.push(val)
|
|
125
|
+
}
|
|
126
|
+
return acc
|
|
127
|
+
}, [])
|
|
128
|
+
)
|
|
129
|
+
|
|
71
130
|
landingPageLinks$ = this.metadata$.pipe(
|
|
72
131
|
map((record) => ('landingPage' in record ? [record.landingPage] : []))
|
|
73
132
|
)
|
|
133
|
+
|
|
74
134
|
otherLinks$ = this.allLinks$.pipe(
|
|
75
135
|
map((links) =>
|
|
76
136
|
links.filter((link) =>
|
|
@@ -79,10 +139,13 @@ export class MdViewFacade {
|
|
|
79
139
|
)
|
|
80
140
|
)
|
|
81
141
|
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
)
|
|
142
|
+
userFeedbacks$ = this.store.pipe(select(MdViewSelectors.getUserFeedbacks))
|
|
143
|
+
isAllUserFeedbackLoading$ = this.store.pipe(
|
|
144
|
+
select(MdViewSelectors.getAllUserFeedbacksLoading)
|
|
145
|
+
)
|
|
146
|
+
isAddUserFeedbackLoading$ = this.store.pipe(
|
|
147
|
+
select(MdViewSelectors.getAddUserFeedbacksLoading)
|
|
148
|
+
)
|
|
86
149
|
|
|
87
150
|
/**
|
|
88
151
|
* This will show an incomplete record (e.g. from a search result) as a preview
|
|
@@ -91,16 +154,30 @@ export class MdViewFacade {
|
|
|
91
154
|
setIncompleteMetadata(incomplete: CatalogRecord) {
|
|
92
155
|
this.store.dispatch(MdViewActions.setIncompleteMetadata({ incomplete }))
|
|
93
156
|
}
|
|
157
|
+
|
|
94
158
|
/**
|
|
95
159
|
* This will trigger the load of a full metadata record
|
|
96
160
|
*/
|
|
97
161
|
loadFull(uuid: string) {
|
|
98
162
|
this.store.dispatch(MdViewActions.loadFullMetadata({ uuid }))
|
|
99
163
|
}
|
|
100
|
-
|
|
101
|
-
|
|
164
|
+
|
|
165
|
+
closeMetadata() {
|
|
166
|
+
this.store.dispatch(MdViewActions.closeMetadata())
|
|
102
167
|
}
|
|
168
|
+
|
|
103
169
|
setChartConfig(chartConfig: DatavizConfigurationModel) {
|
|
104
170
|
this.store.dispatch(MdViewActions.setChartConfig({ chartConfig }))
|
|
105
171
|
}
|
|
172
|
+
|
|
173
|
+
/**
|
|
174
|
+
* UserFeedbacks
|
|
175
|
+
*/
|
|
176
|
+
addUserFeedback(userFeedback: UserFeedback) {
|
|
177
|
+
this.store.dispatch(MdViewActions.addUserFeedback({ userFeedback }))
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
loadUserFeedbacks(datasetUuid: string) {
|
|
181
|
+
this.store.dispatch(MdViewActions.loadUserFeedbacks({ datasetUuid }))
|
|
182
|
+
}
|
|
106
183
|
}
|
|
@@ -1,61 +1,116 @@
|
|
|
1
1
|
import { Action, createReducer, on } from '@ngrx/store'
|
|
2
|
-
import * as
|
|
2
|
+
import * as MetadataViewActions from './mdview.actions'
|
|
3
3
|
import { DatavizConfigurationModel } from '../../../../../../libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model'
|
|
4
|
-
import {
|
|
4
|
+
import {
|
|
5
|
+
CatalogRecord,
|
|
6
|
+
UserFeedback,
|
|
7
|
+
} from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
5
8
|
|
|
6
|
-
export const
|
|
9
|
+
export const METADATA_VIEW_FEATURE_STATE_KEY = 'metadataView'
|
|
7
10
|
|
|
8
|
-
export interface
|
|
11
|
+
export interface MetadataViewState {
|
|
9
12
|
loadingFull: boolean
|
|
10
13
|
error: { notFound?: boolean; otherError?: string } | null
|
|
11
14
|
metadata?: Partial<CatalogRecord>
|
|
12
15
|
related?: CatalogRecord[]
|
|
16
|
+
userFeedbacks?: UserFeedback[]
|
|
17
|
+
allUserFeedbacksLoading: boolean
|
|
18
|
+
addUserFeedbackLoading: boolean
|
|
13
19
|
chartConfig?: DatavizConfigurationModel
|
|
14
20
|
}
|
|
15
21
|
|
|
16
|
-
export const
|
|
22
|
+
export const initialMetadataViewState: MetadataViewState = {
|
|
17
23
|
error: null,
|
|
18
24
|
loadingFull: false,
|
|
25
|
+
allUserFeedbacksLoading: false,
|
|
26
|
+
addUserFeedbackLoading: false,
|
|
19
27
|
}
|
|
20
28
|
|
|
21
|
-
const
|
|
22
|
-
|
|
23
|
-
|
|
29
|
+
const metadataViewReducer = createReducer(
|
|
30
|
+
initialMetadataViewState,
|
|
31
|
+
|
|
32
|
+
/*
|
|
33
|
+
Metadata reducers
|
|
34
|
+
*/
|
|
35
|
+
on(MetadataViewActions.loadFullMetadata, (state) => ({
|
|
24
36
|
...state,
|
|
25
37
|
error: null,
|
|
26
38
|
loadingFull: true,
|
|
27
39
|
})),
|
|
28
|
-
on(
|
|
40
|
+
on(MetadataViewActions.setIncompleteMetadata, (state, { incomplete }) => ({
|
|
29
41
|
...state,
|
|
30
42
|
error: null,
|
|
31
43
|
metadata: incomplete,
|
|
32
44
|
})),
|
|
33
|
-
on(
|
|
45
|
+
on(MetadataViewActions.loadFullMetadataSuccess, (state, { full }) => ({
|
|
34
46
|
...state,
|
|
35
47
|
error: null,
|
|
36
48
|
metadata: full,
|
|
37
49
|
loadingFull: false,
|
|
38
50
|
})),
|
|
39
|
-
on(
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
51
|
+
on(
|
|
52
|
+
MetadataViewActions.loadFullMetadataFailure,
|
|
53
|
+
(state, { otherError, notFound }) => ({
|
|
54
|
+
...state,
|
|
55
|
+
error: { otherError, notFound },
|
|
56
|
+
loadingFull: false,
|
|
57
|
+
})
|
|
58
|
+
),
|
|
59
|
+
on(MetadataViewActions.closeMetadata, (state) => {
|
|
60
|
+
const { metadata, related, userFeedbacks, ...stateWithoutMetadata } = state
|
|
61
|
+
return stateWithoutMetadata
|
|
62
|
+
}),
|
|
63
|
+
|
|
64
|
+
/*
|
|
65
|
+
Related reducers
|
|
66
|
+
*/
|
|
67
|
+
on(MetadataViewActions.setRelated, (state, { related }) => ({
|
|
45
68
|
...state,
|
|
46
69
|
related,
|
|
47
70
|
})),
|
|
48
|
-
|
|
71
|
+
|
|
72
|
+
/*
|
|
73
|
+
ChartConfig reducers
|
|
74
|
+
*/
|
|
75
|
+
on(MetadataViewActions.setChartConfig, (state, { chartConfig }) => ({
|
|
49
76
|
...state,
|
|
50
77
|
chartConfig,
|
|
51
78
|
})),
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
79
|
+
|
|
80
|
+
/*
|
|
81
|
+
UserFeedbacks reducers
|
|
82
|
+
*/
|
|
83
|
+
on(MetadataViewActions.loadUserFeedbacks, (state) => ({
|
|
84
|
+
...state,
|
|
85
|
+
allUserFeedbacksLoading: true,
|
|
86
|
+
})),
|
|
87
|
+
on(MetadataViewActions.addUserFeedback, (state) => ({
|
|
88
|
+
...state,
|
|
89
|
+
addUserFeedbackLoading: true,
|
|
90
|
+
})),
|
|
91
|
+
on(
|
|
92
|
+
MetadataViewActions.loadUserFeedbacksSuccess,
|
|
93
|
+
(state, { userFeedbacks }) => ({
|
|
94
|
+
...state,
|
|
95
|
+
userFeedbacks: userFeedbacks,
|
|
96
|
+
addUserFeedbackLoading: false,
|
|
97
|
+
allUserFeedbacksLoading: false,
|
|
98
|
+
})
|
|
99
|
+
),
|
|
100
|
+
on(
|
|
101
|
+
MetadataViewActions.loadUserFeedbacksFailure,
|
|
102
|
+
(state, { otherError, notFound }) => ({
|
|
103
|
+
...state,
|
|
104
|
+
error: { otherError, notFound },
|
|
105
|
+
addUserFeedbackLoading: false,
|
|
106
|
+
allUserFeedbacksLoading: false,
|
|
107
|
+
})
|
|
108
|
+
)
|
|
57
109
|
)
|
|
58
110
|
|
|
59
|
-
export function reducer(
|
|
60
|
-
|
|
111
|
+
export function reducer(
|
|
112
|
+
metadataViewState: MetadataViewState | undefined,
|
|
113
|
+
action: Action
|
|
114
|
+
) {
|
|
115
|
+
return metadataViewReducer(metadataViewState, action)
|
|
61
116
|
}
|