/usr/share/grafana/public/build
{"version":3,"file":"9292.e6befb57f8f116ad95a8.js","mappings":"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QACjB,CAAC,EACD,cAAY,OAAI,CACd,SAAU,CACZ,CAAC,EACD,YAAU,OAAI,CACZ,KAAMA,EAAM,OAAO,QAAQ,IAC7B,CAAC,EACD,UAAQ,OAAI,CACV,eAAgB,YAClB,CAAC,EACD,eAAa,OAAI,CACf,OAAQ,OACR,SAAUA,EAAM,WAAW,UAAU,SACrC,MAAOA,EAAM,OAAO,KAAK,UACzB,QAAS,OACT,cAAe,MACf,eAAgB,aAChB,UAAWA,EAAM,QAAQ,CAAC,EAC1B,WAAY,QACd,CAAC,CACH,CACF,ECtYawI,GAAyC,CACpD,CACE,KAAM,WACN,KAAM,SACN,MAAO,mEACT,EACA,CACE,KAAM,SACN,KAAM,SACN,MAAO,4DACT,EACA,CACE,KAAM,SACN,KAAM,UACN,MAAO,+DACT,EACA,CACE,KAAM,gBACN,KAAM,UACN,MAAO,uBACT,EACA,CACE,KAAM,kBACN,KAAM,UACN,MAAO,yBACT,EACA,CACE,KAAM,cACN,KAAM,WACN,MAAO,sCACT,EACA,CACE,KAAM,eACN,KAAM,WACN,MAAO,gEACT,EACA,CACE,KAAM,oBACN,KAAM,WACN,MAAO,qEACT,EACA,CACE,KAAM,cACN,KAAM,SACN,MAAO,sDACT,CACF,EAEaC,GAA+C,CAC1D,CACE,KAAM,SACN,KAAM,WACN,MAAO,sCACT,EACA,CACE,KAAM,cACN,KAAM,WACN,MAAO,2CACT,EACA,CACE,KAAM,WACN,KAAM,mBACN,MAAO,gCACT,EACA,CACE,KAAM,SACN,KAAM,mBACN,MAAO,6BACT,CACF,EAEaC,GAAwC,CACnD,CACE,KAAM,SACN,KAAM,SACN,MAAO,qBACT,EACA,CACE,KAAM,SACN,KAAM,WACN,MAAO,sCACT,EACA,CACE,KAAM,cACN,KAAM,WACN,MAAO,2CACT,EACA,CACE,KAAM,SACN,KAAM,WACN,MACE,6IACJ,EACA,CACE,KAAM,WACN,KAAM,YACN,MAAO,gCACT,EACA,CACE,KAAM,SACN,KAAM,YACN,MACE,gJACJ,EACA,CACE,KAAM,eACN,KAAM,SACN,MAAO,kDACT,EACA,CACE,KAAM,aACN,K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","sources":["webpack://grafana/./public/app/features/alerting/unified/components/EditorColumnHeader.tsx","webpack://grafana/./public/app/features/alerting/unified/enterprise-components/AI/addAIFeedbackButton.tsx","webpack://grafana/./public/app/features/alerting/unified/components/receivers/usePreviewTemplate.ts","webpack://grafana/./public/app/features/alerting/unified/components/receivers/TemplatePreview.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rules/state-history/common.ts","webpack://grafana/./node_modules/date-fns/subDays.js","webpack://grafana/./node_modules/date-fns/addMinutes.js","webpack://grafana/./node_modules/date-fns/addHours.js","webpack://grafana/./node_modules/date-fns/subHours.js","webpack://grafana/./public/app/features/alerting/unified/enterprise-components/AI/AIGenTemplateButton/addAITemplateButton.ts","webpack://grafana/./public/app/features/alerting/unified/components/receivers/AlertInstanceModalSelector.tsx","webpack://grafana/./public/app/features/alerting/unified/components/receivers/TemplateData.ts","webpack://grafana/./public/app/features/alerting/unified/components/receivers/TemplateDataDocs.tsx","webpack://grafana/./public/app/features/alerting/unified/components/receivers/form/GenerateAlertDataModal.tsx","webpack://grafana/./public/app/features/alerting/unified/components/receivers/PayloadEditor.tsx","webpack://grafana/./public/app/features/alerting/unified/components/receivers/TemplateDataExamples.ts","webpack://grafana/./public/app/features/alerting/unified/components/receivers/TemplateForm.tsx"],"sourcesContent":["import { css } from '@emotion/css';\nimport * as React from 'react';\nimport { type MergeExclusive } from 'type-fest';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Label, Stack, useStyles2 } from '@grafana/ui';\n\ninterface BaseProps {\n id?: string;\n}\n\ninterface ChildrenProps extends BaseProps {\n children: React.ReactNode;\n}\n\ninterface LabelActionsProps extends BaseProps {\n label: string;\n actions?: React.ReactNode;\n}\n\ntype Props = MergeExclusive<ChildrenProps, LabelActionsProps>;\n\nexport function EditorColumnHeader({ label, actions, id, children }: Props) {\n const styles = useStyles2(editorColumnStyles);\n\n if (children) {\n return <div className={styles.container}>{children}</div>;\n }\n\n return (\n <div className={styles.container}>\n <Label className={styles.label} id={id}>\n {label}\n </Label>\n {actions && (\n <Stack direction=\"row\" gap={1}>\n {actions}\n </Stack>\n )}\n </div>\n );\n}\n\nconst editorColumnStyles = (theme: GrafanaTheme2) => ({\n container: css({\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'space-between',\n alignItems: 'center',\n padding: theme.spacing(1, 2),\n backgroundColor: theme.colors.background.secondary,\n border: `1px solid ${theme.colors.border.medium}`,\n borderTopLeftRadius: theme.shape.radius.default,\n borderTopRightRadius: theme.shape.radius.default,\n }),\n label: css({\n margin: 0,\n }),\n});\n","import { ComponentType, createElement } from 'react';\n\nimport { t } from '@grafana/i18n';\nimport { withErrorBoundary } from '@grafana/ui';\n\nimport { logError } from '../../Analytics';\n\nexport type AIFeedbackOrigin = 'alert-rule' | 'template' | 'triage';\n\nexport interface GenAIFeedbackButtonProps {\n origin: AIFeedbackOrigin;\n shouldShowFeedbackButton?: boolean;\n // If true, the component will use the route detection to determine if the feedback should be shown\n // this is necessary for example in alerting rule form, where the feedback button is shown in the same page as the rule form\n useRouteDetection?: boolean;\n}\n\nlet InternalAIFeedbackButtonComponent: ComponentType<GenAIFeedbackButtonProps> | null = null;\n\nexport const AIFeedbackButtonComponent: ComponentType<GenAIFeedbackButtonProps> = (props) => {\n if (!InternalAIFeedbackButtonComponent) {\n return null;\n }\n\n // Wrap the component with error boundary\n const WrappedComponent = withErrorBoundary(InternalAIFeedbackButtonComponent, {\n title: t('alerting.ai.error-boundary.feedback-button', 'AI Feedback Button failed to load'),\n style: 'alertbox',\n errorLogger: logError,\n });\n\n // Provide default value for shouldShowFeedbackButton\n const propsWithDefaults = {\n shouldShowFeedbackButton: true,\n useRouteDetection: false,\n ...props,\n };\n\n return createElement(WrappedComponent, propsWithDefaults);\n};\n\nexport function addAIFeedbackButton(component: ComponentType<GenAIFeedbackButtonProps> | null) {\n InternalAIFeedbackButtonComponent = component;\n}\n","import { useCallback, useEffect } from 'react';\n\nimport { AlertField, usePreviewTemplateMutation } from '../../api/templateApi';\n\nexport function usePreviewTemplate(\n templateContent: string,\n templateName: string,\n payload: string,\n setPayloadFormatError: (value: React.SetStateAction<string | null>) => void\n) {\n const [trigger, { data, error, isLoading }] = usePreviewTemplateMutation();\n\n const onPreview = useCallback(() => {\n try {\n const alertList: AlertField[] = JSON.parse(payload);\n JSON.stringify([...alertList]); // check if it's iterable, in order to be able to add more data\n trigger({ template: templateContent, alerts: alertList, name: templateName });\n setPayloadFormatError(null);\n } catch (e) {\n setPayloadFormatError(e instanceof Error ? e.message : 'Invalid JSON.');\n }\n }, [templateContent, templateName, payload, setPayloadFormatError, trigger]);\n\n useEffect(() => onPreview(), [onPreview]);\n\n return { data, error, isLoading, onPreview };\n}\n","import { css, cx } from '@emotion/css';\nimport { compact, uniqueId } from 'lodash';\nimport * as React from 'react';\nimport AutoSizer from 'react-virtualized-auto-sizer';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Alert, Box, Button, CodeEditor, useStyles2 } from '@grafana/ui';\n\nimport { TemplatePreviewErrors, TemplatePreviewResponse, TemplatePreviewResult } from '../../api/templateApi';\nimport { AIFeedbackButtonComponent } from '../../enterprise-components/AI/addAIFeedbackButton';\nimport { stringifyErrorLike } from '../../utils/misc';\nimport { EditorColumnHeader } from '../EditorColumnHeader';\n\nimport { usePreviewTemplate } from './usePreviewTemplate';\n\nexport function TemplatePreview({\n payload,\n templateName,\n templateContent,\n payloadFormatError,\n setPayloadFormatError,\n className,\n aiGeneratedTemplate,\n setAiGeneratedTemplate,\n}: {\n payload: string;\n templateName: string;\n templateContent: string;\n payloadFormatError: string | null;\n setPayloadFormatError: (value: React.SetStateAction<string | null>) => void;\n className?: string;\n aiGeneratedTemplate?: boolean;\n setAiGeneratedTemplate?: (aiGeneratedTemplate: boolean) => void;\n}) {\n const styles = useStyles2(getStyles);\n\n const {\n data,\n isLoading,\n onPreview,\n error: previewError,\n } = usePreviewTemplate(templateContent, templateName, payload, setPayloadFormatError);\n\n const previewToRender = getPreviewResults(previewError, payloadFormatError, data);\n\n return (\n <div className={cx(styles.container, className)}>\n <EditorColumnHeader\n label={t('alerting.template-preview.label-preview', 'Preview')}\n actions={\n <Button\n disabled={isLoading}\n icon=\"sync\"\n aria-label={t('alerting.template-preview.aria-label-refresh-preview', 'Refresh preview')}\n onClick={() => {\n onPreview();\n setAiGeneratedTemplate?.(false);\n }}\n size=\"sm\"\n variant=\"secondary\"\n >\n <Trans i18nKey=\"alerting.template-preview.refresh\">Refresh</Trans>\n </Button>\n }\n />\n <div className={styles.viewer.feedbackContainer}>\n <AIFeedbackButtonComponent origin=\"template\" shouldShowFeedbackButton={Boolean(aiGeneratedTemplate)} />\n </div>\n <Box flex={1}>\n <AutoSizer disableWidth>\n {({ height }) => <div className={styles.viewerContainer({ height })}>{previewToRender}</div>}\n </AutoSizer>\n </Box>\n </div>\n );\n}\n\nfunction PreviewResultViewer({ previews }: { previews: TemplatePreviewResult[] }) {\n const styles = useStyles2(getStyles);\n // If there is only one template, we don't need to show the name\n const singleTemplate = previews.length === 1;\n\n const isValidJson = (text: string) => {\n try {\n JSON.parse(text);\n return true;\n } catch {\n return false;\n }\n };\n\n return (\n <ul className={styles.viewer.container} data-testid=\"template-preview\">\n {previews.map((preview) => {\n const language = isValidJson(preview.text) ? 'json' : 'plaintext';\n return (\n <li className={styles.viewer.box} key={preview.name}>\n {singleTemplate ? null : (\n <header className={styles.viewer.header}>\n {preview.name}\n <div className={styles.viewer.language}>{language}</div>\n </header>\n )}\n <CodeEditor\n containerStyles={styles.editorContainer}\n language={language}\n showLineNumbers={false}\n showMiniMap={false}\n value={preview.text}\n readOnly={true}\n monacoOptions={{\n scrollBeyondLastLine: false,\n }}\n />\n </li>\n );\n })}\n </ul>\n );\n}\n\nfunction PreviewErrorViewer({ errors }: { errors: TemplatePreviewErrors[] }) {\n return errors.map((error) => (\n <Alert key={uniqueId('errors-list')} title={compact([error.name, error.kind]).join(' – ')}>\n {error.message}\n </Alert>\n ));\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n container: css({\n label: 'template-preview-container',\n display: 'flex',\n flexDirection: 'column',\n borderRadius: theme.shape.radius.default,\n border: `1px solid ${theme.colors.border.medium}`,\n }),\n editorContainer: css({\n width: '100%',\n height: '100%',\n border: 'none',\n }),\n viewerContainer: ({ height }: { height: number }) =>\n css({\n height,\n overflow: 'auto',\n backgroundColor: theme.colors.background.primary,\n }),\n viewer: {\n container: css({\n display: 'flex',\n flexDirection: 'column',\n height: 'inherit',\n }),\n box: css({\n display: 'flex',\n flexDirection: 'column',\n borderBottom: `1px solid ${theme.colors.border.medium}`,\n height: 'inherit',\n }),\n header: css({\n display: 'flex',\n justifyContent: 'space-between',\n fontSize: theme.typography.bodySmall.fontSize,\n padding: theme.spacing(1, 2),\n borderBottom: `1px solid ${theme.colors.border.medium}`,\n backgroundColor: theme.colors.background.secondary,\n }),\n language: css({\n marginLeft: 'auto',\n fontStyle: 'italic',\n }),\n errorText: css({\n color: theme.colors.error.text,\n }),\n feedbackContainer: css({\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n borderTop: `1px solid ${theme.colors.border.medium}`,\n backgroundColor: theme.colors.background.secondary,\n minHeight: 'auto',\n }),\n emptyState: css({\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n height: '100%',\n color: theme.colors.text.secondary,\n fontSize: theme.typography.bodySmall.fontSize,\n }),\n },\n});\n\nexport function getPreviewResults(\n previewError: unknown | undefined,\n payloadFormatError: string | null,\n data: TemplatePreviewResponse | undefined\n): JSX.Element {\n // ERRORS IN JSON OR IN REQUEST (endpoint not available, for example)\n const previewErrorRequest = previewError ? stringifyErrorLike(previewError) : undefined;\n const errorToRender = payloadFormatError || previewErrorRequest;\n const styles = useStyles2(getStyles);\n\n //PREVIEW : RESULTS AND ERRORS\n const previewResponseResults = data?.results ?? [];\n const previewResponseErrors = data?.errors;\n const hasContent = previewResponseResults.length > 0 || previewResponseErrors || errorToRender;\n\n return (\n <>\n {errorToRender && (\n <Alert severity=\"error\" title={t('alerting.get-preview-results.title-error', 'Error')}>\n {errorToRender}\n </Alert>\n )}\n {previewResponseErrors && <PreviewErrorViewer errors={previewResponseErrors} />}\n {previewResponseResults.length > 0 && <PreviewResultViewer previews={previewResponseResults} />}\n {!hasContent && (\n <div className={styles.viewer.emptyState}>\n <Trans i18nKey=\"alerting.template-preview.empty-state\">Add template content to see preview</Trans>\n </div>\n )}\n </>\n );\n}\n","import { isEqual, uniqBy } from 'lodash';\n\nimport { DataFrameJSON } from '@grafana/data';\nimport { GrafanaAlertStateWithReason } from 'app/types/unified-alerting-dto';\n\nexport interface Line {\n previous: GrafanaAlertStateWithReason;\n current: GrafanaAlertStateWithReason;\n values?: Record<string, number>;\n labels?: Record<string, string>;\n fingerprint?: string;\n ruleUID?: string;\n error?: string;\n}\n\nexport interface LogRecord {\n timestamp: number;\n line: Line;\n}\n\nexport type Label = [string, string];\n\n// omit \"common\" labels from \"labels\"\nexport function omitLabels(labels: Label[], common: Label[]): Label[] {\n return labels.filter((label) => {\n return !common.find((commonLabel) => JSON.stringify(commonLabel) === JSON.stringify(label));\n });\n}\n\n// find all common labels by looking at which ones occur in every record, then create a unique array of items for those\nexport function extractCommonLabels(labels: Label[][]): Label[] {\n const flatLabels = labels.flatMap((label) => label);\n\n const commonLabels = uniqBy(\n flatLabels.filter((label) => {\n const count = flatLabels.filter((l) => isEqual(label, l)).length;\n return count === Object.keys(labels).length;\n }),\n (label) => JSON.stringify(label)\n );\n\n return commonLabels;\n}\n\nexport function historyDataFrameToLogRecords(stateHistory?: DataFrameJSON): LogRecord[] {\n if (!stateHistory?.data || !stateHistory.data.values || !Array.isArray(stateHistory.data.values)) {\n return [];\n }\n\n const [tsValues, lines] = stateHistory.data.values;\n\n if (!Array.isArray(tsValues) || !Array.isArray(lines) || tsValues.length !== lines.length) {\n return [];\n }\n\n const timestamps = isNumbers(tsValues) ? tsValues : [];\n\n // merge timestamp with \"line\"\n const logRecords = timestamps.reduce((acc: LogRecord[], timestamp: number, index: number) => {\n const line = lines[index];\n if (!isLine(line)) {\n return acc;\n }\n acc.push({ timestamp, line });\n return acc;\n }, []);\n\n return logRecords;\n}\n\nexport function isNumbers(value: unknown[]): value is number[] {\n return value.every((v) => typeof v === 'number');\n}\n\nexport function isLine(value: unknown): value is Line {\n return typeof value === 'object' && value !== null && 'current' in value && 'previous' in value;\n}\n","import { addDays } from \"./addDays.js\";\n\n/**\n * The {@link subDays} function options.\n */\n\n/**\n * @name subDays\n * @category Day Helpers\n * @summary Subtract the specified number of days from the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param amount - The amount of days to be subtracted.\n * @param options - An object with options\n *\n * @returns The new date with the days subtracted\n *\n * @example\n * // Subtract 10 days from 1 September 2014:\n * const result = subDays(new Date(2014, 8, 1), 10)\n * //=> Fri Aug 22 2014 00:00:00\n */\nexport function subDays(date, amount, options) {\n return addDays(date, -amount, options);\n}\n\n// Fallback for modularized imports:\nexport default subDays;\n","import { millisecondsInMinute } from \"./constants.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link addMinutes} function options.\n */\n\n/**\n * @name addMinutes\n * @category Minute Helpers\n * @summary Add the specified number of minutes to the given date.\n *\n * @description\n * Add the specified number of minutes to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param amount - The amount of minutes to be added.\n * @param options - An object with options\n *\n * @returns The new date with the minutes added\n *\n * @example\n * // Add 30 minutes to 10 July 2014 12:00:00:\n * const result = addMinutes(new Date(2014, 6, 10, 12, 0), 30)\n * //=> Thu Jul 10 2014 12:30:00\n */\nexport function addMinutes(date, amount, options) {\n const _date = toDate(date, options?.in);\n _date.setTime(_date.getTime() + amount * millisecondsInMinute);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default addMinutes;\n","import { addMilliseconds } from \"./addMilliseconds.js\";\nimport { millisecondsInHour } from \"./constants.js\";\n\n/**\n * The {@link addHours} function options.\n */\n\n/**\n * @name addHours\n * @category Hour Helpers\n * @summary Add the specified number of hours to the given date.\n *\n * @description\n * Add the specified number of hours to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param amount - The amount of hours to be added\n * @param options - An object with options\n *\n * @returns The new date with the hours added\n *\n * @example\n * // Add 2 hours to 10 July 2014 23:00:00:\n * const result = addHours(new Date(2014, 6, 10, 23, 0), 2)\n * //=> Fri Jul 11 2014 01:00:00\n */\nexport function addHours(date, amount, options) {\n return addMilliseconds(date, amount * millisecondsInHour, options);\n}\n\n// Fallback for modularized imports:\nexport default addHours;\n","import { addHours } from \"./addHours.js\";\n\n/**\n * The {@link subHours} function options.\n */\n\n/**\n * @name subHours\n * @category Hour Helpers\n * @summary Subtract the specified number of hours from the given date.\n *\n * @description\n * Subtract the specified number of hours from the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param amount - The amount of hours to be subtracted.\n * @param options - The options\n *\n * @returns The new date with the hours subtracted\n *\n * @example\n * // Subtract 2 hours from 11 July 2014 01:00:00:\n * const result = subHours(new Date(2014, 6, 11, 1, 0), 2)\n * //=> Thu Jul 10 2014 23:00:00\n */\nexport function subHours(date, amount, options) {\n return addHours(date, -amount, options);\n}\n\n// Fallback for modularized imports:\nexport default subHours;\n","import { ComponentType, createElement } from 'react';\n\nimport { t } from '@grafana/i18n';\nimport { withErrorBoundary } from '@grafana/ui';\n\nimport { logError } from '../../../Analytics';\n\nexport interface GenAITemplateButtonProps {\n onTemplateGenerated: (template: string) => void;\n disabled?: boolean;\n}\n\nlet InternalAITemplateButtonComponent: ComponentType<GenAITemplateButtonProps> | null = null;\n\n// this is the component that is used by the consumer in the grafana repo\nexport const AITemplateButtonComponent: ComponentType<GenAITemplateButtonProps> = (props) => {\n if (!InternalAITemplateButtonComponent) {\n return null;\n }\n\n // Wrap the component with error boundary\n const WrappedComponent = withErrorBoundary(InternalAITemplateButtonComponent, {\n title: t('alerting.ai.error-boundary.template-button', 'AI Template Button failed to load'),\n style: 'alertbox',\n errorLogger: logError,\n });\n\n return createElement(WrappedComponent, props);\n};\n\nexport function addAITemplateButton(component: ComponentType<GenAITemplateButtonProps> | null) {\n InternalAITemplateButtonComponent = component;\n}\n","import { css, cx } from '@emotion/css';\nimport { CSSProperties, useCallback, useMemo, useState } from 'react';\nimport AutoSizer from 'react-virtualized-auto-sizer';\nimport { FixedSizeList } from 'react-window';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport {\n Button,\n FilterInput,\n Icon,\n LoadingPlaceholder,\n Modal,\n Tag,\n Tooltip,\n clearButtonStyles,\n useStyles2,\n} from '@grafana/ui';\nimport { AlertmanagerAlert, TestTemplateAlert } from 'app/plugins/datasource/alertmanager/types';\n\nimport { alertmanagerApi } from '../../api/alertmanagerApi';\nimport { GRAFANA_RULES_SOURCE_NAME } from '../../utils/datasource';\nimport { arrayLabelsToObject, labelsToTags, objectLabelsToArray } from '../../utils/labels';\nimport { extractCommonLabels, omitLabels } from '../rules/state-history/common';\n\nexport function AlertInstanceModalSelector({\n onSelect,\n isOpen,\n onClose,\n}: {\n onSelect: (alerts: TestTemplateAlert[]) => void;\n isOpen: boolean;\n onClose: () => void;\n}) {\n const styles = useStyles2(getStyles);\n\n const [selectedRule, setSelectedRule] = useState<string>();\n const [selectedInstances, setSelectedInstances] = useState<AlertmanagerAlert[] | null>(null);\n const { useGetAlertmanagerAlertsQuery } = alertmanagerApi;\n\n const {\n currentData: result = [],\n isFetching: loading,\n isError: error,\n } = useGetAlertmanagerAlertsQuery({\n amSourceName: GRAFANA_RULES_SOURCE_NAME,\n filter: {\n inhibited: true,\n silenced: true,\n active: true,\n },\n });\n\n const [ruleFilter, setRuleFilter] = useState('');\n\n const rulesWithInstances: Record<string, AlertmanagerAlert[]> = useMemo(() => {\n const rules: Record<string, AlertmanagerAlert[]> = {};\n if (!loading && result) {\n result.forEach((instance) => {\n if (!rules[instance.labels.alertname]) {\n rules[instance.labels.alertname] = [];\n }\n const filteredAnnotations = Object.fromEntries(\n Object.entries(instance.annotations).filter(([key]) => !key.startsWith('__'))\n );\n const filteredLabels = Object.fromEntries(\n Object.entries(instance.labels).filter(([key]) => !key.startsWith('__'))\n );\n instance = { ...instance, annotations: filteredAnnotations, labels: filteredLabels };\n rules[instance.labels.alertname].push(instance);\n });\n }\n return rules;\n }, [loading, result]);\n\n const handleRuleChange = useCallback((rule: string) => {\n setSelectedRule(rule);\n setSelectedInstances(null);\n }, []);\n\n const filteredRules: Record<string, AlertmanagerAlert[]> = useMemo(() => {\n const filteredRules = Object.keys(rulesWithInstances).filter((rule) =>\n rule.toLowerCase().includes(ruleFilter.toLowerCase())\n );\n const filteredRulesObject: Record<string, AlertmanagerAlert[]> = {};\n filteredRules.forEach((rule) => {\n filteredRulesObject[rule] = rulesWithInstances[rule];\n });\n return filteredRulesObject;\n }, [rulesWithInstances, ruleFilter]);\n\n if (error) {\n return null;\n }\n\n const filteredRulesKeys = Object.keys(filteredRules || []);\n\n const RuleRow = ({ index, style }: { index: number; style?: CSSProperties }) => {\n if (!filteredRules) {\n return null;\n }\n const ruleName = filteredRulesKeys[index];\n\n const isSelected = ruleName === selectedRule;\n\n return (\n <button\n type=\"button\"\n title={ruleName}\n style={style}\n className={cx(styles.rowButton, { [styles.rowOdd]: index % 2 === 1, [styles.rowSelected]: isSelected })}\n onClick={() => handleRuleChange(ruleName)}\n >\n <div className={cx(styles.ruleTitle, styles.rowButtonTitle)}>{ruleName}</div>\n <div className={styles.alertFolder}>\n <Icon name=\"folder\" /> {filteredRules[ruleName][0].labels.grafana_folder ?? ''}\n </div>\n </button>\n );\n };\n\n const getAlertUniqueLabels = (allAlerts: AlertmanagerAlert[], currentAlert: AlertmanagerAlert) => {\n const allLabels = allAlerts.map((alert) => alert.labels);\n const labelsAsArray = allLabels.map(objectLabelsToArray);\n\n const ruleCommonLabels = extractCommonLabels(labelsAsArray);\n const alertUniqueLabels = omitLabels(objectLabelsToArray(currentAlert.labels), ruleCommonLabels);\n\n const tags = alertUniqueLabels.length\n ? labelsToTags(arrayLabelsToObject(alertUniqueLabels))\n : labelsToTags(currentAlert.labels);\n\n return tags;\n };\n\n const InstanceRow = ({ index, style }: { index: number; style: CSSProperties }) => {\n const alerts = useMemo(() => (selectedRule ? rulesWithInstances[selectedRule] : []), []);\n const alert = alerts[index];\n const isSelected = selectedInstances?.includes(alert);\n const tags = useMemo(() => getAlertUniqueLabels(alerts, alert), [alerts, alert]);\n\n const handleSelectInstances = () => {\n if (isSelected && selectedInstances) {\n setSelectedInstances(selectedInstances.filter((instance) => instance !== alert));\n return;\n }\n setSelectedInstances([...(selectedInstances || []), alert]);\n };\n\n return (\n <button\n type=\"button\"\n style={style}\n className={cx(styles.rowButton, styles.instanceButton, {\n [styles.rowOdd]: index % 2 === 1,\n [styles.rowSelected]: isSelected,\n })}\n onClick={handleSelectInstances}\n >\n <div className={styles.rowButtonTitle} title={alert.labels.alertname}>\n <Tooltip placement=\"bottom\" content={<pre>{JSON.stringify(alert, null, 2)}</pre>} theme={'info'}>\n <div>\n {tags.map((tag, index) => (\n <Tag key={index} name={tag} className={styles.tag} />\n ))}\n </div>\n </Tooltip>\n </div>\n </button>\n );\n };\n\n const handleConfirm = () => {\n const instances: TestTemplateAlert[] =\n selectedInstances?.map((instance: AlertmanagerAlert) => {\n const alert: TestTemplateAlert = {\n status: 'firing',\n annotations: instance.annotations,\n labels: instance.labels,\n startsAt: instance.startsAt,\n endsAt: instance.endsAt,\n generatorURL: instance.generatorURL,\n fingerprint: instance.fingerprint,\n };\n return alert;\n }) || [];\n\n onSelect(instances);\n resetState();\n };\n\n const resetState = () => {\n setSelectedRule(undefined);\n setSelectedInstances(null);\n setRuleFilter('');\n handleSearchRules('');\n };\n\n const onDismiss = () => {\n resetState();\n onClose();\n };\n\n const handleSearchRules = (filter: string) => {\n setRuleFilter(filter);\n };\n\n return (\n <div>\n <Modal\n title={t('alerting.alert-instance-modal-selector.title-select-alert-instances', 'Select alert instances')}\n className={styles.modal}\n closeOnEscape\n isOpen={isOpen}\n onDismiss={onDismiss}\n contentClassName={styles.modalContent}\n >\n <div className={styles.container}>\n <FilterInput\n value={ruleFilter}\n onChange={handleSearchRules}\n title={t('alerting.alert-instance-modal-selector.title-search-alert-rule', 'Search alert rule')}\n placeholder={t('alerting.alert-instance-modal-selector.placeholder-search-alert-rule', 'Search alert rule')}\n autoFocus\n />\n <div>{(selectedRule && 'Select one or more instances from the list below') || ''}</div>\n\n <div className={styles.column}>\n {loading && (\n <LoadingPlaceholder\n text={t('alerting.alert-instance-modal-selector.text-loading-rules', 'Loading rules...')}\n className={styles.loadingPlaceholder}\n />\n )}\n\n {!loading && (\n <AutoSizer>\n {({ height, width }) => (\n <FixedSizeList itemSize={50} height={height} width={width} itemCount={filteredRulesKeys.length}>\n {RuleRow}\n </FixedSizeList>\n )}\n </AutoSizer>\n )}\n </div>\n\n <div className={styles.column}>\n {!selectedRule && !loading && (\n <div className={styles.selectedRulePlaceholder}>\n <div>\n <Trans i18nKey=\"alerting.alert-instance-modal-selector.select-alert-rule\">\n Select an alert rule to get a list of available firing instances\n </Trans>\n </div>\n </div>\n )}\n {loading && (\n <LoadingPlaceholder\n text={t('alerting.alert-instance-modal-selector.text-loading-rule', 'Loading rule...')}\n className={styles.loadingPlaceholder}\n />\n )}\n\n {selectedRule && rulesWithInstances[selectedRule].length && !loading && (\n <AutoSizer>\n {({ width, height }) => (\n <FixedSizeList\n itemSize={32}\n height={height}\n width={width}\n itemCount={rulesWithInstances[selectedRule].length || 0}\n >\n {InstanceRow}\n </FixedSizeList>\n )}\n </AutoSizer>\n )}\n </div>\n </div>\n <Modal.ButtonRow>\n <Button type=\"button\" variant=\"secondary\" onClick={onDismiss}>\n <Trans i18nKey=\"alerting.common.cancel\">Cancel</Trans>\n </Button>\n <Button\n type=\"button\"\n variant=\"primary\"\n disabled={!(selectedRule && selectedInstances)}\n onClick={() => {\n if (selectedRule && selectedInstances) {\n handleConfirm();\n }\n }}\n >\n <Trans i18nKey=\"alerting.alert-instance-modal-selector.add-alert-data-to-payload\">\n Add alert data to payload\n </Trans>\n </Button>\n </Modal.ButtonRow>\n </Modal>\n </div>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => {\n const clearButton = clearButtonStyles(theme);\n\n return {\n container: css({\n display: 'grid',\n gridTemplateColumns: '1fr 1.5fr',\n gridTemplateRows: 'min-content auto',\n gap: theme.spacing(2),\n flex: 1,\n }),\n\n tag: css({\n margin: '5px',\n }),\n\n column: css({\n flex: '1 1 auto',\n }),\n\n alertLabels: css({\n overflowX: 'auto',\n height: '32px',\n }),\n ruleTitle: css({\n height: '22px',\n fontWeight: theme.typography.fontWeightBold,\n }),\n rowButton: css(clearButton, {\n padding: theme.spacing(0.5),\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n textAlign: 'left',\n whiteSpace: 'nowrap',\n cursor: 'pointer',\n border: '2px solid transparent',\n\n '&:disabled': {\n cursor: 'not-allowed',\n color: theme.colors.text.disabled,\n },\n }),\n rowButtonTitle: css({\n overflowX: 'auto',\n }),\n rowSelected: css({\n borderColor: theme.colors.primary.border,\n }),\n rowOdd: css({\n backgroundColor: theme.colors.background.secondary,\n }),\n instanceButton: css({\n display: 'flex',\n gap: theme.spacing(1),\n justifyContent: 'space-between',\n alignItems: 'center',\n }),\n loadingPlaceholder: css({\n height: '100%',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n }),\n selectedRulePlaceholder: css({\n width: '100%',\n height: '100%',\n display: 'flex',\n flexDirection: 'column',\n justifyContent: 'center',\n textAlign: 'center',\n fontWeight: theme.typography.fontWeightBold,\n }),\n modal: css({\n height: '100%',\n }),\n modalContent: css({\n flex: 1,\n display: 'flex',\n flexDirection: 'column',\n }),\n modalAlert: css({\n flexGrow: 0,\n }),\n warnIcon: css({\n fill: theme.colors.warning.main,\n }),\n labels: css({\n justifyContent: 'flex-start',\n }),\n alertFolder: css({\n height: '20px',\n fontSize: theme.typography.bodySmall.fontSize,\n color: theme.colors.text.secondary,\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'flex-start',\n columnGap: theme.spacing(1),\n alignItems: 'center',\n }),\n };\n};\n","export interface TemplateDataItem {\n name: string;\n type: string;\n notes: string;\n}\n\ninterface TemplateFunctionItem {\n name: string;\n args?: '[]string';\n returns: 'KeyValue' | '[]string';\n notes?: string;\n}\n\nexport const GlobalTemplateData: TemplateDataItem[] = [\n {\n name: 'Receiver',\n type: 'string',\n notes: 'Name of the contact point that the notification is being sent to.',\n },\n {\n name: 'Status',\n type: 'string',\n notes: 'firing if at least one alert is firing, otherwise resolved',\n },\n {\n name: 'Alerts',\n type: '[]Alert',\n notes: 'List of alert objects that are included in this notification.',\n },\n {\n name: 'Alerts.Firing',\n type: '[]Alert',\n notes: 'List of firing alerts',\n },\n {\n name: 'Alerts.Resolved',\n type: '[]Alert',\n notes: 'List of resolved alerts',\n },\n {\n name: 'GroupLabels',\n type: 'KeyValue',\n notes: 'Labels these alerts were grouped by.',\n },\n {\n name: 'CommonLabels',\n type: 'KeyValue',\n notes: 'Labels common to all the alerts included in this notification.',\n },\n {\n name: 'CommonAnnotations',\n type: 'KeyValue',\n notes: 'Annotations common to all the alerts included in this notification.',\n },\n {\n name: 'ExternalURL',\n type: 'string',\n notes: 'Back link to the Grafana that sent the notification.',\n },\n];\n\nexport const AlertTemplatePreviewData: TemplateDataItem[] = [\n {\n name: 'labels',\n type: 'Object{}',\n notes: 'Set of labels attached to the alert.',\n },\n {\n name: 'annotations',\n type: 'Object{}',\n notes: 'Set of annotations attached to the alert.',\n },\n {\n name: 'startsAt',\n type: 'string (ISO8601)',\n notes: 'Time the alert started firing.',\n },\n {\n name: 'endsAt',\n type: 'string (ISO8601)',\n notes: 'Time the alert ends firing.',\n },\n];\n\nexport const AlertTemplateData: TemplateDataItem[] = [\n {\n name: 'Status',\n type: 'string',\n notes: 'firing or resolved.',\n },\n {\n name: 'Labels',\n type: 'KeyValue',\n notes: 'Set of labels attached to the alert.',\n },\n {\n name: 'Annotations',\n type: 'KeyValue',\n notes: 'Set of annotations attached to the alert.',\n },\n {\n name: 'Values',\n type: 'KeyValue',\n notes:\n 'The values of all instant queries, reduce and math expressions, and classic conditions for the alert. It does not contain time series data.',\n },\n {\n name: 'StartsAt',\n type: 'time.Time',\n notes: 'Time the alert started firing.',\n },\n {\n name: 'EndsAt',\n type: 'time.Time',\n notes:\n 'Only set if the end time of an alert is known. Otherwise set to a configurable timeout period from the time since the last alert was received.',\n },\n {\n name: 'GeneratorURL',\n type: 'string',\n notes: 'A back link to Grafana or external Alertmanager.',\n },\n {\n name: 'SilenceURL',\n type: 'string',\n notes: 'Link to Grafana silence for with labels for this alert pre-filled. Only for Grafana managed alerts.',\n },\n {\n name: 'DashboardURL',\n type: 'string',\n notes: 'Link to Grafana dashboard, if alert rule belongs to one. Only for Grafana managed alerts.',\n },\n {\n name: 'PanelURL',\n type: 'string',\n notes: 'Link to Grafana dashboard panel, if alert rule belongs to one. Only for Grafana managed alerts.',\n },\n {\n name: 'Fingerprint',\n type: 'string',\n notes: 'Fingerprint that can be used to identify the alert.',\n },\n {\n name: 'ValueString',\n type: 'string',\n notes: 'String that contains the labels and value of each reduced expression in the alert.',\n },\n];\n\nexport const KeyValueTemplateFunctions: TemplateFunctionItem[] = [\n {\n name: 'SortedPairs',\n returns: 'KeyValue',\n notes: 'Returns sorted list of key & value string pairs',\n },\n {\n name: 'Remove',\n args: '[]string',\n returns: 'KeyValue',\n notes: 'Returns a copy of the Key/Value map without the given keys.',\n },\n {\n name: 'Names',\n returns: '[]string',\n notes: 'List of label names',\n },\n {\n name: 'Values',\n returns: '[]string',\n notes: 'List of label values',\n },\n];\n\nexport const KeyValueCodeSnippet = `{\n \"summary\": \"alert summary\",\n \"description\": \"alert description\"\n}\n`;\n","import { css } from '@emotion/css';\nimport * as React from 'react';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans } from '@grafana/i18n';\nimport { Stack, Text, useStyles2 } from '@grafana/ui';\n\nimport { PopupCard } from '../HoverCard';\n\nimport {\n AlertTemplateData,\n GlobalTemplateData,\n KeyValueCodeSnippet,\n KeyValueTemplateFunctions,\n TemplateDataItem,\n} from './TemplateData';\n\nexport function TemplateDataDocs() {\n const styles = useStyles2(getTemplateDataDocsStyles);\n\n const AlertTemplateDataTable = (\n <TemplateDataTable\n caption={\n <>\n <Text variant=\"h4\" element=\"h4\" color=\"primary\">\n <Trans i18nKey=\"alerting.template-data-docs.alert-template-data-table.alert-template-data\">\n Alert template data\n </Trans>\n </Text>\n <Text variant=\"bodySmall\">\n <Trans i18nKey=\"alerting.template-data-docs.alert-template-data-table.only-in-alert\">\n Available only when in the context of an Alert (e.g. inside .Alerts loop)\n </Trans>\n </Text>\n </>\n }\n dataItems={AlertTemplateData}\n />\n );\n\n return (\n <Stack gap={2}>\n <TemplateDataTable\n caption={\n <>\n <Text variant=\"h4\" element=\"h4\" color=\"primary\">\n <Trans i18nKey=\"alerting.template-data-docs.notification-template-data\">Notification template data</Trans>\n </Text>\n <Text variant=\"bodySmall\">\n <Trans i18nKey=\"alerting.template-data-docs.available-context-notification\">\n Available in the context of a notification.\n </Trans>\n </Text>\n </>\n }\n dataItems={GlobalTemplateData}\n typeRenderer={(type) => {\n if (type === '[]Alert') {\n return (\n <PopupCard content={AlertTemplateDataTable}>\n <div className={styles.interactiveType}>{type}</div>\n </PopupCard>\n );\n }\n if (type === 'KeyValue') {\n return (\n <PopupCard content={<KeyValueTemplateDataTable />}>\n <div className={styles.interactiveType}>{type}</div>\n </PopupCard>\n );\n }\n return type;\n }}\n />\n </Stack>\n );\n}\n\nconst getTemplateDataDocsStyles = (theme: GrafanaTheme2) => ({\n interactiveType: css({\n color: theme.colors.text.link,\n }),\n});\n\ninterface TemplateDataTableProps {\n dataItems: TemplateDataItem[];\n caption?: JSX.Element | string;\n typeRenderer?: (type: TemplateDataItem['type']) => React.ReactNode;\n}\n\nexport function TemplateDataTable({ dataItems, caption, typeRenderer }: TemplateDataTableProps) {\n const styles = useStyles2(getTemplateDataTableStyles);\n\n return (\n <table className={styles.table}>\n {caption && <caption>{caption}</caption>}\n <thead>\n <tr>\n <th>\n <Trans i18nKey=\"alerting.template-data-table.name\">Name</Trans>\n </th>\n <th>\n <Trans i18nKey=\"alerting.template-data-table.type\">Type</Trans>\n </th>\n <th>\n <Trans i18nKey=\"alerting.template-data-table.notes\">Notes</Trans>\n </th>\n </tr>\n </thead>\n <tbody>\n {dataItems.map(({ name, type, notes }, index) => (\n <tr key={index}>\n <td>{name}</td>\n <td>{typeRenderer ? typeRenderer(type) : type}</td>\n <td>{notes}</td>\n </tr>\n ))}\n </tbody>\n </table>\n );\n}\n\nfunction KeyValueTemplateDataTable() {\n const tableStyles = useStyles2(getTemplateDataTableStyles);\n\n return (\n <div>\n <Trans i18nKey=\"alerting.key-value-template-data-table.description\">\n KeyValue is a set of key/value string pairs that represent labels and annotations.\n </Trans>\n <pre>\n <code>{KeyValueCodeSnippet}</code>\n </pre>\n <table className={tableStyles.table}>\n <caption>\n <Trans i18nKey=\"alerting.key-value-template-data-table.keyvalue-methods\">Key-value methods</Trans>\n </caption>\n <thead>\n <tr>\n <th>\n <Trans i18nKey=\"alerting.key-value-template-data-table.name\">Name</Trans>\n </th>\n <th>\n <Trans i18nKey=\"alerting.key-value-template-data-table.arguments\">Arguments</Trans>\n </th>\n <th>\n <Trans i18nKey=\"alerting.key-value-template-data-table.returns\">Returns</Trans>\n </th>\n <th>\n <Trans i18nKey=\"alerting.key-value-template-data-table.notes\">Notes</Trans>\n </th>\n </tr>\n </thead>\n <tbody>\n {KeyValueTemplateFunctions.map(({ name, args, returns, notes }) => (\n <tr key={name}>\n <td>{name}</td>\n <td>{args}</td>\n <td>{returns}</td>\n <td>{notes}</td>\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n );\n}\n\nexport const getTemplateDataTableStyles = (theme: GrafanaTheme2) => ({\n table: css({\n borderCollapse: 'collapse',\n width: '100%',\n\n caption: {\n captionSide: 'top',\n },\n\n 'td, th': {\n padding: theme.spacing(1, 1),\n },\n\n thead: {\n fontWeight: theme.typography.fontWeightBold,\n },\n\n 'tbody tr:nth-child(2n + 1)': {\n backgroundColor: theme.colors.background.secondary,\n },\n\n 'tbody td:nth-child(1)': {\n fontWeight: theme.typography.fontWeightBold,\n },\n\n 'tbody td:nth-child(2)': {\n fontStyle: 'italic',\n },\n }),\n});\n","import { css } from '@emotion/css';\nimport { addDays, subDays } from 'date-fns';\nimport { uniqueId } from 'lodash';\nimport { useState } from 'react';\nimport { FormProvider, useForm } from 'react-hook-form';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Button, Card, Modal, RadioButtonGroup, Stack, useStyles2 } from '@grafana/ui';\nimport { TestTemplateAlert } from 'app/plugins/datasource/alertmanager/types';\n\nimport { KeyValueField } from '../../../api/templateApi';\nimport AnnotationsStep from '../../rule-editor/AnnotationsStep';\nimport LabelsField from '../../rule-editor/labels/LabelsField';\n\ninterface Props {\n isOpen: boolean;\n onDismiss: () => void;\n onAccept: (alerts: TestTemplateAlert[]) => void;\n}\n\ninterface FormFields {\n annotations: KeyValueField[];\n labels: KeyValueField[];\n status: 'firing' | 'resolved';\n}\n\nconst defaultValues: FormFields = {\n annotations: [{ key: '', value: '' }],\n labels: [{ key: '', value: '' }],\n status: 'firing',\n};\n\nexport const GenerateAlertDataModal = ({ isOpen, onDismiss, onAccept }: Props) => {\n const styles = useStyles2(getStyles);\n\n const [alerts, setAlerts] = useState<TestTemplateAlert[]>([]);\n\n const formMethods = useForm<FormFields>({ defaultValues, mode: 'onBlur' });\n const annotations = formMethods.watch('annotations');\n const labels = formMethods.watch('labels');\n const [status, setStatus] = useState<'firing' | 'resolved'>('firing');\n\n const onAdd = () => {\n const alert: TestTemplateAlert = {\n annotations: annotations\n .filter(({ key, value }) => !!key && !!value)\n .reduce((acc, { key, value }) => {\n return { ...acc, [key]: value };\n }, {}),\n labels: labels\n .filter(({ key, value }) => !!key && !!value)\n .reduce((acc, { key, value }) => {\n return { ...acc, [key]: value };\n }, {}),\n startsAt: '2023-04-01T00:00:00Z',\n endsAt: status === 'firing' ? addDays(new Date(), 1).toISOString() : subDays(new Date(), 1).toISOString(),\n status,\n fingerprint: uniqueId('fingerprint_'),\n };\n setAlerts((alerts) => [...alerts, alert]);\n formMethods.reset();\n };\n\n const onSubmit = () => {\n onAccept(alerts);\n setAlerts([]);\n formMethods.reset();\n setStatus('firing');\n };\n\n const labelsOrAnnotationsAdded = () => {\n const someLabels = labels.some((lb) => lb.key !== '' && lb.value !== '');\n const someAnnotations = annotations.some((ann) => ann.key !== '' && ann.value !== '');\n return someLabels || someAnnotations;\n };\n\n type AlertOption = {\n label: string;\n value: 'firing' | 'resolved';\n };\n const alertOptions: AlertOption[] = [\n {\n label: t('alerting.generate-alert-data-modal.alert-options.label.firing', 'Firing'),\n value: 'firing',\n },\n { label: t('alerting.generate-alert-data-modal.alert-options.label.resolved', 'Resolved'), value: 'resolved' },\n ];\n\n return (\n <Modal\n onDismiss={onDismiss}\n isOpen={isOpen}\n title={t('alerting.generate-alert-data-modal.title-add-custom-alerts', 'Add custom alerts')}\n >\n <FormProvider {...formMethods}>\n <form\n onSubmit={(e) => {\n e.preventDefault();\n e.stopPropagation();\n formMethods.reset();\n setStatus('firing');\n }}\n >\n <Card noMargin>\n <Stack direction=\"column\" gap={1}>\n <div className={styles.section}>\n <AnnotationsStep />\n </div>\n <div className={styles.section}>\n <LabelsField />\n </div>\n <div className={styles.flexWrapper}>\n <RadioButtonGroup value={status} options={alertOptions} onChange={(value) => setStatus(value)} />\n <Button\n onClick={onAdd}\n className={styles.onAddButton}\n icon=\"plus-circle\"\n type=\"button\"\n variant=\"secondary\"\n disabled={!labelsOrAnnotationsAdded()}\n >\n <Trans i18nKey=\"alerting.generate-alert-data-modal.add-alert-data\">Add alert data</Trans>\n </Button>\n </div>\n </Stack>\n </Card>\n <div className={styles.onSubmitWrapper} />\n {alerts.length > 0 && (\n <Stack direction=\"column\" gap={1}>\n <h5>\n <Trans i18nKey=\"alerting.generate-alert-data-modal.review-alert-payload\">\n {' '}\n Review alert data to add to the payload:\n </Trans>\n </h5>\n <pre className={styles.result} data-testid=\"payloadJSON\">\n {JSON.stringify(alerts, null, 2)}\n </pre>\n </Stack>\n )}\n <div className={styles.onSubmitWrapper}>\n <Modal.ButtonRow>\n <Button onClick={onSubmit} disabled={alerts.length === 0} className={styles.onSubmitButton}>\n <Trans i18nKey=\"alerting.generate-alert-data-modal.add-alert-data-to-payload\">\n Add alert data to payload\n </Trans>\n </Button>\n </Modal.ButtonRow>\n </div>\n </form>\n </FormProvider>\n </Modal>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n section: css({\n marginBottom: theme.spacing(2),\n }),\n onAddButton: css({\n flex: 'none',\n width: 'fit-content',\n paddingRight: theme.spacing(1),\n marginLeft: 'auto',\n }),\n flexWrapper: css({\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'space-between',\n }),\n onSubmitWrapper: css({\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'baseline',\n justifyContent: 'flex-end',\n }),\n onSubmitButton: css({\n marginLeft: theme.spacing(2),\n }),\n result: css({\n width: '570px',\n height: '363px',\n }),\n});\n","import { css, cx } from '@emotion/css';\nimport { useState } from 'react';\nimport * as React from 'react';\nimport AutoSizer from 'react-virtualized-auto-sizer';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Button, CodeEditor, Dropdown, Menu, Stack, Toggletip, useStyles2 } from '@grafana/ui';\nimport { TestTemplateAlert } from 'app/plugins/datasource/alertmanager/types';\n\nimport { EditorColumnHeader } from '../EditorColumnHeader';\n\nimport { AlertInstanceModalSelector } from './AlertInstanceModalSelector';\nimport { AlertTemplatePreviewData } from './TemplateData';\nimport { TemplateDataTable } from './TemplateDataDocs';\nimport { GenerateAlertDataModal } from './form/GenerateAlertDataModal';\n\nexport const RESET_TO_DEFAULT = 'Reset to defaults';\n\nexport function PayloadEditor({\n payload,\n setPayload,\n defaultPayload,\n setPayloadFormatError,\n payloadFormatError,\n className,\n}: {\n payload: string;\n defaultPayload: string;\n setPayload: React.Dispatch<React.SetStateAction<string>>;\n setPayloadFormatError: (value: React.SetStateAction<string | null>) => void;\n payloadFormatError: string | null;\n className?: string;\n}) {\n const styles = useStyles2(getStyles);\n const onReset = () => {\n setPayload(defaultPayload);\n };\n\n const [isEditingAlertData, setIsEditingAlertData] = useState(false);\n\n const onCloseEditAlertModal = () => {\n setIsEditingAlertData(false);\n };\n\n const errorInPayloadJson = payloadFormatError !== null;\n\n const validatePayload = () => {\n try {\n const payloadObj = JSON.parse(payload);\n JSON.stringify([...payloadObj]); // check if it's iterable, in order to be able to add more data\n setPayloadFormatError(null);\n } catch (e) {\n setPayloadFormatError(e instanceof Error ? e.message : 'Invalid JSON.');\n throw e;\n }\n };\n\n const onOpenEditAlertModal = () => {\n try {\n validatePayload();\n setIsEditingAlertData(true);\n } catch (e) {}\n };\n\n const onOpenAlertSelectorModal = () => {\n try {\n validatePayload();\n setIsAlertSelectorOpen(true);\n } catch (e) {}\n };\n\n const onAddAlertList = (alerts: TestTemplateAlert[]) => {\n onCloseEditAlertModal();\n setIsAlertSelectorOpen(false);\n setPayload((payload) => {\n const payloadObj = JSON.parse(payload);\n return JSON.stringify([...payloadObj, ...alerts], undefined, 2);\n });\n };\n\n const [isAlertSelectorOpen, setIsAlertSelectorOpen] = useState(false);\n\n return (\n <>\n <div className={cx(styles.wrapper, className)}>\n <EditorColumnHeader\n label={t('alerting.payload-editor.label-payload', 'Payload')}\n actions={\n <Stack direction=\"row\" alignItems=\"center\" gap={0.5}>\n <Dropdown\n overlay={\n <Menu>\n <Menu.Item\n label={t(\n 'alerting.payload-editor.label-use-existing-alert-instances',\n 'Use existing alert instances'\n )}\n disabled={errorInPayloadJson}\n onClick={onOpenAlertSelectorModal}\n />\n <Menu.Item\n label={t('alerting.payload-editor.label-add-custom-alert-instance', 'Add custom alert instance')}\n disabled={errorInPayloadJson}\n onClick={onOpenEditAlertModal}\n />\n <Menu.Divider />\n <Menu.Item label={RESET_TO_DEFAULT} onClick={onReset} destructive />\n </Menu>\n }\n >\n <Button variant=\"secondary\" size=\"sm\" icon=\"angle-down\">\n <Trans i18nKey=\"alerting.payload-editor.edit-payload\">Edit payload</Trans>\n </Button>\n </Dropdown>\n <Toggletip content={<AlertTemplateDataTable />} placement=\"top\" fitContent>\n <Button variant=\"secondary\" fill=\"outline\" size=\"sm\" icon=\"question-circle\">\n <Trans i18nKey=\"alerting.payload-editor.reference\">Reference</Trans>\n </Button>\n </Toggletip>\n </Stack>\n }\n />\n\n <div className={styles.editorWrapper}>\n <AutoSizer>\n {({ width, height }) => (\n <CodeEditor\n containerStyles={styles.editorContainer}\n width={width}\n height={height}\n language={'json'}\n showLineNumbers={true}\n showMiniMap={false}\n value={payload}\n readOnly={false}\n onBlur={setPayload}\n monacoOptions={{\n scrollBeyondLastLine: false,\n }}\n />\n )}\n </AutoSizer>\n </div>\n </div>\n\n <GenerateAlertDataModal isOpen={isEditingAlertData} onDismiss={onCloseEditAlertModal} onAccept={onAddAlertList} />\n\n <AlertInstanceModalSelector\n onSelect={onAddAlertList}\n isOpen={isAlertSelectorOpen}\n onClose={() => setIsAlertSelectorOpen(false)}\n />\n </>\n );\n}\nconst AlertTemplateDataTable = () => {\n return <TemplateDataTable dataItems={AlertTemplatePreviewData} />;\n};\nconst getStyles = (theme: GrafanaTheme2) => ({\n wrapper: css({\n display: 'flex',\n flexDirection: 'column',\n height: '100%',\n }),\n tooltip: css({\n paddingLeft: theme.spacing(1),\n }),\n label: css({\n margin: 0,\n }),\n editorWrapper: css({\n flex: 1,\n }),\n editorContainer: css({\n width: 'fit-content',\n border: 'none',\n }),\n templateDataDocsHeader: css({\n color: theme.colors.text.primary,\n\n span: {\n color: theme.colors.text.secondary,\n fontSize: theme.typography.bodySmall.fontSize,\n },\n }),\n});\n","export interface TemplateExampleItem {\n description: string;\n example: string;\n}\n\nexport const GlobalTemplateDataExamples: TemplateExampleItem[] = [\n {\n description: 'Default templates for notification titles',\n example: `{{- /* This is a copy of the \"default.title\" template. */ -}}\n{{- /* Edit the template name and template content as needed. */ -}}\n{{ define \"default.title.copy\" }}\n [{{ .Status | toUpper }}{{ if eq .Status \"firing\" }}:{{ .Alerts.Firing | len }}{{ if gt (.Alerts.Resolved | len) 0 }}, RESOLVED:{{ .Alerts.Resolved | len }}{{ end }}{{ end }}] {{ .GroupLabels.SortedPairs.Values | join \" \" }} {{ if gt (len .CommonLabels) (len .GroupLabels) }}({{ with .CommonLabels.Remove .GroupLabels.Names }}{{ .Values | join \" \" }}{{ end }}){{ end }}\n{{ end }}`,\n },\n {\n description: 'Default templates for notification messages',\n example: `{{- /* This is a copy of the \"default.message\" template. */ -}}\n{{- /* Edit the template name and template content as needed. */ -}}\n{{ define \"default.message.copy\" }}{{ if gt (len .Alerts.Firing) 0 }}**Firing**\n{{ template \"__text_alert_list.copy\" .Alerts.Firing }}{{ if gt (len .Alerts.Resolved) 0 }}\n\n{{ end }}{{ end }}{{ if gt (len .Alerts.Resolved) 0 }}**Resolved**\n{{ template \"__text_alert_list.copy\" .Alerts.Resolved }}{{ end }}{{ end }}\n\n{{ define \"__text_alert_list.copy\" }}{{ range . }}\nValue: {{ template \"__text_values_list.copy\" . }}\nLabels:\n{{ range .Labels.SortedPairs }} - {{ .Name }} = {{ .Value }}\n{{ end }}Annotations:\n{{ range .Annotations.SortedPairs }} - {{ .Name }} = {{ .Value }}\n{{ end }}{{ if gt (len .GeneratorURL) 0 }}Source: {{ .GeneratorURL }}\n{{ end }}{{ if gt (len .SilenceURL) 0 }}Silence: {{ .SilenceURL }}\n{{ end }}{{ if gt (len .DashboardURL) 0 }}Dashboard: {{ .DashboardURL }}\n{{ end }}{{ if gt (len .PanelURL) 0 }}Panel: {{ .PanelURL }}\n{{ end }}{{ end }}{{ end }}\n\n{{ define \"__text_values_list.copy\" }}{{ if len .Values }}{{ $first := true }}{{ range $refID, $value := .Values -}}\n{{ if $first }}{{ $first = false }}{{ else }}, {{ end }}{{ $refID }}={{ $value }}{{ end -}}\n{{ else }}[no value]{{ end }}{{ end }}`,\n },\n {\n description: 'Print alerts with summary and description',\n example: `{{- /* Example displaying the summary and description annotations of each alert in the notification. */ -}}\n{{- /* Edit the template name and template content as needed. */ -}}\n{{ define \"custom.alerts\" -}}\n{{ len .Alerts }} alert(s)\n{{ range .Alerts -}}\n {{ template \"alert.summary_and_description\" . -}}\n{{ end -}}\n{{ end -}}\n\n{{ define \"alert.summary_and_description\" }}\n Summary: {{.Annotations.summary}}\n Status: {{ .Status }}\n Description: {{.Annotations.description}}\n{{ end -}}`,\n },\n {\n description: 'Print firing and resolved alerts',\n example: `{{- /* Example displaying firing and resolved alerts separately in the notification. */ -}}\n{{- /* Edit the template name and template content as needed. */ -}}\n{{ define \"custom.firing_and_resolved_alerts\" -}}\n{{ len .Alerts.Resolved }} resolved alert(s)\n{{ range .Alerts.Resolved -}}\n {{ template \"alert.summary_and_description\" . -}}\n{{ end }}\n{{ len .Alerts.Firing }} firing alert(s)\n{{ range .Alerts.Firing -}}\n {{ template \"alert.summary_and_description\" . -}}\n{{ end -}}\n{{ end -}}\n\n{{ define \"alert.summary_and_description\" }}\n Summary: {{.Annotations.summary}}\n Status: {{ .Status }}\n Description: {{.Annotations.description}}\n{{ end -}}`,\n },\n {\n description: 'Print common labels and annotations',\n example: `{{- /* Example displaying labels and annotations that are common to all alerts in the notification.*/ -}}\n{{- /* Edit the template name and template content as needed. */ -}}\n{{ define \"custom.common_labels_and_annotations\" -}}\n{{ len .Alerts.Resolved }} resolved alert(s)\n{{ len .Alerts.Firing }} firing alert(s)\n\nCommon labels: {{ len .CommonLabels.SortedPairs }}\n{{ range .CommonLabels.SortedPairs -}}\n- {{ .Name }} = {{ .Value }}\n{{ end }}\n\nCommon annotations: {{ len .CommonAnnotations.SortedPairs }}\n{{ range .CommonAnnotations.SortedPairs }}\n- {{ .Name }} = {{ .Value }}\n{{ end }}\n\n{{ end -}}`,\n },\n {\n description: 'Print individual labels and annotations',\n example: `{{- /* Example displaying all labels and annotations for each alert in the notification.*/ -}}\n{{- /* Edit the template name and template content as needed. */ -}}\n{{ define \"custom.alert_labels_and_annotations\" -}}\n{{ len .Alerts.Resolved }} resolved alert(s)\n{{ range .Alerts.Resolved -}}\n {{ template \"alert.labels_and_annotations\" . -}}\n{{ end }}\n{{ len .Alerts.Firing }} firing alert(s)\n{{ range .Alerts.Firing -}}\n {{ template \"alert.labels_and_annotations\" . -}}\n{{ end -}}\n{{ end -}}\n\n{{ define \"alert.labels_and_annotations\" }}\nAlert labels: {{ len .Labels.SortedPairs }}\n{{ range .Labels.SortedPairs -}}\n- {{ .Name }} = {{ .Value }}\n{{ end -}}\nAlert annotations: {{ len .Annotations.SortedPairs }}\n{{ range .Annotations.SortedPairs -}}\n- {{ .Name }} = {{ .Value }}\n{{ end -}}\n{{ end -}}`,\n },\n {\n description: 'Print URLs for runbook and alert data in Grafana',\n example: `{{- /* Example displaying additional information, such as runbook link, DashboardURL and SilenceURL, for each alert in the notification.*/ -}}\n{{- /* Edit the template name and template content as needed. */ -}}\n{{ define \"custom.alert_additional_details\" -}}\n{{ len .Alerts.Resolved }} resolved alert(s)\n{{ range .Alerts.Resolved -}}\n {{ template \"alert.additional_details\" . -}}\n{{ end }}\n{{ len .Alerts.Firing }} firing alert(s)\n{{ range .Alerts.Firing -}}\n {{ template \"alert.additional_details\" . -}}\n{{ end -}}\n{{ end -}}\n\n{{ define \"alert.additional_details\" }}\n- Dashboard: {{ .DashboardURL }}\n- Panel: {{ .PanelURL }}\n- AlertGenerator: {{ .GeneratorURL }}\n- Silence: {{ .SilenceURL }}\n- RunbookURL: {{ .Annotations.runbook_url}}\n{{ end -}}`,\n },\n {\n description: 'Create JSON payload for webhook contact point',\n example: `{{- /* Example displaying a custom JSON payload for a webhook contact point.*/ -}}\n{{- /* Edit the template name and template content as needed. */ -}}\n{{- /* Variables defined in the webhook contact point can be accessed in .Vars but will not be previewable. */ -}}\n{{ define \"webhook.custom.payload\" -}}\n {{ coll.Dict\n \"receiver\" .Receiver\n \"status\" .Status\n \"alerts\" (tmpl.Exec \"webhook.custom.simple_alerts\" .Alerts | data.JSON)\n \"groupLabels\" .GroupLabels\n \"commonLabels\" .CommonLabels\n \"commonAnnotations\" .CommonAnnotations\n \"externalURL\" .ExternalURL\n \"version\" \"1\"\n \"orgId\" (index .Alerts 0).OrgID\n \"truncatedAlerts\" .TruncatedAlerts\n \"groupKey\" .GroupKey\n \"state\" (tmpl.Inline \"{{ if eq .Status \\\\\"resolved\\\\\" }}ok{{ else }}alerting{{ end }}\" . )\n \"allVariables\" .Vars\n \"title\" (tmpl.Exec \"default.title\" . )\n \"message\" (tmpl.Exec \"default.message\" . )\n | data.ToJSONPretty \" \"}}\n{{- end }}\n\n{{- /* Example showcasing embedding json templates in other json templates. */ -}}\n{{ define \"webhook.custom.simple_alerts\" -}}\n {{- $alerts := coll.Slice -}}\n {{- range . -}}\n {{ $alerts = coll.Append (coll.Dict\n \"status\" .Status\n \"labels\" .Labels\n \"startsAt\" .StartsAt\n \"endsAt\" .EndsAt\n ) $alerts}}\n {{- end -}}\n {{- $alerts | data.ToJSON -}}\n{{- end }}`,\n },\n];\n","import { css, cx } from '@emotion/css';\nimport { addMinutes, subDays, subHours } from 'date-fns';\nimport { Location } from 'history';\nimport { useRef, useState } from 'react';\nimport { FormProvider, useForm } from 'react-hook-form';\nimport { useToggle } from 'react-use';\nimport AutoSizer from 'react-virtualized-auto-sizer';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { isFetchError, locationService } from '@grafana/runtime';\nimport {\n Alert,\n Box,\n Button,\n Drawer,\n Dropdown,\n FieldSet,\n InlineField,\n Input,\n LinkButton,\n Menu,\n Stack,\n Text,\n useSplitter,\n useStyles2,\n} from '@grafana/ui';\nimport { useAppNotification } from 'app/core/copy/appNotification';\nimport { ActiveTab as ContactPointsActiveTabs } from 'app/features/alerting/unified/components/contact-points/ContactPoints';\nimport { TestTemplateAlert } from 'app/plugins/datasource/alertmanager/types';\n\nimport { AITemplateButtonComponent } from '../../enterprise-components/AI/AIGenTemplateButton/addAITemplateButton';\nimport { GRAFANA_RULES_SOURCE_NAME } from '../../utils/datasource';\nimport { makeAMLink, stringifyErrorLike } from '../../utils/misc';\nimport { EditorColumnHeader } from '../EditorColumnHeader';\nimport { ProvisionedResource, ProvisioningAlert } from '../Provisioning';\nimport { Spacer } from '../Spacer';\nimport {\n NotificationTemplate,\n useCreateNotificationTemplate,\n useNotificationTemplateMetadata,\n useUpdateNotificationTemplate,\n useValidateNotificationTemplate,\n} from '../contact-points/useNotificationTemplates';\n\nimport { PayloadEditor } from './PayloadEditor';\nimport { TemplateDataDocs } from './TemplateDataDocs';\nimport { GlobalTemplateDataExamples } from './TemplateDataExamples';\nimport { TemplateEditor } from './TemplateEditor';\nimport { TemplatePreview } from './TemplatePreview';\nimport { snippets } from './editor/templateDataSuggestions';\n\nexport interface TemplateFormValues {\n title: string;\n content: string;\n}\n\nexport const defaults: TemplateFormValues = Object.freeze({\n title: '',\n content: '',\n});\n\ninterface Props {\n originalTemplate?: NotificationTemplate;\n prefill?: TemplateFormValues;\n alertmanager: string;\n}\n\nexport const isDuplicating = (location: Location) => location.pathname.endsWith('/duplicate');\n\n/**\n * We're going for this type of layout, but with the ability to resize the columns.\n * To achieve this, we're using the useSplitter hook from Grafana UI twice.\n * The first hook is for the vertical splitter between the template editor and the payload editor.\n * The second hook is for the horizontal splitter between the template editor and the preview.\n * If we're using a vanilla Alertmanager source, we don't show the payload editor nor the preview but we still use the splitter at 100/0.\n *\n * ┌───────────────────┐┌───────────┐\n * │ Template ││ Preview │\n * │ ││ │\n * │ ││ │\n * │ ││ │\n * └───────────────────┘│ │\n * ┌───────────────────┐│ │\n * │ Payload ││ │\n * │ ││ │\n * │ ││ │\n * │ ││ │\n * └───────────────────┘└───────────┘\n */\nexport const TemplateForm = ({ originalTemplate, prefill, alertmanager }: Props) => {\n const styles = useStyles2(getStyles);\n\n const appNotification = useAppNotification();\n\n const [createNewTemplate, { error: createTemplateError }] = useCreateNotificationTemplate({ alertmanager });\n const [updateTemplate, { error: updateTemplateError }] = useUpdateNotificationTemplate({ alertmanager });\n const { titleIsUnique } = useValidateNotificationTemplate({ alertmanager, originalTemplate });\n\n const formRef = useRef<HTMLFormElement>(null);\n const isGrafanaAlertManager = alertmanager === GRAFANA_RULES_SOURCE_NAME;\n\n const error = updateTemplateError ?? createTemplateError;\n\n const [cheatsheetOpened, toggleCheatsheetOpened] = useToggle(false);\n\n const [payload, setPayload] = useState(defaultPayloadString);\n const [payloadFormatError, setPayloadFormatError] = useState<string | null>(null);\n\n // AI feedback state\n const [aiGeneratedTemplate, setAiGeneratedTemplate] = useState(false);\n\n const { isProvisioned } = useNotificationTemplateMetadata(originalTemplate);\n const originalTemplatePrefill: TemplateFormValues | undefined = originalTemplate\n ? { title: originalTemplate.title, content: originalTemplate.content }\n : undefined;\n\n // splitter for template and payload editor\n const columnSplitter = useSplitter({\n direction: 'column',\n // if Grafana Alertmanager, split 50/50, otherwise 100/0 because there is no payload editor\n initialSize: isGrafanaAlertManager ? 0.5 : 1,\n dragPosition: 'middle',\n });\n\n // splitter for template editor and preview\n const rowSplitter = useSplitter({\n direction: 'row',\n // if Grafana Alertmanager, split 60/40, otherwise 100/0 because there is no preview\n initialSize: isGrafanaAlertManager ? 0.6 : 1,\n dragPosition: 'middle',\n });\n\n const formApi = useForm<TemplateFormValues>({\n mode: 'onSubmit',\n defaultValues: prefill ?? originalTemplatePrefill ?? defaults,\n });\n const {\n handleSubmit,\n register,\n formState: { errors, isSubmitting },\n getValues,\n setValue,\n watch,\n } = formApi;\n\n const submit = async (values: TemplateFormValues) => {\n const returnLink = makeAMLink('/alerting/notifications', alertmanager, {\n tab: ContactPointsActiveTabs.NotificationTemplates,\n });\n\n try {\n if (!originalTemplate) {\n await createNewTemplate.execute({ templateValues: values });\n } else {\n await updateTemplate.execute({ template: originalTemplate, patch: values });\n }\n appNotification.success('Template saved', `Template ${values.title} has been saved`);\n locationService.push(returnLink);\n } catch (error) {\n appNotification.error('Error saving template', stringifyErrorLike(error));\n }\n };\n\n const appendExample = (example: string) => {\n const content = getValues('content'),\n newValue = !content ? example : `${content}\\n${example}`;\n setValue('content', newValue);\n };\n\n const handleTemplateGenerated = (template: string) => {\n setValue('content', template);\n setAiGeneratedTemplate(true);\n };\n\n return (\n <>\n <FormProvider {...formApi}>\n <form\n onSubmit={handleSubmit(submit)}\n ref={formRef}\n className={styles.form}\n aria-label={t('alerting.template-form.aria-label-template-form', 'Template form')}\n >\n {/* error message */}\n {error && (\n <Alert\n severity=\"error\"\n title={t('alerting.template-form.title-error-saving-template', 'Error saving template')}\n >\n {error.message || (isFetchError(error) && error.data?.message) || String(error)}\n </Alert>\n )}\n {/* warning about provisioned template */}\n {isProvisioned && (\n <Box grow={0}>\n <ProvisioningAlert resource={ProvisionedResource.Template} />\n </Box>\n )}\n\n {/* name field for the template */}\n <FieldSet disabled={isProvisioned} className={styles.fieldset}>\n <Stack direction=\"column\" gap={1} alignItems=\"stretch\" minHeight=\"100%\">\n {/* name and save buttons */}\n <Stack direction=\"row\" alignItems=\"center\">\n <InlineField\n label={t('alerting.template-form.label-template-group-name', 'Template group name')}\n error={errors?.title?.message}\n invalid={!!errors.title?.message}\n required\n >\n <Input\n {...register('title', {\n required: { value: true, message: t('alerting.template-form.message.required', 'Required.') },\n validate: { titleIsUnique },\n })}\n placeholder={t(\n 'alerting.template-form.new-template-name-placeholder-give-your-template-group-a-name',\n 'Give your template group a name'\n )}\n width={42}\n autoFocus={true}\n id=\"new-template-name\"\n />\n </InlineField>\n <Spacer />\n <Stack>\n <Button onClick={() => formRef.current?.requestSubmit()} variant=\"primary\" disabled={isSubmitting}>\n <Trans i18nKey=\"common.save\">Save</Trans>\n </Button>\n <LinkButton\n disabled={isSubmitting}\n href={makeAMLink('alerting/notifications', alertmanager, {\n tab: ContactPointsActiveTabs.NotificationTemplates,\n })}\n variant=\"secondary\"\n >\n <Trans i18nKey=\"common.cancel\">Cancel</Trans>\n </LinkButton>\n </Stack>\n </Stack>\n\n {/* editor layout */}\n <div {...rowSplitter.containerProps} className={styles.contentContainer}>\n <div {...rowSplitter.primaryProps}>\n {/* template content and payload editor column – full height and half-width */}\n <div {...columnSplitter.containerProps} className={styles.contentField}>\n {/* template editor */}\n <div {...columnSplitter.primaryProps}>\n {/* primaryProps will set \"minHeight: min-content;\" so we have to make sure to apply minHeight to the child */}\n <div className={cx(styles.flexColumn, styles.containerWithBorderAndRadius, styles.minEditorSize)}>\n <div>\n <EditorColumnHeader\n label={t('alerting.template-form.label-template-group', 'Template group')}\n actions={\n <>\n {/* examples dropdown – only available for Grafana Alertmanager */}\n {isGrafanaAlertManager && (\n <Dropdown\n overlay={\n <Menu>\n {GlobalTemplateDataExamples.map((item, index) => (\n <Menu.Item\n key={index}\n label={item.description}\n onClick={() => appendExample(item.example)}\n />\n ))}\n <Menu.Divider />\n <Menu.Item\n label={t(\n 'alerting.template-form.label-examples-documentation',\n 'Examples documentation'\n )}\n url=\"https://grafana.com/docs/grafana/latest/alerting/configure-notifications/template-notifications/examples/\"\n target=\"_blank\"\n icon=\"external-link-alt\"\n />\n </Menu>\n }\n >\n <Button variant=\"secondary\" size=\"sm\" icon=\"angle-down\">\n <Trans i18nKey=\"alerting.templates.editor.add-example\">Add example</Trans>\n </Button>\n </Dropdown>\n )}\n {/* GenAI button – only available for Grafana Alertmanager and enterprise */}\n {isGrafanaAlertManager && (\n <AITemplateButtonComponent\n onTemplateGenerated={handleTemplateGenerated}\n disabled={isProvisioned}\n />\n )}\n <Button\n icon=\"question-circle\"\n size=\"sm\"\n fill=\"outline\"\n variant=\"secondary\"\n onClick={toggleCheatsheetOpened}\n >\n <Trans i18nKey=\"common.help\">Help</Trans>\n </Button>\n </>\n }\n />\n </div>\n <Box flex={1}>\n <AutoSizer>\n {({ width, height }) => (\n <TemplateEditor\n value={getValues('content')}\n onBlur={(value) => setValue('content', value)}\n containerStyles={styles.editorContainer}\n width={width}\n height={height}\n />\n )}\n </AutoSizer>\n </Box>\n </div>\n </div>\n {/* payload editor – only available for Grafana Alertmanager */}\n {isGrafanaAlertManager && (\n <>\n <div {...columnSplitter.splitterProps} />\n <div {...columnSplitter.secondaryProps}>\n <div\n className={cx(\n styles.containerWithBorderAndRadius,\n styles.minEditorSize,\n styles.payloadEditor,\n styles.flexFull\n )}\n >\n <PayloadEditor\n payload={payload}\n defaultPayload={defaultPayloadString}\n setPayload={setPayload}\n setPayloadFormatError={setPayloadFormatError}\n payloadFormatError={payloadFormatError}\n />\n </div>\n </div>\n </>\n )}\n </div>\n </div>\n {/* preview column – full height and half-width */}\n {isGrafanaAlertManager && (\n <div {...rowSplitter.secondaryProps}>\n <div {...rowSplitter.splitterProps} />\n <TemplatePreview\n payload={payload}\n templateName={watch('title')}\n templateContent={watch('content')}\n setPayloadFormatError={setPayloadFormatError}\n payloadFormatError={payloadFormatError}\n className={cx(styles.templatePreview, styles.minEditorSize)}\n aiGeneratedTemplate={aiGeneratedTemplate}\n setAiGeneratedTemplate={setAiGeneratedTemplate}\n />\n </div>\n )}\n </div>\n </Stack>\n </FieldSet>\n </form>\n </FormProvider>\n {cheatsheetOpened && (\n <Drawer\n title={t('alerting.template-form.title-templating-cheat-sheet', 'Templating cheat sheet')}\n onClose={toggleCheatsheetOpened}\n size=\"lg\"\n >\n <TemplatingCheatSheet />\n </Drawer>\n )}\n </>\n );\n};\n\nfunction TemplatingBasics() {\n const styles = useStyles2(getStyles);\n\n const intro = t(\n 'alerting.templates.help.intro',\n `Notification templates use Go templating language to create notification messages.\n\nIn Grafana, a template group can define multiple notification templates using {{ define \"<NAME>\" }}.\nThese templates can then be used in contact points and within other notification templates by calling {{ template \"<NAME>\" }}.\nFor detailed information about notification templates, refer to our documentation.`\n );\n\n return (\n <Alert title=\"\" severity=\"info\">\n <Stack direction=\"column\" gap={2}>\n <Stack direction=\"row\">\n <div style={{ whiteSpace: 'pre' }}>{intro}</div>\n <div>\n <LinkButton\n href=\"https://grafana.com/docs/grafana/latest/alerting/manage-notifications/template-notifications/\"\n target=\"_blank\"\n icon=\"external-link-alt\"\n variant=\"secondary\"\n >\n <Trans i18nKey=\"alerting.templates.editor.goto-docs\">Notification templates documentation</Trans>\n </LinkButton>\n </div>\n </Stack>\n\n <Text variant=\"bodySmall\">\n <Trans i18nKey=\"alerting.templates.editor.auto-complete\">\n For auto-completion of common templating code, type the following keywords in the content editor:\n </Trans>\n <div className={styles.code}>\n {Object.values(snippets)\n .map((s) => s.label)\n .join(', ')}\n </div>\n </Text>\n </Stack>\n </Alert>\n );\n}\n\nfunction TemplatingCheatSheet() {\n return (\n <Stack direction=\"column\" gap={1}>\n <TemplatingBasics />\n <TemplateDataDocs />\n </Stack>\n );\n}\n\nexport const getStyles = (theme: GrafanaTheme2) => {\n const narrowScreenQuery = theme.breakpoints.down('md');\n\n return {\n flexFull: css({\n flex: 1,\n }),\n minEditorSize: css({\n minHeight: 300,\n minWidth: 300,\n }),\n payloadEditor: css({\n minHeight: 0,\n }),\n containerWithBorderAndRadius: css({\n borderRadius: theme.shape.radius.default,\n border: `1px solid ${theme.colors.border.medium}`,\n }),\n flexColumn: css({\n display: 'flex',\n flex: 1,\n flexDirection: 'column',\n }),\n form: css({\n label: 'template-form',\n height: '100%',\n display: 'flex',\n flexDirection: 'column',\n }),\n fieldset: css({\n label: 'template-fieldset',\n flex: 1,\n display: 'flex',\n flexDirection: 'column',\n }),\n label: css({\n margin: 0,\n }),\n contentContainer: css({\n flex: 1,\n display: 'flex',\n flexDirection: 'row',\n }),\n contentField: css({\n display: 'flex',\n flexDirection: 'column',\n flex: 1,\n marginBottom: 0,\n }),\n templatePreview: css({\n flex: 1,\n display: 'flex',\n }),\n templatePayload: css({\n flex: 1,\n }),\n editorContainer: css({\n width: 'fit-content',\n border: 'none',\n }),\n payloadCollapseButton: css({\n backgroundColor: theme.colors.info.transparent,\n margin: 0,\n [narrowScreenQuery]: {\n display: 'none',\n },\n }),\n code: css({\n color: theme.colors.text.secondary,\n fontWeight: theme.typography.fontWeightBold,\n }),\n };\n};\n\nconst defaultPayload: TestTemplateAlert[] = [\n {\n status: 'firing',\n annotations: {\n summary: 'Instance instance1 has been down for more than 5 minutes',\n description:\n 'The instance instance1 has been unreachable for more than 5 minutes, indicating a potential service outage.',\n },\n labels: {\n alertname: 'InstanceDown',\n instance: 'instance1',\n severity: 'critical',\n service: 'service1',\n environment: 'production',\n },\n startsAt: subDays(new Date(), 1).toISOString(),\n endsAt: addMinutes(new Date(), 5).toISOString(),\n fingerprint: 'a5331f0d5a9d81d4',\n generatorURL: 'http://grafana.com/alerting/grafana/cdeqmlhvflz40f/view',\n },\n {\n status: 'resolved',\n annotations: {\n summary: 'CPU usage above 90%',\n description:\n 'The CPU usage on instance1 has exceeded 90% for an extended period, which may indicate performance issues or resource constraints.',\n },\n labels: {\n alertname: 'CpuUsage',\n instance: 'instance1',\n severity: 'warning',\n service: 'service1',\n environment: 'dev',\n },\n startsAt: subHours(new Date(), 4).toISOString(),\n endsAt: new Date().toISOString(),\n fingerprint: 'b77d941310f9d381',\n generatorURL: 'http://grafana.com/alerting/grafana/oZSMdGj7z/view',\n },\n];\n\nexport const defaultPayloadString = JSON.stringify(defaultPayload, null, 2);\n"],"names":["EditorColumnHeader","label","actions","id","children","styles","editorColumnStyles","theme","InternalAIFeedbackButtonComponent","AIFeedbackButtonComponent","props","WrappedComponent","propsWithDefaults","addAIFeedbackButton","component","usePreviewTemplate","templateContent","templateName","payload","setPayloadFormatError","trigger","data","error","isLoading","onPreview","alertList","e","TemplatePreview","payloadFormatError","className","aiGeneratedTemplate","setAiGeneratedTemplate","getStyles","previewError","previewToRender","getPreviewResults","Button","Box","height","PreviewResultViewer","previews","singleTemplate","isValidJson","text","preview","language","CodeEditor","PreviewErrorViewer","errors","Alert","previewErrorRequest","errorToRender","previewResponseResults","previewResponseErrors","hasContent","omitLabels","labels","common","commonLabel","extractCommonLabels","flatLabels","l","historyDataFrameToLogRecords","stateHistory","tsValues","lines","isNumbers","acc","timestamp","index","line","isLine","value","v","subDays","date","amount","options","addDays","addMinutes","_date","toDate","addHours","addMilliseconds","subHours","InternalAITemplateButtonComponent","AITemplateButtonComponent","addAITemplateButton","AlertInstanceModalSelector","onSelect","isOpen","onClose","selectedRule","setSelectedRule","selectedInstances","setSelectedInstances","useGetAlertmanagerAlertsQuery","alertmanagerApi","result","loading","ruleFilter","setRuleFilter","rulesWithInstances","rules","instance","filteredAnnotations","key","filteredLabels","handleRuleChange","rule","filteredRules","filteredRulesObject","filteredRulesKeys","RuleRow","style","ruleName","isSelected","Icon","getAlertUniqueLabels","allAlerts","currentAlert","labelsAsArray","alert","ruleCommonLabels","alertUniqueLabels","InstanceRow","alerts","tags","handleSelectInstances","Tooltip","tag","Tag","handleConfirm","instances","resetState","handleSearchRules","onDismiss","filter","Modal","FilterInput","LoadingPlaceholder","width","clearButton","GlobalTemplateData","AlertTemplatePreviewData","AlertTemplateData","KeyValueTemplateFunctions","KeyValueCodeSnippet","TemplateDataDocs","getTemplateDataDocsStyles","AlertTemplateDataTable","TemplateDataTable","Text","Stack","type","KeyValueTemplateDataTable","dataItems","caption","typeRenderer","getTemplateDataTableStyles","name","notes","tableStyles","args","returns","defaultValues","GenerateAlertDataModal","onAccept","setAlerts","formMethods","annotations","status","setStatus","onAdd","onSubmit","labelsOrAnnotationsAdded","someLabels","lb","someAnnotations","ann","alertOptions","Card","AnnotationsStep","LabelsField","RadioButtonGroup","RESET_TO_DEFAULT","PayloadEditor","setPayload","defaultPayload","onReset","isEditingAlertData","setIsEditingAlertData","onCloseEditAlertModal","errorInPayloadJson","validatePayload","payloadObj","onOpenEditAlertModal","onOpenAlertSelectorModal","setIsAlertSelectorOpen","onAddAlertList","isAlertSelectorOpen","Dropdown","Menu","Toggletip","GlobalTemplateDataExamples","defaults","isDuplicating","location","TemplateForm","originalTemplate","prefill","alertmanager","appNotification","createNewTemplate","createTemplateError","updateTemplate","updateTemplateError","titleIsUnique","formRef","isGrafanaAlertManager","cheatsheetOpened","toggleCheatsheetOpened","useToggle","defaultPayloadString","isProvisioned","originalTemplatePrefill","columnSplitter","useSplitter","rowSplitter","formApi","handleSubmit","register","isSubmitting","getValues","setValue","watch","submit","values","returnLink","ContactPoints","appendExample","example","content","newValue","handleTemplateGenerated","template","Provisioning","FieldSet","InlineField","Input","Spacer","item","TemplateEditor","Drawer","TemplatingCheatSheet","TemplatingBasics","intro","s","narrowScreenQuery"],"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