@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.
- package/.prettierrc +11 -0
- package/.storybook/config.js +7 -0
- package/.storybook/head.html +4 -0
- package/.storybook/webpack.config.js +15 -0
- package/.vscode/launch.json +40 -0
- package/LICENSE +21 -0
- package/README.md +19 -0
- package/build-demo.ts +54 -0
- package/lib/CheckboxComponent.d.ts +15 -0
- package/lib/CheckboxComponent.js +25 -0
- package/lib/ColorComponent.d.ts +24 -0
- package/lib/ColorComponent.js +77 -0
- package/lib/ColorSchemeFactory.d.ts +8 -0
- package/lib/ColorSchemeFactory.js +164 -0
- package/lib/CsvBuilder.d.ts +5 -0
- package/lib/CsvBuilder.js +63 -0
- package/lib/DateRangeComponent.d.ts +81 -0
- package/lib/DateRangeComponent.js +190 -0
- package/lib/FiltersDesignerComponent.d.ts +25 -0
- package/lib/FiltersDesignerComponent.js +38 -0
- package/lib/ImplicitFilterBuilder.d.ts +8 -0
- package/lib/ImplicitFilterBuilder.js +114 -0
- package/lib/JsonQLFilter.d.ts +7 -0
- package/lib/JsonQLFilter.js +2 -0
- package/lib/LocaleContextInjector.d.ts +14 -0
- package/lib/LocaleContextInjector.js +20 -0
- package/lib/MWaterAddRelatedFormComponent.d.ts +25 -0
- package/lib/MWaterAddRelatedFormComponent.js +155 -0
- package/lib/MWaterAddRelatedIndicatorComponent.d.ts +31 -0
- package/lib/MWaterAddRelatedIndicatorComponent.js +129 -0
- package/lib/MWaterAssetSystemsListComponent.d.ts +17 -0
- package/lib/MWaterAssetSystemsListComponent.js +78 -0
- package/lib/MWaterCompleteTableSelectComponent.d.ts +224 -0
- package/lib/MWaterCompleteTableSelectComponent.js +680 -0
- package/lib/MWaterContextComponent.d.ts +31 -0
- package/lib/MWaterContextComponent.js +111 -0
- package/lib/MWaterCustomTablesetListComponent.d.ts +17 -0
- package/lib/MWaterCustomTablesetListComponent.js +87 -0
- package/lib/MWaterGlobalFiltersComponent.d.ts +16 -0
- package/lib/MWaterGlobalFiltersComponent.js +103 -0
- package/lib/MWaterLoaderComponent.d.ts +42 -0
- package/lib/MWaterLoaderComponent.js +77 -0
- package/lib/MWaterMetricsTableListComponent.d.ts +17 -0
- package/lib/MWaterMetricsTableListComponent.js +79 -0
- package/lib/MWaterResponsesFilterComponent.d.ts +42 -0
- package/lib/MWaterResponsesFilterComponent.js +145 -0
- package/lib/MWaterTableSelectComponent.d.ts +36 -0
- package/lib/MWaterTableSelectComponent.js +206 -0
- package/lib/MenuItemComponent.d.ts +0 -0
- package/lib/MenuItemComponent.js +3 -0
- package/lib/PopoverComponent.d.ts +15 -0
- package/lib/PopoverComponent.js +49 -0
- package/lib/RadioButtonComponent.d.ts +16 -0
- package/lib/RadioButtonComponent.js +25 -0
- package/lib/TableSelectComponent.d.ts +21 -0
- package/lib/TableSelectComponent.js +68 -0
- package/lib/UIComponents.d.ts +85 -0
- package/lib/UIComponents.js +195 -0
- package/lib/UndoStack.d.ts +11 -0
- package/lib/UndoStack.js +51 -0
- package/lib/VerticalLayoutComponent.d.ts +21 -0
- package/lib/VerticalLayoutComponent.js +76 -0
- package/lib/WidgetScope.d.ts +13 -0
- package/lib/WidgetScope.js +2 -0
- package/lib/axes/Axis.d.ts +81 -0
- package/lib/axes/Axis.js +2 -0
- package/lib/axes/AxisBuilder.d.ts +66 -0
- package/lib/axes/AxisBuilder.js +1202 -0
- package/lib/axes/AxisColorEditorComponent.d.ts +39 -0
- package/lib/axes/AxisColorEditorComponent.js +133 -0
- package/lib/axes/AxisComponent.d.ts +65 -0
- package/lib/axes/AxisComponent.js +359 -0
- package/lib/axes/BinsComponent.d.ts +21 -0
- package/lib/axes/BinsComponent.js +96 -0
- package/lib/axes/CategoryMapComponent.d.ts +41 -0
- package/lib/axes/CategoryMapComponent.js +175 -0
- package/lib/axes/ColorPaletteCollectionComponent.d.ts +17 -0
- package/lib/axes/ColorPaletteCollectionComponent.js +130 -0
- package/lib/axes/RangesComponent.d.ts +35 -0
- package/lib/axes/RangesComponent.js +119 -0
- package/lib/componenttest.d.ts +1 -0
- package/lib/componenttest.js +47 -0
- package/lib/compressJson.d.ts +4 -0
- package/lib/compressJson.js +19 -0
- package/lib/dashboards/DashboardComponent.d.ts +115 -0
- package/lib/dashboards/DashboardComponent.js +297 -0
- package/lib/dashboards/DashboardDataSource.d.ts +9 -0
- package/lib/dashboards/DashboardDataSource.js +14 -0
- package/lib/dashboards/DashboardDesign.d.ts +45 -0
- package/lib/dashboards/DashboardDesign.js +2 -0
- package/lib/dashboards/DashboardUpgrader.d.ts +4 -0
- package/lib/dashboards/DashboardUpgrader.js +95 -0
- package/lib/dashboards/DashboardUtils.d.ts +7 -0
- package/lib/dashboards/DashboardUtils.js +69 -0
- package/lib/dashboards/DashboardViewComponent.d.ts +71 -0
- package/lib/dashboards/DashboardViewComponent.js +235 -0
- package/lib/dashboards/DirectDashboardDataSource.d.ts +31 -0
- package/lib/dashboards/DirectDashboardDataSource.js +62 -0
- package/lib/dashboards/LayoutOptionsComponent.d.ts +11 -0
- package/lib/dashboards/LayoutOptionsComponent.js +119 -0
- package/lib/dashboards/README.md +13 -0
- package/lib/dashboards/ServerDashboardDataSource.d.ts +96 -0
- package/lib/dashboards/ServerDashboardDataSource.js +383 -0
- package/lib/dashboards/SettingsModalComponent.d.ts +33 -0
- package/lib/dashboards/SettingsModalComponent.js +122 -0
- package/lib/dashboards/WidgetComponent.d.ts +53 -0
- package/lib/dashboards/WidgetComponent.js +66 -0
- package/lib/dashboards/layoutOptions.d.ts +19 -0
- package/lib/dashboards/layoutOptions.js +19 -0
- package/lib/datagrids/DatagridComponent.d.ts +122 -0
- package/lib/datagrids/DatagridComponent.js +285 -0
- package/lib/datagrids/DatagridDataSource.d.ts +9 -0
- package/lib/datagrids/DatagridDataSource.js +13 -0
- package/lib/datagrids/DatagridDesign.d.ts +75 -0
- package/lib/datagrids/DatagridDesign.js +2 -0
- package/lib/datagrids/DatagridDesignerComponent.d.ts +114 -0
- package/lib/datagrids/DatagridDesignerComponent.js +389 -0
- package/lib/datagrids/DatagridQueryBuilder.d.ts +68 -0
- package/lib/datagrids/DatagridQueryBuilder.js +540 -0
- package/lib/datagrids/DatagridUtils.d.ts +8 -0
- package/lib/datagrids/DatagridUtils.js +91 -0
- package/lib/datagrids/DatagridViewComponent.d.ts +86 -0
- package/lib/datagrids/DatagridViewComponent.js +321 -0
- package/lib/datagrids/DirectDatagridDataSource.d.ts +20 -0
- package/lib/datagrids/DirectDatagridDataSource.js +62 -0
- package/lib/datagrids/EditExprCellComponent.d.ts +77 -0
- package/lib/datagrids/EditExprCellComponent.js +212 -0
- package/lib/datagrids/ExprCellComponent.d.ts +34 -0
- package/lib/datagrids/ExprCellComponent.js +81 -0
- package/lib/datagrids/FindReplaceModalComponent.d.ts +52 -0
- package/lib/datagrids/FindReplaceModalComponent.js +248 -0
- package/lib/datagrids/LabeledExprGenerator.d.ts +40 -0
- package/lib/datagrids/LabeledExprGenerator.js +252 -0
- package/lib/datagrids/OrderBysDesignerComponent.d.ts +22 -0
- package/lib/datagrids/OrderBysDesignerComponent.js +67 -0
- package/lib/datagrids/README.md +3 -0
- package/lib/datagrids/ServerDatagridDataSource.d.ts +40 -0
- package/lib/datagrids/ServerDatagridDataSource.js +79 -0
- package/lib/demo.d.ts +1 -0
- package/lib/demo.js +4006 -0
- package/lib/demoBlocks.d.ts +1 -0
- package/lib/demoBlocks.js +112 -0
- package/lib/index.css +550 -0
- package/lib/index.d.ts +69 -0
- package/lib/index.js +156 -0
- package/lib/injectTableAlias.d.ts +2 -0
- package/lib/injectTableAlias.js +30 -0
- package/lib/languages.d.ts +9 -0
- package/lib/languages.js +926 -0
- package/lib/layout-styles.css +263 -0
- package/lib/layouts/DecoratedBlockComponent.d.ts +44 -0
- package/lib/layouts/DecoratedBlockComponent.js +96 -0
- package/lib/layouts/DragSourceComponent.d.ts +2 -0
- package/lib/layouts/DragSourceComponent.js +26 -0
- package/lib/layouts/LayoutManager.d.ts +50 -0
- package/lib/layouts/LayoutManager.js +41 -0
- package/lib/layouts/blocks/BlocksDisplayComponent.d.ts +75 -0
- package/lib/layouts/blocks/BlocksDisplayComponent.js +336 -0
- package/lib/layouts/blocks/BlocksLayoutManager.d.ts +36 -0
- package/lib/layouts/blocks/BlocksLayoutManager.js +74 -0
- package/lib/layouts/blocks/ClipboardPaletteItemComponent.d.ts +9 -0
- package/lib/layouts/blocks/ClipboardPaletteItemComponent.js +59 -0
- package/lib/layouts/blocks/DraggableBlockComponent.d.ts +2 -0
- package/lib/layouts/blocks/DraggableBlockComponent.js +163 -0
- package/lib/layouts/blocks/HorizontalBlockComponent.d.ts +31 -0
- package/lib/layouts/blocks/HorizontalBlockComponent.js +191 -0
- package/lib/layouts/blocks/PaletteItemComponent.d.ts +14 -0
- package/lib/layouts/blocks/PaletteItemComponent.js +15 -0
- package/lib/layouts/blocks/README.md +11 -0
- package/lib/layouts/blocks/blockUtils.d.ts +22 -0
- package/lib/layouts/blocks/blockUtils.js +155 -0
- package/lib/layouts/decorated-block.css +100 -0
- package/lib/layouts/grid/GridLayoutComponent.d.ts +23 -0
- package/lib/layouts/grid/GridLayoutComponent.js +49 -0
- package/lib/layouts/grid/GridLayoutManager.d.ts +29 -0
- package/lib/layouts/grid/GridLayoutManager.js +141 -0
- package/lib/layouts/grid/LegoLayoutEngine.d.ts +33 -0
- package/lib/layouts/grid/LegoLayoutEngine.js +129 -0
- package/lib/layouts/grid/PaletteItemComponent.d.ts +14 -0
- package/lib/layouts/grid/PaletteItemComponent.js +15 -0
- package/lib/layouts/grid/README.md +14 -0
- package/lib/layouts/grid/WidgetContainerComponent.d.ts +9 -0
- package/lib/layouts/grid/WidgetContainerComponent.js +333 -0
- package/lib/mWaterLoader.d.ts +26 -0
- package/lib/mWaterLoader.js +55 -0
- package/lib/mapdemo.d.ts +0 -0
- package/lib/mapdemo.js +115 -0
- package/lib/maps/AddLayerComponent.d.ts +22 -0
- package/lib/maps/AddLayerComponent.js +85 -0
- package/lib/maps/AdminScopeAndDetailLevelComponent.d.ts +19 -0
- package/lib/maps/AdminScopeAndDetailLevelComponent.js +59 -0
- package/lib/maps/BaseLayerDesignerComponent.d.ts +28 -0
- package/lib/maps/BaseLayerDesignerComponent.js +57 -0
- package/lib/maps/BingLayer.d.ts +1 -0
- package/lib/maps/BingLayer.js +151 -0
- package/lib/maps/BufferLayer.d.ts +51 -0
- package/lib/maps/BufferLayer.js +816 -0
- package/lib/maps/BufferLayerDesign.d.ts +37 -0
- package/lib/maps/BufferLayerDesign.js +2 -0
- package/lib/maps/BufferLayerDesignerComponent.d.ts +49 -0
- package/lib/maps/BufferLayerDesignerComponent.js +217 -0
- package/lib/maps/ChoroplethLayer.d.ts +74 -0
- package/lib/maps/ChoroplethLayer.js +1515 -0
- package/lib/maps/ChoroplethLayerDesign.d.ts +56 -0
- package/lib/maps/ChoroplethLayerDesign.js +2 -0
- package/lib/maps/ChoroplethLayerDesigner.d.ts +53 -0
- package/lib/maps/ChoroplethLayerDesigner.js +382 -0
- package/lib/maps/ClusterLayer.d.ts +38 -0
- package/lib/maps/ClusterLayer.js +746 -0
- package/lib/maps/ClusterLayerDesign.d.ts +22 -0
- package/lib/maps/ClusterLayerDesign.js +2 -0
- package/lib/maps/ClusterLayerDesignerComponent.d.ts +37 -0
- package/lib/maps/ClusterLayerDesignerComponent.js +110 -0
- package/lib/maps/DetailLevelSelectComponent.d.ts +122 -0
- package/lib/maps/DetailLevelSelectComponent.js +91 -0
- package/lib/maps/DirectMapDataSource.d.ts +68 -0
- package/lib/maps/DirectMapDataSource.js +265 -0
- package/lib/maps/EditHoverOver.d.ts +18 -0
- package/lib/maps/EditHoverOver.js +88 -0
- package/lib/maps/EditPopupComponent.d.ts +26 -0
- package/lib/maps/EditPopupComponent.js +75 -0
- package/lib/maps/Grid Functions.sql +167 -0
- package/lib/maps/GridLayer.d.ts +48 -0
- package/lib/maps/GridLayer.js +684 -0
- package/lib/maps/GridLayerDesign.d.ts +35 -0
- package/lib/maps/GridLayerDesign.js +2 -0
- package/lib/maps/GridLayerDesigner.d.ts +38 -0
- package/lib/maps/GridLayerDesigner.js +229 -0
- package/lib/maps/HoverContent.d.ts +13 -0
- package/lib/maps/HoverContent.js +92 -0
- package/lib/maps/HtmlUrlLegend.d.ts +16 -0
- package/lib/maps/HtmlUrlLegend.js +38 -0
- package/lib/maps/Layer.d.ts +164 -0
- package/lib/maps/Layer.js +193 -0
- package/lib/maps/LayerFactory.d.ts +5 -0
- package/lib/maps/LayerFactory.js +47 -0
- package/lib/maps/LayerLegendComponent.d.ts +23 -0
- package/lib/maps/LayerLegendComponent.js +68 -0
- package/lib/maps/LayerSwitcherComponent.d.ts +7 -0
- package/lib/maps/LayerSwitcherComponent.js +97 -0
- package/lib/maps/LeafletLoading.css +24 -0
- package/lib/maps/LeafletLoading.d.ts +42 -0
- package/lib/maps/LeafletLoading.js +318 -0
- package/lib/maps/LeafletMapComponent.d.ts +141 -0
- package/lib/maps/LeafletMapComponent.js +438 -0
- package/lib/maps/LegendComponent.d.ts +14 -0
- package/lib/maps/LegendComponent.js +74 -0
- package/lib/maps/LegendGroup.d.ts +24 -0
- package/lib/maps/LegendGroup.js +86 -0
- package/lib/maps/MWaterServerLayer.d.ts +40 -0
- package/lib/maps/MWaterServerLayer.js +101 -0
- package/lib/maps/MapBoundsCalculator.d.ts +16 -0
- package/lib/maps/MapBoundsCalculator.js +85 -0
- package/lib/maps/MapComponent.d.ts +98 -0
- package/lib/maps/MapComponent.js +186 -0
- package/lib/maps/MapControlComponent.d.ts +17 -0
- package/lib/maps/MapControlComponent.js +25 -0
- package/lib/maps/MapDataSource.d.ts +18 -0
- package/lib/maps/MapDataSource.js +2 -0
- package/lib/maps/MapDesign.d.ts +77 -0
- package/lib/maps/MapDesign.js +2 -0
- package/lib/maps/MapDesignerComponent.d.ts +39 -0
- package/lib/maps/MapDesignerComponent.js +215 -0
- package/lib/maps/MapFiltersDesignerComponent.d.ts +21 -0
- package/lib/maps/MapFiltersDesignerComponent.js +70 -0
- package/lib/maps/MapLayerDataSource.d.ts +22 -0
- package/lib/maps/MapLayerDataSource.js +2 -0
- package/lib/maps/MapLayerViewDesignerComponent.d.ts +87 -0
- package/lib/maps/MapLayerViewDesignerComponent.js +151 -0
- package/lib/maps/MapLayersDesignerComponent.d.ts +32 -0
- package/lib/maps/MapLayersDesignerComponent.js +98 -0
- package/lib/maps/MapUtils.d.ts +21 -0
- package/lib/maps/MapUtils.js +119 -0
- package/lib/maps/MapViewComponent.d.ts +38 -0
- package/lib/maps/MapViewComponent.js +20 -0
- package/lib/maps/Maptiler-logo.png +0 -0
- package/lib/maps/MarkerSymbolSelectComponent.d.ts +10 -0
- package/lib/maps/MarkerSymbolSelectComponent.js +28 -0
- package/lib/maps/MarkersLayer.d.ts +66 -0
- package/lib/maps/MarkersLayer.js +838 -0
- package/lib/maps/MarkersLayerDesign.d.ts +44 -0
- package/lib/maps/MarkersLayerDesign.js +2 -0
- package/lib/maps/MarkersLayerDesignerComponent.d.ts +56 -0
- package/lib/maps/MarkersLayerDesignerComponent.js +269 -0
- package/lib/maps/PopupFilterJoinsEditComponent.d.ts +30 -0
- package/lib/maps/PopupFilterJoinsEditComponent.js +75 -0
- package/lib/maps/PopupFilterJoinsUtils.d.ts +15 -0
- package/lib/maps/PopupFilterJoinsUtils.js +91 -0
- package/lib/maps/RasterMapViewComponent.d.ts +108 -0
- package/lib/maps/RasterMapViewComponent.js +283 -0
- package/lib/maps/RegionSelectComponent.d.ts +55 -0
- package/lib/maps/RegionSelectComponent.js +61 -0
- package/lib/maps/ScopeAndDetailLevelComponent.d.ts +21 -0
- package/lib/maps/ScopeAndDetailLevelComponent.js +76 -0
- package/lib/maps/ServerMapDataSource.d.ts +86 -0
- package/lib/maps/ServerMapDataSource.js +273 -0
- package/lib/maps/SwitchableTileUrlLayer.d.ts +53 -0
- package/lib/maps/SwitchableTileUrlLayer.js +69 -0
- package/lib/maps/SwitchableTileUrlLayerDesigner.d.ts +14 -0
- package/lib/maps/SwitchableTileUrlLayerDesigner.js +26 -0
- package/lib/maps/TileUrlLayer.d.ts +40 -0
- package/lib/maps/TileUrlLayer.js +96 -0
- package/lib/maps/UtfGridLayer.d.ts +1 -0
- package/lib/maps/UtfGridLayer.js +216 -0
- package/lib/maps/VectorMapViewComponent.css +21 -0
- package/lib/maps/VectorMapViewComponent.d.ts +44 -0
- package/lib/maps/VectorMapViewComponent.js +565 -0
- package/lib/maps/ZoomLevelsComponent.d.ts +15 -0
- package/lib/maps/ZoomLevelsComponent.js +37 -0
- package/lib/maps/mapSymbols.d.ts +6 -0
- package/lib/maps/mapSymbols.js +167 -0
- package/lib/maps/mapboxUtils.d.ts +6 -0
- package/lib/maps/mapboxUtils.js +60 -0
- package/lib/maps/maps.d.ts +36 -0
- package/lib/maps/maps.js +2 -0
- package/lib/maps/marker-icon-2x.png +0 -0
- package/lib/maps/marker-icon.png +0 -0
- package/lib/maps/marker-shadow.png +0 -0
- package/lib/maps/symbols/font-awesome/asterisk.png +0 -0
- package/lib/maps/symbols/font-awesome/ban.png +0 -0
- package/lib/maps/symbols/font-awesome/beer.png +0 -0
- package/lib/maps/symbols/font-awesome/bell.png +0 -0
- package/lib/maps/symbols/font-awesome/bolt.png +0 -0
- package/lib/maps/symbols/font-awesome/building.png +0 -0
- package/lib/maps/symbols/font-awesome/bullseye.png +0 -0
- package/lib/maps/symbols/font-awesome/bus.png +0 -0
- package/lib/maps/symbols/font-awesome/caret-up.png +0 -0
- package/lib/maps/symbols/font-awesome/certificate.png +0 -0
- package/lib/maps/symbols/font-awesome/check-circle.png +0 -0
- package/lib/maps/symbols/font-awesome/check.png +0 -0
- package/lib/maps/symbols/font-awesome/chevron-circle-down.png +0 -0
- package/lib/maps/symbols/font-awesome/chevron-circle-up.png +0 -0
- package/lib/maps/symbols/font-awesome/cloud.png +0 -0
- package/lib/maps/symbols/font-awesome/comment.png +0 -0
- package/lib/maps/symbols/font-awesome/crosshairs.png +0 -0
- package/lib/maps/symbols/font-awesome/dot-circle-o.png +0 -0
- package/lib/maps/symbols/font-awesome/exclamation-circle.png +0 -0
- package/lib/maps/symbols/font-awesome/exclamation-triangle.png +0 -0
- package/lib/maps/symbols/font-awesome/female.png +0 -0
- package/lib/maps/symbols/font-awesome/file.png +0 -0
- package/lib/maps/symbols/font-awesome/flag.png +0 -0
- package/lib/maps/symbols/font-awesome/flask.png +0 -0
- package/lib/maps/symbols/font-awesome/h-square.png +0 -0
- package/lib/maps/symbols/font-awesome/home.png +0 -0
- package/lib/maps/symbols/font-awesome/info-circle.png +0 -0
- package/lib/maps/symbols/font-awesome/male.png +0 -0
- package/lib/maps/symbols/font-awesome/medkit.png +0 -0
- package/lib/maps/symbols/font-awesome/mobile.png +0 -0
- package/lib/maps/symbols/font-awesome/plus-circle.png +0 -0
- package/lib/maps/symbols/font-awesome/plus-square.png +0 -0
- package/lib/maps/symbols/font-awesome/plus.png +0 -0
- package/lib/maps/symbols/font-awesome/square.png +0 -0
- package/lib/maps/symbols/font-awesome/star.png +0 -0
- package/lib/maps/symbols/font-awesome/thumbs-down.png +0 -0
- package/lib/maps/symbols/font-awesome/thumbs-up.png +0 -0
- package/lib/maps/symbols/font-awesome/ticket.png +0 -0
- package/lib/maps/symbols/font-awesome/times-circle.png +0 -0
- package/lib/maps/symbols/font-awesome/times.png +0 -0
- package/lib/maps/symbols/font-awesome/tint.png +0 -0
- package/lib/maps/symbols/font-awesome/tree.png +0 -0
- package/lib/maps/symbols/font-awesome/university.png +0 -0
- package/lib/maps/symbols/font-awesome/usd.png +0 -0
- package/lib/maps/symbols/font-awesome/user.png +0 -0
- package/lib/maps/symbols/font-awesome/users.png +0 -0
- package/lib/maps/symbols/font-awesome/wheelchair.png +0 -0
- package/lib/maps/vectorMaps.d.ts +42 -0
- package/lib/maps/vectorMaps.js +331 -0
- package/lib/memoizedDebounce.d.ts +6 -0
- package/lib/memoizedDebounce.js +21 -0
- package/lib/quickfilter/DateExprComponent.d.ts +81 -0
- package/lib/quickfilter/DateExprComponent.js +197 -0
- package/lib/quickfilter/IdArrayQuickfilterComponent.d.ts +24 -0
- package/lib/quickfilter/IdArrayQuickfilterComponent.js +30 -0
- package/lib/quickfilter/Quickfilter.d.ts +21 -0
- package/lib/quickfilter/Quickfilter.js +2 -0
- package/lib/quickfilter/QuickfilterCompiler.d.ts +16 -0
- package/lib/quickfilter/QuickfilterCompiler.js +167 -0
- package/lib/quickfilter/QuickfilterUtils.d.ts +7 -0
- package/lib/quickfilter/QuickfilterUtils.js +106 -0
- package/lib/quickfilter/QuickfiltersComponent.d.ts +293 -0
- package/lib/quickfilter/QuickfiltersComponent.js +257 -0
- package/lib/quickfilter/QuickfiltersDataSource.d.ts +7 -0
- package/lib/quickfilter/QuickfiltersDataSource.js +2 -0
- package/lib/quickfilter/QuickfiltersDesignComponent.d.ts +46 -0
- package/lib/quickfilter/QuickfiltersDesignComponent.js +176 -0
- package/lib/quickfilter/README.md +8 -0
- package/lib/quickfilter/TextLiteralComponent.d.ts +216 -0
- package/lib/quickfilter/TextLiteralComponent.js +128 -0
- package/lib/richtext/ExprItemsHtmlConverter.d.ts +39 -0
- package/lib/richtext/ExprItemsHtmlConverter.js +118 -0
- package/lib/richtext/FontColorPaletteItem.d.ts +23 -0
- package/lib/richtext/FontColorPaletteItem.js +84 -0
- package/lib/richtext/FontSizePaletteItem.d.ts +29 -0
- package/lib/richtext/FontSizePaletteItem.js +70 -0
- package/lib/richtext/ItemsHtmlConverter.d.ts +31 -0
- package/lib/richtext/ItemsHtmlConverter.js +209 -0
- package/lib/richtext/README.md +3 -0
- package/lib/richtext/RichTextComponent.d.ts +84 -0
- package/lib/richtext/RichTextComponent.js +255 -0
- package/lib/valueFormatter.d.ts +16 -0
- package/lib/valueFormatter.js +93 -0
- package/lib/widgets/DirectWidgetDataSource.d.ts +43 -0
- package/lib/widgets/DirectWidgetDataSource.js +39 -0
- package/lib/widgets/DropdownWidgetComponent.d.ts +31 -0
- package/lib/widgets/DropdownWidgetComponent.js +41 -0
- package/lib/widgets/IFrameWidget.d.ts +16 -0
- package/lib/widgets/IFrameWidget.js +38 -0
- package/lib/widgets/IFrameWidgetComponent.d.ts +33 -0
- package/lib/widgets/IFrameWidgetComponent.js +101 -0
- package/lib/widgets/ImageUploaderComponent.d.ts +29 -0
- package/lib/widgets/ImageUploaderComponent.js +91 -0
- package/lib/widgets/ImageWidget.d.ts +49 -0
- package/lib/widgets/ImageWidget.js +112 -0
- package/lib/widgets/ImageWidgetComponent.d.ts +125 -0
- package/lib/widgets/ImageWidgetComponent.js +368 -0
- package/lib/widgets/ImagelistCarouselComponent.d.ts +29 -0
- package/lib/widgets/ImagelistCarouselComponent.js +64 -0
- package/lib/widgets/MapWidget.d.ts +55 -0
- package/lib/widgets/MapWidget.js +167 -0
- package/lib/widgets/MarkdownWidget.d.ts +53 -0
- package/lib/widgets/MarkdownWidget.js +134 -0
- package/lib/widgets/TOCWidget.d.ts +39 -0
- package/lib/widgets/TOCWidget.js +254 -0
- package/lib/widgets/Widget.d.ts +61 -0
- package/lib/widgets/Widget.js +33 -0
- package/lib/widgets/WidgetDataSource.d.ts +20 -0
- package/lib/widgets/WidgetDataSource.js +2 -0
- package/lib/widgets/WidgetFactory.d.ts +4 -0
- package/lib/widgets/WidgetFactory.js +40 -0
- package/lib/widgets/WidgetScoper.d.ts +9 -0
- package/lib/widgets/WidgetScoper.js +49 -0
- package/lib/widgets/WidgetScopesViewComponent.d.ts +26 -0
- package/lib/widgets/WidgetScopesViewComponent.js +36 -0
- package/lib/widgets/charts/Chart.d.ts +57 -0
- package/lib/widgets/charts/Chart.js +83 -0
- package/lib/widgets/charts/ChartViewComponent.d.ts +72 -0
- package/lib/widgets/charts/ChartViewComponent.js +120 -0
- package/lib/widgets/charts/ChartWidget.d.ts +87 -0
- package/lib/widgets/charts/ChartWidget.js +248 -0
- package/lib/widgets/charts/calendar/CalendarChart.d.ts +39 -0
- package/lib/widgets/charts/calendar/CalendarChart.js +175 -0
- package/lib/widgets/charts/calendar/CalendarChartDesignerComponent.d.ts +35 -0
- package/lib/widgets/charts/calendar/CalendarChartDesignerComponent.js +142 -0
- package/lib/widgets/charts/calendar/CalendarChartViewComponent.d.ts +56 -0
- package/lib/widgets/charts/calendar/CalendarChartViewComponent.js +263 -0
- package/lib/widgets/charts/imagemosaic/ImageMosaicChart.d.ts +21 -0
- package/lib/widgets/charts/imagemosaic/ImageMosaicChart.js +183 -0
- package/lib/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.d.ts +28 -0
- package/lib/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.js +105 -0
- package/lib/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.d.ts +31 -0
- package/lib/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.js +87 -0
- package/lib/widgets/charts/imagemosaic/ImagePopupComponent.d.ts +20 -0
- package/lib/widgets/charts/imagemosaic/ImagePopupComponent.js +38 -0
- package/lib/widgets/charts/layered/LayeredChart.d.ts +28 -0
- package/lib/widgets/charts/layered/LayeredChart.js +324 -0
- package/lib/widgets/charts/layered/LayeredChartCompiler.d.ts +113 -0
- package/lib/widgets/charts/layered/LayeredChartCompiler.js +1092 -0
- package/lib/widgets/charts/layered/LayeredChartDesign.d.ts +76 -0
- package/lib/widgets/charts/layered/LayeredChartDesign.js +2 -0
- package/lib/widgets/charts/layered/LayeredChartDesignerComponent.d.ts +80 -0
- package/lib/widgets/charts/layered/LayeredChartDesignerComponent.js +317 -0
- package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.d.ts +72 -0
- package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.js +329 -0
- package/lib/widgets/charts/layered/LayeredChartSvgFileSaver.d.ts +5 -0
- package/lib/widgets/charts/layered/LayeredChartSvgFileSaver.js +138 -0
- package/lib/widgets/charts/layered/LayeredChartUtils.d.ts +1 -0
- package/lib/widgets/charts/layered/LayeredChartUtils.js +25 -0
- package/lib/widgets/charts/layered/LayeredChartViewComponent.d.ts +44 -0
- package/lib/widgets/charts/layered/LayeredChartViewComponent.js +406 -0
- package/lib/widgets/charts/pivot/IntersectionDesignerComponent.d.ts +115 -0
- package/lib/widgets/charts/pivot/IntersectionDesignerComponent.js +235 -0
- package/lib/widgets/charts/pivot/PivotChart.d.ts +36 -0
- package/lib/widgets/charts/pivot/PivotChart.js +343 -0
- package/lib/widgets/charts/pivot/PivotChartDesign.d.ts +88 -0
- package/lib/widgets/charts/pivot/PivotChartDesign.js +2 -0
- package/lib/widgets/charts/pivot/PivotChartDesignerComponent.d.ts +37 -0
- package/lib/widgets/charts/pivot/PivotChartDesignerComponent.js +159 -0
- package/lib/widgets/charts/pivot/PivotChartLayout.d.ts +73 -0
- package/lib/widgets/charts/pivot/PivotChartLayout.js +2 -0
- package/lib/widgets/charts/pivot/PivotChartLayoutBuilder.d.ts +37 -0
- package/lib/widgets/charts/pivot/PivotChartLayoutBuilder.js +676 -0
- package/lib/widgets/charts/pivot/PivotChartLayoutComponent.d.ts +74 -0
- package/lib/widgets/charts/pivot/PivotChartLayoutComponent.js +333 -0
- package/lib/widgets/charts/pivot/PivotChartQueryBuilder.d.ts +31 -0
- package/lib/widgets/charts/pivot/PivotChartQueryBuilder.js +263 -0
- package/lib/widgets/charts/pivot/PivotChartUtils.d.ts +12 -0
- package/lib/widgets/charts/pivot/PivotChartUtils.js +195 -0
- package/lib/widgets/charts/pivot/PivotChartViewComponent.d.ts +84 -0
- package/lib/widgets/charts/pivot/PivotChartViewComponent.js +205 -0
- package/lib/widgets/charts/pivot/README.md +30 -0
- package/lib/widgets/charts/pivot/SegmentDesignerComponent.d.ts +96 -0
- package/lib/widgets/charts/pivot/SegmentDesignerComponent.js +216 -0
- package/lib/widgets/charts/table/OrderingsComponent.d.ts +15 -0
- package/lib/widgets/charts/table/OrderingsComponent.js +66 -0
- package/lib/widgets/charts/table/TableChart.d.ts +57 -0
- package/lib/widgets/charts/table/TableChart.js +310 -0
- package/lib/widgets/charts/table/TableChartDesignerComponent.d.ts +48 -0
- package/lib/widgets/charts/table/TableChartDesignerComponent.js +291 -0
- package/lib/widgets/charts/table/TableChartViewComponent.d.ts +28 -0
- package/lib/widgets/charts/table/TableChartViewComponent.js +206 -0
- package/lib/widgets/text/ExprInsertModalComponent.d.ts +35 -0
- package/lib/widgets/text/ExprInsertModalComponent.js +51 -0
- package/lib/widgets/text/ExprItemEditorComponent.d.ts +34 -0
- package/lib/widgets/text/ExprItemEditorComponent.js +92 -0
- package/lib/widgets/text/ExprUpdateModalComponent.d.ts +33 -0
- package/lib/widgets/text/ExprUpdateModalComponent.js +47 -0
- package/lib/widgets/text/README.md +2 -0
- package/lib/widgets/text/TextComponent.d.ts +48 -0
- package/lib/widgets/text/TextComponent.js +109 -0
- package/lib/widgets/text/TextWidget.d.ts +29 -0
- package/lib/widgets/text/TextWidget.js +243 -0
- package/lib/widgets/text/TextWidgetComponent.d.ts +33 -0
- package/lib/widgets/text/TextWidgetComponent.js +88 -0
- package/lib/widgets/text/TextWidgetDesign.d.ts +6 -0
- package/lib/widgets/text/TextWidgetDesign.js +2 -0
- package/mocha.html +10 -0
- package/package.json +113 -0
- package/server.js +10 -0
- package/src/CheckboxComponent.ts +33 -0
- package/src/ColorComponent.ts +117 -0
- package/src/ColorSchemeFactory.ts +144 -0
- package/src/CsvBuilder.ts +65 -0
- package/src/DateRangeComponent.ts +279 -0
- package/src/FiltersDesignerComponent.ts +55 -0
- package/src/ImplicitFilterBuilder.ts +135 -0
- package/src/JsonQLFilter.ts +8 -0
- package/src/LocaleContextInjector.tsx +17 -0
- package/src/MWaterAddRelatedFormComponent.ts +213 -0
- package/src/MWaterAddRelatedIndicatorComponent.ts +205 -0
- package/src/MWaterAssetSystemsListComponent.tsx +114 -0
- package/src/MWaterCompleteTableSelectComponent.tsx +984 -0
- package/src/MWaterContextComponent.ts +144 -0
- package/src/MWaterCustomTablesetListComponent.tsx +141 -0
- package/src/MWaterGlobalFiltersComponent.ts +117 -0
- package/src/MWaterLoaderComponent.ts +118 -0
- package/src/MWaterMetricsTableListComponent.tsx +120 -0
- package/src/MWaterResponsesFilterComponent.ts +194 -0
- package/src/MWaterTableSelectComponent.ts +316 -0
- package/src/MenuItemComponent.ts +2 -0
- package/src/PopoverComponent.ts +59 -0
- package/src/RadioButtonComponent.ts +34 -0
- package/src/TableSelectComponent.ts +60 -0
- package/src/UIComponents.ts +289 -0
- package/src/UndoStack.ts +59 -0
- package/src/VerticalLayoutComponent.ts +108 -0
- package/src/WidgetScope.ts +17 -0
- package/src/axes/Axis.ts +89 -0
- package/src/axes/AxisBuilder.ts +1325 -0
- package/src/axes/AxisColorEditorComponent.ts +210 -0
- package/src/axes/AxisComponent.ts +449 -0
- package/src/axes/BinsComponent.tsx +169 -0
- package/src/axes/CategoryMapComponent.ts +278 -0
- package/src/axes/ColorPaletteCollectionComponent.ts +163 -0
- package/src/axes/RangesComponent.ts +234 -0
- package/src/color-mixer.d.ts +1 -0
- package/src/componenttest.ts +64 -0
- package/src/compressJson.ts +13 -0
- package/src/dashboards/DashboardComponent.ts +468 -0
- package/src/dashboards/DashboardDataSource.ts +15 -0
- package/src/dashboards/DashboardDesign.ts +57 -0
- package/src/dashboards/DashboardUpgrader.ts +103 -0
- package/src/dashboards/DashboardUtils.ts +82 -0
- package/src/dashboards/DashboardViewComponent.ts +304 -0
- package/src/dashboards/DirectDashboardDataSource.ts +69 -0
- package/src/dashboards/LayoutOptionsComponent.tsx +227 -0
- package/src/dashboards/README.md +13 -0
- package/src/dashboards/ServerDashboardDataSource.ts +520 -0
- package/src/dashboards/SettingsModalComponent.ts +169 -0
- package/src/dashboards/WidgetComponent.tsx +131 -0
- package/src/dashboards/layoutOptions.ts +40 -0
- package/src/datagrids/DatagridComponent.ts +430 -0
- package/src/datagrids/DatagridDataSource.ts +21 -0
- package/src/datagrids/DatagridDesign.ts +94 -0
- package/src/datagrids/DatagridDesignerComponent.tsx +585 -0
- package/src/datagrids/DatagridQueryBuilder.ts +722 -0
- package/src/datagrids/DatagridUtils.ts +74 -0
- package/src/datagrids/DatagridViewComponent.ts +460 -0
- package/src/datagrids/DirectDatagridDataSource.ts +57 -0
- package/src/datagrids/EditExprCellComponent.tsx +305 -0
- package/src/datagrids/ExprCellComponent.ts +104 -0
- package/src/datagrids/FindReplaceModalComponent.ts +354 -0
- package/src/datagrids/LabeledExprGenerator.ts +302 -0
- package/src/datagrids/OrderBysDesignerComponent.tsx +128 -0
- package/src/datagrids/README.md +3 -0
- package/src/datagrids/ServerDatagridDataSource.ts +119 -0
- package/src/datagrids/react-linkify.d.ts +1 -0
- package/src/demo.ts +4148 -0
- package/src/demoBlocks.ts +130 -0
- package/src/globals.d.ts +2 -0
- package/src/index.css +550 -0
- package/src/index.ts +112 -0
- package/src/injectTableAlias.ts +31 -0
- package/src/languages.ts +931 -0
- package/src/layout-styles.css +263 -0
- package/src/layouts/DecoratedBlockComponent.ts +167 -0
- package/src/layouts/DragSourceComponent.ts +35 -0
- package/src/layouts/LayoutManager.ts +86 -0
- package/src/layouts/blocks/BlocksDisplayComponent.ts +461 -0
- package/src/layouts/blocks/BlocksLayoutManager.ts +78 -0
- package/src/layouts/blocks/ClipboardPaletteItemComponent.ts +89 -0
- package/src/layouts/blocks/DraggableBlockComponent.ts +219 -0
- package/src/layouts/blocks/HorizontalBlockComponent.ts +288 -0
- package/src/layouts/blocks/PaletteItemComponent.ts +27 -0
- package/src/layouts/blocks/README.md +11 -0
- package/src/layouts/blocks/blockUtils.ts +207 -0
- package/src/layouts/decorated-block.css +100 -0
- package/src/layouts/grid/GridLayoutComponent.ts +67 -0
- package/src/layouts/grid/GridLayoutManager.ts +185 -0
- package/src/layouts/grid/LegoLayoutEngine.ts +142 -0
- package/src/layouts/grid/PaletteItemComponent.ts +28 -0
- package/src/layouts/grid/README.md +14 -0
- package/src/layouts/grid/WidgetContainerComponent.ts +420 -0
- package/src/mWaterLoader.ts +82 -0
- package/src/mapdemo.ts +127 -0
- package/src/maps/AddLayerComponent.ts +125 -0
- package/src/maps/AdminScopeAndDetailLevelComponent.ts +90 -0
- package/src/maps/BaseLayerDesignerComponent.ts +104 -0
- package/src/maps/BingLayer.ts +156 -0
- package/src/maps/BufferLayer.ts +927 -0
- package/src/maps/BufferLayerDesign.ts +48 -0
- package/src/maps/BufferLayerDesignerComponent.ts +311 -0
- package/src/maps/ChoroplethLayer.ts +1712 -0
- package/src/maps/ChoroplethLayerDesign.ts +73 -0
- package/src/maps/ChoroplethLayerDesigner.tsx +558 -0
- package/src/maps/ClusterLayer.ts +836 -0
- package/src/maps/ClusterLayerDesign.ts +29 -0
- package/src/maps/ClusterLayerDesignerComponent.ts +190 -0
- package/src/maps/DetailLevelSelectComponent.ts +119 -0
- package/src/maps/DirectMapDataSource.ts +386 -0
- package/src/maps/EditHoverOver.tsx +151 -0
- package/src/maps/EditPopupComponent.ts +121 -0
- package/src/maps/Grid Functions.sql +167 -0
- package/src/maps/GridLayer.ts +776 -0
- package/src/maps/GridLayerDesign.ts +53 -0
- package/src/maps/GridLayerDesigner.tsx +332 -0
- package/src/maps/HoverContent.tsx +96 -0
- package/src/maps/HtmlUrlLegend.tsx +44 -0
- package/src/maps/Layer.ts +338 -0
- package/src/maps/LayerFactory.ts +51 -0
- package/src/maps/LayerLegendComponent.ts +88 -0
- package/src/maps/LayerSwitcherComponent.tsx +91 -0
- package/src/maps/LeafletLoading.css +24 -0
- package/src/maps/LeafletLoading.ts +355 -0
- package/src/maps/LeafletMapComponent.tsx +587 -0
- package/src/maps/LegendComponent.tsx +101 -0
- package/src/maps/LegendGroup.ts +120 -0
- package/src/maps/MWaterServerLayer.ts +116 -0
- package/src/maps/MapBoundsCalculator.ts +88 -0
- package/src/maps/MapComponent.ts +312 -0
- package/src/maps/MapControlComponent.ts +46 -0
- package/src/maps/MapDataSource.ts +20 -0
- package/src/maps/MapDesign.ts +103 -0
- package/src/maps/MapDesignerComponent.ts +356 -0
- package/src/maps/MapFiltersDesignerComponent.ts +95 -0
- package/src/maps/MapLayerDataSource.ts +27 -0
- package/src/maps/MapLayerViewDesignerComponent.ts +243 -0
- package/src/maps/MapLayersDesignerComponent.ts +144 -0
- package/src/maps/MapUtils.ts +148 -0
- package/src/maps/MapViewComponent.tsx +62 -0
- package/src/maps/Maptiler-logo.png +0 -0
- package/src/maps/MarkerSymbolSelectComponent.ts +41 -0
- package/src/maps/MarkersLayer.ts +941 -0
- package/src/maps/MarkersLayerDesign.ts +56 -0
- package/src/maps/MarkersLayerDesignerComponent.ts +374 -0
- package/src/maps/PopupFilterJoinsEditComponent.ts +114 -0
- package/src/maps/PopupFilterJoinsUtils.ts +99 -0
- package/src/maps/RasterMapViewComponent.ts +382 -0
- package/src/maps/RegionSelectComponent.ts +80 -0
- package/src/maps/ScopeAndDetailLevelComponent.ts +82 -0
- package/src/maps/ServerMapDataSource.ts +399 -0
- package/src/maps/SwitchableTileUrlLayer.tsx +130 -0
- package/src/maps/SwitchableTileUrlLayerDesigner.tsx +60 -0
- package/src/maps/TileUrlLayer.tsx +142 -0
- package/src/maps/UtfGridLayer.ts +286 -0
- package/src/maps/VectorMapViewComponent.css +21 -0
- package/src/maps/VectorMapViewComponent.tsx +743 -0
- package/src/maps/ZoomLevelsComponent.ts +72 -0
- package/src/maps/mapSymbols.ts +162 -0
- package/src/maps/mapboxUtils.ts +61 -0
- package/src/maps/maps.ts +38 -0
- package/src/maps/marker-icon-2x.png +0 -0
- package/src/maps/marker-icon.png +0 -0
- package/src/maps/marker-shadow.png +0 -0
- package/src/maps/png.d.ts +1 -0
- package/src/maps/symbols/font-awesome/asterisk.png +0 -0
- package/src/maps/symbols/font-awesome/ban.png +0 -0
- package/src/maps/symbols/font-awesome/beer.png +0 -0
- package/src/maps/symbols/font-awesome/bell.png +0 -0
- package/src/maps/symbols/font-awesome/bolt.png +0 -0
- package/src/maps/symbols/font-awesome/building.png +0 -0
- package/src/maps/symbols/font-awesome/bullseye.png +0 -0
- package/src/maps/symbols/font-awesome/bus.png +0 -0
- package/src/maps/symbols/font-awesome/caret-up.png +0 -0
- package/src/maps/symbols/font-awesome/certificate.png +0 -0
- package/src/maps/symbols/font-awesome/check-circle.png +0 -0
- package/src/maps/symbols/font-awesome/check.png +0 -0
- package/src/maps/symbols/font-awesome/chevron-circle-down.png +0 -0
- package/src/maps/symbols/font-awesome/chevron-circle-up.png +0 -0
- package/src/maps/symbols/font-awesome/cloud.png +0 -0
- package/src/maps/symbols/font-awesome/comment.png +0 -0
- package/src/maps/symbols/font-awesome/crosshairs.png +0 -0
- package/src/maps/symbols/font-awesome/dot-circle-o.png +0 -0
- package/src/maps/symbols/font-awesome/exclamation-circle.png +0 -0
- package/src/maps/symbols/font-awesome/exclamation-triangle.png +0 -0
- package/src/maps/symbols/font-awesome/female.png +0 -0
- package/src/maps/symbols/font-awesome/file.png +0 -0
- package/src/maps/symbols/font-awesome/flag.png +0 -0
- package/src/maps/symbols/font-awesome/flask.png +0 -0
- package/src/maps/symbols/font-awesome/h-square.png +0 -0
- package/src/maps/symbols/font-awesome/home.png +0 -0
- package/src/maps/symbols/font-awesome/info-circle.png +0 -0
- package/src/maps/symbols/font-awesome/male.png +0 -0
- package/src/maps/symbols/font-awesome/medkit.png +0 -0
- package/src/maps/symbols/font-awesome/mobile.png +0 -0
- package/src/maps/symbols/font-awesome/plus-circle.png +0 -0
- package/src/maps/symbols/font-awesome/plus-square.png +0 -0
- package/src/maps/symbols/font-awesome/plus.png +0 -0
- package/src/maps/symbols/font-awesome/square.png +0 -0
- package/src/maps/symbols/font-awesome/star.png +0 -0
- package/src/maps/symbols/font-awesome/thumbs-down.png +0 -0
- package/src/maps/symbols/font-awesome/thumbs-up.png +0 -0
- package/src/maps/symbols/font-awesome/ticket.png +0 -0
- package/src/maps/symbols/font-awesome/times-circle.png +0 -0
- package/src/maps/symbols/font-awesome/times.png +0 -0
- package/src/maps/symbols/font-awesome/tint.png +0 -0
- package/src/maps/symbols/font-awesome/tree.png +0 -0
- package/src/maps/symbols/font-awesome/university.png +0 -0
- package/src/maps/symbols/font-awesome/usd.png +0 -0
- package/src/maps/symbols/font-awesome/user.png +0 -0
- package/src/maps/symbols/font-awesome/users.png +0 -0
- package/src/maps/symbols/font-awesome/wheelchair.png +0 -0
- package/src/maps/vectorMaps.tsx +410 -0
- package/src/memoizedDebounce.tsx +32 -0
- package/src/quickfilter/DateExprComponent.ts +284 -0
- package/src/quickfilter/IdArrayQuickfilterComponent.ts +58 -0
- package/src/quickfilter/Quickfilter.ts +29 -0
- package/src/quickfilter/QuickfilterCompiler.ts +167 -0
- package/src/quickfilter/QuickfilterUtils.ts +123 -0
- package/src/quickfilter/QuickfiltersComponent.ts +416 -0
- package/src/quickfilter/QuickfiltersDataSource.ts +15 -0
- package/src/quickfilter/QuickfiltersDesignComponent.tsx +257 -0
- package/src/quickfilter/README.md +8 -0
- package/src/quickfilter/TextLiteralComponent.ts +161 -0
- package/src/quickfilter/react-onclickout.d.ts +1 -0
- package/src/richtext/ExprItemsHtmlConverter.ts +144 -0
- package/src/richtext/FontColorPaletteItem.ts +172 -0
- package/src/richtext/FontSizePaletteItem.ts +110 -0
- package/src/richtext/ItemsHtmlConverter.ts +246 -0
- package/src/richtext/README.md +3 -0
- package/src/richtext/RichTextComponent.tsx +390 -0
- package/src/richtext/react-float-affixed.d.ts +1 -0
- package/src/update-object.d.ts +1 -0
- package/src/valueFormatter.ts +110 -0
- package/src/widgets/DirectWidgetDataSource.ts +67 -0
- package/src/widgets/DropdownWidgetComponent.ts +78 -0
- package/src/widgets/IFrameWidget.ts +36 -0
- package/src/widgets/IFrameWidgetComponent.ts +116 -0
- package/src/widgets/ImageUploaderComponent.tsx +143 -0
- package/src/widgets/ImageWidget.ts +147 -0
- package/src/widgets/ImageWidgetComponent.ts +546 -0
- package/src/widgets/ImagelistCarouselComponent.ts +109 -0
- package/src/widgets/MapWidget.ts +219 -0
- package/src/widgets/MarkdownWidget.ts +201 -0
- package/src/widgets/TOCWidget.ts +326 -0
- package/src/widgets/Widget.ts +83 -0
- package/src/widgets/WidgetDataSource.ts +23 -0
- package/src/widgets/WidgetFactory.ts +37 -0
- package/src/widgets/WidgetScoper.ts +51 -0
- package/src/widgets/WidgetScopesViewComponent.ts +54 -0
- package/src/widgets/charts/Chart.ts +140 -0
- package/src/widgets/charts/ChartViewComponent.ts +209 -0
- package/src/widgets/charts/ChartWidget.ts +345 -0
- package/src/widgets/charts/calendar/CalendarChart.ts +227 -0
- package/src/widgets/charts/calendar/CalendarChartDesignerComponent.ts +187 -0
- package/src/widgets/charts/calendar/CalendarChartViewComponent.tsx +320 -0
- package/src/widgets/charts/calendar/d3-tip.d.ts +1 -0
- package/src/widgets/charts/imagemosaic/ImageMosaicChart.ts +213 -0
- package/src/widgets/charts/imagemosaic/ImageMosaicChartDesignerComponent.ts +121 -0
- package/src/widgets/charts/imagemosaic/ImageMosaicChartViewComponent.ts +117 -0
- package/src/widgets/charts/imagemosaic/ImagePopupComponent.ts +51 -0
- package/src/widgets/charts/imagemosaic/react-lazy-load-image-component.d.ts +1 -0
- package/src/widgets/charts/layered/LayeredChart.ts +361 -0
- package/src/widgets/charts/layered/LayeredChartCompiler.ts +1299 -0
- package/src/widgets/charts/layered/LayeredChartDesign.ts +106 -0
- package/src/widgets/charts/layered/LayeredChartDesignerComponent.tsx +523 -0
- package/src/widgets/charts/layered/LayeredChartLayerDesignerComponent.tsx +448 -0
- package/src/widgets/charts/layered/LayeredChartSvgFileSaver.ts +146 -0
- package/src/widgets/charts/layered/LayeredChartUtils.ts +24 -0
- package/src/widgets/charts/layered/LayeredChartViewComponent.ts +486 -0
- package/src/widgets/charts/layered/save-svg-as-png.d.ts +1 -0
- package/src/widgets/charts/pivot/IntersectionDesignerComponent.tsx +338 -0
- package/src/widgets/charts/pivot/PivotChart.ts +377 -0
- package/src/widgets/charts/pivot/PivotChartDesign.ts +115 -0
- package/src/widgets/charts/pivot/PivotChartDesignerComponent.tsx +240 -0
- package/src/widgets/charts/pivot/PivotChartLayout.ts +99 -0
- package/src/widgets/charts/pivot/PivotChartLayoutBuilder.ts +779 -0
- package/src/widgets/charts/pivot/PivotChartLayoutComponent.tsx +504 -0
- package/src/widgets/charts/pivot/PivotChartQueryBuilder.ts +273 -0
- package/src/widgets/charts/pivot/PivotChartUtils.ts +219 -0
- package/src/widgets/charts/pivot/PivotChartViewComponent.ts +276 -0
- package/src/widgets/charts/pivot/README.md +30 -0
- package/src/widgets/charts/pivot/SegmentDesignerComponent.tsx +353 -0
- package/src/widgets/charts/table/OrderingsComponent.tsx +119 -0
- package/src/widgets/charts/table/TableChart.ts +420 -0
- package/src/widgets/charts/table/TableChartDesignerComponent.ts +441 -0
- package/src/widgets/charts/table/TableChartViewComponent.ts +327 -0
- package/src/widgets/text/ExprInsertModalComponent.ts +77 -0
- package/src/widgets/text/ExprItemEditorComponent.tsx +164 -0
- package/src/widgets/text/ExprUpdateModalComponent.ts +70 -0
- package/src/widgets/text/README.md +2 -0
- package/src/widgets/text/TextComponent.tsx +151 -0
- package/src/widgets/text/TextWidget.ts +265 -0
- package/src/widgets/text/TextWidgetComponent.ts +120 -0
- package/src/widgets/text/TextWidgetDesign.ts +7 -0
- package/stories/UpdateableComponent.js +29 -0
- package/stories/consoles.js +202 -0
- package/stories/dashboards.js +217 -0
- package/stories/datagridDesign.js +114 -0
- package/stories/datagrids.js +69 -0
- package/stories/dates.js +80 -0
- package/stories/exprcomponent.js +43 -0
- package/stories/index.js +18 -0
- package/stories/leaflet.js +59 -0
- package/stories/maps.js +24 -0
- package/stories/pivotChart.js +235 -0
- package/test/AxisBuilderTests.ts +931 -0
- package/test/ChartWidgetTests.ts +85 -0
- package/test/ColorSchemeFactoryTests.ts +29 -0
- package/test/CsvBuilderTests.ts +22 -0
- package/test/DashboardUpgraderTests.ts +170 -0
- package/test/ImplicitFilterBuilderTests.ts +161 -0
- package/test/LayeredChartCompilerTests.ts +1067 -0
- package/test/LayeredChartTests.ts +88 -0
- package/test/LegoLayoutEngineTests.ts +69 -0
- package/test/MWaterGlobalFiltersComponentTests.ts +130 -0
- package/test/MWaterResponsesFilterComponentTests.ts +164 -0
- package/test/QuickfilterCompilerTests.ts +167 -0
- package/test/TestComponent.ts +49 -0
- package/test/UndoStackTests.ts +73 -0
- package/test/WidgetScoperTests.ts +35 -0
- package/test/blockUtilsTests.ts +290 -0
- package/test/canonical-json.d.ts +1 -0
- package/test/dashboards/DashboardUtilsTests.ts +131 -0
- package/test/datagrids/DatagridQueryBuilderTests.ts +445 -0
- package/test/datagrids/DatagridUtilsTests.ts +54 -0
- package/test/datagrids/LabeledExprGeneratorTests.ts +121 -0
- package/test/fixtures.ts +263 -0
- package/test/index.ts +2 -0
- package/test/maps/MapUtilsTests.ts +168 -0
- package/test/maps/PopupFilterJoinsUtilsTests.ts +105 -0
- package/test/richtext/ItemsHtmlConverterTests.ts +41 -0
- package/test/test_index.ts +4 -0
- package/test/widgets/TextWidgetTests.ts +42 -0
- package/test/widgets/charts/pivot/PivotChartLayoutBuilderTests.ts +817 -0
- package/test/widgets/charts/pivot/PivotChartQueryBuilderTests.ts +359 -0
- package/test/widgets/charts/pivot/PivotChartTests.ts +64 -0
- package/test/widgets/charts/pivot/PivotChartUtilsTests.ts +184 -0
- package/test/widgets/charts/table/TableChartTests.ts +253 -0
- package/tsconfig.build.json +26 -0
- package/types/utm.d.ts +10 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const react_1 = __importDefault(require("react"));
|
|
7
|
+
const R = react_1.default.createElement;
|
|
8
|
+
const update_object_1 = __importDefault(require("update-object"));
|
|
9
|
+
const expressions_1 = require("@mwater/expressions");
|
|
10
|
+
const AxisBuilder_1 = __importDefault(require("./AxisBuilder"));
|
|
11
|
+
const NumberInputComponent_1 = __importDefault(require("@mwater/react-library/lib/NumberInputComponent"));
|
|
12
|
+
const bootstrap_1 = require("@mwater/react-library/lib/bootstrap");
|
|
13
|
+
// Allows setting of bins (min, max and number). Computes defaults if not present
|
|
14
|
+
class BinsComponent extends react_1.default.Component {
|
|
15
|
+
unmounted;
|
|
16
|
+
constructor(props) {
|
|
17
|
+
super(props);
|
|
18
|
+
this.state = {
|
|
19
|
+
guessing: false // True when guessing ranges
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
componentDidMount() {
|
|
23
|
+
// Check if computing is needed
|
|
24
|
+
if (this.props.xform.min == null || this.props.xform.max == null) {
|
|
25
|
+
// Only do for individual (not aggregate) expressions
|
|
26
|
+
const exprUtils = new expressions_1.ExprUtils(this.props.schema);
|
|
27
|
+
if (exprUtils.getExprAggrStatus(this.props.expr) !== "individual") {
|
|
28
|
+
// Percent is a special case where 0-100
|
|
29
|
+
if (this.props.expr?.op === "percent where") {
|
|
30
|
+
this.props.onChange((0, update_object_1.default)(this.props.xform, {
|
|
31
|
+
min: { $set: 0 },
|
|
32
|
+
max: { $set: 100 },
|
|
33
|
+
excludeLower: { $set: true },
|
|
34
|
+
excludeUpper: { $set: true }
|
|
35
|
+
}));
|
|
36
|
+
}
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
const axisBuilder = new AxisBuilder_1.default({ schema: this.props.schema });
|
|
40
|
+
// Get min and max from a query
|
|
41
|
+
const minMaxQuery = axisBuilder.compileBinMinMax(this.props.expr, this.props.expr.table, null, this.props.xform.numBins);
|
|
42
|
+
if (!minMaxQuery) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
this.setState({ guessing: true });
|
|
46
|
+
return this.props.dataSource.performQuery(minMaxQuery, (error, rows) => {
|
|
47
|
+
let max, min;
|
|
48
|
+
if (this.unmounted) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
this.setState({ guessing: false });
|
|
52
|
+
if (error) {
|
|
53
|
+
return; // Ignore
|
|
54
|
+
}
|
|
55
|
+
if (rows[0].min != null) {
|
|
56
|
+
min = parseFloat(rows[0].min);
|
|
57
|
+
max = parseFloat(rows[0].max);
|
|
58
|
+
}
|
|
59
|
+
return this.props.onChange((0, update_object_1.default)(this.props.xform, { min: { $set: min }, max: { $set: max } }));
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
componentWillUnmount() {
|
|
64
|
+
return (this.unmounted = true);
|
|
65
|
+
}
|
|
66
|
+
render() {
|
|
67
|
+
return R("div", null, R("div", { key: "vals" }, R(LabeledInlineComponent, { key: "min", label: "Min:" }, R(NumberInputComponent_1.default, {
|
|
68
|
+
small: true,
|
|
69
|
+
value: this.props.xform.min,
|
|
70
|
+
onChange: (v) => this.props.onChange((0, update_object_1.default)(this.props.xform, { min: { $set: v } }))
|
|
71
|
+
})), " ", R(LabeledInlineComponent, { key: "max", label: "Max:" }, R(NumberInputComponent_1.default, {
|
|
72
|
+
small: true,
|
|
73
|
+
value: this.props.xform.max,
|
|
74
|
+
onChange: (v) => this.props.onChange((0, update_object_1.default)(this.props.xform, { max: { $set: v } }))
|
|
75
|
+
})), " ", R(LabeledInlineComponent, { key: "numBins", label: "# of Bins:" }, R(NumberInputComponent_1.default, {
|
|
76
|
+
small: true,
|
|
77
|
+
value: this.props.xform.numBins,
|
|
78
|
+
decimal: false,
|
|
79
|
+
onChange: (v) => this.props.onChange((0, update_object_1.default)(this.props.xform, { numBins: { $set: v } }))
|
|
80
|
+
})), (() => {
|
|
81
|
+
if (this.state.guessing) {
|
|
82
|
+
return R("i", { className: "fa fa-spinner fa-spin" });
|
|
83
|
+
}
|
|
84
|
+
else if (this.props.xform.min == null || this.props.xform.max == null || !this.props.xform.numBins) {
|
|
85
|
+
return R("span", { className: "text-danger", style: { paddingLeft: 10 } }, "Min and max are required");
|
|
86
|
+
}
|
|
87
|
+
return null;
|
|
88
|
+
})()), this.props.xform.min != null && this.props.xform.max != null && this.props.xform.numBins ? (react_1.default.createElement("div", { key: "excludes" },
|
|
89
|
+
react_1.default.createElement(bootstrap_1.Checkbox, { key: "lower", inline: true, value: !this.props.xform.excludeLower, onChange: (value) => this.props.onChange((0, update_object_1.default)(this.props.xform, { excludeLower: { $set: !value } })) }, `Include < ${this.props.xform.min}`),
|
|
90
|
+
react_1.default.createElement(bootstrap_1.Checkbox, { key: "upper", inline: true, value: !this.props.xform.excludeUpper, onChange: (value) => this.props.onChange((0, update_object_1.default)(this.props.xform, { excludeUpper: { $set: !value } })) }, `Include > ${this.props.xform.max}`))) : undefined);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
exports.default = BinsComponent;
|
|
94
|
+
function LabeledInlineComponent(props) {
|
|
95
|
+
return R("div", { style: { display: "inline-block" } }, R("label", { className: "text-muted" }, props.label), props.children);
|
|
96
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Schema } from "@mwater/expressions";
|
|
3
|
+
import { Axis, AxisCategory } from "./Axis";
|
|
4
|
+
export interface CategoryMapComponentProps {
|
|
5
|
+
schema: Schema;
|
|
6
|
+
axis: Axis;
|
|
7
|
+
onChange: (axis: Axis) => void;
|
|
8
|
+
categories?: AxisCategory[];
|
|
9
|
+
reorderable?: boolean;
|
|
10
|
+
/** True to allow editing the color map */
|
|
11
|
+
showColorMap?: boolean;
|
|
12
|
+
/** True to allow excluding of values via checkboxes */
|
|
13
|
+
allowExcludedValues?: boolean;
|
|
14
|
+
initiallyExpanded?: boolean;
|
|
15
|
+
}
|
|
16
|
+
interface CategoryMapComponentState {
|
|
17
|
+
collapsed: any;
|
|
18
|
+
}
|
|
19
|
+
export default class CategoryMapComponent extends React.Component<CategoryMapComponentProps, CategoryMapComponentState> {
|
|
20
|
+
constructor(props: any);
|
|
21
|
+
handleReorder: (map: any) => void;
|
|
22
|
+
handleColorChange: (value: any, color: any) => void;
|
|
23
|
+
handleExcludeChange: (value: any, ev: any) => void;
|
|
24
|
+
lookupColor(value: any): string | null;
|
|
25
|
+
handleNullLabelChange: (e: any) => void;
|
|
26
|
+
handleCategoryLabelChange: (category: any, e: any) => void;
|
|
27
|
+
handleToggle: () => void;
|
|
28
|
+
renderLabel(category: any): React.DetailedReactHTMLElement<{
|
|
29
|
+
className: string;
|
|
30
|
+
onClick: (e: any) => void;
|
|
31
|
+
style: {
|
|
32
|
+
cursor: "pointer";
|
|
33
|
+
};
|
|
34
|
+
}, HTMLElement>;
|
|
35
|
+
renderCategory: (category: any, index?: any, connectDragSource?: any, connectDragPreview?: any, connectDropTarget?: any) => React.DetailedReactHTMLElement<React.HTMLAttributes<HTMLElement>, HTMLElement>;
|
|
36
|
+
renderReorderable(): React.DetailedReactHTMLElement<React.HTMLAttributes<HTMLElement>, HTMLElement>;
|
|
37
|
+
renderNonReorderable(): React.DetailedReactHTMLElement<React.HTMLAttributes<HTMLElement>, HTMLElement>;
|
|
38
|
+
renderToggle(): React.DetailedReactHTMLElement<React.HTMLAttributes<HTMLElement>, HTMLElement>;
|
|
39
|
+
render(): React.DetailedReactHTMLElement<React.HTMLAttributes<HTMLElement>, HTMLElement>;
|
|
40
|
+
}
|
|
41
|
+
export {};
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const R = react_1.default.createElement;
|
|
9
|
+
const update_object_1 = __importDefault(require("update-object"));
|
|
10
|
+
const ColorComponent_1 = __importDefault(require("../ColorComponent"));
|
|
11
|
+
const ReorderableListComponent_1 = __importDefault(require("@mwater/react-library/lib/reorderable/ReorderableListComponent"));
|
|
12
|
+
const immer_1 = __importDefault(require("immer"));
|
|
13
|
+
// Category map for an axis. Controls the colorMap values and excludedValues
|
|
14
|
+
// Can be collapsed
|
|
15
|
+
class CategoryMapComponent extends react_1.default.Component {
|
|
16
|
+
constructor(props) {
|
|
17
|
+
super(props);
|
|
18
|
+
this.state = {
|
|
19
|
+
collapsed: !props.initiallyExpanded // Start collapsed
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
handleReorder = (map) => {
|
|
23
|
+
const order = lodash_1.default.pluck(map, "value");
|
|
24
|
+
return this.props.onChange((0, update_object_1.default)(this.props.axis, { drawOrder: { $set: order } }));
|
|
25
|
+
};
|
|
26
|
+
handleColorChange = (value, color) => {
|
|
27
|
+
// Delete if present for value
|
|
28
|
+
const colorMap = lodash_1.default.filter(this.props.axis.colorMap || [], (item) => item.value !== value);
|
|
29
|
+
// Add if color present
|
|
30
|
+
if (color) {
|
|
31
|
+
colorMap.push({ value, color });
|
|
32
|
+
}
|
|
33
|
+
return this.props.onChange((0, update_object_1.default)(this.props.axis, { colorMap: { $set: colorMap } }));
|
|
34
|
+
};
|
|
35
|
+
handleExcludeChange = (value, ev) => {
|
|
36
|
+
let excludedValues;
|
|
37
|
+
if (ev.target.checked) {
|
|
38
|
+
excludedValues = lodash_1.default.difference(this.props.axis.excludedValues || [], [value]);
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
excludedValues = lodash_1.default.union(this.props.axis.excludedValues || [], [value]);
|
|
42
|
+
}
|
|
43
|
+
return this.props.onChange((0, update_object_1.default)(this.props.axis, { excludedValues: { $set: excludedValues } }));
|
|
44
|
+
};
|
|
45
|
+
// Gets the current color value if known
|
|
46
|
+
lookupColor(value) {
|
|
47
|
+
const item = lodash_1.default.find(this.props.axis.colorMap || [], (item) => item.value === value);
|
|
48
|
+
if (item) {
|
|
49
|
+
return item.color;
|
|
50
|
+
}
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
53
|
+
handleNullLabelChange = (e) => {
|
|
54
|
+
const name = prompt("Enter label for none value", this.props.axis.nullLabel || "None");
|
|
55
|
+
if (name) {
|
|
56
|
+
return this.props.onChange((0, update_object_1.default)(this.props.axis, { nullLabel: { $set: name } }));
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
handleCategoryLabelChange = (category, e) => {
|
|
60
|
+
let { label } = category;
|
|
61
|
+
if (this.props.axis.categoryLabels) {
|
|
62
|
+
label = this.props.axis.categoryLabels[JSON.stringify(category.value)] || label;
|
|
63
|
+
}
|
|
64
|
+
const name = prompt("Enter label or blank to reset", label);
|
|
65
|
+
if (name != null) {
|
|
66
|
+
if (name) {
|
|
67
|
+
return this.props.onChange((0, immer_1.default)(this.props.axis, (draft) => {
|
|
68
|
+
draft.categoryLabels = draft.categoryLabels || {};
|
|
69
|
+
draft.categoryLabels[JSON.stringify(category.value)] = name;
|
|
70
|
+
}));
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
return this.props.onChange((0, immer_1.default)(this.props.axis, (draft) => {
|
|
74
|
+
draft.categoryLabels = draft.categoryLabels || {};
|
|
75
|
+
delete draft.categoryLabels[JSON.stringify(category.value)];
|
|
76
|
+
}));
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
handleToggle = () => {
|
|
81
|
+
return this.setState({ collapsed: !this.state.collapsed });
|
|
82
|
+
};
|
|
83
|
+
renderLabel(category) {
|
|
84
|
+
let { label } = category;
|
|
85
|
+
if (this.props.axis.categoryLabels) {
|
|
86
|
+
label = this.props.axis.categoryLabels[JSON.stringify(category.value)] || label;
|
|
87
|
+
}
|
|
88
|
+
if (category.value != null) {
|
|
89
|
+
return R("a", {
|
|
90
|
+
className: "link-plain",
|
|
91
|
+
onClick: this.handleCategoryLabelChange.bind(null, category),
|
|
92
|
+
style: { cursor: "pointer" }
|
|
93
|
+
}, label);
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
return R("a", { className: "link-plain", onClick: this.handleNullLabelChange, style: { cursor: "pointer" } }, label, R("span", { style: { fontSize: 12, marginLeft: 4 } }, "(click to change label for none value)"));
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
// Category is { value: category value, label: category label }
|
|
100
|
+
renderCategory = (category, index, connectDragSource, connectDragPreview, connectDropTarget) => {
|
|
101
|
+
const labelStyle = {
|
|
102
|
+
verticalAlign: "middle",
|
|
103
|
+
marginLeft: 5
|
|
104
|
+
};
|
|
105
|
+
const iconStyle = {
|
|
106
|
+
cursor: "move",
|
|
107
|
+
marginRight: 8,
|
|
108
|
+
opacity: 0.5,
|
|
109
|
+
fontSize: 12,
|
|
110
|
+
height: 20
|
|
111
|
+
};
|
|
112
|
+
const colorPickerStyle = {
|
|
113
|
+
verticalAlign: "middle",
|
|
114
|
+
lineHeight: 1,
|
|
115
|
+
display: "inline-block",
|
|
116
|
+
marginLeft: 5
|
|
117
|
+
};
|
|
118
|
+
let elem = R("div", { key: category.value }, connectDragSource ? connectDragSource(R("i", { className: "fa fa-bars", style: iconStyle })) : undefined, this.props.allowExcludedValues
|
|
119
|
+
? R("input", {
|
|
120
|
+
type: "checkbox",
|
|
121
|
+
style: { marginLeft: 5, marginBottom: 5, verticalAlign: "middle" },
|
|
122
|
+
checked: !lodash_1.default.includes(this.props.axis.excludedValues || [], category.value),
|
|
123
|
+
onChange: this.handleExcludeChange.bind(null, category.value)
|
|
124
|
+
})
|
|
125
|
+
: undefined, this.props.showColorMap
|
|
126
|
+
? R("div", { style: colorPickerStyle }, R(ColorComponent_1.default, {
|
|
127
|
+
key: "color",
|
|
128
|
+
color: this.lookupColor(category.value),
|
|
129
|
+
onChange: (color) => this.handleColorChange(category.value, color)
|
|
130
|
+
}))
|
|
131
|
+
: undefined, R("span", { style: labelStyle }, this.renderLabel(category)));
|
|
132
|
+
if (connectDropTarget) {
|
|
133
|
+
elem = connectDropTarget(elem);
|
|
134
|
+
}
|
|
135
|
+
if (connectDragPreview) {
|
|
136
|
+
elem = connectDragPreview(elem);
|
|
137
|
+
}
|
|
138
|
+
return elem;
|
|
139
|
+
};
|
|
140
|
+
renderReorderable() {
|
|
141
|
+
const drawOrder = this.props.axis.drawOrder || lodash_1.default.pluck(this.props.axis.colorMap || [], "value");
|
|
142
|
+
const orderedCategories = lodash_1.default.sortBy(this.props.categories || [], (category) => {
|
|
143
|
+
return lodash_1.default.indexOf(drawOrder, category.value);
|
|
144
|
+
});
|
|
145
|
+
return R("div", null, this.renderToggle(), R(ReorderableListComponent_1.default, {
|
|
146
|
+
items: orderedCategories,
|
|
147
|
+
onReorder: this.handleReorder,
|
|
148
|
+
renderItem: this.renderCategory,
|
|
149
|
+
getItemId: (item) => item.value
|
|
150
|
+
}));
|
|
151
|
+
}
|
|
152
|
+
renderNonReorderable() {
|
|
153
|
+
return R("div", null, this.renderToggle(), lodash_1.default.map(this.props.categories || [], (category) => this.renderCategory(category)));
|
|
154
|
+
}
|
|
155
|
+
renderToggle() {
|
|
156
|
+
if (this.state.collapsed) {
|
|
157
|
+
return R("div", null, R("a", { className: "link-plain", onClick: this.handleToggle }, "Show Values ", R("i", { className: "fa fa-caret-down" })));
|
|
158
|
+
}
|
|
159
|
+
else {
|
|
160
|
+
return R("div", null, R("a", { className: "link-plain", onClick: this.handleToggle }, "Hide Values ", R("i", { className: "fa fa-caret-up" })));
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
render() {
|
|
164
|
+
if (this.state.collapsed) {
|
|
165
|
+
return this.renderToggle();
|
|
166
|
+
}
|
|
167
|
+
if (this.props.reorderable) {
|
|
168
|
+
return this.renderReorderable();
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
return this.renderNonReorderable();
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
exports.default = CategoryMapComponent;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Axis, AxisCategory } from "./Axis";
|
|
3
|
+
export interface ColorPaletteCollectionComponentProps {
|
|
4
|
+
onPaletteSelected: any;
|
|
5
|
+
axis: Axis;
|
|
6
|
+
categories: AxisCategory[];
|
|
7
|
+
onCancel: any;
|
|
8
|
+
}
|
|
9
|
+
export default class ColorPaletteCollectionComponent extends React.Component<ColorPaletteCollectionComponentProps> {
|
|
10
|
+
static palettes: {
|
|
11
|
+
type: string;
|
|
12
|
+
reversed: boolean;
|
|
13
|
+
}[];
|
|
14
|
+
onPaletteSelected: (index: any) => any;
|
|
15
|
+
renderCancel: () => React.DetailedReactHTMLElement<React.HTMLAttributes<HTMLElement>, HTMLElement> | null;
|
|
16
|
+
render(): React.DetailedReactHTMLElement<React.HTMLAttributes<HTMLElement>, HTMLElement>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const R = react_1.default.createElement;
|
|
9
|
+
const ColorSchemeFactory_1 = __importDefault(require("../ColorSchemeFactory"));
|
|
10
|
+
class ColorPaletteCollectionComponent extends react_1.default.Component {
|
|
11
|
+
static palettes = [
|
|
12
|
+
{ type: "schemeSet1", reversed: false },
|
|
13
|
+
{ type: "schemeSet2", reversed: false },
|
|
14
|
+
{ type: "schemeSet3", reversed: false },
|
|
15
|
+
{ type: "schemeAccent", reversed: false },
|
|
16
|
+
{ type: "schemeDark2", reversed: false },
|
|
17
|
+
{ type: "schemePaired", reversed: false },
|
|
18
|
+
{ type: "schemePastel1", reversed: false },
|
|
19
|
+
{ type: "schemePastel2", reversed: false },
|
|
20
|
+
{ type: "interpolateSpectral", reversed: false },
|
|
21
|
+
{ type: "interpolateSpectral", reversed: true },
|
|
22
|
+
{ type: "interpolateBlues", reversed: false },
|
|
23
|
+
{ type: "interpolateBlues", reversed: true },
|
|
24
|
+
{ type: "interpolateGreens", reversed: false },
|
|
25
|
+
{ type: "interpolateGreens", reversed: true },
|
|
26
|
+
{ type: "interpolateGreys", reversed: false },
|
|
27
|
+
{ type: "interpolateGreys", reversed: true },
|
|
28
|
+
{ type: "interpolateOranges", reversed: false },
|
|
29
|
+
{ type: "interpolateOranges", reversed: true },
|
|
30
|
+
{ type: "interpolatePurples", reversed: false },
|
|
31
|
+
{ type: "interpolatePurples", reversed: true },
|
|
32
|
+
{ type: "interpolateReds", reversed: false },
|
|
33
|
+
{ type: "interpolateReds", reversed: true },
|
|
34
|
+
{ type: "interpolateBuGn", reversed: false },
|
|
35
|
+
{ type: "interpolateBuGn", reversed: true },
|
|
36
|
+
{ type: "interpolateBuPu", reversed: false },
|
|
37
|
+
{ type: "interpolateBuPu", reversed: true },
|
|
38
|
+
{ type: "interpolateGnBu", reversed: false },
|
|
39
|
+
{ type: "interpolateGnBu", reversed: true },
|
|
40
|
+
{ type: "interpolateOrRd", reversed: false },
|
|
41
|
+
{ type: "interpolateOrRd", reversed: true },
|
|
42
|
+
{ type: "interpolatePuBuGn", reversed: false },
|
|
43
|
+
{ type: "interpolatePuBuGn", reversed: true },
|
|
44
|
+
{ type: "interpolatePuBu", reversed: false },
|
|
45
|
+
{ type: "interpolatePuBu", reversed: true },
|
|
46
|
+
{ type: "interpolatePuRd", reversed: false },
|
|
47
|
+
{ type: "interpolatePuRd", reversed: true },
|
|
48
|
+
{ type: "interpolateRdPu", reversed: false },
|
|
49
|
+
{ type: "interpolateRdPu", reversed: true },
|
|
50
|
+
{ type: "interpolateYlGnBu", reversed: false },
|
|
51
|
+
{ type: "interpolateYlGnBu", reversed: true },
|
|
52
|
+
{ type: "interpolateYlGn", reversed: false },
|
|
53
|
+
{ type: "interpolateYlGn", reversed: true },
|
|
54
|
+
{ type: "interpolateYlOrBr", reversed: false },
|
|
55
|
+
{ type: "interpolateYlOrBr", reversed: true },
|
|
56
|
+
{ type: "interpolateYlOrRd", reversed: false },
|
|
57
|
+
{ type: "interpolateYlOrRd", reversed: true },
|
|
58
|
+
{ type: "interpolateBrBG", reversed: false },
|
|
59
|
+
{ type: "interpolateBrBG", reversed: true },
|
|
60
|
+
{ type: "interpolatePRGn", reversed: false },
|
|
61
|
+
{ type: "interpolatePRGn", reversed: true },
|
|
62
|
+
{ type: "interpolatePiYG", reversed: false },
|
|
63
|
+
{ type: "interpolatePiYG", reversed: true },
|
|
64
|
+
{ type: "interpolatePuOr", reversed: false },
|
|
65
|
+
{ type: "interpolatePuOr", reversed: true },
|
|
66
|
+
{ type: "interpolateRdBu", reversed: false },
|
|
67
|
+
{ type: "interpolateRdBu", reversed: true },
|
|
68
|
+
{ type: "interpolateRdGy", reversed: false },
|
|
69
|
+
{ type: "interpolateRdGy", reversed: true },
|
|
70
|
+
{ type: "interpolateRdYlBu", reversed: false },
|
|
71
|
+
{ type: "interpolateRdYlBu", reversed: true },
|
|
72
|
+
{ type: "interpolateRdYlGn", reversed: false },
|
|
73
|
+
{ type: "interpolateRdYlGn", reversed: true }
|
|
74
|
+
];
|
|
75
|
+
onPaletteSelected = (index) => {
|
|
76
|
+
// Generate color map
|
|
77
|
+
const scheme = ColorSchemeFactory_1.default.createColorScheme({
|
|
78
|
+
type: ColorPaletteCollectionComponent.palettes[index].type,
|
|
79
|
+
// Null doesn't count to length
|
|
80
|
+
number: lodash_1.default.any(this.props.categories, (c) => c.value == null)
|
|
81
|
+
? this.props.categories.length - 1
|
|
82
|
+
: this.props.categories.length,
|
|
83
|
+
reversed: ColorPaletteCollectionComponent.palettes[index].reversed
|
|
84
|
+
});
|
|
85
|
+
const colorMap = lodash_1.default.map(this.props.categories, (category, i) => ({
|
|
86
|
+
value: category.value,
|
|
87
|
+
color: category.value === null ? "#aaaaaa" : scheme[i % scheme.length]
|
|
88
|
+
}));
|
|
89
|
+
return this.props.onPaletteSelected(colorMap);
|
|
90
|
+
};
|
|
91
|
+
renderCancel = () => {
|
|
92
|
+
if (this.props.axis.colorMap) {
|
|
93
|
+
return R("div", null, R("a", { className: "link-plain", onClick: this.props.onCancel, key: "cancel-customize" }, "Cancel"));
|
|
94
|
+
}
|
|
95
|
+
return null;
|
|
96
|
+
};
|
|
97
|
+
render() {
|
|
98
|
+
return R("div", null, R("p", null, "Please select a color scheme"), lodash_1.default.map(ColorPaletteCollectionComponent.palettes, (config, index) => {
|
|
99
|
+
return R(ColorPaletteComponent, {
|
|
100
|
+
key: index,
|
|
101
|
+
index,
|
|
102
|
+
colorSet: ColorSchemeFactory_1.default.createColorScheme({
|
|
103
|
+
type: config.type,
|
|
104
|
+
number: Math.min(this.props.categories.length - 1, 6),
|
|
105
|
+
reversed: config.reversed
|
|
106
|
+
}),
|
|
107
|
+
onPaletteSelected: this.onPaletteSelected,
|
|
108
|
+
number: this.props.categories.length
|
|
109
|
+
});
|
|
110
|
+
}), this.renderCancel());
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
exports.default = ColorPaletteCollectionComponent;
|
|
114
|
+
class ColorPaletteComponent extends react_1.default.Component {
|
|
115
|
+
static defaultProps = { number: 6 };
|
|
116
|
+
handleSelect = () => {
|
|
117
|
+
return this.props.onPaletteSelected(this.props.index);
|
|
118
|
+
};
|
|
119
|
+
render() {
|
|
120
|
+
return R("div", { onClick: this.handleSelect, className: "axis-palette" }, lodash_1.default.map(this.props.colorSet.slice(0, this.props.number), (color, i) => {
|
|
121
|
+
const cellStyle = {
|
|
122
|
+
display: "inline-block",
|
|
123
|
+
height: 20,
|
|
124
|
+
width: 20,
|
|
125
|
+
backgroundColor: color
|
|
126
|
+
};
|
|
127
|
+
return R("div", { style: cellStyle, key: i }, " ");
|
|
128
|
+
}));
|
|
129
|
+
}
|
|
130
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { AxisXform } from "./Axis";
|
|
3
|
+
import { Expr, Schema } from "@mwater/expressions";
|
|
4
|
+
export interface RangesComponentProps {
|
|
5
|
+
schema: Schema;
|
|
6
|
+
/** Expression for computing min/max */
|
|
7
|
+
expr: Expr;
|
|
8
|
+
xform: AxisXform;
|
|
9
|
+
onChange: any;
|
|
10
|
+
}
|
|
11
|
+
export default class RangesComponent extends React.Component<RangesComponentProps> {
|
|
12
|
+
handleRangeChange: (index: any, range: any) => any;
|
|
13
|
+
handleAddRange: () => any;
|
|
14
|
+
handleRemoveRange: (index: any) => any;
|
|
15
|
+
renderRange: (range: any, index: any, connectDragSource: any, connectDragPreview: any, connectDropTarget: any) => React.CElement<RangeComponentProps, RangeComponent>;
|
|
16
|
+
handleReorder: (ranges: any) => any;
|
|
17
|
+
render(): React.DetailedReactHTMLElement<React.HTMLAttributes<HTMLElement>, HTMLElement>;
|
|
18
|
+
}
|
|
19
|
+
interface RangeComponentProps {
|
|
20
|
+
/** Range to edit */
|
|
21
|
+
range: any;
|
|
22
|
+
onChange: any;
|
|
23
|
+
onRemove: any;
|
|
24
|
+
/** reorderable connector */
|
|
25
|
+
connectDragSource: any;
|
|
26
|
+
/** reorderable connector */
|
|
27
|
+
connectDragPreview: any;
|
|
28
|
+
connectDropTarget: any;
|
|
29
|
+
}
|
|
30
|
+
declare class RangeComponent extends React.Component<RangeComponentProps> {
|
|
31
|
+
handleMinOpenChange: (minOpen: any) => any;
|
|
32
|
+
handleMaxOpenChange: (maxOpen: any) => any;
|
|
33
|
+
render(): any;
|
|
34
|
+
}
|
|
35
|
+
export {};
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const react_1 = __importDefault(require("react"));
|
|
7
|
+
const R = react_1.default.createElement;
|
|
8
|
+
const uuid_1 = __importDefault(require("uuid"));
|
|
9
|
+
const update_object_1 = __importDefault(require("update-object"));
|
|
10
|
+
const expressions_ui_1 = require("@mwater/expressions-ui");
|
|
11
|
+
const NumberInputComponent_1 = __importDefault(require("@mwater/react-library/lib/NumberInputComponent"));
|
|
12
|
+
const ReorderableListComponent_1 = __importDefault(require("@mwater/react-library/lib/reorderable/ReorderableListComponent"));
|
|
13
|
+
// Allows setting of ranges
|
|
14
|
+
class RangesComponent extends react_1.default.Component {
|
|
15
|
+
handleRangeChange = (index, range) => {
|
|
16
|
+
const ranges = this.props.xform.ranges.slice();
|
|
17
|
+
ranges[index] = range;
|
|
18
|
+
return this.props.onChange((0, update_object_1.default)(this.props.xform, { ranges: { $set: ranges } }));
|
|
19
|
+
};
|
|
20
|
+
handleAddRange = () => {
|
|
21
|
+
const ranges = this.props.xform.ranges.slice();
|
|
22
|
+
ranges.push({ id: (0, uuid_1.default)(), minOpen: false, maxOpen: true });
|
|
23
|
+
return this.props.onChange((0, update_object_1.default)(this.props.xform, { ranges: { $set: ranges } }));
|
|
24
|
+
};
|
|
25
|
+
handleRemoveRange = (index) => {
|
|
26
|
+
const ranges = this.props.xform.ranges.slice();
|
|
27
|
+
ranges.splice(index, 1);
|
|
28
|
+
return this.props.onChange((0, update_object_1.default)(this.props.xform, { ranges: { $set: ranges } }));
|
|
29
|
+
};
|
|
30
|
+
renderRange = (range, index, connectDragSource, connectDragPreview, connectDropTarget) => {
|
|
31
|
+
return R(RangeComponent, {
|
|
32
|
+
key: range.id,
|
|
33
|
+
range,
|
|
34
|
+
onChange: this.handleRangeChange.bind(null, index),
|
|
35
|
+
onRemove: this.handleRemoveRange.bind(null, index),
|
|
36
|
+
connectDragSource,
|
|
37
|
+
connectDragPreview,
|
|
38
|
+
connectDropTarget
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
handleReorder = (ranges) => {
|
|
42
|
+
return this.props.onChange((0, update_object_1.default)(this.props.xform, { ranges: { $set: ranges } }));
|
|
43
|
+
};
|
|
44
|
+
render() {
|
|
45
|
+
return R("div", null, R("table", null, this.props.xform.ranges.length > 0
|
|
46
|
+
? R("thead", null, R("tr", null, R("th", null, " "), R("th", { key: "min", colSpan: 2, style: { textAlign: "center" } }, "From"), R("th", { key: "and" }, ""), R("th", { key: "max", colSpan: 2, style: { textAlign: "center" } }, "To"), R("th", { key: "label", colSpan: 1, style: { textAlign: "center" } }, "Label"), R("th", { key: "remove" })))
|
|
47
|
+
: undefined, react_1.default.createElement(ReorderableListComponent_1.default, {
|
|
48
|
+
items: this.props.xform.ranges,
|
|
49
|
+
onReorder: this.handleReorder,
|
|
50
|
+
renderItem: this.renderRange,
|
|
51
|
+
getItemId: (range) => range.id,
|
|
52
|
+
element: R("tbody", null)
|
|
53
|
+
})),
|
|
54
|
+
// _.map @props.xform.ranges, (range, i) =>
|
|
55
|
+
// R RangeComponent, key: range.id, range: range, onChange: @handleRangeChange.bind(null, i), onRemove: @handleRemoveRange.bind(null, i)
|
|
56
|
+
R("button", { className: "btn btn-link btn-sm", type: "button", onClick: this.handleAddRange }, R("span", { className: "fas fa-plus" }), " Add Range"));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
exports.default = RangesComponent;
|
|
60
|
+
// Single range (row)
|
|
61
|
+
class RangeComponent extends react_1.default.Component {
|
|
62
|
+
handleMinOpenChange = (minOpen) => {
|
|
63
|
+
return this.props.onChange((0, update_object_1.default)(this.props.range, { minOpen: { $set: minOpen } }));
|
|
64
|
+
};
|
|
65
|
+
handleMaxOpenChange = (maxOpen) => {
|
|
66
|
+
return this.props.onChange((0, update_object_1.default)(this.props.range, { maxOpen: { $set: maxOpen } }));
|
|
67
|
+
};
|
|
68
|
+
render() {
|
|
69
|
+
let placeholder = "";
|
|
70
|
+
if (this.props.range.minValue != null) {
|
|
71
|
+
if (this.props.range.minOpen) {
|
|
72
|
+
placeholder = `> ${this.props.range.minValue}`;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
placeholder = `>= ${this.props.range.minValue}`;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
if (this.props.range.maxValue != null) {
|
|
79
|
+
if (placeholder) {
|
|
80
|
+
placeholder += " and ";
|
|
81
|
+
}
|
|
82
|
+
if (this.props.range.maxOpen) {
|
|
83
|
+
placeholder += `< ${this.props.range.maxValue}`;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
placeholder += `<= ${this.props.range.maxValue}`;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
return this.props.connectDragPreview(this.props.connectDropTarget(R("tr", null, R("td", null, this.props.connectDragSource(R("span", { className: "fa fa-bars" }))), R("td", { key: "minOpen" }, R(expressions_ui_1.LinkComponent, {
|
|
90
|
+
dropdownItems: [
|
|
91
|
+
{ id: true, name: "greater than" },
|
|
92
|
+
{ id: false, name: "greater than or equal to" }
|
|
93
|
+
],
|
|
94
|
+
onDropdownItemClicked: this.handleMinOpenChange
|
|
95
|
+
}, this.props.range.minOpen ? "greater than" : "greater than or equal to")), R("td", { key: "minValue" }, R(NumberInputComponent_1.default, {
|
|
96
|
+
value: this.props.range.minValue,
|
|
97
|
+
placeholder: "None",
|
|
98
|
+
small: true,
|
|
99
|
+
onChange: (v) => this.props.onChange((0, update_object_1.default)(this.props.range, { minValue: { $set: v } }))
|
|
100
|
+
})), R("td", { key: "and" }, "\u00A0and\u00A0"), R("td", { key: "maxOpen" }, R(expressions_ui_1.LinkComponent, {
|
|
101
|
+
dropdownItems: [
|
|
102
|
+
{ id: true, name: "less than" },
|
|
103
|
+
{ id: false, name: "less than or equal to" }
|
|
104
|
+
],
|
|
105
|
+
onDropdownItemClicked: this.handleMaxOpenChange
|
|
106
|
+
}, this.props.range.maxOpen ? "less than" : "less than or equal to")), R("td", { key: "maxValue" }, R(NumberInputComponent_1.default, {
|
|
107
|
+
value: this.props.range.maxValue,
|
|
108
|
+
placeholder: "None",
|
|
109
|
+
small: true,
|
|
110
|
+
onChange: (v) => this.props.onChange((0, update_object_1.default)(this.props.range, { maxValue: { $set: v } }))
|
|
111
|
+
})), R("td", { key: "label" }, R("input", {
|
|
112
|
+
type: "text",
|
|
113
|
+
className: "form-control form-control-sm",
|
|
114
|
+
value: this.props.range.label || "",
|
|
115
|
+
placeholder,
|
|
116
|
+
onChange: (ev) => this.props.onChange((0, update_object_1.default)(this.props.range, { label: { $set: ev.target.value || null } }))
|
|
117
|
+
})), R("td", { key: "remove" }, R("button", { className: "btn btn-sm btn-link", type: "button", onClick: this.props.onRemove }, R("span", { className: "fas fa-times" }))))));
|
|
118
|
+
}
|
|
119
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
// TODO: This file was created by bulk-decaffeinate.
|
|
7
|
+
// Sanity-check the conversion and remove this comment.
|
|
8
|
+
const react_1 = __importDefault(require("react"));
|
|
9
|
+
const react_dom_1 = __importDefault(require("react-dom"));
|
|
10
|
+
const R = react_1.default.createElement;
|
|
11
|
+
const jquery_1 = __importDefault(require("jquery"));
|
|
12
|
+
// LargeListComponent = require './LargeListComponent'
|
|
13
|
+
const VerticalLayoutComponent_1 = __importDefault(require("./VerticalLayoutComponent"));
|
|
14
|
+
class Parent extends react_1.default.Component {
|
|
15
|
+
componentDidMount() {
|
|
16
|
+
return console.log(this.refs);
|
|
17
|
+
}
|
|
18
|
+
render() {
|
|
19
|
+
return R("div", null, R("div", { ref: "simple" }, R("div", { ref: "complex" })), react_1.default.createElement(Child, {}, R("div", { ref: "simple2" }, R("div", { ref: "complex2" }))));
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
class Child extends react_1.default.Component {
|
|
23
|
+
render() {
|
|
24
|
+
return R("div", { style: { height: this.props.height, backgroundColor: this.props.backgroundColor } }, this.props.children);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
(0, jquery_1.default)(function () {
|
|
28
|
+
const sample = react_1.default.createElement(VerticalLayoutComponent_1.default, {
|
|
29
|
+
height: 200,
|
|
30
|
+
relativeHeights: { a: 0.6, b: 0.4 }
|
|
31
|
+
}, react_1.default.createElement(Child, { key: "a", backgroundColor: "red" }), react_1.default.createElement(Child, { key: "b", backgroundColor: "green" }), react_1.default.createElement(Child, { key: "c", backgroundColor: "blue", height: 50 }));
|
|
32
|
+
// sample = React.createElement(LargeListComponent, {
|
|
33
|
+
// loadRows: (start, number, cb) =>
|
|
34
|
+
// # console.log start
|
|
35
|
+
// # console.log number
|
|
36
|
+
// setTimeout () =>
|
|
37
|
+
// cb(null, _.range(start, start + number))
|
|
38
|
+
// , 200
|
|
39
|
+
// renderRow: (row, index) -> R('div', style: { height: 25 }, key: index + "", "" + row)
|
|
40
|
+
// rowHeight: 25
|
|
41
|
+
// pageSize: 100
|
|
42
|
+
// height: 500
|
|
43
|
+
// rowCount: 10000
|
|
44
|
+
// bufferSize: 100
|
|
45
|
+
// })
|
|
46
|
+
return react_dom_1.default.render(sample, document.body);
|
|
47
|
+
});
|