@mwater/visualization 5.3.2 → 5.4.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.
- package/lib/ColorComponent.d.ts +1 -1
- package/lib/ColorComponent.js +2 -2
- package/lib/CustomColorsContext.d.ts +0 -1
- package/lib/DateRangeComponent.js +10 -10
- package/lib/LocaleContextInjector.js +2 -2
- package/lib/MWaterAddRelatedFormComponent.js +8 -8
- package/lib/MWaterAddRelatedIndicatorComponent.d.ts +0 -1
- package/lib/MWaterAddRelatedIndicatorComponent.js +6 -6
- package/lib/MWaterAssetSystemsListComponent.d.ts +3 -3
- package/lib/MWaterAssetSystemsListComponent.js +4 -3
- package/lib/MWaterCompleteTableSelectComponent.d.ts +33 -34
- package/lib/MWaterCompleteTableSelectComponent.js +39 -38
- package/lib/MWaterCustomTablesetListComponent.d.ts +3 -3
- package/lib/MWaterCustomTablesetListComponent.js +5 -4
- package/lib/MWaterGlobalFiltersComponent.js +4 -4
- package/lib/MWaterLoaderComponent.d.ts +5 -5
- package/lib/MWaterLoaderComponent.js +1 -1
- package/lib/MWaterMetricsTableListComponent.d.ts +3 -3
- package/lib/MWaterMetricsTableListComponent.js +4 -3
- package/lib/MWaterResponsesFilterComponent.js +4 -4
- package/lib/MWaterTableSelectComponent.d.ts +1 -1
- package/lib/MWaterTableSelectComponent.js +5 -5
- package/lib/PopoverComponent.d.ts +4 -4
- package/lib/UIComponents.d.ts +5 -2
- package/lib/axes/AxisBuilder.js +42 -43
- package/lib/axes/AxisColorEditorComponent.d.ts +4 -4
- package/lib/axes/AxisColorEditorComponent.js +25 -60
- package/lib/axes/AxisComponent.d.ts +2 -3
- package/lib/axes/AxisComponent.js +20 -20
- package/lib/axes/BinsComponent.js +6 -6
- package/lib/axes/CategoryMapComponent.d.ts +2 -1
- package/lib/axes/CategoryMapComponent.js +7 -5
- package/lib/axes/ColorPaletteCollectionComponent.js +3 -3
- package/lib/axes/RangesComponent.js +12 -12
- package/lib/compressJson.js +1 -1
- package/lib/dashboards/DashboardComponent.d.ts +2 -0
- package/lib/dashboards/DashboardComponent.js +15 -8
- package/lib/dashboards/DashboardUtils.js +2 -3
- package/lib/dashboards/DashboardViewComponent.js +4 -4
- package/lib/dashboards/FontStyleEditor.js +8 -8
- package/lib/dashboards/LayoutOptionsComponent.js +101 -74
- package/lib/dashboards/SettingsModalComponent.d.ts +3 -4
- package/lib/dashboards/SettingsModalComponent.js +54 -40
- package/lib/dashboards/WidgetComponent.d.ts +0 -1
- package/lib/dashboards/WidgetComponent.js +1 -2
- package/lib/dashboards/layoutOptions.js +11 -7
- package/lib/datagrids/DatagridComponent.d.ts +1 -8
- package/lib/datagrids/DatagridComponent.js +14 -13
- package/lib/datagrids/DatagridDesignerComponent.js +18 -18
- package/lib/datagrids/DatagridQueryBuilder.d.ts +4 -4
- package/lib/datagrids/DatagridUtils.js +2 -2
- package/lib/datagrids/DatagridViewComponent.js +4 -4
- package/lib/datagrids/ExprCellComponent.js +1 -1
- package/lib/datagrids/FindReplaceModalComponent.js +17 -17
- package/lib/datagrids/OrderBysDesignerComponent.js +2 -2
- package/lib/languages.js +2 -2
- package/lib/layouts/DecoratedBlockComponent.js +2 -2
- package/lib/layouts/blocks/BlocksDisplayComponent.js +13 -13
- package/lib/layouts/blocks/BlocksLayoutManager.d.ts +2 -1
- package/lib/layouts/blocks/ClipboardPaletteItemComponent.js +3 -3
- package/lib/layouts/blocks/HorizontalBlockComponent.js +3 -3
- package/lib/layouts/blocks/blockUtils.js +4 -5
- package/lib/mWaterLoader.js +1 -1
- package/lib/maps/AddLayerComponent.js +13 -13
- package/lib/maps/AdminScopeAndDetailLevelComponent.js +5 -5
- package/lib/maps/BaseLayerDesignerComponent.js +2 -2
- package/lib/maps/BufferLayer.js +7 -7
- package/lib/maps/BufferLayerDesignerComponent.js +8 -8
- package/lib/maps/ChoroplethLayer.js +6 -6
- package/lib/maps/ChoroplethLayerDesigner.js +16 -16
- package/lib/maps/ClusterLayer.js +3 -3
- package/lib/maps/ClusterLayerDesignerComponent.js +5 -5
- package/lib/maps/DetailLevelSelectComponent.d.ts +11 -1
- package/lib/maps/DetailLevelSelectComponent.js +3 -3
- package/lib/maps/DirectMapDataSource.js +1 -2
- package/lib/maps/EditHoverOver.js +7 -5
- package/lib/maps/EditPopupComponent.js +2 -2
- package/lib/maps/GridLayer.js +5 -5
- package/lib/maps/GridLayerDesigner.js +15 -15
- package/lib/maps/LayerSwitcherComponent.js +1 -2
- package/lib/maps/LeafletMapComponent.d.ts +1 -1
- package/lib/maps/LeafletMapComponent.js +1 -1
- package/lib/maps/LegendComponent.js +1 -1
- package/lib/maps/MWaterServerLayer.d.ts +0 -1
- package/lib/maps/MWaterServerLayer.js +1 -1
- package/lib/maps/MapComponent.js +8 -8
- package/lib/maps/MapControlComponent.js +1 -1
- package/lib/maps/MapDesignerComponent.js +16 -16
- package/lib/maps/MapFiltersDesignerComponent.js +2 -2
- package/lib/maps/MapLayerViewDesignerComponent.js +8 -8
- package/lib/maps/MapUtils.js +6 -7
- package/lib/maps/MapViewComponent.js +1 -2
- package/lib/maps/MarkerSymbolSelectComponent.js +3 -3
- package/lib/maps/MarkersLayer.js +6 -7
- package/lib/maps/MarkersLayerDesignerComponent.js +22 -22
- package/lib/maps/PopupFilterJoinsEditComponent.js +4 -4
- package/lib/maps/PopupFilterJoinsUtils.js +2 -3
- package/lib/maps/RasterMapViewComponent.d.ts +3 -3
- package/lib/maps/RasterMapViewComponent.js +4 -4
- package/lib/maps/RegionSelectComponent.d.ts +1 -3
- package/lib/maps/RegionSelectComponent.js +1 -2
- package/lib/maps/ScopeAndDetailLevelComponent.js +3 -3
- package/lib/maps/TileUrlLayer.d.ts +1 -1
- package/lib/maps/TileUrlLayer.js +3 -3
- package/lib/maps/VectorMapViewComponent.js +6 -7
- package/lib/maps/ZoomLevelsComponent.js +5 -5
- package/lib/maps/mapSymbols.d.ts +1 -1
- package/lib/maps/mapSymbols.js +51 -50
- package/lib/maps/mapboxUtils.js +2 -3
- package/lib/maps/maps.d.ts +0 -1
- package/lib/maps/vectorMaps.js +14 -15
- package/lib/memoizedDebounce.js +1 -2
- package/lib/quickfilter/DateExprComponent.d.ts +4 -0
- package/lib/quickfilter/DateExprComponent.js +17 -16
- package/lib/quickfilter/IdArrayQuickfilterComponent.js +1 -1
- package/lib/quickfilter/QuickfilterUtils.js +1 -2
- package/lib/quickfilter/QuickfiltersComponent.d.ts +23 -2
- package/lib/quickfilter/QuickfiltersComponent.js +2 -2
- package/lib/quickfilter/QuickfiltersDesignComponent.js +8 -8
- package/lib/quickfilter/TextLiteralComponent.d.ts +35 -2
- package/lib/quickfilter/TextLiteralComponent.js +6 -6
- package/lib/richtext/DropdownPaletteItem.js +1 -1
- package/lib/richtext/ExprItemsHtmlConverter.js +8 -10
- package/lib/richtext/FontColorPaletteItem.js +7 -7
- package/lib/richtext/ItemsHtmlConverter.js +0 -1
- package/lib/richtext/RichTextComponent.d.ts +1 -0
- package/lib/richtext/RichTextComponent.js +33 -29
- package/lib/valueFormatter.js +18 -19
- package/lib/wellknown.js +2 -3
- package/lib/widgets/IFrameWidgetComponent.d.ts +9 -1
- package/lib/widgets/IFrameWidgetComponent.js +3 -3
- package/lib/widgets/ImageUploaderComponent.js +5 -5
- package/lib/widgets/ImageWidget.js +2 -2
- package/lib/widgets/ImageWidgetComponent.d.ts +9 -1
- package/lib/widgets/ImageWidgetComponent.js +20 -20
- package/lib/widgets/ImagelistCarouselComponent.js +1 -1
- package/lib/widgets/MapWidget.js +2 -2
- package/lib/widgets/MarkdownWidget.d.ts +1 -1
- package/lib/widgets/MarkdownWidget.js +1 -1
- package/lib/widgets/TOCWidget.js +11 -12
- package/lib/widgets/WidgetScopesViewComponent.js +1 -1
- package/lib/widgets/charts/Chart.js +1 -1
- package/lib/widgets/charts/ChartViewComponent.js +9 -9
- package/lib/widgets/charts/ChartWidgetComponent.js +4 -4
- package/lib/widgets/charts/calendar/CalendarChart.js +4 -4
- package/lib/widgets/charts/calendar/CalendarChartDesignerComponent.js +7 -7
- package/lib/widgets/charts/calendar/CalendarChartViewComponent.js +3 -3
- package/lib/widgets/charts/imagemosaic/ImageMosaicChart.d.ts +18 -5
- package/lib/widgets/charts/imagemosaic/ImageMosaicChart.js +3 -4
- package/lib/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.js +5 -5
- package/lib/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.d.ts +5 -19
- package/lib/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.js +66 -70
- package/lib/widgets/charts/imagemosaic/ImagePopupComponent.js +1 -1
- package/lib/widgets/charts/layered/LayeredChart.d.ts +1 -1
- package/lib/widgets/charts/layered/LayeredChart.js +9 -9
- package/lib/widgets/charts/layered/LayeredChartCompiler.d.ts +8 -8
- package/lib/widgets/charts/layered/LayeredChartCompiler.js +15 -15
- package/lib/widgets/charts/layered/LayeredChartDesignerComponent.js +33 -33
- package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.js +16 -16
- package/lib/widgets/charts/layered/LayeredChartUtils.js +1 -2
- package/lib/widgets/charts/layered/LayeredChartViewComponent.js +4 -4
- package/lib/widgets/charts/pivot/IntersectionDesignerComponent.js +18 -17
- package/lib/widgets/charts/pivot/PivotChart.d.ts +1 -1
- package/lib/widgets/charts/pivot/PivotChart.js +12 -4
- package/lib/widgets/charts/pivot/PivotChartDesignerComponent.d.ts +5 -5
- package/lib/widgets/charts/pivot/PivotChartDesignerComponent.js +10 -10
- package/lib/widgets/charts/pivot/PivotChartLayoutComponent.js +5 -5
- package/lib/widgets/charts/pivot/PivotChartQueryBuilder.d.ts +1 -1
- package/lib/widgets/charts/pivot/PivotChartQueryBuilder.js +5 -6
- package/lib/widgets/charts/pivot/PivotChartUtils.js +11 -12
- package/lib/widgets/charts/pivot/PivotChartViewComponent.js +9 -9
- package/lib/widgets/charts/pivot/SegmentDesignerComponent.d.ts +30 -30
- package/lib/widgets/charts/pivot/SegmentDesignerComponent.js +28 -26
- package/lib/widgets/charts/table/OrderingsComponent.js +2 -2
- package/lib/widgets/charts/table/TableChart.js +3 -3
- package/lib/widgets/charts/table/TableChartDesignerComponent.js +17 -17
- package/lib/widgets/charts/table/TableChartViewComponent.js +3 -3
- package/lib/widgets/text/ExprInsertModalComponent.d.ts +2 -3
- package/lib/widgets/text/ExprInsertModalComponent.js +2 -14
- package/lib/widgets/text/ExprItemEditorComponent.js +4 -4
- package/lib/widgets/text/ExprUpdateModalComponent.d.ts +2 -3
- package/lib/widgets/text/ExprUpdateModalComponent.js +3 -15
- package/lib/widgets/text/TextComponent.js +3 -3
- package/lib/widgets/text/TextWidget.d.ts +1 -1
- package/lib/widgets/text/TextWidgetComponent.js +11 -11
- package/lib/widgets/text/TextWidgetDesign.d.ts +2 -1
- package/lib/widgets/text/TextWidgetDesign.js +1 -2
- package/package.json +3 -3
- package/src/ColorComponent.tsx +2 -2
- package/src/DateRangeComponent.ts +10 -10
- package/src/LocaleContextInjector.tsx +1 -1
- package/src/MWaterAddRelatedFormComponent.ts +7 -7
- package/src/MWaterAddRelatedIndicatorComponent.ts +5 -5
- package/src/MWaterAssetSystemsListComponent.tsx +3 -3
- package/src/MWaterCompleteTableSelectComponent.tsx +36 -35
- package/src/MWaterCustomTablesetListComponent.tsx +4 -4
- package/src/MWaterGlobalFiltersComponent.ts +4 -4
- package/src/MWaterLoaderComponent.ts +1 -1
- package/src/MWaterMetricsTableListComponent.tsx +3 -3
- package/src/MWaterResponsesFilterComponent.ts +6 -6
- package/src/MWaterTableSelectComponent.tsx +6 -7
- package/src/axes/AxisBuilder.ts +42 -44
- package/src/axes/AxisColorEditorComponent.tsx +178 -0
- package/src/axes/AxisComponent.ts +20 -20
- package/src/axes/BinsComponent.tsx +6 -6
- package/src/axes/CategoryMapComponent.ts +10 -10
- package/src/axes/ColorPaletteCollectionComponent.tsx +3 -3
- package/src/axes/RangesComponent.ts +14 -14
- package/src/dashboards/DashboardComponent.tsx +21 -9
- package/src/dashboards/DashboardViewComponent.tsx +3 -3
- package/src/dashboards/FontStyleEditor.tsx +8 -8
- package/src/dashboards/LayoutOptionsComponent.tsx +74 -74
- package/src/dashboards/SettingsModalComponent.tsx +134 -107
- package/src/dashboards/layoutOptions.tsx +5 -1
- package/src/datagrids/DatagridComponent.ts +65 -62
- package/src/datagrids/DatagridDesignerComponent.tsx +17 -17
- package/src/datagrids/DatagridUtils.ts +2 -2
- package/src/datagrids/DatagridViewComponent.ts +3 -3
- package/src/datagrids/ExprCellComponent.ts +1 -1
- package/src/datagrids/FindReplaceModalComponent.ts +13 -13
- package/src/datagrids/OrderBysDesignerComponent.tsx +2 -2
- package/src/globals.d.ts +7 -1
- package/src/languages.ts +2 -2
- package/src/layouts/blocks/BlocksDisplayComponent.tsx +13 -13
- package/src/layouts/blocks/BlocksLayoutManager.ts +3 -2
- package/src/layouts/blocks/ClipboardPaletteItemComponent.ts +3 -3
- package/src/maps/AddLayerComponent.ts +13 -13
- package/src/maps/AdminScopeAndDetailLevelComponent.ts +5 -5
- package/src/maps/BaseLayerDesignerComponent.ts +8 -8
- package/src/maps/BufferLayer.ts +5 -5
- package/src/maps/BufferLayerDesignerComponent.ts +8 -8
- package/src/maps/ChoroplethLayer.ts +3 -3
- package/src/maps/ChoroplethLayerDesigner.tsx +16 -16
- package/src/maps/ClusterLayer.ts +3 -3
- package/src/maps/ClusterLayerDesignerComponent.ts +5 -5
- package/src/maps/DetailLevelSelectComponent.ts +3 -3
- package/src/maps/EditHoverOver.tsx +5 -5
- package/src/maps/EditPopupComponent.ts +2 -2
- package/src/maps/GridLayer.ts +5 -5
- package/src/maps/GridLayerDesigner.tsx +15 -16
- package/src/maps/MWaterServerLayer.ts +1 -1
- package/src/maps/MapComponent.ts +6 -6
- package/src/maps/MapControlComponent.ts +1 -1
- package/src/maps/MapDesignerComponent.tsx +20 -20
- package/src/maps/MapFiltersDesignerComponent.tsx +3 -3
- package/src/maps/MapLayerViewDesignerComponent.ts +9 -9
- package/src/maps/MarkerSymbolSelectComponent.ts +4 -5
- package/src/maps/MarkersLayerDesignerComponent.ts +22 -22
- package/src/maps/PopupFilterJoinsEditComponent.ts +4 -4
- package/src/maps/RasterMapViewComponent.ts +2 -2
- package/src/maps/RegionSelectComponent.ts +1 -2
- package/src/maps/ScopeAndDetailLevelComponent.ts +3 -3
- package/src/maps/TileUrlLayer.tsx +3 -3
- package/src/maps/VectorMapViewComponent.tsx +5 -5
- package/src/maps/ZoomLevelsComponent.ts +6 -6
- package/src/maps/mapSymbols.ts +49 -49
- package/src/maps/vectorMaps.tsx +2 -2
- package/src/quickfilter/DateExprComponent.ts +19 -18
- package/src/quickfilter/IdArrayQuickfilterComponent.ts +1 -1
- package/src/quickfilter/QuickfiltersComponent.ts +1 -1
- package/src/quickfilter/QuickfiltersDesignComponent.tsx +9 -9
- package/src/quickfilter/TextLiteralComponent.ts +4 -4
- package/src/richtext/DropdownPaletteItem.tsx +1 -1
- package/src/richtext/ExprItemsHtmlConverter.ts +8 -10
- package/src/richtext/ItemsHtmlConverter.ts +0 -1
- package/src/richtext/RichTextComponent.tsx +31 -31
- package/src/valueFormatter.ts +14 -14
- package/src/widgets/IFrameWidgetComponent.ts +3 -3
- package/src/widgets/ImageUploaderComponent.tsx +5 -5
- package/src/widgets/ImageWidget.ts +2 -2
- package/src/widgets/ImageWidgetComponent.ts +26 -26
- package/src/widgets/ImagelistCarouselComponent.ts +2 -2
- package/src/widgets/MapWidget.ts +1 -1
- package/src/widgets/MarkdownWidget.ts +1 -1
- package/src/widgets/TOCWidget.ts +13 -14
- package/src/widgets/WidgetScopesViewComponent.ts +1 -1
- package/src/widgets/charts/Chart.ts +1 -1
- package/src/widgets/charts/ChartViewComponent.ts +4 -4
- package/src/widgets/charts/ChartWidgetComponent.tsx +3 -3
- package/src/widgets/charts/calendar/CalendarChart.ts +4 -4
- package/src/widgets/charts/calendar/CalendarChartDesignerComponent.ts +7 -7
- package/src/widgets/charts/calendar/CalendarChartViewComponent.tsx +2 -2
- package/src/widgets/charts/imagemosaic/ImageMosaicChart.ts +25 -8
- package/src/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.ts +5 -5
- package/src/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.tsx +128 -0
- package/src/widgets/charts/layered/LayeredChart.ts +9 -9
- package/src/widgets/charts/layered/LayeredChartCompiler.ts +45 -45
- package/src/widgets/charts/layered/LayeredChartDesignerComponent.tsx +39 -39
- package/src/widgets/charts/layered/LayeredChartLayerDesignerComponent.tsx +18 -19
- package/src/widgets/charts/layered/LayeredChartViewComponent.ts +1 -1
- package/src/widgets/charts/pivot/IntersectionDesignerComponent.tsx +22 -23
- package/src/widgets/charts/pivot/PivotChart.ts +15 -5
- package/src/widgets/charts/pivot/PivotChartDesignerComponent.tsx +12 -12
- package/src/widgets/charts/pivot/PivotChartLayoutComponent.tsx +5 -5
- package/src/widgets/charts/pivot/PivotChartQueryBuilder.ts +7 -8
- package/src/widgets/charts/pivot/PivotChartViewComponent.tsx +6 -6
- package/src/widgets/charts/pivot/SegmentDesignerComponent.tsx +30 -30
- package/src/widgets/charts/table/OrderingsComponent.tsx +2 -2
- package/src/widgets/charts/table/TableChart.ts +3 -3
- package/src/widgets/charts/table/TableChartDesignerComponent.ts +16 -16
- package/src/widgets/charts/table/TableChartViewComponent.ts +2 -2
- package/src/widgets/text/{ExprInsertModalComponent.ts → ExprInsertModalComponent.tsx} +18 -20
- package/src/widgets/text/ExprItemEditorComponent.tsx +4 -4
- package/src/widgets/text/{ExprUpdateModalComponent.ts → ExprUpdateModalComponent.tsx} +18 -20
- package/src/widgets/text/TextComponent.tsx +2 -2
- package/src/widgets/text/TextWidgetComponent.tsx +10 -10
- package/src/widgets/text/TextWidgetDesign.ts +3 -1
- package/src/axes/AxisColorEditorComponent.ts +0 -210
- 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(
|
|
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
|
-
|
|
107
|
+
T`Hide Legend`
|
|
108
108
|
),
|
|
109
|
-
R("label", { className: "text-muted", key: "label" },
|
|
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:
|
|
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
|
-
|
|
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" }),
|
|
165
|
-
: [R("i", { className: "fa fa-cog" }),
|
|
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(
|
|
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 {
|
|
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 =
|
|
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" }), " ",
|
|
29
|
+
R("label", { className: "text-muted" }, R("span", { className: "fa fa-star" }), " ", T`Symbol`),
|
|
31
30
|
R(ReactSelect, {
|
|
32
|
-
placeholder:
|
|
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" }), " ",
|
|
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" }),
|
|
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" }),
|
|
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" },
|
|
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:
|
|
212
|
-
{ value: 8, label:
|
|
213
|
-
{ value: 10, label:
|
|
214
|
-
{ value: 13, label:
|
|
215
|
-
{ value: 16, label:
|
|
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" },
|
|
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:
|
|
235
|
-
{ value: 1, label:
|
|
236
|
-
{ value: 2, label:
|
|
237
|
-
{ value: 3, label:
|
|
238
|
-
{ value: 4, label:
|
|
239
|
-
{ value: 5, label:
|
|
240
|
-
{ value: 6, label:
|
|
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" },
|
|
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" }),
|
|
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:
|
|
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
|
-
|
|
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" },
|
|
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,
|
|
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:
|
|
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
|
|
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 }) },
|
|
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" },
|
|
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:
|
|
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" },
|
|
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
|
|
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=
|
|
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=
|
|
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
|
-
|
|
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" },
|
|
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" },
|
|
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:
|
|
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" },
|
|
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:
|
|
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
|
})
|
package/src/maps/mapSymbols.ts
CHANGED
|
@@ -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
|
|
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:
|
|
55
|
+
label: T`Dot circle`
|
|
56
56
|
},
|
|
57
|
-
{ url: bullseye, value: "font-awesome/bullseye", label:
|
|
58
|
-
{ url: star, value: "font-awesome/star", label:
|
|
59
|
-
{ url: square, value: "font-awesome/square", label:
|
|
60
|
-
{ url: home, value: "font-awesome/home", label:
|
|
61
|
-
{ url: plus, value: "font-awesome/plus", label:
|
|
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:
|
|
65
|
+
label: T`Plus Circle`
|
|
66
66
|
},
|
|
67
67
|
{
|
|
68
68
|
url: plus_square,
|
|
69
69
|
value: "font-awesome/plus-square",
|
|
70
|
-
label:
|
|
70
|
+
label: T`Plus Square`
|
|
71
71
|
},
|
|
72
|
-
{ url: asterisk, value: "font-awesome/asterisk", label:
|
|
73
|
-
{ url: mobile, value: "font-awesome/mobile", label:
|
|
74
|
-
{ url: check, value: "font-awesome/check", label:
|
|
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:
|
|
78
|
+
label: T`Institution`
|
|
79
79
|
},
|
|
80
80
|
{
|
|
81
81
|
url: check_circle,
|
|
82
82
|
value: "font-awesome/check-circle",
|
|
83
|
-
label:
|
|
83
|
+
label: T`Check Circle`
|
|
84
84
|
},
|
|
85
|
-
{ url: times, value: "font-awesome/times", label:
|
|
86
|
-
{ url: ban, value: "font-awesome/ban", label:
|
|
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:
|
|
90
|
+
label: T`Crosshairs`
|
|
91
91
|
},
|
|
92
|
-
{ url: flask, value: "font-awesome/flask", label:
|
|
93
|
-
{ url: flag, value: "font-awesome/flag", label:
|
|
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:
|
|
97
|
+
label: T`Info Circle`
|
|
98
98
|
},
|
|
99
99
|
{
|
|
100
100
|
url: exclamation_circle,
|
|
101
101
|
value: "font-awesome/exclamation-circle",
|
|
102
|
-
label:
|
|
102
|
+
label: T`Exclamation Circle`
|
|
103
103
|
},
|
|
104
104
|
{
|
|
105
105
|
url: exclamation_triangle,
|
|
106
106
|
value: "font-awesome/exclamation-triangle",
|
|
107
|
-
label:
|
|
107
|
+
label: T`Exclamation Triangle`
|
|
108
108
|
},
|
|
109
|
-
{ url: bell, value: "font-awesome/bell", label:
|
|
110
|
-
{ url: bolt, value: "font-awesome/bolt", label:
|
|
111
|
-
{ url: building, value: "font-awesome/building", label:
|
|
112
|
-
{ url: bus, value: "font-awesome/bus", label:
|
|
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:
|
|
116
|
+
label: T`Certificate`
|
|
117
117
|
},
|
|
118
|
-
{ url: comment, value: "font-awesome/comment", label:
|
|
119
|
-
{ url: male, value: "font-awesome/male", label:
|
|
120
|
-
{ url: female, value: "font-awesome/female", label:
|
|
121
|
-
{ url: user, value: "font-awesome/user", label:
|
|
122
|
-
{ url: users, value: "font-awesome/users", label:
|
|
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:
|
|
126
|
+
label: T`Wheelchair`
|
|
127
127
|
},
|
|
128
128
|
{
|
|
129
129
|
url: h_square,
|
|
130
130
|
value: "font-awesome/h-square",
|
|
131
|
-
label:
|
|
131
|
+
label: T`Hospital Symbol`
|
|
132
132
|
},
|
|
133
|
-
{ url: thumbs_up, value: "font-awesome/thumbs-up", label:
|
|
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:
|
|
137
|
+
label: T`Thumbs Down`
|
|
138
138
|
},
|
|
139
|
-
{ url: ticket, value: "font-awesome/ticket", label:
|
|
140
|
-
{ url: tint, value: "font-awesome/tint", label:
|
|
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:
|
|
144
|
+
label: T`Times Circle`
|
|
145
145
|
},
|
|
146
|
-
{ url: tree, value: "font-awesome/tree", label:
|
|
147
|
-
{ url: file, value: "font-awesome/file", label:
|
|
148
|
-
{ url: usd, value: "font-awesome/usd", label:
|
|
149
|
-
{ url: caret_up, value: "font-awesome/caret-up", label:
|
|
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:
|
|
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:
|
|
158
|
+
label: T`Chevron Down`
|
|
159
159
|
},
|
|
160
|
-
{ url: medkit, value: "font-awesome/medkit", label:
|
|
161
|
-
{ url: cloud, value: "font-awesome/cloud", label:
|
|
162
|
-
{ url: cloud_rain, value: "font-awesome/cloud-rain", label:
|
|
163
|
-
{ url: beer, value: "font-awesome/beer", label:
|
|
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
|
]
|
package/src/maps/vectorMaps.tsx
CHANGED
|
@@ -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 {
|
|
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 =
|
|
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)) {
|