geonetwork-ui 2.3.0-dev.6e2b8bea → 2.3.0-dev.9f0464ae

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 (420) hide show
  1. package/esm2022/index.mjs +2 -1
  2. package/esm2022/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.mjs +6 -2
  3. package/esm2022/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.mjs +1 -1
  4. package/esm2022/libs/api/repository/src/lib/gn4/auth/gravatar.service.mjs +12 -1
  5. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +36 -3
  6. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +19 -7
  7. package/esm2022/libs/common/domain/src/lib/model/record/index.mjs +2 -1
  8. package/esm2022/libs/common/domain/src/lib/model/record/user-feedbacks.model.mjs +2 -0
  9. package/esm2022/libs/common/domain/src/lib/model/user/index.mjs +2 -0
  10. package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
  11. package/esm2022/libs/data-access/gn4/src/openapi/api/records.api.service.mjs +35 -7
  12. package/esm2022/libs/data-access/gn4/src/openapi/model/models.mjs +1 -2
  13. package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +36 -3
  14. package/esm2022/libs/feature/editor/src/index.mjs +2 -2
  15. package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +6 -2
  16. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-array/form-field-array.component.mjs +11 -0
  17. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-file/form-field-file.component.mjs +28 -0
  18. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +64 -0
  19. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-object/form-field-object.component.mjs +11 -0
  20. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.mjs +15 -0
  21. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +45 -0
  22. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.mjs +50 -0
  23. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +11 -0
  24. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extent/form-field-temporal-extent.component.mjs +11 -0
  25. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +121 -0
  26. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.mjs +2 -0
  27. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/index.mjs +10 -0
  28. package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +29 -0
  29. package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +1 -1
  30. package/esm2022/libs/feature/editor/src/lib/feature-editor.module.mjs +10 -10
  31. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +16 -1
  32. package/esm2022/libs/feature/editor/src/lib/models/fields.model.mjs +1 -1
  33. package/esm2022/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.mjs +3 -3
  34. package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +73 -20
  35. package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +1 -1
  36. package/esm2022/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.mjs +1 -1
  37. package/esm2022/libs/feature/map/src/lib/map-context/map-context.model.mjs +1 -1
  38. package/esm2022/libs/feature/map/src/lib/map-context/map-context.service.mjs +29 -8
  39. package/esm2022/libs/feature/notifications/src/index.mjs +4 -0
  40. package/esm2022/libs/feature/notifications/src/lib/feature-notifications.module.mjs +18 -0
  41. package/esm2022/libs/feature/notifications/src/lib/notification.model.mjs +2 -0
  42. package/esm2022/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.mjs +49 -0
  43. package/esm2022/libs/feature/notifications/src/lib/notifications.service.mjs +29 -0
  44. package/esm2022/libs/feature/record/src/lib/feature-record.module.mjs +4 -4
  45. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +3 -2
  46. package/esm2022/libs/feature/record/src/lib/state/mdview.actions.mjs +22 -4
  47. package/esm2022/libs/feature/record/src/lib/state/mdview.effects.mjs +37 -10
  48. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +22 -7
  49. package/esm2022/libs/feature/record/src/lib/state/mdview.reducer.mjs +52 -17
  50. package/esm2022/libs/feature/record/src/lib/state/mdview.selectors.mjs +18 -3
  51. package/esm2022/libs/feature/router/src/lib/default/state/router.effects.mjs +2 -2
  52. package/esm2022/libs/feature/search/src/lib/results-table/results-table.component.mjs +3 -3
  53. package/esm2022/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.mjs +3 -3
  54. package/esm2022/libs/ui/elements/src/index.mjs +15 -15
  55. package/esm2022/libs/ui/elements/src/lib/api-card/api-card.component.mjs +3 -2
  56. package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +2 -2
  57. package/esm2022/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.mjs +5 -5
  58. package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +16 -3
  59. package/esm2022/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.mjs +45 -0
  60. package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
  61. package/esm2022/libs/ui/elements/src/lib/notification/notification.component.mjs +34 -0
  62. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +77 -15
  63. package/esm2022/libs/ui/elements/src/lib/thumbnail/thumbnail.component.mjs +4 -3
  64. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +14 -10
  65. package/esm2022/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.mjs +59 -0
  66. package/esm2022/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.mjs +62 -0
  67. package/esm2022/libs/ui/inputs/src/index.mjs +16 -16
  68. package/esm2022/libs/ui/inputs/src/lib/button/button.component.mjs +2 -1
  69. package/esm2022/libs/ui/inputs/src/lib/date-picker/date-picker.component.mjs +22 -0
  70. package/esm2022/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.mjs +7 -5
  71. package/esm2022/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.mjs +17 -8
  72. package/esm2022/libs/ui/inputs/src/lib/files-drop/files-drop.directive.mjs +59 -0
  73. package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +183 -0
  74. package/esm2022/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.mjs +29 -0
  75. package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +27 -4
  76. package/esm2022/libs/ui/inputs/src/lib/text-input/text-input.component.mjs +21 -3
  77. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +18 -29
  78. package/esm2022/libs/ui/layout/src/index.mjs +7 -5
  79. package/esm2022/libs/ui/layout/src/lib/block-list/block-list.component.mjs +76 -0
  80. package/esm2022/libs/ui/layout/src/lib/carousel/carousel.component.mjs +42 -18
  81. package/esm2022/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.mjs +18 -0
  82. package/esm2022/libs/ui/layout/src/lib/ui-layout.module.mjs +3 -8
  83. package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +2 -2
  84. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +22 -1
  85. package/esm2022/libs/util/shared/src/lib/utils/bytes-convert.mjs +4 -0
  86. package/esm2022/libs/util/shared/src/lib/utils/image-resize.mjs +60 -0
  87. package/esm2022/libs/util/shared/src/lib/utils/index.mjs +8 -6
  88. package/esm2022/translations/de.json +39 -0
  89. package/esm2022/translations/en.json +39 -0
  90. package/esm2022/translations/es.json +39 -0
  91. package/esm2022/translations/fr.json +39 -0
  92. package/esm2022/translations/it.json +39 -0
  93. package/esm2022/translations/nl.json +39 -0
  94. package/esm2022/translations/pt.json +39 -0
  95. package/fesm2022/geonetwork-ui.mjs +3532 -2011
  96. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  97. package/index.d.ts +1 -0
  98. package/index.d.ts.map +1 -1
  99. package/index.ts +1 -0
  100. package/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.d.ts.map +1 -1
  101. package/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.d.ts +1 -0
  102. package/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.d.ts.map +1 -1
  103. package/libs/api/repository/src/lib/gn4/auth/gravatar.service.d.ts +1 -0
  104. package/libs/api/repository/src/lib/gn4/auth/gravatar.service.d.ts.map +1 -1
  105. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts +6 -2
  106. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts.map +1 -1
  107. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +9 -6
  108. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  109. package/libs/common/domain/src/lib/model/record/index.d.ts +1 -0
  110. package/libs/common/domain/src/lib/model/record/index.d.ts.map +1 -1
  111. package/libs/common/domain/src/lib/model/record/user-feedbacks.model.d.ts +15 -0
  112. package/libs/common/domain/src/lib/model/record/user-feedbacks.model.d.ts.map +1 -0
  113. package/libs/common/domain/src/lib/model/user/index.d.ts +2 -0
  114. package/libs/common/domain/src/lib/model/user/index.d.ts.map +1 -0
  115. package/libs/common/domain/src/lib/platform.service.interface.d.ts +3 -0
  116. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  117. package/libs/data-access/gn4/src/openapi/api/records.api.service.d.ts +9 -5
  118. package/libs/data-access/gn4/src/openapi/api/records.api.service.d.ts.map +1 -1
  119. package/libs/data-access/gn4/src/openapi/model/models.d.ts +0 -1
  120. package/libs/data-access/gn4/src/openapi/model/models.d.ts.map +1 -1
  121. package/libs/feature/dataviz/src/lib/service/data.service.d.ts +3 -1
  122. package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
  123. package/libs/feature/editor/src/index.d.ts +1 -1
  124. package/libs/feature/editor/src/index.d.ts.map +1 -1
  125. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +8 -5
  126. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
  127. package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-array/form-field-array.component.d.ts +1 -1
  128. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-array/form-field-array.component.d.ts.map +1 -0
  129. package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-file/form-field-file.component.d.ts +1 -1
  130. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-file/form-field-file.component.d.ts.map +1 -0
  131. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts +39 -0
  132. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts.map +1 -0
  133. package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-object/form-field-object.component.d.ts +1 -1
  134. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-object/form-field-object.component.d.ts.map +1 -0
  135. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts +8 -0
  136. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts.map +1 -0
  137. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts +16 -0
  138. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -0
  139. package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-simple/form-field-simple.component.d.ts +2 -2
  140. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.d.ts.map +1 -0
  141. package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts +1 -1
  142. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts.map +1 -0
  143. package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-temporal-extent/form-field-temporal-extent.component.d.ts +1 -1
  144. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extent/form-field-temporal-extent.component.d.ts.map +1 -0
  145. package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field.component.d.ts +12 -4
  146. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -0
  147. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.d.ts.map +1 -0
  148. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts.map +1 -0
  149. package/libs/feature/editor/src/lib/{record-form → components/record-form}/record-form.component.d.ts +3 -3
  150. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -0
  151. package/libs/feature/editor/src/lib/feature-editor.module.d.ts +1 -1
  152. package/libs/feature/editor/src/lib/feature-editor.module.d.ts.map +1 -1
  153. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  154. package/libs/feature/editor/src/lib/models/fields.model.d.ts +1 -1
  155. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts +10 -5
  156. package/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.d.ts.map +1 -1
  157. package/libs/feature/map/src/lib/map-context/map-context.model.d.ts +1 -0
  158. package/libs/feature/map/src/lib/map-context/map-context.model.d.ts.map +1 -1
  159. package/libs/feature/map/src/lib/map-context/map-context.service.d.ts.map +1 -1
  160. package/libs/feature/notifications/src/index.d.ts +4 -0
  161. package/libs/feature/notifications/src/index.d.ts.map +1 -0
  162. package/libs/feature/notifications/src/lib/feature-notifications.module.d.ts +7 -0
  163. package/libs/feature/notifications/src/lib/feature-notifications.module.d.ts.map +1 -0
  164. package/libs/feature/notifications/src/lib/notification.model.d.ts +7 -0
  165. package/libs/feature/notifications/src/lib/notification.model.d.ts.map +1 -0
  166. package/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.d.ts +12 -0
  167. package/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.d.ts.map +1 -0
  168. package/libs/feature/notifications/src/lib/notifications.service.d.ts +15 -0
  169. package/libs/feature/notifications/src/lib/notifications.service.d.ts.map +1 -0
  170. package/libs/feature/record/src/lib/feature-record.module.d.ts.map +1 -1
  171. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
  172. package/libs/feature/record/src/lib/state/mdview.actions.d.ts +40 -6
  173. package/libs/feature/record/src/lib/state/mdview.actions.d.ts.map +1 -1
  174. package/libs/feature/record/src/lib/state/mdview.effects.d.ts +24 -4
  175. package/libs/feature/record/src/lib/state/mdview.effects.d.ts.map +1 -1
  176. package/libs/feature/record/src/lib/state/mdview.facade.d.ts +14 -4
  177. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  178. package/libs/feature/record/src/lib/state/mdview.reducer.d.ts +8 -5
  179. package/libs/feature/record/src/lib/state/mdview.reducer.d.ts.map +1 -1
  180. package/libs/feature/record/src/lib/state/mdview.selectors.d.ts +12 -9
  181. package/libs/feature/record/src/lib/state/mdview.selectors.d.ts.map +1 -1
  182. package/libs/ui/elements/src/index.d.ts +14 -14
  183. package/libs/ui/elements/src/index.d.ts.map +1 -1
  184. package/libs/ui/elements/src/lib/api-card/api-card.component.d.ts.map +1 -1
  185. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
  186. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +3 -1
  187. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
  188. package/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.d.ts +13 -0
  189. package/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.d.ts.map +1 -0
  190. package/libs/ui/elements/src/lib/notification/notification.component.d.ts +13 -0
  191. package/libs/ui/elements/src/lib/notification/notification.component.d.ts.map +1 -0
  192. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +12 -3
  193. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
  194. package/libs/ui/elements/src/lib/thumbnail/thumbnail.component.d.ts +1 -1
  195. package/libs/ui/elements/src/lib/thumbnail/thumbnail.component.d.ts.map +1 -1
  196. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +29 -28
  197. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  198. package/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.d.ts +11 -0
  199. package/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.d.ts.map +1 -0
  200. package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts +22 -0
  201. package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts.map +1 -0
  202. package/libs/ui/inputs/src/index.d.ts +15 -15
  203. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  204. package/libs/ui/inputs/src/lib/button/button.component.d.ts.map +1 -1
  205. package/libs/ui/inputs/src/lib/date-picker/date-picker.component.d.ts +9 -0
  206. package/libs/ui/inputs/src/lib/date-picker/date-picker.component.d.ts.map +1 -0
  207. package/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.d.ts +1 -1
  208. package/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.d.ts.map +1 -1
  209. package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts +1 -1
  210. package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts.map +1 -1
  211. package/libs/ui/inputs/src/lib/files-drop/files-drop.directive.d.ts +14 -0
  212. package/libs/ui/inputs/src/lib/files-drop/files-drop.directive.d.ts.map +1 -0
  213. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +44 -0
  214. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -0
  215. package/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.d.ts +12 -0
  216. package/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.d.ts.map +1 -0
  217. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +7 -1
  218. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
  219. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts +5 -1
  220. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts.map +1 -1
  221. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +35 -42
  222. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
  223. package/libs/ui/layout/src/index.d.ts +6 -4
  224. package/libs/ui/layout/src/index.d.ts.map +1 -1
  225. package/libs/ui/layout/src/lib/block-list/block-list.component.d.ts +25 -0
  226. package/libs/ui/layout/src/lib/block-list/block-list.component.d.ts.map +1 -0
  227. package/libs/ui/layout/src/lib/carousel/carousel.component.d.ts +13 -6
  228. package/libs/ui/layout/src/lib/carousel/carousel.component.d.ts.map +1 -1
  229. package/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.d.ts +8 -0
  230. package/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.d.ts.map +1 -0
  231. package/libs/ui/layout/src/lib/ui-layout.module.d.ts +4 -5
  232. package/libs/ui/layout/src/lib/ui-layout.module.d.ts.map +1 -1
  233. package/libs/util/shared/src/lib/links/link-utils.d.ts +18 -0
  234. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  235. package/libs/util/shared/src/lib/utils/bytes-convert.d.ts +2 -0
  236. package/libs/util/shared/src/lib/utils/bytes-convert.d.ts.map +1 -0
  237. package/libs/util/shared/src/lib/utils/image-resize.d.ts +3 -0
  238. package/libs/util/shared/src/lib/utils/image-resize.d.ts.map +1 -0
  239. package/libs/util/shared/src/lib/utils/index.d.ts +7 -5
  240. package/libs/util/shared/src/lib/utils/index.d.ts.map +1 -1
  241. package/package.json +1 -1
  242. package/src/libs/api/metadata-converter/src/lib/gn4/gn4.field.mapper.ts +7 -1
  243. package/src/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.ts +1 -0
  244. package/src/libs/api/repository/src/lib/gn4/auth/gravatar.service.ts +12 -1
  245. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +51 -1
  246. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +34 -7
  247. package/src/libs/common/domain/src/lib/model/record/index.ts +1 -0
  248. package/src/libs/common/domain/src/lib/model/record/user-feedbacks.model.ts +15 -0
  249. package/src/libs/common/domain/src/lib/platform.service.interface.ts +3 -0
  250. package/src/libs/common/fixtures/src/index.ts +8 -6
  251. package/src/libs/common/fixtures/src/lib/link.fixtures.ts +8 -0
  252. package/src/libs/common/fixtures/src/lib/records.fixtures.ts +3 -3
  253. package/src/libs/common/fixtures/src/lib/user-feedbacks.fixtures.ts +83 -0
  254. package/src/libs/data-access/gn4/src/openapi/api/records.api.service.ts +43 -12
  255. package/src/libs/data-access/gn4/src/openapi/model/models.ts +0 -1
  256. package/src/libs/data-access/gn4/src/spec.yaml +1 -1
  257. package/src/libs/feature/dataviz/src/lib/service/data.service.ts +52 -2
  258. package/src/libs/feature/editor/src/index.ts +1 -1
  259. package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +8 -1
  260. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +8 -0
  261. package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +70 -0
  262. package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-array/form-field-array.component.ts +1 -0
  263. package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-file/form-field-file.component.ts +4 -1
  264. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.html +8 -0
  265. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.ts +64 -0
  266. package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-object/form-field-object.component.ts +1 -0
  267. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.html +4 -0
  268. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.ts +15 -0
  269. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.html +20 -0
  270. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +44 -0
  271. package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-simple/form-field-simple.component.ts +4 -1
  272. package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-spatial-extent/form-field-spatial-extent.component.ts +1 -0
  273. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-temporal-extent/form-field-temporal-extent.component.css +0 -0
  274. package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-temporal-extent/form-field-temporal-extent.component.ts +1 -0
  275. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.css +0 -0
  276. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +92 -0
  277. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +137 -0
  278. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.css +0 -0
  279. package/src/libs/feature/editor/src/lib/{record-form → components/record-form}/record-form.component.html +1 -0
  280. package/src/libs/feature/editor/src/lib/{record-form → components/record-form}/record-form.component.ts +4 -4
  281. package/src/libs/feature/editor/src/lib/feature-editor.module.ts +9 -9
  282. package/src/libs/feature/editor/src/lib/fields.config.ts +15 -0
  283. package/src/libs/feature/editor/src/lib/models/fields.model.ts +1 -1
  284. package/src/libs/feature/map/src/lib/add-layer-from-file/add-layer-from-file.component.html +1 -1
  285. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.css +7 -0
  286. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.html +32 -18
  287. package/src/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.ts +72 -17
  288. package/src/libs/feature/map/src/lib/map-context/map-context.model.ts +1 -0
  289. package/src/libs/feature/map/src/lib/map-context/map-context.service.ts +26 -8
  290. package/src/libs/feature/notifications/src/index.ts +3 -0
  291. package/src/libs/feature/notifications/src/lib/feature-notifications.module.ts +10 -0
  292. package/src/libs/feature/notifications/src/lib/notification.model.ts +6 -0
  293. package/src/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.css +0 -0
  294. package/src/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.html +17 -0
  295. package/src/libs/feature/notifications/src/lib/notifications-container/notifications-container.component.ts +44 -0
  296. package/src/libs/feature/notifications/src/lib/notifications.service.ts +27 -0
  297. package/src/libs/feature/record/src/lib/feature-record.module.ts +5 -2
  298. package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +2 -1
  299. package/src/libs/feature/record/src/lib/state/mdview.actions.ts +51 -6
  300. package/src/libs/feature/record/src/lib/state/mdview.effects.ts +82 -7
  301. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +48 -8
  302. package/src/libs/feature/record/src/lib/state/mdview.reducer.ts +81 -24
  303. package/src/libs/feature/record/src/lib/state/mdview.selectors.ts +40 -10
  304. package/src/libs/feature/router/src/lib/default/state/router.effects.ts +2 -2
  305. package/src/libs/feature/search/src/lib/results-table/results-table.component.html +3 -3
  306. package/src/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.html +5 -5
  307. package/src/libs/ui/elements/src/index.ts +14 -14
  308. package/src/libs/ui/elements/src/lib/api-card/api-card.component.ts +2 -1
  309. package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +1 -1
  310. package/src/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.html +1 -1
  311. package/src/libs/ui/elements/src/lib/link-card/link-card.component.html +38 -20
  312. package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +12 -0
  313. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.css +0 -5
  314. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.html +0 -21
  315. package/src/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.ts +1 -14
  316. package/src/libs/ui/elements/src/lib/notification/notification.component.css +0 -0
  317. package/src/libs/ui/elements/src/lib/notification/notification.component.html +52 -0
  318. package/src/libs/ui/elements/src/lib/notification/notification.component.ts +31 -0
  319. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +27 -11
  320. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +87 -8
  321. package/src/libs/ui/elements/src/lib/thumbnail/thumbnail.component.ts +5 -3
  322. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +6 -3
  323. package/src/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.ts +54 -0
  324. package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.css +0 -0
  325. package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.html +75 -0
  326. package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.ts +63 -0
  327. package/src/libs/ui/inputs/src/index.ts +15 -15
  328. package/src/libs/ui/inputs/src/lib/button/button.component.ts +1 -1
  329. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.css +3 -0
  330. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.html +11 -0
  331. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.ts +16 -0
  332. package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.ts +8 -1
  333. package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.ts +13 -0
  334. package/src/libs/ui/inputs/src/lib/files-drop/files-drop.directive.ts +45 -0
  335. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.css +0 -0
  336. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +146 -0
  337. package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +193 -0
  338. package/src/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.css +6 -0
  339. package/src/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.html +26 -0
  340. package/src/libs/ui/inputs/src/lib/previous-next-buttons/previous-next-buttons.component.ts +32 -0
  341. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +2 -1
  342. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +29 -0
  343. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.html +2 -1
  344. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +17 -1
  345. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +5 -21
  346. package/src/libs/ui/layout/src/index.ts +6 -4
  347. package/src/libs/ui/layout/src/lib/block-list/block-list.component.css +23 -0
  348. package/src/libs/ui/layout/src/lib/block-list/block-list.component.html +20 -0
  349. package/src/libs/ui/layout/src/lib/block-list/block-list.component.ts +84 -0
  350. package/src/libs/ui/layout/src/lib/carousel/carousel.component.css +8 -4
  351. package/src/libs/ui/layout/src/lib/carousel/carousel.component.html +4 -4
  352. package/src/libs/ui/layout/src/lib/carousel/carousel.component.ts +45 -15
  353. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.css +0 -0
  354. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.html +18 -0
  355. package/src/libs/ui/layout/src/lib/form-field-wrapper/form-field-wrapper.component.ts +16 -0
  356. package/src/libs/ui/layout/src/lib/ui-layout.module.ts +0 -2
  357. package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +1 -1
  358. package/src/libs/util/shared/src/lib/links/link-utils.ts +21 -0
  359. package/src/libs/util/shared/src/lib/utils/bytes-convert.ts +3 -0
  360. package/src/libs/util/shared/src/lib/utils/image-resize.ts +72 -0
  361. package/src/libs/util/shared/src/lib/utils/index.ts +7 -5
  362. package/tailwind.base.css +36 -0
  363. package/translations/de.json +39 -0
  364. package/translations/en.json +39 -0
  365. package/translations/es.json +39 -0
  366. package/translations/fr.json +39 -0
  367. package/translations/it.json +39 -0
  368. package/translations/nl.json +39 -0
  369. package/translations/pt.json +39 -0
  370. package/translations/sk.json +39 -0
  371. package/esm2022/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.mjs +0 -13
  372. package/esm2022/libs/feature/editor/src/lib/record-form/record-form.component.mjs +0 -30
  373. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-array/form-field-array.component.mjs +0 -11
  374. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-file/form-field-file.component.mjs +0 -27
  375. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-object/form-field-object.component.mjs +0 -11
  376. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.mjs +0 -27
  377. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-simple/form-field-simple.component.mjs +0 -49
  378. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +0 -11
  379. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field-temporal-extent/form-field-temporal-extent.component.mjs +0 -11
  380. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field.component.mjs +0 -76
  381. package/esm2022/libs/ui/inputs/src/lib/form-field/form-field.model.mjs +0 -2
  382. package/esm2022/libs/ui/inputs/src/lib/form-field/index.mjs +0 -10
  383. package/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.d.ts +0 -18
  384. package/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.d.ts.map +0 -1
  385. package/libs/feature/editor/src/lib/record-form/record-form.component.d.ts.map +0 -1
  386. package/libs/ui/inputs/src/lib/form-field/form-field-array/form-field-array.component.d.ts.map +0 -1
  387. package/libs/ui/inputs/src/lib/form-field/form-field-file/form-field-file.component.d.ts.map +0 -1
  388. package/libs/ui/inputs/src/lib/form-field/form-field-object/form-field-object.component.d.ts.map +0 -1
  389. package/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.d.ts +0 -11
  390. package/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.d.ts.map +0 -1
  391. package/libs/ui/inputs/src/lib/form-field/form-field-simple/form-field-simple.component.d.ts.map +0 -1
  392. package/libs/ui/inputs/src/lib/form-field/form-field-spatial-extent/form-field-spatial-extent.component.d.ts.map +0 -1
  393. package/libs/ui/inputs/src/lib/form-field/form-field-temporal-extent/form-field-temporal-extent.component.d.ts.map +0 -1
  394. package/libs/ui/inputs/src/lib/form-field/form-field.component.d.ts.map +0 -1
  395. package/libs/ui/inputs/src/lib/form-field/form-field.model.d.ts.map +0 -1
  396. package/libs/ui/inputs/src/lib/form-field/index.d.ts.map +0 -1
  397. package/src/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.ts +0 -18
  398. package/src/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.html +0 -11
  399. package/src/libs/ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.ts +0 -15
  400. package/src/libs/ui/inputs/src/lib/form-field/form-field.component.html +0 -68
  401. package/src/libs/ui/inputs/src/lib/form-field/form-field.component.ts +0 -80
  402. /package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field.model.d.ts +0 -0
  403. /package/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/index.d.ts +0 -0
  404. /package/src/libs/feature/editor/src/lib/{record-form/record-form.component.css → components/overview-upload/overview-upload.component.css} +0 -0
  405. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-array/form-field-array.component.css +0 -0
  406. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-array/form-field-array.component.html +0 -0
  407. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-file/form-field-file.component.css +0 -0
  408. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-file/form-field-file.component.html +0 -0
  409. /package/src/libs/{ui/inputs/src/lib/form-field/form-field-object/form-field-object.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.css} +0 -0
  410. /package/src/libs/{ui/inputs/src/lib/form-field/form-field-rich/form-field-rich.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-object/form-field-object.component.css} +0 -0
  411. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-object/form-field-object.component.html +0 -0
  412. /package/src/libs/{ui/inputs/src/lib/form-field/form-field-simple/form-field-simple.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.css} +0 -0
  413. /package/src/libs/{ui/inputs/src/lib/form-field/form-field-spatial-extent/form-field-spatial-extent.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.css} +0 -0
  414. /package/src/libs/{ui/inputs/src/lib/form-field/form-field-temporal-extent/form-field-temporal-extent.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-simple/form-field-simple.component.css} +0 -0
  415. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-simple/form-field-simple.component.html +0 -0
  416. /package/src/libs/{ui/inputs/src/lib/form-field/form-field.component.css → feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.css} +0 -0
  417. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +0 -0
  418. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field-temporal-extent/form-field-temporal-extent.component.html +0 -0
  419. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/form-field.model.ts +0 -0
  420. /package/src/libs/{ui/inputs/src/lib → feature/editor/src/lib/components/record-form}/form-field/index.ts +0 -0
@@ -13,7 +13,7 @@
13
13
  </p>
14
14
  </button>
15
15
  </div>
16
- <div class="flex flex-row flex-wrap justify-between flex-grow gap-5">
16
+ <div class="flex flex-row flex-wrap justify-between grow gap-5">
17
17
  <div class="flex flex-col gap-3">
18
18
  <p class="text-[14px]" translate>record.metadata.api.form.limit</p>
19
19
  <div class="flex flex-row items-center gap-2">
@@ -37,15 +37,31 @@
37
37
  </div>
38
38
  </div>
39
39
  </div>
40
- <div class="flex flex-col gap-3">
41
- <p class="text-sm" translate>record.metadata.api.form.offset</p>
42
- <gn-ui-text-input
43
- class="w-20"
44
- [value]="offset$ | async"
45
- (valueChange)="setOffset($event)"
46
- hint=""
47
- >
48
- </gn-ui-text-input>
40
+ <div class="flex flex-col gap-3 relative">
41
+ <p class="text-sm" [class.text-gray-600]="!supportOffset" translate>
42
+ record.metadata.api.form.offset
43
+ </p>
44
+ <div class="flex items-center">
45
+ <gn-ui-text-input
46
+ class="w-20"
47
+ [value]="offset$ | async"
48
+ [disabled]="!supportOffset"
49
+ (valueChange)="supportOffset ? setOffset($event) : null"
50
+ hint=""
51
+ >
52
+ </gn-ui-text-input>
53
+ <div
54
+ *ngIf="!supportOffset"
55
+ class="flex items-center gap-2 text-orange-500 z-10 ml-3"
56
+ >
57
+ <span
58
+ class="material-symbols-outlined"
59
+ matTooltip="Not supported on this service"
60
+ >
61
+ warning
62
+ </span>
63
+ </div>
64
+ </div>
49
65
  </div>
50
66
  <div class="flex flex-col gap-3">
51
67
  <p class="text-sm" translate>record.metadata.api.form.type</p>
@@ -55,7 +71,7 @@
55
71
  extraBtnClass="secondary min-w-full !w-40 !text-black"
56
72
  [showTitle]="false"
57
73
  class="text-black"
58
- [choices]="formatsList"
74
+ [choices]="outputFormats"
59
75
  (selectValue)="setFormat($event)"
60
76
  [selected]="format$ | async"
61
77
  ></gn-ui-dropdown-selector>
@@ -1,6 +1,11 @@
1
1
  import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
2
- import { DatasetServiceDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'
3
- import { BehaviorSubject, combineLatest, map } from 'rxjs'
2
+ import { OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client'
3
+ import {
4
+ DatasetServiceDistribution,
5
+ ServiceProtocol,
6
+ } from '../../../../../../libs/common/domain/src/lib/model/record'
7
+ import { mimeTypeToFormat } from '../../../../../../libs/util/shared/src'
8
+ import { BehaviorSubject, combineLatest, map, switchMap } from 'rxjs'
4
9
 
5
10
  const DEFAULT_PARAMS = {
6
11
  OFFSET: '',
@@ -15,19 +20,27 @@ const DEFAULT_PARAMS = {
15
20
  })
16
21
  export class RecordApiFormComponent {
17
22
  @Input() set apiLink(value: DatasetServiceDistribution) {
18
- this.apiBaseUrl = value ? value.url.href : undefined
23
+ this.outputFormats = [{ value: 'json', label: 'JSON' }]
24
+ this.accessServiceProtocol = value ? value.accessServiceProtocol : undefined
25
+ this.apiFeatureType = value ? value.name : undefined
26
+ if (value) {
27
+ this.apiBaseUrl = value.url.href
28
+ this.parseOutputFormats()
29
+ }
19
30
  this.resetUrl()
20
31
  }
32
+
21
33
  offset$ = new BehaviorSubject('')
22
34
  limit$ = new BehaviorSubject('')
23
35
  format$ = new BehaviorSubject('')
24
36
  apiBaseUrl: string
25
- formatsList = [
26
- { label: 'JSON', value: 'json' },
27
- { label: 'CSV', value: 'csv' },
28
- ]
37
+ apiFeatureType: string
38
+ supportOffset = true
39
+ accessServiceProtocol: ServiceProtocol | undefined
40
+ outputFormats = [{ value: 'json', label: 'JSON' }]
41
+
29
42
  apiQueryUrl$ = combineLatest([this.offset$, this.limit$, this.format$]).pipe(
30
- map(([offset, limit, format]) => {
43
+ switchMap(async ([offset, limit, format]) => {
31
44
  let outputUrl
32
45
  if (this.apiBaseUrl) {
33
46
  const url = new URL(this.apiBaseUrl)
@@ -41,6 +54,20 @@ export class RecordApiFormComponent {
41
54
  }
42
55
  outputUrl = url.toString()
43
56
  }
57
+
58
+ if (this.accessServiceProtocol === 'wfs') {
59
+ const wfsEndpoint = new WfsEndpoint(this.apiBaseUrl)
60
+ if (await wfsEndpoint.isReady()) {
61
+ const options = {
62
+ outputFormat: format,
63
+ startIndex: Number(offset),
64
+ }
65
+ if (limit !== '-1') {
66
+ options['maxFeatures'] = Number(limit)
67
+ }
68
+ outputUrl = wfsEndpoint.getFeatureUrl(this.apiFeatureType, options)
69
+ }
70
+ }
44
71
  return outputUrl
45
72
  })
46
73
  )
@@ -70,4 +97,56 @@ export class RecordApiFormComponent {
70
97
  this.limit$.next(DEFAULT_PARAMS.LIMIT)
71
98
  this.format$.next(DEFAULT_PARAMS.FORMAT)
72
99
  }
100
+
101
+ parseOutputFormats() {
102
+ const apiUrl =
103
+ this.apiBaseUrl.slice(-1) === '?'
104
+ ? this.apiBaseUrl.slice(0, -1)
105
+ : this.apiBaseUrl
106
+
107
+ this.getOutputFormats(apiUrl, this.accessServiceProtocol).then(
108
+ (outputFormats) => {
109
+ let formatsList = []
110
+ if ('itemFormats' in outputFormats) {
111
+ formatsList = this.mapFormats(outputFormats.itemFormats)
112
+ } else if ('outputFormats' in outputFormats) {
113
+ formatsList = this.mapFormats(outputFormats.outputFormats)
114
+ }
115
+ this.outputFormats = this.outputFormats.concat(
116
+ formatsList.filter(Boolean)
117
+ )
118
+ this.outputFormats = this.outputFormats
119
+ .filter(
120
+ (format, index, self) =>
121
+ index === self.findIndex((t) => t.value === format.value)
122
+ )
123
+ .sort((a, b) => a.label.localeCompare(b.label))
124
+ }
125
+ )
126
+ }
127
+
128
+ mapFormats(formats: any[]) {
129
+ return formats.map((format) => {
130
+ const normalizedFormat = mimeTypeToFormat(format)
131
+ if (normalizedFormat) {
132
+ return {
133
+ label: normalizedFormat.toUpperCase(),
134
+ value: normalizedFormat,
135
+ }
136
+ }
137
+ return null
138
+ })
139
+ }
140
+
141
+ async getOutputFormats(url: string, accessServiceProtocol: string) {
142
+ if (accessServiceProtocol === 'wfs') {
143
+ const endpoint = await new WfsEndpoint(url).isReady()
144
+ this.supportOffset = endpoint.supportsStartIndex()
145
+ return endpoint.getServiceInfo()
146
+ } else {
147
+ const endpoint = await new OgcApiEndpoint(url)
148
+ const firstCollection = (await endpoint.featureCollections)[0]
149
+ return endpoint.getCollectionInfo(firstCollection)
150
+ }
151
+ }
73
152
  }
@@ -1,3 +1,4 @@
1
+ import { CommonModule } from '@angular/common'
1
2
  import {
2
3
  ChangeDetectionStrategy,
3
4
  Component,
@@ -18,20 +19,21 @@ export const THUMBNAIL_PLACEHOLDER = new InjectionToken<string>(
18
19
  'thumbnail-placeholder'
19
20
  )
20
21
 
22
+ type FitOptions = 'cover' | 'contain' | 'scale-down'
21
23
  type ThumbnailImageObject = {
22
24
  url: string
23
- fit?: 'cover' | 'contain' | 'scale-down'
25
+ fit?: FitOptions
24
26
  }
25
27
 
26
28
  const DEFAULT_PLACEHOLDER =
27
29
  'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGAAAABgCAYAAADimHc4AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA3XAAAN1wFCKJt4AAAAB3RJTUUH5gkNDCUFYjA1nwAAA1pJREFUeNrtnW2TmjAURh8CLlTdrmun///3tZ22+zLuYlehH7jsMGogwRiiec4MM44K6D3x3hAwAIQQQgghhJDYSM5cPwNQAMgBpACUg22GTg2gArAD8A9AKY+9CsgALAF8YRsGALwDeAWw9yGgALCKoKWP+WU8iwxjUsudLBj83sZciIiPSwhoWz7pJ5dUZFQXlEXOZ/DNeTBt3JnhBpc9aacGsOn0BuoIUk3b+5trGnEC4B7Ak4sUlInRU+wB/JbgVxG18KrTBc01EmYmcTFJQUVPy/9zTh/4BthLDOqeenB2DdBtZBN58LsSNpcUoEtTJWM/GIvMhQDde9j6h2OhXAjo6/2Q/lgkLgSQC0IBFEABZEKyiaQv5AAv7fSlS+lPVxRwOXTnEtoTPAs04yfRHGMoz8F/HOiaJfKeggLc78dmOHsVS33y9SUXsDuLlsg6FOAw/fhYhwI0pJ7WoQASpoC9p3UoQEPpaR0K0LCB3fB1e6KfAhxRweAKgQ5PsQxJ+CzCJYC/A7+EWt4TzVCE77GgEsBPHA/G7QBswcE4b+noVRZ2QxkCCqAAQgEUQCiAAggFUAChAAogFEABhAJcfT9FAdOxQuB/ML9lAfdo/qWYy2MK8EiO5mrrliUCvdIudAEzWWzQzWuxwjRnAK9WwAzAWhZTCe3l7cryNQrQBL/txZhKGGrlwc36ogIPfvdzfhuQsDDM80EVZXUFwe+mEJ2EOwBfLfYTTFFWVxL8Qwl3nedSye1jjhEyCjAPflfCWiScU1iDKMrqyoJ/KOFxRDf1sCg/xCxgTPC7EnIHn6GYsiirKw2+ayYryorBn7YoKwb/qCgntywg1OBPdqSsGPyTRXnp07gvPgD8AAl6KIICCAVQAAlLwOg5MSNi9NyqJgKqAHpQoZNZxs5KgG7SDN7AZzgWOxcCtprn5/wVfLb+uWXsrASUPXlvHbmETGKQjBVgMitVJTuaaQS2t/GoEMeE3onEor2jlK4RvwN4G1u9T4n6zp6PMTWAXzCYdCq12OCOhdeYZzT3mIErAW1Fr+HmNOAt82KSesYIAJoRzR2aIVumo+Ms8WwT/HOOZlM0Y+Zzxv2zp/gCTzfzPOyGtdfgp7LEcDvbvSxbWXg/HUIIIYQQQogx/wHLoX7NoCMFPwAAAABJRU5ErkJggg=='
28
30
 
29
- type FitOptions = 'cover' | 'contain' | 'scale-down'
30
-
31
31
  @Component({
32
32
  selector: 'gn-ui-thumbnail',
33
33
  templateUrl: './thumbnail.component.html',
34
34
  changeDetection: ChangeDetectionStrategy.OnPush,
35
+ standalone: true,
36
+ imports: [CommonModule],
35
37
  })
36
38
  export class ThumbnailComponent implements OnInit, OnChanges {
37
39
  @Input() thumbnailUrl: string | string[]
@@ -31,6 +31,8 @@ import { MaxLinesComponent } from './max-lines/max-lines.component'
31
31
  import { RecordApiFormComponent } from './record-api-form/record-api-form.component'
32
32
  import { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'
33
33
  import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'
34
+ import { UserFeedbackItemComponent } from './user-feedback-item/user-feedback-item.component'
35
+ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
34
36
 
35
37
  @NgModule({
36
38
  imports: [
@@ -46,6 +48,8 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
46
48
  FormsModule,
47
49
  NgOptimizedImage,
48
50
  MarkdownParserComponent,
51
+ ThumbnailComponent,
52
+ TimeSincePipe,
49
53
  ],
50
54
  declarations: [
51
55
  MetadataInfoComponent,
@@ -53,7 +57,6 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
53
57
  DownloadItemComponent,
54
58
  DownloadsListComponent,
55
59
  ApiCardComponent,
56
- LinkCardComponent,
57
60
  RelatedRecordCardComponent,
58
61
  MetadataContactComponent,
59
62
  MetadataCatalogComponent,
@@ -61,13 +64,13 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
61
64
  MetadataQualityItemComponent,
62
65
  SearchResultsErrorComponent,
63
66
  PaginationComponent,
64
- ThumbnailComponent,
65
67
  AvatarComponent,
66
68
  UserPreviewComponent,
67
69
  GnUiLinkifyDirective,
68
70
  PaginationButtonsComponent,
69
71
  MaxLinesComponent,
70
72
  RecordApiFormComponent,
73
+ UserFeedbackItemComponent,
71
74
  ImageOverlayPreviewComponent,
72
75
  ],
73
76
  exports: [
@@ -76,7 +79,6 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
76
79
  DownloadItemComponent,
77
80
  DownloadsListComponent,
78
81
  ApiCardComponent,
79
- LinkCardComponent,
80
82
  RelatedRecordCardComponent,
81
83
  MetadataContactComponent,
82
84
  MetadataCatalogComponent,
@@ -91,6 +93,7 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
91
93
  MaxLinesComponent,
92
94
  RecordApiFormComponent,
93
95
  MarkdownParserComponent,
96
+ UserFeedbackItemComponent,
94
97
  ImageOverlayPreviewComponent,
95
98
  ],
96
99
  })
@@ -0,0 +1,54 @@
1
+ import { Pipe, PipeTransform } from '@angular/core'
2
+ import { TranslateService } from '@ngx-translate/core'
3
+ import { formatDistance } from 'date-fns'
4
+ import { de, enUS, es, fr, it, nl, pt, sk } from 'date-fns/locale'
5
+
6
+ @Pipe({
7
+ name: 'timeSince',
8
+ standalone: true,
9
+ })
10
+ export class TimeSincePipe implements PipeTransform {
11
+ constructor(private translate: TranslateService) {}
12
+
13
+ transform(value: Date): string {
14
+ if (isNaN(value.getTime())) {
15
+ throw new Error('Invalid Date')
16
+ }
17
+
18
+ const maintenant = new Date()
19
+ let locale: Locale
20
+
21
+ switch (this.translate.currentLang) {
22
+ case 'fr':
23
+ locale = fr
24
+ break
25
+ case 'de':
26
+ locale = de
27
+ break
28
+ case 'es':
29
+ locale = es
30
+ break
31
+ case 'it':
32
+ locale = it
33
+ break
34
+ case 'nl':
35
+ locale = nl
36
+ break
37
+ case 'pt':
38
+ locale = pt
39
+ break
40
+ case 'sk':
41
+ locale = sk
42
+ break
43
+ case 'en':
44
+ default:
45
+ locale = enUS
46
+ break
47
+ }
48
+
49
+ return formatDistance(value, maintenant, {
50
+ addSuffix: true,
51
+ locale: locale,
52
+ })
53
+ }
54
+ }
@@ -0,0 +1,75 @@
1
+ <div
2
+ *ngIf="userFeedbackParent.published"
3
+ class="flex flex-col bg-white rounded w-full"
4
+ [ngClass]="[isAnAnswer ? 'ps-4 ' : 'p-4']"
5
+ >
6
+ <div class="flex flex-row">
7
+ <div class="avatar">
8
+ <img
9
+ class="rounded-full"
10
+ [src]="userFeedbackParent.avatarUrl"
11
+ alt="avatar"
12
+ />
13
+ </div>
14
+ <div class="p-4 flex flex-col">
15
+ <span>{{ userFeedbackParent.authorName }}</span>
16
+ <span> {{ userFeedbackParent.date | timeSince }}</span>
17
+ </div>
18
+ </div>
19
+ <div data-cy="commentText" class="mt-4 whitespace-pre-line">
20
+ {{ userFeedbackParent.comment }}
21
+ </div>
22
+ <div
23
+ class="w-full"
24
+ *ngFor="let userFeedBacksAnswer of userFeedBacksAnswers; let last = last"
25
+ >
26
+ <hr class="-mx-4 my-6" />
27
+ <gn-ui-user-feedback-item
28
+ [userFeedbackParent]="userFeedBacksAnswer"
29
+ [isLastComment]="last"
30
+ ></gn-ui-user-feedback-item>
31
+ </div>
32
+
33
+ <div *ngIf="isActiveUserEditor" class="mt-2 flex flex-col">
34
+ <hr class="-mx-4 my-4" />
35
+ <div
36
+ id="new-comment-buttons"
37
+ class="flex flex-row gap-2 items-center justify-end"
38
+ >
39
+ <gn-ui-text-area
40
+ [disabled]="isAddUserFeedbackLoading"
41
+ [(value)]="newAnswer"
42
+ (valueChange)="onNewAnswerValueChange()"
43
+ (keyup.control.enter)="publishNewAnswer()"
44
+ [placeholder]="
45
+ 'record.metadata.userFeedbacks.newAnswer.placeholder' | translate
46
+ "
47
+ class="grow"
48
+ extraClass="bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9"
49
+ ></gn-ui-text-area>
50
+ <div *ngIf="!isAnswerEmpty" class="flex flex-row justify-end">
51
+ <gn-ui-button
52
+ [disabled]="isAddUserFeedbackLoading"
53
+ [type]="'outline'"
54
+ (buttonClick)="publishNewAnswer()"
55
+ [title]="
56
+ 'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate
57
+ "
58
+ extraClass="!p-[0.5em] text-primary-darker border-primary-darker h-9"
59
+ >
60
+ <mat-icon
61
+ class="material-symbols-outlined"
62
+ *ngIf="!isAddUserFeedbackLoading"
63
+ >
64
+ send
65
+ </mat-icon>
66
+ <ng-container *ngIf="isAddUserFeedbackLoading">
67
+ <div class="flex justify-center w-full">
68
+ <gn-ui-spinning-loader></gn-ui-spinning-loader>
69
+ </div>
70
+ </ng-container>
71
+ </gn-ui-button>
72
+ </div>
73
+ </div>
74
+ </div>
75
+ </div>
@@ -0,0 +1,63 @@
1
+ import {
2
+ ChangeDetectionStrategy,
3
+ Component,
4
+ EventEmitter,
5
+ Input,
6
+ OnInit,
7
+ Output,
8
+ } from '@angular/core'
9
+ import {
10
+ UserFeedback,
11
+ UserFeedbackViewModel,
12
+ } from '../../../../../../libs/common/domain/src/lib/model/record'
13
+ import { UserModel } from '../../../../../../libs/common/domain/src/lib/model/user'
14
+
15
+ @Component({
16
+ selector: 'gn-ui-user-feedback-item',
17
+ templateUrl: './user-feedback-item.component.html',
18
+ styleUrls: ['./user-feedback-item.component.css'],
19
+ changeDetection: ChangeDetectionStrategy.OnPush,
20
+ })
21
+ export class UserFeedbackItemComponent implements OnInit {
22
+ @Input() userFeedbackParent: UserFeedbackViewModel
23
+ @Input() userFeedBacksAnswers: UserFeedbackViewModel[]
24
+ @Input() isActiveUserEditor: boolean
25
+ @Input() activeUser: UserModel
26
+ @Input() isLastComment: boolean
27
+ @Input() isAddUserFeedbackLoading: boolean
28
+
29
+ @Output() newUserFeedbackAnswer = new EventEmitter<UserFeedback>()
30
+
31
+ isAnAnswer = false
32
+ newAnswer = ''
33
+ isAnswerEmpty = true
34
+
35
+ ngOnInit(): void {
36
+ this.isAnAnswer = !!this.userFeedbackParent.parentUuid
37
+ }
38
+
39
+ onNewAnswerValueChange() {
40
+ this.isAnswerEmpty = this.newAnswer.length === 0
41
+ }
42
+
43
+ publishNewAnswer() {
44
+ if (this.newAnswer.trim() === '') return
45
+
46
+ const newAnswer: UserFeedback = {
47
+ ...this.userFeedbackParent,
48
+ uuid: undefined,
49
+ published: true,
50
+ comment: this.newAnswer,
51
+ parentUuid: this.userFeedbackParent.uuid,
52
+ authorUserId: this.activeUser?.id,
53
+ authorEmail: this.activeUser?.email,
54
+ date: new Date(),
55
+ authorName: `${this.activeUser?.name} ${this.activeUser?.surname}`,
56
+ }
57
+
58
+ this.newUserFeedbackAnswer.emit(newAnswer)
59
+
60
+ this.newAnswer = ''
61
+ this.onNewAnswerValueChange()
62
+ }
63
+ }
@@ -1,22 +1,22 @@
1
- export * from './lib/dropdown-selector/dropdown-selector.component'
2
- export * from './lib/dropdown-selector/dropdown-selector.model'
3
- export * from './lib/dropdown-multiselect/dropdown-multiselect.component'
4
- export * from './lib/dropdown-multiselect/dropdown-multiselect.model'
5
- export * from './lib/text-input/text-input.component'
6
- export * from './lib/chips-input/chips-input.component'
7
- export * from './lib/text-area/text-area.component'
8
1
  export * from './lib/autocomplete/autocomplete.component'
9
- export * from './lib/star-toggle/star-toggle.component'
10
2
  export * from './lib/button/button.component'
11
- export * from './lib/viewport-intersector/viewport-intersector.component'
12
3
  export * from './lib/check-toggle/check-toggle.component'
13
- export * from './lib/ui-inputs.module'
14
- export * from './lib/form-field'
4
+ export * from './lib/checkbox/checkbox.component'
5
+ export * from './lib/chips-input/chips-input.component'
15
6
  export * from './lib/copy-text-button/copy-text-button.component'
7
+ export * from './lib/date-picker/date-picker.component'
8
+ export * from './lib/date-range-picker/date-range-picker.component'
16
9
  export * from './lib/drag-and-drop-file-input/drag-and-drop-file-input.component'
10
+ export * from './lib/dropdown-multiselect/dropdown-multiselect.component'
11
+ export * from './lib/dropdown-multiselect/dropdown-multiselect.model'
12
+ export * from './lib/dropdown-selector/dropdown-selector.component'
13
+ export * from './lib/dropdown-selector/dropdown-selector.model'
14
+ export * from './lib/editable-label/editable-label.directive'
17
15
  export * from './lib/navigation-button/navigation-button.component'
18
- export * from './lib/viewport-intersector/viewport-intersector.component'
19
- export * from './lib/checkbox/checkbox.component'
20
16
  export * from './lib/search-input/search-input.component'
21
- export * from './lib/date-range-picker/date-range-picker.component'
22
- export * from './lib/editable-label/editable-label.directive'
17
+ export * from './lib/star-toggle/star-toggle.component'
18
+ export * from './lib/text-area/text-area.component'
19
+ export * from './lib/text-input/text-input.component'
20
+ export * from './lib/ui-inputs.module'
21
+ export * from './lib/viewport-intersector/viewport-intersector.component'
22
+ export * from './lib/previous-next-buttons/previous-next-buttons.component'
@@ -15,7 +15,7 @@ import { propagateToDocumentOnly } from '../../../../../../libs/util/shared/src'
15
15
  standalone: true,
16
16
  })
17
17
  export class ButtonComponent {
18
- private btnClass: string
18
+ private btnClass = 'gn-ui-btn-default'
19
19
 
20
20
  @Input() set type(
21
21
  value: 'primary' | 'secondary' | 'default' | 'outline' | 'light'
@@ -0,0 +1,3 @@
1
+ mat-datepicker-toggle {
2
+ @apply text-primary;
3
+ }
@@ -0,0 +1,11 @@
1
+ <div
2
+ class="flex items-center justify-between pl-3 rounded-lg border border-gray-300 bg-white"
3
+ >
4
+ <input
5
+ [matDatepicker]="picker"
6
+ [value]="date"
7
+ (dateChange)="dateChange.emit($event.value)"
8
+ />
9
+ <mat-datepicker-toggle matIconSuffix [for]="picker"></mat-datepicker-toggle>
10
+ </div>
11
+ <mat-datepicker #picker></mat-datepicker>
@@ -0,0 +1,16 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core'
2
+ import { MatNativeDateModule } from '@angular/material/core'
3
+ import { MatDatepickerModule } from '@angular/material/datepicker'
4
+ import { MatIconModule } from '@angular/material/icon'
5
+
6
+ @Component({
7
+ selector: 'gn-ui-date-picker',
8
+ templateUrl: './date-picker.component.html',
9
+ styleUrls: ['./date-picker.component.css'],
10
+ standalone: true,
11
+ imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
12
+ })
13
+ export class DatePickerComponent {
14
+ @Input() date: Date
15
+ @Output() dateChange = new EventEmitter<Date>()
16
+ }
@@ -1,10 +1,17 @@
1
1
  import { Component } from '@angular/core'
2
- import { MatDatepickerInputEvent } from '@angular/material/datepicker'
2
+ import { MatNativeDateModule } from '@angular/material/core'
3
+ import {
4
+ MatDatepickerInputEvent,
5
+ MatDatepickerModule,
6
+ } from '@angular/material/datepicker'
7
+ import { MatIconModule } from '@angular/material/icon'
3
8
 
4
9
  @Component({
5
10
  selector: 'gn-ui-date-range-picker',
6
11
  templateUrl: './date-range-picker.component.html',
7
12
  styleUrls: ['./date-range-picker.component.css'],
13
+ standalone: true,
14
+ imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
8
15
  })
9
16
  export class DateRangePickerComponent {
10
17
  startDate: Date
@@ -2,6 +2,7 @@ import {
2
2
  CdkConnectedOverlay,
3
3
  CdkOverlayOrigin,
4
4
  ConnectedPosition,
5
+ OverlayModule,
5
6
  } from '@angular/cdk/overlay'
6
7
  import {
7
8
  ChangeDetectionStrategy,
@@ -17,6 +18,10 @@ import {
17
18
  } from '@angular/core'
18
19
  import { firstValueFrom } from 'rxjs'
19
20
  import { DropdownChoice } from './dropdown-selector.model'
21
+ import { CommonModule } from '@angular/common'
22
+ import { TranslateModule } from '@ngx-translate/core'
23
+ import { MatIconModule } from '@angular/material/icon'
24
+ import { ButtonComponent } from '../button/button.component'
20
25
 
21
26
  const DEFAULT_ROW_NUMBERS = 6
22
27
 
@@ -25,6 +30,14 @@ const DEFAULT_ROW_NUMBERS = 6
25
30
  templateUrl: './dropdown-selector.component.html',
26
31
  styleUrls: ['./dropdown-selector.component.css'],
27
32
  changeDetection: ChangeDetectionStrategy.OnPush,
33
+ standalone: true,
34
+ imports: [
35
+ CommonModule,
36
+ ButtonComponent,
37
+ OverlayModule,
38
+ MatIconModule,
39
+ TranslateModule,
40
+ ],
28
41
  })
29
42
  export class DropdownSelectorComponent implements OnInit {
30
43
  @Input() title: string
@@ -0,0 +1,45 @@
1
+ import { Directive, HostListener, Output, EventEmitter } from '@angular/core'
2
+
3
+ @Directive({
4
+ selector: '[gnUiFilesDrop]',
5
+ standalone: true,
6
+ })
7
+ export class FilesDropDirective {
8
+ @Output() dragFilesOver: EventEmitter<boolean> = new EventEmitter()
9
+ @Output() dropFiles: EventEmitter<File[]> = new EventEmitter()
10
+
11
+ dragEnterCounter = 0
12
+
13
+ @HostListener('dragenter', ['$event'])
14
+ _onDragEnter(event: DragEvent) {
15
+ event.preventDefault()
16
+ this.dragEnterCounter++
17
+ this.dragFilesOver.emit(true)
18
+ }
19
+
20
+ @HostListener('dragover', ['$event'])
21
+ _onDragOver(event: DragEvent) {
22
+ event.preventDefault()
23
+ }
24
+
25
+ @HostListener('dragleave', ['$event'])
26
+ _onDragLeave(event: DragEvent) {
27
+ event.preventDefault()
28
+ this.dragEnterCounter = Math.max(0, this.dragEnterCounter - 1)
29
+ if (this.dragEnterCounter === 0) {
30
+ this.dragFilesOver.emit(false)
31
+ }
32
+ }
33
+
34
+ @HostListener('drop', ['$event'])
35
+ _onDrop(event: DragEvent) {
36
+ event.preventDefault()
37
+ this.dragEnterCounter = 0
38
+ this.dragFilesOver.emit(false)
39
+
40
+ const files = Array.from(event.dataTransfer.files)
41
+ if (files.length > 0) {
42
+ this.dropFiles.emit(files)
43
+ }
44
+ }
45
+ }