geonetwork-ui 2.4.0-dev.6c8dcba0 → 2.4.0-dev.71a43b38

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 (317) hide show
  1. package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/index.mjs +2 -1
  2. package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.mjs +2 -0
  3. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +1 -1
  4. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/keyword.mapper.mjs +1 -1
  5. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +1 -1
  6. package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +14 -5
  7. package/esm2022/libs/api/repository/src/lib/gn4/organizations/organizations-from-groups.service.mjs +2 -1
  8. package/esm2022/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.mjs +3 -1
  9. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +12 -4
  10. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +38 -14
  11. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
  12. package/esm2022/libs/common/domain/src/lib/model/record/organization.model.mjs +1 -1
  13. package/esm2022/libs/common/domain/src/lib/model/thesaurus/thesaurus.model.mjs +1 -1
  14. package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
  15. package/esm2022/libs/common/domain/src/lib/repository/records-repository.interface.mjs +1 -1
  16. package/esm2022/libs/data-access/gn4/src/openapi/model/user.api.model.mjs +1 -1
  17. package/esm2022/libs/feature/catalog/src/index.mjs +2 -1
  18. package/esm2022/libs/feature/catalog/src/lib/feature-catalog.module.mjs +1 -1
  19. package/esm2022/libs/feature/catalog/src/lib/organisations/organisations.component.mjs +6 -6
  20. package/esm2022/libs/feature/catalog/src/lib/organization-url.token.mjs +4 -0
  21. package/esm2022/libs/feature/catalog/src/lib/records/records.service.mjs +4 -6
  22. package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +4 -4
  23. package/esm2022/libs/feature/dataviz/src/lib/feature-dataviz.module.mjs +7 -4
  24. package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +1 -1
  25. package/esm2022/libs/feature/editor/src/lib/+state/editor.actions.mjs +2 -1
  26. package/esm2022/libs/feature/editor/src/lib/+state/editor.effects.mjs +6 -4
  27. package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +2 -1
  28. package/esm2022/libs/feature/editor/src/lib/+state/editor.selectors.mjs +2 -2
  29. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +59 -0
  30. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +64 -50
  31. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +17 -35
  32. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/index.mjs +2 -1
  33. package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +4 -3
  34. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +12 -5
  35. package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +12 -6
  36. package/esm2022/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.mjs +42 -23
  37. package/esm2022/libs/feature/record/src/lib/data-view-share/data-view-share.component.mjs +13 -5
  38. package/esm2022/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.mjs +49 -15
  39. package/esm2022/libs/feature/record/src/lib/feature-record.module.mjs +7 -4
  40. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +3 -3
  41. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +8 -12
  42. package/esm2022/libs/feature/router/src/lib/default/constants.mjs +2 -1
  43. package/esm2022/libs/feature/router/src/lib/default/router.config.mjs +1 -1
  44. package/esm2022/libs/feature/router/src/lib/default/router.service.mjs +9 -2
  45. package/esm2022/libs/feature/router/src/lib/default/state/router.facade.mjs +8 -1
  46. package/esm2022/libs/feature/search/src/index.mjs +2 -2
  47. package/esm2022/libs/feature/search/src/lib/feature-search.module.mjs +7 -4
  48. package/esm2022/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.mjs +3 -3
  49. package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +49 -0
  50. package/esm2022/libs/feature/search/src/lib/state/search.facade.mjs +3 -2
  51. package/esm2022/libs/feature/search/src/lib/state/selectors.mjs +4 -1
  52. package/esm2022/libs/feature/search/src/lib/utils/service/fields.service.mjs +7 -3
  53. package/esm2022/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.mjs +5 -5
  54. package/esm2022/libs/ui/catalog/src/lib/ui-catalog.module.mjs +5 -2
  55. package/esm2022/libs/ui/dataviz/src/lib/figure/figure.component.mjs +5 -8
  56. package/esm2022/libs/ui/elements/src/index.mjs +1 -2
  57. package/esm2022/libs/ui/elements/src/lib/api-card/api-card.component.mjs +3 -3
  58. package/esm2022/libs/ui/elements/src/lib/error/error.component.mjs +5 -3
  59. package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +7 -7
  60. package/esm2022/libs/ui/elements/src/lib/related-record-card/related-record-card.component.mjs +24 -5
  61. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +9 -11
  62. package/esm2022/libs/ui/inputs/src/index.mjs +2 -1
  63. package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +59 -26
  64. package/esm2022/libs/ui/inputs/src/lib/badge/badge.component.mjs +28 -0
  65. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +11 -10
  66. package/esm2022/libs/ui/layout/src/index.mjs +2 -1
  67. package/esm2022/libs/ui/layout/src/lib/max-lines/max-lines.component.mjs +71 -0
  68. package/esm2022/libs/ui/layout/src/lib/ui-layout.module.mjs +1 -1
  69. package/esm2022/libs/ui/search/src/index.mjs +2 -1
  70. package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +120 -0
  71. package/esm2022/libs/ui/widgets/src/index.mjs +1 -2
  72. package/esm2022/libs/ui/widgets/src/lib/popup-alert/popup-alert.component.mjs +5 -3
  73. package/esm2022/libs/ui/widgets/src/lib/ui-widgets.module.mjs +1 -6
  74. package/esm2022/translations/de.json +66 -34
  75. package/esm2022/translations/en.json +37 -5
  76. package/esm2022/translations/es.json +37 -5
  77. package/esm2022/translations/fr.json +38 -6
  78. package/esm2022/translations/it.json +37 -5
  79. package/esm2022/translations/nl.json +37 -5
  80. package/esm2022/translations/pt.json +37 -5
  81. package/fesm2022/geonetwork-ui.mjs +1187 -688
  82. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  83. package/libs/api/metadata-converter/src/lib/gn4/types/index.d.ts +1 -0
  84. package/libs/api/metadata-converter/src/lib/gn4/types/index.d.ts.map +1 -1
  85. package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts +31 -0
  86. package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts.map +1 -0
  87. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +3 -2
  88. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
  89. package/libs/api/metadata-converter/src/lib/iso19139/utils/keyword.mapper.d.ts +1 -1
  90. package/libs/api/metadata-converter/src/lib/iso19139/utils/keyword.mapper.d.ts.map +1 -1
  91. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +3 -2
  92. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  93. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +1 -0
  94. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
  95. package/libs/api/repository/src/lib/gn4/organizations/organizations-from-groups.service.d.ts.map +1 -1
  96. package/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.d.ts.map +1 -1
  97. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts +3 -3
  98. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts.map +1 -1
  99. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +9 -5
  100. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  101. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +4 -7
  102. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  103. package/libs/common/domain/src/lib/model/record/organization.model.d.ts +1 -0
  104. package/libs/common/domain/src/lib/model/record/organization.model.d.ts.map +1 -1
  105. package/libs/common/domain/src/lib/model/thesaurus/thesaurus.model.d.ts +12 -5
  106. package/libs/common/domain/src/lib/model/thesaurus/thesaurus.model.d.ts.map +1 -1
  107. package/libs/common/domain/src/lib/platform.service.interface.d.ts +4 -3
  108. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  109. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +3 -1
  110. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts.map +1 -1
  111. package/libs/data-access/gn4/src/openapi/model/user.api.model.d.ts +1 -1
  112. package/libs/feature/catalog/src/index.d.ts +1 -0
  113. package/libs/feature/catalog/src/index.d.ts.map +1 -1
  114. package/libs/feature/catalog/src/lib/feature-catalog.module.d.ts.map +1 -1
  115. package/libs/feature/catalog/src/lib/organisations/organisations.component.d.ts.map +1 -1
  116. package/libs/feature/catalog/src/lib/organization-url.token.d.ts +3 -0
  117. package/libs/feature/catalog/src/lib/organization-url.token.d.ts.map +1 -0
  118. package/libs/feature/catalog/src/lib/records/records.service.d.ts.map +1 -1
  119. package/libs/feature/dataviz/src/lib/feature-dataviz.module.d.ts +2 -1
  120. package/libs/feature/dataviz/src/lib/feature-dataviz.module.d.ts.map +1 -1
  121. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts +1 -0
  122. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts.map +1 -1
  123. package/libs/feature/editor/src/lib/+state/editor.effects.d.ts +1 -1
  124. package/libs/feature/editor/src/lib/+state/editor.effects.d.ts.map +1 -1
  125. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +1 -0
  126. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
  127. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts +25 -0
  128. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts.map +1 -0
  129. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +6 -6
  130. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts.map +1 -1
  131. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +6 -10
  132. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  133. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts +1 -0
  134. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts.map +1 -1
  135. package/libs/feature/editor/src/lib/feature-editor.module.d.ts.map +1 -1
  136. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  137. package/libs/feature/editor/src/lib/services/editor.service.d.ts +1 -1
  138. package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
  139. package/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.d.ts +4 -1
  140. package/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.d.ts.map +1 -1
  141. package/libs/feature/record/src/lib/data-view-share/data-view-share.component.d.ts +4 -1
  142. package/libs/feature/record/src/lib/data-view-share/data-view-share.component.d.ts.map +1 -1
  143. package/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.d.ts +4 -1
  144. package/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.d.ts.map +1 -1
  145. package/libs/feature/record/src/lib/feature-record.module.d.ts +2 -1
  146. package/libs/feature/record/src/lib/feature-record.module.d.ts.map +1 -1
  147. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  148. package/libs/feature/router/src/lib/default/constants.d.ts +1 -0
  149. package/libs/feature/router/src/lib/default/constants.d.ts.map +1 -1
  150. package/libs/feature/router/src/lib/default/router.config.d.ts +1 -0
  151. package/libs/feature/router/src/lib/default/router.config.d.ts.map +1 -1
  152. package/libs/feature/router/src/lib/default/router.service.d.ts +1 -0
  153. package/libs/feature/router/src/lib/default/router.service.d.ts.map +1 -1
  154. package/libs/feature/router/src/lib/default/state/router.facade.d.ts +1 -0
  155. package/libs/feature/router/src/lib/default/state/router.facade.d.ts.map +1 -1
  156. package/libs/feature/search/src/index.d.ts +1 -1
  157. package/libs/feature/search/src/index.d.ts.map +1 -1
  158. package/libs/feature/search/src/lib/feature-search.module.d.ts +2 -1
  159. package/libs/feature/search/src/lib/feature-search.module.d.ts.map +1 -1
  160. package/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.d.ts.map +1 -1
  161. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +25 -0
  162. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -0
  163. package/libs/feature/search/src/lib/state/search.facade.d.ts +1 -0
  164. package/libs/feature/search/src/lib/state/search.facade.d.ts.map +1 -1
  165. package/libs/feature/search/src/lib/state/selectors.d.ts +1 -0
  166. package/libs/feature/search/src/lib/state/selectors.d.ts.map +1 -1
  167. package/libs/feature/search/src/lib/utils/service/fields.service.d.ts.map +1 -1
  168. package/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.d.ts +2 -2
  169. package/libs/ui/catalog/src/lib/ui-catalog.module.d.ts +2 -1
  170. package/libs/ui/catalog/src/lib/ui-catalog.module.d.ts.map +1 -1
  171. package/libs/ui/dataviz/src/lib/figure/figure.component.d.ts +1 -2
  172. package/libs/ui/dataviz/src/lib/figure/figure.component.d.ts.map +1 -1
  173. package/libs/ui/elements/src/index.d.ts +0 -1
  174. package/libs/ui/elements/src/index.d.ts.map +1 -1
  175. package/libs/ui/elements/src/lib/error/error.component.d.ts +3 -1
  176. package/libs/ui/elements/src/lib/error/error.component.d.ts.map +1 -1
  177. package/libs/ui/elements/src/lib/related-record-card/related-record-card.component.d.ts +5 -1
  178. package/libs/ui/elements/src/lib/related-record-card/related-record-card.component.d.ts.map +1 -1
  179. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +19 -19
  180. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  181. package/libs/ui/inputs/src/index.d.ts +1 -0
  182. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  183. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts +7 -4
  184. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
  185. package/libs/ui/inputs/src/lib/badge/badge.component.d.ts +11 -0
  186. package/libs/ui/inputs/src/lib/badge/badge.component.d.ts.map +1 -0
  187. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +35 -35
  188. package/libs/ui/layout/src/index.d.ts +1 -0
  189. package/libs/ui/layout/src/index.d.ts.map +1 -1
  190. package/libs/ui/{elements → layout}/src/lib/max-lines/max-lines.component.d.ts +2 -2
  191. package/libs/ui/layout/src/lib/max-lines/max-lines.component.d.ts.map +1 -0
  192. package/libs/ui/layout/src/lib/ui-layout.module.d.ts.map +1 -1
  193. package/libs/ui/search/src/index.d.ts +1 -0
  194. package/libs/ui/search/src/index.d.ts.map +1 -1
  195. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +30 -0
  196. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -0
  197. package/libs/ui/widgets/src/index.d.ts +0 -1
  198. package/libs/ui/widgets/src/index.d.ts.map +1 -1
  199. package/libs/ui/widgets/src/lib/popup-alert/popup-alert.component.d.ts +1 -1
  200. package/libs/ui/widgets/src/lib/popup-alert/popup-alert.component.d.ts.map +1 -1
  201. package/libs/ui/widgets/src/lib/ui-widgets.module.d.ts +10 -11
  202. package/libs/ui/widgets/src/lib/ui-widgets.module.d.ts.map +1 -1
  203. package/package.json +1 -1
  204. package/src/libs/api/metadata-converter/src/lib/gn4/types/index.ts +1 -0
  205. package/src/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.ts +31 -0
  206. package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +2 -2
  207. package/src/libs/api/metadata-converter/src/lib/iso19139/utils/keyword.mapper.ts +1 -1
  208. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +2 -2
  209. package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +21 -8
  210. package/src/libs/api/repository/src/lib/gn4/organizations/organizations-from-groups.service.ts +1 -0
  211. package/src/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.ts +3 -1
  212. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +25 -4
  213. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +81 -21
  214. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +4 -9
  215. package/src/libs/common/domain/src/lib/model/record/organization.model.ts +1 -0
  216. package/src/libs/common/domain/src/lib/model/thesaurus/thesaurus.model.ts +13 -6
  217. package/src/libs/common/domain/src/lib/platform.service.interface.ts +7 -3
  218. package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +4 -1
  219. package/src/libs/common/fixtures/src/lib/organisations.fixture.ts +28 -0
  220. package/src/libs/common/fixtures/src/lib/records.fixtures.ts +8 -0
  221. package/src/libs/data-access/datafeeder/src/openapi/model/datasetMetadata.api.model.ts +4 -0
  222. package/src/libs/data-access/datafeeder/src/openapi/model/datasetUploadStatus.api.model.ts +2 -0
  223. package/src/libs/data-access/gn4/src/openapi/model/user.api.model.ts +1 -1
  224. package/src/libs/feature/catalog/src/index.ts +1 -0
  225. package/src/libs/feature/catalog/src/lib/feature-catalog.module.ts +0 -1
  226. package/src/libs/feature/catalog/src/lib/organisations/organisations.component.html +1 -1
  227. package/src/libs/feature/catalog/src/lib/organisations/organisations.component.ts +2 -2
  228. package/src/libs/feature/catalog/src/lib/organization-url.token.ts +6 -0
  229. package/src/libs/feature/catalog/src/lib/records/records.service.ts +6 -8
  230. package/src/libs/feature/dataviz/src/lib/feature-dataviz.module.ts +2 -1
  231. package/src/libs/feature/editor/src/lib/+state/editor.actions.ts +2 -0
  232. package/src/libs/feature/editor/src/lib/+state/editor.effects.ts +35 -29
  233. package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +1 -0
  234. package/src/libs/feature/editor/src/lib/+state/editor.selectors.ts +1 -1
  235. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.html +19 -0
  236. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.ts +79 -0
  237. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +95 -86
  238. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +7 -22
  239. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +16 -44
  240. package/src/libs/feature/editor/src/lib/components/record-form/form-field/index.ts +1 -1
  241. package/src/libs/feature/editor/src/lib/feature-editor.module.ts +2 -1
  242. package/src/libs/feature/editor/src/lib/fields.config.ts +11 -4
  243. package/src/libs/feature/editor/src/lib/services/editor.service.ts +20 -6
  244. package/src/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.ts +36 -19
  245. package/src/libs/feature/record/src/lib/data-view-share/data-view-share.component.html +6 -2
  246. package/src/libs/feature/record/src/lib/data-view-share/data-view-share.component.ts +11 -0
  247. package/src/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.ts +59 -12
  248. package/src/libs/feature/record/src/lib/feature-record.module.ts +3 -2
  249. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +42 -31
  250. package/src/libs/feature/router/src/lib/default/constants.ts +1 -0
  251. package/src/libs/feature/router/src/lib/default/router.config.ts +1 -0
  252. package/src/libs/feature/router/src/lib/default/router.service.ts +13 -1
  253. package/src/libs/feature/router/src/lib/default/state/router.facade.ts +9 -1
  254. package/src/libs/feature/search/src/index.ts +1 -1
  255. package/src/libs/feature/search/src/lib/feature-search.module.ts +2 -1
  256. package/src/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.ts +2 -2
  257. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.html +9 -0
  258. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +49 -0
  259. package/src/libs/feature/search/src/lib/state/search.facade.ts +5 -0
  260. package/src/libs/feature/search/src/lib/state/selectors.ts +7 -0
  261. package/src/libs/feature/search/src/lib/utils/service/fields.service.ts +16 -2
  262. package/src/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.html +8 -6
  263. package/src/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.ts +2 -2
  264. package/src/libs/ui/catalog/src/lib/ui-catalog.module.ts +2 -0
  265. package/src/libs/ui/dataviz/src/lib/figure/figure.component.html +11 -3
  266. package/src/libs/ui/dataviz/src/lib/figure/figure.component.ts +3 -7
  267. package/src/libs/ui/elements/src/index.ts +0 -1
  268. package/src/libs/ui/elements/src/lib/api-card/api-card.component.html +29 -29
  269. package/src/libs/ui/elements/src/lib/error/error.component.html +30 -6
  270. package/src/libs/ui/elements/src/lib/error/error.component.ts +2 -0
  271. package/src/libs/ui/elements/src/lib/related-record-card/related-record-card.component.html +1 -1
  272. package/src/libs/ui/elements/src/lib/related-record-card/related-record-card.component.ts +22 -1
  273. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +4 -6
  274. package/src/libs/ui/inputs/src/index.ts +1 -0
  275. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.css +0 -1
  276. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.html +23 -19
  277. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +79 -27
  278. package/src/libs/ui/inputs/src/lib/badge/badge.component.html +18 -0
  279. package/src/libs/ui/inputs/src/lib/badge/badge.component.ts +27 -0
  280. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.css +31 -0
  281. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.html +15 -0
  282. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.ts +38 -0
  283. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +3 -3
  284. package/src/libs/ui/layout/src/index.ts +1 -0
  285. package/src/libs/ui/layout/src/lib/max-lines/max-lines.component.css +0 -0
  286. package/src/libs/ui/{elements → layout}/src/lib/max-lines/max-lines.component.html +1 -0
  287. package/src/libs/ui/{elements → layout}/src/lib/max-lines/max-lines.component.ts +9 -5
  288. package/src/libs/ui/layout/src/lib/ui-layout.module.ts +0 -1
  289. package/src/libs/ui/search/src/index.ts +1 -0
  290. package/src/libs/ui/search/src/lib/results-table/results-table.component.css +0 -0
  291. package/src/libs/{feature → ui}/search/src/lib/results-table/results-table.component.html +8 -8
  292. package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +138 -0
  293. package/src/libs/ui/widgets/src/index.ts +0 -1
  294. package/src/libs/ui/widgets/src/lib/popup-alert/popup-alert.component.ts +4 -0
  295. package/src/libs/ui/widgets/src/lib/ui-widgets.module.ts +0 -3
  296. package/translations/de.json +66 -34
  297. package/translations/en.json +37 -5
  298. package/translations/es.json +37 -5
  299. package/translations/fr.json +38 -6
  300. package/translations/it.json +37 -5
  301. package/translations/nl.json +37 -5
  302. package/translations/pt.json +37 -5
  303. package/translations/sk.json +38 -6
  304. package/esm2022/libs/feature/search/src/lib/results-table/results-table.component.mjs +0 -136
  305. package/esm2022/libs/ui/elements/src/lib/max-lines/max-lines.component.mjs +0 -69
  306. package/esm2022/libs/ui/widgets/src/lib/badge/badge.component.mjs +0 -18
  307. package/libs/feature/search/src/lib/results-table/results-table.component.d.ts +0 -36
  308. package/libs/feature/search/src/lib/results-table/results-table.component.d.ts.map +0 -1
  309. package/libs/ui/elements/src/lib/max-lines/max-lines.component.d.ts.map +0 -1
  310. package/libs/ui/widgets/src/lib/badge/badge.component.d.ts +0 -7
  311. package/libs/ui/widgets/src/lib/badge/badge.component.d.ts.map +0 -1
  312. package/src/libs/feature/search/src/lib/results-table/results-table.component.ts +0 -172
  313. package/src/libs/ui/widgets/src/lib/badge/badge.component.html +0 -10
  314. package/src/libs/ui/widgets/src/lib/badge/badge.component.ts +0 -14
  315. /package/src/libs/feature/{search/src/lib/results-table/results-table.component.css → editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.css} +0 -0
  316. /package/src/libs/{ui/elements/src/lib/max-lines/max-lines.component.css → feature/search/src/lib/results-table/results-table-container.component.css} +0 -0
  317. /package/src/libs/ui/{widgets → inputs}/src/lib/badge/badge.component.css +0 -0
@@ -1,14 +1,14 @@
1
1
  <a href (click)="clickOrganisation($event)" [attr.href]="organisationUrl">
2
2
  <div
3
3
  class="group cursor-pointer rounded-lg h-full flex flex-col"
4
- [title]="organisation.name"
4
+ [title]="organization.name"
5
5
  >
6
6
  <div
7
7
  class="shrink-0 bg-gray-100 rounded-lg overflow-hidden w-full border border-gray-300 h-36"
8
8
  >
9
9
  <gn-ui-thumbnail
10
10
  class="relative h-full w-full"
11
- [thumbnailUrl]="organisation.logoUrl"
11
+ [thumbnailUrl]="organization.logoUrl"
12
12
  [fit]="'contain'"
13
13
  >
14
14
  </gn-ui-thumbnail>
@@ -18,22 +18,24 @@
18
18
  class="shrink-0 mb-3 mt-5 font-title text-21 text-title group-hover:text-primary line-clamp-2 sm:mt-2 transition-colors"
19
19
  data-cy="organizationName"
20
20
  >
21
- {{ organisation.name }}</span
21
+ {{ organization.name }}</span
22
22
  >
23
23
  <p
24
24
  class="abstract mt-4 mb-5 sm:mb-2 sm:mt-0 grow shrink-1 overflow-hidden"
25
25
  data-cy="organizationDesc"
26
26
  >
27
- {{ organisation.description }}
27
+ {{ organization.description }}
28
28
  </p>
29
29
  <div class="shrink-0 text-primary opacity-50 flex leading-6">
30
30
  <mat-icon class="material-symbols-outlined text-primary opacity-50 mr-1"
31
31
  >folder_open
32
32
  </mat-icon>
33
33
  <span class="mx-1" data-cy="organizationRecordsCount">{{
34
- organisation.recordCount
34
+ organization.recordCount
35
35
  }}</span>
36
- <span translate>record.metadata.publications</span>
36
+ <span translate [translateParams]="{ count: organization.recordCount }"
37
+ >record.metadata.publications</span
38
+ >
37
39
  </div>
38
40
  </div>
39
41
  </div>
@@ -14,12 +14,12 @@ import { Organization } from '../../../../../../libs/common/domain/src/lib/model
14
14
  changeDetection: ChangeDetectionStrategy.OnPush,
15
15
  })
16
16
  export class OrganisationPreviewComponent {
17
- @Input() organisation: Organization
17
+ @Input() organization: Organization
18
18
  @Input() organisationUrl: string
19
19
  @Output() clickedOrganisation = new EventEmitter<Organization>()
20
20
 
21
21
  clickOrganisation(event: Event) {
22
22
  event.preventDefault()
23
- this.clickedOrganisation.emit(this.organisation)
23
+ this.clickedOrganisation.emit(this.organization)
24
24
  }
25
25
  }
@@ -9,6 +9,7 @@ import { OrganisationsFilterComponent } from './organisations-filter/organisatio
9
9
  import { UiInputsModule } from '../../../../../libs/ui/inputs/src'
10
10
  import { LanguageSwitcherComponent } from './language-switcher/language-switcher.component'
11
11
  import { OrganisationsResultComponent } from './organisations-result/organisations-result.component'
12
+ import { RouterLink } from '@angular/router'
12
13
 
13
14
  @NgModule({
14
15
  declarations: [
@@ -24,6 +25,7 @@ import { OrganisationsResultComponent } from './organisations-result/organisatio
24
25
  UiElementsModule,
25
26
  UiInputsModule,
26
27
  MatIconModule,
28
+ RouterLink,
27
29
  ],
28
30
  exports: [
29
31
  CatalogTitleComponent,
@@ -1,7 +1,13 @@
1
1
  <div
2
- translate
3
2
  class="flex flex-row justify-start items-center overflow-hidden"
4
- [title]="hoverTitle"
3
+ data-test="figureTitle"
4
+ [title]="
5
+ figure.toString() +
6
+ ' ' +
7
+ unit +
8
+ ' ' +
9
+ (title | translate: { count: figure })
10
+ "
5
11
  >
6
12
  <mat-icon
7
13
  class="material-symbols-outlined {{ bgClass }} {{
@@ -13,7 +19,9 @@
13
19
  </mat-icon>
14
20
  <div class="shrink overflow-hidden">
15
21
  <div class="figure-block text-[1.5em] text-black">
16
- <span class="figure font-medium mr-[0.3em]">{{ figure }}</span>
22
+ <span class="figure font-medium mr-[0.3em]" data-test="figure">{{
23
+ figure
24
+ }}</span>
17
25
  <span class="unit text-[0.665em]">{{ unit }}</span>
18
26
  </div>
19
27
  <div translate class="title truncate" [translateParams]="{ count: figure }">
@@ -1,4 +1,4 @@
1
- import { Component, ChangeDetectionStrategy, Input } from '@angular/core'
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
2
2
 
3
3
  @Component({
4
4
  selector: 'gn-ui-figure',
@@ -10,17 +10,13 @@ export class FigureComponent {
10
10
  @Input() icon!: string
11
11
  @Input() title!: string
12
12
  @Input() figure!: string | number
13
- @Input() unit?: string
13
+ @Input() unit = ''
14
14
  @Input() color: 'primary' | 'secondary' = 'primary'
15
15
 
16
- get hoverTitle() {
17
- return `${this.figure.toString()} ${this.unit || ''}
18
- ${this.title}`
19
- }
20
-
21
16
  get textClass() {
22
17
  return this.color === 'primary' ? 'text-primary' : 'text-secondary'
23
18
  }
19
+
24
20
  get bgClass() {
25
21
  return this.color === 'primary' ? 'bg-primary-white' : 'bg-secondary-white'
26
22
  }
@@ -8,7 +8,6 @@ export * from './lib/image-overlay-preview/image-overlay-preview.component'
8
8
  export * from './lib/link-card/link-card.component'
9
9
  export * from './lib/markdown-editor/markdown-editor.component'
10
10
  export * from './lib/markdown-parser/markdown-parser.component'
11
- export * from './lib/max-lines/max-lines.component'
12
11
  export * from './lib/metadata-catalog/metadata-catalog.component'
13
12
  export * from './lib/metadata-contact/metadata-contact.component'
14
13
  export * from './lib/metadata-info/metadata-info.component'
@@ -1,7 +1,5 @@
1
1
  <div
2
- class="group flex flex-col justify-between h-40 pt-5 pb-6 px-7 rounded filter overflow-hidden"
3
- [ngClass]="{ 'cursor-pointer': displayApiFormButton }"
4
- (click)="openRecordApiFormPanel()"
2
+ class="group flex flex-col justify-between h-40 pt-5 pb-6 px-7 rounded filter overflow-hidden cursor-default"
5
3
  >
6
4
  <div
7
5
  class="font-title font-medium text-21 text-black text-ellipsis overflow-hidden break-words pb-5 h-[4.5rem]"
@@ -17,35 +15,37 @@
17
15
  }"
18
16
  >{{ link.accessServiceProtocol }}</span
19
17
  >
20
- <gn-ui-copy-text-button
21
- *ngIf="!displayApiFormButton"
22
- [text]="link.url.toString()"
23
- [tooltipText]="'tooltip.url.copy' | translate"
24
- [displayText]="false"
25
- ></gn-ui-copy-text-button>
26
- <button
27
- *ngIf="displayApiFormButton"
28
- type="button"
29
- [ngClass]="{
30
- 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':
31
- displayText
32
- }"
33
- mat-raised-button
34
- [matTooltip]="
35
- !currentlyActive
36
- ? ('record.metadata.api.form.openForm' | translate)
37
- : ('record.metadata.api.form.closeForm' | translate)
38
- "
39
- matTooltipPosition="above"
40
- >
41
- <mat-icon
42
- class="material-symbols-outlined pointer-events-none align-middle card-icon"
18
+ <div class="flex flex-row gap-2 items-center">
19
+ <gn-ui-copy-text-button
20
+ [text]="link.url"
21
+ [tooltipText]="'tooltip.url.copy' | translate"
22
+ [displayText]="false"
23
+ ></gn-ui-copy-text-button>
24
+ <button
25
+ *ngIf="displayApiFormButton"
26
+ type="button"
43
27
  [ngClass]="{
44
- 'text-secondary opacity-100': currentlyActive
28
+ 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':
29
+ displayText
45
30
  }"
46
- >more_horiz</mat-icon
31
+ mat-raised-button
32
+ [matTooltip]="
33
+ !currentlyActive
34
+ ? ('record.metadata.api.form.openForm' | translate)
35
+ : ('record.metadata.api.form.closeForm' | translate)
36
+ "
37
+ matTooltipPosition="above"
38
+ (click)="openRecordApiFormPanel()"
47
39
  >
48
- </button>
40
+ <mat-icon
41
+ class="material-symbols-outlined pointer-events-none align-middle card-icon"
42
+ [ngClass]="{
43
+ 'text-secondary opacity-100': currentlyActive
44
+ }"
45
+ >more_horiz</mat-icon
46
+ >
47
+ </button>
48
+ </div>
49
49
  </div>
50
50
  </div>
51
51
  </div>
@@ -8,11 +8,11 @@
8
8
  <div class="relative opacity-40">
9
9
  <mat-icon class="material-symbols-outlined face">face</mat-icon>
10
10
  <mat-icon class="material-symbols-outlined question-mark1"
11
- >question_mark</mat-icon
12
- >
11
+ >question_mark
12
+ </mat-icon>
13
13
  <mat-icon class="material-symbols-outlined question-mark2"
14
- >question_mark</mat-icon
15
- >
14
+ >question_mark
15
+ </mat-icon>
16
16
  </div>
17
17
  <div translate>search.error.couldNotReachApi</div>
18
18
  </div>
@@ -32,6 +32,15 @@
32
32
  <div translate>search.error.receivedError</div>
33
33
  <div *ngIf="error">{{ error }}</div>
34
34
  </div>
35
+ <div *ngIf="type === types.ORGANIZATION_HAS_NO_DATASET">
36
+ <div class="relative opacity-40">
37
+ <mat-icon class="material-symbols-outlined computer">computer</mat-icon>
38
+ <mat-icon class="material-symbols-outlined computer-question-mark"
39
+ >question_mark
40
+ </mat-icon>
41
+ </div>
42
+ <div translate>search.error.organizationHasNoDataset</div>
43
+ </div>
35
44
  <div
36
45
  *ngIf="type === types.RECORD_NOT_FOUND"
37
46
  data-test="record-not-found-error"
@@ -39,12 +48,27 @@
39
48
  <div class="relative opacity-40">
40
49
  <mat-icon class="material-symbols-outlined computer">computer</mat-icon>
41
50
  <mat-icon class="material-symbols-outlined computer-question-mark"
42
- >question_mark</mat-icon
43
- >
51
+ >question_mark
52
+ </mat-icon>
44
53
  </div>
45
54
  <div translate [translateParams]="{ id: recordId }">
46
55
  search.error.recordNotFound
47
56
  </div>
48
57
  <div *ngIf="error">{{ error }}</div>
49
58
  </div>
59
+ <div
60
+ *ngIf="type === types.ORGANIZATION_NOT_FOUND"
61
+ data-test="org-not-found-error"
62
+ >
63
+ <div class="relative opacity-40">
64
+ <mat-icon class="material-symbols-outlined computer">computer</mat-icon>
65
+ <mat-icon class="material-symbols-outlined computer-question-mark"
66
+ >question_mark
67
+ </mat-icon>
68
+ </div>
69
+ <div translate [translateParams]="{ id: recordId }">
70
+ search.error.organizationNotFound
71
+ </div>
72
+ <div *ngIf="error">{{ error }}</div>
73
+ </div>
50
74
  </div>
@@ -5,6 +5,8 @@ export enum ErrorType {
5
5
  RECEIVED_ERROR,
6
6
  RECORD_NOT_FOUND,
7
7
  DATASET_HAS_NO_LINK,
8
+ ORGANIZATION_HAS_NO_DATASET,
9
+ ORGANIZATION_NOT_FOUND,
8
10
  }
9
11
 
10
12
  @Component({
@@ -1,5 +1,5 @@
1
1
  <a
2
- class="w-72 h-96 overflow-hidden rounded-lg bg-white cursor-pointer block hover:-translate-y-2 duration-[180ms]"
2
+ [class]="classList"
3
3
  [routerLink]="['/dataset', record.uniqueIdentifier]"
4
4
  target="_blank"
5
5
  >
@@ -1,4 +1,4 @@
1
- import { Component, ChangeDetectionStrategy, Input } from '@angular/core'
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
2
2
  import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
3
3
 
4
4
  @Component({
@@ -8,5 +8,26 @@ import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/mode
8
8
  changeDetection: ChangeDetectionStrategy.OnPush,
9
9
  })
10
10
  export class RelatedRecordCardComponent {
11
+ private readonly baseClasses: string
12
+
11
13
  @Input() record: CatalogRecord
14
+ @Input() extraClass = ''
15
+
16
+ constructor() {
17
+ this.baseClasses = [
18
+ 'w-72',
19
+ 'h-96',
20
+ 'overflow-hidden',
21
+ 'rounded-lg',
22
+ 'bg-white',
23
+ 'cursor-pointer',
24
+ 'block',
25
+ 'hover:-translate-y-2 ',
26
+ 'duration-[180ms]',
27
+ ].join(' ')
28
+ }
29
+
30
+ get classList() {
31
+ return `${this.baseClasses} ${this.extraClass}`
32
+ }
12
33
  }
@@ -9,8 +9,8 @@ import { ContentGhostComponent } from './content-ghost/content-ghost.component'
9
9
  import { DownloadItemComponent } from './download-item/download-item.component'
10
10
  import { DownloadsListComponent } from './downloads-list/downloads-list.component'
11
11
  import { ApiCardComponent } from './api-card/api-card.component'
12
- import { BadgeComponent, UiWidgetsModule } from '../../../../../libs/ui/widgets/src'
13
- import { UiLayoutModule } from '../../../../../libs/ui/layout/src'
12
+ import { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'
13
+ import { MaxLinesComponent, UiLayoutModule } from '../../../../../libs/ui/layout/src'
14
14
  import { TranslateModule } from '@ngx-translate/core'
15
15
  import { RelatedRecordCardComponent } from './related-record-card/related-record-card.component'
16
16
  import { MetadataContactComponent } from './metadata-contact/metadata-contact.component'
@@ -20,13 +20,12 @@ import { MetadataQualityItemComponent } from './metadata-quality-item/metadata-q
20
20
  import { ErrorComponent } from './error/error.component'
21
21
  import { PaginationComponent } from './pagination/pagination.component'
22
22
  import { ThumbnailComponent } from './thumbnail/thumbnail.component'
23
- import { UiInputsModule } from '../../../../../libs/ui/inputs/src'
23
+ import { BadgeComponent, UiInputsModule } from '../../../../../libs/ui/inputs/src'
24
24
  import { FormsModule } from '@angular/forms'
25
25
  import { AvatarComponent } from './avatar/avatar.component'
26
26
  import { UserPreviewComponent } from './user-preview/user-preview.component'
27
27
  import { GnUiLinkifyDirective } from './metadata-info/linkify.directive'
28
28
  import { PaginationButtonsComponent } from './pagination-buttons/pagination-buttons.component'
29
- import { MaxLinesComponent } from './max-lines/max-lines.component'
30
29
  import { RecordApiFormComponent } from './record-api-form/record-api-form.component'
31
30
  import { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'
32
31
  import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'
@@ -50,6 +49,7 @@ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
50
49
  ThumbnailComponent,
51
50
  TimeSincePipe,
52
51
  BadgeComponent,
52
+ MaxLinesComponent,
53
53
  ],
54
54
  declarations: [
55
55
  MetadataInfoComponent,
@@ -68,7 +68,6 @@ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
68
68
  UserPreviewComponent,
69
69
  GnUiLinkifyDirective,
70
70
  PaginationButtonsComponent,
71
- MaxLinesComponent,
72
71
  RecordApiFormComponent,
73
72
  UserFeedbackItemComponent,
74
73
  ImageOverlayPreviewComponent,
@@ -90,7 +89,6 @@ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
90
89
  AvatarComponent,
91
90
  UserPreviewComponent,
92
91
  PaginationButtonsComponent,
93
- MaxLinesComponent,
94
92
  RecordApiFormComponent,
95
93
  MarkdownParserComponent,
96
94
  UserFeedbackItemComponent,
@@ -1,4 +1,5 @@
1
1
  export * from './lib/autocomplete/autocomplete.component'
2
+ export * from './lib/badge/badge.component'
2
3
  export * from './lib/button/button.component'
3
4
  export * from './lib/check-toggle/check-toggle.component'
4
5
  export * from './lib/checkbox/checkbox.component'
@@ -3,7 +3,6 @@
3
3
  }
4
4
  .clear-btn {
5
5
  width: var(--input-height);
6
- right: var(--input-height);
7
6
  height: 100%;
8
7
  }
9
8
  .search-btn {
@@ -8,23 +8,27 @@
8
8
  [matAutocomplete]="auto"
9
9
  (keyup.enter)="handleEnter(searchInput.value)"
10
10
  />
11
- <button
12
- type="button"
13
- class="text-primary-lightest hover:text-primary hover:bg-gray-50 absolute transition-all duration-100 clear-btn inset-y-0"
14
- *ngIf="searchInput.value"
15
- aria-label="Clear"
16
- (click)="clear()"
17
- >
18
- <mat-icon class="material-symbols-outlined">close</mat-icon>
19
- </button>
20
- <button
21
- type="button"
22
- class="text-primary bg-white hover:text-primary-darkest hover:bg-gray-100 border-gray-300 hover:border-gray-500 absolute transition-all duration-100 search-btn rounded-r inset-y-0 right-0"
23
- aria-label="Trigger search"
24
- (click)="handleClickSearch()"
25
- >
26
- <mat-icon class="material-symbols-outlined">search</mat-icon>
27
- </button>
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>
28
32
  <gn-ui-popup-alert
29
33
  *ngIf="error"
30
34
  class="absolute mt-2 w-full top-[100%] left-0"
@@ -39,13 +43,13 @@
39
43
  <mat-autocomplete
40
44
  #auto="matAutocomplete"
41
45
  (optionSelected)="handleSelection($event)"
42
- [displayWith]="displayWithFn"
46
+ [displayWith]="displayWithFnInternal"
43
47
  >
44
48
  <mat-option
45
49
  *ngFor="let suggestion of suggestions$ | async"
46
50
  [value]="suggestion"
47
51
  class="p-2 suggestion"
48
52
  >
49
- {{ displayWithFn(suggestion) }}
53
+ {{ displayWithFnInternal(suggestion) }}
50
54
  </mat-option>
51
55
  </mat-autocomplete>
@@ -13,25 +13,29 @@ import {
13
13
  SimpleChanges,
14
14
  ViewChild,
15
15
  } from '@angular/core'
16
- import { UntypedFormControl } from '@angular/forms'
16
+ import { ReactiveFormsModule, UntypedFormControl } from '@angular/forms'
17
17
  import {
18
18
  MatAutocomplete,
19
+ MatAutocompleteModule,
19
20
  MatAutocompleteSelectedEvent,
20
21
  MatAutocompleteTrigger,
21
22
  } from '@angular/material/autocomplete'
22
- import { merge, Observable, of, ReplaySubject, Subscription } from 'rxjs'
23
+ import { first, merge, Observable, of, ReplaySubject, Subscription } from 'rxjs'
23
24
  import {
24
25
  catchError,
25
26
  debounceTime,
26
27
  distinctUntilChanged,
27
28
  filter,
28
29
  finalize,
29
- first,
30
30
  map,
31
31
  switchMap,
32
32
  take,
33
33
  tap,
34
34
  } from 'rxjs/operators'
35
+ import { MatIconModule } from '@angular/material/icon'
36
+ import { PopupAlertComponent } from '../../../../../../libs/ui/widgets/src'
37
+ import { CommonModule } from '@angular/common'
38
+ import { TranslateModule } from '@ngx-translate/core'
35
39
 
36
40
  export type AutocompleteItem = unknown
37
41
 
@@ -40,6 +44,15 @@ export type AutocompleteItem = unknown
40
44
  templateUrl: './autocomplete.component.html',
41
45
  styleUrls: ['./autocomplete.component.css'],
42
46
  changeDetection: ChangeDetectionStrategy.OnPush,
47
+ standalone: true,
48
+ imports: [
49
+ MatIconModule,
50
+ PopupAlertComponent,
51
+ MatAutocompleteModule,
52
+ CommonModule,
53
+ TranslateModule,
54
+ ReactiveFormsModule,
55
+ ],
43
56
  })
44
57
  export class AutocompleteComponent
45
58
  implements OnInit, AfterViewInit, OnDestroy, OnChanges
@@ -49,6 +62,8 @@ export class AutocompleteComponent
49
62
  @Input() value?: AutocompleteItem
50
63
  @Input() clearOnSelection = false
51
64
  @Input() autoFocus = false
65
+ @Input() minCharacterCount? = 3
66
+ @Input() allowSubmit = true
52
67
  @Output() itemSelected = new EventEmitter<AutocompleteItem>()
53
68
  @Output() inputSubmitted = new EventEmitter<string>()
54
69
  @Output() inputCleared = new EventEmitter<void>()
@@ -57,22 +72,28 @@ export class AutocompleteComponent
57
72
  @ViewChild('searchInput') inputRef: ElementRef<HTMLInputElement>
58
73
 
59
74
  searching: boolean
60
- suggestions$: Observable<AutocompleteItem[]>
61
75
  control = new UntypedFormControl()
62
- subscription = new Subscription()
63
76
  cancelEnter = true
64
77
  selectionSubject = new ReplaySubject<MatAutocompleteSelectedEvent>(1)
65
78
  lastInputValue$ = new ReplaySubject<string>(1)
66
79
  error: string | null = null
80
+ suggestions$: Observable<AutocompleteItem[]>
81
+ subscription = new Subscription()
67
82
 
68
- @Input() displayWithFn: (AutocompleteItem) => string = (item) => item
83
+ @Input() displayWithFn: (item: AutocompleteItem) => string = (item) =>
84
+ item.toString()
85
+
86
+ displayWithFnInternal = (item?: AutocompleteItem) => {
87
+ if (item === null || item === undefined) return null
88
+ return this.displayWithFn(item)
89
+ }
69
90
 
70
91
  constructor(private cdRef: ChangeDetectorRef) {}
71
92
  ngOnChanges(changes: SimpleChanges): void {
72
93
  const { value } = changes
73
94
  if (value) {
74
- const previousTextValue = this.displayWithFn(value.previousValue)
75
- const currentTextValue = this.displayWithFn(value.currentValue)
95
+ const previousTextValue = this.displayWithFnInternal(value.previousValue)
96
+ const currentTextValue = this.displayWithFnInternal(value.currentValue)
76
97
  if (previousTextValue !== currentTextValue) {
77
98
  this.updateInputValue(value.currentValue)
78
99
  }
@@ -80,20 +101,33 @@ export class AutocompleteComponent
80
101
  }
81
102
 
82
103
  ngOnInit(): void {
83
- this.suggestions$ = merge(
104
+ const newValue$ = merge(
105
+ of(''),
106
+ this.inputCleared.pipe(map(() => '')),
84
107
  this.control.valueChanges.pipe(
85
108
  filter((value) => typeof value === 'string'),
86
- filter((value: string) => value.length > 2),
87
- debounceTime(400),
88
109
  distinctUntilChanged(),
89
- tap(() => (this.searching = true))
90
- ),
91
- this.control.valueChanges.pipe(
92
- filter((value) => typeof value === 'object' && value.title),
93
- map((item) => item.title)
110
+ debounceTime(400)
94
111
  )
112
+ )
113
+
114
+ const externalValueChange$ = this.control.valueChanges.pipe(
115
+ filter((value) => typeof value === 'object' && value.title),
116
+ map((item) => item.title)
117
+ )
118
+
119
+ // this observable emits arrays of suggestions loaded using the given action
120
+ const suggestionsFromAction = merge(
121
+ newValue$.pipe(
122
+ filter((value: string) => value.length >= this.minCharacterCount)
123
+ ),
124
+ externalValueChange$
95
125
  ).pipe(
96
- switchMap((value) => (value ? this.action(value) : of([]))),
126
+ tap(() => {
127
+ this.searching = true
128
+ this.error = null
129
+ }),
130
+ switchMap((value) => this.action(value)),
97
131
  catchError((error: Error) => {
98
132
  this.error = error.message
99
133
  return of([])
@@ -101,11 +135,32 @@ export class AutocompleteComponent
101
135
  finalize(() => (this.searching = false))
102
136
  )
103
137
 
104
- this.subscription = this.control.valueChanges.subscribe((any) => {
105
- if (any !== '') {
106
- this.cancelEnter = false
107
- }
108
- })
138
+ this.suggestions$ = merge(
139
+ suggestionsFromAction,
140
+ // if a new value is under the min char count, clear suggestions
141
+ newValue$.pipe(
142
+ filter((value: string) => value.length < this.minCharacterCount),
143
+ map(() => [])
144
+ )
145
+ )
146
+
147
+ // close the panel whenever suggestions are cleared
148
+ this.subscription.add(
149
+ this.suggestions$
150
+ .pipe(filter((suggestions) => suggestions.length === 0))
151
+ .subscribe(() => {
152
+ this.triggerRef?.closePanel()
153
+ })
154
+ )
155
+
156
+ this.subscription.add(
157
+ this.control.valueChanges.subscribe((any) => {
158
+ if (any !== '') {
159
+ this.cancelEnter = false
160
+ }
161
+ })
162
+ )
163
+
109
164
  this.control.valueChanges
110
165
  .pipe(filter((value) => typeof value === 'string'))
111
166
  .subscribe(this.lastInputValue$)
@@ -120,7 +175,7 @@ export class AutocompleteComponent
120
175
  }
121
176
 
122
177
  ngOnDestroy(): void {
123
- this.subscription.unsubscribe()
178
+ this.subscription?.unsubscribe()
124
179
  }
125
180
 
126
181
  updateInputValue(value: AutocompleteItem) {
@@ -139,19 +194,16 @@ export class AutocompleteComponent
139
194
  .pipe(take(1))
140
195
  .subscribe((selection) => selection && selection.option.deselect())
141
196
  this.inputRef.nativeElement.focus()
142
- this.triggerRef.closePanel()
143
197
  }
144
198
 
145
199
  handleEnter(any: string) {
146
- if (!this.cancelEnter) {
200
+ if (!this.cancelEnter && this.allowSubmit) {
147
201
  this.inputSubmitted.emit(any)
148
- this.triggerRef.closePanel()
149
202
  }
150
203
  }
151
204
 
152
205
  handleClickSearch() {
153
206
  this.inputSubmitted.emit(this.inputRef.nativeElement.value)
154
- this.triggerRef.closePanel()
155
207
  }
156
208
 
157
209
  handleSelection(event: MatAutocompleteSelectedEvent) {