/usr/share/grafana/public/build
{"version":3,"file":"explore.dd32637df83326225e0d.js","mappings":"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","sources":["webpack://grafana/./public/app/plugins/panel/table/migrations.ts","webpack://grafana/./public/app/features/correlations/Forms/types.ts","webpack://grafana/./node_modules/react-use/esm/useBeforeUnload.js","webpack://grafana/./public/app/features/explore/CorrelationUnsavedChangesModal.tsx","webpack://grafana/./public/app/features/explore/correlationEditLogic.ts","webpack://grafana/./public/app/features/explore/CorrelationEditorModeBar.tsx","webpack://grafana/./public/app/features/explore/ExploreActions.tsx","webpack://grafana/./public/app/features/explore/ExploreDrawer.tsx","webpack://grafana/./node_modules/react-use/esm/useScroll.js","webpack://grafana/./public/app/features/explore/ContentOutline/ContentOutlineContext.tsx","webpack://grafana/./public/app/features/explore/ContentOutline/ContentOutlineItemButton.tsx","webpack://grafana/./public/app/features/explore/ContentOutline/ContentOutline.tsx","webpack://grafana/./public/app/features/explore/ContentOutline/ContentOutlineItem.tsx","webpack://grafana/./public/app/features/explore/CorrelationTransformationAddModal.tsx","webpack://grafana/./public/app/features/explore/CorrelationHelper.tsx","webpack://grafana/./public/app/features/explore/CustomContainer.tsx","webpack://grafana/./public/app/features/explore/TimeSyncButton.tsx","webpack://grafana/./public/app/features/explore/ExploreTimeControls.tsx","webpack://grafana/./public/app/features/explore/LiveTailButton.tsx","webpack://grafana/./public/app/features/explore/ShortLinkButtonMenu.tsx","webpack://grafana/./public/app/features/explore/extensions/toolbar/BasicExtensions.tsx","webpack://grafana/./public/app/features/explore/extensions/toolbar/QuerylessAppsExtensions.tsx","webpack://grafana/./public/app/features/explore/extensions/ToolbarExtensionPoint.tsx","webpack://grafana/./public/app/features/explore/useLiveTailControls.ts","webpack://grafana/./public/app/features/explore/ExploreToolbar.tsx","webpack://grafana/./public/app/features/explore/FlameGraph/FlameGraphExploreContainer.tsx","webpack://grafana/./public/app/features/explore/ElapsedTime.tsx","webpack://grafana/./public/app/features/explore/Logs/LiveLogs.tsx","webpack://grafana/./public/app/features/explore/ContentOutline/ContentOutlineAnalyticEvents.ts","webpack://grafana/./public/app/features/explore/Logs/LogsFeedback.tsx","webpack://grafana/./public/app/features/explore/MetaInfoText.tsx","webpack://grafana/./public/app/features/explore/Logs/LogsMetaRow.tsx","webpack://grafana/./public/app/features/explore/Logs/LogsNavigationPages.tsx","webpack://grafana/./public/app/features/explore/Logs/LogsNavigation.tsx","webpack://grafana/./public/app/features/explore/SupplementaryResultError.tsx","webpack://grafana/./public/app/features/explore/Logs/LogsVolumePanel.tsx","webpack://grafana/./public/app/features/explore/Logs/utils/logsVolumeResponse.ts","webpack://grafana/./public/app/features/explore/Logs/LogsVolumePanelList.tsx","webpack://grafana/./public/app/features/explore/Logs/Logs.tsx","webpack://grafana/./public/app/features/explore/Logs/utils/LogsCrossFadeTransition.tsx","webpack://grafana/./public/app/features/explore/Logs/LogsContainer.tsx","webpack://grafana/./public/app/features/explore/Logs/LogsSamplePanel.tsx","webpack://grafana/./public/app/features/explore/NoData.tsx","webpack://grafana/./public/app/features/explore/NoDataSourceCallToAction.tsx","webpack://grafana/./public/app/features/explore/NodeGraph/NodeGraphContainer.tsx","webpack://grafana/./public/app/features/explore/QueryRows.tsx","webpack://grafana/./public/app/features/explore/PrometheusListView/RawListContainer.tsx","webpack://grafana/./public/app/features/explore/RawPrometheus/RawPrometheusContainer.tsx","webpack://grafana/./public/app/core/components/Animations/FadeIn.tsx","webpack://grafana/./public/app/features/explore/ErrorContainer.tsx","webpack://grafana/./public/app/features/explore/ResponseErrorContainer.tsx","webpack://grafana/./public/app/features/explore/SecondaryActions.tsx","webpack://grafana/./public/app/features/explore/Table/TableContainer.tsx","webpack://grafana/./public/app/features/explore/TraceView/TraceViewContainer.tsx","webpack://grafana/./public/app/features/explore/Explore.tsx","webpack://grafana/./public/app/features/explore/ExploreQueryInspector.tsx","webpack://grafana/./public/app/features/explore/ExplorePaneContainer.tsx","webpack://grafana/./public/app/features/explore/ExploreRunQueryButton.tsx","webpack://grafana/./public/app/features/explore/RichHistory/RichHistoryAddToLibrary.tsx","webpack://grafana/./public/app/features/explore/RichHistory/RichHistoryCard.tsx","webpack://grafana/./public/app/features/explore/RichHistory/RichHistoryQueriesTab.tsx","webpack://grafana/./public/app/features/explore/RichHistory/RichHistorySettingsTab.tsx","webpack://grafana/./public/app/features/explore/RichHistory/RichHistoryStarredTab.tsx","webpack://grafana/./public/app/features/explore/RichHistory/RichHistory.tsx","webpack://grafana/./public/app/features/explore/RichHistory/RichHistoryContainer.tsx","webpack://grafana/./public/app/features/explore/hooks/useExplorePageTitle.ts","webpack://grafana/./public/app/features/explore/hooks/useKeyboardShortcuts.ts","webpack://grafana/./public/app/features/explore/hooks/useSplitSizeUpdater.ts","webpack://grafana/./public/app/features/explore/hooks/useTimeSrvFix.ts","webpack://grafana/./public/app/features/explore/ExplorePage.tsx","webpack://grafana/./node_modules/react-use/esm/useInterval.js"],"sourcesContent":["import { omitBy, isNil, isNumber, defaultTo, groupBy, omit } from 'lodash';\n\nimport {\n PanelModel,\n FieldMatcherID,\n ConfigOverrideRule,\n ThresholdsMode,\n ThresholdsConfig,\n FieldConfig,\n DataFrame,\n FieldType,\n ByNamesMatcherMode,\n} from '@grafana/data';\nimport { ReduceTransformerOptions } from '@grafana/data/internal';\n\nimport { Options } from './panelcfg.gen';\n\n/**\n * At 7.0, the `table` panel was swapped from an angular implementation to a react one.\n * The models do not match, so this process will delegate to the old implementation when\n * a saved table configuration exists.\n */\nexport const tableMigrationHandler = (panel: PanelModel<Options>): Partial<Options> => {\n // Table was saved as an angular table, lets just swap to the 'table-old' panel\n if (!panel.pluginVersion && 'columns' in panel) {\n console.log('Was angular table', panel);\n }\n\n migrateTextWrapToFieldLevel(panel);\n migrateHiddenFields(panel);\n migrateFooterV2(panel);\n\n // Nothing changed\n return panel.options;\n};\n\nconst transformsMap = {\n timeseries_to_rows: 'seriesToRows',\n timeseries_to_columns: 'seriesToColumns',\n timeseries_aggregations: 'reduce',\n table: 'merge',\n};\n\nconst columnsMap = {\n avg: 'mean',\n min: 'min',\n max: 'max',\n total: 'sum',\n current: 'lastNotNull',\n count: 'count',\n};\n\nconst colorModeMap = {\n cell: 'color-background',\n row: 'color-background',\n value: 'color-text',\n};\n\ntype Transformations = keyof typeof transformsMap;\n\ntype Transformation = {\n id: string;\n options: ReduceTransformerOptions;\n};\n\ntype Columns = keyof typeof columnsMap;\n\ntype Column = {\n value: Columns;\n text: string;\n};\n\ntype ColorModes = keyof typeof colorModeMap;\n\nconst generateThresholds = (thresholds: string[], colors: string[]) => {\n return [-Infinity, ...thresholds].map((threshold, idx) => ({\n color: colors[idx],\n value: isNumber(threshold) ? threshold : parseInt(threshold, 10),\n }));\n};\n\nconst migrateTransformations = (\n panel: PanelModel<Partial<Options>>,\n oldOpts: { columns: any; transform: Transformations }\n) => {\n const transformations: Transformation[] = panel.transformations ?? [];\n if (Object.keys(transformsMap).includes(oldOpts.transform)) {\n const opts: ReduceTransformerOptions = {\n reducers: [],\n };\n if (oldOpts.transform === 'timeseries_aggregations') {\n opts.includeTimeField = false;\n opts.reducers = oldOpts.columns.map((column: Column) => columnsMap[column.value]);\n }\n transformations.push({\n id: transformsMap[oldOpts.transform],\n options: opts,\n });\n }\n return transformations;\n};\n\ntype Style = {\n unit: string;\n type: string;\n alias: string;\n decimals: number;\n colors: string[];\n colorMode: ColorModes;\n pattern: string;\n thresholds: string[];\n align?: string;\n dateFormat: string;\n link: boolean;\n linkTargetBlank?: boolean;\n linkTooltip?: string;\n linkUrl?: string;\n};\n\nconst migrateTableStyleToOverride = (style: Style) => {\n const fieldMatcherId = /^\\/.*\\/$/.test(style.pattern) ? FieldMatcherID.byRegexp : FieldMatcherID.byName;\n const override: ConfigOverrideRule = {\n matcher: {\n id: fieldMatcherId,\n options: style.pattern,\n },\n properties: [],\n };\n\n if (style.alias) {\n override.properties.push({\n id: 'displayName',\n value: style.alias,\n });\n }\n\n if (style.unit) {\n override.properties.push({\n id: 'unit',\n value: style.unit,\n });\n }\n\n if (style.decimals !== undefined) {\n override.properties.push({\n id: 'decimals',\n value: style.decimals,\n });\n }\n\n if (style.type === 'date') {\n override.properties.push({\n id: 'unit',\n value: `time: ${style.dateFormat}`,\n });\n }\n\n if (style.type === 'hidden') {\n override.properties.push({\n id: 'custom.hidden',\n value: true,\n });\n }\n\n if (style.link) {\n override.properties.push({\n id: 'links',\n value: [\n {\n title: defaultTo(style.linkTooltip, ''),\n url: defaultTo(style.linkUrl, ''),\n targetBlank: defaultTo(style.linkTargetBlank, false),\n },\n ],\n });\n }\n\n if (style.colorMode) {\n override.properties.push({\n id: 'custom.cellOptions',\n value: {\n type: colorModeMap[style.colorMode],\n },\n });\n }\n\n if (style.align) {\n override.properties.push({\n id: 'custom.align',\n value: style.align === 'auto' ? null : style.align,\n });\n }\n\n if (style.thresholds?.length && style.colors?.length) {\n override.properties.push({\n id: 'thresholds',\n value: {\n mode: ThresholdsMode.Absolute,\n steps: generateThresholds(style.thresholds, style.colors),\n },\n });\n }\n\n return override;\n};\n\nconst migrateDefaults = (prevDefaults: Style) => {\n let defaults: FieldConfig = {\n custom: {},\n };\n if (prevDefaults) {\n defaults = omitBy(\n {\n unit: prevDefaults.unit,\n decimals: prevDefaults.decimals,\n displayName: prevDefaults.alias,\n custom: {\n align: prevDefaults.align === 'auto' ? null : prevDefaults.align,\n },\n },\n isNil\n );\n\n if (prevDefaults.thresholds && prevDefaults.thresholds.length) {\n const thresholds: ThresholdsConfig = {\n mode: ThresholdsMode.Absolute,\n steps: generateThresholds(prevDefaults.thresholds, prevDefaults.colors),\n };\n defaults.thresholds = thresholds;\n }\n\n if (prevDefaults.colorMode) {\n defaults.custom.cellOptions = {\n type: colorModeMap[prevDefaults.colorMode],\n };\n }\n }\n return defaults;\n};\n\n/**\n * This is called when the panel changes from another panel\n */\nexport const tablePanelChangedHandler = (\n panel: PanelModel<Partial<Options>>,\n prevPluginId: string,\n prevOptions: any\n) => {\n // Changing from angular table panel\n if (prevPluginId === 'table-old' && prevOptions.angular) {\n const oldOpts = prevOptions.angular;\n const transformations = migrateTransformations(panel, oldOpts);\n const prevDefaults = oldOpts.styles.find((style: any) => style.pattern === '/.*/');\n const defaults = migrateDefaults(prevDefaults);\n const overrides = oldOpts.styles.filter((style: any) => style.pattern !== '/.*/').map(migrateTableStyleToOverride);\n\n panel.transformations = transformations;\n panel.fieldConfig = {\n defaults,\n overrides,\n };\n }\n\n return {};\n};\n\nconst getMainFrames = (frames: DataFrame[] | null) => {\n return frames?.filter((df) => df.meta?.custom?.parentRowIndex === undefined) || [frames?.[0]];\n};\n\n/**\n * In 9.3 meta.custom.parentRowIndex was introduced to support sub-tables.\n * In 10.2 meta.custom.parentRowIndex was deprecated in favor of FieldType.nestedFrames, which supports multiple nested frames.\n * Migrate DataFrame[] from using meta.custom.parentRowIndex to using FieldType.nestedFrames\n */\nexport const migrateFromParentRowIndexToNestedFrames = (frames: DataFrame[] | null) => {\n const migratedFrames: DataFrame[] = [];\n const mainFrames = getMainFrames(frames).filter(\n (frame: DataFrame | undefined): frame is DataFrame => !!frame && frame.length !== 0\n );\n\n mainFrames?.forEach((frame) => {\n const subFrames = frames?.filter((df) => frame.refId === df.refId && df.meta?.custom?.parentRowIndex !== undefined);\n const subFramesGrouped = groupBy(subFrames, (frame: DataFrame) => frame.meta?.custom?.parentRowIndex);\n const subFramesByIndex = Object.keys(subFramesGrouped).map((key) => subFramesGrouped[key]);\n const migratedFrame = { ...frame };\n\n if (subFrames && subFrames.length > 0) {\n migratedFrame.fields.push({\n name: 'nested',\n type: FieldType.nestedFrames,\n config: {},\n values: subFramesByIndex,\n });\n }\n migratedFrames.push(migratedFrame);\n });\n\n return migratedFrames;\n};\n\nexport const hasDeprecatedParentRowIndex = (frames: DataFrame[] | null) => {\n return frames?.some((df) => df.meta?.custom?.parentRowIndex !== undefined);\n};\n\nexport const migrateTextWrapToFieldLevel = (panel: PanelModel<Partial<Options>>) => {\n if (panel.fieldConfig?.defaults.custom?.wrapText !== undefined) {\n // already migrated\n return;\n }\n\n const legacyDefaultWrapText: boolean | undefined = panel.fieldConfig?.defaults.custom?.cellOptions?.wrapText;\n\n panel.fieldConfig.overrides = panel.fieldConfig.overrides.map((override) => {\n if (override.properties) {\n override.properties = override.properties.flatMap((property) => {\n if (property.id === 'custom.cellOptions' && property.value && property.value.wrapText !== undefined) {\n return [\n { ...property, value: { ...omit(property.value, 'wrapText') } },\n { id: 'custom.wrapText', value: property.value.wrapText },\n ];\n }\n return [property];\n });\n }\n return override;\n });\n\n panel.fieldConfig.defaults.custom = panel.fieldConfig.defaults.custom ?? {};\n panel.fieldConfig.defaults.custom.wrapText = legacyDefaultWrapText;\n delete panel.fieldConfig.defaults.custom.cellOptions?.wrapText;\n\n return panel;\n};\n\nexport const migrateHiddenFields = (panel: PanelModel<Partial<Options>>) => {\n panel.fieldConfig.overrides = panel.fieldConfig.overrides.map((override) => {\n if (override.properties) {\n override.properties = override.properties.map((property) => {\n if (property.id === 'custom.hidden') {\n return { ...property, id: 'custom.hideFrom.viz' };\n }\n return property;\n });\n }\n return override;\n });\n\n return panel;\n};\n\ninterface LegacyTableFooterOptions {\n show: boolean;\n reducer: string[];\n fields?: string[];\n countRows?: boolean;\n enablePagination?: boolean;\n}\n\nexport const migrateFooterV2 = (panel: PanelModel<Options>) => {\n if (panel.options && 'footer' in panel.options) {\n // we need to cast the footer to the old type to work with it here.\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n const oldFooter = panel.options.footer as LegacyTableFooterOptions;\n\n if (oldFooter.show) {\n const reducers = oldFooter.reducer;\n\n panel.fieldConfig.defaults.custom = {\n ...panel.fieldConfig.defaults.custom,\n footer: {\n reducers: reducers,\n },\n };\n\n if (oldFooter.countRows && reducers[0] === 'count') {\n panel.fieldConfig.defaults.custom.footer.reducers = ['countAll'];\n } else if (oldFooter.fields && oldFooter.fields.length > 1) {\n delete panel.fieldConfig.defaults.custom.footer;\n\n // Fields is an array of field names, so push a byNames matcher\n // on with the matched reducer.\n panel.fieldConfig.overrides.push({\n matcher: {\n id: FieldMatcherID.byNames,\n options: {\n mode: ByNamesMatcherMode.include,\n names: oldFooter.fields,\n },\n },\n properties: [{ id: 'custom.footer.reducers', value: reducers }],\n });\n } else if (oldFooter.fields && oldFooter.fields.length === 1) {\n delete panel.fieldConfig.defaults.custom.footer;\n\n // Single field, so we can use a byName matcher\n panel.fieldConfig.overrides.push({\n matcher: {\n id: FieldMatcherID.byName,\n options: oldFooter.fields[0],\n },\n properties: [{ id: 'custom.footer.reducers', value: reducers }],\n });\n }\n }\n\n if (oldFooter.enablePagination != null) {\n panel.options.enablePagination = oldFooter.enablePagination;\n }\n\n delete panel.options.footer;\n }\n};\n","import { DeepMap, FieldError, FieldErrors } from 'react-hook-form';\n\nimport { SupportedTransformationType } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { CorrelationExternal, CorrelationQuery } from '@grafana/runtime';\n\nimport { OmitUnion } from '../types';\n\nexport interface FormExternalDTO {\n sourceUID: string;\n label: string;\n description: string;\n type: 'external';\n config: CorrelationExternal['config'];\n}\n\nexport interface FormQueryDTO {\n sourceUID: string;\n targetUID: string;\n label: string;\n description: string;\n type: 'query';\n config: CorrelationQuery['config'];\n}\n\nexport type FormDTO = FormExternalDTO | FormQueryDTO;\n\nexport function assertIsQueryTypeError(\n errors: FieldErrors<FormDTO>\n): asserts errors is DeepMap<FormQueryDTO, FieldError> {\n // explicitly assert the type so that TS can narrow down FormDTO to FormQueryDTO\n}\n\nexport type EditFormDTO = OmitUnion<FormDTO, 'targetUID' | 'sourceUID'>;\n\nexport type TransformationDTO = {\n type: SupportedTransformationType;\n expression?: string;\n mapValue?: string;\n};\n\nexport interface TransformationFieldDetails {\n show: boolean;\n required?: boolean;\n helpText?: string;\n}\n\ninterface SupportedTransformationTypeDetails {\n label: string;\n value: SupportedTransformationType;\n description?: string;\n expressionDetails: TransformationFieldDetails;\n mapValueDetails: TransformationFieldDetails;\n}\n\nexport function getSupportedTransTypeDetails(\n transType: SupportedTransformationType\n): SupportedTransformationTypeDetails {\n switch (transType) {\n case SupportedTransformationType.Logfmt:\n return {\n label: t('correlations.trans-details.logfmt-label', 'Logfmt'),\n value: SupportedTransformationType.Logfmt,\n description: t(\n 'correlations.trans-details.logfmt-description',\n 'Parse provided field with logfmt to get variables'\n ),\n expressionDetails: { show: false },\n mapValueDetails: { show: false },\n };\n case SupportedTransformationType.Regex:\n return {\n label: t('correlations.trans-details.regex-label', 'Regular expression'),\n value: SupportedTransformationType.Regex,\n description: t(\n 'correlations.trans-details.regex-description',\n 'Field will be parsed with regex. Use named capture groups to return multiple variables, or a single unnamed capture group to add variable to named map value. Regex is case insensitive.'\n ),\n expressionDetails: {\n show: true,\n required: true,\n helpText: t(\n 'correlations.trans-details.regex-expression',\n 'Use capture groups to extract a portion of the field.'\n ),\n },\n mapValueDetails: {\n show: true,\n required: false,\n helpText: t(\n 'correlations.trans-details.regex-map-values',\n 'Defines the name of the variable if the capture group is not named.'\n ),\n },\n };\n default:\n return {\n label: transType,\n value: transType,\n expressionDetails: { show: false },\n mapValueDetails: { show: false },\n };\n }\n}\n\nexport const getTransformOptions = () => {\n return Object.values(SupportedTransformationType).map((transformationType) => {\n const transType = getSupportedTransTypeDetails(transformationType);\n return {\n label: transType.label,\n value: transType.value,\n description: transType.description,\n };\n });\n};\n","import { useCallback, useEffect } from 'react';\nimport { off, on } from './misc/util';\nvar useBeforeUnload = function (enabled, message) {\n if (enabled === void 0) { enabled = true; }\n var handler = useCallback(function (event) {\n var finalEnabled = typeof enabled === 'function' ? enabled() : true;\n if (!finalEnabled) {\n return;\n }\n event.preventDefault();\n if (message) {\n event.returnValue = message;\n }\n return message;\n }, [enabled, message]);\n useEffect(function () {\n if (!enabled) {\n return;\n }\n on(window, 'beforeunload', handler);\n return function () { return off(window, 'beforeunload', handler); };\n }, [enabled, handler]);\n};\nexport default useBeforeUnload;\n","import { css } from '@emotion/css';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { Button, Modal } from '@grafana/ui';\n\ninterface UnsavedChangesModalProps {\n message: string;\n onDiscard: () => void;\n onCancel: () => void;\n onSave: () => void;\n}\n\nexport const CorrelationUnsavedChangesModal = ({ onSave, onDiscard, onCancel, message }: UnsavedChangesModalProps) => {\n return (\n <Modal\n isOpen={true}\n title={t(\n 'explore.correlation-unsaved-changes-modal.title-unsaved-changes-to-correlation',\n 'Unsaved changes to correlation'\n )}\n onDismiss={onCancel}\n icon=\"exclamation-triangle\"\n className={css({ width: '600px' })}\n >\n <h5>{message}</h5>\n <Modal.ButtonRow>\n <Button variant=\"secondary\" onClick={onCancel} fill=\"outline\">\n <Trans i18nKey=\"explore.correlation-unsaved-changes-modal.cancel\">Cancel</Trans>\n </Button>\n <Button variant=\"destructive\" onClick={onDiscard}>\n <Trans i18nKey=\"explore.correlation-unsaved-changes-modal.continue-without-saving\">\n Continue without saving\n </Trans>\n </Button>\n <Button variant=\"primary\" onClick={onSave}>\n <Trans i18nKey=\"explore.correlation-unsaved-changes-modal.save-correlation\">Save correlation</Trans>\n </Button>\n </Modal.ButtonRow>\n </Modal>\n );\n};\n","import { template } from 'lodash';\n\nimport { CORRELATION_EDITOR_POST_CONFIRM_ACTION } from 'app/types/explore';\n\nenum CONSEQUENCES {\n SOURCE_TARGET_CHANGE = 'cause the query in the right pane to be re-ran and links added to that data',\n FULL_QUERY_LOSS = 'lose the changed query',\n FULL_CORR_LOSS = 'cause the correlation in progress to be lost',\n INVALID_VAR = 'remove the variables, and your changed query may no longer be valid',\n}\n\n// returns a string if the modal should show, with what the message string should be\n// returns undefined if the modal shouldn't show\nexport const showModalMessage = (\n action: CORRELATION_EDITOR_POST_CONFIRM_ACTION,\n isActionLeft: boolean,\n dirtyCorrelation: boolean,\n dirtyQueryEditor: boolean\n) => {\n const messageTemplate = template(\n '<%= actionStr %> will <%= consequenceStr %>. Would you like to save before continuing?'\n );\n let actionStr = '';\n let consequenceStr = '';\n\n // dirty correlation message always takes priority over dirty query\n if (action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CLOSE_PANE) {\n actionStr = 'Closing the pane';\n if (isActionLeft) {\n if (dirtyCorrelation) {\n consequenceStr = CONSEQUENCES.FULL_CORR_LOSS;\n } else if (dirtyQueryEditor) {\n consequenceStr = CONSEQUENCES.SOURCE_TARGET_CHANGE;\n } else {\n return undefined;\n }\n } else {\n // right pane close\n if (dirtyCorrelation) {\n consequenceStr = CONSEQUENCES.FULL_CORR_LOSS;\n } else if (dirtyQueryEditor) {\n consequenceStr = CONSEQUENCES.FULL_QUERY_LOSS;\n } else {\n return undefined;\n }\n }\n } else if (action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CHANGE_DATASOURCE) {\n actionStr = 'Changing the datasource';\n if (isActionLeft) {\n if (dirtyCorrelation) {\n consequenceStr = CONSEQUENCES.FULL_CORR_LOSS;\n } else {\n return undefined;\n }\n } else {\n // right datasource change\n if (dirtyQueryEditor) {\n consequenceStr = CONSEQUENCES.FULL_QUERY_LOSS;\n } else {\n return undefined;\n }\n }\n } else if (action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CLOSE_EDITOR) {\n actionStr = 'Closing the editor';\n if (dirtyCorrelation) {\n consequenceStr = CONSEQUENCES.FULL_CORR_LOSS;\n } else if (dirtyQueryEditor) {\n consequenceStr = CONSEQUENCES.INVALID_VAR;\n } else {\n return undefined;\n }\n }\n return messageTemplate({ actionStr, consequenceStr });\n};\n","import { css } from '@emotion/css';\nimport { useEffect, useState } from 'react';\nimport { useBeforeUnload, useUnmount } from 'react-use';\n\nimport { GrafanaTheme2, colorManipulator } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { reportInteraction } from '@grafana/runtime';\nimport { Button, Icon, Stack, Tooltip, useStyles2 } from '@grafana/ui';\nimport { Prompt } from 'app/core/components/FormPrompt/Prompt';\nimport { CORRELATION_EDITOR_POST_CONFIRM_ACTION, ExploreItemState } from 'app/types/explore';\nimport { useDispatch, useSelector } from 'app/types/store';\n\nimport { CorrelationUnsavedChangesModal } from './CorrelationUnsavedChangesModal';\nimport { showModalMessage } from './correlationEditLogic';\nimport { saveCurrentCorrelation } from './state/correlations';\nimport { changeDatasource } from './state/datasource';\nimport { changeCorrelationHelperData } from './state/explorePane';\nimport { changeCorrelationEditorDetails, splitClose } from './state/main';\nimport { runQueries } from './state/query';\nimport { selectCorrelationDetails, selectIsHelperShowing } from './state/selectors';\n\nexport const CorrelationEditorModeBar = ({ panes }: { panes: Array<[string, ExploreItemState]> }) => {\n const dispatch = useDispatch();\n const styles = useStyles2(getStyles);\n const correlationDetails = useSelector(selectCorrelationDetails);\n const isHelperShowing = useSelector(selectIsHelperShowing);\n const [saveMessage, setSaveMessage] = useState<string | undefined>(undefined); // undefined means do not show\n\n // handle refreshing and closing the tab\n useBeforeUnload(correlationDetails?.correlationDirty || false, 'Save correlation?');\n useBeforeUnload(\n (!correlationDetails?.correlationDirty && correlationDetails?.queryEditorDirty) || false,\n 'The query editor was changed. Save correlation before continuing?'\n );\n\n // decide if we are displaying prompt, perform action if not\n useEffect(() => {\n if (correlationDetails?.isExiting) {\n const { correlationDirty, queryEditorDirty } = correlationDetails;\n let isActionLeft = undefined;\n let action = undefined;\n if (correlationDetails.postConfirmAction) {\n isActionLeft = correlationDetails.postConfirmAction.isActionLeft;\n action = correlationDetails.postConfirmAction.action;\n } else {\n // closing the editor only\n action = CORRELATION_EDITOR_POST_CONFIRM_ACTION.CLOSE_EDITOR;\n isActionLeft = false;\n }\n\n const modalMessage = showModalMessage(action, isActionLeft, correlationDirty, queryEditorDirty);\n if (modalMessage !== undefined) {\n setSaveMessage(modalMessage);\n } else {\n // if no prompt, perform action\n if (\n action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CHANGE_DATASOURCE &&\n correlationDetails.postConfirmAction\n ) {\n const { exploreId, changeDatasourceUid } = correlationDetails?.postConfirmAction;\n if (exploreId && changeDatasourceUid) {\n dispatch(\n changeDatasource({ exploreId, datasource: changeDatasourceUid, options: { importQueries: true } })\n );\n dispatch(\n changeCorrelationEditorDetails({\n isExiting: false,\n })\n );\n }\n } else if (\n action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CLOSE_PANE &&\n correlationDetails.postConfirmAction\n ) {\n const { exploreId } = correlationDetails?.postConfirmAction;\n if (exploreId !== undefined) {\n dispatch(splitClose(exploreId));\n dispatch(\n changeCorrelationEditorDetails({\n isExiting: false,\n })\n );\n }\n } else if (action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CLOSE_EDITOR) {\n dispatch(\n changeCorrelationEditorDetails({\n editorMode: false,\n })\n );\n }\n }\n }\n }, [correlationDetails, dispatch, isHelperShowing]);\n\n // clear data when unmounted\n useUnmount(() => {\n dispatch(\n changeCorrelationEditorDetails({\n editorMode: false,\n isExiting: false,\n correlationDirty: false,\n label: undefined,\n description: undefined,\n canSave: false,\n })\n );\n\n panes.forEach((pane) => {\n dispatch(\n changeCorrelationHelperData({\n exploreId: pane[0],\n correlationEditorHelperData: undefined,\n })\n );\n dispatch(runQueries({ exploreId: pane[0] }));\n });\n });\n\n const resetEditor = () => {\n dispatch(\n changeCorrelationEditorDetails({\n editorMode: true,\n isExiting: false,\n correlationDirty: false,\n label: undefined,\n description: undefined,\n canSave: false,\n })\n );\n\n panes.forEach((pane) => {\n dispatch(\n changeCorrelationHelperData({\n exploreId: pane[0],\n correlationEditorHelperData: undefined,\n })\n );\n dispatch(runQueries({ exploreId: pane[0] }));\n });\n };\n\n const closePane = (exploreId: string) => {\n setSaveMessage(undefined);\n dispatch(splitClose(exploreId));\n reportInteraction('grafana_explore_split_view_closed');\n };\n\n const changeDatasourcePostAction = (exploreId: string, datasourceUid: string) => {\n setSaveMessage(undefined);\n dispatch(changeDatasource({ exploreId, datasource: datasourceUid, options: { importQueries: true } }));\n };\n\n const saveCorrelationPostAction = (skipPostConfirmAction: boolean) => {\n dispatch(\n saveCurrentCorrelation(\n correlationDetails?.label,\n correlationDetails?.description,\n correlationDetails?.transformations\n )\n );\n if (!skipPostConfirmAction && correlationDetails?.postConfirmAction !== undefined) {\n const { exploreId, action, changeDatasourceUid } = correlationDetails?.postConfirmAction;\n if (action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CLOSE_PANE) {\n closePane(exploreId);\n resetEditor();\n } else if (\n action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CHANGE_DATASOURCE &&\n changeDatasourceUid !== undefined\n ) {\n changeDatasource({ exploreId, datasource: changeDatasourceUid });\n resetEditor();\n }\n } else {\n dispatch(changeCorrelationEditorDetails({ editorMode: false, correlationDirty: false, isExiting: false }));\n }\n };\n\n return (\n <>\n {/* Handle navigating outside Explore */}\n <Prompt\n message={(location) => {\n if (\n location.pathname !== '/explore' &&\n correlationDetails?.editorMode &&\n correlationDetails?.correlationDirty\n ) {\n return 'You have unsaved correlation data. Continue?';\n } else {\n return true;\n }\n }}\n />\n\n {saveMessage !== undefined && (\n <CorrelationUnsavedChangesModal\n onDiscard={() => {\n if (correlationDetails?.postConfirmAction !== undefined) {\n const { exploreId, action, changeDatasourceUid } = correlationDetails?.postConfirmAction;\n if (action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CLOSE_PANE) {\n closePane(exploreId);\n } else if (\n action === CORRELATION_EDITOR_POST_CONFIRM_ACTION.CHANGE_DATASOURCE &&\n changeDatasourceUid !== undefined\n ) {\n changeDatasourcePostAction(exploreId, changeDatasourceUid);\n }\n dispatch(changeCorrelationEditorDetails({ isExiting: false }));\n } else {\n // exit correlations mode\n // if we are discarding the in progress correlation, reset everything\n // this modal only shows if the editorMode is false, so we just need to update the dirty state\n dispatch(\n changeCorrelationEditorDetails({\n editorMode: false,\n correlationDirty: false,\n isExiting: false,\n })\n );\n }\n }}\n onCancel={() => {\n // if we are cancelling the exit, set the editor mode back to true and hide the prompt\n dispatch(changeCorrelationEditorDetails({ isExiting: false }));\n setSaveMessage(undefined);\n }}\n onSave={() => {\n saveCorrelationPostAction(false);\n }}\n message={saveMessage}\n />\n )}\n <div className={styles.correlationEditorTop}>\n <Stack gap={2} justifyContent=\"flex-end\" alignItems=\"center\">\n <Tooltip\n content={t(\n 'explore.correlation-editor-mode-bar.content-correlations-editor-explore-experimental-feature',\n 'Correlations editor in Explore is an experimental feature.'\n )}\n >\n <Icon className={styles.iconColor} name=\"info-circle\" size=\"xl\" />\n </Tooltip>\n <Button\n variant=\"secondary\"\n disabled={!correlationDetails?.canSave}\n fill=\"outline\"\n className={correlationDetails?.canSave ? styles.buttonColor : styles.disabledButtonColor}\n onClick={() => {\n saveCorrelationPostAction(true);\n }}\n >\n <Trans i18nKey=\"explore.correlation-editor-mode-bar.save\">Save</Trans>\n </Button>\n <Button\n variant=\"secondary\"\n fill=\"outline\"\n className={styles.buttonColor}\n icon=\"times\"\n onClick={() => {\n dispatch(changeCorrelationEditorDetails({ isExiting: true }));\n reportInteraction('grafana_explore_correlation_editor_exit_pressed');\n }}\n >\n <Trans i18nKey=\"explore.correlation-editor-mode-bar.exit-correlation-editor\">Exit correlation editor</Trans>\n </Button>\n </Stack>\n </div>\n </>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => {\n const contrastColor = theme.colors.getContrastText(theme.colors.primary.main);\n const lighterBackgroundColor = colorManipulator.lighten(theme.colors.primary.main, 0.1);\n const darkerBackgroundColor = colorManipulator.darken(theme.colors.primary.main, 0.2);\n\n const disabledColor = colorManipulator.darken(contrastColor, 0.2);\n\n return {\n correlationEditorTop: css({\n backgroundColor: theme.colors.primary.main,\n marginTop: '3px',\n padding: theme.spacing(1),\n }),\n iconColor: css({\n color: contrastColor,\n }),\n buttonColor: css({\n color: contrastColor,\n borderColor: contrastColor,\n '&:hover': {\n color: contrastColor,\n borderColor: contrastColor,\n backgroundColor: lighterBackgroundColor,\n },\n }),\n // important needed to override disabled state styling\n disabledButtonColor: css({\n color: `${disabledColor} !important`,\n backgroundColor: `${darkerBackgroundColor} !important`,\n }),\n };\n};\n","import { useRegisterActions, useKBar, Action, Priority } from 'kbar';\nimport { useEffect, useState } from 'react';\n\nimport { config } from '@grafana/runtime';\nimport { contextSrv } from 'app/core/services/context_srv';\nimport { MIXED_DATASOURCE_NAME } from 'app/plugins/datasource/mixed/MixedDataSource';\nimport { AccessControlAction } from 'app/types/accessControl';\nimport { useDispatch, useSelector } from 'app/types/store';\n\nimport { splitOpen, splitClose, changeCorrelationEditorDetails } from './state/main';\nimport { runQueries } from './state/query';\nimport { isSplit, selectPanes } from './state/selectors';\n\n// FIXME: this should use the new IDs\nexport const ExploreActions = () => {\n const [actions, setActions] = useState<Action[]>([]);\n const { query } = useKBar();\n const dispatch = useDispatch();\n const panes = useSelector(selectPanes);\n const splitted = useSelector(isSplit);\n\n const canWriteCorrelations = contextSrv.hasPermission(AccessControlAction.DataSourcesWrite);\n\n useEffect(() => {\n const keys = Object.keys(panes);\n const exploreSection = {\n name: 'Explore',\n priority: Priority.HIGH + 1,\n };\n\n const actionsArr: Action[] = [];\n\n if (splitted) {\n actionsArr.push({\n id: 'explore/run-query-left',\n name: 'Run query (left)',\n keywords: 'query left',\n perform: () => {\n dispatch(runQueries({ exploreId: keys[0] }));\n },\n section: exploreSection,\n });\n if (panes[1]) {\n // we should always have the right exploreId if split\n actionsArr.push({\n id: 'explore/run-query-right',\n name: 'Run query (right)',\n keywords: 'query right',\n perform: () => {\n dispatch(runQueries({ exploreId: keys[1] }));\n },\n section: exploreSection,\n });\n actionsArr.push({\n id: 'explore/split-view-close-left',\n name: 'Close split view left',\n keywords: 'split',\n perform: () => {\n dispatch(splitClose(keys[0]));\n },\n section: exploreSection,\n });\n actionsArr.push({\n id: 'explore/split-view-close-right',\n name: 'Close split view right',\n keywords: 'split',\n perform: () => {\n dispatch(splitClose(keys[1]));\n },\n section: exploreSection,\n });\n }\n } else {\n // command palette doesn't know what pane we're in, only show option if not split and no datasource is mixed\n const hasMixed = Object.values(panes).some((pane) => {\n return pane?.datasourceInstance?.uid === MIXED_DATASOURCE_NAME;\n });\n\n if (config.featureToggles.correlations && canWriteCorrelations && !hasMixed) {\n actionsArr.push({\n id: 'explore/correlations-editor',\n name: 'Correlations editor',\n perform: () => {\n dispatch(changeCorrelationEditorDetails({ editorMode: true }));\n dispatch(runQueries({ exploreId: keys[0] }));\n },\n section: exploreSection,\n });\n }\n\n actionsArr.push({\n id: 'explore/run-query',\n name: 'Run query',\n keywords: 'query',\n perform: () => {\n dispatch(runQueries({ exploreId: keys[0] }));\n },\n section: exploreSection,\n });\n actionsArr.push({\n id: 'explore/split-view-open',\n name: 'Open split view',\n keywords: 'split',\n perform: () => {\n dispatch(splitOpen());\n },\n section: exploreSection,\n });\n }\n setActions(actionsArr);\n }, [panes, splitted, query, dispatch, canWriteCorrelations]);\n\n useRegisterActions(!query ? [] : actions, [actions, query]);\n\n return null;\n};\n","// Libraries\nimport { css, cx, keyframes } from '@emotion/css';\nimport { Resizable, ResizeCallback } from 're-resizable';\nimport * as React from 'react';\n\n// Services & Utils\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { getDragStyles, useStyles2, useTheme2 } from '@grafana/ui';\n\nexport interface Props {\n children: React.ReactNode;\n onResize?: ResizeCallback;\n initialHeight?: string;\n}\n\nexport function ExploreDrawer(props: Props) {\n const { children, onResize, initialHeight } = props;\n const theme = useTheme2();\n const styles = useStyles2(getStyles);\n const dragStyles = getDragStyles(theme);\n\n const height = initialHeight || `${theme.components.horizontalDrawer.defaultHeight}px`;\n\n return (\n <Resizable\n className={cx(styles.fixed, styles.container, styles.drawerActive)}\n defaultSize={{ width: '100%', height }}\n handleClasses={{ top: dragStyles.dragHandleHorizontal }}\n enable={{\n top: true,\n right: false,\n bottom: false,\n left: false,\n topRight: false,\n bottomRight: false,\n bottomLeft: false,\n topLeft: false,\n }}\n maxHeight=\"100vh\"\n onResize={onResize}\n >\n {children}\n </Resizable>\n );\n}\n\nconst drawerSlide = (theme: GrafanaTheme2) => keyframes`\n 0% {\n transform: translateY(${theme.components.horizontalDrawer.defaultHeight}px);\n }\n\n 100% {\n transform: translateY(0px);\n }\n`;\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n // @ts-expect-error csstype doesn't allow !important. see https://github.com/frenic/csstype/issues/114\n fixed: css({\n position: 'absolute !important',\n }),\n container: css({\n bottom: 0,\n background: theme.colors.background.primary,\n borderTop: `1px solid ${theme.colors.border.weak}`,\n boxShadow: theme.shadows.z3,\n zIndex: theme.zIndex.navbarFixed,\n }),\n drawerActive: css({\n opacity: 1,\n [theme.transitions.handleMotion('no-preference')]: {\n animation: `0.5s ease-out ${drawerSlide(theme)}`,\n },\n }),\n});\n","import { useEffect } from 'react';\nimport useRafState from './useRafState';\nimport { off, on } from './misc/util';\nvar useScroll = function (ref) {\n if (process.env.NODE_ENV === 'development') {\n if (typeof ref !== 'object' || typeof ref.current === 'undefined') {\n console.error('`useScroll` expects a single ref argument.');\n }\n }\n var _a = useRafState({\n x: 0,\n y: 0,\n }), state = _a[0], setState = _a[1];\n useEffect(function () {\n var handler = function () {\n if (ref.current) {\n setState({\n x: ref.current.scrollLeft,\n y: ref.current.scrollTop,\n });\n }\n };\n if (ref.current) {\n on(ref.current, 'scroll', handler, {\n capture: false,\n passive: true,\n });\n }\n return function () {\n if (ref.current) {\n off(ref.current, 'scroll', handler);\n }\n };\n }, [ref]);\n return state;\n};\nexport default useScroll;\n","import { uniqueId } from 'lodash';\nimport { useState, useContext, createContext, ReactNode, useCallback, useRef, useEffect } from 'react';\nimport { SetOptional } from 'type-fest';\n\nimport { ContentOutlineItemBaseProps, ITEM_TYPES } from './ContentOutlineItem';\n\nexport interface ContentOutlineItemContextProps extends ContentOutlineItemBaseProps {\n id: string;\n ref: HTMLElement | null;\n color?: string;\n children?: ContentOutlineItemContextProps[];\n}\n\ntype RegisterFunction = (outlineItem: SetOptional<ContentOutlineItemContextProps, 'id'>) => string;\n\nexport interface ContentOutlineContextProps {\n outlineItems: ContentOutlineItemContextProps[];\n register: RegisterFunction;\n unregister: (id: string) => void;\n unregisterAllChildren: (\n parentIdGetter: (items: ContentOutlineItemContextProps[]) => string | undefined,\n childType: ITEM_TYPES\n ) => void;\n updateOutlineItems: (newItems: ContentOutlineItemContextProps[]) => void;\n updateItem: (id: string, properties: Partial<Omit<ContentOutlineItemContextProps, 'id'>>) => void;\n}\n\ninterface ContentOutlineContextProviderProps {\n children: ReactNode;\n /**\n * used to resort children of an outline item when the dependencies change\n * e.g. when the order of query rows changes on drag and drop\n */\n refreshDependencies?: unknown[];\n}\n\ninterface ParentlessItems {\n [panelId: string]: ContentOutlineItemContextProps[];\n}\n\nexport const ContentOutlineContext = createContext<ContentOutlineContextProps | undefined>(undefined);\n\nexport function ContentOutlineContextProvider({ children, refreshDependencies }: ContentOutlineContextProviderProps) {\n const [outlineItems, setOutlineItems] = useState<ContentOutlineItemContextProps[]>([]);\n const parentlessItemsRef = useRef<ParentlessItems>({});\n\n const register: RegisterFunction = useCallback((outlineItem) => {\n // Allow the caller to define unique ID so the outlineItem can be differentiated\n const id = outlineItem.id\n ? outlineItem.id\n : uniqueId(`${outlineItem.panelId}-${outlineItem.title}-${outlineItem.icon}_`);\n\n setOutlineItems((prevItems) => {\n if (outlineItem.level === 'root') {\n const parentlessItems = parentlessItemsRef.current[outlineItem.panelId] || [];\n\n // if item has children in parentlessItemsRef and they are filters,\n // modify each child to have ref = outlineItem.ref\n // so that clicking on the filter will also bring the parent item into view\n if (parentlessItems.length > 0) {\n parentlessItemsRef.current[outlineItem.panelId].forEach((item) => {\n if (item.type === 'filter') {\n item.ref = outlineItem.ref;\n }\n });\n }\n\n // remove children from parentlessItemsRef\n parentlessItemsRef.current[outlineItem.panelId] = [];\n\n const updatedItems = [\n ...prevItems,\n {\n ...outlineItem,\n id,\n children: parentlessItems,\n },\n ];\n\n return updatedItems.sort(sortElementsByDocumentPosition);\n }\n\n if (outlineItem.level === 'child') {\n let siblingWithSameTitleFound = false;\n // items with type filter should not have siblings with the same title\n // look at all parentless items and check if there is a sibling with the same title\n Object.keys(parentlessItemsRef.current).forEach((key) => {\n const siblingWithSameTitle = parentlessItemsRef.current[key].find(\n (item) =>\n item.title === outlineItem.title && outlineItem.type === 'filter' && outlineItem.panelId === item.panelId\n );\n if (siblingWithSameTitle) {\n siblingWithSameTitleFound = true;\n return;\n }\n });\n\n if (siblingWithSameTitleFound) {\n return [...prevItems];\n }\n\n const parentIndex = prevItems.findIndex(\n (item) => item.panelId === outlineItem.panelId && item.level === 'root'\n );\n if (parentIndex === -1) {\n const parentlessItemSibling = Object.keys(parentlessItemsRef.current).find(\n (key) => key === outlineItem.panelId\n );\n\n if (parentlessItemSibling) {\n parentlessItemsRef.current[outlineItem.panelId].push({\n ...outlineItem,\n id,\n });\n } else {\n parentlessItemsRef.current[outlineItem.panelId] = [\n {\n ...outlineItem,\n id,\n },\n ];\n }\n return [...prevItems];\n }\n\n const newItems = [...prevItems];\n const parent = { ...newItems[parentIndex] };\n\n // look at all registered items inside items parent and check if there is\n // a filter sibling with the same title\n const siblingWithSameTitle = parent.children?.find(\n (item) =>\n item.title === outlineItem.title && outlineItem.type === 'filter' && outlineItem.panelId === item.panelId\n );\n // check if sibling's highlight property has updated\n if (siblingWithSameTitle && siblingWithSameTitle.highlight !== outlineItem.highlight) {\n parent.children?.map((child) => {\n if (child.title === siblingWithSameTitle?.title) {\n child.highlight = outlineItem.highlight;\n }\n });\n return [...prevItems];\n } else if (siblingWithSameTitle) {\n return [...prevItems];\n }\n\n let ref = outlineItem.ref;\n if (outlineItem.type === 'filter') {\n ref = parent.ref;\n }\n\n let childrenUpdated = [{ ...outlineItem, id, ref }, ...(parent.children || [])];\n\n if (!outlineItem.childOnTop) {\n childrenUpdated = sortItems(childrenUpdated);\n }\n\n newItems[parentIndex] = {\n ...parent,\n children: childrenUpdated,\n };\n\n return newItems;\n }\n\n return [...prevItems];\n });\n\n return id;\n }, []);\n\n const unregister = useCallback((id: string) => {\n setOutlineItems((prevItems) =>\n prevItems\n .filter((item) => item.id !== id)\n .map((item) => {\n if (item.children) {\n item.children = item.children.filter((child) => child.id !== id);\n }\n return item;\n })\n );\n }, []);\n\n const updateOutlineItems = useCallback((newItems: ContentOutlineItemContextProps[]) => {\n setOutlineItems(newItems);\n }, []);\n\n const updateItem = useCallback((id: string, properties: Partial<Omit<ContentOutlineItemContextProps, 'id'>>) => {\n setOutlineItems((prevItems) =>\n prevItems.map((item) => {\n if (item.id === id) {\n return {\n ...item,\n ...properties,\n };\n }\n return item;\n })\n );\n }, []);\n\n const unregisterAllChildren = useCallback(\n (parentIdGetter: (items: ContentOutlineItemContextProps[]) => string | undefined, childType: ITEM_TYPES) => {\n setOutlineItems((prevItems) => {\n const parentId = parentIdGetter(prevItems);\n if (!parentId) {\n return prevItems;\n }\n return prevItems.map((item) => {\n if (item.id === parentId) {\n item.children = item.children?.filter((child) => child.type !== childType);\n }\n return item;\n });\n });\n },\n []\n );\n\n useEffect(() => {\n setOutlineItems((prevItems) => {\n const newItems = [...prevItems];\n for (const item of newItems) {\n const sortedItems = sortItems(item.children || []);\n item.children = sortedItems;\n }\n return newItems;\n });\n }, [refreshDependencies]);\n\n return (\n <ContentOutlineContext.Provider\n value={{ outlineItems, register, unregister, updateOutlineItems, unregisterAllChildren, updateItem }}\n >\n {children}\n </ContentOutlineContext.Provider>\n );\n}\n\nfunction sortElementsByDocumentPosition(a: ContentOutlineItemContextProps, b: ContentOutlineItemContextProps) {\n if (a.ref && b.ref) {\n const diff = a.ref.compareDocumentPosition(b.ref);\n if (diff === Node.DOCUMENT_POSITION_PRECEDING) {\n return 1;\n } else if (diff === Node.DOCUMENT_POSITION_FOLLOWING) {\n return -1;\n }\n }\n return 0;\n}\n\nfunction sortItems(outlineItems: ContentOutlineItemContextProps[]): ContentOutlineItemContextProps[] {\n const [skipSort, sortable] = outlineItems.reduce<\n [ContentOutlineItemContextProps[], ContentOutlineItemContextProps[]]\n >(\n (acc, item) => {\n item.childOnTop ? acc[0].push(item) : acc[1].push(item);\n return acc;\n },\n [[], []]\n );\n\n sortable.sort(sortElementsByDocumentPosition);\n\n return [...skipSort, ...sortable];\n}\n\nexport function useContentOutlineContext() {\n return useContext(ContentOutlineContext);\n}\n","import { cx, css } from '@emotion/css';\nimport { ButtonHTMLAttributes, useEffect, useRef, useState } from 'react';\nimport * as React from 'react';\n\nimport { IconName, isIconName, GrafanaTheme2 } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { Button, Icon, Tooltip, useTheme2 } from '@grafana/ui';\nimport { TooltipPlacement } from '@grafana/ui/internal';\n\ntype CommonProps = {\n contentOutlineExpanded?: boolean;\n title?: string;\n icon?: IconName | React.ReactNode;\n tooltip?: string;\n tooltipPlacement?: TooltipPlacement;\n className?: string;\n indentStyle?: string;\n collapsible?: boolean;\n collapsed?: boolean;\n isActive?: boolean;\n extraHighlight?: boolean;\n sectionId?: string;\n toggleCollapsed?: () => void;\n color?: string;\n onRemove?: () => void;\n};\n\nexport type ContentOutlineItemButtonProps = CommonProps & ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport function ContentOutlineItemButton({\n contentOutlineExpanded,\n title,\n icon,\n tooltip,\n tooltipPlacement = 'bottom',\n className,\n indentStyle,\n collapsible,\n collapsed,\n isActive,\n extraHighlight,\n sectionId,\n toggleCollapsed,\n color,\n onRemove,\n ...rest\n}: ContentOutlineItemButtonProps) {\n const theme = useTheme2();\n const styles = getStyles(theme, color);\n\n const buttonStyles = cx(styles.button, className);\n\n const textRef = useRef<HTMLElement>(null);\n const [isOverflowing, setIsOverflowing] = useState(false);\n\n useEffect(() => {\n if (textRef.current) {\n setIsOverflowing(textRef.current?.scrollWidth > textRef.current?.clientWidth);\n }\n }, [title]);\n\n const body = (\n <div className={cx(styles.buttonContainer, indentStyle)}>\n {collapsible && (\n <button\n className={styles.collapseButton}\n onClick={toggleCollapsed}\n aria-label={t(\n 'explore.content-outline-item-button.body.aria-label-content-outline-item-collapse-button',\n 'Content outline item collapse button'\n )}\n aria-expanded={!collapsed}\n aria-controls={sectionId}\n >\n <OutlineIcon icon={collapsed ? 'angle-right' : 'angle-down'} />\n </button>\n )}\n <button\n className={cx(buttonStyles, {\n [styles.active]: isActive,\n [styles.extraHighlight]: extraHighlight,\n })}\n aria-label={tooltip}\n {...rest}\n >\n <OutlineIcon icon={icon} />\n {title && (\n <span className={styles.textContainer} ref={textRef}>\n {title}\n </span>\n )}\n </button>\n {onRemove && (\n <Button\n aria-label={t(\n 'explore.content-outline-item-button.body.aria-label-content-outline-item-delete-button',\n 'Delete item'\n )}\n variant=\"destructive\"\n className={styles.deleteButton}\n icon=\"times\"\n onClick={() => onRemove()}\n data-testid=\"content-outline-item-delete-button\"\n />\n )}\n </div>\n );\n\n // if there's a tooltip we want to show it if the text is overflowing\n const showTooltip = tooltip && (!contentOutlineExpanded || isOverflowing);\n\n return showTooltip ? (\n <Tooltip content={tooltip} placement={tooltipPlacement}>\n {body}\n </Tooltip>\n ) : (\n body\n );\n}\n\nfunction OutlineIcon({ icon }: { icon: IconName | React.ReactNode }) {\n if (!icon) {\n return null;\n }\n\n if (isIconName(icon)) {\n return <Icon name={icon} size={'lg'} title={icon} />;\n }\n\n return icon;\n}\n\nconst getStyles = (theme: GrafanaTheme2, color?: string) => {\n return {\n buttonContainer: css({\n position: 'relative',\n display: 'flex',\n alignItems: 'center',\n flexGrow: 1,\n gap: theme.spacing(0.25),\n width: '100%',\n overflow: 'hidden',\n }),\n button: css({\n label: 'content-outline-item-button',\n display: 'flex',\n alignItems: 'center',\n height: theme.spacing(theme.components.height.md),\n gap: theme.spacing(0.5),\n color: theme.colors.text.secondary,\n width: '100%',\n background: 'transparent',\n overflow: 'hidden',\n border: 'none',\n }),\n collapseButton: css({\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: theme.spacing(3),\n height: theme.spacing(4),\n borderRadius: theme.shape.radius.default,\n color: theme.colors.text.secondary,\n background: 'transparent',\n border: 'none',\n overflow: 'hidden',\n\n '&:hover': {\n color: theme.colors.text.primary,\n background: theme.colors.secondary.shade,\n },\n }),\n textContainer: css({\n whiteSpace: 'nowrap',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n fontSize: theme.typography.bodySmall.fontSize,\n marginLeft: theme.spacing(0.5),\n }),\n active: css({\n backgroundColor: theme.colors.background.secondary,\n borderTopRightRadius: theme.shape.radius.default,\n borderBottomRightRadius: theme.shape.radius.default,\n position: 'relative',\n height: theme.spacing(theme.components.height.md),\n\n '&::before': {\n backgroundImage: color !== undefined ? 'none' : theme.colors.gradients.brandVertical,\n backgroundColor: color !== undefined ? color : 'none',\n borderRadius: theme.shape.radius.default,\n content: '\" \"',\n display: 'block',\n height: '100%',\n position: 'absolute',\n transform: 'translateX(-50%)',\n width: theme.spacing(0.5),\n left: '2px',\n },\n }),\n extraHighlight: css({\n backgroundColor: theme.colors.background.secondary,\n borderTopRightRadius: theme.shape.radius.default,\n borderBottomRightRadius: theme.shape.radius.default,\n position: 'relative',\n\n '&::before': {\n backgroundImage: color !== undefined ? 'none' : theme.colors.gradients.brandVertical,\n backgroundColor: color !== undefined ? color : 'none',\n borderRadius: theme.shape.radius.default,\n content: '\" \"',\n display: 'block',\n height: '100%',\n position: 'absolute',\n transform: 'translateX(-50%)',\n width: theme.spacing(0.5),\n left: '2px',\n },\n }),\n deleteButton: css({\n width: theme.spacing(1),\n height: theme.spacing(1),\n padding: theme.spacing(0.75, 0.75),\n marginRight: theme.spacing(0.5),\n }),\n };\n};\n","import { css, cx } from '@emotion/css';\nimport { Fragment, useEffect, useRef, useState } from 'react';\nimport { useToggle, useScroll } from 'react-use';\n\nimport { GrafanaTheme2, store } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { reportInteraction } from '@grafana/runtime';\nimport { useStyles2, PanelContainer, ScrollContainer } from '@grafana/ui';\n\nimport { ContentOutlineItemContextProps, useContentOutlineContext } from './ContentOutlineContext';\nimport { ContentOutlineItemButton } from './ContentOutlineItemButton';\n\nfunction scrollableChildren(item: ContentOutlineItemContextProps) {\n return item.children?.filter((child) => child.type !== 'filter') || [];\n}\n\ntype SectionsExpanded = Record<string, boolean>;\n\nfunction shouldBeActive(\n item: ContentOutlineItemContextProps,\n activeSectionId: string,\n activeSectionChildId: string | undefined,\n sectionsExpanded: SectionsExpanded\n) {\n const isAnActiveParent = activeSectionId === item.id;\n const isAnActiveChild = activeSectionChildId === item.id;\n const isCollapsed = !sectionsExpanded[item.id];\n const containsScrollableChildren = scrollableChildren(item).length > 0;\n const anyChildActive = isChildActive(item, activeSectionChildId) && !sectionsExpanded[item.id];\n\n if (containsScrollableChildren) {\n return isCollapsed && (isAnActiveParent || anyChildActive);\n } else {\n return isAnActiveParent || isAnActiveChild;\n }\n}\n\nexport const CONTENT_OUTLINE_LOCAL_STORAGE_KEYS = {\n visible: 'grafana.explore.contentOutline.visible',\n expanded: 'grafana.explore.contentOutline.expanded',\n};\n\nexport function ContentOutline({ scroller, panelId }: { scroller: HTMLElement | undefined; panelId: string }) {\n const [contentOutlineExpanded, toggleContentOutlineExpanded] = useToggle(\n store.getBool(CONTENT_OUTLINE_LOCAL_STORAGE_KEYS.expanded, true)\n );\n const styles = useStyles2(getStyles, contentOutlineExpanded);\n const scrollerRef = useRef(scroller || null);\n const { y: verticalScroll } = useScroll(scrollerRef);\n const { outlineItems } = useContentOutlineContext() ?? { outlineItems: [] };\n const [activeSectionId, setActiveSectionId] = useState(outlineItems[0]?.id);\n const [activeSectionChildId, setActiveSectionChildId] = useState(outlineItems[0]?.children?.[0]?.id);\n\n const outlineItemsShouldIndent = outlineItems.some(\n (item) => item.children && !(item.mergeSingleChild && item.children?.length === 1) && item.children.length > 0\n );\n\n const outlineItemsHaveDeleteButton = outlineItems.some((item) => item.children?.some((child) => child.onRemove));\n\n const [sectionsExpanded, setSectionsExpanded] = useState(() => {\n return outlineItems.reduce((acc: { [key: string]: boolean }, item) => {\n acc[item.id] = !!item.expanded;\n return acc;\n }, {});\n });\n\n const scrollIntoView = (ref: HTMLElement | null, customOffsetTop = 0) => {\n let scrollValue = 0;\n let el: HTMLElement | null | undefined = ref;\n\n if (!el) {\n return;\n }\n\n do {\n scrollValue += el?.offsetTop || 0;\n el = el?.offsetParent instanceof HTMLElement ? el.offsetParent : undefined;\n } while (el && el !== scroller);\n\n scroller?.scroll({\n top: scrollValue + customOffsetTop,\n behavior: 'smooth',\n });\n };\n\n const handleItemClicked = (item: ContentOutlineItemContextProps) => {\n if (item.level === 'child' && item.type === 'filter') {\n const activeParent = outlineItems.find((parent) => {\n return parent.children?.find((child) => child.id === item.id);\n });\n\n if (activeParent) {\n scrollIntoView(activeParent.ref, activeParent.customTopOffset);\n }\n } else {\n scrollIntoView(item.ref, item.customTopOffset);\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'select_section',\n type: item.panelId,\n });\n }\n };\n\n const toggle = () => {\n store.set(CONTENT_OUTLINE_LOCAL_STORAGE_KEYS.expanded, !contentOutlineExpanded);\n toggleContentOutlineExpanded();\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'outline',\n type: contentOutlineExpanded ? 'minimize' : 'expand',\n });\n };\n\n const toggleSection = (itemId: string) => {\n setSectionsExpanded((prev) => ({\n ...prev,\n [itemId]: !prev[itemId],\n }));\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'section',\n type: !sectionsExpanded[itemId] ? 'minimize' : 'expand',\n });\n };\n\n useEffect(() => {\n let activeItem;\n\n for (const item of outlineItems) {\n let top = item?.ref?.getBoundingClientRect().top;\n\n // Check item\n if (top && top >= 0) {\n activeItem = item;\n }\n\n // Check children\n const activeChild = scrollableChildren(item).find((child) => {\n const offsetTop = child.customTopOffset || 0;\n let childTop = child?.ref?.getBoundingClientRect().top;\n return childTop && childTop >= offsetTop;\n });\n\n if (activeChild && isCollapsible(item)) {\n setActiveSectionChildId(activeChild.id);\n setActiveSectionId(item.id);\n break;\n }\n\n if (activeItem) {\n setActiveSectionId(activeItem.id);\n setActiveSectionChildId(undefined);\n break;\n }\n }\n }, [outlineItems, verticalScroll]);\n\n return (\n <PanelContainer className={styles.wrapper} id={panelId}>\n <ScrollContainer>\n <div className={styles.content}>\n <ContentOutlineItemButton\n icon={'arrow-from-right'}\n tooltip={\n contentOutlineExpanded\n ? t('explore.content-outline.tooltip-collapse-outline', 'Collapse outline')\n : t('explore.content-outline.tooltip-expand-outline', 'Expand outline')\n }\n tooltipPlacement={contentOutlineExpanded ? 'right' : 'bottom'}\n onClick={toggle}\n className={cx(styles.toggleContentOutlineButton, {\n [styles.justifyCenter]: !contentOutlineExpanded && !outlineItemsShouldIndent,\n })}\n aria-expanded={contentOutlineExpanded}\n />\n\n {outlineItems.map((item) => {\n return (\n <Fragment key={item.id}>\n <ContentOutlineItemButton\n key={item.id}\n title={contentOutlineExpanded ? item.title : undefined}\n contentOutlineExpanded={contentOutlineExpanded}\n className={cx(styles.buttonStyles, {\n [styles.justifyCenter]: !contentOutlineExpanded && !outlineItemsHaveDeleteButton,\n [styles.sectionHighlighter]: isChildActive(item, activeSectionChildId) && !contentOutlineExpanded,\n })}\n indentStyle={cx({\n [styles.indentRoot]: !isCollapsible(item) && outlineItemsShouldIndent,\n [styles.sectionHighlighter]:\n isChildActive(item, activeSectionChildId) && !contentOutlineExpanded && sectionsExpanded[item.id],\n })}\n icon={item.icon}\n onClick={() => handleItemClicked(item)}\n tooltip={item.title}\n collapsible={isCollapsible(item)}\n collapsed={!sectionsExpanded[item.id]}\n toggleCollapsed={() => toggleSection(item.id)}\n isActive={shouldBeActive(item, activeSectionId, activeSectionChildId, sectionsExpanded)}\n sectionId={item.id}\n color={item.color}\n />\n <div id={item.id} data-testid={`section-wrapper-${item.id}`}>\n {item.children &&\n isCollapsible(item) &&\n sectionsExpanded[item.id] &&\n item.children.map((child, i) => (\n <div key={child.id} className={styles.itemWrapper}>\n {contentOutlineExpanded && (\n <div\n className={cx(styles.itemConnector, {\n [styles.firstItemConnector]: i === 0,\n [styles.lastItemConnector]: i === (item.children?.length || 0) - 1,\n })}\n />\n )}\n <ContentOutlineItemButton\n key={child.id}\n title={contentOutlineExpanded ? child.title : undefined}\n contentOutlineExpanded={contentOutlineExpanded}\n icon={contentOutlineExpanded ? undefined : item.icon}\n className={cx(styles.buttonStyles, {\n [styles.justifyCenter]: !contentOutlineExpanded && !outlineItemsHaveDeleteButton,\n [styles.sectionHighlighter]:\n isChildActive(item, activeSectionChildId) && !contentOutlineExpanded,\n })}\n indentStyle={styles.indentChild}\n onClick={(e) => {\n handleItemClicked(child);\n child.onClick?.(e);\n }}\n tooltip={child.title}\n isActive={shouldBeActive(child, activeSectionId, activeSectionChildId, sectionsExpanded)}\n extraHighlight={child.highlight}\n color={child.color}\n onRemove={child.onRemove ? () => child.onRemove?.(child.id) : undefined}\n />\n </div>\n ))}\n </div>\n </Fragment>\n );\n })}\n </div>\n </ScrollContainer>\n </PanelContainer>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2, expanded: boolean) => {\n return {\n wrapper: css({\n label: 'wrapper',\n position: 'relative',\n display: 'flex',\n justifyContent: 'center',\n marginRight: theme.spacing(1),\n height: '100%',\n backgroundColor: theme.colors.background.primary,\n width: expanded ? '160px' : undefined,\n minWidth: expanded ? '160px' : undefined,\n }),\n content: css({\n label: 'content',\n marginLeft: theme.spacing(0.5),\n top: 0,\n }),\n buttonStyles: css({\n display: 'flex',\n '&:hover': {\n color: theme.colors.text.primary,\n textDecoration: 'underline',\n },\n }),\n toggleContentOutlineButton: css({\n '&:hover': {\n color: theme.colors.text.primary,\n },\n transform: expanded ? 'rotate(180deg)' : '',\n marginRight: expanded ? theme.spacing(0.5) : undefined,\n }),\n indentRoot: css({\n paddingLeft: theme.spacing(3),\n }),\n indentChild: css({\n paddingLeft: expanded ? theme.spacing(5) : theme.spacing(2.75),\n }),\n itemWrapper: css({\n display: 'flex',\n height: theme.spacing(4),\n alignItems: 'center',\n }),\n itemConnector: css({\n position: 'relative',\n height: '100%',\n width: theme.spacing(1.5),\n '&::before': {\n borderRight: `1px solid ${theme.colors.border.medium}`,\n content: '\"\"',\n height: '100%',\n left: theme.spacing(4.75),\n position: 'absolute',\n transform: 'translateX(50%)',\n },\n }),\n firstItemConnector: css({\n '&::before': {\n top: theme.spacing(1),\n height: `calc(100% - ${theme.spacing(1)})`,\n },\n }),\n lastItemConnector: css({\n '&::before': {\n height: `calc(100% - ${theme.spacing(1)})`,\n },\n }),\n justifyCenter: css({\n justifyContent: 'center',\n }),\n sectionHighlighter: css({\n backgroundColor: theme.colors.background.secondary,\n }),\n };\n};\n\nfunction isCollapsible(item: ContentOutlineItemContextProps): boolean {\n return !!(item.children && item.children.length > 0 && (!item.mergeSingleChild || item.children.length !== 1));\n}\n\nfunction isChildActive(item: ContentOutlineItemContextProps, activeSectionChildId: string | undefined) {\n return item.children?.some((child) => child.id === activeSectionChildId);\n}\n","import { useEffect, useRef, ReactNode } from 'react';\nimport * as React from 'react';\n\nimport { useContentOutlineContext } from './ContentOutlineContext';\n\ntype INDENT_LEVELS = 'root' | 'child';\n\nexport type ITEM_TYPES = 'scrollIntoView' | 'filter';\n\nexport interface ContentOutlineItemBaseProps {\n panelId: string;\n title: string;\n icon: string;\n /**\n * Custom offset from the top of the Explore container when scrolling to this item.\n * Items like query row need some offset so the top of the query row is not hidden behind the header.\n */\n customTopOffset?: number;\n /**\n * The level of indentation for this item.\n * - `root` is the top level item.\n * - `child` is an item that is a child of an item with `root` level.\n */\n level?: INDENT_LEVELS;\n /**\n * Merges a single child of this item with this item.\n * e.g. It doesn't make sense to nest a single query row under a queries container\n * because user can navigate to the query row by navigating to the queries container.\n */\n mergeSingleChild?: boolean;\n // callback that is called when the item is clicked\n // need this for filtering logs\n onClick?: (e: React.MouseEvent) => void;\n type?: ITEM_TYPES;\n /**\n * Client can additionally mark filter actions as highlighted\n */\n highlight?: boolean;\n onRemove?: (id: string) => void;\n /**\n * Child that will always be on top of the list\n * e.g. pinned log in Logs section\n */\n childOnTop?: boolean;\n expanded?: boolean;\n}\n\ninterface ContentOutlineItemProps extends ContentOutlineItemBaseProps {\n children: ReactNode;\n className?: string;\n}\n\nexport function ContentOutlineItem({\n panelId,\n title,\n icon,\n customTopOffset,\n children,\n className,\n level = 'root',\n mergeSingleChild,\n type = 'scrollIntoView',\n onClick,\n}: ContentOutlineItemProps) {\n const { register, unregister } = useContentOutlineContext() ?? {};\n const ref = useRef(null);\n\n useEffect(() => {\n if (!register || !unregister) {\n return;\n }\n\n // When the component mounts, register it and get its unique ID.\n const id = register({\n panelId: panelId,\n title: title,\n icon: icon,\n ref: ref.current,\n customTopOffset: customTopOffset,\n level: level,\n mergeSingleChild,\n type,\n });\n\n // When the component unmounts, unregister it using its unique ID.\n return () => unregister(id);\n }, [panelId, title, icon, customTopOffset, level, mergeSingleChild, register, unregister, type, onClick]);\n\n return (\n <div className={className} ref={ref}>\n {children}\n </div>\n );\n}\n","import { css } from '@emotion/css';\nimport { useId, useState, useMemo, useEffect } from 'react';\nimport Highlighter from 'react-highlight-words';\nimport { useForm, Controller } from 'react-hook-form';\n\nimport { DataLinkTransformationConfig, ScopedVars } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Button, Field, Icon, Input, Label, Modal, Select, Tooltip, Stack } from '@grafana/ui';\n\nimport {\n getSupportedTransTypeDetails,\n getTransformOptions,\n TransformationFieldDetails,\n} from '../correlations/Forms/types';\nimport { getTransformationVars } from '../correlations/transformations';\n\ninterface CorrelationTransformationAddModalProps {\n onCancel: () => void;\n onSave: (transformation: DataLinkTransformationConfig) => void;\n fieldList: Record<string, string>;\n transformationToEdit?: DataLinkTransformationConfig;\n}\n\ninterface ShowFormFields {\n expressionDetails: TransformationFieldDetails;\n mapValueDetails: TransformationFieldDetails;\n}\n\nconst LabelWithTooltip = ({ label, tooltipText }: { label: string; tooltipText: string }) => (\n <Stack gap={1} direction=\"row\" wrap=\"wrap\" alignItems=\"flex-start\">\n <Label>{label}</Label>\n <Tooltip content={tooltipText}>\n <Icon name=\"info-circle\" size=\"sm\" />\n </Tooltip>\n </Stack>\n);\n\nexport const CorrelationTransformationAddModal = ({\n onSave,\n onCancel,\n fieldList,\n transformationToEdit,\n}: CorrelationTransformationAddModalProps) => {\n const [exampleValue, setExampleValue] = useState<string | undefined>(undefined);\n const [transformationVars, setTransformationVars] = useState<ScopedVars>({});\n const [formFieldsVis, setFormFieldsVis] = useState<ShowFormFields>({\n mapValueDetails: { show: false },\n expressionDetails: { show: false },\n });\n const [isExpValid, setIsExpValid] = useState(false); // keep the highlighter from erroring on bad expressions\n const [validToSave, setValidToSave] = useState(false);\n const { getValues, control, register, watch } = useForm<DataLinkTransformationConfig>({\n defaultValues: useMemo(() => {\n if (transformationToEdit) {\n const exampleVal = fieldList[transformationToEdit?.field!];\n setExampleValue(exampleVal);\n if (transformationToEdit?.expression) {\n setIsExpValid(true);\n }\n const transformationTypeDetails = getSupportedTransTypeDetails(transformationToEdit?.type!);\n setFormFieldsVis({\n mapValueDetails: transformationTypeDetails.mapValueDetails,\n expressionDetails: transformationTypeDetails.expressionDetails,\n });\n\n const transformationVars = getTransformationVars(\n {\n type: transformationToEdit?.type!,\n expression: transformationToEdit?.expression,\n mapValue: transformationToEdit?.mapValue,\n },\n exampleVal || '',\n transformationToEdit?.field!\n );\n setTransformationVars({ ...transformationVars });\n setValidToSave(true);\n return {\n type: transformationToEdit?.type,\n field: transformationToEdit?.field,\n mapValue: transformationToEdit?.mapValue,\n expression: transformationToEdit?.expression,\n };\n } else {\n return undefined;\n }\n }, [fieldList, transformationToEdit]),\n });\n const id = useId();\n\n useEffect(() => {\n const subscription = watch((formValues) => {\n const expression = formValues.expression;\n let isExpressionValid = false;\n if (expression !== undefined) {\n isExpressionValid = true;\n try {\n new RegExp(expression);\n } catch (e) {\n isExpressionValid = false;\n }\n } else {\n isExpressionValid = !formFieldsVis.expressionDetails.show;\n }\n setIsExpValid(isExpressionValid);\n let transKeys = [];\n if (formValues.type) {\n const transformationVars = getTransformationVars(\n {\n type: formValues.type,\n expression: isExpressionValid ? expression : '',\n mapValue: formValues.mapValue,\n },\n fieldList[formValues.field!] || '',\n formValues.field!\n );\n\n transKeys = Object.keys(transformationVars);\n setTransformationVars(transKeys.length > 0 ? { ...transformationVars } : {});\n }\n\n if (transKeys.length === 0 || !isExpressionValid) {\n setValidToSave(false);\n } else {\n setValidToSave(true);\n }\n });\n return () => subscription.unsubscribe();\n }, [fieldList, formFieldsVis.expressionDetails.show, watch]);\n\n return (\n <Modal\n isOpen={true}\n title={\n transformationToEdit\n ? t('explore.correlation-transformation-add-modal.title-edit', 'Edit transformation')\n : t('explore.correlation-transformation-add-modal.title-add', 'Add transformation')\n }\n onDismiss={onCancel}\n className={css({ width: '700px' })}\n >\n <p>\n <Trans i18nKey=\"explore.correlation-transformation-add-modal.body\">\n A transformation extracts variables out of a single field. These variables will be available along with your\n field variables.\n </Trans>\n </p>\n <Field label={t('explore.correlation-transformation-add-modal.label-field', 'Field')}>\n <Controller\n control={control}\n render={({ field: { onChange, ref, ...field } }) => (\n <Select\n {...field}\n onChange={(value) => {\n if (value.value) {\n onChange(value.value);\n setExampleValue(fieldList[value.value]);\n }\n }}\n options={Object.entries(fieldList).map((entry) => {\n return { label: entry[0], value: entry[0] };\n })}\n aria-label={t('explore.correlation-transformation-add-modal.aria-label-field', 'Field')}\n />\n )}\n name={`field` as const}\n />\n </Field>\n\n {exampleValue && (\n <>\n <pre>\n <Highlighter\n textToHighlight={exampleValue}\n searchWords={[isExpValid ? (getValues('expression') ?? '') : '']}\n autoEscape={false}\n />\n </pre>\n <Field label={t('explore.correlation-transformation-add-modal.label-type', 'Type')}>\n <Controller\n control={control}\n render={({ field: { onChange, ref, ...field } }) => (\n <Select\n {...field}\n onChange={(value) => {\n onChange(value.value);\n const transformationTypeDetails = getSupportedTransTypeDetails(value.value!);\n setFormFieldsVis({\n mapValueDetails: transformationTypeDetails.mapValueDetails,\n expressionDetails: transformationTypeDetails.expressionDetails,\n });\n }}\n options={getTransformOptions()}\n aria-label={t('explore.correlation-transformation-add-modal.aria-label-type', 'Type')}\n />\n )}\n name={`type` as const}\n />\n </Field>\n {formFieldsVis.expressionDetails.show && (\n <Field\n label={\n formFieldsVis.expressionDetails.helpText ? (\n <LabelWithTooltip\n label={t('explore.correlation-transformation-add-modal.label-expression', 'Expression')}\n tooltipText={formFieldsVis.expressionDetails.helpText}\n />\n ) : (\n t('explore.correlation-transformation-add-modal.label-expression-without-tooltip', 'Expression')\n )\n }\n htmlFor={`${id}-expression`}\n required={formFieldsVis.expressionDetails.required}\n >\n <Input {...register('expression')} id={`${id}-expression`} />\n </Field>\n )}\n {formFieldsVis.mapValueDetails.show && (\n <Field\n label={\n formFieldsVis.mapValueDetails.helpText ? (\n <LabelWithTooltip\n label={t('explore.correlation-transformation-add-modal.label-variable-name', 'Variable name')}\n tooltipText={formFieldsVis.mapValueDetails.helpText}\n />\n ) : (\n t('explore.correlation-transformation-add-modal.label-variable-name-without-tooltip', 'Variable name')\n )\n }\n htmlFor={`${id}-mapValue`}\n >\n <Input {...register('mapValue')} id={`${id}-mapValue`} />\n </Field>\n )}\n {Object.entries(transformationVars).length > 0 && (\n <>\n <Trans i18nKey=\"explore.correlation-transformation-add-modal.added-variables\">\n This transformation will add the following variables:\n </Trans>\n <pre>\n {Object.entries(transformationVars).map((entry) => {\n return `\\$\\{${entry[0]}\\} = ${entry[1]?.value}\\n`;\n })}\n </pre>\n </>\n )}\n </>\n )}\n <Modal.ButtonRow>\n <Button variant=\"secondary\" onClick={onCancel} fill=\"outline\">\n <Trans i18nKey=\"explore.correlation-transformation-add-modal.cancel\">Cancel</Trans>\n </Button>\n <Button variant=\"primary\" onClick={() => onSave(getValues())} disabled={!validToSave}>\n {transformationToEdit\n ? t('explore.correlation-transformation-add-modal.edit-transformation', 'Edit transformation')\n : t('explore.correlation-transformation-add-modal.add-transformation', 'Add transformation to correlation')}\n </Button>\n </Modal.ButtonRow>\n </Modal>\n );\n};\n","import { css } from '@emotion/css';\nimport { useEffect, useId, useState } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { useAsync } from 'react-use';\n\nimport { DataLinkTransformationConfig, ExploreCorrelationHelperData, GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport {\n Alert,\n Button,\n Card,\n Collapse,\n DeleteButton,\n Field,\n Icon,\n IconButton,\n Input,\n Stack,\n Tooltip,\n useStyles2,\n} from '@grafana/ui';\nimport { useDispatch, useSelector } from 'app/types/store';\n\nimport { getTransformationVars } from '../correlations/transformations';\nimport { generateDefaultLabel } from '../correlations/utils';\n\nimport { CorrelationTransformationAddModal } from './CorrelationTransformationAddModal';\nimport { changeCorrelationHelperData } from './state/explorePane';\nimport { changeCorrelationEditorDetails } from './state/main';\nimport { selectCorrelationDetails, selectPanes } from './state/selectors';\n\ninterface Props {\n exploreId: string;\n correlations: ExploreCorrelationHelperData;\n}\n\ninterface FormValues {\n label: string;\n description: string;\n}\n\nexport const CorrelationHelper = ({ exploreId, correlations }: Props) => {\n const dispatch = useDispatch();\n const styles = useStyles2(getStyles);\n const panes = useSelector(selectPanes);\n const panesVals = Object.values(panes);\n const { value: defaultLabel, loading: loadingLabel } = useAsync(\n async () => await generateDefaultLabel(panesVals[0]!, panesVals[1]!),\n [\n panesVals[0]?.datasourceInstance,\n panesVals[0]?.queries[0].datasource,\n panesVals[1]?.datasourceInstance,\n panesVals[1]?.queries[0].datasource,\n ]\n );\n\n const { register, watch, getValues, setValue } = useForm<FormValues>();\n const [isLabelDescOpen, setIsLabelDescOpen] = useState(false);\n const [isTransformOpen, setIsTransformOpen] = useState(false);\n const [showTransformationAddModal, setShowTransformationAddModal] = useState(false);\n const [transformations, setTransformations] = useState<DataLinkTransformationConfig[]>([]);\n const [transformationIdxToEdit, setTransformationIdxToEdit] = useState<number | undefined>(undefined);\n const correlationDetails = useSelector(selectCorrelationDetails);\n const id = useId();\n\n // only fire once on mount to allow save button to enable / disable when unmounted\n useEffect(() => {\n dispatch(changeCorrelationEditorDetails({ canSave: true }));\n return () => {\n dispatch(changeCorrelationEditorDetails({ canSave: false }));\n };\n }, [dispatch]);\n\n useEffect(() => {\n if (\n !loadingLabel &&\n defaultLabel !== undefined &&\n !correlationDetails?.correlationDirty &&\n getValues('label') !== ''\n ) {\n setValue('label', defaultLabel);\n }\n }, [correlationDetails?.correlationDirty, defaultLabel, getValues, loadingLabel, setValue]);\n\n useEffect(() => {\n const subscription = watch((value) => {\n let dirty = correlationDetails?.correlationDirty || false;\n let description = value.description || '';\n if (!dirty && (value.label !== defaultLabel || description !== '')) {\n dirty = true;\n } else if (dirty && value.label === defaultLabel && description.trim() === '') {\n dirty = false;\n }\n dispatch(\n changeCorrelationEditorDetails({ label: value.label, description: value.description, correlationDirty: dirty })\n );\n });\n return () => subscription.unsubscribe();\n }, [correlationDetails?.correlationDirty, defaultLabel, dispatch, watch]);\n\n useEffect(() => {\n const dirty =\n !correlationDetails?.correlationDirty && transformations.length > 0 ? true : correlationDetails?.correlationDirty;\n dispatch(changeCorrelationEditorDetails({ transformations: transformations, correlationDirty: dirty }));\n let transVarRecords: Record<string, string> = {};\n transformations.forEach((transformation) => {\n const transformationVars = getTransformationVars(\n {\n type: transformation.type,\n expression: transformation.expression,\n mapValue: transformation.mapValue,\n },\n correlations.vars[transformation.field!],\n transformation.field!\n );\n\n Object.keys(transformationVars).forEach((key) => {\n transVarRecords[key] = transformationVars[key]?.value;\n });\n });\n\n dispatch(\n changeCorrelationHelperData({\n exploreId: exploreId,\n correlationEditorHelperData: {\n resultField: correlations.resultField,\n origVars: correlations.origVars,\n vars: { ...correlations.origVars, ...transVarRecords },\n },\n })\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [dispatch, transformations]);\n\n return (\n <>\n {showTransformationAddModal && (\n <CorrelationTransformationAddModal\n onCancel={() => {\n setTransformationIdxToEdit(undefined);\n setShowTransformationAddModal(false);\n }}\n onSave={(transformation: DataLinkTransformationConfig) => {\n if (transformationIdxToEdit !== undefined) {\n const editTransformations = [...transformations];\n editTransformations[transformationIdxToEdit] = transformation;\n setTransformations(editTransformations);\n setTransformationIdxToEdit(undefined);\n } else {\n setTransformations([...transformations, transformation]);\n }\n setShowTransformationAddModal(false);\n }}\n fieldList={correlations.origVars}\n transformationToEdit={\n transformationIdxToEdit !== undefined ? transformations[transformationIdxToEdit] : undefined\n }\n />\n )}\n <Alert title={t('explore.correlation-helper.title-correlation-details', 'Correlation details')} severity=\"info\">\n <Trans\n i18nKey=\"explore.correlation-helper.body-correlation-details\"\n values={{ resultField: correlations.resultField }}\n >\n The correlation link will appear by the <code>{'{{resultField}}'}</code> field. You can use the following\n variables to set up your correlations:\n </Trans>\n <pre>\n {Object.entries(correlations.vars).map((entry) => {\n return `\\$\\{${entry[0]}\\} = ${entry[1]}\\n`;\n })}\n </pre>\n <Collapse\n isOpen={isLabelDescOpen}\n onToggle={() => {\n setIsLabelDescOpen(!isLabelDescOpen);\n }}\n label={\n <Stack gap={1} direction=\"row\" wrap=\"wrap\" alignItems=\"center\">\n <Trans i18nKey=\"explore.correlation-helper.label-description-header\">Label / Description</Trans>\n {!isLabelDescOpen && !loadingLabel && (\n <span className={styles.labelCollapseDetails}>{`Label: ${getValues('label') || defaultLabel}`}</span>\n )}\n </Stack>\n }\n >\n <Field label={t('explore.correlation-helper.label-label', 'Label')} htmlFor={`${id}-label`}>\n <Input\n {...register('label')}\n id={`${id}-label`}\n onBlur={() => {\n if (getValues('label') === '' && defaultLabel !== undefined) {\n setValue('label', defaultLabel);\n }\n }}\n />\n </Field>\n <Field label={t('explore.correlation-helper.label-description', 'Description')} htmlFor={`${id}-description`}>\n <Input {...register('description')} id={`${id}-description`} />\n </Field>\n </Collapse>\n <Collapse\n isOpen={isTransformOpen}\n onToggle={() => {\n setIsTransformOpen(!isTransformOpen);\n }}\n label={\n <Stack gap={1} direction=\"row\" wrap=\"wrap\" alignItems=\"center\">\n <Trans i18nKey=\"explore.correlation-helper.transformations\">Transformations</Trans>\n <Tooltip\n content={t(\n 'explore.correlation-helper.tooltip-transformations',\n 'A transformation extracts one or more variables out of a single field.'\n )}\n >\n <Icon name=\"info-circle\" size=\"sm\" />\n </Tooltip>\n </Stack>\n }\n >\n <Button\n variant=\"secondary\"\n fill=\"outline\"\n onClick={() => {\n setShowTransformationAddModal(true);\n }}\n className={styles.transformationAction}\n >\n <Trans i18nKey=\"explore.correlation-helper.add-transformation\">Add transformation</Trans>\n </Button>\n {transformations.map((transformation, i) => {\n const { type, field, expression, mapValue } = transformation;\n const detailsString = [\n (mapValue ?? '').length > 0 ? `Variable name: ${mapValue}` : undefined,\n (expression ?? '').length > 0 ? (\n <Trans i18nKey=\"explore.correlation-helper.expression\" values={{ expression }}>\n Expression: <code>{'{{expression}}'}</code>\n </Trans>\n ) : undefined,\n ].filter((val) => val);\n return (\n <Card noMargin key={`trans-${i}`}>\n <Card.Heading>\n {field}: {type}\n </Card.Heading>\n {detailsString.length > 0 && (\n <Card.Meta className={styles.transformationMeta}>{detailsString}</Card.Meta>\n )}\n <Card.SecondaryActions>\n <IconButton\n key=\"edit\"\n name=\"edit\"\n aria-label={t('explore.correlation-helper.aria-label-edit-transformation', 'Edit transformation')}\n onClick={() => {\n setTransformationIdxToEdit(i);\n setShowTransformationAddModal(true);\n }}\n />\n <DeleteButton\n aria-label={t(\n 'explore.correlation-helper.aria-label-delete-transformation',\n 'Delete transformation'\n )}\n onConfirm={() => setTransformations(transformations.filter((_, idx) => i !== idx))}\n closeOnConfirm\n />\n </Card.SecondaryActions>\n </Card>\n );\n })}\n </Collapse>\n </Alert>\n </>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n labelCollapseDetails: css({\n marginLeft: theme.spacing(2),\n ...theme.typography['bodySmall'],\n fontStyle: 'italic',\n }),\n transformationAction: css({\n marginBottom: theme.spacing(2),\n }),\n transformationMeta: css({\n alignItems: 'baseline',\n }),\n };\n};\n","import { DataFrame, DataLinksContext, EventBus, LoadingState, SplitOpen, TimeRange } from '@grafana/data';\nimport { PanelRenderer } from '@grafana/runtime';\nimport { PanelChrome } from '@grafana/ui';\n\nimport { getPanelPluginMeta } from '../plugins/importPanelPlugin';\n\nimport { useExploreDataLinkPostProcessor } from './hooks/useExploreDataLinkPostProcessor';\n\nexport interface Props {\n width: number;\n height: number;\n timeZone: string;\n pluginId: string;\n frames: DataFrame[];\n timeRange: TimeRange;\n state: LoadingState;\n splitOpenFn: SplitOpen;\n eventBus: EventBus;\n}\n\nexport function CustomContainer({ width, height, timeZone, state, pluginId, frames, timeRange, splitOpenFn }: Props) {\n const plugin = getPanelPluginMeta(pluginId);\n\n const dataLinkPostProcessor = useExploreDataLinkPostProcessor(splitOpenFn, timeRange);\n\n return (\n <DataLinksContext.Provider value={{ dataLinkPostProcessor }}>\n <PanelChrome title={plugin.name} width={width} height={height} loadingState={state}>\n {(innerWidth, innerHeight) => (\n <PanelRenderer\n data={{ series: frames, state: state, timeRange }}\n pluginId={pluginId}\n title=\"\"\n width={innerWidth}\n height={innerHeight}\n timeZone={timeZone}\n />\n )}\n </PanelChrome>\n </DataLinksContext.Provider>\n );\n}\n","import { t } from '@grafana/i18n';\nimport { Tooltip, ToolbarButton } from '@grafana/ui';\n\ninterface TimeSyncButtonProps {\n isSynced: boolean;\n onClick: () => void;\n}\n\nexport function TimeSyncButton(props: TimeSyncButtonProps) {\n const { onClick, isSynced } = props;\n\n const syncTimesTooltip = () => {\n const { isSynced } = props;\n const tooltip = isSynced ? 'Unsync all views' : 'Sync all views to this time range';\n return <>{tooltip}</>;\n };\n\n return (\n <Tooltip content={syncTimesTooltip} placement=\"bottom\">\n <ToolbarButton\n icon=\"link\"\n variant={isSynced ? 'active' : 'canvas'}\n aria-label={\n isSynced\n ? t('explore.time-sync-button.aria-label-synced', 'Synced times')\n : t('explore.time-sync-button.aria-label-unsynced', 'Unsynced times')\n }\n onClick={onClick}\n />\n </Tooltip>\n );\n}\n","import { TimeRange, RawTimeRange, dateTimeForTimeZone, dateMath } from '@grafana/data';\nimport { reportInteraction } from '@grafana/runtime';\nimport { TimeZone } from '@grafana/schema';\nimport { TimePickerWithHistory } from 'app/core/components/TimePicker/TimePickerWithHistory';\nimport { getShiftedTimeRange, getZoomedTimeRange } from 'app/core/utils/timePicker';\n\nimport { TimeSyncButton } from './TimeSyncButton';\n\nexport interface Props {\n exploreId: string;\n hideText?: boolean;\n range: TimeRange;\n timeZone: TimeZone;\n fiscalYearStartMonth: number;\n splitted: boolean;\n syncedTimes: boolean;\n onChangeTimeSync: () => void;\n onChangeTime: (range: RawTimeRange) => void;\n onChangeTimeZone: (timeZone: TimeZone) => void;\n onChangeFiscalYearStartMonth: (fiscalYearStartMonth: number) => void;\n}\n\nexport const ExploreTimeControls = ({\n range,\n timeZone,\n fiscalYearStartMonth,\n splitted,\n syncedTimes,\n onChangeTimeSync,\n hideText,\n onChangeTimeZone,\n onChangeFiscalYearStartMonth,\n onChangeTime,\n}: Props) => {\n const onMoveTimePicker = (direction: number) => {\n const { from, to } = getShiftedTimeRange(direction, range);\n const nextTimeRange = {\n from: dateTimeForTimeZone(timeZone, from),\n to: dateTimeForTimeZone(timeZone, to),\n };\n\n onChangeTime(nextTimeRange);\n };\n\n const onMoveForward = () => onMoveTimePicker(1);\n const onMoveBack = () => onMoveTimePicker(-1);\n\n const onChangeTimePicker = (timeRange: TimeRange) => {\n const adjustedFrom = dateMath.isMathString(timeRange.raw.from) ? timeRange.raw.from : timeRange.from;\n const adjustedTo = dateMath.isMathString(timeRange.raw.to) ? timeRange.raw.to : timeRange.to;\n\n onChangeTime({\n from: adjustedFrom,\n to: adjustedTo,\n });\n\n reportInteraction('grafana_explore_time_picker_time_range_changed', {\n timeRangeFrom: adjustedFrom,\n timeRangeTo: adjustedTo,\n });\n };\n\n const onZoom = () => {\n const { from, to } = getZoomedTimeRange(range, 2);\n const nextTimeRange = {\n from: dateTimeForTimeZone(timeZone, from),\n to: dateTimeForTimeZone(timeZone, to),\n };\n\n onChangeTime(nextTimeRange);\n };\n\n const timeSyncButton = splitted ? <TimeSyncButton onClick={onChangeTimeSync} isSynced={syncedTimes} /> : undefined;\n const timePickerCommonProps = {\n value: range,\n timeZone,\n fiscalYearStartMonth,\n onMoveBackward: onMoveBack,\n onMoveForward: onMoveForward,\n onZoom: onZoom,\n hideText,\n };\n\n return (\n <TimePickerWithHistory\n isOnCanvas\n {...timePickerCommonProps}\n timeSyncButton={timeSyncButton}\n isSynced={syncedTimes}\n widthOverride={splitted ? window.innerWidth / 2 : undefined}\n onChange={onChangeTimePicker}\n onChangeTimeZone={onChangeTimeZone}\n onChangeFiscalYearStartMonth={onChangeFiscalYearStartMonth}\n />\n );\n};\n","import { css } from '@emotion/css';\nimport { useRef } from 'react';\nimport { CSSTransition } from 'react-transition-group';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { Tooltip, ButtonGroup, ToolbarButton } from '@grafana/ui';\n\ntype LiveTailButtonProps = {\n splitted: boolean;\n start: () => void;\n stop: () => void;\n pause: () => void;\n resume: () => void;\n isLive: boolean;\n isPaused: boolean;\n};\n\nexport function LiveTailButton(props: LiveTailButtonProps) {\n const transitionRef = useRef(null);\n\n const { start, pause, resume, isLive, isPaused, stop, splitted } = props;\n const buttonVariant = isLive && !isPaused ? 'active' : 'canvas';\n const onClickMain = isLive ? (isPaused ? resume : pause) : start;\n\n return (\n <ButtonGroup>\n <Tooltip\n content={\n isLive && !isPaused ? (\n <>\n <Trans i18nKey=\"explore.live-tail-button.pause-the-live-stream\">Pause the live stream</Trans>\n </>\n ) : (\n <>\n <Trans i18nKey=\"explore.live-tail-button.start-live-stream-your-logs\">Start live stream your logs</Trans>\n </>\n )\n }\n placement=\"bottom\"\n >\n <ToolbarButton\n iconOnly={splitted}\n variant={buttonVariant}\n icon={!isLive || isPaused ? 'play' : 'pause'}\n onClick={onClickMain}\n >\n {isLive && isPaused\n ? t('explore.live-tail-button.paused', 'Paused')\n : t('explore.live-tail-button.live', 'Live')}\n </ToolbarButton>\n </Tooltip>\n\n <CSSTransition\n mountOnEnter={true}\n unmountOnExit={true}\n timeout={100}\n in={isLive}\n classNames={{\n enter: styles.stopButtonEnter,\n enterActive: styles.stopButtonEnterActive,\n exit: styles.stopButtonExit,\n exitActive: styles.stopButtonExitActive,\n }}\n nodeRef={transitionRef}\n >\n <Tooltip\n content={\n <>\n <Trans i18nKey=\"explore.live-tail-button.stop-and-exit-the-live-stream\">\n Stop and exit the live stream\n </Trans>\n </>\n }\n placement=\"bottom\"\n >\n <ToolbarButton ref={transitionRef} variant={buttonVariant} onClick={stop} icon=\"square-shape\" />\n </Tooltip>\n </CSSTransition>\n </ButtonGroup>\n );\n}\n\nconst styles = {\n stopButtonEnter: css({\n label: 'stopButtonEnter',\n width: 0,\n opacity: 0,\n overflow: 'hidden',\n }),\n stopButtonEnterActive: css({\n label: 'stopButtonEnterActive',\n opacity: 1,\n width: '32px',\n }),\n stopButtonExit: css({\n label: 'stopButtonExit',\n width: '32px',\n opacity: 1,\n overflow: 'hidden',\n }),\n stopButtonExitActive: css({\n label: 'stopButtonExitActive',\n opacity: 0,\n width: 0,\n }),\n};\n","import { useState } from 'react';\n\nimport { IconName } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { reportInteraction, config } from '@grafana/runtime';\nimport { Dropdown, Menu, MenuGroup, ButtonGroup, Button } from '@grafana/ui';\nimport { copyStringToClipboard } from 'app/core/utils/explore';\nimport { createAndCopyShortLink } from 'app/core/utils/shortLinks';\nimport { useSelector } from 'app/types/store';\n\nimport { selectPanes } from './state/selectors';\nimport { constructAbsoluteUrl } from './utils/links';\n\ninterface ShortLinkGroupData {\n key: string;\n label: string;\n items: ShortLinkMenuItemData[];\n}\n\ninterface ShortLinkMenuItemData {\n key: string;\n label: string;\n icon: IconName;\n getUrl: Function;\n shorten: boolean;\n absTime: boolean;\n}\n\nexport function ShortLinkButtonMenu() {\n const defaultMode: ShortLinkMenuItemData = {\n key: 'copy-link',\n label: t('explore.toolbar.copy-shortened-link', 'Copy shortened URL'),\n icon: 'share-alt',\n getUrl: () => undefined,\n shorten: true,\n absTime: false,\n };\n const panes = useSelector(selectPanes);\n const [isOpen, setIsOpen] = useState(false);\n const [lastSelected, setLastSelected] = useState(defaultMode);\n const onCopyLink = (shorten: boolean, absTime: boolean, url?: string) => {\n if (shorten) {\n createAndCopyShortLink(url || global.location.href);\n reportInteraction('grafana_explore_shortened_link_clicked', { isAbsoluteTime: absTime });\n } else {\n copyStringToClipboard(\n url !== undefined\n ? `${window.location.protocol}//${window.location.host}${config.appSubUrl}${url}`\n : global.location.href\n );\n reportInteraction('grafana_explore_copy_link_clicked', { isAbsoluteTime: absTime });\n }\n };\n\n const menuOptions: ShortLinkGroupData[] = [\n {\n key: 'normal',\n label: t('explore.toolbar.copy-links-normal-category', 'Normal URL links'),\n items: [\n {\n key: 'copy-shortened-link',\n icon: 'link',\n label: t('explore.toolbar.copy-shortened-link', 'Copy shortened URL'),\n getUrl: () => undefined,\n shorten: true,\n absTime: false,\n },\n {\n key: 'copy-link',\n icon: 'link',\n label: t('explore.toolbar.copy-link', 'Copy URL'),\n getUrl: () => undefined,\n shorten: false,\n absTime: false,\n },\n ],\n },\n {\n key: 'timesync',\n label: t('explore.toolbar.copy-links-absolute-category', 'Time-sync URL links (share with time range intact)'),\n items: [\n {\n key: 'copy-short-link-abs-time',\n icon: 'clock-nine',\n label: t('explore.toolbar.copy-shortened-link-abs-time', 'Copy absolute shortened URL'),\n shorten: true,\n getUrl: () => {\n return constructAbsoluteUrl(panes);\n },\n absTime: true,\n },\n {\n key: 'copy-link-abs-time',\n icon: 'clock-nine',\n label: t('explore.toolbar.copy-link-abs-time', 'Copy absolute URL'),\n shorten: false,\n getUrl: () => {\n return constructAbsoluteUrl(panes);\n },\n absTime: true,\n },\n ],\n },\n ];\n\n const MenuActions = (\n <Menu>\n {menuOptions.map((groupOption) => {\n return (\n <MenuGroup key={groupOption.key} label={groupOption.label}>\n {groupOption.items.map((option) => {\n return (\n <Menu.Item\n key={option.key}\n label={option.label}\n icon={option.icon}\n onClick={() => {\n const url = option.getUrl();\n onCopyLink(option.shorten, option.absTime, url);\n setLastSelected(option);\n }}\n />\n );\n })}\n </MenuGroup>\n );\n })}\n </Menu>\n );\n\n // we need the Toolbar button click to be an action separate from opening/closing the menu\n return (\n <ButtonGroup>\n <Button\n tooltip={lastSelected.label}\n icon={lastSelected.icon}\n size=\"sm\"\n variant=\"secondary\"\n onClick={() => {\n const url = lastSelected.getUrl();\n onCopyLink(lastSelected.shorten, lastSelected.absTime, url);\n }}\n aria-label={t('explore.toolbar.copy-shortened-link', 'Copy shortened URL')}\n >\n <Trans i18nKey=\"explore.toolbar.copy-shortened-link-label\">Share</Trans>\n </Button>\n <Dropdown overlay={MenuActions} placement=\"bottom-end\" onVisibleChange={setIsOpen}>\n <Button\n variant={'secondary'}\n size=\"sm\"\n icon={isOpen ? 'angle-up' : 'angle-down'}\n aria-label={t('explore.toolbar.copy-shortened-link-menu', 'Open copy link options')}\n />\n </Dropdown>\n </ButtonGroup>\n );\n}\n","import { lazy, Suspense } from 'react';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { Dropdown, ToolbarButton } from '@grafana/ui';\nimport { contextSrv } from 'app/core/services/context_srv';\nimport { AccessControlAction } from 'app/types/accessControl';\n\nimport { ToolbarExtensionPointMenu } from '../ToolbarExtensionPointMenu';\n\nimport { ExtensionDropdownProps } from './types';\n\nconst AddToDashboard = lazy(() =>\n import('./../AddToDashboard').then(({ AddToDashboard }) => ({ default: AddToDashboard }))\n);\n\nexport function BasicExtensions(props: ExtensionDropdownProps) {\n const { exploreId, links, setSelectedExtension, setIsModalOpen, isModalOpen, noQueriesInPane } = props;\n // If we only have the explore core extension point registered we show the old way of\n // adding a query to a dashboard.\n if (links.length <= 1) {\n const canAddPanelToDashboard =\n contextSrv.hasPermission(AccessControlAction.DashboardsCreate) ||\n contextSrv.hasPermission(AccessControlAction.DashboardsWrite);\n\n if (!canAddPanelToDashboard) {\n return null;\n }\n\n return (\n <Suspense fallback={null}>\n <AddToDashboard exploreId={exploreId} />\n </Suspense>\n );\n }\n\n const menu = <ToolbarExtensionPointMenu extensions={links} onSelect={setSelectedExtension} />;\n\n return (\n <>\n <Dropdown onVisibleChange={setIsModalOpen} placement=\"bottom-start\" overlay={menu}>\n <ToolbarButton\n aria-label={t('explore.basic-extensions.aria-label-add', 'Add')}\n disabled={!Boolean(noQueriesInPane)}\n variant=\"canvas\"\n isOpen={isModalOpen}\n >\n <Trans i18nKey=\"explore.toolbar.add-to-extensions\">Add</Trans>\n </ToolbarButton>\n </Dropdown>\n </>\n );\n}\n","import { first } from 'lodash';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { Dropdown, ToolbarButton } from '@grafana/ui';\n\nimport { ToolbarExtensionPointMenu } from '../ToolbarExtensionPointMenu';\n\nimport { ExtensionDropdownProps } from './types';\n\nexport function QuerylessAppsExtensions(props: ExtensionDropdownProps) {\n const { links, setSelectedExtension, setIsModalOpen, isModalOpen, noQueriesInPane } = props;\n\n if (links.length === 0) {\n return undefined;\n }\n\n const menu = <ToolbarExtensionPointMenu extensions={links} onSelect={setSelectedExtension} />;\n\n if (links.length === 1) {\n const link = first(links)!;\n return (\n <ToolbarButton variant=\"canvas\" icon={link.icon} onClick={() => setSelectedExtension(link)}>\n <Trans i18nKey=\"explore.toolbar.add-to-queryless-extensions\">Go queryless</Trans>\n </ToolbarButton>\n );\n }\n\n return (\n <>\n <Dropdown onVisibleChange={setIsModalOpen} placement=\"bottom-start\" overlay={menu}>\n <ToolbarButton\n aria-label={t('explore.queryless-apps-extensions.aria-label-go-queryless', 'Go queryless')}\n disabled={!Boolean(noQueriesInPane)}\n variant=\"canvas\"\n isOpen={isModalOpen}\n >\n <Trans i18nKey=\"explore.toolbar.add-to-queryless-extensions\">Go queryless</Trans>\n </ToolbarButton>\n </Dropdown>\n </>\n );\n}\n","import { ReactElement, useMemo, useState } from 'react';\n\nimport { type PluginExtensionLink, PluginExtensionPoints, RawTimeRange, getTimeZone } from '@grafana/data';\nimport { config, reportInteraction, usePluginLinks } from '@grafana/runtime';\nimport { DataQuery, TimeZone } from '@grafana/schema';\nimport { contextSrv } from 'app/core/services/context_srv';\nimport { AccessControlAction } from 'app/types/accessControl';\nimport { ExplorePanelData } from 'app/types/explore';\nimport { useSelector } from 'app/types/store';\n\nimport { getExploreItemSelector, isLeftPaneSelector, selectCorrelationDetails } from '../state/selectors';\n\nimport { ConfirmNavigationModal } from './ConfirmNavigationModal';\nimport { BasicExtensions } from './toolbar/BasicExtensions';\nimport { QuerylessAppsExtensions } from './toolbar/QuerylessAppsExtensions';\n\ntype Props = {\n exploreId: string;\n timeZone: TimeZone;\n extensionsToShow: 'queryless' | 'basic';\n};\n\nconst QUERYLESS_APPS = [\n 'grafana-pyroscope-app',\n 'grafana-lokiexplore-app',\n 'grafana-exploretraces-app',\n 'grafana-metricsdrilldown-app',\n];\n\nexport function ToolbarExtensionPoint(props: Props): ReactElement | null {\n const { exploreId, extensionsToShow } = props;\n const [selectedExtension, setSelectedExtension] = useState<PluginExtensionLink | undefined>();\n const [isOpen, setIsOpen] = useState<boolean>(false);\n const context = useExtensionPointContext(props);\n // TODO: Pull it up to avoid calling it twice\n const { links } = usePluginLinks({\n extensionPointId: PluginExtensionPoints.ExploreToolbarAction,\n context: context,\n limitPerPlugin: 3,\n });\n const selectExploreItem = getExploreItemSelector(exploreId);\n const noQueriesInPane = Boolean(useSelector(selectExploreItem)?.queries?.length);\n\n const querylessLinks = links.filter((link) => QUERYLESS_APPS.includes(link.pluginId));\n const commonLinks = links.filter((link) => !QUERYLESS_APPS.includes(link.pluginId));\n\n return (\n <>\n {extensionsToShow === 'queryless' && (\n <QuerylessAppsExtensions\n links={querylessLinks}\n noQueriesInPane={noQueriesInPane}\n exploreId={exploreId}\n setSelectedExtension={(extension) => {\n setSelectedExtension(extension);\n reportInteraction('grafana_explore_queryless_app_link_clicked', {\n pluginId: extension.pluginId,\n });\n }}\n setIsModalOpen={setIsOpen}\n isModalOpen={isOpen}\n />\n )}\n {extensionsToShow === 'basic' && (\n <BasicExtensions\n links={commonLinks}\n noQueriesInPane={noQueriesInPane}\n exploreId={exploreId}\n setSelectedExtension={setSelectedExtension}\n setIsModalOpen={setIsOpen}\n isModalOpen={isOpen}\n />\n )}\n {!!selectedExtension && !!selectedExtension.path && (\n <ConfirmNavigationModal\n path={selectedExtension.path}\n title={selectedExtension.title}\n onDismiss={() => setSelectedExtension(undefined)}\n />\n )}\n </>\n );\n}\n\nexport type PluginExtensionExploreContext = {\n exploreId: string;\n targets: DataQuery[];\n data: ExplorePanelData;\n timeRange: RawTimeRange;\n timeZone: TimeZone;\n shouldShowAddCorrelation: boolean;\n};\n\nfunction useExtensionPointContext(props: Props): PluginExtensionExploreContext {\n const { exploreId, timeZone } = props;\n const isCorrelationDetails = useSelector(selectCorrelationDetails);\n const isCorrelationsEditorMode = isCorrelationDetails?.editorMode || false;\n const { queries, queryResponse, range } = useSelector(getExploreItemSelector(exploreId))!;\n const isLeftPane = useSelector(isLeftPaneSelector(exploreId));\n\n const datasourceUids = queries.map((query) => query?.datasource?.uid).filter((uid) => uid !== undefined);\n const numUniqueIds = [...new Set(datasourceUids)].length;\n const canWriteCorrelations = contextSrv.hasPermission(AccessControlAction.DataSourcesWrite);\n\n return useMemo(() => {\n return {\n exploreId,\n targets: queries,\n data: queryResponse,\n timeRange: range.raw,\n timeZone: getTimeZone({ timeZone }),\n shouldShowAddCorrelation:\n config.featureToggles.correlations === true &&\n canWriteCorrelations &&\n !isCorrelationsEditorMode &&\n isLeftPane &&\n numUniqueIds === 1,\n };\n }, [\n exploreId,\n queries,\n queryResponse,\n range.raw,\n timeZone,\n canWriteCorrelations,\n isCorrelationsEditorMode,\n isLeftPane,\n numUniqueIds,\n ]);\n}\n","import { useCallback } from 'react';\nimport * as React from 'react';\n\nimport { RefreshPicker } from '@grafana/ui';\nimport { useDispatch } from 'app/types/store';\n\nimport { setPausedStateAction, runQueries, clearLogs } from './state/query';\nimport { changeRefreshInterval } from './state/time';\n\n/**\n * Hook that gives you all the functions needed to control the live tailing.\n */\nexport function useLiveTailControls(exploreId: string) {\n const dispatch = useDispatch();\n\n const pause = useCallback(() => {\n dispatch(setPausedStateAction({ exploreId, isPaused: true }));\n }, [exploreId, dispatch]);\n\n const resume = useCallback(() => {\n dispatch(setPausedStateAction({ exploreId, isPaused: false }));\n }, [exploreId, dispatch]);\n\n const stop = useCallback(() => {\n // We need to pause here first because there is transition where we are not live but live logs are still shown\n // to cross fade with the normal view. This will prevent reordering of the logs in the live view during the\n // transition.\n pause();\n\n // TODO referencing this from perspective of refresh picker when there is designated button for it now is not\n // great. Needs a bit of refactoring.\n dispatch(changeRefreshInterval({ exploreId, refreshInterval: RefreshPicker.offOption.value }));\n dispatch(runQueries({ exploreId }));\n }, [exploreId, dispatch, pause]);\n\n const start = useCallback(() => {\n dispatch(changeRefreshInterval({ exploreId, refreshInterval: RefreshPicker.liveOption.value }));\n }, [exploreId, dispatch]);\n\n const clear = useCallback(() => {\n dispatch(clearLogs({ exploreId }));\n }, [exploreId, dispatch]);\n\n return {\n pause,\n resume,\n stop,\n start,\n clear,\n };\n}\n\ntype Props = {\n exploreId: string;\n children: (controls: ReturnType<typeof useLiveTailControls>) => React.ReactElement;\n};\n\n/**\n * If you can't use the hook you can use this as a render prop pattern.\n */\nexport function LiveTailControls(props: Props) {\n const controls = useLiveTailControls(props.exploreId);\n return props.children(controls);\n}\n","import { css, cx } from '@emotion/css';\nimport { pick } from 'lodash';\nimport { useMemo } from 'react';\nimport { shallowEqual } from 'react-redux';\n\nimport { DataSourceInstanceSettings, RawTimeRange, GrafanaTheme2 } from '@grafana/data';\nimport { Components } from '@grafana/e2e-selectors';\nimport { Trans, t } from '@grafana/i18n';\nimport { reportInteraction } from '@grafana/runtime';\nimport {\n defaultIntervals,\n PageToolbar,\n RefreshPicker,\n SetInterval,\n ToolbarButton,\n ButtonGroup,\n useStyles2,\n Button,\n} from '@grafana/ui';\nimport { AppChromeUpdate } from 'app/core/components/AppChrome/AppChromeUpdate';\nimport { DataSourcePicker } from 'app/features/datasources/components/picker/DataSourcePicker';\nimport { CORRELATION_EDITOR_POST_CONFIRM_ACTION } from 'app/types/explore';\nimport { StoreState, useDispatch, useSelector } from 'app/types/store';\n\nimport { contextSrv } from '../../core/core';\nimport { updateFiscalYearStartMonthForSession, updateTimeZoneForSession } from '../profile/state/reducers';\nimport { getFiscalYearStartMonth, getTimeZone } from '../profile/state/selectors';\n\nimport { ExploreTimeControls } from './ExploreTimeControls';\nimport { LiveTailButton } from './LiveTailButton';\nimport { useQueriesDrawerContext } from './QueriesDrawer/QueriesDrawerContext';\nimport { ShortLinkButtonMenu } from './ShortLinkButtonMenu';\nimport { ToolbarExtensionPoint } from './extensions/ToolbarExtensionPoint';\nimport { changeDatasource } from './state/datasource';\nimport { changeCorrelationHelperData } from './state/explorePane';\nimport {\n splitClose,\n splitOpen,\n maximizePaneAction,\n evenPaneResizeAction,\n changeCorrelationEditorDetails,\n} from './state/main';\nimport { cancelQueries, runQueries, selectIsWaitingForData } from './state/query';\nimport { isLeftPaneSelector, isSplit, selectCorrelationDetails, selectPanesEntries } from './state/selectors';\nimport { syncTimes, changeRefreshInterval } from './state/time';\nimport { LiveTailControls } from './useLiveTailControls';\n\nconst getStyles = (theme: GrafanaTheme2, splitted: Boolean) => ({\n rotateIcon: css({\n '> div > svg': {\n transform: 'rotate(180deg)',\n },\n }),\n toolbarButton: css({\n display: 'flex',\n justifyContent: 'center',\n marginRight: theme.spacing(0.5),\n width: splitted && theme.spacing(6),\n }),\n});\n\ninterface Props {\n exploreId: string;\n onChangeTime: (range: RawTimeRange, changedByScanner?: boolean) => void;\n onContentOutlineToogle: () => void;\n isContentOutlineOpen: boolean;\n}\n\nexport function ExploreToolbar({ exploreId, onChangeTime, onContentOutlineToogle, isContentOutlineOpen }: Props) {\n const dispatch = useDispatch();\n const splitted = useSelector(isSplit);\n const styles = useStyles2(getStyles, splitted);\n\n const timeZone = useSelector((state: StoreState) => getTimeZone(state.user));\n const fiscalYearStartMonth = useSelector((state: StoreState) => getFiscalYearStartMonth(state.user));\n const { refreshInterval, datasourceInstance, range, isLive, isPaused, syncedTimes } = useSelector(\n (state: StoreState) => ({\n ...pick(state.explore.panes[exploreId]!, 'refreshInterval', 'datasourceInstance', 'range', 'isLive', 'isPaused'),\n syncedTimes: state.explore.syncedTimes,\n }),\n shallowEqual\n );\n const loading = useSelector(selectIsWaitingForData(exploreId));\n const isLargerPane = useSelector((state: StoreState) => state.explore.largerExploreId === exploreId);\n const showSmallTimePicker = useSelector((state) => splitted || state.explore.panes[exploreId]!.containerWidth < 1210);\n const showSmallDataSourcePicker = useSelector(\n (state) => state.explore.panes[exploreId]!.containerWidth < (splitted ? 700 : 800)\n );\n\n const panes = useSelector(selectPanesEntries);\n const correlationDetails = useSelector(selectCorrelationDetails);\n const isCorrelationsEditorMode = correlationDetails?.editorMode || false;\n const isLeftPane = useSelector(isLeftPaneSelector(exploreId));\n const { drawerOpened, setDrawerOpened } = useQueriesDrawerContext();\n\n const shouldRotateSplitIcon = useMemo(\n () => (isLeftPane && isLargerPane) || (!isLeftPane && !isLargerPane),\n [isLeftPane, isLargerPane]\n );\n\n const refreshPickerLabel = loading\n ? t('explore.toolbar.refresh-picker-cancel', 'Cancel')\n : t('explore.toolbar.refresh-picker-run', 'Run query');\n\n const onChangeDatasource = async (dsSettings: DataSourceInstanceSettings) => {\n if (!isCorrelationsEditorMode) {\n dispatch(changeDatasource({ exploreId, datasource: dsSettings.uid, options: { importQueries: true } }));\n } else {\n if (correlationDetails?.correlationDirty || correlationDetails?.queryEditorDirty) {\n // prompt will handle datasource change if needed\n dispatch(\n changeCorrelationEditorDetails({\n isExiting: true,\n postConfirmAction: {\n exploreId: exploreId,\n action: CORRELATION_EDITOR_POST_CONFIRM_ACTION.CHANGE_DATASOURCE,\n changeDatasourceUid: dsSettings.uid,\n isActionLeft: isLeftPane,\n },\n })\n );\n } else {\n // if the left pane is changing, clear helper data for right pane\n if (isLeftPane) {\n panes.forEach((pane) => {\n dispatch(\n changeCorrelationHelperData({\n exploreId: pane[0],\n correlationEditorHelperData: undefined,\n })\n );\n });\n }\n\n dispatch(changeDatasource({ exploreId, datasource: dsSettings.uid, options: { importQueries: true } }));\n }\n }\n };\n\n const onRunQuery = (loading = false) => {\n if (loading) {\n return dispatch(cancelQueries(exploreId));\n } else {\n return dispatch(runQueries({ exploreId }));\n }\n };\n\n const onChangeTimeZone = (timezone: string) => dispatch(updateTimeZoneForSession(timezone));\n\n const onOpenSplitView = () => {\n dispatch(splitOpen());\n reportInteraction('grafana_explore_split_view_opened', { origin: 'menu' });\n };\n\n const onCloseSplitView = () => {\n if (isCorrelationsEditorMode) {\n if (correlationDetails?.correlationDirty || correlationDetails?.queryEditorDirty) {\n // if dirty, prompt\n dispatch(\n changeCorrelationEditorDetails({\n isExiting: true,\n postConfirmAction: {\n exploreId: exploreId,\n action: CORRELATION_EDITOR_POST_CONFIRM_ACTION.CLOSE_PANE,\n isActionLeft: isLeftPane,\n },\n })\n );\n } else {\n // otherwise, clear helper data and close\n panes.forEach((pane) => {\n dispatch(\n changeCorrelationHelperData({\n exploreId: pane[0],\n correlationEditorHelperData: undefined,\n })\n );\n });\n dispatch(splitClose(exploreId));\n reportInteraction('grafana_explore_split_view_closed');\n }\n } else {\n dispatch(splitClose(exploreId));\n reportInteraction('grafana_explore_split_view_closed');\n }\n };\n\n const onClickResize = () => {\n if (isLargerPane) {\n dispatch(evenPaneResizeAction());\n } else {\n dispatch(maximizePaneAction({ exploreId }));\n }\n };\n\n const onChangeTimeSync = () => {\n dispatch(syncTimes(exploreId));\n };\n\n const onChangeFiscalYearStartMonth = (fiscalyearStartMonth: number) =>\n dispatch(updateFiscalYearStartMonthForSession(fiscalyearStartMonth));\n\n const onChangeRefreshInterval = (refreshInterval: string) => {\n dispatch(changeRefreshInterval({ exploreId, refreshInterval }));\n };\n\n const navBarActions = [\n <Button\n key=\"query-history\"\n size=\"sm\"\n variant={'secondary'}\n aria-label={t('explore.secondary-actions.query-history-button-aria-label', 'Query history')}\n onClick={() => setDrawerOpened(!drawerOpened)}\n data-testid={Components.QueryTab.queryHistoryButton}\n icon=\"history\"\n >\n <Trans i18nKey=\"explore.secondary-actions.query-history-button\">Query history</Trans>\n </Button>,\n <ShortLinkButtonMenu key=\"share\" />,\n ];\n\n return (\n <div>\n {refreshInterval && <SetInterval func={onRunQuery} interval={refreshInterval} loading={loading} />}\n <AppChromeUpdate actions={navBarActions} />\n <PageToolbar\n aria-label={t('explore.toolbar.aria-label', 'Explore toolbar')}\n leftItems={[\n <ToolbarButton\n key=\"content-outline\"\n variant=\"canvas\"\n tooltip={t('explore.explore-toolbar.tooltip-content-outline', 'Content outline')}\n icon=\"list-ui-alt\"\n iconOnly={splitted}\n onClick={onContentOutlineToogle}\n aria-expanded={isContentOutlineOpen}\n aria-controls={isContentOutlineOpen ? 'content-outline-container' : undefined}\n className={styles.toolbarButton}\n >\n <Trans i18nKey=\"explore.explore-toolbar.outline\">Outline</Trans>\n </ToolbarButton>,\n <DataSourcePicker\n key={`${exploreId}-ds-picker`}\n mixed={!isCorrelationsEditorMode}\n onChange={onChangeDatasource}\n current={datasourceInstance?.getRef()}\n hideTextValue={showSmallDataSourcePicker}\n width={showSmallDataSourcePicker ? 8 : undefined}\n />,\n <ToolbarExtensionPoint\n key=\"toolbar-extension-point\"\n exploreId={exploreId}\n timeZone={timeZone}\n extensionsToShow=\"queryless\"\n />,\n ].filter(Boolean)}\n forceShowLeftItems\n >\n {[\n !splitted ? (\n <ToolbarButton\n variant=\"canvas\"\n key=\"split\"\n tooltip={t('explore.toolbar.split-tooltip', 'Split the pane')}\n onClick={onOpenSplitView}\n icon=\"columns\"\n disabled={isLive}\n >\n <Trans i18nKey=\"explore.toolbar.split-title\">Split</Trans>\n </ToolbarButton>\n ) : (\n <ButtonGroup key=\"split-controls\">\n <ToolbarButton\n variant=\"canvas\"\n tooltip={\n isLargerPane\n ? t('explore.toolbar.split-narrow', 'Narrow pane')\n : t('explore.toolbar.split-widen', 'Widen pane')\n }\n onClick={onClickResize}\n icon={isLargerPane ? 'gf-movepane-left' : 'gf-movepane-right'}\n iconOnly={true}\n className={cx(shouldRotateSplitIcon && styles.rotateIcon)}\n />\n <ToolbarButton\n tooltip={t('explore.toolbar.split-close-tooltip', 'Close split pane')}\n onClick={onCloseSplitView}\n icon=\"times\"\n variant=\"canvas\"\n >\n <Trans i18nKey=\"explore.toolbar.split-close\"> Close </Trans>\n </ToolbarButton>\n </ButtonGroup>\n ),\n <ToolbarExtensionPoint\n key=\"toolbar-extension-point\"\n exploreId={exploreId}\n timeZone={timeZone}\n extensionsToShow=\"basic\"\n />,\n !isLive && (\n <ExploreTimeControls\n key=\"timeControls\"\n exploreId={exploreId}\n range={range}\n timeZone={timeZone}\n fiscalYearStartMonth={fiscalYearStartMonth}\n onChangeTime={onChangeTime}\n splitted={splitted}\n syncedTimes={syncedTimes}\n onChangeTimeSync={onChangeTimeSync}\n hideText={showSmallTimePicker}\n onChangeTimeZone={onChangeTimeZone}\n onChangeFiscalYearStartMonth={onChangeFiscalYearStartMonth}\n />\n ),\n <RefreshPicker\n key=\"refreshPicker\"\n onIntervalChanged={onChangeRefreshInterval}\n value={refreshInterval}\n isLoading={loading}\n text={showSmallTimePicker ? undefined : refreshPickerLabel}\n tooltip={showSmallTimePicker ? refreshPickerLabel : undefined}\n intervals={contextSrv.getValidIntervals(defaultIntervals)}\n isLive={isLive}\n onRefresh={() => onRunQuery(loading)}\n noIntervalPicker={isLive}\n primary={true}\n width={(showSmallTimePicker ? 35 : 108) + 'px'}\n />,\n datasourceInstance?.meta.streaming && (\n <LiveTailControls key=\"liveControls\" exploreId={exploreId}>\n {(c) => {\n const controls = {\n ...c,\n start: () => {\n reportInteraction('grafana_explore_logs_live_tailing_clicked', {\n datasourceType: datasourceInstance?.type,\n });\n c.start();\n },\n };\n return (\n <LiveTailButton\n splitted={splitted}\n isLive={isLive}\n isPaused={isPaused}\n start={controls.start}\n pause={controls.pause}\n resume={controls.resume}\n stop={controls.stop}\n />\n );\n }}\n </LiveTailControls>\n ),\n ].filter(Boolean)}\n </PageToolbar>\n </div>\n );\n}\n","import { css } from '@emotion/css';\n\nimport { DataFrame, GrafanaTheme2, CoreApp } from '@grafana/data';\nimport { FlameGraph } from '@grafana/flamegraph';\nimport { reportInteraction, config } from '@grafana/runtime';\nimport { useStyles2 } from '@grafana/ui';\n\ninterface Props {\n dataFrames: DataFrame[];\n}\n\nfunction interaction(name: string, context: Record<string, string | number> = {}) {\n reportInteraction(`grafana_flamegraph_${name}`, {\n app: CoreApp.Unknown,\n grafana_version: config.buildInfo.version,\n ...context,\n });\n}\n\nexport const FlameGraphExploreContainer = (props: Props) => {\n const styles = useStyles2((theme) => getStyles(theme));\n\n return (\n <div className={styles.container}>\n <FlameGraph\n data={props.dataFrames[0]}\n stickyHeader={true}\n getTheme={() => config.theme2}\n onTableSymbolClick={() => interaction('table_item_selected')}\n onViewSelected={(view: string) => interaction('view_selected', { view })}\n onTextAlignSelected={(align: string) => interaction('text_align_selected', { align })}\n onTableSort={(sort: string) => interaction('table_sort_selected', { sort })}\n />\n </div>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n container: css({\n background: theme.colors.background.primary,\n display: 'flow-root',\n padding: theme.spacing(0, 1, 1, 1),\n border: `1px solid ${theme.components.panel.borderColor}`,\n borderRadius: theme.shape.radius.default,\n }),\n});\n","import { useState, useEffect } from 'react';\nimport { useInterval } from 'react-use';\n\nimport { Time, TimeProps } from './Time';\n\nconst INTERVAL = 150;\n\nexport interface ElapsedTimeProps extends Omit<TimeProps, 'timeInMs'> {\n // Use this to reset the timer. Any value is allowed just need to be !== from the previous.\n // Keep in mind things like [] !== [] or {} !== {}.\n resetKey?: unknown;\n}\n\nexport const ElapsedTime = ({ resetKey, humanize, className }: ElapsedTimeProps) => {\n const [elapsed, setElapsed] = useState(0); // the current value of elapsed\n\n // hook that will schedule a interval and then update the elapsed value on every tick.\n useInterval(() => setElapsed(elapsed + INTERVAL), INTERVAL);\n // this effect will only be run when resetKey changes. This will reset the elapsed to 0.\n useEffect(() => setElapsed(0), [resetKey]);\n\n return <Time timeInMs={elapsed} className={className} humanize={humanize} />;\n};\n","import { css, cx, keyframes } from '@emotion/css';\nimport { PureComponent } from 'react';\nimport * as React from 'react';\nimport tinycolor from 'tinycolor2';\n\nimport { LogRowModel, dateTimeFormat, GrafanaTheme2, LogsSortOrder } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { TimeZone } from '@grafana/schema';\nimport { Button, Themeable2, withTheme2 } from '@grafana/ui';\n\nimport { LogMessageAnsi } from '../../logs/components/LogMessageAnsi';\nimport { getLogRowStyles } from '../../logs/components/getLogRowStyles';\nimport { sortLogRows } from '../../logs/utils';\nimport { ElapsedTime } from '../ElapsedTime';\nimport { filterLogRowsByIndex } from '../state/utils';\n\nconst getStyles = (theme: GrafanaTheme2) => {\n const fade = keyframes({\n from: {\n backgroundColor: tinycolor(theme.colors.info.transparent).setAlpha(0.25).toString(),\n },\n to: {\n backgroundColor: 'transparent',\n },\n });\n\n return {\n logsRowsLive: css({\n label: 'logs-rows-live',\n fontFamily: theme.typography.fontFamilyMonospace,\n fontSize: theme.typography.bodySmall.fontSize,\n display: 'flex',\n flexFlow: 'column nowrap',\n height: '60vh',\n overflowY: 'scroll',\n ':first-child': {\n marginTop: 'auto !important',\n },\n }),\n logsRowFade: css({\n label: 'logs-row-fresh',\n color: theme.colors.text.primary,\n backgroundColor: tinycolor(theme.colors.info.transparent).setAlpha(0.25).toString(),\n [theme.transitions.handleMotion('no-preference', 'reduce')]: {\n animation: `${fade} 1s ease-out 1s 1 normal forwards`,\n },\n }),\n logsRowsIndicator: css({\n fontSize: theme.typography.h6.fontSize,\n paddingTop: theme.spacing(1),\n display: 'flex',\n alignItems: 'center',\n }),\n button: css({\n marginRight: theme.spacing(1),\n }),\n fullWidth: css({\n width: '100%',\n }),\n };\n};\n\nexport interface Props extends Themeable2 {\n logRows?: LogRowModel[];\n timeZone: TimeZone;\n stopLive: () => void;\n onPause: () => void;\n onResume: () => void;\n onClear: () => void;\n clearedAtIndex: number | null;\n isPaused: boolean;\n}\n\ninterface State {\n logRowsToRender?: LogRowModel[];\n}\n\nclass LiveLogs extends PureComponent<Props, State> {\n private liveEndDiv: HTMLDivElement | null = null;\n private scrollContainerRef = React.createRef<HTMLTableSectionElement>();\n\n constructor(props: Props) {\n super(props);\n this.state = {\n logRowsToRender: props.logRows,\n };\n }\n\n static getDerivedStateFromProps(nextProps: Props, state: State) {\n if (nextProps.isPaused && nextProps.clearedAtIndex) {\n return {\n logRowsToRender: filterLogRowsByIndex(nextProps.clearedAtIndex, state.logRowsToRender),\n };\n }\n\n if (nextProps.isPaused) {\n return null;\n }\n\n return {\n // We update what we show only if not paused. We keep any background subscriptions running and keep updating\n // our state, but we do not show the updates, this allows us start again showing correct result after resuming\n // without creating a gap in the log results.\n logRowsToRender: nextProps.logRows,\n };\n }\n\n /**\n * Handle pausing when user scrolls up so that we stop resetting his position to the bottom when new row arrives.\n * We do not need to throttle it here much, adding new rows should be throttled/buffered itself in the query epics\n * and after you pause we remove the handler and add it after you manually resume, so this should not be fired often.\n */\n onScroll = (event: React.SyntheticEvent) => {\n const { isPaused, onPause } = this.props;\n const { scrollTop, clientHeight, scrollHeight } = event.currentTarget;\n const distanceFromBottom = scrollHeight - (scrollTop + clientHeight);\n if (distanceFromBottom >= 5 && !isPaused) {\n onPause();\n }\n };\n\n rowsToRender = () => {\n const { isPaused } = this.props;\n let { logRowsToRender: rowsToRender = [] } = this.state;\n if (!isPaused) {\n // A perf optimisation here. Show just 100 rows when streaming and full length when the streaming is paused.\n rowsToRender = sortLogRows(rowsToRender, LogsSortOrder.Ascending).slice(-100);\n }\n return rowsToRender;\n };\n\n render() {\n const { theme, timeZone, onPause, onResume, onClear, isPaused } = this.props;\n const styles = getStyles(theme);\n const { logsRow, logsRowLocalTime, logsRowMessage } = getLogRowStyles(theme);\n\n return (\n <div>\n <table className={styles.fullWidth}>\n <tbody\n onScroll={isPaused ? undefined : this.onScroll}\n className={styles.logsRowsLive}\n ref={this.scrollContainerRef}\n >\n {this.rowsToRender().map((row: LogRowModel) => {\n return (\n <tr className={cx(logsRow, styles.logsRowFade)} key={row.uid}>\n <td className={logsRowLocalTime}>{dateTimeFormat(row.timeEpochMs, { timeZone })}</td>\n <td className={logsRowMessage}>{row.hasAnsi ? <LogMessageAnsi value={row.raw} /> : row.entry}</td>\n </tr>\n );\n })}\n <tr\n ref={(element) => {\n this.liveEndDiv = element;\n // This is triggered on every update so on every new row. It keeps the view scrolled at the bottom by\n // default.\n // As scrollTo is not implemented in JSDOM it needs to be part of the condition\n if (this.liveEndDiv && this.scrollContainerRef.current?.scrollTo && !isPaused) {\n this.scrollContainerRef.current?.scrollTo(0, this.scrollContainerRef.current.scrollHeight);\n }\n }}\n />\n </tbody>\n </table>\n <div className={styles.logsRowsIndicator}>\n <Button\n icon={isPaused ? 'play' : 'pause'}\n variant=\"secondary\"\n onClick={isPaused ? onResume : onPause}\n className={styles.button}\n >\n {isPaused ? t('explore.live-logs.resume', 'Resume') : t('explore.live-logs.pause', 'Pause')}\n </Button>\n <Button icon=\"trash-alt\" variant=\"secondary\" onClick={onClear} className={styles.button}>\n <Trans i18nKey=\"explore.live-logs.clear-logs\">Clear logs</Trans>\n </Button>\n <Button icon=\"square-shape\" variant=\"secondary\" onClick={this.props.stopLive} className={styles.button}>\n <Trans i18nKey=\"explore.live-logs.exit-live-mode\">Exit live mode</Trans>\n </Button>\n {isPaused ||\n (this.rowsToRender().length > 0 && (\n <span>\n <Trans\n i18nKey=\"explore.live-logs.last-line-received\"\n components={{ elapsedTime: <ElapsedTime resetKey={this.props.logRows} humanize={true} /> }}\n >\n Last line received: {'<elapsedTime />'} ago\n </Trans>\n </span>\n ))}\n </div>\n </div>\n );\n }\n}\n\nexport const LiveLogsWithTheme = withTheme2(LiveLogs);\n","import { LogLevel } from '@grafana/data';\nimport { reportInteraction } from '@grafana/runtime';\n\nexport function contentOutlineTrackPinAdded() {\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'section',\n type: 'Logs:pinned:pinned-log-added',\n });\n}\n\nexport function contentOutlineTrackPinRemoved() {\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'section',\n type: 'Logs:pinned:pinned-log-deleted',\n });\n}\n\nexport function contentOutlineTrackPinLimitReached() {\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'section',\n type: 'Logs:pinned:pinned-log-limit-reached',\n });\n}\n\nexport function contentOutlineTrackPinClicked() {\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'section',\n type: 'Logs:pinned:pinned-log-clicked',\n });\n}\n\nexport function contentOutlineTrackUnpinClicked() {\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'section',\n type: 'Logs:pinned:pinned-log-deleted',\n });\n}\n\nexport function contentOutlineTrackLevelFilter(level: LogLevel) {\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'section',\n type: `Logs:filter:${level}`,\n });\n}\n","import { Trans } from '@grafana/i18n';\nimport { Stack, TextLink } from '@grafana/ui';\n\ninterface Props {\n feedbackUrl: string;\n}\n\nexport function LogsFeedback({ feedbackUrl }: Props) {\n return (\n <Stack>\n <TextLink href={feedbackUrl} external>\n <Trans i18nKey=\"explore.logs-feedback.give-feedback\">Give feedback</Trans>\n </TextLink>\n </Stack>\n );\n}\n","import { css } from '@emotion/css';\nimport { memo } from 'react';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { useStyles2 } from '@grafana/ui';\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n metaContainer: css({\n flex: 1,\n color: theme.colors.text.secondary,\n marginBottom: theme.spacing(2),\n minWidth: '30%',\n display: 'flex',\n flexWrap: 'wrap',\n }),\n metaItem: css({\n marginRight: theme.spacing(2),\n marginTop: theme.spacing(0.5),\n display: 'flex',\n alignItems: 'center',\n ['.logs-meta-item__error']: {\n color: theme.colors.error.text,\n },\n }),\n metaLabel: css({\n marginRight: `calc(${theme.spacing(2)} / 2)`,\n fontSize: theme.typography.bodySmall.fontSize,\n fontWeight: theme.typography.fontWeightMedium,\n whiteSpace: 'nowrap',\n }),\n metaValue: css({\n fontFamily: theme.typography.fontFamilyMonospace,\n fontSize: theme.typography.bodySmall.fontSize,\n }),\n});\n\nexport interface MetaItemProps {\n label?: string;\n value: string | JSX.Element;\n}\n\nconst MetaInfoItem = memo(function MetaInfoItem(props: MetaItemProps) {\n const style = useStyles2(getStyles);\n const { label, value } = props;\n\n return (\n <div data-testid=\"meta-info-text-item\" className={style.metaItem}>\n {label && <span className={style.metaLabel}>{label}:</span>}\n <span className={style.metaValue}>{value}</span>\n </div>\n );\n});\n\ninterface MetaInfoTextProps {\n metaItems: MetaItemProps[];\n}\n\nexport const MetaInfoText = memo(function MetaInfoText(props: MetaInfoTextProps) {\n const style = useStyles2(getStyles);\n const { metaItems } = props;\n\n return (\n <div className={style.metaContainer} data-testid=\"meta-info-text\">\n {metaItems.map((item, index) => (\n <MetaInfoItem key={`${index}-${item.label}`} label={item.label} value={item.value} />\n ))}\n </div>\n );\n});\n","import { css } from '@emotion/css';\nimport { memo } from 'react';\n\nimport {\n LogsDedupStrategy,\n LogsMetaItem,\n LogsMetaKind,\n LogRowModel,\n CoreApp,\n Labels,\n store,\n shallowCompare,\n} from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, reportInteraction } from '@grafana/runtime';\nimport { Button, Dropdown, Menu, ToolbarButton, useStyles2 } from '@grafana/ui';\n\nimport { LogLabels, LogLabelsList, Props as LogLabelsProps } from '../../logs/components/LogLabels';\nimport { DownloadFormat, downloadLogs } from '../../logs/utils';\nimport { MetaInfoText, MetaItemProps } from '../MetaInfoText';\n\nimport { LogsVisualisationType } from './Logs';\nimport { SETTINGS_KEYS } from './utils/logs';\n\nconst getStyles = () => ({\n metaContainer: css({\n flex: 1,\n display: 'flex',\n flexWrap: 'wrap',\n '& span': {\n fontWeight: 'normal',\n lineHeight: '1.25em',\n },\n }),\n});\n\nexport type Props = {\n meta: LogsMetaItem[];\n dedupStrategy: LogsDedupStrategy;\n dedupCount: number;\n displayedFields: string[];\n logRows: LogRowModel[];\n clearDisplayedFields: () => void;\n defaultDisplayedFields: string[];\n visualisationType: LogsVisualisationType;\n};\n\nexport const LogsMetaRow = memo(\n ({\n meta,\n dedupStrategy,\n dedupCount,\n displayedFields,\n clearDisplayedFields,\n logRows,\n defaultDisplayedFields,\n visualisationType,\n }: Props) => {\n const style = useStyles2(getStyles);\n\n const logsMetaItem: Array<LogsMetaItem | MetaItemProps> = [...meta];\n\n // Add deduplication info\n if (dedupStrategy !== LogsDedupStrategy.none) {\n logsMetaItem.push({\n label: t('explore.logs-meta-row.label.deduplication-count', 'Deduplication count'),\n value: dedupCount,\n kind: LogsMetaKind.Number,\n });\n }\n\n // Add detected fields info\n if (\n visualisationType === 'logs' &&\n displayedFields?.length > 0 &&\n shallowCompare(displayedFields, defaultDisplayedFields) === false\n ) {\n logsMetaItem.push(\n {\n label: t('explore.logs-meta-row.label.showing-only-selected-fields', 'Showing only selected fields'),\n value: <LogLabelsList labels={displayedFields} />,\n },\n {\n label: '',\n value: (\n <Button variant=\"primary\" fill=\"outline\" size=\"sm\" onClick={clearDisplayedFields}>\n {t('explore.logs-meta-row.show-original-line', 'Show original line')}\n </Button>\n ),\n }\n );\n }\n\n function download(format: DownloadFormat) {\n reportInteraction('grafana_logs_download_logs_clicked', {\n app: CoreApp.Explore,\n format,\n area: 'logs-meta-row',\n });\n downloadLogs(format, logRows, meta);\n }\n\n const downloadMenu = (\n <Menu>\n {/* eslint-disable-next-line @grafana/i18n/no-untranslated-strings */}\n <Menu.Item label=\"txt\" onClick={() => download(DownloadFormat.Text)} />\n {/* eslint-disable-next-line @grafana/i18n/no-untranslated-strings */}\n <Menu.Item label=\"json\" onClick={() => download(DownloadFormat.Json)} />\n {/* eslint-disable-next-line @grafana/i18n/no-untranslated-strings */}\n <Menu.Item label=\"csv\" onClick={() => download(DownloadFormat.CSV)} />\n </Menu>\n );\n\n const onCommonLabelsToggle = (state: boolean) => {\n store.set(SETTINGS_KEYS.commonLabels, state);\n };\n\n const commonLabelsProps = {\n onDisplayMaxToggle: onCommonLabelsToggle,\n displayMax: 3,\n displayAll: store.getBool(SETTINGS_KEYS.commonLabels, false),\n };\n\n return (\n <>\n {logsMetaItem && (\n <div className={style.metaContainer}>\n <MetaInfoText\n metaItems={logsMetaItem.map((item) => {\n return {\n label: item.label,\n value: 'kind' in item ? renderMetaItem(item.value, item.kind, commonLabelsProps) : item.value,\n };\n })}\n />\n {!config.featureToggles.logsPanelControls &&\n !config.featureToggles.newLogsPanel &&\n !config.exploreHideLogsDownload && (\n <Dropdown overlay={downloadMenu}>\n <ToolbarButton isOpen={false} variant=\"canvas\" icon=\"download-alt\">\n <Trans i18nKey=\"explore.logs-meta-row.download\">Download</Trans>\n </ToolbarButton>\n </Dropdown>\n )}\n </div>\n )}\n </>\n );\n }\n);\n\nLogsMetaRow.displayName = 'LogsMetaRow';\n\nfunction renderMetaItem(value: string | number | Labels, kind: LogsMetaKind, logLabelsProps: Partial<LogLabelsProps>) {\n if (typeof value === 'string' || typeof value === 'number') {\n return <>{value}</>;\n }\n if (kind === LogsMetaKind.LabelsMap) {\n return <LogLabels labels={value} {...logLabelsProps} />;\n }\n if (kind === LogsMetaKind.Error) {\n return <span className=\"logs-meta-item__error\">{value.toString()}</span>;\n }\n console.error(`Meta type ${typeof value} ${value} not recognized.`);\n return <></>;\n}\n","import { css, cx } from '@emotion/css';\n\nimport { dateTimeFormat, systemDateFormats, GrafanaTheme2 } from '@grafana/data';\nimport { TimeZone } from '@grafana/schema';\nimport { ScrollContainer, Spinner, useTheme2, clearButtonStyles } from '@grafana/ui';\n\nimport { LogsPage } from './LogsNavigation';\n\ntype Props = {\n pages: LogsPage[];\n currentPageIndex: number;\n oldestLogsFirst: boolean;\n timeZone: TimeZone;\n loading: boolean;\n onClick: (page: LogsPage, pageNumber: number) => void;\n};\n\nexport function LogsNavigationPages({ pages, currentPageIndex, oldestLogsFirst, timeZone, loading, onClick }: Props) {\n const formatTime = (time: number) => {\n return `${dateTimeFormat(time, {\n format: systemDateFormats.interval.second,\n timeZone: timeZone,\n })}`;\n };\n\n const createPageContent = (page: LogsPage, index: number) => {\n if (currentPageIndex === index && loading) {\n return <Spinner />;\n }\n const topContent = formatTime(oldestLogsFirst ? page.logsRange.from : page.logsRange.to);\n const bottomContent = formatTime(oldestLogsFirst ? page.logsRange.to : page.logsRange.from);\n return `${topContent} — ${bottomContent}`;\n };\n\n const theme = useTheme2();\n const styles = getStyles(theme, loading);\n\n return (\n <ScrollContainer>\n <div className={styles.pagesWrapper} data-testid=\"logsNavigationPages\">\n <div className={styles.pagesContainer}>\n {pages.map((page: LogsPage, index: number) => (\n <button\n type=\"button\"\n data-testid={`page${index + 1}`}\n className={cx(clearButtonStyles(theme), styles.page)}\n key={page.queryRange.to}\n onClick={() => {\n onClick(page, index + 1);\n }}\n disabled={loading}\n >\n <div className={cx(styles.line, { selectedBg: currentPageIndex === index })} />\n <div className={cx(styles.time, { selectedText: currentPageIndex === index })}>\n {createPageContent(page, index)}\n </div>\n </button>\n ))}\n </div>\n </div>\n </ScrollContainer>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2, loading: boolean) => {\n return {\n pagesWrapper: css({\n height: '100%',\n paddingLeft: theme.spacing(0.5),\n display: 'flex',\n flexDirection: 'column',\n '&::after': {\n content: \"''\",\n display: 'block',\n background: `repeating-linear-gradient(135deg, ${theme.colors.background.primary}, ${theme.colors.background.primary} 5px, ${theme.colors.background.secondary} 5px, ${theme.colors.background.secondary} 15px)`,\n width: '3px',\n height: 'inherit',\n marginBottom: theme.spacing(1),\n },\n }),\n pagesContainer: css({\n display: 'flex',\n padding: 0,\n flexDirection: 'column',\n }),\n page: css({\n display: 'flex',\n margin: theme.spacing(2, 0),\n cursor: loading ? 'auto' : 'pointer',\n whiteSpace: 'normal',\n '.selectedBg': {\n background: theme.colors.primary.main,\n },\n '.selectedText': {\n color: theme.colors.primary.main,\n },\n }),\n line: css({\n width: '3px',\n height: '100%',\n alignItems: 'center',\n background: theme.colors.text.secondary,\n }),\n time: css({\n width: '60px',\n minHeight: '80px',\n fontSize: theme.v1.typography.size.sm,\n paddingLeft: theme.spacing(0.5),\n display: 'flex',\n alignItems: 'center',\n }),\n };\n};\n","import { css } from '@emotion/css';\nimport { isEqual } from 'lodash';\nimport { memo, useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { AbsoluteTimeRange, GrafanaTheme2, LogsSortOrder } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, reportInteraction } from '@grafana/runtime';\nimport { DataQuery, TimeZone } from '@grafana/schema';\nimport { Button, Icon, Spinner, useTheme2 } from '@grafana/ui';\nimport { getChromeHeaderLevelHeight } from 'app/core/components/AppChrome/TopBar/useChromeHeaderHeight';\n\nimport { LogsNavigationPages } from './LogsNavigationPages';\n\ntype Props = {\n absoluteRange: AbsoluteTimeRange;\n timeZone: TimeZone;\n queries: DataQuery[];\n loading: boolean;\n visibleRange: AbsoluteTimeRange;\n logsSortOrder?: LogsSortOrder | null;\n onChangeTime: (range: AbsoluteTimeRange) => void;\n scrollToTopLogs: () => void;\n scrollToBottomLogs?: () => void;\n addResultsToCache: () => void;\n clearCache: () => void;\n};\n\nexport type LogsPage = {\n logsRange: AbsoluteTimeRange;\n queryRange: AbsoluteTimeRange;\n};\n\nfunction LogsNavigation({\n absoluteRange,\n logsSortOrder,\n timeZone,\n loading,\n onChangeTime,\n scrollToTopLogs,\n scrollToBottomLogs,\n visibleRange,\n queries,\n clearCache,\n addResultsToCache,\n}: Props) {\n const [pages, setPages] = useState<LogsPage[]>([]);\n\n // These refs are to determine, if we want to clear up logs navigation when totally new query is run\n const expectedQueriesRef = useRef<DataQuery[]>();\n const expectedRangeRef = useRef<AbsoluteTimeRange>();\n // This ref is to store range span for future queres based on firstly selected time range\n // e.g. if last 5 min selected, always run 5 min range\n const rangeSpanRef = useRef(0);\n\n const currentPageIndex = useMemo(\n () =>\n pages.findIndex((page) => {\n return page.queryRange.to === absoluteRange.to;\n }),\n [absoluteRange.to, pages]\n );\n\n const oldestLogsFirst = logsSortOrder === LogsSortOrder.Ascending;\n const onFirstPage = oldestLogsFirst ? currentPageIndex === pages.length - 1 : currentPageIndex === 0;\n const onLastPage = oldestLogsFirst ? currentPageIndex === 0 : currentPageIndex === pages.length - 1;\n const theme = useTheme2();\n const styles = getStyles(theme, oldestLogsFirst);\n\n // Main effect to set pages and index\n useEffect(() => {\n const newPage = { logsRange: visibleRange, queryRange: absoluteRange };\n let newPages: LogsPage[] = [];\n // We want to start new pagination if queries change or if absolute range is different than expected\n if (!isEqual(expectedRangeRef.current, absoluteRange) || !isEqual(expectedQueriesRef.current, queries)) {\n clearCache();\n setPages([newPage]);\n expectedQueriesRef.current = queries;\n rangeSpanRef.current = absoluteRange.to - absoluteRange.from;\n } else {\n setPages((pages) => {\n // Remove duplicates with new query\n newPages = pages.filter((page) => !isEqual(newPage.queryRange, page.queryRange));\n // Sort pages based on logsOrder so they visually align with displayed logs\n newPages = [...newPages, newPage].sort((a, b) => sortPages(a, b, logsSortOrder));\n return newPages;\n });\n }\n }, [visibleRange, absoluteRange, logsSortOrder, queries, clearCache, addResultsToCache]);\n\n const changeTime = useCallback(\n ({ from, to }: AbsoluteTimeRange) => {\n addResultsToCache();\n expectedRangeRef.current = { from, to };\n onChangeTime({ from, to });\n },\n [onChangeTime, addResultsToCache]\n );\n\n const sortPages = (a: LogsPage, b: LogsPage, logsSortOrder?: LogsSortOrder | null) => {\n if (logsSortOrder === LogsSortOrder.Ascending) {\n return a.queryRange.to > b.queryRange.to ? 1 : -1;\n }\n return a.queryRange.to > b.queryRange.to ? -1 : 1;\n };\n\n const olderLogsButton = (\n <Button\n data-testid=\"olderLogsButton\"\n className={styles.navButton}\n variant=\"secondary\"\n onClick={() => {\n //If we are not on the last page, use next page's range\n reportInteraction('grafana_explore_logs_pagination_clicked', {\n pageType: 'olderLogsButton',\n });\n if (!onLastPage) {\n const indexChange = oldestLogsFirst ? -1 : 1;\n changeTime({\n from: pages[currentPageIndex + indexChange].queryRange.from,\n to: pages[currentPageIndex + indexChange].queryRange.to,\n });\n } else {\n //If we are on the last page, create new range\n changeTime({ from: visibleRange.from - rangeSpanRef.current, to: visibleRange.from });\n }\n scrollToTopLogs();\n }}\n disabled={loading}\n >\n <div className={styles.navButtonContent}>\n {loading ? <Spinner /> : <Icon name={oldestLogsFirst ? 'angle-up' : 'angle-down'} size=\"lg\" />}\n <Trans i18nKey={'logs.logs-navigation.older-logs'}>Older logs</Trans>\n </div>\n </Button>\n );\n\n const newerLogsButton = (\n <Button\n data-testid=\"newerLogsButton\"\n className={styles.navButton}\n variant=\"secondary\"\n onClick={() => {\n reportInteraction('grafana_explore_logs_pagination_clicked', {\n pageType: 'newerLogsButton',\n });\n //If we are not on the first page, use previous page's range\n if (!onFirstPage) {\n const indexChange = oldestLogsFirst ? 1 : -1;\n changeTime({\n from: pages[currentPageIndex + indexChange].queryRange.from,\n to: pages[currentPageIndex + indexChange].queryRange.to,\n });\n }\n scrollToTopLogs();\n //If we are on the first page, button is disabled and we do nothing\n }}\n disabled={loading || onFirstPage}\n >\n <div className={styles.navButtonContent}>\n {loading && <Spinner />}\n {onFirstPage || loading ? null : <Icon name={oldestLogsFirst ? 'angle-down' : 'angle-up'} size=\"lg\" />}\n {onFirstPage\n ? t('logs.logs-navigation.start-of-range', 'Start of range')\n : t('logs.logs-navigation.newer-logs', 'Newer logs')}\n </div>\n </Button>\n );\n\n const onPageClick = useCallback(\n (page: LogsPage, pageNumber: number) => {\n reportInteraction('grafana_explore_logs_pagination_clicked', {\n pageType: 'page',\n pageNumber,\n });\n changeTime({ from: page.queryRange.from, to: page.queryRange.to });\n scrollToTopLogs();\n },\n [changeTime, scrollToTopLogs]\n );\n\n const onScrollToTopClick = useCallback(() => {\n reportInteraction('grafana_explore_logs_scroll_top_clicked');\n scrollToTopLogs();\n }, [scrollToTopLogs]);\n\n const onScrollToBottomClick = useCallback(() => {\n reportInteraction('grafana_explore_logs_scroll_bottom_clicked');\n scrollToBottomLogs?.();\n }, [scrollToBottomLogs]);\n\n return (\n <div className={styles.navContainer}>\n {!config.featureToggles.logsInfiniteScrolling && (\n <>\n {oldestLogsFirst ? olderLogsButton : newerLogsButton}\n <LogsNavigationPages\n pages={pages}\n currentPageIndex={currentPageIndex}\n oldestLogsFirst={oldestLogsFirst}\n timeZone={timeZone}\n loading={loading}\n onClick={onPageClick}\n />\n {oldestLogsFirst ? newerLogsButton : olderLogsButton}\n </>\n )}\n {scrollToBottomLogs && (\n <Button\n data-testid=\"scrollToBottom\"\n className={styles.scrollToBottomButton}\n variant=\"secondary\"\n onClick={onScrollToBottomClick}\n title={t('logs.logs-navigation.scroll-bottom', 'Scroll to bottom')}\n >\n <Icon name=\"arrow-down\" size=\"lg\" />\n </Button>\n )}\n <Button\n data-testid=\"scrollToTop\"\n className={styles.scrollToTopButton}\n variant=\"secondary\"\n onClick={onScrollToTopClick}\n title={t('logs.logs-navigation.scroll-top', 'Scroll to top')}\n >\n <Icon name=\"arrow-up\" size=\"lg\" />\n </Button>\n </div>\n );\n}\n\nexport default memo(LogsNavigation);\n\nconst getStyles = (theme: GrafanaTheme2, oldestLogsFirst: boolean) => {\n const navContainerHeight = `calc(100vh - 2*${theme.spacing(2)} - 2*${getChromeHeaderLevelHeight()}px)`;\n\n return {\n navContainer: css({\n maxHeight: navContainerHeight,\n width: oldestLogsFirst && !config.featureToggles.newLogsPanel ? '58px' : 'auto',\n display: 'flex',\n flexDirection: 'column',\n justifyContent: config.featureToggles.logsInfiniteScrolling\n ? 'flex-end'\n : oldestLogsFirst\n ? 'flex-start'\n : 'space-between',\n position: 'sticky',\n top: theme.spacing(2),\n right: 0,\n }),\n navButton: css({\n width: '58px',\n height: '68px',\n display: 'flex',\n flexDirection: 'column',\n justifyContent: 'center',\n alignItems: 'center',\n lineHeight: 1,\n }),\n navButtonContent: css({\n display: 'flex',\n flexDirection: 'column',\n justifyContent: 'center',\n alignItems: 'center',\n width: '100%',\n height: '100%',\n whiteSpace: 'normal',\n }),\n scrollToBottomButton: css({\n width: '40px',\n height: '40px',\n display: 'flex',\n flexDirection: 'column',\n justifyContent: 'center',\n alignItems: 'center',\n position: 'absolute',\n top: 0,\n }),\n scrollToTopButton: css({\n width: '40px',\n height: '40px',\n display: 'flex',\n flexDirection: 'column',\n justifyContent: 'center',\n alignItems: 'center',\n marginTop: theme.spacing(1),\n }),\n };\n};\n","import { css } from '@emotion/css';\nimport { ReactNode, useCallback, useState } from 'react';\n\nimport { DataQueryError, GrafanaTheme2 } from '@grafana/data';\nimport { Trans } from '@grafana/i18n';\nimport { Alert, AlertVariant, Button, useTheme2 } from '@grafana/ui';\n\ntype Props = {\n error?: DataQueryError;\n message?: ReactNode;\n title: string;\n severity?: AlertVariant;\n suggestedAction?: string;\n onSuggestedAction?(): void;\n onRemove?(): void;\n dismissable?: boolean;\n};\nconst SHORT_ERROR_MESSAGE_LIMIT = 100;\nexport function SupplementaryResultError(props: Props) {\n const [isOpen, setIsOpen] = useState(false);\n const [dismissed, setDismissed] = useState(false);\n\n const { dismissable, error, title, suggestedAction, onSuggestedAction, onRemove, severity = 'warning' } = props;\n // generic get-error-message-logic, taken from\n // /public/app/features/explore/ErrorContainer.tsx\n const message = props.message ?? error?.message ?? error?.data?.message ?? '';\n const showButton = typeof message === 'string' && message.length > SHORT_ERROR_MESSAGE_LIMIT;\n const theme = useTheme2();\n const styles = getStyles(theme);\n\n const dismiss = useCallback(() => {\n setDismissed(true);\n }, []);\n\n const handleRemove = dismissable ? dismiss : onRemove;\n\n if (dismissed) {\n return null;\n }\n\n return (\n <div className={styles.supplementaryErrorContainer}>\n <Alert title={title} severity={severity} onRemove={handleRemove}>\n {showButton ? (\n <div className={styles.messageWrapper}>\n {!isOpen ? (\n <Button\n variant=\"secondary\"\n size=\"xs\"\n onClick={() => {\n setIsOpen(true);\n }}\n >\n <Trans i18nKey=\"explore.supplementary-result-error.show-details\">Show details</Trans>\n </Button>\n ) : (\n message\n )}\n </div>\n ) : (\n <div className={`${styles.messageWrapper} ${styles.suggestedActionWrapper}`}>\n {message}\n {suggestedAction && onSuggestedAction && (\n <Button variant=\"primary\" size=\"xs\" onClick={onSuggestedAction}>\n {suggestedAction}\n </Button>\n )}\n </div>\n )}\n </Alert>\n </div>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n supplementaryErrorContainer: css({\n width: '60%',\n minWidth: `${theme.breakpoints.values.sm}px`,\n maxWidth: `${theme.breakpoints.values.md}px`,\n margin: '0 auto',\n }),\n messageWrapper: css({\n minHeight: theme.spacing(3),\n ['ul']: {\n paddingLeft: theme.spacing(2),\n },\n ['button']: {\n position: 'absolute',\n bottom: theme.spacing(2),\n right: theme.spacing(2),\n },\n }),\n suggestedActionWrapper: css({\n paddingBottom: theme.spacing(5),\n }),\n };\n};\n","import { css } from '@emotion/css';\nimport { identity } from 'lodash';\nimport * as React from 'react';\n\nimport {\n AbsoluteTimeRange,\n DataQueryResponse,\n LoadingState,\n SplitOpen,\n EventBus,\n GrafanaTheme2,\n DataFrame,\n TimeRange,\n} from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { TimeZone } from '@grafana/schema';\nimport { Icon, SeriesVisibilityChangeMode, Tooltip, TooltipDisplayMode, useStyles2, useTheme2 } from '@grafana/ui';\n\nimport { getLogsVolumeDataSourceInfo, isLogsVolumeLimited } from '../../logs/utils';\nimport { ExploreGraph } from '../Graph/ExploreGraph';\n\ntype Props = {\n logsVolumeData: DataQueryResponse;\n allLogsVolumeMaximum: number;\n timeRange: TimeRange;\n timeZone: TimeZone;\n splitOpen: SplitOpen;\n width: number;\n onUpdateTimeRange: (timeRange: AbsoluteTimeRange) => void;\n onLoadLogsVolume: () => void;\n onHiddenSeriesChanged: (hiddenSeries: string[]) => void;\n eventBus: EventBus;\n annotations: DataFrame[];\n toggleLegendRef?:\n | React.MutableRefObject<(name: string | undefined, mode: SeriesVisibilityChangeMode) => void>\n | undefined;\n};\n\nexport function LogsVolumePanel(props: Props) {\n const {\n width,\n timeZone,\n splitOpen,\n onUpdateTimeRange,\n onHiddenSeriesChanged,\n allLogsVolumeMaximum,\n toggleLegendRef,\n } = props;\n const theme = useTheme2();\n const styles = useStyles2(getStyles);\n\n const spacing = parseInt(theme.spacing(2).slice(0, -2), 10);\n const height = 150;\n\n const logsVolumeData = props.logsVolumeData;\n\n const logsVolumeInfo = getLogsVolumeDataSourceInfo(logsVolumeData?.data);\n let extraInfo = logsVolumeInfo ? `${logsVolumeInfo.name}` : '';\n\n if (isLogsVolumeLimited(logsVolumeData.data)) {\n extraInfo = [\n extraInfo,\n 'This datasource does not support full-range histograms. The graph below is based on the logs seen in the response.',\n ]\n .filter(identity)\n .join('. ');\n }\n\n let extraInfoComponent = <span>{extraInfo}</span>;\n\n if (logsVolumeData.state === LoadingState.Streaming) {\n extraInfoComponent = (\n <>\n {extraInfoComponent}\n <Tooltip content={t('explore.logs-volume-panel.content-streaming', 'Streaming')}>\n <Icon name=\"circle-mono\" size=\"md\" className={styles.streaming} data-testid=\"logs-volume-streaming\" />\n </Tooltip>\n </>\n );\n }\n\n return (\n <div style={{ height }} className={styles.contentContainer}>\n <ExploreGraph\n toggleLegendRef={toggleLegendRef}\n vizLegendOverrides={{\n calcs: ['sum'],\n }}\n graphStyle=\"lines\"\n loadingState={logsVolumeData.state ?? LoadingState.Done}\n data={logsVolumeData.data}\n height={height}\n width={width - spacing * 2}\n timeRange={props.timeRange}\n onChangeTime={onUpdateTimeRange}\n timeZone={timeZone}\n splitOpenFn={splitOpen}\n tooltipDisplayMode={TooltipDisplayMode.Multi}\n onHiddenSeriesChanged={onHiddenSeriesChanged}\n anchorToZero\n yAxisMaximum={allLogsVolumeMaximum}\n eventBus={props.eventBus}\n annotations={props.annotations}\n />\n {extraInfoComponent && <div className={styles.extraInfoContainer}>{extraInfoComponent}</div>}\n </div>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n extraInfoContainer: css({\n display: 'flex',\n justifyContent: 'end',\n position: 'absolute',\n right: '5px',\n top: '-10px',\n fontSize: theme.typography.bodySmall.fontSize,\n color: theme.colors.text.secondary,\n }),\n contentContainer: css({\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n position: 'relative',\n }),\n streaming: css({\n color: theme.colors.success.text,\n }),\n };\n};\n","import { DataQueryError, DataQueryResponse } from '@grafana/data';\n\n// Currently we can only infer if an error response is a timeout or not.\nexport function isTimeoutErrorResponse(response: DataQueryResponse | undefined): boolean {\n if (!response) {\n return false;\n }\n if (!response.error && !response.errors) {\n return false;\n }\n\n const errors = response.error ? [response.error] : response.errors || [];\n\n return errors.some((error: DataQueryError) => {\n const message = `${error.message || error.data?.message}`?.toLowerCase();\n return message.includes('timeout');\n });\n}\n","import { css } from '@emotion/css';\nimport { flatten, groupBy, mapValues, sortBy } from 'lodash';\nimport { useCallback, useMemo } from 'react';\nimport * as React from 'react';\n\nimport {\n AbsoluteTimeRange,\n DataFrame,\n DataQueryResponse,\n DataTopic,\n dateTime,\n EventBus,\n getFrameDisplayName,\n GrafanaTheme2,\n LoadingState,\n shallowCompare,\n SplitOpen,\n TimeRange,\n TimeZone,\n} from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config } from '@grafana/runtime';\nimport { Button, InlineField, Alert, useStyles2, SeriesVisibilityChangeMode } from '@grafana/ui';\n\nimport { mergeLogsVolumeDataFrames, isLogsVolumeLimited, getLogsVolumeMaximumRange } from '../../logs/utils';\nimport { SupplementaryResultError } from '../SupplementaryResultError';\n\nimport { LogsVolumePanel } from './LogsVolumePanel';\nimport { isTimeoutErrorResponse } from './utils/logsVolumeResponse';\n\ntype Props = {\n logsVolumeData: DataQueryResponse | undefined;\n absoluteRange: AbsoluteTimeRange;\n timeZone: TimeZone;\n splitOpen: SplitOpen;\n width: number;\n onUpdateTimeRange: (timeRange: AbsoluteTimeRange) => void;\n onLoadLogsVolume: () => void;\n onDisplayedSeriesChanged: (series: string[]) => void;\n eventBus: EventBus;\n onClose?(): void;\n toggleLegendRef?: React.MutableRefObject<(name: string | undefined, mode: SeriesVisibilityChangeMode) => void>;\n};\n\nexport const LogsVolumePanelList = ({\n logsVolumeData,\n absoluteRange,\n onUpdateTimeRange,\n width,\n onLoadLogsVolume,\n onDisplayedSeriesChanged,\n eventBus,\n splitOpen,\n timeZone,\n onClose,\n toggleLegendRef,\n}: Props) => {\n const {\n logVolumes,\n maximumValue: allLogsVolumeMaximumValue,\n maximumRange: allLogsVolumeMaximumRange,\n annotations,\n } = useMemo(() => {\n let maximumValue = -Infinity;\n const data = logsVolumeData?.data.filter((frame: DataFrame) => frame.meta?.dataTopic !== DataTopic.Annotations);\n const annotations =\n logsVolumeData?.data.filter((frame: DataFrame) => frame.meta?.dataTopic === DataTopic.Annotations) || [];\n const sorted = sortBy(data || [], 'meta.custom.datasourceName');\n const grouped = groupBy(sorted, 'meta.custom.datasourceName');\n const logVolumes = mapValues(grouped, (value) => {\n const mergedData = mergeLogsVolumeDataFrames(value);\n maximumValue = Math.max(maximumValue, mergedData.maximum);\n return mergedData.dataFrames;\n });\n const maximumRange = getLogsVolumeMaximumRange(flatten(Object.values(logVolumes)));\n return {\n maximumValue,\n maximumRange,\n logVolumes,\n annotations,\n };\n }, [logsVolumeData]);\n\n const styles = useStyles2(getStyles);\n\n const numberOfLogVolumes = Object.keys(logVolumes).length;\n\n const containsZoomed = Object.values(logVolumes).some((data: DataFrame[]) => {\n const zoomRatio = logsLevelZoomRatio(data, absoluteRange);\n return !isLogsVolumeLimited(data) && zoomRatio && zoomRatio < 1;\n });\n\n const canShowPartialData =\n config.featureToggles.lokiShardSplitting && logsVolumeData && logsVolumeData.data.length > 0;\n const timeoutError = isTimeoutErrorResponse(logsVolumeData);\n\n const from = dateTime(Math.max(absoluteRange.from, allLogsVolumeMaximumRange.from));\n const to = dateTime(Math.min(absoluteRange.to, allLogsVolumeMaximumRange.to));\n const visibleRange: TimeRange = { from, to, raw: { from, to } };\n\n const handleHiddenSeriesChanged = useCallback(\n (hiddenSeries: string[]) => {\n // Not supported\n if (numberOfLogVolumes > 1) {\n return;\n }\n const allLevels = [\n ...new Set(\n Object.values(logVolumes)\n .map((series) => series.map((dataFrame) => getFrameDisplayName(dataFrame)))\n .flat()\n ),\n ];\n const displayedLevels = allLevels.filter((level) => !hiddenSeries.includes(level));\n onDisplayedSeriesChanged(shallowCompare(allLevels, displayedLevels) ? [] : displayedLevels);\n },\n [logVolumes, numberOfLogVolumes, onDisplayedSeriesChanged]\n );\n\n if (logsVolumeData?.state === LoadingState.Loading) {\n return (\n <span>\n <Trans i18nKey=\"explore.logs-volume-panel-list.loading\">Loading...</Trans>\n </span>\n );\n } else if (timeoutError && !canShowPartialData) {\n return (\n <SupplementaryResultError\n title={t('explore.logs-volume-panel-list.title-unable-to-show-log-volume', 'Unable to show log volume')}\n // Using info to avoid users thinking that the actual query has failed.\n message={\n <>\n <p>\n <Trans i18nKey=\"explore.logs.logs-volume.much-data\">\n The query is trying to access too much data. Try one or more of the following:\n </Trans>\n </p>\n <ul>\n <li>\n <Trans i18nKey=\"explore.logs.logs-volume.add-filters\">\n Add more labels to your query to narrow down your search.\n </Trans>\n </li>\n <li>\n <Trans i18nKey=\"explore.logs.logs-volume.decrease-timerange\">\n Decrease the time range of your query.\n </Trans>\n </li>\n </ul>\n </>\n }\n severity=\"info\"\n suggestedAction=\"Retry\"\n onSuggestedAction={onLoadLogsVolume}\n onRemove={onClose}\n />\n );\n } else if (logsVolumeData?.error !== undefined && !canShowPartialData) {\n return (\n <SupplementaryResultError\n error={logsVolumeData.error}\n title={t(\n 'explore.logs-volume-panel-list.title-failed-volume-query',\n 'Failed to load log volume for this query'\n )}\n />\n );\n }\n\n if (numberOfLogVolumes === 0 && logsVolumeData?.state !== LoadingState.Streaming) {\n return (\n <div className={styles.alertContainer}>\n <Alert\n severity=\"info\"\n title={t('explore.logs-volume-panel-list.title-no-logs-volume-available', 'No logs volume available')}\n >\n <Trans i18nKey=\"explore.logs-volumne-panel-list.body-no-logs-volume-available\">\n No volume information available for the current queries and time range.\n </Trans>\n </Alert>\n </div>\n );\n }\n\n return (\n <div className={styles.listContainer}>\n {timeoutError && canShowPartialData && (\n <SupplementaryResultError\n title={t('explore.logs-volume-panel-list.title-showing-partial-data', 'Showing partial data')}\n message=\"The query is trying to access too much data and some sharded requests could not be completed. Try decreasing the time range or adding more labels to your query.\"\n severity=\"info\"\n dismissable\n />\n )}\n {Object.keys(logVolumes).map((name, index) => {\n return (\n <LogsVolumePanel\n toggleLegendRef={toggleLegendRef}\n key={index}\n timeRange={visibleRange}\n allLogsVolumeMaximum={allLogsVolumeMaximumValue}\n width={width}\n logsVolumeData={{ data: logVolumes[name], state: logsVolumeData?.state }}\n onUpdateTimeRange={onUpdateTimeRange}\n timeZone={timeZone}\n splitOpen={splitOpen}\n onLoadLogsVolume={onLoadLogsVolume}\n // TODO: Support filtering level from multiple log levels\n onHiddenSeriesChanged={numberOfLogVolumes > 1 ? () => {} : handleHiddenSeriesChanged}\n eventBus={eventBus}\n annotations={annotations}\n />\n );\n })}\n {containsZoomed && (\n <div className={styles.extraInfoContainer}>\n <InlineField\n label={t('explore.logs-volume-panel-list.label-reload-log-volume', 'Reload log volume')}\n transparent\n >\n <Button\n aria-label={t('explore.logs-volume-panel-list.aria-label-reload-log-volume', 'Reload log volume')}\n size=\"xs\"\n icon=\"sync\"\n variant=\"secondary\"\n onClick={onLoadLogsVolume}\n id=\"reload-volume\"\n />\n </InlineField>\n </div>\n )}\n </div>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n listContainer: css({\n paddingTop: '10px',\n }),\n extraInfoContainer: css({\n display: 'flex',\n justifyContent: 'end',\n position: 'absolute',\n right: '5px',\n top: '5px',\n }),\n oldInfoText: css({\n fontSize: theme.typography.bodySmall.fontSize,\n color: theme.colors.text.secondary,\n }),\n alertContainer: css({\n width: '50%',\n minWidth: `${theme.breakpoints.values.sm}px`,\n margin: '0 auto',\n }),\n };\n};\n\nfunction logsLevelZoomRatio(\n logsVolumeData: DataFrame[] | undefined,\n selectedTimeRange: AbsoluteTimeRange\n): number | undefined {\n const dataRange = logsVolumeData && logsVolumeData[0] && logsVolumeData[0].meta?.custom?.absoluteRange;\n return dataRange ? (selectedTimeRange.from - selectedTimeRange.to) / (dataRange.from - dataRange.to) : undefined;\n}\n","import { css, cx } from '@emotion/css';\nimport { capitalize, groupBy } from 'lodash';\nimport { useCallback, useEffect, useState, useRef, useMemo } from 'react';\nimport * as React from 'react';\nimport { usePrevious, useUnmount } from 'react-use';\n\nimport {\n SplitOpen,\n LogRowModel,\n LogsMetaItem,\n DataFrame,\n AbsoluteTimeRange,\n GrafanaTheme2,\n LoadingState,\n TimeZone,\n RawTimeRange,\n DataQueryResponse,\n LogRowContextOptions,\n EventBus,\n ExplorePanelsState,\n TimeRange,\n LogsDedupStrategy,\n LogsSortOrder,\n CoreApp,\n LogsDedupDescription,\n rangeUtil,\n ExploreLogsPanelState,\n DataHoverClearEvent,\n DataHoverEvent,\n serializeStateToUrlParam,\n urlUtil,\n LogLevel,\n shallowCompare,\n} from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, reportInteraction } from '@grafana/runtime';\nimport { DataQuery, DataTopic } from '@grafana/schema';\nimport {\n Button,\n InlineField,\n InlineFieldRow,\n InlineSwitch,\n PanelChrome,\n PopoverContent,\n RadioButtonGroup,\n SeriesVisibilityChangeMode,\n Themeable2,\n withTheme2,\n} from '@grafana/ui';\nimport store from 'app/core/store';\nimport { createAndCopyShortLink, getLogsPermalinkRange } from 'app/core/utils/shortLinks';\nimport { ControlledLogRows } from 'app/features/logs/components/ControlledLogRows';\nimport { InfiniteScroll } from 'app/features/logs/components/InfiniteScroll';\nimport { LogRows } from 'app/features/logs/components/LogRows';\nimport { LogRowContextModal } from 'app/features/logs/components/log-context/LogRowContextModal';\nimport { LogLineContext } from 'app/features/logs/components/panel/LogLineContext';\nimport { LogList, LogListOptions } from 'app/features/logs/components/panel/LogList';\nimport { isDedupStrategy, isLogsSortOrder } from 'app/features/logs/components/panel/LogListContext';\nimport { LogLevelColor, dedupLogRows } from 'app/features/logs/logsModel';\nimport { getLogLevelFromKey, getLogLevelInfo } from 'app/features/logs/utils';\nimport { LokiQueryDirection } from 'app/plugins/datasource/loki/dataquery.gen';\nimport { isLokiQuery } from 'app/plugins/datasource/loki/queryUtils';\nimport { GetFieldLinksFn } from 'app/plugins/panel/logs/types';\nimport { getState } from 'app/store/store';\nimport { ExploreItemState } from 'app/types/explore';\nimport { useDispatch } from 'app/types/store';\n\nimport {\n contentOutlineTrackPinAdded,\n contentOutlineTrackPinClicked,\n contentOutlineTrackPinLimitReached,\n contentOutlineTrackPinRemoved,\n contentOutlineTrackUnpinClicked,\n} from '../ContentOutline/ContentOutlineAnalyticEvents';\nimport { useContentOutlineContext } from '../ContentOutline/ContentOutlineContext';\nimport { getUrlStateFromPaneState } from '../hooks/useStateSync';\nimport { changePanelState } from '../state/explorePane';\nimport { changeQueries, runQueries } from '../state/query';\n\nimport { LogsFeedback } from './LogsFeedback';\nimport { LogsMetaRow } from './LogsMetaRow';\nimport LogsNavigation from './LogsNavigation';\nimport { LogsTableWrap, getLogsTableHeight } from './LogsTableWrap';\nimport { LogsVolumePanelList } from './LogsVolumePanelList';\nimport { SETTING_KEY_ROOT, SETTINGS_KEYS, visualisationTypeKey } from './utils/logs';\n\ninterface Props extends Themeable2 {\n width: number;\n splitOpen: SplitOpen;\n logRows: LogRowModel[];\n logsMeta?: LogsMetaItem[];\n logsSeries?: DataFrame[];\n logsQueries?: DataQuery[];\n visibleRange?: AbsoluteTimeRange;\n theme: GrafanaTheme2;\n loading: boolean;\n loadingState: LoadingState;\n absoluteRange: AbsoluteTimeRange;\n timeZone: TimeZone;\n scanning?: boolean;\n scanRange?: RawTimeRange;\n exploreId: string;\n datasourceType?: string;\n logsVolumeEnabled: boolean;\n logsVolumeData: DataQueryResponse | undefined;\n onSetLogsVolumeEnabled: (enabled: boolean) => void;\n loadLogsVolumeData: () => void;\n showContextToggle?: (row: LogRowModel) => boolean;\n onChangeTime: (range: AbsoluteTimeRange) => void;\n onClickFilterLabel?: (key: string, value: string, frame?: DataFrame) => void;\n onClickFilterOutLabel?: (key: string, value: string, frame?: DataFrame) => void;\n onStartScanning?: () => void;\n onStopScanning?: () => void;\n getRowContext?: (row: LogRowModel, origRow: LogRowModel, options: LogRowContextOptions) => Promise<DataQueryResponse>;\n getRowContextQuery?: (\n row: LogRowModel,\n options?: LogRowContextOptions,\n cacheFilters?: boolean\n ) => Promise<DataQuery | null>;\n getLogRowContextUi?: (row: LogRowModel, runContextQuery?: () => void) => React.ReactNode;\n getFieldLinks: GetFieldLinksFn;\n addResultsToCache: () => void;\n clearCache: () => void;\n eventBus: EventBus;\n panelState?: ExplorePanelsState;\n scrollElement?: HTMLDivElement;\n isFilterLabelActive?: (key: string, value: string, refId?: string) => Promise<boolean>;\n logsFrames?: DataFrame[];\n range: TimeRange;\n onClickFilterString?: (value: string, refId?: string) => void;\n onClickFilterOutString?: (value: string, refId?: string) => void;\n loadMoreLogs?(range: AbsoluteTimeRange): void;\n onPinLineCallback?: () => void;\n}\n\nexport type LogsVisualisationType = 'table' | 'logs';\n\n// we need to define the order of these explicitly\nconst DEDUP_OPTIONS = [\n LogsDedupStrategy.none,\n LogsDedupStrategy.exact,\n LogsDedupStrategy.numbers,\n LogsDedupStrategy.signature,\n];\n\nconst getDefaultVisualisationType = (): LogsVisualisationType => {\n const visualisationType = store.get(visualisationTypeKey);\n if (visualisationType === 'table') {\n return 'table';\n }\n if (visualisationType === 'logs') {\n return 'logs';\n }\n if (config.featureToggles.logsExploreTableDefaultVisualization) {\n return 'table';\n }\n return 'logs';\n};\n\nconst PINNED_LOGS_LIMIT = 10;\nconst PINNED_LOGS_TITLE = 'Pinned log';\nconst PINNED_LOGS_MESSAGE = 'Pin to content outline';\nconst PINNED_LOGS_PANELID = 'Logs';\n\nconst UnthemedLogs: React.FunctionComponent<Props> = (props: Props) => {\n const {\n width,\n splitOpen,\n logRows,\n logsMeta,\n logsVolumeEnabled,\n logsVolumeData,\n loadLogsVolumeData,\n loading = false,\n onClickFilterLabel,\n onClickFilterOutLabel,\n timeZone,\n scanning,\n scanRange,\n showContextToggle,\n absoluteRange,\n onChangeTime,\n getFieldLinks,\n theme,\n logsQueries,\n clearCache,\n addResultsToCache,\n exploreId,\n getRowContext,\n getLogRowContextUi,\n getRowContextQuery,\n loadMoreLogs,\n panelState,\n eventBus,\n onPinLineCallback,\n scrollElement,\n } = props;\n const [showLabels, setShowLabels] = useState<boolean>(store.getBool(SETTINGS_KEYS.showLabels, false));\n const [showTime, setShowTime] = useState<boolean>(store.getBool(SETTINGS_KEYS.showTime, true));\n const [wrapLogMessage, setWrapLogMessage] = useState<boolean>(store.getBool(SETTINGS_KEYS.wrapLogMessage, true));\n const [prettifyLogMessage, setPrettifyLogMessage] = useState<boolean>(\n store.getBool(SETTINGS_KEYS.prettifyLogMessage, false)\n );\n const [dedupStrategy, setDedupStrategy] = useState<LogsDedupStrategy>(LogsDedupStrategy.none);\n const [logsSortOrder, setLogsSortOrder] = useState<LogsSortOrder>(\n store.get(SETTINGS_KEYS.logsSortOrder) || LogsSortOrder.Descending\n );\n const [isFlipping, setIsFlipping] = useState<boolean>(false);\n const [displayedFields, setDisplayedFields] = useState<string[]>(panelState?.logs?.displayedFields ?? []);\n const [defaultDisplayedFields, setDefaultDisplayedFields] = useState<string[]>([]);\n const [contextOpen, setContextOpen] = useState<boolean>(false);\n const [contextRow, setContextRow] = useState<LogRowModel | undefined>(undefined);\n const [pinLineButtonTooltipTitle, setPinLineButtonTooltipTitle] = useState<PopoverContent>(PINNED_LOGS_MESSAGE);\n const [visualisationType, setVisualisationType] = useState<LogsVisualisationType>(\n panelState?.logs?.visualisationType ?? getDefaultVisualisationType()\n );\n const logsContainerRef = useRef<HTMLDivElement | null>(null);\n const dispatch = useDispatch();\n const previousLoading = usePrevious(loading);\n\n const logsVolumeEventBus = eventBus.newScopedBus('logsvolume', { onlyLocal: false });\n const { register, unregister, outlineItems, updateItem } = useContentOutlineContext() ?? {};\n const flipOrderTimer = useRef<number | undefined>(undefined);\n const cancelFlippingTimer = useRef<number | undefined>(undefined);\n const toggleLegendRef = useRef<(name: string | undefined, mode: SeriesVisibilityChangeMode) => void>(() => {});\n const topLogsRef = useRef<HTMLDivElement>(null);\n const [filterLevels, setFilterLevels] = useState<LogLevel[] | undefined>(undefined);\n\n const tableHeight = getLogsTableHeight();\n const setWrapperLineWrapStyles = wrapLogMessage || visualisationType === 'table';\n const styles = getStyles(theme, setWrapperLineWrapStyles, tableHeight);\n const hasData = logRows && logRows.length > 0;\n const scanText = scanRange ? `Scanning ${rangeUtil.describeTimeRange(scanRange)}` : 'Scanning...';\n\n // Get pinned log lines\n const logsParent = outlineItems?.find((item) => item.panelId === PINNED_LOGS_PANELID && item.level === 'root');\n const pinnedLogs = useMemo(\n () =>\n logsParent?.children\n ?.filter((outlines) => outlines.title === PINNED_LOGS_TITLE)\n .map((pinnedLogs) => pinnedLogs.id),\n [logsParent?.children]\n );\n\n const getPinnedLogsCount = useCallback(() => {\n const logsParent = outlineItems?.find((item) => item.panelId === PINNED_LOGS_PANELID && item.level === 'root');\n return logsParent?.children?.filter((child) => child.title === PINNED_LOGS_TITLE).length ?? 0;\n }, [outlineItems]);\n\n useEffect(() => {\n if (getPinnedLogsCount() === PINNED_LOGS_LIMIT) {\n setPinLineButtonTooltipTitle(\n <span style={{ display: 'flex', textAlign: 'center' }}>\n ❗️\n <Trans i18nKey=\"explore.logs.maximum-pinned-logs\">\n Maximum of {{ PINNED_LOGS_LIMIT }} pinned logs reached. Unpin a log to add another.\n </Trans>\n </span>\n );\n } else {\n setPinLineButtonTooltipTitle(PINNED_LOGS_MESSAGE);\n }\n }, [outlineItems, getPinnedLogsCount]);\n\n useEffect(() => {\n if (loading && !previousLoading && panelState?.logs?.id) {\n // loading stopped, so we need to remove any permalinked log lines\n delete panelState.logs.id;\n\n dispatch(\n changePanelState(exploreId, 'logs', {\n ...panelState,\n })\n );\n }\n }, [dispatch, exploreId, loading, panelState, previousLoading]);\n\n useEffect(() => {\n const visualisationType = panelState?.logs?.visualisationType ?? getDefaultVisualisationType();\n setVisualisationType(visualisationType);\n\n store.set(visualisationTypeKey, visualisationType);\n }, [panelState?.logs?.visualisationType]);\n\n useUnmount(() => {\n if (flipOrderTimer) {\n window.clearTimeout(flipOrderTimer.current);\n }\n if (cancelFlippingTimer) {\n window.clearTimeout(cancelFlippingTimer.current);\n }\n });\n\n useUnmount(() => {\n // If we're unmounting logs (e.g. switching to another datasource), we need to remove the logs specific panel state, otherwise it will persist in the explore url\n if (\n panelState?.logs?.columns ||\n panelState?.logs?.refId ||\n panelState?.logs?.labelFieldName ||\n panelState?.logs?.displayedFields\n ) {\n dispatch(\n changePanelState(exploreId, 'logs', {\n ...panelState?.logs,\n columns: undefined,\n visualisationType: visualisationType,\n labelFieldName: undefined,\n refId: undefined,\n displayedFields: undefined,\n })\n );\n }\n });\n\n const updatePanelState = useCallback(\n (logsPanelState: Partial<ExploreLogsPanelState>) => {\n const state: ExploreItemState | undefined = getState().explore.panes[exploreId];\n if (state?.panelsState) {\n dispatch(\n changePanelState(exploreId, 'logs', {\n ...state.panelsState.logs,\n columns: logsPanelState.columns ?? panelState?.logs?.columns,\n visualisationType: logsPanelState.visualisationType ?? visualisationType,\n labelFieldName: logsPanelState.labelFieldName,\n refId: logsPanelState.refId ?? panelState?.logs?.refId,\n displayedFields: logsPanelState.displayedFields ?? panelState?.logs?.displayedFields,\n })\n );\n }\n },\n [\n dispatch,\n exploreId,\n panelState?.logs?.columns,\n panelState?.logs?.displayedFields,\n panelState?.logs?.refId,\n visualisationType,\n ]\n );\n\n useEffect(() => {\n if (!shallowCompare(displayedFields, panelState?.logs?.displayedFields ?? [])) {\n updatePanelState({\n ...panelState?.logs,\n displayedFields,\n });\n }\n }, [displayedFields, panelState?.logs, updatePanelState]);\n\n // actions\n const onLogRowHover = useCallback(\n (row?: LogRowModel) => {\n if (!row) {\n props.eventBus.publish(new DataHoverClearEvent());\n } else {\n props.eventBus.publish(\n new DataHoverEvent({\n point: {\n time: row.timeEpochMs,\n },\n })\n );\n }\n },\n [props.eventBus]\n );\n\n const scrollIntoView = useCallback(\n (element: HTMLElement) => {\n if (config.featureToggles.logsInfiniteScrolling) {\n if (logsContainerRef.current) {\n topLogsRef.current?.scrollIntoView();\n logsContainerRef.current.scroll({\n behavior: 'smooth',\n top: logsContainerRef.current.scrollTop + element.getBoundingClientRect().top - window.innerHeight / 2,\n });\n }\n\n return;\n }\n\n if (scrollElement) {\n scrollElement.scroll({\n behavior: 'smooth',\n top: scrollElement.scrollTop + element.getBoundingClientRect().top - window.innerHeight / 2,\n });\n }\n },\n [scrollElement]\n );\n\n const sortOrderChanged = useCallback(\n (newSortOrder: LogsSortOrder) => {\n if (!logsQueries) {\n return;\n }\n let hasLokiQueries = false;\n const newQueries = logsQueries.map((query) => {\n if (query.datasource?.type !== 'loki' || !isLokiQuery(query)) {\n return query;\n }\n if (query.direction === LokiQueryDirection.Scan) {\n // Don't override Scan. When the direction is Scan it means that the user specifically assigned this direction to the query.\n return query;\n }\n hasLokiQueries = true;\n const newDirection =\n newSortOrder === LogsSortOrder.Ascending ? LokiQueryDirection.Forward : LokiQueryDirection.Backward;\n if (newDirection !== query.direction) {\n query.direction = newDirection;\n }\n return query;\n });\n\n if (hasLokiQueries) {\n dispatch(changeQueries({ exploreId, queries: newQueries }));\n dispatch(runQueries({ exploreId }));\n }\n },\n [dispatch, exploreId, logsQueries]\n );\n\n const onChangeLogsSortOrder = useCallback(\n (newSortOrder: LogsSortOrder) => {\n setIsFlipping(true);\n // we are using setTimeout here to make sure that disabled button is rendered before the rendering of reordered logs\n flipOrderTimer.current = window.setTimeout(() => {\n store.set(SETTINGS_KEYS.logsSortOrder, newSortOrder);\n sortOrderChanged(newSortOrder);\n setLogsSortOrder(newSortOrder);\n }, 0);\n cancelFlippingTimer.current = window.setTimeout(() => setIsFlipping(false), 1000);\n },\n [sortOrderChanged]\n );\n\n const onChangeVisualisation = useCallback(\n (visualisation: LogsVisualisationType) => {\n setVisualisationType(visualisation);\n const payload = {\n ...panelState?.logs,\n visualisationType: visualisation,\n };\n updatePanelState(payload);\n\n reportInteraction('grafana_explore_logs_visualisation_changed', {\n newVisualizationType: visualisation,\n datasourceType: props.datasourceType ?? 'unknown',\n defaultVisualisationType: config.featureToggles.logsExploreTableDefaultVisualization ? 'table' : 'logs',\n });\n },\n [panelState?.logs, props.datasourceType, updatePanelState]\n );\n\n const onChangeDedup = useCallback(\n (dedupStrategy: LogsDedupStrategy) => {\n reportInteraction('grafana_explore_logs_deduplication_clicked', {\n deduplicationType: dedupStrategy,\n datasourceType: props.datasourceType,\n });\n setDedupStrategy(dedupStrategy);\n },\n [props.datasourceType]\n );\n\n const onChangeLabels = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const { target } = event;\n if (target) {\n const showLabels = target.checked;\n\n setShowLabels(showLabels);\n store.set(SETTINGS_KEYS.showLabels, showLabels);\n }\n }, []);\n\n const onChangeShowTime = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const { target } = event;\n if (target) {\n const showTime = target.checked;\n\n setShowTime(showTime);\n store.set(SETTINGS_KEYS.showTime, showTime);\n }\n }, []);\n\n const onChangeWrapLogMessage = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const { target } = event;\n if (target) {\n const wrapLogMessage = target.checked;\n\n setWrapLogMessage(wrapLogMessage);\n store.set(SETTINGS_KEYS.wrapLogMessage, wrapLogMessage);\n }\n }, []);\n\n const onChangePrettifyLogMessage = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const { target } = event;\n if (target) {\n const prettifyLogMessage = target.checked;\n\n setPrettifyLogMessage(prettifyLogMessage);\n store.set(SETTINGS_KEYS.prettifyLogMessage, prettifyLogMessage);\n }\n }, []);\n\n const onToggleLogsVolumeCollapse = useCallback(\n (collapsed: boolean) => {\n props.onSetLogsVolumeEnabled(!collapsed);\n reportInteraction('grafana_explore_logs_histogram_toggle_clicked', {\n datasourceType: props.datasourceType,\n type: !collapsed ? 'open' : 'close',\n });\n },\n [props]\n );\n\n const onClickScan = useCallback(\n (event: React.SyntheticEvent) => {\n event.preventDefault();\n if (props.onStartScanning) {\n props.onStartScanning();\n reportInteraction('grafana_explore_logs_scanning_button_clicked', {\n type: 'start',\n datasourceType: props.datasourceType,\n });\n }\n },\n [props]\n );\n\n const onClickStopScan = useCallback(\n (event: React.SyntheticEvent) => {\n event.preventDefault();\n if (props.onStopScanning) {\n props.onStopScanning();\n }\n },\n [props]\n );\n\n const showField = useCallback(\n (key: string) => {\n const index = displayedFields.indexOf(key);\n\n if (index === -1) {\n const updatedDisplayedFields = displayedFields.concat(key);\n setDisplayedFields(updatedDisplayedFields);\n }\n },\n [displayedFields]\n );\n\n const hideField = useCallback(\n (key: string) => {\n const index = displayedFields.indexOf(key);\n if (index > -1) {\n const updatedDisplayedFields = displayedFields.filter((k) => key !== k);\n setDisplayedFields(updatedDisplayedFields);\n }\n },\n [displayedFields]\n );\n\n const clearDisplayedFields = useCallback(() => {\n setDisplayedFields([]);\n }, []);\n\n const onCloseCallbackRef = useRef<() => void>(() => {});\n\n let onCloseContext = useCallback(() => {\n setContextOpen(false);\n setContextRow(undefined);\n if (!config.featureToggles.newLogContext) {\n reportInteraction('grafana_explore_logs_log_context_closed', {\n datasourceType: contextRow?.datasourceType,\n logRowUid: contextRow?.uid,\n });\n }\n onCloseCallbackRef?.current();\n }, [contextRow?.datasourceType, contextRow?.uid, onCloseCallbackRef]);\n\n const onOpenContext = useCallback((row: LogRowModel, onClose: () => void) => {\n // we are setting the `contextOpen` open state and passing it down to the `LogRow` in order to highlight the row when a LogContext is open\n setContextOpen(true);\n setContextRow(row);\n if (!config.featureToggles.newLogContext) {\n reportInteraction('grafana_explore_logs_log_context_opened', {\n datasourceType: row.datasourceType,\n logRowUid: row.uid,\n });\n }\n onCloseCallbackRef.current = onClose;\n }, []);\n\n const onPermalinkClick = useCallback(\n async (row: LogRowModel) => {\n // this is an extra check, to be sure that we are not\n // creating permalinks for logs without an id-field.\n // normally it should never happen, because we do not\n // display the permalink button in such cases.\n if (row.rowId === undefined) {\n return;\n }\n\n // get explore state, add log-row-id and make timerange absolute\n const urlState = getUrlStateFromPaneState(getState().explore.panes[exploreId]!);\n urlState.panelsState = {\n ...panelState,\n logs: { id: row.uid, visualisationType: visualisationType ?? getDefaultVisualisationType(), displayedFields },\n };\n urlState.range = getLogsPermalinkRange(row, logRows, absoluteRange);\n\n // append changed urlState to baseUrl\n const serializedState = serializeStateToUrlParam(urlState);\n const baseUrl = /.*(?=\\/explore)/.exec(`${window.location.href}`)![0];\n const url = urlUtil.renderUrl(`${baseUrl}/explore`, { left: serializedState });\n await createAndCopyShortLink(url);\n\n reportInteraction('grafana_explore_logs_permalink_clicked', {\n datasourceType: row.datasourceType ?? 'unknown',\n logRowUid: row.uid,\n logRowLevel: row.logLevel,\n });\n },\n [absoluteRange, displayedFields, exploreId, logRows, panelState, visualisationType]\n );\n\n const scrollToTopLogs = useCallback(() => {\n if (config.featureToggles.logsInfiniteScrolling) {\n if (logsContainerRef.current) {\n logsContainerRef.current.scroll({\n behavior: 'auto',\n top: 0,\n });\n }\n }\n topLogsRef.current?.scrollIntoView();\n }, []);\n\n const onPinToContentOutlineClick = useCallback(\n (row: LogRowModel, allowUnPin = true) => {\n if (getPinnedLogsCount() === PINNED_LOGS_LIMIT && !allowUnPin) {\n contentOutlineTrackPinLimitReached();\n return;\n }\n\n // find the Logs parent item\n const logsParent = outlineItems?.find((item) => item.panelId === PINNED_LOGS_PANELID && item.level === 'root');\n\n //update the parent's expanded state\n if (logsParent && updateItem) {\n updateItem(logsParent.id, { expanded: true });\n }\n\n const alreadyPinned = pinnedLogs?.find((pin) => pin === row.rowId);\n if (alreadyPinned && row.rowId && allowUnPin) {\n unregister?.(row.rowId);\n contentOutlineTrackPinRemoved();\n } else if (getPinnedLogsCount() !== PINNED_LOGS_LIMIT && !alreadyPinned) {\n register?.({\n id: row.rowId,\n icon: 'gf-logs',\n title: PINNED_LOGS_TITLE,\n panelId: PINNED_LOGS_PANELID,\n level: 'child',\n ref: null,\n color: LogLevelColor[row.logLevel],\n childOnTop: true,\n onClick: () => {\n onOpenContext(row, () => {});\n contentOutlineTrackPinClicked();\n },\n onRemove: (id: string) => {\n unregister?.(id);\n contentOutlineTrackUnpinClicked();\n },\n });\n contentOutlineTrackPinAdded();\n }\n\n onPinLineCallback?.();\n },\n [getPinnedLogsCount, onOpenContext, onPinLineCallback, outlineItems, pinnedLogs, register, unregister, updateItem]\n );\n\n const { dedupedRows, dedupCount } = useMemo(() => dedupRows(logRows, dedupStrategy), [dedupStrategy, logRows]);\n const navigationRange = useMemo(() => createNavigationRange(logRows), [logRows]);\n const infiniteScrollAvailable = useMemo(\n () => !logsQueries?.some((query) => 'direction' in query && query.direction === LokiQueryDirection.Scan),\n [logsQueries]\n );\n\n const visibilityChangedRef = useRef(true);\n const onLogOptionsChange = useCallback(\n (option: LogListOptions, value: string | string[] | boolean) => {\n if (option === 'sortOrder' && isLogsSortOrder(value)) {\n sortOrderChanged(value);\n } else if (option === 'dedupStrategy' && isDedupStrategy(value)) {\n setDedupStrategy(value);\n } else if (option === 'filterLevels' && Array.isArray(value) && logsVolumeEnabled) {\n const logVolData =\n logsVolumeData?.data.filter((frame: DataFrame) => frame.meta?.dataTopic !== DataTopic.Annotations) ?? [];\n const grouped = groupBy(logVolData, 'meta.custom.datasourceName');\n const numberOfLogVolumes = Object.keys(grouped).length;\n\n // Not supported\n if (numberOfLogVolumes > 1) {\n return;\n }\n\n const logsVolumeLevels = [\n ...new Set(\n logVolData.map((dataFrame) => {\n const { level } = getLogLevelInfo(dataFrame, logVolData);\n return getLogLevelFromKey(level);\n })\n ),\n ];\n\n setFilterLevels((currentFilterLevels: LogLevel[] | undefined) => {\n const newLevels = value.map((level) => getLogLevelFromKey(level));\n const newLogsVolumeLevels = newLevels.filter((level) => logsVolumeLevels.includes(level));\n const prevLogsVolumeLevels = currentFilterLevels?.filter((level) => logsVolumeLevels.includes(level)) ?? [];\n\n if (!newLogsVolumeLevels.length) {\n toggleLegendRef.current?.(undefined, SeriesVisibilityChangeMode.ToggleSelection);\n return undefined;\n }\n\n const addedLevels = newLogsVolumeLevels.filter((newLevel) => !prevLogsVolumeLevels.includes(newLevel));\n const removedLevels = prevLogsVolumeLevels.filter((prevLevel) => !newLogsVolumeLevels.includes(prevLevel));\n\n addedLevels.forEach((level) => {\n visibilityChangedRef.current = true;\n toggleLegendRef.current?.(\n level,\n !prevLogsVolumeLevels.length\n ? SeriesVisibilityChangeMode.ToggleSelection\n : SeriesVisibilityChangeMode.AppendToSelection\n );\n });\n removedLevels.forEach((level) => {\n visibilityChangedRef.current = true;\n toggleLegendRef.current?.(level, SeriesVisibilityChangeMode.AppendToSelection);\n });\n\n return newLevels;\n });\n } else if (option === 'defaultDisplayedFields' && Array.isArray(value)) {\n setDefaultDisplayedFields(value);\n }\n },\n [logsVolumeData?.data, logsVolumeEnabled, sortOrderChanged]\n );\n\n const onDisplayedSeriesChanged = useCallback((levels: string[]) => {\n if (visibilityChangedRef.current) {\n visibilityChangedRef.current = false;\n return;\n }\n setFilterLevels(levels.map((level) => getLogLevelFromKey(level)));\n }, []);\n\n return (\n <>\n {(!config.featureToggles.newLogsPanel || !config.featureToggles.newLogContext) && getRowContext && contextRow && (\n <LogRowContextModal\n open={contextOpen}\n row={contextRow}\n onClose={onCloseContext}\n getRowContext={(row, options) => getRowContext(row, contextRow, options)}\n getRowContextQuery={getRowContextQuery}\n getLogRowContextUi={getLogRowContextUi}\n logsSortOrder={logsSortOrder}\n timeZone={timeZone}\n />\n )}\n {config.featureToggles.newLogsPanel && config.featureToggles.newLogContext && getRowContext && contextRow && (\n <LogLineContext\n open={contextOpen}\n log={contextRow}\n onClose={onCloseContext}\n getRowContext={(row, options) => getRowContext(row, contextRow, options)}\n getRowContextQuery={getRowContextQuery}\n getLogRowContextUi={getLogRowContextUi}\n logOptionsStorageKey={SETTING_KEY_ROOT}\n timeZone={timeZone}\n displayedFields={displayedFields}\n onPermalinkClick={onPermalinkClick}\n onClickShowField={showField}\n onClickHideField={hideField}\n />\n )}\n <div className={styles.logsVolumePanel}>\n <PanelChrome\n title={t('explore.unthemed-logs.title-logs-volume', 'Logs volume')}\n collapsible\n collapsed={!logsVolumeEnabled}\n onToggleCollapse={onToggleLogsVolumeCollapse}\n >\n {logsVolumeEnabled && (\n <LogsVolumePanelList\n toggleLegendRef={toggleLegendRef}\n absoluteRange={absoluteRange}\n width={width}\n logsVolumeData={logsVolumeData}\n onUpdateTimeRange={onChangeTime}\n timeZone={timeZone}\n splitOpen={splitOpen}\n onLoadLogsVolume={loadLogsVolumeData}\n onDisplayedSeriesChanged={onDisplayedSeriesChanged}\n eventBus={logsVolumeEventBus}\n onClose={() => onToggleLogsVolumeCollapse(true)}\n />\n )}\n </PanelChrome>\n </div>\n <PanelChrome\n titleItems={[\n config.featureToggles.logsExploreTableVisualisation ? (\n visualisationType === 'logs' ? null : (\n <PanelChrome.TitleItem title={t('explore.unthemed-logs.title-feedback', 'Feedback')} key=\"A\">\n <LogsFeedback feedbackUrl=\"https://forms.gle/5YyKdRQJ5hzq4c289\" />\n </PanelChrome.TitleItem>\n )\n ) : null,\n ]}\n title={t('explore.unthemed-logs.title-logs', 'Logs')}\n actions={\n <>\n {config.featureToggles.logsExploreTableVisualisation && (\n <div className={styles.visualisationType}>\n <RadioButtonGroup\n className={styles.visualisationTypeRadio}\n options={[\n {\n label: t('explore.unthemed-logs.label.logs', 'Logs'),\n value: 'logs',\n description: t(\n 'explore.unthemed-logs.description.show-results-in-logs-visualisation',\n 'Show results in logs visualisation'\n ),\n },\n {\n label: t('explore.unthemed-logs.label.table', 'Table'),\n value: 'table',\n description: t(\n 'explore.unthemed-logs.description.show-results-in-table-visualisation',\n 'Show results in table visualisation'\n ),\n },\n ]}\n size=\"sm\"\n value={visualisationType}\n onChange={onChangeVisualisation}\n />\n </div>\n )}\n </>\n }\n loadingState={loading ? LoadingState.Loading : LoadingState.Done}\n >\n <div className={styles.stickyNavigation}>\n {visualisationType !== 'table' &&\n !config.featureToggles.newLogsPanel &&\n !config.featureToggles.logsPanelControls && (\n <div className={styles.logOptions}>\n <InlineFieldRow>\n <InlineField\n label={t('explore.unthemed-logs.label-time', 'Time')}\n className={styles.horizontalInlineLabel}\n transparent\n >\n <InlineSwitch\n value={showTime}\n onChange={onChangeShowTime}\n className={styles.horizontalInlineSwitch}\n transparent\n id={`show-time_${exploreId}`}\n />\n </InlineField>\n <InlineField\n label={t('explore.unthemed-logs.label-unique-labels', 'Unique labels')}\n className={styles.horizontalInlineLabel}\n transparent\n >\n <InlineSwitch\n value={showLabels}\n onChange={onChangeLabels}\n className={styles.horizontalInlineSwitch}\n transparent\n id={`unique-labels_${exploreId}`}\n />\n </InlineField>\n <InlineField\n label={t('explore.unthemed-logs.label-wrap-lines', 'Wrap lines')}\n className={styles.horizontalInlineLabel}\n transparent\n >\n <InlineSwitch\n value={wrapLogMessage}\n onChange={onChangeWrapLogMessage}\n className={styles.horizontalInlineSwitch}\n transparent\n id={`wrap-lines_${exploreId}`}\n />\n </InlineField>\n <InlineField\n label={t('explore.unthemed-logs.label-prettify-json', 'Prettify JSON')}\n className={styles.horizontalInlineLabel}\n transparent\n >\n <InlineSwitch\n value={prettifyLogMessage}\n onChange={onChangePrettifyLogMessage}\n className={styles.horizontalInlineSwitch}\n transparent\n id={`prettify_${exploreId}`}\n />\n </InlineField>\n <InlineField\n label={t('explore.unthemed-logs.label-deduplication', 'Deduplication')}\n className={styles.horizontalInlineLabel}\n transparent\n >\n <RadioButtonGroup\n options={DEDUP_OPTIONS.map((dedupType) => ({\n label: capitalize(dedupType),\n value: dedupType,\n description: LogsDedupDescription[dedupType],\n }))}\n value={dedupStrategy}\n onChange={onChangeDedup}\n className={styles.radioButtons}\n />\n </InlineField>\n </InlineFieldRow>\n\n <div>\n <InlineField\n label={t('explore.unthemed-logs.label-display-results', 'Display results')}\n className={styles.horizontalInlineLabel}\n transparent\n disabled={isFlipping || loading}\n >\n <RadioButtonGroup\n options={[\n {\n label: t('explore.unthemed-logs.label.newest-first', 'Newest first'),\n value: LogsSortOrder.Descending,\n description: t(\n 'explore.unthemed-logs.description.show-results-newest-to-oldest',\n 'Show results newest to oldest'\n ),\n },\n {\n label: t('explore.unthemed-logs.label.oldest-first', 'Oldest first'),\n value: LogsSortOrder.Ascending,\n description: t(\n 'explore.unthemed-logs.description.show-results-oldest-to-newest',\n 'Show results oldest to newest'\n ),\n },\n ]}\n value={logsSortOrder}\n onChange={onChangeLogsSortOrder}\n className={styles.radioButtons}\n />\n </InlineField>\n </div>\n </div>\n )}\n <div ref={topLogsRef} />\n <LogsMetaRow\n logRows={logRows}\n meta={logsMeta || []}\n dedupStrategy={dedupStrategy}\n dedupCount={dedupCount}\n displayedFields={displayedFields}\n clearDisplayedFields={clearDisplayedFields}\n defaultDisplayedFields={defaultDisplayedFields}\n visualisationType={visualisationType}\n />\n </div>\n <div className={cx(styles.logsSection, visualisationType === 'table' ? styles.logsTable : undefined)}>\n {!config.featureToggles.logsPanelControls && visualisationType === 'table' && hasData && (\n <div className={styles.logRows} data-testid=\"logRowsTable\">\n {/* Width should be full width minus logs navigation and padding */}\n <LogsTableWrap\n logsSortOrder={logsSortOrder}\n range={props.range}\n splitOpen={splitOpen}\n timeZone={timeZone}\n width={width - 80}\n logsFrames={props.logsFrames ?? []}\n onClickFilterLabel={onClickFilterLabel}\n onClickFilterOutLabel={onClickFilterOutLabel}\n panelState={panelState?.logs}\n updatePanelState={updatePanelState}\n datasourceType={props.datasourceType}\n />\n </div>\n )}\n {(!config.featureToggles.newLogsPanel || visualisationType === 'table') &&\n config.featureToggles.logsPanelControls &&\n hasData && (\n <div className={styles.controlledLogRowsWrapper} data-testid=\"logRows\">\n <ControlledLogRows\n ref={logsContainerRef}\n logsTableFrames={props.logsFrames}\n width={width}\n updatePanelState={updatePanelState}\n panelState={panelState?.logs}\n datasourceType={props.datasourceType}\n splitOpen={splitOpen}\n visualisationType={visualisationType}\n loading={loading}\n loadMoreLogs={infiniteScrollAvailable ? loadMoreLogs : undefined}\n range={props.range}\n pinnedLogs={pinnedLogs}\n logRows={logRows}\n deduplicatedRows={dedupedRows}\n dedupStrategy={dedupStrategy}\n onClickFilterLabel={onClickFilterLabel}\n onClickFilterOutLabel={onClickFilterOutLabel}\n showContextToggle={showContextToggle}\n getRowContextQuery={getRowContextQuery}\n showLabels={showLabels}\n showTime={showTime}\n enableLogDetails={true}\n wrapLogMessage={wrapLogMessage}\n prettifyLogMessage={prettifyLogMessage}\n timeZone={timeZone}\n getFieldLinks={getFieldLinks}\n logsSortOrder={logsSortOrder}\n displayedFields={displayedFields}\n onClickShowField={showField}\n onClickHideField={hideField}\n app={CoreApp.Explore}\n onLogRowHover={onLogRowHover}\n onOpenContext={onOpenContext}\n onPermalinkClick={onPermalinkClick}\n permalinkedRowId={panelState?.logs?.id}\n isFilterLabelActive={props.isFilterLabelActive}\n onClickFilterString={props.onClickFilterString}\n onClickFilterOutString={props.onClickFilterOutString}\n onUnpinLine={onPinToContentOutlineClick}\n onPinLine={onPinToContentOutlineClick}\n pinLineButtonTooltipTitle={pinLineButtonTooltipTitle}\n logsMeta={logsMeta}\n logOptionsStorageKey={SETTING_KEY_ROOT}\n onLogOptionsChange={onLogOptionsChange}\n filterLevels={filterLevels}\n timeRange={props.range}\n />\n </div>\n )}\n {!config.featureToggles.logsPanelControls &&\n !config.featureToggles.newLogsPanel &&\n visualisationType === 'logs' &&\n hasData && (\n <>\n <div\n className={config.featureToggles.logsInfiniteScrolling ? styles.scrollableLogRows : styles.logRows}\n data-testid=\"logRows\"\n ref={logsContainerRef}\n >\n <InfiniteScroll\n loading={loading}\n loadMoreLogs={infiniteScrollAvailable ? loadMoreLogs : undefined}\n range={props.range}\n timeZone={timeZone}\n rows={logRows}\n scrollElement={logsContainerRef.current}\n sortOrder={logsSortOrder}\n app={CoreApp.Explore}\n >\n <LogRows\n pinnedLogs={pinnedLogs}\n logRows={logRows}\n deduplicatedRows={dedupedRows}\n dedupStrategy={dedupStrategy}\n onClickFilterLabel={onClickFilterLabel}\n onClickFilterOutLabel={onClickFilterOutLabel}\n showContextToggle={showContextToggle}\n getRowContextQuery={getRowContextQuery}\n showLabels={showLabels}\n showTime={showTime}\n enableLogDetails={true}\n wrapLogMessage={wrapLogMessage}\n prettifyLogMessage={prettifyLogMessage}\n timeZone={timeZone}\n getFieldLinks={getFieldLinks}\n logsSortOrder={logsSortOrder}\n displayedFields={displayedFields}\n onClickShowField={showField}\n onClickHideField={hideField}\n app={CoreApp.Explore}\n onLogRowHover={onLogRowHover}\n onOpenContext={onOpenContext}\n onPermalinkClick={onPermalinkClick}\n permalinkedRowId={panelState?.logs?.id}\n scrollIntoView={scrollIntoView}\n isFilterLabelActive={props.isFilterLabelActive}\n scrollElement={logsContainerRef.current}\n onClickFilterString={props.onClickFilterString}\n onClickFilterOutString={props.onClickFilterOutString}\n onUnpinLine={onPinToContentOutlineClick}\n onPinLine={onPinToContentOutlineClick}\n pinLineButtonTooltipTitle={pinLineButtonTooltipTitle}\n renderPreview\n timeRange={props.range}\n />\n </InfiniteScroll>\n </div>\n <LogsNavigation\n logsSortOrder={logsSortOrder}\n visibleRange={navigationRange ?? absoluteRange}\n absoluteRange={absoluteRange}\n timeZone={timeZone}\n onChangeTime={onChangeTime}\n loading={loading}\n queries={logsQueries ?? []}\n scrollToTopLogs={scrollToTopLogs}\n addResultsToCache={addResultsToCache}\n clearCache={clearCache}\n />\n </>\n )}\n {config.featureToggles.newLogsPanel && visualisationType === 'logs' && (\n <div data-testid=\"logRows\" ref={logsContainerRef} className={styles.logRowsWrapper}>\n {logsContainerRef.current && hasData && (\n <LogList\n app={CoreApp.Explore}\n containerElement={logsContainerRef.current}\n enableLogDetails={true}\n dataFrames={props.logsFrames ?? []}\n dedupStrategy={dedupStrategy}\n displayedFields={displayedFields}\n filterLevels={filterLevels}\n getFieldLinks={getFieldLinks}\n getRowContextQuery={getRowContextQuery}\n isLabelFilterActive={props.isFilterLabelActive}\n loading={loading}\n loadMore={loadMoreLogs}\n logOptionsStorageKey={SETTING_KEY_ROOT}\n logs={dedupedRows}\n logsMeta={logsMeta}\n logSupportsContext={showContextToggle}\n onClickShowField={showField}\n onClickHideField={hideField}\n onClickFilterLabel={onClickFilterLabel}\n onClickFilterOutLabel={onClickFilterOutLabel}\n onClickFilterString={props.onClickFilterString}\n onClickFilterOutString={props.onClickFilterOutString}\n onLogOptionsChange={onLogOptionsChange}\n onLogLineHover={onLogRowHover}\n onOpenContext={onOpenContext}\n onPermalinkClick={onPermalinkClick}\n onPinLine={onPinToContentOutlineClick}\n onUnpinLine={onPinToContentOutlineClick}\n permalinkedLogId={panelState?.logs?.id}\n pinLineButtonTooltipTitle={pinLineButtonTooltipTitle}\n pinnedLogs={pinnedLogs}\n setDisplayedFields={setDisplayedFields}\n showControls\n showFieldSelector\n showTime={showTime}\n sortOrder={logsSortOrder}\n timeRange={props.range}\n timeZone={timeZone}\n wrapLogMessage={wrapLogMessage}\n />\n )}\n </div>\n )}\n {!loading && !hasData && !scanning && (\n <div className={styles.noDataWrapper}>\n <div className={styles.noData}>\n <Trans i18nKey=\"explore.logs.no-logs-found\">No logs found.</Trans>\n <Button size=\"sm\" variant=\"secondary\" className={styles.scanButton} onClick={onClickScan}>\n <Trans i18nKey=\"explore.logs.scan-for-older-logs\">Scan for older logs</Trans>\n </Button>\n </div>\n </div>\n )}\n {scanning && (\n <div className={styles.noDataWrapper}>\n <div className={styles.noData}>\n <span>{scanText}</span>\n <Button size=\"sm\" variant=\"secondary\" className={styles.scanButton} onClick={onClickStopScan}>\n <Trans i18nKey=\"explore.logs.stop-scan\">Stop scan</Trans>\n </Button>\n </div>\n </div>\n )}\n </div>\n </PanelChrome>\n </>\n );\n};\n\nexport const Logs = withTheme2(UnthemedLogs);\n\nconst getStyles = (theme: GrafanaTheme2, wrapLogMessage: boolean, tableHeight: number) => {\n return {\n noDataWrapper: css({\n display: 'flex',\n justifyContent: 'center',\n width: '100%',\n paddingBottom: theme.spacing(2),\n }),\n noData: css({\n display: 'inline-block',\n }),\n scanButton: css({\n marginLeft: theme.spacing(1),\n }),\n logOptions: css({\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'baseline',\n flexWrap: 'wrap',\n backgroundColor: theme.colors.background.primary,\n padding: `${theme.spacing(1)} ${theme.spacing(2)}`,\n borderRadius: theme.shape.radius.default,\n margin: `${theme.spacing(0, 0, 1)}`,\n border: `1px solid ${theme.colors.border.medium}`,\n }),\n headerButton: css({\n margin: `${theme.spacing(0.5, 0, 0, 1)}`,\n }),\n horizontalInlineLabel: css({\n '& > label': {\n marginRight: '0',\n },\n }),\n horizontalInlineSwitch: css({\n padding: `0 ${theme.spacing(1)} 0 0`,\n }),\n radioButtons: css({\n margin: '0',\n }),\n logsSection: css({\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'space-between',\n position: 'relative',\n }),\n logsTable: css({\n maxHeight: `${tableHeight}px`,\n }),\n scrollableLogRows: css({\n overflowY: 'scroll',\n width: '100%',\n maxHeight: '80vh',\n }),\n logRows: css({\n overflowX: `${wrapLogMessage ? 'unset' : 'scroll'}`,\n overflowY: 'visible',\n width: '100%',\n }),\n controlledLogRowsWrapper: css({\n width: '100%',\n maxHeight: '80vh',\n }),\n logRowsWrapper: css({\n width: '100%',\n }),\n visualisationType: css({\n display: 'flex',\n flex: '1',\n justifyContent: 'space-between',\n }),\n visualisationTypeRadio: css({\n margin: `0 0 0 ${theme.spacing(1)}`,\n }),\n stickyNavigation: css({\n overflow: 'visible',\n ...(config.featureToggles.logsInfiniteScrolling && { marginBottom: '0px' }),\n }),\n logsVolumePanel: css({\n marginBottom: theme.spacing(1.5),\n }),\n };\n};\n\nconst dedupRows = (logRows: LogRowModel[], dedupStrategy: LogsDedupStrategy) => {\n const dedupedRows = dedupLogRows(logRows, dedupStrategy);\n const dedupCount = dedupedRows.reduce((sum, row) => (row.duplicates ? sum + row.duplicates : sum), 0);\n return { dedupedRows, dedupCount };\n};\n\nconst createNavigationRange = (logRows: LogRowModel[]): { from: number; to: number } | undefined => {\n if (!logRows || logRows.length === 0) {\n return undefined;\n }\n const firstTimeStamp = logRows[0].timeEpochMs;\n const lastTimeStamp = logRows[logRows.length - 1].timeEpochMs;\n\n if (lastTimeStamp < firstTimeStamp) {\n return { from: lastTimeStamp, to: firstTimeStamp };\n }\n\n return { from: firstTimeStamp, to: lastTimeStamp };\n};\n","import { css } from '@emotion/css';\nimport { useRef } from 'react';\nimport * as React from 'react';\nimport { CSSTransition } from 'react-transition-group';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { useStyles2 } from '@grafana/ui';\n\nconst transitionDuration = 500;\n// We add a bit of delay to the transition as another perf optimisation. As at the start we need to render\n// quite a bit of new rows, if we start transition at the same time there can be frame rate drop. This gives time\n// for react to first render them and then do the animation.\nconst transitionDelay = 100;\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n logsEnter: css({\n label: 'logsEnter',\n position: 'absolute',\n opacity: 0,\n height: 'auto',\n width: '100%',\n }),\n logsEnterActive: css({\n label: 'logsEnterActive',\n opacity: 1,\n [theme.transitions.handleMotion('no-preference', 'reduce')]: {\n transition: `opacity ${transitionDuration}ms ease-out ${transitionDelay}ms`,\n },\n }),\n logsExit: css({\n label: 'logsExit',\n position: 'absolute',\n opacity: 1,\n height: 'auto',\n width: '100%',\n }),\n logsExitActive: css({\n label: 'logsExitActive',\n opacity: 0,\n [theme.transitions.handleMotion('no-preference', 'reduce')]: {\n transition: `opacity ${transitionDuration}ms ease-out ${transitionDelay}ms`,\n },\n }),\n };\n};\n\ntype Props = {\n children: React.ReactElement;\n visible: boolean;\n};\n\n/**\n * Cross fade transition component that is tied a bit too much to the logs containers so not very useful elsewhere\n * right now.\n */\nexport function LogsCrossFadeTransition(props: Props) {\n const { visible, children } = props;\n const transitionRef = useRef(null);\n const styles = useStyles2(getStyles);\n return (\n <CSSTransition\n in={visible}\n mountOnEnter={true}\n unmountOnExit={true}\n timeout={transitionDuration + transitionDelay}\n classNames={{\n enter: styles.logsEnter,\n enterActive: styles.logsEnterActive,\n exit: styles.logsExit,\n exitActive: styles.logsExitActive,\n }}\n nodeRef={transitionRef}\n >\n <div ref={transitionRef}>{children}</div>\n </CSSTransition>\n );\n}\n","import { PureComponent } from 'react';\nimport * as React from 'react';\nimport { connect, ConnectedProps } from 'react-redux';\n\nimport {\n AbsoluteTimeRange,\n hasLogsContextSupport,\n hasLogsContextUiSupport,\n LoadingState,\n LogRowModel,\n RawTimeRange,\n EventBus,\n SplitOpen,\n DataFrame,\n SupplementaryQueryType,\n DataQueryResponse,\n LogRowContextOptions,\n DataSourceWithLogsContextSupport,\n DataSourceApi,\n hasToggleableQueryFiltersSupport,\n DataSourceWithQueryModificationSupport,\n hasQueryModificationSupport,\n} from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { getDataSourceSrv } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport { PanelChrome } from '@grafana/ui';\nimport { MIXED_DATASOURCE_NAME } from 'app/plugins/datasource/mixed/MixedDataSource';\nimport { GetFieldLinksFn } from 'app/plugins/panel/logs/types';\nimport { ExploreItemState } from 'app/types/explore';\nimport { StoreState } from 'app/types/store';\n\nimport { getTimeZone } from '../../profile/state/selectors';\nimport {\n addResultsToCache,\n clearCache,\n loadSupplementaryQueryData,\n selectIsWaitingForData,\n setSupplementaryQueryEnabled,\n} from '../state/query';\nimport { updateTimeRange, loadMoreLogs } from '../state/time';\nimport { LiveTailControls } from '../useLiveTailControls';\nimport { getFieldLinksForExplore } from '../utils/links';\n\nimport { LiveLogsWithTheme } from './LiveLogs';\nimport { Logs } from './Logs';\nimport { LogsCrossFadeTransition } from './utils/LogsCrossFadeTransition';\n\ninterface LogsContainerProps extends PropsFromRedux {\n width: number;\n exploreId: string;\n scanRange?: RawTimeRange;\n syncedTimes: boolean;\n loadingState: LoadingState;\n onClickFilterLabel: (key: string, value: string, frame?: DataFrame) => void;\n onClickFilterOutLabel: (key: string, value: string, frame?: DataFrame) => void;\n onStartScanning: () => void;\n onStopScanning: () => void;\n eventBus: EventBus;\n splitOpenFn: SplitOpen;\n scrollElement?: HTMLDivElement;\n isFilterLabelActive: (key: string, value: string, refId?: string) => Promise<boolean>;\n onClickFilterString: (value: string, refId?: string) => void;\n onClickFilterOutString: (value: string, refId?: string) => void;\n onPinLineCallback?: () => void;\n}\n\ntype DataSourceInstance =\n | DataSourceApi<DataQuery>\n | (DataSourceApi<DataQuery> & DataSourceWithLogsContextSupport<DataQuery>)\n | (DataSourceApi<DataQuery> & DataSourceWithQueryModificationSupport<DataQuery>);\n\ninterface LogsContainerState {\n dsInstances: Record<string, DataSourceInstance>;\n}\n\nclass LogsContainer extends PureComponent<LogsContainerProps, LogsContainerState> {\n state: LogsContainerState = {\n dsInstances: {},\n };\n\n componentDidMount() {\n this.updateDataSourceInstances();\n }\n\n componentDidUpdate(prevProps: LogsContainerProps) {\n if (prevProps.logsQueries !== this.props.logsQueries) {\n this.updateDataSourceInstances();\n }\n }\n\n private updateDataSourceInstances() {\n const { logsQueries, datasourceInstance } = this.props;\n if (!logsQueries || !datasourceInstance) {\n return;\n }\n\n const dsInstances: Record<string, DataSourceInstance> = {};\n\n // Not in mixed mode.\n if (datasourceInstance.uid !== MIXED_DATASOURCE_NAME) {\n logsQueries.forEach(({ refId }) => {\n dsInstances[refId] = datasourceInstance;\n });\n this.setState({ dsInstances });\n return;\n }\n\n // Mixed mode.\n const dsPromises: Array<Promise<{ ds: DataSourceApi; refId: string }>> = [];\n for (const query of logsQueries) {\n if (!query.datasource) {\n continue;\n }\n const mustCheck = !dsInstances[query.refId] || dsInstances[query.refId].uid !== query.datasource.uid;\n if (mustCheck) {\n dsPromises.push(\n new Promise((resolve) => {\n getDataSourceSrv()\n .get(query.datasource)\n .then((ds) => {\n resolve({ ds, refId: query.refId });\n });\n })\n );\n }\n }\n\n if (!dsPromises.length) {\n return;\n }\n\n Promise.all(dsPromises).then((instances) => {\n instances.forEach(({ ds, refId }) => {\n dsInstances[refId] = ds;\n });\n this.setState({ dsInstances });\n });\n }\n\n onChangeTime = (absoluteRange: AbsoluteTimeRange) => {\n const { exploreId, updateTimeRange } = this.props;\n updateTimeRange({ exploreId, absoluteRange });\n };\n\n loadMoreLogs = (absoluteRange: AbsoluteTimeRange) => {\n const { exploreId, loadMoreLogs } = this.props;\n loadMoreLogs({ exploreId, absoluteRange });\n };\n\n private getQuery(\n logsQueries: DataQuery[] | undefined,\n row: LogRowModel,\n datasourceInstance: DataSourceApi<DataQuery> & DataSourceWithLogsContextSupport<DataQuery>\n ) {\n // we need to find the query, and we need to be very sure that it's a query\n // from this datasource\n return (logsQueries ?? []).find(\n (q) => q.refId === row.dataFrame.refId && q.datasource != null && q.datasource.type === datasourceInstance.type\n );\n }\n\n getLogRowContext = async (\n row: LogRowModel,\n origRow: LogRowModel,\n options: LogRowContextOptions\n ): Promise<DataQueryResponse> => {\n const { logsQueries } = this.props;\n\n if (!origRow.dataFrame.refId || !this.state.dsInstances[origRow.dataFrame.refId]) {\n return Promise.resolve({\n data: [],\n });\n }\n\n const ds = this.state.dsInstances[origRow.dataFrame.refId];\n if (!hasLogsContextSupport(ds)) {\n return Promise.resolve({\n data: [],\n });\n }\n\n const query = this.getQuery(logsQueries, origRow, ds);\n return query\n ? ds.getLogRowContext(row, options, query)\n : Promise.resolve({\n data: [],\n });\n };\n\n getLogRowContextQuery = async (\n row: LogRowModel,\n options?: LogRowContextOptions,\n cacheFilters = true\n ): Promise<DataQuery | null> => {\n const { logsQueries } = this.props;\n\n if (!row.dataFrame.refId || !this.state.dsInstances[row.dataFrame.refId]) {\n return Promise.resolve(null);\n }\n\n const ds = this.state.dsInstances[row.dataFrame.refId];\n if (!hasLogsContextSupport(ds)) {\n return Promise.resolve(null);\n }\n\n const query = this.getQuery(logsQueries, row, ds);\n return query && ds.getLogRowContextQuery\n ? ds.getLogRowContextQuery(row, options, query, cacheFilters)\n : Promise.resolve(null);\n };\n\n getLogRowContextUi = (row: LogRowModel, runContextQuery?: () => void): React.ReactNode => {\n const { logsQueries } = this.props;\n\n if (!row.dataFrame.refId || !this.state.dsInstances[row.dataFrame.refId]) {\n return <></>;\n }\n\n const ds = this.state.dsInstances[row.dataFrame.refId];\n if (!hasLogsContextSupport(ds)) {\n return <></>;\n }\n\n const query = this.getQuery(logsQueries, row, ds);\n return query && hasLogsContextUiSupport(ds) && ds.getLogRowContextUi ? (\n ds.getLogRowContextUi(row, runContextQuery, query)\n ) : (\n <></>\n );\n };\n\n showContextToggle = (row?: LogRowModel): boolean => {\n if (!row?.dataFrame.refId || !this.state.dsInstances[row.dataFrame.refId]) {\n return false;\n }\n return hasLogsContextSupport(this.state.dsInstances[row.dataFrame.refId]);\n };\n\n getFieldLinks: GetFieldLinksFn = (field, rowIndex, dataFrame, vars) => {\n const { splitOpenFn, range } = this.props;\n return getFieldLinksForExplore({ field, rowIndex, splitOpenFn, range, dataFrame, vars });\n };\n\n logDetailsFilterAvailable = () => {\n return Object.values(this.state.dsInstances).some(\n (ds) => ds?.modifyQuery || hasQueryModificationSupport(ds) || hasToggleableQueryFiltersSupport(ds)\n );\n };\n\n filterValueAvailable = () => {\n return Object.values(this.state.dsInstances).some(\n (ds) => hasQueryModificationSupport(ds) && ds?.getSupportedQueryModifications().includes('ADD_STRING_FILTER')\n );\n };\n\n filterOutValueAvailable = () => {\n return Object.values(this.state.dsInstances).some(\n (ds) => hasQueryModificationSupport(ds) && ds?.getSupportedQueryModifications().includes('ADD_STRING_FILTER_OUT')\n );\n };\n\n addResultsToCache = () => {\n this.props.addResultsToCache(this.props.exploreId);\n };\n\n clearCache = () => {\n this.props.clearCache(this.props.exploreId);\n };\n\n loadLogsVolumeData = () => {\n this.props.loadSupplementaryQueryData(this.props.exploreId, SupplementaryQueryType.LogsVolume);\n };\n\n onSetLogsVolumeEnabled = (enabled: boolean) => {\n this.props.setSupplementaryQueryEnabled(this.props.exploreId, enabled, SupplementaryQueryType.LogsVolume);\n };\n\n render() {\n const {\n loading,\n loadingState,\n logRows,\n logsMeta,\n logsSeries,\n logsQueries,\n onClickFilterLabel,\n onClickFilterOutLabel,\n onStartScanning,\n onStopScanning,\n absoluteRange,\n timeZone,\n visibleRange,\n scanning,\n range,\n width,\n splitOpenFn,\n isLive,\n exploreId,\n logsVolume,\n scrollElement,\n onPinLineCallback,\n } = this.props;\n\n if (!logRows) {\n return null;\n }\n\n return (\n <>\n <LogsCrossFadeTransition visible={isLive}>\n <PanelChrome title={t('explore.logs-container.label-logs', 'Logs')}>\n <LiveTailControls exploreId={exploreId}>\n {(controls) => (\n <LiveLogsWithTheme\n logRows={logRows}\n timeZone={timeZone}\n stopLive={controls.stop}\n isPaused={this.props.isPaused}\n onPause={controls.pause}\n onResume={controls.resume}\n onClear={controls.clear}\n clearedAtIndex={this.props.clearedAtIndex}\n />\n )}\n </LiveTailControls>\n </PanelChrome>\n </LogsCrossFadeTransition>\n <LogsCrossFadeTransition visible={!isLive}>\n <Logs\n exploreId={exploreId}\n datasourceType={this.props.datasourceInstance?.type}\n logRows={logRows}\n logsMeta={logsMeta}\n logsSeries={logsSeries}\n logsVolumeEnabled={logsVolume.enabled}\n onSetLogsVolumeEnabled={this.onSetLogsVolumeEnabled}\n logsVolumeData={logsVolume.data}\n logsQueries={logsQueries}\n width={width}\n splitOpen={splitOpenFn}\n loading={loading}\n loadingState={loadingState}\n loadLogsVolumeData={this.loadLogsVolumeData}\n onChangeTime={this.onChangeTime}\n loadMoreLogs={this.loadMoreLogs}\n onClickFilterLabel={this.logDetailsFilterAvailable() ? onClickFilterLabel : undefined}\n onClickFilterOutLabel={this.logDetailsFilterAvailable() ? onClickFilterOutLabel : undefined}\n onStartScanning={onStartScanning}\n onStopScanning={onStopScanning}\n absoluteRange={absoluteRange}\n visibleRange={visibleRange}\n timeZone={timeZone}\n scanning={scanning}\n scanRange={range.raw}\n showContextToggle={this.showContextToggle}\n getRowContext={this.getLogRowContext}\n getRowContextQuery={this.getLogRowContextQuery}\n getLogRowContextUi={this.getLogRowContextUi}\n getFieldLinks={this.getFieldLinks}\n addResultsToCache={this.addResultsToCache}\n clearCache={this.clearCache}\n eventBus={this.props.eventBus}\n panelState={this.props.panelState}\n logsFrames={this.props.logsFrames}\n scrollElement={scrollElement}\n isFilterLabelActive={this.logDetailsFilterAvailable() ? this.props.isFilterLabelActive : undefined}\n range={range}\n onPinLineCallback={onPinLineCallback}\n onClickFilterString={this.filterValueAvailable() ? this.props.onClickFilterString : undefined}\n onClickFilterOutString={this.filterOutValueAvailable() ? this.props.onClickFilterOutString : undefined}\n />\n </LogsCrossFadeTransition>\n </>\n );\n }\n}\n\nfunction mapStateToProps(state: StoreState, { exploreId }: { exploreId: string }) {\n const explore = state.explore;\n const item: ExploreItemState = explore.panes[exploreId]!;\n const {\n logsResult,\n scanning,\n datasourceInstance,\n isLive,\n isPaused,\n clearedAtIndex,\n range,\n absoluteRange,\n supplementaryQueries,\n } = item;\n const loading = selectIsWaitingForData(exploreId)(state);\n const panelState = item.panelsState;\n const timeZone = getTimeZone(state.user);\n const logsVolume = supplementaryQueries[SupplementaryQueryType.LogsVolume];\n\n return {\n loading,\n logRows: logsResult?.rows,\n logsMeta: logsResult?.meta,\n logsSeries: logsResult?.series,\n logsQueries: logsResult?.queries,\n visibleRange: logsResult?.visibleRange,\n scanning,\n timeZone,\n datasourceInstance,\n isLive,\n isPaused,\n clearedAtIndex,\n range,\n absoluteRange,\n logsVolume,\n panelState,\n logsFrames: item.queryResponse.logsFrames,\n };\n}\n\nconst mapDispatchToProps = {\n updateTimeRange,\n loadMoreLogs,\n addResultsToCache,\n clearCache,\n loadSupplementaryQueryData,\n setSupplementaryQueryEnabled,\n};\n\nconst connector = connect(mapStateToProps, mapDispatchToProps);\ntype PropsFromRedux = ConnectedProps<typeof connector>;\n\nexport default connector(LogsContainer);\n","import { css } from '@emotion/css';\nimport { useRef } from 'react';\n\nimport {\n CoreApp,\n DataQueryResponse,\n DataSourceApi,\n GrafanaTheme2,\n hasSupplementaryQuerySupport,\n LoadingState,\n LogsDedupStrategy,\n SplitOpen,\n SupplementaryQueryType,\n TimeRange,\n} from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, reportInteraction } from '@grafana/runtime';\nimport { DataQuery, LogsSortOrder, TimeZone } from '@grafana/schema';\nimport { Button, Collapse, Icon, Tooltip, useStyles2 } from '@grafana/ui';\nimport store from 'app/core/store';\nimport { LogList } from 'app/features/logs/components/panel/LogList';\n\nimport { LogRows } from '../../logs/components/LogRows';\nimport { dataFrameToLogsModel } from '../../logs/logsModel';\nimport { SupplementaryResultError } from '../SupplementaryResultError';\n\nimport { SETTING_KEY_ROOT, SETTINGS_KEYS } from './utils/logs';\n\ntype Props = {\n queryResponse: DataQueryResponse | undefined;\n enabled: boolean;\n timeZone: TimeZone;\n queries: DataQuery[];\n datasourceInstance: DataSourceApi | null | undefined;\n splitOpen: SplitOpen;\n setLogsSampleEnabled: (enabled: boolean) => void;\n timeRange: TimeRange;\n};\n\nexport function LogsSamplePanel(props: Props) {\n const { queryResponse, timeZone, enabled, setLogsSampleEnabled, datasourceInstance, queries, splitOpen } = props;\n\n const styles = useStyles2(getStyles);\n\n const logsContainerRef = useRef<HTMLDivElement | null>(null);\n\n const onToggleLogsSampleCollapse = (isOpen: boolean) => {\n setLogsSampleEnabled(isOpen);\n reportInteraction('grafana_explore_logs_sample_toggle_clicked', {\n datasourceType: datasourceInstance?.type ?? 'unknown',\n type: isOpen ? 'open' : 'close',\n });\n };\n\n const OpenInSplitViewButton = () => {\n if (!datasourceInstance) {\n return null;\n }\n if (!hasSupplementaryQuerySupport(datasourceInstance, SupplementaryQueryType.LogsSample)) {\n return null;\n }\n\n const logSampleQueries = queries\n .map((query) => datasourceInstance.getSupplementaryQuery({ type: SupplementaryQueryType.LogsSample }, query))\n .filter((query): query is DataQuery => !!query);\n\n if (!logSampleQueries.length) {\n return null;\n }\n\n const onSplitOpen = () => {\n splitOpen({ queries: logSampleQueries, datasourceUid: datasourceInstance.uid });\n reportInteraction('grafana_explore_logs_sample_split_button_clicked', {\n datasourceType: datasourceInstance?.type ?? 'unknown',\n queriesCount: logSampleQueries.length,\n });\n };\n\n return (\n <Button size=\"sm\" className={styles.logSamplesButton} onClick={onSplitOpen}>\n <Trans i18nKey=\"explore.logs-sample-panel.open-in-split-view-button.open-logs-in-split-view\">\n Open logs in split view\n </Trans>\n </Button>\n );\n };\n\n let LogsSamplePanelContent: JSX.Element | null;\n\n if (queryResponse === undefined) {\n LogsSamplePanelContent = null;\n } else if (queryResponse.error !== undefined) {\n LogsSamplePanelContent = (\n <SupplementaryResultError\n error={queryResponse.error}\n title={t('explore.logs-sample-panel.title-failed-sample-query', 'Failed to load logs sample for this query')}\n />\n );\n } else if (queryResponse.state === LoadingState.Loading) {\n LogsSamplePanelContent = (\n <span>\n <Trans i18nKey=\"explore.logs-sample-panel.logs-sample-is-loading\">Logs sample is loading...</Trans>\n </span>\n );\n } else if (queryResponse.data.length === 0 || queryResponse.data.every((frame) => frame.length === 0)) {\n LogsSamplePanelContent = (\n <span>\n <Trans i18nKey=\"explore.logs-sample-panel.no-logs-sample-data\">No logs sample data.</Trans>\n </span>\n );\n } else {\n const logs = dataFrameToLogsModel(queryResponse.data);\n LogsSamplePanelContent =\n config.featureToggles.newLogsPanel && logsContainerRef.current ? (\n <LogList\n app={CoreApp.Explore}\n containerElement={logsContainerRef.current}\n enableLogDetails\n dedupStrategy={LogsDedupStrategy.none}\n displayedFields={[]}\n logOptionsStorageKey={SETTING_KEY_ROOT}\n logs={logs.rows}\n showControls\n showTime={store.getBool(SETTINGS_KEYS.showTime, true)}\n sortOrder={store.get(SETTINGS_KEYS.logsSortOrder) || LogsSortOrder.Descending}\n timeRange={props.timeRange}\n timeZone={timeZone}\n wrapLogMessage={store.getBool(SETTINGS_KEYS.wrapLogMessage, true)}\n />\n ) : (\n <LogRows\n logRows={logs.rows}\n dedupStrategy={LogsDedupStrategy.none}\n showLabels={store.getBool(SETTINGS_KEYS.showLabels, false)}\n showTime={store.getBool(SETTINGS_KEYS.showTime, true)}\n wrapLogMessage={store.getBool(SETTINGS_KEYS.wrapLogMessage, true)}\n prettifyLogMessage={store.getBool(SETTINGS_KEYS.prettifyLogMessage, false)}\n timeZone={timeZone}\n enableLogDetails\n scrollElement={null}\n timeRange={props.timeRange}\n />\n );\n }\n\n return queryResponse?.state !== LoadingState.NotStarted ? (\n <Collapse\n label={\n <div>\n <Trans i18nKey=\"explore.logs-sample-panel.label\">Logs sample</Trans>\n <Tooltip\n content={t('explore.logs-sample-panel.tooltip', 'Show log lines that contributed to visualized metrics')}\n >\n <Icon name=\"info-circle\" className={styles.infoTooltip} />\n </Tooltip>\n </div>\n }\n isOpen={enabled}\n onToggle={onToggleLogsSampleCollapse}\n >\n <OpenInSplitViewButton />\n <div className={styles.logContainer} ref={logsContainerRef}>\n {LogsSamplePanelContent}\n </div>\n </Collapse>\n ) : null;\n}\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n logSamplesButton: css({\n position: 'absolute',\n top: theme.spacing(1),\n right: theme.spacing(1),\n }),\n logContainer: css({\n overflow: config.featureToggles.newLogsPanel ? 'visible' : 'scroll',\n }),\n infoTooltip: css({\n marginLeft: theme.spacing(1),\n }),\n };\n};\n","import { css } from '@emotion/css';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { useStyles2, PanelContainer } from '@grafana/ui';\n\nexport const NoData = () => {\n const css = useStyles2(getStyles);\n return (\n <>\n <PanelContainer data-testid=\"explore-no-data\" className={css.wrapper}>\n <span className={css.message}>{'No data'}</span>\n </PanelContainer>\n </>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n wrapper: css({\n label: 'no-data-card',\n padding: theme.spacing(3),\n background: theme.colors.background.primary,\n borderRadius: theme.shape.radius.default,\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n flexGrow: 1,\n }),\n message: css({\n fontSize: theme.typography.h2.fontSize,\n padding: theme.spacing(4),\n color: theme.colors.text.disabled,\n }),\n});\n","import { css } from '@emotion/css';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans } from '@grafana/i18n';\nimport { LinkButton, CallToActionCard, Icon, useStyles2 } from '@grafana/ui';\nimport { contextSrv } from 'app/core/core';\nimport { AccessControlAction } from 'app/types/accessControl';\n\nfunction getCardStyles(theme: GrafanaTheme2) {\n return css({\n maxWidth: `${theme.breakpoints.values.lg}px`,\n marginTop: theme.spacing(2),\n alignSelf: 'center',\n });\n}\n\nexport const NoDataSourceCallToAction = () => {\n const cardStyles = useStyles2(getCardStyles);\n\n const canCreateDataSource =\n contextSrv.hasPermission(AccessControlAction.DataSourcesCreate) &&\n contextSrv.hasPermission(AccessControlAction.DataSourcesWrite);\n\n const message =\n 'Explore requires at least one data source. Once you have added a data source, you can query it here.';\n const footer = (\n <>\n <Icon name=\"rocket\" />\n <>\n <Trans i18nKey=\"explore.no-data-source-call-to-action.footer.pro-tip-define-sources-through-configuration-files\">\n {' '}\n ProTip: You can also define data sources through configuration files.{' '}\n </Trans>\n </>\n <a\n href=\"http://docs.grafana.org/administration/provisioning/?utm_source=explore#data-sources\"\n target=\"_blank\"\n rel=\"noreferrer\"\n className=\"text-link\"\n >\n <Trans i18nKey=\"explore.no-data-source-call-to-action.footer.learn-more\">Learn more</Trans>\n </a>\n </>\n );\n\n const ctaElement = (\n <LinkButton size=\"lg\" href=\"datasources/new\" icon=\"database\" disabled={!canCreateDataSource}>\n <Trans i18nKey=\"explore.no-data-source-call-to-action.cta-element.add-data-source\">Add data source</Trans>\n </LinkButton>\n );\n\n return <CallToActionCard callToActionElement={ctaElement} className={cardStyles} footer={footer} message={message} />;\n};\n","import { css } from '@emotion/css';\nimport { useEffect, useRef, useState } from 'react';\nimport { connect, ConnectedProps } from 'react-redux';\nimport { useToggle, useWindowSize } from 'react-use';\n\nimport { applyFieldOverrides, DataFrame, GrafanaTheme2, SplitOpen } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, reportInteraction } from '@grafana/runtime';\nimport { useStyles2, useTheme2, PanelChrome } from '@grafana/ui';\nimport { layeredLayoutThreshold } from 'app/plugins/panel/nodeGraph/NodeGraph';\nimport { StoreState } from 'app/types/store';\n\nimport { NodeGraph } from '../../../plugins/panel/nodeGraph/NodeGraph';\nimport { LayoutAlgorithm } from '../../../plugins/panel/nodeGraph/panelcfg.gen';\nimport { useCategorizeFrames } from '../../../plugins/panel/nodeGraph/useCategorizeFrames';\nimport { useLinks } from '../utils/links';\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n warningText: css({\n label: 'warningText',\n display: 'flex',\n alignItems: 'center',\n fontSize: theme.typography.bodySmall.fontSize,\n color: theme.colors.text.secondary,\n }),\n});\n\ninterface OwnProps {\n // Edges and Nodes are separate frames\n dataFrames: DataFrame[];\n exploreId: string;\n // When showing the node graph together with trace view we do some changes so it works better.\n withTraceView?: boolean;\n datasourceType: string;\n splitOpenFn: SplitOpen;\n}\n\ntype Props = OwnProps & ConnectedProps<typeof connector>;\n\nexport function UnconnectedNodeGraphContainer(props: Props) {\n const { dataFrames, range, splitOpenFn, withTraceView, datasourceType } = props;\n const getLinks = useLinks(range, splitOpenFn);\n const theme = useTheme2();\n const styles = useStyles2(getStyles);\n\n // This is implicit dependency that is needed for links to work. At some point when replacing variables in the link\n // it requires field to have a display property which is added by the overrides even though we don't add any field\n // overrides in explore.\n const frames = applyFieldOverrides({\n fieldConfig: {\n defaults: {},\n overrides: [],\n },\n data: dataFrames,\n // We don't need proper replace here as it is only used in getLinks and we use getFieldLinks\n replaceVariables: (value) => value,\n theme,\n });\n\n const { nodes } = useCategorizeFrames(frames);\n const [collapsed, toggleCollapsed] = useToggle(true);\n\n // Determine default layout algorithm based on node count\n const nodeCount = nodes[0]?.length || 0;\n const layoutAlgorithm = nodeCount > layeredLayoutThreshold ? LayoutAlgorithm.Force : LayoutAlgorithm.Layered;\n\n const toggled = () => {\n toggleCollapsed();\n reportInteraction('grafana_traces_node_graph_panel_clicked', {\n datasourceType: datasourceType,\n grafana_version: config.buildInfo.version,\n isExpanded: !collapsed,\n });\n };\n\n // Calculate node graph height based on window and top position, with some padding\n const { height: windowHeight } = useWindowSize();\n const containerRef = useRef<HTMLDivElement>(null);\n const [top, setTop] = useState(250);\n useEffect(() => {\n if (containerRef.current) {\n const { top } = containerRef.current.getBoundingClientRect();\n setTop(top);\n }\n }, [containerRef]);\n\n const height = windowHeight - top - 32;\n\n const countWarning =\n withTraceView && nodes[0]?.length > 1000 ? (\n <span className={styles.warningText}>\n {' '}\n <Trans i18nKey=\"explore.unconnected-node-graph-container.count-warning\" values={{ numNodes: nodes[0].length }}>\n ({'{{numNodes}}'} nodes, can be slow to load)\n </Trans>\n </span>\n ) : null;\n\n return (\n <PanelChrome\n title={t('explore.unconnected-node-graph-container.title-node-graph', 'Node graph')}\n titleItems={countWarning}\n // We allow collapsing this only when it is shown together with trace view.\n collapsible={!!withTraceView}\n collapsed={withTraceView ? collapsed : false}\n onToggleCollapse={withTraceView ? toggled : undefined}\n >\n <div\n ref={containerRef}\n style={\n withTraceView\n ? { height: 500 }\n : {\n minHeight: 600,\n height,\n }\n }\n >\n <NodeGraph dataFrames={frames} getLinks={getLinks} layoutAlgorithm={layoutAlgorithm} />\n </div>\n </PanelChrome>\n );\n}\n\nfunction mapStateToProps(state: StoreState, { exploreId }: OwnProps) {\n return {\n range: state.explore.panes[exploreId]!.range,\n };\n}\n\nconst connector = connect(mapStateToProps, {});\nexport const NodeGraphContainer = connector(UnconnectedNodeGraphContainer);\n","import { createSelector } from '@reduxjs/toolkit';\nimport { useCallback, useMemo } from 'react';\n\nimport { CoreApp, getNextRefId } from '@grafana/data';\nimport { reportInteraction } from '@grafana/runtime';\nimport { DataQuery, DataSourceRef } from '@grafana/schema';\nimport { ExploreItemState } from 'app/types/explore';\nimport { useDispatch, useSelector } from 'app/types/store';\n\nimport { getDatasourceSrv } from '../plugins/datasource_srv';\nimport { QueryEditorRows } from '../query/components/QueryEditorRows';\n\nimport { ContentOutlineItem } from './ContentOutline/ContentOutlineItem';\nimport { useQueryLibraryContext } from './QueryLibrary/QueryLibraryContext';\nimport { changeDatasource } from './state/datasource';\nimport { updateQueryLibraryRefAction } from './state/explorePane';\nimport { changeQueries, runQueries } from './state/query';\nimport { getExploreItemSelector } from './state/selectors';\n\ninterface Props {\n exploreId: string;\n changeCompactMode: (compact: boolean) => void;\n isOpen?: boolean;\n}\n\nconst makeSelectors = (exploreId: string) => {\n const exploreItemSelector = getExploreItemSelector(exploreId);\n return {\n getQueries: createSelector(exploreItemSelector, (s: ExploreItemState | undefined) => s!.queries),\n getQueryResponse: createSelector(exploreItemSelector, (s: ExploreItemState | undefined) => s!.queryResponse),\n getHistory: createSelector(exploreItemSelector, (s: ExploreItemState | undefined) => s!.history),\n getEventBridge: createSelector(exploreItemSelector, (s: ExploreItemState | undefined) => s!.eventBridge),\n getDatasourceInstanceSettings: createSelector(\n exploreItemSelector,\n (s: ExploreItemState | undefined) => getDatasourceSrv().getInstanceSettings(s!.datasourceInstance?.uid)!\n ),\n getQueryLibraryRef: createSelector(exploreItemSelector, (s) => s!.queryLibraryRef),\n };\n};\n\nexport const QueryRows = ({ exploreId, isOpen, changeCompactMode }: Props) => {\n const dispatch = useDispatch();\n const { openDrawer } = useQueryLibraryContext();\n const {\n getQueries,\n getDatasourceInstanceSettings,\n getQueryResponse,\n getHistory,\n getEventBridge,\n getQueryLibraryRef,\n } = useMemo(() => makeSelectors(exploreId), [exploreId]);\n\n const queries = useSelector(getQueries);\n const dsSettings = useSelector(getDatasourceInstanceSettings);\n const queryResponse = useSelector(getQueryResponse);\n const history = useSelector(getHistory);\n const eventBridge = useSelector(getEventBridge);\n const queryLibraryRef = useSelector(getQueryLibraryRef);\n\n const onRunQueries = useCallback(() => {\n dispatch(runQueries({ exploreId }));\n }, [dispatch, exploreId]);\n\n const onChange = useCallback(\n (newQueries: DataQuery[], options?: { skipAutoImport?: boolean }) => {\n dispatch(changeQueries({ exploreId, queries: newQueries, options }));\n },\n [dispatch, exploreId]\n );\n\n const onUpdateDatasources = useCallback(\n (datasource: DataSourceRef) => {\n dispatch(changeDatasource({ exploreId, datasource }));\n },\n [dispatch, exploreId]\n );\n\n const onAddQuery = useCallback(\n (query: DataQuery) => {\n onChange([...queries, { ...query, refId: getNextRefId(queries) }]);\n },\n [onChange, queries]\n );\n\n const onQueryCopied = () => {\n reportInteraction('grafana_explore_query_row_copy');\n };\n\n const onQueryReplacedFromLibrary = () => {\n reportInteraction('grafana_explore_query_replaced_from_library');\n };\n\n const onQueryRemoved = () => {\n reportInteraction('grafana_explore_query_row_remove');\n };\n\n const onQueryToggled = (queryStatus?: boolean) => {\n reportInteraction('grafana_query_row_toggle', queryStatus === undefined ? {} : { queryEnabled: queryStatus });\n };\n\n const onCancelQueryLibraryEdit = () => {\n // Store the current queryLibraryRef before clearing it\n const originalQueryRef = queryLibraryRef;\n\n // Clear the queryLibraryRef to exit editing mode\n dispatch(updateQueryLibraryRefAction({ exploreId, queryLibraryRef: undefined }));\n\n // Open drawer with the original query highlighted\n if (originalQueryRef) {\n openDrawer({\n datasourceFilters: [],\n options: {\n context: 'explore',\n highlightQuery: originalQueryRef,\n },\n });\n }\n };\n\n const onQueryOpenChanged = () => {\n // Disables compact mode when query is opened.\n // Compact mode can also be disabled by opening Content Outline.\n changeCompactMode(false);\n };\n\n return (\n <QueryEditorRows\n dsSettings={dsSettings}\n queries={queries}\n onQueriesChange={onChange}\n onUpdateDatasources={onUpdateDatasources}\n onAddQuery={onAddQuery}\n onRunQueries={onRunQueries}\n onQueryCopied={onQueryCopied}\n onQueryRemoved={onQueryRemoved}\n onQueryToggled={onQueryToggled}\n onQueryReplacedFromLibrary={onQueryReplacedFromLibrary}\n onQueryOpenChanged={onQueryOpenChanged}\n data={queryResponse}\n app={CoreApp.Explore}\n history={history}\n eventBus={eventBridge}\n queryLibraryRef={queryLibraryRef}\n onCancelQueryLibraryEdit={onCancelQueryLibraryEdit}\n isOpen={isOpen}\n queryRowWrapper={(children, refId) => (\n <ContentOutlineItem\n title={refId}\n icon=\"arrow\"\n key={refId}\n panelId=\"Queries\"\n customTopOffset={-10}\n level=\"child\"\n >\n {children}\n </ContentOutlineItem>\n )}\n />\n );\n};\n","import { css } from '@emotion/css';\nimport { cloneDeep } from 'lodash';\nimport { useEffect, useId, useRef, useState } from 'react';\nimport { useWindowSize } from 'react-use';\nimport { VariableSizeList as List } from 'react-window';\n\nimport { DataFrame, Field as DataFrameField } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { reportInteraction } from '@grafana/runtime';\nimport { Field, Switch } from '@grafana/ui';\n\nimport { ItemLabels } from './ItemLabels';\nimport RawListItem from './RawListItem';\nimport {\n getRawPrometheusListItemsFromDataFrame,\n RawPrometheusListItemEmptyValue,\n} from './utils/getRawPrometheusListItemsFromDataFrame';\n\nexport type instantQueryRawVirtualizedListData = {\n Value: string;\n __name__?: string;\n [index: string]: string | undefined;\n};\n\nexport interface RawListContainerProps {\n tableResult: DataFrame;\n}\n\nconst styles = {\n wrapper: css({\n height: '100%',\n overflow: 'scroll',\n }),\n switchWrapper: css({\n display: 'flex',\n flexDirection: 'row',\n marginBottom: 0,\n }),\n switchLabel: css({\n marginLeft: '15px',\n marginBottom: 0,\n }),\n switch: css({\n marginLeft: '10px',\n }),\n resultCount: css({\n marginBottom: '4px',\n }),\n header: css({\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n padding: '10px 0',\n fontSize: '12px',\n lineHeight: 1.25,\n }),\n};\n\nconst mobileWidthThreshold = 480;\nconst numberOfColumnsBeforeExpandedViewIsDefault = 2;\n\n/**\n * The container that provides the virtualized list to the child components\n * @param props\n * @constructor\n */\nconst RawListContainer = (props: RawListContainerProps) => {\n const { tableResult } = props;\n const dataFrame = cloneDeep(tableResult);\n const listRef = useRef<List | null>(null);\n\n const valueLabels = dataFrame.fields.filter((field) => field.name.includes('Value'));\n const items = getRawPrometheusListItemsFromDataFrame(dataFrame);\n const { width } = useWindowSize();\n const [isExpandedView, setIsExpandedView] = useState(\n width <= mobileWidthThreshold || valueLabels.length > numberOfColumnsBeforeExpandedViewIsDefault\n );\n\n const onContentClick = () => {\n setIsExpandedView(!isExpandedView);\n const props = {\n isExpanded: !isExpandedView,\n };\n reportInteraction('grafana_explore_prometheus_instant_query_ui_raw_toggle_expand', props);\n };\n\n useEffect(() => {\n // After the expanded view has updated, tell the list to re-render\n listRef.current?.resetAfterIndex(0, true);\n }, [isExpandedView]);\n\n const calculateInitialHeight = (length: number): number => {\n const maxListHeight = 600;\n const shortListLength = 10;\n\n if (length < shortListLength) {\n let sum = 0;\n for (let i = 0; i < length; i++) {\n sum += getListItemHeight(i, true);\n }\n\n return Math.min(maxListHeight, sum);\n }\n\n return maxListHeight;\n };\n\n const getListItemHeight = (itemIndex: number, isExpandedView: boolean) => {\n const singleLineHeight = 32;\n const additionalLineHeight = 22;\n if (!isExpandedView) {\n return singleLineHeight;\n }\n const item = items[itemIndex];\n\n // Height of 1.5 lines, plus the number of non-value attributes times the height of additional lines\n return 1.5 * singleLineHeight + (Object.keys(item).length - valueLabels.length) * additionalLineHeight;\n };\n\n const switchId = `isExpandedView ${useId()}`;\n\n return (\n <section>\n <header className={styles.header}>\n <Field\n className={styles.switchWrapper}\n label={t('explore.raw-list-container.label-expand-results', 'Expand results')}\n htmlFor={'isExpandedView'}\n noMargin\n >\n <div className={styles.switch}>\n <Switch\n onChange={onContentClick}\n id={switchId}\n value={isExpandedView}\n label={t('explore.raw-list-container.label-expand-results', 'Expand results')}\n />\n </div>\n </Field>\n\n <div className={styles.resultCount}>\n <Trans i18nKey=\"explore.raw-list-container.item-count\" values={{ numItems: items.length }}>\n Result series: {'{{numItems}}'}\n </Trans>\n </div>\n </header>\n\n <div role={'table'}>\n {\n <>\n {/* Show the value headings above all the values, but only if we're in the contracted view */}\n {valueLabels.length > 1 && !isExpandedView && (\n <ItemLabels valueLabels={valueLabels} expanded={isExpandedView} />\n )}\n <List\n ref={listRef}\n itemCount={items.length}\n className={styles.wrapper}\n itemSize={(index) => getListItemHeight(index, isExpandedView)}\n height={calculateInitialHeight(items.length)}\n width=\"100%\"\n >\n {({ index, style }) => {\n let filteredValueLabels: DataFrameField[] | undefined;\n if (isExpandedView) {\n filteredValueLabels = valueLabels.filter((valueLabel) => {\n const itemWithValue = items[index][valueLabel.name];\n return itemWithValue && itemWithValue !== RawPrometheusListItemEmptyValue;\n });\n }\n\n return (\n <div role=\"row\" style={{ ...style, overflow: 'hidden' }}>\n <RawListItem\n isExpandedView={isExpandedView}\n valueLabels={filteredValueLabels}\n totalNumberOfValues={valueLabels.length}\n listKey={items[index].__name__ || `item-${index}`}\n listItemData={items[index]}\n />\n </div>\n );\n }}\n </List>\n </>\n }\n </div>\n </section>\n );\n};\n\nexport default RawListContainer;\n","import { css } from '@emotion/css';\nimport { PureComponent } from 'react';\nimport { connect, ConnectedProps } from 'react-redux';\n\nimport { applyFieldOverrides, DataFrame, SelectableValue, SplitOpen } from '@grafana/data';\nimport { getTemplateSrv, reportInteraction } from '@grafana/runtime';\nimport { TimeZone } from '@grafana/schema';\nimport { RadioButtonGroup, Table, AdHocFilterItem, PanelChrome } from '@grafana/ui';\nimport { config } from 'app/core/config';\nimport { PANEL_BORDER } from 'app/core/constants';\nimport { ExploreItemState, TABLE_RESULTS_STYLE, TABLE_RESULTS_STYLES, TableResultsStyle } from 'app/types/explore';\nimport { StoreState } from 'app/types/store';\n\nimport { MetaInfoText } from '../MetaInfoText';\nimport RawListContainer from '../PrometheusListView/RawListContainer';\nimport { exploreDataLinkPostProcessorFactory } from '../utils/links';\n\ninterface RawPrometheusContainerProps {\n ariaLabel?: string;\n exploreId: string;\n width: number;\n timeZone: TimeZone;\n onCellFilterAdded?: (filter: AdHocFilterItem) => void;\n showRawPrometheus?: boolean;\n splitOpenFn: SplitOpen;\n}\n\ninterface PrometheusContainerState {\n resultsStyle: TableResultsStyle;\n}\n\nfunction mapStateToProps(state: StoreState, { exploreId }: RawPrometheusContainerProps) {\n const explore = state.explore;\n const item: ExploreItemState = explore.panes[exploreId]!;\n const { rawPrometheusResult, range, queryResponse } = item;\n const rawPrometheusFrame: DataFrame[] = rawPrometheusResult ? [rawPrometheusResult] : [];\n const loading = queryResponse.state;\n\n return { loading, tableResult: rawPrometheusFrame, range };\n}\n\nconst connector = connect(mapStateToProps, {});\n\ntype Props = RawPrometheusContainerProps & ConnectedProps<typeof connector>;\n\nexport class RawPrometheusContainer extends PureComponent<Props, PrometheusContainerState> {\n constructor(props: Props) {\n super(props);\n\n // If resultsStyle is undefined we won't render the toggle, and the default table will be rendered\n if (props.showRawPrometheus) {\n this.state = {\n resultsStyle: TABLE_RESULTS_STYLE.raw,\n };\n }\n }\n\n onChangeResultsStyle = (resultsStyle: TableResultsStyle) => {\n this.setState({ resultsStyle });\n };\n\n getTableHeight() {\n const { tableResult } = this.props;\n\n if (!tableResult || tableResult.length === 0) {\n return 200;\n }\n\n // tries to estimate table height\n return Math.max(Math.min(600, tableResult[0].length * 35) + 35);\n }\n\n renderLabel = () => {\n const spacing = css({\n display: 'flex',\n justifyContent: 'space-between',\n flex: '1',\n });\n const ALL_GRAPH_STYLE_OPTIONS: Array<SelectableValue<TableResultsStyle>> = TABLE_RESULTS_STYLES.map((style) => ({\n value: style,\n // capital-case it and switch `_` to ` `\n label: style[0].toUpperCase() + style.slice(1).replace(/_/, ' '),\n }));\n\n return (\n <div className={spacing}>\n <RadioButtonGroup\n onClick={() => {\n const props = {\n state:\n this.state.resultsStyle === TABLE_RESULTS_STYLE.table\n ? TABLE_RESULTS_STYLE.raw\n : TABLE_RESULTS_STYLE.table,\n };\n reportInteraction('grafana_explore_prometheus_instant_query_ui_toggle_clicked', props);\n }}\n size=\"sm\"\n options={ALL_GRAPH_STYLE_OPTIONS}\n value={this.state?.resultsStyle}\n onChange={this.onChangeResultsStyle}\n />\n </div>\n );\n };\n\n render() {\n const { loading, onCellFilterAdded, tableResult, width, splitOpenFn, range, ariaLabel, timeZone } = this.props;\n const height = this.getTableHeight();\n const tableWidth = width - config.theme.panelPadding * 2 - PANEL_BORDER;\n\n let dataFrames = tableResult;\n\n const dataLinkPostProcessor = exploreDataLinkPostProcessorFactory(splitOpenFn, range);\n\n if (dataFrames?.length) {\n dataFrames = applyFieldOverrides({\n data: dataFrames,\n timeZone,\n theme: config.theme2,\n replaceVariables: getTemplateSrv().replace.bind(getTemplateSrv()),\n fieldConfig: {\n defaults: {},\n overrides: [],\n },\n dataLinkPostProcessor,\n });\n }\n\n const frames = dataFrames?.filter(\n (frame: DataFrame | undefined): frame is DataFrame => !!frame && frame.length !== 0\n );\n\n const title = this.state.resultsStyle === TABLE_RESULTS_STYLE.raw ? 'Raw' : 'Table';\n const label = this.state?.resultsStyle !== undefined ? this.renderLabel() : 'Table';\n\n // Render table as default if resultsStyle is not set.\n const renderTable = !this.state?.resultsStyle || this.state?.resultsStyle === TABLE_RESULTS_STYLE.table;\n\n return (\n <PanelChrome title={title} actions={label} loadingState={loading}>\n {frames?.length && (\n <>\n {renderTable && (\n <Table\n ariaLabel={ariaLabel}\n data={frames[0]}\n width={tableWidth}\n height={height}\n onCellFilterAdded={onCellFilterAdded}\n />\n )}\n {this.state?.resultsStyle === TABLE_RESULTS_STYLE.raw && <RawListContainer tableResult={frames[0]} />}\n </>\n )}\n {!frames?.length && <MetaInfoText metaItems={[{ value: '0 series returned' }]} />}\n </PanelChrome>\n );\n }\n}\n\nexport default connector(RawPrometheusContainer);\n","import { CSSProperties, useRef } from 'react';\nimport Transition, { ExitHandler } from 'react-transition-group/Transition';\n\ninterface Props {\n duration: number;\n children: JSX.Element;\n in: boolean;\n unmountOnExit?: boolean;\n onExited?: ExitHandler<HTMLDivElement>;\n}\n\nexport const FadeIn = (props: Props) => {\n const transitionRef = useRef(null);\n const defaultStyle: CSSProperties = {\n transition: `opacity ${props.duration}ms linear`,\n opacity: 0,\n };\n\n const transitionStyles: { [str: string]: CSSProperties } = {\n exited: { opacity: 0, display: 'none' },\n entering: { opacity: 0 },\n entered: { opacity: 1 },\n exiting: { opacity: 0 },\n };\n\n return (\n <Transition\n in={props.in}\n timeout={props.duration}\n unmountOnExit={props.unmountOnExit || false}\n onExited={props.onExited}\n nodeRef={transitionRef}\n >\n {(state) => (\n <div\n ref={transitionRef}\n style={{\n ...defaultStyle,\n ...transitionStyles[state],\n }}\n >\n {props.children}\n </div>\n )}\n </Transition>\n );\n};\n","import { DataQueryError } from '@grafana/data';\nimport { Alert } from '@grafana/ui';\nimport { FadeIn } from 'app/core/components/Animations/FadeIn';\n\nexport interface ErrorContainerProps {\n queryError?: DataQueryError;\n}\n\nexport const ErrorContainer = (props: ErrorContainerProps) => {\n const { queryError } = props;\n const showError = queryError ? true : false;\n const duration = showError ? 100 : 10;\n const title = queryError ? 'Query error' : 'Unknown error';\n const message = queryError?.message || queryError?.data?.message || null;\n\n return (\n <FadeIn in={showError} duration={duration}>\n <Alert severity=\"error\" title={title} topSpacing={2}>\n {message}\n </Alert>\n </FadeIn>\n );\n};\n","import { LoadingState } from '@grafana/data';\nimport { useSelector } from 'app/types/store';\n\nimport { ErrorContainer } from './ErrorContainer';\n\ninterface Props {\n exploreId: string;\n}\nexport function ResponseErrorContainer(props: Props) {\n const queryResponse = useSelector((state) => state.explore.panes[props.exploreId]!.queryResponse);\n const queryError = queryResponse?.state === LoadingState.Error ? queryResponse?.error : undefined;\n\n // Errors with ref ids are shown below the corresponding query\n if (queryError?.refId) {\n return null;\n }\n\n return <ErrorContainer queryError={queryError} />;\n}\n","import { css } from '@emotion/css';\n\nimport { CoreApp, GrafanaTheme2 } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { Trans, t } from '@grafana/i18n';\nimport { ToolbarButton, useTheme2 } from '@grafana/ui';\n\nimport { useQueryLibraryContext } from './QueryLibrary/QueryLibraryContext';\nimport { type OnSelectQueryType } from './QueryLibrary/types';\n\ntype Props = {\n addQueryRowButtonDisabled?: boolean;\n addQueryRowButtonHidden?: boolean;\n richHistoryRowButtonHidden?: boolean;\n queryInspectorButtonActive?: boolean;\n\n onClickAddQueryRowButton: () => void;\n onClickQueryInspectorButton: () => void;\n onSelectQueryFromLibrary: OnSelectQueryType;\n};\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n containerMargin: css({\n display: 'flex',\n flexWrap: 'wrap',\n gap: theme.spacing(1),\n marginTop: theme.spacing(2),\n }),\n };\n};\n\nexport function SecondaryActions({\n addQueryRowButtonDisabled,\n addQueryRowButtonHidden,\n onClickAddQueryRowButton,\n onClickQueryInspectorButton,\n onSelectQueryFromLibrary,\n queryInspectorButtonActive,\n}: Props) {\n const theme = useTheme2();\n const styles = getStyles(theme);\n const { queryLibraryEnabled, openDrawer: openQueryLibraryDrawer } = useQueryLibraryContext();\n\n return (\n <div className={styles.containerMargin}>\n {!addQueryRowButtonHidden && (\n <>\n <ToolbarButton\n variant=\"canvas\"\n aria-label={t('explore.secondary-actions.query-add-button-aria-label', 'Add query')}\n onClick={onClickAddQueryRowButton}\n disabled={addQueryRowButtonDisabled}\n icon=\"plus\"\n >\n <Trans i18nKey=\"explore.secondary-actions.query-add-button\">Add query</Trans>\n </ToolbarButton>\n {queryLibraryEnabled && (\n <ToolbarButton\n data-testid={selectors.pages.Explore.General.addFromQueryLibrary}\n aria-label={t('explore.secondary-actions.add-from-query-library', 'Add from saved queries')}\n variant=\"canvas\"\n onClick={() =>\n openQueryLibraryDrawer({\n onSelectQuery: onSelectQueryFromLibrary,\n options: { context: CoreApp.Explore },\n })\n }\n icon=\"plus\"\n disabled={addQueryRowButtonDisabled}\n >\n <Trans i18nKey=\"explore.secondary-actions.add-from-query-library\">Add from saved queries</Trans>\n </ToolbarButton>\n )}\n </>\n )}\n <ToolbarButton\n variant={queryInspectorButtonActive ? 'active' : 'canvas'}\n aria-label={t('explore.secondary-actions.query-inspector-button-aria-label', 'Query inspector')}\n onClick={onClickQueryInspectorButton}\n icon=\"info-circle\"\n >\n <Trans i18nKey=\"explore.secondary-actions.query-inspector-button\">Query inspector</Trans>\n </ToolbarButton>\n </div>\n );\n}\n","import { css } from '@emotion/css';\nimport { PureComponent } from 'react';\nimport { connect, ConnectedProps } from 'react-redux';\n\nimport { applyFieldOverrides, SplitOpen, DataFrame, LoadingState, FieldType } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { getTemplateSrv } from '@grafana/runtime';\nimport { TimeZone } from '@grafana/schema';\nimport { Table, AdHocFilterItem, PanelChrome, withTheme2, Themeable2 } from '@grafana/ui';\nimport { config } from 'app/core/config';\nimport {\n hasDeprecatedParentRowIndex,\n migrateFromParentRowIndexToNestedFrames,\n} from 'app/plugins/panel/table/migrations';\nimport { ExploreItemState } from 'app/types/explore';\nimport { StoreState } from 'app/types/store';\n\nimport { LimitedDataDisclaimer } from '../LimitedDataDisclaimer';\nimport { MetaInfoText } from '../MetaInfoText';\nimport { selectIsWaitingForData } from '../state/query';\nimport { exploreDataLinkPostProcessorFactory } from '../utils/links';\n\nconst MAX_NUMBER_OF_COLUMNS = 20;\n\ninterface TableContainerProps extends Themeable2 {\n ariaLabel?: string;\n exploreId: string;\n width: number;\n timeZone: TimeZone;\n onCellFilterAdded?: (filter: AdHocFilterItem) => void;\n splitOpenFn: SplitOpen;\n}\n\nfunction mapStateToProps(state: StoreState, { exploreId }: TableContainerProps) {\n const explore = state.explore;\n const item: ExploreItemState = explore.panes[exploreId]!;\n const { tableResult, range } = item;\n const loadingInState = selectIsWaitingForData(exploreId);\n const loading = tableResult && tableResult.length > 0 ? false : loadingInState;\n return { loading, tableResult, range };\n}\n\nconst connector = connect(mapStateToProps, {});\n\ntype Props = TableContainerProps & ConnectedProps<typeof connector>;\ntype State = {\n showAll: boolean;\n};\n\nexport class TableContainer extends PureComponent<Props, State> {\n state = { showAll: false };\n\n hasSubFrames = (data: DataFrame) => data.fields.some((f) => f.type === FieldType.nestedFrames);\n\n getTableHeight(rowCount: number, hasSubFrames: boolean) {\n if (rowCount === 0) {\n return 200;\n }\n // tries to estimate table height, with a min of 300 and a max of 600\n // if there are multiple tables, there is no min\n return Math.min(600, Math.max(rowCount * 36, hasSubFrames ? 300 : 0) + 40 + 46);\n }\n\n getTableTitle(dataFrames: DataFrame[] | null, data: DataFrame, i: number) {\n let name = data.name;\n if (!name && (dataFrames?.length ?? 0) > 1) {\n name = data.refId || `${i}`;\n }\n\n return name\n ? t('explore.table.title-with-name', 'Table - {{name}}', { name, interpolation: { escapeValue: false } })\n : t('explore.table.title', 'Table');\n }\n\n showAll() {\n this.setState({\n showAll: true,\n });\n }\n\n render() {\n const { loading, onCellFilterAdded, tableResult, width, splitOpenFn, range, ariaLabel, timeZone, theme } =\n this.props;\n\n const { showAll } = this.state;\n\n let dataFrames = hasDeprecatedParentRowIndex(tableResult)\n ? migrateFromParentRowIndexToNestedFrames(tableResult)\n : tableResult;\n const dataLinkPostProcessor = exploreDataLinkPostProcessorFactory(splitOpenFn, range);\n\n let dataLimited = false;\n\n if (dataFrames?.length) {\n dataFrames = dataFrames.map((frame) => {\n frame.fields.forEach((field, index) => {\n const hidden = showAll ? false : index >= MAX_NUMBER_OF_COLUMNS;\n field.config.custom = { hidden };\n dataLimited = dataLimited || hidden;\n });\n return frame;\n });\n\n dataFrames = applyFieldOverrides({\n data: dataFrames,\n timeZone,\n theme: config.theme2,\n replaceVariables: getTemplateSrv().replace.bind(getTemplateSrv()),\n fieldConfig: {\n defaults: {},\n overrides: [],\n },\n dataLinkPostProcessor,\n });\n }\n\n const frames = dataFrames?.filter(\n (frame: DataFrame | undefined): frame is DataFrame => !!frame && frame.length !== 0\n );\n\n return (\n <>\n {frames && frames.length === 0 && (\n <PanelChrome title={t('explore.table.title', 'Table')} width={width} height={200}>\n {() => <MetaInfoText metaItems={[{ value: t('explore.table.no-data', '0 series returned') }]} />}\n </PanelChrome>\n )}\n {frames && frames.length > 0 && (\n <div className={css({ display: 'flex', flexDirection: 'column', gap: theme.spacing(1) })}>\n {frames.map((data, i) => (\n <PanelChrome\n key={data.refId || `table-${i}`}\n title={this.getTableTitle(dataFrames, data, i)}\n titleItems={[\n !showAll && dataLimited && (\n <LimitedDataDisclaimer\n toggleShowAllSeries={() => this.showAll()}\n info={\n <Trans i18nKey={'table.container.show-only-series'}>\n Showing only {{ MAX_NUMBER_OF_COLUMNS }} columns\n </Trans>\n }\n tooltip={t(\n 'table.container.content',\n 'Showing too many columns in a single table may impact performance and make data harder to read. Consider refining your queries.'\n )}\n buttonLabel={<Trans i18nKey={'table.container.show-all-series'}>Show all columns</Trans>}\n />\n ),\n ]}\n width={width}\n height={this.getTableHeight(data.length, this.hasSubFrames(data))}\n loadingState={loading ? LoadingState.Loading : undefined}\n >\n {(innerWidth, innerHeight) => (\n <Table\n ariaLabel={ariaLabel}\n data={data}\n width={innerWidth}\n height={innerHeight}\n onCellFilterAdded={onCellFilterAdded}\n />\n )}\n </PanelChrome>\n ))}\n </div>\n )}\n </>\n );\n }\n}\n\nexport const TableContainerWithTheme = withTheme2(TableContainer);\n\nexport default withTheme2(connector(TableContainer));\n","import { useMemo } from 'react';\n\nimport { DataFrame, DataLinksContext, SplitOpen, TimeRange } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { PanelChrome } from '@grafana/ui';\nimport { StoreState, useSelector } from 'app/types/store';\n\nimport { useExploreDataLinkPostProcessor } from '../hooks/useExploreDataLinkPostProcessor';\n\nimport { TraceView } from './TraceView';\nimport { transformDataFrames } from './utils/transform';\n\ninterface Props {\n dataFrames: DataFrame[];\n splitOpenFn: SplitOpen;\n exploreId: string;\n scrollElement?: Element;\n timeRange: TimeRange;\n}\n\nexport function TraceViewContainer(props: Props) {\n // At this point we only show single trace\n const frame = props.dataFrames[0];\n const { dataFrames, splitOpenFn, exploreId, scrollElement, timeRange } = props;\n const traceProp = useMemo(() => transformDataFrames(frame), [frame]);\n const datasource = useSelector(\n (state: StoreState) => state.explore.panes[props.exploreId]?.datasourceInstance ?? undefined\n );\n\n const dataLinkPostProcessor = useExploreDataLinkPostProcessor(splitOpenFn, timeRange);\n\n if (!traceProp) {\n return null;\n }\n\n return (\n <PanelChrome padding=\"none\" title={t('explore.trace-view-container.title-trace', 'Trace')}>\n <DataLinksContext.Provider value={{ dataLinkPostProcessor }}>\n <TraceView\n exploreId={exploreId}\n dataFrames={dataFrames}\n splitOpenFn={splitOpenFn}\n scrollElement={scrollElement}\n traceProp={traceProp}\n datasource={datasource}\n timeRange={timeRange}\n />\n </DataLinksContext.Provider>\n </PanelChrome>\n );\n}\n","import { css, cx } from '@emotion/css';\nimport { get, groupBy } from 'lodash';\nimport { PureComponent } from 'react';\nimport { connect, ConnectedProps } from 'react-redux';\nimport AutoSizer, { HorizontalSize } from 'react-virtualized-auto-sizer';\n\nimport {\n AbsoluteTimeRange,\n DataFrame,\n EventBus,\n getNextRefId,\n GrafanaTheme2,\n hasToggleableQueryFiltersSupport,\n LoadingState,\n QueryFixAction,\n RawTimeRange,\n SplitOpenOptions,\n store,\n SupplementaryQueryType,\n} from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { t } from '@grafana/i18n';\nimport { getDataSourceSrv, reportInteraction } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport {\n AdHocFilterItem,\n ErrorBoundaryAlert,\n PanelContainer,\n ScrollContainer,\n Themeable2,\n withTheme2,\n} from '@grafana/ui';\nimport { FILTER_FOR_OPERATOR, FILTER_OUT_OPERATOR } from '@grafana/ui/internal';\nimport { supportedFeatures } from 'app/core/history/richHistoryStorageProvider';\nimport { MIXED_DATASOURCE_NAME } from 'app/plugins/datasource/mixed/MixedDataSource';\nimport { StoreState } from 'app/types/store';\n\nimport { getTimeZone } from '../profile/state/selectors';\n\nimport { CONTENT_OUTLINE_LOCAL_STORAGE_KEYS, ContentOutline } from './ContentOutline/ContentOutline';\nimport { ContentOutlineContextProvider } from './ContentOutline/ContentOutlineContext';\nimport { ContentOutlineItem } from './ContentOutline/ContentOutlineItem';\nimport { CorrelationHelper } from './CorrelationHelper';\nimport { CustomContainer } from './CustomContainer';\nimport { ExploreToolbar } from './ExploreToolbar';\nimport { FlameGraphExploreContainer } from './FlameGraph/FlameGraphExploreContainer';\nimport { GraphContainer } from './Graph/GraphContainer';\nimport LogsContainer from './Logs/LogsContainer';\nimport { LogsSamplePanel } from './Logs/LogsSamplePanel';\nimport { NoData } from './NoData';\nimport { NoDataSourceCallToAction } from './NoDataSourceCallToAction';\nimport { NodeGraphContainer } from './NodeGraph/NodeGraphContainer';\nimport { QueryRows } from './QueryRows';\nimport RawPrometheusContainer from './RawPrometheus/RawPrometheusContainer';\nimport { ResponseErrorContainer } from './ResponseErrorContainer';\nimport { SecondaryActions } from './SecondaryActions';\nimport TableContainer from './Table/TableContainer';\nimport { TraceViewContainer } from './TraceView/TraceViewContainer';\nimport { changeDatasource } from './state/datasource';\nimport { changeSize, changeCompactMode } from './state/explorePane';\nimport { splitOpen } from './state/main';\nimport {\n addQueryRow,\n modifyQueries,\n scanStart,\n scanStopAction,\n selectIsWaitingForData,\n setQueries,\n setSupplementaryQueryEnabled,\n} from './state/query';\nimport { isSplit, selectExploreDSMaps } from './state/selectors';\nimport { updateTimeRange } from './state/time';\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n exploreMain: css({\n label: 'exploreMain',\n // Is needed for some transition animations to work.\n position: 'relative',\n marginTop: theme.spacing(3),\n display: 'flex',\n flexDirection: 'column',\n gap: theme.spacing(1),\n }),\n queryContainer: css({\n label: 'queryContainer',\n padding: theme.spacing(1),\n }),\n exploreContainer: css({\n label: 'exploreContainer',\n display: 'flex',\n flexDirection: 'column',\n paddingRight: theme.spacing(2),\n marginBottom: theme.spacing(2),\n }),\n wrapper: css({\n position: 'absolute',\n top: 0,\n left: theme.spacing(2),\n right: 0,\n bottom: 0,\n display: 'flex',\n }),\n };\n};\n\nexport interface ExploreProps extends Themeable2 {\n exploreId: string;\n theme: GrafanaTheme2;\n eventBus: EventBus;\n setShowQueryInspector: (value: boolean) => void;\n showQueryInspector: boolean;\n}\n\ninterface ExploreState {\n contentOutlineVisible: boolean;\n}\n\nexport type Props = ExploreProps & ConnectedProps<typeof connector>;\n\n/**\n * Explore provides an area for quick query iteration for a given datasource.\n * Once a datasource is selected it populates the query section at the top.\n * When queries are run, their results are being displayed in the main section.\n * The datasource determines what kind of query editor it brings, and what kind\n * of results viewers it supports. The state is managed entirely in Redux.\n *\n * SPLIT VIEW\n *\n * Explore can have two Explore areas side-by-side. This is handled in `Wrapper.tsx`.\n * Since there can be multiple Explores (e.g., left and right) each action needs\n * the `exploreId` as first parameter so that the reducer knows which Explore state\n * is affected.\n *\n * DATASOURCE REQUESTS\n *\n * A click on Run Query creates transactions for all DataQueries for all expanded\n * result viewers. New runs are discarding previous runs. Upon completion a transaction\n * saves the result. The result viewers construct their data from the currently existing\n * transactions.\n *\n * The result viewers determine some of the query options sent to the datasource, e.g.,\n * `format`, to indicate eventual transformations by the datasources' result transformers.\n */\n\nexport class Explore extends PureComponent<Props, ExploreState> {\n scrollElement: HTMLDivElement | undefined;\n graphEventBus: EventBus;\n logsEventBus: EventBus;\n\n constructor(props: Props) {\n super(props);\n this.state = {\n contentOutlineVisible: store.getBool(CONTENT_OUTLINE_LOCAL_STORAGE_KEYS.visible, true),\n };\n this.graphEventBus = props.eventBus.newScopedBus('graph', { onlyLocal: false });\n this.logsEventBus = props.eventBus.newScopedBus('logs', { onlyLocal: false });\n }\n\n onChangeTime = (rawRange: RawTimeRange) => {\n const { updateTimeRange, exploreId } = this.props;\n updateTimeRange({ exploreId, rawRange });\n };\n\n // Use this in help pages to set page to a single query\n onClickExample = (query: DataQuery) => {\n this.props.setQueries(this.props.exploreId, [query]);\n };\n\n onCellFilterAdded = (filter: AdHocFilterItem) => {\n const { value, key, operator } = filter;\n if (operator === FILTER_FOR_OPERATOR) {\n this.onClickFilterLabel(key, value);\n }\n\n if (operator === FILTER_OUT_OPERATOR) {\n this.onClickFilterOutLabel(key, value);\n }\n };\n\n onContentOutlineToogle = () => {\n store.set(CONTENT_OUTLINE_LOCAL_STORAGE_KEYS.visible, !this.state.contentOutlineVisible);\n this.setState((state) => {\n const newContentOutlineVisible = this.props.compact ? true : !state.contentOutlineVisible;\n reportInteraction('explore_toolbar_contentoutline_clicked', {\n item: 'outline',\n type: newContentOutlineVisible ? 'open' : 'close',\n });\n return {\n contentOutlineVisible: newContentOutlineVisible,\n };\n });\n this.props.changeCompactMode(this.props.exploreId, false);\n };\n\n /**\n * Used by Logs details.\n * Returns true if the query identified by `refId` has a filter with the provided key and value.\n * @alpha\n */\n isFilterLabelActive = async (key: string, value: string | number, refId?: string) => {\n const query = this.props.queries.find((q) => q.refId === refId);\n if (!query) {\n return false;\n }\n const ds = await getDataSourceSrv().get(query.datasource);\n if (hasToggleableQueryFiltersSupport(ds) && ds.queryHasFilter(query, { key, value: value.toString() })) {\n return true;\n }\n return false;\n };\n\n /**\n * Used by Logs details.\n */\n onClickFilterLabel = (key: string, value: string | number, frame?: DataFrame) => {\n this.onModifyQueries(\n {\n type: 'ADD_FILTER',\n options: { key, value: value.toString() },\n frame,\n },\n frame?.refId\n );\n };\n\n /**\n * Used by Logs details.\n */\n onClickFilterOutLabel = (key: string, value: string | number, frame?: DataFrame) => {\n this.onModifyQueries(\n {\n type: 'ADD_FILTER_OUT',\n options: { key, value: value.toString() },\n frame,\n },\n frame?.refId\n );\n };\n\n /**\n * Used by Logs Popover Menu.\n */\n onClickFilterString = (value: string | number, refId?: string) => {\n this.onModifyQueries({ type: 'ADD_STRING_FILTER', options: { value: value.toString() } }, refId);\n };\n\n /**\n * Used by Logs Popover Menu.\n */\n onClickFilterOutString = (value: string | number, refId?: string) => {\n this.onModifyQueries({ type: 'ADD_STRING_FILTER_OUT', options: { value: value.toString() } }, refId);\n };\n\n onClickAddQueryRowButton = () => {\n const { exploreId, queryKeys } = this.props;\n this.props.addQueryRow(exploreId, queryKeys.length);\n };\n\n /**\n * Used by Logs details.\n */\n onModifyQueries = (action: QueryFixAction, refId?: string) => {\n const modifier = async (query: DataQuery, modification: QueryFixAction) => {\n // This gives Logs Details support to modify the query that produced the log line.\n // If not present, all queries are modified.\n if (refId && refId !== query.refId) {\n return query;\n }\n const { datasource } = query;\n if (datasource == null) {\n return query;\n }\n const ds = await getDataSourceSrv().get(datasource);\n const toggleableFilters = ['ADD_FILTER', 'ADD_FILTER_OUT'];\n if (hasToggleableQueryFiltersSupport(ds) && toggleableFilters.includes(modification.type)) {\n return ds.toggleQueryFilter(query, {\n type: modification.type === 'ADD_FILTER' ? 'FILTER_FOR' : 'FILTER_OUT',\n options: modification.options ?? {},\n frame: modification.frame,\n });\n }\n if (ds.modifyQuery) {\n return ds.modifyQuery(query, modification);\n } else {\n return query;\n }\n };\n this.props.modifyQueries(this.props.exploreId, action, modifier);\n };\n\n onResize = (size: HorizontalSize) => {\n this.props.changeSize(this.props.exploreId, size);\n };\n\n onStartScanning = () => {\n // Scanner will trigger a query\n this.props.scanStart(this.props.exploreId);\n };\n\n onStopScanning = () => {\n this.props.scanStopAction({ exploreId: this.props.exploreId });\n };\n\n onUpdateTimeRange = (absoluteRange: AbsoluteTimeRange) => {\n const { exploreId, updateTimeRange } = this.props;\n updateTimeRange({ exploreId, absoluteRange });\n };\n\n /**\n * Used for interaction from the visualizations. Will open split view in compact mode.\n */\n onSplitOpen = (panelType: string) => {\n return async (options?: SplitOpenOptions) => {\n let compact = false;\n\n /**\n * Temporary fix grafana-clickhouse-datasource as it requires the query editor to be fully rendered to update the query\n * Proposed fixes:\n * - https://github.com/grafana/clickhouse-datasource/issues/1363 - handle query update in data source\n * - https://github.com/grafana/grafana/issues/110868 - allow data links to provide meta info if the link can be handled in compact mode (default to false)\n * Update:\n * More data source may struggle with this setting: https://github.com/grafana/grafana/issues/112075\n * We're making it enabled for tempo only and will try to make it optional for other data sources in the future.\n */\n const dsType = getDataSourceSrv().getInstanceSettings({ uid: options?.datasourceUid })?.type;\n if (dsType === 'tempo' || options?.queries?.every((q) => q.datasource?.type === 'tempo')) {\n compact = true;\n }\n\n this.props.splitOpen(options ? { ...options, compact } : options);\n if (options && this.props.datasourceInstance) {\n const target = (await getDataSourceSrv().get(options.datasourceUid)).type;\n const source =\n this.props.datasourceInstance.uid === MIXED_DATASOURCE_NAME\n ? get(this.props.queries, '0.datasource.type')\n : this.props.datasourceInstance.type;\n const tracking = {\n origin: 'panel',\n panelType,\n source,\n target,\n exploreId: this.props.exploreId,\n };\n reportInteraction('grafana_explore_split_view_opened', tracking);\n }\n };\n };\n\n onPinLineCallback = () => {\n this.setState({ contentOutlineVisible: true });\n };\n\n renderEmptyState(exploreContainerStyles: string) {\n return (\n <div className={cx(exploreContainerStyles)}>\n <NoDataSourceCallToAction />\n </div>\n );\n }\n\n renderNoData() {\n return <NoData />;\n }\n\n renderCustom(width: number) {\n const { timeZone, queryResponse, eventBus } = this.props;\n\n const groupedByPlugin = groupBy(queryResponse?.customFrames, 'meta.preferredVisualisationPluginId');\n\n return Object.entries(groupedByPlugin).map(([pluginId, frames], index) => {\n return (\n <ContentOutlineItem panelId={pluginId} title={pluginId} icon=\"plug\" key={index}>\n <CustomContainer\n key={index}\n timeZone={timeZone}\n pluginId={pluginId}\n frames={frames}\n state={queryResponse.state}\n timeRange={queryResponse.timeRange}\n height={400}\n width={width}\n splitOpenFn={this.onSplitOpen(pluginId)}\n eventBus={eventBus}\n />\n </ContentOutlineItem>\n );\n });\n }\n\n renderGraphPanel(width: number) {\n const { graphResult, timeZone, queryResponse, showFlameGraph } = this.props;\n\n return (\n <ContentOutlineItem panelId=\"Graph\" title={t('explore.explore.title-graph', 'Graph')} icon=\"graph-bar\">\n <GraphContainer\n data={graphResult!}\n height={showFlameGraph ? 180 : 400}\n width={width}\n timeRange={queryResponse.timeRange}\n timeZone={timeZone}\n onChangeTime={this.onUpdateTimeRange}\n annotations={queryResponse.annotations}\n splitOpenFn={this.onSplitOpen('graph')}\n loadingState={queryResponse.state}\n eventBus={this.graphEventBus}\n />\n </ContentOutlineItem>\n );\n }\n\n renderTablePanel(width: number) {\n const { exploreId, timeZone } = this.props;\n return (\n <ContentOutlineItem panelId=\"Table\" title={t('explore.explore.title-table', 'Table')} icon=\"table\">\n <TableContainer\n ariaLabel={selectors.pages.Explore.General.table}\n width={width}\n exploreId={exploreId}\n onCellFilterAdded={this.onCellFilterAdded}\n timeZone={timeZone}\n splitOpenFn={this.onSplitOpen('table')}\n />\n </ContentOutlineItem>\n );\n }\n\n renderRawPrometheus(width: number) {\n const { exploreId, datasourceInstance, timeZone } = this.props;\n return (\n <ContentOutlineItem\n panelId=\"Raw Prometheus\"\n title={t('explore.explore.title-raw-prometheus', 'Raw Prometheus')}\n icon=\"gf-prometheus\"\n >\n <RawPrometheusContainer\n showRawPrometheus={true}\n ariaLabel={selectors.pages.Explore.General.table}\n width={width}\n exploreId={exploreId}\n onCellFilterAdded={datasourceInstance?.modifyQuery ? this.onCellFilterAdded : undefined}\n timeZone={timeZone}\n splitOpenFn={this.onSplitOpen('table')}\n />\n </ContentOutlineItem>\n );\n }\n\n splitOpenFnLogs = this.onSplitOpen('logs');\n\n renderLogsPanel(width: number) {\n const { exploreId, syncedTimes, theme, queryResponse } = this.props;\n const spacing = parseInt(theme.spacing(2).slice(0, -2), 10);\n // Need to make ContentOutlineItem a flex container so the gap works\n const logsContentOutlineWrapper = css({\n display: 'flex',\n flexDirection: 'column',\n gap: theme.spacing(1),\n });\n return (\n <ContentOutlineItem\n panelId=\"Logs\"\n title={t('explore.explore.title-logs', 'Logs')}\n icon=\"gf-logs\"\n className={logsContentOutlineWrapper}\n >\n <LogsContainer\n exploreId={exploreId}\n loadingState={queryResponse.state}\n syncedTimes={syncedTimes}\n width={width - spacing}\n onClickFilterLabel={this.onClickFilterLabel}\n onClickFilterOutLabel={this.onClickFilterOutLabel}\n onStartScanning={this.onStartScanning}\n onStopScanning={this.onStopScanning}\n eventBus={this.logsEventBus}\n splitOpenFn={this.splitOpenFnLogs}\n scrollElement={this.scrollElement}\n isFilterLabelActive={this.isFilterLabelActive}\n onClickFilterString={this.onClickFilterString}\n onClickFilterOutString={this.onClickFilterOutString}\n onPinLineCallback={this.onPinLineCallback}\n />\n </ContentOutlineItem>\n );\n }\n\n renderLogsSamplePanel() {\n const {\n logsSample,\n timeZone,\n setSupplementaryQueryEnabled,\n exploreId,\n datasourceInstance,\n queries,\n queryResponse,\n } = this.props;\n\n return (\n <ContentOutlineItem\n panelId=\"Logs Sample\"\n title={t('explore.explore.title-logs-sample', 'Logs sample')}\n icon=\"gf-logs\"\n >\n <LogsSamplePanel\n queryResponse={logsSample.data}\n timeZone={timeZone}\n enabled={logsSample.enabled}\n queries={queries}\n datasourceInstance={datasourceInstance}\n splitOpen={this.onSplitOpen('logsSample')}\n setLogsSampleEnabled={(enabled: boolean) =>\n setSupplementaryQueryEnabled(exploreId, enabled, SupplementaryQueryType.LogsSample)\n }\n timeRange={queryResponse.timeRange}\n />\n </ContentOutlineItem>\n );\n }\n\n renderNodeGraphPanel() {\n const { exploreId, showTrace, queryResponse, datasourceInstance } = this.props;\n const datasourceType = datasourceInstance ? datasourceInstance?.type : 'unknown';\n\n return (\n <ContentOutlineItem\n panelId=\"Node Graph\"\n title={t('explore.explore.title-node-graph', 'Node graph')}\n icon=\"code-branch\"\n >\n <NodeGraphContainer\n dataFrames={queryResponse.nodeGraphFrames}\n exploreId={exploreId}\n withTraceView={showTrace}\n datasourceType={datasourceType}\n splitOpenFn={this.onSplitOpen('nodeGraph')}\n />\n </ContentOutlineItem>\n );\n }\n\n renderFlameGraphPanel() {\n const { queryResponse } = this.props;\n return (\n <ContentOutlineItem\n panelId=\"Flame Graph\"\n title={t('explore.explore.title-flame-graph', 'Flame graph')}\n icon=\"fire\"\n >\n <FlameGraphExploreContainer dataFrames={queryResponse.flameGraphFrames} />\n </ContentOutlineItem>\n );\n }\n\n renderTraceViewPanel() {\n const { queryResponse, exploreId } = this.props;\n const dataFrames = queryResponse.series.filter((series) => series.meta?.preferredVisualisationType === 'trace');\n\n return (\n // If there is no data (like 404) we show a separate error so no need to show anything here\n dataFrames.length && (\n <ContentOutlineItem panelId=\"Traces\" title={t('explore.explore.title-traces', 'Traces')} icon=\"file-alt\">\n <TraceViewContainer\n exploreId={exploreId}\n dataFrames={dataFrames}\n splitOpenFn={this.onSplitOpen('traceView')}\n scrollElement={this.scrollElement}\n timeRange={queryResponse.timeRange}\n />\n </ContentOutlineItem>\n )\n );\n }\n\n render() {\n const {\n datasourceInstance,\n exploreId,\n graphResult,\n queryResponse,\n isLive,\n theme,\n showMetrics,\n showTable,\n showRawPrometheus,\n showLogs,\n showTrace,\n showCustom,\n showNodeGraph,\n showFlameGraph,\n showLogsSample,\n correlationEditorDetails,\n correlationEditorHelperData,\n showQueryInspector,\n setShowQueryInspector,\n compact,\n queryLibraryRef,\n } = this.props;\n const { contentOutlineVisible } = this.state;\n const styles = getStyles(theme);\n const showPanels = queryResponse && queryResponse.state !== LoadingState.NotStarted;\n const richHistoryRowButtonHidden = !supportedFeatures().queryHistoryAvailable;\n const showNoData =\n queryResponse.state === LoadingState.Done &&\n [\n queryResponse.logsFrames,\n queryResponse.graphFrames,\n queryResponse.nodeGraphFrames,\n queryResponse.flameGraphFrames,\n queryResponse.tableFrames,\n queryResponse.rawPrometheusFrames,\n queryResponse.traceFrames,\n queryResponse.customFrames,\n ].every((e) => e.length === 0);\n\n let correlationsBox = undefined;\n const isCorrelationsEditorMode = correlationEditorDetails?.editorMode;\n const showCorrelationHelper = Boolean(isCorrelationsEditorMode || correlationEditorDetails?.correlationDirty);\n if (showCorrelationHelper && correlationEditorHelperData !== undefined) {\n correlationsBox = <CorrelationHelper exploreId={exploreId} correlations={correlationEditorHelperData} />;\n }\n\n return (\n <ContentOutlineContextProvider refreshDependencies={this.props.queries}>\n <ExploreToolbar\n exploreId={exploreId}\n onChangeTime={this.onChangeTime}\n onContentOutlineToogle={this.onContentOutlineToogle}\n isContentOutlineOpen={contentOutlineVisible}\n />\n <div\n style={{\n position: 'relative',\n height: '100%',\n paddingLeft: theme.spacing(2),\n }}\n >\n <div className={styles.wrapper}>\n {contentOutlineVisible && !compact && (\n <ContentOutline scroller={this.scrollElement} panelId={`content-outline-container-${exploreId}`} />\n )}\n <ScrollContainer\n data-testid={selectors.pages.Explore.General.scrollView}\n ref={(scrollElement) => (this.scrollElement = scrollElement || undefined)}\n >\n <div className={styles.exploreContainer}>\n {datasourceInstance ? (\n <>\n <ContentOutlineItem\n panelId=\"Queries\"\n title={t('explore.explore.title-queries', 'Queries')}\n icon=\"arrow\"\n mergeSingleChild={true}\n >\n <PanelContainer className={styles.queryContainer}>\n {correlationsBox}\n <QueryRows\n exploreId={exploreId}\n // Don't simply pass isOpen here to avoid opening the row when content outline is openend and\n // triggers exiting from compact mode. If it's confusing we can change the behavior to exit\n // compact mode explicitly with a button in the UI instead of exiting when row is opened or\n // content outline is opened.\n isOpen={compact ? false : undefined}\n changeCompactMode={(compact: boolean) =>\n this.props.changeCompactMode(this.props.exploreId, false)\n }\n />\n <SecondaryActions\n // do not allow people to add queries with potentially different datasources in correlations editor mode\n addQueryRowButtonDisabled={\n isLive || (isCorrelationsEditorMode && datasourceInstance.meta.mixed) || !!queryLibraryRef\n }\n // We cannot show multiple traces at the same time right now so we do not show add query button.\n //TODO:unification\n addQueryRowButtonHidden={false}\n richHistoryRowButtonHidden={richHistoryRowButtonHidden}\n queryInspectorButtonActive={showQueryInspector}\n onClickAddQueryRowButton={this.onClickAddQueryRowButton}\n onClickQueryInspectorButton={() => setShowQueryInspector(!showQueryInspector)}\n onSelectQueryFromLibrary={async (query) => {\n const { changeDatasource, queries, setQueries } = this.props;\n const newQueries = [\n ...queries,\n {\n ...query,\n refId: getNextRefId(queries),\n },\n ];\n setQueries(exploreId, newQueries);\n if (query.datasource?.uid) {\n const uniqueDatasources = new Set(newQueries.map((q) => q.datasource?.uid));\n const isMixed = uniqueDatasources.size > 1;\n const newDatasourceRef = {\n uid: isMixed ? MIXED_DATASOURCE_NAME : query.datasource.uid,\n };\n const shouldChangeDatasource = datasourceInstance.uid !== newDatasourceRef.uid;\n if (shouldChangeDatasource) {\n await changeDatasource({ exploreId, datasource: newDatasourceRef });\n }\n }\n }}\n />\n <ResponseErrorContainer exploreId={exploreId} />\n </PanelContainer>\n </ContentOutlineItem>\n <AutoSizer onResize={this.onResize} disableHeight>\n {({ width }) => {\n if (width === 0) {\n return null;\n }\n\n return (\n <main className={cx(styles.exploreMain)} style={{ width }}>\n <ErrorBoundaryAlert boundaryName=\"explore-main\">\n {showPanels && (\n <>\n {showMetrics && graphResult && (\n <ErrorBoundaryAlert boundaryName=\"explore-graph-panel\">\n {this.renderGraphPanel(width)}\n </ErrorBoundaryAlert>\n )}\n {showRawPrometheus && (\n <ErrorBoundaryAlert boundaryName=\"explore-raw-prometheus\">\n {this.renderRawPrometheus(width)}\n </ErrorBoundaryAlert>\n )}\n {showTable && (\n <ErrorBoundaryAlert boundaryName=\"explore-table-panel\">\n {this.renderTablePanel(width)}\n </ErrorBoundaryAlert>\n )}\n {showLogs && (\n <ErrorBoundaryAlert boundaryName=\"explore-logs-panel\">\n {this.renderLogsPanel(width)}\n </ErrorBoundaryAlert>\n )}\n {showNodeGraph && (\n <ErrorBoundaryAlert boundaryName=\"explore-node-graph-panel\">\n {this.renderNodeGraphPanel()}\n </ErrorBoundaryAlert>\n )}\n {showFlameGraph && (\n <ErrorBoundaryAlert boundaryName=\"explore-flame-graph-panel\">\n {this.renderFlameGraphPanel()}\n </ErrorBoundaryAlert>\n )}\n {showTrace && (\n <ErrorBoundaryAlert boundaryName=\"explore-trace-view-panel\">\n {this.renderTraceViewPanel()}\n </ErrorBoundaryAlert>\n )}\n {showLogsSample && (\n <ErrorBoundaryAlert boundaryName=\"explore-logs-sample-panel\">\n {this.renderLogsSamplePanel()}\n </ErrorBoundaryAlert>\n )}\n {showCustom && (\n <ErrorBoundaryAlert boundaryName=\"explore-custom-panel\">\n {this.renderCustom(width)}\n </ErrorBoundaryAlert>\n )}\n {showNoData && (\n <ErrorBoundaryAlert boundaryName=\"explore-no-data\">\n {this.renderNoData()}\n </ErrorBoundaryAlert>\n )}\n </>\n )}\n </ErrorBoundaryAlert>\n </main>\n );\n }}\n </AutoSizer>\n </>\n ) : (\n this.renderEmptyState(styles.exploreContainer)\n )}\n </div>\n </ScrollContainer>\n </div>\n </div>\n </ContentOutlineContextProvider>\n );\n }\n}\n\nfunction mapStateToProps(state: StoreState, { exploreId }: ExploreProps) {\n const explore = state.explore;\n const { syncedTimes } = explore;\n const item = explore.panes[exploreId]!;\n\n const timeZone = getTimeZone(state.user);\n const {\n datasourceInstance,\n queryKeys,\n queries,\n isLive,\n graphResult,\n tableResult,\n logsResult,\n showLogs,\n showMetrics,\n showTable,\n showTrace,\n showCustom,\n queryResponse,\n showNodeGraph,\n showFlameGraph,\n showRawPrometheus,\n supplementaryQueries,\n correlationEditorHelperData,\n compact,\n queryLibraryRef,\n } = item;\n\n const loading = selectIsWaitingForData(exploreId)(state);\n const logsSample = supplementaryQueries[SupplementaryQueryType.LogsSample];\n // We want to show logs sample only if there are no log results and if there is already graph or table result\n const showLogsSample = !!(logsSample.dataProvider !== undefined && !logsResult && (graphResult || tableResult));\n\n return {\n datasourceInstance,\n queryKeys,\n queries,\n isLive,\n graphResult,\n logsResult: logsResult ?? undefined,\n queryResponse,\n syncedTimes,\n timeZone,\n showLogs,\n showMetrics,\n showTable,\n showTrace,\n showCustom,\n showNodeGraph,\n showRawPrometheus,\n showFlameGraph,\n splitted: isSplit(state),\n compact,\n loading,\n logsSample,\n showLogsSample,\n correlationEditorHelperData,\n correlationEditorDetails: explore.correlationEditorDetails,\n exploreActiveDS: selectExploreDSMaps(state),\n queryLibraryRef,\n };\n}\n\nconst mapDispatchToProps = {\n changeDatasource,\n changeSize,\n modifyQueries,\n scanStart,\n scanStopAction,\n setQueries,\n updateTimeRange,\n addQueryRow,\n splitOpen,\n setSupplementaryQueryEnabled,\n changeCompactMode,\n};\n\nconst connector = connect(mapStateToProps, mapDispatchToProps);\n\nexport default withTheme2(connector(Explore));\n","import { css } from '@emotion/css';\nimport { useEffect, useState } from 'react';\nimport { connect, ConnectedProps } from 'react-redux';\n\nimport { CoreApp, GrafanaTheme2, LoadingState } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { reportInteraction } from '@grafana/runtime';\nimport { defaultTimeZone, TimeZone } from '@grafana/schema';\nimport { TabbedContainer, TabConfig, useStyles2 } from '@grafana/ui';\nimport { requestIdGenerator } from 'app/core/utils/explore';\nimport { ExploreDrawer } from 'app/features/explore/ExploreDrawer';\nimport { InspectDataTab } from 'app/features/inspector/InspectDataTab';\nimport { InspectErrorTab } from 'app/features/inspector/InspectErrorTab';\nimport { InspectJSONTab } from 'app/features/inspector/InspectJSONTab';\nimport { InspectStatsTab } from 'app/features/inspector/InspectStatsTab';\nimport { QueryInspector } from 'app/features/inspector/QueryInspector';\nimport { mixedRequestId } from 'app/plugins/datasource/mixed/MixedDataSource';\nimport { ExploreItemState } from 'app/types/explore';\nimport { StoreState } from 'app/types/store';\n\nimport { GetDataOptions } from '../query/state/PanelQueryRunner';\n\nimport { runQueries } from './state/query';\n\ninterface DispatchProps {\n exploreId: string;\n timeZone: TimeZone;\n onClose: () => void;\n}\n\ntype Props = DispatchProps & ConnectedProps<typeof connector>;\n\nexport function ExploreQueryInspector(props: Props) {\n const { onClose, queryResponse, timeZone, isMixed, exploreId } = props;\n const [dataOptions, setDataOptions] = useState<GetDataOptions>({\n withTransforms: false,\n withFieldConfig: true,\n });\n const dataFrames = queryResponse?.series || [];\n let errors = queryResponse?.errors;\n if (!errors?.length && queryResponse?.error) {\n errors = [queryResponse.error];\n }\n const styles = useStyles2(getStyles);\n\n useEffect(() => {\n reportInteraction('grafana_explore_query_inspector_opened');\n }, []);\n\n const statsTab: TabConfig = {\n label: t('explore.explore-query-inspector.stats-tab.label.stats', 'Stats'),\n value: 'stats',\n icon: 'chart-line',\n content: <InspectStatsTab data={queryResponse!} timeZone={queryResponse?.request?.timezone ?? defaultTimeZone} />,\n };\n\n const jsonTab: TabConfig = {\n label: t('explore.explore-query-inspector.json-tab.label.json', 'JSON'),\n value: 'json',\n icon: 'brackets-curly',\n content: <InspectJSONTab data={queryResponse} onClose={onClose} />,\n };\n\n const dataTab: TabConfig = {\n label: t('explore.explore-query-inspector.data-tab.label.data', 'Data'),\n value: 'data',\n icon: 'database',\n content: (\n <InspectDataTab\n data={dataFrames}\n dataName={'Explore'}\n isLoading={queryResponse.state === LoadingState.Loading}\n options={dataOptions}\n timeZone={timeZone}\n app={CoreApp.Explore}\n formattedDataDescription=\"Matches the format in the panel\"\n onOptionsChange={setDataOptions}\n />\n ),\n };\n\n const queryTab: TabConfig = {\n label: t('explore.explore-query-inspector.query-tab.label.query', 'Query'),\n value: 'query',\n icon: 'info-circle',\n content: (\n <div className={styles.queryInspectorWrapper}>\n <QueryInspector\n instanceId={isMixed ? mixedRequestId(0, requestIdGenerator(exploreId)) : requestIdGenerator(exploreId)}\n data={queryResponse}\n onRefreshQuery={() => props.runQueries({ exploreId })}\n />\n </div>\n ),\n };\n\n const tabs = [statsTab, queryTab, jsonTab, dataTab];\n if (errors?.length) {\n const errorTab: TabConfig = {\n label: t('explore.explore-query-inspector.error-tab.label.error', 'Error'),\n value: 'error',\n icon: 'exclamation-triangle',\n content: <InspectErrorTab errors={errors} />,\n };\n tabs.push(errorTab);\n }\n return (\n <ExploreDrawer>\n <TabbedContainer tabs={tabs} onClose={onClose} closeIconTooltip=\"Close query inspector\" />\n </ExploreDrawer>\n );\n}\n\nfunction mapStateToProps(state: StoreState, { exploreId }: { exploreId: string }) {\n const explore = state.explore;\n const item: ExploreItemState = explore.panes[exploreId]!;\n const { queryResponse } = item;\n\n return {\n queryResponse,\n isMixed: item.datasourceInstance?.meta.mixed || false,\n };\n}\n\nconst mapDispatchToProps = {\n runQueries,\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n queryInspectorWrapper: css({\n paddingBottom: theme.spacing(3),\n }),\n});\n\nconst connector = connect(mapStateToProps, mapDispatchToProps);\n\nexport default connector(ExploreQueryInspector);\n","import { css } from '@emotion/css';\nimport { useEffect, useMemo, useRef, useState } from 'react';\nimport { connect } from 'react-redux';\n\nimport { EventBusSrv, getTimeZone } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { stopQueryState } from 'app/core/utils/explore';\nimport { StoreState, useSelector } from 'app/types/store';\n\nimport Explore from './Explore';\nimport ExploreQueryInspector from './ExploreQueryInspector';\nimport { getExploreItemSelector } from './state/selectors';\n\nconst containerStyles = css({\n label: 'explorePaneContainer',\n display: 'flex',\n flexDirection: 'column',\n minWidth: '600px',\n height: '100%',\n});\n\ninterface Props {\n exploreId: string;\n}\n\n/*\n Connected components subscribe to the store before function components (using hooks) and can react to store changes. Thus, this connector function is called before the parent component (ExplorePage) is rerendered.\n This means that child components' mapStateToProps will be executed with a zombie `exploreId` that is not present anymore in the store if the pane gets closed.\n By connecting this component and returning the pane we workaround the zombie children issue here instead of modifying every children.\n This is definitely not the ideal solution and we should in the future invest more time in exploring other approaches to better handle this scenario, potentially by refactoring panels to be function components\n (therefore immune to this behaviour), or by forbidding them to access the store directly and instead pass them all the data they need via props or context.\n\n You can read more about this issue here: https://react-redux.js.org/api/hooks#stale-props-and-zombie-children\n*/\nfunction ExplorePaneContainerUnconnected({ exploreId }: Props) {\n useStopQueries(exploreId);\n const eventBus = useRef(new EventBusSrv());\n const ref = useRef(null);\n const [showQueryInspector, setShowQueryInspector] = useState(false);\n\n useEffect(() => {\n const bus = eventBus.current;\n return () => bus.removeAllListeners();\n }, []);\n\n return (\n <div className={containerStyles} ref={ref} data-testid={selectors.pages.Explore.General.container}>\n <Explore\n exploreId={exploreId}\n eventBus={eventBus.current}\n showQueryInspector={showQueryInspector}\n setShowQueryInspector={setShowQueryInspector}\n />\n {showQueryInspector && (\n <ExploreQueryInspector\n exploreId={exploreId}\n onClose={() => setShowQueryInspector(false)}\n timeZone={getTimeZone()}\n />\n )}\n </div>\n );\n}\n\nfunction mapStateToProps(state: StoreState, props: Props) {\n const pane = state.explore.panes[props.exploreId];\n\n return { pane };\n}\n\nconst connector = connect(mapStateToProps);\n\nexport const ExplorePaneContainer = connector(ExplorePaneContainerUnconnected);\n\nfunction useStopQueries(exploreId: string) {\n const paneSelector = useMemo(() => getExploreItemSelector(exploreId), [exploreId]);\n const paneRef = useRef<ReturnType<typeof paneSelector>>();\n paneRef.current = useSelector(paneSelector);\n\n useEffect(() => {\n return () => {\n stopQueryState(paneRef.current?.querySubscription);\n };\n }, []);\n}\n","import { useState } from 'react';\nimport { ConnectedProps, connect } from 'react-redux';\n\nimport { t } from '@grafana/i18n';\nimport { config, reportInteraction } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport { Button, Dropdown, Menu, ToolbarButton } from '@grafana/ui';\nimport { useSelector } from 'app/types/store';\n\nimport { changeDatasource } from './state/datasource';\nimport { setQueries } from './state/query';\nimport { isSplit, selectExploreDSMaps, selectPanesEntries } from './state/selectors';\n\nconst mapDispatchToProps = {\n setQueries,\n changeDatasource,\n};\n\nconst connector = connect(undefined, mapDispatchToProps);\n\ninterface ExploreRunQueryButtonProps {\n queries: DataQuery[];\n rootDatasourceUid?: string;\n disabled?: boolean;\n onClick?: () => void;\n}\n\nexport type Props = ConnectedProps<typeof connector> & ExploreRunQueryButtonProps;\n\n/*\nThis component does not validate datasources before running them. Root datasource validation should happen outside this component and can pass in an undefined if invalid\nIf query level validation is done and a query datasource is invalid, pass in disabled = true\n*/\n\nexport function ExploreRunQueryButton({\n rootDatasourceUid,\n queries,\n disabled = false,\n onClick,\n changeDatasource,\n setQueries,\n}: Props) {\n const [openRunQueryButton, setOpenRunQueryButton] = useState(false);\n const isPaneSplit = useSelector(isSplit);\n const exploreActiveDS = useSelector(selectExploreDSMaps);\n const panesEntries = useSelector(selectPanesEntries);\n\n const isDifferentDatasource = (uid: string, exploreId: string) =>\n !exploreActiveDS.dsToExplore.find((di) => di.datasource.uid === uid)?.exploreIds.includes(exploreId);\n\n // exploreId on where the query will be ran, and the datasource ID for the item's DS\n const runQueryText = (exploreId: string, dsUid?: string) => {\n // if the datasource or exploreID is undefined, it will be disabled, but give it default query button text\n return dsUid !== undefined && exploreId !== undefined && isDifferentDatasource(dsUid, exploreId)\n ? {\n fallbackText: 'Switch data source and run query',\n translation: t('explore.run-query.switch-datasource-button', 'Switch data source and run query'),\n }\n : {\n fallbackText: 'Run query',\n translation: t('explore.run-query.run-query-button', 'Run query'),\n };\n };\n\n const runQuery = async (exploreId: string) => {\n const differentDataSource = isDifferentDatasource(rootDatasourceUid!, exploreId);\n if (differentDataSource) {\n await changeDatasource({ exploreId, datasource: rootDatasourceUid! });\n }\n setQueries(exploreId, queries);\n\n reportInteraction('grafana_explore_query_history_run', {\n queryHistoryEnabled: config.queryHistoryEnabled,\n differentDataSource,\n });\n };\n\n const runButton = () => {\n const isInvalid = disabled || queries.length === 0 || rootDatasourceUid === undefined;\n if (!isPaneSplit) {\n const exploreId = exploreActiveDS.exploreToDS[0]?.exploreId; // may be undefined if explore is refreshed while the pane is up\n const buttonText = runQueryText(exploreId, rootDatasourceUid);\n return (\n <Button\n variant={'primary'}\n aria-label={buttonText.translation}\n onClick={() => {\n runQuery(exploreId);\n onClick?.();\n }}\n disabled={isInvalid || exploreId === undefined}\n >\n {buttonText.translation}\n </Button>\n );\n } else {\n const menu = (\n <Menu>\n {panesEntries.map((pane, i) => {\n const buttonText = runQueryText(pane[0], rootDatasourceUid);\n const paneLabel =\n i === 0 ? t('explore.run-query.left-pane', 'Left pane') : t('explore.run-query.right-pane', 'Right pane');\n return (\n <Menu.Item\n key={i}\n ariaLabel={buttonText.fallbackText}\n onClick={() => {\n runQuery(pane[0]);\n onClick?.();\n }}\n // eslint-disable-next-line @grafana/i18n/no-untranslated-strings\n label={`${paneLabel}: ${buttonText.translation}`}\n disabled={isInvalid || pane[0] === undefined}\n />\n );\n })}\n </Menu>\n );\n\n return (\n <Dropdown onVisibleChange={(state) => setOpenRunQueryButton(state)} placement=\"bottom-start\" overlay={menu}>\n <ToolbarButton\n aria-label={t(\n 'explore.explore-run-query-button.run-button.aria-label-run-query-options',\n 'Run query options'\n )}\n variant=\"canvas\"\n isOpen={openRunQueryButton}\n >\n {t('explore.run-query.run-query-button', 'Run query')}\n </ToolbarButton>\n </Dropdown>\n );\n }\n };\n\n return <>{runButton()}</>;\n}\n\nexport default connector(ExploreRunQueryButton);\n","import { useState } from 'react';\n\nimport { t } from '@grafana/i18n';\nimport { reportInteraction } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport { Button } from '@grafana/ui';\nimport { contextSrv } from 'app/core/services/context_srv';\nimport { useDispatch, useSelector } from 'app/types/store';\n\nimport { useQueryLibraryContext } from '../QueryLibrary/QueryLibraryContext';\nimport { changeQueries } from '../state/query';\nimport { selectExploreDSMaps } from '../state/selectors';\n\ntype Props = {\n query: DataQuery;\n};\n\nexport const RichHistoryAddToLibrary = ({ query }: Props) => {\n const [hasBeenSaved, setHasBeenSaved] = useState(false);\n const { openDrawer, queryLibraryEnabled } = useQueryLibraryContext();\n const dispatch = useDispatch();\n const exploreActiveDS = useSelector(selectExploreDSMaps);\n const exploreId = exploreActiveDS.exploreToDS[0]?.exploreId;\n\n const onSelectQuery = (newQuery: DataQuery) => {\n reportInteraction('grafana_explore_query_replaced_from_library');\n if (exploreId) {\n dispatch(changeQueries({ exploreId, queries: [newQuery] }));\n }\n };\n\n const buttonLabel = t('explore.rich-history-card.add-to-library', 'Save query');\n\n if (!contextSrv.isEditor) {\n return null;\n }\n\n return queryLibraryEnabled && !hasBeenSaved ? (\n <>\n <Button\n variant=\"secondary\"\n aria-label={buttonLabel}\n onClick={() => {\n openDrawer({\n query,\n onSelectQuery,\n options: {\n onSave: () => {\n setHasBeenSaved(true);\n },\n context: 'rich-history',\n },\n });\n }}\n >\n {buttonLabel}\n </Button>\n </>\n ) : null;\n};\n","import { css, cx } from '@emotion/css';\nimport { useCallback, useState } from 'react';\nimport * as React from 'react';\nimport { connect, ConnectedProps } from 'react-redux';\n\nimport { GrafanaTheme2, DataSourceApi } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, reportInteraction, getAppEvents } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport { TextArea, Button, IconButton, useStyles2 } from '@grafana/ui';\nimport { notifyApp } from 'app/core/actions';\nimport { createSuccessNotification } from 'app/core/copy/appNotification';\nimport { copyStringToClipboard } from 'app/core/utils/explore';\nimport { createUrlFromRichHistory, createQueryText } from 'app/core/utils/richHistory';\nimport { createAndCopyShortLink } from 'app/core/utils/shortLinks';\nimport { changeDatasource } from 'app/features/explore/state/datasource';\nimport { starHistoryItem, commentHistoryItem, deleteHistoryItem } from 'app/features/explore/state/history';\nimport { setQueries } from 'app/features/explore/state/query';\nimport { dispatch } from 'app/store/store';\nimport { ShowConfirmModalEvent } from 'app/types/events';\nimport { RichHistoryQuery } from 'app/types/explore';\nimport icnDatasourceSvg from 'img/icn-datasource.svg';\n\nimport ExploreRunQueryButton from '../ExploreRunQueryButton';\n\nimport { RichHistoryAddToLibrary } from './RichHistoryAddToLibrary';\n\nconst mapDispatchToProps = {\n changeDatasource,\n deleteHistoryItem,\n commentHistoryItem,\n starHistoryItem,\n setQueries,\n};\n\nconst connector = connect(undefined, mapDispatchToProps);\n\ninterface OwnProps<T extends DataQuery = DataQuery> {\n datasourceInstances?: DataSourceApi[];\n queryHistoryItem: RichHistoryQuery<T>;\n}\n\nexport type Props<T extends DataQuery = DataQuery> = ConnectedProps<typeof connector> & OwnProps<T>;\n\nconst getStyles = (theme: GrafanaTheme2) => {\n /* Hard-coded value so all buttons and icons on right side of card are aligned */\n const rightColumnWidth = '240px';\n const rightColumnContentWidth = '170px';\n\n /* If datasource was removed, card will have inactive color */\n const cardColor = theme.colors.background.secondary;\n\n return {\n queryCard: css({\n position: 'relative',\n display: 'flex',\n flexDirection: 'column',\n border: `1px solid ${theme.colors.border.weak}`,\n margin: theme.spacing(1, 0),\n backgroundColor: cardColor,\n borderRadius: theme.shape.radius.default,\n '.starred': {\n color: theme.v1.palette.orange,\n },\n }),\n cardRow: css({\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n padding: theme.spacing(1),\n borderBottom: 'none',\n ':first-of-type': {\n borderBottom: `1px solid ${theme.colors.border.weak}`,\n padding: theme.spacing(0.5, 1),\n },\n img: {\n height: `${theme.typography.fontSize}px`,\n maxWidth: `${theme.typography.fontSize}px`,\n marginRight: theme.spacing(1),\n },\n }),\n queryActionButtons: css({\n maxWidth: rightColumnContentWidth,\n display: 'flex',\n justifyContent: 'flex-end',\n fontSize: theme.typography.size.base,\n button: {\n marginLeft: theme.spacing(1),\n },\n }),\n queryContainer: css({\n fontWeight: theme.typography.fontWeightMedium,\n width: `calc(100% - ${rightColumnWidth})`,\n }),\n updateCommentContainer: css({\n width: `calc(100% + ${rightColumnWidth})`,\n marginTop: theme.spacing(1),\n }),\n comment: css({\n overflowWrap: 'break-word',\n fontSize: theme.typography.bodySmall.fontSize,\n fontWeight: theme.typography.fontWeightRegular,\n marginTop: theme.spacing(0.5),\n }),\n commentButtonRow: css({\n '> *': {\n marginTop: theme.spacing(1),\n marginRight: theme.spacing(1),\n },\n }),\n textArea: css({\n width: '100%',\n }),\n runButton: css({\n maxWidth: rightColumnContentWidth,\n display: 'flex',\n justifyContent: 'flex-end',\n button: {\n height: 'auto',\n padding: theme.spacing(0.5, 2),\n lineHeight: 1.4,\n span: {\n whiteSpace: 'normal !important',\n },\n },\n }),\n loader: css({\n position: 'absolute',\n width: '100%',\n height: '100%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: theme.colors.background.secondary,\n }),\n };\n};\n\nexport function RichHistoryCard(props: Props) {\n const { queryHistoryItem, commentHistoryItem, starHistoryItem, deleteHistoryItem, datasourceInstances } = props;\n\n const [activeUpdateComment, setActiveUpdateComment] = useState(false);\n const [comment, setComment] = useState<string | undefined>(queryHistoryItem.comment);\n const styles = useStyles2(getStyles);\n\n const cardRootDatasource = datasourceInstances\n ? datasourceInstances.find((di) => di.uid === queryHistoryItem.datasourceUid)\n : undefined;\n\n const onCopyQuery = async () => {\n const datasources = [...queryHistoryItem.queries.map((query) => query.datasource?.type || 'unknown')];\n reportInteraction('grafana_explore_query_history_copy_query', {\n datasources,\n mixed: Boolean(cardRootDatasource?.meta.mixed),\n });\n\n const queriesText = queryHistoryItem.queries\n .map((query) => {\n let queryDS = datasourceInstances?.find((di) => di.uid === queryHistoryItem.datasourceUid);\n if (queryDS?.meta.mixed) {\n queryDS = datasourceInstances?.find((di) => di.uid === query.datasource?.uid);\n }\n return createQueryText(query, queryDS);\n })\n .join('\\n');\n\n copyStringToClipboard(queriesText);\n dispatch(\n notifyApp(\n createSuccessNotification(t('explore.rich-history-notification.query-copied', 'Query copied to clipboard'))\n )\n );\n };\n\n const onCreateShortLink = async () => {\n const link = createUrlFromRichHistory(queryHistoryItem);\n await createAndCopyShortLink(link);\n };\n\n const onDeleteQuery = () => {\n const performDelete = (queryId: string) => {\n deleteHistoryItem(queryId);\n dispatch(\n notifyApp(createSuccessNotification(t('explore.rich-history-notification.query-deleted', 'Query deleted')))\n );\n reportInteraction('grafana_explore_query_history_deleted', {\n queryHistoryEnabled: config.queryHistoryEnabled,\n });\n };\n\n // For starred queries, we want confirmation. For non-starred, we don't.\n if (queryHistoryItem.starred) {\n getAppEvents().publish(\n new ShowConfirmModalEvent({\n title: t('explore.rich-history-card.delete-query-confirmation-title', 'Delete'),\n text: t(\n 'explore.rich-history-card.delete-starred-query-confirmation-text',\n 'Are you sure you want to permanently delete your starred query?'\n ),\n yesText: t('explore.rich-history-card.confirm-delete', 'Delete'),\n icon: 'trash-alt',\n onConfirm: () => performDelete(queryHistoryItem.id),\n })\n );\n } else {\n performDelete(queryHistoryItem.id);\n }\n };\n\n const onStarQuery = () => {\n starHistoryItem(queryHistoryItem.id, !queryHistoryItem.starred);\n reportInteraction('grafana_explore_query_history_starred', {\n queryHistoryEnabled: config.queryHistoryEnabled,\n newValue: !queryHistoryItem.starred,\n });\n };\n\n const toggleActiveUpdateComment = () => setActiveUpdateComment(!activeUpdateComment);\n\n const onUpdateComment = () => {\n commentHistoryItem(queryHistoryItem.id, comment);\n setActiveUpdateComment(false);\n reportInteraction('grafana_explore_query_history_commented', {\n queryHistoryEnabled: config.queryHistoryEnabled,\n });\n };\n\n const onCancelUpdateComment = () => {\n setActiveUpdateComment(false);\n setComment(queryHistoryItem.comment);\n };\n\n const onKeyDown = (keyEvent: React.KeyboardEvent) => {\n if (keyEvent.key === 'Enter' && (keyEvent.shiftKey || keyEvent.ctrlKey)) {\n onUpdateComment();\n }\n\n if (keyEvent.key === 'Escape') {\n onCancelUpdateComment();\n }\n };\n\n const updateComment = (\n <div\n className={styles.updateCommentContainer}\n aria-label={\n comment\n ? t('explore.rich-history-card.update-comment-form', 'Update comment form')\n : t('explore.rich-history-card.add-comment-form', 'Add comment form')\n }\n >\n <TextArea\n onKeyDown={onKeyDown}\n value={comment}\n placeholder={\n comment\n ? undefined\n : t('explore.rich-history-card.optional-description', 'An optional description of what the query does.')\n }\n onChange={(e) => setComment(e.currentTarget.value)}\n className={styles.textArea}\n />\n <div className={styles.commentButtonRow}>\n <Button onClick={onUpdateComment}>\n <Trans i18nKey=\"explore.rich-history-card.save-comment\">Save comment</Trans>\n </Button>\n <Button variant=\"secondary\" onClick={onCancelUpdateComment}>\n <Trans i18nKey=\"explore.rich-history-card.cancel\">Cancel</Trans>\n </Button>\n </div>\n </div>\n );\n\n const queryActionButtons = (\n <div className={styles.queryActionButtons}>\n <IconButton\n name=\"comment-alt\"\n onClick={toggleActiveUpdateComment}\n tooltip={\n queryHistoryItem.comment?.length > 0\n ? t('explore.rich-history-card.edit-comment-tooltip', 'Edit comment')\n : t('explore.rich-history-card.add-comment-tooltip', 'Add comment')\n }\n />\n <IconButton\n name=\"copy\"\n onClick={onCopyQuery}\n tooltip={t('explore.rich-history-card.copy-query-tooltip', 'Copy query to clipboard')}\n />\n {cardRootDatasource && (\n <IconButton\n name=\"share-alt\"\n onClick={onCreateShortLink}\n tooltip={\n <Trans i18nKey=\"explore.rich-history-card.copy-shortened-link-tooltip\">\n Copy shortened link to clipboard\n </Trans>\n }\n />\n )}\n <IconButton\n name=\"trash-alt\"\n title={t('explore.rich-history-card.delete-query-title', 'Delete query')}\n tooltip={t('explore.rich-history-card.delete-query-tooltip', 'Delete query')}\n onClick={onDeleteQuery}\n />\n <IconButton\n name={queryHistoryItem.starred ? 'favorite' : 'star'}\n iconType={queryHistoryItem.starred ? 'mono' : 'default'}\n onClick={onStarQuery}\n tooltip={\n queryHistoryItem.starred\n ? t('explore.rich-history-card.unstar-query-tooltip', 'Unstar query')\n : t('explore.rich-history-card.star-query-tooltip', 'Star query')\n }\n />\n </div>\n );\n\n return (\n <div className={styles.queryCard}>\n <div className={styles.cardRow}>\n <DatasourceInfo dsApi={cardRootDatasource} size=\"sm\" />\n\n {queryActionButtons}\n </div>\n <div className={cx(styles.cardRow)}>\n <div className={styles.queryContainer}>\n {queryHistoryItem?.queries.map((q, i) => {\n const queryDs = datasourceInstances?.find((ds) => ds.uid === q.datasource?.uid);\n return (\n <Query\n query={{ query: q, datasource: queryDs }}\n key={`${q}-${i}`}\n showDsInfo={cardRootDatasource?.meta.mixed}\n />\n );\n })}\n {!activeUpdateComment && queryHistoryItem.comment && (\n <div\n aria-label={t('explore.rich-history-card.query-comment-label', 'Query comment')}\n className={styles.comment}\n >\n {queryHistoryItem.comment}\n </div>\n )}\n {activeUpdateComment && updateComment}\n </div>\n {!activeUpdateComment && <RichHistoryAddToLibrary query={queryHistoryItem?.queries[0]} />}\n {!activeUpdateComment && (\n <div className={styles.runButton}>\n <ExploreRunQueryButton queries={queryHistoryItem.queries} rootDatasourceUid={cardRootDatasource?.uid} />\n </div>\n )}\n </div>\n </div>\n );\n}\n\nconst getQueryStyles = (theme: GrafanaTheme2) => ({\n queryRow: css({\n borderTop: `1px solid ${theme.colors.border.weak}`,\n display: 'flex',\n flexDirection: 'row',\n padding: theme.spacing(0.5, 0),\n gap: theme.spacing(0.5),\n ':first-child': {\n borderTop: 'none',\n },\n }),\n dsInfoContainer: css({\n display: 'flex',\n alignItems: 'center',\n }),\n queryText: css({\n wordBreak: 'break-all',\n }),\n});\n\ninterface QueryProps {\n query: {\n query: DataQuery;\n datasource?: DataSourceApi;\n };\n /** Show datasource info (icon+name) alongside the query text */\n showDsInfo?: boolean;\n}\n\nconst Query = ({ query, showDsInfo = false }: QueryProps) => {\n const styles = useStyles2(getQueryStyles);\n\n return (\n <div className={styles.queryRow}>\n {showDsInfo && (\n <div className={styles.dsInfoContainer}>\n <DatasourceInfo dsApi={query.datasource} size=\"md\" />\n {': '}\n </div>\n )}\n <span aria-label={t('explore.rich-history-card.query-text-label', 'Query text')} className={styles.queryText}>\n {createQueryText(query.query, query.datasource)}\n </span>\n </div>\n );\n};\n\nconst getDsInfoStyles = (size: 'sm' | 'md') => (theme: GrafanaTheme2) =>\n css({\n display: 'flex',\n alignItems: 'center',\n fontSize: theme.typography[size === 'sm' ? 'bodySmall' : 'body'].fontSize,\n fontWeight: theme.typography.fontWeightMedium,\n whiteSpace: 'nowrap',\n });\n\nfunction DatasourceInfo({ dsApi, size }: { dsApi?: DataSourceApi; size: 'sm' | 'md' }) {\n const getStyles = useCallback((theme: GrafanaTheme2) => getDsInfoStyles(size)(theme), [size]);\n const styles = useStyles2(getStyles);\n\n return (\n <div className={styles}>\n <img\n src={dsApi?.meta.info.logos.small || icnDatasourceSvg}\n alt={dsApi?.type || t('explore.rich-history-card.datasource-not-exist', 'Data source does not exist anymore')}\n aria-label={t('explore.rich-history-card.datasource-icon-label', 'Data source icon')}\n />\n <div aria-label={t('explore.rich-history-card.datasource-name-label', 'Data source name')}>\n {dsApi?.name || t('explore.rich-history-card.datasource-not-exist', 'Data source does not exist anymore')}\n </div>\n </div>\n );\n}\n\nexport default connector(RichHistoryCard);\n","import { css } from '@emotion/css';\nimport { useEffect } from 'react';\nimport { useAsync } from 'react-use';\n\nimport { DataSourceApi, GrafanaTheme2, SelectableValue } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, getDataSourceSrv } from '@grafana/runtime';\nimport { Button, FilterInput, MultiSelect, RangeSlider, Select, useStyles2 } from '@grafana/ui';\nimport { mapNumbertoTimeInSlider, mapQueriesToHeadings } from 'app/core/utils/richHistory';\nimport { SortOrder, RichHistorySearchFilters, RichHistorySettings } from 'app/core/utils/richHistoryTypes';\nimport { RichHistoryQuery } from 'app/types/explore';\n\nimport { getSortOrderOptions } from './RichHistory';\nimport RichHistoryCard from './RichHistoryCard';\n\nexport interface RichHistoryQueriesTabProps {\n queries: RichHistoryQuery[];\n totalQueries: number;\n loading: boolean;\n updateFilters: (filtersToUpdate?: Partial<RichHistorySearchFilters>) => void;\n clearRichHistoryResults: () => void;\n loadMoreRichHistory: () => void;\n richHistorySettings: RichHistorySettings;\n richHistorySearchFilters?: RichHistorySearchFilters;\n activeDatasources: string[];\n listOfDatasources: Array<{ name: string; uid: string }>;\n height: number;\n}\n\nconst getStyles = (theme: GrafanaTheme2, height: number) => {\n return {\n container: css({\n display: 'flex',\n }),\n labelSlider: css({\n fontSize: theme.typography.bodySmall.fontSize,\n '&:last-of-type': {\n marginTop: theme.spacing(3),\n },\n '&:first-of-type': {\n fontWeight: theme.typography.fontWeightMedium,\n marginBottom: theme.spacing(2),\n },\n }),\n containerContent: css({\n /* 134px is based on the width of the Query history tabs bar, so the content is aligned to right side of the tab */\n width: 'calc(100% - 134px)',\n }),\n containerSlider: css({\n width: '129px',\n marginRight: theme.spacing(1),\n }),\n fixedSlider: css({\n position: 'fixed',\n }),\n slider: css({\n bottom: '10px',\n height: `${height - 180}px`,\n width: '129px',\n padding: theme.spacing(1, 0),\n }),\n selectors: css({\n display: 'flex',\n justifyContent: 'space-between',\n flexWrap: 'wrap',\n }),\n filterInput: css({\n marginBottom: theme.spacing(1),\n }),\n multiselect: css({\n width: '100%',\n marginBottom: theme.spacing(1),\n }),\n sort: css({\n width: '170px',\n }),\n sessionName: css({\n display: 'flex',\n alignItems: 'flex-start',\n justifyContent: 'flex-start',\n marginTop: theme.spacing(3),\n h4: {\n margin: '0 10px 0 0',\n },\n }),\n heading: css({\n fontSize: theme.typography.h4.fontSize,\n margin: theme.spacing(2, 0.25, 1, 0.25),\n }),\n footer: css({\n height: '60px',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n fontWeight: theme.typography.fontWeightLight,\n fontSize: theme.typography.bodySmall.fontSize,\n a: {\n fontWeight: theme.typography.fontWeightMedium,\n marginLeft: theme.spacing(0.25),\n },\n }),\n queries: css({\n fontSize: theme.typography.bodySmall.fontSize,\n fontWeight: theme.typography.fontWeightRegular,\n marginLeft: theme.spacing(0.5),\n }),\n };\n};\n\nexport function RichHistoryQueriesTab(props: RichHistoryQueriesTabProps) {\n const {\n queries,\n totalQueries,\n loading,\n richHistorySearchFilters,\n updateFilters,\n clearRichHistoryResults,\n loadMoreRichHistory,\n richHistorySettings,\n height,\n listOfDatasources,\n activeDatasources,\n } = props;\n\n const styles = useStyles2(getStyles, height);\n\n // on mount, set filter to either active datasource or all datasources\n useEffect(() => {\n const datasourceFilters =\n !richHistorySettings.activeDatasourcesOnly && richHistorySettings.lastUsedDatasourceFilters\n ? richHistorySettings.lastUsedDatasourceFilters\n : activeDatasources;\n const filters: RichHistorySearchFilters = {\n search: '',\n sortOrder: SortOrder.Descending,\n datasourceFilters,\n from: 0,\n to: richHistorySettings.retentionPeriod,\n starred: false,\n };\n updateFilters(filters);\n\n return () => {\n clearRichHistoryResults();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const { value: datasourceFilterApis, loading: loadingDs } = useAsync(async () => {\n const datasourcesToGet = listOfDatasources.map((ds) => ds.uid);\n const dsGetProm = datasourcesToGet.map(async (dsf) => {\n try {\n // this get works off datasource names\n return getDataSourceSrv().get(dsf);\n } catch (e) {\n return Promise.resolve();\n }\n });\n\n if (dsGetProm !== undefined) {\n const enhancedDatasourceData = (await Promise.all(dsGetProm)).filter((dsi): dsi is DataSourceApi => !!dsi);\n return enhancedDatasourceData;\n } else {\n return [];\n }\n }, [richHistorySearchFilters?.datasourceFilters]);\n\n if (!richHistorySearchFilters) {\n return (\n <span>\n <Trans i18nKey=\"explore.rich-history-queries-tab.loading\">Loading...</Trans>\n </span>\n );\n }\n\n /* mappedQueriesToHeadings is an object where query headings (stringified dates/data sources)\n * are keys and arrays with queries that belong to that headings are values.\n */\n const mappedQueriesToHeadings = mapQueriesToHeadings(queries, richHistorySearchFilters.sortOrder);\n const sortOrderOptions = getSortOrderOptions();\n const partialResults = queries.length && queries.length !== totalQueries;\n const timeFilter = [\n richHistorySearchFilters.from || 0,\n richHistorySearchFilters.to || richHistorySettings.retentionPeriod,\n ];\n\n return (\n <div className={styles.container}>\n <div className={styles.containerSlider}>\n <div className={styles.fixedSlider}>\n <div className={styles.labelSlider}>\n <Trans i18nKey=\"explore.rich-history-queries-tab.filter-history\">Filter history</Trans>\n </div>\n <div className={styles.labelSlider}>{mapNumbertoTimeInSlider(timeFilter[0])}</div>\n <div className={styles.slider}>\n <RangeSlider\n tooltipAlwaysVisible={false}\n min={0}\n max={richHistorySettings.retentionPeriod}\n value={timeFilter}\n orientation=\"vertical\"\n formatTooltipResult={mapNumbertoTimeInSlider}\n reverse={true}\n onAfterChange={(value) => {\n updateFilters({ from: value![0], to: value![1] });\n }}\n />\n </div>\n <div className={styles.labelSlider}>{mapNumbertoTimeInSlider(timeFilter[1])}</div>\n </div>\n </div>\n\n <div className={styles.containerContent} data-testid=\"query-history-queries-tab\">\n <div className={styles.selectors}>\n {!richHistorySettings.activeDatasourcesOnly && (\n <MultiSelect\n className={styles.multiselect}\n options={listOfDatasources.map((ds) => {\n return { value: ds.name, label: ds.name };\n })}\n value={richHistorySearchFilters.datasourceFilters}\n placeholder={t(\n 'explore.rich-history-queries-tab.filter-placeholder',\n 'Filter queries for data sources(s)'\n )}\n aria-label={t('explore.rich-history-queries-tab.filter-aria-label', 'Filter queries for data sources(s)')}\n onChange={(options: SelectableValue[]) => {\n updateFilters({ datasourceFilters: options.map((option) => option.value) });\n }}\n />\n )}\n <div className={styles.filterInput}>\n <FilterInput\n escapeRegex={false}\n placeholder={t('explore.rich-history-queries-tab.search-placeholder', 'Search queries')}\n value={richHistorySearchFilters.search}\n onChange={(search: string) => updateFilters({ search })}\n />\n </div>\n <div\n aria-label={t('explore.rich-history-queries-tab.sort-aria-label', 'Sort queries')}\n className={styles.sort}\n >\n <Select\n value={sortOrderOptions.filter((order) => order.value === richHistorySearchFilters.sortOrder)}\n options={sortOrderOptions}\n placeholder={t('explore.rich-history-queries-tab.sort-placeholder', 'Sort queries by')}\n onChange={(e: SelectableValue<SortOrder>) => updateFilters({ sortOrder: e.value })}\n />\n </div>\n </div>\n\n {(loading || loadingDs) && (\n <span>\n <Trans i18nKey=\"explore.rich-history-queries-tab.loading-results\">Loading results...</Trans>\n </span>\n )}\n\n {!(loading || loadingDs) &&\n Object.keys(mappedQueriesToHeadings).map((heading) => {\n return (\n <div key={heading}>\n <div className={styles.heading}>\n {heading}{' '}\n <span className={styles.queries}>\n {partialResults ? (\n <Trans\n i18nKey=\"explore.rich-history-queries-tab.displaying-partial-queries\"\n defaults=\"Displaying {{ count }} queries\"\n values={{ count: mappedQueriesToHeadings[heading].length }}\n />\n ) : (\n <Trans\n i18nKey=\"explore.rich-history-queries-tab.displaying-queries\"\n defaults=\"{{ count }} queries\"\n values={{ count: mappedQueriesToHeadings[heading].length }}\n />\n )}\n </span>\n </div>\n {mappedQueriesToHeadings[heading].map((q) => {\n return <RichHistoryCard datasourceInstances={datasourceFilterApis} queryHistoryItem={q} key={q.id} />;\n })}\n </div>\n );\n })}\n {partialResults ? (\n <div>\n <Trans\n i18nKey=\"explore.rich-history-queries-tab.showing-queries\"\n defaults=\"Showing {{ shown }} of {{ total }} <0>Load more</0>\"\n values={{ shown: queries.length, total: totalQueries }}\n components={[\n <Button onClick={loadMoreRichHistory} key=\"loadMoreButton\">\n Load more\n </Button>,\n ]}\n />\n </div>\n ) : null}\n <div className={styles.footer}>\n {!config.queryHistoryEnabled\n ? t(\n 'explore.rich-history-queries-tab.history-local',\n 'The history is local to your browser and is not shared with others.'\n )\n : ''}\n </div>\n </div>\n </div>\n );\n}\n","import { css } from '@emotion/css';\n\nimport { GrafanaTheme2, SelectableValue } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { getAppEvents } from '@grafana/runtime';\nimport { useStyles2, Select, Button, Field, InlineField, InlineSwitch, Alert } from '@grafana/ui';\nimport { notifyApp } from 'app/core/actions';\nimport { createSuccessNotification } from 'app/core/copy/appNotification';\nimport { MAX_HISTORY_ITEMS } from 'app/core/history/RichHistoryLocalStorage';\nimport { dispatch } from 'app/store/store';\n\nimport { supportedFeatures } from '../../../core/history/richHistoryStorageProvider';\nimport { ShowConfirmModalEvent } from '../../../types/events';\n\nexport interface RichHistorySettingsProps {\n retentionPeriod: number;\n starredTabAsFirstTab: boolean;\n activeDatasourcesOnly: boolean;\n onChangeRetentionPeriod: (option: SelectableValue<number>) => void;\n toggleStarredTabAsFirstTab: () => void;\n toggleActiveDatasourcesOnly: () => void;\n deleteRichHistory: () => void;\n}\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n container: css({\n fontSize: theme.typography.bodySmall.fontSize,\n }),\n spaceBetween: css({\n marginBottom: theme.spacing(3),\n }),\n input: css({\n maxWidth: '200px',\n }),\n bold: css({\n fontWeight: theme.typography.fontWeightBold,\n }),\n bottomMargin: css({\n marginBottom: theme.spacing(1),\n }),\n };\n};\n\nexport function RichHistorySettingsTab(props: RichHistorySettingsProps) {\n const {\n retentionPeriod,\n starredTabAsFirstTab,\n activeDatasourcesOnly,\n onChangeRetentionPeriod,\n toggleStarredTabAsFirstTab,\n toggleActiveDatasourcesOnly,\n deleteRichHistory,\n } = props;\n const styles = useStyles2(getStyles);\n\n const retentionPeriodOptions = [\n { value: 2, label: t('explore.rich-history-settings-tab.retention-period.2-days', '2 days') },\n { value: 5, label: t('explore.rich-history-settings-tab.retention-period.5-days', '5 days') },\n { value: 7, label: t('explore.rich-history-settings-tab.retention-period.1-week', '1 week') },\n { value: 14, label: t('explore.rich-history-settings-tab.retention-period.2-weeks', '2 weeks') },\n ];\n const selectedOption = retentionPeriodOptions.find((v) => v.value === retentionPeriod);\n\n const onDelete = () => {\n getAppEvents().publish(\n new ShowConfirmModalEvent({\n title: t('explore.rich-history-settings-tab.delete-title', 'Delete'),\n text: t(\n 'explore.rich-history-settings-tab.delete-confirm-text',\n 'Are you sure you want to permanently delete your query history?'\n ),\n yesText: t('explore.rich-history-settings-tab.delete-confirm', 'Delete'),\n icon: 'trash-alt',\n onConfirm: () => {\n deleteRichHistory();\n dispatch(\n notifyApp(\n createSuccessNotification(\n t('explore.rich-history-settings-tab.query-history-deleted', 'Query history deleted')\n )\n )\n );\n },\n })\n );\n };\n\n return (\n <div className={styles.container}>\n {supportedFeatures().changeRetention ? (\n <Field\n label={t('explore.rich-history-settings-tab.history-time-span', 'History time span')}\n description={t(\n 'explore.rich-history-settings-tab.history-time-span-description',\n 'Select the period of time for which Grafana will save your query history. Up to {{MAX_HISTORY_ITEMS}} entries will be stored.',\n { MAX_HISTORY_ITEMS }\n )}\n >\n <div className={styles.input}>\n <Select value={selectedOption} options={retentionPeriodOptions} onChange={onChangeRetentionPeriod}></Select>\n </div>\n </Field>\n ) : (\n <Alert severity=\"info\" title={t('explore.rich-history-settings-tab.history-time-span', 'History time span')}>\n {t(\n 'explore.rich-history-settings-tab.alert-info',\n \"Grafana will keep entries up to {{optionLabel}}.Starred entries won't be deleted.\",\n {\n optionLabel: selectedOption?.label,\n }\n )}\n </Alert>\n )}\n <InlineField\n label={t(\n 'explore.rich-history-settings-tab.change-default-tab',\n 'Change the default active tab from “Query history” to “Starred”'\n )}\n className={styles.spaceBetween}\n >\n <InlineSwitch\n id=\"explore-query-history-settings-default-active-tab\"\n value={starredTabAsFirstTab}\n onChange={toggleStarredTabAsFirstTab}\n />\n </InlineField>\n {supportedFeatures().onlyActiveDataSource && (\n <InlineField\n label={t(\n 'explore.rich-history-settings-tab.only-show-active-datasource',\n 'Only show queries for data source currently active in Explore'\n )}\n className={styles.spaceBetween}\n >\n <InlineSwitch\n id=\"explore-query-history-settings-data-source-behavior\"\n value={activeDatasourcesOnly}\n onChange={toggleActiveDatasourcesOnly}\n />\n </InlineField>\n )}\n {supportedFeatures().clearHistory && (\n <div>\n <div className={styles.bold}>\n <Trans i18nKey=\"explore.rich-history-settings-tab.clear-query-history\">Clear query history</Trans>\n </div>\n <div className={styles.bottomMargin}>\n <Trans i18nKey=\"explore.rich-history-settings-tab.clear-history-info\">\n Delete all of your query history, permanently.\n </Trans>\n </div>\n <Button variant=\"destructive\" onClick={onDelete}>\n <Trans i18nKey=\"explore.rich-history-settings-tab.clear-query-history-button\">Clear query history</Trans>\n </Button>\n </div>\n )}\n </div>\n );\n}\n","import { css } from '@emotion/css';\nimport { useEffect } from 'react';\nimport { useAsync } from 'react-use';\n\nimport { DataSourceApi, GrafanaTheme2, SelectableValue } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, getDataSourceSrv } from '@grafana/runtime';\nimport { useStyles2, Select, MultiSelect, FilterInput, Button } from '@grafana/ui';\nimport { createDatasourcesList } from 'app/core/utils/richHistory';\nimport { SortOrder, RichHistorySearchFilters, RichHistorySettings } from 'app/core/utils/richHistoryTypes';\nimport { RichHistoryQuery } from 'app/types/explore';\nimport { useSelector } from 'app/types/store';\n\nimport { selectExploreDSMaps } from '../state/selectors';\n\nimport { getSortOrderOptions } from './RichHistory';\nimport RichHistoryCard from './RichHistoryCard';\n\nexport interface RichHistoryStarredTabProps {\n queries: RichHistoryQuery[];\n totalQueries: number;\n loading: boolean;\n updateFilters: (filtersToUpdate: Partial<RichHistorySearchFilters>) => void;\n clearRichHistoryResults: () => void;\n loadMoreRichHistory: () => void;\n richHistorySearchFilters?: RichHistorySearchFilters;\n richHistorySettings: RichHistorySettings;\n}\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n container: css({\n display: 'flex',\n }),\n containerContent: css({\n width: '100%',\n }),\n selectors: css({\n display: 'flex',\n justifyContent: 'space-between',\n flexWrap: 'wrap',\n }),\n multiselect: css({\n width: '100%',\n marginBottom: theme.spacing(1),\n }),\n filterInput: css({\n marginBottom: theme.spacing(1),\n }),\n sort: css({\n width: '170px',\n }),\n footer: css({\n height: '60px',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n fontWeight: theme.typography.fontWeightLight,\n fontSize: theme.typography.bodySmall.fontSize,\n a: {\n fontWeight: theme.typography.fontWeightMedium,\n marginLeft: theme.spacing(0.25),\n },\n }),\n };\n};\n\nexport function RichHistoryStarredTab(props: RichHistoryStarredTabProps) {\n const {\n updateFilters,\n clearRichHistoryResults,\n loadMoreRichHistory,\n richHistorySettings,\n queries,\n totalQueries,\n loading,\n richHistorySearchFilters,\n } = props;\n\n const styles = useStyles2(getStyles);\n const exploreActiveDS = useSelector(selectExploreDSMaps);\n\n const listOfDatasources = createDatasourcesList();\n\n useEffect(() => {\n const datasourceFilters =\n richHistorySettings.activeDatasourcesOnly && richHistorySettings.lastUsedDatasourceFilters\n ? richHistorySettings.lastUsedDatasourceFilters\n : exploreActiveDS.dsToExplore\n .map((eDs) => listOfDatasources.find((ds) => ds.uid === eDs.datasource?.uid)?.name)\n .filter((name): name is string => !!name);\n const filters: RichHistorySearchFilters = {\n search: '',\n sortOrder: SortOrder.Descending,\n datasourceFilters,\n from: 0,\n to: richHistorySettings.retentionPeriod,\n starred: true,\n };\n updateFilters(filters);\n return () => {\n clearRichHistoryResults();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const { value: datasourceFilterApis, loading: loadingDs } = useAsync(async () => {\n const datasourcesToGet =\n richHistorySearchFilters?.datasourceFilters && richHistorySearchFilters?.datasourceFilters.length > 0\n ? richHistorySearchFilters?.datasourceFilters\n : listOfDatasources.map((ds) => ds.uid);\n const dsGetProm = await datasourcesToGet.map(async (dsf) => {\n try {\n // this get works off datasource names\n return getDataSourceSrv().get(dsf);\n } catch (e) {\n return Promise.resolve();\n }\n });\n\n if (dsGetProm !== undefined) {\n const enhancedDatasourceData = (await Promise.all(dsGetProm)).filter((dsi): dsi is DataSourceApi => !!dsi);\n //setDatasourceFilterApiList(enhancedDatasourceData)\n return enhancedDatasourceData;\n } else {\n return [];\n }\n }, [richHistorySearchFilters?.datasourceFilters]);\n\n if (!richHistorySearchFilters) {\n return (\n <span>\n <Trans i18nKey=\"explore.rich-history-starred-tab.loading\">Loading...</Trans>;\n </span>\n );\n }\n\n const sortOrderOptions = getSortOrderOptions();\n\n return (\n <div className={styles.container}>\n <div className={styles.containerContent}>\n <div className={styles.selectors}>\n {!richHistorySettings.activeDatasourcesOnly && (\n <MultiSelect\n className={styles.multiselect}\n options={listOfDatasources.map((ds) => {\n return { value: ds.name, label: ds.name };\n })}\n value={richHistorySearchFilters.datasourceFilters}\n placeholder={t(\n 'explore.rich-history-starred-tab.filter-queries-placeholder',\n 'Filter queries for data sources(s)'\n )}\n aria-label={t(\n 'explore.rich-history-starred-tab.filter-queries-aria-label',\n 'Filter queries for data sources(s)'\n )}\n onChange={(options: SelectableValue[]) => {\n updateFilters({ datasourceFilters: options.map((option) => option.value) });\n }}\n />\n )}\n <div className={styles.filterInput}>\n <FilterInput\n escapeRegex={false}\n placeholder={t('explore.rich-history-starred-tab.search-queries-placeholder', 'Search queries')}\n value={richHistorySearchFilters.search}\n onChange={(search: string) => updateFilters({ search })}\n />\n </div>\n <div\n aria-label={t('explore.rich-history-starred-tab.sort-queries-aria-label', 'Sort queries')}\n className={styles.sort}\n >\n <Select\n value={sortOrderOptions.filter((order) => order.value === richHistorySearchFilters.sortOrder)}\n options={sortOrderOptions}\n placeholder={t('explore.rich-history-starred-tab.sort-queries-placeholder', 'Sort queries by')}\n onChange={(e: SelectableValue<SortOrder>) => updateFilters({ sortOrder: e.value })}\n />\n </div>\n </div>\n {loading && loadingDs && (\n <span>\n <Trans i18nKey=\"explore.rich-history-starred-tab.loading-results\">Loading results...</Trans>\n </span>\n )}\n {!(loading && loadingDs) &&\n queries.map((q) => {\n return <RichHistoryCard queryHistoryItem={q} key={q.id} datasourceInstances={datasourceFilterApis} />;\n })}\n {queries.length && queries.length !== totalQueries ? (\n <div>\n <Trans\n i18nKey=\"explore.rich-history-starred-tab.showing-queries\"\n defaults=\"Showing {{ shown }} of {{ total }} <0>Load more</0>\"\n values={{ shown: queries.length, total: totalQueries }}\n components={[\n <Button onClick={loadMoreRichHistory} key=\"loadMoreButton\">\n Load more\n </Button>,\n ]}\n />\n </div>\n ) : null}\n <div className={styles.footer}>\n {!config.queryHistoryEnabled\n ? t(\n 'explore.rich-history-starred-tab.local-history-message',\n 'The history is local to your browser and is not shared with others.'\n )\n : ''}\n </div>\n </div>\n </div>\n );\n}\n","import { debounce } from 'lodash';\nimport { useState, useEffect } from 'react';\n\nimport { SelectableValue } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { t } from '@grafana/i18n';\nimport { TabbedContainer, TabConfig } from '@grafana/ui';\nimport { createDatasourcesList } from 'app/core/utils/richHistory';\nimport { SortOrder, RichHistorySearchFilters, RichHistorySettings } from 'app/core/utils/richHistoryTypes';\nimport { RichHistoryQuery } from 'app/types/explore';\nimport { useSelector } from 'app/types/store';\n\nimport { supportedFeatures } from '../../../core/history/richHistoryStorageProvider';\nimport { Tabs } from '../QueriesDrawer/QueriesDrawerContext';\nimport { selectExploreDSMaps } from '../state/selectors';\n\nimport { RichHistoryQueriesTab } from './RichHistoryQueriesTab';\nimport { RichHistorySettingsTab } from './RichHistorySettingsTab';\nimport { RichHistoryStarredTab } from './RichHistoryStarredTab';\n\nexport const getSortOrderOptions = () =>\n [\n { label: t('explore.rich-history.newest-first', 'Newest first'), value: SortOrder.Descending },\n { label: t('explore.rich-history.oldest-first', 'Oldest first'), value: SortOrder.Ascending },\n { label: t('explore.rich-history.datasource-a-z', 'Data source A-Z'), value: SortOrder.DatasourceAZ },\n { label: t('explore.rich-history.datasource-z-a', 'Data source Z-A'), value: SortOrder.DatasourceZA },\n ].filter((option) => supportedFeatures().availableFilters.includes(option.value));\n\nexport interface RichHistoryProps {\n richHistory: RichHistoryQuery[];\n richHistoryTotal?: number;\n richHistorySettings: RichHistorySettings;\n richHistorySearchFilters?: RichHistorySearchFilters;\n updateHistorySettings: (settings: RichHistorySettings) => void;\n updateHistorySearchFilters: (filters: RichHistorySearchFilters) => void;\n loadRichHistory: () => void;\n loadMoreRichHistory: () => void;\n clearRichHistoryResults: () => void;\n deleteRichHistory: () => void;\n firstTab: Tabs;\n height: number;\n onClose: () => void;\n}\n\nexport function RichHistory(props: RichHistoryProps) {\n const { richHistory, richHistoryTotal, height, deleteRichHistory, onClose, firstTab } = props;\n\n const [loading, setLoading] = useState(false);\n\n const updateSettings = (settingsToUpdate: Partial<RichHistorySettings>) => {\n props.updateHistorySettings({ ...props.richHistorySettings, ...settingsToUpdate });\n };\n\n const updateFilters = (filtersToUpdate?: Partial<RichHistorySearchFilters>) => {\n const filters = {\n ...props.richHistorySearchFilters!,\n ...filtersToUpdate,\n page: 1, // always load fresh results when updating filters\n };\n props.updateHistorySearchFilters(filters);\n loadRichHistory();\n };\n\n const loadRichHistory = debounce(() => {\n props.loadRichHistory();\n setLoading(true);\n }, 300);\n\n const onChangeRetentionPeriod = (retentionPeriod: SelectableValue<number>) => {\n if (retentionPeriod.value !== undefined) {\n updateSettings({ retentionPeriod: retentionPeriod.value });\n }\n };\n\n const toggleStarredTabAsFirstTab = () =>\n updateSettings({ starredTabAsFirstTab: !props.richHistorySettings.starredTabAsFirstTab });\n\n const toggleActiveDatasourcesOnly = () =>\n updateSettings({ activeDatasourcesOnly: !props.richHistorySettings.activeDatasourcesOnly });\n\n useEffect(() => {\n setLoading(false);\n }, [richHistory]);\n\n const exploreActiveDS = useSelector(selectExploreDSMaps);\n const listOfDatasources = createDatasourcesList();\n const activeDatasources = exploreActiveDS.dsToExplore\n .map((eDs) => listOfDatasources.find((ds) => ds.uid === eDs.datasource?.uid)?.name)\n .filter((name): name is string => !!name);\n\n const QueriesTab: TabConfig = {\n label: t('explore.rich-history.query-history', 'Query history'),\n value: Tabs.RichHistory,\n content: (\n <RichHistoryQueriesTab\n queries={richHistory}\n totalQueries={richHistoryTotal || 0}\n loading={loading}\n updateFilters={updateFilters}\n clearRichHistoryResults={() => props.clearRichHistoryResults()}\n loadMoreRichHistory={() => props.loadMoreRichHistory()}\n richHistorySettings={props.richHistorySettings}\n richHistorySearchFilters={props.richHistorySearchFilters}\n height={height}\n activeDatasources={activeDatasources}\n listOfDatasources={listOfDatasources}\n />\n ),\n icon: 'history',\n };\n\n const StarredTab: TabConfig = {\n label: t('explore.rich-history.starred', 'Starred'),\n value: Tabs.Starred,\n content: (\n <RichHistoryStarredTab\n queries={richHistory}\n totalQueries={richHistoryTotal || 0}\n loading={loading}\n updateFilters={updateFilters}\n clearRichHistoryResults={() => props.clearRichHistoryResults()}\n loadMoreRichHistory={() => props.loadMoreRichHistory()}\n richHistorySettings={props.richHistorySettings}\n richHistorySearchFilters={props.richHistorySearchFilters}\n />\n ),\n icon: 'star',\n };\n\n const SettingsTab: TabConfig = {\n label: t('explore.rich-history.settings', 'Settings'),\n value: Tabs.Settings,\n content: (\n <RichHistorySettingsTab\n retentionPeriod={props.richHistorySettings.retentionPeriod}\n starredTabAsFirstTab={props.richHistorySettings.starredTabAsFirstTab}\n activeDatasourcesOnly={props.richHistorySettings.activeDatasourcesOnly}\n onChangeRetentionPeriod={onChangeRetentionPeriod}\n toggleStarredTabAsFirstTab={toggleStarredTabAsFirstTab}\n toggleActiveDatasourcesOnly={toggleActiveDatasourcesOnly}\n deleteRichHistory={deleteRichHistory}\n />\n ),\n icon: 'sliders-v-alt',\n };\n\n let tabs = [QueriesTab, StarredTab, SettingsTab];\n return (\n <TabbedContainer\n tabs={tabs}\n onClose={onClose}\n defaultTab={firstTab}\n closeIconTooltip={t('explore.rich-history.close-tooltip', 'Close query history')}\n testId={selectors.pages.Explore.QueryHistory.container}\n />\n );\n}\n","// Libraries\nimport { useEffect, useState } from 'react';\nimport { connect, ConnectedProps } from 'react-redux';\n\nimport { Trans } from '@grafana/i18n';\nimport { config, reportInteraction } from '@grafana/runtime';\nimport { useTheme2 } from '@grafana/ui';\n// Types\nimport { StoreState } from 'app/types/store';\n\n// Components, enums\nimport { useQueriesDrawerContext } from '../QueriesDrawer/QueriesDrawerContext';\nimport {\n deleteRichHistory,\n initRichHistory,\n loadRichHistory,\n loadMoreRichHistory,\n clearRichHistoryResults,\n updateHistorySettings,\n updateHistorySearchFilters,\n} from '../state/history';\n\nimport { RichHistory } from './RichHistory';\n\n//Actions\n\nfunction mapStateToProps(state: StoreState) {\n const explore = state.explore;\n const richHistorySearchFilters = explore.richHistorySearchFilters;\n const { richHistorySettings, richHistory, richHistoryTotal } = explore;\n\n return {\n richHistory,\n richHistoryTotal,\n richHistorySettings,\n richHistorySearchFilters,\n };\n}\n\nconst mapDispatchToProps = {\n initRichHistory,\n loadRichHistory,\n loadMoreRichHistory,\n clearRichHistoryResults,\n updateHistorySettings,\n updateHistorySearchFilters,\n deleteRichHistory,\n};\n\nconst connector = connect(mapStateToProps, mapDispatchToProps);\n\ninterface OwnProps {\n onClose: () => void;\n}\nexport type Props = ConnectedProps<typeof connector> & OwnProps;\n\nexport function RichHistoryContainer(props: Props) {\n const theme = useTheme2();\n\n const {\n richHistory,\n richHistoryTotal,\n deleteRichHistory,\n initRichHistory,\n loadRichHistory,\n loadMoreRichHistory,\n clearRichHistoryResults,\n richHistorySettings,\n updateHistorySettings,\n richHistorySearchFilters,\n updateHistorySearchFilters,\n onClose,\n } = props;\n\n useEffect(() => {\n initRichHistory();\n }, [initRichHistory]);\n\n const { selectedTab } = useQueriesDrawerContext();\n const [tracked, setTracked] = useState(false);\n\n useEffect(() => {\n if (!tracked) {\n setTracked(true);\n reportInteraction('grafana_explore_query_history_opened', {\n queryHistoryEnabled: config.queryHistoryEnabled,\n selectedTab,\n });\n }\n }, [tracked, selectedTab]);\n\n if (!richHistorySettings) {\n return (\n <span>\n <Trans i18nKey=\"explore.rich-history-container.loading\">Loading...</Trans>\n </span>\n );\n }\n\n return (\n <RichHistory\n richHistory={richHistory}\n richHistoryTotal={richHistoryTotal}\n firstTab={selectedTab}\n onClose={onClose}\n height={theme.components.horizontalDrawer.defaultHeight}\n deleteRichHistory={deleteRichHistory}\n richHistorySettings={richHistorySettings}\n richHistorySearchFilters={richHistorySearchFilters}\n updateHistorySettings={updateHistorySettings}\n updateHistorySearchFilters={updateHistorySearchFilters}\n loadRichHistory={loadRichHistory}\n loadMoreRichHistory={loadMoreRichHistory}\n clearRichHistoryResults={clearRichHistoryResults}\n />\n );\n}\n\nexport default connector(RichHistoryContainer);\n","import { useEffect } from 'react';\n\nimport { getDataSourceSrv } from '@grafana/runtime';\nimport { Branding } from 'app/core/components/Branding/Branding';\nimport { useGrafana } from 'app/core/context/GrafanaContext';\nimport { useNavModel } from 'app/core/hooks/useNavModel';\nimport { ExploreQueryParams } from 'app/types/explore';\n\nimport { isFulfilled, hasKey } from './utils';\n\nexport function useExplorePageTitle(params: ExploreQueryParams) {\n const navModel = useNavModel('explore');\n const { chrome } = useGrafana();\n\n useEffect(() => {\n if (!params.panes || typeof params.panes !== 'string') {\n return;\n }\n\n let panesObject: unknown;\n try {\n panesObject = JSON.parse(params.panes);\n } catch {\n return;\n }\n\n if (typeof panesObject !== 'object' || panesObject === null) {\n return;\n }\n\n Promise.allSettled(\n Object.values(panesObject).map((pane) => {\n if (\n !pane ||\n typeof pane !== 'object' ||\n !hasKey('datasource', pane) ||\n !pane.datasource ||\n typeof pane.datasource !== 'string'\n ) {\n return Promise.reject();\n }\n\n return getDataSourceSrv().get(pane.datasource);\n })\n )\n .then((results) => results.filter(isFulfilled).map((result) => result.value))\n .then((datasources) => {\n if (datasources.length === 0) {\n global.document.title = `${navModel.main.text} - ${Branding.AppTitle}`;\n chrome.update({\n pageNav: undefined,\n });\n return;\n }\n\n const namesString = datasources.map((ds) => ds.name).join(' | ');\n chrome.update({\n pageNav: {\n text: namesString,\n },\n });\n global.document.title = `${navModel.main.text} - ${namesString} - ${Branding.AppTitle}`;\n });\n }, [params.panes, navModel.main.text, chrome]);\n}\n","import { useEffect } from 'react';\nimport { Unsubscribable } from 'rxjs';\n\nimport { getAppEvents } from '@grafana/runtime';\nimport { useGrafana } from 'app/core/context/GrafanaContext';\nimport { AbsoluteTimeEvent, CopyTimeEvent, PasteTimeEvent, ShiftTimeEvent, ZoomOutEvent } from 'app/types/events';\nimport { useDispatch } from 'app/types/store';\n\nimport {\n copyTimeRangeToClipboard,\n makeAbsoluteTime,\n pasteTimeRangeFromClipboard,\n shiftTime,\n zoomOut,\n} from '../state/time';\n\nexport function useKeyboardShortcuts() {\n const { keybindings } = useGrafana();\n const dispatch = useDispatch();\n\n useEffect(() => {\n keybindings.setupTimeRangeBindings(false);\n\n const tearDown: Unsubscribable[] = [];\n\n tearDown.push(\n getAppEvents().subscribe(AbsoluteTimeEvent, () => {\n dispatch(makeAbsoluteTime());\n })\n );\n\n tearDown.push(\n getAppEvents().subscribe(ShiftTimeEvent, (event) => {\n dispatch(shiftTime(event.payload.direction));\n })\n );\n\n tearDown.push(\n getAppEvents().subscribe(ZoomOutEvent, (event) => {\n dispatch(zoomOut(event.payload.scale));\n })\n );\n\n tearDown.push(\n getAppEvents().subscribe(CopyTimeEvent, () => {\n dispatch(copyTimeRangeToClipboard());\n })\n );\n\n tearDown.push(\n getAppEvents().subscribe(PasteTimeEvent, () => {\n dispatch(pasteTimeRangeFromClipboard());\n })\n );\n\n return () => {\n tearDown.forEach((u) => u.unsubscribe());\n };\n }, [dispatch, keybindings]);\n}\n","import { inRange } from 'lodash';\nimport { useState } from 'react';\nimport { useWindowSize } from 'react-use';\n\nimport { useDispatch, useSelector } from 'app/types/store';\n\nimport { splitSizeUpdateAction } from '../state/main';\nimport { isSplit, selectPanesEntries } from '../state/selectors';\n\nexport const useSplitSizeUpdater = (minWidth: number) => {\n const dispatch = useDispatch();\n const { width: windowWidth } = useWindowSize();\n const panes = useSelector(selectPanesEntries);\n const hasSplit = useSelector(isSplit);\n const [rightPaneWidthRatio, setRightPaneWidthRatio] = useState(0.5);\n\n const exploreState = useSelector((state) => state.explore);\n\n const updateSplitSize = (size: number) => {\n const evenSplitWidth = windowWidth / 2;\n const areBothSimilar = inRange(size, evenSplitWidth - 100, evenSplitWidth + 100);\n if (areBothSimilar) {\n dispatch(splitSizeUpdateAction({ largerExploreId: undefined }));\n } else {\n dispatch(\n splitSizeUpdateAction({\n largerExploreId: size > evenSplitWidth ? panes[1][0] : panes[0][0],\n })\n );\n }\n\n setRightPaneWidthRatio(size / windowWidth);\n };\n\n let widthCalc = 0;\n if (hasSplit) {\n if (!exploreState.evenSplitPanes && exploreState.maxedExploreId) {\n widthCalc = exploreState.maxedExploreId === panes[1][0] ? windowWidth - minWidth : minWidth;\n } else if (exploreState.evenSplitPanes) {\n widthCalc = Math.floor(windowWidth / 2);\n } else if (rightPaneWidthRatio !== undefined) {\n widthCalc = windowWidth * rightPaneWidthRatio;\n }\n }\n\n return { updateSplitSize, widthCalc };\n};\n","import { useEffect } from 'react';\n\nimport { useGrafana } from 'app/core/context/GrafanaContext';\n\n/**\n * timeSrv (which is used internally) on init reads `from` and `to` param from the URL and updates itself\n * using those value regardless of what is passed to the init method.\n * The updated value is then used by Explore to get the range for each pane.\n * This means that if `from` and `to` parameters are present in the URL,\n * it would be impossible to change the time range in Explore.\n * We are only doing this on mount for 2 reasons:\n * 1: Doing it on update means we'll enter a render loop.\n * 2: when parsing time in Explore (before feeding it to timeSrv) we make sure `from` is before `to` inside\n * each pane state in order to not trigger un URL update from timeSrv.\n */\nexport function useTimeSrvFix() {\n const { location } = useGrafana();\n\n useEffect(() => {\n const searchParams = location.getSearchObject();\n if (searchParams.from || searchParams.to) {\n location.partial({ from: undefined, to: undefined }, true);\n }\n }, [location]);\n}\n","import { css, cx } from '@emotion/css';\nimport { useEffect } from 'react';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { t, Trans } from '@grafana/i18n';\nimport { config } from '@grafana/runtime';\nimport { ErrorBoundaryAlert, LoadingPlaceholder, useStyles2, useTheme2 } from '@grafana/ui';\nimport { SplitPaneWrapper } from 'app/core/components/SplitPaneWrapper/SplitPaneWrapper';\nimport { useGrafana } from 'app/core/context/GrafanaContext';\nimport { useNavModel } from 'app/core/hooks/useNavModel';\nimport { GrafanaRouteComponentProps } from 'app/core/navigation/types';\nimport { ExploreQueryParams } from 'app/types/explore';\nimport { useSelector } from 'app/types/store';\n\nimport { CorrelationEditorModeBar } from './CorrelationEditorModeBar';\nimport { ExploreActions } from './ExploreActions';\nimport { ExploreDrawer } from './ExploreDrawer';\nimport { ExplorePaneContainer } from './ExplorePaneContainer';\nimport { useQueriesDrawerContext } from './QueriesDrawer/QueriesDrawerContext';\nimport RichHistoryContainer from './RichHistory/RichHistoryContainer';\nimport { useExplorePageTitle } from './hooks/useExplorePageTitle';\nimport { useKeyboardShortcuts } from './hooks/useKeyboardShortcuts';\nimport { useSplitSizeUpdater } from './hooks/useSplitSizeUpdater';\nimport { useStateSync } from './hooks/useStateSync';\nimport { useTimeSrvFix } from './hooks/useTimeSrvFix';\nimport { isSplit, selectCorrelationDetails, selectPanesEntries } from './state/selectors';\n\nconst MIN_PANE_WIDTH = 200;\n\nexport default function ExplorePage(props: GrafanaRouteComponentProps<{}, ExploreQueryParams>) {\n return <ExplorePageContent {...props} />;\n}\n\nfunction ExplorePageContent(props: GrafanaRouteComponentProps<{}, ExploreQueryParams>) {\n const styles = useStyles2(getStyles);\n const theme = useTheme2();\n useTimeSrvFix();\n useStateSync(props.queryParams);\n // We want to set the title according to the URL and not to the state because the URL itself may lag\n // (due to how useStateSync above works) by a few milliseconds.\n // When a URL is pushed to the history, the browser also saves the title of the page and\n // if we were to update the URL on state change, the title would not match the URL.\n // Ultimately the URL is the single source of truth from which state is derived, the page title is not different\n useExplorePageTitle(props.queryParams);\n const { chrome } = useGrafana();\n const navModel = useNavModel('explore');\n const { updateSplitSize, widthCalc } = useSplitSizeUpdater(MIN_PANE_WIDTH);\n\n const panes = useSelector(selectPanesEntries);\n const hasSplit = useSelector(isSplit);\n const correlationDetails = useSelector(selectCorrelationDetails);\n const { drawerOpened, setDrawerOpened } = useQueriesDrawerContext();\n const showCorrelationEditorBar = config.featureToggles.correlations && (correlationDetails?.editorMode || false);\n\n useEffect(() => {\n //This is needed for breadcrumbs and topnav.\n //We should probably abstract this out at some point\n chrome.update({\n sectionNav: navModel,\n });\n }, [chrome, navModel]);\n\n useKeyboardShortcuts();\n\n return (\n <div\n className={cx(styles.pageScrollbarWrapper, {\n [styles.correlationsEditorIndicator]: showCorrelationEditorBar,\n })}\n >\n <h1 className=\"sr-only\">\n <Trans i18nKey=\"nav.explore.title\" />\n </h1>\n <ExploreActions />\n {showCorrelationEditorBar && <CorrelationEditorModeBar panes={panes} />}\n <SplitPaneWrapper\n splitOrientation=\"vertical\"\n paneSize={widthCalc}\n minSize={MIN_PANE_WIDTH}\n maxSize={MIN_PANE_WIDTH * -1}\n primary=\"second\"\n splitVisible={hasSplit}\n parentStyle={showCorrelationEditorBar ? { height: `calc(100% - ${theme.spacing(6)}` } : {}} // button = 4, padding = 1 x 2\n paneStyle={{ overflow: 'auto', display: 'flex', flexDirection: 'column' }}\n onDragFinished={(size) => size && updateSplitSize(size)}\n >\n {panes.map(([exploreId, pane]) => {\n return (\n <ErrorBoundaryAlert boundaryName=\"explore-pane\" key={exploreId} style=\"page\">\n {pane.initialized ? (\n <ExplorePaneContainer exploreId={exploreId} />\n ) : (\n <LoadingPlaceholder text={t('explore.pane.loading-placeholder', 'Loading...')} />\n )}\n </ErrorBoundaryAlert>\n );\n })}\n </SplitPaneWrapper>\n {drawerOpened && (\n <ExploreDrawer>\n <RichHistoryContainer\n onClose={() => {\n setDrawerOpened(false);\n }}\n />\n </ExploreDrawer>\n )}\n </div>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n pageScrollbarWrapper: css({\n width: '100%',\n flexGrow: 1,\n minHeight: 0,\n height: '100%',\n position: 'relative',\n overflow: 'hidden',\n }),\n correlationsEditorIndicator: css({\n borderLeft: `4px solid ${theme.colors.primary.main}`,\n borderRight: `4px solid ${theme.colors.primary.main}`,\n borderBottom: `4px solid ${theme.colors.primary.main}`,\n overflow: 'scroll',\n }),\n };\n};\n","import { useEffect, useRef } from 'react';\nvar useInterval = function (callback, delay) {\n var savedCallback = useRef(function () { });\n useEffect(function () {\n savedCallback.current = callback;\n });\n useEffect(function () {\n if (delay !== null) {\n var interval_1 = setInterval(function () { return savedCallback.current(); }, delay || 0);\n return function () { return clearInterval(interval_1); };\n }\n return undefined;\n }, [delay]);\n};\nexport default useInterval;\n"],"names":["tableMigrationHandler","panel","migrateTextWrapToFieldLevel","migrateHiddenFields","migrateFooterV2","transformsMap","columnsMap","colorModeMap","generateThresholds","thresholds","colors","threshold","idx","migrateTransformations","oldOpts","transformations","opts","column","migrateTableStyleToOverride","style","override","migrateDefaults","prevDefaults","defaults","tablePanelChangedHandler","prevPluginId","prevOptions","overrides","getMainFrames","frames","df","migrateFromParentRowIndexToNestedFrames","migratedFrames","frame","subFrames","subFramesGrouped","subFramesByIndex","key","migratedFrame","hasDeprecatedParentRowIndex","legacyDefaultWrapText","property","oldFooter","reducers","assertIsQueryTypeError","errors","getSupportedTransTypeDetails","transType","getTransformOptions","transformationType","useBeforeUnload","enabled","message","handler","event","finalEnabled","CorrelationUnsavedChangesModal","onSave","onDiscard","onCancel","Modal","Button","CONSEQUENCES","showModalMessage","action","isActionLeft","dirtyCorrelation","dirtyQueryEditor","messageTemplate","actionStr","consequenceStr","CorrelationEditorModeBar","panes","dispatch","styles","getStyles","correlationDetails","isHelperShowing","saveMessage","setSaveMessage","correlationDirty","queryEditorDirty","modalMessage","exploreId","changeDatasourceUid","useUnmount","pane","resetEditor","closePane","changeDatasourcePostAction","datasourceUid","saveCorrelationPostAction","skipPostConfirmAction","Prompt","location","Stack","Tooltip","Icon","theme","contrastColor","lighterBackgroundColor","colorManipulator","darkerBackgroundColor","disabledColor","ExploreActions","actions","setActions","query","splitted","canWriteCorrelations","keys","exploreSection","actionsArr","hasMixed","config","ExploreDrawer","props","children","onResize","initialHeight","dragStyles","height","drawerSlide","useScroll","ref","_a","useRafState","state","setState","ContentOutlineContext","ContentOutlineContextProvider","refreshDependencies","outlineItems","setOutlineItems","parentlessItemsRef","register","outlineItem","id","prevItems","parentlessItems","item","sortElementsByDocumentPosition","siblingWithSameTitleFound","parentIndex","newItems","parent","siblingWithSameTitle","child","childrenUpdated","sortItems","unregister","updateOutlineItems","updateItem","properties","unregisterAllChildren","parentIdGetter","childType","parentId","sortedItems","a","b","diff","skipSort","sortable","acc","useContentOutlineContext","ContentOutlineItemButton","contentOutlineExpanded","title","icon","tooltip","tooltipPlacement","className","indentStyle","collapsible","collapsed","isActive","extraHighlight","sectionId","toggleCollapsed","color","onRemove","rest","buttonStyles","textRef","isOverflowing","setIsOverflowing","body","OutlineIcon","scrollableChildren","shouldBeActive","activeSectionId","activeSectionChildId","sectionsExpanded","isAnActiveParent","isAnActiveChild","isCollapsed","containsScrollableChildren","anyChildActive","isChildActive","CONTENT_OUTLINE_LOCAL_STORAGE_KEYS","ContentOutline","scroller","panelId","toggleContentOutlineExpanded","useToggle","scrollerRef","verticalScroll","setActiveSectionId","setActiveSectionChildId","outlineItemsShouldIndent","outlineItemsHaveDeleteButton","setSectionsExpanded","scrollIntoView","customOffsetTop","scrollValue","el","handleItemClicked","activeParent","toggle","toggleSection","itemId","prev","activeItem","top","activeChild","offsetTop","childTop","isCollapsible","PanelContainer","ScrollContainer","i","e","expanded","ContentOutlineItem","customTopOffset","level","mergeSingleChild","type","onClick","LabelWithTooltip","label","tooltipText","Label","CorrelationTransformationAddModal","fieldList","transformationToEdit","exampleValue","setExampleValue","transformationVars","setTransformationVars","formFieldsVis","setFormFieldsVis","isExpValid","setIsExpValid","validToSave","setValidToSave","getValues","control","watch","exampleVal","transformationTypeDetails","subscription","formValues","expression","isExpressionValid","transKeys","Field","onChange","field","Select","value","entry","Input","CorrelationHelper","correlations","panesVals","defaultLabel","loadingLabel","useAsync","setValue","isLabelDescOpen","setIsLabelDescOpen","isTransformOpen","setIsTransformOpen","showTransformationAddModal","setShowTransformationAddModal","setTransformations","transformationIdxToEdit","setTransformationIdxToEdit","dirty","description","transVarRecords","transformation","editTransformations","Alert","Collapse","mapValue","detailsString","val","Card","IconButton","DeleteButton","_","CustomContainer","width","timeZone","pluginId","timeRange","splitOpenFn","plugin","dataLinkPostProcessor","useExploreDataLinkPostProcessor","PanelChrome","innerWidth","innerHeight","PanelRenderer","TimeSyncButton","isSynced","syncTimesTooltip","ToolbarButton","ExploreTimeControls","range","fiscalYearStartMonth","syncedTimes","onChangeTimeSync","hideText","onChangeTimeZone","onChangeFiscalYearStartMonth","onChangeTime","onMoveTimePicker","direction","from","to","nextTimeRange","onMoveForward","onMoveBack","onChangeTimePicker","adjustedFrom","adjustedTo","onZoom","timeSyncButton","timePickerCommonProps","TimePickerWithHistory","LiveTailButton","transitionRef","start","pause","resume","isLive","isPaused","stop","buttonVariant","onClickMain","ButtonGroup","CSSTransition","ShortLinkButtonMenu","defaultMode","isOpen","setIsOpen","lastSelected","setLastSelected","onCopyLink","shorten","absTime","url","menuOptions","MenuActions","Menu","groupOption","MenuGroup","option","Dropdown","AddToDashboard","BasicExtensions","links","setSelectedExtension","setIsModalOpen","isModalOpen","noQueriesInPane","menu","ToolbarExtensionPointMenu","QuerylessAppsExtensions","link","QUERYLESS_APPS","ToolbarExtensionPoint","extensionsToShow","selectedExtension","context","useExtensionPointContext","usePluginLinks","selectExploreItem","querylessLinks","commonLinks","extension","ConfirmNavigationModal","isCorrelationsEditorMode","queries","queryResponse","isLeftPane","datasourceUids","uid","numUniqueIds","useLiveTailControls","RefreshPicker","clear","LiveTailControls","controls","ExploreToolbar","onContentOutlineToogle","isContentOutlineOpen","refreshInterval","datasourceInstance","loading","isLargerPane","showSmallTimePicker","showSmallDataSourcePicker","drawerOpened","setDrawerOpened","shouldRotateSplitIcon","refreshPickerLabel","onChangeDatasource","dsSettings","onRunQuery","timezone","onOpenSplitView","onCloseSplitView","onClickResize","fiscalyearStartMonth","onChangeRefreshInterval","navBarActions","SetInterval","AppChromeUpdate","PageToolbar","DataSourcePicker","c","interaction","name","FlameGraphExploreContainer","view","align","sort","INTERVAL","ElapsedTime","resetKey","humanize","elapsed","setElapsed","useInterval","Time","fade","tinycolor","LiveLogs","onPause","scrollTop","clientHeight","scrollHeight","rowsToRender","nextProps","onResume","onClear","logsRow","logsRowLocalTime","logsRowMessage","getLogRowStyles","row","LogMessageAnsi","element","LiveLogsWithTheme","contentOutlineTrackPinAdded","contentOutlineTrackPinRemoved","contentOutlineTrackPinLimitReached","contentOutlineTrackPinClicked","contentOutlineTrackUnpinClicked","contentOutlineTrackLevelFilter","LogsFeedback","feedbackUrl","TextLink","MetaInfoItem","MetaInfoText","metaItems","index","LogsMetaRow","meta","dedupStrategy","dedupCount","displayedFields","clearDisplayedFields","logRows","defaultDisplayedFields","visualisationType","logsMetaItem","LogLabels","download","format","downloadMenu","commonLabelsProps","renderMetaItem","kind","logLabelsProps","LogsNavigationPages","pages","currentPageIndex","oldestLogsFirst","formatTime","time","createPageContent","page","Spinner","topContent","bottomContent","LogsNavigation","absoluteRange","logsSortOrder","scrollToTopLogs","scrollToBottomLogs","visibleRange","clearCache","addResultsToCache","setPages","expectedQueriesRef","expectedRangeRef","rangeSpanRef","onFirstPage","onLastPage","newPage","newPages","sortPages","changeTime","olderLogsButton","indexChange","newerLogsButton","onPageClick","pageNumber","onScrollToTopClick","onScrollToBottomClick","navContainerHeight","SHORT_ERROR_MESSAGE_LIMIT","SupplementaryResultError","dismissed","setDismissed","dismissable","error","suggestedAction","onSuggestedAction","severity","showButton","dismiss","handleRemove","LogsVolumePanel","splitOpen","onUpdateTimeRange","onHiddenSeriesChanged","allLogsVolumeMaximum","toggleLegendRef","spacing","logsVolumeData","logsVolumeInfo","extraInfo","extraInfoComponent","ExploreGraph","isTimeoutErrorResponse","response","LogsVolumePanelList","onLoadLogsVolume","onDisplayedSeriesChanged","eventBus","onClose","logVolumes","allLogsVolumeMaximumValue","allLogsVolumeMaximumRange","annotations","maximumValue","data","sorted","grouped","mergedData","maximumRange","numberOfLogVolumes","containsZoomed","zoomRatio","logsLevelZoomRatio","canShowPartialData","timeoutError","handleHiddenSeriesChanged","hiddenSeries","allLevels","series","dataFrame","displayedLevels","InlineField","selectedTimeRange","dataRange","DEDUP_OPTIONS","getDefaultVisualisationType","PINNED_LOGS_LIMIT","PINNED_LOGS_TITLE","PINNED_LOGS_MESSAGE","PINNED_LOGS_PANELID","UnthemedLogs","logsMeta","logsVolumeEnabled","loadLogsVolumeData","onClickFilterLabel","onClickFilterOutLabel","scanning","scanRange","showContextToggle","getFieldLinks","logsQueries","getRowContext","getLogRowContextUi","getRowContextQuery","loadMoreLogs","panelState","onPinLineCallback","scrollElement","showLabels","setShowLabels","showTime","setShowTime","wrapLogMessage","setWrapLogMessage","prettifyLogMessage","setPrettifyLogMessage","setDedupStrategy","setLogsSortOrder","isFlipping","setIsFlipping","setDisplayedFields","setDefaultDisplayedFields","contextOpen","setContextOpen","contextRow","setContextRow","pinLineButtonTooltipTitle","setPinLineButtonTooltipTitle","setVisualisationType","logsContainerRef","previousLoading","usePrevious","logsVolumeEventBus","flipOrderTimer","cancelFlippingTimer","topLogsRef","filterLevels","setFilterLevels","tableHeight","hasData","scanText","logsParent","pinnedLogs","outlines","getPinnedLogsCount","updatePanelState","logsPanelState","onLogRowHover","sortOrderChanged","newSortOrder","hasLokiQueries","newQueries","newDirection","onChangeLogsSortOrder","onChangeVisualisation","visualisation","payload","onChangeDedup","onChangeLabels","target","onChangeShowTime","onChangeWrapLogMessage","onChangePrettifyLogMessage","onToggleLogsVolumeCollapse","onClickScan","onClickStopScan","showField","updatedDisplayedFields","hideField","k","onCloseCallbackRef","onCloseContext","onOpenContext","onPermalinkClick","urlState","serializedState","baseUrl","onPinToContentOutlineClick","allowUnPin","alreadyPinned","pin","dedupedRows","dedupRows","navigationRange","createNavigationRange","infiniteScrollAvailable","visibilityChangedRef","onLogOptionsChange","logVolData","logsVolumeLevels","currentFilterLevels","newLevels","newLogsVolumeLevels","prevLogsVolumeLevels","addedLevels","newLevel","removedLevels","prevLevel","levels","LogRowContextModal","options","LogLineContext","RadioButtonGroup","InlineFieldRow","dedupType","LogsTableWrap","ControlledLogRows","InfiniteScroll","LogRows","LogList","Logs","sum","firstTimeStamp","lastTimeStamp","transitionDuration","transitionDelay","LogsCrossFadeTransition","visible","LogsContainer","updateTimeRange","origRow","ds","cacheFilters","runContextQuery","rowIndex","vars","prevProps","dsInstances","refId","dsPromises","resolve","instances","q","loadingState","logsSeries","onStartScanning","onStopScanning","logsVolume","mapStateToProps","logsResult","clearedAtIndex","supplementaryQueries","mapDispatchToProps","LogsSamplePanel","setLogsSampleEnabled","onToggleLogsSampleCollapse","OpenInSplitViewButton","logSampleQueries","onSplitOpen","LogsSamplePanelContent","logs","NoData","css","getCardStyles","NoDataSourceCallToAction","cardStyles","canCreateDataSource","footer","ctaElement","CallToActionCard","UnconnectedNodeGraphContainer","dataFrames","withTraceView","datasourceType","getLinks","nodes","useCategorizeFrames","layoutAlgorithm","toggled","windowHeight","useWindowSize","containerRef","setTop","countWarning","NodeGraph","NodeGraphContainer","makeSelectors","exploreItemSelector","QueryRows","changeCompactMode","openDrawer","getQueries","getDatasourceInstanceSettings","getQueryResponse","getHistory","getEventBridge","getQueryLibraryRef","history","eventBridge","queryLibraryRef","onRunQueries","onUpdateDatasources","datasource","onAddQuery","onQueryCopied","onQueryReplacedFromLibrary","onQueryRemoved","onQueryToggled","queryStatus","onCancelQueryLibraryEdit","originalQueryRef","onQueryOpenChanged","QueryEditorRows","mobileWidthThreshold","numberOfColumnsBeforeExpandedViewIsDefault","tableResult","listRef","valueLabels","items","getRawPrometheusListItemsFromDataFrame","isExpandedView","setIsExpandedView","onContentClick","calculateInitialHeight","length","getListItemHeight","itemIndex","switchId","Switch","ItemLabels","filteredValueLabels","valueLabel","itemWithValue","RawListItem","rawPrometheusResult","rawPrometheusFrame","RawPrometheusContainer","resultsStyle","ALL_GRAPH_STYLE_OPTIONS","onCellFilterAdded","ariaLabel","tableWidth","renderTable","Table","FadeIn","defaultStyle","transitionStyles","Transition","ErrorContainer","queryError","showError","duration","ResponseErrorContainer","SecondaryActions","addQueryRowButtonDisabled","addQueryRowButtonHidden","onClickAddQueryRowButton","onClickQueryInspectorButton","onSelectQueryFromLibrary","queryInspectorButtonActive","queryLibraryEnabled","openQueryLibraryDrawer","MAX_NUMBER_OF_COLUMNS","loadingInState","TableContainer","f","rowCount","hasSubFrames","showAll","dataLimited","hidden","LimitedDataDisclaimer","TableContainerWithTheme","TraceViewContainer","traceProp","transform","TraceView","Explore","rawRange","filter","operator","newContentOutlineVisible","queryKeys","modifier","modification","toggleableFilters","size","panelType","compact","source","tracking","exploreContainerStyles","groupedByPlugin","graphResult","showFlameGraph","GraphContainer","logsContentOutlineWrapper","logsSample","setSupplementaryQueryEnabled","showTrace","showMetrics","showTable","showRawPrometheus","showLogs","showCustom","showNodeGraph","showLogsSample","correlationEditorDetails","correlationEditorHelperData","showQueryInspector","setShowQueryInspector","contentOutlineVisible","showPanels","richHistoryRowButtonHidden","showNoData","correlationsBox","changeDatasource","setQueries","newDatasourceRef","ErrorBoundary","explore","ExploreQueryInspector","isMixed","dataOptions","setDataOptions","statsTab","InspectStatsTab","jsonTab","InspectJSONTab","dataTab","InspectDataTab","queryTab","QueryInspector","tabs","errorTab","InspectErrorTab","TabbedContainer","containerStyles","ExplorePaneContainerUnconnected","useStopQueries","EventBus","bus","ExplorePaneContainer","paneSelector","paneRef","ExploreRunQueryButton","rootDatasourceUid","disabled","openRunQueryButton","setOpenRunQueryButton","isPaneSplit","exploreActiveDS","panesEntries","isDifferentDatasource","di","runQueryText","dsUid","runQuery","differentDataSource","runButton","isInvalid","buttonText","paneLabel","RichHistoryAddToLibrary","hasBeenSaved","setHasBeenSaved","onSelectQuery","newQuery","buttonLabel","rightColumnWidth","rightColumnContentWidth","cardColor","RichHistoryCard","queryHistoryItem","commentHistoryItem","starHistoryItem","deleteHistoryItem","datasourceInstances","activeUpdateComment","setActiveUpdateComment","comment","setComment","cardRootDatasource","onCopyQuery","datasources","queriesText","queryDS","onCreateShortLink","onDeleteQuery","performDelete","queryId","onStarQuery","toggleActiveUpdateComment","onUpdateComment","onCancelUpdateComment","onKeyDown","keyEvent","updateComment","TextArea","queryActionButtons","DatasourceInfo","queryDs","Query","getQueryStyles","showDsInfo","getDsInfoStyles","dsApi","RichHistoryQueriesTab","totalQueries","richHistorySearchFilters","updateFilters","clearRichHistoryResults","loadMoreRichHistory","richHistorySettings","listOfDatasources","activeDatasources","datasourceFilters","filters","datasourceFilterApis","loadingDs","dsGetProm","dsf","dsi","mappedQueriesToHeadings","sortOrderOptions","getSortOrderOptions","partialResults","timeFilter","RangeSlider","FilterInput","search","order","heading","RichHistorySettingsTab","retentionPeriod","starredTabAsFirstTab","activeDatasourcesOnly","onChangeRetentionPeriod","toggleStarredTabAsFirstTab","toggleActiveDatasourcesOnly","deleteRichHistory","retentionPeriodOptions","selectedOption","v","onDelete","RichHistoryStarredTab","eDs","RichHistory","richHistory","richHistoryTotal","firstTab","setLoading","updateSettings","settingsToUpdate","filtersToUpdate","loadRichHistory","QueriesTab","StarredTab","SettingsTab","RichHistoryContainer","initRichHistory","updateHistorySettings","updateHistorySearchFilters","selectedTab","tracked","setTracked","useExplorePageTitle","params","navModel","useNavModel","chrome","panesObject","results","result","Branding","namesString","useKeyboardShortcuts","keybindings","tearDown","u","useSplitSizeUpdater","minWidth","windowWidth","hasSplit","rightPaneWidthRatio","setRightPaneWidthRatio","exploreState","updateSplitSize","evenSplitWidth","areBothSimilar","widthCalc","useTimeSrvFix","searchParams","MIN_PANE_WIDTH","ExplorePage","ExplorePageContent","useStateSync","showCorrelationEditorBar","SplitPaneWrapper","LoadingPlaceholder","callback","delay","savedCallback","interval_1"],"sourceRoot":""}
.
Edit
..
Edit
1117.145ac642f59357bc40d8.js
Edit
1117.145ac642f59357bc40d8.js.map
Edit
1118.c684d1aadf16a6c70620.js
Edit
1118.c684d1aadf16a6c70620.js.map
Edit
1122.5fbf0d7cd148c610616d.js
Edit
1122.5fbf0d7cd148c610616d.js.map
Edit
1142.a4b35a0e8699cafd901e.js
Edit
1142.a4b35a0e8699cafd901e.js.map
Edit
1162.81868b3ac499fa5ea04b.js
Edit
1162.81868b3ac499fa5ea04b.js.map
Edit
1183.7444f51e5996a7f23c7d.js
Edit
1183.7444f51e5996a7f23c7d.js.map
Edit
1282.ae38cac1b732d8ac1d96.js
Edit
1282.ae38cac1b732d8ac1d96.js.map
Edit
130.a58aaeea748f37ee6482.js
Edit
130.a58aaeea748f37ee6482.js.map
Edit
1419.59f53ae25085b28e1e11.js
Edit
1419.59f53ae25085b28e1e11.js.map
Edit
1420.e63ce495727f83b8887d.js
Edit
1420.e63ce495727f83b8887d.js.map
Edit
1438.ccdd05d7188edf4191ff.js
Edit
1438.ccdd05d7188edf4191ff.js.map
Edit
1446.fe7b1f4563629b80793f.js
Edit
1446.fe7b1f4563629b80793f.js.map
Edit
1484.3da94e44ecdadcd342d4.js
Edit
1484.3da94e44ecdadcd342d4.js.map
Edit
1492.4026c6e7130c3afdae87.js
Edit
1494.ef220afb67ff6c52c7af.js
Edit
1494.ef220afb67ff6c52c7af.js.map
Edit
1560.538cd2395be11ba4e2c9.js
Edit
1560.538cd2395be11ba4e2c9.js.map
Edit
1579.c391ef869d4f7bfc0d1c.js
Edit
1579.c391ef869d4f7bfc0d1c.js.map
Edit
1646.d7d87a40853795910533.js
Edit
1646.d7d87a40853795910533.js.map
Edit
1710.7db3f56c6714c0c340e0.js
Edit
1710.7db3f56c6714c0c340e0.js.map
Edit
1716.f71f518289da5d2229bc.js
Edit
1716.f71f518289da5d2229bc.js.map
Edit
1740.baf38e7ee007e1a6935e.js
Edit
1740.baf38e7ee007e1a6935e.js.map
Edit
1821.c9a2456dc8d78cf6b02f.js
Edit
1821.c9a2456dc8d78cf6b02f.js.map
Edit
1888.d33142738af4fbf8a230.js
Edit
1888.d33142738af4fbf8a230.js.map
Edit
1914.5f33b3c2133b5bb7ea6e.js
Edit
1914.5f33b3c2133b5bb7ea6e.js.map
Edit
198.65a768ff6c601d19ea3f.js
Edit
198.65a768ff6c601d19ea3f.js.map
Edit
1990.9171129a8deabb59bf30.js
Edit
1990.9171129a8deabb59bf30.js.map
Edit
2018.5ff00ee0456301c1cf43.js
Edit
2018.5ff00ee0456301c1cf43.js.map
Edit
205.2eb73847215c8d021cc9.js
Edit
205.2eb73847215c8d021cc9.js.map
Edit
2077.a5848ca4b4b9fdebca17.js
Edit
2077.a5848ca4b4b9fdebca17.js.map
Edit
2094.97e7f0876201e76a77fd.js
Edit
2094.97e7f0876201e76a77fd.js.map
Edit
2150.7576285186c713978b39.js
Edit
2150.7576285186c713978b39.js.map
Edit
2152.b55841e6f422682a3891.js
Edit
2152.b55841e6f422682a3891.js.map
Edit
221.0fc4d14d0a67f3a25d64.js
Edit
221.0fc4d14d0a67f3a25d64.js.map
Edit
2218.623d73bd0985ddf5f8c4.js
Edit
2218.623d73bd0985ddf5f8c4.js.map
Edit
2223.e65417164a45701ed9dc.js
Edit
2223.e65417164a45701ed9dc.js.map
Edit
2244.70c156ada2487a05595c.js
Edit
2244.70c156ada2487a05595c.js.map
Edit
2278.f887de0a65e1b784ea9f.js
Edit
2278.f887de0a65e1b784ea9f.js.map
Edit
2288.6a65ba08c6c0f4f83435.js
Edit
2288.6a65ba08c6c0f4f83435.js.map
Edit
2311.73e1a2b949d289f5d6c9.js
Edit
2311.73e1a2b949d289f5d6c9.js.map
Edit
2398.d142e32be48079fc63c0.js
Edit
2398.d142e32be48079fc63c0.js.map
Edit
2405.c1b37a7cc8182472f6a6.js
Edit
2405.c1b37a7cc8182472f6a6.js.map
Edit
2446.0418c7ea000998178d8b.js
Edit
2446.0418c7ea000998178d8b.js.map
Edit
2450.d73c024ff7273aebf911.js
Edit
2450.d73c024ff7273aebf911.js.map
Edit
2586.668c65b61e9ea31b5bca.js
Edit
2586.668c65b61e9ea31b5bca.js.map
Edit
265.ed6933785cc750cbd9ed.js
Edit
265.ed6933785cc750cbd9ed.js.map
Edit
2658.7f70ebc378803654a814.js
Edit
2658.7f70ebc378803654a814.js.map
Edit
2686.ae267304ddd1380c30c7.js
Edit
2686.ae267304ddd1380c30c7.js.map
Edit
2692.fa24ada7d987a7ee05f1.js
Edit
2692.fa24ada7d987a7ee05f1.js.map
Edit
2699.b79e57051a1a63376320.js
Edit
2699.b79e57051a1a63376320.js.map
Edit
2710.e1ac8e57578a838f5bd8.js
Edit
2710.e1ac8e57578a838f5bd8.js.map
Edit
2744.d6b14bf01022bdb8eab5.js
Edit
2744.d6b14bf01022bdb8eab5.js.map
Edit
2745.8049d948cb362dfc6cb3.js
Edit
2745.8049d948cb362dfc6cb3.js.map
Edit
2835.01beb5b1a252d779aad7.js
Edit
2835.01beb5b1a252d779aad7.js.map
Edit
2961.4b27b21453fdbb115dd4.js
Edit
2961.4b27b21453fdbb115dd4.js.map
Edit
2962.85c9dc0cca68efab5e0c.js
Edit
2962.85c9dc0cca68efab5e0c.js.map
Edit
2975.e64aaea6ff35a7d3b3fd.js
Edit
2975.e64aaea6ff35a7d3b3fd.js.map
Edit
3003.f51365051eb27cf765d8.js
Edit
3003.f51365051eb27cf765d8.js.map
Edit
3042.44bad7d2d0536000b808.js
Edit
3042.44bad7d2d0536000b808.js.map
Edit
3062.ad5844391370fcc7525a.js
Edit
3062.ad5844391370fcc7525a.js.map
Edit
3082.704af6779ad700a5fa42.js
Edit
3082.704af6779ad700a5fa42.js.map
Edit
3096.aed61083f1ba4803ae84.js
Edit
3096.aed61083f1ba4803ae84.js.map
Edit
3126.10c85e1f02105e470a69.js
Edit
3126.10c85e1f02105e470a69.js.map
Edit
3169.0b88a5a2340f70961599.js
Edit
3169.0b88a5a2340f70961599.js.map
Edit
3171.c79c28e2611563e2dbcb.js
Edit
3171.c79c28e2611563e2dbcb.js.map
Edit
3182.831f754ed3b6f10441a0.js
Edit
3182.831f754ed3b6f10441a0.js.map
Edit
3192.2cb90eadf3399270363e.js
Edit
3192.2cb90eadf3399270363e.js.map
Edit
3217.c6faaa4f5637068f90f3.js
Edit
3217.c6faaa4f5637068f90f3.js.map
Edit
3259.c8e4d6ad93201a56e49f.js
Edit
3259.c8e4d6ad93201a56e49f.js.map
Edit
3284.79c2897655286b0c1f6d.js
Edit
3284.79c2897655286b0c1f6d.js.map
Edit
3303.225dae64cff0c2280c3b.js
Edit
3303.225dae64cff0c2280c3b.js.map
Edit
3326.cabc370d66d7ecfbd2c3.js
Edit
3326.cabc370d66d7ecfbd2c3.js.map
Edit
344.85cff3029cbbb5463c7e.js
Edit
344.85cff3029cbbb5463c7e.js.map
Edit
3466.fda7da0cb4150e59da98.js
Edit
3466.fda7da0cb4150e59da98.js.map
Edit
3474.74dfd856a9528c758a57.js
Edit
3474.74dfd856a9528c758a57.js.map
Edit
348.fd20e2547f12dbed76c7.js
Edit
348.fd20e2547f12dbed76c7.js.map
Edit
3495.9c1ae6f61edf7aef207b.js
Edit
3495.9c1ae6f61edf7aef207b.js.map
Edit
3501.a0ee7c2b24136aa91eb5.js
Edit
3501.a0ee7c2b24136aa91eb5.js.map
Edit
3520.a3c2b474e2dcaf9879fc.js
Edit
3520.a3c2b474e2dcaf9879fc.js.map
Edit
3605.41e3c44dfe2ca2966198.js
Edit
3605.41e3c44dfe2ca2966198.js.map
Edit
362.e5ce68af98ee6713a4e7.js
Edit
362.e5ce68af98ee6713a4e7.js.map
Edit
3622.0b196041f825b42c5233.js
Edit
3622.0b196041f825b42c5233.js.map
Edit
3630.1ffe9229d5c27fd0823a.js
Edit
3630.1ffe9229d5c27fd0823a.js.map
Edit
3659.f5dc1bb19d36546aadb8.js
Edit
3659.f5dc1bb19d36546aadb8.js.map
Edit
3688.ec5e74c60569e9498687.js
Edit
3688.ec5e74c60569e9498687.js.map
Edit
3718.b570aa4fa35f8dfc686e.js
Edit
3718.b570aa4fa35f8dfc686e.js.map
Edit
3726.84ef8bb1304f7adbc7f3.js
Edit
3726.84ef8bb1304f7adbc7f3.js.map
Edit
398.ceeafcf522343c717c4b.js
Edit
398.ceeafcf522343c717c4b.js.map
Edit
4064.e52eb763993ad947e4a1.js
Edit
4064.e52eb763993ad947e4a1.js.map
Edit
407.594046bd73cc88c29e80.js
Edit
407.594046bd73cc88c29e80.js.map
Edit
4113.3fa5432815c4662eb03e.js
Edit
4113.3fa5432815c4662eb03e.js.map
Edit
4114.c4741f0a73781d3f87dc.js
Edit
4114.c4741f0a73781d3f87dc.js.map
Edit
4120.968e1408d894f8515330.js
Edit
4120.968e1408d894f8515330.js.map
Edit
4162.8b8a683fa98d677f9137.js
Edit
4162.8b8a683fa98d677f9137.js.map
Edit
4209.de7f2b850ee1292a67e5.js
Edit
4209.de7f2b850ee1292a67e5.js.map
Edit
4224.cc13db0c6e3f7fdb05c9.js
Edit
4224.cc13db0c6e3f7fdb05c9.js.map
Edit
4251.28e90ad13c8fe749062c.js
Edit
4251.28e90ad13c8fe749062c.js.map
Edit
4334.396d65b7ba31733108e9.js
Edit
4334.396d65b7ba31733108e9.js.map
Edit
4350.6db49924324f8061d361.js
Edit
4350.6db49924324f8061d361.js.map
Edit
4463.24a3e34bed64cbbb8b99.js
Edit
4463.24a3e34bed64cbbb8b99.js.map
Edit
4514.03e966fee9064d7305dd.js
Edit
4514.03e966fee9064d7305dd.js.map
Edit
4564.ea4a09ba96ddbf74a0ee.js
Edit
4564.ea4a09ba96ddbf74a0ee.js.map
Edit
46.7809585ddbb4791e248a.js
Edit
46.7809585ddbb4791e248a.js.map
Edit
4630.54d7f3b9d384c6b95bbc.js
Edit
4630.54d7f3b9d384c6b95bbc.js.map
Edit
4656.a07d832134b096826a58.js
Edit
4656.a07d832134b096826a58.js.map
Edit
468.d3a2ba8b0d226ca1475b.js
Edit
468.d3a2ba8b0d226ca1475b.js.map
Edit
4680.abd86af55b75e75326ab.js
Edit
4680.abd86af55b75e75326ab.js.map
Edit
4691.2f69f76af87a66a1513c.js
Edit
4691.2f69f76af87a66a1513c.js.map
Edit
4698.c9a2c562b12da12dc66e.js
Edit
4698.c9a2c562b12da12dc66e.js.map
Edit
4791.fc3ef0337811ab73b164.js
Edit
4791.fc3ef0337811ab73b164.js.map
Edit
4814.2d8cb562606e508512d8.js
Edit
4814.2d8cb562606e508512d8.js.map
Edit
4824.2da8107f19d58bf153e0.js
Edit
4824.2da8107f19d58bf153e0.js.map
Edit
4839.f4d2edd5c2678ef2b624.js
Edit
4839.f4d2edd5c2678ef2b624.js.map
Edit
4857.4971a98037d2ec3b663d.js
Edit
4857.4971a98037d2ec3b663d.js.map
Edit
4865.be02c1283a83523c4414.js
Edit
4865.be02c1283a83523c4414.js.map
Edit
494.5463fc5a297eaedd150f.js
Edit
494.5463fc5a297eaedd150f.js.map
Edit
4958.226af5f19bf47305a407.js
Edit
4958.226af5f19bf47305a407.js.map
Edit
4962.bbff24c5a85e9314600a.js
Edit
4962.bbff24c5a85e9314600a.js.map
Edit
4964.1f2cc5acc0078feb7b08.js
Edit
4964.1f2cc5acc0078feb7b08.js.map
Edit
4965.ccdc00d808390be53820.js
Edit
4965.ccdc00d808390be53820.js.map
Edit
5065.a2c71dab50ccb4174ee2.js
Edit
5065.a2c71dab50ccb4174ee2.js.map
Edit
5074.92e2d1ae98dcd913506e.js
Edit
5074.92e2d1ae98dcd913506e.js.map
Edit
5091.987ffc33b70121541e5d.js
Edit
5091.987ffc33b70121541e5d.js.map
Edit
5106.581eaf66a6592320d97a.js
Edit
5106.581eaf66a6592320d97a.js.map
Edit
5110.96d49ea826be96c65045.js
Edit
5110.96d49ea826be96c65045.js.map
Edit
5130.cbdddcd716a093bdbaac.js
Edit
5130.cbdddcd716a093bdbaac.js.map
Edit
5196.9b7364caf64a8583ad01.js
Edit
5196.9b7364caf64a8583ad01.js.map
Edit
5198.2cd64d4e16a385dd9b91.js
Edit
5198.2cd64d4e16a385dd9b91.js.map
Edit
5280.2c29942977baa2dfbe0e.js
Edit
5280.2c29942977baa2dfbe0e.js.map
Edit
5364.0288d9c98f74f26b73e7.js
Edit
5364.0288d9c98f74f26b73e7.js.map
Edit
5446.ad01d0b233122dd49849.js
Edit
5446.ad01d0b233122dd49849.js.map
Edit
5550.5bf3e7d23d6b104740fd.js
Edit
5550.5bf3e7d23d6b104740fd.js.map
Edit
5618.909592bbe054b70f2377.js
Edit
5618.909592bbe054b70f2377.js.map
Edit
5648.a1fc2b0cbbca9bfa1d94.js
Edit
5648.a1fc2b0cbbca9bfa1d94.js.map
Edit
5664.c55be32f6d459ac3f3d8.js
Edit
5664.c55be32f6d459ac3f3d8.js.map
Edit
5671.e1e396b75d7b95ef461f.js
Edit
5671.e1e396b75d7b95ef461f.js.map
Edit
5742.117597ec799ab75cb2f4.js
Edit
5742.117597ec799ab75cb2f4.js.map
Edit
5747.b9389680058c12ffba68.js
Edit
5747.b9389680058c12ffba68.js.map
Edit
5757.5a4b7f2368dd09da42be.js
Edit
5786.c45dfaf9e1d969472e5e.js
Edit
5786.c45dfaf9e1d969472e5e.js.map
Edit
5790.29b0a5797fd46e9664f5.js
Edit
5790.29b0a5797fd46e9664f5.js.map
Edit
5923.b9c876b4bf528d8511cb.js
Edit
5923.b9c876b4bf528d8511cb.js.map
Edit
5984.1efdc4bb85100bd19ca9.js
Edit
5984.1efdc4bb85100bd19ca9.js.map
Edit
5995.5c7a375f33ea1cd16daa.js
Edit
5995.5c7a375f33ea1cd16daa.js.map
Edit
6018.befdd11bf701ea71f7bf.js
Edit
6018.befdd11bf701ea71f7bf.js.map
Edit
6029.bdcbf27bcdd36812f646.js
Edit
6029.bdcbf27bcdd36812f646.js.map
Edit
6088.7f526abfdb4003574c68.js
Edit
6088.7f526abfdb4003574c68.js.map
Edit
613.084d33252856771cf6e1.js
Edit
613.084d33252856771cf6e1.js.map
Edit
6185.2a7c893c6b3f2f0dadb8.js
Edit
6185.2a7c893c6b3f2f0dadb8.js.map
Edit
6208.571f272269524cfd14e7.js
Edit
6208.571f272269524cfd14e7.js.map
Edit
6236.30d1fa6aee173c946c50.js
Edit
6236.30d1fa6aee173c946c50.js.map
Edit
6244.64f83fc5d05560979c51.js
Edit
6244.64f83fc5d05560979c51.js.map
Edit
6260.b8be95165766a81dade2.js
Edit
6260.b8be95165766a81dade2.js.map
Edit
630.56b78dcdaeeb9d9c2967.js
Edit
630.56b78dcdaeeb9d9c2967.js.map
Edit
6302.a2ffa52069511df9772f.js
Edit
6302.a2ffa52069511df9772f.js.map
Edit
6315.f4d87fc6f8ae3cb40e38.js
Edit
6315.f4d87fc6f8ae3cb40e38.js.map
Edit
6414.7520859a2d9cc0a63d7f.js
Edit
6414.7520859a2d9cc0a63d7f.js.map
Edit
6446.1d75a8140260005fffbd.js
Edit
6446.1d75a8140260005fffbd.js.map
Edit
6743.67a52a99e2fdd1ae1e10.js
Edit
6743.67a52a99e2fdd1ae1e10.js.map
Edit
6759.0454d3c1e41385379bdc.js
Edit
6759.0454d3c1e41385379bdc.js.map
Edit
6772.0d4a074848bc323be8f8.js
Edit
6772.0d4a074848bc323be8f8.js.map
Edit
680.726adca366b4ecb272db.js
Edit
680.726adca366b4ecb272db.js.map
Edit
6830.a4b0ecf3a6d784ca7609.js
Edit
6830.a4b0ecf3a6d784ca7609.js.map
Edit
6834.0c9ef40e2f2b5428983d.js
Edit
6834.0c9ef40e2f2b5428983d.js.map
Edit
6857.252a60422ee275193aa7.js
Edit
6857.252a60422ee275193aa7.js.map
Edit
6940.b6c74df14413f0188f0d.js
Edit
6940.b6c74df14413f0188f0d.js.map
Edit
6990.d663924714fc213b17c6.js
Edit
6990.d663924714fc213b17c6.js.map
Edit
7018.5a037d2577fedc8d10f1.js
Edit
7018.5a037d2577fedc8d10f1.js.map
Edit
7031.047b15171c23b248efa0.js
Edit
7031.047b15171c23b248efa0.js.map
Edit
7033.141597840e42815ef6a4.js
Edit
7033.141597840e42815ef6a4.js.map
Edit
7048.3746fc9a274bf8ff72f1.js
Edit
7048.3746fc9a274bf8ff72f1.js.map
Edit
7051.604a402d305e093c00c2.js
Edit
7051.604a402d305e093c00c2.js.map
Edit
7061.f18464bcd6c6d7455662.js
Edit
7061.f18464bcd6c6d7455662.js.map
Edit
7080.9cdd1b7a0bf62b48e1fe.js
Edit
7080.9cdd1b7a0bf62b48e1fe.js.map
Edit
7200.d4425528f6cee80f9931.js
Edit
7200.d4425528f6cee80f9931.js.map
Edit
7235.46f071d3e4d0bb976223.js
Edit
7235.46f071d3e4d0bb976223.js.map
Edit
7246.03f5a8496e53f64602e2.js
Edit
7246.03f5a8496e53f64602e2.js.map
Edit
7249.3bea4aaf890f89fdad45.js
Edit
7249.3bea4aaf890f89fdad45.js.map
Edit
7299.cdff402b076dfea09ead.js
Edit
7299.cdff402b076dfea09ead.js.map
Edit
7348.6fd722455e8c7e077815.js
Edit
7348.6fd722455e8c7e077815.js.map
Edit
7396.ded473b7a47dc42fbb59.js
Edit
7396.ded473b7a47dc42fbb59.js.map
Edit
7466.b7c17c526c7b734dd5f7.js
Edit
7466.b7c17c526c7b734dd5f7.js.map
Edit
7539.5f405cae3b15e1e2f6fa.js
Edit
7539.5f405cae3b15e1e2f6fa.js.map
Edit
7585.084552e02c66201a55be.js
Edit
7585.084552e02c66201a55be.js.map
Edit
7626.38819cc0696f2d25cf99.js
Edit
7626.38819cc0696f2d25cf99.js.map
Edit
7651.5024ed8dd1beb08d01ab.js
Edit
7651.5024ed8dd1beb08d01ab.js.map
Edit
7681.7ef7b4f86e99abd7b7e1.js
Edit
7681.7ef7b4f86e99abd7b7e1.js.map
Edit
7691.0ad86f0c686b19ce829e.js
Edit
7691.0ad86f0c686b19ce829e.js.map
Edit
7790.4c141092868e7208a087.js
Edit
7790.4c141092868e7208a087.js.map
Edit
7806.dff3509790e494ca5a45.js
Edit
7806.dff3509790e494ca5a45.js.map
Edit
7836.afe37ef4be354f0a3b91.js
Edit
7836.afe37ef4be354f0a3b91.js.map
Edit
7882.e1721e9d6ac2d421bcda.js
Edit
7882.e1721e9d6ac2d421bcda.js.map
Edit
7886.8499ded396232466be7d.js
Edit
7886.8499ded396232466be7d.js.map
Edit
7887.a6dcfd824d57598ba1c3.js
Edit
7887.a6dcfd824d57598ba1c3.js.map
Edit
7969.a048d8060cabf1aede33.js
Edit
7969.a048d8060cabf1aede33.js.map
Edit
7996.bd232896e4559d37a26f.js
Edit
7996.bd232896e4559d37a26f.js.map
Edit
8016.8145cd87abcdd0646db2.js
Edit
8016.8145cd87abcdd0646db2.js.map
Edit
8018.c31846109f2dff21d8c4.js
Edit
8018.c31846109f2dff21d8c4.js.map
Edit
8056.4e8f71ed4d507f89b487.js
Edit
8056.4e8f71ed4d507f89b487.js.map
Edit
8177.52abd0953ac914f69e26.js
Edit
8177.52abd0953ac914f69e26.js.map
Edit
8220.aeea4a8f0893b3447b56.js
Edit
8220.aeea4a8f0893b3447b56.js.map
Edit
8224.75bd73bf51ff7a2fc4a0.js
Edit
8224.75bd73bf51ff7a2fc4a0.js.map
Edit
8230.d65bce2998eec95c6082.js
Edit
8230.d65bce2998eec95c6082.js.map
Edit
8260.c1da67af19b9259d5651.js
Edit
8260.c1da67af19b9259d5651.js.map
Edit
8271.0ee36e030014244adb47.js
Edit
8271.0ee36e030014244adb47.js.map
Edit
8332.a62e8632a336661f2969.js
Edit
8332.a62e8632a336661f2969.js.map
Edit
8334.1196f5ddcef25711fc25.js
Edit
8334.1196f5ddcef25711fc25.js.map
Edit
8347.de402f9280cd7a316c57.js
Edit
8347.de402f9280cd7a316c57.js.map
Edit
8390.9de755da2e214cc845a3.js
Edit
8390.9de755da2e214cc845a3.js.map
Edit
8393.30e95ae45cbe5455dcda.js
Edit
8393.30e95ae45cbe5455dcda.js.map
Edit
8477.4dad0537d13cf9315e86.js
Edit
8477.4dad0537d13cf9315e86.js.map
Edit
8494.659892f00c9d15ae441a.js
Edit
8494.659892f00c9d15ae441a.js.map
Edit
8530.0460c988ee4a40ce7769.js
Edit
8530.0460c988ee4a40ce7769.js.map
Edit
8542.317c15ed57f68fcf0c97.js
Edit
8542.317c15ed57f68fcf0c97.js.map
Edit
8547.390120a5caf7646e0e3e.js
Edit
8547.390120a5caf7646e0e3e.js.map
Edit
8566.5c8f392bb383ab92eed0.js
Edit
8566.5c8f392bb383ab92eed0.js.map
Edit
8622.5acf73c1485a11dfb0ab.js
Edit
8622.5acf73c1485a11dfb0ab.js.map
Edit
8706.f17afa6bcdfd511d5b03.js
Edit
8706.f17afa6bcdfd511d5b03.js.map
Edit
874.d24410518317d605c708.js
Edit
874.d24410518317d605c708.js.map
Edit
8813.e5137844631f6ddedbce.js
Edit
8813.e5137844631f6ddedbce.js.map
Edit
8856.2720526447b3adb5c75f.js
Edit
8856.2720526447b3adb5c75f.js.map
Edit
886.5f3383e84b10a6530b97.js
Edit
886.5f3383e84b10a6530b97.js.map
Edit
8864.2f4ee982114c25634e55.js
Edit
8864.2f4ee982114c25634e55.js.map
Edit
8902.71f14964ec6cea84dc8e.js
Edit
8902.71f14964ec6cea84dc8e.js.map
Edit
8932.e59e50ddb63414e0f2b9.js
Edit
8932.e59e50ddb63414e0f2b9.js.map
Edit
8990.665213a5c89afd6b2f83.js
Edit
8990.665213a5c89afd6b2f83.js.map
Edit
9034.a32e36472481cbe5d72d.js
Edit
9034.a32e36472481cbe5d72d.js.map
Edit
9038.f03b25f160057d4a0bf6.js
Edit
9038.f03b25f160057d4a0bf6.js.map
Edit
904.b68cd2a0cd6d68c5f1ae.js
Edit
904.b68cd2a0cd6d68c5f1ae.js.map
Edit
9044.441f64d6d946cc93be46.js
Edit
9044.441f64d6d946cc93be46.js.map
Edit
9147.8309cadbc384209d62e5.js
Edit
9147.8309cadbc384209d62e5.js.map
Edit
9150.38487365ffd149b730af.js
Edit
9150.38487365ffd149b730af.js.map
Edit
9292.e6befb57f8f116ad95a8.js
Edit
9292.e6befb57f8f116ad95a8.js.map
Edit
9355.95d7e1782f93f339549e.js
Edit
9355.95d7e1782f93f339549e.js.map
Edit
9388.88d95a230e9432e7037b.js
Edit
9388.88d95a230e9432e7037b.js.map
Edit
9390.c72fcd228017f7647b38.js
Edit
9390.c72fcd228017f7647b38.js.map
Edit
9414.642bfe0d5eb16efd0c16.js
Edit
9414.642bfe0d5eb16efd0c16.js.map
Edit
9449.502f2a824d0203e88d4d.js
Edit
9449.502f2a824d0203e88d4d.js.map
Edit
946.48c5e8c688cf29424295.js
Edit
946.48c5e8c688cf29424295.js.map
Edit
9473.e6fc327da88d88712828.js
Edit
9473.e6fc327da88d88712828.js.map
Edit
9510.1e255e96fe40aad2ed6f.js
Edit
9510.1e255e96fe40aad2ed6f.js.map
Edit
9521.e65411d726c29d77c526.js
Edit
9521.e65411d726c29d77c526.js.map
Edit
9538.a2289ff9ad06e24e391f.js
Edit
9538.a2289ff9ad06e24e391f.js.map
Edit
957.3c35d66aa698d8bdfe05.js
Edit
957.3c35d66aa698d8bdfe05.js.map
Edit
9571.41558d40bff9ea8c0726.js
Edit
9571.41558d40bff9ea8c0726.js.map
Edit
9578.9cfae16465bb9bc1f336.js
Edit
9578.9cfae16465bb9bc1f336.js.map
Edit
968.d4b150f9211c478b7b05.js
Edit
968.d4b150f9211c478b7b05.js.map
Edit
970.46f17b76711e4961a575.js
Edit
970.46f17b76711e4961a575.js.map
Edit
9700.02180b7a06c8a1f7606b.js
Edit
9700.02180b7a06c8a1f7606b.js.map
Edit
9744.aa6baaf988a68fa6a9ba.js
Edit
9744.aa6baaf988a68fa6a9ba.js.map
Edit
9820.6b462d83575efd05c883.js
Edit
9820.6b462d83575efd05c883.js.map
Edit
9838.06bd7dfd4290786f80e3.js
Edit
9838.06bd7dfd4290786f80e3.js.map
Edit
9992.fb08517d3ff77e887443.js
Edit
9992.fb08517d3ff77e887443.js.map
Edit
9996.21c451f22ff76b4bb683.js
Edit
9996.21c451f22ff76b4bb683.js.map
Edit
AdminAuthentication.076c98c6380fd1e42f7e.js
Edit
AdminAuthentication.076c98c6380fd1e42f7e.js.map
Edit
AdminEditOrgPage.8df8167ea6ff8f4803bd.js
Edit
AdminEditOrgPage.8df8167ea6ff8f4803bd.js.map
Edit
AdminListOrgsPage.176dac9ed391bda8952b.js
Edit
AdminListOrgsPage.176dac9ed391bda8952b.js.map
Edit
AdminSettings.7373ed8fa9b943bb2098.js
Edit
AdminSettings.7373ed8fa9b943bb2098.js.map
Edit
AlertGroups.81264e6e5009c36eed6e.js
Edit
AlertGroups.81264e6e5009c36eed6e.js.map
Edit
AlertRuleListIndex.98e7328feeaa2ffe67eb.js
Edit
AlertRuleListIndex.98e7328feeaa2ffe67eb.js.map
Edit
AlertingDisabled.b2c834be0ca4666dd793.js
Edit
AlertingDisabled.b2c834be0ca4666dd793.js.map
Edit
AlertingGroupDetails.3a2c6ef8085b505852e4.js
Edit
AlertingGroupDetails.3a2c6ef8085b505852e4.js.map
Edit
AlertingGroupEdit.69cfe9d5f37a1fc65326.js
Edit
AlertingGroupEdit.69cfe9d5f37a1fc65326.js.map
Edit
AlertingHome.06f307ab9a2a5d8b7f93.js
Edit
AlertingHome.06f307ab9a2a5d8b7f93.js.map
Edit
AlertingImportFromDSRules.f1224bcb622d25e2c94f.js
Edit
AlertingImportFromDSRules.f1224bcb622d25e2c94f.js.map
Edit
AlertingRedirectToRule.9ed1d16829d6833d2827.js
Edit
AlertingRedirectToRule.9ed1d16829d6833d2827.js.map
Edit
AlertingRuleForm.2e69d3f00eb6221e7355.js
Edit
AlertingRuleForm.2e69d3f00eb6221e7355.js.map
Edit
AlertingSettings.7a5f782f877cec4790cb.js
Edit
AlertingSettings.7a5f782f877cec4790cb.js.map
Edit
AlertingTriage.1174f36b4937ad0047c1.js
Edit
AlertingTriage.1174f36b4937ad0047c1.js.map
Edit
BenchmarksPage.ef387f4598ba2b2236ad.js
Edit
BenchmarksPage.ef387f4598ba2b2236ad.js.map
Edit
BookmarksPage.8fe93eb7377073f0c985.js
Edit
BookmarksPage.8fe93eb7377073f0c985.js.map
Edit
ChangePasswordPage.f21b0b1dd107ccd33c1a.js
Edit
ChangePasswordPage.f21b0b1dd107ccd33c1a.js.map
Edit
Connections.949b6389e73bcadb2109.js
Edit
Connections.949b6389e73bcadb2109.js.map
Edit
ContactPoints.9ae2d1927d60c6169b87.js
Edit
ContactPoints.9ae2d1927d60c6169b87.js.map
Edit
CorrelationsFeatureToggle.ec2f1aefce6b456e15eb.js
Edit
CorrelationsFeatureToggle.ec2f1aefce6b456e15eb.js.map
Edit
CorrelationsPage.bd7fcd24ed0b5fe8ac3e.js
Edit
CorrelationsPage.bd7fcd24ed0b5fe8ac3e.js.map
Edit
CreateTeam.429acf93986740280312.js
Edit
CreateTeam.429acf93986740280312.js.map
Edit
DashboardImport.3e9b6f980b81d6f1c755.js
Edit
DashboardImport.3e9b6f980b81d6f1c755.js.map
Edit
DashboardListPage.abeb0c29f072f888f9fb.js
Edit
DashboardListPage.abeb0c29f072f888f9fb.js.map
Edit
DashboardPage.72557fe6dd1a022b7d48.js
Edit
DashboardPage.72557fe6dd1a022b7d48.js.map
Edit
DashboardPageProxy.80adfefad8a885d8e2ef.js
Edit
DashboardPageProxy.80adfefad8a885d8e2ef.js.map
Edit
DashboardScenePage.83fe1fa9509b50120d65.js
Edit
DashboardScenePage.83fe1fa9509b50120d65.js.map
Edit
EditContactPoint.0c33428ddc8ba974d946.js
Edit
EditContactPoint.0c33428ddc8ba974d946.js.map
Edit
EditMuteTiming.8760cc9c77560acf0cd6.js
Edit
EditMuteTiming.8760cc9c77560acf0cd6.js.map
Edit
EditRepositoryPage.d71faaab1af2c8d70a22.js
Edit
EditRepositoryPage.d71faaab1af2c8d70a22.js.map
Edit
EmbeddedDashboard.57de550bce819e3d52e6.js
Edit
EmbeddedDashboard.57de550bce819e3d52e6.js.map
Edit
FileHistoryPage.154ab77c19bbe0ebed20.js
Edit
FileHistoryPage.154ab77c19bbe0ebed20.js.map
Edit
FileStatusPage.36f58cd61202ec603d22.js
Edit
FileStatusPage.36f58cd61202ec603d22.js.map
Edit
FolderAlerting.0b9acb6c42276aaee57d.js
Edit
FolderAlerting.0b9acb6c42276aaee57d.js.map
Edit
FolderLibraryPanelsPage.44f8cabf542ec314d176.js
Edit
FolderLibraryPanelsPage.44f8cabf542ec314d176.js.map
Edit
GettingStartedPage.4bea37f1c9bdcfd0f41b.js
Edit
GettingStartedPage.4bea37f1c9bdcfd0f41b.js.map
Edit
GlobalConfig.1377596507974d18caf6.js
Edit
GlobalConfig.1377596507974d18caf6.js.map
Edit
HistoryPage.4da98f4fa313ee3676ca.js
Edit
HistoryPage.4da98f4fa313ee3676ca.js.map
Edit
LdapSettingsPage.0e9f08d5e59150ecf466.js
Edit
LdapSettingsPage.0e9f08d5e59150ecf466.js.map
Edit
LibraryPanelsPage.824580d7751526c658e2.js
Edit
LibraryPanelsPage.824580d7751526c658e2.js.map
Edit
ListPublicDashboardPage.64c26ffd3ebe6c9076f3.js
Edit
ListPublicDashboardPage.64c26ffd3ebe6c9076f3.js.map
Edit
LoginPage.db48423ed1b455431daa.js
Edit
LoginPage.db48423ed1b455431daa.js.map
Edit
MetricsDrilldownRedirect.fcad4bdff346974952f4.js
Edit
MetricsDrilldownRedirect.fcad4bdff346974952f4.js.map
Edit
MigrateToCloud.5b474ad00e8a3d979750.js
Edit
MigrateToCloud.5b474ad00e8a3d979750.js.map
Edit
NewMuteTiming.2f6302420674f1c73aba.js
Edit
NewMuteTiming.2f6302420674f1c73aba.js.map
Edit
NewOrgPage.be31eaee06e2043d609b.js
Edit
NewOrgPage.be31eaee06e2043d609b.js.map
Edit
NewReceiverView.f1d83eb66a39882b8661.js
Edit
NewReceiverView.f1d83eb66a39882b8661.js.map
Edit
NewSilencePage.2643a48031f7e5d8f376.js
Edit
NewSilencePage.2643a48031f7e5d8f376.js.map
Edit
NotificationPoliciesPage.9333d10ecad1452ebf27.js
Edit
NotificationPoliciesPage.9333d10ecad1452ebf27.js.map
Edit
NotificationsPage.57df4ff5ba1433a4345d.js
Edit
NotificationsPage.57df4ff5ba1433a4345d.js.map
Edit
OrgDetailsPage.7b5835c30585aae81343.js
Edit
OrgDetailsPage.7b5835c30585aae81343.js.map
Edit
PlaylistEditPage.8310e384af659e40c313.js
Edit
PlaylistEditPage.8310e384af659e40c313.js.map
Edit
PlaylistNewPage.f45b642a98a747e28c0d.js
Edit
PlaylistNewPage.f45b642a98a747e28c0d.js.map
Edit
PlaylistPage.9af74957a1cdfb125338.js
Edit
PlaylistPage.9af74957a1cdfb125338.js.map
Edit
PlaylistStartPage.8011a98267ac64c7fa05.js
Edit
PlaylistStartPage.8011a98267ac64c7fa05.js.map
Edit
PluginExtensionsLog.54c02047d569b0c05823.js
Edit
PluginExtensionsLog.54c02047d569b0c05823.js.map
Edit
PluginListPage.e50c18fed21c23ca4ee8.js
Edit
PluginListPage.e50c18fed21c23ca4ee8.js.map
Edit
PluginPage.ae424531bce63dd4721e.js
Edit
PluginPage.ae424531bce63dd4721e.js.map
Edit
ProfileFeatureTogglePage.27378dcbb7520611348e.js
Edit
ProfileFeatureTogglePage.27378dcbb7520611348e.js.map
Edit
ProvisioningWizardPage.c4e4a8f431b4719b0e95.js
Edit
ProvisioningWizardPage.c4e4a8f431b4719b0e95.js.map
Edit
PublicDashboardPage.33d6ec8f685f1b70b9a6.js
Edit
PublicDashboardPage.33d6ec8f685f1b70b9a6.js.map
Edit
RecentlyDeleted.5e0ec16474d939fd9683.js
Edit
RecentlyDeleted.5e0ec16474d939fd9683.js.map
Edit
RecentlyDeletedPage.1dbc2b80b28204de8237.js
Edit
RecentlyDeletedPage.1dbc2b80b28204de8237.js.map
Edit
RepositoryListPage.ec3a0af1cbe2740800bf.js
Edit
RepositoryListPage.ec3a0af1cbe2740800bf.js.map
Edit
RepositoryStatusPage.9aee60589e35a4a19ec2.js
Edit
RepositoryStatusPage.9aee60589e35a4a19ec2.js.map
Edit
SelectOrgPage.910a8d842019a6d7fe93.js
Edit
SelectOrgPage.910a8d842019a6d7fe93.js.map
Edit
SendResetMailPage.513361d6980f98ff8139.js
Edit
SendResetMailPage.513361d6980f98ff8139.js.map
Edit
ServerStats.2830ca154f465dbdecea.js
Edit
ServerStats.2830ca154f465dbdecea.js.map
Edit
ServiceAccountCreatePage.80fcbdd2b7f5aa4e2da1.js
Edit
ServiceAccountCreatePage.80fcbdd2b7f5aa4e2da1.js.map
Edit
ServiceAccountPage.48944056459bb412ff33.js
Edit
ServiceAccountPage.48944056459bb412ff33.js.map
Edit
ServiceAccountsPage.d20b1eb9f87661f10b45.js
Edit
ServiceAccountsPage.d20b1eb9f87661f10b45.js.map
Edit
SignupInvited.fe2c29f380e9888c28cf.js
Edit
SignupInvited.fe2c29f380e9888c28cf.js.map
Edit
SilencesTablePage.b998fdbdcc3d60a81739.js
Edit
SilencesTablePage.b998fdbdcc3d60a81739.js.map
Edit
SnapshotListPage.6feaf24adb92e6a302ec.js
Edit
SnapshotListPage.6feaf24adb92e6a302ec.js.map
Edit
SoloPanelPage.7fc6a934aaadf4c1f84d.js
Edit
SoloPanelPage.7fc6a934aaadf4c1f84d.js.map
Edit
SoloPanelPageOld.bde57e000dd0a0108685.js
Edit
SoloPanelPageOld.bde57e000dd0a0108685.js.map
Edit
SupportBundles.1f46603ad3494624d67a.js
Edit
SupportBundles.1f46603ad3494624d67a.js.map
Edit
SupportBundlesCreate.5eaea61a9713f057277b.js
Edit
SupportBundlesCreate.5eaea61a9713f057277b.js.map
Edit
TeamList.6b088f83e6e8cb66b21d.js
Edit
TeamList.6b088f83e6e8cb66b21d.js.map
Edit
TeamPages.9d8b5dceef8be43c6923.js
Edit
TeamPages.9d8b5dceef8be43c6923.js.map
Edit
Templates.7a02a8497ebca052dcfb.js
Edit
Templates.7a02a8497ebca052dcfb.js.map
Edit
TestStuffPage.982c641592b2f7c9db40.js
Edit
TestStuffPage.982c641592b2f7c9db40.js.map
Edit
ThemePlayground.aeeec77fd8e9c1482f55.js
Edit
ThemePlayground.aeeec77fd8e9c1482f55.js.map
Edit
UserAdminPage.fc4d562eef05d9f59aca.js
Edit
UserAdminPage.fc4d562eef05d9f59aca.js.map
Edit
UserCreatePage.b7036214c66612fb31e9.js
Edit
UserCreatePage.b7036214c66612fb31e9.js.map
Edit
UserInvitePage.4a9bcd4084d7ae454c73.js
Edit
UserInvitePage.4a9bcd4084d7ae454c73.js.map
Edit
UserListPage.a452e1153ae820f58ac9.js
Edit
UserListPage.a452e1153ae820f58ac9.js.map
Edit
UserProfileEditPage.82c11690282e669eabb1.js
Edit
UserProfileEditPage.82c11690282e669eabb1.js.map
Edit
alert-rules-drawer-content.c95bb5ddd3fc813cae92.js
Edit
alert-rules-drawer-content.c95bb5ddd3fc813cae92.js.map
Edit
alert-rules-toolbar-button.0d86c1adae7edb55ff76.js
Edit
alert-rules-toolbar-button.0d86c1adae7edb55ff76.js.map
Edit
alertListPanel.0110106a8d1ab70d65d5.js
Edit
alertListPanel.0110106a8d1ab70d65d5.js.map
Edit
alertmanagerPlugin.2b59de5e7b7a556f87f1.js
Edit
alertmanagerPlugin.2b59de5e7b7a556f87f1.js.map
Edit
annoListPanel.0005a0eab0b05e24d970.js
Edit
annoListPanel.0005a0eab0b05e24d970.js.map
Edit
app.8385deda1df49aa75ec2.js
Edit
app.8385deda1df49aa75ec2.js.map
Edit
assets-manifest.json
Edit
barChartPanel.eecdaeab7d146d477721.js
Edit
barChartPanel.eecdaeab7d146d477721.js.map
Edit
barGaugePanel.6d9e94bbb72ba92a0e9b.js
Edit
barGaugePanel.6d9e94bbb72ba92a0e9b.js.map
Edit
candlestickPanel.af0e0decd06e7b7ab286.js
Edit
candlestickPanel.af0e0decd06e7b7ab286.js.map
Edit
canvasPanel.ddab72fab6e58c3419b2.js
Edit
canvasPanel.ddab72fab6e58c3419b2.js.map
Edit
cloudwatchPlugin.06ef34f60000c4f7ea37.js
Edit
cloudwatchPlugin.06ef34f60000c4f7ea37.js.map
Edit
dark.b66fa87185b9a313ec14.js
Edit
dashListPanel.23b954da0c4888602048.js
Edit
dashListPanel.23b954da0c4888602048.js.map
Edit
dataGridPanel.bb5d4b678cba38dd380b.js
Edit
debugPanel.fff63da32084d7a2e236.js
Edit
debugPanel.fff63da32084d7a2e236.js.map
Edit
elasticsearchPlugin.3f2edb012f5162b48903.js
Edit
elasticsearchPlugin.3f2edb012f5162b48903.js.map
Edit
explore-feature-toggle-page.3de03fa91c88d05cea1c.js
Edit
explore-feature-toggle-page.3de03fa91c88d05cea1c.js.map
Edit
explore.dd32637df83326225e0d.js
Edit
explore.dd32637df83326225e0d.js.map
Edit
flamegraphPanel.cc6c5b4bcd69e406fbb7.js
Edit
flamegraphPanel.cc6c5b4bcd69e406fbb7.js.map
Edit
gaugePanel.5da3c4e39a652e281cc4.js
Edit
gaugePanel.5da3c4e39a652e281cc4.js.map
Edit
gazetteer
Edit
geomapPanel.67ebb4567e9b5fa5074b.js
Edit
gettingStartedPanel.833059170dbbf8d5c4bf.js
Edit
gettingStartedPanel.833059170dbbf8d5c4bf.js.map
Edit
grafana.1492.25120d27db88f863e058.css
Edit
grafana.4350.a45e45977094df4a0bc9.css
Edit
grafana.5790.ffb3a9cd952d3cd7471b.css
Edit
grafana.DashboardPage.a66335f88cd003e4a44f.css
Edit
grafana.DashboardPageProxy.a66335f88cd003e4a44f.css
Edit
grafana.app.1f6473bb54b1e1647be8.css
Edit
grafana.dark.1e8d85816912aadbbba5.css
Edit
grafana.dataGridPanel.c1fc5db1829b1b31eb4d.css
Edit
grafana.geomapPanel.0057d964fa972bb207ec.css
Edit
grafana.light.111a5a99fcebc0962ddc.css
Edit
grafana.livePanel.25120d27db88f863e058.css
Edit
grafana.react-monaco-editor.ffb3a9cd952d3cd7471b.css
Edit
grafana.swagger.d0a2da197b9827204ac1.css
Edit
grafana.tablePanel.25120d27db88f863e058.css
Edit
grafanaPlugin.f21cdb4b84a732cc9dd8.js
Edit
grafanaPlugin.f21cdb4b84a732cc9dd8.js.map
Edit
heatmapPanel.7834b997bc573eddba88.js
Edit
heatmapPanel.7834b997bc573eddba88.js.map
Edit
histogramPanel.9953bfeccf8774500c0c.js
Edit
histogramPanel.9953bfeccf8774500c0c.js.map
Edit
img
Edit
influxdbPlugin.7a899e63be0a65d41e13.js
Edit
influxdbPlugin.7a899e63be0a65d41e13.js.map
Edit
light.827d442410485e491818.js
Edit
livePanel.2a43f499bc746d928d45.js
Edit
livePanel.2a43f499bc746d928d45.js.map
Edit
logsPanel.a328022d248508a083c1.js
Edit
logsPanel.a328022d248508a083c1.js.map
Edit
loki-query-field.f9a0b82b636d4821760c.js
Edit
loki-query-field.f9a0b82b636d4821760c.js.map
Edit
maps
Edit
mixedPlugin.3a69de93f366afbb2f85.js
Edit
newsPanel.c17f40f7c88ea14620e7.js
Edit
newsPanel.c17f40f7c88ea14620e7.js.map
Edit
nodeGraphPanel.f717a9075d994a9a8af4.js
Edit
nodeGraphPanel.f717a9075d994a9a8af4.js.map
Edit
opentsdbPlugin.1795eab1c223ea030c2e.js
Edit
opentsdbPlugin.1795eab1c223ea030c2e.js.map
Edit
pieChartPanel.45166aa6d57d163817ea.js
Edit
pieChartPanel.45166aa6d57d163817ea.js.map
Edit
prometheusPlugin.c3a55eb5353085fc3d2b.js
Edit
prometheusPlugin.c3a55eb5353085fc3d2b.js.map
Edit
radialBarPanel.294c52d497d8f5c2bebb.js
Edit
radialBarPanel.294c52d497d8f5c2bebb.js.map
Edit
runtime.a37cc2f12a959f33871a.js
Edit
runtime.a37cc2f12a959f33871a.js.map
Edit
sql-query-editor.e767d4a2aef360034bd9.js
Edit
sql-query-editor.e767d4a2aef360034bd9.js.map
Edit
statPanel.3a7f191bfb27fd320014.js
Edit
statPanel.3a7f191bfb27fd320014.js.map
Edit
stateTimelinePanel.08d857b143ef89dc195f.js
Edit
stateTimelinePanel.08d857b143ef89dc195f.js.map
Edit
static
Edit
statusHistoryPanel.29f7b8dc01039ba795af.js
Edit
statusHistoryPanel.29f7b8dc01039ba795af.js.map
Edit
swagger.06875a6266679f54141d.js
Edit
swagger.06875a6266679f54141d.js.map
Edit
tablePanel.43861ce2a60617dcd19d.js
Edit
tablePanel.43861ce2a60617dcd19d.js.map
Edit
textPanel.867ee60d01b2039aa159.js
Edit
textPanel.867ee60d01b2039aa159.js.map
Edit
timeseriesPanel.b4a947da450030262a31.js
Edit
timeseriesPanel.b4a947da450030262a31.js.map
Edit
tracesPanel.35bfc3e5ff6bea4212a3.js
Edit
tracesPanel.35bfc3e5ff6bea4212a3.js.map
Edit
trendPanel.001aff2bd153e737c464.js
Edit
trendPanel.001aff2bd153e737c464.js.map
Edit
vis-data.b34535ebabc0fcb91557.js
Edit
vis-data.b34535ebabc0fcb91557.js.map
Edit
vis-network.1b41caf21892c9525709.js
Edit
vis-network.1b41caf21892c9525709.js.map
Edit
welcomeBanner.1a693c9dc02006be4f0b.js
Edit
welcomeBanner.1a693c9dc02006be4f0b.js.map
Edit
xychart.cb20af67a6c495ba6ccd.js
Edit
xychart.cb20af67a6c495ba6ccd.js.map
Edit