geonetwork-ui 2.4.0-dev.78565730 → 2.4.0-dev.7a893adc

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 (346) hide show
  1. package/esm2022/libs/api/metadata-converter/src/index.mjs +1 -2
  2. package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.mjs +1 -1
  3. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +7 -5
  4. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +30 -2
  5. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.mjs +31 -0
  6. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +23 -1
  7. package/esm2022/libs/api/metadata-converter/src/lib/xml-utils.mjs +10 -3
  8. package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +21 -4
  9. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +11 -1
  10. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +11 -1
  11. package/esm2022/libs/common/domain/src/lib/model/record/contact.model.mjs +28 -1
  12. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
  13. package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
  14. package/esm2022/libs/common/domain/src/lib/repository/records-repository.interface.mjs +1 -1
  15. package/esm2022/libs/feature/editor/src/lib/+state/editor.actions.mjs +2 -1
  16. package/esm2022/libs/feature/editor/src/lib/+state/editor.effects.mjs +6 -1
  17. package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +4 -1
  18. package/esm2022/libs/feature/editor/src/lib/components/contact-card/contact-card.component.mjs +29 -0
  19. package/esm2022/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.mjs +78 -0
  20. package/esm2022/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.mjs +96 -0
  21. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.mjs +164 -0
  22. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +19 -41
  23. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +10 -8
  24. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.mjs +101 -0
  25. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.mjs +44 -0
  26. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.mjs +28 -0
  27. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.mjs +10 -6
  28. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +11 -11
  29. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.mjs +9 -8
  30. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +111 -5
  31. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.mjs +49 -52
  32. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +16 -14
  33. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +37 -43
  34. package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +5 -3
  35. package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +8 -8
  36. package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +6 -4
  37. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +37 -4
  38. package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +5 -1
  39. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.mjs +6 -6
  40. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.mjs +6 -5
  41. package/esm2022/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.mjs +8 -5
  42. package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +6 -7
  43. package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +8 -7
  44. package/esm2022/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.mjs +7 -6
  45. package/esm2022/libs/feature/map/src/lib/feature-map.module.mjs +7 -26
  46. package/esm2022/libs/feature/map/src/lib/layers-panel/layers-panel.component.mjs +29 -13
  47. package/esm2022/libs/feature/map/src/lib/utils/map-utils.service.mjs +10 -5
  48. package/esm2022/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.mjs +3 -3
  49. package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +40 -7
  50. package/esm2022/libs/feature/search/src/lib/state/search.facade.mjs +6 -2
  51. package/esm2022/libs/ui/elements/src/index.mjs +2 -1
  52. package/esm2022/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.mjs +27 -0
  53. package/esm2022/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.mjs +4 -3
  54. package/esm2022/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.mjs +2 -2
  55. package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
  56. package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +5 -11
  57. package/esm2022/libs/ui/elements/src/lib/metadata-quality-item/metadata-quality-item.component.mjs +3 -3
  58. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +5 -5
  59. package/esm2022/libs/ui/elements/src/lib/sortable-list/sortable-list.component.mjs +6 -10
  60. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +11 -5
  61. package/esm2022/libs/ui/inputs/src/index.mjs +2 -1
  62. package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +19 -5
  63. package/esm2022/libs/ui/inputs/src/lib/editable-label/editable-label.directive.mjs +26 -24
  64. package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +17 -14
  65. package/esm2022/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.mjs +32 -0
  66. package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +6 -21
  67. package/esm2022/libs/ui/inputs/src/lib/text-input/text-input.component.mjs +6 -17
  68. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +3 -7
  69. package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +43 -0
  70. package/esm2022/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.mjs +3 -3
  71. package/esm2022/libs/ui/layout/src/lib/interactive-table/interactive-table.component.mjs +3 -3
  72. package/esm2022/libs/ui/map/src/lib/ui-map.module.mjs +3 -3
  73. package/esm2022/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.mjs +49 -11
  74. package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +18 -6
  75. package/esm2022/libs/ui/widgets/src/index.mjs +2 -1
  76. package/esm2022/libs/ui/widgets/src/lib/popover/popover.component.mjs +68 -0
  77. package/esm2022/translations/de.json +59 -17
  78. package/esm2022/translations/en.json +52 -10
  79. package/esm2022/translations/es.json +51 -9
  80. package/esm2022/translations/fr.json +63 -21
  81. package/esm2022/translations/it.json +52 -10
  82. package/esm2022/translations/nl.json +51 -9
  83. package/esm2022/translations/pt.json +51 -9
  84. package/fesm2022/geonetwork-ui.mjs +4578 -3282
  85. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  86. package/libs/api/metadata-converter/src/index.d.ts +0 -1
  87. package/libs/api/metadata-converter/src/index.d.ts.map +1 -1
  88. package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts +2 -6
  89. package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts.map +1 -1
  90. package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts.map +1 -1
  91. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +8 -1
  92. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
  93. package/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.d.ts +5 -0
  94. package/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.d.ts.map +1 -0
  95. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +3 -1
  96. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  97. package/libs/api/metadata-converter/src/lib/xml-utils.d.ts +1 -0
  98. package/libs/api/metadata-converter/src/lib/xml-utils.d.ts.map +1 -1
  99. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +6 -1
  100. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
  101. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts.map +1 -1
  102. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +1 -0
  103. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  104. package/libs/common/domain/src/lib/model/record/contact.model.d.ts +1 -0
  105. package/libs/common/domain/src/lib/model/record/contact.model.d.ts.map +1 -1
  106. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +3 -1
  107. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  108. package/libs/common/domain/src/lib/platform.service.interface.d.ts +1 -0
  109. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  110. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +8 -0
  111. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts.map +1 -1
  112. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts +1 -0
  113. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts.map +1 -1
  114. package/libs/feature/editor/src/lib/+state/editor.effects.d.ts +5 -0
  115. package/libs/feature/editor/src/lib/+state/editor.effects.d.ts.map +1 -1
  116. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +1 -0
  117. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
  118. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts +12 -0
  119. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts.map +1 -0
  120. package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts +32 -0
  121. package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts.map +1 -0
  122. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts +27 -0
  123. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts.map +1 -0
  124. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts +44 -0
  125. 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
  126. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts +8 -19
  127. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts.map +1 -1
  128. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts +6 -4
  129. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts.map +1 -1
  130. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.d.ts +22 -0
  131. 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
  132. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.d.ts +15 -0
  133. 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
  134. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts +13 -0
  135. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts.map +1 -0
  136. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts +4 -3
  137. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts.map +1 -1
  138. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts +4 -4
  139. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -1
  140. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts +4 -3
  141. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts.map +1 -1
  142. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts +23 -0
  143. 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
  144. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts +15 -15
  145. 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
  146. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +5 -5
  147. 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
  148. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +15 -19
  149. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  150. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts +3 -2
  151. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -1
  152. package/libs/feature/editor/src/lib/feature-editor.module.d.ts +2 -1
  153. package/libs/feature/editor/src/lib/feature-editor.module.d.ts.map +1 -1
  154. package/libs/feature/editor/src/lib/fields.config.d.ts +8 -0
  155. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  156. package/libs/feature/editor/src/lib/services/editor.service.d.ts +1 -0
  157. package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
  158. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts +1 -1
  159. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts.map +1 -1
  160. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts +1 -1
  161. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts.map +1 -1
  162. package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts +1 -1
  163. package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts.map +1 -1
  164. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts +1 -1
  165. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts.map +1 -1
  166. package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts +1 -1
  167. package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts.map +1 -1
  168. package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts +1 -1
  169. package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts.map +1 -1
  170. package/libs/feature/map/src/lib/feature-map.module.d.ts +16 -21
  171. package/libs/feature/map/src/lib/feature-map.module.d.ts.map +1 -1
  172. package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts +1 -1
  173. package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts.map +1 -1
  174. package/libs/feature/map/src/lib/utils/map-utils.service.d.ts.map +1 -1
  175. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +11 -3
  176. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -1
  177. package/libs/feature/search/src/lib/state/search.facade.d.ts +1 -0
  178. package/libs/feature/search/src/lib/state/search.facade.d.ts.map +1 -1
  179. package/libs/ui/elements/src/index.d.ts +1 -0
  180. package/libs/ui/elements/src/index.d.ts.map +1 -1
  181. package/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.d.ts +18 -0
  182. package/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.d.ts.map +1 -0
  183. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
  184. package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts +0 -3
  185. package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts.map +1 -1
  186. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +1 -1
  187. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts +5 -10
  188. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts.map +1 -1
  189. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +8 -6
  190. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  191. package/libs/ui/inputs/src/index.d.ts +1 -0
  192. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  193. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts +9 -1
  194. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
  195. package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts +5 -3
  196. package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts.map +1 -1
  197. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +3 -4
  198. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -1
  199. package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts +17 -0
  200. package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts.map +1 -0
  201. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +0 -4
  202. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
  203. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts +2 -4
  204. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts.map +1 -1
  205. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +34 -35
  206. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
  207. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts +18 -0
  208. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts.map +1 -0
  209. package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts +10 -1
  210. package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts.map +1 -1
  211. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +6 -2
  212. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
  213. package/libs/ui/widgets/src/index.d.ts +1 -0
  214. package/libs/ui/widgets/src/index.d.ts.map +1 -1
  215. package/libs/ui/widgets/src/lib/popover/popover.component.d.ts +19 -0
  216. package/libs/ui/widgets/src/lib/popover/popover.component.d.ts.map +1 -0
  217. package/package.json +1 -1
  218. package/src/libs/api/metadata-converter/src/index.ts +0 -1
  219. package/src/libs/api/metadata-converter/src/lib/fixtures/generic.records.ts +6 -1
  220. package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +5 -1
  221. package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +37 -12
  222. package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +5 -1
  223. package/src/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.ts +2 -6
  224. package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +6 -2
  225. package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +72 -2
  226. package/src/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.ts +39 -0
  227. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +70 -1
  228. package/src/libs/api/metadata-converter/src/lib/xml-utils.ts +13 -5
  229. package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +24 -4
  230. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +12 -1
  231. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +43 -12
  232. package/src/libs/common/domain/src/lib/model/record/contact.model.ts +28 -0
  233. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +3 -1
  234. package/src/libs/common/domain/src/lib/platform.service.interface.ts +4 -0
  235. package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +10 -0
  236. package/src/libs/feature/editor/src/lib/+state/editor.actions.ts +2 -0
  237. package/src/libs/feature/editor/src/lib/+state/editor.effects.ts +15 -0
  238. package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +4 -0
  239. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.css +0 -0
  240. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.html +25 -0
  241. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.ts +30 -0
  242. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.css +0 -0
  243. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.html +26 -0
  244. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.ts +89 -0
  245. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +2 -1
  246. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +74 -31
  247. 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
  248. 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
  249. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.ts +249 -0
  250. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.html +7 -17
  251. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.ts +18 -51
  252. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.ts +13 -5
  253. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.css +0 -0
  254. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.html +4 -0
  255. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.ts +128 -0
  256. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.css +0 -0
  257. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.html +6 -0
  258. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.ts +48 -0
  259. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.css +0 -0
  260. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.html +5 -0
  261. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.ts +33 -0
  262. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.html +2 -2
  263. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.ts +9 -3
  264. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.html +2 -2
  265. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +13 -7
  266. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.html +5 -3
  267. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.ts +11 -4
  268. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +15 -1
  269. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.ts +156 -1
  270. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.html +9 -2
  271. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.ts +59 -70
  272. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +17 -15
  273. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +103 -68
  274. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +43 -43
  275. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +2 -1
  276. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.ts +7 -2
  277. package/src/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.html +1 -1
  278. package/src/libs/feature/editor/src/lib/feature-editor.module.ts +2 -1
  279. package/src/libs/feature/editor/src/lib/fields.config.ts +40 -3
  280. package/src/libs/feature/editor/src/lib/services/editor.service.ts +7 -0
  281. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.ts +3 -0
  282. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.ts +5 -1
  283. package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.ts +5 -0
  284. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.html +1 -1
  285. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.ts +10 -7
  286. package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.html +1 -1
  287. package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.ts +5 -0
  288. package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.html +1 -1
  289. package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.ts +6 -1
  290. package/src/libs/feature/map/src/lib/feature-map.module.ts +2 -15
  291. package/src/libs/feature/map/src/lib/layers-panel/layers-panel.component.ts +24 -1
  292. package/src/libs/feature/map/src/lib/utils/map-utils.service.ts +8 -4
  293. package/src/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.html +1 -1
  294. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.html +2 -1
  295. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +52 -3
  296. package/src/libs/feature/search/src/lib/state/search.facade.ts +6 -0
  297. package/src/libs/ui/elements/src/index.ts +1 -0
  298. package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.css +0 -0
  299. package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.html +12 -0
  300. package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.ts +37 -0
  301. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.html +4 -1
  302. package/src/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.css +2 -1
  303. package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +12 -8
  304. package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +14 -20
  305. package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.ts +0 -10
  306. package/src/libs/ui/elements/src/lib/metadata-quality-item/metadata-quality-item.component.html +1 -1
  307. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +2 -2
  308. package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.html +3 -10
  309. package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.ts +7 -7
  310. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +8 -2
  311. package/src/libs/ui/inputs/src/index.ts +1 -0
  312. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +15 -3
  313. package/src/libs/ui/inputs/src/lib/editable-label/editable-label.directive.ts +40 -26
  314. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.css +0 -0
  315. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.html +85 -0
  316. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.ts +91 -0
  317. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +49 -49
  318. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +15 -13
  319. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +2 -1
  320. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +2 -27
  321. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.html +4 -3
  322. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +4 -16
  323. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +0 -3
  324. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.css +9 -0
  325. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.html +37 -0
  326. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.ts +33 -0
  327. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.html +1 -1
  328. package/src/libs/ui/layout/src/lib/interactive-table/interactive-table.component.html +1 -0
  329. package/src/libs/ui/map/src/lib/ui-map.module.ts +1 -1
  330. package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html +10 -1
  331. package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.ts +55 -3
  332. package/src/libs/ui/search/src/lib/results-table/results-table.component.html +7 -2
  333. package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +9 -9
  334. package/src/libs/ui/widgets/src/index.ts +1 -0
  335. package/src/libs/ui/widgets/src/lib/popover/popover.component.css +0 -0
  336. package/src/libs/ui/widgets/src/lib/popover/popover.component.html +3 -0
  337. package/src/libs/ui/widgets/src/lib/popover/popover.component.ts +85 -0
  338. package/tailwind.base.css +18 -5
  339. package/translations/de.json +59 -17
  340. package/translations/en.json +52 -10
  341. package/translations/es.json +51 -9
  342. package/translations/fr.json +63 -21
  343. package/translations/it.json +52 -10
  344. package/translations/nl.json +51 -9
  345. package/translations/pt.json +51 -9
  346. package/translations/sk.json +52 -10
@@ -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
- (change)="handleAltTextChange($event)"
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="block flex-1 border-2 border-dashed border-gray-300 rounded-lg p-6 flex flex-col items-center justify-center gap-4"
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 class="w-14 h-14 rounded-md bg-gray-200 grid">
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 && !uploadProgress && !uploadError"
61
- class="material-symbols-outlined place-self-center text-blue-500"
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 && !uploadProgress && !uploadError"
66
- class="material-symbols-outlined place-self-center text-blue-500"
70
+ *ngIf="dragFilesOver"
71
+ class="material-symbols-outlined place-self-center text-primary"
67
72
  >add_box</mat-icon
68
73
  >
69
- <div *ngIf="uploadProgress">
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
- [mode]="'determinate'"
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
- uploadProgress || uploadError
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 || uploadProgress || uploadError"
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
- <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>
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
- handleUrlChange(event: Event) {
114
+ async downloadUrl(url: string) {
108
115
  this.downloadError = false
109
- this.urlInputValue = (event.target as HTMLInputElement).value
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(this.urlInputValue, { observe: 'response' })
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(this.urlInputValue, { responseType: 'blob' }).subscribe({
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(this.urlInputValue)
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(event: Event) {
176
- const input = event.target as HTMLInputElement
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
- [class]="classList"
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]="hint"
9
- [attr.aria-label]="hint"
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() hint: string
22
+ @Input() placeholder: string
31
23
  @Input() required = false
32
24
  @Input() disabled: boolean
33
25
  rawChange = new Subject<string>()
34
26
  @Output() valueChange = this.rawChange.pipe(distinctUntilChanged())
35
27
  @ViewChild('input') input
36
28
 
37
- get classList() {
38
- return `${this.baseClass} ${this.extraClass}`
39
- }
40
-
41
29
  ngAfterViewInit() {
42
30
  this.checkRequired(this.input.nativeElement.value)
43
31
  }
@@ -10,7 +10,6 @@ import { ChipsInputComponent } from './chips-input/chips-input.component'
10
10
  import { DragAndDropFileInputComponent } from './drag-and-drop-file-input/drag-and-drop-file-input.component'
11
11
  import { DropdownSelectorComponent } from './dropdown-selector/dropdown-selector.component'
12
12
  import { TextAreaComponent } from './text-area/text-area.component'
13
- import { TextInputComponent } from './text-input/text-input.component'
14
13
  import { MatAutocompleteModule } from '@angular/material/autocomplete'
15
14
  import { MatIconModule } from '@angular/material/icon'
16
15
  import { NavigationButtonComponent } from './navigation-button/navigation-button.component'
@@ -36,7 +35,6 @@ import { ImageInputComponent } from './image-input/image-input.component'
36
35
 
37
36
  @NgModule({
38
37
  declarations: [
39
- TextInputComponent,
40
38
  DragAndDropFileInputComponent,
41
39
  ChipsInputComponent,
42
40
  NavigationButtonComponent,
@@ -77,7 +75,6 @@ import { ImageInputComponent } from './image-input/image-input.component'
77
75
  exports: [
78
76
  DropdownSelectorComponent,
79
77
  ButtonComponent,
80
- TextInputComponent,
81
78
  DragAndDropFileInputComponent,
82
79
  TextAreaComponent,
83
80
  ChipsInputComponent,
@@ -0,0 +1,9 @@
1
+ :host {
2
+ --gn-ui-button-rounded: 8px;
3
+ --gn-ui-button-width: 32px;
4
+ --gn-ui-button-padding: 0;
5
+
6
+ --side-padding: calc(var(--gn-ui-text-input-padding, 0.6em) - 6px);
7
+ --2x-side-padding: calc(var(--side-padding) * 2);
8
+ --text-padding: calc(var(--side-padding) + 40px);
9
+ }
@@ -0,0 +1,37 @@
1
+ <span class="w-full inline-block relative">
2
+ <input
3
+ #input
4
+ class="gn-ui-text-input px-[var(--text-padding)]"
5
+ [ngClass]="extraClass"
6
+ type="url"
7
+ [value]="value"
8
+ (input)="handleInput()"
9
+ (keydown.enter)="handleChange(input)"
10
+ [placeholder]="placeholder"
11
+ [attr.aria-label]="placeholder"
12
+ [disabled]="disabled"
13
+ />
14
+ <div
15
+ class="absolute inset-y-[var(--side-padding)] left-[var(--2x-side-padding)] grid justify-center items-center pointer-events-none"
16
+ [ngClass]='{
17
+ "text-primary": !disabled,
18
+ "text-primary-lightest": disabled,
19
+ }'
20
+ >
21
+ <mat-icon
22
+ class="material-symbols-outlined h-[24px] !w-[26px] text-[28px] leading-[24px]"
23
+ >
24
+ link
25
+ </mat-icon>
26
+ </div>
27
+ <gn-ui-button
28
+ extraClass="absolute inset-y-[var(--side-padding)] right-[var(--side-padding)]"
29
+ type="primary"
30
+ [disabled]="disabled || input.value === ''"
31
+ (buttonClick)="handleChange(input)"
32
+ >
33
+ <mat-icon class="material-symbols-outlined text-[20px] leading-[26px]">
34
+ arrow_upward
35
+ </mat-icon>
36
+ </gn-ui-button>
37
+ </span>
@@ -0,0 +1,33 @@
1
+ import { ChangeDetectorRef, Component, Input, Output } from '@angular/core'
2
+ import { CommonModule } from '@angular/common'
3
+ import { ButtonComponent } from '../button/button.component'
4
+ import { MatIconModule } from '@angular/material/icon'
5
+ import { filter } from 'rxjs/operators'
6
+ import { Subject } from 'rxjs'
7
+
8
+ @Component({
9
+ selector: 'gn-ui-url-input',
10
+ templateUrl: './url-input.component.html',
11
+ styleUrls: ['./url-input.component.css'],
12
+ standalone: true,
13
+ imports: [CommonModule, ButtonComponent, MatIconModule],
14
+ })
15
+ export class UrlInputComponent {
16
+ @Input() value = ''
17
+ @Input() extraClass = ''
18
+ @Input() placeholder = 'https://'
19
+ @Input() disabled: boolean
20
+ rawChange = new Subject<string>()
21
+ @Output() valueChange = this.rawChange.pipe(filter((v) => !!v))
22
+
23
+ constructor(private cd: ChangeDetectorRef) {}
24
+
25
+ handleInput() {
26
+ this.cd.markForCheck()
27
+ }
28
+
29
+ handleChange(element: HTMLInputElement) {
30
+ const value = element.value
31
+ this.rawChange.next(value)
32
+ }
33
+ }
@@ -12,7 +12,7 @@
12
12
  </span>
13
13
  </div>
14
14
  </div>
15
- <div class="flex-1">
15
+ <div class="flex-1 overflow-y-auto">
16
16
  <ng-content></ng-content>
17
17
  </div>
18
18
  </div>
@@ -30,6 +30,7 @@
30
30
  class="contents text-gray-900 cursor-pointer group"
31
31
  *ngFor="let item of items"
32
32
  (click)="handleRowClick(item)"
33
+ data-cy="table-row"
33
34
  >
34
35
  <div
35
36
  class="relative h-0"
@@ -12,7 +12,7 @@ import { MatIconModule } from '@angular/material/icon'
12
12
  CommonModule,
13
13
  HttpClientModule,
14
14
  MatIconModule,
15
- TranslateModule.forRoot(),
15
+ TranslateModule.forChild(),
16
16
  ],
17
17
  exports: [MapComponent, FeatureDetailComponent],
18
18
  })
@@ -1,5 +1,5 @@
1
1
  <gn-ui-button
2
- type="outline"
2
+ type="light"
3
3
  [matMenuTriggerFor]="menu"
4
4
  (buttonClick)="openMenu()"
5
5
  data-test="record-menu-button"
@@ -9,9 +9,18 @@
9
9
  <mat-menu #menu="matMenu">
10
10
  <button
11
11
  mat-menu-item
12
+ [disabled]="!canDuplicate"
12
13
  (click)="duplicate.emit()"
13
14
  data-test="record-menu-duplicate-button"
14
15
  >
15
16
  <span translate>record.action.duplicate</span>
16
17
  </button>
18
+ <button
19
+ mat-menu-item
20
+ [disabled]="!canDelete"
21
+ (click)="openDeleteConfirmationDialog()"
22
+ data-test="record-menu-delete-button"
23
+ >
24
+ <span translate>record.action.delete</span>
25
+ </button>
17
26
  </mat-menu>
@@ -1,22 +1,74 @@
1
- import { Component, EventEmitter, Output, ViewChild } from '@angular/core'
1
+ import {
2
+ Component,
3
+ EventEmitter,
4
+ Input,
5
+ Output,
6
+ ViewChild,
7
+ } from '@angular/core'
8
+ import { MatDialog, MatDialogModule } from '@angular/material/dialog'
2
9
  import { MatIconModule } from '@angular/material/icon'
3
10
  import { MatMenuModule, MatMenuTrigger } from '@angular/material/menu'
11
+ import { ConfirmationDialogComponent } from '../../../../../../../libs/ui/elements/src'
4
12
  import { ButtonComponent } from '../../../../../../../libs/ui/inputs/src'
5
- import { TranslateModule } from '@ngx-translate/core'
13
+ import { TranslateModule, TranslateService } from '@ngx-translate/core'
6
14
 
7
15
  @Component({
8
16
  selector: 'gn-ui-action-menu',
9
17
  templateUrl: './action-menu.component.html',
10
18
  styleUrls: ['./action-menu.component.css'],
11
19
  standalone: true,
12
- imports: [MatIconModule, ButtonComponent, MatMenuModule, TranslateModule],
20
+ imports: [
21
+ MatIconModule,
22
+ ButtonComponent,
23
+ MatMenuModule,
24
+ MatDialogModule,
25
+ ConfirmationDialogComponent,
26
+ TranslateModule,
27
+ ],
13
28
  })
14
29
  export class ActionMenuComponent {
30
+ @Input() canDuplicate: boolean
31
+ @Input() canDelete: boolean
15
32
  @Output() duplicate = new EventEmitter<void>()
33
+ @Output() delete = new EventEmitter<void>()
16
34
 
17
35
  @ViewChild(MatMenuTrigger) trigger: MatMenuTrigger
18
36
 
37
+ constructor(
38
+ public dialog: MatDialog,
39
+ private translateService: TranslateService
40
+ ) {}
41
+
19
42
  openMenu() {
20
43
  this.trigger.openMenu()
21
44
  }
45
+
46
+ openDeleteConfirmationDialog() {
47
+ const dialogRef = this.dialog.open(ConfirmationDialogComponent, {
48
+ data: {
49
+ title: this.translateService.instant(
50
+ 'editor.record.delete.confirmation.title'
51
+ ),
52
+ message: this.translateService.instant(
53
+ 'editor.record.delete.confirmation.message'
54
+ ),
55
+ confirmText: this.translateService.instant(
56
+ 'editor.record.delete.confirmation.confirmText'
57
+ ),
58
+ cancelText: this.translateService.instant(
59
+ 'editor.record.delete.confirmation.cancelText'
60
+ ),
61
+ },
62
+ restoreFocus: false,
63
+ })
64
+
65
+ // Manually restore focus to the menu trigger since the element that
66
+ // opens the dialog won't be in the DOM any more when the dialog closes.
67
+ dialogRef.afterClosed().subscribe((confirmed) => {
68
+ this.trigger.focus()
69
+ if (confirmed) {
70
+ this.delete.emit()
71
+ }
72
+ })
73
+ }
22
74
  }
@@ -37,7 +37,7 @@
37
37
  <div class="flex flex-row items-center gap-2 max-w-full">
38
38
  <span class="overflow-hidden text-ellipsis">{{ item.title }}</span>
39
39
  <gn-ui-badge
40
- *ngIf="recordHasDraft(item)"
40
+ *ngIf="hasDraft(item)"
41
41
  [style.--gn-ui-badge-padding]="'0.4em 0.6em'"
42
42
  [style.--gn-ui-badge-text-color]="'#3d2006'"
43
43
  [style.--gn-ui-badge-background-color]="'#ffbc7b'"
@@ -125,7 +125,12 @@
125
125
  <gn-ui-interactive-table-column>
126
126
  <ng-template #header> </ng-template>
127
127
  <ng-template #cell let-item>
128
- <gn-ui-action-menu (duplicate)="handleDuplicate(item)">
128
+ <gn-ui-action-menu
129
+ [canDuplicate]="canDuplicate(item)"
130
+ [canDelete]="canDelete(item)"
131
+ (duplicate)="handleDuplicate(item)"
132
+ (delete)="handleDelete(item)"
133
+ >
129
134
  </gn-ui-action-menu>
130
135
  </ng-template>
131
136
  </gn-ui-interactive-table-column>
@@ -1,13 +1,6 @@
1
1
  import { CommonModule } from '@angular/common'
2
- import {
3
- Component,
4
- EventEmitter,
5
- Input,
6
- Output,
7
- ViewChild,
8
- } from '@angular/core'
2
+ import { Component, EventEmitter, Input, Output } from '@angular/core'
9
3
  import { MatIconModule } from '@angular/material/icon'
10
- import { MatMenuModule, MatMenuTrigger } from '@angular/material/menu'
11
4
  import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
12
5
  import {
13
6
  FieldSort,
@@ -47,12 +40,15 @@ export class ResultsTableComponent {
47
40
  @Input() records: CatalogRecord[] = []
48
41
  @Input() selectedRecordsIdentifiers: string[] = []
49
42
  @Input() sortOrder: SortByField = null
50
- @Input() recordHasDraft: (record: CatalogRecord) => boolean = () => false
43
+ @Input() hasDraft: (record: CatalogRecord) => boolean = () => false
44
+ @Input() canDuplicate: (record: CatalogRecord) => boolean = () => true
45
+ @Input() canDelete: (record: CatalogRecord) => boolean = () => true
51
46
 
52
47
  // emits the column (field) as well as the order
53
48
  @Output() sortByChange = new EventEmitter<[string, 'asc' | 'desc']>()
54
49
  @Output() recordClick = new EventEmitter<CatalogRecord>()
55
50
  @Output() duplicateRecord = new EventEmitter<CatalogRecord>()
51
+ @Output() deleteRecord = new EventEmitter<CatalogRecord>()
56
52
  @Output() recordsSelectedChange = new EventEmitter<
57
53
  [CatalogRecord[], boolean]
58
54
  >()
@@ -103,6 +99,10 @@ export class ResultsTableComponent {
103
99
  this.duplicateRecord.emit(item as CatalogRecord)
104
100
  }
105
101
 
102
+ handleDelete(item: unknown) {
103
+ this.deleteRecord.emit(item as CatalogRecord)
104
+ }
105
+
106
106
  setSortBy(col: string, order: 'asc' | 'desc') {
107
107
  this.sortByChange.emit([col, order])
108
108
  }