geonetwork-ui 2.3.0-dev.c3722986 → 2.3.0-dev.c4b41b40
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/lib/gn4/gn4.field.mapper.mjs +6 -2
- 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/platform/gn4-platform.mapper.mjs +36 -3
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +19 -7
- package/esm2022/libs/common/domain/src/lib/model/record/index.mjs +2 -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/feature/dataviz/src/lib/service/data.service.mjs +53 -2
- 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.component.mjs +121 -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 +16 -1
- package/esm2022/libs/feature/editor/src/lib/models/fields.model.mjs +1 -1
- 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 +1 -1
- 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/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/feature-record.module.mjs +4 -4
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +3 -2
- 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 +22 -7
- package/esm2022/libs/feature/record/src/lib/state/mdview.reducer.mjs +52 -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/lib/results-table/results-table.component.mjs +3 -3
- package/esm2022/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/index.mjs +15 -15
- package/esm2022/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.mjs +3 -3
- 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/notification/notification.component.mjs +34 -0
- package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +34 -7
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +10 -7
- 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 +62 -0
- package/esm2022/libs/ui/inputs/src/index.mjs +16 -16
- 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 +17 -8
- 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 +19 -3
- package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +11 -28
- 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/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/translations/de.json +34 -0
- package/esm2022/translations/en.json +34 -0
- package/esm2022/translations/es.json +34 -0
- package/esm2022/translations/fr.json +34 -0
- package/esm2022/translations/it.json +34 -0
- package/esm2022/translations/nl.json +34 -0
- package/esm2022/translations/pt.json +34 -0
- package/fesm2022/geonetwork-ui.mjs +2797 -1712
- 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/lib/gn4/gn4.field.mapper.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/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/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/feature/dataviz/src/lib/service/data.service.d.ts +3 -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/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field.component.d.ts +12 -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/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.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 +14 -4
- 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/ui/elements/src/index.d.ts +14 -14
- 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/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 +4 -2
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +16 -15
- 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 +22 -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/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 +1 -1
- package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts.map +1 -1
- 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 +4 -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 -43
- 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/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/package.json +1 -1
- package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +7 -1
- 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/platform/gn4-platform.mapper.ts +51 -1
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +34 -7
- package/src/libs/common/domain/src/lib/model/record/index.ts +1 -0
- 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/records.fixtures.ts +3 -3
- package/src/libs/common/fixtures/src/lib/user-feedbacks.fixtures.ts +83 -0
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +68 -1
- 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/{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/{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.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +92 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +137 -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 +15 -0
- package/src/libs/feature/editor/src/lib/models/fields.model.ts +1 -1
- package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.html +1 -1
- 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 +2 -1
- 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 +48 -8
- package/src/libs/feature/record/src/lib/state/mdview.reducer.ts +81 -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/lib/results-table/results-table.component.html +3 -3
- package/src/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.html +5 -5
- package/src/libs/ui/elements/src/index.ts +14 -14
- 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 +2 -2
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +40 -4
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +5 -2
- 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 +63 -0
- package/src/libs/ui/inputs/src/index.ts +15 -15
- 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.ts +13 -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 +1 -1
- package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +16 -1
- package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +2 -21
- 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 +7 -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/shared/src/lib/links/link-classifier.service.ts +1 -1
- package/src/libs/util/shared/src/lib/links/link-utils.ts +21 -0
- package/tailwind.base.css +36 -0
- package/translations/de.json +34 -0
- package/translations/en.json +34 -0
- package/translations/es.json +34 -0
- package/translations/fr.json +34 -0
- package/translations/it.json +34 -0
- package/translations/nl.json +34 -0
- package/translations/pt.json +34 -0
- package/translations/sk.json +34 -0
- package/esm2022/libs/feature/editor/src/lib/record-form/record-form.component.mjs +0 -30
- 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/feature/editor/src/lib/record-form/record-form.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/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/{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/{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/feature/editor/src/lib/{record-form/record-form.component.css → components/record-form/form-field/form-field-license/form-field-license.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.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-rich/form-field-rich.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-simple/form-field-simple.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-spatial-extent/form-field-spatial-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-temporal-extent/form-field-temporal-extent.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/form-field/form-field.component.css → 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.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
|
@@ -1,12 +1,24 @@
|
|
|
1
1
|
import { Component, ChangeDetectionStrategy, Input } from '@angular/core'
|
|
2
2
|
import { DatasetDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
3
|
+
import { MatIconModule } from '@angular/material/icon'
|
|
4
|
+
import { CommonModule } from '@angular/common'
|
|
3
5
|
|
|
4
6
|
@Component({
|
|
5
7
|
selector: 'gn-ui-link-card',
|
|
6
8
|
templateUrl: './link-card.component.html',
|
|
7
9
|
styleUrls: ['./link-card.component.css'],
|
|
8
10
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
11
|
+
standalone: true,
|
|
12
|
+
imports: [CommonModule, MatIconModule],
|
|
9
13
|
})
|
|
10
14
|
export class LinkCardComponent {
|
|
11
15
|
@Input() link: DatasetDistribution
|
|
16
|
+
@Input() compact = false
|
|
17
|
+
|
|
18
|
+
get title() {
|
|
19
|
+
if (this.link.name && this.link.description) {
|
|
20
|
+
return `${this.link.name} | ${this.link.description}`
|
|
21
|
+
}
|
|
22
|
+
return this.link.name || this.link.description || ''
|
|
23
|
+
}
|
|
12
24
|
}
|
|
@@ -1,25 +1,4 @@
|
|
|
1
1
|
<div class="h-full flex flex-col">
|
|
2
|
-
<div class="flex-none w-full flex flex-row items-center">
|
|
3
|
-
<p class="flex-none font-bold">{{ label }}</p>
|
|
4
|
-
<div class="flex-1 flex justify-end items-center">
|
|
5
|
-
<gn-ui-button
|
|
6
|
-
[extraClass]="getButtonExtraClass()"
|
|
7
|
-
(buttonClick)="togglePreview()"
|
|
8
|
-
>
|
|
9
|
-
<span class="material-symbols-outlined mr-1 icon-small">{{
|
|
10
|
-
preview ? 'visibility' : 'visibility_off'
|
|
11
|
-
}}</span>
|
|
12
|
-
{{ preview ? 'WYSIWYG' : 'Markdown' }}
|
|
13
|
-
</gn-ui-button>
|
|
14
|
-
<span
|
|
15
|
-
class="material-symbols-outlined m-2 icon-small"
|
|
16
|
-
[matTooltip]="tooltip"
|
|
17
|
-
matTooltipPosition="above"
|
|
18
|
-
>
|
|
19
|
-
help
|
|
20
|
-
</span>
|
|
21
|
-
</div>
|
|
22
|
-
</div>
|
|
23
2
|
<p class="flex-none mb-2 font-medium text-sm text-gray-900">
|
|
24
3
|
{{ helperText }}
|
|
25
4
|
</p>
|
|
@@ -31,26 +31,13 @@ import { MatTooltipModule } from '@angular/material/tooltip'
|
|
|
31
31
|
],
|
|
32
32
|
})
|
|
33
33
|
export class MarkdownEditorComponent {
|
|
34
|
-
@Input()
|
|
35
|
-
@Input() tooltip?: string
|
|
34
|
+
@Input() preview = false
|
|
36
35
|
@Input() helperText?: string
|
|
37
36
|
@Input() placeholder: string
|
|
38
37
|
@Input() textContent: string
|
|
39
38
|
@Output() textContentChanged: EventEmitter<string> =
|
|
40
39
|
new EventEmitter<string>()
|
|
41
40
|
|
|
42
|
-
preview = false
|
|
43
|
-
|
|
44
|
-
getButtonExtraClass() {
|
|
45
|
-
return `${
|
|
46
|
-
this.preview ? 'text-gray-200 bg-gray-900' : 'text-gray-900 bg-gray-200'
|
|
47
|
-
} rounded-[1.25rem] p-[0.375rem] text-xs font-medium w-24`
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
togglePreview() {
|
|
51
|
-
this.preview = !this.preview
|
|
52
|
-
}
|
|
53
|
-
|
|
54
41
|
textContentChangedHandler(textContent: string) {
|
|
55
42
|
this.textContent = textContent
|
|
56
43
|
this.textContentChanged.emit(this.textContent)
|
|
File without changes
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
<div
|
|
2
|
+
class="p-[16px] flex flex-row gap-[16px] items-start border border-gray-200 shadow-md rounded bg-background"
|
|
3
|
+
>
|
|
4
|
+
<div
|
|
5
|
+
role="alert"
|
|
6
|
+
class="rounded-full text-white p-[6px] w-[32px] h-[32px] flex shrink-0"
|
|
7
|
+
[ngClass]="{
|
|
8
|
+
'bg-red-500': type === 'error',
|
|
9
|
+
'bg-yellow-500': type === 'warning',
|
|
10
|
+
'bg-green-500': type === 'success',
|
|
11
|
+
'bg-blue-500': type === 'info'
|
|
12
|
+
}"
|
|
13
|
+
[ngSwitch]="type"
|
|
14
|
+
>
|
|
15
|
+
<mat-icon class="material-symbols-outlined !w-[18px] !h-[18px] text-[20px]">
|
|
16
|
+
<ng-container *ngSwitchCase="'success'">check_circle</ng-container>
|
|
17
|
+
<ng-container *ngSwitchCase="'info'">info</ng-container>
|
|
18
|
+
<ng-container *ngSwitchCase="'warning'">warning</ng-container>
|
|
19
|
+
<ng-container *ngSwitchCase="'error'">error</ng-container>
|
|
20
|
+
</mat-icon>
|
|
21
|
+
</div>
|
|
22
|
+
<div
|
|
23
|
+
class="flex flex-col items-start gap-[4px] pt-[3px] grow shrink overflow-hidden"
|
|
24
|
+
>
|
|
25
|
+
<div class="font-bold text-[16px] text-gray-900">
|
|
26
|
+
{{ title }}
|
|
27
|
+
</div>
|
|
28
|
+
<div class="text-[14px] text-gray-800">
|
|
29
|
+
{{ text }}
|
|
30
|
+
</div>
|
|
31
|
+
<a
|
|
32
|
+
href
|
|
33
|
+
*ngIf="closeMessage"
|
|
34
|
+
class="text-[14px] gn-ui-link"
|
|
35
|
+
(click)="handleClose($event)"
|
|
36
|
+
>
|
|
37
|
+
{{ closeMessage }}
|
|
38
|
+
</a>
|
|
39
|
+
</div>
|
|
40
|
+
<gn-ui-button
|
|
41
|
+
type="light"
|
|
42
|
+
class="shrink-0"
|
|
43
|
+
(buttonClick)="handleClose()"
|
|
44
|
+
[style.--gn-ui-button-padding]="0"
|
|
45
|
+
[style.--gn-ui-button-width]="'21px'"
|
|
46
|
+
[style.--gn-ui-button-height]="'21px'"
|
|
47
|
+
>
|
|
48
|
+
<mat-icon class="material-symbols-outlined text-[22px] !w-[21px] !h-[21px]"
|
|
49
|
+
>close</mat-icon
|
|
50
|
+
>
|
|
51
|
+
</gn-ui-button>
|
|
52
|
+
</div>
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ChangeDetectionStrategy,
|
|
3
|
+
Component,
|
|
4
|
+
EventEmitter,
|
|
5
|
+
Input,
|
|
6
|
+
Output,
|
|
7
|
+
} from '@angular/core'
|
|
8
|
+
import { CommonModule } from '@angular/common'
|
|
9
|
+
import { MatIconModule } from '@angular/material/icon'
|
|
10
|
+
import { ButtonComponent } from '../../../../../../libs/ui/inputs/src'
|
|
11
|
+
|
|
12
|
+
@Component({
|
|
13
|
+
selector: 'gn-ui-notification',
|
|
14
|
+
standalone: true,
|
|
15
|
+
imports: [CommonModule, MatIconModule, ButtonComponent],
|
|
16
|
+
templateUrl: './notification.component.html',
|
|
17
|
+
styleUrls: ['./notification.component.css'],
|
|
18
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
19
|
+
})
|
|
20
|
+
export class NotificationComponent {
|
|
21
|
+
@Input() type: 'info' | 'warning' | 'error' | 'success' = 'info'
|
|
22
|
+
@Input() title: string
|
|
23
|
+
@Input() text: string
|
|
24
|
+
@Input() closeMessage?: string
|
|
25
|
+
@Output() notificationClose = new EventEmitter<void>()
|
|
26
|
+
|
|
27
|
+
handleClose(event?: Event) {
|
|
28
|
+
event?.preventDefault()
|
|
29
|
+
this.notificationClose.emit()
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
</p>
|
|
14
14
|
</button>
|
|
15
15
|
</div>
|
|
16
|
-
<div class="flex flex-row flex-wrap justify-between
|
|
16
|
+
<div class="flex flex-row flex-wrap justify-between grow gap-5">
|
|
17
17
|
<div class="flex flex-col gap-3">
|
|
18
18
|
<p class="text-[14px]" translate>record.metadata.api.form.limit</p>
|
|
19
19
|
<div class="flex flex-row items-center gap-2">
|
|
@@ -55,7 +55,7 @@
|
|
|
55
55
|
extraBtnClass="secondary min-w-full !w-40 !text-black"
|
|
56
56
|
[showTitle]="false"
|
|
57
57
|
class="text-black"
|
|
58
|
-
[choices]="
|
|
58
|
+
[choices]="outputFormats"
|
|
59
59
|
(selectValue)="setFormat($event)"
|
|
60
60
|
[selected]="format$ | async"
|
|
61
61
|
></gn-ui-dropdown-selector>
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
|
|
2
|
+
import { OgcApiEndpoint } from '@camptocamp/ogc-client'
|
|
2
3
|
import { DatasetServiceDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
4
|
+
import { mimeTypeToFormat } from '../../../../../../libs/util/shared/src'
|
|
3
5
|
import { BehaviorSubject, combineLatest, map } from 'rxjs'
|
|
4
6
|
|
|
5
7
|
const DEFAULT_PARAMS = {
|
|
@@ -16,16 +18,15 @@ const DEFAULT_PARAMS = {
|
|
|
16
18
|
export class RecordApiFormComponent {
|
|
17
19
|
@Input() set apiLink(value: DatasetServiceDistribution) {
|
|
18
20
|
this.apiBaseUrl = value ? value.url.href : undefined
|
|
21
|
+
this.outputFormats = [{ value: 'json', label: 'JSON' }]
|
|
22
|
+
this.parseOutputFormats()
|
|
19
23
|
this.resetUrl()
|
|
20
24
|
}
|
|
21
25
|
offset$ = new BehaviorSubject('')
|
|
22
26
|
limit$ = new BehaviorSubject('')
|
|
23
27
|
format$ = new BehaviorSubject('')
|
|
24
28
|
apiBaseUrl: string
|
|
25
|
-
|
|
26
|
-
{ label: 'JSON', value: 'json' },
|
|
27
|
-
{ label: 'CSV', value: 'csv' },
|
|
28
|
-
]
|
|
29
|
+
outputFormats = [{ value: 'json', label: 'JSON' }]
|
|
29
30
|
apiQueryUrl$ = combineLatest([this.offset$, this.limit$, this.format$]).pipe(
|
|
30
31
|
map(([offset, limit, format]) => {
|
|
31
32
|
let outputUrl
|
|
@@ -70,4 +71,39 @@ export class RecordApiFormComponent {
|
|
|
70
71
|
this.limit$.next(DEFAULT_PARAMS.LIMIT)
|
|
71
72
|
this.format$.next(DEFAULT_PARAMS.FORMAT)
|
|
72
73
|
}
|
|
74
|
+
|
|
75
|
+
parseOutputFormats() {
|
|
76
|
+
const apiUrl =
|
|
77
|
+
this.apiBaseUrl.slice(-1) === '?'
|
|
78
|
+
? this.apiBaseUrl.slice(0, -1)
|
|
79
|
+
: this.apiBaseUrl
|
|
80
|
+
|
|
81
|
+
this.getOutputFormats(apiUrl).then((outputFormats) => {
|
|
82
|
+
const formatsList = outputFormats.itemFormats.map((format) => {
|
|
83
|
+
const normalizedFormat = mimeTypeToFormat(format)
|
|
84
|
+
if (normalizedFormat) {
|
|
85
|
+
return {
|
|
86
|
+
label: normalizedFormat?.toUpperCase(),
|
|
87
|
+
value: normalizedFormat,
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return null
|
|
91
|
+
})
|
|
92
|
+
this.outputFormats = this.outputFormats.concat(
|
|
93
|
+
formatsList.filter(Boolean)
|
|
94
|
+
)
|
|
95
|
+
this.outputFormats = this.outputFormats
|
|
96
|
+
.filter(
|
|
97
|
+
(format, index, self) =>
|
|
98
|
+
index === self.findIndex((t) => t.value === format.value)
|
|
99
|
+
)
|
|
100
|
+
.sort((a, b) => a.label.localeCompare(b.label))
|
|
101
|
+
})
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
async getOutputFormats(url) {
|
|
105
|
+
const endpoint = await new OgcApiEndpoint(url)
|
|
106
|
+
const firstCollection = (await endpoint.featureCollections)[0]
|
|
107
|
+
return endpoint.getCollectionInfo(firstCollection)
|
|
108
|
+
}
|
|
73
109
|
}
|
|
@@ -31,6 +31,8 @@ import { MaxLinesComponent } from './max-lines/max-lines.component'
|
|
|
31
31
|
import { RecordApiFormComponent } from './record-api-form/record-api-form.component'
|
|
32
32
|
import { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'
|
|
33
33
|
import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'
|
|
34
|
+
import { UserFeedbackItemComponent } from './user-feedback-item/user-feedback-item.component'
|
|
35
|
+
import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
|
|
34
36
|
|
|
35
37
|
@NgModule({
|
|
36
38
|
imports: [
|
|
@@ -47,6 +49,7 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
|
|
|
47
49
|
NgOptimizedImage,
|
|
48
50
|
MarkdownParserComponent,
|
|
49
51
|
ThumbnailComponent,
|
|
52
|
+
TimeSincePipe,
|
|
50
53
|
],
|
|
51
54
|
declarations: [
|
|
52
55
|
MetadataInfoComponent,
|
|
@@ -54,7 +57,6 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
|
|
|
54
57
|
DownloadItemComponent,
|
|
55
58
|
DownloadsListComponent,
|
|
56
59
|
ApiCardComponent,
|
|
57
|
-
LinkCardComponent,
|
|
58
60
|
RelatedRecordCardComponent,
|
|
59
61
|
MetadataContactComponent,
|
|
60
62
|
MetadataCatalogComponent,
|
|
@@ -68,6 +70,7 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
|
|
|
68
70
|
PaginationButtonsComponent,
|
|
69
71
|
MaxLinesComponent,
|
|
70
72
|
RecordApiFormComponent,
|
|
73
|
+
UserFeedbackItemComponent,
|
|
71
74
|
ImageOverlayPreviewComponent,
|
|
72
75
|
],
|
|
73
76
|
exports: [
|
|
@@ -76,7 +79,6 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
|
|
|
76
79
|
DownloadItemComponent,
|
|
77
80
|
DownloadsListComponent,
|
|
78
81
|
ApiCardComponent,
|
|
79
|
-
LinkCardComponent,
|
|
80
82
|
RelatedRecordCardComponent,
|
|
81
83
|
MetadataContactComponent,
|
|
82
84
|
MetadataCatalogComponent,
|
|
@@ -91,6 +93,7 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
|
|
|
91
93
|
MaxLinesComponent,
|
|
92
94
|
RecordApiFormComponent,
|
|
93
95
|
MarkdownParserComponent,
|
|
96
|
+
UserFeedbackItemComponent,
|
|
94
97
|
ImageOverlayPreviewComponent,
|
|
95
98
|
],
|
|
96
99
|
})
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { Pipe, PipeTransform } from '@angular/core'
|
|
2
|
+
import { TranslateService } from '@ngx-translate/core'
|
|
3
|
+
import { formatDistance } from 'date-fns'
|
|
4
|
+
import { de, enUS, es, fr, it, nl, pt, sk } from 'date-fns/locale'
|
|
5
|
+
|
|
6
|
+
@Pipe({
|
|
7
|
+
name: 'timeSince',
|
|
8
|
+
standalone: true,
|
|
9
|
+
})
|
|
10
|
+
export class TimeSincePipe implements PipeTransform {
|
|
11
|
+
constructor(private translate: TranslateService) {}
|
|
12
|
+
|
|
13
|
+
transform(value: Date): string {
|
|
14
|
+
if (isNaN(value.getTime())) {
|
|
15
|
+
throw new Error('Invalid Date')
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const maintenant = new Date()
|
|
19
|
+
let locale: Locale
|
|
20
|
+
|
|
21
|
+
switch (this.translate.currentLang) {
|
|
22
|
+
case 'fr':
|
|
23
|
+
locale = fr
|
|
24
|
+
break
|
|
25
|
+
case 'de':
|
|
26
|
+
locale = de
|
|
27
|
+
break
|
|
28
|
+
case 'es':
|
|
29
|
+
locale = es
|
|
30
|
+
break
|
|
31
|
+
case 'it':
|
|
32
|
+
locale = it
|
|
33
|
+
break
|
|
34
|
+
case 'nl':
|
|
35
|
+
locale = nl
|
|
36
|
+
break
|
|
37
|
+
case 'pt':
|
|
38
|
+
locale = pt
|
|
39
|
+
break
|
|
40
|
+
case 'sk':
|
|
41
|
+
locale = sk
|
|
42
|
+
break
|
|
43
|
+
case 'en':
|
|
44
|
+
default:
|
|
45
|
+
locale = enUS
|
|
46
|
+
break
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return formatDistance(value, maintenant, {
|
|
50
|
+
addSuffix: true,
|
|
51
|
+
locale: locale,
|
|
52
|
+
})
|
|
53
|
+
}
|
|
54
|
+
}
|
|
File without changes
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
<div
|
|
2
|
+
*ngIf="userFeedbackParent.published"
|
|
3
|
+
class="flex flex-col bg-white rounded w-full"
|
|
4
|
+
[ngClass]="[isAnAnswer ? 'ps-4 ' : 'p-4']"
|
|
5
|
+
>
|
|
6
|
+
<div class="flex flex-row">
|
|
7
|
+
<div class="avatar">
|
|
8
|
+
<img
|
|
9
|
+
class="rounded-full"
|
|
10
|
+
[src]="userFeedbackParent.avatarUrl"
|
|
11
|
+
alt="avatar"
|
|
12
|
+
/>
|
|
13
|
+
</div>
|
|
14
|
+
<div class="p-4 flex flex-col">
|
|
15
|
+
<span>{{ userFeedbackParent.authorName }}</span>
|
|
16
|
+
<span> {{ userFeedbackParent.date | timeSince }}</span>
|
|
17
|
+
</div>
|
|
18
|
+
</div>
|
|
19
|
+
<div data-cy="commentText" class="mt-4 whitespace-pre-line">
|
|
20
|
+
{{ userFeedbackParent.comment }}
|
|
21
|
+
</div>
|
|
22
|
+
<div
|
|
23
|
+
class="w-full"
|
|
24
|
+
*ngFor="let userFeedBacksAnswer of userFeedBacksAnswers; let last = last"
|
|
25
|
+
>
|
|
26
|
+
<hr class="-mx-4 my-6" />
|
|
27
|
+
<gn-ui-user-feedback-item
|
|
28
|
+
[userFeedbackParent]="userFeedBacksAnswer"
|
|
29
|
+
[isLastComment]="last"
|
|
30
|
+
></gn-ui-user-feedback-item>
|
|
31
|
+
</div>
|
|
32
|
+
|
|
33
|
+
<div *ngIf="isActiveUserEditor" class="mt-2 flex flex-col">
|
|
34
|
+
<hr class="-mx-4 my-4" />
|
|
35
|
+
<div
|
|
36
|
+
id="new-comment-buttons"
|
|
37
|
+
class="flex flex-row gap-2 items-center justify-end"
|
|
38
|
+
>
|
|
39
|
+
<gn-ui-text-area
|
|
40
|
+
[disabled]="isAddUserFeedbackLoading"
|
|
41
|
+
[(value)]="newAnswer"
|
|
42
|
+
(valueChange)="onNewAnswerValueChange()"
|
|
43
|
+
(keyup.control.enter)="publishNewAnswer()"
|
|
44
|
+
[placeholder]="
|
|
45
|
+
'record.metadata.userFeedbacks.newAnswer.placeholder' | translate
|
|
46
|
+
"
|
|
47
|
+
class="grow"
|
|
48
|
+
extraClass="bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9"
|
|
49
|
+
></gn-ui-text-area>
|
|
50
|
+
<div *ngIf="!isAnswerEmpty" class="flex flex-row justify-end">
|
|
51
|
+
<gn-ui-button
|
|
52
|
+
[disabled]="isAddUserFeedbackLoading"
|
|
53
|
+
[type]="'outline'"
|
|
54
|
+
(buttonClick)="publishNewAnswer()"
|
|
55
|
+
[title]="
|
|
56
|
+
'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate
|
|
57
|
+
"
|
|
58
|
+
extraClass="!p-[0.5em] text-primary-darker border-primary-darker h-9"
|
|
59
|
+
>
|
|
60
|
+
<mat-icon
|
|
61
|
+
class="material-symbols-outlined"
|
|
62
|
+
*ngIf="!isAddUserFeedbackLoading"
|
|
63
|
+
>
|
|
64
|
+
send
|
|
65
|
+
</mat-icon>
|
|
66
|
+
<ng-container *ngIf="isAddUserFeedbackLoading">
|
|
67
|
+
<div class="flex justify-center w-full">
|
|
68
|
+
<gn-ui-spinning-loader></gn-ui-spinning-loader>
|
|
69
|
+
</div>
|
|
70
|
+
</ng-container>
|
|
71
|
+
</gn-ui-button>
|
|
72
|
+
</div>
|
|
73
|
+
</div>
|
|
74
|
+
</div>
|
|
75
|
+
</div>
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ChangeDetectionStrategy,
|
|
3
|
+
Component,
|
|
4
|
+
EventEmitter,
|
|
5
|
+
Input,
|
|
6
|
+
OnInit,
|
|
7
|
+
Output,
|
|
8
|
+
} from '@angular/core'
|
|
9
|
+
import {
|
|
10
|
+
UserFeedback,
|
|
11
|
+
UserFeedbackViewModel,
|
|
12
|
+
} from '../../../../../../libs/common/domain/src/lib/model/record'
|
|
13
|
+
import { UserModel } from '../../../../../../libs/common/domain/src/lib/model/user'
|
|
14
|
+
|
|
15
|
+
@Component({
|
|
16
|
+
selector: 'gn-ui-user-feedback-item',
|
|
17
|
+
templateUrl: './user-feedback-item.component.html',
|
|
18
|
+
styleUrls: ['./user-feedback-item.component.css'],
|
|
19
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
20
|
+
})
|
|
21
|
+
export class UserFeedbackItemComponent implements OnInit {
|
|
22
|
+
@Input() userFeedbackParent: UserFeedbackViewModel
|
|
23
|
+
@Input() userFeedBacksAnswers: UserFeedbackViewModel[]
|
|
24
|
+
@Input() isActiveUserEditor: boolean
|
|
25
|
+
@Input() activeUser: UserModel
|
|
26
|
+
@Input() isLastComment: boolean
|
|
27
|
+
@Input() isAddUserFeedbackLoading: boolean
|
|
28
|
+
|
|
29
|
+
@Output() newUserFeedbackAnswer = new EventEmitter<UserFeedback>()
|
|
30
|
+
|
|
31
|
+
isAnAnswer = false
|
|
32
|
+
newAnswer = ''
|
|
33
|
+
isAnswerEmpty = true
|
|
34
|
+
|
|
35
|
+
ngOnInit(): void {
|
|
36
|
+
this.isAnAnswer = !!this.userFeedbackParent.parentUuid
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
onNewAnswerValueChange() {
|
|
40
|
+
this.isAnswerEmpty = this.newAnswer.length === 0
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
publishNewAnswer() {
|
|
44
|
+
if (this.newAnswer.trim() === '') return
|
|
45
|
+
|
|
46
|
+
const newAnswer: UserFeedback = {
|
|
47
|
+
...this.userFeedbackParent,
|
|
48
|
+
uuid: undefined,
|
|
49
|
+
published: true,
|
|
50
|
+
comment: this.newAnswer,
|
|
51
|
+
parentUuid: this.userFeedbackParent.uuid,
|
|
52
|
+
authorUserId: this.activeUser?.id,
|
|
53
|
+
authorEmail: this.activeUser?.email,
|
|
54
|
+
date: new Date(),
|
|
55
|
+
authorName: `${this.activeUser?.name} ${this.activeUser?.surname}`,
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
this.newUserFeedbackAnswer.emit(newAnswer)
|
|
59
|
+
|
|
60
|
+
this.newAnswer = ''
|
|
61
|
+
this.onNewAnswerValueChange()
|
|
62
|
+
}
|
|
63
|
+
}
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
export * from './lib/dropdown-selector/dropdown-selector.component'
|
|
2
|
-
export * from './lib/dropdown-selector/dropdown-selector.model'
|
|
3
|
-
export * from './lib/dropdown-multiselect/dropdown-multiselect.component'
|
|
4
|
-
export * from './lib/dropdown-multiselect/dropdown-multiselect.model'
|
|
5
|
-
export * from './lib/text-input/text-input.component'
|
|
6
|
-
export * from './lib/chips-input/chips-input.component'
|
|
7
|
-
export * from './lib/text-area/text-area.component'
|
|
8
1
|
export * from './lib/autocomplete/autocomplete.component'
|
|
9
|
-
export * from './lib/star-toggle/star-toggle.component'
|
|
10
2
|
export * from './lib/button/button.component'
|
|
11
|
-
export * from './lib/viewport-intersector/viewport-intersector.component'
|
|
12
3
|
export * from './lib/check-toggle/check-toggle.component'
|
|
13
|
-
export * from './lib/
|
|
14
|
-
export * from './lib/
|
|
4
|
+
export * from './lib/checkbox/checkbox.component'
|
|
5
|
+
export * from './lib/chips-input/chips-input.component'
|
|
15
6
|
export * from './lib/copy-text-button/copy-text-button.component'
|
|
7
|
+
export * from './lib/date-picker/date-picker.component'
|
|
8
|
+
export * from './lib/date-range-picker/date-range-picker.component'
|
|
16
9
|
export * from './lib/drag-and-drop-file-input/drag-and-drop-file-input.component'
|
|
10
|
+
export * from './lib/dropdown-multiselect/dropdown-multiselect.component'
|
|
11
|
+
export * from './lib/dropdown-multiselect/dropdown-multiselect.model'
|
|
12
|
+
export * from './lib/dropdown-selector/dropdown-selector.component'
|
|
13
|
+
export * from './lib/dropdown-selector/dropdown-selector.model'
|
|
14
|
+
export * from './lib/editable-label/editable-label.directive'
|
|
17
15
|
export * from './lib/navigation-button/navigation-button.component'
|
|
18
|
-
export * from './lib/viewport-intersector/viewport-intersector.component'
|
|
19
|
-
export * from './lib/checkbox/checkbox.component'
|
|
20
16
|
export * from './lib/search-input/search-input.component'
|
|
21
|
-
export * from './lib/
|
|
22
|
-
export * from './lib/
|
|
17
|
+
export * from './lib/star-toggle/star-toggle.component'
|
|
18
|
+
export * from './lib/text-area/text-area.component'
|
|
19
|
+
export * from './lib/text-input/text-input.component'
|
|
20
|
+
export * from './lib/ui-inputs.module'
|
|
21
|
+
export * from './lib/viewport-intersector/viewport-intersector.component'
|
|
22
|
+
export * from './lib/previous-next-buttons/previous-next-buttons.component'
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
<div
|
|
2
|
+
class="flex items-center justify-between pl-3 rounded-lg border border-gray-300 bg-white"
|
|
3
|
+
>
|
|
4
|
+
<input
|
|
5
|
+
[matDatepicker]="picker"
|
|
6
|
+
[value]="date"
|
|
7
|
+
(dateChange)="dateChange.emit($event.value)"
|
|
8
|
+
/>
|
|
9
|
+
<mat-datepicker-toggle matIconSuffix [for]="picker"></mat-datepicker-toggle>
|
|
10
|
+
</div>
|
|
11
|
+
<mat-datepicker #picker></mat-datepicker>
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core'
|
|
2
|
+
import { MatNativeDateModule } from '@angular/material/core'
|
|
3
|
+
import { MatDatepickerModule } from '@angular/material/datepicker'
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon'
|
|
5
|
+
|
|
6
|
+
@Component({
|
|
7
|
+
selector: 'gn-ui-date-picker',
|
|
8
|
+
templateUrl: './date-picker.component.html',
|
|
9
|
+
styleUrls: ['./date-picker.component.css'],
|
|
10
|
+
standalone: true,
|
|
11
|
+
imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
|
|
12
|
+
})
|
|
13
|
+
export class DatePickerComponent {
|
|
14
|
+
@Input() date: Date
|
|
15
|
+
@Output() dateChange = new EventEmitter<Date>()
|
|
16
|
+
}
|
|
@@ -1,10 +1,17 @@
|
|
|
1
1
|
import { Component } from '@angular/core'
|
|
2
|
-
import {
|
|
2
|
+
import { MatNativeDateModule } from '@angular/material/core'
|
|
3
|
+
import {
|
|
4
|
+
MatDatepickerInputEvent,
|
|
5
|
+
MatDatepickerModule,
|
|
6
|
+
} from '@angular/material/datepicker'
|
|
7
|
+
import { MatIconModule } from '@angular/material/icon'
|
|
3
8
|
|
|
4
9
|
@Component({
|
|
5
10
|
selector: 'gn-ui-date-range-picker',
|
|
6
11
|
templateUrl: './date-range-picker.component.html',
|
|
7
12
|
styleUrls: ['./date-range-picker.component.css'],
|
|
13
|
+
standalone: true,
|
|
14
|
+
imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
|
|
8
15
|
})
|
|
9
16
|
export class DateRangePickerComponent {
|
|
10
17
|
startDate: Date
|
|
@@ -2,6 +2,7 @@ import {
|
|
|
2
2
|
CdkConnectedOverlay,
|
|
3
3
|
CdkOverlayOrigin,
|
|
4
4
|
ConnectedPosition,
|
|
5
|
+
OverlayModule,
|
|
5
6
|
} from '@angular/cdk/overlay'
|
|
6
7
|
import {
|
|
7
8
|
ChangeDetectionStrategy,
|
|
@@ -17,6 +18,10 @@ import {
|
|
|
17
18
|
} from '@angular/core'
|
|
18
19
|
import { firstValueFrom } from 'rxjs'
|
|
19
20
|
import { DropdownChoice } from './dropdown-selector.model'
|
|
21
|
+
import { CommonModule } from '@angular/common'
|
|
22
|
+
import { TranslateModule } from '@ngx-translate/core'
|
|
23
|
+
import { MatIconModule } from '@angular/material/icon'
|
|
24
|
+
import { ButtonComponent } from '../button/button.component'
|
|
20
25
|
|
|
21
26
|
const DEFAULT_ROW_NUMBERS = 6
|
|
22
27
|
|
|
@@ -25,6 +30,14 @@ const DEFAULT_ROW_NUMBERS = 6
|
|
|
25
30
|
templateUrl: './dropdown-selector.component.html',
|
|
26
31
|
styleUrls: ['./dropdown-selector.component.css'],
|
|
27
32
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
33
|
+
standalone: true,
|
|
34
|
+
imports: [
|
|
35
|
+
CommonModule,
|
|
36
|
+
ButtonComponent,
|
|
37
|
+
OverlayModule,
|
|
38
|
+
MatIconModule,
|
|
39
|
+
TranslateModule,
|
|
40
|
+
],
|
|
28
41
|
})
|
|
29
42
|
export class DropdownSelectorComponent implements OnInit {
|
|
30
43
|
@Input() title: string
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
<div class="flex flex-row gap-x-4 items-center">
|
|
2
|
+
<gn-ui-button
|
|
3
|
+
data-test="previousButton"
|
|
4
|
+
[type]="isFirst ? 'default' : 'outline'"
|
|
5
|
+
[disabled]="isFirst"
|
|
6
|
+
(buttonClick)="previousButtonClicked()"
|
|
7
|
+
>
|
|
8
|
+
<mat-icon
|
|
9
|
+
class="material-symbols-outlined text-[14px] text-center pt-[5px]"
|
|
10
|
+
>
|
|
11
|
+
arrow_back
|
|
12
|
+
</mat-icon>
|
|
13
|
+
</gn-ui-button>
|
|
14
|
+
<gn-ui-button
|
|
15
|
+
data-test="nextButton"
|
|
16
|
+
[type]="isLast ? 'default' : 'outline'"
|
|
17
|
+
[disabled]="isLast"
|
|
18
|
+
(buttonClick)="nextButtonClicked()"
|
|
19
|
+
>
|
|
20
|
+
<mat-icon
|
|
21
|
+
class="material-symbols-outlined text-[14px] text-center pt-[5px]"
|
|
22
|
+
>
|
|
23
|
+
arrow_forward
|
|
24
|
+
</mat-icon>
|
|
25
|
+
</gn-ui-button>
|
|
26
|
+
</div>
|