@mwater/visualization 5.0.0

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 (860) hide show
  1. package/.prettierrc +11 -0
  2. package/.storybook/config.js +7 -0
  3. package/.storybook/head.html +4 -0
  4. package/.storybook/webpack.config.js +15 -0
  5. package/.vscode/launch.json +40 -0
  6. package/LICENSE +21 -0
  7. package/README.md +19 -0
  8. package/build-demo.ts +54 -0
  9. package/lib/CheckboxComponent.d.ts +15 -0
  10. package/lib/CheckboxComponent.js +25 -0
  11. package/lib/ColorComponent.d.ts +24 -0
  12. package/lib/ColorComponent.js +77 -0
  13. package/lib/ColorSchemeFactory.d.ts +8 -0
  14. package/lib/ColorSchemeFactory.js +164 -0
  15. package/lib/CsvBuilder.d.ts +5 -0
  16. package/lib/CsvBuilder.js +63 -0
  17. package/lib/DateRangeComponent.d.ts +81 -0
  18. package/lib/DateRangeComponent.js +190 -0
  19. package/lib/FiltersDesignerComponent.d.ts +25 -0
  20. package/lib/FiltersDesignerComponent.js +38 -0
  21. package/lib/ImplicitFilterBuilder.d.ts +8 -0
  22. package/lib/ImplicitFilterBuilder.js +114 -0
  23. package/lib/JsonQLFilter.d.ts +7 -0
  24. package/lib/JsonQLFilter.js +2 -0
  25. package/lib/LocaleContextInjector.d.ts +14 -0
  26. package/lib/LocaleContextInjector.js +20 -0
  27. package/lib/MWaterAddRelatedFormComponent.d.ts +25 -0
  28. package/lib/MWaterAddRelatedFormComponent.js +155 -0
  29. package/lib/MWaterAddRelatedIndicatorComponent.d.ts +31 -0
  30. package/lib/MWaterAddRelatedIndicatorComponent.js +129 -0
  31. package/lib/MWaterAssetSystemsListComponent.d.ts +17 -0
  32. package/lib/MWaterAssetSystemsListComponent.js +78 -0
  33. package/lib/MWaterCompleteTableSelectComponent.d.ts +224 -0
  34. package/lib/MWaterCompleteTableSelectComponent.js +680 -0
  35. package/lib/MWaterContextComponent.d.ts +31 -0
  36. package/lib/MWaterContextComponent.js +111 -0
  37. package/lib/MWaterCustomTablesetListComponent.d.ts +17 -0
  38. package/lib/MWaterCustomTablesetListComponent.js +87 -0
  39. package/lib/MWaterGlobalFiltersComponent.d.ts +16 -0
  40. package/lib/MWaterGlobalFiltersComponent.js +103 -0
  41. package/lib/MWaterLoaderComponent.d.ts +42 -0
  42. package/lib/MWaterLoaderComponent.js +77 -0
  43. package/lib/MWaterMetricsTableListComponent.d.ts +17 -0
  44. package/lib/MWaterMetricsTableListComponent.js +79 -0
  45. package/lib/MWaterResponsesFilterComponent.d.ts +42 -0
  46. package/lib/MWaterResponsesFilterComponent.js +145 -0
  47. package/lib/MWaterTableSelectComponent.d.ts +36 -0
  48. package/lib/MWaterTableSelectComponent.js +206 -0
  49. package/lib/MenuItemComponent.d.ts +0 -0
  50. package/lib/MenuItemComponent.js +3 -0
  51. package/lib/PopoverComponent.d.ts +15 -0
  52. package/lib/PopoverComponent.js +49 -0
  53. package/lib/RadioButtonComponent.d.ts +16 -0
  54. package/lib/RadioButtonComponent.js +25 -0
  55. package/lib/TableSelectComponent.d.ts +21 -0
  56. package/lib/TableSelectComponent.js +68 -0
  57. package/lib/UIComponents.d.ts +85 -0
  58. package/lib/UIComponents.js +195 -0
  59. package/lib/UndoStack.d.ts +11 -0
  60. package/lib/UndoStack.js +51 -0
  61. package/lib/VerticalLayoutComponent.d.ts +21 -0
  62. package/lib/VerticalLayoutComponent.js +76 -0
  63. package/lib/WidgetScope.d.ts +13 -0
  64. package/lib/WidgetScope.js +2 -0
  65. package/lib/axes/Axis.d.ts +81 -0
  66. package/lib/axes/Axis.js +2 -0
  67. package/lib/axes/AxisBuilder.d.ts +66 -0
  68. package/lib/axes/AxisBuilder.js +1202 -0
  69. package/lib/axes/AxisColorEditorComponent.d.ts +39 -0
  70. package/lib/axes/AxisColorEditorComponent.js +133 -0
  71. package/lib/axes/AxisComponent.d.ts +65 -0
  72. package/lib/axes/AxisComponent.js +359 -0
  73. package/lib/axes/BinsComponent.d.ts +21 -0
  74. package/lib/axes/BinsComponent.js +96 -0
  75. package/lib/axes/CategoryMapComponent.d.ts +41 -0
  76. package/lib/axes/CategoryMapComponent.js +175 -0
  77. package/lib/axes/ColorPaletteCollectionComponent.d.ts +17 -0
  78. package/lib/axes/ColorPaletteCollectionComponent.js +130 -0
  79. package/lib/axes/RangesComponent.d.ts +35 -0
  80. package/lib/axes/RangesComponent.js +119 -0
  81. package/lib/componenttest.d.ts +1 -0
  82. package/lib/componenttest.js +47 -0
  83. package/lib/compressJson.d.ts +4 -0
  84. package/lib/compressJson.js +19 -0
  85. package/lib/dashboards/DashboardComponent.d.ts +115 -0
  86. package/lib/dashboards/DashboardComponent.js +297 -0
  87. package/lib/dashboards/DashboardDataSource.d.ts +9 -0
  88. package/lib/dashboards/DashboardDataSource.js +14 -0
  89. package/lib/dashboards/DashboardDesign.d.ts +45 -0
  90. package/lib/dashboards/DashboardDesign.js +2 -0
  91. package/lib/dashboards/DashboardUpgrader.d.ts +4 -0
  92. package/lib/dashboards/DashboardUpgrader.js +95 -0
  93. package/lib/dashboards/DashboardUtils.d.ts +7 -0
  94. package/lib/dashboards/DashboardUtils.js +69 -0
  95. package/lib/dashboards/DashboardViewComponent.d.ts +71 -0
  96. package/lib/dashboards/DashboardViewComponent.js +235 -0
  97. package/lib/dashboards/DirectDashboardDataSource.d.ts +31 -0
  98. package/lib/dashboards/DirectDashboardDataSource.js +62 -0
  99. package/lib/dashboards/LayoutOptionsComponent.d.ts +11 -0
  100. package/lib/dashboards/LayoutOptionsComponent.js +119 -0
  101. package/lib/dashboards/README.md +13 -0
  102. package/lib/dashboards/ServerDashboardDataSource.d.ts +96 -0
  103. package/lib/dashboards/ServerDashboardDataSource.js +383 -0
  104. package/lib/dashboards/SettingsModalComponent.d.ts +33 -0
  105. package/lib/dashboards/SettingsModalComponent.js +122 -0
  106. package/lib/dashboards/WidgetComponent.d.ts +53 -0
  107. package/lib/dashboards/WidgetComponent.js +66 -0
  108. package/lib/dashboards/layoutOptions.d.ts +19 -0
  109. package/lib/dashboards/layoutOptions.js +19 -0
  110. package/lib/datagrids/DatagridComponent.d.ts +122 -0
  111. package/lib/datagrids/DatagridComponent.js +285 -0
  112. package/lib/datagrids/DatagridDataSource.d.ts +9 -0
  113. package/lib/datagrids/DatagridDataSource.js +13 -0
  114. package/lib/datagrids/DatagridDesign.d.ts +75 -0
  115. package/lib/datagrids/DatagridDesign.js +2 -0
  116. package/lib/datagrids/DatagridDesignerComponent.d.ts +114 -0
  117. package/lib/datagrids/DatagridDesignerComponent.js +389 -0
  118. package/lib/datagrids/DatagridQueryBuilder.d.ts +68 -0
  119. package/lib/datagrids/DatagridQueryBuilder.js +540 -0
  120. package/lib/datagrids/DatagridUtils.d.ts +8 -0
  121. package/lib/datagrids/DatagridUtils.js +91 -0
  122. package/lib/datagrids/DatagridViewComponent.d.ts +86 -0
  123. package/lib/datagrids/DatagridViewComponent.js +321 -0
  124. package/lib/datagrids/DirectDatagridDataSource.d.ts +20 -0
  125. package/lib/datagrids/DirectDatagridDataSource.js +62 -0
  126. package/lib/datagrids/EditExprCellComponent.d.ts +77 -0
  127. package/lib/datagrids/EditExprCellComponent.js +212 -0
  128. package/lib/datagrids/ExprCellComponent.d.ts +34 -0
  129. package/lib/datagrids/ExprCellComponent.js +81 -0
  130. package/lib/datagrids/FindReplaceModalComponent.d.ts +52 -0
  131. package/lib/datagrids/FindReplaceModalComponent.js +248 -0
  132. package/lib/datagrids/LabeledExprGenerator.d.ts +40 -0
  133. package/lib/datagrids/LabeledExprGenerator.js +252 -0
  134. package/lib/datagrids/OrderBysDesignerComponent.d.ts +22 -0
  135. package/lib/datagrids/OrderBysDesignerComponent.js +67 -0
  136. package/lib/datagrids/README.md +3 -0
  137. package/lib/datagrids/ServerDatagridDataSource.d.ts +40 -0
  138. package/lib/datagrids/ServerDatagridDataSource.js +79 -0
  139. package/lib/demo.d.ts +1 -0
  140. package/lib/demo.js +4006 -0
  141. package/lib/demoBlocks.d.ts +1 -0
  142. package/lib/demoBlocks.js +112 -0
  143. package/lib/index.css +550 -0
  144. package/lib/index.d.ts +69 -0
  145. package/lib/index.js +156 -0
  146. package/lib/injectTableAlias.d.ts +2 -0
  147. package/lib/injectTableAlias.js +30 -0
  148. package/lib/languages.d.ts +9 -0
  149. package/lib/languages.js +926 -0
  150. package/lib/layout-styles.css +263 -0
  151. package/lib/layouts/DecoratedBlockComponent.d.ts +44 -0
  152. package/lib/layouts/DecoratedBlockComponent.js +96 -0
  153. package/lib/layouts/DragSourceComponent.d.ts +2 -0
  154. package/lib/layouts/DragSourceComponent.js +26 -0
  155. package/lib/layouts/LayoutManager.d.ts +50 -0
  156. package/lib/layouts/LayoutManager.js +41 -0
  157. package/lib/layouts/blocks/BlocksDisplayComponent.d.ts +75 -0
  158. package/lib/layouts/blocks/BlocksDisplayComponent.js +336 -0
  159. package/lib/layouts/blocks/BlocksLayoutManager.d.ts +36 -0
  160. package/lib/layouts/blocks/BlocksLayoutManager.js +74 -0
  161. package/lib/layouts/blocks/ClipboardPaletteItemComponent.d.ts +9 -0
  162. package/lib/layouts/blocks/ClipboardPaletteItemComponent.js +59 -0
  163. package/lib/layouts/blocks/DraggableBlockComponent.d.ts +2 -0
  164. package/lib/layouts/blocks/DraggableBlockComponent.js +163 -0
  165. package/lib/layouts/blocks/HorizontalBlockComponent.d.ts +31 -0
  166. package/lib/layouts/blocks/HorizontalBlockComponent.js +191 -0
  167. package/lib/layouts/blocks/PaletteItemComponent.d.ts +14 -0
  168. package/lib/layouts/blocks/PaletteItemComponent.js +15 -0
  169. package/lib/layouts/blocks/README.md +11 -0
  170. package/lib/layouts/blocks/blockUtils.d.ts +22 -0
  171. package/lib/layouts/blocks/blockUtils.js +155 -0
  172. package/lib/layouts/decorated-block.css +100 -0
  173. package/lib/layouts/grid/GridLayoutComponent.d.ts +23 -0
  174. package/lib/layouts/grid/GridLayoutComponent.js +49 -0
  175. package/lib/layouts/grid/GridLayoutManager.d.ts +29 -0
  176. package/lib/layouts/grid/GridLayoutManager.js +141 -0
  177. package/lib/layouts/grid/LegoLayoutEngine.d.ts +33 -0
  178. package/lib/layouts/grid/LegoLayoutEngine.js +129 -0
  179. package/lib/layouts/grid/PaletteItemComponent.d.ts +14 -0
  180. package/lib/layouts/grid/PaletteItemComponent.js +15 -0
  181. package/lib/layouts/grid/README.md +14 -0
  182. package/lib/layouts/grid/WidgetContainerComponent.d.ts +9 -0
  183. package/lib/layouts/grid/WidgetContainerComponent.js +333 -0
  184. package/lib/mWaterLoader.d.ts +26 -0
  185. package/lib/mWaterLoader.js +55 -0
  186. package/lib/mapdemo.d.ts +0 -0
  187. package/lib/mapdemo.js +115 -0
  188. package/lib/maps/AddLayerComponent.d.ts +22 -0
  189. package/lib/maps/AddLayerComponent.js +85 -0
  190. package/lib/maps/AdminScopeAndDetailLevelComponent.d.ts +19 -0
  191. package/lib/maps/AdminScopeAndDetailLevelComponent.js +59 -0
  192. package/lib/maps/BaseLayerDesignerComponent.d.ts +28 -0
  193. package/lib/maps/BaseLayerDesignerComponent.js +57 -0
  194. package/lib/maps/BingLayer.d.ts +1 -0
  195. package/lib/maps/BingLayer.js +151 -0
  196. package/lib/maps/BufferLayer.d.ts +51 -0
  197. package/lib/maps/BufferLayer.js +816 -0
  198. package/lib/maps/BufferLayerDesign.d.ts +37 -0
  199. package/lib/maps/BufferLayerDesign.js +2 -0
  200. package/lib/maps/BufferLayerDesignerComponent.d.ts +49 -0
  201. package/lib/maps/BufferLayerDesignerComponent.js +217 -0
  202. package/lib/maps/ChoroplethLayer.d.ts +74 -0
  203. package/lib/maps/ChoroplethLayer.js +1515 -0
  204. package/lib/maps/ChoroplethLayerDesign.d.ts +56 -0
  205. package/lib/maps/ChoroplethLayerDesign.js +2 -0
  206. package/lib/maps/ChoroplethLayerDesigner.d.ts +53 -0
  207. package/lib/maps/ChoroplethLayerDesigner.js +382 -0
  208. package/lib/maps/ClusterLayer.d.ts +38 -0
  209. package/lib/maps/ClusterLayer.js +746 -0
  210. package/lib/maps/ClusterLayerDesign.d.ts +22 -0
  211. package/lib/maps/ClusterLayerDesign.js +2 -0
  212. package/lib/maps/ClusterLayerDesignerComponent.d.ts +37 -0
  213. package/lib/maps/ClusterLayerDesignerComponent.js +110 -0
  214. package/lib/maps/DetailLevelSelectComponent.d.ts +122 -0
  215. package/lib/maps/DetailLevelSelectComponent.js +91 -0
  216. package/lib/maps/DirectMapDataSource.d.ts +68 -0
  217. package/lib/maps/DirectMapDataSource.js +265 -0
  218. package/lib/maps/EditHoverOver.d.ts +18 -0
  219. package/lib/maps/EditHoverOver.js +88 -0
  220. package/lib/maps/EditPopupComponent.d.ts +26 -0
  221. package/lib/maps/EditPopupComponent.js +75 -0
  222. package/lib/maps/Grid Functions.sql +167 -0
  223. package/lib/maps/GridLayer.d.ts +48 -0
  224. package/lib/maps/GridLayer.js +684 -0
  225. package/lib/maps/GridLayerDesign.d.ts +35 -0
  226. package/lib/maps/GridLayerDesign.js +2 -0
  227. package/lib/maps/GridLayerDesigner.d.ts +38 -0
  228. package/lib/maps/GridLayerDesigner.js +229 -0
  229. package/lib/maps/HoverContent.d.ts +13 -0
  230. package/lib/maps/HoverContent.js +92 -0
  231. package/lib/maps/HtmlUrlLegend.d.ts +16 -0
  232. package/lib/maps/HtmlUrlLegend.js +38 -0
  233. package/lib/maps/Layer.d.ts +164 -0
  234. package/lib/maps/Layer.js +193 -0
  235. package/lib/maps/LayerFactory.d.ts +5 -0
  236. package/lib/maps/LayerFactory.js +47 -0
  237. package/lib/maps/LayerLegendComponent.d.ts +23 -0
  238. package/lib/maps/LayerLegendComponent.js +68 -0
  239. package/lib/maps/LayerSwitcherComponent.d.ts +7 -0
  240. package/lib/maps/LayerSwitcherComponent.js +97 -0
  241. package/lib/maps/LeafletLoading.css +24 -0
  242. package/lib/maps/LeafletLoading.d.ts +42 -0
  243. package/lib/maps/LeafletLoading.js +318 -0
  244. package/lib/maps/LeafletMapComponent.d.ts +141 -0
  245. package/lib/maps/LeafletMapComponent.js +438 -0
  246. package/lib/maps/LegendComponent.d.ts +14 -0
  247. package/lib/maps/LegendComponent.js +74 -0
  248. package/lib/maps/LegendGroup.d.ts +24 -0
  249. package/lib/maps/LegendGroup.js +86 -0
  250. package/lib/maps/MWaterServerLayer.d.ts +40 -0
  251. package/lib/maps/MWaterServerLayer.js +101 -0
  252. package/lib/maps/MapBoundsCalculator.d.ts +16 -0
  253. package/lib/maps/MapBoundsCalculator.js +85 -0
  254. package/lib/maps/MapComponent.d.ts +98 -0
  255. package/lib/maps/MapComponent.js +186 -0
  256. package/lib/maps/MapControlComponent.d.ts +17 -0
  257. package/lib/maps/MapControlComponent.js +25 -0
  258. package/lib/maps/MapDataSource.d.ts +18 -0
  259. package/lib/maps/MapDataSource.js +2 -0
  260. package/lib/maps/MapDesign.d.ts +77 -0
  261. package/lib/maps/MapDesign.js +2 -0
  262. package/lib/maps/MapDesignerComponent.d.ts +39 -0
  263. package/lib/maps/MapDesignerComponent.js +215 -0
  264. package/lib/maps/MapFiltersDesignerComponent.d.ts +21 -0
  265. package/lib/maps/MapFiltersDesignerComponent.js +70 -0
  266. package/lib/maps/MapLayerDataSource.d.ts +22 -0
  267. package/lib/maps/MapLayerDataSource.js +2 -0
  268. package/lib/maps/MapLayerViewDesignerComponent.d.ts +87 -0
  269. package/lib/maps/MapLayerViewDesignerComponent.js +151 -0
  270. package/lib/maps/MapLayersDesignerComponent.d.ts +32 -0
  271. package/lib/maps/MapLayersDesignerComponent.js +98 -0
  272. package/lib/maps/MapUtils.d.ts +21 -0
  273. package/lib/maps/MapUtils.js +119 -0
  274. package/lib/maps/MapViewComponent.d.ts +38 -0
  275. package/lib/maps/MapViewComponent.js +20 -0
  276. package/lib/maps/Maptiler-logo.png +0 -0
  277. package/lib/maps/MarkerSymbolSelectComponent.d.ts +10 -0
  278. package/lib/maps/MarkerSymbolSelectComponent.js +28 -0
  279. package/lib/maps/MarkersLayer.d.ts +66 -0
  280. package/lib/maps/MarkersLayer.js +838 -0
  281. package/lib/maps/MarkersLayerDesign.d.ts +44 -0
  282. package/lib/maps/MarkersLayerDesign.js +2 -0
  283. package/lib/maps/MarkersLayerDesignerComponent.d.ts +56 -0
  284. package/lib/maps/MarkersLayerDesignerComponent.js +269 -0
  285. package/lib/maps/PopupFilterJoinsEditComponent.d.ts +30 -0
  286. package/lib/maps/PopupFilterJoinsEditComponent.js +75 -0
  287. package/lib/maps/PopupFilterJoinsUtils.d.ts +15 -0
  288. package/lib/maps/PopupFilterJoinsUtils.js +91 -0
  289. package/lib/maps/RasterMapViewComponent.d.ts +108 -0
  290. package/lib/maps/RasterMapViewComponent.js +283 -0
  291. package/lib/maps/RegionSelectComponent.d.ts +55 -0
  292. package/lib/maps/RegionSelectComponent.js +61 -0
  293. package/lib/maps/ScopeAndDetailLevelComponent.d.ts +21 -0
  294. package/lib/maps/ScopeAndDetailLevelComponent.js +76 -0
  295. package/lib/maps/ServerMapDataSource.d.ts +86 -0
  296. package/lib/maps/ServerMapDataSource.js +273 -0
  297. package/lib/maps/SwitchableTileUrlLayer.d.ts +53 -0
  298. package/lib/maps/SwitchableTileUrlLayer.js +69 -0
  299. package/lib/maps/SwitchableTileUrlLayerDesigner.d.ts +14 -0
  300. package/lib/maps/SwitchableTileUrlLayerDesigner.js +26 -0
  301. package/lib/maps/TileUrlLayer.d.ts +40 -0
  302. package/lib/maps/TileUrlLayer.js +96 -0
  303. package/lib/maps/UtfGridLayer.d.ts +1 -0
  304. package/lib/maps/UtfGridLayer.js +216 -0
  305. package/lib/maps/VectorMapViewComponent.css +21 -0
  306. package/lib/maps/VectorMapViewComponent.d.ts +44 -0
  307. package/lib/maps/VectorMapViewComponent.js +565 -0
  308. package/lib/maps/ZoomLevelsComponent.d.ts +15 -0
  309. package/lib/maps/ZoomLevelsComponent.js +37 -0
  310. package/lib/maps/mapSymbols.d.ts +6 -0
  311. package/lib/maps/mapSymbols.js +167 -0
  312. package/lib/maps/mapboxUtils.d.ts +6 -0
  313. package/lib/maps/mapboxUtils.js +60 -0
  314. package/lib/maps/maps.d.ts +36 -0
  315. package/lib/maps/maps.js +2 -0
  316. package/lib/maps/marker-icon-2x.png +0 -0
  317. package/lib/maps/marker-icon.png +0 -0
  318. package/lib/maps/marker-shadow.png +0 -0
  319. package/lib/maps/symbols/font-awesome/asterisk.png +0 -0
  320. package/lib/maps/symbols/font-awesome/ban.png +0 -0
  321. package/lib/maps/symbols/font-awesome/beer.png +0 -0
  322. package/lib/maps/symbols/font-awesome/bell.png +0 -0
  323. package/lib/maps/symbols/font-awesome/bolt.png +0 -0
  324. package/lib/maps/symbols/font-awesome/building.png +0 -0
  325. package/lib/maps/symbols/font-awesome/bullseye.png +0 -0
  326. package/lib/maps/symbols/font-awesome/bus.png +0 -0
  327. package/lib/maps/symbols/font-awesome/caret-up.png +0 -0
  328. package/lib/maps/symbols/font-awesome/certificate.png +0 -0
  329. package/lib/maps/symbols/font-awesome/check-circle.png +0 -0
  330. package/lib/maps/symbols/font-awesome/check.png +0 -0
  331. package/lib/maps/symbols/font-awesome/chevron-circle-down.png +0 -0
  332. package/lib/maps/symbols/font-awesome/chevron-circle-up.png +0 -0
  333. package/lib/maps/symbols/font-awesome/cloud.png +0 -0
  334. package/lib/maps/symbols/font-awesome/comment.png +0 -0
  335. package/lib/maps/symbols/font-awesome/crosshairs.png +0 -0
  336. package/lib/maps/symbols/font-awesome/dot-circle-o.png +0 -0
  337. package/lib/maps/symbols/font-awesome/exclamation-circle.png +0 -0
  338. package/lib/maps/symbols/font-awesome/exclamation-triangle.png +0 -0
  339. package/lib/maps/symbols/font-awesome/female.png +0 -0
  340. package/lib/maps/symbols/font-awesome/file.png +0 -0
  341. package/lib/maps/symbols/font-awesome/flag.png +0 -0
  342. package/lib/maps/symbols/font-awesome/flask.png +0 -0
  343. package/lib/maps/symbols/font-awesome/h-square.png +0 -0
  344. package/lib/maps/symbols/font-awesome/home.png +0 -0
  345. package/lib/maps/symbols/font-awesome/info-circle.png +0 -0
  346. package/lib/maps/symbols/font-awesome/male.png +0 -0
  347. package/lib/maps/symbols/font-awesome/medkit.png +0 -0
  348. package/lib/maps/symbols/font-awesome/mobile.png +0 -0
  349. package/lib/maps/symbols/font-awesome/plus-circle.png +0 -0
  350. package/lib/maps/symbols/font-awesome/plus-square.png +0 -0
  351. package/lib/maps/symbols/font-awesome/plus.png +0 -0
  352. package/lib/maps/symbols/font-awesome/square.png +0 -0
  353. package/lib/maps/symbols/font-awesome/star.png +0 -0
  354. package/lib/maps/symbols/font-awesome/thumbs-down.png +0 -0
  355. package/lib/maps/symbols/font-awesome/thumbs-up.png +0 -0
  356. package/lib/maps/symbols/font-awesome/ticket.png +0 -0
  357. package/lib/maps/symbols/font-awesome/times-circle.png +0 -0
  358. package/lib/maps/symbols/font-awesome/times.png +0 -0
  359. package/lib/maps/symbols/font-awesome/tint.png +0 -0
  360. package/lib/maps/symbols/font-awesome/tree.png +0 -0
  361. package/lib/maps/symbols/font-awesome/university.png +0 -0
  362. package/lib/maps/symbols/font-awesome/usd.png +0 -0
  363. package/lib/maps/symbols/font-awesome/user.png +0 -0
  364. package/lib/maps/symbols/font-awesome/users.png +0 -0
  365. package/lib/maps/symbols/font-awesome/wheelchair.png +0 -0
  366. package/lib/maps/vectorMaps.d.ts +42 -0
  367. package/lib/maps/vectorMaps.js +331 -0
  368. package/lib/memoizedDebounce.d.ts +6 -0
  369. package/lib/memoizedDebounce.js +21 -0
  370. package/lib/quickfilter/DateExprComponent.d.ts +81 -0
  371. package/lib/quickfilter/DateExprComponent.js +197 -0
  372. package/lib/quickfilter/IdArrayQuickfilterComponent.d.ts +24 -0
  373. package/lib/quickfilter/IdArrayQuickfilterComponent.js +30 -0
  374. package/lib/quickfilter/Quickfilter.d.ts +21 -0
  375. package/lib/quickfilter/Quickfilter.js +2 -0
  376. package/lib/quickfilter/QuickfilterCompiler.d.ts +16 -0
  377. package/lib/quickfilter/QuickfilterCompiler.js +167 -0
  378. package/lib/quickfilter/QuickfilterUtils.d.ts +7 -0
  379. package/lib/quickfilter/QuickfilterUtils.js +106 -0
  380. package/lib/quickfilter/QuickfiltersComponent.d.ts +293 -0
  381. package/lib/quickfilter/QuickfiltersComponent.js +257 -0
  382. package/lib/quickfilter/QuickfiltersDataSource.d.ts +7 -0
  383. package/lib/quickfilter/QuickfiltersDataSource.js +2 -0
  384. package/lib/quickfilter/QuickfiltersDesignComponent.d.ts +46 -0
  385. package/lib/quickfilter/QuickfiltersDesignComponent.js +176 -0
  386. package/lib/quickfilter/README.md +8 -0
  387. package/lib/quickfilter/TextLiteralComponent.d.ts +216 -0
  388. package/lib/quickfilter/TextLiteralComponent.js +128 -0
  389. package/lib/richtext/ExprItemsHtmlConverter.d.ts +39 -0
  390. package/lib/richtext/ExprItemsHtmlConverter.js +118 -0
  391. package/lib/richtext/FontColorPaletteItem.d.ts +23 -0
  392. package/lib/richtext/FontColorPaletteItem.js +84 -0
  393. package/lib/richtext/FontSizePaletteItem.d.ts +29 -0
  394. package/lib/richtext/FontSizePaletteItem.js +70 -0
  395. package/lib/richtext/ItemsHtmlConverter.d.ts +31 -0
  396. package/lib/richtext/ItemsHtmlConverter.js +209 -0
  397. package/lib/richtext/README.md +3 -0
  398. package/lib/richtext/RichTextComponent.d.ts +84 -0
  399. package/lib/richtext/RichTextComponent.js +255 -0
  400. package/lib/valueFormatter.d.ts +16 -0
  401. package/lib/valueFormatter.js +93 -0
  402. package/lib/widgets/DirectWidgetDataSource.d.ts +43 -0
  403. package/lib/widgets/DirectWidgetDataSource.js +39 -0
  404. package/lib/widgets/DropdownWidgetComponent.d.ts +31 -0
  405. package/lib/widgets/DropdownWidgetComponent.js +41 -0
  406. package/lib/widgets/IFrameWidget.d.ts +16 -0
  407. package/lib/widgets/IFrameWidget.js +38 -0
  408. package/lib/widgets/IFrameWidgetComponent.d.ts +33 -0
  409. package/lib/widgets/IFrameWidgetComponent.js +101 -0
  410. package/lib/widgets/ImageUploaderComponent.d.ts +29 -0
  411. package/lib/widgets/ImageUploaderComponent.js +91 -0
  412. package/lib/widgets/ImageWidget.d.ts +49 -0
  413. package/lib/widgets/ImageWidget.js +112 -0
  414. package/lib/widgets/ImageWidgetComponent.d.ts +125 -0
  415. package/lib/widgets/ImageWidgetComponent.js +368 -0
  416. package/lib/widgets/ImagelistCarouselComponent.d.ts +29 -0
  417. package/lib/widgets/ImagelistCarouselComponent.js +64 -0
  418. package/lib/widgets/MapWidget.d.ts +55 -0
  419. package/lib/widgets/MapWidget.js +167 -0
  420. package/lib/widgets/MarkdownWidget.d.ts +53 -0
  421. package/lib/widgets/MarkdownWidget.js +134 -0
  422. package/lib/widgets/TOCWidget.d.ts +39 -0
  423. package/lib/widgets/TOCWidget.js +254 -0
  424. package/lib/widgets/Widget.d.ts +61 -0
  425. package/lib/widgets/Widget.js +33 -0
  426. package/lib/widgets/WidgetDataSource.d.ts +20 -0
  427. package/lib/widgets/WidgetDataSource.js +2 -0
  428. package/lib/widgets/WidgetFactory.d.ts +4 -0
  429. package/lib/widgets/WidgetFactory.js +40 -0
  430. package/lib/widgets/WidgetScoper.d.ts +9 -0
  431. package/lib/widgets/WidgetScoper.js +49 -0
  432. package/lib/widgets/WidgetScopesViewComponent.d.ts +26 -0
  433. package/lib/widgets/WidgetScopesViewComponent.js +36 -0
  434. package/lib/widgets/charts/Chart.d.ts +57 -0
  435. package/lib/widgets/charts/Chart.js +83 -0
  436. package/lib/widgets/charts/ChartViewComponent.d.ts +72 -0
  437. package/lib/widgets/charts/ChartViewComponent.js +120 -0
  438. package/lib/widgets/charts/ChartWidget.d.ts +87 -0
  439. package/lib/widgets/charts/ChartWidget.js +248 -0
  440. package/lib/widgets/charts/calendar/CalendarChart.d.ts +39 -0
  441. package/lib/widgets/charts/calendar/CalendarChart.js +175 -0
  442. package/lib/widgets/charts/calendar/CalendarChartDesignerComponent.d.ts +35 -0
  443. package/lib/widgets/charts/calendar/CalendarChartDesignerComponent.js +142 -0
  444. package/lib/widgets/charts/calendar/CalendarChartViewComponent.d.ts +56 -0
  445. package/lib/widgets/charts/calendar/CalendarChartViewComponent.js +263 -0
  446. package/lib/widgets/charts/imagemosaic/ImageMosaicChart.d.ts +21 -0
  447. package/lib/widgets/charts/imagemosaic/ImageMosaicChart.js +183 -0
  448. package/lib/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.d.ts +28 -0
  449. package/lib/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.js +105 -0
  450. package/lib/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.d.ts +31 -0
  451. package/lib/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.js +87 -0
  452. package/lib/widgets/charts/imagemosaic/ImagePopupComponent.d.ts +20 -0
  453. package/lib/widgets/charts/imagemosaic/ImagePopupComponent.js +38 -0
  454. package/lib/widgets/charts/layered/LayeredChart.d.ts +28 -0
  455. package/lib/widgets/charts/layered/LayeredChart.js +324 -0
  456. package/lib/widgets/charts/layered/LayeredChartCompiler.d.ts +113 -0
  457. package/lib/widgets/charts/layered/LayeredChartCompiler.js +1092 -0
  458. package/lib/widgets/charts/layered/LayeredChartDesign.d.ts +76 -0
  459. package/lib/widgets/charts/layered/LayeredChartDesign.js +2 -0
  460. package/lib/widgets/charts/layered/LayeredChartDesignerComponent.d.ts +80 -0
  461. package/lib/widgets/charts/layered/LayeredChartDesignerComponent.js +317 -0
  462. package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.d.ts +72 -0
  463. package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.js +329 -0
  464. package/lib/widgets/charts/layered/LayeredChartSvgFileSaver.d.ts +5 -0
  465. package/lib/widgets/charts/layered/LayeredChartSvgFileSaver.js +138 -0
  466. package/lib/widgets/charts/layered/LayeredChartUtils.d.ts +1 -0
  467. package/lib/widgets/charts/layered/LayeredChartUtils.js +25 -0
  468. package/lib/widgets/charts/layered/LayeredChartViewComponent.d.ts +44 -0
  469. package/lib/widgets/charts/layered/LayeredChartViewComponent.js +406 -0
  470. package/lib/widgets/charts/pivot/IntersectionDesignerComponent.d.ts +115 -0
  471. package/lib/widgets/charts/pivot/IntersectionDesignerComponent.js +235 -0
  472. package/lib/widgets/charts/pivot/PivotChart.d.ts +36 -0
  473. package/lib/widgets/charts/pivot/PivotChart.js +343 -0
  474. package/lib/widgets/charts/pivot/PivotChartDesign.d.ts +88 -0
  475. package/lib/widgets/charts/pivot/PivotChartDesign.js +2 -0
  476. package/lib/widgets/charts/pivot/PivotChartDesignerComponent.d.ts +37 -0
  477. package/lib/widgets/charts/pivot/PivotChartDesignerComponent.js +159 -0
  478. package/lib/widgets/charts/pivot/PivotChartLayout.d.ts +73 -0
  479. package/lib/widgets/charts/pivot/PivotChartLayout.js +2 -0
  480. package/lib/widgets/charts/pivot/PivotChartLayoutBuilder.d.ts +37 -0
  481. package/lib/widgets/charts/pivot/PivotChartLayoutBuilder.js +676 -0
  482. package/lib/widgets/charts/pivot/PivotChartLayoutComponent.d.ts +74 -0
  483. package/lib/widgets/charts/pivot/PivotChartLayoutComponent.js +333 -0
  484. package/lib/widgets/charts/pivot/PivotChartQueryBuilder.d.ts +31 -0
  485. package/lib/widgets/charts/pivot/PivotChartQueryBuilder.js +263 -0
  486. package/lib/widgets/charts/pivot/PivotChartUtils.d.ts +12 -0
  487. package/lib/widgets/charts/pivot/PivotChartUtils.js +195 -0
  488. package/lib/widgets/charts/pivot/PivotChartViewComponent.d.ts +84 -0
  489. package/lib/widgets/charts/pivot/PivotChartViewComponent.js +205 -0
  490. package/lib/widgets/charts/pivot/README.md +30 -0
  491. package/lib/widgets/charts/pivot/SegmentDesignerComponent.d.ts +96 -0
  492. package/lib/widgets/charts/pivot/SegmentDesignerComponent.js +216 -0
  493. package/lib/widgets/charts/table/OrderingsComponent.d.ts +15 -0
  494. package/lib/widgets/charts/table/OrderingsComponent.js +66 -0
  495. package/lib/widgets/charts/table/TableChart.d.ts +57 -0
  496. package/lib/widgets/charts/table/TableChart.js +310 -0
  497. package/lib/widgets/charts/table/TableChartDesignerComponent.d.ts +48 -0
  498. package/lib/widgets/charts/table/TableChartDesignerComponent.js +291 -0
  499. package/lib/widgets/charts/table/TableChartViewComponent.d.ts +28 -0
  500. package/lib/widgets/charts/table/TableChartViewComponent.js +206 -0
  501. package/lib/widgets/text/ExprInsertModalComponent.d.ts +35 -0
  502. package/lib/widgets/text/ExprInsertModalComponent.js +51 -0
  503. package/lib/widgets/text/ExprItemEditorComponent.d.ts +34 -0
  504. package/lib/widgets/text/ExprItemEditorComponent.js +92 -0
  505. package/lib/widgets/text/ExprUpdateModalComponent.d.ts +33 -0
  506. package/lib/widgets/text/ExprUpdateModalComponent.js +47 -0
  507. package/lib/widgets/text/README.md +2 -0
  508. package/lib/widgets/text/TextComponent.d.ts +48 -0
  509. package/lib/widgets/text/TextComponent.js +109 -0
  510. package/lib/widgets/text/TextWidget.d.ts +29 -0
  511. package/lib/widgets/text/TextWidget.js +243 -0
  512. package/lib/widgets/text/TextWidgetComponent.d.ts +33 -0
  513. package/lib/widgets/text/TextWidgetComponent.js +88 -0
  514. package/lib/widgets/text/TextWidgetDesign.d.ts +6 -0
  515. package/lib/widgets/text/TextWidgetDesign.js +2 -0
  516. package/mocha.html +10 -0
  517. package/package.json +113 -0
  518. package/server.js +10 -0
  519. package/src/CheckboxComponent.ts +33 -0
  520. package/src/ColorComponent.ts +117 -0
  521. package/src/ColorSchemeFactory.ts +144 -0
  522. package/src/CsvBuilder.ts +65 -0
  523. package/src/DateRangeComponent.ts +279 -0
  524. package/src/FiltersDesignerComponent.ts +55 -0
  525. package/src/ImplicitFilterBuilder.ts +135 -0
  526. package/src/JsonQLFilter.ts +8 -0
  527. package/src/LocaleContextInjector.tsx +17 -0
  528. package/src/MWaterAddRelatedFormComponent.ts +213 -0
  529. package/src/MWaterAddRelatedIndicatorComponent.ts +205 -0
  530. package/src/MWaterAssetSystemsListComponent.tsx +114 -0
  531. package/src/MWaterCompleteTableSelectComponent.tsx +984 -0
  532. package/src/MWaterContextComponent.ts +144 -0
  533. package/src/MWaterCustomTablesetListComponent.tsx +141 -0
  534. package/src/MWaterGlobalFiltersComponent.ts +117 -0
  535. package/src/MWaterLoaderComponent.ts +118 -0
  536. package/src/MWaterMetricsTableListComponent.tsx +120 -0
  537. package/src/MWaterResponsesFilterComponent.ts +194 -0
  538. package/src/MWaterTableSelectComponent.ts +316 -0
  539. package/src/MenuItemComponent.ts +2 -0
  540. package/src/PopoverComponent.ts +59 -0
  541. package/src/RadioButtonComponent.ts +34 -0
  542. package/src/TableSelectComponent.ts +60 -0
  543. package/src/UIComponents.ts +289 -0
  544. package/src/UndoStack.ts +59 -0
  545. package/src/VerticalLayoutComponent.ts +108 -0
  546. package/src/WidgetScope.ts +17 -0
  547. package/src/axes/Axis.ts +89 -0
  548. package/src/axes/AxisBuilder.ts +1325 -0
  549. package/src/axes/AxisColorEditorComponent.ts +210 -0
  550. package/src/axes/AxisComponent.ts +449 -0
  551. package/src/axes/BinsComponent.tsx +169 -0
  552. package/src/axes/CategoryMapComponent.ts +278 -0
  553. package/src/axes/ColorPaletteCollectionComponent.ts +163 -0
  554. package/src/axes/RangesComponent.ts +234 -0
  555. package/src/color-mixer.d.ts +1 -0
  556. package/src/componenttest.ts +64 -0
  557. package/src/compressJson.ts +13 -0
  558. package/src/dashboards/DashboardComponent.ts +468 -0
  559. package/src/dashboards/DashboardDataSource.ts +15 -0
  560. package/src/dashboards/DashboardDesign.ts +57 -0
  561. package/src/dashboards/DashboardUpgrader.ts +103 -0
  562. package/src/dashboards/DashboardUtils.ts +82 -0
  563. package/src/dashboards/DashboardViewComponent.ts +304 -0
  564. package/src/dashboards/DirectDashboardDataSource.ts +69 -0
  565. package/src/dashboards/LayoutOptionsComponent.tsx +227 -0
  566. package/src/dashboards/README.md +13 -0
  567. package/src/dashboards/ServerDashboardDataSource.ts +520 -0
  568. package/src/dashboards/SettingsModalComponent.ts +169 -0
  569. package/src/dashboards/WidgetComponent.tsx +131 -0
  570. package/src/dashboards/layoutOptions.ts +40 -0
  571. package/src/datagrids/DatagridComponent.ts +430 -0
  572. package/src/datagrids/DatagridDataSource.ts +21 -0
  573. package/src/datagrids/DatagridDesign.ts +94 -0
  574. package/src/datagrids/DatagridDesignerComponent.tsx +585 -0
  575. package/src/datagrids/DatagridQueryBuilder.ts +722 -0
  576. package/src/datagrids/DatagridUtils.ts +74 -0
  577. package/src/datagrids/DatagridViewComponent.ts +460 -0
  578. package/src/datagrids/DirectDatagridDataSource.ts +57 -0
  579. package/src/datagrids/EditExprCellComponent.tsx +305 -0
  580. package/src/datagrids/ExprCellComponent.ts +104 -0
  581. package/src/datagrids/FindReplaceModalComponent.ts +354 -0
  582. package/src/datagrids/LabeledExprGenerator.ts +302 -0
  583. package/src/datagrids/OrderBysDesignerComponent.tsx +128 -0
  584. package/src/datagrids/README.md +3 -0
  585. package/src/datagrids/ServerDatagridDataSource.ts +119 -0
  586. package/src/datagrids/react-linkify.d.ts +1 -0
  587. package/src/demo.ts +4148 -0
  588. package/src/demoBlocks.ts +130 -0
  589. package/src/globals.d.ts +2 -0
  590. package/src/index.css +550 -0
  591. package/src/index.ts +112 -0
  592. package/src/injectTableAlias.ts +31 -0
  593. package/src/languages.ts +931 -0
  594. package/src/layout-styles.css +263 -0
  595. package/src/layouts/DecoratedBlockComponent.ts +167 -0
  596. package/src/layouts/DragSourceComponent.ts +35 -0
  597. package/src/layouts/LayoutManager.ts +86 -0
  598. package/src/layouts/blocks/BlocksDisplayComponent.ts +461 -0
  599. package/src/layouts/blocks/BlocksLayoutManager.ts +78 -0
  600. package/src/layouts/blocks/ClipboardPaletteItemComponent.ts +89 -0
  601. package/src/layouts/blocks/DraggableBlockComponent.ts +219 -0
  602. package/src/layouts/blocks/HorizontalBlockComponent.ts +288 -0
  603. package/src/layouts/blocks/PaletteItemComponent.ts +27 -0
  604. package/src/layouts/blocks/README.md +11 -0
  605. package/src/layouts/blocks/blockUtils.ts +207 -0
  606. package/src/layouts/decorated-block.css +100 -0
  607. package/src/layouts/grid/GridLayoutComponent.ts +67 -0
  608. package/src/layouts/grid/GridLayoutManager.ts +185 -0
  609. package/src/layouts/grid/LegoLayoutEngine.ts +142 -0
  610. package/src/layouts/grid/PaletteItemComponent.ts +28 -0
  611. package/src/layouts/grid/README.md +14 -0
  612. package/src/layouts/grid/WidgetContainerComponent.ts +420 -0
  613. package/src/mWaterLoader.ts +82 -0
  614. package/src/mapdemo.ts +127 -0
  615. package/src/maps/AddLayerComponent.ts +125 -0
  616. package/src/maps/AdminScopeAndDetailLevelComponent.ts +90 -0
  617. package/src/maps/BaseLayerDesignerComponent.ts +104 -0
  618. package/src/maps/BingLayer.ts +156 -0
  619. package/src/maps/BufferLayer.ts +927 -0
  620. package/src/maps/BufferLayerDesign.ts +48 -0
  621. package/src/maps/BufferLayerDesignerComponent.ts +311 -0
  622. package/src/maps/ChoroplethLayer.ts +1712 -0
  623. package/src/maps/ChoroplethLayerDesign.ts +73 -0
  624. package/src/maps/ChoroplethLayerDesigner.tsx +558 -0
  625. package/src/maps/ClusterLayer.ts +836 -0
  626. package/src/maps/ClusterLayerDesign.ts +29 -0
  627. package/src/maps/ClusterLayerDesignerComponent.ts +190 -0
  628. package/src/maps/DetailLevelSelectComponent.ts +119 -0
  629. package/src/maps/DirectMapDataSource.ts +386 -0
  630. package/src/maps/EditHoverOver.tsx +151 -0
  631. package/src/maps/EditPopupComponent.ts +121 -0
  632. package/src/maps/Grid Functions.sql +167 -0
  633. package/src/maps/GridLayer.ts +776 -0
  634. package/src/maps/GridLayerDesign.ts +53 -0
  635. package/src/maps/GridLayerDesigner.tsx +332 -0
  636. package/src/maps/HoverContent.tsx +96 -0
  637. package/src/maps/HtmlUrlLegend.tsx +44 -0
  638. package/src/maps/Layer.ts +338 -0
  639. package/src/maps/LayerFactory.ts +51 -0
  640. package/src/maps/LayerLegendComponent.ts +88 -0
  641. package/src/maps/LayerSwitcherComponent.tsx +91 -0
  642. package/src/maps/LeafletLoading.css +24 -0
  643. package/src/maps/LeafletLoading.ts +355 -0
  644. package/src/maps/LeafletMapComponent.tsx +587 -0
  645. package/src/maps/LegendComponent.tsx +101 -0
  646. package/src/maps/LegendGroup.ts +120 -0
  647. package/src/maps/MWaterServerLayer.ts +116 -0
  648. package/src/maps/MapBoundsCalculator.ts +88 -0
  649. package/src/maps/MapComponent.ts +312 -0
  650. package/src/maps/MapControlComponent.ts +46 -0
  651. package/src/maps/MapDataSource.ts +20 -0
  652. package/src/maps/MapDesign.ts +103 -0
  653. package/src/maps/MapDesignerComponent.ts +356 -0
  654. package/src/maps/MapFiltersDesignerComponent.ts +95 -0
  655. package/src/maps/MapLayerDataSource.ts +27 -0
  656. package/src/maps/MapLayerViewDesignerComponent.ts +243 -0
  657. package/src/maps/MapLayersDesignerComponent.ts +144 -0
  658. package/src/maps/MapUtils.ts +148 -0
  659. package/src/maps/MapViewComponent.tsx +62 -0
  660. package/src/maps/Maptiler-logo.png +0 -0
  661. package/src/maps/MarkerSymbolSelectComponent.ts +41 -0
  662. package/src/maps/MarkersLayer.ts +941 -0
  663. package/src/maps/MarkersLayerDesign.ts +56 -0
  664. package/src/maps/MarkersLayerDesignerComponent.ts +374 -0
  665. package/src/maps/PopupFilterJoinsEditComponent.ts +114 -0
  666. package/src/maps/PopupFilterJoinsUtils.ts +99 -0
  667. package/src/maps/RasterMapViewComponent.ts +382 -0
  668. package/src/maps/RegionSelectComponent.ts +80 -0
  669. package/src/maps/ScopeAndDetailLevelComponent.ts +82 -0
  670. package/src/maps/ServerMapDataSource.ts +399 -0
  671. package/src/maps/SwitchableTileUrlLayer.tsx +130 -0
  672. package/src/maps/SwitchableTileUrlLayerDesigner.tsx +60 -0
  673. package/src/maps/TileUrlLayer.tsx +142 -0
  674. package/src/maps/UtfGridLayer.ts +286 -0
  675. package/src/maps/VectorMapViewComponent.css +21 -0
  676. package/src/maps/VectorMapViewComponent.tsx +743 -0
  677. package/src/maps/ZoomLevelsComponent.ts +72 -0
  678. package/src/maps/mapSymbols.ts +162 -0
  679. package/src/maps/mapboxUtils.ts +61 -0
  680. package/src/maps/maps.ts +38 -0
  681. package/src/maps/marker-icon-2x.png +0 -0
  682. package/src/maps/marker-icon.png +0 -0
  683. package/src/maps/marker-shadow.png +0 -0
  684. package/src/maps/png.d.ts +1 -0
  685. package/src/maps/symbols/font-awesome/asterisk.png +0 -0
  686. package/src/maps/symbols/font-awesome/ban.png +0 -0
  687. package/src/maps/symbols/font-awesome/beer.png +0 -0
  688. package/src/maps/symbols/font-awesome/bell.png +0 -0
  689. package/src/maps/symbols/font-awesome/bolt.png +0 -0
  690. package/src/maps/symbols/font-awesome/building.png +0 -0
  691. package/src/maps/symbols/font-awesome/bullseye.png +0 -0
  692. package/src/maps/symbols/font-awesome/bus.png +0 -0
  693. package/src/maps/symbols/font-awesome/caret-up.png +0 -0
  694. package/src/maps/symbols/font-awesome/certificate.png +0 -0
  695. package/src/maps/symbols/font-awesome/check-circle.png +0 -0
  696. package/src/maps/symbols/font-awesome/check.png +0 -0
  697. package/src/maps/symbols/font-awesome/chevron-circle-down.png +0 -0
  698. package/src/maps/symbols/font-awesome/chevron-circle-up.png +0 -0
  699. package/src/maps/symbols/font-awesome/cloud.png +0 -0
  700. package/src/maps/symbols/font-awesome/comment.png +0 -0
  701. package/src/maps/symbols/font-awesome/crosshairs.png +0 -0
  702. package/src/maps/symbols/font-awesome/dot-circle-o.png +0 -0
  703. package/src/maps/symbols/font-awesome/exclamation-circle.png +0 -0
  704. package/src/maps/symbols/font-awesome/exclamation-triangle.png +0 -0
  705. package/src/maps/symbols/font-awesome/female.png +0 -0
  706. package/src/maps/symbols/font-awesome/file.png +0 -0
  707. package/src/maps/symbols/font-awesome/flag.png +0 -0
  708. package/src/maps/symbols/font-awesome/flask.png +0 -0
  709. package/src/maps/symbols/font-awesome/h-square.png +0 -0
  710. package/src/maps/symbols/font-awesome/home.png +0 -0
  711. package/src/maps/symbols/font-awesome/info-circle.png +0 -0
  712. package/src/maps/symbols/font-awesome/male.png +0 -0
  713. package/src/maps/symbols/font-awesome/medkit.png +0 -0
  714. package/src/maps/symbols/font-awesome/mobile.png +0 -0
  715. package/src/maps/symbols/font-awesome/plus-circle.png +0 -0
  716. package/src/maps/symbols/font-awesome/plus-square.png +0 -0
  717. package/src/maps/symbols/font-awesome/plus.png +0 -0
  718. package/src/maps/symbols/font-awesome/square.png +0 -0
  719. package/src/maps/symbols/font-awesome/star.png +0 -0
  720. package/src/maps/symbols/font-awesome/thumbs-down.png +0 -0
  721. package/src/maps/symbols/font-awesome/thumbs-up.png +0 -0
  722. package/src/maps/symbols/font-awesome/ticket.png +0 -0
  723. package/src/maps/symbols/font-awesome/times-circle.png +0 -0
  724. package/src/maps/symbols/font-awesome/times.png +0 -0
  725. package/src/maps/symbols/font-awesome/tint.png +0 -0
  726. package/src/maps/symbols/font-awesome/tree.png +0 -0
  727. package/src/maps/symbols/font-awesome/university.png +0 -0
  728. package/src/maps/symbols/font-awesome/usd.png +0 -0
  729. package/src/maps/symbols/font-awesome/user.png +0 -0
  730. package/src/maps/symbols/font-awesome/users.png +0 -0
  731. package/src/maps/symbols/font-awesome/wheelchair.png +0 -0
  732. package/src/maps/vectorMaps.tsx +410 -0
  733. package/src/memoizedDebounce.tsx +32 -0
  734. package/src/quickfilter/DateExprComponent.ts +284 -0
  735. package/src/quickfilter/IdArrayQuickfilterComponent.ts +58 -0
  736. package/src/quickfilter/Quickfilter.ts +29 -0
  737. package/src/quickfilter/QuickfilterCompiler.ts +167 -0
  738. package/src/quickfilter/QuickfilterUtils.ts +123 -0
  739. package/src/quickfilter/QuickfiltersComponent.ts +416 -0
  740. package/src/quickfilter/QuickfiltersDataSource.ts +15 -0
  741. package/src/quickfilter/QuickfiltersDesignComponent.tsx +257 -0
  742. package/src/quickfilter/README.md +8 -0
  743. package/src/quickfilter/TextLiteralComponent.ts +161 -0
  744. package/src/quickfilter/react-onclickout.d.ts +1 -0
  745. package/src/richtext/ExprItemsHtmlConverter.ts +144 -0
  746. package/src/richtext/FontColorPaletteItem.ts +172 -0
  747. package/src/richtext/FontSizePaletteItem.ts +110 -0
  748. package/src/richtext/ItemsHtmlConverter.ts +246 -0
  749. package/src/richtext/README.md +3 -0
  750. package/src/richtext/RichTextComponent.tsx +390 -0
  751. package/src/richtext/react-float-affixed.d.ts +1 -0
  752. package/src/update-object.d.ts +1 -0
  753. package/src/valueFormatter.ts +110 -0
  754. package/src/widgets/DirectWidgetDataSource.ts +67 -0
  755. package/src/widgets/DropdownWidgetComponent.ts +78 -0
  756. package/src/widgets/IFrameWidget.ts +36 -0
  757. package/src/widgets/IFrameWidgetComponent.ts +116 -0
  758. package/src/widgets/ImageUploaderComponent.tsx +143 -0
  759. package/src/widgets/ImageWidget.ts +147 -0
  760. package/src/widgets/ImageWidgetComponent.ts +546 -0
  761. package/src/widgets/ImagelistCarouselComponent.ts +109 -0
  762. package/src/widgets/MapWidget.ts +219 -0
  763. package/src/widgets/MarkdownWidget.ts +201 -0
  764. package/src/widgets/TOCWidget.ts +326 -0
  765. package/src/widgets/Widget.ts +83 -0
  766. package/src/widgets/WidgetDataSource.ts +23 -0
  767. package/src/widgets/WidgetFactory.ts +37 -0
  768. package/src/widgets/WidgetScoper.ts +51 -0
  769. package/src/widgets/WidgetScopesViewComponent.ts +54 -0
  770. package/src/widgets/charts/Chart.ts +140 -0
  771. package/src/widgets/charts/ChartViewComponent.ts +209 -0
  772. package/src/widgets/charts/ChartWidget.ts +345 -0
  773. package/src/widgets/charts/calendar/CalendarChart.ts +227 -0
  774. package/src/widgets/charts/calendar/CalendarChartDesignerComponent.ts +187 -0
  775. package/src/widgets/charts/calendar/CalendarChartViewComponent.tsx +320 -0
  776. package/src/widgets/charts/calendar/d3-tip.d.ts +1 -0
  777. package/src/widgets/charts/imagemosaic/ImageMosaicChart.ts +213 -0
  778. package/src/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.ts +121 -0
  779. package/src/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.ts +117 -0
  780. package/src/widgets/charts/imagemosaic/ImagePopupComponent.ts +51 -0
  781. package/src/widgets/charts/imagemosaic/react-lazy-load-image-component.d.ts +1 -0
  782. package/src/widgets/charts/layered/LayeredChart.ts +361 -0
  783. package/src/widgets/charts/layered/LayeredChartCompiler.ts +1299 -0
  784. package/src/widgets/charts/layered/LayeredChartDesign.ts +106 -0
  785. package/src/widgets/charts/layered/LayeredChartDesignerComponent.tsx +523 -0
  786. package/src/widgets/charts/layered/LayeredChartLayerDesignerComponent.tsx +448 -0
  787. package/src/widgets/charts/layered/LayeredChartSvgFileSaver.ts +146 -0
  788. package/src/widgets/charts/layered/LayeredChartUtils.ts +24 -0
  789. package/src/widgets/charts/layered/LayeredChartViewComponent.ts +486 -0
  790. package/src/widgets/charts/layered/save-svg-as-png.d.ts +1 -0
  791. package/src/widgets/charts/pivot/IntersectionDesignerComponent.tsx +338 -0
  792. package/src/widgets/charts/pivot/PivotChart.ts +377 -0
  793. package/src/widgets/charts/pivot/PivotChartDesign.ts +115 -0
  794. package/src/widgets/charts/pivot/PivotChartDesignerComponent.tsx +240 -0
  795. package/src/widgets/charts/pivot/PivotChartLayout.ts +99 -0
  796. package/src/widgets/charts/pivot/PivotChartLayoutBuilder.ts +779 -0
  797. package/src/widgets/charts/pivot/PivotChartLayoutComponent.tsx +504 -0
  798. package/src/widgets/charts/pivot/PivotChartQueryBuilder.ts +273 -0
  799. package/src/widgets/charts/pivot/PivotChartUtils.ts +219 -0
  800. package/src/widgets/charts/pivot/PivotChartViewComponent.ts +276 -0
  801. package/src/widgets/charts/pivot/README.md +30 -0
  802. package/src/widgets/charts/pivot/SegmentDesignerComponent.tsx +353 -0
  803. package/src/widgets/charts/table/OrderingsComponent.tsx +119 -0
  804. package/src/widgets/charts/table/TableChart.ts +420 -0
  805. package/src/widgets/charts/table/TableChartDesignerComponent.ts +441 -0
  806. package/src/widgets/charts/table/TableChartViewComponent.ts +327 -0
  807. package/src/widgets/text/ExprInsertModalComponent.ts +77 -0
  808. package/src/widgets/text/ExprItemEditorComponent.tsx +164 -0
  809. package/src/widgets/text/ExprUpdateModalComponent.ts +70 -0
  810. package/src/widgets/text/README.md +2 -0
  811. package/src/widgets/text/TextComponent.tsx +151 -0
  812. package/src/widgets/text/TextWidget.ts +265 -0
  813. package/src/widgets/text/TextWidgetComponent.ts +120 -0
  814. package/src/widgets/text/TextWidgetDesign.ts +7 -0
  815. package/stories/UpdateableComponent.js +29 -0
  816. package/stories/consoles.js +202 -0
  817. package/stories/dashboards.js +217 -0
  818. package/stories/datagridDesign.js +114 -0
  819. package/stories/datagrids.js +69 -0
  820. package/stories/dates.js +80 -0
  821. package/stories/exprcomponent.js +43 -0
  822. package/stories/index.js +18 -0
  823. package/stories/leaflet.js +59 -0
  824. package/stories/maps.js +24 -0
  825. package/stories/pivotChart.js +235 -0
  826. package/test/AxisBuilderTests.ts +931 -0
  827. package/test/ChartWidgetTests.ts +85 -0
  828. package/test/ColorSchemeFactoryTests.ts +29 -0
  829. package/test/CsvBuilderTests.ts +22 -0
  830. package/test/DashboardUpgraderTests.ts +170 -0
  831. package/test/ImplicitFilterBuilderTests.ts +161 -0
  832. package/test/LayeredChartCompilerTests.ts +1067 -0
  833. package/test/LayeredChartTests.ts +88 -0
  834. package/test/LegoLayoutEngineTests.ts +69 -0
  835. package/test/MWaterGlobalFiltersComponentTests.ts +130 -0
  836. package/test/MWaterResponsesFilterComponentTests.ts +164 -0
  837. package/test/QuickfilterCompilerTests.ts +167 -0
  838. package/test/TestComponent.ts +49 -0
  839. package/test/UndoStackTests.ts +73 -0
  840. package/test/WidgetScoperTests.ts +35 -0
  841. package/test/blockUtilsTests.ts +290 -0
  842. package/test/canonical-json.d.ts +1 -0
  843. package/test/dashboards/DashboardUtilsTests.ts +131 -0
  844. package/test/datagrids/DatagridQueryBuilderTests.ts +445 -0
  845. package/test/datagrids/DatagridUtilsTests.ts +54 -0
  846. package/test/datagrids/LabeledExprGeneratorTests.ts +121 -0
  847. package/test/fixtures.ts +263 -0
  848. package/test/index.ts +2 -0
  849. package/test/maps/MapUtilsTests.ts +168 -0
  850. package/test/maps/PopupFilterJoinsUtilsTests.ts +105 -0
  851. package/test/richtext/ItemsHtmlConverterTests.ts +41 -0
  852. package/test/test_index.ts +4 -0
  853. package/test/widgets/TextWidgetTests.ts +42 -0
  854. package/test/widgets/charts/pivot/PivotChartLayoutBuilderTests.ts +817 -0
  855. package/test/widgets/charts/pivot/PivotChartQueryBuilderTests.ts +359 -0
  856. package/test/widgets/charts/pivot/PivotChartTests.ts +64 -0
  857. package/test/widgets/charts/pivot/PivotChartUtilsTests.ts +184 -0
  858. package/test/widgets/charts/table/TableChartTests.ts +253 -0
  859. package/tsconfig.build.json +26 -0
  860. package/types/utm.d.ts +10 -0
@@ -0,0 +1,941 @@
1
+ import _ from "lodash"
2
+ import React from "react"
3
+
4
+ import { original, produce } from "immer"
5
+
6
+ import Layer, { OnGridClickOptions, OnGridHoverOptions, VectorTileDef } from "./Layer"
7
+ import { ExprCompiler, ExprCleaner, injectTableAlias, Schema, DataSource, ExprValidator } from "@mwater/expressions"
8
+ import AxisBuilder from "../axes/AxisBuilder"
9
+ import { OnGridClickResults, OnGridHoverResults } from "./maps"
10
+ import { JsonQLFilter } from "../index"
11
+ import { JsonQLExpr, JsonQLQuery, JsonQLScalar, JsonQLSelect, JsonQLSelectQuery } from "@mwater/jsonql"
12
+ import { MarkersLayerDesign } from "./MarkersLayerDesign"
13
+ import { compileColorMapToMapbox, compileColorToMapbox } from "./mapboxUtils"
14
+ import LayerLegendComponent from "./LayerLegendComponent"
15
+ import * as PopupFilterJoinsUtils from "./PopupFilterJoinsUtils"
16
+ import { ExpressionSpecification, FilterSpecification, LayerSpecification } from "maplibre-gl"
17
+ import HoverContent from "./HoverContent"
18
+
19
+ export default class MarkersLayer extends Layer<MarkersLayerDesign> {
20
+ /** Gets the type of layer definition */
21
+ getLayerDefinitionType(): "VectorTile" {
22
+ return "VectorTile"
23
+ }
24
+
25
+ getVectorTile(
26
+ design: MarkersLayerDesign,
27
+ sourceId: string,
28
+ schema: Schema,
29
+ filters: JsonQLFilter[],
30
+ opacity: number
31
+ ): VectorTileDef {
32
+ const jsonql = this.createJsonQL(design, schema, filters)
33
+
34
+ const mapLayers: LayerSpecification[] = []
35
+
36
+ // If color axes, add color conditions
37
+ const color = compileColorMapToMapbox(design.axes.color, design.color || "#666666")
38
+
39
+ const baseFilters: FilterSpecification[] = []
40
+ const excludedValues = design.axes.color?.excludedValues ?? []
41
+ if (excludedValues.length > 0) {
42
+ baseFilters.push(["!", ["in", ["get", "color"], ["literal", excludedValues]]])
43
+ }
44
+
45
+ /** Adds a filter to the libreFilters */
46
+ const addFilter = (f: ExpressionSpecification): FilterSpecification => {
47
+ if (baseFilters.length > 0) {
48
+ return ["all", ...baseFilters, f] as FilterSpecification
49
+ } else {
50
+ return f
51
+ }
52
+ }
53
+
54
+ // Add polygons
55
+ mapLayers.push({
56
+ id: `${sourceId}:polygons`,
57
+ type: "fill",
58
+ source: sourceId,
59
+ "source-layer": "main",
60
+ paint: {
61
+ "fill-color": color,
62
+ "fill-opacity": (design.polygonFillOpacity ?? 0.25) * opacity
63
+ },
64
+ filter: addFilter([
65
+ "any",
66
+ ["==", ["geometry-type"], "Polygon"],
67
+ ["==", ["geometry-type"], "MultiPolygon"]
68
+ ])
69
+ })
70
+
71
+ // Add polygon outlines and lines
72
+ mapLayers.push({
73
+ id: `${sourceId}:polygon-outlines`,
74
+ type: "line",
75
+ source: sourceId,
76
+ "source-layer": "main",
77
+ paint: {
78
+ "line-color": design.polygonBorderColor || color,
79
+ "line-width": design.lineWidth != null ? design.lineWidth : 3,
80
+ "line-opacity": opacity
81
+ },
82
+ filter: addFilter([
83
+ "any",
84
+ ["==", ["geometry-type"], "Polygon"],
85
+ ["==", ["geometry-type"], "MultiPolygon"]
86
+ ])
87
+ })
88
+
89
+ // Add lines
90
+ mapLayers.push({
91
+ id: `${sourceId}:lines`,
92
+ type: "line",
93
+ source: sourceId,
94
+ "source-layer": "main",
95
+ paint: {
96
+ "line-color": color,
97
+ "line-width": design.lineWidth != null ? design.lineWidth : 3,
98
+ "line-opacity": opacity
99
+ },
100
+ filter: addFilter([
101
+ "any",
102
+ ["==", ["geometry-type"], "LineString"],
103
+ ["==", ["geometry-type"], "MultiLineString"]
104
+ ])
105
+ })
106
+
107
+ if (!design.symbol) {
108
+ mapLayers.push({
109
+ id: `${sourceId}:points`,
110
+ type: "circle",
111
+ source: sourceId,
112
+ "source-layer": "main",
113
+ paint: {
114
+ "circle-color": color,
115
+ "circle-opacity": 0.8 * opacity,
116
+ "circle-stroke-color": compileColorToMapbox("white", design.axes.color?.excludedValues),
117
+ "circle-stroke-width": 1,
118
+ "circle-stroke-opacity": 0.5 * opacity,
119
+ "circle-radius": (design.markerSize || 10) / 2
120
+ },
121
+ filter: addFilter(["==", ["geometry-type"], "Point"])
122
+ })
123
+ } else {
124
+ mapLayers.push({
125
+ id: `${sourceId}:points`,
126
+ type: "symbol",
127
+ source: sourceId,
128
+ "source-layer": "main",
129
+ layout: {
130
+ "icon-image": design.symbol,
131
+ "icon-allow-overlap": true,
132
+ "icon-size": (design.markerSize || 10) / 14 // For some reason, scales down from 20 to 14. No idea why
133
+ },
134
+ paint: {
135
+ "icon-color": color,
136
+ "icon-opacity": opacity
137
+ },
138
+ filter: addFilter(["==", ["geometry-type"], "Point"])
139
+ })
140
+ }
141
+
142
+ return {
143
+ sourceLayers: [{ id: "main", jsonql }],
144
+ ctes: [],
145
+ minZoom: design.minZoom,
146
+ maxZoom: design.maxZoom,
147
+ mapLayers: mapLayers,
148
+ mapLayersHandleClicks: [
149
+ `${sourceId}:points`,
150
+ `${sourceId}:lines`,
151
+ `${sourceId}:polygon-outlines`,
152
+ `${sourceId}:polygons`
153
+ ]
154
+ }
155
+ }
156
+
157
+ createJsonQL(design: MarkersLayerDesign, schema: Schema, filters: JsonQLFilter[]) {
158
+ const axisBuilder = new AxisBuilder({ schema })
159
+ const exprCompiler = new ExprCompiler(schema)
160
+
161
+ // Compile geometry axis
162
+ const geometryExpr = axisBuilder.compileAxis({ axis: design.axes.geometry, tableAlias: "basequery" })
163
+
164
+ // Select _id, location
165
+ const basequery: JsonQLSelectQuery = {
166
+ type: "query",
167
+ selects: [
168
+ {
169
+ type: "select",
170
+ expr: { type: "field", tableAlias: "basequery", column: schema.getTable(design.table)!.primaryKey },
171
+ alias: "id"
172
+ }, // main primary key as id
173
+ { type: "select", expr: geometryExpr, alias: "the_geom_webmercator" }, // geometry as the_geom_webmercator
174
+ ],
175
+ from: exprCompiler.compileTable(design.table, "basequery")
176
+ }
177
+
178
+ // Add color select if color axis
179
+ if (design.axes.color) {
180
+ const colorExpr = axisBuilder.compileAxis({ axis: design.axes.color, tableAlias: "basequery" })
181
+ basequery.selects.push({ type: "select", expr: colorExpr, alias: "color" })
182
+ }
183
+
184
+ // Create filters
185
+ let whereClauses: JsonQLExpr[] = []
186
+
187
+ // Add filters baked into layer
188
+ if (design.filter) {
189
+ whereClauses.push(exprCompiler.compileExpr({ expr: design.filter, tableAlias: "basequery" }))
190
+ }
191
+
192
+ // Add extra filters passed in, if relevant
193
+ const relevantFilters = _.where(filters, { table: design.table })
194
+ for (let filter of relevantFilters) {
195
+ whereClauses.push(injectTableAlias(filter.jsonql, "basequery"))
196
+ }
197
+
198
+ whereClauses = _.compact(whereClauses)
199
+
200
+ // Wrap if multiple
201
+ if (whereClauses.length > 1) {
202
+ basequery.where = { type: "op", op: "and", exprs: whereClauses }
203
+ } else {
204
+ basequery.where = whereClauses[0]
205
+ }
206
+
207
+ // Convert this to a markers query that thins out the number of markers returned and does appropriate clipping.
208
+ const markersQuery = createMarkersVectorQuery(basequery)
209
+
210
+ return markersQuery
211
+ }
212
+
213
+ // Gets the layer definition as JsonQL + CSS in format:
214
+ // {
215
+ // layers: array of { id: layer id, jsonql: jsonql that includes "the_webmercator_geom" as a column }
216
+ // css: carto css
217
+ // interactivity: (optional) { layer: id of layer, fields: array of field names }
218
+ // }
219
+ // arguments:
220
+ // design: design of layer
221
+ // schema: schema to use
222
+ // filters: array of filters to apply. Each is { table: table id, jsonql: jsonql condition with {alias} for tableAlias. Use injectAlias to put in table alias
223
+ getJsonQLCss(design: MarkersLayerDesign, schema: Schema, filters: JsonQLFilter[]) {
224
+ // Create design
225
+ const layerDef = {
226
+ layers: [
227
+ {
228
+ id: "layer0",
229
+ jsonql: this.createMapnikJsonQL(design, schema, filters)
230
+ }
231
+ ],
232
+ css: this.createCss(design),
233
+ interactivity: {
234
+ layer: "layer0",
235
+ fields: ["id"]
236
+ }
237
+ }
238
+
239
+ return layerDef
240
+ }
241
+
242
+ createMapnikJsonQL(design: MarkersLayerDesign, schema: Schema, filters: JsonQLFilter[]): JsonQLQuery {
243
+ const axisBuilder = new AxisBuilder({ schema })
244
+ const exprCompiler = new ExprCompiler(schema)
245
+
246
+ // Compile geometry axis
247
+ let geometryExpr = axisBuilder.compileAxis({ axis: design.axes.geometry, tableAlias: "innerquery" })
248
+
249
+ // row_number() over (partition by round(ST_XMin(location)/!(pixel_width!*5)), round(ST_YMin(location)/(!pixel_height!*5))) AS r
250
+ const cluster: JsonQLSelect = {
251
+ type: "select",
252
+ expr: {
253
+ type: "op",
254
+ op: "row_number",
255
+ exprs: [],
256
+ over: {
257
+ partitionBy: [
258
+ {
259
+ type: "op",
260
+ op: "round",
261
+ exprs: [
262
+ {
263
+ type: "op",
264
+ op: "/",
265
+ exprs: [
266
+ { type: "op", op: "ST_XMin", exprs: [geometryExpr] },
267
+ { type: "op", op: "*", exprs: [{ type: "token", token: "!pixel_width!" }, 5] }
268
+ ]
269
+ }
270
+ ]
271
+ },
272
+ {
273
+ type: "op",
274
+ op: "round",
275
+ exprs: [
276
+ {
277
+ type: "op",
278
+ op: "/",
279
+ exprs: [
280
+ { type: "op", op: "ST_YMin", exprs: [geometryExpr] },
281
+ { type: "op", op: "*", exprs: [{ type: "token", token: "!pixel_height!" }, 5] }
282
+ ]
283
+ }
284
+ ]
285
+ }
286
+ ]
287
+ }
288
+ },
289
+ alias: "r"
290
+ }
291
+
292
+ // Select _id, location and clustered row number
293
+ const innerquery: JsonQLSelectQuery = {
294
+ type: "query",
295
+ selects: [
296
+ {
297
+ type: "select",
298
+ expr: { type: "field", tableAlias: "innerquery", column: schema.getTable(design.table)!.primaryKey },
299
+ alias: "id"
300
+ }, // main primary key as id
301
+ { type: "select", expr: geometryExpr, alias: "the_geom_webmercator" }, // geometry as the_geom_webmercator
302
+ cluster
303
+ ],
304
+ from: exprCompiler.compileTable(design.table, "innerquery")
305
+ }
306
+
307
+ // Add color select if color axis
308
+ if (design.axes.color) {
309
+ const colorExpr = axisBuilder.compileAxis({ axis: design.axes.color, tableAlias: "innerquery" })
310
+ innerquery.selects.push({ type: "select", expr: colorExpr, alias: "color" })
311
+ }
312
+
313
+ // Create filters. First limit to bounding box
314
+ let whereClauses: JsonQLExpr[] = [
315
+ {
316
+ type: "op",
317
+ op: "&&",
318
+ exprs: [geometryExpr, { type: "token", token: "!bbox!" }]
319
+ }
320
+ ]
321
+
322
+ // Then add filters baked into layer
323
+ if (design.filter) {
324
+ whereClauses.push(exprCompiler.compileExpr({ expr: design.filter, tableAlias: "innerquery" }))
325
+ }
326
+
327
+ // Then add extra filters passed in, if relevant
328
+ // Get relevant filters
329
+ const relevantFilters = _.where(filters, { table: design.table })
330
+ for (let filter of relevantFilters) {
331
+ whereClauses.push(injectTableAlias(filter.jsonql, "innerquery"))
332
+ }
333
+
334
+ whereClauses = _.compact(whereClauses)
335
+
336
+ // Wrap if multiple
337
+ if (whereClauses.length > 1) {
338
+ innerquery.where = { type: "op", op: "and", exprs: whereClauses }
339
+ } else {
340
+ innerquery.where = whereClauses[0]
341
+ }
342
+
343
+ // Create outer query which takes where r <= 3 to limit # of points in a cluster
344
+ const outerquery: JsonQLQuery = {
345
+ type: "query",
346
+ selects: [
347
+ {
348
+ type: "select",
349
+ expr: { type: "field", tableAlias: "innerquery", column: "id" },
350
+ alias: "id"
351
+ }, // innerquery._id as id
352
+ {
353
+ type: "select",
354
+ expr: { type: "field", tableAlias: "innerquery", column: "the_geom_webmercator" },
355
+ alias: "the_geom_webmercator"
356
+ }, // innerquery.the_geom_webmercator as the_geom_webmercator
357
+ {
358
+ type: "select",
359
+ expr: {
360
+ type: "op",
361
+ op: "ST_GeometryType",
362
+ exprs: [{ type: "field", tableAlias: "innerquery", column: "the_geom_webmercator" }]
363
+ },
364
+ alias: "geometry_type"
365
+ } // ST_GeometryType(innerquery.the_geom_webmercator) as geometry_type
366
+ ],
367
+ from: { type: "subquery", query: innerquery, alias: "innerquery" },
368
+ where: { type: "op", op: "<=", exprs: [{ type: "field", tableAlias: "innerquery", column: "r" }, 3] }
369
+ }
370
+
371
+ // Add color select if color axis
372
+ if (design.axes.color) {
373
+ outerquery.selects.push({
374
+ type: "select",
375
+ expr: { type: "field", tableAlias: "innerquery", column: "color" },
376
+ alias: "color"
377
+ }) // innerquery.color as color
378
+ }
379
+
380
+ return outerquery
381
+ }
382
+
383
+ // Creates CartoCSS
384
+ createCss(design: MarkersLayerDesign) {
385
+ let stroke, symbol
386
+ let css = ""
387
+
388
+ if (design.symbol) {
389
+ symbol = `marker-file: url(${design.symbol});`
390
+ stroke = "marker-line-width: 60;"
391
+ } else {
392
+ symbol = "marker-type: ellipse;"
393
+ stroke = "marker-line-width: 1;"
394
+ }
395
+
396
+ // Should only display markers when it is a point geometry
397
+ css +=
398
+ `\
399
+ #layer0[geometry_type='ST_Point'] {
400
+ marker-fill: ` +
401
+ (design.color || "#666666") +
402
+ `;
403
+ marker-width: ` +
404
+ (design.markerSize || 10) +
405
+ `;
406
+ marker-line-color: white;\
407
+ ` +
408
+ stroke +
409
+ `\
410
+ marker-line-opacity: 0.6;
411
+ marker-placement: point;\
412
+ ` +
413
+ symbol +
414
+ `\
415
+ marker-allow-overlap: true;
416
+ }
417
+ #layer0 {
418
+ line-color: ` +
419
+ (design.color || "#666666") +
420
+ `;
421
+ line-width: ` +
422
+ (design.lineWidth != null ? design.lineWidth : "3") +
423
+ `;
424
+ }
425
+ #layer0[geometry_type='ST_Polygon'],#layer0[geometry_type='ST_MultiPolygon'] {
426
+ polygon-fill: ` +
427
+ (design.color || "#666666") +
428
+ `;
429
+ polygon-opacity: ${design.polygonFillOpacity ?? 0.25};
430
+ }
431
+ \
432
+ `
433
+
434
+ // If color axes, add color conditions
435
+ if (design.axes.color && design.axes.color.colorMap) {
436
+ for (let item of design.axes.color.colorMap) {
437
+ // If invisible
438
+ if (_.includes(design.axes.color.excludedValues || [], item.value)) {
439
+ css +=
440
+ `\
441
+ #layer0[color=` +
442
+ JSON.stringify(item.value) +
443
+ `] { line-opacity: 0; marker-line-opacity: 0; marker-fill-opacity: 0; polygon-opacity: 0; }\
444
+ `
445
+ } else {
446
+ css +=
447
+ `\
448
+ #layer0[color=` +
449
+ JSON.stringify(item.value) +
450
+ "] { line-color: " +
451
+ item.color +
452
+ ` }
453
+ #layer0[color=` +
454
+ JSON.stringify(item.value) +
455
+ "][geometry_type='ST_Point'] { marker-fill: " +
456
+ item.color +
457
+ ` }
458
+ #layer0[color=` +
459
+ JSON.stringify(item.value) +
460
+ "][geometry_type='ST_Polygon'],#layer0[color=" +
461
+ JSON.stringify(item.value) +
462
+ `][geometry_type='ST_MultiPolygon'] {
463
+ polygon-fill: ` +
464
+ item.color +
465
+ `;\
466
+ ${design.polygonBorderColor ? "line-color: " + design.polygonBorderColor + ";" : ""}\
467
+ }\
468
+ `
469
+ }
470
+ }
471
+ }
472
+
473
+ return css
474
+ }
475
+
476
+ // same as onGridClick but handles hover over
477
+ onGridHoverOver(
478
+ ev: { data: any; event: any },
479
+ hoverOptions: OnGridHoverOptions<MarkersLayerDesign>
480
+ ): OnGridHoverResults {
481
+ if (ev.data && ev.data.id) {
482
+ const { table } = hoverOptions.design
483
+ const results: OnGridHoverResults = {}
484
+
485
+ // Popup
486
+ if (hoverOptions.design.hoverOver) {
487
+ // Create filter using popupFilterJoins
488
+ const popupFilterJoins =
489
+ hoverOptions.design.popupFilterJoins || PopupFilterJoinsUtils.createDefaultPopupFilterJoins(table)
490
+ const popupFilters = PopupFilterJoinsUtils.createPopupFilters(
491
+ popupFilterJoins,
492
+ hoverOptions.schema,
493
+ table,
494
+ ev.data.id
495
+ )
496
+
497
+ results.hoverOver = React.createElement(HoverContent, {
498
+ key: ev.data.id,
499
+ schema: hoverOptions.schema,
500
+ dataSource: hoverOptions.dataSource,
501
+ design: hoverOptions.design,
502
+ filters: popupFilters
503
+ })
504
+ }
505
+
506
+ return results
507
+ } else {
508
+ return null
509
+ }
510
+ }
511
+
512
+ // Called when the interactivity grid is clicked.
513
+ // arguments:
514
+ // ev: { data: interactivty data e.g. `{ id: 123 }` }
515
+ // clickOptions:
516
+ // design: design of layer
517
+ // schema: schema to use
518
+ // dataSource: data source to use
519
+ // layerDataSource: layer data source
520
+ // scopeData: current scope data if layer is scoping
521
+ // filters: compiled filters to apply to the popup
522
+ //
523
+ // Returns:
524
+ // null/undefined
525
+ // or
526
+ // {
527
+ // scope: scope to apply ({ name, filter, data })
528
+ // row: { tableId:, primaryKey: } # row that was selected
529
+ // popup: React element to put into a popup
530
+ // }
531
+ onGridClick(ev: { data: any; event: any }, clickOptions: OnGridClickOptions<MarkersLayerDesign>): OnGridClickResults {
532
+ // TODO abstract most to base class
533
+ if (ev.data && ev.data.id) {
534
+ const { table } = clickOptions.design
535
+ const results: OnGridClickResults = {}
536
+
537
+ // Scope toggle item if ctrl-click
538
+ if (ev.event.originalEvent.shiftKey) {
539
+ let ids = clickOptions.scopeData || []
540
+ if (ids.includes(ev.data.id)) {
541
+ ids = _.without(ids, ev.data.id)
542
+ } else {
543
+ ids = ids.concat([ev.data.id])
544
+ }
545
+
546
+ // Create filter for rows
547
+ const filter = {
548
+ table,
549
+ jsonql: {
550
+ type: "op",
551
+ op: "=",
552
+ modifier: "any",
553
+ exprs: [
554
+ { type: "field", tableAlias: "{alias}", column: clickOptions.schema.getTable(table)!.primaryKey },
555
+ { type: "literal", value: ids }
556
+ ]
557
+ }
558
+ }
559
+
560
+ // Scope to item
561
+ if (ids.length > 0) {
562
+ results.scope = {
563
+ name: `Selected ${ids.length} Markers(s)`,
564
+ filter,
565
+ data: ids
566
+ }
567
+ } else {
568
+ results.scope = null
569
+ }
570
+ }
571
+
572
+ // Popup
573
+ if (clickOptions.design.popup && !ev.event.originalEvent.shiftKey) {
574
+ // Create filter using popupFilterJoins
575
+ const popupFilterJoins =
576
+ clickOptions.design.popupFilterJoins || PopupFilterJoinsUtils.createDefaultPopupFilterJoins(table)
577
+ const popupFilters = PopupFilterJoinsUtils.createPopupFilters(
578
+ popupFilterJoins,
579
+ clickOptions.schema,
580
+ table,
581
+ ev.data.id
582
+ )
583
+
584
+ const BlocksLayoutManager = require("../layouts/blocks/BlocksLayoutManager").default
585
+ const WidgetFactory = require("../widgets/WidgetFactory").default
586
+
587
+ results.popup = new BlocksLayoutManager().renderLayout({
588
+ items: clickOptions.design.popup.items,
589
+ style: "popup",
590
+ renderWidget: (options: any) => {
591
+ const widget = WidgetFactory.createWidget(options.type)
592
+
593
+ const filters = clickOptions.filters.concat(popupFilters)
594
+
595
+ // Get data source for widget
596
+ const widgetDataSource = clickOptions.layerDataSource.getPopupWidgetDataSource(
597
+ clickOptions.design,
598
+ options.id
599
+ )
600
+
601
+ return widget.createViewElement({
602
+ schema: clickOptions.schema,
603
+ dataSource: clickOptions.dataSource,
604
+ widgetDataSource,
605
+ design: options.design,
606
+ scope: null,
607
+ filters,
608
+ onScopeChange: null,
609
+ onDesignChange: null,
610
+ width: options.width,
611
+ height: options.height
612
+ })
613
+ }
614
+ })
615
+ } else if (!ev.event.originalEvent.shiftKey) {
616
+ results.row = { tableId: table, primaryKey: ev.data.id }
617
+ }
618
+
619
+ return results
620
+ } else {
621
+ return null
622
+ }
623
+ }
624
+
625
+ // Gets the bounds of the layer as GeoJSON
626
+ getBounds(
627
+ design: MarkersLayerDesign,
628
+ schema: Schema,
629
+ dataSource: DataSource,
630
+ filters: JsonQLFilter[],
631
+ callback: any
632
+ ) {
633
+ return this.getBoundsFromExpr(
634
+ schema,
635
+ dataSource,
636
+ design.table,
637
+ design.axes.geometry.expr,
638
+ design.filter || null,
639
+ filters,
640
+ callback
641
+ )
642
+ }
643
+
644
+ // Get min and max zoom levels
645
+ getMinZoom(design: MarkersLayerDesign) {
646
+ return design.minZoom
647
+ }
648
+ getMaxZoom(design: MarkersLayerDesign) {
649
+ return design.maxZoom || 21
650
+ }
651
+
652
+ // Get the legend to be optionally displayed on the map. Returns
653
+ // a React element
654
+ getLegend(
655
+ design: MarkersLayerDesign,
656
+ schema: Schema,
657
+ name: string,
658
+ dataSource: DataSource,
659
+ locale: string,
660
+ filters: JsonQLFilter[]
661
+ ) {
662
+ const _filters = filters.slice()
663
+ if (design.filter != null) {
664
+ const exprCompiler = new ExprCompiler(schema)
665
+ const jsonql = exprCompiler.compileExpr({ expr: design.filter, tableAlias: "{alias}" })
666
+ if (jsonql) {
667
+ _filters.push({ table: (design.filter as any).table, jsonql })
668
+ }
669
+ }
670
+
671
+ const axisBuilder = new AxisBuilder({ schema })
672
+ return React.createElement(LayerLegendComponent, {
673
+ schema,
674
+ defaultColor: design.color,
675
+ symbol: design.symbol || "font-awesome/circle",
676
+ markerSize: design.markerSize,
677
+ name,
678
+ filters: _.compact(_filters),
679
+ axis: axisBuilder.cleanAxis({
680
+ axis: design.axes.color || null,
681
+ table: design.table,
682
+ types: ["enum", "text", "boolean", "date"],
683
+ aggrNeed: "none"
684
+ }),
685
+ locale
686
+ })
687
+ }
688
+
689
+ // Get a list of table ids that can be filtered on
690
+ getFilterableTables(design: MarkersLayerDesign, schema: Schema): string[] {
691
+ if (design.table) {
692
+ return [design.table]
693
+ } else {
694
+ return []
695
+ }
696
+ }
697
+
698
+ // True if layer can be edited
699
+ isEditable() {
700
+ return true
701
+ }
702
+
703
+ // Creates a design element with specified options
704
+ // options:
705
+ // design: design of layer
706
+ // schema: schema to use
707
+ // dataSource: data source to use
708
+ // onDesignChange: function called when design changes
709
+ // filters: array of filters
710
+ createDesignerElement(options: {
711
+ design: MarkersLayerDesign
712
+ schema: Schema
713
+ dataSource: DataSource
714
+ onDesignChange: (design: MarkersLayerDesign) => void
715
+ filters: JsonQLFilter[]
716
+ }): React.ReactElement<{}> {
717
+ // Require here to prevent server require problems
718
+ const MarkersLayerDesignerComponent = require("./MarkersLayerDesignerComponent").default
719
+
720
+ // Clean on way in and out
721
+ return React.createElement(MarkersLayerDesignerComponent, {
722
+ schema: options.schema,
723
+ dataSource: options.dataSource,
724
+ design: this.cleanDesign(options.design, options.schema),
725
+ filters: options.filters,
726
+ onDesignChange: (design: MarkersLayerDesign) => {
727
+ return options.onDesignChange(this.cleanDesign(design, options.schema))
728
+ }
729
+ })
730
+ }
731
+
732
+ // Returns a cleaned design
733
+ cleanDesign(design: MarkersLayerDesign, schema: Schema): MarkersLayerDesign {
734
+ const exprCleaner = new ExprCleaner(schema)
735
+ const axisBuilder = new AxisBuilder({ schema })
736
+
737
+ // Migrate legacy sublayers
738
+ if (design.sublayers) {
739
+ design = _.extend({}, design, design.sublayers[0])
740
+ delete design.sublayers
741
+ }
742
+
743
+ design = produce(design, draft => {
744
+ draft.axes = design.axes || {}
745
+ draft.color = design.color || "#0088FF"
746
+
747
+ draft.axes.geometry = axisBuilder.cleanAxis({
748
+ axis: draft.axes.geometry ? original(draft.axes.geometry) || null : null,
749
+ table: design.table,
750
+ types: ["geometry"],
751
+ aggrNeed: "none"
752
+ })!
753
+ draft.axes.color = axisBuilder.cleanAxis({
754
+ axis: draft.axes.color ? original(draft.axes.color) || null : null,
755
+ table: design.table,
756
+ types: ["enum", "text", "boolean", "date"],
757
+ aggrNeed: "none"
758
+ })!
759
+
760
+ draft.filter = exprCleaner.cleanExpr(design.filter || null, { table: draft.table })
761
+ })
762
+
763
+ return design
764
+ }
765
+
766
+ // Validates design. Null if ok, message otherwise
767
+ validateDesign(design: MarkersLayerDesign, schema: Schema) {
768
+ const axisBuilder = new AxisBuilder({ schema })
769
+ const exprValidator = new ExprValidator(schema)
770
+
771
+ if (!design.table) {
772
+ return "Missing table"
773
+ }
774
+
775
+ if (!design.axes || !design.axes.geometry) {
776
+ return "Missing axes"
777
+ }
778
+
779
+ let error = axisBuilder.validateAxis({ axis: design.axes.geometry })
780
+ if (error) {
781
+ return error
782
+ }
783
+
784
+ // Validate color
785
+ error = axisBuilder.validateAxis({ axis: design.axes.color || null })
786
+ if (error) {
787
+ return error
788
+ }
789
+
790
+ // Check that doesn't compile to null (persistent bug that haven't been able to track down)
791
+ if (!axisBuilder.compileAxis({ axis: design.axes.geometry, tableAlias: "innerquery" })) {
792
+ return "Null geometry axis"
793
+ }
794
+
795
+ // Validate filter
796
+ error = exprValidator.validateExpr(design.filter || null)
797
+ if (error) {
798
+ return error
799
+ }
800
+
801
+ return null
802
+ }
803
+ }
804
+
805
+ /**
806
+ * Takes a base query that has any number of selects and where conditions. It must have a geometry
807
+ * field called the_geom_webmercator. It then adds a select that is a row_number() over a partition by the rounded
808
+ * ST_XMin and ST_YMin of the geometry divided by the scale of the tile. This creates clusters of markers
809
+ * that are within the same grid square of the size of the scale. The row_number() is aliased as "r".
810
+ *
811
+ * It then adds a where clause that clips the geometry to the envelope of the tile plus a margin.
812
+ *
813
+ * The outer query then selects all non-geometry and non-cluster fields and wraps the geometry in
814
+ * ST_AsMVTGeom to prepare it for display. It also limits the clusters to a maximum of 3 markers per
815
+ * small area to limit tile sizes
816
+ *
817
+ * @param baseQuery query to build from
818
+ * @returns query ready for sending to server
819
+ */
820
+ export function createMarkersVectorQuery(baseQuery: JsonQLSelectQuery) {
821
+ // Expression of scale and envelope from tile table
822
+ const scaleExpr: JsonQLScalar = {
823
+ type: "scalar",
824
+ expr: { type: "field", tableAlias: "tile", column: "scale" },
825
+ from: { type: "table", table: "tile", alias: "tile" }
826
+ }
827
+ const envelopeExpr: JsonQLScalar = {
828
+ type: "scalar",
829
+ expr: { type: "field", tableAlias: "tile", column: "envelope" },
830
+ from: { type: "table", table: "tile", alias: "tile" }
831
+ }
832
+ const envelopeWithMarginExpr: JsonQLScalar = {
833
+ type: "scalar",
834
+ expr: { type: "field", tableAlias: "tile", column: "envelope_with_margin" },
835
+ from: { type: "table", table: "tile", alias: "tile" }
836
+ }
837
+
838
+ // Extract geometry expression from base query
839
+ const geometryExpr = _.find(baseQuery.selects, select => select.alias === "the_geom_webmercator")?.expr
840
+ if (!geometryExpr) {
841
+ throw new Error("No geometry expression found")
842
+ }
843
+
844
+ // row_number() over (partition by st_snaptogrid(location, tile.scale / 150, tile.scale / 150)) AS r
845
+ const cluster: JsonQLSelect = {
846
+ type: "select",
847
+ expr: {
848
+ type: "op",
849
+ op: "row_number",
850
+ exprs: [],
851
+ over: {
852
+ partitionBy: [
853
+ {
854
+ type: "op",
855
+ op: "round",
856
+ exprs: [
857
+ {
858
+ type: "op",
859
+ op: "/",
860
+ exprs: [
861
+ { type: "op", op: "ST_XMin", exprs: [geometryExpr] },
862
+ { type: "op", op: "/", exprs: [scaleExpr, 150] }
863
+ ]
864
+ }
865
+ ]
866
+ },
867
+ {
868
+ type: "op",
869
+ op: "round",
870
+ exprs: [
871
+ {
872
+ type: "op",
873
+ op: "/",
874
+ exprs: [
875
+ { type: "op", op: "ST_YMin", exprs: [geometryExpr] },
876
+ { type: "op", op: "/", exprs: [scaleExpr, 150] }
877
+ ]
878
+ }
879
+ ]
880
+ }
881
+ ]
882
+ }
883
+ },
884
+ alias: "r"
885
+ }
886
+
887
+ // Add where clause for limiting to envelope
888
+ const clipEnvelopeWithMargin: JsonQLExpr = {
889
+ type: "op",
890
+ op: "&&",
891
+ exprs: [geometryExpr, envelopeWithMarginExpr]
892
+ }
893
+
894
+ // Create inner query which has the cluster as a SELECT and the clipping as a WHERE clause.
895
+ const innerquery = produce(baseQuery, draft => {
896
+ draft.selects.push(cluster)
897
+ if (!draft.where) {
898
+ draft.where = clipEnvelopeWithMargin
899
+ } else {
900
+ draft.where = {
901
+ type: "op",
902
+ op: "and",
903
+ exprs: [draft.where, clipEnvelopeWithMargin]
904
+ }
905
+ }
906
+ })
907
+
908
+ // Bubble up selects that are not cluster or geometry to the outer query
909
+ const innerSelects: JsonQLSelect[] = baseQuery.selects.filter(
910
+ select => select.alias !== "the_geom_webmercator"
911
+ ).map(select => ({ type: "select", expr: { type: "field", tableAlias: "innerquery", column: select.alias }, alias: select.alias}))
912
+
913
+ // Create outer query which takes where r <= 3 to limit # of points in a cluster
914
+ // Wrap geometry in ST_Force2D to avoid https://trac.osgeo.org/postgis/ticket/4690 (https://github.com/mWater/mwater-server/issues/495)
915
+ const outerquery: JsonQLQuery = {
916
+ type: "query",
917
+ selects: [
918
+ ...innerSelects,
919
+ {
920
+ type: "select",
921
+ expr: {
922
+ type: "op",
923
+ op: "ST_AsMVTGeom",
924
+ exprs: [
925
+ {
926
+ type: "op",
927
+ op: "ST_Force2D",
928
+ exprs: [{ type: "field", tableAlias: "innerquery", column: "the_geom_webmercator" }]
929
+ },
930
+ envelopeExpr
931
+ ]
932
+ },
933
+ alias: "the_geom_webmercator"
934
+ }, // innerquery.the_geom_webmercator as the_geom_webmercator
935
+ ],
936
+ from: { type: "subquery", query: innerquery, alias: "innerquery" },
937
+ where: { type: "op", op: "<=", exprs: [{ type: "field", tableAlias: "innerquery", column: "r" }, 3] }
938
+ }
939
+
940
+ return outerquery
941
+ }