geonetwork-ui 2.2.0-dev.f866474c → 2.2.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/libs/api/metadata-converter/src/lib/gn4/atomic-operations.mjs +28 -1
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +96 -59
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.metadata.mapper.mjs +8 -4
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.mjs +1 -1
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/codelists/keyword.mapper.mjs +14 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/converter.mjs +25 -17
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +55 -23
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +52 -32
- package/esm2022/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.mjs +2 -2
- package/esm2022/libs/api/repository/src/lib/gn4/index.mjs +3 -1
- package/esm2022/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.mjs +10 -3
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +14 -5
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +33 -8
- package/esm2022/libs/api/repository/src/lib/gn4/selection/selection.service.mjs +13 -26
- package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/model/search/aggregation.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/model/search/field.model.mjs +2 -0
- package/esm2022/libs/common/domain/src/lib/model/search/filter.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/model/search/index.mjs +2 -1
- package/esm2022/libs/common/domain/src/lib/model/search/search.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/model/thesaurus/thesaurus.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
- package/esm2022/libs/feature/catalog/src/lib/my-org/my-org.service.mjs +4 -10
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +5 -4
- package/esm2022/libs/feature/editor/src/index.mjs +6 -1
- package/esm2022/libs/feature/editor/src/lib/+state/editor.actions.mjs +8 -0
- package/esm2022/libs/feature/editor/src/lib/+state/editor.effects.mjs +26 -0
- package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +30 -0
- package/esm2022/libs/feature/editor/src/lib/+state/editor.models.mjs +2 -0
- package/esm2022/libs/feature/editor/src/lib/+state/editor.reducer.mjs +42 -0
- package/esm2022/libs/feature/editor/src/lib/+state/editor.selectors.mjs +13 -0
- package/esm2022/libs/feature/editor/src/lib/expressions.mjs +13 -0
- package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +16 -4
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +34 -0
- package/esm2022/libs/feature/editor/src/lib/models/fields.model.mjs +2 -0
- package/esm2022/libs/feature/editor/src/lib/record-form/record-form.component.mjs +17 -11
- package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +22 -44
- package/esm2022/libs/feature/map/src/index.mjs +2 -1
- package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.mjs +1 -1
- package/esm2022/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.mjs +106 -0
- package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +64 -0
- package/esm2022/libs/feature/map/src/lib/constant/index.mjs +2 -1
- package/esm2022/libs/feature/map/src/lib/constant/projections.mjs +2 -0
- package/esm2022/libs/feature/map/src/lib/feature-map.module.mjs +23 -3
- package/esm2022/libs/feature/map/src/lib/geocoding/geocoding.component.mjs +93 -0
- package/esm2022/libs/feature/map/src/lib/geocoding.service.mjs +40 -0
- package/esm2022/libs/feature/map/src/lib/layers-panel/layers-panel.component.mjs +5 -3
- package/esm2022/libs/feature/map/src/lib/map-context/map-context.service.mjs +11 -1
- package/esm2022/libs/feature/map/src/lib/utils/index.mjs +1 -3
- package/esm2022/libs/feature/map/src/lib/utils/map-utils.service.mjs +60 -29
- package/esm2022/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.mjs +13 -13
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +29 -20
- package/esm2022/libs/feature/record/src/lib/state/mdview.reducer.mjs +2 -2
- package/esm2022/libs/feature/router/src/lib/default/index.mjs +2 -1
- package/esm2022/libs/feature/router/src/lib/default/router.service.mjs +1 -1
- package/esm2022/libs/feature/search/src/index.mjs +4 -1
- package/esm2022/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.mjs +7 -4
- package/esm2022/libs/feature/search/src/lib/feature-search.module.mjs +2 -6
- package/esm2022/libs/feature/search/src/lib/filter-dropdown/filter-dropdown.component.mjs +1 -1
- package/esm2022/libs/feature/search/src/lib/filter-geometry.token.mjs +4 -0
- package/esm2022/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.mjs +7 -3
- package/esm2022/libs/feature/search/src/lib/record-url.token.mjs +4 -0
- package/esm2022/libs/feature/search/src/lib/results-list/results-list.container.component.mjs +3 -3
- package/esm2022/libs/feature/search/src/lib/results-table/results-table.component.mjs +128 -0
- package/esm2022/libs/feature/search/src/lib/state/effects.mjs +6 -4
- package/esm2022/libs/feature/search/src/lib/state/search.facade.mjs +3 -2
- package/esm2022/libs/feature/search/src/lib/utils/service/fields.mjs +41 -26
- package/esm2022/libs/feature/search/src/lib/utils/service/fields.service.mjs +11 -9
- package/esm2022/libs/ui/catalog/src/lib/language-switcher/language-switcher.component.mjs +4 -4
- package/esm2022/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.mjs +1 -1
- package/esm2022/libs/ui/elements/src/index.mjs +4 -1
- package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.mjs +27 -0
- package/esm2022/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.mjs +17 -0
- package/esm2022/libs/ui/elements/src/lib/max-lines/max-lines.component.mjs +5 -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 +47 -16
- package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +3 -4
- package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +9 -6
- package/esm2022/libs/ui/elements/src/lib/related-record-card/related-record-card.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/thumbnail/thumbnail.component.mjs +8 -4
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +16 -4
- package/esm2022/libs/ui/inputs/src/index.mjs +2 -1
- package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +3 -3
- package/esm2022/libs/ui/inputs/src/lib/button/button.component.mjs +9 -9
- package/esm2022/libs/ui/inputs/src/lib/checkbox/checkbox.component.mjs +3 -3
- 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/editable-label/editable-label.directive.mjs +46 -0
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field.component.mjs +4 -2
- package/esm2022/libs/ui/inputs/src/lib/form-field/form-field.model.mjs +1 -1
- package/esm2022/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.mjs +3 -3
- package/esm2022/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.mjs +2 -2
- package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +3 -3
- package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +12 -7
- package/esm2022/libs/ui/layout/src/index.mjs +3 -1
- package/esm2022/libs/ui/layout/src/lib/carousel/carousel.component.mjs +3 -3
- package/esm2022/libs/ui/layout/src/lib/interactive-table/interactive-table-column/interactive-table-column.component.mjs +36 -0
- package/esm2022/libs/ui/layout/src/lib/interactive-table/interactive-table.component.mjs +37 -0
- package/esm2022/libs/ui/search/src/index.mjs +1 -2
- package/esm2022/libs/ui/search/src/lib/record-preview-card/record-preview-card.component.mjs +1 -1
- package/esm2022/libs/ui/search/src/lib/record-preview-feed/record-preview-feed.component.mjs +1 -1
- package/esm2022/libs/ui/search/src/lib/record-preview-list/record-preview-list.component.mjs +1 -1
- package/esm2022/libs/ui/search/src/lib/record-preview-row/record-preview-row.component.mjs +1 -1
- package/esm2022/libs/ui/search/src/lib/record-preview-title/record-preview-title.component.mjs +1 -1
- package/esm2022/libs/ui/search/src/lib/ui-search.module.mjs +9 -10
- package/esm2022/libs/ui/widgets/src/lib/badge/badge.component.mjs +3 -3
- package/esm2022/libs/util/i18n/src/index.mjs +1 -2
- package/esm2022/libs/util/i18n/src/lib/i18n.constants.mjs +18 -1
- package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +29 -13
- package/esm2022/libs/util/shared/src/lib/utils/index.mjs +2 -1
- package/esm2022/libs/util/shared/src/lib/utils/temporal-extent-union.mjs +32 -0
- package/esm2022/translations/de.json +131 -109
- package/esm2022/translations/en.json +63 -41
- package/esm2022/translations/es.json +41 -19
- package/esm2022/translations/fr.json +57 -35
- package/esm2022/translations/it.json +58 -36
- package/esm2022/translations/nl.json +42 -20
- package/esm2022/translations/pt.json +41 -19
- package/fesm2022/geonetwork-ui.mjs +1933 -1071
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/atomic-operations.d.ts +3 -0
- package/libs/api/metadata-converter/src/lib/gn4/atomic-operations.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts +0 -1
- package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/gn4.metadata.mapper.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.d.ts +4 -5
- package/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/codelists/keyword.mapper.d.ts +3 -0
- package/libs/api/metadata-converter/src/lib/iso19139/codelists/keyword.mapper.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/converter.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +7 -6
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +4 -3
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/index.d.ts +2 -0
- package/libs/api/repository/src/lib/gn4/index.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts +1 -1
- 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 -2
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/selection/selection.service.d.ts +4 -5
- package/libs/api/repository/src/lib/gn4/selection/selection.service.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +31 -17
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/search/aggregation.model.d.ts +1 -1
- package/libs/common/domain/src/lib/model/search/aggregation.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/search/field.model.d.ts +2 -0
- package/libs/common/domain/src/lib/model/search/field.model.d.ts.map +1 -0
- package/libs/common/domain/src/lib/model/search/filter.model.d.ts +1 -1
- package/libs/common/domain/src/lib/model/search/filter.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/search/index.d.ts +1 -0
- package/libs/common/domain/src/lib/model/search/index.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/search/search.model.d.ts +2 -3
- package/libs/common/domain/src/lib/model/search/search.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/thesaurus/thesaurus.model.d.ts +1 -0
- package/libs/common/domain/src/lib/model/thesaurus/thesaurus.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/platform.service.interface.d.ts +1 -1
- package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
- package/libs/feature/catalog/src/lib/my-org/my-org.service.d.ts +0 -1
- package/libs/feature/catalog/src/lib/my-org/my-org.service.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts +15 -2
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/editor/src/index.d.ts +5 -0
- package/libs/feature/editor/src/index.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/+state/editor.actions.d.ts +23 -0
- package/libs/feature/editor/src/lib/+state/editor.actions.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/+state/editor.effects.d.ts +15 -0
- package/libs/feature/editor/src/lib/+state/editor.effects.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +19 -0
- package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/+state/editor.models.d.ts +2 -0
- package/libs/feature/editor/src/lib/+state/editor.models.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/+state/editor.reducer.d.ts +18 -0
- package/libs/feature/editor/src/lib/+state/editor.reducer.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/+state/editor.selectors.d.ts +15 -0
- package/libs/feature/editor/src/lib/+state/editor.selectors.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/expressions.d.ts +4 -0
- package/libs/feature/editor/src/lib/expressions.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/feature-editor.module.d.ts +3 -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 +3 -0
- package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/models/fields.model.d.ts +15 -0
- package/libs/feature/editor/src/lib/models/fields.model.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/record-form/record-form.component.d.ts +10 -5
- package/libs/feature/editor/src/lib/record-form/record-form.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/services/editor.service.d.ts +3 -13
- package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
- package/libs/feature/map/src/index.d.ts +1 -0
- package/libs/feature/map/src/index.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts +22 -0
- package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts.map +1 -0
- package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts +22 -0
- package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts.map +1 -0
- package/libs/feature/map/src/lib/constant/index.d.ts +1 -0
- package/libs/feature/map/src/lib/constant/index.d.ts.map +1 -1
- package/libs/feature/map/src/lib/constant/projections.d.ts.map +1 -0
- package/libs/feature/map/src/lib/feature-map.module.d.ts +15 -12
- package/libs/feature/map/src/lib/feature-map.module.d.ts.map +1 -1
- package/libs/feature/map/src/lib/geocoding/geocoding.component.d.ts +25 -0
- package/libs/feature/map/src/lib/geocoding/geocoding.component.d.ts.map +1 -0
- package/libs/feature/map/src/lib/geocoding.service.d.ts +18 -0
- package/libs/feature/map/src/lib/geocoding.service.d.ts.map +1 -0
- package/libs/feature/map/src/lib/map-context/map-context.service.d.ts +2 -0
- package/libs/feature/map/src/lib/map-context/map-context.service.d.ts.map +1 -1
- package/libs/feature/map/src/lib/utils/index.d.ts +0 -2
- package/libs/feature/map/src/lib/utils/index.d.ts.map +1 -1
- package/libs/feature/map/src/lib/utils/map-utils.service.d.ts +13 -11
- package/libs/feature/map/src/lib/utils/map-utils.service.d.ts.map +1 -1
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +1 -3
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
- package/libs/feature/router/src/lib/default/index.d.ts +1 -0
- package/libs/feature/router/src/lib/default/index.d.ts.map +1 -1
- package/libs/feature/router/src/lib/default/router.service.d.ts +1 -1
- package/libs/feature/router/src/lib/default/router.service.d.ts.map +1 -1
- package/libs/feature/search/src/index.d.ts +3 -0
- package/libs/feature/search/src/index.d.ts.map +1 -1
- package/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.d.ts +5 -4
- package/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.d.ts.map +1 -1
- package/libs/feature/search/src/lib/feature-search.module.d.ts +0 -4
- package/libs/feature/search/src/lib/feature-search.module.d.ts.map +1 -1
- package/libs/feature/search/src/lib/filter-dropdown/filter-dropdown.component.d.ts +3 -2
- package/libs/feature/search/src/lib/filter-dropdown/filter-dropdown.component.d.ts.map +1 -1
- package/libs/feature/search/src/lib/filter-geometry.token.d.ts +4 -0
- package/libs/feature/search/src/lib/filter-geometry.token.d.ts.map +1 -0
- package/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.d.ts +1 -1
- package/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.d.ts.map +1 -1
- package/libs/feature/search/src/lib/record-url.token.d.ts +3 -0
- package/libs/feature/search/src/lib/record-url.token.d.ts.map +1 -0
- package/libs/feature/search/src/lib/results-table/results-table.component.d.ts +33 -0
- package/libs/feature/search/src/lib/results-table/results-table.component.d.ts.map +1 -0
- package/libs/feature/search/src/lib/state/effects.d.ts.map +1 -1
- package/libs/feature/search/src/lib/state/search.facade.d.ts +1 -1
- package/libs/feature/search/src/lib/state/search.facade.d.ts.map +1 -1
- package/libs/feature/search/src/lib/utils/service/fields.d.ts +21 -8
- 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 +1 -1
- package/libs/ui/elements/src/index.d.ts +3 -0
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.d.ts +10 -0
- package/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.d.ts +8 -0
- package/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/max-lines/max-lines.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/metadata-info/metadata-info.component.d.ts +16 -5
- package/libs/ui/elements/src/lib/metadata-info/metadata-info.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +3 -1
- 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 +3 -2
- 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 +13 -11
- 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/editable-label/editable-label.directive.d.ts +13 -0
- package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/form-field/form-field.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/form-field/form-field.model.d.ts +0 -1
- package/libs/ui/inputs/src/lib/form-field/form-field.model.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +1 -1
- package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +40 -39
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
- package/libs/ui/layout/src/index.d.ts +2 -0
- package/libs/ui/layout/src/index.d.ts.map +1 -1
- package/libs/ui/layout/src/lib/interactive-table/interactive-table-column/interactive-table-column.component.d.ts +14 -0
- package/libs/ui/layout/src/lib/interactive-table/interactive-table-column/interactive-table-column.component.d.ts.map +1 -0
- package/libs/ui/layout/src/lib/interactive-table/interactive-table.component.d.ts +15 -0
- package/libs/ui/layout/src/lib/interactive-table/interactive-table.component.d.ts.map +1 -0
- package/libs/ui/search/src/index.d.ts +0 -1
- package/libs/ui/search/src/index.d.ts.map +1 -1
- package/libs/ui/search/src/lib/ui-search.module.d.ts +15 -15
- package/libs/ui/search/src/lib/ui-search.module.d.ts.map +1 -1
- package/libs/util/i18n/src/index.d.ts +0 -1
- package/libs/util/i18n/src/index.d.ts.map +1 -1
- package/libs/util/i18n/src/lib/i18n.constants.d.ts +17 -0
- package/libs/util/i18n/src/lib/i18n.constants.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts +19 -7
- package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/index.d.ts +1 -0
- package/libs/util/shared/src/lib/utils/index.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/temporal-extent-union.d.ts +5 -0
- package/libs/util/shared/src/lib/utils/temporal-extent-union.d.ts.map +1 -0
- package/package.json +4 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/generic.records.ts +63 -8
- package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +57 -9
- package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +229 -24
- package/src/libs/api/metadata-converter/src/lib/gn4/atomic-operations.ts +32 -0
- package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +140 -74
- package/src/libs/api/metadata-converter/src/lib/gn4/gn4.metadata.mapper.ts +7 -3
- package/src/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.ts +4 -5
- package/src/libs/api/metadata-converter/src/lib/iso19139/codelists/keyword.mapper.ts +16 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/converter.ts +30 -21
- package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +120 -63
- package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +177 -97
- package/src/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.ts +1 -1
- package/src/libs/api/repository/src/lib/gn4/index.ts +2 -0
- package/src/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.ts +22 -2
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +15 -4
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +47 -8
- package/src/libs/api/repository/src/lib/gn4/selection/selection.service.ts +14 -38
- package/src/libs/common/domain/src/lib/index.ts +2 -0
- package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +37 -21
- package/src/libs/common/domain/src/lib/model/search/aggregation.model.ts +1 -1
- package/src/libs/common/domain/src/lib/model/search/field.model.ts +1 -0
- package/src/libs/common/domain/src/lib/model/search/filter.model.ts +1 -1
- package/src/libs/common/domain/src/lib/model/search/index.ts +1 -0
- package/src/libs/common/domain/src/lib/model/search/search.model.ts +2 -2
- package/src/libs/common/domain/src/lib/model/thesaurus/thesaurus.model.ts +1 -0
- package/src/libs/common/domain/src/lib/model/user/index.ts +1 -0
- package/src/libs/common/domain/src/lib/platform.service.interface.ts +1 -4
- package/src/libs/common/fixtures/src/lib/elasticsearch/full-response.ts +1 -1
- package/src/libs/common/fixtures/src/lib/gn4/groups.fixtures.ts +1 -1
- package/src/libs/common/fixtures/src/lib/records.fixtures.ts +52 -10
- package/src/libs/feature/catalog/src/lib/my-org/my-org.service.ts +4 -16
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +8 -5
- package/src/libs/feature/editor/src/index.ts +5 -0
- package/src/libs/feature/editor/src/lib/+state/editor.actions.ts +24 -0
- package/src/libs/feature/editor/src/lib/+state/editor.effects.ts +49 -0
- package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +30 -0
- package/src/libs/feature/editor/src/lib/+state/editor.models.ts +1 -0
- package/src/libs/feature/editor/src/lib/+state/editor.reducer.ts +68 -0
- package/src/libs/feature/editor/src/lib/+state/editor.selectors.ts +39 -0
- package/src/libs/feature/editor/src/lib/expressions.ts +16 -0
- package/src/libs/feature/editor/src/lib/feature-editor.module.ts +11 -0
- package/src/libs/feature/editor/src/lib/fields.config.ts +35 -0
- package/src/libs/feature/editor/src/lib/models/fields.model.ts +29 -0
- package/src/libs/feature/editor/src/lib/record-form/record-form.component.html +9 -7
- package/src/libs/feature/editor/src/lib/record-form/record-form.component.ts +13 -6
- package/src/libs/feature/editor/src/lib/services/editor.service.ts +34 -73
- package/src/libs/feature/map/src/index.ts +1 -0
- package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.css +0 -0
- package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.html +21 -0
- package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.ts +107 -0
- package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.css +0 -0
- package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.html +37 -0
- package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.ts +64 -0
- package/src/libs/feature/map/src/lib/constant/index.ts +1 -0
- package/src/libs/feature/map/src/lib/feature-map.module.ts +12 -0
- package/src/libs/feature/map/src/lib/geocoding/geocoding.component.css +0 -0
- package/src/libs/feature/map/src/lib/geocoding/geocoding.component.html +39 -0
- package/src/libs/feature/map/src/lib/geocoding/geocoding.component.ts +99 -0
- package/src/libs/feature/map/src/lib/geocoding.service.ts +59 -0
- package/src/libs/feature/map/src/lib/layers-panel/layers-panel.component.html +6 -2
- package/src/libs/feature/map/src/lib/map-context/map-context.service.ts +16 -0
- package/src/libs/feature/map/src/lib/utils/index.ts +0 -2
- package/src/libs/feature/map/src/lib/utils/map-utils.service.ts +85 -50
- package/src/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.ts +12 -12
- package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +18 -3
- package/src/libs/feature/record/src/lib/state/mdview.reducer.ts +1 -1
- package/src/libs/feature/router/src/lib/default/index.ts +1 -0
- package/src/libs/feature/router/src/lib/default/router.service.ts +1 -1
- package/src/libs/feature/search/src/index.ts +3 -0
- package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html +13 -4
- package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.ts +2 -1
- package/src/libs/feature/search/src/lib/feature-search.module.ts +1 -10
- package/src/libs/feature/search/src/lib/filter-dropdown/filter-dropdown.component.ts +4 -4
- package/src/libs/feature/search/src/lib/filter-geometry.token.ts +7 -0
- package/src/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.ts +9 -3
- package/src/libs/feature/search/src/lib/record-url.token.ts +4 -0
- package/src/libs/feature/search/src/lib/results-list/results-list.container.component.ts +1 -1
- package/src/libs/feature/search/src/lib/results-table/results-table.component.css +0 -0
- package/src/libs/feature/search/src/lib/results-table/results-table.component.html +112 -0
- package/src/libs/feature/search/src/lib/results-table/results-table.component.ts +164 -0
- package/src/libs/feature/search/src/lib/state/effects.ts +5 -4
- package/src/libs/feature/search/src/lib/state/search.facade.ts +2 -1
- package/src/libs/feature/search/src/lib/utils/service/fields.service.ts +21 -16
- package/src/libs/feature/search/src/lib/utils/service/fields.ts +43 -34
- package/src/libs/ui/catalog/src/lib/language-switcher/language-switcher.component.html +1 -0
- package/src/libs/ui/catalog/src/lib/language-switcher/language-switcher.component.ts +1 -1
- package/src/libs/ui/elements/src/index.ts +3 -0
- package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.html +4 -1
- package/src/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.css +0 -0
- package/src/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.html +30 -0
- package/src/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.ts +15 -0
- package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.css +5 -0
- package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.html +39 -0
- package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.ts +58 -0
- package/src/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.css +264 -0
- package/src/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.html +1 -0
- package/src/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.ts +17 -0
- package/src/libs/ui/elements/src/lib/max-lines/max-lines.component.html +5 -1
- package/src/libs/ui/elements/src/lib/max-lines/max-lines.component.ts +1 -0
- package/src/libs/ui/elements/src/lib/metadata-contact/metadata-contact.component.html +3 -3
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.css +4 -0
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +212 -68
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts +51 -10
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.ts +2 -3
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +5 -5
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +12 -4
- package/src/libs/ui/elements/src/lib/related-record-card/related-record-card.component.html +1 -1
- package/src/libs/ui/elements/src/lib/thumbnail/thumbnail.component.html +2 -2
- package/src/libs/ui/elements/src/lib/thumbnail/thumbnail.component.ts +4 -0
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +7 -0
- package/src/libs/ui/inputs/src/index.ts +1 -0
- package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.html +1 -1
- package/src/libs/ui/inputs/src/lib/button/button.component.css +0 -5
- package/src/libs/ui/inputs/src/lib/button/button.component.html +0 -1
- package/src/libs/ui/inputs/src/lib/button/button.component.ts +7 -6
- package/src/libs/ui/inputs/src/lib/checkbox/checkbox.component.html +0 -1
- package/src/libs/ui/inputs/src/lib/dropdown-multiselect/dropdown-multiselect.component.html +2 -2
- package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.html +3 -1
- package/src/libs/ui/inputs/src/lib/editable-label/editable-label.directive.ts +48 -0
- package/src/libs/ui/inputs/src/lib/form-field/form-field.component.ts +3 -1
- package/src/libs/ui/inputs/src/lib/form-field/form-field.model.ts +0 -1
- package/src/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.css +3 -0
- package/src/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.html +8 -3
- package/src/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.css +1 -0
- package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +1 -0
- package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +5 -2
- package/src/libs/ui/layout/src/index.ts +2 -0
- package/src/libs/ui/layout/src/lib/carousel/carousel.component.css +1 -1
- package/src/libs/ui/layout/src/lib/carousel/carousel.component.html +1 -0
- package/src/libs/ui/layout/src/lib/interactive-table/interactive-table-column/interactive-table-column.component.css +0 -0
- package/src/libs/ui/layout/src/lib/interactive-table/interactive-table-column/interactive-table-column.component.html +1 -0
- package/src/libs/ui/layout/src/lib/interactive-table/interactive-table-column/interactive-table-column.component.ts +33 -0
- package/src/libs/ui/layout/src/lib/interactive-table/interactive-table.component.css +15 -0
- package/src/libs/ui/layout/src/lib/interactive-table/interactive-table.component.html +54 -0
- package/src/libs/ui/layout/src/lib/interactive-table/interactive-table.component.ts +42 -0
- package/src/libs/ui/search/src/index.ts +0 -1
- package/src/libs/ui/search/src/lib/ui-search.module.ts +2 -3
- package/src/libs/ui/widgets/src/lib/badge/badge.component.html +3 -1
- package/src/libs/util/i18n/src/index.ts +0 -1
- package/src/libs/util/i18n/src/lib/i18n.constants.ts +18 -0
- package/src/libs/util/shared/src/lib/links/link-utils.ts +34 -11
- package/src/libs/util/shared/src/lib/utils/index.ts +1 -0
- package/src/libs/util/shared/src/lib/utils/temporal-extent-union.ts +32 -0
- package/tailwind.base.css +44 -15
- package/translations/de.json +131 -109
- package/translations/en.json +63 -41
- package/translations/es.json +41 -19
- package/translations/fr.json +57 -35
- package/translations/it.json +58 -36
- package/translations/nl.json +42 -20
- package/translations/pt.json +41 -19
- package/translations/sk.json +119 -97
- package/esm2022/libs/feature/map/src/lib/utils/map-utils-wms.service.mjs +0 -55
- package/esm2022/libs/feature/map/src/lib/utils/projections.mjs +0 -2
- package/esm2022/libs/ui/search/src/lib/record-table/record-table.component.mjs +0 -145
- package/esm2022/libs/util/i18n/src/lib/testing/test.translate.loader.mjs +0 -24
- package/esm2022/libs/util/i18n/src/lib/testing/test.translate.module.mjs +0 -109
- package/esm2022/libs/util/i18n/src/lib/testing/translations.model.mjs +0 -6
- package/libs/feature/map/src/lib/utils/map-utils-wms.service.d.ts +0 -17
- package/libs/feature/map/src/lib/utils/map-utils-wms.service.d.ts.map +0 -1
- package/libs/feature/map/src/lib/utils/projections.d.ts.map +0 -1
- package/libs/ui/search/src/lib/record-table/record-table.component.d.ts +0 -31
- package/libs/ui/search/src/lib/record-table/record-table.component.d.ts.map +0 -1
- package/libs/util/i18n/src/lib/testing/test.translate.loader.d.ts +0 -17
- package/libs/util/i18n/src/lib/testing/test.translate.loader.d.ts.map +0 -1
- package/libs/util/i18n/src/lib/testing/test.translate.module.d.ts +0 -131
- package/libs/util/i18n/src/lib/testing/test.translate.module.d.ts.map +0 -1
- package/libs/util/i18n/src/lib/testing/translations.model.d.ts +0 -21
- package/libs/util/i18n/src/lib/testing/translations.model.d.ts.map +0 -1
- package/src/libs/feature/map/src/lib/utils/map-utils-wms.service.ts +0 -58
- package/src/libs/ui/search/src/lib/record-table/record-table.component.css +0 -7
- package/src/libs/ui/search/src/lib/record-table/record-table.component.html +0 -215
- package/src/libs/ui/search/src/lib/record-table/record-table.component.ts +0 -149
- package/src/libs/util/i18n/src/lib/testing/test.translate.loader.ts +0 -26
- package/src/libs/util/i18n/src/lib/testing/test.translate.module.ts +0 -235
- package/src/libs/util/i18n/src/lib/testing/translations.model.ts +0 -28
- /package/libs/feature/map/src/lib/{utils → constant}/projections.d.ts +0 -0
- /package/src/libs/feature/map/src/lib/{utils → constant}/projections.ts +0 -0
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { createAction, props } from '@ngrx/store'
|
|
2
|
+
import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
3
|
+
import { SaveRecordError } from './editor.models'
|
|
4
|
+
|
|
5
|
+
export const openRecord = createAction(
|
|
6
|
+
'[Editor] Open record',
|
|
7
|
+
props<{ record: CatalogRecord }>()
|
|
8
|
+
)
|
|
9
|
+
|
|
10
|
+
export const updateRecordField = createAction(
|
|
11
|
+
'[Editor] Update record field',
|
|
12
|
+
props<{ field: string; value: unknown }>()
|
|
13
|
+
)
|
|
14
|
+
|
|
15
|
+
export const markRecordAsChanged = createAction(
|
|
16
|
+
'[Editor] Mark record as changed'
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
export const saveRecord = createAction('[Editor] Save record')
|
|
20
|
+
export const saveRecordSuccess = createAction('[Editor] Save record success')
|
|
21
|
+
export const saveRecordFailure = createAction(
|
|
22
|
+
'[Editor] Save record failure',
|
|
23
|
+
props<{ error: SaveRecordError }>()
|
|
24
|
+
)
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { inject, Injectable } from '@angular/core'
|
|
2
|
+
import { Actions, createEffect, ofType } from '@ngrx/effects'
|
|
3
|
+
import { of, withLatestFrom } from 'rxjs'
|
|
4
|
+
import { catchError, map, switchMap } from 'rxjs/operators'
|
|
5
|
+
import * as EditorActions from './editor.actions'
|
|
6
|
+
import { EditorService } from '../services/editor.service'
|
|
7
|
+
import { Store } from '@ngrx/store'
|
|
8
|
+
import { selectRecord, selectRecordFieldsConfig } from './editor.selectors'
|
|
9
|
+
|
|
10
|
+
@Injectable()
|
|
11
|
+
export class EditorEffects {
|
|
12
|
+
private actions$ = inject(Actions)
|
|
13
|
+
private editorService = inject(EditorService)
|
|
14
|
+
private store = inject(Store)
|
|
15
|
+
|
|
16
|
+
saveRecord$ = createEffect(() =>
|
|
17
|
+
this.actions$.pipe(
|
|
18
|
+
ofType(EditorActions.saveRecord),
|
|
19
|
+
withLatestFrom(
|
|
20
|
+
this.store.select(selectRecord),
|
|
21
|
+
this.store.select(selectRecordFieldsConfig)
|
|
22
|
+
),
|
|
23
|
+
switchMap(([, record, fieldsConfig]) =>
|
|
24
|
+
this.editorService.saveRecord(record, fieldsConfig).pipe(
|
|
25
|
+
switchMap((newRecord) =>
|
|
26
|
+
of(
|
|
27
|
+
EditorActions.saveRecordSuccess(),
|
|
28
|
+
EditorActions.openRecord({ record: newRecord })
|
|
29
|
+
)
|
|
30
|
+
),
|
|
31
|
+
catchError((error) =>
|
|
32
|
+
of(
|
|
33
|
+
EditorActions.saveRecordFailure({
|
|
34
|
+
error: error.message,
|
|
35
|
+
})
|
|
36
|
+
)
|
|
37
|
+
)
|
|
38
|
+
)
|
|
39
|
+
)
|
|
40
|
+
)
|
|
41
|
+
)
|
|
42
|
+
|
|
43
|
+
markAsChanged$ = createEffect(() =>
|
|
44
|
+
this.actions$.pipe(
|
|
45
|
+
ofType(EditorActions.updateRecordField),
|
|
46
|
+
map(() => EditorActions.markRecordAsChanged())
|
|
47
|
+
)
|
|
48
|
+
)
|
|
49
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { inject, Injectable } from '@angular/core'
|
|
2
|
+
import { select, Store } from '@ngrx/store'
|
|
3
|
+
import * as EditorActions from './editor.actions'
|
|
4
|
+
import * as EditorSelectors from './editor.selectors'
|
|
5
|
+
import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
6
|
+
|
|
7
|
+
@Injectable()
|
|
8
|
+
export class EditorFacade {
|
|
9
|
+
private readonly store = inject(Store)
|
|
10
|
+
|
|
11
|
+
record$ = this.store.pipe(select(EditorSelectors.selectRecord))
|
|
12
|
+
saving$ = this.store.pipe(select(EditorSelectors.selectRecordSaving))
|
|
13
|
+
saveError$ = this.store.pipe(select(EditorSelectors.selectRecordSaveError))
|
|
14
|
+
changedSinceSave$ = this.store.pipe(
|
|
15
|
+
select(EditorSelectors.selectRecordChangedSinceSave)
|
|
16
|
+
)
|
|
17
|
+
recordFields$ = this.store.pipe(select(EditorSelectors.selectRecordFields))
|
|
18
|
+
|
|
19
|
+
openRecord(record: CatalogRecord) {
|
|
20
|
+
this.store.dispatch(EditorActions.openRecord({ record }))
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
saveRecord() {
|
|
24
|
+
this.store.dispatch(EditorActions.saveRecord())
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
updateRecordField(field: string, value: unknown) {
|
|
28
|
+
this.store.dispatch(EditorActions.updateRecordField({ field, value }))
|
|
29
|
+
}
|
|
30
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type SaveRecordError = string
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { Action, createReducer, on } from '@ngrx/store'
|
|
2
|
+
import * as EditorActions from './editor.actions'
|
|
3
|
+
import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
4
|
+
import { SaveRecordError } from './editor.models'
|
|
5
|
+
import { EditorFieldsConfig } from '../models/fields.model'
|
|
6
|
+
import { DEFAULT_FIELDS } from '../fields.config'
|
|
7
|
+
|
|
8
|
+
export const EDITOR_FEATURE_KEY = 'editor'
|
|
9
|
+
|
|
10
|
+
export interface EditorState {
|
|
11
|
+
record: CatalogRecord | null
|
|
12
|
+
saving: boolean
|
|
13
|
+
saveError: SaveRecordError | null
|
|
14
|
+
changedSinceSave: boolean
|
|
15
|
+
fieldsConfig: EditorFieldsConfig
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export interface EditorPartialState {
|
|
19
|
+
readonly [EDITOR_FEATURE_KEY]: EditorState
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export const initialEditorState: EditorState = {
|
|
23
|
+
record: null,
|
|
24
|
+
saving: false,
|
|
25
|
+
saveError: null,
|
|
26
|
+
changedSinceSave: false,
|
|
27
|
+
fieldsConfig: DEFAULT_FIELDS,
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const reducer = createReducer(
|
|
31
|
+
initialEditorState,
|
|
32
|
+
on(EditorActions.openRecord, (state, { record }) => ({
|
|
33
|
+
...state,
|
|
34
|
+
changedSinceSave: false,
|
|
35
|
+
record,
|
|
36
|
+
})),
|
|
37
|
+
on(EditorActions.saveRecord, (state) => ({
|
|
38
|
+
...state,
|
|
39
|
+
saving: true,
|
|
40
|
+
saveError: null,
|
|
41
|
+
})),
|
|
42
|
+
on(EditorActions.saveRecordSuccess, (state) => ({
|
|
43
|
+
...state,
|
|
44
|
+
saving: false,
|
|
45
|
+
saveError: null,
|
|
46
|
+
changedSinceSave: false,
|
|
47
|
+
})),
|
|
48
|
+
on(EditorActions.saveRecordFailure, (state, { error }) => ({
|
|
49
|
+
...state,
|
|
50
|
+
saving: false,
|
|
51
|
+
saveError: error,
|
|
52
|
+
})),
|
|
53
|
+
on(EditorActions.updateRecordField, (state, { field, value }) => ({
|
|
54
|
+
...state,
|
|
55
|
+
record: {
|
|
56
|
+
...state.record,
|
|
57
|
+
[field]: value,
|
|
58
|
+
},
|
|
59
|
+
})),
|
|
60
|
+
on(EditorActions.markRecordAsChanged, (state) => ({
|
|
61
|
+
...state,
|
|
62
|
+
changedSinceSave: true,
|
|
63
|
+
}))
|
|
64
|
+
)
|
|
65
|
+
|
|
66
|
+
export function editorReducer(state: EditorState | undefined, action: Action) {
|
|
67
|
+
return reducer(state, action)
|
|
68
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { createFeatureSelector, createSelector } from '@ngrx/store'
|
|
2
|
+
import { EDITOR_FEATURE_KEY, EditorState } from './editor.reducer'
|
|
3
|
+
|
|
4
|
+
export const selectEditorState =
|
|
5
|
+
createFeatureSelector<EditorState>(EDITOR_FEATURE_KEY)
|
|
6
|
+
|
|
7
|
+
export const selectRecord = createSelector(
|
|
8
|
+
selectEditorState,
|
|
9
|
+
(state: EditorState) => state.record
|
|
10
|
+
)
|
|
11
|
+
|
|
12
|
+
export const selectRecordSaving = createSelector(
|
|
13
|
+
selectEditorState,
|
|
14
|
+
(state: EditorState) => state.saving
|
|
15
|
+
)
|
|
16
|
+
|
|
17
|
+
export const selectRecordSaveError = createSelector(
|
|
18
|
+
selectEditorState,
|
|
19
|
+
(state: EditorState) => state.saveError
|
|
20
|
+
)
|
|
21
|
+
|
|
22
|
+
export const selectRecordChangedSinceSave = createSelector(
|
|
23
|
+
selectEditorState,
|
|
24
|
+
(state: EditorState) => state.changedSinceSave
|
|
25
|
+
)
|
|
26
|
+
|
|
27
|
+
export const selectRecordFieldsConfig = createSelector(
|
|
28
|
+
selectEditorState,
|
|
29
|
+
(state: EditorState) => state.fieldsConfig
|
|
30
|
+
)
|
|
31
|
+
|
|
32
|
+
export const selectRecordFields = createSelector(
|
|
33
|
+
selectEditorState,
|
|
34
|
+
(state: EditorState) =>
|
|
35
|
+
state.fieldsConfig.map((fieldConfig) => ({
|
|
36
|
+
config: fieldConfig,
|
|
37
|
+
value: state.record?.[fieldConfig.model] || null,
|
|
38
|
+
}))
|
|
39
|
+
)
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { EditorFieldState, EditorFieldValue } from './models/fields.model'
|
|
2
|
+
|
|
3
|
+
export type ExpressionEvaluator = (field: EditorFieldState) => EditorFieldValue
|
|
4
|
+
|
|
5
|
+
export function evaluate(expression: string): ExpressionEvaluator {
|
|
6
|
+
if (expression.match(/^\${.*}$/)) {
|
|
7
|
+
return evaluate(expression.slice(2, -1))
|
|
8
|
+
}
|
|
9
|
+
const operator = expression.split('(')[0]
|
|
10
|
+
switch (operator) {
|
|
11
|
+
case 'dateNow':
|
|
12
|
+
return () => new Date()
|
|
13
|
+
default:
|
|
14
|
+
throw new Error(`Unknown operator: ${operator}`)
|
|
15
|
+
}
|
|
16
|
+
}
|
|
@@ -10,6 +10,11 @@ import { TranslateModule } from '@ngx-translate/core'
|
|
|
10
10
|
import { WizardSummarizeComponent } from './components/wizard-summarize/wizard-summarize.component'
|
|
11
11
|
import { CommonModule } from '@angular/common'
|
|
12
12
|
import { HttpClientModule, HttpClientXsrfModule } from '@angular/common/http'
|
|
13
|
+
import { StoreModule } from '@ngrx/store'
|
|
14
|
+
import { EffectsModule } from '@ngrx/effects'
|
|
15
|
+
import * as fromEditor from './+state/editor.reducer'
|
|
16
|
+
import { EditorEffects } from './+state/editor.effects'
|
|
17
|
+
import { EditorFacade } from './+state/editor.facade'
|
|
13
18
|
|
|
14
19
|
@NgModule({
|
|
15
20
|
declarations: [
|
|
@@ -27,8 +32,14 @@ import { HttpClientModule, HttpClientXsrfModule } from '@angular/common/http'
|
|
|
27
32
|
MatFormFieldModule,
|
|
28
33
|
HttpClientModule,
|
|
29
34
|
HttpClientXsrfModule,
|
|
35
|
+
StoreModule.forFeature(
|
|
36
|
+
fromEditor.EDITOR_FEATURE_KEY,
|
|
37
|
+
fromEditor.editorReducer
|
|
38
|
+
),
|
|
39
|
+
EffectsModule.forFeature([EditorEffects]),
|
|
30
40
|
],
|
|
31
41
|
exports: [WizardComponent, WizardSummarizeComponent],
|
|
42
|
+
providers: [EditorFacade],
|
|
32
43
|
})
|
|
33
44
|
export class FeatureEditorModule {}
|
|
34
45
|
export * from './services/wizard.service'
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { EditorFieldsConfig } from './models/fields.model'
|
|
2
|
+
|
|
3
|
+
export const DEFAULT_FIELDS: EditorFieldsConfig = [
|
|
4
|
+
{
|
|
5
|
+
model: 'title',
|
|
6
|
+
formFieldConfig: {
|
|
7
|
+
labelKey: 'Metadata title',
|
|
8
|
+
type: 'text',
|
|
9
|
+
},
|
|
10
|
+
},
|
|
11
|
+
{
|
|
12
|
+
model: 'abstract',
|
|
13
|
+
formFieldConfig: {
|
|
14
|
+
labelKey: 'Abstract',
|
|
15
|
+
type: 'rich',
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
model: 'uniqueIdentifier',
|
|
20
|
+
formFieldConfig: {
|
|
21
|
+
labelKey: 'Unique identifier',
|
|
22
|
+
type: 'text',
|
|
23
|
+
locked: true,
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
model: 'recordUpdated',
|
|
28
|
+
formFieldConfig: {
|
|
29
|
+
labelKey: 'Record Updated',
|
|
30
|
+
type: 'text',
|
|
31
|
+
locked: true,
|
|
32
|
+
},
|
|
33
|
+
onSaveProcess: '${dateNow()}',
|
|
34
|
+
},
|
|
35
|
+
]
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { FormFieldConfig } from '../../../../../../libs/ui/inputs/src'
|
|
2
|
+
|
|
3
|
+
// Expressions should be enclosed in `${}` to be recognized as such
|
|
4
|
+
// eg. ${dateNow()}
|
|
5
|
+
export type EditorFieldExpression = `$\{${string}}`
|
|
6
|
+
|
|
7
|
+
export interface EditorFieldConfig {
|
|
8
|
+
// configuration of the form field used as presentation; optional, nothing shown if not defined
|
|
9
|
+
formFieldConfig?: FormFieldConfig
|
|
10
|
+
|
|
11
|
+
// name of the target field in the record; will not change the record directly if not defined
|
|
12
|
+
model?: string
|
|
13
|
+
|
|
14
|
+
// a hidden field won't show but can still be used to modify the record
|
|
15
|
+
// FIXME: currently this is redundant with an absence of formFieldConfig but necessary for clarity
|
|
16
|
+
hidden?: boolean
|
|
17
|
+
|
|
18
|
+
// the result of this expression will replace the field value on save
|
|
19
|
+
onSaveProcess?: EditorFieldExpression
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export type EditorFieldsConfig = EditorFieldConfig[]
|
|
23
|
+
|
|
24
|
+
export type EditorFieldValue = string | number | boolean | unknown
|
|
25
|
+
|
|
26
|
+
export interface EditorFieldState {
|
|
27
|
+
config: EditorFieldConfig
|
|
28
|
+
value: string | number | boolean | unknown
|
|
29
|
+
}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
|
-
<div class="flex flex-col gap-6">
|
|
2
|
-
<
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
<div class="flex flex-col gap-6 p-6">
|
|
2
|
+
<ng-container *ngFor="let field of fields$ | async; trackBy: fieldTracker">
|
|
3
|
+
<gn-ui-form-field
|
|
4
|
+
*ngIf="field.config.formFieldConfig && !field.config.hidden"
|
|
5
|
+
[config]="field.config.formFieldConfig"
|
|
6
|
+
[value]="field.value"
|
|
7
|
+
(valueChange)="handleFieldValueChange(field, $event)"
|
|
8
|
+
></gn-ui-form-field>
|
|
9
|
+
</ng-container>
|
|
8
10
|
</div>
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common'
|
|
2
2
|
import { ChangeDetectionStrategy, Component } from '@angular/core'
|
|
3
|
-
import {
|
|
3
|
+
import { UiInputsModule } from '../../../../../../libs/ui/inputs/src'
|
|
4
|
+
import { EditorFacade } from '../+state/editor.facade'
|
|
5
|
+
import { EditorFieldState, EditorFieldValue } from '../models/fields.model'
|
|
4
6
|
|
|
5
7
|
@Component({
|
|
6
8
|
selector: 'gn-ui-record-form',
|
|
@@ -8,16 +10,21 @@ import { EditorService, FormField } from '../services/editor.service'
|
|
|
8
10
|
styleUrls: ['./record-form.component.css'],
|
|
9
11
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
10
12
|
standalone: true,
|
|
11
|
-
imports: [CommonModule],
|
|
13
|
+
imports: [CommonModule, UiInputsModule],
|
|
12
14
|
})
|
|
13
15
|
export class RecordFormComponent {
|
|
14
|
-
|
|
16
|
+
fields$ = this.facade.recordFields$
|
|
15
17
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
+
constructor(public facade: EditorFacade) {}
|
|
19
|
+
|
|
20
|
+
handleFieldValueChange(field: EditorFieldState, newValue: EditorFieldValue) {
|
|
21
|
+
if (!field.config.model) {
|
|
22
|
+
return
|
|
23
|
+
}
|
|
24
|
+
this.facade.updateRecordField(field.config.model, newValue)
|
|
18
25
|
}
|
|
19
26
|
|
|
20
|
-
fieldTracker(index: number, field:
|
|
27
|
+
fieldTracker(index: number, field: EditorFieldState) {
|
|
21
28
|
return field.config.model
|
|
22
29
|
}
|
|
23
30
|
}
|
|
@@ -1,59 +1,27 @@
|
|
|
1
1
|
import { Inject, Injectable, Optional } from '@angular/core'
|
|
2
2
|
import { toModel, toXml } from '../../../../../../libs/api/metadata-converter/src'
|
|
3
3
|
import { Configuration } from '../../../../../../libs/data-access/gn4/src'
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
4
|
+
import { Observable } from 'rxjs'
|
|
5
|
+
import { map } from 'rxjs/operators'
|
|
6
6
|
import { HttpClient } from '@angular/common/http'
|
|
7
|
-
import { FormFieldConfig } from '../../../../../../libs/ui/inputs/src'
|
|
8
7
|
import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
config: FormFieldConfig
|
|
12
|
-
value: string | number | boolean | unknown
|
|
13
|
-
}
|
|
8
|
+
import { EditorFieldsConfig } from '../models/fields.model'
|
|
9
|
+
import { evaluate } from '../expressions'
|
|
14
10
|
|
|
15
11
|
@Injectable({
|
|
16
12
|
providedIn: 'root',
|
|
17
13
|
})
|
|
18
14
|
export class EditorService {
|
|
19
|
-
private record$ = new BehaviorSubject<CatalogRecord | null>(null)
|
|
20
|
-
private fieldsConfig: FormFieldConfig[] = [
|
|
21
|
-
{
|
|
22
|
-
model: 'title',
|
|
23
|
-
labelKey: 'Metadata title',
|
|
24
|
-
type: 'text',
|
|
25
|
-
},
|
|
26
|
-
{
|
|
27
|
-
model: 'abstract',
|
|
28
|
-
labelKey: 'Abstract',
|
|
29
|
-
type: 'rich',
|
|
30
|
-
},
|
|
31
|
-
{
|
|
32
|
-
model: 'uniqueIdentifier',
|
|
33
|
-
labelKey: 'Unique identifier',
|
|
34
|
-
type: 'text',
|
|
35
|
-
locked: true,
|
|
36
|
-
},
|
|
37
|
-
]
|
|
38
|
-
|
|
39
15
|
private apiUrl = `${this.apiConfiguration?.basePath || '/geonetwork/srv/api'}`
|
|
40
16
|
|
|
41
|
-
fields$: Observable<FormField[]> = this.record$.pipe(
|
|
42
|
-
map((record) =>
|
|
43
|
-
this.fieldsConfig.map((fieldConfig) => ({
|
|
44
|
-
config: fieldConfig,
|
|
45
|
-
value: record?.[fieldConfig.model] || null,
|
|
46
|
-
}))
|
|
47
|
-
)
|
|
48
|
-
)
|
|
49
|
-
saving$ = new BehaviorSubject(false)
|
|
50
|
-
|
|
51
17
|
constructor(
|
|
52
18
|
private http: HttpClient,
|
|
53
19
|
@Optional()
|
|
54
20
|
@Inject(Configuration)
|
|
55
21
|
private apiConfiguration: Configuration
|
|
56
22
|
) {}
|
|
23
|
+
|
|
24
|
+
// TODO: use the catalog repository instead
|
|
57
25
|
loadRecordByUuid(uuid: string): Observable<CatalogRecord> {
|
|
58
26
|
return this.http
|
|
59
27
|
.get(`${this.apiUrl}/records/${uuid}/formatters/xml`, {
|
|
@@ -65,43 +33,36 @@ export class EditorService {
|
|
|
65
33
|
.pipe(map((response) => toModel(response.toString())))
|
|
66
34
|
}
|
|
67
35
|
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
this.saving$.next(true)
|
|
75
|
-
}),
|
|
76
|
-
switchMap((record) =>
|
|
77
|
-
this.http.put(
|
|
78
|
-
`${this.apiUrl}/records?metadataType=METADATA&uuidProcessing=OVERWRITE&transformWith=_none_&publishToAll=on`,
|
|
79
|
-
toXml(record),
|
|
80
|
-
{
|
|
81
|
-
headers: {
|
|
82
|
-
'Content-Type': 'application/xml',
|
|
83
|
-
},
|
|
84
|
-
withCredentials: true,
|
|
85
|
-
}
|
|
86
|
-
)
|
|
87
|
-
),
|
|
88
|
-
map(() => undefined),
|
|
89
|
-
finalize(() => {
|
|
90
|
-
this.saving$.next(false)
|
|
91
|
-
})
|
|
92
|
-
)
|
|
93
|
-
}
|
|
36
|
+
// returns the record as it was when saved
|
|
37
|
+
saveRecord(
|
|
38
|
+
record: CatalogRecord,
|
|
39
|
+
fieldsConfig: EditorFieldsConfig
|
|
40
|
+
): Observable<CatalogRecord> {
|
|
41
|
+
const savedRecord = { ...record }
|
|
94
42
|
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
43
|
+
// run onSave processes
|
|
44
|
+
for (const field of fieldsConfig) {
|
|
45
|
+
if (field.onSaveProcess && field.model) {
|
|
46
|
+
const evaluator = evaluate(field.onSaveProcess)
|
|
47
|
+
savedRecord[field.model] = evaluator({
|
|
48
|
+
config: field,
|
|
49
|
+
value: record[field.model],
|
|
50
|
+
})
|
|
51
|
+
}
|
|
52
|
+
}
|
|
98
53
|
|
|
99
|
-
|
|
100
|
-
this.
|
|
101
|
-
.
|
|
102
|
-
|
|
103
|
-
|
|
54
|
+
// TODO: use the catalog repository instead
|
|
55
|
+
return this.http
|
|
56
|
+
.put(
|
|
57
|
+
`${this.apiUrl}/records?metadataType=METADATA&uuidProcessing=OVERWRITE&transformWith=_none_&publishToAll=on`,
|
|
58
|
+
toXml(savedRecord),
|
|
59
|
+
{
|
|
60
|
+
headers: {
|
|
61
|
+
'Content-Type': 'application/xml',
|
|
62
|
+
},
|
|
63
|
+
withCredentials: true,
|
|
64
|
+
}
|
|
104
65
|
)
|
|
105
|
-
.
|
|
66
|
+
.pipe(map(() => savedRecord))
|
|
106
67
|
}
|
|
107
68
|
}
|
|
@@ -17,3 +17,4 @@ export * from './lib/layers-panel/layers-panel.component'
|
|
|
17
17
|
export * from './lib/add-layer-from-catalog/add-layer-from-catalog.component'
|
|
18
18
|
export * from './lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component'
|
|
19
19
|
export * from './lib/map-container/map-container.component'
|
|
20
|
+
export * from './lib/geocoding/geocoding.component'
|
|
File without changes
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
<div class="flex flex-col gap-2 my-2">
|
|
2
|
+
<div class="flex items-center gap-4">
|
|
3
|
+
<div class="flex-grow rounded-md border-2 border-gray-200">
|
|
4
|
+
<gn-ui-drag-and-drop-file-input
|
|
5
|
+
(fileChange)="handleFileChange($event)"
|
|
6
|
+
[accept]="acceptedMimeType.join(',')"
|
|
7
|
+
[placeholder]="'map.addFromFile.placeholder' | translate"
|
|
8
|
+
class="placeholder-grey"
|
|
9
|
+
></gn-ui-drag-and-drop-file-input>
|
|
10
|
+
</div>
|
|
11
|
+
</div>
|
|
12
|
+
<p class="text-sm text-gray-600" translate>map.help.addFromFile</p>
|
|
13
|
+
</div>
|
|
14
|
+
|
|
15
|
+
<div *ngIf="errorMessage" class="text-red-500 mt-2">
|
|
16
|
+
{{ errorMessage }}
|
|
17
|
+
</div>
|
|
18
|
+
|
|
19
|
+
<div *ngIf="successMessage" class="text-green-500 mt-2">
|
|
20
|
+
{{ successMessage }}
|
|
21
|
+
</div>
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { ChangeDetectorRef, Component } from '@angular/core'
|
|
2
|
+
import { MapContextLayerModel } from '../map-context/map-context.model'
|
|
3
|
+
import { MapFacade } from '../+state/map.facade'
|
|
4
|
+
|
|
5
|
+
const INVALID_FILE_FORMAT_ERROR_MESSAGE = 'Invalid file format'
|
|
6
|
+
|
|
7
|
+
@Component({
|
|
8
|
+
selector: 'gn-ui-add-layer-from-file',
|
|
9
|
+
templateUrl: './add-layer-from-file.component.html',
|
|
10
|
+
styleUrls: ['./add-layer-from-file.component.css'],
|
|
11
|
+
})
|
|
12
|
+
export class AddLayerFromFileComponent {
|
|
13
|
+
errorMessage: string | null = null
|
|
14
|
+
successMessage: string | null = null
|
|
15
|
+
loading = false
|
|
16
|
+
readonly acceptedMimeType = ['.geojson']
|
|
17
|
+
readonly maxFileSize = 5000000
|
|
18
|
+
|
|
19
|
+
constructor(
|
|
20
|
+
private mapFacade: MapFacade,
|
|
21
|
+
private changeDetectorRef: ChangeDetectorRef
|
|
22
|
+
) {}
|
|
23
|
+
|
|
24
|
+
async handleFileChange(file: File) {
|
|
25
|
+
if (!file) {
|
|
26
|
+
this.displayMessage(INVALID_FILE_FORMAT_ERROR_MESSAGE, 'error')
|
|
27
|
+
return
|
|
28
|
+
}
|
|
29
|
+
if (file.size > this.maxFileSize) {
|
|
30
|
+
this.displayMessage('File size exceeds the limit of 5MB', 'error')
|
|
31
|
+
return
|
|
32
|
+
}
|
|
33
|
+
await this.addLayer(file)
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
private async addLayer(file: File) {
|
|
37
|
+
this.errorMessage = null
|
|
38
|
+
this.loading = true
|
|
39
|
+
try {
|
|
40
|
+
if (!this.isFileFormatValid(file)) {
|
|
41
|
+
this.displayMessage(INVALID_FILE_FORMAT_ERROR_MESSAGE, 'error')
|
|
42
|
+
return
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
const fileExtension = this.getFileExtension(file)
|
|
46
|
+
switch (fileExtension) {
|
|
47
|
+
case 'geojson':
|
|
48
|
+
await this.addGeoJsonLayer(file)
|
|
49
|
+
break
|
|
50
|
+
default:
|
|
51
|
+
this.displayMessage(INVALID_FILE_FORMAT_ERROR_MESSAGE, 'error')
|
|
52
|
+
break
|
|
53
|
+
}
|
|
54
|
+
} catch (error) {
|
|
55
|
+
const err = error as Error
|
|
56
|
+
this.displayMessage('Error loading file: ' + err.message, 'error')
|
|
57
|
+
} finally {
|
|
58
|
+
this.loading = false
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
private addGeoJsonLayer(file: File) {
|
|
63
|
+
return new Promise<void>((resolve, reject) => {
|
|
64
|
+
try {
|
|
65
|
+
const reader = new FileReader()
|
|
66
|
+
reader.onload = () => {
|
|
67
|
+
const result = reader.result as string
|
|
68
|
+
const title = file.name.split('.').slice(0, -1).join('.')
|
|
69
|
+
const layerToAdd: MapContextLayerModel = {
|
|
70
|
+
type: 'geojson',
|
|
71
|
+
data: result,
|
|
72
|
+
}
|
|
73
|
+
this.mapFacade.addLayer({ ...layerToAdd, title: title })
|
|
74
|
+
this.displayMessage('File successfully added to map', 'success')
|
|
75
|
+
resolve()
|
|
76
|
+
}
|
|
77
|
+
reader.onerror = reject
|
|
78
|
+
reader.readAsText(file)
|
|
79
|
+
} catch (error) {
|
|
80
|
+
reject(error)
|
|
81
|
+
}
|
|
82
|
+
})
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
private isFileFormatValid(file: File): boolean {
|
|
86
|
+
const fileExtension = this.getFileExtension(file)
|
|
87
|
+
return this.acceptedMimeType.includes(`.${fileExtension}`)
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
private getFileExtension(file: File): string | undefined {
|
|
91
|
+
return file.name.split('.').pop()
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
private displayMessage(message: string, type: 'success' | 'error') {
|
|
95
|
+
if (type === 'success') {
|
|
96
|
+
this.successMessage = message
|
|
97
|
+
} else if (type === 'error') {
|
|
98
|
+
this.errorMessage = message
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
setTimeout(() => {
|
|
102
|
+
this.successMessage = null
|
|
103
|
+
this.errorMessage = null
|
|
104
|
+
this.changeDetectorRef.detectChanges()
|
|
105
|
+
}, 5000)
|
|
106
|
+
}
|
|
107
|
+
}
|
|
File without changes
|