/usr/share/grafana/public/build
{"version":3,"file":"sql-query-editor.e767d4a2aef360034bd9.js","mappings":"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","sources":["webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/EditorRows.js","webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/EditorHeader.js","webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/AccessoryButton.js","webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/EditorList.js","webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/EditorRow.js","webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/FlexItem.js","webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/EditorStack.js","webpack://grafana/./packages/grafana-sql/src/components/ConfirmModal.tsx","webpack://grafana/./packages/grafana-sql/src/components/DatasetSelector.tsx","webpack://grafana/./packages/grafana-sql/src/components/TableSelector.tsx","webpack://grafana/./packages/grafana-sql/src/components/QueryHeader.tsx","webpack://grafana/./packages/grafana-sql/src/components/query-editor-raw/QueryEditorRaw.tsx","webpack://grafana/./packages/grafana-sql/src/components/query-editor-raw/QueryValidator.tsx","webpack://grafana/./packages/grafana-sql/src/components/query-editor-raw/QueryToolbox.tsx","webpack://grafana/./packages/grafana-sql/src/components/query-editor-raw/RawEditor.tsx","webpack://grafana/./packages/grafana-sql/src/utils/getColumnsWithIndices.ts","webpack://grafana/./packages/grafana-sql/src/utils/useSqlChange.ts","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/GroupByRow.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/SQLGroupByRow.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/OrderByRow.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/SQLOrderByRow.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/AwesomeQueryBuilder.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/WhereRow.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/SQLWhereRow.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/SelectColumn.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/SelectCustomFunctionParameters.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/SelectFunctionParameters.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/SelectRow.tsx","webpack://grafana/./packages/grafana-sql/src/components/visual-query-builder/VisualEditor.tsx","webpack://grafana/./packages/grafana-sql/src/components/QueryEditor.tsx","webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/InputGroup.js","webpack://grafana/./node_modules/@grafana/plugin-ui/dist/esm/components/QueryEditor/InlineSelect.js"],"sourcesContent":["import React__default from 'react';\nimport { EditorStack } from './EditorStack.js';\n\nconst EditorRows = ({ children }) => {\n return /* @__PURE__ */ React__default.createElement(EditorStack, { gap: 0.5, direction: \"column\" }, children);\n};\n\nexport { EditorRows };\n//# sourceMappingURL=EditorRows.js.map\n","import { css } from '@emotion/css';\nimport React__default from 'react';\nimport '@grafana/data';\nimport { useStyles2 } from '@grafana/ui';\n\nconst EditorHeader = ({ children }) => {\n const styles = useStyles2(getStyles);\n return /* @__PURE__ */ React__default.createElement(\"div\", { className: styles.root }, children);\n};\nconst getStyles = (theme) => ({\n root: css({\n display: \"flex\",\n flexWrap: \"wrap\",\n alignItems: \"center\",\n gap: theme.spacing(3),\n minHeight: theme.spacing(4)\n })\n});\n\nexport { EditorHeader };\n//# sourceMappingURL=EditorHeader.js.map\n","import { cx, css } from '@emotion/css';\nimport React__default from 'react';\nimport '@grafana/data';\nimport { useStyles2, Button } from '@grafana/ui';\n\nconst AccessoryButton = ({ className, ...props }) => {\n const styles = useStyles2(getButtonStyles);\n return /* @__PURE__ */ React__default.createElement(Button, { ...props, className: cx(className, styles.button) });\n};\nconst getButtonStyles = (theme) => ({\n button: css({\n paddingLeft: theme.spacing(3 / 2),\n paddingRight: theme.spacing(3 / 2)\n })\n});\n\nexport { AccessoryButton };\n//# sourceMappingURL=AccessoryButton.js.map\n","import { Button } from '@grafana/ui';\nimport React__default from 'react';\nimport { EditorStack } from './EditorStack.js';\n\nconst EditorList = React__default.forwardRef(function EditorList2({ items, renderItem, onChange }, ref) {\n const onAddItem = () => {\n const newItems = [...items, {}];\n onChange(newItems);\n };\n const onChangeItem = (itemIndex, newItem) => {\n const newItems = [...items];\n newItems[itemIndex] = newItem;\n onChange(newItems);\n };\n const onDeleteItem = (itemIndex) => {\n const newItems = [...items];\n newItems.splice(itemIndex, 1);\n onChange(newItems);\n };\n return /* @__PURE__ */ React__default.createElement(EditorStack, null, items.map((item, index) => /* @__PURE__ */ React__default.createElement(\"div\", { key: index }, renderItem(\n item,\n (newItem) => onChangeItem(index, newItem),\n () => onDeleteItem(index)\n ))), /* @__PURE__ */ React__default.createElement(Button, { ref, onClick: onAddItem, variant: \"secondary\", size: \"md\", icon: \"plus\", \"aria-label\": \"Add\", type: \"button\" }));\n});\n\nexport { EditorList };\n//# sourceMappingURL=EditorList.js.map\n","import { css } from '@emotion/css';\nimport React__default from 'react';\nimport '@grafana/data';\nimport { useStyles2 } from '@grafana/ui';\nimport { EditorStack } from './EditorStack.js';\n\nconst EditorRow = ({ children }) => {\n const styles = useStyles2(getStyles);\n return /* @__PURE__ */ React__default.createElement(\"div\", { className: styles.root }, /* @__PURE__ */ React__default.createElement(EditorStack, { gap: 2 }, children));\n};\nconst getStyles = (theme) => {\n return {\n root: css({\n padding: theme.spacing(1),\n backgroundColor: theme.colors.background.secondary,\n borderRadius: theme.shape.radius.default\n })\n };\n};\n\nexport { EditorRow };\n//# sourceMappingURL=EditorRow.js.map\n","import React__default from 'react';\n\nconst FlexItem = ({ grow, shrink }) => {\n return /* @__PURE__ */ React__default.createElement(\"div\", { style: { display: \"block\", flexGrow: grow, flexShrink: shrink } });\n};\n\nexport { FlexItem };\n//# sourceMappingURL=FlexItem.js.map\n","import React__default from 'react';\nimport { Stack } from '@grafana/ui';\nimport '@grafana/data';\n\nconst EditorStack = ({ children, wrap: wrapItems = true, ...props }) => {\n var _a, _b;\n return /* @__PURE__ */ React__default.createElement(Stack, { wrap: wrapItems ? \"wrap\" : undefined, direction: (_a = props.direction) != null ? _a : \"row\", gap: (_b = props.gap) != null ? _b : 2, ...props }, children);\n};\n\nexport { EditorStack };\n//# sourceMappingURL=EditorStack.js.map\n","import { css } from '@emotion/css';\nimport { useRef, useEffect } from 'react';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { t, Trans } from '@grafana/i18n';\nimport { Button, Icon, Modal, useStyles2 } from '@grafana/ui';\n\ntype ConfirmModalProps = {\n isOpen: boolean;\n onCancel?: () => void;\n onDiscard?: () => void;\n onCopy?: () => void;\n};\nexport function ConfirmModal({ isOpen, onCancel, onDiscard, onCopy }: ConfirmModalProps) {\n const buttonRef = useRef<HTMLButtonElement>(null);\n const styles = useStyles2(getStyles);\n\n // Moved from grafana/ui\n useEffect(() => {\n // for some reason autoFocus property did no work on this button, but this does\n if (isOpen) {\n buttonRef.current?.focus();\n }\n }, [isOpen]);\n\n return (\n <Modal\n title={\n <div className={styles.modalHeaderTitle}>\n <Icon name=\"exclamation-triangle\" size=\"lg\" />\n <span className={styles.titleText}>\n <Trans i18nKey=\"grafana-sql.components.confirm-modal.warning\">Warning</Trans>\n </span>\n </div>\n }\n ariaLabel={t('grafana-sql.components.confirm-modal.warning', 'Warning')}\n onDismiss={onCancel}\n isOpen={isOpen}\n >\n <p>\n <Trans i18nKey=\"grafana-sql.components.confirm-modal.builder-mode\">\n Builder mode does not display changes made in code. The query builder will display the last changes you made\n in builder mode.\n </Trans>\n </p>\n <p>\n <Trans i18nKey=\"grafana-sql.components.confirm-modal.clipboard\">\n Do you want to copy your code to the clipboard?\n </Trans>\n </p>\n <Modal.ButtonRow>\n <Button type=\"button\" variant=\"secondary\" onClick={onCancel} fill=\"outline\">\n <Trans i18nKey=\"grafana-sql.components.confirm-modal.cancel\">Cancel</Trans>\n </Button>\n <Button variant=\"destructive\" type=\"button\" onClick={onDiscard} ref={buttonRef}>\n <Trans i18nKey=\"grafana-sql.components.confirm-modal.discard-code-and-switch\">Discard code and switch</Trans>\n </Button>\n <Button variant=\"primary\" onClick={onCopy}>\n <Trans i18nKey=\"grafana-sql.components.confirm-modal.copy-code-and-switch\">Copy code and switch</Trans>\n </Button>\n </Modal.ButtonRow>\n </Modal>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n titleText: css({\n paddingLeft: theme.spacing(2),\n }),\n modalHeaderTitle: css({\n fontSize: theme.typography.size.lg,\n float: 'left',\n paddingTop: theme.spacing(1),\n margin: theme.spacing(0, 2),\n }),\n});\n","import { useAsync } from 'react-use';\n\nimport { SelectableValue } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { Select } from '@grafana/ui';\n\nimport { DB, ResourceSelectorProps, SQLDialect, toOption } from '../types';\n\nexport interface DatasetSelectorProps extends ResourceSelectorProps {\n db: DB;\n dataset: string | undefined;\n preconfiguredDataset: string;\n dialect: SQLDialect;\n onChange: (v: SelectableValue) => void;\n inputId?: string | undefined;\n}\n\nexport const DatasetSelector = ({\n dataset,\n db,\n dialect,\n onChange,\n inputId,\n preconfiguredDataset,\n}: DatasetSelectorProps) => {\n /*\n The behavior of this component - for MSSQL and MySQL datasources - is based on whether the user chose to create a datasource\n with or without a default database (preconfiguredDataset). If the user configured a default database, this selector\n should only allow that single preconfigured database option to be selected. If the user chose to NOT assign/configure a default database,\n then the user should be able to use this component to choose between multiple databases available to the datasource.\n */\n // `hasPreconfigCondition` is true if either 1) the sql datasource has a preconfigured default database,\n // OR if 2) the datasource is Postgres. In either case the only option available to the user is the preconfigured database.\n const hasPreconfigCondition = !!preconfiguredDataset || dialect === 'postgres';\n\n const state = useAsync(async () => {\n // If a default database is already configured for a MSSQL or MySQL data source, OR the data source is Postgres, no need to fetch other databases.\n if (hasPreconfigCondition) {\n // Set the current database to the preconfigured database.\n onChange(toOption(preconfiguredDataset));\n return [toOption(preconfiguredDataset)];\n }\n\n // If there is no preconfigured database, but there is a selected dataset, set the current database to the selected dataset.\n if (dataset) {\n onChange(toOption(dataset));\n }\n\n // Otherwise, fetch all databases available to the datasource.\n const datasets = await db.datasets();\n return datasets.map(toOption);\n }, []);\n\n return (\n <Select\n aria-label={t('grafana-sql.components.dataset-selector.aria-label-dataset-selector', 'Dataset selector')}\n inputId={inputId}\n value={dataset}\n options={state.value}\n onChange={onChange}\n disabled={state.loading}\n isLoading={state.loading}\n menuShouldPortal={true}\n />\n );\n};\n","import { useAsync } from 'react-use';\n\nimport { SelectableValue, toOption } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { t } from '@grafana/i18n';\nimport { Select } from '@grafana/ui';\n\nimport { DB, ResourceSelectorProps } from '../types';\n\nexport interface TableSelectorProps extends ResourceSelectorProps {\n db: DB;\n table: string | undefined;\n dataset: string | undefined;\n onChange: (v: SelectableValue) => void;\n inputId?: string | undefined;\n}\n\nexport const TableSelector = ({ db, dataset, table, className, onChange, inputId }: TableSelectorProps) => {\n const state = useAsync(async () => {\n // No need to attempt to fetch tables for an unknown dataset.\n if (!dataset) {\n return [];\n }\n\n const tables = await db.tables(dataset);\n return tables.map(toOption);\n }, [dataset]);\n\n return (\n <Select\n className={className}\n disabled={state.loading}\n aria-label={t('grafana-sql.components.table-selector.aria-label-table-selector', 'Table selector')}\n inputId={inputId}\n data-testid={selectors.components.SQLQueryEditor.headerTableSelector}\n value={table}\n options={state.value}\n onChange={onChange}\n isLoading={state.loading}\n menuShouldPortal={true}\n placeholder={\n state.loading\n ? t('grafana-sql.components.table-selector.placeholder-loading', 'Loading tables')\n : t('grafana-sql.components.table-selector.placeholder-select-table', 'Select table')\n }\n allowCustomValue={true}\n />\n );\n};\n","import { useCallback, useId, useState } from 'react';\nimport { useCopyToClipboard } from 'react-use';\n\nimport { SelectableValue } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { t, Trans } from '@grafana/i18n';\nimport { EditorField, EditorHeader, EditorMode, EditorRow, FlexItem, InlineSelect } from '@grafana/plugin-ui';\nimport { reportInteraction } from '@grafana/runtime';\nimport { Button, InlineSwitch, RadioButtonGroup, Tooltip, Space } from '@grafana/ui';\n\nimport { QueryWithDefaults } from '../defaults';\nimport { SQLQuery, QueryFormat, QueryRowFilter, QUERY_FORMAT_OPTIONS, DB, SQLDialect } from '../types';\n\nimport { ConfirmModal } from './ConfirmModal';\nimport { DatasetSelector } from './DatasetSelector';\nimport { TableSelector } from './TableSelector';\n\nexport interface QueryHeaderProps {\n db: DB;\n dialect: SQLDialect;\n isQueryRunnable: boolean;\n onChange: (query: SQLQuery) => void;\n onQueryRowChange: (queryRowFilter: QueryRowFilter) => void;\n onRunQuery: () => void;\n preconfiguredDataset: string;\n query: QueryWithDefaults;\n queryRowFilter: QueryRowFilter;\n}\n\nexport function QueryHeader({\n db,\n dialect,\n isQueryRunnable,\n onChange,\n onQueryRowChange,\n onRunQuery,\n preconfiguredDataset,\n query,\n queryRowFilter,\n}: QueryHeaderProps) {\n const { editorMode } = query;\n const [_, copyToClipboard] = useCopyToClipboard();\n const [showConfirm, setShowConfirm] = useState(false);\n const toRawSql = db.toRawSql;\n\n const htmlId = useId();\n\n const editorModes = [\n {\n label: t('grafana-sql.components.query-header.editor-modes.label-builder', 'Builder'),\n value: EditorMode.Builder,\n },\n { label: t('grafana-sql.components.query-header.editor-modes.label-code', 'Code'), value: EditorMode.Code },\n ];\n\n const onEditorModeChange = useCallback(\n (newEditorMode: EditorMode) => {\n if (newEditorMode === EditorMode.Code) {\n reportInteraction('grafana_sql_editor_mode_changed', {\n datasource: query.datasource?.type,\n selectedEditorMode: EditorMode.Code,\n });\n }\n\n if (editorMode === EditorMode.Code) {\n setShowConfirm(true);\n return;\n }\n onChange({ ...query, editorMode: newEditorMode });\n },\n [editorMode, onChange, query]\n );\n\n const onFormatChange = (e: SelectableValue) => {\n const next = { ...query, format: e.value !== undefined ? e.value : QueryFormat.Table };\n\n reportInteraction('grafana_sql_format_changed', {\n datasource: query.datasource?.type,\n selectedFormat: next.format,\n });\n onChange(next);\n };\n\n const onDatasetChange = (e: SelectableValue) => {\n if (e.value === query.dataset) {\n return;\n }\n\n const next = {\n ...query,\n dataset: e.value,\n table: undefined,\n sql: undefined,\n rawSql: '',\n };\n\n onChange(next);\n };\n\n const onTableChange = (e: SelectableValue) => {\n if (e.value === query.table) {\n return;\n }\n\n const next: SQLQuery = {\n ...query,\n table: e.value,\n sql: undefined,\n rawSql: '',\n };\n\n onChange(next);\n };\n\n const datasetDropdownIsAvailable = () => {\n if (dialect === 'influx') {\n return false;\n }\n\n return true;\n };\n\n return (\n <>\n <EditorHeader>\n <InlineSelect\n label={t('grafana-sql.components.query-header.label-format', 'Format')}\n value={query.format}\n placeholder={t('grafana-sql.components.query-header.placeholder-select-format', 'Select format')}\n menuShouldPortal\n onChange={onFormatChange}\n options={QUERY_FORMAT_OPTIONS}\n />\n\n {editorMode === EditorMode.Builder && (\n <>\n <InlineSwitch\n id={`sql-filter-${htmlId}`}\n label={t('grafana-sql.components.query-header.label-filter', 'Filter')}\n data-testid={selectors.components.SQLQueryEditor.headerFilterSwitch}\n transparent={true}\n showLabel={true}\n value={queryRowFilter.filter}\n onChange={(ev) => {\n if (!(ev.target instanceof HTMLInputElement)) {\n return;\n }\n\n reportInteraction('grafana_sql_filter_toggled', {\n datasource: query.datasource?.type,\n displayed: ev.target.checked,\n });\n\n onQueryRowChange({ ...queryRowFilter, filter: ev.target.checked });\n }}\n />\n\n <InlineSwitch\n id={`sql-group-${htmlId}`}\n label={t('grafana-sql.components.query-header.label-group', 'Group')}\n data-testid={selectors.components.SQLQueryEditor.headerGroupSwitch}\n transparent={true}\n showLabel={true}\n value={queryRowFilter.group}\n onChange={(ev) => {\n if (!(ev.target instanceof HTMLInputElement)) {\n return;\n }\n\n reportInteraction('grafana_sql_group_toggled', {\n datasource: query.datasource?.type,\n displayed: ev.target.checked,\n });\n\n onQueryRowChange({ ...queryRowFilter, group: ev.target.checked });\n }}\n />\n\n <InlineSwitch\n id={`sql-order-${htmlId}`}\n label={t('grafana-sql.components.query-header.label-order', 'Order')}\n data-testid={selectors.components.SQLQueryEditor.headerOrderSwitch}\n transparent={true}\n showLabel={true}\n value={queryRowFilter.order}\n onChange={(ev) => {\n if (!(ev.target instanceof HTMLInputElement)) {\n return;\n }\n\n reportInteraction('grafana_sql_order_toggled', {\n datasource: query.datasource?.type,\n displayed: ev.target.checked,\n });\n\n onQueryRowChange({ ...queryRowFilter, order: ev.target.checked });\n }}\n />\n\n <InlineSwitch\n id={`sql-preview-${htmlId}`}\n label={t('grafana-sql.components.query-header.label-preview', 'Preview')}\n data-testid={selectors.components.SQLQueryEditor.headerPreviewSwitch}\n transparent={true}\n showLabel={true}\n value={queryRowFilter.preview}\n onChange={(ev) => {\n if (!(ev.target instanceof HTMLInputElement)) {\n return;\n }\n\n reportInteraction('grafana_sql_preview_toggled', {\n datasource: query.datasource?.type,\n displayed: ev.target.checked,\n });\n\n onQueryRowChange({ ...queryRowFilter, preview: ev.target.checked });\n }}\n />\n </>\n )}\n\n <FlexItem grow={1} />\n\n {isQueryRunnable ? (\n <Button icon=\"play\" variant=\"primary\" size=\"sm\" onClick={() => onRunQuery()}>\n <Trans i18nKey=\"grafana-sql.components.query-header.run-query\">Run query</Trans>\n </Button>\n ) : (\n <Tooltip\n theme=\"error\"\n content={\n <Trans i18nKey=\"grafana-sql.components.query-header.content-invalid-query\">\n Your query is invalid. Check below for details. <br />\n However, you can still run this query.\n </Trans>\n }\n placement=\"top\"\n >\n <Button icon=\"exclamation-triangle\" variant=\"secondary\" size=\"sm\" onClick={() => onRunQuery()}>\n <Trans i18nKey=\"grafana-sql.components.query-header.run-query\">Run query</Trans>\n </Button>\n </Tooltip>\n )}\n\n <RadioButtonGroup options={editorModes} size=\"sm\" value={editorMode} onChange={onEditorModeChange} />\n\n <ConfirmModal\n isOpen={showConfirm}\n onCopy={() => {\n reportInteraction('grafana_sql_editor_mode_changed', {\n datasource: query.datasource?.type,\n selectedEditorMode: EditorMode.Builder,\n type: 'copy',\n });\n\n setShowConfirm(false);\n copyToClipboard(query.rawSql!);\n onChange({\n ...query,\n rawSql: toRawSql(query),\n editorMode: EditorMode.Builder,\n });\n }}\n onDiscard={() => {\n reportInteraction('grafana_sql_editor_mode_changed', {\n datasource: query.datasource?.type,\n selectedEditorMode: EditorMode.Builder,\n type: 'discard',\n });\n\n setShowConfirm(false);\n onChange({\n ...query,\n rawSql: toRawSql(query),\n editorMode: EditorMode.Builder,\n });\n }}\n onCancel={() => {\n reportInteraction('grafana_sql_editor_mode_changed', {\n datasource: query.datasource?.type,\n selectedEditorMode: EditorMode.Builder,\n type: 'cancel',\n });\n\n setShowConfirm(false);\n }}\n />\n </EditorHeader>\n\n {editorMode === EditorMode.Builder && (\n <>\n <Space v={0.5} />\n <EditorRow>\n {datasetDropdownIsAvailable() && (\n <EditorField label={t('grafana-sql.components.query-header.label-dataset', 'Dataset')} width={25}>\n <DatasetSelector\n db={db}\n inputId={`sql-dataset-${htmlId}`}\n dataset={query.dataset}\n dialect={dialect}\n preconfiguredDataset={preconfiguredDataset}\n onChange={onDatasetChange}\n />\n </EditorField>\n )}\n <EditorField label={t('grafana-sql.components.query-header.label-table', 'Table')} width={25}>\n <TableSelector\n db={db}\n inputId={`sql-tableselect-${htmlId}`}\n dataset={query.dataset || preconfiguredDataset}\n table={query.table}\n onChange={onTableChange}\n />\n </EditorField>\n </EditorRow>\n </>\n )}\n </>\n );\n}\n","import { useCallback, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { LanguageDefinition, SQLEditor } from '@grafana/plugin-ui';\n\nimport { SQLQuery } from '../../types';\n\ntype Props = {\n query: SQLQuery;\n onChange: (value: SQLQuery, processQuery: boolean) => void;\n children?: (props: { formatQuery: () => void }) => React.ReactNode;\n width?: number;\n height?: number;\n editorLanguageDefinition: LanguageDefinition;\n};\n\nexport function QueryEditorRaw({ children, onChange, query, width, height, editorLanguageDefinition }: Props) {\n // We need to pass query via ref to SQLEditor as onChange is executed via monacoEditor.onDidChangeModelContent callback, not onChange property\n const queryRef = useRef<SQLQuery>(query);\n useEffect(() => {\n queryRef.current = query;\n }, [query]);\n\n const onRawQueryChange = useCallback(\n (rawSql: string, processQuery: boolean) => {\n const newQuery = {\n ...queryRef.current,\n rawQuery: true,\n rawSql,\n };\n onChange(newQuery, processQuery);\n },\n [onChange]\n );\n\n return (\n <SQLEditor\n width={width}\n height={height}\n query={query.rawSql!}\n onChange={onRawQueryChange}\n language={editorLanguageDefinition}\n >\n {children}\n </SQLEditor>\n );\n}\n","import { css } from '@emotion/css';\nimport { useState, useMemo, useEffect } from 'react';\nimport { useAsyncFn, useDebounce } from 'react-use';\n\nimport { formattedValueToString, getValueFormat, TimeRange } from '@grafana/data';\nimport { Trans } from '@grafana/i18n';\nimport { Icon, Spinner, useTheme2 } from '@grafana/ui';\n\nimport { DB, SQLQuery, ValidationResults } from '../../types';\n\nexport interface QueryValidatorProps {\n db: DB;\n query: SQLQuery;\n range?: TimeRange;\n onValidate: (isValid: boolean) => void;\n}\n\nexport function QueryValidator({ db, query, onValidate, range }: QueryValidatorProps) {\n const [validationResult, setValidationResult] = useState<ValidationResults | null>();\n const theme = useTheme2();\n const valueFormatter = useMemo(() => getValueFormat('bytes'), []);\n\n const styles = useMemo(() => {\n return {\n error: css({\n color: theme.colors.error.text,\n fontSize: theme.typography.bodySmall.fontSize,\n fontFamily: theme.typography.fontFamilyMonospace,\n }),\n valid: css({\n color: theme.colors.success.text,\n }),\n info: css({\n color: theme.colors.text.secondary,\n }),\n };\n }, [theme]);\n\n const [state, validateQuery] = useAsyncFn(\n async (q: SQLQuery) => {\n if (q.rawSql?.trim() === '') {\n return null;\n }\n\n return await db.validateQuery(q, range);\n },\n [db]\n );\n\n const [,] = useDebounce(\n async () => {\n const result = await validateQuery(query);\n if (result) {\n setValidationResult(result);\n }\n\n return null;\n },\n 1000,\n [query, validateQuery]\n );\n\n useEffect(() => {\n if (validationResult?.isError) {\n onValidate(false);\n }\n if (validationResult?.isValid) {\n onValidate(true);\n }\n }, [validationResult, onValidate]);\n\n if (!state.value && !state.loading) {\n return null;\n }\n\n const error = state.value?.error ? processErrorMessage(state.value.error) : '';\n\n return (\n <>\n {state.loading && (\n <div className={styles.info}>\n <Spinner inline={true} size=\"xs\" />{' '}\n <Trans i18nKey=\"grafana-sql.components.query-validator.validating-query\">Validating query...</Trans>\n </div>\n )}\n {!state.loading && state.value && (\n <>\n <>\n {state.value.isValid && state.value.statistics && (\n <div className={styles.valid}>\n <Trans\n i18nKey=\"grafana-sql.components.query-validator.query-will-process\"\n values={{ bytes: formattedValueToString(valueFormatter(state.value.statistics.TotalBytesProcessed)) }}\n >\n <Icon name=\"check\" /> This query will process <strong>{'{{bytes}}'}</strong> when run.\n </Trans>\n </div>\n )}\n </>\n\n <>{state.value.isError && <div className={styles.error}>{error}</div>}</>\n </>\n )}\n </>\n );\n}\n\nfunction processErrorMessage(error: string) {\n const splat = error.split(':');\n if (splat.length > 2) {\n return splat.slice(2).join(':');\n }\n return error;\n}\n","import { css } from '@emotion/css';\nimport { useMemo, useState } from 'react';\n\nimport { t } from '@grafana/i18n';\nimport { reportInteraction } from '@grafana/runtime';\nimport { Stack, Icon, IconButton, Tooltip, useTheme2 } from '@grafana/ui';\n\nimport { QueryValidator, QueryValidatorProps } from './QueryValidator';\n\ninterface QueryToolboxProps extends Omit<QueryValidatorProps, 'onValidate'> {\n showTools?: boolean;\n isExpanded?: boolean;\n onFormatCode?: () => void;\n onExpand?: (expand: boolean) => void;\n onValidate?: (isValid: boolean) => void;\n}\n\nexport function QueryToolbox({ showTools, onFormatCode, onExpand, isExpanded, ...validatorProps }: QueryToolboxProps) {\n const theme = useTheme2();\n const [validationResult, setValidationResult] = useState<boolean>();\n\n const styles = useMemo(() => {\n return {\n container: css({\n border: `1px solid ${theme.colors.border.medium}`,\n borderTop: 'none',\n padding: theme.spacing(0.5, 0.5, 0.5, 0.5),\n display: 'flex',\n flexGrow: 1,\n justifyContent: 'space-between',\n fontSize: theme.typography.bodySmall.fontSize,\n }),\n error: css({\n color: theme.colors.error.text,\n fontSize: theme.typography.bodySmall.fontSize,\n fontFamily: theme.typography.fontFamilyMonospace,\n }),\n valid: css({\n color: theme.colors.success.text,\n }),\n info: css({\n color: theme.colors.text.secondary,\n }),\n hint: css({\n color: theme.colors.text.disabled,\n whiteSpace: 'nowrap',\n cursor: 'help',\n }),\n };\n }, [theme]);\n\n let style = {};\n\n if (!showTools && validationResult === undefined) {\n style = { height: 0, padding: 0, visibility: 'hidden' };\n }\n\n return (\n <div className={styles.container} style={style}>\n <div>\n {validatorProps.onValidate && (\n <QueryValidator\n {...validatorProps}\n onValidate={(result: boolean) => {\n setValidationResult(result);\n validatorProps.onValidate!(result);\n }}\n />\n )}\n </div>\n {showTools && (\n <div>\n <Stack gap={1}>\n {onFormatCode && (\n <IconButton\n onClick={() => {\n reportInteraction('grafana_sql_query_formatted', {\n datasource: validatorProps.query.datasource?.type,\n });\n onFormatCode();\n }}\n name=\"brackets-curly\"\n size=\"xs\"\n tooltip={t('grafana-sql.components.query-toolbox.tooltip-format-query', 'Format query')}\n />\n )}\n {onExpand && (\n <IconButton\n onClick={() => {\n reportInteraction('grafana_sql_editor_expand', {\n datasource: validatorProps.query.datasource?.type,\n expanded: !isExpanded,\n });\n\n onExpand(!isExpanded);\n }}\n name={isExpanded ? 'angle-up' : 'angle-down'}\n size=\"xs\"\n tooltip={\n isExpanded\n ? t('grafana-sql.components.query-toolbox.tooltip-collapse', 'Collapse editor')\n : t('grafana-sql.components.query-toolbox.tooltip-expand', 'Expand editor')\n }\n />\n )}\n <Tooltip\n content={t(\n 'grafana-sql.components.query-toolbox.content-hit-ctrlcmdreturn-to-run-query',\n 'Hit CTRL/CMD+Return to run query'\n )}\n >\n <Icon className={styles.hint} name=\"keyboard\" />\n </Tooltip>\n </Stack>\n </div>\n )}\n </div>\n );\n}\n","import { css } from '@emotion/css';\nimport { useMemo, useState } from 'react';\nimport { useMeasure } from 'react-use';\nimport AutoSizer from 'react-virtualized-auto-sizer';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { reportInteraction } from '@grafana/runtime';\nimport { Modal, useStyles2, useTheme2 } from '@grafana/ui';\n\nimport { SQLQuery, QueryEditorProps } from '../../types';\n\nimport { QueryEditorRaw } from './QueryEditorRaw';\nimport { QueryToolbox } from './QueryToolbox';\n\ninterface RawEditorProps extends Omit<QueryEditorProps, 'onChange'> {\n onRunQuery: () => void;\n onChange: (q: SQLQuery, processQuery: boolean) => void;\n onValidate: (isValid: boolean) => void;\n queryToValidate: SQLQuery;\n}\n\nexport function RawEditor({ db, query, onChange, onRunQuery, onValidate, queryToValidate, range }: RawEditorProps) {\n const theme = useTheme2();\n const styles = useStyles2(getStyles);\n const [isExpanded, setIsExpanded] = useState(false);\n const [toolboxRef, toolboxMeasure] = useMeasure<HTMLDivElement>();\n const [editorRef, editorMeasure] = useMeasure<HTMLDivElement>();\n\n const editorLanguageDefinition = useMemo(() => db.getEditorLanguageDefinition(), [db]);\n\n const renderQueryEditor = (width?: number, height?: number) => {\n return (\n <QueryEditorRaw\n editorLanguageDefinition={editorLanguageDefinition}\n query={query}\n width={width}\n height={height ? height - toolboxMeasure.height : undefined}\n onChange={onChange}\n >\n {({ formatQuery }) => {\n return (\n <div ref={toolboxRef}>\n <QueryToolbox\n db={db}\n query={queryToValidate}\n onValidate={onValidate}\n onFormatCode={formatQuery}\n showTools\n range={range}\n onExpand={setIsExpanded}\n isExpanded={isExpanded}\n />\n </div>\n );\n }}\n </QueryEditorRaw>\n );\n };\n\n const renderEditor = (standalone = false) => {\n return standalone ? (\n <AutoSizer>\n {({ width, height }) => {\n return renderQueryEditor(width, height);\n }}\n </AutoSizer>\n ) : (\n <div ref={editorRef}>{renderQueryEditor()}</div>\n );\n };\n\n const renderPlaceholder = () => {\n return (\n <div\n style={{\n width: editorMeasure.width,\n height: editorMeasure.height,\n background: theme.colors.background.primary,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n }}\n >\n <Trans i18nKey=\"grafana-sql.components.raw-editor.render-placeholder.editing-in-expanded-code-editor\">\n Editing in expanded code editor\n </Trans>\n </div>\n );\n };\n\n return (\n <>\n {isExpanded ? renderPlaceholder() : renderEditor()}\n {isExpanded && (\n <Modal\n title={t('grafana-sql.components.raw-editor.title-query-num', 'Query {{queryNum}}', {\n queryNum: query.refId,\n })}\n closeOnBackdropClick={false}\n closeOnEscape={false}\n className={styles.modal}\n contentClassName={styles.modalContent}\n isOpen={isExpanded}\n onDismiss={() => {\n reportInteraction('grafana_sql_editor_expand', {\n datasource: query.datasource?.type,\n expanded: false,\n });\n setIsExpanded(false);\n }}\n >\n {renderEditor(true)}\n </Modal>\n )}\n </>\n );\n}\n\nfunction getStyles(theme: GrafanaTheme2) {\n return {\n modal: css({\n width: '95vw',\n height: '95vh',\n }),\n modalContent: css({\n height: '100%',\n paddingTop: 0,\n }),\n };\n}\n","import { SelectableValue } from '@grafana/data';\nimport { t } from '@grafana/i18n';\n\nimport { SQLQuery } from '../types';\n\nexport function getColumnsWithIndices(query: SQLQuery, fields: SelectableValue[]): SelectableValue[] {\n if (!fields || !query.sql?.columns) {\n return fields;\n }\n\n const options = query.sql.columns.map((c, i) => {\n const value = c.name\n ? `${c.name}(${c.parameters?.map((p) => p.name).join(', ')})`\n : c.parameters?.map((p) => p.name).join(', ');\n return {\n value,\n label: `${i + 1} - ${value}`,\n };\n });\n\n return [\n {\n value: '',\n label: t('grafana-sql.utils.get-columns-width-indices.label-selected-columns', 'Selected columns'),\n options,\n expanded: true,\n },\n ...fields,\n ];\n}\n","import { useCallback } from 'react';\n\nimport { DB, SQLExpression, SQLQuery } from '../types';\n\ninterface UseSqlChange {\n db: DB;\n query: SQLQuery;\n onQueryChange: (query: SQLQuery) => void;\n}\n\nexport function useSqlChange({ query, onQueryChange, db }: UseSqlChange) {\n const onSqlChange = useCallback(\n (sql: SQLExpression) => {\n const toRawSql = db.toRawSql;\n const rawSql = toRawSql({ sql, dataset: query.dataset, table: query.table, refId: query.refId });\n const newQuery: SQLQuery = { ...query, sql, rawSql };\n onQueryChange(newQuery);\n },\n [db, onQueryChange, query]\n );\n\n return { onSqlChange };\n}\n","import { useCallback } from 'react';\n\nimport { SelectableValue, toOption } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { AccessoryButton, EditorList, InputGroup } from '@grafana/plugin-ui';\nimport { Select } from '@grafana/ui';\n\nimport { QueryEditorGroupByExpression } from '../../expressions';\nimport { SQLExpression } from '../../types';\nimport { setGroupByField } from '../../utils/sql.utils';\n\ninterface GroupByRowProps {\n sql: SQLExpression;\n onSqlChange: (sql: SQLExpression) => void;\n columns?: Array<SelectableValue<string>>;\n}\n\nexport function GroupByRow({ sql, columns, onSqlChange }: GroupByRowProps) {\n const onGroupByChange = useCallback(\n (item: Array<Partial<QueryEditorGroupByExpression>>) => {\n // As new (empty object) items come in, we need to make sure they have the correct type\n const cleaned = item.map((v) => setGroupByField(v.property?.name));\n const newSql = { ...sql, groupBy: cleaned };\n onSqlChange(newSql);\n },\n [onSqlChange, sql]\n );\n\n return (\n <EditorList\n items={sql.groupBy!}\n onChange={onGroupByChange}\n renderItem={makeRenderColumn({\n options: columns,\n })}\n />\n );\n}\n\nfunction makeRenderColumn({ options }: { options?: Array<SelectableValue<string>> }) {\n const renderColumn = function (\n item: Partial<QueryEditorGroupByExpression>,\n onChangeItem: (item: QueryEditorGroupByExpression) => void,\n onDeleteItem: () => void\n ) {\n return (\n <InputGroup>\n <Select\n value={item.property?.name ? toOption(item.property.name) : null}\n aria-label={t('grafana-sql.components.make-render-column.render-column.aria-label-group-by', 'Group by')}\n options={options}\n menuShouldPortal\n onChange={({ value }) => value && onChangeItem(setGroupByField(value))}\n />\n <AccessoryButton\n aria-label={t(\n 'grafana-sql.components.make-render-column.render-column.title-remove-group-by-column',\n 'Remove group by column'\n )}\n icon=\"times\"\n variant=\"secondary\"\n onClick={onDeleteItem}\n />\n </InputGroup>\n );\n };\n return renderColumn;\n}\n","import { SelectableValue } from '@grafana/data';\n\nimport { QueryWithDefaults } from '../../defaults';\nimport { DB, SQLQuery } from '../../types';\nimport { getColumnsWithIndices } from '../../utils/getColumnsWithIndices';\nimport { useSqlChange } from '../../utils/useSqlChange';\n\nimport { GroupByRow } from './GroupByRow';\n\ninterface SQLGroupByRowProps {\n fields: SelectableValue[];\n query: QueryWithDefaults;\n onQueryChange: (query: SQLQuery) => void;\n db: DB;\n}\n\nexport function SQLGroupByRow({ fields, query, onQueryChange, db }: SQLGroupByRowProps) {\n const { onSqlChange } = useSqlChange({ query, onQueryChange, db });\n let columnsWithIndices: SelectableValue[] = getColumnsWithIndices(query, fields);\n return <GroupByRow columns={columnsWithIndices} sql={query.sql!} onSqlChange={onSqlChange} />;\n}\n","import { uniqueId } from 'lodash';\nimport { useCallback } from 'react';\nimport * as React from 'react';\n\nimport { SelectableValue, toOption } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { EditorField, InputGroup } from '@grafana/plugin-ui';\nimport { Input, RadioButtonGroup, Select, Space } from '@grafana/ui';\n\nimport { SQLExpression } from '../../types';\nimport { setPropertyField } from '../../utils/sql.utils';\n\ntype OrderByRowProps = {\n sql: SQLExpression;\n onSqlChange: (sql: SQLExpression) => void;\n columns?: Array<SelectableValue<string>>;\n showOffset?: boolean;\n};\n\nconst sortOrderOptions = [\n { description: 'Sort by ascending', value: 'ASC', icon: 'sort-amount-up' } as const,\n { description: 'Sort by descending', value: 'DESC', icon: 'sort-amount-down' } as const,\n];\n\nexport function OrderByRow({ sql, onSqlChange, columns, showOffset }: OrderByRowProps) {\n const onSortOrderChange = useCallback(\n (item: 'ASC' | 'DESC') => {\n const newSql: SQLExpression = { ...sql, orderByDirection: item };\n onSqlChange(newSql);\n },\n [onSqlChange, sql]\n );\n\n const onLimitChange = useCallback(\n (event: React.FormEvent<HTMLInputElement>) => {\n const newSql: SQLExpression = { ...sql, limit: Number.parseInt(event.currentTarget.value, 10) };\n onSqlChange(newSql);\n },\n [onSqlChange, sql]\n );\n\n const onOffsetChange = useCallback(\n (event: React.FormEvent<HTMLInputElement>) => {\n const newSql: SQLExpression = { ...sql, offset: Number.parseInt(event.currentTarget.value, 10) };\n onSqlChange(newSql);\n },\n [onSqlChange, sql]\n );\n\n const onOrderByChange = useCallback(\n (item: SelectableValue<string>) => {\n const newSql: SQLExpression = { ...sql, orderBy: setPropertyField(item?.value) };\n if (item === null) {\n newSql.orderByDirection = undefined;\n }\n onSqlChange(newSql);\n },\n [onSqlChange, sql]\n );\n\n return (\n <>\n <EditorField label={t('grafana-sql.components.order-by-row.label-order-by', 'Order by')} width={25}>\n <InputGroup>\n <Select\n aria-label={t('grafana-sql.components.order-by-row.aria-label-order-by', 'Order by')}\n options={columns}\n value={sql.orderBy?.property.name ? toOption(sql.orderBy.property.name) : null}\n isClearable\n menuShouldPortal\n onChange={onOrderByChange}\n />\n\n <Space h={1.5} />\n\n <RadioButtonGroup\n options={sortOrderOptions}\n disabled={!sql?.orderBy?.property.name}\n value={sql.orderByDirection}\n onChange={onSortOrderChange}\n />\n </InputGroup>\n </EditorField>\n <EditorField label={t('grafana-sql.components.order-by-row.label-limit', 'Limit')} optional width={25}>\n <Input type=\"number\" min={0} id={uniqueId('limit-')} value={sql.limit || ''} onChange={onLimitChange} />\n </EditorField>\n {showOffset && (\n <EditorField label={t('grafana-sql.components.order-by-row.label-offset', 'Offset')} optional width={25}>\n <Input type=\"number\" id={uniqueId('offset-')} value={sql.offset || ''} onChange={onOffsetChange} />\n </EditorField>\n )}\n </>\n );\n}\n","import { SelectableValue } from '@grafana/data';\n\nimport { QueryWithDefaults } from '../../defaults';\nimport { DB, SQLQuery } from '../../types';\nimport { getColumnsWithIndices } from '../../utils/getColumnsWithIndices';\nimport { useSqlChange } from '../../utils/useSqlChange';\n\nimport { OrderByRow } from './OrderByRow';\n\ntype SQLOrderByRowProps = {\n fields: SelectableValue[];\n query: QueryWithDefaults;\n onQueryChange: (query: SQLQuery) => void;\n db: DB;\n};\n\nexport function SQLOrderByRow({ fields, query, onQueryChange, db }: SQLOrderByRowProps) {\n const { onSqlChange } = useSqlChange({ query, onQueryChange, db });\n let columnsWithIndices: SelectableValue[] = getColumnsWithIndices(query, fields);\n return <OrderByRow sql={query.sql!} onSqlChange={onSqlChange} columns={columnsWithIndices} />;\n}\n","import {\n BaseOperator,\n BasicConfig,\n Config,\n Field,\n ImmutableList,\n JsonTree,\n Operator,\n OperatorOptionsI,\n Settings,\n Utils,\n ValueSource,\n WidgetProps,\n Widgets,\n} from '@react-awesome-query-builder/ui';\nimport { isString } from 'lodash';\n\nimport { dateTime, toOption } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { t } from '@grafana/i18n';\nimport { Button, DateTimePicker, Input, Select } from '@grafana/ui';\n\nconst buttonLabels = {\n add: 'Add',\n remove: 'Remove',\n};\n\nexport const emptyInitTree: JsonTree = {\n id: Utils.uuid(),\n type: 'group',\n};\n\nconst TIME_FILTER = 'timeFilter';\nconst macros = [TIME_FILTER];\n\n// Widgets are the components rendered for each field type see the docs for more info\n// https://github.com/ukrbublik/react-awesome-query-builder/blob/master/CONFIG.adoc#configwidgets\nexport const widgets: Widgets = {\n ...BasicConfig.widgets,\n text: {\n ...BasicConfig.widgets.text,\n factory: function TextInput(props: WidgetProps) {\n return (\n <Input\n value={props?.value || ''}\n placeholder={props?.placeholder}\n onChange={(e) => props?.setValue(e.currentTarget.value)}\n />\n );\n },\n },\n number: {\n ...BasicConfig.widgets.number,\n factory: function NumberInput(props: WidgetProps) {\n return (\n <Input\n value={props?.value}\n placeholder={props?.placeholder}\n type=\"number\"\n onChange={(e) => props?.setValue(Number.parseInt(e.currentTarget.value, 10))}\n />\n );\n },\n },\n datetime: {\n ...BasicConfig.widgets.datetime,\n factory: function DateTimeInput(props: WidgetProps) {\n if (props?.operator === Op.MACROS) {\n return (\n <Select\n id={props.id}\n aria-label={t('grafana-sql.components.widgets.aria-label-macros-value-selector', 'Macros value selector')}\n menuShouldPortal\n options={macros.map(toOption)}\n value={props?.value}\n onChange={(val) => props.setValue(val.value)}\n />\n );\n }\n const dateValue = dateTime(props?.value).isValid() ? dateTime(props?.value).utc() : undefined;\n return (\n <DateTimePicker\n onChange={(e) => {\n props?.setValue(e?.format(BasicConfig.widgets.datetime.valueFormat));\n }}\n date={dateValue}\n />\n );\n },\n // Function for formatting widget’s value in SQL WHERE query.\n sqlFormatValue: (val, field, widget, operator, operatorDefinition, rightFieldDef) => {\n if (operator === Op.MACROS) {\n if (macros.includes(val)) {\n return val;\n }\n return undefined;\n }\n\n // This is just satisfying the type checker, this should never happen\n if (\n typeof BasicConfig.widgets.datetime.sqlFormatValue === 'string' ||\n typeof BasicConfig.widgets.datetime.sqlFormatValue === 'object'\n ) {\n return undefined;\n }\n const func = BasicConfig.widgets.datetime.sqlFormatValue;\n // We need to pass the ctx to this function this way so *this* is correct\n return func?.call(BasicConfig.ctx, val, field, widget, operator, operatorDefinition, rightFieldDef) || '';\n },\n },\n};\n\n// Settings are the configuration options for the query builder see the docs for more info\n// https://github.com/ukrbublik/react-awesome-query-builder/blob/master/CONFIG.adoc#configsettings\nexport const settings: Settings = {\n ...BasicConfig.settings,\n canRegroup: false,\n maxNesting: 1,\n canReorder: false,\n showNot: false,\n addRuleLabel: buttonLabels.add,\n deleteLabel: buttonLabels.remove,\n // This is the component that renders conjunctions (logical operators)\n renderConjs: function Conjunctions(conjProps) {\n return (\n <Select\n id={conjProps?.id}\n aria-label={t('grafana-sql.components.settings.aria-label-conjunction', 'Conjunction')}\n data-testid={selectors.components.SQLQueryEditor.filterConjunction}\n menuShouldPortal\n options={conjProps?.conjunctionOptions ? Object.keys(conjProps?.conjunctionOptions).map(toOption) : undefined}\n value={conjProps?.selectedConjunction}\n onChange={(val) => conjProps?.setConjunction(val.value!)}\n />\n );\n },\n // This is the component that renders fields\n renderField: function Field(fieldProps) {\n const fields = fieldProps?.config?.fields || {};\n return (\n <Select\n id={fieldProps?.id}\n width={25}\n aria-label={t('grafana-sql.components.settings.aria-label-field', 'Field')}\n data-testid={selectors.components.SQLQueryEditor.filterField}\n menuShouldPortal\n options={fieldProps?.items.map((f) => {\n // @ts-ignore\n const icon = fields[f.key].mainWidgetProps?.customProps?.icon;\n return {\n label: f.label,\n value: f.key,\n icon,\n };\n })}\n value={fieldProps?.selectedKey}\n onChange={(val) => {\n fieldProps?.setField(val.label!);\n }}\n />\n );\n },\n // This is the component used for the Add/Remove buttons\n renderButton: function RAQBButton(buttonProps) {\n return (\n <Button\n type=\"button\"\n aria-label={t('grafana-sql.components.settings.title-button-filter', '{{ buttonLabel }} filter', {\n buttonLabel: buttonProps?.label,\n })}\n onClick={buttonProps?.onClick}\n variant=\"secondary\"\n size=\"md\"\n icon={buttonProps?.label === buttonLabels.add ? 'plus' : 'times'}\n />\n );\n },\n // This is the component used for the fields operator selector\n renderOperator: function Operator(operatorProps) {\n return (\n <Select\n options={operatorProps?.items.map((op) => ({ label: op.label, value: op.key }))}\n aria-label={t('grafana-sql.components.settings.aria-label-operator', 'Operator')}\n data-testid={selectors.components.SQLQueryEditor.filterOperator}\n menuShouldPortal\n value={operatorProps?.selectedKey}\n onChange={(val) => {\n operatorProps?.setField(val.value || '');\n }}\n />\n );\n },\n};\n\n// add IN / NOT IN operators to text to support multi-value variables\nconst enum Op {\n IN = 'select_any_in',\n NOT_IN = 'select_not_any_in',\n MACROS = 'macros',\n}\nconst customOperators = getCustomOperators(BasicConfig);\nconst textWidget = BasicConfig.types.text.widgets.text;\nconst opers = [...(textWidget.operators || []), Op.IN, Op.NOT_IN];\nconst customTextWidget = {\n ...textWidget,\n operators: opers,\n};\n\nconst customTypes = {\n ...BasicConfig.types,\n text: {\n ...BasicConfig.types.text,\n widgets: {\n ...BasicConfig.types.text.widgets,\n text: customTextWidget,\n },\n },\n datetime: {\n ...BasicConfig.types.datetime,\n widgets: {\n ...BasicConfig.types.datetime.widgets,\n datetime: {\n ...BasicConfig.types.datetime.widgets.datetime,\n operators: [Op.MACROS, ...(BasicConfig.types.datetime.widgets.datetime.operators || [])],\n },\n },\n },\n};\n\n// This is the configuration for the query builder that doesn't include the fields but all the other configuration for the UI\n// Fields should be added dynamically based on returned data\n// See the doc for more info https://github.com/ukrbublik/react-awesome-query-builder/blob/master/CONFIG.adoc\nexport const raqbConfig: Config = {\n ...BasicConfig,\n widgets,\n settings,\n operators: customOperators,\n types: customTypes,\n};\n\nexport type { Config };\n\nconst noop = () => '';\n\nfunction getCustomOperators(config: BasicConfig) {\n const { ...supportedOperators } = config.operators;\n\n // IN operator expects array, override IN formatter for multi-value variables\n const sqlFormatInOp = supportedOperators[Op.IN].sqlFormatOp?.bind(config.ctx) || noop;\n const formatInOp = supportedOperators[Op.IN].formatOp?.bind(config.ctx) || noop;\n const customSqlInFormatter = (\n field: string,\n op: string,\n value: string | string[] | ImmutableList<string>,\n valueSrc: ValueSource | undefined,\n valueType: string | undefined,\n opDef: Operator | undefined,\n operatorOptions: OperatorOptionsI | undefined,\n fieldDef: Field | undefined\n ) => {\n return sqlFormatInOp(field, op, splitIfString(value), valueSrc, valueType, opDef, operatorOptions, fieldDef);\n };\n\n // NOT IN operator expects array, override NOT IN formatter for multi-value variables\n const sqlFormatNotInOp = supportedOperators[Op.NOT_IN].sqlFormatOp?.bind(config.ctx) || noop;\n const formatNotInOp = supportedOperators[Op.NOT_IN].formatOp?.bind(config.ctx) || noop;\n const customSqlNotInFormatter = (\n field: string,\n op: string,\n value: string | string[] | ImmutableList<string>,\n valueSrc: ValueSource | undefined,\n valueType: string | undefined,\n opDef: Operator | undefined,\n operatorOptions: OperatorOptionsI | undefined,\n fieldDef: Field | undefined\n ) => {\n return sqlFormatNotInOp(field, op, splitIfString(value), valueSrc, valueType, opDef, operatorOptions, fieldDef);\n };\n\n const customOperators: Record<string, BaseOperator> = {\n ...supportedOperators,\n [Op.IN]: {\n ...supportedOperators[Op.IN],\n formatOp: (\n field: string,\n op: string,\n value: string | string[] | ImmutableList<string>,\n valueSrc?: ValueSource\n ) => {\n return formatInOp(field, op, splitIfString(value), valueSrc);\n },\n sqlFormatOp: customSqlInFormatter,\n },\n [Op.NOT_IN]: {\n ...supportedOperators[Op.NOT_IN],\n formatOp: (\n field: string,\n op: string,\n value: string | string[] | ImmutableList<string>,\n valueSrc?: ValueSource\n ) => {\n return formatNotInOp(field, op, splitIfString(value), valueSrc);\n },\n sqlFormatOp: customSqlNotInFormatter,\n },\n [Op.MACROS]: {\n label: t('grafana-sql.components.get-custom-operators.custom-operators.label.macros', 'Macros'),\n sqlFormatOp: (field: string, _operator: string, value: string | string[] | ImmutableList<string>) => {\n if (value === TIME_FILTER) {\n return `$__timeFilter(${field})`;\n }\n throw new Error('Invalid macro');\n },\n },\n };\n\n return customOperators;\n}\n\n// value: string | List<string> but AQB uses a different version of Immutable\nfunction splitIfString(value: string | string[] | ImmutableList<string>) {\n if (isString(value)) {\n return value.split(',');\n }\n return value;\n}\n","import { injectGlobal } from '@emotion/css';\nimport { Builder, Config, ImmutableTree, Query, Utils } from '@react-awesome-query-builder/ui';\nimport { useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { SQLExpression } from '../../types';\n\nimport { emptyInitTree, raqbConfig } from './AwesomeQueryBuilder';\n\ninterface SQLBuilderWhereRowProps {\n sql: SQLExpression;\n onSqlChange: (sql: SQLExpression) => void;\n config?: Partial<Config>;\n}\n\nexport function WhereRow({ sql, config, onSqlChange }: SQLBuilderWhereRowProps) {\n const [tree, setTree] = useState<ImmutableTree>();\n const configWithDefaults = useMemo(() => ({ ...raqbConfig, ...config }), [config]);\n\n useEffect(() => {\n // Set the initial tree\n if (!tree) {\n const initTree = Utils.checkTree(Utils.loadTree(sql.whereJsonTree ?? emptyInitTree), configWithDefaults);\n setTree(initTree);\n }\n }, [configWithDefaults, sql.whereJsonTree, tree]);\n\n useEffect(() => {\n if (!sql.whereJsonTree) {\n setTree(Utils.checkTree(Utils.loadTree(emptyInitTree), configWithDefaults));\n }\n }, [configWithDefaults, sql.whereJsonTree]);\n\n const onTreeChange = useCallback(\n (changedTree: ImmutableTree, config: Config) => {\n setTree(changedTree);\n const newSql = {\n ...sql,\n whereJsonTree: Utils.getTree(changedTree),\n whereString: Utils.sqlFormat(changedTree, config),\n };\n\n onSqlChange(newSql);\n },\n [onSqlChange, sql]\n );\n\n if (!tree) {\n return null;\n }\n\n return (\n <Query\n {...configWithDefaults}\n value={tree}\n onChange={onTreeChange}\n renderBuilder={(props) => <Builder {...props} />}\n />\n );\n}\n\nfunction flex(direction: string) {\n return `\n display: flex;\n gap: 8px;\n flex-direction: ${direction};`;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-expressions\ninjectGlobal`\n .group--header {\n ${flex('row')}\n }\n\n .group-or-rule {\n ${flex('column')}\n .rule {\n flex-direction: row;\n }\n }\n\n .rule--body {\n ${flex('row')}\n }\n\n .group--children {\n ${flex('column')}\n }\n\n .group--conjunctions:empty {\n display: none;\n }\n`;\n","import { useAsync } from 'react-use';\n\nimport { SelectableValue, TypedVariableModel } from '@grafana/data';\nimport { getTemplateSrv } from '@grafana/runtime';\n\nimport { QueryWithDefaults } from '../../defaults';\nimport { DB, SQLExpression, SQLQuery, SQLSelectableValue } from '../../types';\nimport { useSqlChange } from '../../utils/useSqlChange';\n\nimport { Config } from './AwesomeQueryBuilder';\nimport { WhereRow } from './WhereRow';\n\ninterface WhereRowProps {\n query: QueryWithDefaults;\n fields: SelectableValue[];\n onQueryChange: (query: SQLQuery) => void;\n db: DB;\n}\n\nexport function SQLWhereRow({ query, fields, onQueryChange, db }: WhereRowProps) {\n const state = useAsync(async () => {\n return mapFieldsToTypes(fields);\n }, [fields]);\n\n const { onSqlChange } = useSqlChange({ query, onQueryChange, db });\n\n return (\n <WhereRow\n // TODO: fix key that's used to force clean render or SQLWhereRow - otherwise it doesn't render operators correctly\n key={JSON.stringify(state.value)}\n config={{ fields: state.value || {} }}\n sql={query.sql!}\n onSqlChange={(val: SQLExpression) => {\n const templateVars = getTemplateSrv().getVariables();\n\n removeQuotesForMultiVariables(val, templateVars);\n\n onSqlChange(val);\n }}\n />\n );\n}\n\n// needed for awesome query builder\nfunction mapFieldsToTypes(columns: SQLSelectableValue[]) {\n const fields: Config['fields'] = {};\n for (const col of columns) {\n fields[col.value] = {\n type: col.raqbFieldType || 'text',\n valueSources: ['value'],\n mainWidgetProps: { customProps: { icon: col.icon } },\n };\n }\n return fields;\n}\n\nexport function removeQuotesForMultiVariables(val: SQLExpression, templateVars: TypedVariableModel[]) {\n const multiVariableInWhereString = (tv: TypedVariableModel) =>\n 'multi' in tv &&\n tv.multi &&\n (val.whereString?.includes(`\\${${tv.name}}`) || val.whereString?.includes(`$${tv.name}`));\n\n if (templateVars.some((tv) => multiVariableInWhereString(tv))) {\n val.whereString = val.whereString?.replaceAll(\"')\", ')');\n val.whereString = val.whereString?.replaceAll(\"('\", '(');\n }\n}\n","import { useId } from 'react';\n\nimport { SelectableValue } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { t } from '@grafana/i18n';\nimport { EditorField } from '@grafana/plugin-ui';\nimport { Select } from '@grafana/ui';\n\ninterface Props {\n columns: Array<SelectableValue<string>>;\n onParameterChange: (value?: string) => void;\n value: SelectableValue<string> | null;\n}\n\nexport function SelectColumn({ columns, onParameterChange, value }: Props) {\n const selectInputId = useId();\n\n return (\n <EditorField label={t('grafana-sql.components.select-column.label-column', 'Column')} width={25}>\n <Select\n value={value}\n data-testid={selectors.components.SQLQueryEditor.selectColumn}\n inputId={selectInputId}\n menuShouldPortal\n options={[{ label: '*', value: '*' }, ...columns]}\n allowCustomValue\n onChange={(s) => onParameterChange(s.value)}\n />\n </EditorField>\n );\n}\n","import { css } from '@emotion/css';\nimport { useCallback } from 'react';\n\nimport { SelectableValue } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { t } from '@grafana/i18n';\nimport { Button, InlineLabel, Input, Stack, useStyles2 } from '@grafana/ui';\n\nimport { QueryEditorExpressionType } from '../../expressions';\nimport { SQLExpression, SQLQuery } from '../../types';\nimport { getColumnValue } from '../../utils/sql.utils';\n\nimport { SelectColumn } from './SelectColumn';\n\ninterface Props {\n columns: Array<SelectableValue<string>>;\n query: SQLQuery;\n onSqlChange: (sql: SQLExpression) => void;\n onParameterChange: (index: number) => (value?: string) => void;\n currentColumnIndex: number;\n}\n\nexport function SelectCustomFunctionParameters({\n columns,\n query,\n onSqlChange,\n onParameterChange,\n currentColumnIndex,\n}: Props) {\n const styles = useStyles2(getStyles);\n const macroOrFunction = query.sql?.columns?.[currentColumnIndex];\n\n const addParameter = useCallback(\n (index: number) => {\n const item = query.sql?.columns?.[index];\n if (!item) {\n return;\n }\n\n item.parameters = item.parameters\n ? [...item.parameters, { type: QueryEditorExpressionType.FunctionParameter, name: '' }]\n : [];\n\n const newSql: SQLExpression = {\n ...query.sql,\n columns: query.sql?.columns?.map((c, i) => (i === index ? item : c)),\n };\n\n onSqlChange(newSql);\n },\n [onSqlChange, query.sql]\n );\n\n const removeParameter = useCallback(\n (columnIndex: number, index: number) => {\n const item = query.sql?.columns?.[columnIndex];\n if (!item?.parameters) {\n return;\n }\n item.parameters = item.parameters?.filter((_, i) => i !== index);\n\n const newSql: SQLExpression = {\n ...query.sql,\n columns: query.sql?.columns?.map((c, i) => (i === columnIndex ? item : c)),\n };\n\n onSqlChange(newSql);\n },\n [onSqlChange, query.sql]\n );\n\n function renderParameters(columnIndex: number) {\n if (!macroOrFunction?.parameters || macroOrFunction.parameters.length <= 1) {\n return null;\n }\n\n const paramComponents = macroOrFunction.parameters.map((param, index) => {\n // Skip the first parameter as it is the column name\n if (index === 0) {\n return null;\n }\n\n return (\n <Stack key={index} gap={2}>\n <InlineLabel className={styles.label}>,</InlineLabel>\n <Input\n onChange={(e) => onParameterChange(index)(e.currentTarget.value)}\n value={param.name}\n aria-label={t(\n 'grafana-sql.components.select-custom-function-parameters.aria-label-parameter',\n 'Parameter {{index}} for column {{columnIndex}}',\n { index, columnIndex }\n )}\n data-testid={selectors.components.SQLQueryEditor.selectInputParameter}\n addonAfter={\n <Button\n aria-label={t(\n 'grafana-sql.components.select-custom-function-parameters.render-parameters.params.title-remove-parameter',\n 'Remove parameter'\n )}\n type=\"button\"\n icon=\"times\"\n variant=\"secondary\"\n size=\"md\"\n onClick={() => removeParameter(columnIndex, index)}\n />\n }\n />\n </Stack>\n );\n });\n return paramComponents;\n }\n\n return (\n <>\n <InlineLabel className={styles.label}>(</InlineLabel>\n <SelectColumn\n columns={columns}\n onParameterChange={(s) => onParameterChange(0)(s)}\n value={getColumnValue(macroOrFunction?.parameters?.[0])}\n />\n {renderParameters(currentColumnIndex)}\n <Button\n type=\"button\"\n onClick={() => addParameter(currentColumnIndex)}\n variant=\"secondary\"\n size=\"md\"\n icon=\"plus\"\n aria-label={t('grafana-sql.components.select-custom-function-parameters.title-add-parameter', 'Add parameter')}\n />\n <InlineLabel className={styles.label}>)</InlineLabel>\n </>\n );\n}\n\nconst getStyles = () => {\n return {\n label: css({\n padding: 0,\n margin: 0,\n width: 'unset',\n }),\n };\n};\n","import { css } from '@emotion/css';\nimport { useCallback, useEffect, useId, useState } from 'react';\n\nimport { SelectableValue } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { EditorField } from '@grafana/plugin-ui';\nimport { InlineLabel, Input, Select, Stack, useStyles2 } from '@grafana/ui';\n\nimport { QueryEditorExpressionType } from '../../expressions';\nimport { DB, SQLExpression, SQLQuery } from '../../types';\nimport { getColumnValue } from '../../utils/sql.utils';\n\nimport { SelectColumn } from './SelectColumn';\nimport { SelectCustomFunctionParameters } from './SelectCustomFunctionParameters';\n\ninterface Props {\n query: SQLQuery;\n onSqlChange: (sql: SQLExpression) => void;\n currentColumnIndex: number;\n db: DB;\n columns: Array<SelectableValue<string>>;\n}\n\nexport function SelectFunctionParameters({ query, onSqlChange, currentColumnIndex, db, columns }: Props) {\n const selectInputId = useId();\n const macroOrFunction = query.sql?.columns?.[currentColumnIndex];\n const styles = useStyles2(getStyles);\n const func = db.functions().find((f) => f.name === macroOrFunction?.name);\n\n const [fieldsFromFunction, setFieldsFromFunction] = useState<Array<Array<SelectableValue<string>>>>([]);\n\n useEffect(() => {\n const getFieldsFromFunction = async () => {\n if (!func) {\n return;\n }\n const options: Array<Array<SelectableValue<string>>> = [];\n for (const param of func.parameters ?? []) {\n if (param.options) {\n options.push(await param.options(query));\n } else {\n options.push([]);\n }\n }\n setFieldsFromFunction(options);\n };\n getFieldsFromFunction();\n\n // It is fine to ignore the warning here and omit the query object\n // only table property is used in the query object and whenever table changes the component is re-rendered\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [macroOrFunction?.name]);\n\n const onParameterChange = useCallback(\n (index: number, keepIndex?: boolean) => (s: string | undefined) => {\n const item = query.sql?.columns?.[currentColumnIndex];\n if (!item) {\n return;\n }\n if (!item.parameters) {\n item.parameters = [];\n }\n if (item.parameters[index] === undefined) {\n item.parameters[index] = { type: QueryEditorExpressionType.FunctionParameter, name: s };\n } else if (s == null && keepIndex) {\n // Remove value from index\n item.parameters = item.parameters.map((p, i) => (i === index ? { ...p, name: '' } : p));\n // Remove the last empty parameter\n if (item.parameters[item.parameters.length - 1]?.name === '') {\n item.parameters = item.parameters.filter((p) => p.name !== '');\n }\n } else if (s == null) {\n item.parameters = item.parameters.filter((_, i) => i !== index);\n } else {\n item.parameters = item.parameters.map((p, i) => (i === index ? { ...p, name: s } : p));\n }\n\n const newSql: SQLExpression = {\n ...query.sql,\n columns: query.sql?.columns?.map((c, i) => (i === currentColumnIndex ? item : c)),\n };\n\n onSqlChange(newSql);\n },\n [currentColumnIndex, onSqlChange, query.sql]\n );\n\n function renderParametersWithFunctions() {\n if (!func?.parameters) {\n return null;\n }\n\n return func?.parameters.map((funcParam, index) => {\n return (\n <Stack key={index} alignItems=\"flex-end\" gap={2}>\n <EditorField label={funcParam.name} width={25} optional={!funcParam.required}>\n <>\n {funcParam.options ? (\n <Select\n value={getColumnValue(macroOrFunction?.parameters![index])}\n options={fieldsFromFunction?.[index]}\n data-testid={selectors.components.SQLQueryEditor.selectFunctionParameter(funcParam.name)}\n inputId={selectInputId}\n menuShouldPortal\n allowCustomValue\n isClearable\n onChange={(s) => onParameterChange(index, true)(s?.value)}\n />\n ) : (\n <Input\n onChange={(e) => onParameterChange(index, true)(e.currentTarget.value)}\n value={macroOrFunction?.parameters![index]?.name}\n data-testid={selectors.components.SQLQueryEditor.selectInputParameter}\n />\n )}\n </>\n </EditorField>\n {func.parameters!.length !== index + 1 && <InlineLabel className={styles.label}>,</InlineLabel>}\n </Stack>\n );\n });\n }\n\n // This means that no function is selected, we render a column selector\n if (macroOrFunction?.name === undefined) {\n return (\n <SelectColumn\n columns={columns}\n onParameterChange={(s) => onParameterChange(0)(s)}\n value={getColumnValue(macroOrFunction?.parameters?.[0])}\n />\n );\n }\n\n // If the function is not found, that means that it might be a custom value\n // we let the user add any number of parameters\n if (!func) {\n return (\n <SelectCustomFunctionParameters\n query={query}\n onSqlChange={onSqlChange}\n currentColumnIndex={currentColumnIndex}\n columns={columns}\n onParameterChange={onParameterChange}\n />\n );\n }\n\n // Else we render the function parameters based on the provided settings\n return (\n <>\n <InlineLabel className={styles.label}>(</InlineLabel>\n {renderParametersWithFunctions()}\n <InlineLabel className={styles.label}>)</InlineLabel>\n </>\n );\n}\n\nconst getStyles = () => {\n return {\n label: css({\n padding: 0,\n margin: 0,\n width: 'unset',\n }),\n };\n};\n","import { css } from '@emotion/css';\nimport { uniqueId } from 'lodash';\nimport { useCallback } from 'react';\n\nimport { SelectableValue, toOption } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { t } from '@grafana/i18n';\nimport { EditorField } from '@grafana/plugin-ui';\nimport { Button, Select, Stack, useStyles2 } from '@grafana/ui';\n\nimport { QueryEditorExpressionType, QueryEditorFunctionExpression } from '../../expressions';\nimport { DB, QueryFormat, SQLExpression, SQLQuery } from '../../types';\nimport { createFunctionField } from '../../utils/sql.utils';\nimport { useSqlChange } from '../../utils/useSqlChange';\n\nimport { SelectFunctionParameters } from './SelectFunctionParameters';\n\ninterface SelectRowProps {\n query: SQLQuery;\n onQueryChange: (sql: SQLQuery) => void;\n db: DB;\n columns: Array<SelectableValue<string>>;\n}\n\nexport function SelectRow({ query, onQueryChange, db, columns }: SelectRowProps) {\n const styles = useStyles2(getStyles);\n const { onSqlChange } = useSqlChange({ query, onQueryChange, db });\n const timeSeriesAliasOpts: Array<SelectableValue<string>> = [];\n\n // Add necessary alias options for time series format\n // when that format has been selected\n if (query.format === QueryFormat.Timeseries) {\n timeSeriesAliasOpts.push({ label: t('grafana-sql.components.select-row.label.time', 'time'), value: 'time' });\n timeSeriesAliasOpts.push({ label: t('grafana-sql.components.select-row.label.value', 'value'), value: 'value' });\n }\n\n const onAggregationChange = useCallback(\n (item: QueryEditorFunctionExpression, index: number) => (aggregation: SelectableValue<string>) => {\n const newItem = {\n ...item,\n name: aggregation?.value,\n parameters: [\n { type: QueryEditorExpressionType.FunctionParameter as const, name: item.parameters?.[0]?.name || '' },\n ],\n };\n const newSql: SQLExpression = {\n ...query.sql,\n columns: query.sql?.columns?.map((c, i) => (i === index ? newItem : c)),\n };\n\n onSqlChange(newSql);\n },\n [onSqlChange, query.sql]\n );\n\n const onAliasChange = useCallback(\n (item: QueryEditorFunctionExpression, index: number) => (alias: SelectableValue<string>) => {\n let newItem = { ...item };\n\n if (alias !== null) {\n newItem = { ...item, alias: `\"${alias?.value?.trim()}\"` };\n } else {\n delete newItem.alias;\n }\n\n const newSql: SQLExpression = {\n ...query.sql,\n columns: query.sql?.columns?.map((c, i) => (i === index ? newItem : c)),\n };\n\n onSqlChange(newSql);\n },\n [onSqlChange, query.sql]\n );\n\n const removeColumn = useCallback(\n (index: number) => () => {\n const clone = [...(query.sql?.columns || [])];\n clone.splice(index, 1);\n const newSql: SQLExpression = {\n ...query.sql,\n columns: clone,\n };\n onSqlChange(newSql);\n },\n [onSqlChange, query.sql]\n );\n\n const addColumn = useCallback(() => {\n const newSql: SQLExpression = { ...query.sql, columns: [...(query.sql?.columns || []), createFunctionField()] };\n onSqlChange(newSql);\n }, [onSqlChange, query.sql]);\n\n const aggregateOptions = () => {\n const options: Array<SelectableValue<string>> = [\n {\n label: t('grafana-sql.components.select-row.aggregate-options.options.label.aggregations', 'Aggregations'),\n options: [],\n },\n { label: t('grafana-sql.components.select-row.aggregate-options.options.label.macros', 'Macros'), options: [] },\n ];\n for (const func of db.functions()) {\n // Create groups for macros\n if (func.name.startsWith('$__')) {\n options[1].options.push({ label: func.name, value: func.name });\n } else {\n options[0].options.push({ label: func.name, value: func.name });\n }\n }\n return options;\n };\n\n return (\n <Stack gap={2} wrap=\"wrap\" direction=\"column\">\n {query.sql?.columns?.map((item, index) => (\n <div key={index}>\n <Stack gap={2} alignItems=\"end\">\n <EditorField\n label={t('grafana-sql.components.select-row.label-data-operations', 'Data operations')}\n optional\n width={25}\n >\n <Select\n value={item.name ? toOption(item.name) : null}\n inputId={`select-aggregation-${index}-${uniqueId()}`}\n data-testid={selectors.components.SQLQueryEditor.selectAggregation}\n isClearable\n menuShouldPortal\n allowCustomValue\n options={aggregateOptions()}\n onChange={onAggregationChange(item, index)}\n />\n </EditorField>\n\n <SelectFunctionParameters\n currentColumnIndex={index}\n columns={columns}\n onSqlChange={onSqlChange}\n query={query}\n db={db}\n />\n\n <EditorField label={t('grafana-sql.components.select-row.label-alias', 'Alias')} optional width={15}>\n <Select\n value={item.alias ? toOption(item.alias) : null}\n inputId={`select-alias-${index}-${uniqueId()}`}\n data-testid={selectors.components.SQLQueryEditor.selectAlias}\n options={timeSeriesAliasOpts}\n onChange={onAliasChange(item, index)}\n isClearable\n menuShouldPortal\n allowCustomValue\n />\n </EditorField>\n <Button\n aria-label={t('grafana-sql.components.select-row.title-remove-column', 'Remove column')}\n type=\"button\"\n icon=\"trash-alt\"\n variant=\"secondary\"\n size=\"md\"\n onClick={removeColumn(index)}\n />\n </Stack>\n </div>\n ))}\n <Button\n type=\"button\"\n onClick={addColumn}\n variant=\"secondary\"\n aria-label={t('grafana-sql.components.select-row.title-add-column', 'Add column')}\n size=\"md\"\n icon=\"plus\"\n className={styles.addButton}\n />\n </Stack>\n );\n}\n\nconst getStyles = () => {\n return {\n addButton: css({ alignSelf: 'flex-start' }),\n label: css({\n padding: 0,\n margin: 0,\n width: 'unset',\n }),\n };\n};\n","import { useAsync } from 'react-use';\n\nimport { t } from '@grafana/i18n';\nimport { EditorRows, EditorRow, EditorField } from '@grafana/plugin-ui';\n\nimport { DB, QueryEditorProps, QueryRowFilter } from '../../types';\nimport { QueryToolbox } from '../query-editor-raw/QueryToolbox';\n\nimport { Preview } from './Preview';\nimport { SQLGroupByRow } from './SQLGroupByRow';\nimport { SQLOrderByRow } from './SQLOrderByRow';\nimport { SQLWhereRow } from './SQLWhereRow';\nimport { SelectRow } from './SelectRow';\n\ninterface VisualEditorProps extends QueryEditorProps {\n db: DB;\n queryRowFilter: QueryRowFilter;\n onValidate: (isValid: boolean) => void;\n}\n\nexport const VisualEditor = ({ query, db, queryRowFilter, onChange, onValidate, range }: VisualEditorProps) => {\n const state = useAsync(async () => {\n const fields = await db.fields(query);\n return fields;\n }, [db, query.dataset, query.table]);\n\n return (\n <>\n <EditorRows>\n <EditorRow>\n <SelectRow columns={state.value || []} query={query} onQueryChange={onChange} db={db} />\n </EditorRow>\n {queryRowFilter.filter && (\n <EditorRow>\n <EditorField\n label={t('grafana-sql.components.visual-editor.label-filter-by-column-value', 'Filter by column value')}\n optional\n >\n <SQLWhereRow fields={state.value || []} query={query} onQueryChange={onChange} db={db} />\n </EditorField>\n </EditorRow>\n )}\n {queryRowFilter.group && (\n <EditorRow>\n <EditorField label={t('grafana-sql.components.visual-editor.label-group-by-column', 'Group by column')}>\n <SQLGroupByRow fields={state.value || []} query={query} onQueryChange={onChange} db={db} />\n </EditorField>\n </EditorRow>\n )}\n {queryRowFilter.order && (\n <EditorRow>\n <SQLOrderByRow fields={state.value || []} query={query} onQueryChange={onChange} db={db} />\n </EditorRow>\n )}\n {queryRowFilter.preview && query.rawSql && (\n <EditorRow>\n <Preview rawSql={query.rawSql} datasourceType={query.datasource?.type} />\n </EditorRow>\n )}\n </EditorRows>\n <QueryToolbox db={db} query={query} onValidate={onValidate} range={range} />\n </>\n );\n};\n","import { useCallback, useEffect, useState } from 'react';\nimport { useAsync } from 'react-use';\n\nimport { QueryEditorProps } from '@grafana/data';\nimport { EditorMode } from '@grafana/plugin-ui';\nimport { Space } from '@grafana/ui';\n\nimport { SqlDatasource } from '../datasource/SqlDatasource';\nimport { applyQueryDefaults } from '../defaults';\nimport { SQLQuery, QueryRowFilter, SQLOptions } from '../types';\nimport { haveColumns } from '../utils/sql.utils';\n\nimport { QueryHeader, QueryHeaderProps } from './QueryHeader';\nimport { RawEditor } from './query-editor-raw/RawEditor';\nimport { VisualEditor } from './visual-query-builder/VisualEditor';\n\nexport interface SqlQueryEditorProps extends QueryEditorProps<SqlDatasource, SQLQuery, SQLOptions> {\n queryHeaderProps?: Pick<QueryHeaderProps, 'dialect'>;\n}\n\nexport default function SqlQueryEditor({\n datasource,\n query,\n onChange,\n onRunQuery,\n range,\n queryHeaderProps,\n}: SqlQueryEditorProps) {\n const [isQueryRunnable, setIsQueryRunnable] = useState(true);\n const db = datasource.getDB();\n\n const { preconfiguredDatabase } = datasource;\n const dialect = queryHeaderProps?.dialect ?? 'other';\n const { loading, error } = useAsync(async () => {\n return () => {\n if (datasource.getDB(datasource.id).init !== undefined) {\n datasource.getDB(datasource.id).init!();\n }\n };\n }, [datasource]);\n\n const queryWithDefaults = applyQueryDefaults(query);\n const [queryRowFilter, setQueryRowFilter] = useState<QueryRowFilter>({\n filter: !!queryWithDefaults.sql?.whereString,\n group: !!queryWithDefaults.sql?.groupBy?.[0]?.property.name,\n order: !!queryWithDefaults.sql?.orderBy?.property.name,\n preview: true,\n });\n const [queryToValidate, setQueryToValidate] = useState(queryWithDefaults);\n\n useEffect(() => {\n return () => {\n if (datasource.getDB(datasource.id).dispose !== undefined) {\n datasource.getDB(datasource.id).dispose!();\n }\n };\n }, [datasource]);\n\n const processQuery = useCallback(\n (q: SQLQuery) => {\n if (isQueryValid(q) && onRunQuery) {\n onRunQuery();\n }\n },\n [onRunQuery]\n );\n\n const onQueryChange = (q: SQLQuery, process = true) => {\n setQueryToValidate(q);\n onChange(q);\n\n if (haveColumns(q.sql?.columns) && q.sql?.columns.some((c) => c.name) && !queryRowFilter.group) {\n setQueryRowFilter({ ...queryRowFilter, group: true });\n }\n\n if (process) {\n processQuery(q);\n }\n };\n\n const onQueryHeaderChange = (q: SQLQuery) => {\n setQueryToValidate(q);\n onChange(q);\n };\n\n if (loading || error) {\n return null;\n }\n\n return (\n <>\n <QueryHeader\n db={db}\n preconfiguredDataset={preconfiguredDatabase}\n onChange={onQueryHeaderChange}\n onRunQuery={onRunQuery}\n onQueryRowChange={setQueryRowFilter}\n queryRowFilter={queryRowFilter}\n query={queryWithDefaults}\n isQueryRunnable={isQueryRunnable}\n dialect={dialect}\n />\n\n <Space v={0.5} />\n\n {queryWithDefaults.editorMode !== EditorMode.Code && (\n <VisualEditor\n db={db}\n query={queryWithDefaults}\n onChange={(q: SQLQuery) => onQueryChange(q, false)}\n queryRowFilter={queryRowFilter}\n onValidate={setIsQueryRunnable}\n range={range}\n />\n )}\n\n {queryWithDefaults.editorMode === EditorMode.Code && (\n <RawEditor\n db={db}\n query={queryWithDefaults}\n queryToValidate={queryToValidate}\n onChange={onQueryChange}\n onRunQuery={onRunQuery}\n onValidate={setIsQueryRunnable}\n range={range}\n />\n )}\n </>\n );\n}\n\nconst isQueryValid = (q: SQLQuery) => {\n return Boolean(q.rawSql);\n};\n","import { cx, css } from '@emotion/css';\nimport { useStyles2 } from '@grafana/ui';\nimport React__default, { Children, isValidElement, cloneElement } from 'react';\n\nconst InputGroup = ({ children }) => {\n const styles = useStyles2(getStyles);\n const modifiedChildren = Children.map(children, (child) => {\n if (isValidElement(child) && child.props.invalid) {\n return cloneElement(child, { className: cx(child.props.className, styles.invalidChild) });\n }\n return child;\n });\n return /* @__PURE__ */ React__default.createElement(\"div\", { className: styles.root }, modifiedChildren);\n};\nconst borderPriority = [\n \"\",\n // lowest priority\n \"base\",\n \"hovered\",\n \"invalid\",\n \"focused\"\n // highest priority\n];\nconst getStyles = () => ({\n root: css({\n display: \"flex\",\n // Style the direct children of the component\n \"> *\": {\n \"&:not(:first-child)\": {\n // Negative margin hides the double-border on adjacent selects\n marginLeft: -1\n },\n \"&:first-child\": {\n borderTopRightRadius: 0,\n borderBottomRightRadius: 0\n },\n \"&:last-child\": {\n borderTopLeftRadius: 0,\n borderBottomLeftRadius: 0\n },\n \"&:not(:first-child):not(:last-child)\": {\n borderRadius: 0\n },\n //\n position: \"relative\",\n zIndex: borderPriority.indexOf(\"base\"),\n // Adjacent borders are overlapping, so raise children up when hovering etc\n // so all that child's borders are visible.\n \"&:hover\": {\n zIndex: borderPriority.indexOf(\"hovered\")\n },\n \"&:focus-within\": {\n zIndex: borderPriority.indexOf(\"focused\")\n }\n }\n }),\n invalidChild: css({\n zIndex: borderPriority.indexOf(\"invalid\")\n })\n});\n\nexport { InputGroup };\n//# sourceMappingURL=InputGroup.js.map\n","import { css, cx } from '@emotion/css';\nimport React__default, { useState } from 'react';\nimport '@grafana/data';\nimport { useStyles2, Select, SelectContainer as SelectContainer$1 } from '@grafana/ui';\n\nfunction InlineSelect({ label: labelProp, ...props }) {\n const [id] = useState(() => Math.random().toString(16).slice(2));\n const styles = useStyles2(getSelectStyles);\n const components = {\n SelectContainer,\n ValueContainer,\n SingleValue: ValueContainer\n };\n return /* @__PURE__ */ React__default.createElement(\"div\", { className: styles.root }, labelProp && /* @__PURE__ */ React__default.createElement(\"label\", { className: styles.label, htmlFor: id }, labelProp, \":\", \"\\xA0\"), /* @__PURE__ */ React__default.createElement(Select, { openMenuOnFocus: true, inputId: id, ...props, components }));\n}\nconst SelectContainer = (props) => {\n const { children } = props;\n const styles = useStyles2(getSelectStyles);\n return /* @__PURE__ */ React__default.createElement(SelectContainer$1, { ...props, className: cx(props.className, styles.container) }, children);\n};\nconst ValueContainer = (props) => {\n const { className, children } = props;\n const styles = useStyles2(getSelectStyles);\n return /* @__PURE__ */ React__default.createElement(\"div\", { className: cx(className, styles.valueContainer) }, children);\n};\nconst getSelectStyles = (theme) => ({\n root: css({\n display: \"flex\",\n fontSize: 12,\n alignItems: \"center\"\n }),\n label: css({\n color: theme.colors.text.secondary,\n whiteSpace: \"nowrap\"\n }),\n container: css({\n background: \"none\",\n borderColor: \"transparent\"\n }),\n valueContainer: css({\n display: \"flex\",\n alignItems: \"center\",\n flex: \"initial\",\n color: theme.colors.text.secondary,\n fontSize: 12\n })\n});\n\nexport { InlineSelect };\n//# sourceMappingURL=InlineSelect.js.map\n"],"names":["EditorRows","children","EditorHeader","styles","getStyles","theme","AccessoryButton","className","props","getButtonStyles","EditorList","items","renderItem","onChange","ref","onAddItem","newItems","onChangeItem","itemIndex","newItem","onDeleteItem","item","index","EditorRow","FlexItem","grow","shrink","EditorStack","wrapItems","_a","_b","ConfirmModal","isOpen","onCancel","onDiscard","onCopy","buttonRef","Modal","Icon","Button","DatasetSelector","dataset","db","dialect","inputId","preconfiguredDataset","hasPreconfigCondition","state","useAsync","Select","TableSelector","table","selectors","QueryHeader","isQueryRunnable","onQueryRowChange","onRunQuery","query","queryRowFilter","editorMode","_","copyToClipboard","useCopyToClipboard","showConfirm","setShowConfirm","toRawSql","htmlId","editorModes","onEditorModeChange","newEditorMode","onFormatChange","e","next","onDatasetChange","onTableChange","datasetDropdownIsAvailable","InlineSelect","ev","Tooltip","RadioButtonGroup","Space","EditorField","QueryEditorRaw","width","height","editorLanguageDefinition","queryRef","onRawQueryChange","rawSql","processQuery","newQuery","SQLEditor","QueryValidator","onValidate","range","validationResult","setValidationResult","valueFormatter","validateQuery","useAsyncFn","q","useDebounce","result","error","processErrorMessage","Spinner","splat","QueryToolbox","showTools","onFormatCode","onExpand","isExpanded","validatorProps","style","Stack","IconButton","RawEditor","queryToValidate","setIsExpanded","toolboxRef","toolboxMeasure","useMeasure","editorRef","editorMeasure","renderQueryEditor","formatQuery","renderEditor","standalone","renderPlaceholder","getColumnsWithIndices","fields","options","c","i","value","p","useSqlChange","onQueryChange","sql","GroupByRow","columns","onSqlChange","onGroupByChange","cleaned","v","newSql","makeRenderColumn","InputGroup","SQLGroupByRow","columnsWithIndices","sortOrderOptions","OrderByRow","showOffset","onSortOrderChange","onLimitChange","event","onOffsetChange","onOrderByChange","Input","SQLOrderByRow","buttonLabels","emptyInitTree","TIME_FILTER","macros","widgets","val","dateValue","DateTimePicker","field","widget","operator","operatorDefinition","rightFieldDef","settings","conjProps","fieldProps","f","icon","buttonProps","operatorProps","op","Op","customOperators","getCustomOperators","textWidget","opers","customTextWidget","customTypes","raqbConfig","noop","config","supportedOperators","sqlFormatInOp","formatInOp","customSqlInFormatter","valueSrc","valueType","opDef","operatorOptions","fieldDef","splitIfString","sqlFormatNotInOp","formatNotInOp","customSqlNotInFormatter","_operator","WhereRow","tree","setTree","configWithDefaults","initTree","onTreeChange","changedTree","flex","direction","SQLWhereRow","mapFieldsToTypes","templateVars","removeQuotesForMultiVariables","col","multiVariableInWhereString","tv","SelectColumn","onParameterChange","selectInputId","s","SelectCustomFunctionParameters","currentColumnIndex","macroOrFunction","addParameter","removeParameter","columnIndex","renderParameters","param","InlineLabel","SelectFunctionParameters","func","fieldsFromFunction","setFieldsFromFunction","keepIndex","renderParametersWithFunctions","funcParam","SelectRow","timeSeriesAliasOpts","onAggregationChange","aggregation","onAliasChange","alias","removeColumn","clone","addColumn","aggregateOptions","VisualEditor","Preview","SqlQueryEditor","datasource","queryHeaderProps","setIsQueryRunnable","preconfiguredDatabase","loading","queryWithDefaults","setQueryRowFilter","setQueryToValidate","isQueryValid","process","onQueryHeaderChange","modifiedChildren","child","borderPriority","labelProp","id","getSelectStyles","components","SelectContainer","ValueContainer"],"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