geonetwork-ui 2.4.0-dev.ac57b75b → 2.4.0-dev.c2a3cdd1

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.
Files changed (527) hide show
  1. package/esm2022/libs/api/metadata-converter/src/index.mjs +2 -1
  2. package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +10 -3
  3. package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.mjs +1 -1
  4. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.mjs +5 -5
  5. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.mjs +7 -4
  6. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.mjs +10 -7
  7. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +11 -16
  8. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +6 -6
  9. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +28 -33
  10. package/esm2022/libs/api/metadata-converter/src/lib/xml-utils.mjs +22 -4
  11. package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +78 -39
  12. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +11 -1
  13. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +51 -7
  14. package/esm2022/libs/common/domain/src/lib/model/record/contact.model.mjs +28 -1
  15. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
  16. package/esm2022/libs/common/domain/src/lib/model/user/user.model.mjs +1 -1
  17. package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
  18. package/esm2022/libs/common/domain/src/lib/repository/records-repository.interface.mjs +1 -1
  19. package/esm2022/libs/data-access/gn4/src/fixtures/site.fixtures.mjs +5 -5
  20. package/esm2022/libs/data-access/gn4/src/fixtures/ui.fixtures.mjs +3 -3
  21. package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +1 -1
  22. package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +1 -1
  23. package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +1 -1
  24. package/esm2022/libs/feature/editor/src/index.mjs +2 -1
  25. package/esm2022/libs/feature/editor/src/lib/+state/editor.actions.mjs +2 -1
  26. package/esm2022/libs/feature/editor/src/lib/+state/editor.effects.mjs +6 -1
  27. package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +4 -1
  28. package/esm2022/libs/feature/editor/src/lib/components/contact-card/contact-card.component.mjs +17 -0
  29. package/esm2022/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.mjs +80 -0
  30. package/esm2022/libs/feature/editor/src/lib/components/import-record/import-record.component.mjs +93 -0
  31. package/esm2022/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.mjs +71 -0
  32. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.mjs +145 -0
  33. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.mjs +19 -0
  34. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +31 -40
  35. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +11 -9
  36. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.mjs +101 -0
  37. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.mjs +148 -0
  38. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.mjs +44 -0
  39. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.mjs +93 -11
  40. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +12 -16
  41. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.mjs +9 -8
  42. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +140 -5
  43. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.mjs +41 -69
  44. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +17 -15
  45. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +46 -55
  46. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/index.mjs +2 -2
  47. package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +5 -4
  48. package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +8 -8
  49. package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +6 -4
  50. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +58 -7
  51. package/esm2022/libs/feature/editor/src/lib/models/editor-config.model.mjs +1 -1
  52. package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +5 -1
  53. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.mjs +6 -6
  54. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.mjs +7 -6
  55. package/esm2022/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.mjs +8 -5
  56. package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +6 -7
  57. package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +8 -7
  58. package/esm2022/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.mjs +7 -6
  59. package/esm2022/libs/feature/map/src/lib/feature-map.module.mjs +7 -26
  60. package/esm2022/libs/feature/map/src/lib/layers-panel/layers-panel.component.mjs +29 -13
  61. package/esm2022/libs/feature/map/src/lib/style/map-style.fixtures.mjs +3 -3
  62. package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +1 -1
  63. package/esm2022/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.mjs +1 -1
  64. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +1 -1
  65. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +4 -2
  66. package/esm2022/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.mjs +3 -3
  67. package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +10 -4
  68. package/esm2022/libs/ui/dataviz/src/lib/table/table.fixtures.mjs +3 -3
  69. package/esm2022/libs/ui/elements/src/index.mjs +2 -2
  70. package/esm2022/libs/ui/elements/src/lib/download-item/download-item.component.mjs +2 -2
  71. package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +1 -1
  72. package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +2 -2
  73. package/esm2022/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.mjs +6 -6
  74. package/esm2022/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.mjs +2 -2
  75. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +5 -5
  76. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +7 -4
  77. package/esm2022/libs/ui/inputs/src/index.mjs +6 -1
  78. package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +24 -7
  79. package/esm2022/libs/ui/inputs/src/lib/badge/badge.component.mjs +5 -3
  80. package/esm2022/libs/ui/inputs/src/lib/button/button.component.mjs +8 -1
  81. package/esm2022/libs/ui/inputs/src/lib/date-picker/date-picker.component.mjs +11 -4
  82. package/esm2022/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.mjs +9 -3
  83. package/esm2022/libs/ui/inputs/src/lib/editable-label/editable-label.directive.mjs +26 -24
  84. package/esm2022/libs/ui/inputs/src/lib/file-input/file-input.component.mjs +87 -0
  85. package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +21 -23
  86. package/esm2022/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.mjs +32 -0
  87. package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +7 -21
  88. package/esm2022/libs/ui/inputs/src/lib/text-input/text-input.component.mjs +6 -17
  89. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +3 -7
  90. package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +43 -0
  91. package/esm2022/libs/ui/layout/src/index.mjs +3 -1
  92. package/esm2022/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.mjs +5 -3
  93. package/esm2022/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.mjs +29 -0
  94. package/esm2022/libs/ui/layout/src/lib/sortable-list/sortable-list.component.mjs +43 -0
  95. package/esm2022/libs/ui/map/src/lib/ui-map.module.mjs +3 -3
  96. package/esm2022/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.mjs +7 -7
  97. package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +8 -8
  98. package/esm2022/libs/util/app-config/src/lib/fixtures.mjs +10 -10
  99. package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +1 -1
  100. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +1 -1
  101. package/esm2022/libs/util/shared/src/lib/services/theme.service.mjs +2 -1
  102. package/esm2022/libs/util/shared/src/lib/utils/bytes-convert.mjs +4 -1
  103. package/esm2022/translations/de.json +66 -2
  104. package/esm2022/translations/en.json +66 -2
  105. package/esm2022/translations/es.json +64 -0
  106. package/esm2022/translations/fr.json +69 -5
  107. package/esm2022/translations/it.json +66 -2
  108. package/esm2022/translations/nl.json +64 -0
  109. package/esm2022/translations/pt.json +64 -0
  110. package/fesm2022/geonetwork-ui.mjs +3093 -1619
  111. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  112. package/libs/api/metadata-converter/src/index.d.ts +1 -0
  113. package/libs/api/metadata-converter/src/index.d.ts.map +1 -1
  114. package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts +3 -3
  115. package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
  116. package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts +2 -6
  117. package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts.map +1 -1
  118. package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts +2 -2
  119. package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts.map +1 -1
  120. package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts +1 -1
  121. package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts.map +1 -1
  122. package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts.map +1 -1
  123. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +4 -5
  124. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
  125. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +7 -7
  126. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  127. package/libs/api/metadata-converter/src/lib/xml-utils.d.ts +6 -0
  128. package/libs/api/metadata-converter/src/lib/xml-utils.d.ts.map +1 -1
  129. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +12 -7
  130. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
  131. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts.map +1 -1
  132. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +22 -2
  133. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  134. package/libs/common/domain/src/lib/model/record/contact.model.d.ts +1 -0
  135. package/libs/common/domain/src/lib/model/record/contact.model.d.ts.map +1 -1
  136. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +7 -6
  137. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  138. package/libs/common/domain/src/lib/model/user/user.model.d.ts +1 -1
  139. package/libs/common/domain/src/lib/model/user/user.model.d.ts.map +1 -1
  140. package/libs/common/domain/src/lib/platform.service.interface.d.ts +16 -0
  141. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  142. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +7 -0
  143. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts.map +1 -1
  144. package/libs/data-access/gn4/src/fixtures/site.fixtures.d.ts +2 -2
  145. package/libs/data-access/gn4/src/fixtures/site.fixtures.d.ts.map +1 -1
  146. package/libs/data-access/gn4/src/fixtures/ui.fixtures.d.ts +1 -1
  147. package/libs/data-access/gn4/src/fixtures/ui.fixtures.d.ts.map +1 -1
  148. package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts +2 -2
  149. package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
  150. package/libs/feature/dataviz/src/lib/service/data.service.d.ts +6 -6
  151. package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
  152. package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts +3 -3
  153. package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts.map +1 -1
  154. package/libs/feature/editor/src/index.d.ts +1 -0
  155. package/libs/feature/editor/src/index.d.ts.map +1 -1
  156. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts +1 -0
  157. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts.map +1 -1
  158. package/libs/feature/editor/src/lib/+state/editor.effects.d.ts +5 -0
  159. package/libs/feature/editor/src/lib/+state/editor.effects.d.ts.map +1 -1
  160. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +1 -0
  161. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
  162. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts +8 -0
  163. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts.map +1 -0
  164. package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts +33 -0
  165. package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts.map +1 -0
  166. package/libs/feature/editor/src/lib/components/import-record/import-record.component.d.ts +33 -0
  167. package/libs/feature/editor/src/lib/components/import-record/import-record.component.d.ts.map +1 -0
  168. package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts +15 -0
  169. package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts.map +1 -0
  170. 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
  171. 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
  172. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.d.ts +9 -0
  173. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.d.ts.map +1 -0
  174. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts +11 -19
  175. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts.map +1 -1
  176. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts +6 -4
  177. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts.map +1 -1
  178. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.d.ts +22 -0
  179. 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
  180. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.d.ts +35 -0
  181. 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
  182. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.d.ts +15 -0
  183. 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
  184. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts +24 -4
  185. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts.map +1 -1
  186. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts +4 -6
  187. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -1
  188. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts +4 -3
  189. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts.map +1 -1
  190. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts +28 -0
  191. 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
  192. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts +10 -18
  193. 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
  194. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +5 -5
  195. 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
  196. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +18 -24
  197. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  198. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts +1 -1
  199. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts.map +1 -1
  200. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts +5 -3
  201. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -1
  202. package/libs/feature/editor/src/lib/feature-editor.module.d.ts +2 -1
  203. package/libs/feature/editor/src/lib/feature-editor.module.d.ts.map +1 -1
  204. package/libs/feature/editor/src/lib/fields.config.d.ts +15 -0
  205. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  206. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts +6 -0
  207. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts.map +1 -1
  208. package/libs/feature/editor/src/lib/services/editor.service.d.ts +1 -0
  209. package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
  210. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts +1 -1
  211. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts.map +1 -1
  212. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts +6 -6
  213. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts.map +1 -1
  214. package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts +1 -1
  215. package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts.map +1 -1
  216. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts +1 -1
  217. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts.map +1 -1
  218. package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts +1 -1
  219. package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts.map +1 -1
  220. package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts +1 -1
  221. package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts.map +1 -1
  222. package/libs/feature/map/src/lib/feature-map.module.d.ts +16 -21
  223. package/libs/feature/map/src/lib/feature-map.module.d.ts.map +1 -1
  224. package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts +1 -1
  225. package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts.map +1 -1
  226. package/libs/feature/map/src/lib/style/map-style.fixtures.d.ts +2 -2
  227. package/libs/feature/map/src/lib/style/map-style.fixtures.d.ts.map +1 -1
  228. package/libs/feature/record/src/lib/data-view/data-view.component.d.ts +3 -3
  229. package/libs/feature/record/src/lib/data-view/data-view.component.d.ts.map +1 -1
  230. package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts +2 -2
  231. package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts.map +1 -1
  232. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +2 -2
  233. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
  234. package/libs/feature/record/src/lib/state/mdview.facade.d.ts +7 -7
  235. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  236. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +1 -0
  237. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -1
  238. package/libs/ui/dataviz/src/lib/table/table.fixtures.d.ts +2 -2
  239. package/libs/ui/dataviz/src/lib/table/table.fixtures.d.ts.map +1 -1
  240. package/libs/ui/elements/src/index.d.ts +1 -1
  241. package/libs/ui/elements/src/index.d.ts.map +1 -1
  242. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts +2 -2
  243. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts.map +1 -1
  244. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +7 -7
  245. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts.map +1 -1
  246. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +2 -2
  247. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
  248. package/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.d.ts +2 -2
  249. package/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.d.ts.map +1 -1
  250. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +1 -1
  251. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -1
  252. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  253. package/libs/ui/inputs/src/index.d.ts +5 -0
  254. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  255. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts +9 -1
  256. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
  257. package/libs/ui/inputs/src/lib/badge/badge.component.d.ts.map +1 -1
  258. package/libs/ui/inputs/src/lib/button/button.component.d.ts +1 -1
  259. package/libs/ui/inputs/src/lib/button/button.component.d.ts.map +1 -1
  260. package/libs/ui/inputs/src/lib/date-picker/date-picker.component.d.ts.map +1 -1
  261. package/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.d.ts.map +1 -1
  262. package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts +5 -3
  263. package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts.map +1 -1
  264. package/libs/ui/inputs/src/lib/file-input/file-input.component.d.ts +24 -0
  265. package/libs/ui/inputs/src/lib/file-input/file-input.component.d.ts.map +1 -0
  266. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +6 -9
  267. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -1
  268. package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts +16 -0
  269. package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts.map +1 -0
  270. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +0 -4
  271. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
  272. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts +2 -4
  273. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts.map +1 -1
  274. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +34 -35
  275. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
  276. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts +18 -0
  277. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts.map +1 -0
  278. package/libs/ui/layout/src/index.d.ts +2 -0
  279. package/libs/ui/layout/src/index.d.ts.map +1 -1
  280. package/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.d.ts +2 -2
  281. package/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.d.ts.map +1 -1
  282. package/libs/ui/layout/src/lib/interactive-table/interactive-table-column/interactive-table-column.component.d.ts +1 -1
  283. package/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.d.ts +20 -0
  284. package/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.d.ts.map +1 -0
  285. package/libs/ui/layout/src/lib/sortable-list/sortable-list.component.d.ts +14 -0
  286. package/libs/ui/layout/src/lib/sortable-list/sortable-list.component.d.ts.map +1 -0
  287. package/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.d.ts +3 -3
  288. package/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.d.ts.map +1 -1
  289. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +3 -3
  290. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
  291. package/libs/util/app-config/src/lib/fixtures.d.ts +8 -8
  292. package/libs/util/app-config/src/lib/fixtures.d.ts.map +1 -1
  293. package/libs/util/shared/src/lib/links/link-classifier.service.d.ts +3 -3
  294. package/libs/util/shared/src/lib/links/link-classifier.service.d.ts.map +1 -1
  295. package/libs/util/shared/src/lib/links/link-utils.d.ts +6 -6
  296. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  297. package/libs/util/shared/src/lib/services/theme.service.d.ts.map +1 -1
  298. package/libs/util/shared/src/lib/utils/bytes-convert.d.ts +2 -1
  299. package/libs/util/shared/src/lib/utils/bytes-convert.d.ts.map +1 -1
  300. package/package.json +1 -1
  301. package/src/libs/api/metadata-converter/src/index.ts +1 -0
  302. package/src/libs/api/metadata-converter/src/lib/fixtures/generic.records.ts +7 -2
  303. package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +1 -1
  304. package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +1 -1
  305. package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +1 -1
  306. package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +18 -16
  307. package/src/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.ts +2 -6
  308. package/src/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.ts +4 -4
  309. package/src/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.ts +12 -4
  310. package/src/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.ts +14 -8
  311. package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +8 -15
  312. package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +13 -15
  313. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +48 -63
  314. package/src/libs/api/metadata-converter/src/lib/xml-utils.ts +25 -6
  315. package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +132 -68
  316. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +12 -1
  317. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +90 -15
  318. package/src/libs/common/domain/src/lib/model/record/contact.model.ts +28 -0
  319. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +8 -7
  320. package/src/libs/common/domain/src/lib/model/user/user.model.ts +1 -1
  321. package/src/libs/common/domain/src/lib/platform.service.interface.ts +30 -0
  322. package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +10 -0
  323. package/src/libs/common/fixtures/src/index.ts +1 -1
  324. package/src/libs/common/fixtures/src/lib/editor/editor.fixtures.ts +37 -37
  325. package/src/libs/common/fixtures/src/lib/elasticsearch/{aggregations-request.ts → aggregations-request.fixtures.ts} +1 -3
  326. package/src/libs/common/fixtures/src/lib/elasticsearch/{aggregations-response.ts → aggregations-response.fixtures.ts} +6 -8
  327. package/src/libs/common/fixtures/src/lib/elasticsearch/{full-response.ts → full-response.fixtures.ts} +1 -3
  328. package/src/libs/common/fixtures/src/lib/elasticsearch/index.ts +5 -5
  329. package/src/libs/common/fixtures/src/lib/elasticsearch/metadata-links.fixtures.ts +1 -3
  330. package/src/libs/common/fixtures/src/lib/elasticsearch/metadata.fixtures.ts +1739 -1742
  331. package/src/libs/common/fixtures/src/lib/elasticsearch/{search-requests.ts → search-requests.fixtures.ts} +1 -3
  332. package/src/libs/common/fixtures/src/lib/elasticsearch/{search-responses.ts → search-responses.fixtures.ts} +4 -6
  333. package/src/libs/common/fixtures/src/lib/geojson.fixtures.ts +57178 -57195
  334. package/src/libs/common/fixtures/src/lib/gn4/groups.fixtures.ts +2 -4
  335. package/src/libs/common/fixtures/src/lib/link.fixtures.ts +233 -164
  336. package/src/libs/common/fixtures/src/lib/ol-feature.fixtures.ts +10 -0
  337. package/src/libs/common/fixtures/src/lib/organisations.fixture.ts +37 -3
  338. package/src/libs/common/fixtures/src/lib/record-link.fixtures.ts +9 -7
  339. package/src/libs/common/fixtures/src/lib/records.fixtures.ts +9 -9
  340. package/src/libs/common/fixtures/src/lib/repository.fixtures.ts +4 -4
  341. package/src/libs/common/fixtures/src/lib/search/aggregations.ts +2 -3
  342. package/src/libs/common/fixtures/src/lib/user-feedbacks.fixtures.ts +14 -15
  343. package/src/libs/common/fixtures/src/lib/user.fixtures.ts +32 -15
  344. package/src/libs/data-access/gn4/src/fixtures/site.fixtures.ts +4 -4
  345. package/src/libs/data-access/gn4/src/fixtures/ui.fixtures.ts +2 -2
  346. package/src/libs/feature/catalog/src/lib/sources/sources.fixture.ts +1 -1
  347. package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +3 -3
  348. package/src/libs/feature/dataviz/src/lib/figure/figure.fixtures.ts +2 -2
  349. package/src/libs/feature/dataviz/src/lib/service/data.service.ts +6 -6
  350. package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.ts +4 -4
  351. package/src/libs/feature/editor/src/index.ts +1 -0
  352. package/src/libs/feature/editor/src/lib/+state/editor.actions.ts +2 -0
  353. package/src/libs/feature/editor/src/lib/+state/editor.effects.ts +15 -0
  354. package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +4 -0
  355. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.html +15 -0
  356. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.ts +18 -0
  357. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.html +26 -0
  358. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.ts +90 -0
  359. package/src/libs/feature/editor/src/lib/components/import-record/import-record.component.html +43 -0
  360. package/src/libs/feature/editor/src/lib/components/import-record/import-record.component.ts +129 -0
  361. package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.html +35 -0
  362. package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.ts +79 -0
  363. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.css +4 -0
  364. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.html +66 -0
  365. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.ts +211 -0
  366. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.css +0 -0
  367. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.html +4 -0
  368. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.ts +21 -0
  369. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.html +7 -16
  370. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.ts +44 -45
  371. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.css +8 -0
  372. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.ts +13 -5
  373. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.css +0 -0
  374. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.html +4 -0
  375. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.ts +128 -0
  376. 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
  377. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.html +34 -0
  378. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.ts +182 -0
  379. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.css +0 -0
  380. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.html +6 -0
  381. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.ts +48 -0
  382. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.html +11 -5
  383. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.ts +107 -7
  384. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.html +15 -8
  385. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +11 -14
  386. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.html +5 -3
  387. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.ts +11 -4
  388. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +20 -1
  389. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.ts +212 -1
  390. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.css +4 -0
  391. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.html +31 -4
  392. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.ts +43 -87
  393. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.css +4 -0
  394. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.html +16 -14
  395. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +17 -15
  396. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +110 -74
  397. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +50 -55
  398. package/src/libs/feature/editor/src/lib/components/record-form/form-field/index.ts +1 -1
  399. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +32 -29
  400. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.ts +9 -4
  401. package/src/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.html +1 -1
  402. package/src/libs/feature/editor/src/lib/feature-editor.module.ts +2 -1
  403. package/src/libs/feature/editor/src/lib/fields.config.ts +64 -6
  404. package/src/libs/feature/editor/src/lib/models/editor-config.model.ts +12 -0
  405. package/src/libs/feature/editor/src/lib/services/editor.service.ts +7 -0
  406. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.ts +3 -0
  407. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.ts +12 -8
  408. package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.ts +5 -0
  409. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.html +1 -1
  410. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.ts +10 -7
  411. package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.html +1 -1
  412. package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.ts +5 -0
  413. package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.html +1 -1
  414. package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.ts +6 -1
  415. package/src/libs/feature/map/src/lib/feature-map.module.ts +2 -15
  416. package/src/libs/feature/map/src/lib/layers-panel/layers-panel.component.ts +24 -1
  417. package/src/libs/feature/map/src/lib/map-context/map-context.fixtures.ts +26 -22
  418. package/src/libs/feature/map/src/lib/style/map-style.fixtures.ts +29 -27
  419. package/src/libs/feature/record/src/lib/data-view/data-view.component.ts +3 -3
  420. package/src/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.ts +2 -2
  421. package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +2 -2
  422. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +5 -1
  423. package/src/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.html +2 -1
  424. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.html +1 -0
  425. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +22 -1
  426. package/src/libs/feature/search/src/lib/state/fixtures/search-state.fixtures.ts +2 -2
  427. package/src/libs/ui/dataviz/src/lib/chart/chart.fixtures.ts +2 -2
  428. package/src/libs/ui/dataviz/src/lib/table/table.fixtures.ts +2 -2
  429. package/src/libs/ui/elements/src/index.ts +1 -1
  430. package/src/libs/ui/elements/src/lib/download-item/download-item.component.ts +4 -4
  431. package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +7 -7
  432. package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +3 -3
  433. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.html +13 -20
  434. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.ts +1 -1
  435. package/src/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.css +5 -0
  436. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +2 -2
  437. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +6 -1
  438. package/src/libs/ui/inputs/src/index.ts +5 -0
  439. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.css +25 -18
  440. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.html +38 -24
  441. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +19 -4
  442. package/src/libs/ui/inputs/src/lib/badge/badge.component.html +12 -3
  443. package/src/libs/ui/inputs/src/lib/badge/badge.component.ts +2 -1
  444. package/src/libs/ui/inputs/src/lib/button/button.component.ts +15 -1
  445. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.css +7 -2
  446. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.html +14 -6
  447. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.ts +7 -1
  448. package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.css +7 -2
  449. package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.html +28 -23
  450. package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.ts +7 -1
  451. package/src/libs/ui/inputs/src/lib/editable-label/editable-label.directive.ts +40 -26
  452. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.css +4 -0
  453. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.html +89 -0
  454. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.ts +92 -0
  455. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.css +4 -0
  456. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +76 -68
  457. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +19 -21
  458. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.css +4 -3
  459. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.html +0 -1
  460. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.ts +1 -2
  461. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +3 -2
  462. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +3 -28
  463. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.html +4 -3
  464. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +4 -16
  465. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +0 -3
  466. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.css +9 -0
  467. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.html +37 -0
  468. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.ts +33 -0
  469. package/src/libs/ui/layout/src/index.ts +2 -0
  470. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.html +8 -3
  471. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.ts +4 -3
  472. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.css +0 -0
  473. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.html +15 -0
  474. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.ts +44 -0
  475. package/src/libs/ui/layout/src/lib/sortable-list/sortable-list.component.html +37 -0
  476. package/src/libs/ui/{elements → layout}/src/lib/sortable-list/sortable-list.component.ts +11 -18
  477. package/src/libs/ui/map/src/lib/ui-map.module.ts +1 -1
  478. package/src/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.ts +7 -6
  479. package/src/libs/ui/search/src/lib/results-table/results-table.component.html +9 -2
  480. package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +5 -6
  481. package/src/libs/util/app-config/src/lib/fixtures.ts +9 -9
  482. package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +4 -3
  483. package/src/libs/util/shared/src/lib/links/link-utils.ts +6 -6
  484. package/src/libs/util/shared/src/lib/services/theme.service.ts +1 -0
  485. package/src/libs/util/shared/src/lib/utils/bytes-convert.ts +4 -1
  486. package/tailwind.base.config.js +1 -0
  487. package/tailwind.base.css +49 -6
  488. package/translations/de.json +66 -2
  489. package/translations/en.json +66 -2
  490. package/translations/es.json +64 -0
  491. package/translations/fr.json +69 -5
  492. package/translations/it.json +66 -2
  493. package/translations/nl.json +64 -0
  494. package/translations/pt.json +64 -0
  495. package/translations/sk.json +64 -0
  496. package/esm2022/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.mjs +0 -138
  497. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.mjs +0 -15
  498. 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
  499. 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
  500. package/esm2022/libs/ui/elements/src/lib/sortable-list/sortable-list.component.mjs +0 -46
  501. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts +0 -27
  502. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts.map +0 -1
  503. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts +0 -8
  504. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts.map +0 -1
  505. 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
  506. 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
  507. 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
  508. 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
  509. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts +0 -23
  510. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts.map +0 -1
  511. package/src/libs/common/fixtures/src/lib/ol-feature.fixture.ts +0 -7
  512. package/src/libs/common/fixtures/src/lib/utils/freeze.ts +0 -10
  513. package/src/libs/common/fixtures/src/lib/utils/index.ts +0 -1
  514. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +0 -10
  515. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +0 -166
  516. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.html +0 -4
  517. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.ts +0 -15
  518. 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
  519. 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
  520. 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
  521. 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
  522. package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.html +0 -38
  523. /package/src/libs/feature/editor/src/lib/components/{overview-upload/overview-upload.component.css → contact-card/contact-card.component.css} +0 -0
  524. /package/src/libs/feature/editor/src/lib/components/{record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.css → generic-keywords/generic-keywords.component.css} +0 -0
  525. /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 → import-record/import-record.component.css} +0 -0
  526. /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
  527. /package/src/libs/ui/{elements → layout}/src/lib/sortable-list/sortable-list.component.css +0 -0
@@ -8,6 +8,7 @@ import {
8
8
  import { MatNativeDateModule } from '@angular/material/core'
9
9
  import { MatDatepickerModule } from '@angular/material/datepicker'
10
10
  import { MatIconModule } from '@angular/material/icon'
11
+ import { ButtonComponent } from '../button/button.component'
11
12
 
12
13
  @Component({
13
14
  selector: 'gn-ui-date-range-picker',
@@ -15,7 +16,12 @@ import { MatIconModule } from '@angular/material/icon'
15
16
  styleUrls: ['./date-range-picker.component.css'],
16
17
  changeDetection: ChangeDetectionStrategy.OnPush,
17
18
  standalone: true,
18
- imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
19
+ imports: [
20
+ MatIconModule,
21
+ MatNativeDateModule,
22
+ MatDatepickerModule,
23
+ ButtonComponent,
24
+ ],
19
25
  })
20
26
  export class DateRangePickerComponent {
21
27
  @Input() startDate: Date
@@ -1,48 +1,62 @@
1
1
  import {
2
+ AfterViewInit,
2
3
  Directive,
3
4
  ElementRef,
4
- Renderer2,
5
- AfterViewInit,
6
5
  EventEmitter,
7
- Output,
8
6
  Input,
7
+ OnChanges,
8
+ Output,
9
+ Renderer2,
9
10
  } from '@angular/core'
10
11
 
11
12
  @Directive({
12
13
  selector: '[gnUiEditableLabel]',
13
14
  standalone: true,
14
15
  })
15
- export class EditableLabelDirective implements AfterViewInit {
16
+ export class EditableLabelDirective implements OnChanges, AfterViewInit {
17
+ @Input() gnUiEditableLabel?: string
16
18
  @Output() editableLabelChanged = new EventEmitter<string>()
17
- @Input() gnUiEditableLabel?: boolean
19
+
20
+ appendedInput: HTMLInputElement
18
21
 
19
22
  constructor(private el: ElementRef, private renderer: Renderer2) {}
20
23
 
24
+ ngOnChanges() {
25
+ if (this.appendedInput) {
26
+ this.renderer.setProperty(
27
+ this.appendedInput,
28
+ 'value',
29
+ this.gnUiEditableLabel
30
+ )
31
+ }
32
+ }
33
+
21
34
  ngAfterViewInit() {
22
- if (this.gnUiEditableLabel !== false) {
23
- const appendedInput = this.renderer.createElement('input')
24
-
25
- this.renderer.setStyle(appendedInput, 'background', 'inherit')
26
- this.renderer.setStyle(appendedInput, 'color', 'inherit')
27
- this.renderer.setStyle(appendedInput, 'font', 'inherit')
28
- this.renderer.setStyle(appendedInput, 'border', 'inherit')
29
- this.renderer.setStyle(appendedInput, 'width', '100%')
30
- this.renderer.setStyle(appendedInput, 'padding', 'inherit')
31
- this.renderer.setStyle(appendedInput, 'margin', '0')
32
- this.renderer.setStyle(appendedInput, 'height', 'inherit')
33
- this.renderer.setStyle(appendedInput, 'line-height', 'inherit')
34
- this.renderer.setStyle(appendedInput, 'text-decoration', 'inherit')
35
-
36
- const hostContent = this.el.nativeElement.textContent || ''
37
- const formattedContent = hostContent.replace(/\s+/g, ' ').trim()
38
- this.renderer.setProperty(appendedInput, 'value', formattedContent)
39
- this.renderer.setProperty(this.el.nativeElement, 'innerHTML', '')
40
-
41
- this.renderer.listen(appendedInput, 'input', (event) => {
35
+ if (this.gnUiEditableLabel !== undefined) {
36
+ this.appendedInput = this.renderer.createElement('input')
37
+
38
+ this.renderer.setStyle(this.appendedInput, 'background', 'inherit')
39
+ this.renderer.setStyle(this.appendedInput, 'color', 'inherit')
40
+ this.renderer.setStyle(this.appendedInput, 'font', 'inherit')
41
+ this.renderer.setStyle(this.appendedInput, 'border', 'inherit')
42
+ this.renderer.setStyle(this.appendedInput, 'width', '100%')
43
+ this.renderer.setStyle(this.appendedInput, 'padding', 'inherit')
44
+ this.renderer.setStyle(this.appendedInput, 'margin', '0')
45
+ this.renderer.setStyle(this.appendedInput, 'height', 'inherit')
46
+ this.renderer.setStyle(this.appendedInput, 'line-height', 'inherit')
47
+ this.renderer.setStyle(this.appendedInput, 'text-decoration', 'inherit')
48
+
49
+ this.renderer.setProperty(
50
+ this.appendedInput,
51
+ 'value',
52
+ this.gnUiEditableLabel
53
+ )
54
+
55
+ this.renderer.listen(this.appendedInput, 'input', (event) => {
42
56
  this.editableLabelChanged.emit(event.target.value)
43
57
  })
44
58
 
45
- this.renderer.appendChild(this.el.nativeElement, appendedInput)
59
+ this.renderer.appendChild(this.el.nativeElement, this.appendedInput)
46
60
  }
47
61
  }
48
62
  }
@@ -0,0 +1,4 @@
1
+ :host {
2
+ --gn-ui-button-padding: 8px 8px;
3
+ --gn-ui-button-rounded: 8px;
4
+ }
@@ -0,0 +1,89 @@
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
+ 'cursor-pointer hover:border-gray-500': !isUploadInProgress
9
+ }"
10
+ [attr.tabindex]="isUploadInProgress ? null : 0"
11
+ (dragFilesOver)="handleDragFilesOver($event)"
12
+ (dropFiles)="handleDropFiles($event)"
13
+ (keydown.enter)="fileInput.click()"
14
+ >
15
+ <div
16
+ class="w-14 h-14 rounded-md bg-gray-50 grid"
17
+ *ngIf="!isUploadInProgress"
18
+ >
19
+ <mat-icon
20
+ *ngIf="!dragFilesOver"
21
+ class="material-symbols-outlined place-self-center text-primary"
22
+ >cloud_upload</mat-icon
23
+ >
24
+ <mat-icon
25
+ *ngIf="dragFilesOver"
26
+ class="material-symbols-outlined place-self-center text-primary"
27
+ >add_box</mat-icon
28
+ >
29
+ </div>
30
+ <div
31
+ *ngIf="isUploadInProgress"
32
+ class="w-14 h-14 grid items-center justify-center relative"
33
+ >
34
+ <div class="text-gray-100 absolute">
35
+ <mat-progress-spinner
36
+ class="place-self-center"
37
+ [diameter]="56"
38
+ mode="determinate"
39
+ [value]="100"
40
+ ></mat-progress-spinner>
41
+ </div>
42
+ <div class="text-primary absolute">
43
+ <mat-progress-spinner
44
+ class="place-self-center"
45
+ [diameter]="56"
46
+ mode="determinate"
47
+ [value]="uploadProgress"
48
+ ></mat-progress-spinner>
49
+ </div>
50
+ <span class="text-sm text-main font-bold">{{ uploadProgress }}%</span>
51
+ </div>
52
+ <div class="flex flex-col items-center gap-1">
53
+ <p class="font-medium">
54
+ {{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}
55
+ </p>
56
+ <p
57
+ class="text-sm"
58
+ [class]="
59
+ isUploadInProgress
60
+ ? 'font-bold text-primary cursor-pointer'
61
+ : 'font-medium text-gray-500'
62
+ "
63
+ (click)="handleSecondaryTextClick($event)"
64
+ >
65
+ {{ getSecondaryText() | translate }}
66
+ </p>
67
+ </div>
68
+ <p class="w-full flex flex-row items-center justify-stretch gap-[16px]">
69
+ <span class="border-b border-gray-300 grow"></span>
70
+ <span class="text-sm font-medium text-gray-500 or-input-url" translate>
71
+ input.file.orInputUrl</span
72
+ >
73
+ <span class="border-b border-gray-300 grow"></span>
74
+ </p>
75
+ <input
76
+ #fileInput
77
+ type="file"
78
+ class="hidden"
79
+ (change)="handleFileInput($event)"
80
+ [disabled]="isUploadInProgress"
81
+ />
82
+
83
+ <gn-ui-url-input
84
+ class="w-full"
85
+ [disabled]="isUploadInProgress"
86
+ (valueChange)="handleUrlChange($event)"
87
+ ></gn-ui-url-input>
88
+ </label>
89
+ </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
+ }
@@ -0,0 +1,4 @@
1
+ :host {
2
+ --gn-ui-button-padding: 8px 8px;
3
+ --gn-ui-button-rounded: 8px;
4
+ }
@@ -5,42 +5,42 @@
5
5
  <div class="w-full h-full flex flex-col gap-2">
6
6
  <div class="flex-1 group relative">
7
7
  <img
8
- class="w-full h-full object-cover border-2 border-gray-300 rounded-lg"
8
+ class="w-full object-cover border-2 border-gray-300 rounded-lg h-[172px]"
9
9
  [alt]="altText"
10
10
  loading="lazy"
11
11
  [src]="previewUrl"
12
12
  />
13
13
  <gn-ui-button
14
- [extraClass]="
15
- 'bg-gray-200 absolute right-2 bottom-2 invisible group-hover:visible'
16
- "
14
+ type="outline"
15
+ style="--gn-ui-button-height: 40px; --gn-ui-button-width: 40px"
16
+ extraClass="absolute right-2 bottom-2 invisible group-hover:visible bg-background"
17
17
  (buttonClick)="handleDelete()"
18
18
  >
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
- (change)="handleAltTextChange($event)"
29
- />
30
- <div class="flex flex-row gap-2">
31
- <gn-ui-button
32
- [extraClass]="'bg-gray-200 font-bold'"
33
- (buttonClick)="handleDelete()"
34
- >
35
- <mat-icon class="material-symbols-outlined me-1">delete</mat-icon>
25
+ [value]="altText ?? ''"
26
+ (valueChange)="handleAltTextChange($event)"
27
+ extraClass="gn-ui-editor-textarea"
28
+ ></gn-ui-text-input>
29
+ <div class="flex flex-row gap-2 mt-2">
30
+ <gn-ui-button type="gray" (buttonClick)="handleDelete()">
31
+ <mat-icon class="material-symbols-outlined me-1 text-primary"
32
+ >delete</mat-icon
33
+ >
36
34
  {{ 'input.image.delete' | translate }}
37
35
  </gn-ui-button>
38
36
  <gn-ui-button
39
37
  *ngIf="!showAltTextInput"
40
- [extraClass]="'bg-gray-200 font-bold'"
38
+ type="gray"
41
39
  (buttonClick)="toggleAltTextInput()"
42
40
  >
43
- <mat-icon class="material-symbols-outlined me-1">add</mat-icon>
41
+ <mat-icon class="material-symbols-outlined me-1 text-primary"
42
+ >add</mat-icon
43
+ >
44
44
  {{ 'input.image.displayAltTextInput' | translate }}
45
45
  </gn-ui-button>
46
46
  </div>
@@ -51,96 +51,104 @@
51
51
  <div class="w-full h-full flex flex-col gap-2">
52
52
  <label
53
53
  gnUiFilesDrop
54
- class="block flex-1 border-2 border-dashed border-gray-300 rounded-lg p-6 flex flex-col items-center justify-center gap-4 hover:cursor-pointer"
54
+ class="flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100"
55
+ [ngClass]="{
56
+ 'border-primary-lighter bg-primary-white': dragFilesOver,
57
+ 'border-gray-300': !dragFilesOver,
58
+ 'cursor-pointer hover:border-gray-500':
59
+ !isUploadInProgress && !uploadError && !showUrlInput
60
+ }"
61
+ [attr.tabindex]="
62
+ isUploadInProgress || uploadError || showUrlInput ? null : 0
63
+ "
64
+ (keydown.enter)="fileInput.click()"
55
65
  (dragFilesOver)="handleDragFilesOver($event)"
56
66
  (dropFiles)="handleDropFiles($event)"
57
67
  >
58
- <div class="w-14 h-14 rounded-md bg-gray-200 grid">
68
+ <div
69
+ class="w-14 h-14 rounded-md bg-gray-50 grid"
70
+ *ngIf="!isUploadInProgress && !uploadError"
71
+ >
59
72
  <mat-icon
60
- *ngIf="!dragFilesOver && !uploadProgress && !uploadError"
61
- class="material-symbols-outlined place-self-center text-blue-500"
73
+ *ngIf="!dragFilesOver"
74
+ class="material-symbols-outlined place-self-center text-primary"
62
75
  >image</mat-icon
63
76
  >
64
77
  <mat-icon
65
- *ngIf="dragFilesOver && !uploadProgress && !uploadError"
66
- class="material-symbols-outlined place-self-center text-blue-500"
78
+ *ngIf="dragFilesOver"
79
+ class="material-symbols-outlined place-self-center text-primary"
67
80
  >add_box</mat-icon
68
81
  >
69
- <div *ngIf="uploadProgress">
82
+ </div>
83
+
84
+ <div
85
+ *ngIf="isUploadInProgress && !uploadError"
86
+ class="w-14 h-14 grid items-center justify-center relative"
87
+ >
88
+ <div class="text-gray-100 absolute">
89
+ <mat-progress-spinner
90
+ class="place-self-center"
91
+ [diameter]="56"
92
+ mode="determinate"
93
+ [value]="100"
94
+ ></mat-progress-spinner>
95
+ </div>
96
+ <div class="text-primary absolute">
70
97
  <mat-progress-spinner
71
98
  class="place-self-center"
72
99
  [diameter]="56"
73
- [mode]="'determinate'"
100
+ mode="determinate"
74
101
  [value]="uploadProgress"
75
102
  ></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
103
  </div>
104
+ <span class="text-sm text-main font-bold">{{ uploadProgress }}%</span>
105
+ </div>
106
+
107
+ <div class="w-14 h-14 rounded-md bg-gray-50 grid" *ngIf="uploadError">
82
108
  <mat-icon
83
- *ngIf="uploadError"
84
109
  class="material-symbols-outlined place-self-center text-rose-500"
85
110
  >broken_image</mat-icon
86
111
  >
87
112
  </div>
113
+
88
114
  <div class="flex flex-col items-center gap-1">
89
115
  <p class="font-medium">{{ getPrimaryText() | translate }}</p>
90
116
  <p
91
117
  class="text-sm"
92
118
  [class]="
93
- uploadProgress || uploadError
119
+ isUploadInProgress || uploadError
94
120
  ? 'font-bold text-blue-500 cursor-pointer'
95
121
  : 'font-medium text-gray-500'
96
122
  "
97
- (click)="handleSecondaryTextClick()"
123
+ (click)="handleSecondaryTextClick($event)"
98
124
  >
99
125
  {{ getSecondaryText() | translate }}
100
126
  </p>
101
127
  </div>
102
128
  <input
129
+ #fileInput
103
130
  type="file"
104
131
  class="hidden"
105
132
  (change)="handleFileInput($event)"
106
- [disabled]="showUrlInput || uploadProgress || uploadError"
133
+ [disabled]="showUrlInput || isUploadInProgress || uploadError"
107
134
  />
108
135
  </label>
109
- <div *ngIf="!showUrlInput" class="flex-none">
110
- <gn-ui-button
111
- [extraClass]="'bg-gray-200 font-bold'"
112
- (buttonClick)="displayUrlInput()"
113
- >
114
- <mat-icon class="material-symbols-outlined me-1">link</mat-icon>
136
+
137
+ <div *ngIf="!showUrlInput" class="flex-none mt-2">
138
+ <gn-ui-button (buttonClick)="displayUrlInput()" type="gray">
139
+ <mat-icon class="material-symbols-outlined me-1 text-primary"
140
+ >link</mat-icon
141
+ >
115
142
  {{ 'input.image.displayUrlInput' | translate }}
116
143
  </gn-ui-button>
117
144
  </div>
118
- <div *ngIf="showUrlInput" class="flex-none flex flex-col gap-2">
119
- <div class="h-2"></div>
120
- <div class="flex gap-2 items-center">
121
- <div class="flex-1 flex rounded-lg">
122
- <span
123
- class="material-symbols-outlined px-4 inline-flex items-center min-w-fit rounded-s-lg border-2 border-e-0 border-gray-300"
124
- >link</span
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>
145
+
146
+ <gn-ui-url-input
147
+ *ngIf="showUrlInput"
148
+ class="mt-3.5"
149
+ (valueChange)="downloadUrl($event)"
150
+ [disabled]="isUploadInProgress"
151
+ >
152
+ </gn-ui-url-input>
145
153
  </div>
146
154
  </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 { FormControl, ReactiveFormsModule } from '@angular/forms'
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
- ReactiveFormsModule,
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?: URL
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
- handleUrlChange(event: Event) {
114
+ async downloadUrl(url: string) {
111
115
  this.downloadError = false
112
- this.urlInputValue = (event.target as HTMLInputElement).value
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(this.urlInputValue, { observe: 'response' })
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(this.urlInputValue, { responseType: 'blob' }).subscribe({
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: (error) => {
134
- console.error(error)
133
+ error: () => {
135
134
  this.downloadError = true
136
135
  this.cd.markForCheck()
137
- this.urlChange.emit(this.urlInputValue)
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(event: Event) {
181
- const input = event.target as HTMLInputElement
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[]) {
@@ -11,15 +11,16 @@
11
11
  }
12
12
 
13
13
  .mat-button-toggle-appearance-standard {
14
- color: var(--color-main);
14
+ color: black;
15
15
  background-color: var(--color-gray-200);
16
16
  border-radius: 4px;
17
17
  border-left: none;
18
+ font-family: var(--font-family-main);
18
19
  }
19
20
 
20
21
  .mat-button-toggle-appearance-standard.mat-button-toggle-checked {
21
- background-color: var(--color-main);
22
- color: var(--color-primary-white);
22
+ background-color: black;
23
+ color: var(--color-background);
23
24
  }
24
25
 
25
26
  button.mat-button-toggle-button.mat-focus-indicator.mat-button-toggle-label-content {
@@ -6,7 +6,6 @@
6
6
  <mat-button-toggle
7
7
  *ngFor="let option of options"
8
8
  [aria-label]="option.label"
9
- [value]="option.value"
10
9
  [checked]="option.checked"
11
10
  (change)="onChange(option)"
12
11
  [class]="extraClasses"