@grafana/scenes 6.8.0 → 6.8.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +20 -0
- package/dist/esm/index.js +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
- package/dist/esm/components/layout/CSSGrid/SceneCSSGridItem.js +0 -33
- package/dist/esm/dist/esm/behaviors/CursorSync.js +0 -76
- package/dist/esm/dist/esm/behaviors/LiveNowTimer.js +0 -44
- package/dist/esm/dist/esm/behaviors/SceneQueryController.js +0 -14
- package/dist/esm/dist/esm/components/EmbeddedScene.js +0 -59
- package/dist/esm/dist/esm/components/NestedScene.js +0 -95
- package/dist/esm/dist/esm/components/SceneApp/SceneApp.js +0 -27
- package/dist/esm/dist/esm/components/SceneApp/SceneAppPage.js +0 -176
- package/dist/esm/dist/esm/components/SceneApp/SceneAppPageView.js +0 -104
- package/dist/esm/dist/esm/components/SceneApp/utils.js +0 -42
- package/dist/esm/dist/esm/components/SceneByFrameRepeater.js +0 -41
- package/dist/esm/dist/esm/components/SceneByVariableRepeater.js +0 -55
- package/dist/esm/dist/esm/components/SceneCanvasText.js +0 -32
- package/dist/esm/dist/esm/components/SceneControlsSpacer.js +0 -17
- package/dist/esm/dist/esm/components/SceneDebugger/DebugDetails.js +0 -82
- package/dist/esm/dist/esm/components/SceneDebugger/DebugTreeNode.js +0 -72
- package/dist/esm/dist/esm/components/SceneDebugger/SceneDebugger.js +0 -77
- package/dist/esm/dist/esm/components/SceneReactObject.js +0 -34
- package/dist/esm/dist/esm/components/SceneRefreshPicker.js +0 -205
- package/dist/esm/dist/esm/components/SceneTimePicker.js +0 -139
- package/dist/esm/dist/esm/components/SceneTimeRangeCompare.js +0 -240
- package/dist/esm/dist/esm/components/SceneToolbarButton.js +0 -33
- package/dist/esm/dist/esm/components/VizPanel/VizPanel.js +0 -406
- package/dist/esm/dist/esm/components/VizPanel/VizPanelExploreButton.js +0 -44
- package/dist/esm/dist/esm/components/VizPanel/VizPanelMenu.js +0 -59
- package/dist/esm/dist/esm/components/VizPanel/VizPanelRenderer.js +0 -285
- package/dist/esm/dist/esm/components/VizPanel/VizPanelSeriesLimit.js +0 -45
- package/dist/esm/dist/esm/components/VizPanel/colorSeriesConfigFactory.js +0 -72
- package/dist/esm/dist/esm/components/VizPanel/registerRuntimePanelPlugin.js +0 -11
- package/dist/esm/dist/esm/components/VizPanel/seriesVisibilityConfigFactory.js +0 -164
- package/dist/esm/dist/esm/components/layout/CSSGrid/SceneCSSGridLayout.js +0 -124
- package/dist/esm/dist/esm/components/layout/LazyLoader.js +0 -103
- package/dist/esm/dist/esm/components/layout/SceneFlexLayout.js +0 -135
- package/dist/esm/dist/esm/components/layout/grid/SceneGridItem.js +0 -30
- package/dist/esm/dist/esm/components/layout/grid/SceneGridLayout.js +0 -283
- package/dist/esm/dist/esm/components/layout/grid/SceneGridLayoutRenderer.js +0 -178
- package/dist/esm/dist/esm/components/layout/grid/SceneGridRow.js +0 -190
- package/dist/esm/dist/esm/components/layout/grid/constants.js +0 -7
- package/dist/esm/dist/esm/components/layout/grid/utils.js +0 -36
- package/dist/esm/dist/esm/components/layout/split/SplitLayout.js +0 -17
- package/dist/esm/dist/esm/components/layout/split/SplitLayoutRenderer.js +0 -29
- package/dist/esm/dist/esm/components/layout/split/Splitter.js +0 -386
- package/dist/esm/dist/esm/core/SceneComponentWrapper.js +0 -57
- package/dist/esm/dist/esm/core/SceneDataNode.js +0 -43
- package/dist/esm/dist/esm/core/SceneObjectBase.js +0 -286
- package/dist/esm/dist/esm/core/SceneObjectRef.js +0 -32
- package/dist/esm/dist/esm/core/SceneTimeRange.js +0 -231
- package/dist/esm/dist/esm/core/events.js +0 -11
- package/dist/esm/dist/esm/core/sceneGraph/getTimeRange.js +0 -10
- package/dist/esm/dist/esm/core/sceneGraph/index.js +0 -25
- package/dist/esm/dist/esm/core/sceneGraph/sceneGraph.js +0 -178
- package/dist/esm/dist/esm/core/sceneGraph/utils.js +0 -64
- package/dist/esm/dist/esm/core/types.js +0 -15
- package/dist/esm/dist/esm/querying/DataLayersMerger.js +0 -46
- package/dist/esm/dist/esm/querying/ExtraQueryProvider.js +0 -6
- package/dist/esm/dist/esm/querying/RuntimeDataSource.js +0 -6
- package/dist/esm/dist/esm/querying/SceneDataLayerSet.js +0 -100
- package/dist/esm/dist/esm/querying/SceneQueryRunner.js +0 -468
- package/dist/esm/dist/esm/querying/extraQueryProcessingOperator.js +0 -46
- package/dist/esm/dist/esm/querying/getEnrichedDataRequest.js +0 -12
- package/dist/esm/dist/esm/querying/layers/SceneDataLayerBase.js +0 -112
- package/dist/esm/dist/esm/querying/layers/SceneDataLayerControls.js +0 -51
- package/dist/esm/dist/esm/querying/layers/annotations/AnnotationsDataLayer.js +0 -130
- package/dist/esm/dist/esm/querying/layers/annotations/filterAnnotations.js +0 -85
- package/dist/esm/dist/esm/querying/layers/annotations/standardAnnotationQuery.js +0 -121
- package/dist/esm/dist/esm/querying/layers/annotations/standardAnnotationsSupport.js +0 -211
- package/dist/esm/dist/esm/querying/layers/annotations/utils.js +0 -77
- package/dist/esm/dist/esm/querying/registerQueryWithController.js +0 -41
- package/dist/esm/dist/esm/services/SceneObjectUrlSyncConfig.js +0 -30
- package/dist/esm/dist/esm/services/UniqueUrlKeyMapper.js +0 -45
- package/dist/esm/dist/esm/services/UrlSyncManager.js +0 -167
- package/dist/esm/dist/esm/services/useUrlSync.js +0 -29
- package/dist/esm/dist/esm/services/utils.js +0 -71
- package/dist/esm/dist/esm/utils/ControlsLabel.js +0 -107
- package/dist/esm/dist/esm/utils/LoadingIndicator.js +0 -19
- package/dist/esm/dist/esm/utils/SafeSerializableSceneObject.js +0 -39
- package/dist/esm/dist/esm/utils/compatibility/setWindowGrafanaSceneContext.js +0 -16
- package/dist/esm/dist/esm/utils/date.js +0 -15
- package/dist/esm/dist/esm/utils/evaluateTimeRange.js +0 -16
- package/dist/esm/dist/esm/utils/explore.js +0 -47
- package/dist/esm/dist/esm/utils/getCompareSeriesRefId.js +0 -4
- package/dist/esm/dist/esm/utils/getDataSource.js +0 -18
- package/dist/esm/dist/esm/utils/getMessageFromError.js +0 -24
- package/dist/esm/dist/esm/utils/metricTree.js +0 -53
- package/dist/esm/dist/esm/utils/parseUrlParam.js +0 -41
- package/dist/esm/dist/esm/utils/utils.js +0 -11
- package/dist/esm/dist/esm/utils/wrapInSafeSerializableSceneObject.js +0 -30
- package/dist/esm/dist/esm/utils/writeSceneLog.js +0 -12
- package/dist/esm/dist/esm/variables/VariableDependencyConfig.js +0 -150
- package/dist/esm/dist/esm/variables/VariableValueRecorder.js +0 -71
- package/dist/esm/dist/esm/variables/adhoc/AdHocFilterBuilder.js +0 -24
- package/dist/esm/dist/esm/variables/adhoc/AdHocFilterRenderer.js +0 -303
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFilterPill.js +0 -162
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersAlwaysWipCombobox.js +0 -20
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersCombobox.js +0 -640
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersComboboxRenderer.js +0 -65
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/DropdownItem.js +0 -146
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/MultiValuePill.js +0 -114
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/useFloatingInteractions.js +0 -68
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/utils.js +0 -146
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersVariable.js +0 -289
- package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersVariableUrlSyncHandler.js +0 -76
- package/dist/esm/dist/esm/variables/adhoc/getAdhocOptionSearcher.js +0 -13
- package/dist/esm/dist/esm/variables/adhoc/patchGetAdhocFilters.js +0 -47
- package/dist/esm/dist/esm/variables/components/VariableValueControl.js +0 -23
- package/dist/esm/dist/esm/variables/components/VariableValueInput.js +0 -33
- package/dist/esm/dist/esm/variables/components/VariableValueSelect.js +0 -228
- package/dist/esm/dist/esm/variables/components/VariableValueSelectors.js +0 -72
- package/dist/esm/dist/esm/variables/components/getOptionSearcher.js +0 -15
- package/dist/esm/dist/esm/variables/constants.js +0 -9
- package/dist/esm/dist/esm/variables/getEnrichedFiltersRequest.js +0 -12
- package/dist/esm/dist/esm/variables/groupby/GroupByVariable.js +0 -259
- package/dist/esm/dist/esm/variables/groupby/GroupByVariableUrlSyncHandler.js +0 -63
- package/dist/esm/dist/esm/variables/groupby/findActiveGroupByVariablesByUid.js +0 -13
- package/dist/esm/dist/esm/variables/interpolation/ScopedVarsVariable.js +0 -40
- package/dist/esm/dist/esm/variables/interpolation/defaults.js +0 -21
- package/dist/esm/dist/esm/variables/interpolation/fieldAccessorCache.js +0 -13
- package/dist/esm/dist/esm/variables/interpolation/formatRegistry.js +0 -296
- package/dist/esm/dist/esm/variables/interpolation/sceneInterpolator.js +0 -87
- package/dist/esm/dist/esm/variables/lookupVariable.js +0 -20
- package/dist/esm/dist/esm/variables/macros/AllVariablesMacro.js +0 -57
- package/dist/esm/dist/esm/variables/macros/contextMacros.js +0 -43
- package/dist/esm/dist/esm/variables/macros/dataMacros.js +0 -134
- package/dist/esm/dist/esm/variables/macros/index.js +0 -26
- package/dist/esm/dist/esm/variables/macros/templateProxies.js +0 -51
- package/dist/esm/dist/esm/variables/macros/timeMacros.js +0 -86
- package/dist/esm/dist/esm/variables/macros/types.js +0 -11
- package/dist/esm/dist/esm/variables/macros/urlMacros.js +0 -56
- package/dist/esm/dist/esm/variables/sets/SceneVariableSet.js +0 -254
- package/dist/esm/dist/esm/variables/types.js +0 -11
- package/dist/esm/dist/esm/variables/utils.js +0 -172
- package/dist/esm/dist/esm/variables/variants/ConstantVariable.js +0 -38
- package/dist/esm/dist/esm/variables/variants/CustomVariable.js +0 -60
- package/dist/esm/dist/esm/variables/variants/DataSourceVariable.js +0 -88
- package/dist/esm/dist/esm/variables/variants/IntervalVariable.js +0 -117
- package/dist/esm/dist/esm/variables/variants/MultiValueVariable.js +0 -295
- package/dist/esm/dist/esm/variables/variants/TestVariable.js +0 -117
- package/dist/esm/dist/esm/variables/variants/TextBoxVariable.js +0 -61
- package/dist/esm/dist/esm/variables/variants/query/QueryVariable.js +0 -139
- package/dist/esm/dist/esm/variables/variants/query/createQueryVariableRunner.js +0 -129
- package/dist/esm/dist/esm/variables/variants/query/guards.js +0 -28
- package/dist/esm/dist/esm/variables/variants/query/toMetricFindValues.js +0 -96
- package/dist/esm/dist/esm/variables/variants/query/utils.js +0 -124
- package/dist/esm/querying/DataProviderSharer.js +0 -39
- package/dist/esm/src/behaviors/ActWhenVariableChanged.js +0 -27
- package/dist/esm/src/behaviors/CursorSync.js +0 -76
- package/dist/esm/src/behaviors/LiveNowTimer.js +0 -44
- package/dist/esm/src/behaviors/SceneQueryController.js +0 -60
- package/dist/esm/src/behaviors/index.js +0 -5
- package/dist/esm/src/components/EmbeddedScene.js +0 -59
- package/dist/esm/src/components/NestedScene.js +0 -95
- package/dist/esm/src/components/SceneApp/SceneApp.js +0 -37
- package/dist/esm/src/components/SceneApp/SceneAppPage.js +0 -176
- package/dist/esm/src/components/SceneApp/SceneAppPageView.js +0 -104
- package/dist/esm/src/components/SceneApp/utils.js +0 -42
- package/dist/esm/src/components/SceneByFrameRepeater.js +0 -41
- package/dist/esm/src/components/SceneByVariableRepeater.js +0 -55
- package/dist/esm/src/components/SceneCanvasText.js +0 -32
- package/dist/esm/src/components/SceneControlsSpacer.js +0 -17
- package/dist/esm/src/components/SceneDebugger/DebugDetails.js +0 -82
- package/dist/esm/src/components/SceneDebugger/DebugTreeNode.js +0 -72
- package/dist/esm/src/components/SceneDebugger/SceneDebugger.js +0 -77
- package/dist/esm/src/components/SceneReactObject.js +0 -34
- package/dist/esm/src/components/SceneRefreshPicker.js +0 -205
- package/dist/esm/src/components/SceneTimePicker.js +0 -139
- package/dist/esm/src/components/SceneTimeRangeCompare.js +0 -240
- package/dist/esm/src/components/SceneToolbarButton.js +0 -33
- package/dist/esm/src/components/VizPanel/VizPanel.js +0 -406
- package/dist/esm/src/components/VizPanel/VizPanelExploreButton.js +0 -44
- package/dist/esm/src/components/VizPanel/VizPanelMenu.js +0 -59
- package/dist/esm/src/components/VizPanel/VizPanelRenderer.js +0 -285
- package/dist/esm/src/components/VizPanel/VizPanelSeriesLimit.js +0 -45
- package/dist/esm/src/components/VizPanel/colorSeriesConfigFactory.js +0 -72
- package/dist/esm/src/components/VizPanel/registerRuntimePanelPlugin.js +0 -56
- package/dist/esm/src/components/VizPanel/seriesVisibilityConfigFactory.js +0 -164
- package/dist/esm/src/components/layout/CSSGrid/SceneCSSGridLayout.js +0 -124
- package/dist/esm/src/components/layout/LazyLoader.js +0 -103
- package/dist/esm/src/components/layout/SceneFlexLayout.js +0 -135
- package/dist/esm/src/components/layout/grid/SceneGridItem.js +0 -30
- package/dist/esm/src/components/layout/grid/SceneGridLayout.js +0 -283
- package/dist/esm/src/components/layout/grid/SceneGridLayoutRenderer.js +0 -178
- package/dist/esm/src/components/layout/grid/SceneGridRow.js +0 -190
- package/dist/esm/src/components/layout/grid/constants.js +0 -7
- package/dist/esm/src/components/layout/grid/utils.js +0 -36
- package/dist/esm/src/components/layout/split/SplitLayout.js +0 -17
- package/dist/esm/src/components/layout/split/SplitLayoutRenderer.js +0 -29
- package/dist/esm/src/components/layout/split/Splitter.js +0 -386
- package/dist/esm/src/core/PanelBuilders/FieldConfigBuilder.js +0 -100
- package/dist/esm/src/core/PanelBuilders/FieldConfigBuilders.js +0 -75
- package/dist/esm/src/core/PanelBuilders/FieldConfigOverridesBuilder.js +0 -75
- package/dist/esm/src/core/PanelBuilders/PanelOptionsBuilder.js +0 -22
- package/dist/esm/src/core/PanelBuilders/PanelOptionsBuilders.js +0 -85
- package/dist/esm/src/core/PanelBuilders/StandardFieldConfigBuilders.js +0 -52
- package/dist/esm/src/core/PanelBuilders/VizConfigBuilder.js +0 -78
- package/dist/esm/src/core/PanelBuilders/VizConfigBuilders.js +0 -114
- package/dist/esm/src/core/PanelBuilders/VizPanelBuilder.js +0 -162
- package/dist/esm/src/core/PanelBuilders/index.js +0 -116
- package/dist/esm/src/core/SceneComponentWrapper.js +0 -57
- package/dist/esm/src/core/SceneDataNode.js +0 -43
- package/dist/esm/src/core/SceneObjectBase.js +0 -286
- package/dist/esm/src/core/SceneObjectRef.js +0 -32
- package/dist/esm/src/core/SceneTimeRange.js +0 -231
- package/dist/esm/src/core/SceneTimeRangeTransformerBase.js +0 -35
- package/dist/esm/src/core/SceneTimeZoneOverride.js +0 -63
- package/dist/esm/src/core/events.js +0 -11
- package/dist/esm/src/core/sceneGraph/getTimeRange.js +0 -10
- package/dist/esm/src/core/sceneGraph/index.js +0 -25
- package/dist/esm/src/core/sceneGraph/sceneGraph.js +0 -178
- package/dist/esm/src/core/sceneGraph/utils.js +0 -64
- package/dist/esm/src/core/types.js +0 -15
- package/dist/esm/src/index.js +0 -108
- package/dist/esm/src/querying/DataLayersMerger.js +0 -46
- package/dist/esm/src/querying/DataProviderProxy.js +0 -37
- package/dist/esm/src/querying/DataProviderSharer.js +0 -108
- package/dist/esm/src/querying/ExtraQueryProvider.js +0 -6
- package/dist/esm/src/querying/RuntimeDataSource.js +0 -49
- package/dist/esm/src/querying/SceneDataLayerSet.js +0 -100
- package/dist/esm/src/querying/SceneDataTransformer.js +0 -178
- package/dist/esm/src/querying/SceneQueryRunner.js +0 -468
- package/dist/esm/src/querying/extraQueryProcessingOperator.js +0 -46
- package/dist/esm/src/querying/getEnrichedDataRequest.js +0 -12
- package/dist/esm/src/querying/layers/SceneDataLayerBase.js +0 -112
- package/dist/esm/src/querying/layers/SceneDataLayerControls.js +0 -51
- package/dist/esm/src/querying/layers/annotations/AnnotationsDataLayer.js +0 -130
- package/dist/esm/src/querying/layers/annotations/filterAnnotations.js +0 -85
- package/dist/esm/src/querying/layers/annotations/standardAnnotationQuery.js +0 -121
- package/dist/esm/src/querying/layers/annotations/standardAnnotationsSupport.js +0 -211
- package/dist/esm/src/querying/layers/annotations/utils.js +0 -77
- package/dist/esm/src/querying/layers/index.js +0 -2
- package/dist/esm/src/querying/registerQueryWithController.js +0 -41
- package/dist/esm/src/services/SceneObjectUrlSyncConfig.js +0 -30
- package/dist/esm/src/services/UniqueUrlKeyMapper.js +0 -45
- package/dist/esm/src/services/UrlSyncContextProvider.js +0 -17
- package/dist/esm/src/services/UrlSyncManager.js +0 -167
- package/dist/esm/src/services/useUrlSync.js +0 -29
- package/dist/esm/src/services/utils.js +0 -75
- package/dist/esm/src/utils/ControlsLabel.js +0 -107
- package/dist/esm/src/utils/LoadingIndicator.js +0 -19
- package/dist/esm/src/utils/SafeSerializableSceneObject.js +0 -39
- package/dist/esm/src/utils/compatibility/setWindowGrafanaSceneContext.js +0 -16
- package/dist/esm/src/utils/date.js +0 -15
- package/dist/esm/src/utils/evaluateTimeRange.js +0 -16
- package/dist/esm/src/utils/explore.js +0 -47
- package/dist/esm/src/utils/getCompareSeriesRefId.js +0 -4
- package/dist/esm/src/utils/getDataSource.js +0 -18
- package/dist/esm/src/utils/getMessageFromError.js +0 -24
- package/dist/esm/src/utils/metricTree.js +0 -53
- package/dist/esm/src/utils/parseUrlParam.js +0 -41
- package/dist/esm/src/utils/utils.js +0 -11
- package/dist/esm/src/utils/wrapInSafeSerializableSceneObject.js +0 -30
- package/dist/esm/src/utils/writeSceneLog.js +0 -12
- package/dist/esm/src/variables/VariableDependencyConfig.js +0 -150
- package/dist/esm/src/variables/VariableValueRecorder.js +0 -71
- package/dist/esm/src/variables/adhoc/AdHocFilterBuilder.js +0 -24
- package/dist/esm/src/variables/adhoc/AdHocFilterRenderer.js +0 -303
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFilterPill.js +0 -162
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersAlwaysWipCombobox.js +0 -20
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersCombobox.js +0 -640
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersComboboxRenderer.js +0 -65
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/DropdownItem.js +0 -146
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/MultiValuePill.js +0 -114
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/useFloatingInteractions.js +0 -68
- package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/utils.js +0 -146
- package/dist/esm/src/variables/adhoc/AdHocFiltersVariable.js +0 -289
- package/dist/esm/src/variables/adhoc/AdHocFiltersVariableUrlSyncHandler.js +0 -76
- package/dist/esm/src/variables/adhoc/getAdhocOptionSearcher.js +0 -13
- package/dist/esm/src/variables/adhoc/patchGetAdhocFilters.js +0 -47
- package/dist/esm/src/variables/components/VariableValueControl.js +0 -23
- package/dist/esm/src/variables/components/VariableValueInput.js +0 -33
- package/dist/esm/src/variables/components/VariableValueSelect.js +0 -228
- package/dist/esm/src/variables/components/VariableValueSelectors.js +0 -72
- package/dist/esm/src/variables/components/getOptionSearcher.js +0 -15
- package/dist/esm/src/variables/constants.js +0 -9
- package/dist/esm/src/variables/getEnrichedFiltersRequest.js +0 -12
- package/dist/esm/src/variables/groupby/GroupByVariable.js +0 -259
- package/dist/esm/src/variables/groupby/GroupByVariableUrlSyncHandler.js +0 -63
- package/dist/esm/src/variables/groupby/findActiveGroupByVariablesByUid.js +0 -13
- package/dist/esm/src/variables/interpolation/ScopedVarsVariable.js +0 -40
- package/dist/esm/src/variables/interpolation/defaults.js +0 -21
- package/dist/esm/src/variables/interpolation/fieldAccessorCache.js +0 -13
- package/dist/esm/src/variables/interpolation/formatRegistry.js +0 -296
- package/dist/esm/src/variables/interpolation/sceneInterpolator.js +0 -87
- package/dist/esm/src/variables/lookupVariable.js +0 -20
- package/dist/esm/src/variables/macros/AllVariablesMacro.js +0 -57
- package/dist/esm/src/variables/macros/contextMacros.js +0 -43
- package/dist/esm/src/variables/macros/dataMacros.js +0 -134
- package/dist/esm/src/variables/macros/index.js +0 -35
- package/dist/esm/src/variables/macros/templateProxies.js +0 -51
- package/dist/esm/src/variables/macros/timeMacros.js +0 -86
- package/dist/esm/src/variables/macros/types.js +0 -11
- package/dist/esm/src/variables/macros/urlMacros.js +0 -56
- package/dist/esm/src/variables/sets/SceneVariableSet.js +0 -254
- package/dist/esm/src/variables/types.js +0 -11
- package/dist/esm/src/variables/utils.js +0 -172
- package/dist/esm/src/variables/variants/ConstantVariable.js +0 -38
- package/dist/esm/src/variables/variants/CustomVariable.js +0 -60
- package/dist/esm/src/variables/variants/DataSourceVariable.js +0 -88
- package/dist/esm/src/variables/variants/IntervalVariable.js +0 -117
- package/dist/esm/src/variables/variants/JsonVariable.js +0 -193
- package/dist/esm/src/variables/variants/LocalValueVariable.js +0 -56
- package/dist/esm/src/variables/variants/MultiValueVariable.js +0 -295
- package/dist/esm/src/variables/variants/TestVariable.js +0 -117
- package/dist/esm/src/variables/variants/TextBoxVariable.js +0 -61
- package/dist/esm/src/variables/variants/guards.js +0 -27
- package/dist/esm/src/variables/variants/query/QueryVariable.js +0 -139
- package/dist/esm/src/variables/variants/query/createQueryVariableRunner.js +0 -129
- package/dist/esm/src/variables/variants/query/guards.js +0 -28
- package/dist/esm/src/variables/variants/query/toMetricFindValues.js +0 -96
- package/dist/esm/src/variables/variants/query/utils.js +0 -124
- package/dist/esm/variables/variants/JsonVariable.js +0 -96
- package/dist/esm/variables/variants/json/JsonVariable.js +0 -95
- package/dist/esm/variables/variants/json/JsonVariableOptionProviders.js +0 -70
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import { cx, css } from '@emotion/css';
|
|
2
|
-
import { useStyles2, Icon } from '@grafana/ui';
|
|
3
|
-
import React, { memo, useRef } from 'react';
|
|
4
|
-
import { AdHocFilterPill } from './AdHocFilterPill.js';
|
|
5
|
-
import { AdHocFiltersAlwaysWipCombobox } from './AdHocFiltersAlwaysWipCombobox.js';
|
|
6
|
-
|
|
7
|
-
const AdHocFiltersComboboxRenderer = memo(function AdHocFiltersComboboxRenderer2({ model }) {
|
|
8
|
-
const { filters, readOnly } = model.useState();
|
|
9
|
-
const styles = useStyles2(getStyles);
|
|
10
|
-
const focusOnWipInputRef = useRef();
|
|
11
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
12
|
-
className: cx(styles.comboboxWrapper, { [styles.comboboxFocusOutline]: !readOnly }),
|
|
13
|
-
onClick: () => {
|
|
14
|
-
var _a;
|
|
15
|
-
(_a = focusOnWipInputRef.current) == null ? void 0 : _a.call(focusOnWipInputRef);
|
|
16
|
-
}
|
|
17
|
-
}, /* @__PURE__ */ React.createElement(Icon, {
|
|
18
|
-
name: "filter",
|
|
19
|
-
className: styles.filterIcon,
|
|
20
|
-
size: "lg"
|
|
21
|
-
}), filters.map((filter, index) => /* @__PURE__ */ React.createElement(AdHocFilterPill, {
|
|
22
|
-
key: `${index}-${filter.key}`,
|
|
23
|
-
filter,
|
|
24
|
-
model,
|
|
25
|
-
readOnly,
|
|
26
|
-
focusOnWipInputRef: focusOnWipInputRef.current
|
|
27
|
-
})), !readOnly ? /* @__PURE__ */ React.createElement(AdHocFiltersAlwaysWipCombobox, {
|
|
28
|
-
model,
|
|
29
|
-
ref: focusOnWipInputRef
|
|
30
|
-
}) : null);
|
|
31
|
-
});
|
|
32
|
-
const getStyles = (theme) => ({
|
|
33
|
-
comboboxWrapper: css({
|
|
34
|
-
display: "flex",
|
|
35
|
-
flexWrap: "wrap",
|
|
36
|
-
alignItems: "center",
|
|
37
|
-
columnGap: theme.spacing(1),
|
|
38
|
-
rowGap: theme.spacing(0.5),
|
|
39
|
-
minHeight: theme.spacing(4),
|
|
40
|
-
backgroundColor: theme.components.input.background,
|
|
41
|
-
border: `1px solid ${theme.colors.border.strong}`,
|
|
42
|
-
borderRadius: theme.shape.radius.default,
|
|
43
|
-
paddingInline: theme.spacing(1),
|
|
44
|
-
paddingBlock: theme.spacing(0.5),
|
|
45
|
-
flexGrow: 1
|
|
46
|
-
}),
|
|
47
|
-
comboboxFocusOutline: css({
|
|
48
|
-
"&:focus-within": {
|
|
49
|
-
outline: "2px dotted transparent",
|
|
50
|
-
outlineOffset: "2px",
|
|
51
|
-
boxShadow: `0 0 0 2px ${theme.colors.background.canvas}, 0 0 0px 4px ${theme.colors.primary.main}`,
|
|
52
|
-
transitionTimingFunction: `cubic-bezier(0.19, 1, 0.22, 1)`,
|
|
53
|
-
transitionDuration: "0.2s",
|
|
54
|
-
transitionProperty: "outline, outline-offset, box-shadow",
|
|
55
|
-
zIndex: 2
|
|
56
|
-
}
|
|
57
|
-
}),
|
|
58
|
-
filterIcon: css({
|
|
59
|
-
color: theme.colors.text.secondary,
|
|
60
|
-
alignSelf: "center"
|
|
61
|
-
})
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
export { AdHocFiltersComboboxRenderer };
|
|
65
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWRIb2NGaWx0ZXJzQ29tYm9ib3hSZW5kZXJlci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3ZhcmlhYmxlcy9hZGhvYy9BZEhvY0ZpbHRlcnNDb21ib2JveC9BZEhvY0ZpbHRlcnNDb21ib2JveFJlbmRlcmVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIGN4IH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcbmltcG9ydCB7IEdyYWZhbmFUaGVtZTIgfSBmcm9tICdAZ3JhZmFuYS9kYXRhJztcbmltcG9ydCB7IEljb24sIHVzZVN0eWxlczIgfSBmcm9tICdAZ3JhZmFuYS91aSc7XG5pbXBvcnQgUmVhY3QsIHsgbWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQWRIb2NGaWx0ZXJzVmFyaWFibGUgfSBmcm9tICcuLi9BZEhvY0ZpbHRlcnNWYXJpYWJsZSc7XG5pbXBvcnQgeyBBZEhvY0ZpbHRlclBpbGwgfSBmcm9tICcuL0FkSG9jRmlsdGVyUGlsbCc7XG5pbXBvcnQgeyBBZEhvY0ZpbHRlcnNBbHdheXNXaXBDb21ib2JveCB9IGZyb20gJy4vQWRIb2NGaWx0ZXJzQWx3YXlzV2lwQ29tYm9ib3gnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBtb2RlbDogQWRIb2NGaWx0ZXJzVmFyaWFibGU7XG59XG5cbmV4cG9ydCBjb25zdCBBZEhvY0ZpbHRlcnNDb21ib2JveFJlbmRlcmVyID0gbWVtbyhmdW5jdGlvbiBBZEhvY0ZpbHRlcnNDb21ib2JveFJlbmRlcmVyKHsgbW9kZWwgfTogUHJvcHMpIHtcbiAgY29uc3QgeyBmaWx0ZXJzLCByZWFkT25seSB9ID0gbW9kZWwudXNlU3RhdGUoKTtcbiAgY29uc3Qgc3R5bGVzID0gdXNlU3R5bGVzMihnZXRTdHlsZXMpO1xuXG4gIC8vIHJlZiB0aGF0IGZvY3VzZXMgb24gdGhlIGFsd2F5cyB3aXAgZmlsdGVyIGlucHV0XG4gIC8vIGRlZmluZWQgaW4gdGhlIGNvbWJvYm94IGNvbXBvbmVudCB2aWEgdXNlSW1wZXJhdGl2ZUhhbmRsZVxuICBjb25zdCBmb2N1c09uV2lwSW5wdXRSZWYgPSB1c2VSZWY8KCkgPT4gdm9pZD4oKTtcblxuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNsYXNzTmFtZT17Y3goc3R5bGVzLmNvbWJvYm94V3JhcHBlciwgeyBbc3R5bGVzLmNvbWJvYm94Rm9jdXNPdXRsaW5lXTogIXJlYWRPbmx5IH0pfVxuICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICBmb2N1c09uV2lwSW5wdXRSZWYuY3VycmVudD8uKCk7XG4gICAgICB9fVxuICAgID5cbiAgICAgIDxJY29uIG5hbWU9XCJmaWx0ZXJcIiBjbGFzc05hbWU9e3N0eWxlcy5maWx0ZXJJY29ufSBzaXplPVwibGdcIiAvPlxuXG4gICAgICB7ZmlsdGVycy5tYXAoKGZpbHRlciwgaW5kZXgpID0+IChcbiAgICAgICAgPEFkSG9jRmlsdGVyUGlsbFxuICAgICAgICAgIGtleT17YCR7aW5kZXh9LSR7ZmlsdGVyLmtleX1gfVxuICAgICAgICAgIGZpbHRlcj17ZmlsdGVyfVxuICAgICAgICAgIG1vZGVsPXttb2RlbH1cbiAgICAgICAgICByZWFkT25seT17cmVhZE9ubHl9XG4gICAgICAgICAgZm9jdXNPbldpcElucHV0UmVmPXtmb2N1c09uV2lwSW5wdXRSZWYuY3VycmVudH1cbiAgICAgICAgLz5cbiAgICAgICkpfVxuXG4gICAgICB7IXJlYWRPbmx5ID8gPEFkSG9jRmlsdGVyc0Fsd2F5c1dpcENvbWJvYm94IG1vZGVsPXttb2RlbH0gcmVmPXtmb2N1c09uV2lwSW5wdXRSZWZ9IC8+IDogbnVsbH1cbiAgICA8L2Rpdj5cbiAgKTtcbn0pO1xuXG5jb25zdCBnZXRTdHlsZXMgPSAodGhlbWU6IEdyYWZhbmFUaGVtZTIpID0+ICh7XG4gIGNvbWJvYm94V3JhcHBlcjogY3NzKHtcbiAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgZmxleFdyYXA6ICd3cmFwJyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICBjb2x1bW5HYXA6IHRoZW1lLnNwYWNpbmcoMSksXG4gICAgcm93R2FwOiB0aGVtZS5zcGFjaW5nKDAuNSksXG4gICAgbWluSGVpZ2h0OiB0aGVtZS5zcGFjaW5nKDQpLFxuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29tcG9uZW50cy5pbnB1dC5iYWNrZ3JvdW5kLFxuICAgIGJvcmRlcjogYDFweCBzb2xpZCAke3RoZW1lLmNvbG9ycy5ib3JkZXIuc3Ryb25nfWAsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS5zaGFwZS5yYWRpdXMuZGVmYXVsdCxcbiAgICBwYWRkaW5nSW5saW5lOiB0aGVtZS5zcGFjaW5nKDEpLFxuICAgIHBhZGRpbmdCbG9jazogdGhlbWUuc3BhY2luZygwLjUpLFxuICAgIGZsZXhHcm93OiAxLFxuICB9KSxcbiAgY29tYm9ib3hGb2N1c091dGxpbmU6IGNzcyh7XG4gICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgb3V0bGluZTogJzJweCBkb3R0ZWQgdHJhbnNwYXJlbnQnLFxuICAgICAgb3V0bGluZU9mZnNldDogJzJweCcsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAycHggJHt0aGVtZS5jb2xvcnMuYmFja2dyb3VuZC5jYW52YXN9LCAwIDAgMHB4IDRweCAke3RoZW1lLmNvbG9ycy5wcmltYXJ5Lm1haW59YCxcbiAgICAgIHRyYW5zaXRpb25UaW1pbmdGdW5jdGlvbjogYGN1YmljLWJlemllcigwLjE5LCAxLCAwLjIyLCAxKWAsXG4gICAgICB0cmFuc2l0aW9uRHVyYXRpb246ICcwLjJzJyxcbiAgICAgIHRyYW5zaXRpb25Qcm9wZXJ0eTogJ291dGxpbmUsIG91dGxpbmUtb2Zmc2V0LCBib3gtc2hhZG93JyxcbiAgICAgIHpJbmRleDogMixcbiAgICB9LFxuICB9KSxcbiAgZmlsdGVySWNvbjogY3NzKHtcbiAgICBjb2xvcjogdGhlbWUuY29sb3JzLnRleHQuc2Vjb25kYXJ5LFxuICAgIGFsaWduU2VsZjogJ2NlbnRlcics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
|
|
@@ -1,146 +0,0 @@
|
|
|
1
|
-
import { cx, css } from '@emotion/css';
|
|
2
|
-
import { useStyles2, Checkbox, Button } from '@grafana/ui';
|
|
3
|
-
import React, { forwardRef, useId } from 'react';
|
|
4
|
-
|
|
5
|
-
var __defProp = Object.defineProperty;
|
|
6
|
-
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
9
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
10
|
-
var __spreadValues = (a, b) => {
|
|
11
|
-
for (var prop in b || (b = {}))
|
|
12
|
-
if (__hasOwnProp.call(b, prop))
|
|
13
|
-
__defNormalProp(a, prop, b[prop]);
|
|
14
|
-
if (__getOwnPropSymbols)
|
|
15
|
-
for (var prop of __getOwnPropSymbols(b)) {
|
|
16
|
-
if (__propIsEnum.call(b, prop))
|
|
17
|
-
__defNormalProp(a, prop, b[prop]);
|
|
18
|
-
}
|
|
19
|
-
return a;
|
|
20
|
-
};
|
|
21
|
-
var __objRest = (source, exclude) => {
|
|
22
|
-
var target = {};
|
|
23
|
-
for (var prop in source)
|
|
24
|
-
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
25
|
-
target[prop] = source[prop];
|
|
26
|
-
if (source != null && __getOwnPropSymbols)
|
|
27
|
-
for (var prop of __getOwnPropSymbols(source)) {
|
|
28
|
-
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
29
|
-
target[prop] = source[prop];
|
|
30
|
-
}
|
|
31
|
-
return target;
|
|
32
|
-
};
|
|
33
|
-
const DropdownItem = forwardRef(
|
|
34
|
-
function DropdownItem2(_a, ref) {
|
|
35
|
-
var _b = _a, { children, active, addGroupBottomBorder, isMultiValueEdit, checked } = _b, rest = __objRest(_b, ["children", "active", "addGroupBottomBorder", "isMultiValueEdit", "checked"]);
|
|
36
|
-
const styles = useStyles2(getStyles);
|
|
37
|
-
const id = useId();
|
|
38
|
-
return /* @__PURE__ */ React.createElement("div", __spreadValues({
|
|
39
|
-
ref,
|
|
40
|
-
role: "option",
|
|
41
|
-
id,
|
|
42
|
-
"aria-selected": active,
|
|
43
|
-
className: cx(styles.option, active && styles.optionFocused, addGroupBottomBorder && styles.groupBottomBorder)
|
|
44
|
-
}, rest), /* @__PURE__ */ React.createElement("div", {
|
|
45
|
-
className: styles.optionBody,
|
|
46
|
-
"data-testid": `data-testid ad hoc filter option value ${children}`
|
|
47
|
-
}, /* @__PURE__ */ React.createElement("span", null, isMultiValueEdit ? /* @__PURE__ */ React.createElement(Checkbox, {
|
|
48
|
-
tabIndex: -1,
|
|
49
|
-
checked,
|
|
50
|
-
className: styles.checkbox
|
|
51
|
-
}) : null, children)));
|
|
52
|
-
}
|
|
53
|
-
);
|
|
54
|
-
const getStyles = (theme) => ({
|
|
55
|
-
option: css({
|
|
56
|
-
label: "grafana-select-option",
|
|
57
|
-
top: 0,
|
|
58
|
-
left: 0,
|
|
59
|
-
width: "100%",
|
|
60
|
-
position: "absolute",
|
|
61
|
-
padding: theme.spacing(1),
|
|
62
|
-
display: "flex",
|
|
63
|
-
alignItems: "center",
|
|
64
|
-
flexDirection: "row",
|
|
65
|
-
flexShrink: 0,
|
|
66
|
-
whiteSpace: "nowrap",
|
|
67
|
-
cursor: "pointer",
|
|
68
|
-
"&:hover": {
|
|
69
|
-
background: theme.colors.action.hover,
|
|
70
|
-
"@media (forced-colors: active), (prefers-contrast: more)": {
|
|
71
|
-
border: `1px solid ${theme.colors.primary.border}`
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}),
|
|
75
|
-
optionFocused: css({
|
|
76
|
-
label: "grafana-select-option-focused",
|
|
77
|
-
background: theme.colors.action.focus,
|
|
78
|
-
"@media (forced-colors: active), (prefers-contrast: more)": {
|
|
79
|
-
border: `1px solid ${theme.colors.primary.border}`
|
|
80
|
-
}
|
|
81
|
-
}),
|
|
82
|
-
optionBody: css({
|
|
83
|
-
label: "grafana-select-option-body",
|
|
84
|
-
display: "flex",
|
|
85
|
-
fontWeight: theme.typography.fontWeightMedium,
|
|
86
|
-
flexDirection: "column",
|
|
87
|
-
flexGrow: 1
|
|
88
|
-
}),
|
|
89
|
-
groupBottomBorder: css({
|
|
90
|
-
borderBottom: `1px solid ${theme.colors.border.weak}`
|
|
91
|
-
}),
|
|
92
|
-
checkbox: css({
|
|
93
|
-
paddingRight: theme.spacing(0.5)
|
|
94
|
-
}),
|
|
95
|
-
multiValueApplyWrapper: css({
|
|
96
|
-
position: "fixed",
|
|
97
|
-
top: 0,
|
|
98
|
-
left: 0,
|
|
99
|
-
display: "flex",
|
|
100
|
-
backgroundColor: theme.colors.background.primary,
|
|
101
|
-
color: theme.colors.text.primary,
|
|
102
|
-
boxShadow: theme.shadows.z2,
|
|
103
|
-
overflowY: "auto",
|
|
104
|
-
zIndex: theme.zIndex.dropdown,
|
|
105
|
-
gap: theme.spacing(1.5),
|
|
106
|
-
padding: `${theme.spacing(1.5)} ${theme.spacing(1)}`
|
|
107
|
-
})
|
|
108
|
-
});
|
|
109
|
-
const LoadingOptionsPlaceholder = () => {
|
|
110
|
-
return /* @__PURE__ */ React.createElement(DropdownItem, {
|
|
111
|
-
onClick: (e) => e.stopPropagation()
|
|
112
|
-
}, "Loading options...");
|
|
113
|
-
};
|
|
114
|
-
const NoOptionsPlaceholder = () => {
|
|
115
|
-
return /* @__PURE__ */ React.createElement(DropdownItem, {
|
|
116
|
-
onClick: (e) => e.stopPropagation()
|
|
117
|
-
}, "No options found");
|
|
118
|
-
};
|
|
119
|
-
const OptionsErrorPlaceholder = ({ handleFetchOptions }) => {
|
|
120
|
-
return /* @__PURE__ */ React.createElement(DropdownItem, {
|
|
121
|
-
onClick: handleFetchOptions
|
|
122
|
-
}, "An error has occurred fetching labels. Click to retry");
|
|
123
|
-
};
|
|
124
|
-
const MultiValueApplyButton = ({
|
|
125
|
-
onApply,
|
|
126
|
-
floatingElement,
|
|
127
|
-
maxOptionWidth,
|
|
128
|
-
menuHeight
|
|
129
|
-
}) => {
|
|
130
|
-
const styles = useStyles2(getStyles);
|
|
131
|
-
const floatingElementRect = floatingElement == null ? void 0 : floatingElement.getBoundingClientRect();
|
|
132
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
133
|
-
className: styles.multiValueApplyWrapper,
|
|
134
|
-
style: {
|
|
135
|
-
width: `${maxOptionWidth}px`,
|
|
136
|
-
transform: `translate(${floatingElementRect == null ? void 0 : floatingElementRect.left}px,${floatingElementRect ? floatingElementRect.top + menuHeight : 0}px)`
|
|
137
|
-
}
|
|
138
|
-
}, /* @__PURE__ */ React.createElement(Button, {
|
|
139
|
-
onClick: onApply,
|
|
140
|
-
size: "sm",
|
|
141
|
-
tabIndex: -1
|
|
142
|
-
}, "Apply"));
|
|
143
|
-
};
|
|
144
|
-
|
|
145
|
-
export { DropdownItem, LoadingOptionsPlaceholder, MultiValueApplyButton, NoOptionsPlaceholder, OptionsErrorPlaceholder };
|
|
146
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"DropdownItem.js","sources":["../../../../../../src/variables/adhoc/AdHocFiltersCombobox/DropdownItem.tsx"],"sourcesContent":["import { css, cx } from '@emotion/css';\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Button, Checkbox, useStyles2 } from '@grafana/ui';\nimport React, { forwardRef, useId } from 'react';\n\ninterface DropdownItemProps {\n  children: React.ReactNode;\n  active?: boolean;\n  addGroupBottomBorder?: boolean;\n  isMultiValueEdit?: boolean;\n  checked?: boolean;\n}\n\nexport const DropdownItem = forwardRef<HTMLDivElement, DropdownItemProps & React.HTMLProps<HTMLDivElement>>(\n  function DropdownItem({ children, active, addGroupBottomBorder, isMultiValueEdit, checked, ...rest }, ref) {\n    const styles = useStyles2(getStyles);\n    const id = useId();\n    return (\n      <div\n        ref={ref}\n        role=\"option\"\n        id={id}\n        aria-selected={active}\n        className={cx(styles.option, active && styles.optionFocused, addGroupBottomBorder && styles.groupBottomBorder)}\n        {...rest}\n      >\n        <div className={styles.optionBody} data-testid={`data-testid ad hoc filter option value ${children}`}>\n          <span>\n            {isMultiValueEdit ? <Checkbox tabIndex={-1} checked={checked} className={styles.checkbox} /> : null}\n            {children}\n          </span>\n        </div>\n      </div>\n    );\n  }\n);\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n  option: css({\n    label: 'grafana-select-option',\n    top: 0,\n    left: 0,\n    width: '100%',\n    position: 'absolute',\n    padding: theme.spacing(1),\n    display: 'flex',\n    alignItems: 'center',\n    flexDirection: 'row',\n    flexShrink: 0,\n    whiteSpace: 'nowrap',\n    cursor: 'pointer',\n    '&:hover': {\n      background: theme.colors.action.hover,\n      '@media (forced-colors: active), (prefers-contrast: more)': {\n        border: `1px solid ${theme.colors.primary.border}`,\n      },\n    },\n  }),\n  optionFocused: css({\n    label: 'grafana-select-option-focused',\n    background: theme.colors.action.focus,\n    '@media (forced-colors: active), (prefers-contrast: more)': {\n      border: `1px solid ${theme.colors.primary.border}`,\n    },\n  }),\n  optionBody: css({\n    label: 'grafana-select-option-body',\n    display: 'flex',\n    fontWeight: theme.typography.fontWeightMedium,\n    flexDirection: 'column',\n    flexGrow: 1,\n  }),\n  groupBottomBorder: css({\n    borderBottom: `1px solid ${theme.colors.border.weak}`,\n  }),\n  checkbox: css({\n    paddingRight: theme.spacing(0.5),\n  }),\n  multiValueApplyWrapper: css({\n    position: 'fixed',\n    top: 0,\n    left: 0,\n    display: 'flex',\n    backgroundColor: theme.colors.background.primary,\n    color: theme.colors.text.primary,\n    boxShadow: theme.shadows.z2,\n    overflowY: 'auto',\n    zIndex: theme.zIndex.dropdown,\n    gap: theme.spacing(1.5),\n    padding: `${theme.spacing(1.5)} ${theme.spacing(1)}`,\n  }),\n});\n\nexport const LoadingOptionsPlaceholder = () => {\n  return <DropdownItem onClick={(e) => e.stopPropagation()}>Loading options...</DropdownItem>;\n};\n\nexport const NoOptionsPlaceholder = () => {\n  return <DropdownItem onClick={(e) => e.stopPropagation()}>No options found</DropdownItem>;\n};\n\nexport const OptionsErrorPlaceholder = ({ handleFetchOptions }: { handleFetchOptions: () => void }) => {\n  return (\n    <DropdownItem onClick={handleFetchOptions}>An error has occurred fetching labels. Click to retry</DropdownItem>\n  );\n};\n\ninterface MultiValueApplyButtonProps {\n  onApply: () => void;\n  floatingElement: HTMLElement | null;\n  maxOptionWidth: number;\n  menuHeight: number;\n}\n\nexport const MultiValueApplyButton = ({\n  onApply,\n  floatingElement,\n  maxOptionWidth,\n  menuHeight,\n}: MultiValueApplyButtonProps) => {\n  const styles = useStyles2(getStyles);\n\n  const floatingElementRect = floatingElement?.getBoundingClientRect();\n  return (\n    <div\n      className={styles.multiValueApplyWrapper}\n      style={{\n        width: `${maxOptionWidth}px`,\n        transform: `translate(${floatingElementRect?.left}px,${\n          floatingElementRect ? floatingElementRect.top + menuHeight : 0\n        }px)`,\n      }}\n    >\n      <Button onClick={onApply} size=\"sm\" tabIndex={-1}>\n        Apply\n      </Button>\n    </div>\n  );\n};\n"],"names":["DropdownItem"],"mappings":"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"}
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import { cx, css } from '@emotion/css';
|
|
2
|
-
import { useStyles2, Button, Icon } from '@grafana/ui';
|
|
3
|
-
import React, { useCallback } from 'react';
|
|
4
|
-
|
|
5
|
-
var __defProp = Object.defineProperty;
|
|
6
|
-
var __defProps = Object.defineProperties;
|
|
7
|
-
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
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
|
-
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
24
|
-
const MultiValuePill = ({
|
|
25
|
-
item,
|
|
26
|
-
handleRemoveMultiValue,
|
|
27
|
-
index,
|
|
28
|
-
handleEditMultiValuePill
|
|
29
|
-
}) => {
|
|
30
|
-
var _a, _b;
|
|
31
|
-
const styles = useStyles2(getStyles);
|
|
32
|
-
const editMultiValuePill = useCallback(
|
|
33
|
-
(e) => {
|
|
34
|
-
e.stopPropagation();
|
|
35
|
-
e.preventDefault();
|
|
36
|
-
handleEditMultiValuePill(item);
|
|
37
|
-
},
|
|
38
|
-
[handleEditMultiValuePill, item]
|
|
39
|
-
);
|
|
40
|
-
const editMultiValuePillWithKeyboard = useCallback(
|
|
41
|
-
(e) => {
|
|
42
|
-
if (e.key === "Enter") {
|
|
43
|
-
editMultiValuePill(e);
|
|
44
|
-
}
|
|
45
|
-
},
|
|
46
|
-
[editMultiValuePill]
|
|
47
|
-
);
|
|
48
|
-
const removePillHandler = useCallback(
|
|
49
|
-
(e) => {
|
|
50
|
-
e.stopPropagation();
|
|
51
|
-
e.preventDefault();
|
|
52
|
-
handleRemoveMultiValue(item);
|
|
53
|
-
},
|
|
54
|
-
[handleRemoveMultiValue, item]
|
|
55
|
-
);
|
|
56
|
-
const removePillHandlerWithKeyboard = useCallback(
|
|
57
|
-
(e) => {
|
|
58
|
-
if (e.key === "Enter") {
|
|
59
|
-
removePillHandler(e);
|
|
60
|
-
}
|
|
61
|
-
},
|
|
62
|
-
[removePillHandler]
|
|
63
|
-
);
|
|
64
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
65
|
-
className: cx(styles.basePill, styles.valuePill),
|
|
66
|
-
onClick: editMultiValuePill,
|
|
67
|
-
onKeyDown: editMultiValuePillWithKeyboard,
|
|
68
|
-
tabIndex: 0,
|
|
69
|
-
id: `${item.value}-${index}`
|
|
70
|
-
}, (_a = item.label) != null ? _a : item.value, /* @__PURE__ */ React.createElement(Button, {
|
|
71
|
-
onClick: removePillHandler,
|
|
72
|
-
onKeyDownCapture: removePillHandlerWithKeyboard,
|
|
73
|
-
fill: "text",
|
|
74
|
-
size: "sm",
|
|
75
|
-
variant: "secondary",
|
|
76
|
-
className: styles.removeButton,
|
|
77
|
-
tooltip: `Remove filter value - ${(_b = item.label) != null ? _b : item.value}`
|
|
78
|
-
}, /* @__PURE__ */ React.createElement(Icon, {
|
|
79
|
-
name: "times",
|
|
80
|
-
size: "md",
|
|
81
|
-
id: `${item.value}-${index}-close-icon`
|
|
82
|
-
})));
|
|
83
|
-
};
|
|
84
|
-
const getStyles = (theme) => ({
|
|
85
|
-
basePill: css(__spreadProps(__spreadValues({
|
|
86
|
-
display: "flex",
|
|
87
|
-
alignItems: "center",
|
|
88
|
-
background: theme.colors.action.disabledBackground,
|
|
89
|
-
border: `1px solid ${theme.colors.border.weak}`,
|
|
90
|
-
padding: theme.spacing(0.125, 1, 0.125, 1),
|
|
91
|
-
color: theme.colors.text.primary,
|
|
92
|
-
overflow: "hidden",
|
|
93
|
-
whiteSpace: "nowrap",
|
|
94
|
-
minHeight: theme.spacing(2.75)
|
|
95
|
-
}, theme.typography.bodySmall), {
|
|
96
|
-
cursor: "pointer"
|
|
97
|
-
})),
|
|
98
|
-
valuePill: css({
|
|
99
|
-
background: theme.colors.action.selected,
|
|
100
|
-
padding: theme.spacing(0.125, 0, 0.125, 1)
|
|
101
|
-
}),
|
|
102
|
-
removeButton: css({
|
|
103
|
-
marginInline: theme.spacing(0.5),
|
|
104
|
-
height: "100%",
|
|
105
|
-
padding: 0,
|
|
106
|
-
cursor: "pointer",
|
|
107
|
-
"&:hover": {
|
|
108
|
-
color: theme.colors.text.primary
|
|
109
|
-
}
|
|
110
|
-
})
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
export { MultiValuePill };
|
|
114
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"MultiValuePill.js","sources":["../../../../../../src/variables/adhoc/AdHocFiltersCombobox/MultiValuePill.tsx"],"sourcesContent":["import { cx, css } from '@emotion/css';\nimport { SelectableValue, GrafanaTheme2 } from '@grafana/data';\nimport { useStyles2, Button, Icon } from '@grafana/ui';\nimport React, { useCallback } from 'react';\n\ninterface MultiValuePillProps {\n  item: SelectableValue<string>;\n  handleRemoveMultiValue: (item: SelectableValue<string>) => void;\n  index: number;\n  handleEditMultiValuePill: (value: SelectableValue<string>) => void;\n}\nexport const MultiValuePill = ({\n  item,\n  handleRemoveMultiValue,\n  index,\n  handleEditMultiValuePill,\n}: MultiValuePillProps) => {\n  const styles = useStyles2(getStyles);\n\n  const editMultiValuePill = useCallback(\n    (e: React.SyntheticEvent) => {\n      e.stopPropagation();\n      e.preventDefault();\n      handleEditMultiValuePill(item);\n    },\n    [handleEditMultiValuePill, item]\n  );\n\n  const editMultiValuePillWithKeyboard = useCallback(\n    (e: React.KeyboardEvent) => {\n      if (e.key === 'Enter') {\n        editMultiValuePill(e);\n      }\n    },\n    [editMultiValuePill]\n  );\n\n  const removePillHandler = useCallback(\n    (e: React.SyntheticEvent) => {\n      e.stopPropagation();\n      e.preventDefault();\n      handleRemoveMultiValue(item);\n    },\n    [handleRemoveMultiValue, item]\n  );\n\n  const removePillHandlerWithKeyboard = useCallback(\n    (e: React.KeyboardEvent) => {\n      if (e.key === 'Enter') {\n        removePillHandler(e);\n      }\n    },\n    [removePillHandler]\n  );\n\n  return (\n    <div\n      className={cx(styles.basePill, styles.valuePill)}\n      onClick={editMultiValuePill}\n      onKeyDown={editMultiValuePillWithKeyboard}\n      tabIndex={0}\n      id={`${item.value}-${index}`}\n    >\n      {item.label ?? item.value}\n      <Button\n        onClick={removePillHandler}\n        onKeyDownCapture={removePillHandlerWithKeyboard}\n        fill=\"text\"\n        size=\"sm\"\n        variant=\"secondary\"\n        className={styles.removeButton}\n        tooltip={`Remove filter value - ${item.label ?? item.value}`}\n      >\n        <Icon name=\"times\" size=\"md\" id={`${item.value}-${index}-close-icon`} />\n      </Button>\n    </div>\n  );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n  basePill: css({\n    display: 'flex',\n    alignItems: 'center',\n    background: theme.colors.action.disabledBackground,\n    border: `1px solid ${theme.colors.border.weak}`,\n    padding: theme.spacing(0.125, 1, 0.125, 1),\n    color: theme.colors.text.primary,\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    minHeight: theme.spacing(2.75),\n    ...theme.typography.bodySmall,\n    cursor: 'pointer',\n  }),\n  valuePill: css({\n    background: theme.colors.action.selected,\n    padding: theme.spacing(0.125, 0, 0.125, 1),\n  }),\n  removeButton: css({\n    marginInline: theme.spacing(0.5),\n    height: '100%',\n    padding: 0,\n    cursor: 'pointer',\n    '&:hover': {\n      color: theme.colors.text.primary,\n    },\n  }),\n});\n"],"names":[],"mappings":"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"}
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { useFloating, autoUpdate, offset, flip, size, useRole, useDismiss, useListNavigation, useInteractions } from '@floating-ui/react';
|
|
2
|
-
|
|
3
|
-
const MAX_MENU_HEIGHT = 300;
|
|
4
|
-
const useFloatingInteractions = ({
|
|
5
|
-
open,
|
|
6
|
-
onOpenChange,
|
|
7
|
-
activeIndex,
|
|
8
|
-
setActiveIndex,
|
|
9
|
-
outsidePressIdsToIgnore,
|
|
10
|
-
listRef,
|
|
11
|
-
disabledIndicesRef
|
|
12
|
-
}) => {
|
|
13
|
-
const { refs, floatingStyles, context } = useFloating({
|
|
14
|
-
whileElementsMounted: autoUpdate,
|
|
15
|
-
open,
|
|
16
|
-
onOpenChange,
|
|
17
|
-
placement: "bottom-start",
|
|
18
|
-
middleware: [
|
|
19
|
-
offset(10),
|
|
20
|
-
flip({ padding: 10 }),
|
|
21
|
-
size({
|
|
22
|
-
apply({ availableHeight, availableWidth, elements }) {
|
|
23
|
-
elements.floating.style.maxHeight = `${Math.min(MAX_MENU_HEIGHT, availableHeight)}px`;
|
|
24
|
-
elements.floating.style.maxWidth = `${availableWidth}px`;
|
|
25
|
-
},
|
|
26
|
-
padding: 10
|
|
27
|
-
})
|
|
28
|
-
],
|
|
29
|
-
strategy: "fixed"
|
|
30
|
-
});
|
|
31
|
-
const role = useRole(context, { role: "listbox" });
|
|
32
|
-
const dismiss = useDismiss(context, {
|
|
33
|
-
outsidePress: (event) => {
|
|
34
|
-
var _a;
|
|
35
|
-
if (event.currentTarget instanceof Element) {
|
|
36
|
-
const target = event.currentTarget;
|
|
37
|
-
let idToCompare = target.id;
|
|
38
|
-
if (target.nodeName === "path") {
|
|
39
|
-
idToCompare = ((_a = target.parentElement) == null ? void 0 : _a.id) || "";
|
|
40
|
-
}
|
|
41
|
-
if (outsidePressIdsToIgnore.includes(idToCompare)) {
|
|
42
|
-
return false;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
return true;
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
const listNav = useListNavigation(context, {
|
|
49
|
-
listRef,
|
|
50
|
-
activeIndex,
|
|
51
|
-
onNavigate: setActiveIndex,
|
|
52
|
-
virtual: true,
|
|
53
|
-
loop: true,
|
|
54
|
-
disabledIndices: disabledIndicesRef.current
|
|
55
|
-
});
|
|
56
|
-
const { getReferenceProps, getFloatingProps, getItemProps } = useInteractions([role, dismiss, listNav]);
|
|
57
|
-
return {
|
|
58
|
-
refs,
|
|
59
|
-
floatingStyles,
|
|
60
|
-
context,
|
|
61
|
-
getReferenceProps,
|
|
62
|
-
getFloatingProps,
|
|
63
|
-
getItemProps
|
|
64
|
-
};
|
|
65
|
-
};
|
|
66
|
-
|
|
67
|
-
export { MAX_MENU_HEIGHT, useFloatingInteractions };
|
|
68
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlRmxvYXRpbmdJbnRlcmFjdGlvbnMuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy92YXJpYWJsZXMvYWRob2MvQWRIb2NGaWx0ZXJzQ29tYm9ib3gvdXNlRmxvYXRpbmdJbnRlcmFjdGlvbnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlRmxvYXRpbmcsXG4gIGF1dG9VcGRhdGUsXG4gIG9mZnNldCxcbiAgdXNlUm9sZSxcbiAgdXNlRGlzbWlzcyxcbiAgdXNlTGlzdE5hdmlnYXRpb24sXG4gIFVzZUZsb2F0aW5nT3B0aW9ucyxcbiAgZmxpcCxcbiAgc2l6ZSxcbiAgVXNlTGlzdE5hdmlnYXRpb25Qcm9wcyxcbiAgdXNlSW50ZXJhY3Rpb25zLFxufSBmcm9tICdAZmxvYXRpbmctdWkvcmVhY3QnO1xuXG50eXBlIHVzZUZsb2F0aW5nSW50ZXJhY3Rpb25zUHJvcHMgPSB7XG4gIG9wZW46IFVzZUZsb2F0aW5nT3B0aW9uc1snb3BlbiddO1xuICBvbk9wZW5DaGFuZ2U6IFVzZUZsb2F0aW5nT3B0aW9uc1snb25PcGVuQ2hhbmdlJ107XG4gIGFjdGl2ZUluZGV4OiBVc2VMaXN0TmF2aWdhdGlvblByb3BzWydhY3RpdmVJbmRleCddO1xuICBzZXRBY3RpdmVJbmRleDogVXNlTGlzdE5hdmlnYXRpb25Qcm9wc1snb25OYXZpZ2F0ZSddO1xuICBvdXRzaWRlUHJlc3NJZHNUb0lnbm9yZTogc3RyaW5nW107XG4gIGxpc3RSZWY6IFJlYWN0Lk11dGFibGVSZWZPYmplY3Q8QXJyYXk8SFRNTEVsZW1lbnQgfCBudWxsPj47XG4gIGRpc2FibGVkSW5kaWNlc1JlZjogUmVhY3QuTXV0YWJsZVJlZk9iamVjdDxudW1iZXJbXT47XG59O1xuXG5leHBvcnQgY29uc3QgTUFYX01FTlVfSEVJR0hUID0gMzAwO1xuXG5leHBvcnQgY29uc3QgdXNlRmxvYXRpbmdJbnRlcmFjdGlvbnMgPSAoe1xuICBvcGVuLFxuICBvbk9wZW5DaGFuZ2UsXG4gIGFjdGl2ZUluZGV4LFxuICBzZXRBY3RpdmVJbmRleCxcbiAgb3V0c2lkZVByZXNzSWRzVG9JZ25vcmUsXG4gIGxpc3RSZWYsXG4gIGRpc2FibGVkSW5kaWNlc1JlZixcbn06IHVzZUZsb2F0aW5nSW50ZXJhY3Rpb25zUHJvcHMpID0+IHtcbiAgY29uc3QgeyByZWZzLCBmbG9hdGluZ1N0eWxlcywgY29udGV4dCB9ID0gdXNlRmxvYXRpbmc8SFRNTElucHV0RWxlbWVudD4oe1xuICAgIHdoaWxlRWxlbWVudHNNb3VudGVkOiBhdXRvVXBkYXRlLFxuICAgIG9wZW4sXG4gICAgb25PcGVuQ2hhbmdlLFxuICAgIHBsYWNlbWVudDogJ2JvdHRvbS1zdGFydCcsXG4gICAgbWlkZGxld2FyZTogW1xuICAgICAgb2Zmc2V0KDEwKSxcbiAgICAgIGZsaXAoeyBwYWRkaW5nOiAxMCB9KSxcbiAgICAgIHNpemUoe1xuICAgICAgICBhcHBseSh7IGF2YWlsYWJsZUhlaWdodCwgYXZhaWxhYmxlV2lkdGgsIGVsZW1lbnRzIH0pIHtcbiAgICAgICAgICAvLyBsaW1pdCBtYXhIZWlnaHQgYW5kIG1heFdpZHRoIG9mIGRyb3Bkb3duXG4gICAgICAgICAgZWxlbWVudHMuZmxvYXRpbmcuc3R5bGUubWF4SGVpZ2h0ID0gYCR7TWF0aC5taW4oTUFYX01FTlVfSEVJR0hULCBhdmFpbGFibGVIZWlnaHQpfXB4YDtcbiAgICAgICAgICBlbGVtZW50cy5mbG9hdGluZy5zdHlsZS5tYXhXaWR0aCA9IGAke2F2YWlsYWJsZVdpZHRofXB4YDtcbiAgICAgICAgfSxcbiAgICAgICAgcGFkZGluZzogMTAsXG4gICAgICB9KSxcbiAgICBdLFxuICAgIHN0cmF0ZWd5OiAnZml4ZWQnLFxuICB9KTtcblxuICBjb25zdCByb2xlID0gdXNlUm9sZShjb250ZXh0LCB7IHJvbGU6ICdsaXN0Ym94JyB9KTtcbiAgY29uc3QgZGlzbWlzcyA9IHVzZURpc21pc3MoY29udGV4dCwge1xuICAgIC8vIGlmIG91dHNpZGUgY2xpY2sgbGFuZHMgb24gb3BlcmF0b3IgcGlsbCwgdGhlbiBpZ25vcmUgb3V0c2lkZSBjbGlja1xuICAgIG91dHNpZGVQcmVzczogKGV2ZW50KSA9PiB7XG4gICAgICBpZiAoZXZlbnQuY3VycmVudFRhcmdldCBpbnN0YW5jZW9mIEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3QgdGFyZ2V0ID0gZXZlbnQuY3VycmVudFRhcmdldDtcbiAgICAgICAgbGV0IGlkVG9Db21wYXJlID0gdGFyZ2V0LmlkO1xuICAgICAgICBpZiAodGFyZ2V0Lm5vZGVOYW1lID09PSAncGF0aCcpIHtcbiAgICAgICAgICBpZFRvQ29tcGFyZSA9IHRhcmdldC5wYXJlbnRFbGVtZW50Py5pZCB8fCAnJztcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChvdXRzaWRlUHJlc3NJZHNUb0lnbm9yZS5pbmNsdWRlcyhpZFRvQ29tcGFyZSkpIHtcbiAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH0sXG4gIH0pO1xuICBjb25zdCBsaXN0TmF2ID0gdXNlTGlzdE5hdmlnYXRpb24oY29udGV4dCwge1xuICAgIGxpc3RSZWYsXG4gICAgYWN0aXZlSW5kZXgsXG4gICAgb25OYXZpZ2F0ZTogc2V0QWN0aXZlSW5kZXgsXG4gICAgdmlydHVhbDogdHJ1ZSxcbiAgICBsb29wOiB0cnVlLFxuICAgIGRpc2FibGVkSW5kaWNlczogZGlzYWJsZWRJbmRpY2VzUmVmLmN1cnJlbnQsXG4gIH0pO1xuXG4gIGNvbnN0IHsgZ2V0UmVmZXJlbmNlUHJvcHMsIGdldEZsb2F0aW5nUHJvcHMsIGdldEl0ZW1Qcm9wcyB9ID0gdXNlSW50ZXJhY3Rpb25zKFtyb2xlLCBkaXNtaXNzLCBsaXN0TmF2XSk7XG5cbiAgcmV0dXJuIHtcbiAgICByZWZzLFxuICAgIGZsb2F0aW5nU3R5bGVzLFxuICAgIGNvbnRleHQsXG4gICAgZ2V0UmVmZXJlbmNlUHJvcHMsXG4gICAgZ2V0RmxvYXRpbmdQcm9wcyxcbiAgICBnZXRJdGVt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
|
|
@@ -1,146 +0,0 @@
|
|
|
1
|
-
import { isMultiValueOperator } from '../AdHocFiltersVariable.js';
|
|
2
|
-
import { getFuzzySearcher } from '../../utils.js';
|
|
3
|
-
|
|
4
|
-
const VIRTUAL_LIST_WIDTH_ESTIMATE_MULTIPLIER = 8;
|
|
5
|
-
const VIRTUAL_LIST_DESCRIPTION_WIDTH_ESTIMATE_MULTIPLIER = 6;
|
|
6
|
-
const VIRTUAL_LIST_PADDING = 8;
|
|
7
|
-
const VIRTUAL_LIST_OVERSCAN = 5;
|
|
8
|
-
const VIRTUAL_LIST_ITEM_HEIGHT = 38;
|
|
9
|
-
const VIRTUAL_LIST_ITEM_HEIGHT_WITH_DESCRIPTION = 60;
|
|
10
|
-
const ERROR_STATE_DROPDOWN_WIDTH = 366;
|
|
11
|
-
function fuzzySearchOptions(options) {
|
|
12
|
-
const haystack = options.map((o) => {
|
|
13
|
-
var _a;
|
|
14
|
-
return (_a = o.label) != null ? _a : o.value;
|
|
15
|
-
});
|
|
16
|
-
const fuzzySearch = getFuzzySearcher(haystack);
|
|
17
|
-
return (search, filterInputType) => {
|
|
18
|
-
if (filterInputType === "operator" && search !== "") {
|
|
19
|
-
search = `"${search}"`;
|
|
20
|
-
}
|
|
21
|
-
return fuzzySearch(search).map((i) => options[i]);
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
const flattenOptionGroups = (options) => options.flatMap((option) => option.options ? [option, ...option.options] : [option]);
|
|
25
|
-
const setupDropdownAccessibility = (options, listRef, disabledIndicesRef) => {
|
|
26
|
-
var _a, _b, _c, _d;
|
|
27
|
-
let maxOptionWidth = 182;
|
|
28
|
-
const listRefArr = [];
|
|
29
|
-
const disabledIndices = [];
|
|
30
|
-
for (let i = 0; i < options.length; i++) {
|
|
31
|
-
listRefArr.push(null);
|
|
32
|
-
if ((_a = options[i]) == null ? void 0 : _a.options) {
|
|
33
|
-
disabledIndices.push(i);
|
|
34
|
-
}
|
|
35
|
-
let label = (_c = (_b = options[i].label) != null ? _b : options[i].value) != null ? _c : "";
|
|
36
|
-
let multiplierToUse = VIRTUAL_LIST_WIDTH_ESTIMATE_MULTIPLIER;
|
|
37
|
-
if (label.length * VIRTUAL_LIST_WIDTH_ESTIMATE_MULTIPLIER < (((_d = options[i].description) == null ? void 0 : _d.length) || 0) * VIRTUAL_LIST_DESCRIPTION_WIDTH_ESTIMATE_MULTIPLIER) {
|
|
38
|
-
label = options[i].description;
|
|
39
|
-
multiplierToUse = VIRTUAL_LIST_DESCRIPTION_WIDTH_ESTIMATE_MULTIPLIER;
|
|
40
|
-
}
|
|
41
|
-
const widthEstimate = (options[i].isCustom ? label.length + 18 : label.length) * multiplierToUse + VIRTUAL_LIST_PADDING * 2;
|
|
42
|
-
if (widthEstimate > maxOptionWidth) {
|
|
43
|
-
maxOptionWidth = widthEstimate;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
listRef.current = [...listRefArr];
|
|
47
|
-
disabledIndicesRef.current = [...disabledIndices];
|
|
48
|
-
return maxOptionWidth;
|
|
49
|
-
};
|
|
50
|
-
const nextInputTypeMap = {
|
|
51
|
-
key: "operator",
|
|
52
|
-
operator: "value",
|
|
53
|
-
value: "key"
|
|
54
|
-
};
|
|
55
|
-
const switchToNextInputType = (filterInputType, setInputType, handleChangeViewMode, element, shouldFocusOnPillWrapperOverride) => switchInputType(
|
|
56
|
-
nextInputTypeMap[filterInputType],
|
|
57
|
-
setInputType,
|
|
58
|
-
filterInputType === "value" ? handleChangeViewMode : void 0,
|
|
59
|
-
element,
|
|
60
|
-
shouldFocusOnPillWrapperOverride
|
|
61
|
-
);
|
|
62
|
-
const switchInputType = (filterInputType, setInputType, handleChangeViewMode, element, shouldFocusOnPillWrapperOverride) => {
|
|
63
|
-
setInputType(filterInputType);
|
|
64
|
-
handleChangeViewMode == null ? void 0 : handleChangeViewMode(void 0, shouldFocusOnPillWrapperOverride);
|
|
65
|
-
setTimeout(() => element == null ? void 0 : element.focus());
|
|
66
|
-
};
|
|
67
|
-
const generateFilterUpdatePayload = ({
|
|
68
|
-
filterInputType,
|
|
69
|
-
item,
|
|
70
|
-
filter,
|
|
71
|
-
setFilterMultiValues
|
|
72
|
-
}) => {
|
|
73
|
-
var _a, _b, _c, _d, _e;
|
|
74
|
-
if (filterInputType === "key") {
|
|
75
|
-
return {
|
|
76
|
-
key: item.value,
|
|
77
|
-
keyLabel: item.label ? item.label : item.value
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
if (filterInputType === "value") {
|
|
81
|
-
return {
|
|
82
|
-
value: item.value,
|
|
83
|
-
valueLabels: [item.label ? item.label : item.value]
|
|
84
|
-
};
|
|
85
|
-
}
|
|
86
|
-
if (filterInputType === "operator") {
|
|
87
|
-
if (isMultiValueOperator(filter.operator) && !isMultiValueOperator(item.value)) {
|
|
88
|
-
setFilterMultiValues([]);
|
|
89
|
-
return {
|
|
90
|
-
operator: item.value,
|
|
91
|
-
valueLabels: [((_a = filter.valueLabels) == null ? void 0 : _a[0]) || ((_b = filter.values) == null ? void 0 : _b[0]) || filter.value],
|
|
92
|
-
values: void 0
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
if (isMultiValueOperator(item.value) && !isMultiValueOperator(filter.operator)) {
|
|
96
|
-
const valueLabels = [((_c = filter.valueLabels) == null ? void 0 : _c[0]) || ((_d = filter.values) == null ? void 0 : _d[0]) || filter.value];
|
|
97
|
-
const values = [filter.value];
|
|
98
|
-
if (values[0]) {
|
|
99
|
-
setFilterMultiValues([
|
|
100
|
-
{
|
|
101
|
-
value: values[0],
|
|
102
|
-
label: (_e = valueLabels == null ? void 0 : valueLabels[0]) != null ? _e : values[0]
|
|
103
|
-
}
|
|
104
|
-
]);
|
|
105
|
-
}
|
|
106
|
-
return {
|
|
107
|
-
operator: item.value,
|
|
108
|
-
valueLabels,
|
|
109
|
-
values
|
|
110
|
-
};
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
return {
|
|
114
|
-
[filterInputType]: item.value
|
|
115
|
-
};
|
|
116
|
-
};
|
|
117
|
-
const INPUT_PLACEHOLDER = "Filter by label values";
|
|
118
|
-
const generatePlaceholder = (filter, filterInputType, isMultiValueEdit, isAlwaysWip) => {
|
|
119
|
-
var _a;
|
|
120
|
-
if (filterInputType === "key") {
|
|
121
|
-
return INPUT_PLACEHOLDER;
|
|
122
|
-
}
|
|
123
|
-
if (filterInputType === "value") {
|
|
124
|
-
if (isMultiValueEdit) {
|
|
125
|
-
return "Edit values";
|
|
126
|
-
}
|
|
127
|
-
return ((_a = filter.valueLabels) == null ? void 0 : _a[0]) || "";
|
|
128
|
-
}
|
|
129
|
-
return filter[filterInputType] && !isAlwaysWip ? `${filter[filterInputType]}` : INPUT_PLACEHOLDER;
|
|
130
|
-
};
|
|
131
|
-
const populateInputValueOnInputTypeSwitch = ({
|
|
132
|
-
populateInputOnEdit,
|
|
133
|
-
item,
|
|
134
|
-
filterInputType,
|
|
135
|
-
setInputValue,
|
|
136
|
-
filter
|
|
137
|
-
}) => {
|
|
138
|
-
if (populateInputOnEdit && !isMultiValueOperator(item.value || "") && nextInputTypeMap[filterInputType] === "value") {
|
|
139
|
-
setInputValue((filter == null ? void 0 : filter.value) || "");
|
|
140
|
-
} else {
|
|
141
|
-
setInputValue("");
|
|
142
|
-
}
|
|
143
|
-
};
|
|
144
|
-
|
|
145
|
-
export { ERROR_STATE_DROPDOWN_WIDTH, VIRTUAL_LIST_ITEM_HEIGHT, VIRTUAL_LIST_ITEM_HEIGHT_WITH_DESCRIPTION, VIRTUAL_LIST_OVERSCAN, flattenOptionGroups, fuzzySearchOptions, generateFilterUpdatePayload, generatePlaceholder, populateInputValueOnInputTypeSwitch, setupDropdownAccessibility, switchInputType, switchToNextInputType };
|
|
146
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"utils.js","sources":["../../../../../../src/variables/adhoc/AdHocFiltersCombobox/utils.ts"],"sourcesContent":["import { SelectableValue } from '@grafana/data';\nimport { AdHocInputType } from './AdHocFiltersCombobox';\nimport { AdHocFilterWithLabels, isMultiValueOperator } from '../AdHocFiltersVariable';\nimport { getFuzzySearcher } from '../../utils';\n\nconst VIRTUAL_LIST_WIDTH_ESTIMATE_MULTIPLIER = 8;\nconst VIRTUAL_LIST_DESCRIPTION_WIDTH_ESTIMATE_MULTIPLIER = 6;\nconst VIRTUAL_LIST_PADDING = 8;\nexport const VIRTUAL_LIST_OVERSCAN = 5;\nexport const VIRTUAL_LIST_ITEM_HEIGHT = 38;\nexport const VIRTUAL_LIST_ITEM_HEIGHT_WITH_DESCRIPTION = 60;\nexport const ERROR_STATE_DROPDOWN_WIDTH = 366;\n\nexport function fuzzySearchOptions(options: Array<SelectableValue<string>>) {\n  const haystack = options.map((o) => o.label ?? o.value!);\n  const fuzzySearch = getFuzzySearcher(haystack);\n\n  return (search: string, filterInputType: AdHocInputType) => {\n    if (filterInputType === 'operator' && search !== '') {\n      // uFuzzy can only match non-alphanum chars if quoted\n      search = `\"${search}\"`;\n    }\n\n    return fuzzySearch(search).map((i) => options[i]);\n  };\n}\nexport const flattenOptionGroups = (options: Array<SelectableValue<string>>) =>\n  options.flatMap<SelectableValue<string>>((option) => (option.options ? [option, ...option.options] : [option]));\n\nexport const setupDropdownAccessibility = (\n  options: Array<SelectableValue<string>>,\n  listRef: React.MutableRefObject<Array<HTMLElement | null>>,\n  disabledIndicesRef: React.MutableRefObject<number[]>\n) => {\n  let maxOptionWidth = 182;\n  const listRefArr = [];\n  const disabledIndices = [];\n\n  for (let i = 0; i < options.length; i++) {\n    // listRefArr should be filled with nulls for amount of dropdown items so that\n    //    useNavigationList sets activeIndex correctly when navigating with arrow keys\n    listRefArr.push(null);\n\n    // disabledIndices are used to skip unselectable group items in dropdown when\n    //    navigating with arrow keys\n    if (options[i]?.options) {\n      disabledIndices.push(i);\n    }\n    let label = options[i].label ?? options[i].value ?? '';\n    let multiplierToUse = VIRTUAL_LIST_WIDTH_ESTIMATE_MULTIPLIER;\n    if (\n      label.length * VIRTUAL_LIST_WIDTH_ESTIMATE_MULTIPLIER <\n      (options[i].description?.length || 0) * VIRTUAL_LIST_DESCRIPTION_WIDTH_ESTIMATE_MULTIPLIER\n    ) {\n      label = options[i].description!;\n      multiplierToUse = VIRTUAL_LIST_DESCRIPTION_WIDTH_ESTIMATE_MULTIPLIER;\n    }\n\n    // rough widthEstimate\n    const widthEstimate =\n      (options[i].isCustom ? label.length + 18 : label.length) * multiplierToUse + VIRTUAL_LIST_PADDING * 2;\n    if (widthEstimate > maxOptionWidth) {\n      maxOptionWidth = widthEstimate;\n    }\n  }\n\n  listRef.current = [...listRefArr];\n  disabledIndicesRef.current = [...disabledIndices];\n  return maxOptionWidth;\n};\n\nconst nextInputTypeMap = {\n  key: 'operator',\n  operator: 'value',\n  value: 'key',\n} as const;\n\nexport const switchToNextInputType = (\n  filterInputType: AdHocInputType,\n  setInputType: React.Dispatch<React.SetStateAction<AdHocInputType>>,\n  handleChangeViewMode: ((event?: React.MouseEvent, shouldFocusOnFilterPill?: boolean) => void) | undefined,\n  element: HTMLInputElement | null,\n  shouldFocusOnPillWrapperOverride?: boolean\n) =>\n  switchInputType(\n    nextInputTypeMap[filterInputType],\n    setInputType,\n    filterInputType === 'value' ? handleChangeViewMode : undefined,\n    element,\n    shouldFocusOnPillWrapperOverride\n  );\n\nexport const switchInputType = (\n  filterInputType: AdHocInputType,\n  setInputType: React.Dispatch<React.SetStateAction<AdHocInputType>>,\n  handleChangeViewMode?: (event?: React.MouseEvent, shouldFocusOnFilterPill?: boolean) => void,\n  element?: HTMLInputElement | null,\n  shouldFocusOnPillWrapperOverride?: boolean\n) => {\n  setInputType(filterInputType);\n\n  handleChangeViewMode?.(undefined, shouldFocusOnPillWrapperOverride);\n\n  setTimeout(() => element?.focus());\n};\n\nexport const generateFilterUpdatePayload = ({\n  filterInputType,\n  item,\n  filter,\n  setFilterMultiValues,\n}: {\n  filterInputType: AdHocInputType;\n  item: SelectableValue<string>;\n  filter: AdHocFilterWithLabels;\n  setFilterMultiValues: (value: React.SetStateAction<Array<SelectableValue<string>>>) => void;\n}): Partial<AdHocFilterWithLabels> => {\n  if (filterInputType === 'key') {\n    return {\n      key: item.value,\n      keyLabel: item.label ? item.label : item.value,\n    };\n  }\n  if (filterInputType === 'value') {\n    return {\n      value: item.value,\n      valueLabels: [item.label ? item.label : item.value!],\n    };\n  }\n\n  if (filterInputType === 'operator') {\n    // handle values/valueLabels when switching from multi to single value operator\n    if (isMultiValueOperator(filter.operator) && !isMultiValueOperator(item.value!)) {\n      // reset local multi values state\n      setFilterMultiValues([]);\n      // update operator and reset values and valueLabels\n      return {\n        operator: item.value,\n        valueLabels: [filter.valueLabels?.[0] || filter.values?.[0] || filter.value],\n        values: undefined,\n      };\n    }\n\n    // handle values/valueLabels when switching from single to multi value operator\n    if (isMultiValueOperator(item.value!) && !isMultiValueOperator(filter.operator)) {\n      const valueLabels = [filter.valueLabels?.[0] || filter.values?.[0] || filter.value];\n      const values = [filter.value];\n\n      // populate local multi values state\n      if (values[0]) {\n        setFilterMultiValues([\n          {\n            value: values[0],\n            label: valueLabels?.[0] ?? values[0],\n          },\n        ]);\n      }\n\n      // update operator and default values and valueLabels\n      return {\n        operator: item.value,\n        valueLabels: valueLabels,\n        values: values,\n      };\n    }\n  }\n\n  // default operator update of same multi/single type\n  return {\n    [filterInputType]: item.value,\n  };\n};\n\nconst INPUT_PLACEHOLDER = 'Filter by label values';\n\nexport const generatePlaceholder = (\n  filter: AdHocFilterWithLabels,\n  filterInputType: AdHocInputType,\n  isMultiValueEdit: boolean,\n  isAlwaysWip?: boolean\n) => {\n  if (filterInputType === 'key') {\n    return INPUT_PLACEHOLDER;\n  }\n  if (filterInputType === 'value') {\n    if (isMultiValueEdit) {\n      return 'Edit values';\n    }\n    return filter.valueLabels?.[0] || '';\n  }\n\n  return filter[filterInputType] && !isAlwaysWip ? `${filter[filterInputType]}` : INPUT_PLACEHOLDER;\n};\n\nexport const populateInputValueOnInputTypeSwitch = ({\n  populateInputOnEdit,\n  item,\n  filterInputType,\n  setInputValue,\n  filter,\n}: {\n  populateInputOnEdit: boolean | undefined;\n  item: SelectableValue<string>;\n  filterInputType: AdHocInputType;\n  setInputValue: (value: React.SetStateAction<string>) => void;\n  filter: AdHocFilterWithLabels | undefined;\n}) => {\n  if (populateInputOnEdit && !isMultiValueOperator(item.value || '') && nextInputTypeMap[filterInputType] === 'value') {\n    setInputValue(filter?.value || '');\n  } else {\n    setInputValue('');\n  }\n};\n"],"names":[],"mappings":"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"}
|