geonetwork-ui 2.4.0-dev.a9a61288 → 2.4.0-dev.aa689838
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/gn4.field.mapper.mjs +10 -3
- package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.mjs +1 -1
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.mjs +5 -5
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.mjs +7 -4
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.mjs +10 -7
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +10 -15
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +6 -6
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +28 -18
- package/esm2022/libs/api/metadata-converter/src/lib/xml-utils.mjs +5 -3
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +11 -1
- package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +51 -7
- package/esm2022/libs/common/domain/src/lib/model/record/contact.model.mjs +28 -1
- package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/model/user/user.model.mjs +1 -1
- package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
- package/esm2022/libs/data-access/gn4/src/fixtures/site.fixtures.mjs +5 -5
- package/esm2022/libs/data-access/gn4/src/fixtures/ui.fixtures.mjs +3 -3
- package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +1 -1
- package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +1 -1
- package/esm2022/libs/feature/editor/src/lib/+state/editor.actions.mjs +2 -1
- package/esm2022/libs/feature/editor/src/lib/+state/editor.effects.mjs +6 -1
- package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +4 -1
- package/esm2022/libs/feature/editor/src/lib/components/contact-card/contact-card.component.mjs +29 -0
- package/esm2022/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.mjs +78 -0
- package/esm2022/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.mjs +71 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.mjs +143 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +19 -41
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +10 -8
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.mjs +101 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.mjs +146 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.mjs +44 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.mjs +91 -11
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.mjs +10 -6
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +11 -11
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.mjs +9 -8
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +111 -5
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.mjs +38 -68
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +16 -14
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +44 -53
- package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +5 -4
- package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +8 -8
- package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +6 -4
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +34 -4
- package/esm2022/libs/feature/editor/src/lib/models/editor-config.model.mjs +1 -1
- package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +5 -1
- package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.mjs +6 -6
- package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.mjs +7 -6
- package/esm2022/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.mjs +8 -5
- package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +6 -7
- package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +8 -7
- package/esm2022/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.mjs +7 -6
- package/esm2022/libs/feature/map/src/lib/feature-map.module.mjs +7 -26
- package/esm2022/libs/feature/map/src/lib/layers-panel/layers-panel.component.mjs +29 -13
- package/esm2022/libs/feature/map/src/lib/style/map-style.fixtures.mjs +3 -3
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +1 -1
- package/esm2022/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.mjs +1 -1
- package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +1 -1
- package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +4 -2
- package/esm2022/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.mjs +3 -3
- package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +10 -4
- package/esm2022/libs/ui/dataviz/src/lib/table/table.fixtures.mjs +3 -3
- package/esm2022/libs/ui/elements/src/index.mjs +1 -2
- package/esm2022/libs/ui/elements/src/lib/download-item/download-item.component.mjs +2 -2
- package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +1 -1
- package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +2 -2
- package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +5 -5
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +7 -4
- package/esm2022/libs/ui/inputs/src/index.mjs +5 -1
- package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +19 -5
- package/esm2022/libs/ui/inputs/src/lib/editable-label/editable-label.directive.mjs +26 -24
- package/esm2022/libs/ui/inputs/src/lib/file-input/file-input.component.mjs +87 -0
- package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +21 -23
- package/esm2022/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.mjs +32 -0
- package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +7 -21
- package/esm2022/libs/ui/inputs/src/lib/text-input/text-input.component.mjs +6 -17
- package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +3 -7
- package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +43 -0
- package/esm2022/libs/ui/layout/src/index.mjs +3 -1
- package/esm2022/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.mjs +29 -0
- package/esm2022/libs/ui/layout/src/lib/sortable-list/sortable-list.component.mjs +43 -0
- package/esm2022/libs/ui/map/src/lib/ui-map.module.mjs +3 -3
- package/esm2022/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.mjs +7 -7
- package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +8 -8
- package/esm2022/libs/util/app-config/src/lib/fixtures.mjs +10 -10
- package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +1 -1
- package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +1 -1
- package/esm2022/libs/util/shared/src/lib/utils/bytes-convert.mjs +4 -1
- package/esm2022/translations/de.json +57 -2
- package/esm2022/translations/en.json +57 -2
- package/esm2022/translations/es.json +55 -0
- package/esm2022/translations/fr.json +60 -5
- package/esm2022/translations/it.json +57 -2
- package/esm2022/translations/nl.json +55 -0
- package/esm2022/translations/pt.json +55 -0
- package/fesm2022/geonetwork-ui.mjs +2720 -1488
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts +3 -3
- package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts +2 -6
- package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts +2 -2
- package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts +1 -1
- package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +4 -5
- 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 +7 -6
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +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 +22 -2
- package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/contact.model.d.ts +1 -0
- package/libs/common/domain/src/lib/model/record/contact.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +7 -6
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/model/user/user.model.d.ts +1 -1
- package/libs/common/domain/src/lib/model/user/user.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/platform.service.interface.d.ts +16 -0
- package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
- package/libs/data-access/gn4/src/fixtures/site.fixtures.d.ts +2 -2
- package/libs/data-access/gn4/src/fixtures/site.fixtures.d.ts.map +1 -1
- package/libs/data-access/gn4/src/fixtures/ui.fixtures.d.ts +1 -1
- package/libs/data-access/gn4/src/fixtures/ui.fixtures.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts +2 -2
- package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts +6 -6
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts +3 -3
- package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/+state/editor.actions.d.ts +1 -0
- package/libs/feature/editor/src/lib/+state/editor.actions.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/+state/editor.effects.d.ts +5 -0
- package/libs/feature/editor/src/lib/+state/editor.effects.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +1 -0
- package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts +12 -0
- package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts +32 -0
- package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts +15 -0
- package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts +41 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts +8 -19
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts +6 -4
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.d.ts +22 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.d.ts +34 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.d.ts +15 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts +23 -4
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts +4 -3
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts +4 -4
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts +4 -3
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts +23 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts +10 -16
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +5 -5
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +18 -24
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts +5 -3
- package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/feature-editor.module.d.ts +2 -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 +8 -0
- package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/models/editor-config.model.d.ts +5 -0
- package/libs/feature/editor/src/lib/models/editor-config.model.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/services/editor.service.d.ts +1 -0
- package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts +1 -1
- package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts +6 -6
- package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts +1 -1
- package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts +1 -1
- package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts +1 -1
- package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts +1 -1
- package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/feature-map.module.d.ts +16 -21
- package/libs/feature/map/src/lib/feature-map.module.d.ts.map +1 -1
- package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts +1 -1
- package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/style/map-style.fixtures.d.ts +2 -2
- package/libs/feature/map/src/lib/style/map-style.fixtures.d.ts.map +1 -1
- package/libs/feature/record/src/lib/data-view/data-view.component.d.ts +3 -3
- package/libs/feature/record/src/lib/data-view/data-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts +2 -2
- package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +2 -2
- package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts +7 -7
- package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
- package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +1 -0
- package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -1
- package/libs/ui/dataviz/src/lib/table/table.fixtures.d.ts +2 -2
- package/libs/ui/dataviz/src/lib/table/table.fixtures.d.ts.map +1 -1
- package/libs/ui/elements/src/index.d.ts +0 -1
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts +2 -2
- package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +7 -7
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +2 -2
- package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
- package/libs/ui/inputs/src/index.d.ts +4 -0
- package/libs/ui/inputs/src/index.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts +9 -1
- package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts +5 -3
- package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/file-input/file-input.component.d.ts +24 -0
- package/libs/ui/inputs/src/lib/file-input/file-input.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +6 -9
- package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts +17 -0
- package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +0 -4
- 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 +2 -4
- 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 +34 -35
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts +18 -0
- package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts.map +1 -0
- 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/modal-dialog/modal-dialog.component.d.ts +20 -0
- package/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.d.ts.map +1 -0
- package/libs/ui/layout/src/lib/sortable-list/sortable-list.component.d.ts +14 -0
- package/libs/ui/layout/src/lib/sortable-list/sortable-list.component.d.ts.map +1 -0
- package/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.d.ts +3 -3
- package/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.d.ts.map +1 -1
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +2 -2
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
- package/libs/util/app-config/src/lib/fixtures.d.ts +8 -8
- package/libs/util/app-config/src/lib/fixtures.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-classifier.service.d.ts +3 -3
- package/libs/util/shared/src/lib/links/link-classifier.service.d.ts.map +1 -1
- package/libs/util/shared/src/lib/links/link-utils.d.ts +6 -6
- package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/bytes-convert.d.ts +2 -1
- package/libs/util/shared/src/lib/utils/bytes-convert.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/generic.records.ts +7 -2
- package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +18 -16
- package/src/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.ts +2 -6
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.ts +4 -4
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.ts +12 -4
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.ts +14 -8
- package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +7 -13
- package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +13 -15
- package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +48 -36
- package/src/libs/api/metadata-converter/src/lib/xml-utils.ts +5 -5
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +12 -1
- package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +90 -15
- package/src/libs/common/domain/src/lib/model/record/contact.model.ts +28 -0
- package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +8 -7
- package/src/libs/common/domain/src/lib/model/user/user.model.ts +1 -1
- package/src/libs/common/domain/src/lib/platform.service.interface.ts +30 -0
- package/src/libs/common/fixtures/src/index.ts +1 -1
- package/src/libs/common/fixtures/src/lib/editor/editor.fixtures.ts +37 -37
- package/src/libs/common/fixtures/src/lib/elasticsearch/{aggregations-request.ts → aggregations-request.fixtures.ts} +1 -3
- package/src/libs/common/fixtures/src/lib/elasticsearch/{aggregations-response.ts → aggregations-response.fixtures.ts} +6 -8
- package/src/libs/common/fixtures/src/lib/elasticsearch/{full-response.ts → full-response.fixtures.ts} +1 -3
- package/src/libs/common/fixtures/src/lib/elasticsearch/index.ts +5 -5
- package/src/libs/common/fixtures/src/lib/elasticsearch/metadata-links.fixtures.ts +1 -3
- package/src/libs/common/fixtures/src/lib/elasticsearch/metadata.fixtures.ts +1739 -1742
- package/src/libs/common/fixtures/src/lib/elasticsearch/{search-requests.ts → search-requests.fixtures.ts} +1 -3
- package/src/libs/common/fixtures/src/lib/elasticsearch/{search-responses.ts → search-responses.fixtures.ts} +4 -6
- package/src/libs/common/fixtures/src/lib/geojson.fixtures.ts +57178 -57195
- package/src/libs/common/fixtures/src/lib/gn4/groups.fixtures.ts +2 -4
- package/src/libs/common/fixtures/src/lib/link.fixtures.ts +233 -164
- package/src/libs/common/fixtures/src/lib/ol-feature.fixtures.ts +10 -0
- package/src/libs/common/fixtures/src/lib/organisations.fixture.ts +37 -3
- package/src/libs/common/fixtures/src/lib/record-link.fixtures.ts +9 -7
- package/src/libs/common/fixtures/src/lib/records.fixtures.ts +9 -9
- package/src/libs/common/fixtures/src/lib/repository.fixtures.ts +4 -4
- package/src/libs/common/fixtures/src/lib/search/aggregations.ts +2 -3
- package/src/libs/common/fixtures/src/lib/user-feedbacks.fixtures.ts +14 -15
- package/src/libs/common/fixtures/src/lib/user.fixtures.ts +32 -15
- package/src/libs/data-access/gn4/src/fixtures/site.fixtures.ts +4 -4
- package/src/libs/data-access/gn4/src/fixtures/ui.fixtures.ts +2 -2
- package/src/libs/feature/catalog/src/lib/sources/sources.fixture.ts +1 -1
- package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +3 -3
- package/src/libs/feature/dataviz/src/lib/figure/figure.fixtures.ts +2 -2
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +6 -6
- package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.ts +4 -4
- package/src/libs/feature/editor/src/lib/+state/editor.actions.ts +2 -0
- package/src/libs/feature/editor/src/lib/+state/editor.effects.ts +15 -0
- package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +4 -0
- package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.html +25 -0
- package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.ts +30 -0
- package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.html +26 -0
- package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.ts +89 -0
- package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.html +35 -0
- package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.ts +79 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.html +86 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.ts +210 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.html +7 -17
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.ts +18 -51
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.ts +13 -5
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.html +4 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.ts +128 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.html +33 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.ts +179 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.html +6 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.ts +48 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.html +11 -5
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.ts +104 -7
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.html +2 -2
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.ts +9 -3
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.html +2 -2
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +13 -7
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.html +5 -3
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.ts +11 -4
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +15 -1
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.ts +156 -1
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.html +30 -4
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.ts +41 -86
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +17 -15
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +111 -74
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +48 -53
- package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +3 -1
- package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.ts +9 -4
- package/src/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.html +1 -1
- package/src/libs/feature/editor/src/lib/feature-editor.module.ts +2 -1
- package/src/libs/feature/editor/src/lib/fields.config.ts +37 -3
- package/src/libs/feature/editor/src/lib/models/editor-config.model.ts +9 -0
- package/src/libs/feature/editor/src/lib/services/editor.service.ts +7 -0
- package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.ts +3 -0
- package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.ts +12 -8
- package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.ts +5 -0
- package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.html +1 -1
- package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.ts +10 -7
- package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.html +1 -1
- package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.ts +5 -0
- package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.html +1 -1
- package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.ts +6 -1
- package/src/libs/feature/map/src/lib/feature-map.module.ts +2 -15
- package/src/libs/feature/map/src/lib/layers-panel/layers-panel.component.ts +24 -1
- package/src/libs/feature/map/src/lib/map-context/map-context.fixtures.ts +26 -22
- package/src/libs/feature/map/src/lib/style/map-style.fixtures.ts +29 -27
- package/src/libs/feature/record/src/lib/data-view/data-view.component.ts +3 -3
- package/src/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.ts +2 -2
- package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +2 -2
- package/src/libs/feature/record/src/lib/state/mdview.facade.ts +5 -1
- package/src/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.html +1 -1
- package/src/libs/feature/search/src/lib/results-table/results-table-container.component.html +1 -0
- package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +22 -1
- package/src/libs/feature/search/src/lib/state/fixtures/search-state.fixtures.ts +2 -2
- package/src/libs/ui/dataviz/src/lib/chart/chart.fixtures.ts +2 -2
- package/src/libs/ui/dataviz/src/lib/table/table.fixtures.ts +2 -2
- package/src/libs/ui/elements/src/index.ts +0 -1
- package/src/libs/ui/elements/src/lib/download-item/download-item.component.ts +4 -4
- package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +7 -7
- package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +3 -3
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +2 -2
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +6 -1
- package/src/libs/ui/inputs/src/index.ts +4 -0
- package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +15 -3
- package/src/libs/ui/inputs/src/lib/editable-label/editable-label.directive.ts +40 -26
- package/src/libs/ui/inputs/src/lib/file-input/file-input.component.css +0 -0
- package/src/libs/ui/inputs/src/lib/file-input/file-input.component.html +85 -0
- package/src/libs/ui/inputs/src/lib/file-input/file-input.component.ts +92 -0
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +50 -50
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +19 -21
- package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +3 -2
- package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +3 -28
- package/src/libs/ui/inputs/src/lib/text-input/text-input.component.html +4 -3
- package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +4 -16
- package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +0 -3
- package/src/libs/ui/inputs/src/lib/url-input/url-input.component.css +9 -0
- package/src/libs/ui/inputs/src/lib/url-input/url-input.component.html +37 -0
- package/src/libs/ui/inputs/src/lib/url-input/url-input.component.ts +33 -0
- package/src/libs/ui/layout/src/index.ts +2 -0
- package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.css +0 -0
- package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.html +15 -0
- package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.ts +44 -0
- package/src/libs/ui/layout/src/lib/sortable-list/sortable-list.component.html +37 -0
- package/src/libs/ui/{elements → layout}/src/lib/sortable-list/sortable-list.component.ts +15 -18
- package/src/libs/ui/map/src/lib/ui-map.module.ts +1 -1
- package/src/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.ts +7 -6
- package/src/libs/ui/search/src/lib/results-table/results-table.component.html +9 -2
- package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +5 -6
- package/src/libs/util/app-config/src/lib/fixtures.ts +9 -9
- package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +4 -3
- package/src/libs/util/shared/src/lib/links/link-utils.ts +6 -6
- package/src/libs/util/shared/src/lib/utils/bytes-convert.ts +4 -1
- package/tailwind.base.css +21 -4
- package/translations/de.json +57 -2
- package/translations/en.json +57 -2
- package/translations/es.json +55 -0
- package/translations/fr.json +60 -5
- package/translations/it.json +57 -2
- package/translations/nl.json +55 -0
- package/translations/pt.json +55 -0
- package/translations/sk.json +55 -0
- package/esm2022/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.mjs +0 -138
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.mjs +0 -17
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.mjs +0 -17
- package/esm2022/libs/ui/elements/src/lib/sortable-list/sortable-list.component.mjs +0 -43
- package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts +0 -27
- package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts.map +0 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.d.ts +0 -8
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.d.ts.map +0 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.d.ts +0 -8
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.d.ts.map +0 -1
- package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts +0 -22
- package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts.map +0 -1
- package/src/libs/common/fixtures/src/lib/ol-feature.fixture.ts +0 -7
- package/src/libs/common/fixtures/src/lib/utils/freeze.ts +0 -10
- package/src/libs/common/fixtures/src/lib/utils/index.ts +0 -1
- package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +0 -10
- package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +0 -166
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.html +0 -7
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.ts +0 -16
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.html +0 -13
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.ts +0 -16
- package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.html +0 -36
- /package/src/libs/feature/editor/src/lib/components/{overview-upload/overview-upload.component.css → contact-card/contact-card.component.css} +0 -0
- /package/src/libs/feature/editor/src/lib/components/{record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.css → generic-keywords/generic-keywords.component.css} +0 -0
- /package/src/libs/feature/editor/src/lib/components/{record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.css → online-resource-card/online-resource-card.component.css} +0 -0
- /package/src/libs/ui/{elements → layout}/src/lib/sortable-list/sortable-list.component.css +0 -0
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
<div class="w-full flex flex-col gap-[16px]">
|
|
2
|
+
<label
|
|
3
|
+
gnUiFilesDrop
|
|
4
|
+
class="flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100"
|
|
5
|
+
[ngClass]="{
|
|
6
|
+
'border-primary-lighter bg-primary-white': dragFilesOver,
|
|
7
|
+
'border-gray-300': !dragFilesOver
|
|
8
|
+
}"
|
|
9
|
+
(dragFilesOver)="handleDragFilesOver($event)"
|
|
10
|
+
(dropFiles)="handleDropFiles($event)"
|
|
11
|
+
>
|
|
12
|
+
<div
|
|
13
|
+
class="w-14 h-14 rounded-md bg-gray-50 grid"
|
|
14
|
+
*ngIf="!isUploadInProgress"
|
|
15
|
+
>
|
|
16
|
+
<mat-icon
|
|
17
|
+
*ngIf="!dragFilesOver"
|
|
18
|
+
class="material-symbols-outlined place-self-center text-primary"
|
|
19
|
+
>cloud_upload</mat-icon
|
|
20
|
+
>
|
|
21
|
+
<mat-icon
|
|
22
|
+
*ngIf="dragFilesOver"
|
|
23
|
+
class="material-symbols-outlined place-self-center text-primary"
|
|
24
|
+
>add_box</mat-icon
|
|
25
|
+
>
|
|
26
|
+
</div>
|
|
27
|
+
<div
|
|
28
|
+
*ngIf="isUploadInProgress"
|
|
29
|
+
class="w-14 h-14 grid items-center justify-center"
|
|
30
|
+
>
|
|
31
|
+
<div class="text-gray-100 absolute">
|
|
32
|
+
<mat-progress-spinner
|
|
33
|
+
class="place-self-center"
|
|
34
|
+
[diameter]="56"
|
|
35
|
+
mode="determinate"
|
|
36
|
+
[value]="100"
|
|
37
|
+
></mat-progress-spinner>
|
|
38
|
+
</div>
|
|
39
|
+
<div class="text-primary absolute">
|
|
40
|
+
<mat-progress-spinner
|
|
41
|
+
class="place-self-center"
|
|
42
|
+
[diameter]="56"
|
|
43
|
+
mode="determinate"
|
|
44
|
+
[value]="uploadProgress"
|
|
45
|
+
></mat-progress-spinner>
|
|
46
|
+
</div>
|
|
47
|
+
<span class="text-sm text-main font-bold">{{ uploadProgress }}%</span>
|
|
48
|
+
</div>
|
|
49
|
+
<div class="flex flex-col items-center gap-1">
|
|
50
|
+
<p class="font-medium">
|
|
51
|
+
{{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}
|
|
52
|
+
</p>
|
|
53
|
+
<p
|
|
54
|
+
class="text-sm"
|
|
55
|
+
[class]="
|
|
56
|
+
isUploadInProgress
|
|
57
|
+
? 'font-bold text-primary cursor-pointer'
|
|
58
|
+
: 'font-medium text-gray-500'
|
|
59
|
+
"
|
|
60
|
+
(click)="handleSecondaryTextClick($event)"
|
|
61
|
+
>
|
|
62
|
+
{{ getSecondaryText() | translate }}
|
|
63
|
+
</p>
|
|
64
|
+
</div>
|
|
65
|
+
<p class="w-full flex flex-row items-center justify-stretch gap-[16px]">
|
|
66
|
+
<span class="border-b border-gray-300 grow"></span>
|
|
67
|
+
<span class="text-sm font-medium text-gray-500 or-input-url" translate>
|
|
68
|
+
input.file.orInputUrl</span
|
|
69
|
+
>
|
|
70
|
+
<span class="border-b border-gray-300 grow"></span>
|
|
71
|
+
</p>
|
|
72
|
+
<input
|
|
73
|
+
type="file"
|
|
74
|
+
class="hidden"
|
|
75
|
+
(change)="handleFileInput($event)"
|
|
76
|
+
[disabled]="isUploadInProgress"
|
|
77
|
+
/>
|
|
78
|
+
|
|
79
|
+
<gn-ui-url-input
|
|
80
|
+
class="w-full"
|
|
81
|
+
[disabled]="isUploadInProgress"
|
|
82
|
+
(valueChange)="handleUrlChange($event)"
|
|
83
|
+
></gn-ui-url-input>
|
|
84
|
+
</label>
|
|
85
|
+
</div>
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common'
|
|
2
|
+
import {
|
|
3
|
+
ChangeDetectionStrategy,
|
|
4
|
+
ChangeDetectorRef,
|
|
5
|
+
Component,
|
|
6
|
+
EventEmitter,
|
|
7
|
+
Input,
|
|
8
|
+
Output,
|
|
9
|
+
} from '@angular/core'
|
|
10
|
+
import { MatIconModule } from '@angular/material/icon'
|
|
11
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner'
|
|
12
|
+
import { ButtonComponent } from '../button/button.component'
|
|
13
|
+
import { FilesDropDirective } from '../files-drop/files-drop.directive'
|
|
14
|
+
import { TranslateModule } from '@ngx-translate/core'
|
|
15
|
+
import { marker } from '@biesbjerg/ngx-translate-extract-marker'
|
|
16
|
+
import { UrlInputComponent } from '../url-input/url-input.component'
|
|
17
|
+
|
|
18
|
+
@Component({
|
|
19
|
+
selector: 'gn-ui-file-input',
|
|
20
|
+
templateUrl: './file-input.component.html',
|
|
21
|
+
styleUrls: ['./file-input.component.css'],
|
|
22
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
23
|
+
standalone: true,
|
|
24
|
+
imports: [
|
|
25
|
+
CommonModule,
|
|
26
|
+
ButtonComponent,
|
|
27
|
+
MatIconModule,
|
|
28
|
+
FilesDropDirective,
|
|
29
|
+
MatProgressSpinnerModule,
|
|
30
|
+
TranslateModule,
|
|
31
|
+
UrlInputComponent,
|
|
32
|
+
],
|
|
33
|
+
})
|
|
34
|
+
export class FileInputComponent {
|
|
35
|
+
@Input() maxSizeMB: number
|
|
36
|
+
@Input() uploadProgress?: number
|
|
37
|
+
@Output() fileChange: EventEmitter<File> = new EventEmitter()
|
|
38
|
+
@Output() urlChange: EventEmitter<string> = new EventEmitter()
|
|
39
|
+
@Output() uploadCancel: EventEmitter<void> = new EventEmitter()
|
|
40
|
+
|
|
41
|
+
dragFilesOver = false
|
|
42
|
+
|
|
43
|
+
get isUploadInProgress() {
|
|
44
|
+
return this.uploadProgress !== undefined
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
constructor(private cd: ChangeDetectorRef) {}
|
|
48
|
+
|
|
49
|
+
getPrimaryText() {
|
|
50
|
+
if (this.uploadProgress) {
|
|
51
|
+
return marker('input.file.uploadProgressLabel')
|
|
52
|
+
}
|
|
53
|
+
return marker('input.file.selectFileLabel')
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
getSecondaryText() {
|
|
57
|
+
if (this.uploadProgress) {
|
|
58
|
+
return marker('input.file.uploadProgressCancel')
|
|
59
|
+
}
|
|
60
|
+
return marker('input.file.dropFileLabel')
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
handleDragFilesOver(dragFilesOver: boolean) {
|
|
64
|
+
this.dragFilesOver = dragFilesOver
|
|
65
|
+
this.cd.markForCheck()
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
handleDropFiles(files: File[]) {
|
|
69
|
+
if (files.length > 0) {
|
|
70
|
+
this.fileChange.emit(files[0])
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
handleFileInput(event: Event) {
|
|
75
|
+
this.handleDropFiles(Array.from((event.target as HTMLInputElement).files))
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
handleUrlChange(url: string) {
|
|
79
|
+
this.urlChange.emit(url)
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
handleSecondaryTextClick(event: Event) {
|
|
83
|
+
if (this.uploadProgress) {
|
|
84
|
+
this.handleCancel()
|
|
85
|
+
event.preventDefault()
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
handleCancel() {
|
|
90
|
+
this.uploadCancel.emit()
|
|
91
|
+
}
|
|
92
|
+
}
|
|
@@ -19,14 +19,12 @@
|
|
|
19
19
|
<mat-icon class="material-symbols-outlined">delete</mat-icon>
|
|
20
20
|
</gn-ui-button>
|
|
21
21
|
</div>
|
|
22
|
-
<input
|
|
22
|
+
<gn-ui-text-input
|
|
23
23
|
*ngIf="showAltTextInput"
|
|
24
|
-
type="text"
|
|
25
|
-
class="py-3 px-2 border-2 border-gray-300 rounded-lg text-sm font-medium"
|
|
26
24
|
[placeholder]="'input.image.altTextPlaceholder' | translate"
|
|
27
|
-
[value]="altText"
|
|
28
|
-
(
|
|
29
|
-
|
|
25
|
+
[value]="altText ?? ''"
|
|
26
|
+
(valueChange)="handleAltTextChange($event)"
|
|
27
|
+
></gn-ui-text-input>
|
|
30
28
|
<div class="flex flex-row gap-2">
|
|
31
29
|
<gn-ui-button
|
|
32
30
|
[extraClass]="'bg-gray-200 font-bold'"
|
|
@@ -51,50 +49,70 @@
|
|
|
51
49
|
<div class="w-full h-full flex flex-col gap-2">
|
|
52
50
|
<label
|
|
53
51
|
gnUiFilesDrop
|
|
54
|
-
class="
|
|
52
|
+
class="flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4"
|
|
53
|
+
[ngClass]="{
|
|
54
|
+
'border-primary-lighter bg-primary-white': dragFilesOver,
|
|
55
|
+
'border-gray-300': !dragFilesOver
|
|
56
|
+
}"
|
|
55
57
|
(dragFilesOver)="handleDragFilesOver($event)"
|
|
56
58
|
(dropFiles)="handleDropFiles($event)"
|
|
57
59
|
>
|
|
58
|
-
<div
|
|
60
|
+
<div
|
|
61
|
+
class="w-14 h-14 rounded-md bg-gray-50 grid"
|
|
62
|
+
*ngIf="!isUploadInProgress && !uploadError"
|
|
63
|
+
>
|
|
59
64
|
<mat-icon
|
|
60
|
-
*ngIf="!dragFilesOver
|
|
61
|
-
class="material-symbols-outlined place-self-center text-
|
|
65
|
+
*ngIf="!dragFilesOver"
|
|
66
|
+
class="material-symbols-outlined place-self-center text-primary"
|
|
62
67
|
>image</mat-icon
|
|
63
68
|
>
|
|
64
69
|
<mat-icon
|
|
65
|
-
*ngIf="dragFilesOver
|
|
66
|
-
class="material-symbols-outlined place-self-center text-
|
|
70
|
+
*ngIf="dragFilesOver"
|
|
71
|
+
class="material-symbols-outlined place-self-center text-primary"
|
|
67
72
|
>add_box</mat-icon
|
|
68
73
|
>
|
|
69
|
-
|
|
74
|
+
</div>
|
|
75
|
+
|
|
76
|
+
<div
|
|
77
|
+
*ngIf="isUploadInProgress && !uploadError"
|
|
78
|
+
class="w-14 h-14 grid items-center justify-center"
|
|
79
|
+
>
|
|
80
|
+
<div class="text-gray-100 absolute">
|
|
81
|
+
<mat-progress-spinner
|
|
82
|
+
class="place-self-center"
|
|
83
|
+
[diameter]="56"
|
|
84
|
+
mode="determinate"
|
|
85
|
+
[value]="100"
|
|
86
|
+
></mat-progress-spinner>
|
|
87
|
+
</div>
|
|
88
|
+
<div class="text-primary absolute">
|
|
70
89
|
<mat-progress-spinner
|
|
71
90
|
class="place-self-center"
|
|
72
91
|
[diameter]="56"
|
|
73
|
-
|
|
92
|
+
mode="determinate"
|
|
74
93
|
[value]="uploadProgress"
|
|
75
94
|
></mat-progress-spinner>
|
|
76
|
-
<span
|
|
77
|
-
class="text-sm font-medium relative inline-block width-[30px] bottom-[40px] left-[15px]"
|
|
78
|
-
>
|
|
79
|
-
{{ uploadProgress }}%
|
|
80
|
-
</span>
|
|
81
95
|
</div>
|
|
96
|
+
<span class="text-sm text-main font-bold">{{ uploadProgress }}%</span>
|
|
97
|
+
</div>
|
|
98
|
+
|
|
99
|
+
<div class="w-14 h-14 rounded-md bg-gray-50 grid" *ngIf="uploadError">
|
|
82
100
|
<mat-icon
|
|
83
|
-
*ngIf="uploadError"
|
|
84
101
|
class="material-symbols-outlined place-self-center text-rose-500"
|
|
85
102
|
>broken_image</mat-icon
|
|
86
103
|
>
|
|
87
104
|
</div>
|
|
105
|
+
|
|
88
106
|
<div class="flex flex-col items-center gap-1">
|
|
89
107
|
<p class="font-medium">{{ getPrimaryText() | translate }}</p>
|
|
90
108
|
<p
|
|
91
109
|
class="text-sm"
|
|
92
110
|
[class]="
|
|
93
|
-
|
|
111
|
+
isUploadInProgress || uploadError
|
|
94
112
|
? 'font-bold text-blue-500 cursor-pointer'
|
|
95
113
|
: 'font-medium text-gray-500'
|
|
96
114
|
"
|
|
97
|
-
(click)="handleSecondaryTextClick()"
|
|
115
|
+
(click)="handleSecondaryTextClick($event)"
|
|
98
116
|
>
|
|
99
117
|
{{ getSecondaryText() | translate }}
|
|
100
118
|
</p>
|
|
@@ -103,9 +121,10 @@
|
|
|
103
121
|
type="file"
|
|
104
122
|
class="hidden"
|
|
105
123
|
(change)="handleFileInput($event)"
|
|
106
|
-
[disabled]="showUrlInput ||
|
|
124
|
+
[disabled]="showUrlInput || isUploadInProgress || uploadError"
|
|
107
125
|
/>
|
|
108
126
|
</label>
|
|
127
|
+
|
|
109
128
|
<div *ngIf="!showUrlInput" class="flex-none">
|
|
110
129
|
<gn-ui-button
|
|
111
130
|
[extraClass]="'bg-gray-200 font-bold'"
|
|
@@ -115,32 +134,13 @@
|
|
|
115
134
|
{{ 'input.image.displayUrlInput' | translate }}
|
|
116
135
|
</gn-ui-button>
|
|
117
136
|
</div>
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
<input
|
|
127
|
-
type="text"
|
|
128
|
-
class="py-3 ps-1 block w-full border-2 border-s-0 border-e-0 border-gray-300 text-sm font-medium"
|
|
129
|
-
placeholder="https://exemple.com/image.jpg"
|
|
130
|
-
(change)="handleUrlChange($event)"
|
|
131
|
-
/>
|
|
132
|
-
<gn-ui-button
|
|
133
|
-
class="px-1 inline-flex items-center min-w-fit rounded-e-lg border-2 border-s-0 border-gray-300 text-white"
|
|
134
|
-
[extraClass]="
|
|
135
|
-
urlInputValue && !downloadError ? 'bg-blue-500' : 'bg-gray-500'
|
|
136
|
-
"
|
|
137
|
-
[disabled]="!urlInputValue || downloadError"
|
|
138
|
-
(buttonClick)="downloadUrl()"
|
|
139
|
-
>
|
|
140
|
-
<mat-icon class="material-symbols-outlined">arrow_upward</mat-icon>
|
|
141
|
-
</gn-ui-button>
|
|
142
|
-
</div>
|
|
143
|
-
</div>
|
|
144
|
-
</div>
|
|
137
|
+
|
|
138
|
+
<gn-ui-url-input
|
|
139
|
+
*ngIf="showUrlInput"
|
|
140
|
+
class="mt-3.5"
|
|
141
|
+
(valueChange)="downloadUrl($event)"
|
|
142
|
+
[disabled]="isUploadInProgress"
|
|
143
|
+
>
|
|
144
|
+
</gn-ui-url-input>
|
|
145
145
|
</div>
|
|
146
146
|
</ng-template>
|
|
@@ -16,7 +16,8 @@ import { ButtonComponent } from '../button/button.component'
|
|
|
16
16
|
import { FilesDropDirective } from '../files-drop/files-drop.directive'
|
|
17
17
|
import { TranslateModule } from '@ngx-translate/core'
|
|
18
18
|
import { marker } from '@biesbjerg/ngx-translate-extract-marker'
|
|
19
|
-
import {
|
|
19
|
+
import { UrlInputComponent } from '../url-input/url-input.component'
|
|
20
|
+
import { TextInputComponent } from '../text-input/text-input.component'
|
|
20
21
|
|
|
21
22
|
@Component({
|
|
22
23
|
selector: 'gn-ui-image-input',
|
|
@@ -31,13 +32,13 @@ import { FormControl, ReactiveFormsModule } from '@angular/forms'
|
|
|
31
32
|
FilesDropDirective,
|
|
32
33
|
MatProgressSpinnerModule,
|
|
33
34
|
TranslateModule,
|
|
34
|
-
|
|
35
|
+
UrlInputComponent,
|
|
36
|
+
TextInputComponent,
|
|
35
37
|
],
|
|
36
38
|
})
|
|
37
39
|
export class ImageInputComponent {
|
|
38
|
-
@Input() formControl!: FormControl
|
|
39
40
|
@Input() maxSizeMB: number
|
|
40
|
-
@Input() previewUrl?:
|
|
41
|
+
@Input() previewUrl?: string
|
|
41
42
|
@Input() altText?: string
|
|
42
43
|
@Input() uploadProgress?: number
|
|
43
44
|
@Input() uploadError?: boolean
|
|
@@ -52,10 +53,13 @@ export class ImageInputComponent {
|
|
|
52
53
|
downloadError = false
|
|
53
54
|
showAltTextInput = false
|
|
54
55
|
|
|
55
|
-
urlInputValue?: string
|
|
56
56
|
lastUploadType?: 'file' | 'url'
|
|
57
57
|
lastUploadContent?: string | File
|
|
58
58
|
|
|
59
|
+
get isUploadInProgress() {
|
|
60
|
+
return this.uploadProgress !== undefined
|
|
61
|
+
}
|
|
62
|
+
|
|
59
63
|
constructor(private http: HttpClient, private cd: ChangeDetectorRef) {}
|
|
60
64
|
|
|
61
65
|
getPrimaryText() {
|
|
@@ -107,34 +111,29 @@ export class ImageInputComponent {
|
|
|
107
111
|
this.showUrlInput = true
|
|
108
112
|
}
|
|
109
113
|
|
|
110
|
-
|
|
114
|
+
async downloadUrl(url: string) {
|
|
111
115
|
this.downloadError = false
|
|
112
|
-
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
async downloadUrl() {
|
|
116
|
-
const name = this.urlInputValue.split('/').pop()
|
|
116
|
+
const name = url.split('/').pop()
|
|
117
117
|
|
|
118
118
|
try {
|
|
119
119
|
const response = await firstValueFrom(
|
|
120
|
-
this.http.head(
|
|
120
|
+
this.http.head(url, { observe: 'response' })
|
|
121
121
|
)
|
|
122
122
|
if (
|
|
123
123
|
response.headers.get('content-type')?.startsWith('image/') &&
|
|
124
124
|
parseInt(response.headers.get('content-length')) <
|
|
125
125
|
megabytesToBytes(this.maxSizeMB)
|
|
126
126
|
) {
|
|
127
|
-
this.http.get(
|
|
127
|
+
this.http.get(url, { responseType: 'blob' }).subscribe({
|
|
128
128
|
next: (blob) => {
|
|
129
129
|
this.cd.markForCheck()
|
|
130
130
|
const file = new File([blob], name)
|
|
131
131
|
this.fileChange.emit(file)
|
|
132
132
|
},
|
|
133
|
-
error: (
|
|
134
|
-
console.error(error)
|
|
133
|
+
error: () => {
|
|
135
134
|
this.downloadError = true
|
|
136
135
|
this.cd.markForCheck()
|
|
137
|
-
this.urlChange.emit(
|
|
136
|
+
this.urlChange.emit(url)
|
|
138
137
|
},
|
|
139
138
|
})
|
|
140
139
|
}
|
|
@@ -145,11 +144,12 @@ export class ImageInputComponent {
|
|
|
145
144
|
}
|
|
146
145
|
}
|
|
147
146
|
|
|
148
|
-
handleSecondaryTextClick() {
|
|
147
|
+
handleSecondaryTextClick(event: Event) {
|
|
149
148
|
if (this.uploadError) {
|
|
150
149
|
this.handleRetry()
|
|
151
150
|
} else if (this.uploadProgress) {
|
|
152
151
|
this.handleCancel()
|
|
152
|
+
event.preventDefault()
|
|
153
153
|
}
|
|
154
154
|
}
|
|
155
155
|
|
|
@@ -169,7 +169,6 @@ export class ImageInputComponent {
|
|
|
169
169
|
}
|
|
170
170
|
|
|
171
171
|
handleDelete() {
|
|
172
|
-
this.formControl.markAsDirty()
|
|
173
172
|
this.delete.emit()
|
|
174
173
|
}
|
|
175
174
|
|
|
@@ -177,9 +176,8 @@ export class ImageInputComponent {
|
|
|
177
176
|
this.showAltTextInput = !this.showAltTextInput
|
|
178
177
|
}
|
|
179
178
|
|
|
180
|
-
handleAltTextChange(
|
|
181
|
-
|
|
182
|
-
this.altTextChange.emit(input.value)
|
|
179
|
+
handleAltTextChange(altText: string) {
|
|
180
|
+
this.altTextChange.emit(altText)
|
|
183
181
|
}
|
|
184
182
|
|
|
185
183
|
private filterTypeImage(files: File[]) {
|
|
@@ -2,12 +2,13 @@
|
|
|
2
2
|
<textarea
|
|
3
3
|
#input
|
|
4
4
|
name="textArea"
|
|
5
|
+
class="gn-ui-text-input leading-tight"
|
|
6
|
+
[ngClass]="extraClass"
|
|
5
7
|
[disabled]="disabled"
|
|
6
8
|
[placeholder]="placeholder"
|
|
7
|
-
[value]="value"
|
|
9
|
+
[value]="value ?? ''"
|
|
8
10
|
(change)="handleChange($event)"
|
|
9
11
|
(input)="handleChange($event)"
|
|
10
|
-
[class]="classList"
|
|
11
12
|
[attr.required]="required || null"
|
|
12
13
|
></textarea>
|
|
13
14
|
</div>
|
|
@@ -7,21 +7,20 @@ import {
|
|
|
7
7
|
} from '@angular/core'
|
|
8
8
|
import { Subject } from 'rxjs'
|
|
9
9
|
import { distinctUntilChanged } from 'rxjs/operators'
|
|
10
|
+
import { CommonModule } from '@angular/common'
|
|
10
11
|
|
|
11
12
|
@Component({
|
|
12
13
|
selector: 'gn-ui-text-area',
|
|
13
14
|
templateUrl: './text-area.component.html',
|
|
14
15
|
styleUrls: ['./text-area.component.css'],
|
|
15
16
|
standalone: true,
|
|
17
|
+
imports: [CommonModule],
|
|
16
18
|
})
|
|
17
19
|
export class TextAreaComponent implements AfterViewInit {
|
|
18
|
-
private readonly baseClasses: string
|
|
19
|
-
private readonly disabledClasses: string
|
|
20
|
-
|
|
21
20
|
@Input() value = ''
|
|
22
21
|
@Input() disabled = false
|
|
23
22
|
@Input() extraClass = ''
|
|
24
|
-
@Input() placeholder
|
|
23
|
+
@Input() placeholder = ''
|
|
25
24
|
@Input() required = false
|
|
26
25
|
|
|
27
26
|
rawChange = new Subject<string>()
|
|
@@ -29,30 +28,6 @@ export class TextAreaComponent implements AfterViewInit {
|
|
|
29
28
|
|
|
30
29
|
@ViewChild('input') input
|
|
31
30
|
|
|
32
|
-
constructor() {
|
|
33
|
-
this.baseClasses = [
|
|
34
|
-
'w-full',
|
|
35
|
-
'pt-2',
|
|
36
|
-
'pl-2',
|
|
37
|
-
'resize-none',
|
|
38
|
-
'border',
|
|
39
|
-
'border-gray-800',
|
|
40
|
-
'rounded italic',
|
|
41
|
-
'leading-tight',
|
|
42
|
-
'focus:outline-none',
|
|
43
|
-
'focus:bg-background',
|
|
44
|
-
'focus:border-primary',
|
|
45
|
-
].join(' ')
|
|
46
|
-
|
|
47
|
-
this.disabledClasses = ['cursor-not-allowed'].join(' ')
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
get classList() {
|
|
51
|
-
return `${this.baseClasses} ${this.extraClass} ${
|
|
52
|
-
this.disabled ? this.disabledClasses : ''
|
|
53
|
-
}`
|
|
54
|
-
}
|
|
55
|
-
|
|
56
31
|
ngAfterViewInit() {
|
|
57
32
|
this.checkRequired(this.input.nativeElement.value)
|
|
58
33
|
}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
<input
|
|
2
2
|
#input
|
|
3
|
-
|
|
3
|
+
class="gn-ui-text-input"
|
|
4
|
+
[ngClass]="extraClass"
|
|
4
5
|
type="text"
|
|
5
6
|
[value]="value"
|
|
6
7
|
(change)="handleChange($event)"
|
|
7
8
|
(input)="handleChange($event)"
|
|
8
|
-
[placeholder]="
|
|
9
|
-
[attr.aria-label]="
|
|
9
|
+
[placeholder]="placeholder"
|
|
10
|
+
[attr.aria-label]="placeholder"
|
|
10
11
|
[attr.required]="required || null"
|
|
11
12
|
[disabled]="disabled"
|
|
12
13
|
/>
|
|
@@ -7,37 +7,25 @@ import {
|
|
|
7
7
|
} from '@angular/core'
|
|
8
8
|
import { distinctUntilChanged } from 'rxjs/operators'
|
|
9
9
|
import { Subject } from 'rxjs'
|
|
10
|
+
import { CommonModule } from '@angular/common'
|
|
10
11
|
|
|
11
12
|
@Component({
|
|
12
13
|
selector: 'gn-ui-text-input',
|
|
13
14
|
templateUrl: './text-input.component.html',
|
|
14
15
|
styleUrls: ['./text-input.component.css'],
|
|
16
|
+
standalone: true,
|
|
17
|
+
imports: [CommonModule],
|
|
15
18
|
})
|
|
16
19
|
export class TextInputComponent implements AfterViewInit {
|
|
17
|
-
private readonly baseClass = [
|
|
18
|
-
'appearance-none',
|
|
19
|
-
'border border-gray-300',
|
|
20
|
-
'rounded w-full',
|
|
21
|
-
'p-2',
|
|
22
|
-
'text-gray-700',
|
|
23
|
-
'leading-tight',
|
|
24
|
-
'focus:outline-none',
|
|
25
|
-
'focus:border-primary',
|
|
26
|
-
].join(' ')
|
|
27
|
-
|
|
28
20
|
@Input() value = ''
|
|
29
21
|
@Input() extraClass = ''
|
|
30
|
-
@Input()
|
|
22
|
+
@Input() placeholder: string
|
|
31
23
|
@Input() required = false
|
|
32
24
|
@Input() disabled: boolean
|
|
33
25
|
rawChange = new Subject<string>()
|
|
34
26
|
@Output() valueChange = this.rawChange.pipe(distinctUntilChanged())
|
|
35
27
|
@ViewChild('input') input
|
|
36
28
|
|
|
37
|
-
get classList() {
|
|
38
|
-
return `${this.baseClass} ${this.extraClass}`
|
|
39
|
-
}
|
|
40
|
-
|
|
41
29
|
ngAfterViewInit() {
|
|
42
30
|
this.checkRequired(this.input.nativeElement.value)
|
|
43
31
|
}
|
|
@@ -10,7 +10,6 @@ import { ChipsInputComponent } from './chips-input/chips-input.component'
|
|
|
10
10
|
import { DragAndDropFileInputComponent } from './drag-and-drop-file-input/drag-and-drop-file-input.component'
|
|
11
11
|
import { DropdownSelectorComponent } from './dropdown-selector/dropdown-selector.component'
|
|
12
12
|
import { TextAreaComponent } from './text-area/text-area.component'
|
|
13
|
-
import { TextInputComponent } from './text-input/text-input.component'
|
|
14
13
|
import { MatAutocompleteModule } from '@angular/material/autocomplete'
|
|
15
14
|
import { MatIconModule } from '@angular/material/icon'
|
|
16
15
|
import { NavigationButtonComponent } from './navigation-button/navigation-button.component'
|
|
@@ -36,7 +35,6 @@ import { ImageInputComponent } from './image-input/image-input.component'
|
|
|
36
35
|
|
|
37
36
|
@NgModule({
|
|
38
37
|
declarations: [
|
|
39
|
-
TextInputComponent,
|
|
40
38
|
DragAndDropFileInputComponent,
|
|
41
39
|
ChipsInputComponent,
|
|
42
40
|
NavigationButtonComponent,
|
|
@@ -77,7 +75,6 @@ import { ImageInputComponent } from './image-input/image-input.component'
|
|
|
77
75
|
exports: [
|
|
78
76
|
DropdownSelectorComponent,
|
|
79
77
|
ButtonComponent,
|
|
80
|
-
TextInputComponent,
|
|
81
78
|
DragAndDropFileInputComponent,
|
|
82
79
|
TextAreaComponent,
|
|
83
80
|
ChipsInputComponent,
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
:host {
|
|
2
|
+
--gn-ui-button-rounded: 8px;
|
|
3
|
+
--gn-ui-button-width: 32px;
|
|
4
|
+
--gn-ui-button-padding: 0;
|
|
5
|
+
|
|
6
|
+
--side-padding: calc(var(--gn-ui-text-input-padding, 0.6em) - 6px);
|
|
7
|
+
--2x-side-padding: calc(var(--side-padding) * 2);
|
|
8
|
+
--text-padding: calc(var(--side-padding) + 40px);
|
|
9
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
<span class="w-full inline-block relative">
|
|
2
|
+
<input
|
|
3
|
+
#input
|
|
4
|
+
class="gn-ui-text-input px-[var(--text-padding)]"
|
|
5
|
+
[ngClass]="extraClass"
|
|
6
|
+
type="url"
|
|
7
|
+
[value]="value"
|
|
8
|
+
(input)="handleInput()"
|
|
9
|
+
(keydown.enter)="handleChange(input)"
|
|
10
|
+
[placeholder]="placeholder"
|
|
11
|
+
[attr.aria-label]="placeholder"
|
|
12
|
+
[disabled]="disabled"
|
|
13
|
+
/>
|
|
14
|
+
<div
|
|
15
|
+
class="absolute inset-y-[var(--side-padding)] left-[var(--2x-side-padding)] grid justify-center items-center pointer-events-none"
|
|
16
|
+
[ngClass]='{
|
|
17
|
+
"text-primary": !disabled,
|
|
18
|
+
"text-primary-lightest": disabled,
|
|
19
|
+
}'
|
|
20
|
+
>
|
|
21
|
+
<mat-icon
|
|
22
|
+
class="material-symbols-outlined h-[24px] !w-[26px] text-[28px] leading-[24px]"
|
|
23
|
+
>
|
|
24
|
+
link
|
|
25
|
+
</mat-icon>
|
|
26
|
+
</div>
|
|
27
|
+
<gn-ui-button
|
|
28
|
+
extraClass="absolute inset-y-[var(--side-padding)] right-[var(--side-padding)]"
|
|
29
|
+
type="primary"
|
|
30
|
+
[disabled]="disabled || input.value === ''"
|
|
31
|
+
(buttonClick)="handleChange(input)"
|
|
32
|
+
>
|
|
33
|
+
<mat-icon class="material-symbols-outlined text-[20px] leading-[26px]">
|
|
34
|
+
arrow_upward
|
|
35
|
+
</mat-icon>
|
|
36
|
+
</gn-ui-button>
|
|
37
|
+
</span>
|