geonetwork-ui 2.6.0-dev.502fa026d → 2.6.0-dev.76a84fb05

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 (249) hide show
  1. package/esm2022/libs/api/metadata-converter/src/lib/base.converter.mjs +1 -1
  2. package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +8 -3
  3. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +3 -3
  4. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +4 -4
  5. package/esm2022/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.mjs +2 -10
  6. package/esm2022/libs/api/repository/src/lib/gn4/gn4.provider.mjs +7 -1
  7. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
  8. package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +5 -1
  9. package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +5 -1
  10. package/esm2022/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.mjs +2 -3
  11. package/esm2022/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.mjs +1 -1
  12. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +5 -5
  13. package/esm2022/libs/feature/record/src/index.mjs +1 -2
  14. package/esm2022/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.mjs +5 -9
  15. package/esm2022/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.mjs +7 -11
  16. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +6 -1
  17. package/esm2022/libs/feature/record/src/lib/record-meta/record-meta.component.mjs +1 -1
  18. package/esm2022/libs/feature/record/src/lib/state/mdview.effects.mjs +8 -5
  19. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +4 -6
  20. package/esm2022/libs/feature/router/src/lib/default/constants.mjs +3 -1
  21. package/esm2022/libs/feature/router/src/lib/default/router.config.mjs +1 -1
  22. package/esm2022/libs/feature/router/src/lib/default/router.service.mjs +10 -2
  23. package/esm2022/libs/feature/router/src/lib/default/state/router.facade.mjs +9 -3
  24. package/esm2022/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.mjs +8 -7
  25. package/esm2022/libs/feature/search/src/lib/feature-search.module.mjs +2 -15
  26. package/esm2022/libs/feature/search/src/lib/record-url.token.mjs +4 -2
  27. package/esm2022/libs/feature/search/src/lib/results-list/results-list.container.component.mjs +26 -10
  28. package/esm2022/libs/ui/catalog/src/lib/language-switcher/language-switcher.component.mjs +3 -3
  29. package/esm2022/libs/ui/elements/src/index.mjs +3 -1
  30. package/esm2022/libs/ui/elements/src/lib/api-card/api-card.component.mjs +27 -6
  31. package/esm2022/libs/ui/elements/src/lib/download-item/download-item.component.mjs +22 -6
  32. package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +3 -3
  33. package/esm2022/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.mjs +163 -0
  34. package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +29 -7
  35. package/esm2022/libs/ui/elements/src/lib/metadata-catalog/metadata-catalog.component.mjs +3 -3
  36. package/esm2022/libs/ui/elements/src/lib/metadata-contact/metadata-contact.component.mjs +3 -3
  37. package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +8 -5
  38. package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +3 -3
  39. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +3 -2
  40. package/esm2022/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.mjs +161 -0
  41. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +16 -4
  42. package/esm2022/libs/ui/inputs/src/index.mjs +1 -2
  43. package/esm2022/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.mjs +4 -3
  44. package/esm2022/libs/ui/layout/src/lib/anchor-link/anchor-link.directive.mjs +43 -3
  45. package/esm2022/libs/ui/layout/src/lib/carousel/carousel.component.mjs +3 -3
  46. package/esm2022/libs/ui/layout/src/lib/interactive-table/interactive-table.component.mjs +15 -3
  47. package/esm2022/libs/ui/map/src/index.mjs +2 -1
  48. package/esm2022/libs/ui/map/src/lib/components/spatial-extent/spatial-extent.component.mjs +79 -0
  49. package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +5 -4
  50. package/esm2022/libs/ui/widgets/src/lib/progress-bar/progress-bar.component.mjs +3 -3
  51. package/esm2022/libs/util/app-config/src/lib/app-config.mjs +2 -1
  52. package/esm2022/libs/util/app-config/src/lib/fixtures.mjs +2 -1
  53. package/esm2022/libs/util/shared/src/index.mjs +2 -1
  54. package/esm2022/libs/util/shared/src/lib/gn-ui-version.mjs +6 -0
  55. package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +2 -1
  56. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +33 -24
  57. package/esm2022/translations/de.json +33 -3
  58. package/esm2022/translations/en.json +34 -4
  59. package/esm2022/translations/es.json +33 -3
  60. package/esm2022/translations/fr.json +35 -5
  61. package/esm2022/translations/it.json +33 -4
  62. package/esm2022/translations/nl.json +33 -3
  63. package/esm2022/translations/pt.json +33 -3
  64. package/fesm2022/geonetwork-ui.mjs +1266 -515
  65. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  66. package/libs/api/metadata-converter/src/lib/base.converter.d.ts.map +1 -1
  67. package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
  68. package/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.d.ts.map +1 -1
  69. package/libs/api/repository/src/lib/gn4/gn4.provider.d.ts.map +1 -1
  70. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +6 -2
  71. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  72. package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
  73. package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts +1 -1
  74. package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts.map +1 -1
  75. package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts.map +1 -1
  76. package/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.d.ts +6 -6
  77. package/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.d.ts.map +1 -1
  78. 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
  79. package/libs/feature/record/src/index.d.ts +0 -1
  80. package/libs/feature/record/src/index.d.ts.map +1 -1
  81. package/libs/feature/record/src/lib/data-view/data-view.component.d.ts +9 -1
  82. package/libs/feature/record/src/lib/data-view/data-view.component.d.ts.map +1 -1
  83. package/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.d.ts +2 -3
  84. package/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.d.ts.map +1 -1
  85. package/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.d.ts +1 -2
  86. package/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.d.ts.map +1 -1
  87. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
  88. package/libs/feature/record/src/lib/record-meta/record-meta.component.d.ts +2 -2
  89. package/libs/feature/record/src/lib/state/mdview.effects.d.ts +3 -1
  90. package/libs/feature/record/src/lib/state/mdview.effects.d.ts.map +1 -1
  91. package/libs/feature/record/src/lib/state/mdview.facade.d.ts +7 -7
  92. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  93. package/libs/feature/router/src/lib/default/constants.d.ts +2 -0
  94. package/libs/feature/router/src/lib/default/constants.d.ts.map +1 -1
  95. package/libs/feature/router/src/lib/default/router.config.d.ts +2 -0
  96. package/libs/feature/router/src/lib/default/router.config.d.ts.map +1 -1
  97. package/libs/feature/router/src/lib/default/router.service.d.ts.map +1 -1
  98. package/libs/feature/router/src/lib/default/state/router.facade.d.ts +5 -0
  99. package/libs/feature/router/src/lib/default/state/router.facade.d.ts.map +1 -1
  100. package/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.d.ts.map +1 -1
  101. package/libs/feature/search/src/lib/feature-search.module.d.ts.map +1 -1
  102. package/libs/feature/search/src/lib/record-url.token.d.ts +3 -1
  103. package/libs/feature/search/src/lib/record-url.token.d.ts.map +1 -1
  104. package/libs/feature/search/src/lib/results-list/results-list.container.component.d.ts +5 -3
  105. package/libs/feature/search/src/lib/results-list/results-list.container.component.d.ts.map +1 -1
  106. package/libs/ui/elements/src/index.d.ts +2 -0
  107. package/libs/ui/elements/src/index.d.ts.map +1 -1
  108. package/libs/ui/elements/src/lib/api-card/api-card.component.d.ts +9 -1
  109. package/libs/ui/elements/src/lib/api-card/api-card.component.d.ts.map +1 -1
  110. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts +8 -1
  111. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts.map +1 -1
  112. package/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.d.ts +43 -0
  113. package/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.d.ts.map +1 -0
  114. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +10 -2
  115. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
  116. package/libs/ui/elements/src/lib/metadata-info/metadata-info.component.d.ts +2 -2
  117. package/libs/ui/elements/src/lib/metadata-info/metadata-info.component.d.ts.map +1 -1
  118. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
  119. package/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.d.ts +30 -0
  120. package/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.d.ts.map +1 -0
  121. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +3 -1
  122. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  123. package/libs/ui/inputs/src/index.d.ts +0 -1
  124. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  125. package/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.d.ts.map +1 -1
  126. package/libs/ui/layout/src/lib/anchor-link/anchor-link.directive.d.ts +10 -3
  127. package/libs/ui/layout/src/lib/anchor-link/anchor-link.directive.d.ts.map +1 -1
  128. package/libs/ui/layout/src/lib/interactive-table/interactive-table.component.d.ts +2 -0
  129. package/libs/ui/layout/src/lib/interactive-table/interactive-table.component.d.ts.map +1 -1
  130. package/libs/ui/map/src/index.d.ts +1 -0
  131. package/libs/ui/map/src/index.d.ts.map +1 -1
  132. package/libs/ui/map/src/lib/components/spatial-extent/spatial-extent.component.d.ts +15 -0
  133. package/libs/ui/map/src/lib/components/spatial-extent/spatial-extent.component.d.ts.map +1 -0
  134. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
  135. package/libs/util/app-config/src/lib/app-config.d.ts.map +1 -1
  136. package/libs/util/app-config/src/lib/fixtures.d.ts.map +1 -1
  137. package/libs/util/shared/src/index.d.ts +1 -0
  138. package/libs/util/shared/src/index.d.ts.map +1 -1
  139. package/libs/util/shared/src/lib/gn-ui-version.d.ts +3 -0
  140. package/libs/util/shared/src/lib/gn-ui-version.d.ts.map +1 -0
  141. package/libs/util/shared/src/lib/links/link-classifier.service.d.ts +3 -3
  142. package/libs/util/shared/src/lib/links/link-classifier.service.d.ts.map +1 -1
  143. package/libs/util/shared/src/lib/links/link-utils.d.ts +30 -23
  144. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  145. package/package.json +1 -1
  146. package/src/libs/api/metadata-converter/src/lib/base.converter.ts +1 -4
  147. package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.service+eaux-usees.ts +2 -2
  148. package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +2 -2
  149. package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +2 -2
  150. package/src/libs/api/metadata-converter/src/lib/fixtures/wallonie.records.service+napitswallonia.ts +2 -2
  151. package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +8 -2
  152. package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +2 -2
  153. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +3 -3
  154. package/src/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.ts +1 -9
  155. package/src/libs/api/repository/src/lib/gn4/gn4.provider.ts +6 -0
  156. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +6 -2
  157. package/src/libs/common/fixtures/src/lib/elasticsearch/metadata-links.fixtures.ts +26 -26
  158. package/src/libs/common/fixtures/src/lib/link.fixtures.ts +2 -2
  159. package/src/libs/common/fixtures/src/lib/record-link.fixtures.ts +5 -5
  160. package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +4 -0
  161. package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.ts +4 -0
  162. package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.ts +1 -2
  163. package/src/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.ts +2 -2
  164. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +2 -2
  165. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.ts +2 -2
  166. package/src/libs/feature/record/src/index.ts +0 -1
  167. package/src/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.ts +2 -3
  168. package/src/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.ts +4 -5
  169. package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +5 -0
  170. package/src/libs/feature/record/src/lib/record-meta/record-meta.component.ts +2 -2
  171. package/src/libs/feature/record/src/lib/state/mdview.effects.ts +5 -3
  172. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +4 -7
  173. package/src/libs/feature/router/src/lib/default/constants.ts +2 -0
  174. package/src/libs/feature/router/src/lib/default/router.config.ts +2 -0
  175. package/src/libs/feature/router/src/lib/default/router.service.ts +10 -0
  176. package/src/libs/feature/router/src/lib/default/state/router.facade.ts +10 -1
  177. package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html +1 -7
  178. package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.ts +16 -8
  179. package/src/libs/feature/search/src/lib/feature-search.module.ts +0 -8
  180. package/src/libs/feature/search/src/lib/record-url.token.ts +10 -1
  181. package/src/libs/feature/search/src/lib/results-list/results-list.container.component.css +6 -0
  182. package/src/libs/feature/search/src/lib/results-list/results-list.container.component.html +1 -0
  183. package/src/libs/feature/search/src/lib/results-list/results-list.container.component.ts +24 -5
  184. package/src/libs/ui/catalog/src/lib/language-switcher/language-switcher.component.html +1 -1
  185. package/src/libs/ui/elements/src/index.ts +2 -0
  186. package/src/libs/ui/elements/src/lib/api-card/api-card.component.html +64 -38
  187. package/src/libs/ui/elements/src/lib/api-card/api-card.component.ts +26 -2
  188. package/src/libs/ui/elements/src/lib/download-item/download-item.component.html +17 -17
  189. package/src/libs/ui/elements/src/lib/download-item/download-item.component.ts +20 -2
  190. package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.html +7 -6
  191. package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.html +156 -0
  192. package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.ts +190 -0
  193. package/src/libs/ui/elements/src/lib/link-card/link-card.component.html +27 -29
  194. package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +33 -3
  195. package/src/libs/ui/elements/src/lib/metadata-catalog/metadata-catalog.component.html +1 -1
  196. package/src/libs/ui/elements/src/lib/metadata-contact/metadata-contact.component.html +1 -1
  197. package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.css +9 -0
  198. package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +13 -4
  199. package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts +12 -4
  200. package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +4 -2
  201. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +2 -1
  202. package/src/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.css +0 -0
  203. package/src/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.html +96 -0
  204. package/src/libs/ui/elements/src/lib/service-capabilities/service-capabilities.component.ts +183 -0
  205. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +6 -0
  206. package/src/libs/ui/inputs/src/index.ts +0 -1
  207. package/src/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.html +5 -5
  208. package/src/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.ts +2 -1
  209. package/src/libs/ui/layout/src/lib/anchor-link/anchor-link.directive.ts +46 -2
  210. package/src/libs/ui/layout/src/lib/carousel/carousel.component.css +0 -4
  211. package/src/libs/ui/layout/src/lib/interactive-table/interactive-table.component.html +3 -7
  212. package/src/libs/ui/layout/src/lib/interactive-table/interactive-table.component.ts +13 -0
  213. package/src/libs/ui/map/src/index.ts +1 -0
  214. package/src/libs/ui/map/src/lib/components/spatial-extent/spatial-extent.component.css +0 -0
  215. package/src/libs/ui/map/src/lib/components/spatial-extent/spatial-extent.component.html +4 -0
  216. package/src/libs/{feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.ts → ui/map/src/lib/components/spatial-extent/spatial-extent.component.ts} +7 -8
  217. package/src/libs/ui/search/src/lib/results-table/results-table.component.html +7 -4
  218. package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +2 -1
  219. package/src/libs/ui/widgets/src/lib/progress-bar/progress-bar.component.html +3 -2
  220. package/src/libs/util/app-config/src/lib/app-config.ts +1 -0
  221. package/src/libs/util/app-config/src/lib/fixtures.ts +1 -0
  222. package/src/libs/util/shared/src/index.ts +1 -0
  223. package/src/libs/util/shared/src/lib/gn-ui-version.ts +8 -0
  224. package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +12 -3
  225. package/src/libs/util/shared/src/lib/links/link-utils.ts +50 -30
  226. package/tailwind.base.css +51 -13
  227. package/translations/de.json +33 -3
  228. package/translations/en.json +34 -4
  229. package/translations/es.json +33 -3
  230. package/translations/fr.json +35 -5
  231. package/translations/it.json +33 -4
  232. package/translations/nl.json +33 -3
  233. package/translations/pt.json +33 -3
  234. package/translations/sk.json +33 -3
  235. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.mjs +0 -79
  236. package/esm2022/libs/feature/record/src/lib/gn-ui-version.token.mjs +0 -3
  237. package/esm2022/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.mjs +0 -16
  238. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.d.ts +0 -15
  239. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.d.ts.map +0 -1
  240. package/libs/feature/record/src/lib/gn-ui-version.token.d.ts +0 -3
  241. package/libs/feature/record/src/lib/gn-ui-version.token.d.ts.map +0 -1
  242. package/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.d.ts +0 -8
  243. package/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.d.ts.map +0 -1
  244. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.html +0 -1
  245. package/src/libs/feature/record/src/lib/gn-ui-version.token.ts +0 -3
  246. package/src/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.css +0 -3
  247. package/src/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.html +0 -9
  248. package/src/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.ts +0 -15
  249. /package/src/libs/{feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.css → ui/elements/src/lib/internal-link-card/internal-link-card.component.css} +0 -0
@@ -4,6 +4,8 @@ export interface RouterConfigModel {
4
4
  searchStateId: string
5
5
  searchRouteComponent: Type<any>
6
6
  recordRouteComponent: Type<any>
7
+ serviceRouteComponent: Type<any>
8
+ reuseRouteComponent: Type<any>
7
9
  organizationRouteComponent: Type<any>
8
10
  }
9
11
 
@@ -3,6 +3,8 @@ import {
3
3
  ROUTER_ROUTE_DATASET,
4
4
  ROUTER_ROUTE_ORGANIZATION,
5
5
  ROUTER_ROUTE_SEARCH,
6
+ ROUTER_ROUTE_SERVICE,
7
+ ROUTER_ROUTE_REUSE,
6
8
  } from '.'
7
9
  import { Router, Routes } from '@angular/router'
8
10
  import { ROUTER_CONFIG, RouterConfigModel } from './router.config'
@@ -34,6 +36,14 @@ export class RouterService {
34
36
  path: `${ROUTER_ROUTE_DATASET}/:metadataUuid`,
35
37
  component: this.routerConfig.recordRouteComponent,
36
38
  },
39
+ {
40
+ path: `${ROUTER_ROUTE_SERVICE}/:metadataUuid`,
41
+ component: this.routerConfig.recordRouteComponent,
42
+ },
43
+ {
44
+ path: `${ROUTER_ROUTE_REUSE}/:metadataUuid`,
45
+ component: this.routerConfig.recordRouteComponent,
46
+ },
37
47
  {
38
48
  path: `${ROUTER_ROUTE_ORGANIZATION}/:name`,
39
49
  component: this.routerConfig.organizationRouteComponent,
@@ -7,6 +7,8 @@ import { distinctUntilChanged, filter, map, take } from 'rxjs/operators'
7
7
  import {
8
8
  ROUTER_ROUTE_DATASET,
9
9
  ROUTER_ROUTE_SEARCH,
10
+ ROUTER_ROUTE_SERVICE,
11
+ ROUTER_ROUTE_REUSE,
10
12
  SearchRouteParams,
11
13
  } from '../constants'
12
14
  import {
@@ -32,12 +34,19 @@ export class RouterFacade {
32
34
  map(expandQueryParams)
33
35
  )
34
36
 
37
+ routeMap = {
38
+ dataset: ROUTER_ROUTE_DATASET,
39
+ service: ROUTER_ROUTE_SERVICE,
40
+ reuse: ROUTER_ROUTE_REUSE,
41
+ }
42
+
35
43
  constructor(
36
44
  private store: Store<RouterReducerState>,
37
45
  private routerService: RouterService
38
46
  ) {}
39
47
 
40
48
  goToMetadata(metadata: CatalogRecord) {
49
+ const selectedRoute = this.routeMap[metadata.kind] || ROUTER_ROUTE_DATASET
41
50
  this.pathParams$
42
51
  .pipe(
43
52
  take(1),
@@ -45,7 +54,7 @@ export class RouterFacade {
45
54
  )
46
55
  .subscribe(() => {
47
56
  this.go({
48
- path: `${ROUTER_ROUTE_DATASET}/${metadata.uniqueIdentifier}`,
57
+ path: `${selectedRoute}/${metadata.uniqueIdentifier}`,
49
58
  })
50
59
  this.store.dispatch(
51
60
  MdViewActions.setIncompleteMetadata({ incomplete: metadata })
@@ -1,6 +1,6 @@
1
1
  <div class="flex flex-row items-center">
2
2
  <span
3
- class="align-text-top mr-1.5"
3
+ class="align-text-top mr-1.5 mt-0.5"
4
4
  data-test="favorite-count"
5
5
  *ngIf="hasFavoriteCount && displayCount"
6
6
  >{{ favoriteCount }}</span
@@ -10,10 +10,4 @@
10
10
  (newValue)="toggleFavorite($event)"
11
11
  [disabled]="loading || (isAnonymous$ | async)"
12
12
  ></gn-ui-star-toggle>
13
- <span
14
- class="align-text-top ml-1.5"
15
- data-test="favorite-count"
16
- *ngIf="!displayCount"
17
- translate="datahub.record.addToFavorites"
18
- ></span>
19
13
  </div>
@@ -8,9 +8,15 @@ import {
8
8
  OnDestroy,
9
9
  ViewChild,
10
10
  } from '@angular/core'
11
- import { map, pairwise, withLatestFrom } from 'rxjs/operators'
11
+ import {
12
+ map,
13
+ pairwise,
14
+ startWith,
15
+ switchMap,
16
+ withLatestFrom,
17
+ } from 'rxjs/operators'
12
18
  import tippy from 'tippy.js'
13
- import { TranslateService } from '@ngx-translate/core'
19
+ import { TranslateModule, TranslateService } from '@ngx-translate/core'
14
20
  import { StarToggleComponent } from '../../../../../../../libs/ui/inputs/src'
15
21
  import { Observable, Subscription } from 'rxjs'
16
22
  import { CatalogRecord } from '../../../../../../../libs/common/domain/src/lib/model/record'
@@ -24,7 +30,7 @@ import { CommonModule } from '@angular/common'
24
30
  styleUrls: ['./favorite-star.component.css'],
25
31
  changeDetection: ChangeDetectionStrategy.OnPush,
26
32
  standalone: true,
27
- imports: [CommonModule, StarToggleComponent],
33
+ imports: [CommonModule, StarToggleComponent, TranslateModule],
28
34
  })
29
35
  export class FavoriteStarComponent implements AfterViewInit, OnDestroy {
30
36
  @Input() displayCount? = true
@@ -46,11 +52,13 @@ export class FavoriteStarComponent implements AfterViewInit, OnDestroy {
46
52
  favoriteCount: number | null
47
53
  loading = false
48
54
  loginUrl = this.authService.loginUrl
49
- loginMessage$: Observable<string> = this.translateService.get(
50
- 'favorite.not.authenticated.tooltip',
51
- {
52
- link: this.loginUrl,
53
- }
55
+ loginMessage$: Observable<string> = this.translateService.onLangChange.pipe(
56
+ startWith(null), // make sure to wait for translations to be loaded with and without language change
57
+ switchMap(() =>
58
+ this.translateService.get('favorite.not.authenticated.tooltip', {
59
+ link: this.loginUrl,
60
+ })
61
+ )
54
62
  )
55
63
  @ViewChild(StarToggleComponent, { read: ElementRef })
56
64
  starToggleRef: ElementRef
@@ -26,8 +26,6 @@ import {
26
26
  SpinningLoaderComponent,
27
27
  UiWidgetsModule,
28
28
  } from '../../../../../libs/ui/widgets/src'
29
- import { RecordsRepositoryInterface } from '../../../../../libs/common/domain/src/lib/repository/records-repository.interface'
30
- import { Gn4Repository } from '../../../../../libs/api/repository/src'
31
29
  import { FavoriteStarComponent } from './favorites/favorite-star/favorite-star.component'
32
30
 
33
31
  @NgModule({
@@ -72,11 +70,5 @@ import { FavoriteStarComponent } from './favorites/favorite-star/favorite-star.c
72
70
  SearchStateContainerDirective,
73
71
  FilterDropdownComponent,
74
72
  ],
75
- providers: [
76
- {
77
- provide: RecordsRepositoryInterface,
78
- useClass: Gn4Repository,
79
- },
80
- ],
81
73
  })
82
74
  export class FeatureSearchModule {}
@@ -1,4 +1,13 @@
1
1
  import { InjectionToken } from '@angular/core'
2
2
 
3
3
  // expects the replacement key ${uuid}
4
- export const RECORD_URL_TOKEN = new InjectionToken<string>('record-url-token')
4
+ export const RECORD_DATASET_URL_TOKEN = new InjectionToken<string>(
5
+ 'record-dataset-url-token'
6
+ )
7
+ export const RECORD_SERVICE_URL_TOKEN = new InjectionToken<string>(
8
+ 'record-service-url-token'
9
+ )
10
+
11
+ export const RECORD_REUSE_URL_TOKEN = new InjectionToken<string>(
12
+ 'record-reuse-url-token'
13
+ )
@@ -0,0 +1,6 @@
1
+ :host {
2
+ --gn-ui-button-height: 24px;
3
+ --gn-ui-button-width: 24px;
4
+ --gn-ui-button-color: var(--color-secondary);
5
+ --gn-ui-button-border-width: 0px;
6
+ }
@@ -16,6 +16,7 @@
16
16
  type="secondary"
17
17
  (buttonClick)="onShowMore()"
18
18
  extraClass="m-auto !p-[22px]"
19
+ [style.--gn-ui-button-width]="!auto"
19
20
  >
20
21
  <span class="uppercase font-medium tracking-widest" translate
21
22
  >results.showMore</span
@@ -17,7 +17,11 @@ import {
17
17
  ResultsLayoutConfigItem,
18
18
  ResultsLayoutConfigModel,
19
19
  } from '../../../../../../libs/ui/search/src'
20
- import { RECORD_URL_TOKEN } from '../record-url.token'
20
+ import {
21
+ RECORD_DATASET_URL_TOKEN,
22
+ RECORD_SERVICE_URL_TOKEN,
23
+ RECORD_REUSE_URL_TOKEN,
24
+ } from '../record-url.token'
21
25
  import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
22
26
 
23
27
  export type ResultsListShowMoreStrategy = 'auto' | 'button' | 'none'
@@ -49,8 +53,12 @@ export class ResultsListContainerComponent implements OnInit {
49
53
  @Inject(RESULTS_LAYOUT_CONFIG)
50
54
  private resultsLayoutConfig: ResultsLayoutConfigModel,
51
55
  @Optional()
52
- @Inject(RECORD_URL_TOKEN)
53
- private recordUrlTemplate: string
56
+ @Inject(RECORD_DATASET_URL_TOKEN)
57
+ private recordDatasetUrlTemplate: string,
58
+ @Inject(RECORD_SERVICE_URL_TOKEN)
59
+ private recordServiceUrlTemplate: string,
60
+ @Inject(RECORD_REUSE_URL_TOKEN)
61
+ private recordReuseUrlTemplate: string
54
62
  ) {}
55
63
 
56
64
  ngOnInit(): void {
@@ -103,7 +111,18 @@ export class ResultsListContainerComponent implements OnInit {
103
111
  }
104
112
 
105
113
  getRecordUrl(metadata: CatalogRecord) {
106
- if (!this.recordUrlTemplate) return null
107
- return this.recordUrlTemplate.replace('${uuid}', metadata.uniqueIdentifier)
114
+ const tokenMap = {
115
+ dataset: this.recordDatasetUrlTemplate,
116
+ service: this.recordServiceUrlTemplate,
117
+ reuse: this.recordReuseUrlTemplate,
118
+ }
119
+ if (
120
+ !this.recordDatasetUrlTemplate &&
121
+ !this.recordServiceUrlTemplate &&
122
+ !this.recordReuseUrlTemplate
123
+ )
124
+ return null
125
+ const urlKind = tokenMap[metadata.kind]
126
+ return urlKind.replace('${uuid}', metadata.uniqueIdentifier)
108
127
  }
109
128
  }
@@ -5,6 +5,6 @@
5
5
  [selected]="currentLang"
6
6
  ariaName="languages"
7
7
  [showTitle]="false"
8
- extraBtnClass="bg-transparent flex justify-items-center !pl-2 !py-1"
8
+ extraBtnClass="bg-transparent flex justify-items-center !pl-2 !py-1 rounded-lg"
9
9
  >
10
10
  </gn-ui-dropdown-selector>
@@ -23,3 +23,5 @@ export * from './lib/ui-elements.module'
23
23
  export * from './lib/user-feedback-item/user-feedback-item.component'
24
24
  export * from './lib/user-preview/user-preview.component'
25
25
  export * from './lib/application-banner/application-banner.component'
26
+ export * from './lib/internal-link-card/internal-link-card.component'
27
+ export * from './lib/service-capabilities/service-capabilities.component'
@@ -1,13 +1,66 @@
1
1
  <div
2
- class="group flex flex-col justify-between h-40 pt-5 pb-6 px-7 rounded filter overflow-hidden cursor-default"
2
+ class="group flex justify-between rounded filter overflow-hidden"
3
+ [ngClass]="cardClass"
3
4
  >
4
- <div
5
- class="font-title font-medium text-21 text-black text-ellipsis overflow-hidden break-words pb-5 h-[4.5rem]"
6
- >
7
- {{ link.name || link.description }}
5
+ <ng-container *ngIf="size !== 'S'">
6
+ <div>
7
+ <ng-container *ngTemplateOutlet="content"></ng-container>
8
+ </div>
9
+ <div class="flex items-center">
10
+ <ng-container *ngTemplateOutlet="buttons"></ng-container>
11
+ </div>
12
+ </ng-container>
13
+ <ng-container *ngIf="size === 'S'">
14
+ <ng-container *ngTemplateOutlet="content"></ng-container>
15
+ </ng-container>
16
+ </div>
17
+
18
+ <ng-template #buttons>
19
+ <div class="flex flex-row gap-2">
20
+ <gn-ui-copy-text-button
21
+ [text]="link.url"
22
+ [tooltipText]="'tooltip.url.copy' | translate"
23
+ [displayText]="false"
24
+ class="border border-gray-300 rounded-lg pt-1 px-2 h-[34px]"
25
+ ></gn-ui-copy-text-button>
26
+ <button
27
+ *ngIf="displayApiFormButton"
28
+ type="button"
29
+ class="gn-ui-card-icon"
30
+ [ngClass]="{
31
+ 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':
32
+ displayText,
33
+ }"
34
+ [matTooltip]="
35
+ !currentlyActive
36
+ ? ('record.metadata.api.form.openForm' | translate)
37
+ : ('record.metadata.api.form.closeForm' | translate)
38
+ "
39
+ matTooltipPosition="above"
40
+ (click)="openRecordApiFormPanel()"
41
+ >
42
+ <ng-icon
43
+ class="pointer-events-none align-middle card-icon"
44
+ name="iconoirSettings"
45
+ [ngClass]="{
46
+ 'text-secondary opacity-100': currentlyActive,
47
+ }"
48
+ ></ng-icon>
49
+ </button>
8
50
  </div>
9
- <div class="">
10
- <div class="flex flex-row justify-between">
51
+ </ng-template>
52
+
53
+ <ng-template #content>
54
+ <div>
55
+ <div class="gn-ui-card-title">
56
+ {{ link.description || link.name }}
57
+ </div>
58
+ <div class="gn-ui-card-detail">
59
+ {{ link.name }}
60
+ </div>
61
+ </div>
62
+ <div class="flex flex-row justify-between">
63
+ <div class="flex flex-row gap-2.5 items-center pt-1">
11
64
  <span
12
65
  *ngIf="link.accessServiceProtocol !== 'GPFDL'"
13
66
  class="bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors"
@@ -26,36 +79,9 @@
26
79
  >
27
80
  record.metadata.api.gpfdl</span
28
81
  >
29
- <div class="flex flex-row gap-2 items-center">
30
- <gn-ui-copy-text-button
31
- [text]="link.url"
32
- [tooltipText]="'tooltip.url.copy' | translate"
33
- [displayText]="false"
34
- ></gn-ui-copy-text-button>
35
- <button
36
- *ngIf="displayApiFormButton"
37
- type="button"
38
- [ngClass]="{
39
- 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':
40
- displayText,
41
- }"
42
- [matTooltip]="
43
- !currentlyActive
44
- ? ('record.metadata.api.form.openForm' | translate)
45
- : ('record.metadata.api.form.closeForm' | translate)
46
- "
47
- matTooltipPosition="above"
48
- (click)="openRecordApiFormPanel()"
49
- >
50
- <ng-icon
51
- class="pointer-events-none align-middle card-icon"
52
- name="matMoreHoriz"
53
- [ngClass]="{
54
- 'text-secondary opacity-100': currentlyActive,
55
- }"
56
- ></ng-icon>
57
- </button>
58
- </div>
82
+ </div>
83
+ <div *ngIf="size === 'S'">
84
+ <ng-container *ngTemplateOutlet="buttons"></ng-container>
59
85
  </div>
60
86
  </div>
61
- </div>
87
+ </ng-template>
@@ -14,7 +14,9 @@ import { CopyTextButtonComponent } from '../../../../../../libs/ui/inputs/src'
14
14
  import { TranslateModule } from '@ngx-translate/core'
15
15
  import { MatTooltipModule } from '@angular/material/tooltip'
16
16
  import { NgIcon, provideIcons } from '@ng-icons/core'
17
- import { matMoreHoriz } from '@ng-icons/material-icons/baseline'
17
+ import { iconoirSettings } from '@ng-icons/iconoir'
18
+
19
+ type CardSize = 'L' | 'M' | 'S' | 'XS'
18
20
 
19
21
  @Component({
20
22
  selector: 'gn-ui-api-card',
@@ -31,18 +33,40 @@ import { matMoreHoriz } from '@ng-icons/material-icons/baseline'
31
33
  ],
32
34
  viewProviders: [
33
35
  provideIcons({
34
- matMoreHoriz,
36
+ iconoirSettings,
35
37
  }),
36
38
  ],
37
39
  })
38
40
  export class ApiCardComponent implements OnInit, OnChanges {
41
+ private _size: 'L' | 'M' | 'S' | 'XS'
39
42
  @Input() link: DatasetServiceDistribution
40
43
  @Input() currentLink: DatasetServiceDistribution
44
+ private readonly sizeClassMap: Record<CardSize, string> = {
45
+ L: 'gn-ui-card-l py-2 px-5 flex-row',
46
+ M: 'gn-ui-card-m py-2 px-5 flex-row',
47
+ S: 'gn-ui-card-s p-4 flex-col',
48
+ XS: 'gn-ui-card-xs py-2 px-5 flex-row',
49
+ }
50
+
51
+ @Input() set size(value: CardSize) {
52
+ this._size = value
53
+ this.cardClass = this.sizeClassMap[value]
54
+ }
55
+ get size(): 'L' | 'M' | 'S' | 'XS' {
56
+ return this._size
57
+ }
58
+ cardClass = ''
41
59
  displayApiFormButton: boolean
42
60
  currentlyActive = false
43
61
  @Output() openRecordApiForm: EventEmitter<DatasetServiceDistribution> =
44
62
  new EventEmitter<DatasetServiceDistribution>()
45
63
 
64
+ get generatedText() {
65
+ return this.link.accessServiceProtocol === 'wfs'
66
+ ? 'datahub.search.filter.generatedByWfs'
67
+ : 'datahub.search.filter.generatedByAPI'
68
+ }
69
+
46
70
  ngOnInit() {
47
71
  this.displayApiFormButton =
48
72
  this.link.accessServiceProtocol === 'ogcFeatures' ||
@@ -1,36 +1,36 @@
1
1
  <a
2
2
  href="{{ link.url }}"
3
3
  target="_blank"
4
- class="group flex justify-between card-shadow px-6 py-5 cursor-pointer"
4
+ class="group flex flex-row justify-between card-shadow cursor-pointer rounded overflow-hidden"
5
5
  rel="noopener"
6
+ [ngClass]="cardClass"
6
7
  >
7
- <div class="grow-1 w-full overflow-hidden">
8
- <div
9
- class="text-21 text-black truncate font-title w-11/12"
10
- [title]="link.description || link.name"
11
- >
8
+ <div class="flex flex-col justify-between">
9
+ <div class="gn-ui-card-title" [title]="link.description || link.name">
12
10
  {{ link.description || link.name }}
13
11
  </div>
14
- <div class="pt-1">
12
+ <div class="gn-ui-card-detail">
13
+ {{ link.name }}
14
+ </div>
15
+ <div class="flex flex-row gap-2 items-center pt-1">
15
16
  <span
16
17
  class="inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded transition-opacity opacity-70 group-hover:opacity-100"
17
18
  [style.background-color]="color"
18
19
  data-cy="download-format"
19
20
  >{{ format || ('downloads.format.unknown' | translate) }}</span
20
21
  >
21
- <span
22
- class="pl-2 inline-flex items-center text-gray-800 text-sm"
23
- *ngIf="isFromApi"
24
- translate=""
22
+ <span class="text-gray-800 text-xs" *ngIf="isFromApi" translate=""
25
23
  >datahub.search.filter.generatedByAPI</span
26
24
  >
27
25
  </div>
28
26
  </div>
29
- <div class="shrink-1 w-14 flex flex-col justify-center items-center">
30
- <ng-icon
31
- class="!w-8 !h-8 card-icon text-3xl"
32
- name="matCloudDownloadOutline"
33
- >
34
- </ng-icon>
27
+ <div class="flex" [ngClass]="size === 'S' ? 'items-end' : 'items-center'">
28
+ <div class="gn-ui-card-icon">
29
+ <ng-icon
30
+ class="inline-block card-icon align-middle"
31
+ name="iconoirDownload"
32
+ >
33
+ </ng-icon>
34
+ </div>
35
35
  </div>
36
36
  </a>
@@ -9,7 +9,9 @@ import { DatasetOnlineResource } from '../../../../../../libs/common/domain/src/
9
9
  import { TranslateModule } from '@ngx-translate/core'
10
10
  import { CommonModule } from '@angular/common'
11
11
  import { NgIcon, provideIcons } from '@ng-icons/core'
12
- import { matCloudDownloadOutline } from '@ng-icons/material-icons/outline'
12
+ import { iconoirDownload } from '@ng-icons/iconoir'
13
+
14
+ type CardSize = 'L' | 'M' | 'S' | 'XS'
13
15
 
14
16
  @Component({
15
17
  selector: 'gn-ui-download-item',
@@ -20,15 +22,31 @@ import { matCloudDownloadOutline } from '@ng-icons/material-icons/outline'
20
22
  standalone: true,
21
23
  viewProviders: [
22
24
  provideIcons({
23
- matCloudDownloadOutline,
25
+ iconoirDownload,
24
26
  }),
25
27
  ],
26
28
  })
27
29
  export class DownloadItemComponent {
30
+ private _size: 'L' | 'M' | 'S' | 'XS'
28
31
  @Input() link: DatasetOnlineResource
29
32
  @Input() color: string
30
33
  @Input() format: string
31
34
  @Input() isFromApi: boolean
35
+ private readonly sizeClassMap: Record<CardSize, string> = {
36
+ L: 'gn-ui-card-l py-2 px-5',
37
+ M: 'gn-ui-card-m py-2 px-5',
38
+ S: 'gn-ui-card-s p-4',
39
+ XS: 'gn-ui-card-xs py-2 px-5',
40
+ }
41
+
42
+ @Input() set size(value: CardSize) {
43
+ this._size = value
44
+ this.cardClass = this.sizeClassMap[value]
45
+ }
46
+ get size(): 'L' | 'M' | 'S' | 'XS' {
47
+ return this._size
48
+ }
49
+ cardClass = ''
32
50
  @Output() exportUrl = new EventEmitter<string>()
33
51
 
34
52
  openUrl() {
@@ -1,22 +1,22 @@
1
1
  <div
2
- class="flex flex-wrap justify-between mt-8 mb-6 sm:mt-12 sm:mb-2"
2
+ class="flex flex-wrap justify-between items-center pb-4"
3
3
  *ngIf="links && links.length > 0"
4
4
  >
5
- <p
6
- class="font-title text-[28px] text-title font-medium mr-4 pb-4 text-center sm:text-left"
5
+ <div
6
+ class="font-title text-xl text-title font-medium mr-4 text-center sm:text-left"
7
7
  translate
8
8
  >
9
9
  record.metadata.download
10
- </p>
10
+ </div>
11
11
  <div
12
- class="flex flex-wrap justify-start sm:justify-end sm:pb-4"
12
+ class="flex flex-wrap justify-start sm:justify-end"
13
13
  data-cy="download-format-filters"
14
14
  >
15
15
  <gn-ui-button
16
16
  class="m-1 format-filter"
17
17
  [extraClass]="
18
18
  '!px-[12px] !py-[8px] !text-[15px]' +
19
- (isFilterActive(format) ? ' opacity-100' : ' opacity-50')
19
+ (isFilterActive(format) ? ' opacity-100' : ' opacity-60')
20
20
  "
21
21
  (buttonClick)="toggleFilterFormat(format)"
22
22
  [attr.data-format]="format"
@@ -28,6 +28,7 @@
28
28
  </div>
29
29
  <div class="mb-2 sm:mb-3" *ngFor="let link of filteredLinks">
30
30
  <gn-ui-download-item
31
+ size="L"
31
32
  [link]="link"
32
33
  [color]="getLinkColor(link)"
33
34
  [format]="getLinkFormat(link)"