geonetwork-ui 2.4.0-dev.e77c0f8c → 2.4.0-dev.e7ff1d25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (313) hide show
  1. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +5 -5
  2. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +30 -2
  3. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.mjs +31 -0
  4. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +23 -1
  5. package/esm2022/libs/api/metadata-converter/src/lib/xml-utils.mjs +10 -3
  6. package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +31 -3
  7. package/esm2022/libs/common/domain/src/lib/model/record/contact.model.mjs +28 -1
  8. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
  9. package/esm2022/libs/common/domain/src/lib/repository/records-repository.interface.mjs +1 -1
  10. package/esm2022/libs/data-access/gn4/src/openapi/api/records.api.service.mjs +2 -6
  11. package/esm2022/libs/feature/editor/src/lib/+state/editor.actions.mjs +2 -1
  12. package/esm2022/libs/feature/editor/src/lib/+state/editor.effects.mjs +3 -3
  13. package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +7 -2
  14. package/esm2022/libs/feature/editor/src/lib/+state/editor.models.mjs +1 -1
  15. package/esm2022/libs/feature/editor/src/lib/+state/editor.reducer.mjs +7 -3
  16. package/esm2022/libs/feature/editor/src/lib/+state/editor.selectors.mjs +16 -6
  17. package/esm2022/libs/feature/editor/src/lib/components/contact-card/contact-card.component.mjs +29 -0
  18. package/esm2022/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.mjs +131 -0
  19. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.mjs +170 -0
  20. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +3 -3
  21. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.mjs +47 -0
  22. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.mjs +21 -0
  23. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.mjs +7 -6
  24. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +33 -9
  25. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/index.mjs +1 -2
  26. package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +11 -7
  27. package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +8 -8
  28. package/esm2022/libs/feature/editor/src/lib/expressions.mjs +1 -1
  29. package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +6 -4
  30. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +169 -59
  31. package/esm2022/libs/feature/editor/src/lib/models/editor-config.model.mjs +2 -0
  32. package/esm2022/libs/feature/editor/src/lib/models/index.mjs +2 -1
  33. package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +4 -3
  34. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.mjs +6 -6
  35. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.mjs +6 -5
  36. package/esm2022/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.mjs +8 -5
  37. package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +6 -7
  38. package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +8 -7
  39. package/esm2022/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.mjs +7 -6
  40. package/esm2022/libs/feature/map/src/lib/feature-map.module.mjs +7 -26
  41. package/esm2022/libs/feature/map/src/lib/layers-panel/layers-panel.component.mjs +29 -13
  42. package/esm2022/libs/feature/map/src/lib/utils/map-utils.service.mjs +10 -5
  43. package/esm2022/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.mjs +3 -3
  44. package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +46 -7
  45. package/esm2022/libs/feature/search/src/lib/state/search.facade.mjs +6 -2
  46. package/esm2022/libs/ui/elements/src/index.mjs +2 -1
  47. package/esm2022/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.mjs +27 -0
  48. package/esm2022/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.mjs +4 -3
  49. package/esm2022/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.mjs +2 -2
  50. package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
  51. package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +5 -11
  52. package/esm2022/libs/ui/elements/src/lib/metadata-quality-item/metadata-quality-item.component.mjs +3 -3
  53. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +5 -5
  54. package/esm2022/libs/ui/elements/src/lib/sortable-list/sortable-list.component.mjs +7 -3
  55. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +11 -5
  56. package/esm2022/libs/ui/elements/src/lib/user-preview/user-preview.component.mjs +3 -3
  57. package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +19 -5
  58. package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +17 -14
  59. package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +6 -21
  60. package/esm2022/libs/ui/inputs/src/lib/text-input/text-input.component.mjs +6 -17
  61. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +3 -7
  62. package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +43 -0
  63. package/esm2022/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.mjs +3 -3
  64. package/esm2022/libs/ui/layout/src/lib/interactive-table/interactive-table.component.mjs +3 -3
  65. package/esm2022/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.mjs +67 -0
  66. package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +28 -8
  67. package/esm2022/libs/ui/widgets/src/index.mjs +2 -1
  68. package/esm2022/libs/ui/widgets/src/lib/popover/popover.component.mjs +68 -0
  69. package/esm2022/translations/de.json +70 -10
  70. package/esm2022/translations/en.json +70 -10
  71. package/esm2022/translations/es.json +69 -9
  72. package/esm2022/translations/fr.json +81 -21
  73. package/esm2022/translations/it.json +70 -10
  74. package/esm2022/translations/nl.json +69 -9
  75. package/esm2022/translations/pt.json +69 -9
  76. package/fesm2022/geonetwork-ui.mjs +4678 -3349
  77. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  78. package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts.map +1 -1
  79. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +8 -1
  80. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
  81. package/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.d.ts +5 -0
  82. package/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.d.ts.map +1 -0
  83. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +3 -1
  84. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  85. package/libs/api/metadata-converter/src/lib/xml-utils.d.ts +1 -0
  86. package/libs/api/metadata-converter/src/lib/xml-utils.d.ts.map +1 -1
  87. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +7 -1
  88. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
  89. package/libs/common/domain/src/lib/model/record/contact.model.d.ts +1 -0
  90. package/libs/common/domain/src/lib/model/record/contact.model.d.ts.map +1 -1
  91. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +2 -1
  92. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  93. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +17 -0
  94. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts.map +1 -1
  95. package/libs/data-access/gn4/src/openapi/api/records.api.service.d.ts.map +1 -1
  96. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts +5 -0
  97. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts.map +1 -1
  98. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +4 -4
  99. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
  100. package/libs/feature/editor/src/lib/+state/editor.models.d.ts +8 -0
  101. package/libs/feature/editor/src/lib/+state/editor.models.d.ts.map +1 -1
  102. package/libs/feature/editor/src/lib/+state/editor.reducer.d.ts +4 -3
  103. package/libs/feature/editor/src/lib/+state/editor.reducer.d.ts.map +1 -1
  104. package/libs/feature/editor/src/lib/+state/editor.selectors.d.ts +4 -8
  105. package/libs/feature/editor/src/lib/+state/editor.selectors.d.ts.map +1 -1
  106. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts +12 -0
  107. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts.map +1 -0
  108. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts +27 -0
  109. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts.map +1 -0
  110. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts +47 -0
  111. 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
  112. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.d.ts +17 -0
  113. 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
  114. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts +11 -0
  115. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts.map +1 -0
  116. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts +3 -1
  117. 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
  118. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +10 -2
  119. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  120. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts +0 -1
  121. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts.map +1 -1
  122. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts +5 -7
  123. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -1
  124. package/libs/feature/editor/src/lib/expressions.d.ts +1 -1
  125. package/libs/feature/editor/src/lib/expressions.d.ts.map +1 -1
  126. package/libs/feature/editor/src/lib/feature-editor.module.d.ts +2 -1
  127. package/libs/feature/editor/src/lib/feature-editor.module.d.ts.map +1 -1
  128. package/libs/feature/editor/src/lib/fields.config.d.ts +45 -2
  129. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  130. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts +36 -0
  131. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts.map +1 -0
  132. package/libs/feature/editor/src/lib/models/index.d.ts +1 -0
  133. package/libs/feature/editor/src/lib/models/index.d.ts.map +1 -1
  134. package/libs/feature/editor/src/lib/services/editor.service.d.ts +2 -2
  135. package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
  136. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts +1 -1
  137. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts.map +1 -1
  138. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts +1 -1
  139. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts.map +1 -1
  140. package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts +1 -1
  141. package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts.map +1 -1
  142. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts +1 -1
  143. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts.map +1 -1
  144. package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts +1 -1
  145. package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts.map +1 -1
  146. package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts +1 -1
  147. package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts.map +1 -1
  148. package/libs/feature/map/src/lib/feature-map.module.d.ts +16 -21
  149. package/libs/feature/map/src/lib/feature-map.module.d.ts.map +1 -1
  150. package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts +1 -1
  151. package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts.map +1 -1
  152. package/libs/feature/map/src/lib/utils/map-utils.service.d.ts.map +1 -1
  153. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +14 -4
  154. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -1
  155. package/libs/feature/search/src/lib/state/search.facade.d.ts +1 -0
  156. package/libs/feature/search/src/lib/state/search.facade.d.ts.map +1 -1
  157. package/libs/ui/elements/src/index.d.ts +1 -0
  158. package/libs/ui/elements/src/index.d.ts.map +1 -1
  159. package/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.d.ts +18 -0
  160. package/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.d.ts.map +1 -0
  161. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
  162. package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts +0 -3
  163. package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts.map +1 -1
  164. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +1 -1
  165. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts +4 -4
  166. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts.map +1 -1
  167. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +8 -6
  168. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  169. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts +9 -1
  170. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
  171. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +3 -4
  172. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -1
  173. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +0 -4
  174. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
  175. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts +2 -4
  176. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts.map +1 -1
  177. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +34 -35
  178. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
  179. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts +18 -0
  180. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts.map +1 -0
  181. package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts +20 -0
  182. package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts.map +1 -0
  183. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +9 -3
  184. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
  185. package/libs/ui/widgets/src/index.d.ts +1 -0
  186. package/libs/ui/widgets/src/index.d.ts.map +1 -1
  187. package/libs/ui/widgets/src/lib/popover/popover.component.d.ts +19 -0
  188. package/libs/ui/widgets/src/lib/popover/popover.component.d.ts.map +1 -0
  189. package/package.json +1 -1
  190. package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +5 -1
  191. package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +37 -12
  192. package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +5 -1
  193. package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +4 -2
  194. package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +72 -2
  195. package/src/libs/api/metadata-converter/src/lib/iso19139/utils/geometry.ts +39 -0
  196. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +70 -1
  197. package/src/libs/api/metadata-converter/src/lib/xml-utils.ts +13 -5
  198. package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +42 -2
  199. package/src/libs/common/domain/src/lib/model/record/contact.model.ts +28 -0
  200. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +2 -1
  201. package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +22 -0
  202. package/src/libs/common/fixtures/src/index.ts +2 -0
  203. package/src/libs/common/fixtures/src/lib/editor/editor.fixtures.ts +156 -0
  204. package/src/libs/common/fixtures/src/lib/editor/index.ts +1 -0
  205. package/src/libs/data-access/gn4/src/openapi/api/records.api.service.ts +1 -5
  206. package/src/libs/data-access/gn4/src/spec.yaml +0 -8
  207. package/src/libs/feature/editor/src/lib/+state/editor.actions.ts +5 -0
  208. package/src/libs/feature/editor/src/lib/+state/editor.effects.ts +2 -2
  209. package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +9 -1
  210. package/src/libs/feature/editor/src/lib/+state/editor.models.ts +11 -0
  211. package/src/libs/feature/editor/src/lib/+state/editor.reducer.ts +11 -5
  212. package/src/libs/feature/editor/src/lib/+state/editor.selectors.ts +22 -8
  213. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.css +0 -0
  214. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.html +25 -0
  215. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.ts +30 -0
  216. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +2 -1
  217. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +110 -19
  218. 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
  219. 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
  220. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.ts +271 -0
  221. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.html +1 -1
  222. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.css +0 -0
  223. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.html +6 -0
  224. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.ts +59 -0
  225. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.css +0 -0
  226. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.html +5 -0
  227. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.ts +22 -0
  228. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.ts +8 -7
  229. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +27 -10
  230. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +32 -2
  231. package/src/libs/feature/editor/src/lib/components/record-form/form-field/index.ts +0 -1
  232. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +51 -11
  233. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.ts +15 -8
  234. package/src/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.html +1 -1
  235. package/src/libs/feature/editor/src/lib/expressions.ts +1 -1
  236. package/src/libs/feature/editor/src/lib/feature-editor.module.ts +2 -1
  237. package/src/libs/feature/editor/src/lib/fields.config.ts +204 -60
  238. package/src/libs/feature/editor/src/lib/models/editor-config.model.ts +53 -0
  239. package/src/libs/feature/editor/src/lib/models/index.ts +1 -0
  240. package/src/libs/feature/editor/src/lib/services/editor.service.ts +8 -4
  241. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.ts +3 -0
  242. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.ts +5 -1
  243. package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.ts +5 -0
  244. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.html +1 -1
  245. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.ts +10 -7
  246. package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.html +1 -1
  247. package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.ts +5 -0
  248. package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.html +1 -1
  249. package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.ts +6 -1
  250. package/src/libs/feature/map/src/lib/feature-map.module.ts +2 -15
  251. package/src/libs/feature/map/src/lib/layers-panel/layers-panel.component.ts +24 -1
  252. package/src/libs/feature/map/src/lib/utils/map-utils.service.ts +8 -4
  253. package/src/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.html +1 -1
  254. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.html +3 -1
  255. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +57 -3
  256. package/src/libs/feature/search/src/lib/state/search.facade.ts +6 -0
  257. package/src/libs/ui/elements/src/index.ts +1 -0
  258. package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.css +0 -0
  259. package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.html +12 -0
  260. package/src/libs/ui/elements/src/lib/confirmation-dialog/confirmation-dialog.component.ts +37 -0
  261. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.html +4 -1
  262. package/src/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.css +2 -1
  263. package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +12 -8
  264. package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +14 -20
  265. package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.ts +0 -10
  266. package/src/libs/ui/elements/src/lib/metadata-quality-item/metadata-quality-item.component.html +1 -1
  267. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +2 -2
  268. package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.html +3 -1
  269. package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.ts +8 -4
  270. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +8 -2
  271. package/src/libs/ui/elements/src/lib/user-preview/user-preview.component.html +1 -1
  272. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +15 -3
  273. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.css +0 -0
  274. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.html +85 -0
  275. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.ts +91 -0
  276. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +49 -49
  277. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +15 -13
  278. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +2 -1
  279. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +2 -27
  280. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.html +4 -3
  281. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +4 -16
  282. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +0 -3
  283. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.css +9 -0
  284. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.html +37 -0
  285. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.ts +33 -0
  286. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.html +1 -1
  287. package/src/libs/ui/layout/src/lib/interactive-table/interactive-table.component.html +1 -0
  288. package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.css +0 -0
  289. package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html +26 -0
  290. package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.ts +74 -0
  291. package/src/libs/ui/search/src/lib/results-table/results-table.component.html +15 -1
  292. package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +26 -12
  293. package/src/libs/ui/widgets/src/index.ts +1 -0
  294. package/src/libs/ui/widgets/src/lib/popover/popover.component.css +0 -0
  295. package/src/libs/ui/widgets/src/lib/popover/popover.component.html +3 -0
  296. package/src/libs/ui/widgets/src/lib/popover/popover.component.ts +85 -0
  297. package/tailwind.base.css +18 -5
  298. package/translations/de.json +70 -10
  299. package/translations/en.json +70 -10
  300. package/translations/es.json +69 -9
  301. package/translations/fr.json +81 -21
  302. package/translations/it.json +70 -10
  303. package/translations/nl.json +69 -9
  304. package/translations/pt.json +69 -9
  305. package/translations/sk.json +70 -10
  306. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.mjs +0 -2
  307. package/esm2022/libs/feature/editor/src/lib/models/fields.model.mjs +0 -2
  308. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.d.ts +0 -26
  309. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.d.ts.map +0 -1
  310. package/libs/feature/editor/src/lib/models/fields.model.d.ts +0 -15
  311. package/libs/feature/editor/src/lib/models/fields.model.d.ts.map +0 -1
  312. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.ts +0 -43
  313. package/src/libs/feature/editor/src/lib/models/fields.model.ts +0 -29
@@ -0,0 +1,76 @@
1
+ <div class="flex flex-col gap-3">
2
+ <div class="flex flex-row flex-wrap gap-2" data-test="rolesToPick">
3
+ <ng-container *ngFor="let role of rolesToPick">
4
+ <gn-ui-button
5
+ extraClass="px-2 py-1.5"
6
+ (buttonClick)="addRoleToDisplay(role)"
7
+ >
8
+ <div class="flex flex-row gap-1 items-center">
9
+ <span class="text-primary text-[20px] leading-[0] font-bold pb-[5px]"
10
+ >&#8330;</span
11
+ >
12
+ <span class="font-bold" translate>{{ roleToLabel(role) }}</span>
13
+ </div>
14
+ </gn-ui-button>
15
+ </ng-container>
16
+ </div>
17
+ <div
18
+ class="mt-8"
19
+ *ngIf="
20
+ roleSectionsToDisplay && roleSectionsToDisplay.length > 0;
21
+ else noContact
22
+ "
23
+ data-test="displayedRoles"
24
+ >
25
+ <div
26
+ *ngFor="
27
+ let role of roleSectionsToDisplay;
28
+ let index = index;
29
+ let isLast = last
30
+ "
31
+ class="flex flex-col gap-4"
32
+ >
33
+ <div class="flex flex-row justify-between">
34
+ <span class="font-bold text-base" translate>{{
35
+ roleToLabel(role)
36
+ }}</span>
37
+ </div>
38
+
39
+ <gn-ui-autocomplete
40
+ [placeholder]="'Choose a contact'"
41
+ [action]="autoCompleteAction"
42
+ (itemSelected)="addContact($event, role)"
43
+ [displayWithFn]="displayWithFn"
44
+ [minCharacterCount]="1"
45
+ [clearOnSelection]="true"
46
+ >
47
+ </gn-ui-autocomplete>
48
+
49
+ <ng-container *ngIf="contactsForRessourceByRole.get(role) as contacts">
50
+ <ng-container *ngIf="contacts.length > 1">
51
+ <gn-ui-sortable-list
52
+ [elements]="contactsAsDynElemByRole.get(role)"
53
+ (elementsChange)="handleContactsChanged($event)"
54
+ ></gn-ui-sortable-list>
55
+ </ng-container>
56
+ <ng-container *ngIf="contacts.length === 1">
57
+ <ng-container *ngFor="let contact of contacts">
58
+ <gn-ui-contact-card
59
+ [contact]="contact"
60
+ (contactRemoved)="removeContact(index)"
61
+ ></gn-ui-contact-card> </ng-container
62
+ ></ng-container>
63
+ </ng-container>
64
+
65
+ <hr class="border-t-[#D6D3D1] mt-4 mb-6" *ngIf="!isLast" />
66
+ </div>
67
+ </div>
68
+ <ng-template #noContact>
69
+ <div
70
+ class="p-4 border border-primary bg-primary-lightest rounded-lg"
71
+ translate
72
+ >
73
+ editor.record.form.field.contactsForResource.noContact
74
+ </div>
75
+ </ng-template>
76
+ </div>
@@ -0,0 +1,271 @@
1
+ import { CommonModule } from '@angular/common'
2
+ import {
3
+ ChangeDetectionStrategy,
4
+ ChangeDetectorRef,
5
+ Component,
6
+ Input,
7
+ OnDestroy,
8
+ OnInit,
9
+ } from '@angular/core'
10
+ import { FormControl } from '@angular/forms'
11
+ import {
12
+ AutocompleteComponent,
13
+ DropdownSelectorComponent,
14
+ UiInputsModule,
15
+ } from '../../../../../../../../../libs/ui/inputs/src'
16
+ import { UiWidgetsModule } from '../../../../../../../../../libs/ui/widgets/src'
17
+ import {
18
+ Individual,
19
+ Organization,
20
+ Role,
21
+ RoleLabels,
22
+ } from '../../../../../../../../../libs/common/domain/src/lib/model/record'
23
+ import { TranslateModule } from '@ngx-translate/core'
24
+ import {
25
+ debounceTime,
26
+ distinctUntilChanged,
27
+ firstValueFrom,
28
+ Observable,
29
+ Subscription,
30
+ switchMap,
31
+ } from 'rxjs'
32
+ import { UserModel } from '../../../../../../../../../libs/common/domain/src/lib/model/user'
33
+ import { PlatformServiceInterface } from '../../../../../../../../../libs/common/domain/src/lib/platform.service.interface'
34
+ import { OrganizationsServiceInterface } from '../../../../../../../../../libs/common/domain/src/lib/organizations.service.interface'
35
+ import { ContactCardComponent } from '../../../contact-card/contact-card.component'
36
+ import {
37
+ DynamicElement,
38
+ SortableListComponent,
39
+ } from '../../../../../../../../../libs/ui/elements/src'
40
+ import { createFuzzyFilter } from '../../../../../../../../../libs/util/shared/src'
41
+ import { map } from 'rxjs/operators'
42
+
43
+ @Component({
44
+ selector: 'gn-ui-form-field-contacts-for-resource',
45
+ templateUrl: './form-field-contacts-for-resource.component.html',
46
+ styleUrls: ['./form-field-contacts-for-resource.component.css'],
47
+ changeDetection: ChangeDetectionStrategy.OnPush,
48
+ standalone: true,
49
+ imports: [
50
+ DropdownSelectorComponent,
51
+ UiInputsModule,
52
+ CommonModule,
53
+ UiWidgetsModule,
54
+ AutocompleteComponent,
55
+ TranslateModule,
56
+ ContactCardComponent,
57
+ SortableListComponent,
58
+ ],
59
+ })
60
+ export class FormFieldContactsForResourceComponent
61
+ implements OnInit, OnDestroy
62
+ {
63
+ @Input() control: FormControl<Individual[]>
64
+
65
+ subscription: Subscription = new Subscription()
66
+
67
+ allUsers$: Observable<UserModel[]>
68
+
69
+ contactsForRessourceByRole: Map<Role, Individual[]> = new Map()
70
+
71
+ contactsAsDynElemByRole: Map<Role, DynamicElement[]> = new Map()
72
+
73
+ rolesToPick: Role[] = [
74
+ 'resource_provider',
75
+ 'custodian',
76
+ 'owner',
77
+ 'point_of_contact',
78
+ 'author',
79
+ ]
80
+
81
+ roleSectionsToDisplay: Role[] = []
82
+
83
+ allOrganizations: Map<string, Organization> = new Map()
84
+
85
+ constructor(
86
+ private platformServiceInterface: PlatformServiceInterface,
87
+ private organizationsServiceInterface: OrganizationsServiceInterface,
88
+ private changeDetectorRef: ChangeDetectorRef
89
+ ) {
90
+ this.allUsers$ = this.platformServiceInterface.getUsers()
91
+ }
92
+
93
+ async ngOnInit(): Promise<void> {
94
+ this.allOrganizations = new Map<string, Organization>(
95
+ (
96
+ await firstValueFrom(this.organizationsServiceInterface.organisations$)
97
+ ).map((organization) => [organization.name, organization])
98
+ )
99
+ this.updateContactsForRessource()
100
+ this.manageRoleSectionsToDisplay(this.control.value)
101
+ this.filterRolesToPick()
102
+
103
+ this.changeDetectorRef.markForCheck()
104
+
105
+ this.subscription.add(
106
+ this.control.valueChanges.subscribe((contactsForResource) => {
107
+ this.updateContactsForRessource()
108
+ this.manageRoleSectionsToDisplay(contactsForResource)
109
+ this.filterRolesToPick()
110
+
111
+ this.changeDetectorRef.markForCheck()
112
+ })
113
+ )
114
+ }
115
+
116
+ addRoleToDisplay(roleToAdd: string) {
117
+ this.roleSectionsToDisplay.push(roleToAdd)
118
+ this.filterRolesToPick()
119
+ }
120
+
121
+ filterRolesToPick() {
122
+ this.rolesToPick = this.rolesToPick.filter(
123
+ (role) => !this.roleSectionsToDisplay.includes(role)
124
+ )
125
+ }
126
+
127
+ updateContactsForRessource() {
128
+ this.contactsForRessourceByRole = this.control.value.reduce(
129
+ (acc, contact) => {
130
+ const completeOrganization = this.allOrganizations.get(
131
+ contact.organization.name
132
+ )
133
+
134
+ const updatedContact = {
135
+ ...contact,
136
+ organization:
137
+ completeOrganization ??
138
+ ({ name: contact.organization.name } as Organization),
139
+ }
140
+
141
+ if (!acc.has(contact.role)) {
142
+ acc.set(contact.role, [])
143
+ }
144
+
145
+ acc.get(contact.role).push(updatedContact)
146
+
147
+ return acc
148
+ },
149
+ new Map<Role, Individual[]>()
150
+ )
151
+
152
+ this.contactsAsDynElemByRole = this.control.value.reduce((acc, contact) => {
153
+ const completeOrganization = this.allOrganizations.get(
154
+ contact.organization.name
155
+ )
156
+
157
+ const updatedContact = {
158
+ ...contact,
159
+ organization:
160
+ completeOrganization ??
161
+ ({ name: contact.organization.name } as Organization),
162
+ }
163
+
164
+ const contactAsDynElem = {
165
+ component: ContactCardComponent,
166
+ inputs: {
167
+ contact: updatedContact,
168
+ removable: false,
169
+ },
170
+ } as DynamicElement
171
+
172
+ if (!acc.has(contact.role)) {
173
+ acc.set(contact.role, [])
174
+ }
175
+
176
+ acc.get(contact.role).push(contactAsDynElem)
177
+
178
+ return acc
179
+ }, new Map<Role, DynamicElement[]>())
180
+
181
+ this.changeDetectorRef.markForCheck()
182
+ }
183
+
184
+ manageRoleSectionsToDisplay(contactsForResource: Individual[]) {
185
+ const roles = contactsForResource.map(
186
+ (contact: Individual) => contact.role
187
+ ) as Role[]
188
+
189
+ roles.forEach((role: Role) => {
190
+ if (!this.roleSectionsToDisplay.includes(role)) {
191
+ this.roleSectionsToDisplay.push(role)
192
+ }
193
+ })
194
+ }
195
+
196
+ removeContact(index: number) {
197
+ const newContactsforRessource = this.control.value.filter(
198
+ (_, i) => i !== index
199
+ )
200
+ this.control.setValue(newContactsforRessource)
201
+ }
202
+
203
+ handleContactsChanged(event: DynamicElement[]) {
204
+ const newContactsOrdered = event.map(
205
+ (contactAsDynElem) => contactAsDynElem.inputs['contact']
206
+ ) as Individual[]
207
+
208
+ const role = newContactsOrdered[0].role
209
+
210
+ this.contactsForRessourceByRole.set(role, newContactsOrdered)
211
+
212
+ const newControlValue = Array.from(
213
+ this.contactsForRessourceByRole.values()
214
+ ).flat()
215
+
216
+ this.control.setValue(newControlValue)
217
+ }
218
+
219
+ protected roleToLabel(role: string): string {
220
+ return RoleLabels.get(role)
221
+ }
222
+
223
+ /**
224
+ * gn-ui-autocomplete
225
+ */
226
+ displayWithFn: (user: UserModel) => string = (user) =>
227
+ `${user.name} ${user.surname} ${
228
+ user.organisation ? `(${user.organisation})` : ''
229
+ }`
230
+
231
+ /**
232
+ * gn-ui-autocomplete
233
+ */
234
+ autoCompleteAction = (query: string) => {
235
+ const fuzzyFilter = createFuzzyFilter(query)
236
+ return this.allUsers$.pipe(
237
+ switchMap((users) => [
238
+ users.filter((user) => fuzzyFilter(user.username)),
239
+ ]),
240
+ map((results) => results.slice(0, 10)),
241
+ debounceTime(300),
242
+ distinctUntilChanged()
243
+ )
244
+ }
245
+
246
+ /**
247
+ * gn-ui-autocomplete
248
+ */
249
+ addContact(contact: UserModel, role: string) {
250
+ const newContactsForRessource = {
251
+ firstName: contact.name ?? '',
252
+ lastName: contact.surname ?? '',
253
+ organization:
254
+ this.allOrganizations.get(contact.organisation) ??
255
+ ({ name: contact.organisation } as Organization),
256
+ email: contact.email ?? '',
257
+ role,
258
+ address: '',
259
+ phone: '',
260
+ position: '',
261
+ } as Individual
262
+
263
+ const newControlValue = [...this.control.value, newContactsForRessource]
264
+
265
+ this.control.setValue(newControlValue)
266
+ }
267
+
268
+ ngOnDestroy(): void {
269
+ this.subscription.unsubscribe()
270
+ }
271
+ }
@@ -4,7 +4,7 @@
4
4
  [displayWithFn]="displayWithFn"
5
5
  [action]="autoCompleteAction"
6
6
  (itemSelected)="handleItemSelection($event)"
7
- [clearOnSelection]="true"
7
+ [preventCompleteOnSelection]="true"
8
8
  [minCharacterCount]="0"
9
9
  [allowSubmit]="false"
10
10
  ></gn-ui-autocomplete>
@@ -0,0 +1,6 @@
1
+ <gn-ui-check-toggle
2
+ [label]="'editor.record.form.classification.opendata' | translate"
3
+ [value]="value"
4
+ (toggled)="onOpenDataToggled($event)"
5
+ data-cy="openDataToggle"
6
+ ></gn-ui-check-toggle>
@@ -0,0 +1,59 @@
1
+ import {
2
+ ChangeDetectionStrategy,
3
+ Component,
4
+ EventEmitter,
5
+ Input,
6
+ OnChanges,
7
+ OnInit,
8
+ Output,
9
+ SimpleChanges,
10
+ } from '@angular/core'
11
+ import { FormControl } from '@angular/forms'
12
+ import { CheckToggleComponent } from '../../../../../../../../../libs/ui/inputs/src'
13
+ import { TranslateModule } from '@ngx-translate/core'
14
+ import { OPEN_DATA_LICENSES } from './../../../../fields.config'
15
+ import { Subscription } from 'rxjs'
16
+
17
+ @Component({
18
+ selector: 'gn-ui-form-field-open-data',
19
+ templateUrl: './form-field-open-data.component.html',
20
+ styleUrls: ['./form-field-open-data.component.css'],
21
+ standalone: true,
22
+ imports: [CheckToggleComponent, TranslateModule],
23
+ changeDetection: ChangeDetectionStrategy.OnPush,
24
+ })
25
+ export class FormFieldOpenDataComponent implements OnInit {
26
+ @Input() control: FormControl
27
+ value = false
28
+ @Output() visibilityChange = new EventEmitter<boolean>()
29
+ subscription: Subscription
30
+
31
+ get config() {
32
+ return OPEN_DATA_LICENSES
33
+ }
34
+
35
+ ngOnInit() {
36
+ this.initToggle()
37
+ this.subscription = new Subscription()
38
+
39
+ this.subscription.add(
40
+ this.control.valueChanges.subscribe((value) => {
41
+ this.value = this.config.includes(value[0].text)
42
+ this.visibilityChange.emit(this.value)
43
+ })
44
+ )
45
+ }
46
+
47
+ initToggle() {
48
+ this.value = this.config.includes(this.control.value[0].text)
49
+ this.visibilityChange.emit(this.value)
50
+ }
51
+
52
+ onOpenDataToggled(boolean) {
53
+ if (boolean) {
54
+ this.control.setValue([{ text: this.config[0] }])
55
+ }
56
+ this.value = !this.value
57
+ this.visibilityChange.emit(boolean)
58
+ }
59
+ }
@@ -0,0 +1,5 @@
1
+ <gn-ui-overview-upload
2
+ [metadataUuid]="metadataUuid"
3
+ [formControl]="control"
4
+ (overviewChange)="handleOverviewChange($event)"
5
+ ></gn-ui-overview-upload>
@@ -0,0 +1,22 @@
1
+ import { CommonModule } from '@angular/common'
2
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
3
+ import { OverviewUploadComponent } from '../../../overview-upload/overview-upload.component'
4
+ import { FormControl } from '@angular/forms'
5
+ import { GraphicOverview } from '../../../../../../../../../libs/common/domain/src/lib/model/record'
6
+
7
+ @Component({
8
+ selector: 'gn-ui-form-field-overviews',
9
+ templateUrl: './form-field-overviews.component.html',
10
+ styleUrls: ['./form-field-overviews.component.css'],
11
+ changeDetection: ChangeDetectionStrategy.OnPush,
12
+ standalone: true,
13
+ imports: [CommonModule, OverviewUploadComponent],
14
+ })
15
+ export class FormFieldOverviewsComponent {
16
+ @Input() metadataUuid: string
17
+ @Input() control!: FormControl
18
+
19
+ handleOverviewChange(overView: GraphicOverview | null) {
20
+ this.control.setValue(overView ? [overView] : [])
21
+ }
22
+ }
@@ -62,9 +62,9 @@ export class FormFieldTemporalExtentsComponent implements OnInit, OnDestroy {
62
62
  )
63
63
  }
64
64
 
65
- onElementsChange(elements: any) {
65
+ onElementsChange(elements: { inputs: Record<string, unknown> }[]) {
66
66
  this.array.clear({ emitEvent: false })
67
- elements.forEach((e: any, i: number) =>
67
+ elements.forEach((e, i) =>
68
68
  this.array.push(e.inputs.control, {
69
69
  emitEvent: i === elements.length - 1,
70
70
  })
@@ -95,7 +95,7 @@ export class FormFieldTemporalExtentsComponent implements OnInit, OnDestroy {
95
95
 
96
96
  private resetValueFromInput(value) {
97
97
  this.array.clear({ emitEvent: false })
98
- this.elements = []
98
+ let newElements = []
99
99
  value.forEach((v: any) => {
100
100
  if ('start' in v && 'end' in v) {
101
101
  const rangeControl = new FormControl({
@@ -103,8 +103,8 @@ export class FormFieldTemporalExtentsComponent implements OnInit, OnDestroy {
103
103
  end: v.end,
104
104
  })
105
105
  this.array.push(rangeControl, { emitEvent: false })
106
- this.elements = [
107
- ...this.elements,
106
+ newElements = [
107
+ ...newElements,
108
108
  {
109
109
  component: FormFieldTemporalExtentsRangeComponent,
110
110
  inputs: {
@@ -115,8 +115,8 @@ export class FormFieldTemporalExtentsComponent implements OnInit, OnDestroy {
115
115
  } else {
116
116
  const dateControl = new FormControl({ start: v.start })
117
117
  this.array.push(dateControl, { emitEvent: false })
118
- this.elements = [
119
- ...this.elements,
118
+ newElements = [
119
+ ...newElements,
120
120
  {
121
121
  component: FormFieldTemporalExtentsDateComponent,
122
122
  inputs: {
@@ -126,5 +126,6 @@ export class FormFieldTemporalExtentsComponent implements OnInit, OnDestroy {
126
126
  ]
127
127
  }
128
128
  })
129
+ this.elements = newElements
129
130
  }
130
131
  }
@@ -1,11 +1,17 @@
1
- <div class="flex flex-col h-full">
1
+ <ng-container *ngIf="isOpenData">
2
+ <gn-ui-form-field-open-data
3
+ [control]="formControl"
4
+ (visibilityChange)="onVisibilityChange($event)"
5
+ ></gn-ui-form-field-open-data>
6
+ </ng-container>
7
+ <div class="flex flex-col h-full" *ngIf="!isHidden">
2
8
  <ng-container *ngIf="withoutWrapper; else withGenericWrapper">
3
9
  <ng-container *ngTemplateOutlet="fieldContent"></ng-container>
4
10
  </ng-container>
5
11
  <ng-template #withGenericWrapper>
6
12
  <gn-ui-form-field-wrapper
7
- [label]="config.labelKey | translate"
8
- [hint]="config.hintKey | translate"
13
+ [label]="config.labelKey! | translate"
14
+ [hint]="config.hintKey! | translate"
9
15
  >
10
16
  <ng-container *ngTemplateOutlet="fieldContent"></ng-container>
11
17
  </gn-ui-form-field-wrapper>
@@ -15,14 +21,14 @@
15
21
  <ng-template #fieldContent>
16
22
  <ng-container *ngIf="isTitle">
17
23
  <div class="flex justify-between items-center gap-3">
18
- <h2
24
+ <span
19
25
  #titleInput
20
- class="grow text-3xl font-normal"
26
+ class="grow font-title text-3xl font-normal"
21
27
  [gnUiEditableLabel]="true"
22
28
  (editableLabelChanged)="formControl.setValue($event)"
23
29
  >
24
30
  {{ formControl.value }}
25
- </h2>
31
+ </span>
26
32
  <span
27
33
  class="material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer"
28
34
  (click)="focusTitleInput()"
@@ -30,7 +36,7 @@
30
36
  >
31
37
  <span
32
38
  class="material-symbols-outlined gn-ui-icon-small m-2"
33
- [matTooltip]="config.hintKey | translate"
39
+ [matTooltip]="config.hintKey! | translate"
34
40
  matTooltipPosition="above"
35
41
  >
36
42
  help
@@ -41,14 +47,14 @@
41
47
  <gn-ui-form-field-rich
42
48
  class="h-[8rem]"
43
49
  [control]="formControl"
44
- [label]="config.labelKey | translate"
45
- [hint]="config.hintKey | translate"
50
+ [label]="config.labelKey! | translate"
51
+ [hint]="config.hintKey! | translate"
46
52
  ></gn-ui-form-field-rich>
47
53
  </ng-container>
48
54
  <ng-container *ngIf="isLicenses">
49
55
  <gn-ui-form-field-license
50
56
  [control]="formControl"
51
- [label]="config.labelKey | translate"
57
+ [label]="config.labelKey! | translate"
52
58
  ></gn-ui-form-field-license>
53
59
  </ng-container>
54
60
  <ng-container *ngIf="isResourceUpdated">
@@ -76,9 +82,20 @@
76
82
  <ng-container *ngIf="isSpatialExtentField">
77
83
  <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>
78
84
  </ng-container>
85
+ <ng-container *ngIf="isGraphicOverview">
86
+ <gn-ui-form-field-overviews
87
+ [control]="formControl"
88
+ [metadataUuid]="metadataUuid$ | async"
89
+ ></gn-ui-form-field-overviews>
90
+ </ng-container>
79
91
  <ng-container *ngIf="isKeywords">
80
92
  <gn-ui-form-field-keywords
81
93
  [control]="formControl"
82
94
  ></gn-ui-form-field-keywords>
83
95
  </ng-container>
96
+ <ng-container *ngIf="isContactsForResource">
97
+ <gn-ui-form-field-contacts-for-resource
98
+ [control]="formControl"
99
+ ></gn-ui-form-field-contacts-for-resource>
100
+ </ng-container>
84
101
  </ng-template>
@@ -3,6 +3,7 @@ import {
3
3
  ChangeDetectionStrategy,
4
4
  Component,
5
5
  ElementRef,
6
+ EventEmitter,
6
7
  Input,
7
8
  Output,
8
9
  ViewChild,
@@ -25,10 +26,15 @@ import { FormFieldObjectComponent } from './form-field-object/form-field-object.
25
26
  import { FormFieldRichComponent } from './form-field-rich/form-field-rich.component'
26
27
  import { FormFieldSimpleComponent } from './form-field-simple/form-field-simple.component'
27
28
  import { FormFieldSpatialExtentComponent } from './form-field-spatial-extent/form-field-spatial-extent.component'
28
- import { FormFieldConfig } from './form-field.model'
29
29
  import { FormFieldUpdateFrequencyComponent } from './form-field-update-frequency/form-field-update-frequency.component'
30
30
  import { CatalogRecordKeys } from '../../../../../../../../libs/common/domain/src/lib/model/record'
31
31
  import { FormFieldKeywordsComponent } from './form-field-keywords/form-field-keywords.component'
32
+ import { FormFieldOverviewsComponent } from './form-field-overviews/form-field-overviews.component'
33
+ import { map, take } from 'rxjs/operators'
34
+ import { EditorFacade } from '../../../+state/editor.facade'
35
+ import { FormFieldConfig } from '../../../models'
36
+ import { FormFieldContactsForResourceComponent } from './form-field-contacts-for-resource/form-field-contacts-for-resource.component'
37
+ import { FormFieldOpenDataComponent } from './form-field-open-data/form-field-open-data.component'
32
38
 
33
39
  @Component({
34
40
  selector: 'gn-ui-form-field',
@@ -55,6 +61,9 @@ import { FormFieldKeywordsComponent } from './form-field-keywords/form-field-key
55
61
  FormFieldArrayComponent,
56
62
  FormFieldKeywordsComponent,
57
63
  TranslateModule,
64
+ FormFieldOverviewsComponent,
65
+ FormFieldContactsForResourceComponent,
66
+ FormFieldOpenDataComponent,
58
67
  ],
59
68
  })
60
69
  export class FormFieldComponent {
@@ -65,13 +74,20 @@ export class FormFieldComponent {
65
74
  emitEvent: false,
66
75
  })
67
76
  }
77
+
68
78
  @Output() valueChange: Observable<unknown>
79
+ isHidden = false
69
80
 
70
81
  @ViewChild('titleInput') titleInput: ElementRef
71
82
 
83
+ metadataUuid$ = this.facade.record$.pipe(
84
+ take(1),
85
+ map((record) => record.uniqueIdentifier)
86
+ )
87
+
72
88
  formControl = new FormControl()
73
89
 
74
- constructor() {
90
+ constructor(private facade: EditorFacade) {
75
91
  this.valueChange = this.formControl.valueChanges
76
92
  }
77
93
 
@@ -79,6 +95,10 @@ export class FormFieldComponent {
79
95
  this.titleInput.nativeElement.children[0].focus()
80
96
  }
81
97
 
98
+ onVisibilityChange(visibility: boolean) {
99
+ this.isHidden = visibility
100
+ }
101
+
82
102
  get isTitle() {
83
103
  return this.model === 'title'
84
104
  }
@@ -100,6 +120,9 @@ export class FormFieldComponent {
100
120
  get isSpatialExtentField() {
101
121
  return this.model === 'spatialExtents'
102
122
  }
123
+ get isGraphicOverview() {
124
+ return this.model === 'overviews'
125
+ }
103
126
  get isSimpleField() {
104
127
  return this.model === 'uniqueIdentifier' || this.model === 'recordUpdated'
105
128
  }
@@ -109,8 +132,15 @@ export class FormFieldComponent {
109
132
  get isKeywords() {
110
133
  return this.model === 'keywords'
111
134
  }
135
+ get isContactsForResource() {
136
+ return this.model === 'contactsForResource'
137
+ }
112
138
 
113
139
  get withoutWrapper() {
114
140
  return this.model === 'title' || this.model === 'abstract'
115
141
  }
142
+
143
+ get isOpenData() {
144
+ return this.model === 'licenses'
145
+ }
116
146
  }