geonetwork-ui 2.4.0-dev.e6ae55aa → 2.4.0-dev.e7ff1d25
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/libs/api/metadata-converter/src/index.mjs +1 -2
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +5 -5
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +30 -2
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.mjs +31 -0
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +23 -1
- package/esm2022/libs/api/metadata-converter/src/lib/xml-utils.mjs +10 -3
- package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +21 -4
- 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/repository/records-repository.interface.mjs +1 -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/overview-upload/overview-upload.component.mjs +131 -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 +170 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +3 -3
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.mjs +47 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.mjs +21 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.mjs +7 -6
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +33 -9
- package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +3 -3
- 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 +30 -3
- 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 +6 -5
- 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/utils/map-utils.service.mjs +10 -5
- 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 +40 -7
- package/esm2022/libs/feature/search/src/lib/state/search.facade.mjs +6 -2
- package/esm2022/libs/ui/elements/src/index.mjs +2 -1
- package/esm2022/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.mjs +27 -0
- package/esm2022/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.mjs +4 -3
- package/esm2022/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.mjs +2 -2
- package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +5 -11
- package/esm2022/libs/ui/elements/src/lib/metadata-quality-item/metadata-quality-item.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +5 -5
- package/esm2022/libs/ui/elements/src/lib/sortable-list/sortable-list.component.mjs +7 -3
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +11 -5
- package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +19 -5
- package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +17 -14
- package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +6 -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/lib/form-field-wrapper/form-field-wrapper.component.mjs +3 -3
- package/esm2022/libs/ui/layout/src/lib/interactive-table/interactive-table.component.mjs +3 -3
- package/esm2022/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.mjs +49 -11
- package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +18 -6
- package/esm2022/libs/ui/widgets/src/index.mjs +2 -1
- package/esm2022/libs/ui/widgets/src/lib/popover/popover.component.mjs +68 -0
- package/esm2022/translations/de.json +47 -17
- package/esm2022/translations/en.json +40 -10
- package/esm2022/translations/es.json +39 -9
- package/esm2022/translations/fr.json +52 -22
- package/esm2022/translations/it.json +40 -10
- package/esm2022/translations/nl.json +39 -9
- package/esm2022/translations/pt.json +39 -9
- package/fesm2022/geonetwork-ui.mjs +4151 -3180
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/metadata-converter/src/index.d.ts +0 -1
- package/libs/api/metadata-converter/src/index.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 +8 -1
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.d.ts +5 -0
- package/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.d.ts.map +1 -0
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +3 -1
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/xml-utils.d.ts +1 -0
- package/libs/api/metadata-converter/src/lib/xml-utils.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +6 -1
- package/libs/api/repository/src/lib/gn4/gn4-repository.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 +2 -1
- package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
- package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +8 -0
- package/libs/common/domain/src/lib/repository/records-repository.interface.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/overview-upload/overview-upload.component.d.ts +27 -0
- package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.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 +47 -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-open-data/form-field-open-data.component.d.ts +17 -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 +11 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts +3 -1
- 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.component.d.ts +9 -1
- 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/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 +7 -0
- package/libs/feature/editor/src/lib/fields.config.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 +1 -1
- package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts.map +1 -1
- package/libs/feature/map/src/lib/add-layer-from-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/utils/map-utils.service.d.ts.map +1 -1
- package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +11 -3
- package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -1
- package/libs/feature/search/src/lib/state/search.facade.d.ts +1 -0
- package/libs/feature/search/src/lib/state/search.facade.d.ts.map +1 -1
- package/libs/ui/elements/src/index.d.ts +1 -0
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.d.ts +18 -0
- package/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts +0 -3
- package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts +4 -4
- package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +8 -6
- package/libs/ui/elements/src/lib/ui-elements.module.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/image-input/image-input.component.d.ts +3 -4
- package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -1
- 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/search/src/lib/results-table/action-menu/action-menu.component.d.ts +10 -1
- package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts.map +1 -1
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +6 -2
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
- package/libs/ui/widgets/src/index.d.ts +1 -0
- package/libs/ui/widgets/src/index.d.ts.map +1 -1
- package/libs/ui/widgets/src/lib/popover/popover.component.d.ts +19 -0
- package/libs/ui/widgets/src/lib/popover/popover.component.d.ts.map +1 -0
- package/package.json +1 -1
- package/src/libs/api/metadata-converter/src/index.ts +0 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +5 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +37 -12
- package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +5 -1
- package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +4 -2
- package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +72 -2
- package/src/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.ts +39 -0
- package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +70 -1
- package/src/libs/api/metadata-converter/src/lib/xml-utils.ts +13 -5
- package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +24 -4
- 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 +2 -1
- package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +10 -0
- package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.css +0 -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/overview-upload/overview-upload.component.html +2 -1
- package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +110 -19
- 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 +76 -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 +271 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.html +1 -1
- 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 +59 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.html +5 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.ts +22 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.ts +8 -7
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +18 -1
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +30 -1
- package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +1 -1
- 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 +32 -2
- 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 +5 -1
- 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/utils/map-utils.service.ts +8 -4
- 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 +2 -1
- package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +52 -3
- package/src/libs/feature/search/src/lib/state/search.facade.ts +6 -0
- package/src/libs/ui/elements/src/index.ts +1 -0
- package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.css +0 -0
- package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.html +12 -0
- package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.ts +37 -0
- package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.html +4 -1
- package/src/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.css +2 -1
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +12 -8
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +14 -20
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.ts +0 -10
- package/src/libs/ui/elements/src/lib/metadata-quality-item/metadata-quality-item.component.html +1 -1
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +2 -2
- package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.html +3 -1
- package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.ts +8 -4
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +8 -2
- package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +15 -3
- 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 +91 -0
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +49 -49
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +15 -13
- 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 +2 -27
- 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/lib/form-field-wrapper/form-field-wrapper.component.html +1 -1
- package/src/libs/ui/layout/src/lib/interactive-table/interactive-table.component.html +1 -0
- package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html +10 -1
- package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.ts +55 -3
- package/src/libs/ui/search/src/lib/results-table/results-table.component.html +7 -2
- package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +9 -9
- package/src/libs/ui/widgets/src/index.ts +1 -0
- package/src/libs/ui/widgets/src/lib/popover/popover.component.css +0 -0
- package/src/libs/ui/widgets/src/lib/popover/popover.component.html +3 -0
- package/src/libs/ui/widgets/src/lib/popover/popover.component.ts +85 -0
- package/tailwind.base.css +18 -5
- package/translations/de.json +47 -17
- package/translations/en.json +40 -10
- package/translations/es.json +39 -9
- package/translations/fr.json +52 -22
- package/translations/it.json +40 -10
- package/translations/nl.json +39 -9
- package/translations/pt.json +39 -9
- package/translations/sk.json +40 -10
|
@@ -17,9 +17,9 @@ import {
|
|
|
17
17
|
import { MatIconModule } from '@angular/material/icon'
|
|
18
18
|
import { ButtonComponent } from '../../../../../../libs/ui/inputs/src'
|
|
19
19
|
|
|
20
|
-
type DynamicElement = {
|
|
21
|
-
component: Type<
|
|
22
|
-
inputs: Record<string,
|
|
20
|
+
export type DynamicElement = {
|
|
21
|
+
component: Type<unknown>
|
|
22
|
+
inputs: Record<string, unknown>
|
|
23
23
|
}
|
|
24
24
|
|
|
25
25
|
@Component({
|
|
@@ -40,7 +40,7 @@ type DynamicElement = {
|
|
|
40
40
|
})
|
|
41
41
|
export class SortableListComponent {
|
|
42
42
|
@Input() elements: Array<DynamicElement>
|
|
43
|
-
@Input() addOptions: Array<{ buttonLabel: string; eventName: string }>
|
|
43
|
+
@Input() addOptions: Array<{ buttonLabel: string; eventName: string }> = []
|
|
44
44
|
@Output() elementsChange = new EventEmitter<Array<DynamicElement>>()
|
|
45
45
|
@Output() add = new EventEmitter<string>()
|
|
46
46
|
|
|
@@ -53,4 +53,8 @@ export class SortableListComponent {
|
|
|
53
53
|
this.elements = this.elements.filter((_, i) => i !== index)
|
|
54
54
|
this.elementsChange.emit(this.elements)
|
|
55
55
|
}
|
|
56
|
+
|
|
57
|
+
trackByFn(index: number) {
|
|
58
|
+
return index
|
|
59
|
+
}
|
|
56
60
|
}
|
|
@@ -9,7 +9,7 @@ import { ContentGhostComponent } from './content-ghost/content-ghost.component'
|
|
|
9
9
|
import { DownloadItemComponent } from './download-item/download-item.component'
|
|
10
10
|
import { DownloadsListComponent } from './downloads-list/downloads-list.component'
|
|
11
11
|
import { ApiCardComponent } from './api-card/api-card.component'
|
|
12
|
-
import { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'
|
|
12
|
+
import { PopoverComponent, UiWidgetsModule } from '../../../../../libs/ui/widgets/src'
|
|
13
13
|
import { MaxLinesComponent, UiLayoutModule } from '../../../../../libs/ui/layout/src'
|
|
14
14
|
import { TranslateModule } from '@ngx-translate/core'
|
|
15
15
|
import { RelatedRecordCardComponent } from './related-record-card/related-record-card.component'
|
|
@@ -20,7 +20,11 @@ import { MetadataQualityItemComponent } from './metadata-quality-item/metadata-q
|
|
|
20
20
|
import { ErrorComponent } from './error/error.component'
|
|
21
21
|
import { PaginationComponent } from './pagination/pagination.component'
|
|
22
22
|
import { ThumbnailComponent } from './thumbnail/thumbnail.component'
|
|
23
|
-
import {
|
|
23
|
+
import {
|
|
24
|
+
BadgeComponent,
|
|
25
|
+
TextInputComponent,
|
|
26
|
+
UiInputsModule,
|
|
27
|
+
} from '../../../../../libs/ui/inputs/src'
|
|
24
28
|
import { FormsModule } from '@angular/forms'
|
|
25
29
|
import { AvatarComponent } from './avatar/avatar.component'
|
|
26
30
|
import { UserPreviewComponent } from './user-preview/user-preview.component'
|
|
@@ -45,11 +49,13 @@ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
|
|
|
45
49
|
UiInputsModule,
|
|
46
50
|
FormsModule,
|
|
47
51
|
NgOptimizedImage,
|
|
52
|
+
PopoverComponent,
|
|
48
53
|
MarkdownParserComponent,
|
|
49
54
|
ThumbnailComponent,
|
|
50
55
|
TimeSincePipe,
|
|
51
56
|
BadgeComponent,
|
|
52
57
|
MaxLinesComponent,
|
|
58
|
+
TextInputComponent,
|
|
53
59
|
],
|
|
54
60
|
declarations: [
|
|
55
61
|
MetadataInfoComponent,
|
|
@@ -61,6 +61,7 @@ export class AutocompleteComponent
|
|
|
61
61
|
@Input() action: (value: string) => Observable<AutocompleteItem[]>
|
|
62
62
|
@Input() value?: AutocompleteItem
|
|
63
63
|
@Input() clearOnSelection = false
|
|
64
|
+
@Input() preventCompleteOnSelection = false
|
|
64
65
|
@Input() autoFocus = false
|
|
65
66
|
@Input() minCharacterCount? = 3
|
|
66
67
|
@Input() allowSubmit = true
|
|
@@ -206,13 +207,24 @@ export class AutocompleteComponent
|
|
|
206
207
|
this.inputSubmitted.emit(this.inputRef.nativeElement.value)
|
|
207
208
|
}
|
|
208
209
|
|
|
210
|
+
/**
|
|
211
|
+
* This function is triggered when an item is selected in the list of displayed items.
|
|
212
|
+
* If preventCompleteOnSelection is true then the input will be left as entered by the user.
|
|
213
|
+
* If preventCompleteOnSelection is false (by default) then the input will be completed with the item selected by the user.
|
|
214
|
+
* If clearOnSelection is true then the input will be cleared upon selection.
|
|
215
|
+
* @param event
|
|
216
|
+
*/
|
|
209
217
|
handleSelection(event: MatAutocompleteSelectedEvent) {
|
|
210
218
|
this.cancelEnter = true
|
|
211
219
|
this.itemSelected.emit(event.option.value)
|
|
212
|
-
if (this.
|
|
213
|
-
this.lastInputValue$.pipe(first()).subscribe((
|
|
214
|
-
this.inputRef.nativeElement.value =
|
|
220
|
+
if (this.preventCompleteOnSelection) {
|
|
221
|
+
this.lastInputValue$.pipe(first()).subscribe((lastInputValue) => {
|
|
222
|
+
this.inputRef.nativeElement.value = lastInputValue
|
|
215
223
|
})
|
|
224
|
+
return
|
|
225
|
+
}
|
|
226
|
+
if (this.clearOnSelection) {
|
|
227
|
+
this.inputRef.nativeElement.value = ''
|
|
216
228
|
}
|
|
217
229
|
}
|
|
218
230
|
}
|
|
File without changes
|
|
@@ -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()"
|
|
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,91 @@
|
|
|
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() {
|
|
83
|
+
if (this.uploadProgress) {
|
|
84
|
+
this.handleCancel()
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
handleCancel() {
|
|
89
|
+
this.uploadCancel.emit()
|
|
90
|
+
}
|
|
91
|
+
}
|
|
@@ -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,46 +49,66 @@
|
|
|
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
|
"
|
|
@@ -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,6 +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 { UrlInputComponent } from '../url-input/url-input.component'
|
|
20
|
+
import { TextInputComponent } from '../text-input/text-input.component'
|
|
19
21
|
|
|
20
22
|
@Component({
|
|
21
23
|
selector: 'gn-ui-image-input',
|
|
@@ -30,6 +32,8 @@ import { marker } from '@biesbjerg/ngx-translate-extract-marker'
|
|
|
30
32
|
FilesDropDirective,
|
|
31
33
|
MatProgressSpinnerModule,
|
|
32
34
|
TranslateModule,
|
|
35
|
+
UrlInputComponent,
|
|
36
|
+
TextInputComponent,
|
|
33
37
|
],
|
|
34
38
|
})
|
|
35
39
|
export class ImageInputComponent {
|
|
@@ -49,10 +53,13 @@ export class ImageInputComponent {
|
|
|
49
53
|
downloadError = false
|
|
50
54
|
showAltTextInput = false
|
|
51
55
|
|
|
52
|
-
urlInputValue?: string
|
|
53
56
|
lastUploadType?: 'file' | 'url'
|
|
54
57
|
lastUploadContent?: string | File
|
|
55
58
|
|
|
59
|
+
get isUploadInProgress() {
|
|
60
|
+
return this.uploadProgress !== undefined
|
|
61
|
+
}
|
|
62
|
+
|
|
56
63
|
constructor(private http: HttpClient, private cd: ChangeDetectorRef) {}
|
|
57
64
|
|
|
58
65
|
getPrimaryText() {
|
|
@@ -104,24 +111,20 @@ export class ImageInputComponent {
|
|
|
104
111
|
this.showUrlInput = true
|
|
105
112
|
}
|
|
106
113
|
|
|
107
|
-
|
|
114
|
+
async downloadUrl(url: string) {
|
|
108
115
|
this.downloadError = false
|
|
109
|
-
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
async downloadUrl() {
|
|
113
|
-
const name = this.urlInputValue.split('/').pop()
|
|
116
|
+
const name = url.split('/').pop()
|
|
114
117
|
|
|
115
118
|
try {
|
|
116
119
|
const response = await firstValueFrom(
|
|
117
|
-
this.http.head(
|
|
120
|
+
this.http.head(url, { observe: 'response' })
|
|
118
121
|
)
|
|
119
122
|
if (
|
|
120
123
|
response.headers.get('content-type')?.startsWith('image/') &&
|
|
121
124
|
parseInt(response.headers.get('content-length')) <
|
|
122
125
|
megabytesToBytes(this.maxSizeMB)
|
|
123
126
|
) {
|
|
124
|
-
this.http.get(
|
|
127
|
+
this.http.get(url, { responseType: 'blob' }).subscribe({
|
|
125
128
|
next: (blob) => {
|
|
126
129
|
this.cd.markForCheck()
|
|
127
130
|
const file = new File([blob], name)
|
|
@@ -130,7 +133,7 @@ export class ImageInputComponent {
|
|
|
130
133
|
error: () => {
|
|
131
134
|
this.downloadError = true
|
|
132
135
|
this.cd.markForCheck()
|
|
133
|
-
this.urlChange.emit(
|
|
136
|
+
this.urlChange.emit(url)
|
|
134
137
|
},
|
|
135
138
|
})
|
|
136
139
|
}
|
|
@@ -172,9 +175,8 @@ export class ImageInputComponent {
|
|
|
172
175
|
this.showAltTextInput = !this.showAltTextInput
|
|
173
176
|
}
|
|
174
177
|
|
|
175
|
-
handleAltTextChange(
|
|
176
|
-
|
|
177
|
-
this.altTextChange.emit(input.value)
|
|
178
|
+
handleAltTextChange(altText: string) {
|
|
179
|
+
this.altTextChange.emit(altText)
|
|
178
180
|
}
|
|
179
181
|
|
|
180
182
|
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
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,17 +7,16 @@ 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 = ''
|
|
@@ -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
|
+
}
|