@mwater/visualization 5.3.2 → 5.4.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 (309) hide show
  1. package/lib/ColorComponent.d.ts +1 -1
  2. package/lib/ColorComponent.js +2 -2
  3. package/lib/CustomColorsContext.d.ts +0 -1
  4. package/lib/DateRangeComponent.js +10 -10
  5. package/lib/LocaleContextInjector.js +2 -2
  6. package/lib/MWaterAddRelatedFormComponent.js +8 -8
  7. package/lib/MWaterAddRelatedIndicatorComponent.d.ts +0 -1
  8. package/lib/MWaterAddRelatedIndicatorComponent.js +6 -6
  9. package/lib/MWaterAssetSystemsListComponent.d.ts +3 -3
  10. package/lib/MWaterAssetSystemsListComponent.js +4 -3
  11. package/lib/MWaterCompleteTableSelectComponent.d.ts +33 -34
  12. package/lib/MWaterCompleteTableSelectComponent.js +39 -38
  13. package/lib/MWaterCustomTablesetListComponent.d.ts +3 -3
  14. package/lib/MWaterCustomTablesetListComponent.js +5 -4
  15. package/lib/MWaterGlobalFiltersComponent.js +4 -4
  16. package/lib/MWaterLoaderComponent.d.ts +5 -5
  17. package/lib/MWaterLoaderComponent.js +1 -1
  18. package/lib/MWaterMetricsTableListComponent.d.ts +3 -3
  19. package/lib/MWaterMetricsTableListComponent.js +4 -3
  20. package/lib/MWaterResponsesFilterComponent.js +4 -4
  21. package/lib/MWaterTableSelectComponent.d.ts +1 -1
  22. package/lib/MWaterTableSelectComponent.js +5 -5
  23. package/lib/PopoverComponent.d.ts +4 -4
  24. package/lib/UIComponents.d.ts +5 -2
  25. package/lib/axes/AxisBuilder.js +42 -43
  26. package/lib/axes/AxisColorEditorComponent.d.ts +4 -4
  27. package/lib/axes/AxisColorEditorComponent.js +25 -60
  28. package/lib/axes/AxisComponent.d.ts +2 -3
  29. package/lib/axes/AxisComponent.js +20 -20
  30. package/lib/axes/BinsComponent.js +6 -6
  31. package/lib/axes/CategoryMapComponent.d.ts +2 -1
  32. package/lib/axes/CategoryMapComponent.js +7 -5
  33. package/lib/axes/ColorPaletteCollectionComponent.js +3 -3
  34. package/lib/axes/RangesComponent.js +12 -12
  35. package/lib/compressJson.js +1 -1
  36. package/lib/dashboards/DashboardComponent.d.ts +2 -0
  37. package/lib/dashboards/DashboardComponent.js +15 -8
  38. package/lib/dashboards/DashboardUtils.js +2 -3
  39. package/lib/dashboards/DashboardViewComponent.js +4 -4
  40. package/lib/dashboards/FontStyleEditor.js +8 -8
  41. package/lib/dashboards/LayoutOptionsComponent.js +101 -74
  42. package/lib/dashboards/SettingsModalComponent.d.ts +3 -4
  43. package/lib/dashboards/SettingsModalComponent.js +54 -40
  44. package/lib/dashboards/WidgetComponent.d.ts +0 -1
  45. package/lib/dashboards/WidgetComponent.js +1 -2
  46. package/lib/dashboards/layoutOptions.js +11 -7
  47. package/lib/datagrids/DatagridComponent.d.ts +1 -8
  48. package/lib/datagrids/DatagridComponent.js +14 -13
  49. package/lib/datagrids/DatagridDesignerComponent.js +18 -18
  50. package/lib/datagrids/DatagridQueryBuilder.d.ts +4 -4
  51. package/lib/datagrids/DatagridUtils.js +2 -2
  52. package/lib/datagrids/DatagridViewComponent.js +4 -4
  53. package/lib/datagrids/ExprCellComponent.js +1 -1
  54. package/lib/datagrids/FindReplaceModalComponent.js +17 -17
  55. package/lib/datagrids/OrderBysDesignerComponent.js +2 -2
  56. package/lib/languages.js +2 -2
  57. package/lib/layouts/DecoratedBlockComponent.js +2 -2
  58. package/lib/layouts/blocks/BlocksDisplayComponent.js +13 -13
  59. package/lib/layouts/blocks/BlocksLayoutManager.d.ts +2 -1
  60. package/lib/layouts/blocks/ClipboardPaletteItemComponent.js +3 -3
  61. package/lib/layouts/blocks/HorizontalBlockComponent.js +3 -3
  62. package/lib/layouts/blocks/blockUtils.js +4 -5
  63. package/lib/mWaterLoader.js +1 -1
  64. package/lib/maps/AddLayerComponent.js +13 -13
  65. package/lib/maps/AdminScopeAndDetailLevelComponent.js +5 -5
  66. package/lib/maps/BaseLayerDesignerComponent.js +2 -2
  67. package/lib/maps/BufferLayer.js +7 -7
  68. package/lib/maps/BufferLayerDesignerComponent.js +8 -8
  69. package/lib/maps/ChoroplethLayer.js +6 -6
  70. package/lib/maps/ChoroplethLayerDesigner.js +16 -16
  71. package/lib/maps/ClusterLayer.js +3 -3
  72. package/lib/maps/ClusterLayerDesignerComponent.js +5 -5
  73. package/lib/maps/DetailLevelSelectComponent.d.ts +11 -1
  74. package/lib/maps/DetailLevelSelectComponent.js +3 -3
  75. package/lib/maps/DirectMapDataSource.js +1 -2
  76. package/lib/maps/EditHoverOver.js +7 -5
  77. package/lib/maps/EditPopupComponent.js +2 -2
  78. package/lib/maps/GridLayer.js +5 -5
  79. package/lib/maps/GridLayerDesigner.js +15 -15
  80. package/lib/maps/LayerSwitcherComponent.js +1 -2
  81. package/lib/maps/LeafletMapComponent.d.ts +1 -1
  82. package/lib/maps/LeafletMapComponent.js +1 -1
  83. package/lib/maps/LegendComponent.js +1 -1
  84. package/lib/maps/MWaterServerLayer.d.ts +0 -1
  85. package/lib/maps/MWaterServerLayer.js +1 -1
  86. package/lib/maps/MapComponent.js +8 -8
  87. package/lib/maps/MapControlComponent.js +1 -1
  88. package/lib/maps/MapDesignerComponent.js +16 -16
  89. package/lib/maps/MapFiltersDesignerComponent.js +2 -2
  90. package/lib/maps/MapLayerViewDesignerComponent.js +8 -8
  91. package/lib/maps/MapUtils.js +6 -7
  92. package/lib/maps/MapViewComponent.js +1 -2
  93. package/lib/maps/MarkerSymbolSelectComponent.js +3 -3
  94. package/lib/maps/MarkersLayer.js +6 -7
  95. package/lib/maps/MarkersLayerDesignerComponent.js +22 -22
  96. package/lib/maps/PopupFilterJoinsEditComponent.js +4 -4
  97. package/lib/maps/PopupFilterJoinsUtils.js +2 -3
  98. package/lib/maps/RasterMapViewComponent.d.ts +3 -3
  99. package/lib/maps/RasterMapViewComponent.js +4 -4
  100. package/lib/maps/RegionSelectComponent.d.ts +1 -3
  101. package/lib/maps/RegionSelectComponent.js +1 -2
  102. package/lib/maps/ScopeAndDetailLevelComponent.js +3 -3
  103. package/lib/maps/TileUrlLayer.d.ts +1 -1
  104. package/lib/maps/TileUrlLayer.js +3 -3
  105. package/lib/maps/VectorMapViewComponent.js +6 -7
  106. package/lib/maps/ZoomLevelsComponent.js +5 -5
  107. package/lib/maps/mapSymbols.d.ts +1 -1
  108. package/lib/maps/mapSymbols.js +51 -50
  109. package/lib/maps/mapboxUtils.js +2 -3
  110. package/lib/maps/maps.d.ts +0 -1
  111. package/lib/maps/vectorMaps.js +14 -15
  112. package/lib/memoizedDebounce.js +1 -2
  113. package/lib/quickfilter/DateExprComponent.d.ts +4 -0
  114. package/lib/quickfilter/DateExprComponent.js +17 -16
  115. package/lib/quickfilter/IdArrayQuickfilterComponent.js +1 -1
  116. package/lib/quickfilter/QuickfilterUtils.js +1 -2
  117. package/lib/quickfilter/QuickfiltersComponent.d.ts +23 -2
  118. package/lib/quickfilter/QuickfiltersComponent.js +2 -2
  119. package/lib/quickfilter/QuickfiltersDesignComponent.js +8 -8
  120. package/lib/quickfilter/TextLiteralComponent.d.ts +35 -2
  121. package/lib/quickfilter/TextLiteralComponent.js +6 -6
  122. package/lib/richtext/DropdownPaletteItem.js +1 -1
  123. package/lib/richtext/ExprItemsHtmlConverter.js +8 -10
  124. package/lib/richtext/FontColorPaletteItem.js +7 -7
  125. package/lib/richtext/ItemsHtmlConverter.js +0 -1
  126. package/lib/richtext/RichTextComponent.d.ts +1 -0
  127. package/lib/richtext/RichTextComponent.js +33 -29
  128. package/lib/valueFormatter.js +18 -19
  129. package/lib/wellknown.js +2 -3
  130. package/lib/widgets/IFrameWidgetComponent.d.ts +9 -1
  131. package/lib/widgets/IFrameWidgetComponent.js +3 -3
  132. package/lib/widgets/ImageUploaderComponent.js +5 -5
  133. package/lib/widgets/ImageWidget.js +2 -2
  134. package/lib/widgets/ImageWidgetComponent.d.ts +9 -1
  135. package/lib/widgets/ImageWidgetComponent.js +20 -20
  136. package/lib/widgets/ImagelistCarouselComponent.js +1 -1
  137. package/lib/widgets/MapWidget.js +2 -2
  138. package/lib/widgets/MarkdownWidget.d.ts +1 -1
  139. package/lib/widgets/MarkdownWidget.js +1 -1
  140. package/lib/widgets/TOCWidget.js +11 -12
  141. package/lib/widgets/WidgetScopesViewComponent.js +1 -1
  142. package/lib/widgets/charts/Chart.js +1 -1
  143. package/lib/widgets/charts/ChartViewComponent.js +9 -9
  144. package/lib/widgets/charts/ChartWidgetComponent.js +4 -4
  145. package/lib/widgets/charts/calendar/CalendarChart.js +4 -4
  146. package/lib/widgets/charts/calendar/CalendarChartDesignerComponent.js +7 -7
  147. package/lib/widgets/charts/calendar/CalendarChartViewComponent.js +3 -3
  148. package/lib/widgets/charts/imagemosaic/ImageMosaicChart.d.ts +18 -5
  149. package/lib/widgets/charts/imagemosaic/ImageMosaicChart.js +3 -4
  150. package/lib/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.js +5 -5
  151. package/lib/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.d.ts +5 -19
  152. package/lib/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.js +66 -70
  153. package/lib/widgets/charts/imagemosaic/ImagePopupComponent.js +1 -1
  154. package/lib/widgets/charts/layered/LayeredChart.d.ts +1 -1
  155. package/lib/widgets/charts/layered/LayeredChart.js +9 -9
  156. package/lib/widgets/charts/layered/LayeredChartCompiler.d.ts +8 -8
  157. package/lib/widgets/charts/layered/LayeredChartCompiler.js +17 -17
  158. package/lib/widgets/charts/layered/LayeredChartDesignerComponent.js +33 -33
  159. package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.js +16 -16
  160. package/lib/widgets/charts/layered/LayeredChartUtils.js +1 -2
  161. package/lib/widgets/charts/layered/LayeredChartViewComponent.js +4 -4
  162. package/lib/widgets/charts/pivot/IntersectionDesignerComponent.js +18 -17
  163. package/lib/widgets/charts/pivot/PivotChart.d.ts +1 -1
  164. package/lib/widgets/charts/pivot/PivotChart.js +12 -4
  165. package/lib/widgets/charts/pivot/PivotChartDesignerComponent.d.ts +6 -5
  166. package/lib/widgets/charts/pivot/PivotChartDesignerComponent.js +10 -10
  167. package/lib/widgets/charts/pivot/PivotChartLayoutComponent.js +5 -5
  168. package/lib/widgets/charts/pivot/PivotChartQueryBuilder.d.ts +1 -1
  169. package/lib/widgets/charts/pivot/PivotChartQueryBuilder.js +5 -6
  170. package/lib/widgets/charts/pivot/PivotChartUtils.js +11 -12
  171. package/lib/widgets/charts/pivot/PivotChartViewComponent.js +9 -9
  172. package/lib/widgets/charts/pivot/SegmentDesignerComponent.d.ts +36 -30
  173. package/lib/widgets/charts/pivot/SegmentDesignerComponent.js +28 -26
  174. package/lib/widgets/charts/table/OrderingsComponent.js +2 -2
  175. package/lib/widgets/charts/table/TableChart.js +3 -3
  176. package/lib/widgets/charts/table/TableChartDesignerComponent.js +17 -17
  177. package/lib/widgets/charts/table/TableChartViewComponent.js +3 -3
  178. package/lib/widgets/text/ExprInsertModalComponent.d.ts +2 -3
  179. package/lib/widgets/text/ExprInsertModalComponent.js +2 -14
  180. package/lib/widgets/text/ExprItemEditorComponent.js +4 -4
  181. package/lib/widgets/text/ExprUpdateModalComponent.d.ts +2 -3
  182. package/lib/widgets/text/ExprUpdateModalComponent.js +3 -15
  183. package/lib/widgets/text/TextComponent.js +3 -3
  184. package/lib/widgets/text/TextWidget.d.ts +1 -1
  185. package/lib/widgets/text/TextWidgetComponent.js +11 -11
  186. package/lib/widgets/text/TextWidgetDesign.d.ts +2 -1
  187. package/lib/widgets/text/TextWidgetDesign.js +1 -2
  188. package/package.json +3 -3
  189. package/src/ColorComponent.tsx +2 -2
  190. package/src/DateRangeComponent.ts +10 -10
  191. package/src/LocaleContextInjector.tsx +1 -1
  192. package/src/MWaterAddRelatedFormComponent.ts +7 -7
  193. package/src/MWaterAddRelatedIndicatorComponent.ts +5 -5
  194. package/src/MWaterAssetSystemsListComponent.tsx +3 -3
  195. package/src/MWaterCompleteTableSelectComponent.tsx +36 -35
  196. package/src/MWaterCustomTablesetListComponent.tsx +4 -4
  197. package/src/MWaterGlobalFiltersComponent.ts +4 -4
  198. package/src/MWaterLoaderComponent.ts +1 -1
  199. package/src/MWaterMetricsTableListComponent.tsx +3 -3
  200. package/src/MWaterResponsesFilterComponent.ts +6 -6
  201. package/src/MWaterTableSelectComponent.tsx +6 -7
  202. package/src/axes/AxisBuilder.ts +42 -44
  203. package/src/axes/AxisColorEditorComponent.tsx +178 -0
  204. package/src/axes/AxisComponent.ts +20 -20
  205. package/src/axes/BinsComponent.tsx +6 -6
  206. package/src/axes/CategoryMapComponent.ts +10 -10
  207. package/src/axes/ColorPaletteCollectionComponent.tsx +3 -3
  208. package/src/axes/RangesComponent.ts +14 -14
  209. package/src/dashboards/DashboardComponent.tsx +21 -9
  210. package/src/dashboards/DashboardViewComponent.tsx +3 -3
  211. package/src/dashboards/FontStyleEditor.tsx +8 -8
  212. package/src/dashboards/LayoutOptionsComponent.tsx +74 -74
  213. package/src/dashboards/SettingsModalComponent.tsx +134 -107
  214. package/src/dashboards/layoutOptions.tsx +5 -1
  215. package/src/datagrids/DatagridComponent.ts +65 -62
  216. package/src/datagrids/DatagridDesignerComponent.tsx +17 -17
  217. package/src/datagrids/DatagridUtils.ts +2 -2
  218. package/src/datagrids/DatagridViewComponent.ts +3 -3
  219. package/src/datagrids/ExprCellComponent.ts +1 -1
  220. package/src/datagrids/FindReplaceModalComponent.ts +13 -13
  221. package/src/datagrids/OrderBysDesignerComponent.tsx +2 -2
  222. package/src/globals.d.ts +7 -1
  223. package/src/languages.ts +2 -2
  224. package/src/layouts/blocks/BlocksDisplayComponent.tsx +13 -13
  225. package/src/layouts/blocks/BlocksLayoutManager.ts +3 -2
  226. package/src/layouts/blocks/ClipboardPaletteItemComponent.ts +3 -3
  227. package/src/maps/AddLayerComponent.ts +13 -13
  228. package/src/maps/AdminScopeAndDetailLevelComponent.ts +5 -5
  229. package/src/maps/BaseLayerDesignerComponent.ts +8 -8
  230. package/src/maps/BufferLayer.ts +5 -5
  231. package/src/maps/BufferLayerDesignerComponent.ts +8 -8
  232. package/src/maps/ChoroplethLayer.ts +3 -3
  233. package/src/maps/ChoroplethLayerDesigner.tsx +16 -16
  234. package/src/maps/ClusterLayer.ts +3 -3
  235. package/src/maps/ClusterLayerDesignerComponent.ts +5 -5
  236. package/src/maps/DetailLevelSelectComponent.ts +3 -3
  237. package/src/maps/EditHoverOver.tsx +5 -5
  238. package/src/maps/EditPopupComponent.ts +2 -2
  239. package/src/maps/GridLayer.ts +5 -5
  240. package/src/maps/GridLayerDesigner.tsx +15 -16
  241. package/src/maps/MWaterServerLayer.ts +1 -1
  242. package/src/maps/MapComponent.ts +6 -6
  243. package/src/maps/MapControlComponent.ts +1 -1
  244. package/src/maps/MapDesignerComponent.tsx +20 -20
  245. package/src/maps/MapFiltersDesignerComponent.tsx +3 -3
  246. package/src/maps/MapLayerViewDesignerComponent.ts +9 -9
  247. package/src/maps/MarkerSymbolSelectComponent.ts +4 -5
  248. package/src/maps/MarkersLayerDesignerComponent.ts +22 -22
  249. package/src/maps/PopupFilterJoinsEditComponent.ts +4 -4
  250. package/src/maps/RasterMapViewComponent.ts +2 -2
  251. package/src/maps/RegionSelectComponent.ts +1 -2
  252. package/src/maps/ScopeAndDetailLevelComponent.ts +3 -3
  253. package/src/maps/TileUrlLayer.tsx +3 -3
  254. package/src/maps/VectorMapViewComponent.tsx +5 -5
  255. package/src/maps/ZoomLevelsComponent.ts +6 -6
  256. package/src/maps/mapSymbols.ts +49 -49
  257. package/src/maps/vectorMaps.tsx +2 -2
  258. package/src/quickfilter/DateExprComponent.ts +19 -18
  259. package/src/quickfilter/IdArrayQuickfilterComponent.ts +1 -1
  260. package/src/quickfilter/QuickfiltersComponent.ts +1 -1
  261. package/src/quickfilter/QuickfiltersDesignComponent.tsx +9 -9
  262. package/src/quickfilter/TextLiteralComponent.ts +4 -4
  263. package/src/richtext/DropdownPaletteItem.tsx +1 -1
  264. package/src/richtext/ExprItemsHtmlConverter.ts +8 -10
  265. package/src/richtext/ItemsHtmlConverter.ts +0 -1
  266. package/src/richtext/RichTextComponent.tsx +31 -31
  267. package/src/valueFormatter.ts +14 -14
  268. package/src/widgets/IFrameWidgetComponent.ts +3 -3
  269. package/src/widgets/ImageUploaderComponent.tsx +5 -5
  270. package/src/widgets/ImageWidget.ts +2 -2
  271. package/src/widgets/ImageWidgetComponent.ts +26 -26
  272. package/src/widgets/ImagelistCarouselComponent.ts +2 -2
  273. package/src/widgets/MapWidget.ts +1 -1
  274. package/src/widgets/MarkdownWidget.ts +1 -1
  275. package/src/widgets/TOCWidget.ts +13 -14
  276. package/src/widgets/WidgetScopesViewComponent.ts +1 -1
  277. package/src/widgets/charts/Chart.ts +1 -1
  278. package/src/widgets/charts/ChartViewComponent.ts +4 -4
  279. package/src/widgets/charts/ChartWidgetComponent.tsx +3 -3
  280. package/src/widgets/charts/calendar/CalendarChart.ts +4 -4
  281. package/src/widgets/charts/calendar/CalendarChartDesignerComponent.ts +7 -7
  282. package/src/widgets/charts/calendar/CalendarChartViewComponent.tsx +2 -2
  283. package/src/widgets/charts/imagemosaic/ImageMosaicChart.ts +25 -8
  284. package/src/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.ts +5 -5
  285. package/src/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.tsx +128 -0
  286. package/src/widgets/charts/layered/LayeredChart.ts +9 -9
  287. package/src/widgets/charts/layered/LayeredChartCompiler.ts +47 -47
  288. package/src/widgets/charts/layered/LayeredChartDesignerComponent.tsx +39 -39
  289. package/src/widgets/charts/layered/LayeredChartLayerDesignerComponent.tsx +18 -19
  290. package/src/widgets/charts/layered/LayeredChartViewComponent.ts +1 -1
  291. package/src/widgets/charts/pivot/IntersectionDesignerComponent.tsx +22 -23
  292. package/src/widgets/charts/pivot/PivotChart.ts +15 -5
  293. package/src/widgets/charts/pivot/PivotChartDesignerComponent.tsx +12 -12
  294. package/src/widgets/charts/pivot/PivotChartLayoutComponent.tsx +5 -5
  295. package/src/widgets/charts/pivot/PivotChartQueryBuilder.ts +7 -8
  296. package/src/widgets/charts/pivot/PivotChartViewComponent.tsx +6 -6
  297. package/src/widgets/charts/pivot/SegmentDesignerComponent.tsx +30 -30
  298. package/src/widgets/charts/table/OrderingsComponent.tsx +2 -2
  299. package/src/widgets/charts/table/TableChart.ts +3 -3
  300. package/src/widgets/charts/table/TableChartDesignerComponent.ts +16 -16
  301. package/src/widgets/charts/table/TableChartViewComponent.ts +2 -2
  302. package/src/widgets/text/{ExprInsertModalComponent.ts → ExprInsertModalComponent.tsx} +18 -20
  303. package/src/widgets/text/ExprItemEditorComponent.tsx +4 -4
  304. package/src/widgets/text/{ExprUpdateModalComponent.ts → ExprUpdateModalComponent.tsx} +18 -20
  305. package/src/widgets/text/TextComponent.tsx +2 -2
  306. package/src/widgets/text/TextWidgetComponent.tsx +10 -10
  307. package/src/widgets/text/TextWidgetDesign.ts +3 -1
  308. package/src/axes/AxisColorEditorComponent.ts +0 -210
  309. package/src/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.ts +0 -117
@@ -71,7 +71,7 @@ export default class MapLayerViewDesignerComponent extends React.Component<
71
71
 
72
72
  handleRename = () => {
73
73
  if (this.props.allowEditingLayer) {
74
- const name = prompt("Enter new name", this.props.layerView.name)
74
+ const name = prompt(T`Enter new name`, this.props.layerView.name)
75
75
  if (name) {
76
76
  return this.update({ name })
77
77
  }
@@ -104,15 +104,15 @@ export default class MapLayerViewDesignerComponent extends React.Component<
104
104
  R(
105
105
  ui.Checkbox,
106
106
  { value: this.props.layerView.hideLegend, onChange: this.handleHideLegend, inline: true },
107
- "Hide Legend"
107
+ T`Hide Legend`
108
108
  ),
109
- R("label", { className: "text-muted", key: "label" }, "Group:"),
109
+ R("label", { className: "text-muted", key: "label" }, T`Group:`),
110
110
  R(ui.TextInput, {
111
111
  key: "input",
112
112
  value: this.props.layerView.group,
113
113
  onChange: this.handleGroupChange,
114
114
  style: { width: "5em" },
115
- placeholder: "None"
115
+ placeholder: T`None`
116
116
  }),
117
117
  R(
118
118
  "div",
@@ -120,7 +120,7 @@ export default class MapLayerViewDesignerComponent extends React.Component<
120
120
  R(
121
121
  PopoverHelpComponent,
122
122
  { placement: "top", key: "help" },
123
- "Layers in the same group can only be selected one at a time"
123
+ T`Layers in the same group can only be selected one at a time`
124
124
  )
125
125
  )
126
126
  )
@@ -161,8 +161,8 @@ export default class MapLayerViewDesignerComponent extends React.Component<
161
161
  "a",
162
162
  { className: "link-plain", onClick: this.handleToggleEditing, style: { fontSize: 12 } },
163
163
  this.state.editing
164
- ? [R("i", { className: "fa fa-caret-up" }), " Close"]
165
- : [R("i", { className: "fa fa-cog" }), " Customize..."]
164
+ ? [R("i", { className: "fa fa-caret-up" }), T` Close`]
165
+ : [R("i", { className: "fa fa-cog" }), T` Customize...`]
166
166
  )
167
167
  )
168
168
  }
@@ -172,7 +172,7 @@ export default class MapLayerViewDesignerComponent extends React.Component<
172
172
  }
173
173
 
174
174
  handleRemove = () => {
175
- if (confirm("Delete layer?")) {
175
+ if (confirm(T`Delete layer?`)) {
176
176
  return this.props.onRemove()
177
177
  }
178
178
  }
@@ -184,7 +184,7 @@ export default class MapLayerViewDesignerComponent extends React.Component<
184
184
  R(
185
185
  "label",
186
186
  { className: "text-muted" },
187
- R("span", null, `Opacity: ${Math.round(this.props.layerView.opacity * 100)}%`)
187
+ R("span", null, T`Opacity: ${Math.round(this.props.layerView.opacity * 100)}%`)
188
188
  ),
189
189
  R(
190
190
  "div",
@@ -1,9 +1,8 @@
1
- import PropTypes from "prop-types"
2
1
  import _ from "lodash"
3
2
  import React from "react"
4
3
  const R = React.createElement
5
4
  import { default as ReactSelect } from "react-select"
6
- import { mapSymbols } from "./mapSymbols"
5
+ import { getMapSymbols } from "./mapSymbols"
7
6
 
8
7
  export interface MarkerSymbolSelectComponentProps {
9
8
  symbol?: string
@@ -14,7 +13,7 @@ export interface MarkerSymbolSelectComponentProps {
14
13
  export default class MarkerSymbolSelectComponent extends React.Component<MarkerSymbolSelectComponentProps> {
15
14
  render() {
16
15
  // Create options
17
- const options = mapSymbols
16
+ const options = getMapSymbols()
18
17
 
19
18
  const optionRenderer = (option: any) =>
20
19
  R(
@@ -27,9 +26,9 @@ export default class MarkerSymbolSelectComponent extends React.Component<MarkerS
27
26
  return R(
28
27
  "div",
29
28
  { className: "mb-3" },
30
- R("label", { className: "text-muted" }, R("span", { className: "fa fa-star" }), " ", "Symbol"),
29
+ R("label", { className: "text-muted" }, R("span", { className: "fa fa-star" }), " ", T`Symbol`),
31
30
  R(ReactSelect, {
32
- placeholder: "Circle",
31
+ placeholder: T`Circle`,
33
32
  value: _.findWhere(options, { value: this.props.symbol }) || null,
34
33
  options,
35
34
  formatOptionLabel: optionRenderer,
@@ -78,7 +78,7 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
78
78
  return R(
79
79
  "div",
80
80
  { className: "mb-3" },
81
- R("label", { className: "text-muted" }, R("i", { className: "fa fa-database" }), " ", "Data Source"),
81
+ R("label", { className: "text-muted" }, R("i", { className: "fa fa-database" }), " ", T`Data Source`),
82
82
  R(
83
83
  "div",
84
84
  { style: { marginLeft: 10 } },
@@ -98,7 +98,7 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
98
98
  return
99
99
  }
100
100
 
101
- const title = R("span", null, R("span", { className: "fas fa-map-marker-alt" }), " Location")
101
+ const title = R("span", null, R("span", { className: "fas fa-map-marker-alt" }), " ", T`Location`)
102
102
 
103
103
  const filters = _.clone(this.props.filters) || []
104
104
 
@@ -153,7 +153,7 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
153
153
  ? R(
154
154
  "div",
155
155
  { className: "mb-3" },
156
- R("label", { className: "text-muted" }, R("span", { className: "fas fa-tint" }), "Color"),
156
+ R("label", { className: "text-muted" }, R("span", { className: "fas fa-tint" }), T`Color`),
157
157
 
158
158
  R(
159
159
  "div",
@@ -169,7 +169,7 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
169
169
  R(
170
170
  "div",
171
171
  { className: "mb-3" },
172
- R("label", { className: "text-muted" }, R("span", { className: "fas fa-tint" }), "Color By Data"),
172
+ R("label", { className: "text-muted" }, R("span", { className: "fas fa-tint" }), T`Color By Data`),
173
173
 
174
174
  R(AxisComponent, {
175
175
  schema: this.props.schema,
@@ -204,15 +204,15 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
204
204
  return R(
205
205
  "div",
206
206
  { className: "mb-3" },
207
- R("label", { className: "text-muted" }, "Marker Size"),
207
+ R("label", { className: "text-muted" }, T`Marker Size`),
208
208
  R(ui.Select, {
209
209
  value: this.props.design.markerSize || 10,
210
210
  options: [
211
- { value: 5, label: "Extra small" },
212
- { value: 8, label: "Small" },
213
- { value: 10, label: "Normal" },
214
- { value: 13, label: "Large" },
215
- { value: 16, label: "Extra large" }
211
+ { value: 5, label: T`Extra small` },
212
+ { value: 8, label: T`Small` },
213
+ { value: 10, label: T`Normal` },
214
+ { value: 13, label: T`Large` },
215
+ { value: 16, label: T`Extra large` }
216
216
  ],
217
217
  onChange: this.handleMarkerSizeChange
218
218
  })
@@ -227,17 +227,17 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
227
227
  return R(
228
228
  "div",
229
229
  { className: "mb-3" },
230
- R("label", { className: "text-muted" }, "Line Width (for shapes)"),
230
+ R("label", { className: "text-muted" }, T`Line Width (for shapes)`),
231
231
  R(ui.Select, {
232
232
  value: this.props.design.lineWidth != null ? this.props.design.lineWidth : 3,
233
233
  options: [
234
- { value: 0, label: "None" },
235
- { value: 1, label: "1 pixel" },
236
- { value: 2, label: "2 pixels" },
237
- { value: 3, label: "3 pixels" },
238
- { value: 4, label: "4 pixels" },
239
- { value: 5, label: "5 pixels" },
240
- { value: 6, label: "6 pixels" }
234
+ { value: 0, label: T`None` },
235
+ { value: 1, label: T`1 pixel` },
236
+ { value: 2, label: T`2 pixels` },
237
+ { value: 3, label: T`3 pixels` },
238
+ { value: 4, label: T`4 pixels` },
239
+ { value: 5, label: T`5 pixels` },
240
+ { value: 6, label: T`6 pixels` }
241
241
  ],
242
242
  onChange: this.handleLineWidthChange
243
243
  })
@@ -252,7 +252,7 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
252
252
  return R(
253
253
  "div",
254
254
  { className: "mb-3" },
255
- R("label", { className: "text-muted" }, "Polygon border color (blank for same as fill color)"),
255
+ R("label", { className: "text-muted" }, T`Polygon border color (blank for same as fill color)`),
256
256
  R(
257
257
  "div",
258
258
  null,
@@ -274,7 +274,7 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
274
274
  return R(
275
275
  "div",
276
276
  { className: "mb-3"},
277
- R("label", { className: "text-muted" }, R("span", null, `Polygon Fill Opacity: ${Math.round(opacity * 100)}%`)),
277
+ R("label", { className: "text-muted" }, R("span", null, T`Polygon Fill Opacity: ${Math.round(opacity * 100)}%`)),
278
278
  R(
279
279
  "div",
280
280
  { style: { padding: "10px" } },
@@ -299,7 +299,7 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
299
299
  return R(
300
300
  "div",
301
301
  { className: "mb-3" },
302
- R("label", { className: "text-muted" }, R("span", { className: "fas fa-filter" }), " Filters"),
302
+ R("label", { className: "text-muted" }, R("span", { className: "fas fa-filter" }), T`Filters`),
303
303
  R(
304
304
  "div",
305
305
  { style: { marginLeft: 8 } },
@@ -356,7 +356,7 @@ export default class MarkersLayerDesignerComponent extends React.Component<Marke
356
356
  this.renderSymbol(),
357
357
  this.renderMarkerSize(),
358
358
  R(ui.CollapsibleSection, {
359
- label: "Shape Options",
359
+ label: T`Shape Options`,
360
360
  labelMuted: true
361
361
  }, [
362
362
  this.renderLineWidth(),
@@ -56,7 +56,7 @@ export default class PopupFilterJoinsEditComponent extends React.Component<
56
56
  return R(
57
57
  "a",
58
58
  { className: "btn btn-link", onClick: () => this.setState({ expanded: true }) },
59
- "Advanced Popup Options"
59
+ T`Advanced Popup Options`
60
60
  )
61
61
  }
62
62
 
@@ -73,11 +73,11 @@ export default class PopupFilterJoinsEditComponent extends React.Component<
73
73
  return R(
74
74
  "div",
75
75
  null,
76
- R("div", { className: "text-muted" }, "Optional connections for other tables to filtering the popup"),
76
+ R("div", { className: "text-muted" }, T`Optional connections for other tables to filtering the popup`),
77
77
  R(
78
78
  "table",
79
79
  { className: "table table-sm table-bordered" },
80
- R("thead", null, R("tr", null, R("th", null, "Data Source"), R("th", null, "Connection"))),
80
+ R("thead", null, R("tr", null, R("th", null, T`Data Source`), R("th", null, T`Connection`))),
81
81
  R(
82
82
  "tbody",
83
83
  null,
@@ -102,7 +102,7 @@ export default class PopupFilterJoinsEditComponent extends React.Component<
102
102
  types: this.props.table === this.props.idTable ? ["id", "id[]"] : ["id"], // TODO support id[] some day for admin choropleth maps too
103
103
  idTable: this.props.idTable,
104
104
  preferLiteral: false,
105
- placeholder: "None"
105
+ placeholder: T`None`
106
106
  })
107
107
  )
108
108
  )
@@ -12,7 +12,7 @@ import { JsonQLFilter } from "../JsonQLFilter"
12
12
  import { MapDesign } from "./MapDesign"
13
13
  import { MapDataSource } from "./MapDataSource"
14
14
  import { MapScope } from "./MapUtils"
15
- import { LocaleContext } from "@mwater/expressions-ui/lib/contexts"
15
+ import { LocaleContext } from "@mwater/expressions-ui"
16
16
 
17
17
  export interface RasterMapViewComponentProps {
18
18
  schema: Schema
@@ -239,7 +239,7 @@ export default class RasterMapViewComponent extends React.Component<
239
239
  R(
240
240
  "div",
241
241
  { style: { textAlign: "right", marginTop: 10 } },
242
- R("button", { className: "btn btn-secondary", onClick: () => this.setState({ popupContents: null }) }, "Close")
242
+ R("button", { className: "btn btn-secondary", onClick: () => this.setState({ popupContents: null }) }, T`Close`)
243
243
  )
244
244
  )
245
245
  }
@@ -23,7 +23,6 @@ export interface RegionSelectComponentProps {
23
23
  // Allows selecting of a single region
24
24
  export default class RegionSelectComponent extends React.Component<RegionSelectComponentProps> {
25
25
  static defaultProps = {
26
- placeholder: "All Countries",
27
26
  regionsTable: "admin_regions"
28
27
  }
29
28
 
@@ -72,7 +71,7 @@ export default class RegionSelectComponent extends React.Component<RegionSelectC
72
71
  idTable: this.props.regionsTable!,
73
72
  schema: this.props.schema,
74
73
  dataSource: this.props.dataSource,
75
- placeholder: this.props.placeholder,
74
+ placeholder: this.props.placeholder || T`All Countries`,
76
75
  orderBy: [{ expr: { type: "field", tableAlias: "main", column: "level" }, direction: "asc" }],
77
76
  filter
78
77
  })
@@ -56,7 +56,7 @@ export default class ScopeAndDetailLevelComponent extends React.Component<ScopeA
56
56
  R(
57
57
  "div",
58
58
  { className: "mb-3" },
59
- R("label", { className: "text-muted" }, "Region to Map"),
59
+ R("label", { className: "text-muted" }, T`Region to Map`),
60
60
  R(RegionSelectComponent, {
61
61
  region: this.props.scope,
62
62
  onChange: this.handleScopeChange,
@@ -64,13 +64,13 @@ export default class ScopeAndDetailLevelComponent extends React.Component<ScopeA
64
64
  dataSource: this.props.dataSource,
65
65
  regionsTable: this.props.regionsTable,
66
66
  maxLevel: maxLevel - 1,
67
- placeholder: "All Regions"
67
+ placeholder: T`All Regions`
68
68
  })
69
69
  ),
70
70
  R(
71
71
  "div",
72
72
  { className: "mb-3" },
73
- R("label", { className: "text-muted" }, "Detail Level"),
73
+ R("label", { className: "text-muted" }, T`Detail Level`),
74
74
  R(ui.Select, {
75
75
  value: this.props.detailLevel,
76
76
  options: detailLevelOptions,
@@ -99,7 +99,7 @@ export default class TileUrlLayer extends Layer<TileUrlLayerDesign> {
99
99
  // Validates design. Null if ok, message otherwise
100
100
  validateDesign(design: any, schema: Schema) {
101
101
  if (!design.tileUrl) {
102
- return "Missing Url"
102
+ return T`Missing Url`
103
103
  }
104
104
  return null
105
105
  }
@@ -127,12 +127,12 @@ class TileUrlLayerDesignerComponent extends React.Component<TileUrlLayerDesigner
127
127
  }
128
128
 
129
129
  return <div className="mb-3">
130
- <FormGroup label="Url (containing {z}, {x} and {y})" labelMuted>
130
+ <FormGroup label={T`Url (containing {z}, {x} and {y})`} labelMuted>
131
131
  <TextInput
132
132
  value={this.props.design.tileUrl}
133
133
  onChange={this.handleTileUrlChange} />
134
134
  </FormGroup>
135
- <FormGroup label="Optional URL of Legend" labelMuted>
135
+ <FormGroup label={T`Optional URL of Legend`} labelMuted>
136
136
  <TextInput
137
137
  value={this.props.design.legendUrl || ""}
138
138
  onChange={this.handleLegendUrlChange} />
@@ -396,12 +396,12 @@ export function VectorMapViewComponent(props: {
396
396
  useEffect(() => {
397
397
  updateUserStyle()
398
398
  }, [
399
- props.design.layerViews,
400
- props.scope,
399
+ JSON.stringify(props.design.layerViews),
400
+ JSON.stringify(props.scope),
401
401
  layersCreatedAfter,
402
402
  JSON.stringify(props.extraFilters),
403
- props.design.filters,
404
- props.design.globalFilters,
403
+ JSON.stringify(props.design.filters),
404
+ JSON.stringify(props.design.globalFilters),
405
405
  props.refreshTrigger
406
406
  ])
407
407
 
@@ -564,7 +564,7 @@ export function VectorMapViewComponent(props: {
564
564
  <div style={{ height: "80vh" }}>{popupContents}</div>
565
565
  <div style={{ textAlign: "right", marginTop: 10 }}>
566
566
  <button className="btn btn-secondary" onClick={() => setPopupContents(null)}>
567
- Close
567
+ {T`Close`}
568
568
  </button>
569
569
  </div>
570
570
  </ModalPopupComponent>
@@ -31,7 +31,7 @@ export default class ZoomLevelsComponent extends React.Component<ZoomLevelsCompo
31
31
  R(
32
32
  "a",
33
33
  { className: "btn btn-link btn-sm", onClick: () => this.setState({ expanded: true }) },
34
- "Zoom level options..."
34
+ T`Zoom level options...`
35
35
  )
36
36
  )
37
37
  }
@@ -39,16 +39,16 @@ export default class ZoomLevelsComponent extends React.Component<ZoomLevelsCompo
39
39
  return R(
40
40
  "div",
41
41
  { className: "mb-3" },
42
- R("label", { className: "text-muted" }, "Zoom level options"),
42
+ R("label", { className: "text-muted" }, T`Zoom level options`),
43
43
  R(
44
44
  "div",
45
45
  { key: "min" },
46
- R("span", { className: "text-muted" }, "Minimum Zoom Level:"),
46
+ R("span", { className: "text-muted" }, T`Minimum Zoom Level:`),
47
47
  " ",
48
48
  R(NumberInputComponent, {
49
49
  small: true,
50
50
  style: { display: "inline-block" },
51
- placeholder: "None",
51
+ placeholder: T`None`,
52
52
  value: this.props.design.minZoom,
53
53
  onChange: (v: any) => this.props.onDesignChange(_.extend({}, this.props.design, { minZoom: v }))
54
54
  })
@@ -57,12 +57,12 @@ export default class ZoomLevelsComponent extends React.Component<ZoomLevelsCompo
57
57
  R(
58
58
  "div",
59
59
  { key: "max" },
60
- R("span", { className: "text-muted" }, "Maximum Zoom Level: "),
60
+ R("span", { className: "text-muted" }, T`Maximum Zoom Level: `),
61
61
  " ",
62
62
  R(NumberInputComponent, {
63
63
  small: true,
64
64
  style: { display: "inline-block" },
65
- placeholder: "None",
65
+ placeholder: T`None`,
66
66
  value: this.props.design.maxZoom,
67
67
  onChange: (v: any) => this.props.onDesignChange(_.extend({}, this.props.design, { maxZoom: v }))
68
68
  })
@@ -48,117 +48,117 @@ import beer from "./symbols/font-awesome/beer.png"
48
48
  import cloud_rain from "./symbols/font-awesome/cloud-rain.png"
49
49
 
50
50
  /** Symbols used on the map */
51
- export const mapSymbols: { value: string; label: string; url: string }[] = [
51
+ export const getMapSymbols = (): { value: string; label: string; url: string }[] => [
52
52
  {
53
53
  url: dot_circle_o,
54
54
  value: "font-awesome/dot-circle-o",
55
- label: "Dot circle"
55
+ label: T`Dot circle`
56
56
  },
57
- { url: bullseye, value: "font-awesome/bullseye", label: "Bullseye" },
58
- { url: star, value: "font-awesome/star", label: "Star" },
59
- { url: square, value: "font-awesome/square", label: "Square" },
60
- { url: home, value: "font-awesome/home", label: "Home" },
61
- { url: plus, value: "font-awesome/plus", label: "Plus" },
57
+ { url: bullseye, value: "font-awesome/bullseye", label: T`Bullseye` },
58
+ { url: star, value: "font-awesome/star", label: T`Star` },
59
+ { url: square, value: "font-awesome/square", label: T`Square` },
60
+ { url: home, value: "font-awesome/home", label: T`Home` },
61
+ { url: plus, value: "font-awesome/plus", label: T`Plus` },
62
62
  {
63
63
  url: plus_circle,
64
64
  value: "font-awesome/plus-circle",
65
- label: "Plus Circle"
65
+ label: T`Plus Circle`
66
66
  },
67
67
  {
68
68
  url: plus_square,
69
69
  value: "font-awesome/plus-square",
70
- label: "Plus Square"
70
+ label: T`Plus Square`
71
71
  },
72
- { url: asterisk, value: "font-awesome/asterisk", label: "Asterisk" },
73
- { url: mobile, value: "font-awesome/mobile", label: "Mobile" },
74
- { url: check, value: "font-awesome/check", label: "Check" },
72
+ { url: asterisk, value: "font-awesome/asterisk", label: T`Asterisk` },
73
+ { url: mobile, value: "font-awesome/mobile", label: T`Mobile` },
74
+ { url: check, value: "font-awesome/check", label: T`Check` },
75
75
  {
76
76
  url: university,
77
77
  value: "font-awesome/university",
78
- label: "Institution"
78
+ label: T`Institution`
79
79
  },
80
80
  {
81
81
  url: check_circle,
82
82
  value: "font-awesome/check-circle",
83
- label: "Check Circle"
83
+ label: T`Check Circle`
84
84
  },
85
- { url: times, value: "font-awesome/times", label: "Removed" },
86
- { url: ban, value: "font-awesome/ban", label: "Ban" },
85
+ { url: times, value: "font-awesome/times", label: T`Removed` },
86
+ { url: ban, value: "font-awesome/ban", label: T`Ban` },
87
87
  {
88
88
  url: crosshairs,
89
89
  value: "font-awesome/crosshairs",
90
- label: "Crosshairs"
90
+ label: T`Crosshairs`
91
91
  },
92
- { url: flask, value: "font-awesome/flask", label: "Flask" },
93
- { url: flag, value: "font-awesome/flag", label: "Flag" },
92
+ { url: flask, value: "font-awesome/flask", label: T`Flask` },
93
+ { url: flag, value: "font-awesome/flag", label: T`Flag` },
94
94
  {
95
95
  url: info_circle,
96
96
  value: "font-awesome/info-circle",
97
- label: "Info Circle"
97
+ label: T`Info Circle`
98
98
  },
99
99
  {
100
100
  url: exclamation_circle,
101
101
  value: "font-awesome/exclamation-circle",
102
- label: "Exclamation Circle"
102
+ label: T`Exclamation Circle`
103
103
  },
104
104
  {
105
105
  url: exclamation_triangle,
106
106
  value: "font-awesome/exclamation-triangle",
107
- label: "Exclamation Triangle"
107
+ label: T`Exclamation Triangle`
108
108
  },
109
- { url: bell, value: "font-awesome/bell", label: "Bell" },
110
- { url: bolt, value: "font-awesome/bolt", label: "Bolt" },
111
- { url: building, value: "font-awesome/building", label: "Building" },
112
- { url: bus, value: "font-awesome/bus", label: "Bus" },
109
+ { url: bell, value: "font-awesome/bell", label: T`Bell` },
110
+ { url: bolt, value: "font-awesome/bolt", label: T`Bolt` },
111
+ { url: building, value: "font-awesome/building", label: T`Building` },
112
+ { url: bus, value: "font-awesome/bus", label: T`Bus` },
113
113
  {
114
114
  url: certificate,
115
115
  value: "font-awesome/certificate",
116
- label: "Certificate"
116
+ label: T`Certificate`
117
117
  },
118
- { url: comment, value: "font-awesome/comment", label: "Comment" },
119
- { url: male, value: "font-awesome/male", label: "Male" },
120
- { url: female, value: "font-awesome/female", label: "Female" },
121
- { url: user, value: "font-awesome/user", label: "Person" },
122
- { url: users, value: "font-awesome/users", label: "Group" },
118
+ { url: comment, value: "font-awesome/comment", label: T`Comment` },
119
+ { url: male, value: "font-awesome/male", label: T`Male` },
120
+ { url: female, value: "font-awesome/female", label: T`Female` },
121
+ { url: user, value: "font-awesome/user", label: T`Person` },
122
+ { url: users, value: "font-awesome/users", label: T`Group` },
123
123
  {
124
124
  url: wheelchair,
125
125
  value: "font-awesome/wheelchair",
126
- label: "Wheelchair"
126
+ label: T`Wheelchair`
127
127
  },
128
128
  {
129
129
  url: h_square,
130
130
  value: "font-awesome/h-square",
131
- label: "Hospital Symbol"
131
+ label: T`Hospital Symbol`
132
132
  },
133
- { url: thumbs_up, value: "font-awesome/thumbs-up", label: "Thumbs Up" },
133
+ { url: thumbs_up, value: "font-awesome/thumbs-up", label: T`Thumbs Up` },
134
134
  {
135
135
  url: thumbs_down,
136
136
  value: "font-awesome/thumbs-down",
137
- label: "Thumbs Down"
137
+ label: T`Thumbs Down`
138
138
  },
139
- { url: ticket, value: "font-awesome/ticket", label: "Ticket" },
140
- { url: tint, value: "font-awesome/tint", label: "Tint" },
139
+ { url: ticket, value: "font-awesome/ticket", label: T`Ticket` },
140
+ { url: tint, value: "font-awesome/tint", label: T`Tint` },
141
141
  {
142
142
  url: times_circle,
143
143
  value: "font-awesome/times-circle",
144
- label: "Times Circle"
144
+ label: T`Times Circle`
145
145
  },
146
- { url: tree, value: "font-awesome/tree", label: "Tree" },
147
- { url: file, value: "font-awesome/file", label: "File" },
148
- { url: usd, value: "font-awesome/usd", label: "USD" },
149
- { url: caret_up, value: "font-awesome/caret-up", label: "Caret Up" },
146
+ { url: tree, value: "font-awesome/tree", label: T`Tree` },
147
+ { url: file, value: "font-awesome/file", label: T`File` },
148
+ { url: usd, value: "font-awesome/usd", label: T`USD` },
149
+ { url: caret_up, value: "font-awesome/caret-up", label: T`Caret Up` },
150
150
  {
151
151
  url: chevron_circle_up,
152
152
  value: "font-awesome/chevron-circle-up",
153
- label: "Chevron Up"
153
+ label: T`Chevron Up`
154
154
  },
155
155
  {
156
156
  url: chevron_circle_down,
157
157
  value: "font-awesome/chevron-circle-down",
158
- label: "Chevron Down"
158
+ label: T`Chevron Down`
159
159
  },
160
- { url: medkit, value: "font-awesome/medkit", label: "Medkit" },
161
- { url: cloud, value: "font-awesome/cloud", label: "Cloud" },
162
- { url: cloud_rain, value: "font-awesome/cloud-rain", label: "Cloud Rain" },
163
- { url: beer, value: "font-awesome/beer", label: "Cup" }
160
+ { url: medkit, value: "font-awesome/medkit", label: T`Medkit` },
161
+ { url: cloud, value: "font-awesome/cloud", label: T`Cloud` },
162
+ { url: cloud_rain, value: "font-awesome/cloud-rain", label: T`Cloud Rain` },
163
+ { url: beer, value: "font-awesome/beer", label: T`Cup` }
164
164
  ]
@@ -1,7 +1,7 @@
1
1
  import _ from "lodash"
2
2
  import maplibregl, { Map, LayerSpecification, LngLatBoundsLike, MapLayerMouseEvent } from "maplibre-gl"
3
3
  import { useEffect, useMemo, useState } from "react"
4
- import { mapSymbols } from "./mapSymbols"
4
+ import { getMapSymbols } from "./mapSymbols"
5
5
 
6
6
  import "maplibre-gl/dist/maplibre-gl.css"
7
7
  import "./VectorMapViewComponent.css"
@@ -133,7 +133,7 @@ export function useVectorMap(options: {
133
133
  // Dynamically load symbols
134
134
  m.on("styleimagemissing" as any, function (ev: { id: string }) {
135
135
  // Check if known
136
- const mapSymbol = mapSymbols.find((s) => s.value == ev.id)
136
+ const mapSymbol = getMapSymbols().find((s) => s.value == ev.id)
137
137
  if (mapSymbol) {
138
138
  m.loadImage(mapSymbol.url, (err: any, image: any) => {
139
139
  if (image && !m.hasImage(mapSymbol.value)) {