@mapsight/ui 7.1.0 → 7.2.1

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 (497) hide show
  1. package/README.md +95 -2
  2. package/dist/components/app.d.ts +1 -1
  3. package/dist/components/app.d.ts.map +1 -1
  4. package/dist/components/feature-details-content/feature-details-content.d.ts +1 -1
  5. package/dist/components/feature-details-content/feature-details-content.d.ts.map +1 -1
  6. package/dist/components/feature-details-content/index.d.ts +1 -1
  7. package/dist/components/feature-details-content/share-feature-link-modal.d.ts +1 -1
  8. package/dist/components/feature-details-content/share-feature-link-modal.d.ts.map +1 -1
  9. package/dist/components/feature-list/context.d.ts +12 -4
  10. package/dist/components/feature-list/context.d.ts.map +1 -1
  11. package/dist/components/feature-list/context.js.map +1 -1
  12. package/dist/components/feature-list/empty-message.d.ts +1 -1
  13. package/dist/components/feature-list/empty-message.d.ts.map +1 -1
  14. package/dist/components/feature-list/filter.d.ts +1 -1
  15. package/dist/components/feature-list/filter.d.ts.map +1 -1
  16. package/dist/components/feature-list/footer.d.ts +1 -1
  17. package/dist/components/feature-list/footer.d.ts.map +1 -1
  18. package/dist/components/feature-list/hooks/useAutoloadFeatureSource.d.ts.map +1 -1
  19. package/dist/components/feature-list/hooks/useAutoloadFeatureSource.js +12 -3
  20. package/dist/components/feature-list/hooks/useAutoloadFeatureSource.js.map +1 -1
  21. package/dist/components/feature-list/hooks/useFeatureListItemGroups.js +1 -1
  22. package/dist/components/feature-list/hooks/useFeatureListItemGroups.js.map +1 -1
  23. package/dist/components/feature-list/index.d.ts +3 -2
  24. package/dist/components/feature-list/index.d.ts.map +1 -1
  25. package/dist/components/feature-list/index.js +33 -42
  26. package/dist/components/feature-list/index.js.map +1 -1
  27. package/dist/components/feature-list/layer-switcher-control.d.ts +4 -0
  28. package/dist/components/feature-list/layer-switcher-control.d.ts.map +1 -0
  29. package/dist/components/feature-list/layer-switcher-control.js +11 -0
  30. package/dist/components/feature-list/layer-switcher-control.js.map +1 -0
  31. package/dist/components/feature-list/pagination.d.ts +1 -1
  32. package/dist/components/feature-list/pagination.d.ts.map +1 -1
  33. package/dist/components/feature-list/query-input.d.ts +1 -1
  34. package/dist/components/feature-list/query-input.d.ts.map +1 -1
  35. package/dist/components/feature-list/tag-switcher-control.d.ts +4 -0
  36. package/dist/components/feature-list/tag-switcher-control.d.ts.map +1 -0
  37. package/dist/components/feature-list/tag-switcher-control.js +10 -0
  38. package/dist/components/feature-list/tag-switcher-control.js.map +1 -0
  39. package/dist/components/feature-list-cycling/button.d.ts +1 -1
  40. package/dist/components/feature-list-cycling/button.d.ts.map +1 -1
  41. package/dist/components/feature-list-cycling/dot.d.ts +1 -1
  42. package/dist/components/feature-list-cycling/dot.d.ts.map +1 -1
  43. package/dist/components/feature-list-cycling/feature-list-cycling.d.ts +1 -1
  44. package/dist/components/feature-list-cycling/feature-list-cycling.d.ts.map +1 -1
  45. package/dist/components/feature-list-cycling/index.d.ts +1 -1
  46. package/dist/components/feature-list-item/icon.d.ts +8 -6
  47. package/dist/components/feature-list-item/icon.d.ts.map +1 -1
  48. package/dist/components/feature-list-item/icon.js +5 -13
  49. package/dist/components/feature-list-item/icon.js.map +1 -1
  50. package/dist/components/feature-list-item/index.d.ts +1 -1
  51. package/dist/components/feature-list-item/index.d.ts.map +1 -1
  52. package/dist/components/feature-list-sorting/feature-list-sorting.d.ts +1 -1
  53. package/dist/components/feature-list-sorting/feature-list-sorting.d.ts.map +1 -1
  54. package/dist/components/feature-list-sorting/feature-list-sorting.js +3 -12
  55. package/dist/components/feature-list-sorting/feature-list-sorting.js.map +1 -1
  56. package/dist/components/feature-list-sorting/index.d.ts +1 -1
  57. package/dist/components/feature-list-sorting/status-indicator.d.ts +1 -1
  58. package/dist/components/feature-list-sorting/status-indicator.d.ts.map +1 -1
  59. package/dist/components/feature-select-button.d.ts +1 -1
  60. package/dist/components/feature-select-button.d.ts.map +1 -1
  61. package/dist/components/feature-selection-info/close-button.d.ts +1 -1
  62. package/dist/components/feature-selection-info/close-button.d.ts.map +1 -1
  63. package/dist/components/feature-selection-info/container.d.ts +1 -1
  64. package/dist/components/feature-selection-info/container.d.ts.map +1 -1
  65. package/dist/components/feature-selection-info/header.d.ts +1 -1
  66. package/dist/components/feature-selection-info/header.d.ts.map +1 -1
  67. package/dist/components/feature-selection-info/index.d.ts +1 -1
  68. package/dist/components/feature-selection-info/index.d.ts.map +1 -1
  69. package/dist/components/feature-selection-info/with-sticky-header.d.ts +1 -1
  70. package/dist/components/feature-selection-info/with-sticky-header.d.ts.map +1 -1
  71. package/dist/components/feature-selection-info/without-sticky-header.d.ts +1 -1
  72. package/dist/components/feature-selection-info/without-sticky-header.d.ts.map +1 -1
  73. package/dist/components/filter-toggle-control/FilterToggleControl.d.ts +12 -0
  74. package/dist/components/filter-toggle-control/FilterToggleControl.d.ts.map +1 -0
  75. package/dist/components/filter-toggle-control/FilterToggleControl.js +20 -0
  76. package/dist/components/filter-toggle-control/FilterToggleControl.js.map +1 -0
  77. package/dist/components/helping/app-channel.d.ts +1 -1
  78. package/dist/components/helping/app-channel.d.ts.map +1 -1
  79. package/dist/components/helping/app-context.d.ts +1 -1
  80. package/dist/components/helping/app-context.d.ts.map +1 -1
  81. package/dist/components/instance.d.ts +1 -1
  82. package/dist/components/instance.d.ts.map +1 -1
  83. package/dist/components/layer-switcher/GroupedLayerSwitcher.d.ts +1 -1
  84. package/dist/components/layer-switcher/LayerSwitcher.d.ts +1 -1
  85. package/dist/components/layer-switcher/LayerSwitcherContainer.d.ts +4 -2
  86. package/dist/components/layer-switcher/LayerSwitcherContainer.d.ts.map +1 -1
  87. package/dist/components/layer-switcher/LayerSwitcherContainer.js +10 -4
  88. package/dist/components/layer-switcher/LayerSwitcherContainer.js.map +1 -1
  89. package/dist/components/layer-switcher/LayerSwitcherEntry.d.ts +1 -1
  90. package/dist/components/layer-switcher/SplitBaseLayerSwitcher.d.ts +26 -0
  91. package/dist/components/layer-switcher/SplitBaseLayerSwitcher.d.ts.map +1 -0
  92. package/dist/components/layer-switcher/SplitBaseLayerSwitcher.js +48 -0
  93. package/dist/components/layer-switcher/SplitBaseLayerSwitcher.js.map +1 -0
  94. package/dist/components/layer-switcher/index.d.ts +1 -1
  95. package/dist/components/layer-switcher/index.d.ts.map +1 -1
  96. package/dist/components/layer-switcher/index.js +1 -0
  97. package/dist/components/layer-switcher/index.js.map +1 -1
  98. package/dist/components/layout/additional-container/content.d.ts +1 -1
  99. package/dist/components/layout/additional-container/content.d.ts.map +1 -1
  100. package/dist/components/layout/additional-container/index.d.ts +1 -1
  101. package/dist/components/layout/additional-container/index.d.ts.map +1 -1
  102. package/dist/components/layout/additional-container/marginal.d.ts +1 -1
  103. package/dist/components/layout/additional-container/marginal.d.ts.map +1 -1
  104. package/dist/components/layout/main-container.d.ts +1 -1
  105. package/dist/components/layout/main-container.d.ts.map +1 -1
  106. package/dist/components/layout/map-row.d.ts +1 -1
  107. package/dist/components/layout/map-row.d.ts.map +1 -1
  108. package/dist/components/layout/title-bar.d.ts +1 -1
  109. package/dist/components/layout/title-bar.d.ts.map +1 -1
  110. package/dist/components/layout/wrapper.d.ts +1 -1
  111. package/dist/components/layout/wrapper.d.ts.map +1 -1
  112. package/dist/components/link-share.d.ts +1 -1
  113. package/dist/components/link-share.d.ts.map +1 -1
  114. package/dist/components/main-panel/container.d.ts +1 -1
  115. package/dist/components/main-panel/container.d.ts.map +1 -1
  116. package/dist/components/main-panel/context.d.ts +1 -1
  117. package/dist/components/main-panel/context.d.ts.map +1 -1
  118. package/dist/components/main-panel/index.d.ts +1 -1
  119. package/dist/components/main-panel/index.d.ts.map +1 -1
  120. package/dist/components/main-panel/list-toggle-button.d.ts +1 -1
  121. package/dist/components/main-panel/list-toggle-button.d.ts.map +1 -1
  122. package/dist/components/map-overlay/attribution-entries.d.ts +1 -1
  123. package/dist/components/map-overlay/attribution-entries.d.ts.map +1 -1
  124. package/dist/components/map-overlay/attribution.d.ts +1 -1
  125. package/dist/components/map-overlay/attribution.d.ts.map +1 -1
  126. package/dist/components/map-overlay/combined-buttons.d.ts +1 -1
  127. package/dist/components/map-overlay/combined-buttons.d.ts.map +1 -1
  128. package/dist/components/map-overlay/index.d.ts +1 -1
  129. package/dist/components/map-overlay/index.d.ts.map +1 -1
  130. package/dist/components/map-overlay/info-overlay-left.d.ts +1 -1
  131. package/dist/components/map-overlay/info-overlay-left.d.ts.map +1 -1
  132. package/dist/components/map-overlay/info-overlay-modal.d.ts +1 -1
  133. package/dist/components/map-overlay/info-overlay-modal.d.ts.map +1 -1
  134. package/dist/components/map-overlay/info-overlay-right.d.ts +1 -1
  135. package/dist/components/map-overlay/info-overlay-right.d.ts.map +1 -1
  136. package/dist/components/map-overlay/layer-switcher-overlay.d.ts +1 -1
  137. package/dist/components/map-overlay/layer-switcher-overlay.d.ts.map +1 -1
  138. package/dist/components/map-overlay/legend.d.ts +1 -1
  139. package/dist/components/map-overlay/legend.d.ts.map +1 -1
  140. package/dist/components/map-overlay/logo.d.ts +1 -1
  141. package/dist/components/map-overlay/logo.d.ts.map +1 -1
  142. package/dist/components/map-overlay/measure-distance-button.d.ts +1 -1
  143. package/dist/components/map-overlay/measure-distance-button.d.ts.map +1 -1
  144. package/dist/components/map-overlay/measure-distance-overlay.d.ts +1 -1
  145. package/dist/components/map-overlay/measure-distance-overlay.d.ts.map +1 -1
  146. package/dist/components/map-overlay/search-overlay.d.ts +1 -1
  147. package/dist/components/map-overlay/search-overlay.d.ts.map +1 -1
  148. package/dist/components/map-overlay/share-position-link-button.d.ts +1 -1
  149. package/dist/components/map-overlay/share-position-link-button.d.ts.map +1 -1
  150. package/dist/components/map-overlay/tool-overlay.d.ts +1 -1
  151. package/dist/components/map-overlay/tool-overlay.d.ts.map +1 -1
  152. package/dist/components/map-overlay/zoom-buttons.d.ts +1 -1
  153. package/dist/components/map-overlay/zoom-buttons.d.ts.map +1 -1
  154. package/dist/components/map-synced-interlay/index.d.ts +1 -1
  155. package/dist/components/map-synced-interlay/map-synced-interlay.d.ts +1 -1
  156. package/dist/components/map-synced-interlay/map-synced-interlay.d.ts.map +1 -1
  157. package/dist/components/map-synced-interlay/tooltip.d.ts +1 -1
  158. package/dist/components/map-synced-interlay/tooltip.d.ts.map +1 -1
  159. package/dist/components/map-wrapper.d.ts +3 -3
  160. package/dist/components/map-wrapper.d.ts.map +1 -1
  161. package/dist/components/map-wrapper.js +4 -7
  162. package/dist/components/map-wrapper.js.map +1 -1
  163. package/dist/components/map.d.ts +1 -1
  164. package/dist/components/map.d.ts.map +1 -1
  165. package/dist/components/mapsight-icon/mapsight-icon.d.ts +10 -0
  166. package/dist/components/mapsight-icon/mapsight-icon.d.ts.map +1 -0
  167. package/dist/components/mapsight-icon/mapsight-icon.js +33 -0
  168. package/dist/components/mapsight-icon/mapsight-icon.js.map +1 -0
  169. package/dist/components/modal.d.ts +1 -1
  170. package/dist/components/modal.d.ts.map +1 -1
  171. package/dist/components/query-input-with-label.d.ts +1 -1
  172. package/dist/components/query-input-with-label.d.ts.map +1 -1
  173. package/dist/components/search/index.d.ts +1 -1
  174. package/dist/components/search/index.d.ts.map +1 -1
  175. package/dist/components/search/result-entry.d.ts +1 -1
  176. package/dist/components/search/result-entry.d.ts.map +1 -1
  177. package/dist/components/search/result.d.ts +1 -1
  178. package/dist/components/search/result.d.ts.map +1 -1
  179. package/dist/components/switcher/GroupedSwitcher.d.ts +1 -1
  180. package/dist/components/switcher/GroupedSwitcher.d.ts.map +1 -1
  181. package/dist/components/switcher/Switcher.d.ts +1 -1
  182. package/dist/components/switcher/Switcher.d.ts.map +1 -1
  183. package/dist/components/switcher/SwitcherButton.d.ts +1 -1
  184. package/dist/components/switcher/SwitcherButton.d.ts.map +1 -1
  185. package/dist/components/switcher/SwitcherEntry.d.ts +1 -1
  186. package/dist/components/switcher/SwitcherEntry.d.ts.map +1 -1
  187. package/dist/components/switcher/SwitcherHeader.d.ts +1 -1
  188. package/dist/components/switcher/SwitcherHeader.d.ts.map +1 -1
  189. package/dist/components/switcher/SwitcherStatusIcon.d.ts +1 -1
  190. package/dist/components/switcher/SwitcherStatusIcon.d.ts.map +1 -1
  191. package/dist/components/tag-switcher/TagSwitcher.d.ts +1 -1
  192. package/dist/components/tag-switcher/TagSwitcher.d.ts.map +1 -1
  193. package/dist/components/tag-switcher/createTagSwitcherEntry.d.ts +1 -1
  194. package/dist/components/tag-switcher/createTagSwitcherHeader.d.ts +1 -1
  195. package/dist/components/tag-switcher/index.d.ts +1 -1
  196. package/dist/components/time-filter.d.ts +1 -1
  197. package/dist/components/time-filter.d.ts.map +1 -1
  198. package/dist/components/view-toggle-button/desktop-button.d.ts +1 -1
  199. package/dist/components/view-toggle-button/desktop-button.d.ts.map +1 -1
  200. package/dist/components/view-toggle-button/index.d.ts +1 -1
  201. package/dist/components/view-toggle-button/mobile-button.d.ts +1 -1
  202. package/dist/components/view-toggle-button/mobile-button.d.ts.map +1 -1
  203. package/dist/components/view-toggle-button/view-toggle-button.d.ts +1 -1
  204. package/dist/components/view-toggle-button/view-toggle-button.d.ts.map +1 -1
  205. package/dist/components/view-toggle-button/viewport-button.d.ts +1 -1
  206. package/dist/components/view-toggle-button/viewport-button.d.ts.map +1 -1
  207. package/dist/config/feature/sources.d.ts +8 -5
  208. package/dist/config/feature/sources.d.ts.map +1 -1
  209. package/dist/config/feature/sources.js +7 -9
  210. package/dist/config/feature/sources.js.map +1 -1
  211. package/dist/config/index.d.ts +1 -1
  212. package/dist/config/map/featureInteractions.js.map +1 -1
  213. package/dist/config/map/layers.d.ts +16 -13
  214. package/dist/config/map/layers.d.ts.map +1 -1
  215. package/dist/config/map/layers.js.map +1 -1
  216. package/dist/config/schema/index.d.ts +197 -0
  217. package/dist/config/schema/index.d.ts.map +1 -0
  218. package/dist/config/schema/index.js +26 -0
  219. package/dist/config/schema/index.js.map +1 -0
  220. package/dist/config/schema/validate.d.ts +8 -0
  221. package/dist/config/schema/validate.d.ts.map +1 -0
  222. package/dist/config/schema/validate.js +7 -0
  223. package/dist/config/schema/validate.js.map +1 -0
  224. package/dist/controllers/defaults.d.ts.map +1 -1
  225. package/dist/controllers/defaults.js +5 -0
  226. package/dist/controllers/defaults.js.map +1 -1
  227. package/dist/filters/tag-filter.d.ts +7 -0
  228. package/dist/filters/tag-filter.d.ts.map +1 -1
  229. package/dist/filters/tag-filter.js +10 -0
  230. package/dist/filters/tag-filter.js.map +1 -1
  231. package/dist/filters/time-filter.d.ts +9 -0
  232. package/dist/filters/time-filter.d.ts.map +1 -1
  233. package/dist/filters/time-filter.js +10 -0
  234. package/dist/filters/time-filter.js.map +1 -1
  235. package/dist/helpers/i18n/de.d.ts.map +1 -1
  236. package/dist/helpers/i18n/de.js +3 -0
  237. package/dist/helpers/i18n/de.js.map +1 -1
  238. package/dist/helpers/i18n/en.d.ts.map +1 -1
  239. package/dist/helpers/i18n/en.js +3 -0
  240. package/dist/helpers/i18n/en.js.map +1 -1
  241. package/dist/helpers/sort-features-by-distance.d.ts +2 -7
  242. package/dist/helpers/sort-features-by-distance.d.ts.map +1 -1
  243. package/dist/helpers/sort-features-by-distance.js +27 -39
  244. package/dist/helpers/sort-features-by-distance.js.map +1 -1
  245. package/dist/hooks/useMapsightIcon.d.ts +8 -0
  246. package/dist/hooks/useMapsightIcon.d.ts.map +1 -0
  247. package/dist/hooks/useMapsightIcon.js +50 -0
  248. package/dist/hooks/useMapsightIcon.js.map +1 -0
  249. package/dist/index.d.ts +2 -2
  250. package/dist/index.d.ts.map +1 -1
  251. package/dist/index.js +15 -2
  252. package/dist/index.js.map +1 -1
  253. package/dist/plugins/browser-defaults.d.ts +2 -0
  254. package/dist/plugins/browser-defaults.d.ts.map +1 -1
  255. package/dist/plugins/browser-defaults.js +5 -0
  256. package/dist/plugins/browser-defaults.js.map +1 -1
  257. package/dist/plugins/common/combined-visible-layers.d.ts +15 -0
  258. package/dist/plugins/common/combined-visible-layers.d.ts.map +1 -0
  259. package/dist/plugins/common/combined-visible-layers.js +63 -0
  260. package/dist/plugins/common/combined-visible-layers.js.map +1 -0
  261. package/dist/plugins/common/runtime-icon-style.d.ts +12 -0
  262. package/dist/plugins/common/runtime-icon-style.d.ts.map +1 -0
  263. package/dist/plugins/common/runtime-icon-style.js +58 -0
  264. package/dist/plugins/common/runtime-icon-style.js.map +1 -0
  265. package/dist/react-modal-app-element.d.ts +6 -0
  266. package/dist/react-modal-app-element.d.ts.map +1 -0
  267. package/dist/react-modal-app-element.js +9 -0
  268. package/dist/react-modal-app-element.js.map +1 -0
  269. package/dist/store/actions.d.ts.map +1 -1
  270. package/dist/store/actions.js +6 -1
  271. package/dist/store/actions.js.map +1 -1
  272. package/dist/store/reducers.d.ts +75 -6
  273. package/dist/store/reducers.d.ts.map +1 -1
  274. package/dist/store/selectors.d.ts +75 -17
  275. package/dist/store/selectors.d.ts.map +1 -1
  276. package/dist/store/selectors.js +9 -1
  277. package/dist/store/selectors.js.map +1 -1
  278. package/dist/types.d.ts +21 -5
  279. package/dist/types.d.ts.map +1 -1
  280. package/package.json +24 -8
  281. package/src/scss/blocks/_features-sorting.scss +0 -13
  282. package/src/scss/blocks/_filter-button.scss +39 -8
  283. package/src/scss/blocks/_filter-toggle-control.scss +15 -0
  284. package/src/scss/default.scss +1 -0
  285. package/src/scss/themes/2022-03.scss +66 -0
  286. package/src/img/mapsight-ui/check-empty.svg +0 -1
  287. package/src/img/mapsight-ui/check.svg +0 -2
  288. package/src/img/mapsight-ui/close-list.svg +0 -1
  289. package/src/img/mapsight-ui/close.svg +0 -1
  290. package/src/img/mapsight-ui/error.svg +0 -1
  291. package/src/img/mapsight-ui/fullscreen-close.svg +0 -1
  292. package/src/img/mapsight-ui/fullscreen.svg +0 -1
  293. package/src/img/mapsight-ui/geo-active.svg +0 -1
  294. package/src/img/mapsight-ui/geo-error.svg +0 -1
  295. package/src/img/mapsight-ui/geo-inactive.svg +0 -1
  296. package/src/img/mapsight-ui/info.svg +0 -1
  297. package/src/img/mapsight-ui/layers.svg +0 -1
  298. package/src/img/mapsight-ui/loading.svg +0 -1
  299. package/src/img/mapsight-ui/map.svg +0 -1
  300. package/src/img/mapsight-ui/measure-distance.svg +0 -7
  301. package/src/img/mapsight-ui/open-list.svg +0 -1
  302. package/src/img/mapsight-ui/place-marker.svg +0 -4
  303. package/src/img/mapsight-ui/print.svg +0 -4
  304. package/src/img/mapsight-ui/reset-active.svg +0 -1
  305. package/src/img/mapsight-ui/reset.svg +0 -1
  306. package/src/img/mapsight-ui/search.svg +0 -1
  307. package/src/img/mapsight-ui/sharing.svg +0 -7
  308. package/src/img/mapsight-ui/sort-active.svg +0 -1
  309. package/src/img/mapsight-ui/sort.svg +0 -1
  310. package/src/img/mapsight-ui/watermark.svg +0 -1
  311. package/src/img/mapsight-ui/zoom-in.svg +0 -3
  312. package/src/img/mapsight-ui/zoom-out.svg +0 -3
  313. package/src/js/components/app.tsx +0 -232
  314. package/src/js/components/close-overlay-button.tsx +0 -27
  315. package/src/js/components/feature-details-content/feature-details-content-inner.tsx +0 -116
  316. package/src/js/components/feature-details-content/feature-details-content.jsx +0 -185
  317. package/src/js/components/feature-details-content/index.js +0 -16
  318. package/src/js/components/feature-details-content/share-feature-link-modal.jsx +0 -56
  319. package/src/js/components/feature-list/content.jsx +0 -42
  320. package/src/js/components/feature-list/context.tsx +0 -47
  321. package/src/js/components/feature-list/empty-message.jsx +0 -15
  322. package/src/js/components/feature-list/filter.jsx +0 -35
  323. package/src/js/components/feature-list/footer.jsx +0 -5
  324. package/src/js/components/feature-list/grouped-content.jsx +0 -74
  325. package/src/js/components/feature-list/header.jsx +0 -7
  326. package/src/js/components/feature-list/hooks/useAutoloadFeatureSource.ts +0 -25
  327. package/src/js/components/feature-list/hooks/useFeatureListFeatureSource.ts +0 -22
  328. package/src/js/components/feature-list/hooks/useFeatureListItemGroups.ts +0 -127
  329. package/src/js/components/feature-list/hooks/useFeatureListState.ts +0 -98
  330. package/src/js/components/feature-list/hooks/useKeyboardNavigation.js +0 -112
  331. package/src/js/components/feature-list/hooks/useMakeHeaderSticky.js +0 -40
  332. package/src/js/components/feature-list/hooks/usePaginatedFilteredFeatures.ts +0 -129
  333. package/src/js/components/feature-list/hooks/useRestoreDocumentScroll.js +0 -12
  334. package/src/js/components/feature-list/hooks/useSelectFeature.js +0 -88
  335. package/src/js/components/feature-list/index.jsx +0 -278
  336. package/src/js/components/feature-list/pagination.tsx +0 -57
  337. package/src/js/components/feature-list/query-input.jsx +0 -14
  338. package/src/js/components/feature-list-cycling/button.jsx +0 -13
  339. package/src/js/components/feature-list-cycling/dot.jsx +0 -43
  340. package/src/js/components/feature-list-cycling/feature-list-cycling.jsx +0 -153
  341. package/src/js/components/feature-list-cycling/index.js +0 -82
  342. package/src/js/components/feature-list-item/head.jsx +0 -131
  343. package/src/js/components/feature-list-item/hooks/useFeatureListItemScrollAndFocus.js +0 -51
  344. package/src/js/components/feature-list-item/hooks/useFeatureListItemState.ts +0 -75
  345. package/src/js/components/feature-list-item/icon.jsx +0 -35
  346. package/src/js/components/feature-list-item/index.jsx +0 -168
  347. package/src/js/components/feature-list-sorting/feature-list-sorting.tsx +0 -144
  348. package/src/js/components/feature-list-sorting/index.js +0 -22
  349. package/src/js/components/feature-list-sorting/status-indicator.jsx +0 -10
  350. package/src/js/components/feature-select-button.jsx +0 -70
  351. package/src/js/components/feature-selection-info/close-button.jsx +0 -64
  352. package/src/js/components/feature-selection-info/container.jsx +0 -9
  353. package/src/js/components/feature-selection-info/header.tsx +0 -27
  354. package/src/js/components/feature-selection-info/index.tsx +0 -81
  355. package/src/js/components/feature-selection-info/with-sticky-header.tsx +0 -76
  356. package/src/js/components/feature-selection-info/without-sticky-header.jsx +0 -19
  357. package/src/js/components/feature-selection-info/wrapper.jsx +0 -43
  358. package/src/js/components/helping/app-channel.tsx +0 -99
  359. package/src/js/components/helping/app-context.tsx +0 -32
  360. package/src/js/components/helping/visibility-wrapper.jsx +0 -23
  361. package/src/js/components/instance.tsx +0 -48
  362. package/src/js/components/layer-switcher/GroupedLayerSwitcher.js +0 -47
  363. package/src/js/components/layer-switcher/LayerSwitcher.ts +0 -34
  364. package/src/js/components/layer-switcher/LayerSwitcherContainer.tsx +0 -88
  365. package/src/js/components/layer-switcher/LayerSwitcherEntry.ts +0 -152
  366. package/src/js/components/layer-switcher/index.ts +0 -42
  367. package/src/js/components/layout/additional-container/content.jsx +0 -10
  368. package/src/js/components/layout/additional-container/index.jsx +0 -5
  369. package/src/js/components/layout/additional-container/marginal.jsx +0 -10
  370. package/src/js/components/layout/main-container.jsx +0 -5
  371. package/src/js/components/layout/map-row.jsx +0 -5
  372. package/src/js/components/layout/title-bar.tsx +0 -25
  373. package/src/js/components/layout/wrapper.jsx +0 -28
  374. package/src/js/components/link-share.jsx +0 -78
  375. package/src/js/components/main-panel/container.tsx +0 -23
  376. package/src/js/components/main-panel/context.tsx +0 -71
  377. package/src/js/components/main-panel/index.tsx +0 -46
  378. package/src/js/components/main-panel/list-toggle-button.jsx +0 -43
  379. package/src/js/components/map-overlay/area.jsx +0 -17
  380. package/src/js/components/map-overlay/attribution-entries.tsx +0 -33
  381. package/src/js/components/map-overlay/attribution.tsx +0 -25
  382. package/src/js/components/map-overlay/combined-buttons.jsx +0 -5
  383. package/src/js/components/map-overlay/index.jsx +0 -5
  384. package/src/js/components/map-overlay/info-overlay-left.jsx +0 -51
  385. package/src/js/components/map-overlay/info-overlay-modal.tsx +0 -49
  386. package/src/js/components/map-overlay/info-overlay-right.jsx +0 -46
  387. package/src/js/components/map-overlay/layer-switcher-overlay.tsx +0 -100
  388. package/src/js/components/map-overlay/legend.tsx +0 -22
  389. package/src/js/components/map-overlay/logo.jsx +0 -11
  390. package/src/js/components/map-overlay/measure-distance-button.tsx +0 -116
  391. package/src/js/components/map-overlay/measure-distance-overlay.jsx +0 -56
  392. package/src/js/components/map-overlay/mini-legend.jsx +0 -103
  393. package/src/js/components/map-overlay/region-selector.jsx +0 -63
  394. package/src/js/components/map-overlay/search-overlay.jsx +0 -79
  395. package/src/js/components/map-overlay/share-position-link-button.tsx +0 -144
  396. package/src/js/components/map-overlay/tool-overlay.tsx +0 -28
  397. package/src/js/components/map-overlay/user-geo-location-button.jsx +0 -89
  398. package/src/js/components/map-overlay/zoom-button.jsx +0 -98
  399. package/src/js/components/map-overlay/zoom-buttons.jsx +0 -26
  400. package/src/js/components/map-synced-interlay/index.ts +0 -15
  401. package/src/js/components/map-synced-interlay/map-synced-interlay.jsx +0 -22
  402. package/src/js/components/map-synced-interlay/tooltip-content.tsx +0 -22
  403. package/src/js/components/map-synced-interlay/tooltip.tsx +0 -199
  404. package/src/js/components/map-wrapper.tsx +0 -65
  405. package/src/js/components/map.tsx +0 -55
  406. package/src/js/components/modal.tsx +0 -40
  407. package/src/js/components/query-input-with-label.tsx +0 -71
  408. package/src/js/components/query-input.tsx +0 -81
  409. package/src/js/components/search/index.jsx +0 -83
  410. package/src/js/components/search/query-input.jsx +0 -20
  411. package/src/js/components/search/result-entry.jsx +0 -63
  412. package/src/js/components/search/result.jsx +0 -71
  413. package/src/js/components/switcher/GroupedSwitcher.jsx +0 -42
  414. package/src/js/components/switcher/Switcher.jsx +0 -54
  415. package/src/js/components/switcher/SwitcherButton.jsx +0 -23
  416. package/src/js/components/switcher/SwitcherEntry.tsx +0 -164
  417. package/src/js/components/switcher/SwitcherHeader.jsx +0 -58
  418. package/src/js/components/switcher/SwitcherStatusIcon.jsx +0 -36
  419. package/src/js/components/tag-switcher/TagSwitcher.tsx +0 -56
  420. package/src/js/components/tag-switcher/createTagSwitcherEntry.ts +0 -39
  421. package/src/js/components/tag-switcher/createTagSwitcherHeader.ts +0 -47
  422. package/src/js/components/tag-switcher/index.ts +0 -17
  423. package/src/js/components/time-filter.jsx +0 -187
  424. package/src/js/components/view-toggle-button/desktop-button.jsx +0 -13
  425. package/src/js/components/view-toggle-button/index.ts +0 -42
  426. package/src/js/components/view-toggle-button/mobile-button.tsx +0 -13
  427. package/src/js/components/view-toggle-button/view-toggle-button.jsx +0 -74
  428. package/src/js/components/view-toggle-button/viewport-button.tsx +0 -13
  429. package/src/js/config/constants/app.ts +0 -16
  430. package/src/js/config/constants/controllers.ts +0 -11
  431. package/src/js/config/feature/selections.ts +0 -13
  432. package/src/js/config/feature/sources.ts +0 -77
  433. package/src/js/config/index.ts +0 -133
  434. package/src/js/config/map/featureInteractions.ts +0 -53
  435. package/src/js/config/map/interactions.ts +0 -15
  436. package/src/js/config/map/layers.ts +0 -190
  437. package/src/js/controllers/defaults.ts +0 -36
  438. package/src/js/embed/browser.ts +0 -89
  439. package/src/js/embed/node.ts +0 -57
  440. package/src/js/filters/tag-filter.ts +0 -135
  441. package/src/js/filters/time-filter.ts +0 -53
  442. package/src/js/helpers/components.ts +0 -66
  443. package/src/js/helpers/create-action-watcher.ts +0 -35
  444. package/src/js/helpers/events.ts +0 -11
  445. package/src/js/helpers/get-feature-property.ts +0 -14
  446. package/src/js/helpers/i18n/de.ts +0 -145
  447. package/src/js/helpers/i18n/en.ts +0 -140
  448. package/src/js/helpers/i18n/index.ts +0 -41
  449. package/src/js/helpers/makeReplaceableComponent.ts +0 -0
  450. package/src/js/helpers/mod-classes.ts +0 -47
  451. package/src/js/helpers/react.ts +0 -14
  452. package/src/js/helpers/scroll-to-element-top.ts +0 -16
  453. package/src/js/helpers/sort-features-by-distance.ts +0 -102
  454. package/src/js/helpers/sticky.js +0 -143
  455. package/src/js/hooks/useCallbackRef.ts +0 -14
  456. package/src/js/hooks/useControllableState.ts +0 -50
  457. package/src/js/hooks/useDebounce.ts +0 -32
  458. package/src/js/hooks/useHandleEscapeKeyDown.ts +0 -27
  459. package/src/js/hooks/useMapsightPanel.ts +0 -40
  460. package/src/js/hooks/useMountable.ts +0 -47
  461. package/src/js/hooks/usePrevious.ts +0 -15
  462. package/src/js/hooks/useStickyHeader.ts +0 -50
  463. package/src/js/hooks/useUpdateMapSizeCallback.ts +0 -32
  464. package/src/js/hooks/useUpdateMapSizeOnRender.ts +0 -16
  465. package/src/js/hooks/useUpdateMapSizeOnTransitionEnd.ts +0 -40
  466. package/src/js/hooks/useUpdateMapSizeOnViewChange.ts +0 -36
  467. package/src/js/index.ts +0 -320
  468. package/src/js/plugins/browser/app-title.ts +0 -36
  469. package/src/js/plugins/browser/debug.ts +0 -37
  470. package/src/js/plugins/browser/feature-deep-link.ts +0 -223
  471. package/src/js/plugins/browser/local-storage.ts +0 -79
  472. package/src/js/plugins/browser/native-fullscreen.ts +0 -81
  473. package/src/js/plugins/browser/no-scroll.ts +0 -91
  474. package/src/js/plugins/browser/partial-content-changed-event.ts +0 -23
  475. package/src/js/plugins/browser/piwik-track-feature-selection-event.ts +0 -75
  476. package/src/js/plugins/browser/piwik-track-fullscreen-toggle-event.ts +0 -46
  477. package/src/js/plugins/browser/search.ts +0 -42
  478. package/src/js/plugins/browser/share-position-link.ts +0 -463
  479. package/src/js/plugins/browser/toggle-mobile-views.ts +0 -60
  480. package/src/js/plugins/browser/user-geolocation.ts +0 -142
  481. package/src/js/plugins/browser/views.ts +0 -141
  482. package/src/js/plugins/browser-defaults.ts +0 -101
  483. package/src/js/plugins/common/feature-selection-details-url.ts +0 -135
  484. package/src/js/plugins/common/lang.ts +0 -17
  485. package/src/js/plugins/common/measure-distance.ts +0 -223
  486. package/src/js/plugins/common/ol-proxy.ts +0 -68
  487. package/src/js/plugins/common/render-await-feature-details-loaded.ts +0 -154
  488. package/src/js/plugins/common/render-await-list-feature-sources-loaded.ts +0 -109
  489. package/src/js/plugins/server/feature-deep-link.ts +0 -67
  490. package/src/js/plugins/server-defaults.ts +0 -36
  491. package/src/js/renderer/browser-dom.tsx +0 -27
  492. package/src/js/renderer/server-string.tsx +0 -17
  493. package/src/js/server-handler.js +0 -39
  494. package/src/js/store/actions.ts +0 -662
  495. package/src/js/store/reducers.ts +0 -491
  496. package/src/js/store/selectors.ts +0 -483
  497. package/src/js/types.ts +0 -405
@@ -1,278 +0,0 @@
1
- import {deselectAll} from "@mapsight/core/lib/feature-selections/actions";
2
- import {forwardRef, useCallback, useMemo, useRef} from "react";
3
- import {useDispatch, useSelector} from "react-redux";
4
-
5
- import {FEATURE_SELECTIONS} from "../../config/constants/controllers";
6
- import getFeatureProperty from "../../helpers/get-feature-property";
7
- import {
8
- layerSwitcherConfigExternalSelector,
9
- listUiOptionsSelector,
10
- viewSelector,
11
- } from "../../store/selectors";
12
- import FeatureCycling from "../feature-list-cycling";
13
-
14
- import FeatureSorter from "../feature-list-sorting";
15
-
16
- import {
17
- APP_EVENT_SCROLL_TO_FEATURE_LIST,
18
- useAppChannelEventListener,
19
- } from "../helping/app-channel";
20
- import LayerSwitcher from "../layer-switcher/index";
21
- import TagSwitcher from "../tag-switcher/index";
22
-
23
- import {FeatureListContextProvider} from "./context";
24
-
25
- import FeatureFilter from "./filter";
26
- import FeatureListFooter from "./footer";
27
- import FeatureListGroupedContent from "./grouped-content";
28
- import FeatureListHeader from "./header";
29
- import useAutoloadFeatureSource from "./hooks/useAutoloadFeatureSource";
30
- import useFeatureListState from "./hooks/useFeatureListState";
31
- import {useMakeHeaderSticky} from "./hooks/useMakeHeaderSticky";
32
- import useRestoreDocumentScroll from "./hooks/useRestoreDocumentScroll";
33
- import useSelectFeature from "./hooks/useSelectFeature";
34
- import Pagination from "./pagination";
35
-
36
- export const DEFAULT_LIST_RENDER_AS = "ul";
37
-
38
- function stopEventPropagation(e) {
39
- e.stopPropagation();
40
- }
41
-
42
- function determineShowListInfo(features) {
43
- if (features.length) {
44
- const firstInfo = getFeatureProperty(features[0], "listInformation");
45
- for (let i = 0; i < features.length; i++) {
46
- const info = getFeatureProperty(features[i], "listInformation");
47
-
48
- if (firstInfo !== info) {
49
- return true;
50
- }
51
- }
52
- }
53
-
54
- return false;
55
- }
56
-
57
- function determineItemType(containerType = DEFAULT_LIST_RENDER_AS) {
58
- if (containerType === "ul" || containerType === "ol") {
59
- return "li";
60
- }
61
-
62
- return "p";
63
- }
64
-
65
- /**
66
- * @template T
67
- * @param {import("../../types").FeatureListProps<T>} props props
68
- * @param {React.RefObject<React.ElementRef<T>>} forwardedRef ref
69
- * @returns {React.ReactElement} element
70
- */
71
- function FeatureList(props, forwardedRef) {
72
- const {
73
- additionalClasses,
74
- as: T = "div",
75
- attributes = {},
76
- headerAs: HeaderT = FeatureListHeader,
77
- contentAs: ContentT = FeatureListGroupedContent,
78
- footerAs: FooterT = FeatureListFooter,
79
- itemAs,
80
- enableKeyboardControl = false,
81
- autoloadFeatureSource = true,
82
- sort = true,
83
- filter = true,
84
- enableScrollPosition = true,
85
- overrideListUiOptions,
86
- listControllerName,
87
- } = props;
88
-
89
- const listUiOptionsState = useSelector(listUiOptionsSelector);
90
- const listUiOptions = overrideListUiOptions || listUiOptionsState;
91
- const {
92
- stickyHeader,
93
- detailsInList,
94
- showVaryingListInfoOnly,
95
- renderGroupAs,
96
- renderAs = DEFAULT_LIST_RENDER_AS,
97
- selectionBehaviorSelection,
98
- } = listUiOptions;
99
- const state = useFeatureListState(
100
- listUiOptions,
101
- sort,
102
- filter,
103
- enableScrollPosition,
104
- listControllerName,
105
- );
106
- const view = useSelector(viewSelector);
107
-
108
- if (renderAs === "table") {
109
- throw new Error(
110
- "@mapsight/ui does not support rendering the feature list as <table> anymore!",
111
- );
112
- }
113
-
114
- /** @type {React.RefObject<HTMLElement>} */
115
- const headerRef = useRef();
116
-
117
- /** @type {React.RefObject<HTMLElement>} */
118
- const ownRef = useRef();
119
-
120
- /** @type {React.RefObject<HTMLElement>} */
121
- const ref = forwardedRef || ownRef;
122
-
123
- useMakeHeaderSticky(stickyHeader, ref, headerRef, view);
124
- useAutoloadFeatureSource(autoloadFeatureSource, state.featureSourceId);
125
- useRestoreDocumentScroll(view, state.scrollPosition);
126
-
127
- useAppChannelEventListener(
128
- APP_EVENT_SCROLL_TO_FEATURE_LIST,
129
- useCallback(() => {
130
- ref.current.scrollIntoView({block: "start", behavior: "smooth"});
131
- }, [ref]),
132
- );
133
-
134
- const dispatch = useDispatch();
135
- const selectFeatureAction = useSelectFeature();
136
- const selectFeature = useCallback(
137
- (featureId, options) =>
138
- dispatch(selectFeatureAction(featureId, options)),
139
- [dispatch, selectFeatureAction],
140
- );
141
- const deselectFeature = useCallback(
142
- () =>
143
- dispatch(
144
- deselectAll(FEATURE_SELECTIONS, selectionBehaviorSelection),
145
- ),
146
- [dispatch, selectionBehaviorSelection],
147
- );
148
-
149
- // Decide whether to show the info column
150
- // based on if there is any "interesting" aka distinct data available in the features
151
- // We do this before filtering so it does not change while changing the filter
152
- const showFeatureListInfo =
153
- state.filteredFeatures.length !== 0 &&
154
- (showVaryingListInfoOnly === false ||
155
- determineShowListInfo(state.features));
156
-
157
- // TODO:
158
- //<StatusIndicator {...{
159
- // lastUpdate: this.props.lastUpdate,
160
- // status: this.props.status,
161
- // key: 'si'
162
- //}} />
163
-
164
- let className = "ms3-list-wrapper";
165
- if (detailsInList) {
166
- className += " ms3-list-wrapper--with-details";
167
- }
168
- if (additionalClasses) {
169
- className += ` ${additionalClasses}`;
170
- }
171
-
172
- const itemProps = useMemo(
173
- () => ({
174
- showFeatureListInfo: showFeatureListInfo,
175
- enableKeyboardControl: enableKeyboardControl,
176
- selectFeature: selectFeature,
177
- deselectFeature: deselectFeature,
178
- }),
179
- [
180
- deselectFeature,
181
- enableKeyboardControl,
182
- selectFeature,
183
- showFeatureListInfo,
184
- ],
185
- );
186
-
187
- const renderItemAs = itemAs || determineItemType(renderAs);
188
- const contextValue = useMemo(
189
- () =>
190
- /** @type {import("./context").FeatureListContextValue} */ ({
191
- state: state,
192
- listUiOptions: listUiOptions,
193
- enableKeyboardControl: enableKeyboardControl,
194
- showFeatureListInfo: showFeatureListInfo,
195
- selectFeature: selectFeature,
196
- deselectFeature: deselectFeature,
197
- itemProps: itemProps,
198
- }),
199
- [
200
- deselectFeature,
201
- enableKeyboardControl,
202
- listUiOptions,
203
- selectFeature,
204
- showFeatureListInfo,
205
- state,
206
- itemProps,
207
- ],
208
- );
209
-
210
- const {
211
- filterControl,
212
- sortControl,
213
- cyclingControl,
214
- integratedList,
215
- paginationControl,
216
- itemsPerPage,
217
- } = listUiOptions;
218
- const {
219
- page,
220
- featureCount,
221
- features,
222
- featureSourceId,
223
- filteredFeatures,
224
- layerSwitcherShowExternal,
225
- tagSwitcherShow,
226
- } = state;
227
-
228
- let filterBox = null;
229
- if (filterControl !== false) {
230
- filterBox = <FeatureFilter allFeatures={features} />;
231
- } else if (sortControl !== false || !cyclingControl) {
232
- filterBox = <div className="ms3-list__filter-box">&nbsp;</div>;
233
- }
234
-
235
- return (
236
- <FeatureListContextProvider value={contextValue}>
237
- <T
238
- className={className}
239
- onTouchMove={stopEventPropagation}
240
- ref={ref}
241
- {...attributes}
242
- >
243
- <HeaderT ref={headerRef}>
244
- {filterBox}
245
-
246
- {sortControl !== false && <FeatureSorter />}
247
-
248
- {cyclingControl && (
249
- <FeatureCycling filteredFeatures={filteredFeatures} />
250
- )}
251
-
252
- {integratedList && layerSwitcherShowExternal && (
253
- <LayerSwitcher
254
- configSelector={layerSwitcherConfigExternalSelector}
255
- />
256
- )}
257
-
258
- {integratedList && tagSwitcherShow && <TagSwitcher />}
259
- </HeaderT>
260
- <ContentT
261
- groupAs={renderGroupAs}
262
- itemAs={renderItemAs}
263
- featureSourceId={featureSourceId}
264
- />
265
- <FooterT>
266
- {paginationControl ? (
267
- <Pagination
268
- page={page}
269
- count={Math.ceil(featureCount / itemsPerPage)}
270
- />
271
- ) : null}
272
- </FooterT>
273
- </T>
274
- </FeatureListContextProvider>
275
- );
276
- }
277
-
278
- export default forwardRef(FeatureList);
@@ -1,57 +0,0 @@
1
- import ReactPaginate from "react-paginate";
2
- import {useDispatch} from "react-redux";
3
-
4
- import {translate} from "../../helpers/i18n";
5
- import {setListPage} from "../../store/actions";
6
-
7
- function ariaLabelBuilder(page: number, selected: number) {
8
- const label =
9
- page === selected
10
- ? translate("ui.pagination.goToSelectedPageLabel")
11
- : translate("ui.pagination.goToPageLabel");
12
-
13
- return label.replace("{page}", String(page));
14
- }
15
-
16
- function Pagination({page, count}: {page: number; count: number}) {
17
- const dispatch = useDispatch();
18
-
19
- return null;
20
-
21
- return (
22
- <ReactPaginate
23
- disableInitialCallback={true}
24
- forcePage={Math.min(page, count)}
25
- pageCount={count}
26
- onPageChange={(e) => {
27
- dispatch(setListPage(e.selected));
28
- }}
29
- pageRangeDisplayed={3}
30
- marginPagesDisplayed={2}
31
- previousLabel={translate("ui.pagination.prevPage")}
32
- nextLabel={translate("ui.pagination.nextPage")}
33
- previousAriaLabel={translate("ui.pagination.prevPageLabel")}
34
- nextAriaLabel={translate("ui.pagination.nextPageLabel")}
35
- ariaLabelBuilder={ariaLabelBuilder}
36
- // TODO:
37
- // Handle deep urls (maybe also SSR)
38
- //hrefBuilder={hrefBuilder}
39
-
40
- eventListener="onClick"
41
- containerClassName="ms3-list-pagination"
42
- pageClassName="ms3-list-pagination__page"
43
- pageLinkClassName="ms3-list-pagination__page-link"
44
- previousClassName="ms3-list-pagination__page ms3-list-pagination__page--previous"
45
- previousLinkClassName="ms3-list-pagination__page-link ms3-list-pagination__page-link--previous"
46
- nextClassName="ms3-list-pagination__page ms3-list-pagination__page--next"
47
- nextLinkClassName="ms3-list-pagination__page-link ms3-list-pagination__page-link--next"
48
- activeClassName="ms3-list-pagination__page--active"
49
- activeLinkClassName="ms3-list-pagination__page-link--active"
50
- disabledClassName="ms3-list-pagination__page--disabled"
51
- breakClassName="ms3-list-pagination__break"
52
- breakLinkClassName="ms3-list-pagination__break-link"
53
- />
54
- );
55
- }
56
-
57
- export default Pagination;
@@ -1,14 +0,0 @@
1
- import {translate} from "../../helpers/i18n";
2
- import QueryInputWithLabel from "../query-input-with-label";
3
-
4
- function FeatureQueryInput(props) {
5
- return (
6
- <QueryInputWithLabel
7
- label={translate("ui.feature-list.query-input.placeholder")}
8
- // placeholder={translate("ui.feature-list.query-input.placeholder")}
9
- {...props}
10
- />
11
- );
12
- }
13
-
14
- export default FeatureQueryInput;
@@ -1,13 +0,0 @@
1
- function FeatureListCyclingButton({direction, label, ...rest}) {
2
- return (
3
- <button
4
- type="button"
5
- className={`ms3-list-cycling-box__button ms3-list-cycling-box__button--${direction}`}
6
- {...rest}
7
- >
8
- <span className="ms3-visuallyhidden">{label}</span>
9
- </button>
10
- );
11
- }
12
-
13
- export default FeatureListCyclingButton;
@@ -1,43 +0,0 @@
1
- import {useCallback, useEffect} from "react";
2
-
3
- function FeatureListCyclingDot({
4
- featureId,
5
- onFeatureSelection,
6
- onFeatureHighlight,
7
- onFeatureUnHighlight,
8
- isSelected,
9
- isHighlighted,
10
- updateScroll,
11
- }) {
12
- const onClick = useCallback(
13
- () => onFeatureSelection(featureId),
14
- [featureId, onFeatureSelection],
15
- );
16
- const onMouseEnter = useCallback(
17
- () => (isSelected ? undefined : onFeatureHighlight(featureId)),
18
- [isSelected, onFeatureHighlight, featureId],
19
- );
20
-
21
- useEffect(() => {
22
- if (isSelected) {
23
- updateScroll();
24
- }
25
- }, [isSelected, updateScroll]);
26
-
27
- return (
28
- <button
29
- tabIndex={-1}
30
- type="button"
31
- className={
32
- "ms3-list-cycling-box__dot " +
33
- (isSelected ? " ms3-list-cycling-box__dot--selected" : "") +
34
- (isHighlighted ? " ms3-list-cycling-box__dot--highlight" : "")
35
- }
36
- onClick={onClick}
37
- onMouseEnter={onMouseEnter}
38
- onMouseLeave={onFeatureUnHighlight}
39
- />
40
- );
41
- }
42
-
43
- export default FeatureListCyclingDot;
@@ -1,153 +0,0 @@
1
- import debounce from "lodash/debounce";
2
- import {
3
- memo,
4
- useCallback,
5
- useEffect,
6
- useLayoutEffect,
7
- useRef,
8
- } from "react";
9
-
10
- import {translate} from "../../helpers/i18n";
11
- import FeatureListCyclingButton from "./button";
12
-
13
- import FeatureListCyclingDot from "./dot";
14
-
15
- function FeatureListCycling({
16
- filteredFeatures,
17
- selectedFeatureId,
18
- highlightedFeatureId,
19
- onFeatureSelection,
20
- onFeatureHighlight,
21
- onFeatureUnHighlight,
22
- }) {
23
- let selectedIdx;
24
- if (filteredFeatures?.length) {
25
- selectedIdx = filteredFeatures.findIndex(
26
- (feature) => feature.id === selectedFeatureId,
27
- );
28
- }
29
-
30
- if (selectedIdx === undefined) {
31
- selectedIdx = -2;
32
- }
33
-
34
- const handlePrev = useCallback(() => {
35
- if (filteredFeatures?.length) {
36
- if (!selectedFeatureId) {
37
- onFeatureSelection(filteredFeatures[0].id);
38
- } else if (selectedIdx > 0) {
39
- onFeatureSelection(filteredFeatures[selectedIdx - 1].id);
40
- } else {
41
- onFeatureSelection(
42
- filteredFeatures[filteredFeatures.length - 1].id,
43
- );
44
- }
45
- }
46
- }, [filteredFeatures, selectedFeatureId, onFeatureSelection, selectedIdx]);
47
-
48
- const handleNext = useCallback(() => {
49
- if (filteredFeatures?.length) {
50
- if (
51
- selectedFeatureId &&
52
- selectedIdx < filteredFeatures.length - 1
53
- ) {
54
- onFeatureSelection(filteredFeatures[selectedIdx + 1].id);
55
- } else {
56
- onFeatureSelection(filteredFeatures[0].id);
57
- }
58
- }
59
- }, [filteredFeatures, selectedFeatureId, onFeatureSelection, selectedIdx]);
60
-
61
- const containerRef = useRef();
62
- const container = containerRef.current;
63
- const scroller = container?.querySelector(
64
- ".ms3-list-cycling-box__dots-scroller",
65
- );
66
-
67
- const updateScroll = useCallback(() => {
68
- if (container && scroller) {
69
- const scrollerWidth = scroller.offsetWidth;
70
-
71
- let scrollLeft;
72
- const activeDotElement = scroller.querySelector(
73
- ".ms3-list-cycling-box__dot--selected",
74
- );
75
- if (activeDotElement) {
76
- scrollLeft = Math.max(
77
- 0,
78
- activeDotElement.offsetLeft - scrollerWidth / 2,
79
- );
80
- scroller.scrollTo({
81
- top: 0,
82
- left: scrollLeft,
83
- behavior: "smooth",
84
- });
85
- } else {
86
- scrollLeft = scroller.scrollLeft;
87
- }
88
-
89
- const shadows = container.querySelector(
90
- ".ms3-list-cycling-box__dots-shadows",
91
- );
92
- const dots = container.querySelector(".ms3-list-cycling-box__dots");
93
- if (shadows && dots) {
94
- const dotsWidth = dots.offsetWidth;
95
- const hasOverflowLeft =
96
- dotsWidth > scrollerWidth && scrollLeft > 0;
97
- const hasOverflowRight = dotsWidth - scrollLeft > scrollerWidth;
98
- shadows.classList[hasOverflowLeft ? "add" : "remove"](
99
- "ms3-list-cycling-box__dots-shadows--overflow-left",
100
- );
101
- shadows.classList[hasOverflowRight ? "add" : "remove"](
102
- "ms3-list-cycling-box__dots-shadows--overflow-right",
103
- );
104
- }
105
- }
106
- }, [container, scroller]);
107
-
108
- useEffect(() => {
109
- const debouncedUpdateScroll = debounce(updateScroll, 500);
110
- window.addEventListener("resize", debouncedUpdateScroll);
111
- return () =>
112
- window.removeEventListener("resize", debouncedUpdateScroll);
113
- }, [updateScroll]);
114
-
115
- useLayoutEffect(updateScroll);
116
-
117
- return (
118
- <div className="ms3-list-cycling-box" ref={containerRef}>
119
- <FeatureListCyclingButton
120
- direction="prev"
121
- label={translate("prevEntry")}
122
- onClick={handlePrev}
123
- />
124
- <div className="ms3-list-cycling-box__dots-shadows">
125
- <div className="ms3-list-cycling-box__dots-scroller">
126
- <div className="ms3-list-cycling-box__dots">
127
- {filteredFeatures?.map((feature, index) => (
128
- <FeatureListCyclingDot
129
- key={index}
130
- featureId={feature.id}
131
- isSelected={feature.id === selectedFeatureId}
132
- isHighlighted={
133
- feature.id === highlightedFeatureId
134
- }
135
- onFeatureUnHighlight={onFeatureUnHighlight}
136
- onFeatureHighlight={onFeatureHighlight}
137
- onFeatureSelection={onFeatureSelection}
138
- updateScroll={updateScroll}
139
- />
140
- ))}
141
- </div>
142
- </div>
143
- </div>
144
- <FeatureListCyclingButton
145
- direction="next"
146
- label={translate("nextEntry")}
147
- onClick={handleNext}
148
- />
149
- </div>
150
- );
151
- }
152
-
153
- export default memo(FeatureListCycling);
@@ -1,82 +0,0 @@
1
- import {connect} from "react-redux";
2
-
3
- import {createSelector} from "@reduxjs/toolkit";
4
- import {batchActions} from "redux-batched-actions";
5
-
6
- import {
7
- deselectAll,
8
- selectExclusively,
9
- } from "@mapsight/core/lib/feature-selections/actions";
10
- import {
11
- createFeatureSelectionSelector,
12
- getFilteredFeatures,
13
- } from "@mapsight/core/lib/feature-selections/selectors";
14
-
15
- import {FEATURE_SELECTIONS} from "../../config/constants/controllers";
16
- import {
17
- FEATURE_SELECTION_HIGHLIGHT,
18
- FEATURE_SELECTION_SELECT,
19
- } from "../../config/feature/selections";
20
- import FeatureListCycling from "./feature-list-cycling";
21
-
22
- export default connect(
23
- // stateProps selector
24
- createSelector(
25
- [
26
- createFeatureSelectionSelector(
27
- FEATURE_SELECTIONS,
28
- FEATURE_SELECTION_SELECT,
29
- ),
30
- createFeatureSelectionSelector(
31
- FEATURE_SELECTIONS,
32
- FEATURE_SELECTION_HIGHLIGHT,
33
- ),
34
- ],
35
-
36
- (selectSelection, highlightSelection) => {
37
- const selectSelectionFeatures =
38
- getFilteredFeatures(selectSelection);
39
- const highlightSelectionFeatures =
40
- getFilteredFeatures(highlightSelection);
41
-
42
- return {
43
- selectedFeatureId:
44
- selectSelectionFeatures && selectSelectionFeatures[0],
45
- highlightedFeatureId:
46
- highlightSelectionFeatures && highlightSelectionFeatures[0],
47
- };
48
- },
49
- ),
50
-
51
- // dispatchProps
52
- (dispatch) => ({
53
- onFeatureSelection: (id, b, c) => {
54
- const actions = [
55
- deselectAll(FEATURE_SELECTIONS, FEATURE_SELECTION_HIGHLIGHT),
56
- selectExclusively(
57
- FEATURE_SELECTIONS,
58
- FEATURE_SELECTION_SELECT,
59
- id,
60
- b,
61
- c,
62
- ),
63
- ];
64
-
65
- dispatch(batchActions(actions));
66
- },
67
- onFeatureUnSelection: () =>
68
- dispatch(deselectAll(FEATURE_SELECTIONS, FEATURE_SELECTION_SELECT)),
69
- onFeatureHighlight: (id) =>
70
- dispatch(
71
- selectExclusively(
72
- FEATURE_SELECTIONS,
73
- FEATURE_SELECTION_HIGHLIGHT,
74
- id,
75
- ),
76
- ),
77
- onFeatureUnHighlight: () =>
78
- dispatch(
79
- deselectAll(FEATURE_SELECTIONS, FEATURE_SELECTION_HIGHLIGHT),
80
- ),
81
- }),
82
- )(FeatureListCycling);