geonetwork-ui 2.4.0-dev.a9a61288 → 2.4.0-dev.aa689838

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 (447) hide show
  1. package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +10 -3
  2. package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.mjs +1 -1
  3. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.mjs +5 -5
  4. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.mjs +7 -4
  5. package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.mjs +10 -7
  6. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.mjs +10 -15
  7. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +6 -6
  8. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +28 -18
  9. package/esm2022/libs/api/metadata-converter/src/lib/xml-utils.mjs +5 -3
  10. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +11 -1
  11. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +51 -7
  12. package/esm2022/libs/common/domain/src/lib/model/record/contact.model.mjs +28 -1
  13. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
  14. package/esm2022/libs/common/domain/src/lib/model/user/user.model.mjs +1 -1
  15. package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
  16. package/esm2022/libs/data-access/gn4/src/fixtures/site.fixtures.mjs +5 -5
  17. package/esm2022/libs/data-access/gn4/src/fixtures/ui.fixtures.mjs +3 -3
  18. package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +1 -1
  19. package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +1 -1
  20. package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +1 -1
  21. package/esm2022/libs/feature/editor/src/lib/+state/editor.actions.mjs +2 -1
  22. package/esm2022/libs/feature/editor/src/lib/+state/editor.effects.mjs +6 -1
  23. package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +4 -1
  24. package/esm2022/libs/feature/editor/src/lib/components/contact-card/contact-card.component.mjs +29 -0
  25. package/esm2022/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.mjs +78 -0
  26. package/esm2022/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.mjs +71 -0
  27. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.mjs +143 -0
  28. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +19 -41
  29. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +10 -8
  30. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.mjs +101 -0
  31. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.mjs +146 -0
  32. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.mjs +44 -0
  33. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.mjs +91 -11
  34. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.mjs +10 -6
  35. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +11 -11
  36. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.mjs +9 -8
  37. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +111 -5
  38. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.mjs +38 -68
  39. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +16 -14
  40. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +44 -53
  41. package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +5 -4
  42. package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +8 -8
  43. package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +6 -4
  44. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +34 -4
  45. package/esm2022/libs/feature/editor/src/lib/models/editor-config.model.mjs +1 -1
  46. package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +5 -1
  47. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.mjs +6 -6
  48. package/esm2022/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.mjs +7 -6
  49. package/esm2022/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.mjs +8 -5
  50. package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +6 -7
  51. package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +8 -7
  52. package/esm2022/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.mjs +7 -6
  53. package/esm2022/libs/feature/map/src/lib/feature-map.module.mjs +7 -26
  54. package/esm2022/libs/feature/map/src/lib/layers-panel/layers-panel.component.mjs +29 -13
  55. package/esm2022/libs/feature/map/src/lib/style/map-style.fixtures.mjs +3 -3
  56. package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +1 -1
  57. package/esm2022/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.mjs +1 -1
  58. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +1 -1
  59. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +4 -2
  60. package/esm2022/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.mjs +3 -3
  61. package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +10 -4
  62. package/esm2022/libs/ui/dataviz/src/lib/table/table.fixtures.mjs +3 -3
  63. package/esm2022/libs/ui/elements/src/index.mjs +1 -2
  64. package/esm2022/libs/ui/elements/src/lib/download-item/download-item.component.mjs +2 -2
  65. package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +1 -1
  66. package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +2 -2
  67. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +5 -5
  68. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +7 -4
  69. package/esm2022/libs/ui/inputs/src/index.mjs +5 -1
  70. package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +19 -5
  71. package/esm2022/libs/ui/inputs/src/lib/editable-label/editable-label.directive.mjs +26 -24
  72. package/esm2022/libs/ui/inputs/src/lib/file-input/file-input.component.mjs +87 -0
  73. package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +21 -23
  74. package/esm2022/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.mjs +32 -0
  75. package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +7 -21
  76. package/esm2022/libs/ui/inputs/src/lib/text-input/text-input.component.mjs +6 -17
  77. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +3 -7
  78. package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +43 -0
  79. package/esm2022/libs/ui/layout/src/index.mjs +3 -1
  80. package/esm2022/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.mjs +29 -0
  81. package/esm2022/libs/ui/layout/src/lib/sortable-list/sortable-list.component.mjs +43 -0
  82. package/esm2022/libs/ui/map/src/lib/ui-map.module.mjs +3 -3
  83. package/esm2022/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.mjs +7 -7
  84. package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +8 -8
  85. package/esm2022/libs/util/app-config/src/lib/fixtures.mjs +10 -10
  86. package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +1 -1
  87. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +1 -1
  88. package/esm2022/libs/util/shared/src/lib/utils/bytes-convert.mjs +4 -1
  89. package/esm2022/translations/de.json +57 -2
  90. package/esm2022/translations/en.json +57 -2
  91. package/esm2022/translations/es.json +55 -0
  92. package/esm2022/translations/fr.json +60 -5
  93. package/esm2022/translations/it.json +57 -2
  94. package/esm2022/translations/nl.json +55 -0
  95. package/esm2022/translations/pt.json +55 -0
  96. package/fesm2022/geonetwork-ui.mjs +2720 -1488
  97. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  98. package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts +3 -3
  99. package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
  100. package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts +2 -6
  101. package/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.d.ts.map +1 -1
  102. package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts +2 -2
  103. package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts.map +1 -1
  104. package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts +1 -1
  105. package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts.map +1 -1
  106. package/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.d.ts.map +1 -1
  107. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts +4 -5
  108. package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
  109. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts +7 -6
  110. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  111. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts.map +1 -1
  112. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +22 -2
  113. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  114. package/libs/common/domain/src/lib/model/record/contact.model.d.ts +1 -0
  115. package/libs/common/domain/src/lib/model/record/contact.model.d.ts.map +1 -1
  116. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +7 -6
  117. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  118. package/libs/common/domain/src/lib/model/user/user.model.d.ts +1 -1
  119. package/libs/common/domain/src/lib/model/user/user.model.d.ts.map +1 -1
  120. package/libs/common/domain/src/lib/platform.service.interface.d.ts +16 -0
  121. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  122. package/libs/data-access/gn4/src/fixtures/site.fixtures.d.ts +2 -2
  123. package/libs/data-access/gn4/src/fixtures/site.fixtures.d.ts.map +1 -1
  124. package/libs/data-access/gn4/src/fixtures/ui.fixtures.d.ts +1 -1
  125. package/libs/data-access/gn4/src/fixtures/ui.fixtures.d.ts.map +1 -1
  126. package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts +2 -2
  127. package/libs/feature/dataviz/src/lib/chart-view/chart-view.component.d.ts.map +1 -1
  128. package/libs/feature/dataviz/src/lib/service/data.service.d.ts +6 -6
  129. package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
  130. package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts +3 -3
  131. package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts.map +1 -1
  132. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts +1 -0
  133. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts.map +1 -1
  134. package/libs/feature/editor/src/lib/+state/editor.effects.d.ts +5 -0
  135. package/libs/feature/editor/src/lib/+state/editor.effects.d.ts.map +1 -1
  136. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +1 -0
  137. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
  138. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts +12 -0
  139. package/libs/feature/editor/src/lib/components/contact-card/contact-card.component.d.ts.map +1 -0
  140. package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts +32 -0
  141. package/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.d.ts.map +1 -0
  142. package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts +15 -0
  143. package/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.d.ts.map +1 -0
  144. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts +41 -0
  145. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts.map +1 -0
  146. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts +8 -19
  147. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts.map +1 -1
  148. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts +6 -4
  149. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts.map +1 -1
  150. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.d.ts +22 -0
  151. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.d.ts.map +1 -0
  152. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.d.ts +34 -0
  153. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.d.ts.map +1 -0
  154. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.d.ts +15 -0
  155. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.d.ts.map +1 -0
  156. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts +23 -4
  157. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.d.ts.map +1 -1
  158. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts +4 -3
  159. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts.map +1 -1
  160. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts +4 -4
  161. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -1
  162. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts +4 -3
  163. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts.map +1 -1
  164. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts +23 -0
  165. 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
  166. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts +10 -16
  167. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.d.ts.map +1 -1
  168. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +5 -5
  169. 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
  170. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +18 -24
  171. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  172. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts +5 -3
  173. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -1
  174. package/libs/feature/editor/src/lib/feature-editor.module.d.ts +2 -1
  175. package/libs/feature/editor/src/lib/feature-editor.module.d.ts.map +1 -1
  176. package/libs/feature/editor/src/lib/fields.config.d.ts +8 -0
  177. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  178. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts +5 -0
  179. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts.map +1 -1
  180. package/libs/feature/editor/src/lib/services/editor.service.d.ts +1 -0
  181. package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
  182. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts +1 -1
  183. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.d.ts.map +1 -1
  184. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts +6 -6
  185. package/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.d.ts.map +1 -1
  186. package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts +1 -1
  187. package/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.d.ts.map +1 -1
  188. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts +1 -1
  189. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts.map +1 -1
  190. package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts +1 -1
  191. package/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.d.ts.map +1 -1
  192. package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts +1 -1
  193. package/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.d.ts.map +1 -1
  194. package/libs/feature/map/src/lib/feature-map.module.d.ts +16 -21
  195. package/libs/feature/map/src/lib/feature-map.module.d.ts.map +1 -1
  196. package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts +1 -1
  197. package/libs/feature/map/src/lib/layers-panel/layers-panel.component.d.ts.map +1 -1
  198. package/libs/feature/map/src/lib/style/map-style.fixtures.d.ts +2 -2
  199. package/libs/feature/map/src/lib/style/map-style.fixtures.d.ts.map +1 -1
  200. package/libs/feature/record/src/lib/data-view/data-view.component.d.ts +3 -3
  201. package/libs/feature/record/src/lib/data-view/data-view.component.d.ts.map +1 -1
  202. package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts +2 -2
  203. package/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.d.ts.map +1 -1
  204. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +2 -2
  205. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
  206. package/libs/feature/record/src/lib/state/mdview.facade.d.ts +7 -7
  207. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  208. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +1 -0
  209. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -1
  210. package/libs/ui/dataviz/src/lib/table/table.fixtures.d.ts +2 -2
  211. package/libs/ui/dataviz/src/lib/table/table.fixtures.d.ts.map +1 -1
  212. package/libs/ui/elements/src/index.d.ts +0 -1
  213. package/libs/ui/elements/src/index.d.ts.map +1 -1
  214. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts +2 -2
  215. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts.map +1 -1
  216. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +7 -7
  217. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts.map +1 -1
  218. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +2 -2
  219. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
  220. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -1
  221. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  222. package/libs/ui/inputs/src/index.d.ts +4 -0
  223. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  224. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts +9 -1
  225. package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
  226. package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts +5 -3
  227. package/libs/ui/inputs/src/lib/editable-label/editable-label.directive.d.ts.map +1 -1
  228. package/libs/ui/inputs/src/lib/file-input/file-input.component.d.ts +24 -0
  229. package/libs/ui/inputs/src/lib/file-input/file-input.component.d.ts.map +1 -0
  230. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +6 -9
  231. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -1
  232. package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts +17 -0
  233. package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts.map +1 -0
  234. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +0 -4
  235. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
  236. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts +2 -4
  237. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts.map +1 -1
  238. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +34 -35
  239. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
  240. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts +18 -0
  241. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts.map +1 -0
  242. package/libs/ui/layout/src/index.d.ts +2 -0
  243. package/libs/ui/layout/src/index.d.ts.map +1 -1
  244. package/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.d.ts +20 -0
  245. package/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.d.ts.map +1 -0
  246. package/libs/ui/layout/src/lib/sortable-list/sortable-list.component.d.ts +14 -0
  247. package/libs/ui/layout/src/lib/sortable-list/sortable-list.component.d.ts.map +1 -0
  248. package/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.d.ts +3 -3
  249. package/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.d.ts.map +1 -1
  250. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +2 -2
  251. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
  252. package/libs/util/app-config/src/lib/fixtures.d.ts +8 -8
  253. package/libs/util/app-config/src/lib/fixtures.d.ts.map +1 -1
  254. package/libs/util/shared/src/lib/links/link-classifier.service.d.ts +3 -3
  255. package/libs/util/shared/src/lib/links/link-classifier.service.d.ts.map +1 -1
  256. package/libs/util/shared/src/lib/links/link-utils.d.ts +6 -6
  257. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  258. package/libs/util/shared/src/lib/utils/bytes-convert.d.ts +2 -1
  259. package/libs/util/shared/src/lib/utils/bytes-convert.d.ts.map +1 -1
  260. package/package.json +1 -1
  261. package/src/libs/api/metadata-converter/src/lib/fixtures/generic.records.ts +7 -2
  262. package/src/libs/api/metadata-converter/src/lib/fixtures/geo2france.records.ts +1 -1
  263. package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +1 -1
  264. package/src/libs/api/metadata-converter/src/lib/fixtures/metawal.records.ts +1 -1
  265. package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +18 -16
  266. package/src/libs/api/metadata-converter/src/lib/gn4/types/keywords.model.ts +2 -6
  267. package/src/libs/api/metadata-converter/src/lib/iso19115-3/iso19115-3.converter.ts +4 -4
  268. package/src/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.ts +12 -4
  269. package/src/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.ts +14 -8
  270. package/src/libs/api/metadata-converter/src/lib/iso19139/iso19139.converter.ts +7 -13
  271. package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +13 -15
  272. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +48 -36
  273. package/src/libs/api/metadata-converter/src/lib/xml-utils.ts +5 -5
  274. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +12 -1
  275. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +90 -15
  276. package/src/libs/common/domain/src/lib/model/record/contact.model.ts +28 -0
  277. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +8 -7
  278. package/src/libs/common/domain/src/lib/model/user/user.model.ts +1 -1
  279. package/src/libs/common/domain/src/lib/platform.service.interface.ts +30 -0
  280. package/src/libs/common/fixtures/src/index.ts +1 -1
  281. package/src/libs/common/fixtures/src/lib/editor/editor.fixtures.ts +37 -37
  282. package/src/libs/common/fixtures/src/lib/elasticsearch/{aggregations-request.ts → aggregations-request.fixtures.ts} +1 -3
  283. package/src/libs/common/fixtures/src/lib/elasticsearch/{aggregations-response.ts → aggregations-response.fixtures.ts} +6 -8
  284. package/src/libs/common/fixtures/src/lib/elasticsearch/{full-response.ts → full-response.fixtures.ts} +1 -3
  285. package/src/libs/common/fixtures/src/lib/elasticsearch/index.ts +5 -5
  286. package/src/libs/common/fixtures/src/lib/elasticsearch/metadata-links.fixtures.ts +1 -3
  287. package/src/libs/common/fixtures/src/lib/elasticsearch/metadata.fixtures.ts +1739 -1742
  288. package/src/libs/common/fixtures/src/lib/elasticsearch/{search-requests.ts → search-requests.fixtures.ts} +1 -3
  289. package/src/libs/common/fixtures/src/lib/elasticsearch/{search-responses.ts → search-responses.fixtures.ts} +4 -6
  290. package/src/libs/common/fixtures/src/lib/geojson.fixtures.ts +57178 -57195
  291. package/src/libs/common/fixtures/src/lib/gn4/groups.fixtures.ts +2 -4
  292. package/src/libs/common/fixtures/src/lib/link.fixtures.ts +233 -164
  293. package/src/libs/common/fixtures/src/lib/ol-feature.fixtures.ts +10 -0
  294. package/src/libs/common/fixtures/src/lib/organisations.fixture.ts +37 -3
  295. package/src/libs/common/fixtures/src/lib/record-link.fixtures.ts +9 -7
  296. package/src/libs/common/fixtures/src/lib/records.fixtures.ts +9 -9
  297. package/src/libs/common/fixtures/src/lib/repository.fixtures.ts +4 -4
  298. package/src/libs/common/fixtures/src/lib/search/aggregations.ts +2 -3
  299. package/src/libs/common/fixtures/src/lib/user-feedbacks.fixtures.ts +14 -15
  300. package/src/libs/common/fixtures/src/lib/user.fixtures.ts +32 -15
  301. package/src/libs/data-access/gn4/src/fixtures/site.fixtures.ts +4 -4
  302. package/src/libs/data-access/gn4/src/fixtures/ui.fixtures.ts +2 -2
  303. package/src/libs/feature/catalog/src/lib/sources/sources.fixture.ts +1 -1
  304. package/src/libs/feature/dataviz/src/lib/chart-view/chart-view.component.ts +3 -3
  305. package/src/libs/feature/dataviz/src/lib/figure/figure.fixtures.ts +2 -2
  306. package/src/libs/feature/dataviz/src/lib/service/data.service.ts +6 -6
  307. package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.ts +4 -4
  308. package/src/libs/feature/editor/src/lib/+state/editor.actions.ts +2 -0
  309. package/src/libs/feature/editor/src/lib/+state/editor.effects.ts +15 -0
  310. package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +4 -0
  311. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.html +25 -0
  312. package/src/libs/feature/editor/src/lib/components/contact-card/contact-card.component.ts +30 -0
  313. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.html +26 -0
  314. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.ts +89 -0
  315. package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.html +35 -0
  316. package/src/libs/feature/editor/src/lib/components/online-resource-card/online-resource-card.component.ts +79 -0
  317. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.css +0 -0
  318. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.html +86 -0
  319. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.ts +210 -0
  320. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.html +7 -17
  321. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.ts +18 -51
  322. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.ts +13 -5
  323. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.css +0 -0
  324. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.html +4 -0
  325. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-map-container/form-field-map-container.component.ts +128 -0
  326. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.css +0 -0
  327. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.html +33 -0
  328. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.ts +179 -0
  329. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.css +0 -0
  330. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.html +6 -0
  331. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-open-data/form-field-open-data.component.ts +48 -0
  332. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.html +11 -5
  333. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.ts +104 -7
  334. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.html +2 -2
  335. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.ts +9 -3
  336. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.html +2 -2
  337. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +13 -7
  338. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.html +5 -3
  339. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.ts +11 -4
  340. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +15 -1
  341. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.ts +156 -1
  342. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.html +30 -4
  343. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents.component.ts +41 -86
  344. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +17 -15
  345. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +111 -74
  346. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +48 -53
  347. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +3 -1
  348. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.ts +9 -4
  349. package/src/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.html +1 -1
  350. package/src/libs/feature/editor/src/lib/feature-editor.module.ts +2 -1
  351. package/src/libs/feature/editor/src/lib/fields.config.ts +37 -3
  352. package/src/libs/feature/editor/src/lib/models/editor-config.model.ts +9 -0
  353. package/src/libs/feature/editor/src/lib/services/editor.service.ts +7 -0
  354. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-from-catalog.component.ts +3 -0
  355. package/src/libs/feature/map/src/lib/add-layer-from-catalog/add-layer-record-preview/add-layer-record-preview.component.ts +12 -8
  356. package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.ts +5 -0
  357. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.html +1 -1
  358. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.ts +10 -7
  359. package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.html +1 -1
  360. package/src/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.ts +5 -0
  361. package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.html +1 -1
  362. package/src/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.ts +6 -1
  363. package/src/libs/feature/map/src/lib/feature-map.module.ts +2 -15
  364. package/src/libs/feature/map/src/lib/layers-panel/layers-panel.component.ts +24 -1
  365. package/src/libs/feature/map/src/lib/map-context/map-context.fixtures.ts +26 -22
  366. package/src/libs/feature/map/src/lib/style/map-style.fixtures.ts +29 -27
  367. package/src/libs/feature/record/src/lib/data-view/data-view.component.ts +3 -3
  368. package/src/libs/feature/record/src/lib/external-viewer-button/external-viewer-button.component.ts +2 -2
  369. package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +2 -2
  370. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +5 -1
  371. package/src/libs/feature/search/src/lib/fuzzy-search/fuzzy-search.component.html +1 -1
  372. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.html +1 -0
  373. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +22 -1
  374. package/src/libs/feature/search/src/lib/state/fixtures/search-state.fixtures.ts +2 -2
  375. package/src/libs/ui/dataviz/src/lib/chart/chart.fixtures.ts +2 -2
  376. package/src/libs/ui/dataviz/src/lib/table/table.fixtures.ts +2 -2
  377. package/src/libs/ui/elements/src/index.ts +0 -1
  378. package/src/libs/ui/elements/src/lib/download-item/download-item.component.ts +4 -4
  379. package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +7 -7
  380. package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +3 -3
  381. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +2 -2
  382. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +6 -1
  383. package/src/libs/ui/inputs/src/index.ts +4 -0
  384. package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +15 -3
  385. package/src/libs/ui/inputs/src/lib/editable-label/editable-label.directive.ts +40 -26
  386. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.css +0 -0
  387. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.html +85 -0
  388. package/src/libs/ui/inputs/src/lib/file-input/file-input.component.ts +92 -0
  389. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +50 -50
  390. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +19 -21
  391. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +3 -2
  392. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +3 -28
  393. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.html +4 -3
  394. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +4 -16
  395. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +0 -3
  396. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.css +9 -0
  397. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.html +37 -0
  398. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.ts +33 -0
  399. package/src/libs/ui/layout/src/index.ts +2 -0
  400. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.css +0 -0
  401. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.html +15 -0
  402. package/src/libs/ui/layout/src/lib/modal-dialog/modal-dialog.component.ts +44 -0
  403. package/src/libs/ui/layout/src/lib/sortable-list/sortable-list.component.html +37 -0
  404. package/src/libs/ui/{elements → layout}/src/lib/sortable-list/sortable-list.component.ts +15 -18
  405. package/src/libs/ui/map/src/lib/ui-map.module.ts +1 -1
  406. package/src/libs/ui/search/src/lib/facets/fixtures/aggregations-model-response.ts +7 -6
  407. package/src/libs/ui/search/src/lib/results-table/results-table.component.html +9 -2
  408. package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +5 -6
  409. package/src/libs/util/app-config/src/lib/fixtures.ts +9 -9
  410. package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +4 -3
  411. package/src/libs/util/shared/src/lib/links/link-utils.ts +6 -6
  412. package/src/libs/util/shared/src/lib/utils/bytes-convert.ts +4 -1
  413. package/tailwind.base.css +21 -4
  414. package/translations/de.json +57 -2
  415. package/translations/en.json +57 -2
  416. package/translations/es.json +55 -0
  417. package/translations/fr.json +60 -5
  418. package/translations/it.json +57 -2
  419. package/translations/nl.json +55 -0
  420. package/translations/pt.json +55 -0
  421. package/translations/sk.json +55 -0
  422. package/esm2022/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.mjs +0 -138
  423. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.mjs +0 -17
  424. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.mjs +0 -17
  425. package/esm2022/libs/ui/elements/src/lib/sortable-list/sortable-list.component.mjs +0 -43
  426. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts +0 -27
  427. package/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.d.ts.map +0 -1
  428. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.d.ts +0 -8
  429. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.d.ts.map +0 -1
  430. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.d.ts +0 -8
  431. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.d.ts.map +0 -1
  432. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts +0 -22
  433. package/libs/ui/elements/src/lib/sortable-list/sortable-list.component.d.ts.map +0 -1
  434. package/src/libs/common/fixtures/src/lib/ol-feature.fixture.ts +0 -7
  435. package/src/libs/common/fixtures/src/lib/utils/freeze.ts +0 -10
  436. package/src/libs/common/fixtures/src/lib/utils/index.ts +0 -1
  437. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +0 -10
  438. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +0 -166
  439. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.html +0 -7
  440. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.ts +0 -16
  441. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.html +0 -13
  442. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.ts +0 -16
  443. package/src/libs/ui/elements/src/lib/sortable-list/sortable-list.component.html +0 -36
  444. /package/src/libs/feature/editor/src/lib/components/{overview-upload/overview-upload.component.css → contact-card/contact-card.component.css} +0 -0
  445. /package/src/libs/feature/editor/src/lib/components/{record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-date/form-field-temporal-extents-date.component.css → generic-keywords/generic-keywords.component.css} +0 -0
  446. /package/src/libs/feature/editor/src/lib/components/{record-form/form-field/form-field-temporal-extents/form-field-temporal-extents-range/form-field-temporal-extents-range.component.css → online-resource-card/online-resource-card.component.css} +0 -0
  447. /package/src/libs/ui/{elements → layout}/src/lib/sortable-list/sortable-list.component.css +0 -0
@@ -0,0 +1,85 @@
1
+ <div class="w-full flex flex-col gap-[16px]">
2
+ <label
3
+ gnUiFilesDrop
4
+ class="flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100"
5
+ [ngClass]="{
6
+ 'border-primary-lighter bg-primary-white': dragFilesOver,
7
+ 'border-gray-300': !dragFilesOver
8
+ }"
9
+ (dragFilesOver)="handleDragFilesOver($event)"
10
+ (dropFiles)="handleDropFiles($event)"
11
+ >
12
+ <div
13
+ class="w-14 h-14 rounded-md bg-gray-50 grid"
14
+ *ngIf="!isUploadInProgress"
15
+ >
16
+ <mat-icon
17
+ *ngIf="!dragFilesOver"
18
+ class="material-symbols-outlined place-self-center text-primary"
19
+ >cloud_upload</mat-icon
20
+ >
21
+ <mat-icon
22
+ *ngIf="dragFilesOver"
23
+ class="material-symbols-outlined place-self-center text-primary"
24
+ >add_box</mat-icon
25
+ >
26
+ </div>
27
+ <div
28
+ *ngIf="isUploadInProgress"
29
+ class="w-14 h-14 grid items-center justify-center"
30
+ >
31
+ <div class="text-gray-100 absolute">
32
+ <mat-progress-spinner
33
+ class="place-self-center"
34
+ [diameter]="56"
35
+ mode="determinate"
36
+ [value]="100"
37
+ ></mat-progress-spinner>
38
+ </div>
39
+ <div class="text-primary absolute">
40
+ <mat-progress-spinner
41
+ class="place-self-center"
42
+ [diameter]="56"
43
+ mode="determinate"
44
+ [value]="uploadProgress"
45
+ ></mat-progress-spinner>
46
+ </div>
47
+ <span class="text-sm text-main font-bold">{{ uploadProgress }}%</span>
48
+ </div>
49
+ <div class="flex flex-col items-center gap-1">
50
+ <p class="font-medium">
51
+ {{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}
52
+ </p>
53
+ <p
54
+ class="text-sm"
55
+ [class]="
56
+ isUploadInProgress
57
+ ? 'font-bold text-primary cursor-pointer'
58
+ : 'font-medium text-gray-500'
59
+ "
60
+ (click)="handleSecondaryTextClick($event)"
61
+ >
62
+ {{ getSecondaryText() | translate }}
63
+ </p>
64
+ </div>
65
+ <p class="w-full flex flex-row items-center justify-stretch gap-[16px]">
66
+ <span class="border-b border-gray-300 grow"></span>
67
+ <span class="text-sm font-medium text-gray-500 or-input-url" translate>
68
+ input.file.orInputUrl</span
69
+ >
70
+ <span class="border-b border-gray-300 grow"></span>
71
+ </p>
72
+ <input
73
+ type="file"
74
+ class="hidden"
75
+ (change)="handleFileInput($event)"
76
+ [disabled]="isUploadInProgress"
77
+ />
78
+
79
+ <gn-ui-url-input
80
+ class="w-full"
81
+ [disabled]="isUploadInProgress"
82
+ (valueChange)="handleUrlChange($event)"
83
+ ></gn-ui-url-input>
84
+ </label>
85
+ </div>
@@ -0,0 +1,92 @@
1
+ import { CommonModule } from '@angular/common'
2
+ import {
3
+ ChangeDetectionStrategy,
4
+ ChangeDetectorRef,
5
+ Component,
6
+ EventEmitter,
7
+ Input,
8
+ Output,
9
+ } from '@angular/core'
10
+ import { MatIconModule } from '@angular/material/icon'
11
+ import { MatProgressSpinnerModule } from '@angular/material/progress-spinner'
12
+ import { ButtonComponent } from '../button/button.component'
13
+ import { FilesDropDirective } from '../files-drop/files-drop.directive'
14
+ import { TranslateModule } from '@ngx-translate/core'
15
+ import { marker } from '@biesbjerg/ngx-translate-extract-marker'
16
+ import { UrlInputComponent } from '../url-input/url-input.component'
17
+
18
+ @Component({
19
+ selector: 'gn-ui-file-input',
20
+ templateUrl: './file-input.component.html',
21
+ styleUrls: ['./file-input.component.css'],
22
+ changeDetection: ChangeDetectionStrategy.OnPush,
23
+ standalone: true,
24
+ imports: [
25
+ CommonModule,
26
+ ButtonComponent,
27
+ MatIconModule,
28
+ FilesDropDirective,
29
+ MatProgressSpinnerModule,
30
+ TranslateModule,
31
+ UrlInputComponent,
32
+ ],
33
+ })
34
+ export class FileInputComponent {
35
+ @Input() maxSizeMB: number
36
+ @Input() uploadProgress?: number
37
+ @Output() fileChange: EventEmitter<File> = new EventEmitter()
38
+ @Output() urlChange: EventEmitter<string> = new EventEmitter()
39
+ @Output() uploadCancel: EventEmitter<void> = new EventEmitter()
40
+
41
+ dragFilesOver = false
42
+
43
+ get isUploadInProgress() {
44
+ return this.uploadProgress !== undefined
45
+ }
46
+
47
+ constructor(private cd: ChangeDetectorRef) {}
48
+
49
+ getPrimaryText() {
50
+ if (this.uploadProgress) {
51
+ return marker('input.file.uploadProgressLabel')
52
+ }
53
+ return marker('input.file.selectFileLabel')
54
+ }
55
+
56
+ getSecondaryText() {
57
+ if (this.uploadProgress) {
58
+ return marker('input.file.uploadProgressCancel')
59
+ }
60
+ return marker('input.file.dropFileLabel')
61
+ }
62
+
63
+ handleDragFilesOver(dragFilesOver: boolean) {
64
+ this.dragFilesOver = dragFilesOver
65
+ this.cd.markForCheck()
66
+ }
67
+
68
+ handleDropFiles(files: File[]) {
69
+ if (files.length > 0) {
70
+ this.fileChange.emit(files[0])
71
+ }
72
+ }
73
+
74
+ handleFileInput(event: Event) {
75
+ this.handleDropFiles(Array.from((event.target as HTMLInputElement).files))
76
+ }
77
+
78
+ handleUrlChange(url: string) {
79
+ this.urlChange.emit(url)
80
+ }
81
+
82
+ handleSecondaryTextClick(event: Event) {
83
+ if (this.uploadProgress) {
84
+ this.handleCancel()
85
+ event.preventDefault()
86
+ }
87
+ }
88
+
89
+ handleCancel() {
90
+ this.uploadCancel.emit()
91
+ }
92
+ }
@@ -19,14 +19,12 @@
19
19
  <mat-icon class="material-symbols-outlined">delete</mat-icon>
20
20
  </gn-ui-button>
21
21
  </div>
22
- <input
22
+ <gn-ui-text-input
23
23
  *ngIf="showAltTextInput"
24
- type="text"
25
- class="py-3 px-2 border-2 border-gray-300 rounded-lg text-sm font-medium"
26
24
  [placeholder]="'input.image.altTextPlaceholder' | translate"
27
- [value]="altText"
28
- (change)="handleAltTextChange($event)"
29
- />
25
+ [value]="altText ?? ''"
26
+ (valueChange)="handleAltTextChange($event)"
27
+ ></gn-ui-text-input>
30
28
  <div class="flex flex-row gap-2">
31
29
  <gn-ui-button
32
30
  [extraClass]="'bg-gray-200 font-bold'"
@@ -51,50 +49,70 @@
51
49
  <div class="w-full h-full flex flex-col gap-2">
52
50
  <label
53
51
  gnUiFilesDrop
54
- class="block flex-1 border-2 border-dashed border-gray-300 rounded-lg p-6 flex flex-col items-center justify-center gap-4 hover:cursor-pointer"
52
+ class="flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4"
53
+ [ngClass]="{
54
+ 'border-primary-lighter bg-primary-white': dragFilesOver,
55
+ 'border-gray-300': !dragFilesOver
56
+ }"
55
57
  (dragFilesOver)="handleDragFilesOver($event)"
56
58
  (dropFiles)="handleDropFiles($event)"
57
59
  >
58
- <div class="w-14 h-14 rounded-md bg-gray-200 grid">
60
+ <div
61
+ class="w-14 h-14 rounded-md bg-gray-50 grid"
62
+ *ngIf="!isUploadInProgress && !uploadError"
63
+ >
59
64
  <mat-icon
60
- *ngIf="!dragFilesOver && !uploadProgress && !uploadError"
61
- class="material-symbols-outlined place-self-center text-blue-500"
65
+ *ngIf="!dragFilesOver"
66
+ class="material-symbols-outlined place-self-center text-primary"
62
67
  >image</mat-icon
63
68
  >
64
69
  <mat-icon
65
- *ngIf="dragFilesOver && !uploadProgress && !uploadError"
66
- class="material-symbols-outlined place-self-center text-blue-500"
70
+ *ngIf="dragFilesOver"
71
+ class="material-symbols-outlined place-self-center text-primary"
67
72
  >add_box</mat-icon
68
73
  >
69
- <div *ngIf="uploadProgress">
74
+ </div>
75
+
76
+ <div
77
+ *ngIf="isUploadInProgress && !uploadError"
78
+ class="w-14 h-14 grid items-center justify-center"
79
+ >
80
+ <div class="text-gray-100 absolute">
81
+ <mat-progress-spinner
82
+ class="place-self-center"
83
+ [diameter]="56"
84
+ mode="determinate"
85
+ [value]="100"
86
+ ></mat-progress-spinner>
87
+ </div>
88
+ <div class="text-primary absolute">
70
89
  <mat-progress-spinner
71
90
  class="place-self-center"
72
91
  [diameter]="56"
73
- [mode]="'determinate'"
92
+ mode="determinate"
74
93
  [value]="uploadProgress"
75
94
  ></mat-progress-spinner>
76
- <span
77
- class="text-sm font-medium relative inline-block width-[30px] bottom-[40px] left-[15px]"
78
- >
79
- {{ uploadProgress }}%
80
- </span>
81
95
  </div>
96
+ <span class="text-sm text-main font-bold">{{ uploadProgress }}%</span>
97
+ </div>
98
+
99
+ <div class="w-14 h-14 rounded-md bg-gray-50 grid" *ngIf="uploadError">
82
100
  <mat-icon
83
- *ngIf="uploadError"
84
101
  class="material-symbols-outlined place-self-center text-rose-500"
85
102
  >broken_image</mat-icon
86
103
  >
87
104
  </div>
105
+
88
106
  <div class="flex flex-col items-center gap-1">
89
107
  <p class="font-medium">{{ getPrimaryText() | translate }}</p>
90
108
  <p
91
109
  class="text-sm"
92
110
  [class]="
93
- uploadProgress || uploadError
111
+ isUploadInProgress || uploadError
94
112
  ? 'font-bold text-blue-500 cursor-pointer'
95
113
  : 'font-medium text-gray-500'
96
114
  "
97
- (click)="handleSecondaryTextClick()"
115
+ (click)="handleSecondaryTextClick($event)"
98
116
  >
99
117
  {{ getSecondaryText() | translate }}
100
118
  </p>
@@ -103,9 +121,10 @@
103
121
  type="file"
104
122
  class="hidden"
105
123
  (change)="handleFileInput($event)"
106
- [disabled]="showUrlInput || uploadProgress || uploadError"
124
+ [disabled]="showUrlInput || isUploadInProgress || uploadError"
107
125
  />
108
126
  </label>
127
+
109
128
  <div *ngIf="!showUrlInput" class="flex-none">
110
129
  <gn-ui-button
111
130
  [extraClass]="'bg-gray-200 font-bold'"
@@ -115,32 +134,13 @@
115
134
  {{ 'input.image.displayUrlInput' | translate }}
116
135
  </gn-ui-button>
117
136
  </div>
118
- <div *ngIf="showUrlInput" class="flex-none flex flex-col gap-2">
119
- <div class="h-2"></div>
120
- <div class="flex gap-2 items-center">
121
- <div class="flex-1 flex rounded-lg">
122
- <span
123
- class="material-symbols-outlined px-4 inline-flex items-center min-w-fit rounded-s-lg border-2 border-e-0 border-gray-300"
124
- >link</span
125
- >
126
- <input
127
- type="text"
128
- class="py-3 ps-1 block w-full border-2 border-s-0 border-e-0 border-gray-300 text-sm font-medium"
129
- placeholder="https://exemple.com/image.jpg"
130
- (change)="handleUrlChange($event)"
131
- />
132
- <gn-ui-button
133
- class="px-1 inline-flex items-center min-w-fit rounded-e-lg border-2 border-s-0 border-gray-300 text-white"
134
- [extraClass]="
135
- urlInputValue && !downloadError ? 'bg-blue-500' : 'bg-gray-500'
136
- "
137
- [disabled]="!urlInputValue || downloadError"
138
- (buttonClick)="downloadUrl()"
139
- >
140
- <mat-icon class="material-symbols-outlined">arrow_upward</mat-icon>
141
- </gn-ui-button>
142
- </div>
143
- </div>
144
- </div>
137
+
138
+ <gn-ui-url-input
139
+ *ngIf="showUrlInput"
140
+ class="mt-3.5"
141
+ (valueChange)="downloadUrl($event)"
142
+ [disabled]="isUploadInProgress"
143
+ >
144
+ </gn-ui-url-input>
145
145
  </div>
146
146
  </ng-template>
@@ -16,7 +16,8 @@ import { ButtonComponent } from '../button/button.component'
16
16
  import { FilesDropDirective } from '../files-drop/files-drop.directive'
17
17
  import { TranslateModule } from '@ngx-translate/core'
18
18
  import { marker } from '@biesbjerg/ngx-translate-extract-marker'
19
- import { FormControl, ReactiveFormsModule } from '@angular/forms'
19
+ import { UrlInputComponent } from '../url-input/url-input.component'
20
+ import { TextInputComponent } from '../text-input/text-input.component'
20
21
 
21
22
  @Component({
22
23
  selector: 'gn-ui-image-input',
@@ -31,13 +32,13 @@ import { FormControl, ReactiveFormsModule } from '@angular/forms'
31
32
  FilesDropDirective,
32
33
  MatProgressSpinnerModule,
33
34
  TranslateModule,
34
- ReactiveFormsModule,
35
+ UrlInputComponent,
36
+ TextInputComponent,
35
37
  ],
36
38
  })
37
39
  export class ImageInputComponent {
38
- @Input() formControl!: FormControl
39
40
  @Input() maxSizeMB: number
40
- @Input() previewUrl?: URL
41
+ @Input() previewUrl?: string
41
42
  @Input() altText?: string
42
43
  @Input() uploadProgress?: number
43
44
  @Input() uploadError?: boolean
@@ -52,10 +53,13 @@ export class ImageInputComponent {
52
53
  downloadError = false
53
54
  showAltTextInput = false
54
55
 
55
- urlInputValue?: string
56
56
  lastUploadType?: 'file' | 'url'
57
57
  lastUploadContent?: string | File
58
58
 
59
+ get isUploadInProgress() {
60
+ return this.uploadProgress !== undefined
61
+ }
62
+
59
63
  constructor(private http: HttpClient, private cd: ChangeDetectorRef) {}
60
64
 
61
65
  getPrimaryText() {
@@ -107,34 +111,29 @@ export class ImageInputComponent {
107
111
  this.showUrlInput = true
108
112
  }
109
113
 
110
- handleUrlChange(event: Event) {
114
+ async downloadUrl(url: string) {
111
115
  this.downloadError = false
112
- this.urlInputValue = (event.target as HTMLInputElement).value
113
- }
114
-
115
- async downloadUrl() {
116
- const name = this.urlInputValue.split('/').pop()
116
+ const name = url.split('/').pop()
117
117
 
118
118
  try {
119
119
  const response = await firstValueFrom(
120
- this.http.head(this.urlInputValue, { observe: 'response' })
120
+ this.http.head(url, { observe: 'response' })
121
121
  )
122
122
  if (
123
123
  response.headers.get('content-type')?.startsWith('image/') &&
124
124
  parseInt(response.headers.get('content-length')) <
125
125
  megabytesToBytes(this.maxSizeMB)
126
126
  ) {
127
- this.http.get(this.urlInputValue, { responseType: 'blob' }).subscribe({
127
+ this.http.get(url, { responseType: 'blob' }).subscribe({
128
128
  next: (blob) => {
129
129
  this.cd.markForCheck()
130
130
  const file = new File([blob], name)
131
131
  this.fileChange.emit(file)
132
132
  },
133
- error: (error) => {
134
- console.error(error)
133
+ error: () => {
135
134
  this.downloadError = true
136
135
  this.cd.markForCheck()
137
- this.urlChange.emit(this.urlInputValue)
136
+ this.urlChange.emit(url)
138
137
  },
139
138
  })
140
139
  }
@@ -145,11 +144,12 @@ export class ImageInputComponent {
145
144
  }
146
145
  }
147
146
 
148
- handleSecondaryTextClick() {
147
+ handleSecondaryTextClick(event: Event) {
149
148
  if (this.uploadError) {
150
149
  this.handleRetry()
151
150
  } else if (this.uploadProgress) {
152
151
  this.handleCancel()
152
+ event.preventDefault()
153
153
  }
154
154
  }
155
155
 
@@ -169,7 +169,6 @@ export class ImageInputComponent {
169
169
  }
170
170
 
171
171
  handleDelete() {
172
- this.formControl.markAsDirty()
173
172
  this.delete.emit()
174
173
  }
175
174
 
@@ -177,9 +176,8 @@ export class ImageInputComponent {
177
176
  this.showAltTextInput = !this.showAltTextInput
178
177
  }
179
178
 
180
- handleAltTextChange(event: Event) {
181
- const input = event.target as HTMLInputElement
182
- this.altTextChange.emit(input.value)
179
+ handleAltTextChange(altText: string) {
180
+ this.altTextChange.emit(altText)
183
181
  }
184
182
 
185
183
  private filterTypeImage(files: File[]) {
@@ -2,12 +2,13 @@
2
2
  <textarea
3
3
  #input
4
4
  name="textArea"
5
+ class="gn-ui-text-input leading-tight"
6
+ [ngClass]="extraClass"
5
7
  [disabled]="disabled"
6
8
  [placeholder]="placeholder"
7
- [value]="value"
9
+ [value]="value ?? ''"
8
10
  (change)="handleChange($event)"
9
11
  (input)="handleChange($event)"
10
- [class]="classList"
11
12
  [attr.required]="required || null"
12
13
  ></textarea>
13
14
  </div>
@@ -7,21 +7,20 @@ import {
7
7
  } from '@angular/core'
8
8
  import { Subject } from 'rxjs'
9
9
  import { distinctUntilChanged } from 'rxjs/operators'
10
+ import { CommonModule } from '@angular/common'
10
11
 
11
12
  @Component({
12
13
  selector: 'gn-ui-text-area',
13
14
  templateUrl: './text-area.component.html',
14
15
  styleUrls: ['./text-area.component.css'],
15
16
  standalone: true,
17
+ imports: [CommonModule],
16
18
  })
17
19
  export class TextAreaComponent implements AfterViewInit {
18
- private readonly baseClasses: string
19
- private readonly disabledClasses: string
20
-
21
20
  @Input() value = ''
22
21
  @Input() disabled = false
23
22
  @Input() extraClass = ''
24
- @Input() placeholder: string
23
+ @Input() placeholder = ''
25
24
  @Input() required = false
26
25
 
27
26
  rawChange = new Subject<string>()
@@ -29,30 +28,6 @@ export class TextAreaComponent implements AfterViewInit {
29
28
 
30
29
  @ViewChild('input') input
31
30
 
32
- constructor() {
33
- this.baseClasses = [
34
- 'w-full',
35
- 'pt-2',
36
- 'pl-2',
37
- 'resize-none',
38
- 'border',
39
- 'border-gray-800',
40
- 'rounded italic',
41
- 'leading-tight',
42
- 'focus:outline-none',
43
- 'focus:bg-background',
44
- 'focus:border-primary',
45
- ].join(' ')
46
-
47
- this.disabledClasses = ['cursor-not-allowed'].join(' ')
48
- }
49
-
50
- get classList() {
51
- return `${this.baseClasses} ${this.extraClass} ${
52
- this.disabled ? this.disabledClasses : ''
53
- }`
54
- }
55
-
56
31
  ngAfterViewInit() {
57
32
  this.checkRequired(this.input.nativeElement.value)
58
33
  }
@@ -1,12 +1,13 @@
1
1
  <input
2
2
  #input
3
- [class]="classList"
3
+ class="gn-ui-text-input"
4
+ [ngClass]="extraClass"
4
5
  type="text"
5
6
  [value]="value"
6
7
  (change)="handleChange($event)"
7
8
  (input)="handleChange($event)"
8
- [placeholder]="hint"
9
- [attr.aria-label]="hint"
9
+ [placeholder]="placeholder"
10
+ [attr.aria-label]="placeholder"
10
11
  [attr.required]="required || null"
11
12
  [disabled]="disabled"
12
13
  />
@@ -7,37 +7,25 @@ import {
7
7
  } from '@angular/core'
8
8
  import { distinctUntilChanged } from 'rxjs/operators'
9
9
  import { Subject } from 'rxjs'
10
+ import { CommonModule } from '@angular/common'
10
11
 
11
12
  @Component({
12
13
  selector: 'gn-ui-text-input',
13
14
  templateUrl: './text-input.component.html',
14
15
  styleUrls: ['./text-input.component.css'],
16
+ standalone: true,
17
+ imports: [CommonModule],
15
18
  })
16
19
  export class TextInputComponent implements AfterViewInit {
17
- private readonly baseClass = [
18
- 'appearance-none',
19
- 'border border-gray-300',
20
- 'rounded w-full',
21
- 'p-2',
22
- 'text-gray-700',
23
- 'leading-tight',
24
- 'focus:outline-none',
25
- 'focus:border-primary',
26
- ].join(' ')
27
-
28
20
  @Input() value = ''
29
21
  @Input() extraClass = ''
30
- @Input() hint: string
22
+ @Input() placeholder: string
31
23
  @Input() required = false
32
24
  @Input() disabled: boolean
33
25
  rawChange = new Subject<string>()
34
26
  @Output() valueChange = this.rawChange.pipe(distinctUntilChanged())
35
27
  @ViewChild('input') input
36
28
 
37
- get classList() {
38
- return `${this.baseClass} ${this.extraClass}`
39
- }
40
-
41
29
  ngAfterViewInit() {
42
30
  this.checkRequired(this.input.nativeElement.value)
43
31
  }
@@ -10,7 +10,6 @@ import { ChipsInputComponent } from './chips-input/chips-input.component'
10
10
  import { DragAndDropFileInputComponent } from './drag-and-drop-file-input/drag-and-drop-file-input.component'
11
11
  import { DropdownSelectorComponent } from './dropdown-selector/dropdown-selector.component'
12
12
  import { TextAreaComponent } from './text-area/text-area.component'
13
- import { TextInputComponent } from './text-input/text-input.component'
14
13
  import { MatAutocompleteModule } from '@angular/material/autocomplete'
15
14
  import { MatIconModule } from '@angular/material/icon'
16
15
  import { NavigationButtonComponent } from './navigation-button/navigation-button.component'
@@ -36,7 +35,6 @@ import { ImageInputComponent } from './image-input/image-input.component'
36
35
 
37
36
  @NgModule({
38
37
  declarations: [
39
- TextInputComponent,
40
38
  DragAndDropFileInputComponent,
41
39
  ChipsInputComponent,
42
40
  NavigationButtonComponent,
@@ -77,7 +75,6 @@ import { ImageInputComponent } from './image-input/image-input.component'
77
75
  exports: [
78
76
  DropdownSelectorComponent,
79
77
  ButtonComponent,
80
- TextInputComponent,
81
78
  DragAndDropFileInputComponent,
82
79
  TextAreaComponent,
83
80
  ChipsInputComponent,
@@ -0,0 +1,9 @@
1
+ :host {
2
+ --gn-ui-button-rounded: 8px;
3
+ --gn-ui-button-width: 32px;
4
+ --gn-ui-button-padding: 0;
5
+
6
+ --side-padding: calc(var(--gn-ui-text-input-padding, 0.6em) - 6px);
7
+ --2x-side-padding: calc(var(--side-padding) * 2);
8
+ --text-padding: calc(var(--side-padding) + 40px);
9
+ }
@@ -0,0 +1,37 @@
1
+ <span class="w-full inline-block relative">
2
+ <input
3
+ #input
4
+ class="gn-ui-text-input px-[var(--text-padding)]"
5
+ [ngClass]="extraClass"
6
+ type="url"
7
+ [value]="value"
8
+ (input)="handleInput()"
9
+ (keydown.enter)="handleChange(input)"
10
+ [placeholder]="placeholder"
11
+ [attr.aria-label]="placeholder"
12
+ [disabled]="disabled"
13
+ />
14
+ <div
15
+ class="absolute inset-y-[var(--side-padding)] left-[var(--2x-side-padding)] grid justify-center items-center pointer-events-none"
16
+ [ngClass]='{
17
+ "text-primary": !disabled,
18
+ "text-primary-lightest": disabled,
19
+ }'
20
+ >
21
+ <mat-icon
22
+ class="material-symbols-outlined h-[24px] !w-[26px] text-[28px] leading-[24px]"
23
+ >
24
+ link
25
+ </mat-icon>
26
+ </div>
27
+ <gn-ui-button
28
+ extraClass="absolute inset-y-[var(--side-padding)] right-[var(--side-padding)]"
29
+ type="primary"
30
+ [disabled]="disabled || input.value === ''"
31
+ (buttonClick)="handleChange(input)"
32
+ >
33
+ <mat-icon class="material-symbols-outlined text-[20px] leading-[26px]">
34
+ arrow_upward
35
+ </mat-icon>
36
+ </gn-ui-button>
37
+ </span>