@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,65 +0,0 @@
1
- import type {PropsWithChildren, RefCallback} from "react";
2
- import {memo, useCallback, useRef} from "react";
3
- import {useInView} from "react-intersection-observer";
4
- import {useDispatch, useSelector, useStore} from "react-redux";
5
-
6
- import useUpdateMapSizeOnRender from "../hooks/useUpdateMapSizeOnRender";
7
- import useUpdateMapSizeOnTransitionEnd from "../hooks/useUpdateMapSizeOnTransitionEnd";
8
- import useUpdateMapSizeOnViewChange from "../hooks/useUpdateMapSizeOnViewChange";
9
- import {setMapIsOutOfViewport} from "../store/actions";
10
- import {viewSelector} from "../store/selectors";
11
- import {
12
- APP_EVENT_SCROLL_TO_MAP,
13
- useAppChannelEventListener,
14
- } from "./helping/app-channel";
15
-
16
- function MapWrapper(props: PropsWithChildren) {
17
- const {children} = props;
18
-
19
- const dispatch = useDispatch();
20
- const mapWrapperRef = useRef<HTMLDivElement | undefined>(undefined);
21
-
22
- useUpdateMapSizeOnViewChange(
23
- useSelector(viewSelector) ?? "desktop",
24
- useStore(),
25
- );
26
- useUpdateMapSizeOnTransitionEnd(mapWrapperRef.current, dispatch);
27
- useUpdateMapSizeOnRender(dispatch);
28
-
29
- useAppChannelEventListener(
30
- APP_EVENT_SCROLL_TO_MAP,
31
- useCallback(() => {
32
- mapWrapperRef.current?.scrollIntoView({
33
- block: "start",
34
- behavior: "smooth",
35
- });
36
- }, [mapWrapperRef]),
37
- );
38
-
39
- const {ref: inViewRef} = useInView({
40
- threshold: 0,
41
- initialInView: true,
42
- fallbackInView: true,
43
- onChange: (inView) => dispatch(setMapIsOutOfViewport(!inView)),
44
- });
45
-
46
- const setRef: RefCallback<HTMLDivElement> = useCallback(
47
- (node) => {
48
- mapWrapperRef.current = node ?? undefined;
49
- inViewRef(node);
50
- },
51
- [inViewRef],
52
- );
53
-
54
- return (
55
- <div
56
- ref={setRef}
57
- // ms3-map-wrapper--anchored-${anchor}
58
- className={`ms3-map-wrapper [ ms3-flex ms3-flex--column ] [ ms3-scroll-target ]`}
59
- >
60
- {children}
61
- </div>
62
- );
63
- }
64
-
65
- export default memo(MapWrapper);
@@ -1,55 +0,0 @@
1
- import type {HTMLAttributes} from "react";
2
- import {memo, useEffect, useMemo, useRef} from "react";
3
- import {useStore} from "react-redux";
4
-
5
- import type {EnhancedStore} from "@mapsight/core/types";
6
-
7
- import {MAP} from "../config/constants/controllers";
8
- import {translate} from "../helpers/i18n";
9
- import useMountable, {isMountable} from "../hooks/useMountable";
10
-
11
- type MapsightMapProps = HTMLAttributes<HTMLDivElement> & {
12
- controllerName?: string;
13
- enableKeyboardControl?: boolean;
14
- };
15
-
16
- function MapsightMap({
17
- controllerName = MAP,
18
- enableKeyboardControl = true,
19
- ...attributes
20
- }: MapsightMapProps) {
21
- const store = useStore() as EnhancedStore;
22
- const ref = useRef<HTMLDivElement>(null);
23
-
24
- const mountable = useMemo(() => {
25
- const controller = store.getController(controllerName);
26
- if (!isMountable(controller)) {
27
- console.error(`Controller '${controllerName}' is not mountable`);
28
- return undefined;
29
- }
30
- return controller;
31
- }, [store, controllerName]);
32
- const handleMount = useMountable(mountable);
33
- useEffect(() => {
34
- if (ref.current) {
35
- handleMount(ref.current);
36
- }
37
- }, [ref, handleMount]);
38
-
39
- if (enableKeyboardControl) {
40
- attributes.tabIndex = 0;
41
- }
42
-
43
- return (
44
- <div className="ms3-map-target" ref={ref} {...attributes}>
45
- <span className="ms3-visuallyhidden">
46
- {translate("ui.map.visuallyhidden")}
47
- </span>
48
- <div className="ol-viewport">
49
- <canvas className="ol-unselectable" />
50
- </div>
51
- </div>
52
- );
53
- }
54
-
55
- export default memo(MapsightMap);
@@ -1,40 +0,0 @@
1
- import type {KeyboardEvent, MouseEvent, ReactNode} from "react";
2
- import type {Props as ReactModalProps} from "react-modal";
3
- import ReactModal from "react-modal";
4
-
5
- import CloseOverlayButton from "./close-overlay-button";
6
-
7
- export type Props = ReactModalProps & {
8
- closeLabel?: string;
9
- headline: ReactNode;
10
- };
11
-
12
- const Modal = ({children, closeLabel, headline, ...props}: Props) => {
13
- const handleClose = (event: MouseEvent | KeyboardEvent) =>
14
- props.onRequestClose?.(event);
15
-
16
- return (
17
- <ReactModal
18
- onRequestClose={handleClose}
19
- className="ms3-modal"
20
- overlayClassName="ms3-app-overlay"
21
- shouldCloseOnOverlayClick={true}
22
- {...props}
23
- >
24
- <div className="ms3-modal__inner ms3-modal__inner--search">
25
- <div className="ms3-modal__header">
26
- <h3 className="ms3-modal__headline">{headline}</h3>
27
- <div className="ms3-modal__close">
28
- <CloseOverlayButton
29
- label={closeLabel}
30
- onClose={(event) => handleClose(event)}
31
- />
32
- </div>
33
- </div>
34
- {children}
35
- </div>
36
- </ReactModal>
37
- );
38
- };
39
-
40
- export default Modal;
@@ -1,71 +0,0 @@
1
- import type {ChangeEvent, ReactNode} from "react";
2
- import {useCallback, useRef} from "react";
3
- import {useId} from "react-aria";
4
-
5
- import {translate} from "../helpers/i18n";
6
-
7
- export type Props = {
8
- label: ReactNode;
9
- placeholder?: string;
10
- query: string;
11
- onChange: (query: string) => void;
12
- };
13
-
14
- /**
15
- * Same as `QueryInput` but with the label prepended and visible. Not possible to change
16
- * `QueryInput` into something like this due to leaky abstractions
17
- * (leaking internas like classnames)
18
- **/
19
- function QueryInputWithLabel({label, placeholder, query, onChange}: Props) {
20
- const inputRef = useRef<HTMLInputElement>(null);
21
-
22
- const handleInput = useCallback(
23
- (e: ChangeEvent<HTMLInputElement>) => onChange(e.target.value),
24
- [onChange],
25
- );
26
-
27
- const handleReset = useCallback(() => {
28
- onChange("");
29
- inputRef.current?.focus();
30
- }, [onChange, inputRef]);
31
-
32
- const inputId = useId();
33
-
34
- return (
35
- <fieldset className="ms3-query-input-with-label">
36
- <label
37
- className="ms3-query-input-with-label__label"
38
- htmlFor={inputId}
39
- >
40
- {label}
41
- </label>
42
-
43
- <div className="ms3-query-input-with-label__input-container">
44
- <input
45
- id={inputId}
46
- ref={inputRef}
47
- className="ms3-query-input-with-label__input"
48
- placeholder={placeholder}
49
- type="search"
50
- value={query}
51
- onChange={handleInput}
52
- autoComplete="off"
53
- />
54
-
55
- {query !== "" && (
56
- <button
57
- className="ms3-query-input-with-label__reset-button"
58
- type="button"
59
- onClick={handleReset}
60
- >
61
- <span className="ms3-visuallyhidden">
62
- {translate("ui.query-input.reset")}
63
- </span>
64
- </button>
65
- )}
66
- </div>
67
- </fieldset>
68
- );
69
- }
70
-
71
- export default QueryInputWithLabel;
@@ -1,81 +0,0 @@
1
- import type {ChangeEvent, ReactNode} from "react";
2
- import {forwardRef, useCallback, useRef} from "react";
3
-
4
- import {translate} from "../helpers/i18n";
5
- import {forwardRefValue} from "../helpers/react";
6
-
7
- /* NOTE: for attribute not required because of nesting */
8
-
9
- export type Props = {
10
- label: ReactNode;
11
- placeholder?: string;
12
- className?: string;
13
- groupClassName?: string;
14
- resetButtonClassName?: string;
15
- name?: string;
16
- query: string;
17
- onChange: (query: string) => void;
18
- autoFocus?: boolean;
19
- };
20
-
21
- const QueryInput = forwardRef<HTMLInputElement, Props>(function QueryInput(
22
- {
23
- label,
24
- placeholder,
25
- className,
26
- groupClassName,
27
- resetButtonClassName,
28
- name,
29
- query,
30
- onChange,
31
- autoFocus,
32
- },
33
- forwardedRef,
34
- ) {
35
- const inputRef = useRef<HTMLInputElement>(null);
36
- forwardRefValue(inputRef, forwardedRef);
37
-
38
- const handleInput = useCallback(
39
- (e: ChangeEvent<HTMLInputElement>) => onChange(e.target.value),
40
- [onChange],
41
- );
42
-
43
- const handleReset = useCallback(() => {
44
- onChange("");
45
- inputRef.current?.focus();
46
- }, [onChange, inputRef]);
47
-
48
- return (
49
- <fieldset className={groupClassName}>
50
- <label>
51
- <span className="ms3-visuallyhidden">{label}</span>
52
-
53
- <input
54
- ref={inputRef}
55
- className={className}
56
- placeholder={placeholder}
57
- type="search"
58
- name={name}
59
- value={query}
60
- onChange={handleInput}
61
- autoComplete="off"
62
- autoFocus={autoFocus}
63
- />
64
- </label>
65
-
66
- {query !== "" && (
67
- <button
68
- className={resetButtonClassName}
69
- type="button"
70
- onClick={handleReset}
71
- >
72
- <span className="ms3-visuallyhidden">
73
- {translate("ui.query-input.reset")}
74
- </span>
75
- </button>
76
- )}
77
- </fieldset>
78
- );
79
- });
80
-
81
- export default QueryInput;
@@ -1,83 +0,0 @@
1
- import {memo, useCallback, useEffect, useRef} from "react";
2
- import {useDispatch, useSelector} from "react-redux";
3
-
4
- import {translate} from "../../helpers/i18n";
5
- import useDebounce from "../../hooks/useDebounce";
6
- import {search} from "../../store/actions";
7
- import {searchQuerySelector} from "../../store/selectors";
8
-
9
- import SearchQueryInput from "./query-input";
10
- import SearchResult from "./result";
11
- import useHandleEscapeKeyDown from "../../hooks/useHandleEscapeKeyDown";
12
-
13
- const preventDefault = (e) => e.preventDefault();
14
-
15
- function Search({closeSearch, autoFocus}) {
16
- const dispatch = useDispatch();
17
- const query = useSelector(searchQuerySelector);
18
-
19
- const debouncedQuery = useDebounce(query, 200);
20
- useEffect(() => {
21
- if (debouncedQuery !== "") {
22
- dispatch(search(debouncedQuery));
23
- }
24
- }, [dispatch, debouncedQuery]);
25
-
26
- // needed to "override" debounce if the value is ""
27
- useEffect(() => {
28
- if (query === "") {
29
- dispatch(search(query));
30
- }
31
- }, [dispatch, query]);
32
-
33
- const handleInput = useCallback(
34
- (searchQuery) => {
35
- dispatch({type: "SEARCH", query: searchQuery}); // action without ajax side effect
36
- },
37
- [dispatch],
38
- );
39
-
40
- const inputRef = useRef();
41
-
42
- useHandleEscapeKeyDown(
43
- inputRef,
44
- useCallback(() => dispatch(search(""), [dispatch])),
45
- );
46
-
47
- const handleReturnFocus = useCallback(() => inputRef.current?.focus(), []);
48
-
49
- return (
50
- <form className="ms3-search" onSubmit={preventDefault}>
51
- <div className="ms3-search__query-input">
52
- <SearchQueryInput
53
- ref={inputRef}
54
- query={query}
55
- onChange={handleInput}
56
- name="search"
57
- autoFocus={autoFocus}
58
- />
59
-
60
- <button className="ms3-search__send-button" type="submit">
61
- <span className="ms3-visuallyhidden">
62
- {translate("ui.search.send")}
63
- </span>
64
- </button>
65
- </div>
66
-
67
- {query && (
68
- <output
69
- className="ms3-search__output"
70
- name="search-output"
71
- htmlFor="search"
72
- >
73
- <SearchResult
74
- onReturnFocus={handleReturnFocus}
75
- closeSearch={closeSearch}
76
- />
77
- </output>
78
- )}
79
- </form>
80
- );
81
- }
82
-
83
- export default memo(Search);
@@ -1,20 +0,0 @@
1
- import {forwardRef} from "react";
2
-
3
- import {translate} from "../../helpers/i18n";
4
- import QueryInput from "../query-input";
5
-
6
- function SearchQueryInput(props, ref) {
7
- return (
8
- <QueryInput
9
- ref={ref}
10
- className="ms3-search__input"
11
- groupClassName="ms3-search__input-group"
12
- resetButtonClassName="ms3-search__reset-button"
13
- label={translate("ui.search.query-input.label")}
14
- placeholder={translate("ui.search.query-input.placeholder")}
15
- {...props}
16
- />
17
- );
18
- }
19
-
20
- export default forwardRef(SearchQueryInput);
@@ -1,63 +0,0 @@
1
- import {selectExclusively} from "@mapsight/core/lib/feature-selections/actions";
2
- import {memo, useCallback} from "react";
3
- import {useDispatch} from "react-redux";
4
- import {FEATURE_SELECTIONS} from "../../config/constants/controllers";
5
- import {FEATURE_SELECTION_SELECT} from "../../config/feature/selections";
6
-
7
- import getFeatureProperty from "../../helpers/get-feature-property";
8
- import {search, selectSearchResult} from "../../store/actions";
9
-
10
- function SearchResultEntry({closeSearch, onReturnFocus, feature}) {
11
- const dispatch = useDispatch();
12
-
13
- const name = getFeatureProperty(feature, "name");
14
- const listInformation = getFeatureProperty(feature, "listInformation");
15
- const isIncompleteSuggest =
16
- getFeatureProperty(feature, "isIncompleteSuggest") === true;
17
-
18
- const handleClick = useCallback(() => {
19
- if (isIncompleteSuggest) {
20
- dispatch(search(name.trim() + " "));
21
- onReturnFocus();
22
- } else {
23
- dispatch(selectSearchResult(feature));
24
- dispatch(
25
- selectExclusively(
26
- FEATURE_SELECTIONS,
27
- FEATURE_SELECTION_SELECT,
28
- feature.id,
29
- ),
30
- );
31
-
32
- if (closeSearch) {
33
- closeSearch();
34
- }
35
- }
36
- }, [
37
- dispatch,
38
- feature,
39
- isIncompleteSuggest,
40
- name,
41
- onReturnFocus,
42
- closeSearch,
43
- ]);
44
-
45
- return (
46
- <li className="ms3-search-result__list-item">
47
- <button
48
- className="ms3-search-result__entry"
49
- type="button"
50
- onClick={handleClick}
51
- >
52
- <div className="ms3-search-result__entry__title">{name}</div>
53
- {listInformation && (
54
- <div className="ms3-search-result__entry__subline">
55
- {listInformation}
56
- </div>
57
- )}
58
- </button>
59
- </li>
60
- );
61
- }
62
-
63
- export default memo(SearchResultEntry);
@@ -1,71 +0,0 @@
1
- import {memo} from "react";
2
- import {useSelector} from "react-redux";
3
- import getFeatureProperty from "../../helpers/get-feature-property";
4
- import {translate} from "../../helpers/i18n";
5
-
6
- import {
7
- SEARCH_STATUS_EMPTY,
8
- SEARCH_STATUS_ERROR,
9
- SEARCH_STATUS_FOUND,
10
- SEARCH_STATUS_LOADING,
11
- searchResultFeaturesSelector,
12
- searchStatusSelector,
13
- } from "../../store/selectors";
14
-
15
- import SearchResultEntry from "./result-entry";
16
-
17
- const defaultGroup = "__default__";
18
-
19
- function SearchResult({closeSearch, onReturnFocus}) {
20
- const status = useSelector(searchStatusSelector);
21
- const features = useSelector(searchResultFeaturesSelector);
22
-
23
- const groupedEntries = {};
24
- features.forEach((feature, i) => {
25
- const group = getFeatureProperty(feature, "group") || defaultGroup;
26
- groupedEntries[group] = groupedEntries[group] || [];
27
- groupedEntries[group].push(
28
- <SearchResultEntry
29
- key={feature.id || i}
30
- feature={feature}
31
- closeSearch={closeSearch}
32
- onReturnFocus={onReturnFocus}
33
- />,
34
- );
35
- });
36
-
37
- return (
38
- <div className={`ms3-search-result ms3-search-result--${status}`}>
39
- {status === SEARCH_STATUS_ERROR && (
40
- <p className="ms3-search-result__error">
41
- {translate("ui.search.result.error")}
42
- </p>
43
- )}
44
-
45
- {status === SEARCH_STATUS_EMPTY && (
46
- <p className="ms3-search-result__empty-message">
47
- {translate("ui.search.result.empty")}
48
- </p>
49
- )}
50
-
51
- {(status === SEARCH_STATUS_FOUND ||
52
- status === SEARCH_STATUS_LOADING) &&
53
- features &&
54
- Object.keys(groupedEntries).map((group) => (
55
- <div className="ms3-search-result__group" key={group}>
56
- {group && group !== defaultGroup ? (
57
- <h4 className="ms3-search-result__group-head">
58
- {group}
59
- </h4>
60
- ) : null}
61
-
62
- <ul className="ms3-search-result__list">
63
- {groupedEntries[group]}
64
- </ul>
65
- </div>
66
- ))}
67
- </div>
68
- );
69
- }
70
-
71
- export default memo(SearchResult);
@@ -1,42 +0,0 @@
1
- import {Fragment, memo} from "react";
2
-
3
- import Switcher from "./Switcher";
4
-
5
- function GroupedSwitcher(props) {
6
- const {
7
- as: T = "div",
8
- className = "ms3-grouped-switcher",
9
- renderEntry,
10
- renderHeader = undefined,
11
- ungroupedIds = [],
12
- groupedIds = {},
13
- ...attributes
14
- } = props;
15
-
16
- const children = Object.entries(groupedIds).map(([key, group]) => (
17
- <Switcher
18
- key={key}
19
- ids={group}
20
- group={key}
21
- as={Fragment}
22
- renderEntry={renderEntry}
23
- renderHeader={renderHeader}
24
- />
25
- ));
26
-
27
- return (
28
- <T className={className} {...attributes}>
29
- {ungroupedIds.length !== 0 && (
30
- <Switcher
31
- ids={ungroupedIds}
32
- as={Fragment}
33
- renderEntry={renderEntry}
34
- renderHeader={renderHeader}
35
- />
36
- )}
37
- {children}
38
- </T>
39
- );
40
- }
41
-
42
- export default memo(GroupedSwitcher);
@@ -1,54 +0,0 @@
1
- import {Fragment, memo} from "react";
2
-
3
- import SwitcherHeader from "./SwitcherHeader";
4
-
5
- const defaultRenderHeader = (label, props) => (
6
- <SwitcherHeader label={label} {...props} />
7
- );
8
-
9
- function Switcher(props) {
10
- const {
11
- as: T = "div",
12
- headlineAs = "h3",
13
- entriesAs: V = "ul",
14
- baseClass = "ms3-layer-switcher", // TODO: Move to generic class name
15
- renderEntry,
16
- renderHeader = defaultRenderHeader,
17
- ids = [],
18
- group = null,
19
- headerAttributes: headerAttributes_ = {},
20
- entriesAttributes: entriesAttributes_ = {},
21
- ...attributes
22
- } = props;
23
-
24
- const headerAttributes = {...headerAttributes_};
25
- const entriesAttributes = {...entriesAttributes_};
26
-
27
- attributes.className = `${baseClass} ${attributes.className || ""}`;
28
- headerAttributes.className = `${baseClass}__header ${
29
- headerAttributes.className || ""
30
- }`;
31
- entriesAttributes.className = `${baseClass}__entries ${
32
- entriesAttributes.className || ""
33
- }`;
34
-
35
- if (group) {
36
- attributes["data-ms3-switcher-group"] = group;
37
- headerAttributes["data-ms3-switcher-header-group"] = group;
38
- entriesAttributes["data-ms3-switcher-entries-group"] = group;
39
- }
40
-
41
- return (
42
- <T {...(T === Fragment ? {} : attributes)}>
43
- {group
44
- ? renderHeader(group, {as: headlineAs, ...headerAttributes})
45
- : null}
46
-
47
- <V {...entriesAttributes}>
48
- {ids.map((id) => renderEntry(id, group))}
49
- </V>
50
- </T>
51
- );
52
- }
53
-
54
- export default memo(Switcher);
@@ -1,23 +0,0 @@
1
- function SwitcherButton(props) {
2
- const {
3
- baseClass = "ms3-layer-switcher__button", // TODO: Use generic class name
4
- children,
5
- toggleActive,
6
- status,
7
- active,
8
- } = props;
9
-
10
- return (
11
- <button
12
- type="button"
13
- role="checkbox"
14
- aria-checked={active ? "true" : "false"}
15
- className={`${baseClass} ${baseClass}--${status}`}
16
- onClick={toggleActive}
17
- >
18
- {children}
19
- </button>
20
- );
21
- }
22
-
23
- export default SwitcherButton;