geonetwork-ui 2.4.0-dev.503109c9 → 2.4.0-dev.575f30f2

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 (347) hide show
  1. package/esm2022/libs/api/metadata-converter/src/index.mjs +2 -1
  2. package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +10 -3
  3. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.mjs +5 -5
  4. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.mjs +7 -4
  5. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.mjs +10 -7
  6. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +7 -14
  7. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +6 -6
  8. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +28 -18
  9. package/esm2022/libs/api/metadata-converter/src/lib/xml-utils.mjs +18 -2
  10. package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +78 -39
  11. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +41 -7
  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/dataviz/src/lib/chart-view/chart-view.component.mjs +1 -1
  16. package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +1 -1
  17. package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +1 -1
  18. package/esm2022/libs/feature/editor/src/index.mjs +2 -1
  19. package/esm2022/libs/feature/editor/src/lib/components/contact-card/contact-card.component.mjs +4 -16
  20. package/esm2022/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.mjs +4 -2
  21. package/esm2022/libs/feature/editor/src/lib/components/import-record/import-record.component.mjs +93 -0
  22. package/esm2022/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.mjs +71 -0
  23. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.mjs +11 -29
  24. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.mjs +19 -0
  25. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +23 -10
  26. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +3 -3
  27. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.mjs +148 -0
  28. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.mjs +86 -11
  29. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +4 -8
  30. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +36 -7
  31. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.mjs +35 -59
  32. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +3 -3
  33. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +12 -5
  34. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/index.mjs +2 -2
  35. package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +3 -3
  36. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +34 -6
  37. package/esm2022/libs/feature/editor/src/lib/models/editor-config.model.mjs +1 -1
  38. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.mjs +2 -2
  39. package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +1 -1
  40. package/esm2022/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.mjs +1 -1
  41. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +1 -1
  42. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +4 -2
  43. package/esm2022/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.mjs +3 -3
  44. package/esm2022/libs/ui/elements/src/index.mjs +2 -2
  45. package/esm2022/libs/ui/elements/src/lib/download-item/download-item.component.mjs +2 -2
  46. package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +1 -1
  47. package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +2 -2
  48. package/esm2022/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.mjs +6 -6
  49. package/esm2022/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.mjs +2 -2
  50. package/esm2022/libs/ui/inputs/src/index.mjs +5 -1
  51. package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +7 -4
  52. package/esm2022/libs/ui/inputs/src/lib/badge/badge.component.mjs +5 -3
  53. package/esm2022/libs/ui/inputs/src/lib/button/button.component.mjs +8 -1
  54. package/esm2022/libs/ui/inputs/src/lib/date-picker/date-picker.component.mjs +11 -4
  55. package/esm2022/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.mjs +9 -3
  56. package/esm2022/libs/ui/inputs/src/lib/file-input/file-input.component.mjs +87 -0
  57. package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +5 -4
  58. package/esm2022/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.mjs +4 -4
  59. package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +4 -3
  60. package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +3 -3
  61. package/esm2022/libs/ui/layout/src/index.mjs +3 -1
  62. package/esm2022/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.mjs +5 -3
  63. package/esm2022/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.mjs +29 -0
  64. package/esm2022/libs/ui/layout/src/lib/sortable-list/sortable-list.component.mjs +43 -0
  65. package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +3 -3
  66. package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +1 -1
  67. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +1 -1
  68. package/esm2022/libs/util/shared/src/lib/services/theme.service.mjs +2 -1
  69. package/esm2022/libs/util/shared/src/lib/utils/bytes-convert.mjs +4 -1
  70. package/esm2022/translations/de.json +20 -0
  71. package/esm2022/translations/en.json +20 -0
  72. package/esm2022/translations/es.json +20 -0
  73. package/esm2022/translations/fr.json +21 -1
  74. package/esm2022/translations/it.json +20 -0
  75. package/esm2022/translations/nl.json +20 -0
  76. package/esm2022/translations/pt.json +20 -0
  77. package/fesm2022/geonetwork-ui.mjs +3136 -2523
  78. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  79. package/libs/api/metadata-converter/src/index.d.ts +1 -0
  80. package/libs/api/metadata-converter/src/index.d.ts.map +1 -1
  81. package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts +3 -3
  82. package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
  83. package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts +2 -2
  84. package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts.map +1 -1
  85. package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts +1 -1
  86. package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts.map +1 -1
  87. package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts.map +1 -1
  88. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +4 -5
  89. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
  90. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +7 -6
  91. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  92. package/libs/api/metadata-converter/src/lib/xml-utils.d.ts +6 -0
  93. package/libs/api/metadata-converter/src/lib/xml-utils.d.ts.map +1 -1
  94. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +12 -7
  95. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
  96. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +21 -2
  97. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  98. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +6 -6
  99. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  100. package/libs/common/domain/src/lib/platform.service.interface.d.ts +15 -0
  101. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  102. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +7 -0
  103. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts.map +1 -1
  104. package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts +2 -2
  105. package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
  106. package/libs/feature/dataviz/src/lib/service/data.service.d.ts +6 -6
  107. package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
  108. package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts +3 -3
  109. package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts.map +1 -1
  110. package/libs/feature/editor/src/index.d.ts +1 -0
  111. package/libs/feature/editor/src/index.d.ts.map +1 -1
  112. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts +1 -5
  113. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts.map +1 -1
  114. package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts +2 -1
  115. package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts.map +1 -1
  116. package/libs/feature/editor/src/lib/components/import-record/import-record.component.d.ts +33 -0
  117. package/libs/feature/editor/src/lib/components/import-record/import-record.component.d.ts.map +1 -0
  118. package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts +15 -0
  119. package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts.map +1 -0
  120. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts +2 -5
  121. 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 -1
  122. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.d.ts +9 -0
  123. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-date-updated/form-field-date-updated.component.d.ts.map +1 -0
  124. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts +5 -2
  125. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts.map +1 -1
  126. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.d.ts +35 -0
  127. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.d.ts.map +1 -0
  128. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts +20 -2
  129. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts.map +1 -1
  130. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts +1 -3
  131. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -1
  132. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts +7 -2
  133. 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
  134. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts +9 -15
  135. 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
  136. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +5 -3
  137. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  138. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts +1 -1
  139. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts.map +1 -1
  140. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts +3 -2
  141. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -1
  142. package/libs/feature/editor/src/lib/fields.config.d.ts +9 -1
  143. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  144. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts +6 -0
  145. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts.map +1 -1
  146. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts +5 -5
  147. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts.map +1 -1
  148. package/libs/feature/record/src/lib/data-view/data-view.component.d.ts +3 -3
  149. package/libs/feature/record/src/lib/data-view/data-view.component.d.ts.map +1 -1
  150. package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts +2 -2
  151. package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts.map +1 -1
  152. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +2 -2
  153. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
  154. package/libs/feature/record/src/lib/state/mdview.facade.d.ts +7 -7
  155. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  156. package/libs/ui/elements/src/index.d.ts +1 -1
  157. package/libs/ui/elements/src/index.d.ts.map +1 -1
  158. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts +2 -2
  159. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts.map +1 -1
  160. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +7 -7
  161. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts.map +1 -1
  162. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +2 -2
  163. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
  164. package/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.d.ts +2 -2
  165. package/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.d.ts.map +1 -1
  166. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +1 -1
  167. package/libs/ui/inputs/src/index.d.ts +4 -0
  168. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  169. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
  170. package/libs/ui/inputs/src/lib/badge/badge.component.d.ts.map +1 -1
  171. package/libs/ui/inputs/src/lib/button/button.component.d.ts +1 -1
  172. package/libs/ui/inputs/src/lib/button/button.component.d.ts.map +1 -1
  173. package/libs/ui/inputs/src/lib/date-picker/date-picker.component.d.ts.map +1 -1
  174. package/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.d.ts.map +1 -1
  175. package/libs/ui/inputs/src/lib/file-input/file-input.component.d.ts +24 -0
  176. package/libs/ui/inputs/src/lib/file-input/file-input.component.d.ts.map +1 -0
  177. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +1 -1
  178. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -1
  179. package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts +0 -1
  180. package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts.map +1 -1
  181. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
  182. package/libs/ui/layout/src/index.d.ts +2 -0
  183. package/libs/ui/layout/src/index.d.ts.map +1 -1
  184. package/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.d.ts +2 -2
  185. package/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.d.ts.map +1 -1
  186. package/libs/ui/layout/src/lib/interactive-table/interactive-table-column/interactive-table-column.component.d.ts +1 -1
  187. package/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.d.ts +20 -0
  188. package/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.d.ts.map +1 -0
  189. package/libs/ui/layout/src/lib/sortable-list/sortable-list.component.d.ts +14 -0
  190. package/libs/ui/layout/src/lib/sortable-list/sortable-list.component.d.ts.map +1 -0
  191. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +1 -1
  192. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
  193. package/libs/util/shared/src/lib/links/link-classifier.service.d.ts +3 -3
  194. package/libs/util/shared/src/lib/links/link-classifier.service.d.ts.map +1 -1
  195. package/libs/util/shared/src/lib/links/link-utils.d.ts +6 -6
  196. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  197. package/libs/util/shared/src/lib/services/theme.service.d.ts.map +1 -1
  198. package/libs/util/shared/src/lib/utils/bytes-convert.d.ts +2 -1
  199. package/libs/util/shared/src/lib/utils/bytes-convert.d.ts.map +1 -1
  200. package/package.json +1 -1
  201. package/src/libs/api/metadata-converter/src/index.ts +1 -0
  202. package/src/libs/api/metadata-converter/src/lib/fixtures/generic.records.ts +1 -1
  203. package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +1 -1
  204. package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +1 -1
  205. package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +1 -1
  206. package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +18 -16
  207. package/src/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.ts +4 -4
  208. package/src/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.ts +12 -4
  209. package/src/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.ts +14 -8
  210. package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +4 -12
  211. package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +13 -15
  212. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +48 -36
  213. package/src/libs/api/metadata-converter/src/lib/xml-utils.ts +20 -1
  214. package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +132 -68
  215. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +47 -3
  216. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +7 -7
  217. package/src/libs/common/domain/src/lib/platform.service.interface.ts +26 -0
  218. package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +10 -0
  219. package/src/libs/common/fixtures/src/lib/link.fixtures.ts +216 -175
  220. package/src/libs/common/fixtures/src/lib/records.fixtures.ts +3 -3
  221. package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +3 -3
  222. package/src/libs/feature/dataviz/src/lib/service/data.service.ts +6 -6
  223. package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.ts +4 -4
  224. package/src/libs/feature/editor/src/index.ts +1 -0
  225. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.html +12 -24
  226. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.ts +1 -13
  227. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.ts +1 -0
  228. package/src/libs/feature/editor/src/lib/components/import-record/import-record.component.html +43 -0
  229. package/src/libs/feature/editor/src/lib/components/import-record/import-record.component.ts +129 -0
  230. package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.html +35 -0
  231. package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.ts +79 -0
  232. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.css +4 -0
  233. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.html +13 -23
  234. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.ts +7 -44
  235. package/src/libs/feature/editor/src/lib/components/record-form/form-field/{form-field-resource-updated/form-field-resource-updated.component.ts → form-field-date-updated/form-field-date-updated.component.ts} +4 -4
  236. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.html +3 -2
  237. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.ts +35 -3
  238. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.css +8 -0
  239. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.html +34 -0
  240. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.ts +182 -0
  241. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.html +11 -5
  242. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.ts +93 -4
  243. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.html +13 -6
  244. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +0 -9
  245. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +7 -2
  246. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.ts +62 -6
  247. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.css +4 -0
  248. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.html +23 -3
  249. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.ts +37 -69
  250. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.css +4 -0
  251. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.html +16 -14
  252. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +27 -20
  253. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +10 -3
  254. package/src/libs/feature/editor/src/lib/components/record-form/form-field/index.ts +1 -1
  255. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +31 -29
  256. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.ts +2 -1
  257. package/src/libs/feature/editor/src/lib/fields.config.ts +37 -5
  258. package/src/libs/feature/editor/src/lib/models/editor-config.model.ts +12 -0
  259. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.ts +7 -7
  260. package/src/libs/feature/record/src/lib/data-view/data-view.component.ts +3 -3
  261. package/src/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.ts +2 -2
  262. package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +2 -2
  263. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +5 -1
  264. package/src/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.html +1 -0
  265. package/src/libs/ui/elements/src/index.ts +1 -1
  266. package/src/libs/ui/elements/src/lib/download-item/download-item.component.ts +4 -4
  267. package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +7 -7
  268. package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +3 -3
  269. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.html +13 -20
  270. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.ts +1 -1
  271. package/src/libs/ui/elements/src/lib/markdown-parser/markdown-parser.component.css +5 -0
  272. package/src/libs/ui/inputs/src/index.ts +4 -0
  273. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.css +25 -18
  274. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.html +38 -24
  275. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +4 -1
  276. package/src/libs/ui/inputs/src/lib/badge/badge.component.html +12 -3
  277. package/src/libs/ui/inputs/src/lib/badge/badge.component.ts +2 -1
  278. package/src/libs/ui/inputs/src/lib/button/button.component.ts +15 -1
  279. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.css +7 -2
  280. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.html +13 -6
  281. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.ts +7 -1
  282. package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.css +7 -2
  283. package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.html +27 -23
  284. package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.ts +7 -1
  285. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.css +4 -0
  286. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.html +7 -3
  287. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.ts +2 -1
  288. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.css +4 -0
  289. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +30 -22
  290. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +2 -1
  291. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.css +4 -3
  292. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.html +0 -1
  293. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.ts +1 -2
  294. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +1 -1
  295. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +1 -1
  296. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.html +1 -1
  297. package/src/libs/ui/layout/src/index.ts +2 -0
  298. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.html +8 -3
  299. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.ts +4 -3
  300. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.css +0 -0
  301. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.html +15 -0
  302. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.ts +44 -0
  303. package/src/libs/ui/layout/src/lib/sortable-list/sortable-list.component.html +37 -0
  304. package/src/libs/ui/{elements → layout}/src/lib/sortable-list/sortable-list.component.ts +13 -16
  305. package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +4 -2
  306. package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +4 -3
  307. package/src/libs/util/shared/src/lib/links/link-utils.ts +6 -6
  308. package/src/libs/util/shared/src/lib/services/theme.service.ts +1 -0
  309. package/src/libs/util/shared/src/lib/utils/bytes-convert.ts +4 -1
  310. package/tailwind.base.config.js +1 -0
  311. package/tailwind.base.css +35 -4
  312. package/translations/de.json +20 -0
  313. package/translations/en.json +20 -0
  314. package/translations/es.json +20 -0
  315. package/translations/fr.json +21 -1
  316. package/translations/it.json +20 -0
  317. package/translations/nl.json +20 -0
  318. package/translations/pt.json +20 -0
  319. package/translations/sk.json +20 -0
  320. package/esm2022/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.mjs +0 -96
  321. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.mjs +0 -19
  322. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.mjs +0 -17
  323. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.mjs +0 -17
  324. package/esm2022/libs/ui/elements/src/lib/sortable-list/sortable-list.component.mjs +0 -39
  325. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts +0 -27
  326. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts.map +0 -1
  327. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts +0 -9
  328. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts.map +0 -1
  329. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.d.ts +0 -8
  330. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.d.ts.map +0 -1
  331. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.d.ts +0 -8
  332. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.d.ts.map +0 -1
  333. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts +0 -17
  334. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts.map +0 -1
  335. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +0 -9
  336. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +0 -113
  337. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.html +0 -7
  338. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.ts +0 -16
  339. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.html +0 -13
  340. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.ts +0 -16
  341. package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.html +0 -29
  342. /package/src/libs/feature/editor/src/lib/components/{overview-upload/overview-upload.component.css → import-record/import-record.component.css} +0 -0
  343. /package/src/libs/feature/editor/src/lib/components/{record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.css → online-resource-card/online-resource-card.component.css} +0 -0
  344. /package/src/libs/feature/editor/src/lib/components/record-form/form-field/{form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.css → form-field-date-updated/form-field-date-updated.component.css} +0 -0
  345. /package/src/libs/feature/editor/src/lib/components/record-form/form-field/{form-field-resource-updated/form-field-resource-updated.component.html → form-field-date-updated/form-field-date-updated.component.html} +0 -0
  346. /package/src/libs/feature/editor/src/lib/components/record-form/form-field/{form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.css → form-field-online-link-resources/form-field-online-link-resources.component.css} +0 -0
  347. /package/src/libs/ui/{elements → layout}/src/lib/sortable-list/sortable-list.component.css +0 -0
@@ -40,7 +40,7 @@ import {
40
40
  } from 'rxjs/operators'
41
41
  import { MdViewFacade } from '../state/mdview.facade'
42
42
  import { DataService } from '../../../../../../libs/feature/dataviz/src'
43
- import { DatasetDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'
43
+ import { DatasetOnlineResource } from '../../../../../../libs/common/domain/src/lib/model/record'
44
44
 
45
45
  @Component({
46
46
  selector: 'gn-ui-map-view',
@@ -183,7 +183,7 @@ export class MapViewComponent implements OnInit, OnDestroy {
183
183
  }
184
184
 
185
185
  getLayerFromLink(
186
- link: DatasetDistribution
186
+ link: DatasetOnlineResource
187
187
  ): Observable<MapContextLayerModel> {
188
188
  if (link.type === 'service' && link.accessServiceProtocol === 'wms') {
189
189
  return of({
@@ -63,7 +63,11 @@ export class MdViewFacade {
63
63
  chartConfig$ = this.store.pipe(select(MdViewSelectors.getChartConfig))
64
64
 
65
65
  allLinks$ = this.metadata$.pipe(
66
- map((record) => ('distributions' in record ? record.distributions : []))
66
+ map((record) =>
67
+ record.kind === 'dataset' && 'onlineResources' in record
68
+ ? record.onlineResources
69
+ : []
70
+ )
67
71
  )
68
72
 
69
73
  apiLinks$ = this.allLinks$.pipe(
@@ -8,4 +8,5 @@
8
8
  [value]="searchInputValue$ | async"
9
9
  [preventCompleteOnSelection]="true"
10
10
  [autoFocus]="autoFocus"
11
+ [allowSubmit]="true"
11
12
  ></gn-ui-autocomplete>
@@ -19,7 +19,7 @@ export * from './lib/pagination-buttons/pagination-buttons.component'
19
19
  export * from './lib/pagination/pagination.component'
20
20
  export * from './lib/record-api-form/record-api-form.component'
21
21
  export * from './lib/related-record-card/related-record-card.component'
22
- export * from './lib/sortable-list/sortable-list.component'
23
22
  export * from './lib/thumbnail/thumbnail.component'
24
23
  export * from './lib/ui-elements.module'
25
24
  export * from './lib/user-preview/user-preview.component'
25
+ export * from './lib/user-feedback-item/user-feedback-item.component'
@@ -1,11 +1,11 @@
1
1
  import {
2
- Component,
3
2
  ChangeDetectionStrategy,
3
+ Component,
4
+ EventEmitter,
4
5
  Input,
5
6
  Output,
6
- EventEmitter,
7
7
  } from '@angular/core'
8
- import { DatasetDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'
8
+ import { DatasetOnlineResource } from '../../../../../../libs/common/domain/src/lib/model/record'
9
9
 
10
10
  @Component({
11
11
  selector: 'gn-ui-download-item',
@@ -14,7 +14,7 @@ import { DatasetDistribution } from '../../../../../../libs/common/domain/src/li
14
14
  changeDetection: ChangeDetectionStrategy.OnPush,
15
15
  })
16
16
  export class DownloadItemComponent {
17
- @Input() link: DatasetDistribution
17
+ @Input() link: DatasetOnlineResource
18
18
  @Input() color: string
19
19
  @Input() format: string
20
20
  @Input() isFromWfs: boolean
@@ -2,7 +2,7 @@ import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
2
2
  import { TranslateService } from '@ngx-translate/core'
3
3
  import { marker } from '@biesbjerg/ngx-translate-extract-marker'
4
4
  import { getBadgeColor, getFileFormat } from '../../../../../../libs/util/shared/src'
5
- import { DatasetDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'
5
+ import { DatasetOnlineResource } from '../../../../../../libs/common/domain/src/lib/model/record'
6
6
 
7
7
  marker('datahub.search.filter.all')
8
8
  marker('datahub.search.filter.others')
@@ -19,11 +19,11 @@ type FilterFormat = typeof FILTER_FORMATS[number]
19
19
  export class DownloadsListComponent {
20
20
  constructor(private translateService: TranslateService) {}
21
21
 
22
- @Input() links: DatasetDistribution[]
22
+ @Input() links: DatasetOnlineResource[]
23
23
 
24
24
  activeFilterFormats: FilterFormat[] = ['all']
25
25
 
26
- get filteredLinks(): DatasetDistribution[] {
26
+ get filteredLinks(): DatasetOnlineResource[] {
27
27
  return this.links.filter((link) =>
28
28
  this.activeFilterFormats.some((format) =>
29
29
  this.isLinkOfFormat(link, format)
@@ -68,7 +68,7 @@ export class DownloadsListComponent {
68
68
  return format
69
69
  }
70
70
 
71
- isLinkOfFormat(link: DatasetDistribution, format: FilterFormat): boolean {
71
+ isLinkOfFormat(link: DatasetOnlineResource, format: FilterFormat): boolean {
72
72
  if (format === 'all') {
73
73
  return true
74
74
  }
@@ -86,15 +86,15 @@ export class DownloadsListComponent {
86
86
  return getFileFormat(link).includes(format)
87
87
  }
88
88
 
89
- getLinkFormat(link: DatasetDistribution) {
89
+ getLinkFormat(link: DatasetOnlineResource) {
90
90
  return getFileFormat(link)
91
91
  }
92
92
 
93
- getLinkColor(link: DatasetDistribution) {
93
+ getLinkColor(link: DatasetOnlineResource) {
94
94
  return getBadgeColor(getFileFormat(link))
95
95
  }
96
96
 
97
- isFromWfs(link: DatasetDistribution) {
97
+ isFromWfs(link: DatasetOnlineResource) {
98
98
  return link.type === 'download' && link.accessServiceProtocol === 'wfs'
99
99
  }
100
100
  }
@@ -1,5 +1,5 @@
1
- import { Component, ChangeDetectionStrategy, Input } from '@angular/core'
2
- import { DatasetDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
2
+ import { DatasetOnlineResource } from '../../../../../../libs/common/domain/src/lib/model/record'
3
3
  import { MatIconModule } from '@angular/material/icon'
4
4
  import { CommonModule } from '@angular/common'
5
5
 
@@ -12,7 +12,7 @@ import { CommonModule } from '@angular/common'
12
12
  imports: [CommonModule, MatIconModule],
13
13
  })
14
14
  export class LinkCardComponent {
15
- @Input() link: DatasetDistribution
15
+ @Input() link: DatasetOnlineResource
16
16
  @Input() compact = false
17
17
 
18
18
  get title() {
@@ -1,21 +1,14 @@
1
- <div class="h-full flex flex-col">
2
- <p
3
- *ngIf="helperText"
4
- class="flex-none mb-2 font-medium text-sm text-gray-900"
5
- >
6
- {{ helperText }}
7
- </p>
8
- <div class="flex-1" [hidden]="preview">
9
- <gn-ui-text-area
10
- [placeholder]="placeholder"
11
- [value]="textContent"
12
- (valueChange)="textContentChangedHandler($event)"
13
- ></gn-ui-text-area>
14
- </div>
15
- <div
16
- class="flex-1 border border-gray-800 rounded overflow-y-scroll"
17
- [hidden]="!preview"
18
- >
19
- <gn-ui-markdown-parser [textContent]="textContent"></gn-ui-markdown-parser>
20
- </div>
1
+ <gn-ui-text-area
2
+ [hidden]="preview"
3
+ [placeholder]="placeholder"
4
+ [value]="textContent"
5
+ [extraClass]="textAreaExtraClass + ' !leading-normal'"
6
+ (valueChange)="textContentChangedHandler($event)"
7
+ ></gn-ui-text-area>
8
+
9
+ <div
10
+ class="gn-ui-text-input border-gray-100 hover:border-gray-100"
11
+ [hidden]="!preview"
12
+ >
13
+ <gn-ui-markdown-parser [textContent]="textContent"></gn-ui-markdown-parser>
21
14
  </div>
@@ -32,9 +32,9 @@ import { MatTooltipModule } from '@angular/material/tooltip'
32
32
  })
33
33
  export class MarkdownEditorComponent {
34
34
  @Input() preview = false
35
- @Input() helperText?: string
36
35
  @Input() placeholder: string
37
36
  @Input() textContent: string
37
+ @Input() textAreaExtraClass = ''
38
38
  @Output() textContentChanged: EventEmitter<string> =
39
39
  new EventEmitter<string>()
40
40
 
@@ -29,6 +29,11 @@
29
29
  @apply text-title font-title font-bold;
30
30
  }
31
31
 
32
+ /** No margin for first child/heading, that cannot be detected by getBoundingClientRect() **/
33
+ :host ::ng-deep .markdown-body :first-child {
34
+ margin-top: 0;
35
+ }
36
+
32
37
  :host ::ng-deep .markdown-body h1 {
33
38
  margin: 0.67em 0;
34
39
  padding-bottom: 0.3em;
@@ -19,6 +19,10 @@ export * from './lib/star-toggle/star-toggle.component'
19
19
  export * from './lib/text-area/text-area.component'
20
20
  export * from './lib/text-input/text-input.component'
21
21
  export * from './lib/ui-inputs.module'
22
+ export * from './lib/url-input/url-input.component'
22
23
  export * from './lib/viewport-intersector/viewport-intersector.component'
23
24
  export * from './lib/previous-next-buttons/previous-next-buttons.component'
24
25
  export * from './lib/switch-toggle/switch-toggle.component'
26
+ export * from './lib/file-input/file-input.component'
27
+ export * from './lib/image-input/image-input.component'
28
+ export * from './lib/url-input/url-input.component'
@@ -1,28 +1,35 @@
1
- :host {
2
- --input-height: 3.5em;
1
+ span {
2
+ --icon-padding: var(--gn-ui-text-input-border-size, 2px);
3
+ --icon-width: calc(var(--gn-ui-text-input-padding, 0.6em) * 2 + 1.25em);
3
4
  }
4
- .clear-btn {
5
- width: var(--input-height);
6
- height: 100%;
5
+ /* this is because we don't want to change the popup alert font size */
6
+ span > *:not(gn-ui-popup-alert) {
7
+ font-size: var(--gn-ui-text-input-font-size, 1em);
7
8
  }
8
- .search-btn {
9
- width: var(--input-height);
10
- height: 100%;
11
- border-left-width: 0.1em;
9
+
10
+ input:placeholder-shown {
11
+ text-overflow: ellipsis;
12
+ }
13
+ gn-ui-button {
14
+ --gn-ui-button-rounded: 0;
15
+ --gn-ui-button-width: var(--icon-width);
16
+ --gn-ui-button-padding: 0;
17
+ font-size: 1em;
12
18
  }
13
19
  mat-icon {
14
20
  width: 100%;
15
21
  height: 100%;
16
- padding: 0.65em;
17
- font-size: 1.5em;
18
- }
19
- input {
20
- height: var(--input-height);
21
- padding: 1.05em;
22
- padding-right: calc(2 * var(--input-height));
22
+ font-size: calc(
23
+ 0.9em + 11px
24
+ ); /* this formula gives a good icon size across different font size values */
25
+ line-height: 0.8em;
26
+ display: grid;
27
+ align-items: center;
28
+ justify-content: center;
23
29
  }
24
- input:placeholder-shown {
25
- text-overflow: ellipsis;
30
+ gn-ui-button:last-of-type {
31
+ --gn-ui-button-rounded: 0 var(--gn-ui-text-input-rounded, 0.25em)
32
+ var(--gn-ui-text-input-rounded, 0.25em) 0;
26
33
  }
27
34
 
28
35
  .mat-mdc-option.suggestion.mat-mdc-option-active {
@@ -1,34 +1,47 @@
1
- <div class="relative">
1
+ <span class="w-full inline-block relative">
2
+ <div
3
+ class="absolute inset-y-[--icon-padding] left-[--icon-padding] w-[--icon-width] pointer-events-none"
4
+ *ngIf="!allowSubmit"
5
+ >
6
+ <mat-icon class="material-symbols-outlined text-primary"> search </mat-icon>
7
+ </div>
2
8
  <input
3
9
  #searchInput
4
10
  type="text"
5
- class="appearance-none focus:outline-white focus:outline-2 focus:outline-dotted focus:outline-offset-2 leading-tight rounded w-full text-black shadow-xl focus:shadow-[0_0_24px_0_rgba(21,40,184,0.09)]"
11
+ class="gn-ui-text-input"
12
+ [ngClass]="{
13
+ 'px-[--icon-width]': !allowSubmit
14
+ }"
6
15
  [placeholder]="placeholder"
7
16
  [formControl]="control"
8
17
  [matAutocomplete]="auto"
9
18
  (keyup.enter)="handleEnter(searchInput.value)"
10
19
  />
11
- <div class="flex flex-row absolute inset-y-0 right-0">
12
- <button
13
- type="button"
14
- class="text-primary-lightest hover:text-primary hover:bg-gray-50 transition-all duration-100 clear-btn"
15
- *ngIf="searchInput.value"
16
- aria-label="Clear"
17
- (click)="clear()"
18
- >
19
- <mat-icon class="material-symbols-outlined">close</mat-icon>
20
- </button>
21
- <button
22
- type="button"
23
- class="text-primary bg-white hover:text-primary-darkest hover:bg-gray-100 border-gray-300 hover:border-gray-500 transition-all duration-100 search-btn rounded-r"
24
- aria-label="Trigger search"
25
- *ngIf="allowSubmit"
26
- data-test="autocomplete-submit-btn"
27
- (click)="handleClickSearch()"
28
- >
29
- <mat-icon class="material-symbols-outlined">search</mat-icon>
30
- </button>
31
- </div>
20
+ <gn-ui-button
21
+ type="light"
22
+ extraClass="border-0 text-primary-lightest hover:text-primary focus:text-primary absolute inset-y-[--icon-padding] {{
23
+ allowSubmit
24
+ ? 'right-[calc(var(--icon-width)+var(--icon-padding))]'
25
+ : 'right-[--icon-padding]'
26
+ }}"
27
+ data-test="clear-btn"
28
+ *ngIf="searchInput.value"
29
+ aria-label="Clear"
30
+ (buttonClick)="clear()"
31
+ >
32
+ <mat-icon class="material-symbols-outlined">close</mat-icon>
33
+ </gn-ui-button>
34
+ <gn-ui-button
35
+ type="light"
36
+ extraClass="border-0 border-l-[1px] border-gray-300 hover:border-gray-500 text-primary hover:text-primary-darkest focus:text-primary-darkest absolute inset-y-[--icon-padding] right-[--icon-padding]"
37
+ aria-label="Trigger search"
38
+ *ngIf="allowSubmit"
39
+ data-test="autocomplete-submit-btn"
40
+ (buttonClick)="handleClickSearch()"
41
+ >
42
+ <mat-icon class="material-symbols-outlined">search</mat-icon>
43
+ </gn-ui-button>
44
+
32
45
  <gn-ui-popup-alert
33
46
  *ngIf="error"
34
47
  class="absolute mt-2 w-full top-[100%] left-0"
@@ -39,7 +52,8 @@
39
52
  <span translate>search.autocomplete.error</span>
40
53
  {{ error }}
41
54
  </gn-ui-popup-alert>
42
- </div>
55
+ </span>
56
+
43
57
  <mat-autocomplete
44
58
  #auto="matAutocomplete"
45
59
  (optionSelected)="handleSelection($event)"
@@ -36,6 +36,7 @@ import { MatIconModule } from '@angular/material/icon'
36
36
  import { PopupAlertComponent } from '../../../../../../libs/ui/widgets/src'
37
37
  import { CommonModule } from '@angular/common'
38
38
  import { TranslateModule } from '@ngx-translate/core'
39
+ import { ButtonComponent } from '../button/button.component'
39
40
 
40
41
  export type AutocompleteItem = unknown
41
42
 
@@ -52,6 +53,7 @@ export type AutocompleteItem = unknown
52
53
  CommonModule,
53
54
  TranslateModule,
54
55
  ReactiveFormsModule,
56
+ ButtonComponent,
55
57
  ],
56
58
  })
57
59
  export class AutocompleteComponent
@@ -64,7 +66,8 @@ export class AutocompleteComponent
64
66
  @Input() preventCompleteOnSelection = false
65
67
  @Input() autoFocus = false
66
68
  @Input() minCharacterCount? = 3
67
- @Input() allowSubmit = true
69
+ // this will show a submit button next to the input; if false, a search icon will appear on the left
70
+ @Input() allowSubmit = false
68
71
  @Output() itemSelected = new EventEmitter<AutocompleteItem>()
69
72
  @Output() inputSubmitted = new EventEmitter<string>()
70
73
  @Output() inputCleared = new EventEmitter<void>()
@@ -8,11 +8,20 @@
8
8
  >
9
9
  <span><ng-content></ng-content></span>
10
10
  <gn-ui-button
11
- class="material-symbols-outlined cursor-pointer text-xs"
11
+ type="light"
12
12
  *ngIf="removable"
13
13
  (buttonClick)="removeBadge()"
14
- extraClass="p-1 bg-transparent border-0 border-transparent "
14
+ class="ml-1 -my-[0.4em] -mr-[0.45em]"
15
+ extraClass="border-0"
16
+ style="
17
+ --gn-ui-button-padding: 0;
18
+ --gn-ui-button-font-size: 0.8em;
19
+ --gn-ui-button-width: 1.4em;
20
+ --gn-ui-button-height: 1.4em;
21
+ --gn-ui-button-rounded: 1.4em;
22
+ --gn-ui-button-background: white;
23
+ "
15
24
  >
16
- close
25
+ <mat-icon class="material-symbols-outlined leading-[1.1]">close</mat-icon>
17
26
  </gn-ui-button>
18
27
  </div>
@@ -7,6 +7,7 @@ import {
7
7
  Output,
8
8
  } from '@angular/core'
9
9
  import { ButtonComponent } from '../button/button.component'
10
+ import { MatIconModule } from '@angular/material/icon'
10
11
 
11
12
  @Component({
12
13
  selector: 'gn-ui-badge',
@@ -14,7 +15,7 @@ import { ButtonComponent } from '../button/button.component'
14
15
  styleUrls: ['./badge.component.css'],
15
16
  changeDetection: ChangeDetectionStrategy.OnPush,
16
17
  standalone: true,
17
- imports: [CommonModule, ButtonComponent],
18
+ imports: [CommonModule, ButtonComponent, MatIconModule],
18
19
  })
19
20
  export class BadgeComponent {
20
21
  @Input() clickable? = false
@@ -18,7 +18,14 @@ export class ButtonComponent {
18
18
  private btnClass = 'gn-ui-btn-default'
19
19
 
20
20
  @Input() set type(
21
- value: 'primary' | 'secondary' | 'default' | 'outline' | 'light'
21
+ value:
22
+ | 'primary'
23
+ | 'secondary'
24
+ | 'default'
25
+ | 'outline'
26
+ | 'light'
27
+ | 'gray'
28
+ | 'black'
22
29
  ) {
23
30
  // btn-classes are written in full to be picked up by tailwind
24
31
  switch (value) {
@@ -34,6 +41,13 @@ export class ButtonComponent {
34
41
  case 'light':
35
42
  this.btnClass = 'gn-ui-btn-light'
36
43
  break
44
+ case 'gray':
45
+ this.btnClass = 'gn-ui-btn-gray'
46
+ break
47
+ case 'black':
48
+ this.btnClass = 'gn-ui-btn-black'
49
+ break
50
+ case 'default':
37
51
  default:
38
52
  this.btnClass = 'gn-ui-btn-default'
39
53
  break
@@ -1,3 +1,8 @@
1
- mat-datepicker-toggle {
2
- @apply text-primary;
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
+ --text-padding: calc(var(--side-padding) + 40px);
3
8
  }
@@ -1,12 +1,19 @@
1
- <div
2
- class="flex items-center justify-between rounded-lg border border-gray-300 bg-white"
3
- >
1
+ <span class="w-full inline-block relative">
4
2
  <input
5
- class="pl-3"
3
+ class="gn-ui-text-input pr-[var(--text-padding)]"
6
4
  [matDatepicker]="picker"
7
5
  [value]="date"
8
6
  (dateChange)="dateChange.emit($event.value)"
9
7
  />
10
- <mat-datepicker-toggle matIconSuffix [for]="picker"></mat-datepicker-toggle>
11
- </div>
8
+ <gn-ui-button
9
+ type="light"
10
+ (buttonClick)="picker.open()"
11
+ extraClass="absolute inset-y-[var(--side-padding)] right-[var(--side-padding)]"
12
+ data-cy="date-picker-button"
13
+ >
14
+ <mat-icon class="material-symbols-outlined text-primary"
15
+ >calendar_today</mat-icon
16
+ >
17
+ </gn-ui-button>
18
+ </span>
12
19
  <mat-datepicker #picker></mat-datepicker>
@@ -8,6 +8,7 @@ import {
8
8
  import { MatNativeDateModule } from '@angular/material/core'
9
9
  import { MatDatepickerModule } from '@angular/material/datepicker'
10
10
  import { MatIconModule } from '@angular/material/icon'
11
+ import { ButtonComponent } from '../button/button.component'
11
12
 
12
13
  @Component({
13
14
  selector: 'gn-ui-date-picker',
@@ -15,7 +16,12 @@ import { MatIconModule } from '@angular/material/icon'
15
16
  styleUrls: ['./date-picker.component.css'],
16
17
  changeDetection: ChangeDetectionStrategy.OnPush,
17
18
  standalone: true,
18
- imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
19
+ imports: [
20
+ MatIconModule,
21
+ MatNativeDateModule,
22
+ MatDatepickerModule,
23
+ ButtonComponent,
24
+ ],
19
25
  })
20
26
  export class DatePickerComponent {
21
27
  @Input() date: Date
@@ -1,3 +1,8 @@
1
- mat-datepicker-toggle {
2
- @apply text-primary;
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
+ --text-padding: calc(var(--side-padding) + 40px);
3
8
  }
@@ -1,24 +1,28 @@
1
- <div
2
- class="flex items-center justify-between rounded-lg border border-gray-300 bg-white"
3
- >
4
- <div class="pl-3 flex justify-center">
5
- <mat-date-range-input [rangePicker]="picker" class="w-full">
6
- <input
7
- matStartDate
8
- placeholder="Start date"
9
- [value]="startDate"
10
- (dateInput)="startDateChange.emit($event.value)"
11
- />
12
- <input
13
- matEndDate
14
- placeholder="End date"
15
- [value]="endDate"
16
- (dateInput)="endDateChange.emit($event.value)"
17
- />
18
- </mat-date-range-input>
19
- </div>
20
- <mat-datepicker-toggle matSuffix [for]="picker">
21
- <mat-icon>calendar_today</mat-icon>
22
- </mat-datepicker-toggle>
23
- </div>
1
+ <span class="w-full inline-block relative">
2
+ <mat-date-range-input [rangePicker]="picker" class="gn-ui-text-input">
3
+ <input
4
+ matStartDate
5
+ placeholder="Start date"
6
+ [value]="startDate"
7
+ (dateInput)="startDateChange.emit($event.value)"
8
+ />
9
+ <input
10
+ matEndDate
11
+ placeholder="End date"
12
+ [value]="endDate"
13
+ (dateInput)="endDateChange.emit($event.value)"
14
+ />
15
+ </mat-date-range-input>
16
+
17
+ <gn-ui-button
18
+ type="light"
19
+ (buttonClick)="picker.open()"
20
+ extraClass="absolute inset-y-[var(--side-padding)] right-[var(--side-padding)]"
21
+ data-cy="date-picker-button"
22
+ >
23
+ <mat-icon class="material-symbols-outlined text-primary"
24
+ >date_range</mat-icon
25
+ >
26
+ </gn-ui-button>
27
+ </span>
24
28
  <mat-date-range-picker #picker></mat-date-range-picker>
@@ -8,6 +8,7 @@ import {
8
8
  import { MatNativeDateModule } from '@angular/material/core'
9
9
  import { MatDatepickerModule } from '@angular/material/datepicker'
10
10
  import { MatIconModule } from '@angular/material/icon'
11
+ import { ButtonComponent } from '../button/button.component'
11
12
 
12
13
  @Component({
13
14
  selector: 'gn-ui-date-range-picker',
@@ -15,7 +16,12 @@ import { MatIconModule } from '@angular/material/icon'
15
16
  styleUrls: ['./date-range-picker.component.css'],
16
17
  changeDetection: ChangeDetectionStrategy.OnPush,
17
18
  standalone: true,
18
- imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
19
+ imports: [
20
+ MatIconModule,
21
+ MatNativeDateModule,
22
+ MatDatepickerModule,
23
+ ButtonComponent,
24
+ ],
19
25
  })
20
26
  export class DateRangePickerComponent {
21
27
  @Input() startDate: Date
@@ -0,0 +1,4 @@
1
+ :host {
2
+ --gn-ui-button-padding: 8px 8px;
3
+ --gn-ui-button-rounded: 8px;
4
+ }
@@ -4,10 +4,13 @@
4
4
  class="flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100"
5
5
  [ngClass]="{
6
6
  'border-primary-lighter bg-primary-white': dragFilesOver,
7
- 'border-gray-300': !dragFilesOver
7
+ 'border-gray-300': !dragFilesOver,
8
+ 'cursor-pointer hover:border-gray-500': !isUploadInProgress
8
9
  }"
10
+ [attr.tabindex]="isUploadInProgress ? null : 0"
9
11
  (dragFilesOver)="handleDragFilesOver($event)"
10
12
  (dropFiles)="handleDropFiles($event)"
13
+ (keydown.enter)="fileInput.click()"
11
14
  >
12
15
  <div
13
16
  class="w-14 h-14 rounded-md bg-gray-50 grid"
@@ -26,7 +29,7 @@
26
29
  </div>
27
30
  <div
28
31
  *ngIf="isUploadInProgress"
29
- class="w-14 h-14 grid items-center justify-center"
32
+ class="w-14 h-14 grid items-center justify-center relative"
30
33
  >
31
34
  <div class="text-gray-100 absolute">
32
35
  <mat-progress-spinner
@@ -57,7 +60,7 @@
57
60
  ? 'font-bold text-primary cursor-pointer'
58
61
  : 'font-medium text-gray-500'
59
62
  "
60
- (click)="handleSecondaryTextClick()"
63
+ (click)="handleSecondaryTextClick($event)"
61
64
  >
62
65
  {{ getSecondaryText() | translate }}
63
66
  </p>
@@ -70,6 +73,7 @@
70
73
  <span class="border-b border-gray-300 grow"></span>
71
74
  </p>
72
75
  <input
76
+ #fileInput
73
77
  type="file"
74
78
  class="hidden"
75
79
  (change)="handleFileInput($event)"