@grafana/scenes 6.7.0--canary.1091.14350229100.0 → 6.8.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/CHANGELOG.md +25 -0
- package/dist/esm/components/layout/CSSGrid/SceneCSSGridItem.js +33 -0
- package/dist/esm/dist/esm/behaviors/CursorSync.js +76 -0
- package/dist/esm/dist/esm/behaviors/LiveNowTimer.js +44 -0
- package/dist/esm/dist/esm/behaviors/SceneQueryController.js +14 -0
- package/dist/esm/dist/esm/components/EmbeddedScene.js +59 -0
- package/dist/esm/dist/esm/components/NestedScene.js +95 -0
- package/dist/esm/dist/esm/components/SceneApp/SceneApp.js +27 -0
- package/dist/esm/dist/esm/components/SceneApp/SceneAppPage.js +176 -0
- package/dist/esm/dist/esm/components/SceneApp/SceneAppPageView.js +104 -0
- package/dist/esm/dist/esm/components/SceneApp/utils.js +42 -0
- package/dist/esm/dist/esm/components/SceneByFrameRepeater.js +41 -0
- package/dist/esm/dist/esm/components/SceneByVariableRepeater.js +55 -0
- package/dist/esm/dist/esm/components/SceneCanvasText.js +32 -0
- package/dist/esm/dist/esm/components/SceneControlsSpacer.js +17 -0
- package/dist/esm/dist/esm/components/SceneDebugger/DebugDetails.js +82 -0
- package/dist/esm/dist/esm/components/SceneDebugger/DebugTreeNode.js +72 -0
- package/dist/esm/dist/esm/components/SceneDebugger/SceneDebugger.js +77 -0
- package/dist/esm/dist/esm/components/SceneReactObject.js +34 -0
- package/dist/esm/dist/esm/components/SceneRefreshPicker.js +205 -0
- package/dist/esm/dist/esm/components/SceneTimePicker.js +139 -0
- package/dist/esm/dist/esm/components/SceneTimeRangeCompare.js +240 -0
- package/dist/esm/dist/esm/components/SceneToolbarButton.js +33 -0
- package/dist/esm/dist/esm/components/VizPanel/VizPanel.js +406 -0
- package/dist/esm/dist/esm/components/VizPanel/VizPanelExploreButton.js +44 -0
- package/dist/esm/dist/esm/components/VizPanel/VizPanelMenu.js +59 -0
- package/dist/esm/dist/esm/components/VizPanel/VizPanelRenderer.js +285 -0
- package/dist/esm/dist/esm/components/VizPanel/VizPanelSeriesLimit.js +45 -0
- package/dist/esm/dist/esm/components/VizPanel/colorSeriesConfigFactory.js +72 -0
- package/dist/esm/dist/esm/components/VizPanel/registerRuntimePanelPlugin.js +11 -0
- package/dist/esm/dist/esm/components/VizPanel/seriesVisibilityConfigFactory.js +164 -0
- package/dist/esm/dist/esm/components/layout/CSSGrid/SceneCSSGridLayout.js +124 -0
- package/dist/esm/dist/esm/components/layout/LazyLoader.js +103 -0
- package/dist/esm/dist/esm/components/layout/SceneFlexLayout.js +135 -0
- package/dist/esm/dist/esm/components/layout/grid/SceneGridItem.js +30 -0
- package/dist/esm/dist/esm/components/layout/grid/SceneGridLayout.js +283 -0
- package/dist/esm/dist/esm/components/layout/grid/SceneGridLayoutRenderer.js +178 -0
- package/dist/esm/dist/esm/components/layout/grid/SceneGridRow.js +190 -0
- package/dist/esm/dist/esm/components/layout/grid/constants.js +7 -0
- package/dist/esm/dist/esm/components/layout/grid/utils.js +36 -0
- package/dist/esm/dist/esm/components/layout/split/SplitLayout.js +17 -0
- package/dist/esm/dist/esm/components/layout/split/SplitLayoutRenderer.js +29 -0
- package/dist/esm/dist/esm/components/layout/split/Splitter.js +386 -0
- package/dist/esm/dist/esm/core/SceneComponentWrapper.js +57 -0
- package/dist/esm/dist/esm/core/SceneDataNode.js +43 -0
- package/dist/esm/dist/esm/core/SceneObjectBase.js +286 -0
- package/dist/esm/dist/esm/core/SceneObjectRef.js +32 -0
- package/dist/esm/dist/esm/core/SceneTimeRange.js +231 -0
- package/dist/esm/dist/esm/core/events.js +11 -0
- package/dist/esm/dist/esm/core/sceneGraph/getTimeRange.js +10 -0
- package/dist/esm/dist/esm/core/sceneGraph/index.js +25 -0
- package/dist/esm/dist/esm/core/sceneGraph/sceneGraph.js +178 -0
- package/dist/esm/dist/esm/core/sceneGraph/utils.js +64 -0
- package/dist/esm/dist/esm/core/types.js +15 -0
- package/dist/esm/dist/esm/querying/DataLayersMerger.js +46 -0
- package/dist/esm/dist/esm/querying/ExtraQueryProvider.js +6 -0
- package/dist/esm/dist/esm/querying/RuntimeDataSource.js +6 -0
- package/dist/esm/dist/esm/querying/SceneDataLayerSet.js +100 -0
- package/dist/esm/dist/esm/querying/SceneQueryRunner.js +468 -0
- package/dist/esm/dist/esm/querying/extraQueryProcessingOperator.js +46 -0
- package/dist/esm/dist/esm/querying/getEnrichedDataRequest.js +12 -0
- package/dist/esm/dist/esm/querying/layers/SceneDataLayerBase.js +112 -0
- package/dist/esm/dist/esm/querying/layers/SceneDataLayerControls.js +51 -0
- package/dist/esm/dist/esm/querying/layers/annotations/AnnotationsDataLayer.js +130 -0
- package/dist/esm/dist/esm/querying/layers/annotations/filterAnnotations.js +85 -0
- package/dist/esm/dist/esm/querying/layers/annotations/standardAnnotationQuery.js +121 -0
- package/dist/esm/dist/esm/querying/layers/annotations/standardAnnotationsSupport.js +211 -0
- package/dist/esm/dist/esm/querying/layers/annotations/utils.js +77 -0
- package/dist/esm/dist/esm/querying/registerQueryWithController.js +41 -0
- package/dist/esm/dist/esm/services/SceneObjectUrlSyncConfig.js +30 -0
- package/dist/esm/dist/esm/services/UniqueUrlKeyMapper.js +45 -0
- package/dist/esm/dist/esm/services/UrlSyncManager.js +167 -0
- package/dist/esm/dist/esm/services/useUrlSync.js +29 -0
- package/dist/esm/dist/esm/services/utils.js +71 -0
- package/dist/esm/dist/esm/utils/ControlsLabel.js +107 -0
- package/dist/esm/dist/esm/utils/LoadingIndicator.js +19 -0
- package/dist/esm/dist/esm/utils/SafeSerializableSceneObject.js +39 -0
- package/dist/esm/dist/esm/utils/compatibility/setWindowGrafanaSceneContext.js +16 -0
- package/dist/esm/dist/esm/utils/date.js +15 -0
- package/dist/esm/dist/esm/utils/evaluateTimeRange.js +16 -0
- package/dist/esm/dist/esm/utils/explore.js +47 -0
- package/dist/esm/dist/esm/utils/getCompareSeriesRefId.js +4 -0
- package/dist/esm/dist/esm/utils/getDataSource.js +18 -0
- package/dist/esm/dist/esm/utils/getMessageFromError.js +24 -0
- package/dist/esm/dist/esm/utils/metricTree.js +53 -0
- package/dist/esm/dist/esm/utils/parseUrlParam.js +41 -0
- package/dist/esm/dist/esm/utils/utils.js +11 -0
- package/dist/esm/dist/esm/utils/wrapInSafeSerializableSceneObject.js +30 -0
- package/dist/esm/dist/esm/utils/writeSceneLog.js +12 -0
- package/dist/esm/dist/esm/variables/VariableDependencyConfig.js +150 -0
- package/dist/esm/dist/esm/variables/VariableValueRecorder.js +71 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFilterBuilder.js +24 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFilterRenderer.js +303 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFilterPill.js +162 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersAlwaysWipCombobox.js +20 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersCombobox.js +640 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersComboboxRenderer.js +65 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/DropdownItem.js +146 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/MultiValuePill.js +114 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/useFloatingInteractions.js +68 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/utils.js +146 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersVariable.js +289 -0
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersVariableUrlSyncHandler.js +76 -0
- package/dist/esm/dist/esm/variables/adhoc/getAdhocOptionSearcher.js +13 -0
- package/dist/esm/dist/esm/variables/adhoc/patchGetAdhocFilters.js +47 -0
- package/dist/esm/dist/esm/variables/components/VariableValueControl.js +23 -0
- package/dist/esm/dist/esm/variables/components/VariableValueInput.js +33 -0
- package/dist/esm/dist/esm/variables/components/VariableValueSelect.js +228 -0
- package/dist/esm/dist/esm/variables/components/VariableValueSelectors.js +72 -0
- package/dist/esm/dist/esm/variables/components/getOptionSearcher.js +15 -0
- package/dist/esm/dist/esm/variables/constants.js +9 -0
- package/dist/esm/dist/esm/variables/getEnrichedFiltersRequest.js +12 -0
- package/dist/esm/dist/esm/variables/groupby/GroupByVariable.js +259 -0
- package/dist/esm/dist/esm/variables/groupby/GroupByVariableUrlSyncHandler.js +63 -0
- package/dist/esm/dist/esm/variables/groupby/findActiveGroupByVariablesByUid.js +13 -0
- package/dist/esm/dist/esm/variables/interpolation/ScopedVarsVariable.js +40 -0
- package/dist/esm/dist/esm/variables/interpolation/defaults.js +21 -0
- package/dist/esm/dist/esm/variables/interpolation/fieldAccessorCache.js +13 -0
- package/dist/esm/dist/esm/variables/interpolation/formatRegistry.js +296 -0
- package/dist/esm/dist/esm/variables/interpolation/sceneInterpolator.js +87 -0
- package/dist/esm/dist/esm/variables/lookupVariable.js +20 -0
- package/dist/esm/dist/esm/variables/macros/AllVariablesMacro.js +57 -0
- package/dist/esm/dist/esm/variables/macros/contextMacros.js +43 -0
- package/dist/esm/dist/esm/variables/macros/dataMacros.js +134 -0
- package/dist/esm/dist/esm/variables/macros/index.js +26 -0
- package/dist/esm/dist/esm/variables/macros/templateProxies.js +51 -0
- package/dist/esm/dist/esm/variables/macros/timeMacros.js +86 -0
- package/dist/esm/dist/esm/variables/macros/types.js +11 -0
- package/dist/esm/dist/esm/variables/macros/urlMacros.js +56 -0
- package/dist/esm/dist/esm/variables/sets/SceneVariableSet.js +254 -0
- package/dist/esm/dist/esm/variables/types.js +11 -0
- package/dist/esm/dist/esm/variables/utils.js +172 -0
- package/dist/esm/dist/esm/variables/variants/ConstantVariable.js +38 -0
- package/dist/esm/dist/esm/variables/variants/CustomVariable.js +60 -0
- package/dist/esm/dist/esm/variables/variants/DataSourceVariable.js +88 -0
- package/dist/esm/dist/esm/variables/variants/IntervalVariable.js +117 -0
- package/dist/esm/dist/esm/variables/variants/MultiValueVariable.js +295 -0
- package/dist/esm/dist/esm/variables/variants/TestVariable.js +117 -0
- package/dist/esm/dist/esm/variables/variants/TextBoxVariable.js +61 -0
- package/dist/esm/dist/esm/variables/variants/query/QueryVariable.js +139 -0
- package/dist/esm/dist/esm/variables/variants/query/createQueryVariableRunner.js +129 -0
- package/dist/esm/dist/esm/variables/variants/query/guards.js +28 -0
- package/dist/esm/dist/esm/variables/variants/query/toMetricFindValues.js +96 -0
- package/dist/esm/dist/esm/variables/variants/query/utils.js +124 -0
- package/dist/esm/index.js +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/querying/DataProviderSharer.js +39 -0
- package/dist/esm/src/behaviors/ActWhenVariableChanged.js +27 -0
- package/dist/esm/src/behaviors/CursorSync.js +76 -0
- package/dist/esm/src/behaviors/LiveNowTimer.js +44 -0
- package/dist/esm/src/behaviors/SceneQueryController.js +60 -0
- package/dist/esm/src/behaviors/index.js +5 -0
- package/dist/esm/src/components/EmbeddedScene.js +59 -0
- package/dist/esm/src/components/NestedScene.js +95 -0
- package/dist/esm/src/components/SceneApp/SceneApp.js +37 -0
- package/dist/esm/src/components/SceneApp/SceneAppPage.js +176 -0
- package/dist/esm/src/components/SceneApp/SceneAppPageView.js +104 -0
- package/dist/esm/src/components/SceneApp/utils.js +42 -0
- package/dist/esm/src/components/SceneByFrameRepeater.js +41 -0
- package/dist/esm/src/components/SceneByVariableRepeater.js +55 -0
- package/dist/esm/src/components/SceneCanvasText.js +32 -0
- package/dist/esm/src/components/SceneControlsSpacer.js +17 -0
- package/dist/esm/src/components/SceneDebugger/DebugDetails.js +82 -0
- package/dist/esm/src/components/SceneDebugger/DebugTreeNode.js +72 -0
- package/dist/esm/src/components/SceneDebugger/SceneDebugger.js +77 -0
- package/dist/esm/src/components/SceneReactObject.js +34 -0
- package/dist/esm/src/components/SceneRefreshPicker.js +205 -0
- package/dist/esm/src/components/SceneTimePicker.js +139 -0
- package/dist/esm/src/components/SceneTimeRangeCompare.js +240 -0
- package/dist/esm/src/components/SceneToolbarButton.js +33 -0
- package/dist/esm/src/components/VizPanel/VizPanel.js +406 -0
- package/dist/esm/src/components/VizPanel/VizPanelExploreButton.js +44 -0
- package/dist/esm/src/components/VizPanel/VizPanelMenu.js +59 -0
- package/dist/esm/src/components/VizPanel/VizPanelRenderer.js +285 -0
- package/dist/esm/src/components/VizPanel/VizPanelSeriesLimit.js +45 -0
- package/dist/esm/src/components/VizPanel/colorSeriesConfigFactory.js +72 -0
- package/dist/esm/src/components/VizPanel/registerRuntimePanelPlugin.js +56 -0
- package/dist/esm/src/components/VizPanel/seriesVisibilityConfigFactory.js +164 -0
- package/dist/esm/src/components/layout/CSSGrid/SceneCSSGridLayout.js +124 -0
- package/dist/esm/src/components/layout/LazyLoader.js +103 -0
- package/dist/esm/src/components/layout/SceneFlexLayout.js +135 -0
- package/dist/esm/src/components/layout/grid/SceneGridItem.js +30 -0
- package/dist/esm/src/components/layout/grid/SceneGridLayout.js +283 -0
- package/dist/esm/src/components/layout/grid/SceneGridLayoutRenderer.js +178 -0
- package/dist/esm/src/components/layout/grid/SceneGridRow.js +190 -0
- package/dist/esm/src/components/layout/grid/constants.js +7 -0
- package/dist/esm/src/components/layout/grid/utils.js +36 -0
- package/dist/esm/src/components/layout/split/SplitLayout.js +17 -0
- package/dist/esm/src/components/layout/split/SplitLayoutRenderer.js +29 -0
- package/dist/esm/src/components/layout/split/Splitter.js +386 -0
- package/dist/esm/src/core/PanelBuilders/FieldConfigBuilder.js +100 -0
- package/dist/esm/src/core/PanelBuilders/FieldConfigBuilders.js +75 -0
- package/dist/esm/src/core/PanelBuilders/FieldConfigOverridesBuilder.js +75 -0
- package/dist/esm/src/core/PanelBuilders/PanelOptionsBuilder.js +22 -0
- package/dist/esm/src/core/PanelBuilders/PanelOptionsBuilders.js +85 -0
- package/dist/esm/src/core/PanelBuilders/StandardFieldConfigBuilders.js +52 -0
- package/dist/esm/src/core/PanelBuilders/VizConfigBuilder.js +78 -0
- package/dist/esm/src/core/PanelBuilders/VizConfigBuilders.js +114 -0
- package/dist/esm/src/core/PanelBuilders/VizPanelBuilder.js +162 -0
- package/dist/esm/src/core/PanelBuilders/index.js +116 -0
- package/dist/esm/src/core/SceneComponentWrapper.js +57 -0
- package/dist/esm/src/core/SceneDataNode.js +43 -0
- package/dist/esm/src/core/SceneObjectBase.js +286 -0
- package/dist/esm/src/core/SceneObjectRef.js +32 -0
- package/dist/esm/src/core/SceneTimeRange.js +231 -0
- package/dist/esm/src/core/SceneTimeRangeTransformerBase.js +35 -0
- package/dist/esm/src/core/SceneTimeZoneOverride.js +63 -0
- package/dist/esm/src/core/events.js +11 -0
- package/dist/esm/src/core/sceneGraph/getTimeRange.js +10 -0
- package/dist/esm/src/core/sceneGraph/index.js +25 -0
- package/dist/esm/src/core/sceneGraph/sceneGraph.js +178 -0
- package/dist/esm/src/core/sceneGraph/utils.js +64 -0
- package/dist/esm/src/core/types.js +15 -0
- package/dist/esm/src/index.js +108 -0
- package/dist/esm/src/querying/DataLayersMerger.js +46 -0
- package/dist/esm/src/querying/DataProviderProxy.js +37 -0
- package/dist/esm/src/querying/DataProviderSharer.js +108 -0
- package/dist/esm/src/querying/ExtraQueryProvider.js +6 -0
- package/dist/esm/src/querying/RuntimeDataSource.js +49 -0
- package/dist/esm/src/querying/SceneDataLayerSet.js +100 -0
- package/dist/esm/src/querying/SceneDataTransformer.js +178 -0
- package/dist/esm/src/querying/SceneQueryRunner.js +468 -0
- package/dist/esm/src/querying/extraQueryProcessingOperator.js +46 -0
- package/dist/esm/src/querying/getEnrichedDataRequest.js +12 -0
- package/dist/esm/src/querying/layers/SceneDataLayerBase.js +112 -0
- package/dist/esm/src/querying/layers/SceneDataLayerControls.js +51 -0
- package/dist/esm/src/querying/layers/annotations/AnnotationsDataLayer.js +130 -0
- package/dist/esm/src/querying/layers/annotations/filterAnnotations.js +85 -0
- package/dist/esm/src/querying/layers/annotations/standardAnnotationQuery.js +121 -0
- package/dist/esm/src/querying/layers/annotations/standardAnnotationsSupport.js +211 -0
- package/dist/esm/src/querying/layers/annotations/utils.js +77 -0
- package/dist/esm/src/querying/layers/index.js +2 -0
- package/dist/esm/src/querying/registerQueryWithController.js +41 -0
- package/dist/esm/src/services/SceneObjectUrlSyncConfig.js +30 -0
- package/dist/esm/src/services/UniqueUrlKeyMapper.js +45 -0
- package/dist/esm/src/services/UrlSyncContextProvider.js +17 -0
- package/dist/esm/src/services/UrlSyncManager.js +167 -0
- package/dist/esm/src/services/useUrlSync.js +29 -0
- package/dist/esm/src/services/utils.js +75 -0
- package/dist/esm/src/utils/ControlsLabel.js +107 -0
- package/dist/esm/src/utils/LoadingIndicator.js +19 -0
- package/dist/esm/src/utils/SafeSerializableSceneObject.js +39 -0
- package/dist/esm/src/utils/compatibility/setWindowGrafanaSceneContext.js +16 -0
- package/dist/esm/src/utils/date.js +15 -0
- package/dist/esm/src/utils/evaluateTimeRange.js +16 -0
- package/dist/esm/src/utils/explore.js +47 -0
- package/dist/esm/src/utils/getCompareSeriesRefId.js +4 -0
- package/dist/esm/src/utils/getDataSource.js +18 -0
- package/dist/esm/src/utils/getMessageFromError.js +24 -0
- package/dist/esm/src/utils/metricTree.js +53 -0
- package/dist/esm/src/utils/parseUrlParam.js +41 -0
- package/dist/esm/src/utils/utils.js +11 -0
- package/dist/esm/src/utils/wrapInSafeSerializableSceneObject.js +30 -0
- package/dist/esm/src/utils/writeSceneLog.js +12 -0
- package/dist/esm/src/variables/VariableDependencyConfig.js +150 -0
- package/dist/esm/src/variables/VariableValueRecorder.js +71 -0
- package/dist/esm/src/variables/adhoc/AdHocFilterBuilder.js +24 -0
- package/dist/esm/src/variables/adhoc/AdHocFilterRenderer.js +303 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFilterPill.js +162 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersAlwaysWipCombobox.js +20 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersCombobox.js +640 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersComboboxRenderer.js +65 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/DropdownItem.js +146 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/MultiValuePill.js +114 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/useFloatingInteractions.js +68 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/utils.js +146 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersVariable.js +289 -0
- package/dist/esm/src/variables/adhoc/AdHocFiltersVariableUrlSyncHandler.js +76 -0
- package/dist/esm/src/variables/adhoc/getAdhocOptionSearcher.js +13 -0
- package/dist/esm/src/variables/adhoc/patchGetAdhocFilters.js +47 -0
- package/dist/esm/src/variables/components/VariableValueControl.js +23 -0
- package/dist/esm/src/variables/components/VariableValueInput.js +33 -0
- package/dist/esm/src/variables/components/VariableValueSelect.js +228 -0
- package/dist/esm/src/variables/components/VariableValueSelectors.js +72 -0
- package/dist/esm/src/variables/components/getOptionSearcher.js +15 -0
- package/dist/esm/src/variables/constants.js +9 -0
- package/dist/esm/src/variables/getEnrichedFiltersRequest.js +12 -0
- package/dist/esm/src/variables/groupby/GroupByVariable.js +259 -0
- package/dist/esm/src/variables/groupby/GroupByVariableUrlSyncHandler.js +63 -0
- package/dist/esm/src/variables/groupby/findActiveGroupByVariablesByUid.js +13 -0
- package/dist/esm/src/variables/interpolation/ScopedVarsVariable.js +40 -0
- package/dist/esm/src/variables/interpolation/defaults.js +21 -0
- package/dist/esm/src/variables/interpolation/fieldAccessorCache.js +13 -0
- package/dist/esm/src/variables/interpolation/formatRegistry.js +296 -0
- package/dist/esm/src/variables/interpolation/sceneInterpolator.js +87 -0
- package/dist/esm/src/variables/lookupVariable.js +20 -0
- package/dist/esm/src/variables/macros/AllVariablesMacro.js +57 -0
- package/dist/esm/src/variables/macros/contextMacros.js +43 -0
- package/dist/esm/src/variables/macros/dataMacros.js +134 -0
- package/dist/esm/src/variables/macros/index.js +35 -0
- package/dist/esm/src/variables/macros/templateProxies.js +51 -0
- package/dist/esm/src/variables/macros/timeMacros.js +86 -0
- package/dist/esm/src/variables/macros/types.js +11 -0
- package/dist/esm/src/variables/macros/urlMacros.js +56 -0
- package/dist/esm/src/variables/sets/SceneVariableSet.js +254 -0
- package/dist/esm/src/variables/types.js +11 -0
- package/dist/esm/src/variables/utils.js +172 -0
- package/dist/esm/src/variables/variants/ConstantVariable.js +38 -0
- package/dist/esm/src/variables/variants/CustomVariable.js +60 -0
- package/dist/esm/src/variables/variants/DataSourceVariable.js +88 -0
- package/dist/esm/src/variables/variants/IntervalVariable.js +117 -0
- package/dist/esm/src/variables/variants/JsonVariable.js +193 -0
- package/dist/esm/src/variables/variants/LocalValueVariable.js +56 -0
- package/dist/esm/src/variables/variants/MultiValueVariable.js +295 -0
- package/dist/esm/src/variables/variants/TestVariable.js +117 -0
- package/dist/esm/src/variables/variants/TextBoxVariable.js +61 -0
- package/dist/esm/src/variables/variants/guards.js +27 -0
- package/dist/esm/src/variables/variants/query/QueryVariable.js +139 -0
- package/dist/esm/src/variables/variants/query/createQueryVariableRunner.js +129 -0
- package/dist/esm/src/variables/variants/query/guards.js +28 -0
- package/dist/esm/src/variables/variants/query/toMetricFindValues.js +96 -0
- package/dist/esm/src/variables/variants/query/utils.js +124 -0
- package/dist/esm/variables/components/VariableValueSelect.js +13 -9
- package/dist/esm/variables/components/VariableValueSelect.js.map +1 -1
- package/dist/esm/variables/variants/ConstantVariable.js +22 -0
- package/dist/esm/variables/variants/ConstantVariable.js.map +1 -1
- package/dist/esm/variables/variants/CustomVariable.js +3 -2
- package/dist/esm/variables/variants/CustomVariable.js.map +1 -1
- package/dist/esm/variables/variants/DataSourceVariable.js +3 -2
- package/dist/esm/variables/variants/DataSourceVariable.js.map +1 -1
- package/dist/esm/variables/variants/JsonVariable.js +96 -0
- package/dist/esm/variables/variants/TestVariable.js +3 -2
- package/dist/esm/variables/variants/TestVariable.js.map +1 -1
- package/dist/esm/variables/variants/json/JsonVariable.js +95 -0
- package/dist/esm/variables/variants/json/JsonVariableOptionProviders.js +70 -0
- package/dist/esm/variables/variants/query/QueryVariable.js +3 -2
- package/dist/esm/variables/variants/query/QueryVariable.js.map +1 -1
- package/dist/index.d.ts +14 -6
- package/dist/index.js +35 -13
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Splitter } from './Splitter.js';
|
|
3
|
+
|
|
4
|
+
function SplitLayoutRenderer({ model }) {
|
|
5
|
+
const { primary, secondary, direction, isHidden, initialSize, primaryPaneStyles, secondaryPaneStyles } = model.useState();
|
|
6
|
+
if (isHidden) {
|
|
7
|
+
return null;
|
|
8
|
+
}
|
|
9
|
+
const Prim = primary.Component;
|
|
10
|
+
const Sec = secondary == null ? void 0 : secondary.Component;
|
|
11
|
+
let startSize = secondary ? initialSize : 1;
|
|
12
|
+
return /* @__PURE__ */ React.createElement(Splitter, {
|
|
13
|
+
direction,
|
|
14
|
+
initialSize: startSize != null ? startSize : 0.5,
|
|
15
|
+
primaryPaneStyles,
|
|
16
|
+
secondaryPaneStyles
|
|
17
|
+
}, /* @__PURE__ */ React.createElement(Prim, {
|
|
18
|
+
key: primary.state.key,
|
|
19
|
+
model: primary,
|
|
20
|
+
parentState: model.state
|
|
21
|
+
}), Sec && secondary && /* @__PURE__ */ React.createElement(Sec, {
|
|
22
|
+
key: secondary.state.key,
|
|
23
|
+
model: secondary,
|
|
24
|
+
parentState: model.state
|
|
25
|
+
}));
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export { SplitLayoutRenderer };
|
|
29
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3BsaXRMYXlvdXRSZW5kZXJlci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vY29tcG9uZW50cy9sYXlvdXQvc3BsaXQvU3BsaXRMYXlvdXRSZW5kZXJlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgU3BsaXR0ZXIgfSBmcm9tICcuL1NwbGl0dGVyLmpzJztcblxuZnVuY3Rpb24gU3BsaXRMYXlvdXRSZW5kZXJlcih7IG1vZGVsIH0pIHtcbiAgY29uc3QgeyBwcmltYXJ5LCBzZWNvbmRhcnksIGRpcmVjdGlvbiwgaXNIaWRkZW4sIGluaXRpYWxTaXplLCBwcmltYXJ5UGFuZVN0eWxlcywgc2Vjb25kYXJ5UGFuZVN0eWxlcyB9ID0gbW9kZWwudXNlU3RhdGUoKTtcbiAgaWYgKGlzSGlkZGVuKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cbiAgY29uc3QgUHJpbSA9IHByaW1hcnkuQ29tcG9uZW50O1xuICBjb25zdCBTZWMgPSBzZWNvbmRhcnkgPT0gbnVsbCA/IHZvaWQgMCA6IHNlY29uZGFyeS5Db21wb25lbnQ7XG4gIGxldCBzdGFydFNpemUgPSBzZWNvbmRhcnkgPyBpbml0aWFsU2l6ZSA6IDE7XG4gIHJldHVybiAvKiBAX19QVVJFX18gKi8gUmVhY3QuY3JlYXRlRWxlbWVudChTcGxpdHRlciwge1xuICAgIGRpcmVjdGlvbixcbiAgICBpbml0aWFsU2l6ZTogc3RhcnRTaXplICE9IG51bGwgPyBzdGFydFNpemUgOiAwLjUsXG4gICAgcHJpbWFyeVBhbmVTdHlsZXMsXG4gICAgc2Vjb25kYXJ5UGFuZVN0eWxlc1xuICB9LCAvKiBAX19QVVJFX18gKi8gUmVhY3QuY3JlYXRlRWxlbWVudChQcmltLCB7XG4gICAga2V5OiBwcmltYXJ5LnN0YXRlLmtleSxcbiAgICBtb2RlbDogcHJpbWFyeSxcbiAgICBwYXJlbnRTdGF0ZTogbW9kZWwuc3RhdGVcbiAgfSksIFNlYyAmJiBzZWNvbmRhcnkgJiYgLyogQF9fUFVSRV9fICovIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VjLCB7XG4gICAga2V5OiBzZWNvbmRhcnkuc3RhdGUua2V5LFxuICAgIG1vZGVsOiBzZWNvbmRhcnksXG4gICAgcGFyZW50U3RhdGU6IG1vZGVsLnN0YXRlXG4gIH0pKTtcbn1cblxuZXhwb3J0IHsgU3BsaXRMYXlvdXRSZW5kZXJlciB9O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGF0YTphcHBsaWNhdGlvbi9qc29uO2NoYXJzZXQ9dXRmLTg7YmFzZTY0LGV5SjJaWEp6YVc5dUlqb3pMQ0ptYVd4bElqb2lVM0JzYVhSTVlYbHZkWFJTWlc1a1pYSmxjaTVxY3lJc0luTnZkWEpqWlhNaU9sc2lMaTR2TGk0dkxpNHZMaTR2TGk0dmMzSmpMMk52YlhCdmJtVnVkSE12YkdGNWIzVjBMM053YkdsMEwxTndiR2wwVEdGNWIzVjBVbVZ1WkdWeVpYSXVkSE40SWwwc0luTnZkWEpqWlhORGIyNTBaVzUwSWpwYkltbHRjRzl5ZENCU1pXRmpkQ3dnZXlCRGIyMXdiMjVsYm5SVWVYQmxJSDBnWm5KdmJTQW5jbVZoWTNRbk8xeHVYRzVwYlhCdmNuUWdleUJUWTJWdVpVTnZiWEJ2Ym1WdWRGQnliM0J6TENCVFkyVnVaVTlpYW1WamRGTjBZWFJsTENCVFkyVnVaVTlpYW1WamRDQjlJR1p5YjIwZ0p5NHVMeTR1THk0dUwyTnZjbVV2ZEhsd1pYTW5PMXh1YVcxd2IzSjBJSHNnVTJObGJtVkdiR1Y0U1hSbGJWQnNZV05sYldWdWRDQjlJR1p5YjIwZ0p5NHVMMU5qWlc1bFJteGxlRXhoZVc5MWRDYzdYRzVwYlhCdmNuUWdleUJUY0d4cGRFeGhlVzkxZENCOUlHWnliMjBnSnk0dlUzQnNhWFJNWVhsdmRYUW5PMXh1YVcxd2IzSjBJSHNnVTNCc2FYUjBaWElnZlNCbWNtOXRJQ2N1TDFOd2JHbDBkR1Z5Snp0Y2JseHVaWGh3YjNKMElHWjFibU4wYVc5dUlGTndiR2wwVEdGNWIzVjBVbVZ1WkdWeVpYSW9leUJ0YjJSbGJDQjlPaUJUWTJWdVpVWnNaWGhKZEdWdFVtVnVaR1Z5VUhKdmNITThVM0JzYVhSTVlYbHZkWFErS1NCN1hHNGdJR052Ym5OMElIc2djSEpwYldGeWVTd2djMlZqYjI1a1lYSjVMQ0JrYVhKbFkzUnBiMjRzSUdselNHbGtaR1Z1TENCcGJtbDBhV0ZzVTJsNlpTd2djSEpwYldGeWVWQmhibVZUZEhsc1pYTXNJSE5sWTI5dVpHRnllVkJoYm1WVGRIbHNaWE1nZlNBOVhHNGdJQ0FnYlc5a1pXd3VkWE5sVTNSaGRHVW9LVHRjYmx4dUlDQnBaaUFvYVhOSWFXUmtaVzRwSUh0Y2JpQWdJQ0J5WlhSMWNtNGdiblZzYkR0Y2JpQWdmVnh1WEc0Z0lHTnZibk4wSUZCeWFXMGdQU0J3Y21sdFlYSjVMa052YlhCdmJtVnVkQ0JoY3lCRGIyMXdiMjVsYm5SVWVYQmxQRk5qWlc1bFJteGxlRWwwWlcxU1pXNWtaWEpRY205d2N6eFRZMlZ1WlU5aWFtVmpkRDQrTzF4dUlDQmpiMjV6ZENCVFpXTWdQU0J6WldOdmJtUmhjbmsvTGtOdmJYQnZibVZ1ZENCaGN5QkRiMjF3YjI1bGJuUlVlWEJsUEZOalpXNWxSbXhsZUVsMFpXMVNaVzVrWlhKUWNtOXdjenhUWTJWdVpVOWlhbVZqZEQ0K08xeHVJQ0JzWlhRZ2MzUmhjblJUYVhwbElEMGdjMlZqYjI1a1lYSjVJRDhnYVc1cGRHbGhiRk5wZW1VZ09pQXhPMXh1WEc0Z0lISmxkSFZ5YmlBb1hHNGdJQ0FnUEZOd2JHbDBkR1Z5WEc0Z0lDQWdJQ0JrYVhKbFkzUnBiMjQ5ZTJScGNtVmpkR2x2Ym4xY2JpQWdJQ0FnSUdsdWFYUnBZV3hUYVhwbFBYdHpkR0Z5ZEZOcGVtVWdQejhnTUM0MWZWeHVJQ0FnSUNBZ2NISnBiV0Z5ZVZCaGJtVlRkSGxzWlhNOWUzQnlhVzFoY25sUVlXNWxVM1I1YkdWemZWeHVJQ0FnSUNBZ2MyVmpiMjVrWVhKNVVHRnVaVk4wZVd4bGN6MTdjMlZqYjI1a1lYSjVVR0Z1WlZOMGVXeGxjMzFjYmlBZ0lDQStYRzRnSUNBZ0lDQThVSEpwYlNCclpYazllM0J5YVcxaGNua3VjM1JoZEdVdWEyVjVmU0J0YjJSbGJEMTdjSEpwYldGeWVYMGdjR0Z5Wlc1MFUzUmhkR1U5ZTIxdlpHVnNMbk4wWVhSbGZTQXZQbHh1SUNBZ0lDQWdlMU5sWXlBbUppQnpaV052Ym1SaGNua2dKaVlnUEZObFl5QnJaWGs5ZTNObFkyOXVaR0Z5ZVM1emRHRjBaUzVyWlhsOUlHMXZaR1ZzUFh0elpXTnZibVJoY25sOUlIQmhjbVZ1ZEZOMFlYUmxQWHR0YjJSbGJDNXpkR0YwWlgwZ0x6NTlYRzRnSUNBZ1BDOVRjR3hwZEhSbGNqNWNiaUFnS1R0Y2JuMWNibHh1Wlhod2IzSjBJR2x1ZEdWeVptRmpaU0JUWTJWdVpVWnNaWGhKZEdWdFUzUmhkR1VnWlhoMFpXNWtjeUJUWTJWdVpVWnNaWGhKZEdWdFVHeGhZMlZ0Wlc1MExDQlRZMlZ1WlU5aWFtVmpkRk4wWVhSbElIdGNiaUFnWW05a2VUb2dVMk5sYm1WUFltcGxZM1FnZkNCMWJtUmxabWx1WldRN1hHNTlYRzVjYm1sdWRHVnlabUZqWlNCVFkyVnVaVVpzWlhoSmRHVnRVbVZ1WkdWeVVISnZjSE04VkQ0Z1pYaDBaVzVrY3lCVFkyVnVaVU52YlhCdmJtVnVkRkJ5YjNCelBGUStJSHRjYmlBZ2NHRnlaVzUwVTNSaGRHVS9PaUJUWTJWdVpVWnNaWGhKZEdWdFVHeGhZMlZ0Wlc1ME8xeHVmVnh1SWwwc0ltNWhiV1Z6SWpwYlhTd2liV0Z3Y0dsdVozTWlPaUk3T3p0QlFVOW5RaXhUUVVGQkxHMUNRVUZCTEVOQlFXOUNMRVZCUVVVc1MwRkJRU3hGUVVGblJDeEZRVUZCTzBGQlEzQkdMRVZCUVUwc1RVRkJRU3hGUVVGRkxFOUJRVk1zUlVGQlFTeFRRVUZCTEVWQlFWY3NVMEZCVnl4RlFVRkJMRkZCUVVFc1JVRkJWU3hoUVVGaExHbENRVUZ0UWl4RlFVRkJMRzFDUVVGQkxFVkJReTlGTEVkQlFVRXNTMEZCUVN4RFFVRk5MRkZCUVZNc1JVRkJRU3hEUVVGQk8wRkJSV3BDTEVWQlFVRXNTVUZCU1N4UlFVRlZMRVZCUVVFN1FVRkRXaXhKUVVGUExFOUJRVUVzU1VGQlFTeERRVUZCTzBGQlFVRXNSMEZEVkR0QlFVVkJMRVZCUVVFc1RVRkJUU3hQUVVGUExFOUJRVkVzUTBGQlFTeFRRVUZCTEVOQlFVRTdRVUZEY2tJc1JVRkJRU3hOUVVGTkxFMUJRVTBzVTBGQlZ5eEpRVUZCTEVsQlFVRXNSMEZCUVN4TFFVRkJMRU5CUVVFc1IwRkJRU3hUUVVGQkxFTkJRVUVzVTBGQlFTeERRVUZCTzBGQlEzWkNMRVZCUVVrc1NVRkJRU3hUUVVGQkxFZEJRVmtzV1VGQldTeFhRVUZqTEVkQlFVRXNRMEZCUVN4RFFVRkJPMEZCUlRGRExFVkJRVUVzZFVKQlEwY3NTMEZCUVN4RFFVRkJMR0ZCUVVFc1EwRkJRU3hSUVVGQkxFVkJRVUU3UVVGQlFTeEpRVU5ETEZOQlFVRTdRVUZCUVN4SlFVTkJMR0ZCUVdFc1UwRkJZU3hKUVVGQkxFbEJRVUVzUjBGQlFTeFRRVUZCTEVkQlFVRXNSMEZCUVR0QlFVRkJMRWxCUXpGQ0xHbENRVUZCTzBGQlFVRXNTVUZEUVN4dFFrRkJRVHRCUVVGQkxFZEJRVUVzYTBKQlJVTXNTMEZCUVN4RFFVRkJMR0ZCUVVFc1EwRkJRU3hKUVVGQkxFVkJRVUU3UVVGQlFTeEpRVUZMTEVkQlFVRXNSVUZCU3l4UlFVRlJMRXRCUVUwc1EwRkJRU3hIUVVGQk8wRkJRVUVzU1VGQlN5eExRVUZQTEVWQlFVRXNUMEZCUVR0QlFVRkJMRWxCUVZNc1lVRkJZU3hMUVVGTkxFTkJRVUVzUzBGQlFUdEJRVUZCTEVkQlFVOHNRMEZCUVN4RlFVTjJSU3hIUVVGUExFbEJRVUVzVTBGQlFTeHZRa0ZCWXl4TFFVRkJMRU5CUVVFc1lVRkJRU3hEUVVGQkxFZEJRVUVzUlVGQlFUdEJRVUZCTEVsQlFVa3NSMEZCUVN4RlFVRkxMRlZCUVZVc1MwRkJUU3hEUVVGQkxFZEJRVUU3UVVGQlFTeEpRVUZMTEV0QlFVOHNSVUZCUVN4VFFVRkJPMEZCUVVFc1NVRkJWeXhoUVVGaExFdEJRVTBzUTBGQlFTeExRVUZCTzBGQlFVRXNSMEZCVHl4RFFVTnNSeXhEUVVGQkxFTkJRVUU3UVVGRlNqczdPenNpZlE9PVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQU9nQixTQUFBLG1CQUFBLENBQW9CLEVBQUUsS0FBQSxFQUFnRCxFQUFBO0FBQzlFLEVBQUEsTUFBQSxFQUFFLE9BQVMsRUFBQSxTQUFBLEVBQVcsU0FBVyxFQUFBLFFBQUEsRUFBVSxhQUFhLGlCQUFtQixFQUFBLG1CQUFBLEVBQy9FLEdBQUEsS0FBQSxDQUFNLFFBQVMsRUFBQSxDQUFBO0FBRWpCLEVBQUEsSUFBSSxRQUFVLEVBQUE7QUFDTCxJQUFBLE9BQUEsSUFBQSxDQUFBO0FBQUEsR0FBQTtBQUdULEVBQUEsTUFBTSxPQUFPLE9BQVEsQ0FBQSxTQUFBLENBQUE7QUFDckIsRUFBQSxNQUFNLEdBQU0sR0FBQSxTQUFBLElBQVcsSUFBQSxHQUFBLEtBQUEsQ0FBQSxHQUFBLFNBQUEsQ0FBQSxTQUFBLENBQUE7QUFDbkIsRUFBQSxJQUFBLFNBQUEsR0FBWSxZQUFZLFdBQWMsR0FBQSxDQUFBLENBQUE7QUFFMUMsRUFDRyx1QkFBQSxLQUFBLENBQUEsY0FBQSxRQUFBLEVBQUE7QUFDQyxJQUFBLFNBQUE7SUFDQSxXQUFhLEVBQUEsU0FBQSxJQUFhLE9BQUEsU0FBQSxHQUFBLEdBQUE7QUFDMUIsSUFBQSxpQkFBQTtBQUNBLElBQUEsbUJBQUE7R0FFQyxrQkFBQSxLQUFBLENBQUEsY0FBQSxJQUFBLEVBQUE7QUFBSyxJQUFBLEdBQUEsRUFBSyxRQUFRLEtBQU0sQ0FBQSxHQUFBO0lBQUssS0FBTyxFQUFBLE9BQUE7QUFBUyxJQUFBLFdBQUEsRUFBYSxLQUFNLENBQUEsS0FBQTtBQUFBLEdBQU8sQ0FDdkUsRUFBQSxHQUFBLElBQU8sU0FBYyxvQkFBQSxLQUFBLENBQUEsY0FBQSxHQUFBLEVBQUE7QUFBSSxJQUFBLEdBQUEsRUFBSyxVQUFVLEtBQU0sQ0FBQSxHQUFBO0lBQUssS0FBTyxFQUFBLFNBQUE7QUFBVyxJQUFBLFdBQUEsRUFBYSxLQUFNLENBQUEsS0FBQTtBQUFBLEdBQU8sQ0FDbEcsQ0FBQSxDQUFBO0FBRUo7Ozs7In0=
|
|
@@ -0,0 +1,386 @@
|
|
|
1
|
+
import { cx, css } from '@emotion/css';
|
|
2
|
+
import { useStyles2 } from '@grafana/ui';
|
|
3
|
+
import { clamp, throttle } from 'lodash';
|
|
4
|
+
import React, { useRef, useCallback, useLayoutEffect } from 'react';
|
|
5
|
+
import { useUniqueId } from '../LazyLoader.js';
|
|
6
|
+
|
|
7
|
+
var __defProp = Object.defineProperty;
|
|
8
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
9
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
10
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
11
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
+
var __spreadValues = (a, b) => {
|
|
13
|
+
for (var prop in b || (b = {}))
|
|
14
|
+
if (__hasOwnProp.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
if (__getOwnPropSymbols)
|
|
17
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
18
|
+
if (__propIsEnum.call(b, prop))
|
|
19
|
+
__defNormalProp(a, prop, b[prop]);
|
|
20
|
+
}
|
|
21
|
+
return a;
|
|
22
|
+
};
|
|
23
|
+
const PIXELS_PER_MS = 0.3;
|
|
24
|
+
const VERTICAL_KEYS = /* @__PURE__ */ new Set(["ArrowUp", "ArrowDown"]);
|
|
25
|
+
const HORIZONTAL_KEYS = /* @__PURE__ */ new Set(["ArrowLeft", "ArrowRight"]);
|
|
26
|
+
const propsForDirection = {
|
|
27
|
+
row: {
|
|
28
|
+
dim: "width",
|
|
29
|
+
axis: "clientX",
|
|
30
|
+
min: "minWidth",
|
|
31
|
+
max: "maxWidth"
|
|
32
|
+
},
|
|
33
|
+
column: {
|
|
34
|
+
dim: "height",
|
|
35
|
+
axis: "clientY",
|
|
36
|
+
min: "minHeight",
|
|
37
|
+
max: "maxHeight"
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
function Splitter({
|
|
41
|
+
direction = "row",
|
|
42
|
+
handleSize = 32,
|
|
43
|
+
initialSize = "auto",
|
|
44
|
+
primaryPaneStyles,
|
|
45
|
+
secondaryPaneStyles,
|
|
46
|
+
onDragFinished,
|
|
47
|
+
children
|
|
48
|
+
}) {
|
|
49
|
+
const kids = React.Children.toArray(children);
|
|
50
|
+
const splitterRef = useRef(null);
|
|
51
|
+
const firstPaneRef = useRef(null);
|
|
52
|
+
const secondPaneRef = useRef(null);
|
|
53
|
+
const containerRef = useRef(null);
|
|
54
|
+
const containerSize = useRef(null);
|
|
55
|
+
const primarySizeRef = useRef("1fr");
|
|
56
|
+
const firstPaneMeasurements = useRef(void 0);
|
|
57
|
+
const savedPos = useRef(void 0);
|
|
58
|
+
const measurementProp = propsForDirection[direction].dim;
|
|
59
|
+
const clientAxis = propsForDirection[direction].axis;
|
|
60
|
+
const minDimProp = propsForDirection[direction].min;
|
|
61
|
+
const maxDimProp = propsForDirection[direction].max;
|
|
62
|
+
useResizeObserver(
|
|
63
|
+
containerRef.current,
|
|
64
|
+
(entries) => {
|
|
65
|
+
for (const entry of entries) {
|
|
66
|
+
if (!entry.target.isSameNode(containerRef.current)) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
const curSize = firstPaneRef.current.getBoundingClientRect()[measurementProp];
|
|
70
|
+
const newDims = measureElement(firstPaneRef.current);
|
|
71
|
+
splitterRef.current.ariaValueNow = `${clamp(
|
|
72
|
+
(curSize - newDims[minDimProp]) / (newDims[maxDimProp] - newDims[minDimProp]) * 100,
|
|
73
|
+
0,
|
|
74
|
+
100
|
|
75
|
+
)}`;
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
500,
|
|
79
|
+
[maxDimProp, minDimProp, direction, measurementProp]
|
|
80
|
+
);
|
|
81
|
+
const dragStart = useRef(null);
|
|
82
|
+
const onPointerDown = useCallback(
|
|
83
|
+
(e) => {
|
|
84
|
+
primarySizeRef.current = firstPaneRef.current.getBoundingClientRect()[measurementProp];
|
|
85
|
+
containerSize.current = containerRef.current.getBoundingClientRect()[measurementProp];
|
|
86
|
+
dragStart.current = e[clientAxis];
|
|
87
|
+
splitterRef.current.setPointerCapture(e.pointerId);
|
|
88
|
+
firstPaneMeasurements.current = measureElement(firstPaneRef.current);
|
|
89
|
+
savedPos.current = void 0;
|
|
90
|
+
},
|
|
91
|
+
[measurementProp, clientAxis]
|
|
92
|
+
);
|
|
93
|
+
const onPointerMove = useCallback(
|
|
94
|
+
(e) => {
|
|
95
|
+
if (dragStart.current !== null && primarySizeRef.current !== "1fr") {
|
|
96
|
+
const diff = e[clientAxis] - dragStart.current;
|
|
97
|
+
const dims = firstPaneMeasurements.current;
|
|
98
|
+
const newSize = clamp(primarySizeRef.current + diff, dims[minDimProp], dims[maxDimProp]);
|
|
99
|
+
const newFlex = newSize / (containerSize.current - handleSize);
|
|
100
|
+
firstPaneRef.current.style.flexGrow = `${newFlex}`;
|
|
101
|
+
secondPaneRef.current.style.flexGrow = `${1 - newFlex}`;
|
|
102
|
+
const ariaValueNow = clamp(
|
|
103
|
+
(newSize - dims[minDimProp]) / (dims[maxDimProp] - dims[minDimProp]) * 100,
|
|
104
|
+
0,
|
|
105
|
+
100
|
|
106
|
+
);
|
|
107
|
+
splitterRef.current.ariaValueNow = `${ariaValueNow}`;
|
|
108
|
+
}
|
|
109
|
+
},
|
|
110
|
+
[handleSize, clientAxis, minDimProp, maxDimProp]
|
|
111
|
+
);
|
|
112
|
+
const onPointerUp = useCallback(
|
|
113
|
+
(e) => {
|
|
114
|
+
e.preventDefault();
|
|
115
|
+
e.stopPropagation();
|
|
116
|
+
splitterRef.current.releasePointerCapture(e.pointerId);
|
|
117
|
+
dragStart.current = null;
|
|
118
|
+
onDragFinished == null ? void 0 : onDragFinished(parseFloat(firstPaneRef.current.style.flexGrow));
|
|
119
|
+
},
|
|
120
|
+
[onDragFinished]
|
|
121
|
+
);
|
|
122
|
+
const pressedKeys = useRef(/* @__PURE__ */ new Set());
|
|
123
|
+
const keysLastHandledAt = useRef(null);
|
|
124
|
+
const handlePressedKeys = useCallback(
|
|
125
|
+
(time) => {
|
|
126
|
+
var _a;
|
|
127
|
+
const nothingPressed = pressedKeys.current.size === 0;
|
|
128
|
+
if (nothingPressed) {
|
|
129
|
+
keysLastHandledAt.current = null;
|
|
130
|
+
return;
|
|
131
|
+
} else if (primarySizeRef.current === "1fr") {
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
const dt = time - ((_a = keysLastHandledAt.current) != null ? _a : time);
|
|
135
|
+
const dx = dt * PIXELS_PER_MS;
|
|
136
|
+
let sizeChange = 0;
|
|
137
|
+
if (direction === "row") {
|
|
138
|
+
if (pressedKeys.current.has("ArrowLeft")) {
|
|
139
|
+
sizeChange -= dx;
|
|
140
|
+
}
|
|
141
|
+
if (pressedKeys.current.has("ArrowRight")) {
|
|
142
|
+
sizeChange += dx;
|
|
143
|
+
}
|
|
144
|
+
} else {
|
|
145
|
+
if (pressedKeys.current.has("ArrowUp")) {
|
|
146
|
+
sizeChange -= dx;
|
|
147
|
+
}
|
|
148
|
+
if (pressedKeys.current.has("ArrowDown")) {
|
|
149
|
+
sizeChange += dx;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
const firstPaneDims = firstPaneMeasurements.current;
|
|
153
|
+
const curSize = firstPaneRef.current.getBoundingClientRect()[measurementProp];
|
|
154
|
+
const newSize = clamp(curSize + sizeChange, firstPaneDims[minDimProp], firstPaneDims[maxDimProp]);
|
|
155
|
+
const newFlex = newSize / (containerSize.current - handleSize);
|
|
156
|
+
firstPaneRef.current.style.flexGrow = `${newFlex}`;
|
|
157
|
+
secondPaneRef.current.style.flexGrow = `${1 - newFlex}`;
|
|
158
|
+
const ariaValueNow = (newSize - firstPaneDims[minDimProp]) / (firstPaneDims[maxDimProp] - firstPaneDims[minDimProp]) * 100;
|
|
159
|
+
splitterRef.current.ariaValueNow = `${clamp(ariaValueNow, 0, 100)}`;
|
|
160
|
+
keysLastHandledAt.current = time;
|
|
161
|
+
window.requestAnimationFrame(handlePressedKeys);
|
|
162
|
+
},
|
|
163
|
+
[direction, handleSize, minDimProp, maxDimProp, measurementProp]
|
|
164
|
+
);
|
|
165
|
+
const onKeyDown = useCallback(
|
|
166
|
+
(e) => {
|
|
167
|
+
if (e.key === "Enter") {
|
|
168
|
+
if (savedPos.current === void 0) {
|
|
169
|
+
savedPos.current = firstPaneRef.current.style.flexGrow;
|
|
170
|
+
firstPaneRef.current.style.flexGrow = "0";
|
|
171
|
+
secondPaneRef.current.style.flexGrow = "1";
|
|
172
|
+
} else {
|
|
173
|
+
firstPaneRef.current.style.flexGrow = savedPos.current;
|
|
174
|
+
secondPaneRef.current.style.flexGrow = `${1 - parseFloat(savedPos.current)}`;
|
|
175
|
+
savedPos.current = void 0;
|
|
176
|
+
}
|
|
177
|
+
return;
|
|
178
|
+
} else if (e.key === "Home") {
|
|
179
|
+
firstPaneMeasurements.current = measureElement(firstPaneRef.current);
|
|
180
|
+
containerSize.current = containerRef.current.getBoundingClientRect()[measurementProp];
|
|
181
|
+
const newFlex = firstPaneMeasurements.current[minDimProp] / (containerSize.current - handleSize);
|
|
182
|
+
firstPaneRef.current.style.flexGrow = `${newFlex}`;
|
|
183
|
+
secondPaneRef.current.style.flexGrow = `${1 - newFlex}`;
|
|
184
|
+
splitterRef.current.ariaValueNow = "0";
|
|
185
|
+
return;
|
|
186
|
+
} else if (e.key === "End") {
|
|
187
|
+
firstPaneMeasurements.current = measureElement(firstPaneRef.current);
|
|
188
|
+
containerSize.current = containerRef.current.getBoundingClientRect()[measurementProp];
|
|
189
|
+
const newFlex = firstPaneMeasurements.current[maxDimProp] / (containerSize.current - handleSize);
|
|
190
|
+
firstPaneRef.current.style.flexGrow = `${newFlex}`;
|
|
191
|
+
secondPaneRef.current.style.flexGrow = `${1 - newFlex}`;
|
|
192
|
+
splitterRef.current.ariaValueNow = "100";
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
if (!(direction === "column" && VERTICAL_KEYS.has(e.key) || direction === "row" && HORIZONTAL_KEYS.has(e.key)) || pressedKeys.current.has(e.key)) {
|
|
196
|
+
return;
|
|
197
|
+
}
|
|
198
|
+
savedPos.current = void 0;
|
|
199
|
+
e.preventDefault();
|
|
200
|
+
e.stopPropagation();
|
|
201
|
+
primarySizeRef.current = firstPaneRef.current.getBoundingClientRect()[measurementProp];
|
|
202
|
+
containerSize.current = containerRef.current.getBoundingClientRect()[measurementProp];
|
|
203
|
+
firstPaneMeasurements.current = measureElement(firstPaneRef.current);
|
|
204
|
+
const newKey = !pressedKeys.current.has(e.key);
|
|
205
|
+
if (newKey) {
|
|
206
|
+
const initiateAnimationLoop = pressedKeys.current.size === 0;
|
|
207
|
+
pressedKeys.current.add(e.key);
|
|
208
|
+
if (initiateAnimationLoop) {
|
|
209
|
+
window.requestAnimationFrame(handlePressedKeys);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
},
|
|
213
|
+
[direction, handlePressedKeys, handleSize, maxDimProp, measurementProp, minDimProp]
|
|
214
|
+
);
|
|
215
|
+
const onKeyUp = useCallback(
|
|
216
|
+
(e) => {
|
|
217
|
+
if (direction === "row" && !HORIZONTAL_KEYS.has(e.key) || direction === "column" && !VERTICAL_KEYS.has(e.key)) {
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
pressedKeys.current.delete(e.key);
|
|
221
|
+
onDragFinished == null ? void 0 : onDragFinished(parseFloat(firstPaneRef.current.style.flexGrow));
|
|
222
|
+
},
|
|
223
|
+
[direction, onDragFinished]
|
|
224
|
+
);
|
|
225
|
+
const onDoubleClick = useCallback(() => {
|
|
226
|
+
firstPaneRef.current.style.flexGrow = "0.5";
|
|
227
|
+
secondPaneRef.current.style.flexGrow = "0.5";
|
|
228
|
+
const dim = measureElement(firstPaneRef.current);
|
|
229
|
+
firstPaneMeasurements.current = dim;
|
|
230
|
+
primarySizeRef.current = firstPaneRef.current.getBoundingClientRect()[measurementProp];
|
|
231
|
+
splitterRef.current.ariaValueNow = `${(primarySizeRef.current - dim[minDimProp]) / (dim[maxDimProp] - dim[minDimProp]) * 100}`;
|
|
232
|
+
}, [maxDimProp, measurementProp, minDimProp]);
|
|
233
|
+
const onBlur = useCallback(() => {
|
|
234
|
+
if (pressedKeys.current.size > 0) {
|
|
235
|
+
pressedKeys.current.clear();
|
|
236
|
+
dragStart.current = null;
|
|
237
|
+
onDragFinished == null ? void 0 : onDragFinished(parseFloat(firstPaneRef.current.style.flexGrow));
|
|
238
|
+
}
|
|
239
|
+
}, [onDragFinished]);
|
|
240
|
+
const styles = useStyles2(getStyles);
|
|
241
|
+
const id = useUniqueId();
|
|
242
|
+
const secondAvailable = kids.length === 2;
|
|
243
|
+
const visibilitySecond = secondAvailable ? "visible" : "hidden";
|
|
244
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
245
|
+
ref: containerRef,
|
|
246
|
+
className: styles.container,
|
|
247
|
+
style: {
|
|
248
|
+
flexDirection: direction
|
|
249
|
+
}
|
|
250
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
251
|
+
ref: firstPaneRef,
|
|
252
|
+
className: styles.panel,
|
|
253
|
+
style: __spreadValues({
|
|
254
|
+
flexGrow: initialSize === "auto" ? 0.5 : clamp(initialSize, 0, 1),
|
|
255
|
+
[minDimProp]: "min-content"
|
|
256
|
+
}, primaryPaneStyles),
|
|
257
|
+
id: `start-panel-${id}`
|
|
258
|
+
}, kids[0]), kids[1] && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("div", {
|
|
259
|
+
ref: splitterRef,
|
|
260
|
+
style: { [measurementProp]: `${handleSize}px` },
|
|
261
|
+
className: cx(styles.handle, { [styles.handleHorizontal]: direction === "column" }),
|
|
262
|
+
onPointerUp,
|
|
263
|
+
onPointerDown,
|
|
264
|
+
onPointerMove,
|
|
265
|
+
onKeyDown,
|
|
266
|
+
onKeyUp,
|
|
267
|
+
onDoubleClick,
|
|
268
|
+
onBlur,
|
|
269
|
+
role: "separator",
|
|
270
|
+
"aria-valuemin": 0,
|
|
271
|
+
"aria-valuemax": 100,
|
|
272
|
+
"aria-valuenow": 50,
|
|
273
|
+
"aria-controls": `start-panel-${id}`,
|
|
274
|
+
"aria-label": "Pane resize widget",
|
|
275
|
+
tabIndex: 0
|
|
276
|
+
}), /* @__PURE__ */ React.createElement("div", {
|
|
277
|
+
ref: secondPaneRef,
|
|
278
|
+
className: styles.panel,
|
|
279
|
+
style: __spreadValues({
|
|
280
|
+
flexGrow: initialSize === "auto" ? 0.5 : clamp(1 - initialSize, 0, 1),
|
|
281
|
+
[minDimProp]: "min-content",
|
|
282
|
+
visibility: `${visibilitySecond}`
|
|
283
|
+
}, secondaryPaneStyles),
|
|
284
|
+
id: `end-panel-${id}`
|
|
285
|
+
}, kids[1])));
|
|
286
|
+
}
|
|
287
|
+
function getStyles(theme) {
|
|
288
|
+
return {
|
|
289
|
+
handle: css({
|
|
290
|
+
cursor: "col-resize",
|
|
291
|
+
position: "relative",
|
|
292
|
+
flexShrink: 0,
|
|
293
|
+
userSelect: "none",
|
|
294
|
+
"&::before": {
|
|
295
|
+
content: '""',
|
|
296
|
+
position: "absolute",
|
|
297
|
+
backgroundColor: theme.colors.primary.main,
|
|
298
|
+
left: "50%",
|
|
299
|
+
transform: "translate(-50%)",
|
|
300
|
+
top: 0,
|
|
301
|
+
height: "100%",
|
|
302
|
+
width: "1px",
|
|
303
|
+
opacity: 0,
|
|
304
|
+
transition: "opacity ease-in-out 0.2s"
|
|
305
|
+
},
|
|
306
|
+
"&::after": {
|
|
307
|
+
content: '""',
|
|
308
|
+
width: "4px",
|
|
309
|
+
borderRadius: "4px",
|
|
310
|
+
backgroundColor: theme.colors.border.weak,
|
|
311
|
+
transition: "background-color ease-in-out 0.2s",
|
|
312
|
+
height: "50%",
|
|
313
|
+
top: "calc(50% - (50%) / 2)",
|
|
314
|
+
transform: "translateX(-50%)",
|
|
315
|
+
position: "absolute",
|
|
316
|
+
left: "50%"
|
|
317
|
+
},
|
|
318
|
+
"&:hover, &:focus-visible": {
|
|
319
|
+
outline: "none",
|
|
320
|
+
"&::before": {
|
|
321
|
+
opacity: 1
|
|
322
|
+
},
|
|
323
|
+
"&::after": {
|
|
324
|
+
backgroundColor: theme.colors.primary.main
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
}),
|
|
328
|
+
handleHorizontal: css({
|
|
329
|
+
cursor: "row-resize",
|
|
330
|
+
"&::before": {
|
|
331
|
+
left: "inherit",
|
|
332
|
+
transform: "translateY(-50%)",
|
|
333
|
+
top: "50%",
|
|
334
|
+
height: "1px",
|
|
335
|
+
width: "100%"
|
|
336
|
+
},
|
|
337
|
+
"&::after": {
|
|
338
|
+
width: "50%",
|
|
339
|
+
height: "4px",
|
|
340
|
+
top: "50%",
|
|
341
|
+
transform: "translateY(-50%)",
|
|
342
|
+
left: "calc(50% - (50%) / 2)"
|
|
343
|
+
}
|
|
344
|
+
}),
|
|
345
|
+
container: css({
|
|
346
|
+
display: "flex",
|
|
347
|
+
width: "100%",
|
|
348
|
+
flexGrow: 1,
|
|
349
|
+
overflow: "hidden"
|
|
350
|
+
}),
|
|
351
|
+
panel: css({ display: "flex", position: "relative", flexBasis: 0 })
|
|
352
|
+
};
|
|
353
|
+
}
|
|
354
|
+
function measureElement(ref) {
|
|
355
|
+
if (ref === null) {
|
|
356
|
+
return void 0;
|
|
357
|
+
}
|
|
358
|
+
const savedBodyOverflow = document.body.style.overflow;
|
|
359
|
+
const savedWidth = ref.style.width;
|
|
360
|
+
const savedHeight = ref.style.height;
|
|
361
|
+
const savedFlex = ref.style.flexGrow;
|
|
362
|
+
document.body.style.overflow = "hidden";
|
|
363
|
+
ref.style.flexGrow = "0";
|
|
364
|
+
const { width: minWidth, height: minHeight } = ref.getBoundingClientRect();
|
|
365
|
+
ref.style.flexGrow = "100";
|
|
366
|
+
const { width: maxWidth, height: maxHeight } = ref.getBoundingClientRect();
|
|
367
|
+
document.body.style.overflow = savedBodyOverflow;
|
|
368
|
+
ref.style.width = savedWidth;
|
|
369
|
+
ref.style.height = savedHeight;
|
|
370
|
+
ref.style.flexGrow = savedFlex;
|
|
371
|
+
return { minWidth, maxWidth, minHeight, maxHeight };
|
|
372
|
+
}
|
|
373
|
+
function useResizeObserver(target, cb, throttleWait = 0, deps) {
|
|
374
|
+
const throttledCallback = throttle(cb, throttleWait);
|
|
375
|
+
useLayoutEffect(() => {
|
|
376
|
+
if (!target) {
|
|
377
|
+
return;
|
|
378
|
+
}
|
|
379
|
+
const resizeObserver = new ResizeObserver(throttledCallback);
|
|
380
|
+
resizeObserver.observe(target, { box: "device-pixel-content-box" });
|
|
381
|
+
return () => resizeObserver.disconnect();
|
|
382
|
+
}, deps);
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
export { Splitter };
|
|
386
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Splitter.js","sources":["../../../../../components/layout/split/Splitter.js"],"sourcesContent":["import { cx, css } from '@emotion/css';\nimport { useStyles2 } from '@grafana/ui';\nimport { clamp, throttle } from 'lodash';\nimport React, { useRef, useCallback, useLayoutEffect } from 'react';\nimport { useUniqueId } from '../LazyLoader.js';\n\nvar __defProp = Object.defineProperty;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp.call(b, prop))\n      __defNormalProp(a, prop, b[prop]);\n  if (__getOwnPropSymbols)\n    for (var prop of __getOwnPropSymbols(b)) {\n      if (__propIsEnum.call(b, prop))\n        __defNormalProp(a, prop, b[prop]);\n    }\n  return a;\n};\nconst PIXELS_PER_MS = 0.3;\nconst VERTICAL_KEYS = /* @__PURE__ */ new Set([\"ArrowUp\", \"ArrowDown\"]);\nconst HORIZONTAL_KEYS = /* @__PURE__ */ new Set([\"ArrowLeft\", \"ArrowRight\"]);\nconst propsForDirection = {\n  row: {\n    dim: \"width\",\n    axis: \"clientX\",\n    min: \"minWidth\",\n    max: \"maxWidth\"\n  },\n  column: {\n    dim: \"height\",\n    axis: \"clientY\",\n    min: \"minHeight\",\n    max: \"maxHeight\"\n  }\n};\nfunction Splitter({\n  direction = \"row\",\n  handleSize = 32,\n  initialSize = \"auto\",\n  primaryPaneStyles,\n  secondaryPaneStyles,\n  onDragFinished,\n  children\n}) {\n  const kids = React.Children.toArray(children);\n  const splitterRef = useRef(null);\n  const firstPaneRef = useRef(null);\n  const secondPaneRef = useRef(null);\n  const containerRef = useRef(null);\n  const containerSize = useRef(null);\n  const primarySizeRef = useRef(\"1fr\");\n  const firstPaneMeasurements = useRef(void 0);\n  const savedPos = useRef(void 0);\n  const measurementProp = propsForDirection[direction].dim;\n  const clientAxis = propsForDirection[direction].axis;\n  const minDimProp = propsForDirection[direction].min;\n  const maxDimProp = propsForDirection[direction].max;\n  useResizeObserver(\n    containerRef.current,\n    (entries) => {\n      for (const entry of entries) {\n        if (!entry.target.isSameNode(containerRef.current)) {\n          return;\n        }\n        const curSize = firstPaneRef.current.getBoundingClientRect()[measurementProp];\n        const newDims = measureElement(firstPaneRef.current);\n        splitterRef.current.ariaValueNow = `${clamp(\n          (curSize - newDims[minDimProp]) / (newDims[maxDimProp] - newDims[minDimProp]) * 100,\n          0,\n          100\n        )}`;\n      }\n    },\n    500,\n    [maxDimProp, minDimProp, direction, measurementProp]\n  );\n  const dragStart = useRef(null);\n  const onPointerDown = useCallback(\n    (e) => {\n      primarySizeRef.current = firstPaneRef.current.getBoundingClientRect()[measurementProp];\n      containerSize.current = containerRef.current.getBoundingClientRect()[measurementProp];\n      dragStart.current = e[clientAxis];\n      splitterRef.current.setPointerCapture(e.pointerId);\n      firstPaneMeasurements.current = measureElement(firstPaneRef.current);\n      savedPos.current = void 0;\n    },\n    [measurementProp, clientAxis]\n  );\n  const onPointerMove = useCallback(\n    (e) => {\n      if (dragStart.current !== null && primarySizeRef.current !== \"1fr\") {\n        const diff = e[clientAxis] - dragStart.current;\n        const dims = firstPaneMeasurements.current;\n        const newSize = clamp(primarySizeRef.current + diff, dims[minDimProp], dims[maxDimProp]);\n        const newFlex = newSize / (containerSize.current - handleSize);\n        firstPaneRef.current.style.flexGrow = `${newFlex}`;\n        secondPaneRef.current.style.flexGrow = `${1 - newFlex}`;\n        const ariaValueNow = clamp(\n          (newSize - dims[minDimProp]) / (dims[maxDimProp] - dims[minDimProp]) * 100,\n          0,\n          100\n        );\n        splitterRef.current.ariaValueNow = `${ariaValueNow}`;\n      }\n    },\n    [handleSize, clientAxis, minDimProp, maxDimProp]\n  );\n  const onPointerUp = useCallback(\n    (e) => {\n      e.preventDefault();\n      e.stopPropagation();\n      splitterRef.current.releasePointerCapture(e.pointerId);\n      dragStart.current = null;\n      onDragFinished == null ? void 0 : onDragFinished(parseFloat(firstPaneRef.current.style.flexGrow));\n    },\n    [onDragFinished]\n  );\n  const pressedKeys = useRef(/* @__PURE__ */ new Set());\n  const keysLastHandledAt = useRef(null);\n  const handlePressedKeys = useCallback(\n    (time) => {\n      var _a;\n      const nothingPressed = pressedKeys.current.size === 0;\n      if (nothingPressed) {\n        keysLastHandledAt.current = null;\n        return;\n      } else if (primarySizeRef.current === \"1fr\") {\n        return;\n      }\n      const dt = time - ((_a = keysLastHandledAt.current) != null ? _a : time);\n      const dx = dt * PIXELS_PER_MS;\n      let sizeChange = 0;\n      if (direction === \"row\") {\n        if (pressedKeys.current.has(\"ArrowLeft\")) {\n          sizeChange -= dx;\n        }\n        if (pressedKeys.current.has(\"ArrowRight\")) {\n          sizeChange += dx;\n        }\n      } else {\n        if (pressedKeys.current.has(\"ArrowUp\")) {\n          sizeChange -= dx;\n        }\n        if (pressedKeys.current.has(\"ArrowDown\")) {\n          sizeChange += dx;\n        }\n      }\n      const firstPaneDims = firstPaneMeasurements.current;\n      const curSize = firstPaneRef.current.getBoundingClientRect()[measurementProp];\n      const newSize = clamp(curSize + sizeChange, firstPaneDims[minDimProp], firstPaneDims[maxDimProp]);\n      const newFlex = newSize / (containerSize.current - handleSize);\n      firstPaneRef.current.style.flexGrow = `${newFlex}`;\n      secondPaneRef.current.style.flexGrow = `${1 - newFlex}`;\n      const ariaValueNow = (newSize - firstPaneDims[minDimProp]) / (firstPaneDims[maxDimProp] - firstPaneDims[minDimProp]) * 100;\n      splitterRef.current.ariaValueNow = `${clamp(ariaValueNow, 0, 100)}`;\n      keysLastHandledAt.current = time;\n      window.requestAnimationFrame(handlePressedKeys);\n    },\n    [direction, handleSize, minDimProp, maxDimProp, measurementProp]\n  );\n  const onKeyDown = useCallback(\n    (e) => {\n      if (e.key === \"Enter\") {\n        if (savedPos.current === void 0) {\n          savedPos.current = firstPaneRef.current.style.flexGrow;\n          firstPaneRef.current.style.flexGrow = \"0\";\n          secondPaneRef.current.style.flexGrow = \"1\";\n        } else {\n          firstPaneRef.current.style.flexGrow = savedPos.current;\n          secondPaneRef.current.style.flexGrow = `${1 - parseFloat(savedPos.current)}`;\n          savedPos.current = void 0;\n        }\n        return;\n      } else if (e.key === \"Home\") {\n        firstPaneMeasurements.current = measureElement(firstPaneRef.current);\n        containerSize.current = containerRef.current.getBoundingClientRect()[measurementProp];\n        const newFlex = firstPaneMeasurements.current[minDimProp] / (containerSize.current - handleSize);\n        firstPaneRef.current.style.flexGrow = `${newFlex}`;\n        secondPaneRef.current.style.flexGrow = `${1 - newFlex}`;\n        splitterRef.current.ariaValueNow = \"0\";\n        return;\n      } else if (e.key === \"End\") {\n        firstPaneMeasurements.current = measureElement(firstPaneRef.current);\n        containerSize.current = containerRef.current.getBoundingClientRect()[measurementProp];\n        const newFlex = firstPaneMeasurements.current[maxDimProp] / (containerSize.current - handleSize);\n        firstPaneRef.current.style.flexGrow = `${newFlex}`;\n        secondPaneRef.current.style.flexGrow = `${1 - newFlex}`;\n        splitterRef.current.ariaValueNow = \"100\";\n        return;\n      }\n      if (!(direction === \"column\" && VERTICAL_KEYS.has(e.key) || direction === \"row\" && HORIZONTAL_KEYS.has(e.key)) || pressedKeys.current.has(e.key)) {\n        return;\n      }\n      savedPos.current = void 0;\n      e.preventDefault();\n      e.stopPropagation();\n      primarySizeRef.current = firstPaneRef.current.getBoundingClientRect()[measurementProp];\n      containerSize.current = containerRef.current.getBoundingClientRect()[measurementProp];\n      firstPaneMeasurements.current = measureElement(firstPaneRef.current);\n      const newKey = !pressedKeys.current.has(e.key);\n      if (newKey) {\n        const initiateAnimationLoop = pressedKeys.current.size === 0;\n        pressedKeys.current.add(e.key);\n        if (initiateAnimationLoop) {\n          window.requestAnimationFrame(handlePressedKeys);\n        }\n      }\n    },\n    [direction, handlePressedKeys, handleSize, maxDimProp, measurementProp, minDimProp]\n  );\n  const onKeyUp = useCallback(\n    (e) => {\n      if (direction === \"row\" && !HORIZONTAL_KEYS.has(e.key) || direction === \"column\" && !VERTICAL_KEYS.has(e.key)) {\n        return;\n      }\n      pressedKeys.current.delete(e.key);\n      onDragFinished == null ? void 0 : onDragFinished(parseFloat(firstPaneRef.current.style.flexGrow));\n    },\n    [direction, onDragFinished]\n  );\n  const onDoubleClick = useCallback(() => {\n    firstPaneRef.current.style.flexGrow = \"0.5\";\n    secondPaneRef.current.style.flexGrow = \"0.5\";\n    const dim = measureElement(firstPaneRef.current);\n    firstPaneMeasurements.current = dim;\n    primarySizeRef.current = firstPaneRef.current.getBoundingClientRect()[measurementProp];\n    splitterRef.current.ariaValueNow = `${(primarySizeRef.current - dim[minDimProp]) / (dim[maxDimProp] - dim[minDimProp]) * 100}`;\n  }, [maxDimProp, measurementProp, minDimProp]);\n  const onBlur = useCallback(() => {\n    if (pressedKeys.current.size > 0) {\n      pressedKeys.current.clear();\n      dragStart.current = null;\n      onDragFinished == null ? void 0 : onDragFinished(parseFloat(firstPaneRef.current.style.flexGrow));\n    }\n  }, [onDragFinished]);\n  const styles = useStyles2(getStyles);\n  const id = useUniqueId();\n  const secondAvailable = kids.length === 2;\n  const visibilitySecond = secondAvailable ? \"visible\" : \"hidden\";\n  return /* @__PURE__ */ React.createElement(\"div\", {\n    ref: containerRef,\n    className: styles.container,\n    style: {\n      flexDirection: direction\n    }\n  }, /* @__PURE__ */ React.createElement(\"div\", {\n    ref: firstPaneRef,\n    className: styles.panel,\n    style: __spreadValues({\n      flexGrow: initialSize === \"auto\" ? 0.5 : clamp(initialSize, 0, 1),\n      [minDimProp]: \"min-content\"\n    }, primaryPaneStyles),\n    id: `start-panel-${id}`\n  }, kids[0]), kids[1] && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(\"div\", {\n    ref: splitterRef,\n    style: { [measurementProp]: `${handleSize}px` },\n    className: cx(styles.handle, { [styles.handleHorizontal]: direction === \"column\" }),\n    onPointerUp,\n    onPointerDown,\n    onPointerMove,\n    onKeyDown,\n    onKeyUp,\n    onDoubleClick,\n    onBlur,\n    role: \"separator\",\n    \"aria-valuemin\": 0,\n    \"aria-valuemax\": 100,\n    \"aria-valuenow\": 50,\n    \"aria-controls\": `start-panel-${id}`,\n    \"aria-label\": \"Pane resize widget\",\n    tabIndex: 0\n  }), /* @__PURE__ */ React.createElement(\"div\", {\n    ref: secondPaneRef,\n    className: styles.panel,\n    style: __spreadValues({\n      flexGrow: initialSize === \"auto\" ? 0.5 : clamp(1 - initialSize, 0, 1),\n      [minDimProp]: \"min-content\",\n      visibility: `${visibilitySecond}`\n    }, secondaryPaneStyles),\n    id: `end-panel-${id}`\n  }, kids[1])));\n}\nfunction getStyles(theme) {\n  return {\n    handle: css({\n      cursor: \"col-resize\",\n      position: \"relative\",\n      flexShrink: 0,\n      userSelect: \"none\",\n      \"&::before\": {\n        content: '\"\"',\n        position: \"absolute\",\n        backgroundColor: theme.colors.primary.main,\n        left: \"50%\",\n        transform: \"translate(-50%)\",\n        top: 0,\n        height: \"100%\",\n        width: \"1px\",\n        opacity: 0,\n        transition: \"opacity ease-in-out 0.2s\"\n      },\n      \"&::after\": {\n        content: '\"\"',\n        width: \"4px\",\n        borderRadius: \"4px\",\n        backgroundColor: theme.colors.border.weak,\n        transition: \"background-color ease-in-out 0.2s\",\n        height: \"50%\",\n        top: \"calc(50% - (50%) / 2)\",\n        transform: \"translateX(-50%)\",\n        position: \"absolute\",\n        left: \"50%\"\n      },\n      \"&:hover, &:focus-visible\": {\n        outline: \"none\",\n        \"&::before\": {\n          opacity: 1\n        },\n        \"&::after\": {\n          backgroundColor: theme.colors.primary.main\n        }\n      }\n    }),\n    handleHorizontal: css({\n      cursor: \"row-resize\",\n      \"&::before\": {\n        left: \"inherit\",\n        transform: \"translateY(-50%)\",\n        top: \"50%\",\n        height: \"1px\",\n        width: \"100%\"\n      },\n      \"&::after\": {\n        width: \"50%\",\n        height: \"4px\",\n        top: \"50%\",\n        transform: \"translateY(-50%)\",\n        left: \"calc(50% - (50%) / 2)\"\n      }\n    }),\n    container: css({\n      display: \"flex\",\n      width: \"100%\",\n      flexGrow: 1,\n      overflow: \"hidden\"\n    }),\n    panel: css({ display: \"flex\", position: \"relative\", flexBasis: 0 })\n  };\n}\nfunction measureElement(ref) {\n  if (ref === null) {\n    return void 0;\n  }\n  const savedBodyOverflow = document.body.style.overflow;\n  const savedWidth = ref.style.width;\n  const savedHeight = ref.style.height;\n  const savedFlex = ref.style.flexGrow;\n  document.body.style.overflow = \"hidden\";\n  ref.style.flexGrow = \"0\";\n  const { width: minWidth, height: minHeight } = ref.getBoundingClientRect();\n  ref.style.flexGrow = \"100\";\n  const { width: maxWidth, height: maxHeight } = ref.getBoundingClientRect();\n  document.body.style.overflow = savedBodyOverflow;\n  ref.style.width = savedWidth;\n  ref.style.height = savedHeight;\n  ref.style.flexGrow = savedFlex;\n  return { minWidth, maxWidth, minHeight, maxHeight };\n}\nfunction useResizeObserver(target, cb, throttleWait = 0, deps) {\n  const throttledCallback = throttle(cb, throttleWait);\n  useLayoutEffect(() => {\n    if (!target) {\n      return;\n    }\n    const resizeObserver = new ResizeObserver(throttledCallback);\n    resizeObserver.observe(target, { box: \"device-pixel-content-box\" });\n    return () => resizeObserver.disconnect();\n  }, deps);\n}\n\nexport { Splitter };\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Splitter.js","sources":["../../../../../src/components/layout/split/Splitter.tsx"],"sourcesContent":["import { css, cx } from '@emotion/css';\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { useStyles2 } from '@grafana/ui';\nimport { clamp, throttle } from 'lodash';\nimport React, { useCallback, useLayoutEffect, useRef } from 'react';\nimport { useUniqueId } from '../LazyLoader';\n\ninterface Props {\n  handleSize?: number;\n  initialSize?: number | 'auto';\n  direction?: 'row' | 'column';\n  primary?: 'first' | 'second';\n  collapsedDefault?: boolean;\n  primaryPaneStyles?: React.CSSProperties;\n  secondaryPaneStyles?: React.CSSProperties;\n  onDragFinished?: (size: number) => void;\n  children: [React.ReactNode, React.ReactNode];\n}\n\nconst PIXELS_PER_MS = 0.3 as const;\nconst VERTICAL_KEYS = new Set(['ArrowUp', 'ArrowDown']);\nconst HORIZONTAL_KEYS = new Set(['ArrowLeft', 'ArrowRight']);\n\nconst propsForDirection = {\n  row: {\n    dim: 'width',\n    axis: 'clientX',\n    min: 'minWidth',\n    max: 'maxWidth',\n  },\n  column: {\n    dim: 'height',\n    axis: 'clientY',\n    min: 'minHeight',\n    max: 'maxHeight',\n  },\n} as const;\n\nexport function Splitter({\n  direction = 'row',\n  handleSize = 32,\n  initialSize = 'auto',\n  primaryPaneStyles,\n  secondaryPaneStyles,\n  onDragFinished,\n  children,\n}: Props) {\n  const kids = React.Children.toArray(children);\n\n  const splitterRef = useRef<HTMLDivElement | null>(null);\n  const firstPaneRef = useRef<HTMLDivElement | null>(null);\n  const secondPaneRef = useRef<HTMLDivElement | null>(null);\n  const containerRef = useRef<HTMLDivElement | null>(null);\n  const containerSize = useRef<number | null>(null);\n  const primarySizeRef = useRef<'1fr' | number>('1fr');\n\n  const firstPaneMeasurements = useRef<ReturnType<typeof measureElement>>(undefined);\n  const savedPos = useRef<string | undefined>(undefined);\n\n  const measurementProp = propsForDirection[direction].dim;\n  const clientAxis = propsForDirection[direction].axis;\n  const minDimProp = propsForDirection[direction].min;\n  const maxDimProp = propsForDirection[direction].max;\n\n  // Using a resize observer here, as with content or screen based width/height the ratio between panes might\n  // change after a window resize, so ariaValueNow needs to be updated accordingly\n  useResizeObserver(\n    containerRef.current!,\n    (entries) => {\n      for (const entry of entries) {\n        if (!entry.target.isSameNode(containerRef.current)) {\n          return;\n        }\n\n        const curSize = firstPaneRef.current!.getBoundingClientRect()[measurementProp];\n        const newDims = measureElement(firstPaneRef.current!);\n        splitterRef.current!.ariaValueNow = `${clamp(\n          ((curSize - newDims[minDimProp]) / (newDims[maxDimProp] - newDims[minDimProp])) * 100,\n          0,\n          100\n        )}`;\n      }\n    },\n    500,\n    [maxDimProp, minDimProp, direction, measurementProp]\n  );\n\n  const dragStart = useRef<number | null>(null);\n  const onPointerDown = useCallback(\n    (e: React.PointerEvent<HTMLDivElement>) => {\n      // measure left-side width\n      primarySizeRef.current = firstPaneRef.current!.getBoundingClientRect()[measurementProp];\n      containerSize.current = containerRef.current!.getBoundingClientRect()[measurementProp];\n\n      // set position at start of drag\n      dragStart.current = e[clientAxis];\n      splitterRef.current!.setPointerCapture(e.pointerId);\n      firstPaneMeasurements.current = measureElement(firstPaneRef.current!);\n\n      savedPos.current = undefined;\n    },\n    [measurementProp, clientAxis]\n  );\n\n  const onPointerMove = useCallback(\n    (e: React.PointerEvent<HTMLDivElement>) => {\n      if (dragStart.current !== null && primarySizeRef.current !== '1fr') {\n        const diff = e[clientAxis] - dragStart.current;\n        const dims = firstPaneMeasurements.current!;\n        const newSize = clamp(primarySizeRef.current + diff, dims[minDimProp], dims[maxDimProp]);\n        const newFlex = newSize / (containerSize.current! - handleSize);\n        firstPaneRef.current!.style.flexGrow = `${newFlex}`;\n        secondPaneRef.current!.style.flexGrow = `${1 - newFlex}`;\n        const ariaValueNow = clamp(\n          ((newSize - dims[minDimProp]) / (dims[maxDimProp] - dims[minDimProp])) * 100,\n          0,\n          100\n        );\n\n        splitterRef.current!.ariaValueNow = `${ariaValueNow}`;\n      }\n    },\n    [handleSize, clientAxis, minDimProp, maxDimProp]\n  );\n\n  const onPointerUp = useCallback(\n    (e: React.PointerEvent<HTMLDivElement>) => {\n      e.preventDefault();\n      e.stopPropagation();\n      splitterRef.current!.releasePointerCapture(e.pointerId);\n      dragStart.current = null;\n      onDragFinished?.(parseFloat(firstPaneRef.current!.style.flexGrow));\n    },\n    [onDragFinished]\n  );\n\n  const pressedKeys = useRef(new Set<string>());\n  const keysLastHandledAt = useRef<number | null>(null);\n  const handlePressedKeys = useCallback(\n    (time: number) => {\n      const nothingPressed = pressedKeys.current.size === 0;\n      if (nothingPressed) {\n        keysLastHandledAt.current = null;\n        return;\n      } else if (primarySizeRef.current === '1fr') {\n        return;\n      }\n\n      const dt = time - (keysLastHandledAt.current ?? time);\n      const dx = dt * PIXELS_PER_MS;\n      let sizeChange = 0;\n\n      if (direction === 'row') {\n        if (pressedKeys.current.has('ArrowLeft')) {\n          sizeChange -= dx;\n        }\n        if (pressedKeys.current.has('ArrowRight')) {\n          sizeChange += dx;\n        }\n      } else {\n        if (pressedKeys.current.has('ArrowUp')) {\n          sizeChange -= dx;\n        }\n        if (pressedKeys.current.has('ArrowDown')) {\n          sizeChange += dx;\n        }\n      }\n\n      const firstPaneDims = firstPaneMeasurements.current!;\n      const curSize = firstPaneRef.current!.getBoundingClientRect()[measurementProp];\n      const newSize = clamp(curSize + sizeChange, firstPaneDims[minDimProp], firstPaneDims[maxDimProp]);\n\n      const newFlex = newSize / (containerSize.current! - handleSize);\n\n      firstPaneRef.current!.style.flexGrow = `${newFlex}`;\n      secondPaneRef.current!.style.flexGrow = `${1 - newFlex}`;\n      const ariaValueNow =\n        ((newSize - firstPaneDims[minDimProp]) / (firstPaneDims[maxDimProp] - firstPaneDims[minDimProp])) * 100;\n      splitterRef.current!.ariaValueNow = `${clamp(ariaValueNow, 0, 100)}`;\n\n      keysLastHandledAt.current = time;\n      window.requestAnimationFrame(handlePressedKeys);\n    },\n    [direction, handleSize, minDimProp, maxDimProp, measurementProp]\n  );\n\n  const onKeyDown = useCallback(\n    (e: React.KeyboardEvent<HTMLDivElement>) => {\n      if (e.key === 'Enter') {\n        if (savedPos.current === undefined) {\n          savedPos.current = firstPaneRef.current!.style.flexGrow;\n          firstPaneRef.current!.style.flexGrow = '0';\n          secondPaneRef.current!.style.flexGrow = '1';\n        } else {\n          firstPaneRef.current!.style.flexGrow = savedPos.current;\n          secondPaneRef.current!.style.flexGrow = `${1 - parseFloat(savedPos.current)}`;\n          savedPos.current = undefined;\n        }\n        return;\n      } else if (e.key === 'Home') {\n        firstPaneMeasurements.current = measureElement(firstPaneRef.current!);\n        containerSize.current = containerRef.current!.getBoundingClientRect()[measurementProp];\n        const newFlex = firstPaneMeasurements.current[minDimProp] / (containerSize.current! - handleSize);\n        firstPaneRef.current!.style.flexGrow = `${newFlex}`;\n        secondPaneRef.current!.style.flexGrow = `${1 - newFlex}`;\n        splitterRef.current!.ariaValueNow = '0';\n        return;\n      } else if (e.key === 'End') {\n        firstPaneMeasurements.current = measureElement(firstPaneRef.current!);\n        containerSize.current = containerRef.current!.getBoundingClientRect()[measurementProp];\n        const newFlex = firstPaneMeasurements.current[maxDimProp] / (containerSize.current! - handleSize);\n        firstPaneRef.current!.style.flexGrow = `${newFlex}`;\n        secondPaneRef.current!.style.flexGrow = `${1 - newFlex}`;\n        splitterRef.current!.ariaValueNow = '100';\n        return;\n      }\n\n      if (\n        !(\n          (direction === 'column' && VERTICAL_KEYS.has(e.key)) ||\n          (direction === 'row' && HORIZONTAL_KEYS.has(e.key))\n        ) ||\n        pressedKeys.current.has(e.key)\n      ) {\n        return;\n      }\n\n      savedPos.current = undefined;\n      e.preventDefault();\n      e.stopPropagation();\n      primarySizeRef.current = firstPaneRef.current!.getBoundingClientRect()[measurementProp];\n      containerSize.current = containerRef.current!.getBoundingClientRect()[measurementProp];\n      firstPaneMeasurements.current = measureElement(firstPaneRef.current!);\n      const newKey = !pressedKeys.current.has(e.key);\n\n      if (newKey) {\n        const initiateAnimationLoop = pressedKeys.current.size === 0;\n        pressedKeys.current.add(e.key);\n\n        if (initiateAnimationLoop) {\n          window.requestAnimationFrame(handlePressedKeys);\n        }\n      }\n    },\n    [direction, handlePressedKeys, handleSize, maxDimProp, measurementProp, minDimProp]\n  );\n\n  const onKeyUp = useCallback(\n    (e: React.KeyboardEvent<HTMLDivElement>) => {\n      if (\n        (direction === 'row' && !HORIZONTAL_KEYS.has(e.key)) ||\n        (direction === 'column' && !VERTICAL_KEYS.has(e.key))\n      ) {\n        return;\n      }\n\n      pressedKeys.current.delete(e.key);\n      onDragFinished?.(parseFloat(firstPaneRef.current!.style.flexGrow));\n    },\n    [direction, onDragFinished]\n  );\n\n  const onDoubleClick = useCallback(() => {\n    firstPaneRef.current!.style.flexGrow = '0.5';\n    secondPaneRef.current!.style.flexGrow = '0.5';\n    const dim = measureElement(firstPaneRef.current!);\n    firstPaneMeasurements.current = dim;\n    primarySizeRef.current = firstPaneRef.current!.getBoundingClientRect()[measurementProp];\n    splitterRef.current!.ariaValueNow = `${\n      ((primarySizeRef.current - dim[minDimProp]) / (dim[maxDimProp] - dim[minDimProp])) * 100\n    }`;\n  }, [maxDimProp, measurementProp, minDimProp]);\n\n  const onBlur = useCallback(() => {\n    // If focus is lost while keys are held, stop changing panel sizes\n    if (pressedKeys.current.size > 0) {\n      pressedKeys.current.clear();\n      dragStart.current = null;\n      onDragFinished?.(parseFloat(firstPaneRef.current!.style.flexGrow));\n    }\n  }, [onDragFinished]);\n\n  const styles = useStyles2(getStyles);\n  const id = useUniqueId();\n\n  const secondAvailable = kids.length === 2;\n  const visibilitySecond = secondAvailable ? 'visible' : 'hidden';\n\n  return (\n    <div\n      ref={containerRef}\n      className={styles.container}\n      style={{\n        flexDirection: direction,\n      }}\n    >\n      <div\n        ref={firstPaneRef}\n        className={styles.panel}\n        style={{\n          flexGrow: initialSize === 'auto' ? 0.5 : clamp(initialSize, 0, 1),\n          [minDimProp]: 'min-content',\n          ...primaryPaneStyles,\n        }}\n        id={`start-panel-${id}`}\n      >\n        {kids[0]}\n      </div>\n\n      {kids[1] && (\n        <>\n          <div\n            ref={splitterRef}\n            style={{ [measurementProp]: `${handleSize}px` }}\n            className={cx(styles.handle, { [styles.handleHorizontal]: direction === 'column' })}\n            onPointerUp={onPointerUp}\n            onPointerDown={onPointerDown}\n            onPointerMove={onPointerMove}\n            onKeyDown={onKeyDown}\n            onKeyUp={onKeyUp}\n            onDoubleClick={onDoubleClick}\n            onBlur={onBlur}\n            role=\"separator\"\n            aria-valuemin={0}\n            aria-valuemax={100}\n            aria-valuenow={50}\n            aria-controls={`start-panel-${id}`}\n            aria-label=\"Pane resize widget\"\n            tabIndex={0}\n          ></div>\n\n          <div\n            ref={secondPaneRef}\n            className={styles.panel}\n            style={{\n              flexGrow: initialSize === 'auto' ? 0.5 : clamp(1 - initialSize, 0, 1),\n              [minDimProp]: 'min-content',\n              visibility: `${visibilitySecond}`,\n              ...secondaryPaneStyles,\n            }}\n            id={`end-panel-${id}`}\n          >\n            {kids[1]}\n          </div>\n        </>\n      )}\n    </div>\n  );\n}\n\nfunction getStyles(theme: GrafanaTheme2) {\n  return {\n    handle: css({\n      cursor: 'col-resize',\n      position: 'relative',\n      flexShrink: 0,\n      userSelect: 'none',\n\n      '&::before': {\n        content: '\"\"',\n        position: 'absolute',\n        backgroundColor: theme.colors.primary.main,\n        left: '50%',\n        transform: 'translate(-50%)',\n        top: 0,\n        height: '100%',\n        width: '1px',\n        opacity: 0,\n        transition: 'opacity ease-in-out 0.2s',\n      },\n\n      '&::after': {\n        content: '\"\"',\n        width: '4px',\n        borderRadius: '4px',\n        backgroundColor: theme.colors.border.weak,\n        transition: 'background-color ease-in-out 0.2s',\n        height: '50%',\n        top: 'calc(50% - (50%) / 2)',\n        transform: 'translateX(-50%)',\n        position: 'absolute',\n        left: '50%',\n      },\n\n      '&:hover, &:focus-visible': {\n        outline: 'none',\n        '&::before': {\n          opacity: 1,\n        },\n\n        '&::after': {\n          backgroundColor: theme.colors.primary.main,\n        },\n      },\n    }),\n    handleHorizontal: css({\n      cursor: 'row-resize',\n\n      '&::before': {\n        left: 'inherit',\n        transform: 'translateY(-50%)',\n        top: '50%',\n        height: '1px',\n        width: '100%',\n      },\n\n      '&::after': {\n        width: '50%',\n        height: '4px',\n        top: '50%',\n        transform: 'translateY(-50%)',\n        left: 'calc(50% - (50%) / 2)',\n      },\n    }),\n    container: css({\n      display: 'flex',\n      width: '100%',\n      flexGrow: 1,\n      overflow: 'hidden',\n    }),\n    panel: css({ display: 'flex', position: 'relative', flexBasis: 0 }),\n  };\n}\n\ntype MeasureR<T> = T extends HTMLElement\n  ? { minWidth: number; maxWidth: number; minHeight: number; maxHeight: number }\n  : T extends null\n  ? undefined\n  : never;\ntype HTMLElementOrNull = HTMLElement | null;\n\nfunction measureElement<T extends HTMLElementOrNull>(ref: T): MeasureR<T> {\n  if (ref === null) {\n    return undefined as MeasureR<T>;\n  }\n\n  const savedBodyOverflow = document.body.style.overflow;\n  const savedWidth = ref.style.width;\n  const savedHeight = ref.style.height;\n  const savedFlex = ref.style.flexGrow;\n  document.body.style.overflow = 'hidden';\n  ref.style.flexGrow = '0';\n  const { width: minWidth, height: minHeight } = ref.getBoundingClientRect();\n\n  ref.style.flexGrow = '100';\n  const { width: maxWidth, height: maxHeight } = ref.getBoundingClientRect();\n\n  document.body.style.overflow = savedBodyOverflow;\n  ref.style.width = savedWidth;\n  ref.style.height = savedHeight;\n  ref.style.flexGrow = savedFlex;\n\n  return { minWidth, maxWidth, minHeight, maxHeight } as MeasureR<T>;\n}\n\nfunction useResizeObserver(\n  target: Element,\n  cb: (entries: ResizeObserverEntry[]) => void,\n  throttleWait = 0,\n  deps?: React.DependencyList\n) {\n  const throttledCallback = throttle(cb, throttleWait);\n\n  useLayoutEffect(() => {\n    if (!target) {\n      return;\n    }\n\n    const resizeObserver = new ResizeObserver(throttledCallback);\n\n    resizeObserver.observe(target, { box: 'device-pixel-content-box' });\n    return () => resizeObserver.disconnect();\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, deps);\n}\n"],"names":[],"mappings":"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"}\n"],"names":[],"mappings":"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"}
|