/usr/share/grafana/public/build
{"version":3,"file":"AlertingRuleForm.2e69d3f00eb6221e7355.js","mappings":"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","sources":["webpack://grafana/./public/app/features/alerting/unified/utils/duplicate.ts","webpack://grafana/./public/app/features/alerting/unified/enterprise-components/AI/AIGenImproveLabelsButton/addAIImproveLabelsButton.ts","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/labels/LabelsFieldInForm.tsx","webpack://grafana/./public/app/features/alerting/unified/AlertWarning.tsx","webpack://grafana/./public/app/features/alerting/unified/api/alertRuleModel.ts","webpack://grafana/./public/app/features/alerting/unified/components/export/GrafanaRuleExporter.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/GroupAndNamespaceFields.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/CloudEvaluationBehavior.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/RecordingRulesNameSpaceAndGroupStep.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/AlertRuleForm.tsx","webpack://grafana/./public/app/features/alerting/unified/rule-editor/clone.utils.ts","webpack://grafana/./public/app/features/alerting/unified/rule-editor/ExistingRuleEditor.tsx","webpack://grafana/./public/app/features/alerting/unified/rule-editor/RuleEditor.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/labels/LabelsEditorModal.tsx","webpack://grafana/./public/app/features/alerting/unified/components/export/GrafanaModifyExport.tsx","webpack://grafana/./public/app/features/alerting/unified/components/create-folder/CreateNewFolder.tsx","webpack://grafana/./public/app/features/alerting/unified/types/preview.ts","webpack://grafana/./public/app/features/alerting/unified/api/preview.ts","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/PreviewRuleResult.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/PreviewRule.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/preview.ts","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/CloudAlertPreview.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/ExpressionEditor.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/ExpressionsEditor.tsx","webpack://grafana/./public/app/features/alerting/unified/components/extensions/ConfirmationNavigationModal.tsx","webpack://grafana/./public/app/features/alerting/unified/components/extensions/AlertingRuleExtensionPointMenu.tsx","webpack://grafana/./public/app/features/alerting/unified/components/extensions/QuerylessAppExtensions.tsx","webpack://grafana/./public/app/features/alerting/unified/components/extensions/AlertingRuleQueryExtensionPoint.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/QueryOptions.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/QueryWrapper.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/QueryRows.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/QueryEditor.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/RecordingRuleEditor.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/query-and-alert-condition/CloudDataSourceSelector.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/query-and-alert-condition/reducer.ts","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/query-and-alert-condition/SimpleCondition.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/query-and-alert-condition/utils.ts","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/query-and-alert-condition/SmartAlertTypeDetector.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/query-and-alert-condition/descriptions.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/query-and-alert-condition/useAdvancedMode.ts","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/query-and-alert-condition/QueryAndExpressionsStep.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/ModifyExportRuleForm.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/FolderSelector.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/GrafanaFolderAndLabelsStep.tsx","webpack://grafana/./public/app/features/alerting/unified/hooks/useRuleSourcesWithRuler.ts","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/CloudRulesSourcePicker.tsx","webpack://grafana/./public/app/features/alerting/unified/components/export/ExportNewGrafanaRule.tsx","webpack://grafana/./public/app/features/alerting/unified/utils/accessControlHooks.ts","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/simplifiedRouting/contactPoint/ContactPointSelector.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/simplifiedRouting/route-settings/ActiveTimingFields.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/simplifiedRouting/route-settings/MuteTimingFields.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/simplifiedRouting/route-settings/RouteTimings.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/simplifiedRouting/route-settings/RouteSettings.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/simplifiedRouting/AlertManagerRouting.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/alert-rule-form/simplifiedRouting/SimplifiedRouting.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/notificaton-preview/NotificationPreview.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/NotificationsStep.tsx","webpack://grafana/./public/app/features/alerting/unified/components/rule-editor/AlertRuleNameInput.tsx"],"sourcesContent":["export function generateCopiedName(originalName: string, exisitingNames: string[]) {\n const nonDuplicateName = originalName.replace(/\\(copy( [0-9]+)?\\)$/, '').trim();\n\n let newName = `${nonDuplicateName} (copy)`;\n\n for (let i = 2; exisitingNames.includes(newName); i++) {\n newName = `${nonDuplicateName} (copy ${i})`;\n }\n\n return newName;\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 interface GenAIImproveLabelsButtonProps {}\n\n// Internal variable to store the actual component\nlet InternalAIImproveLabelsButtonComponent: ComponentType<GenAIImproveLabelsButtonProps> | null = null;\n\nexport const AIImproveLabelsButtonComponent: ComponentType<GenAIImproveLabelsButtonProps> = (props) => {\n if (!InternalAIImproveLabelsButtonComponent) {\n return null;\n }\n\n // Wrap the component with error boundary\n const WrappedComponent = withErrorBoundary(InternalAIImproveLabelsButtonComponent, {\n title: t('alerting.ai.error-boundary.improve-labels-button', 'AI Improve Labels Button failed to load'),\n style: 'alertbox',\n errorLogger: logError,\n });\n\n return createElement(WrappedComponent, props);\n};\n\nexport function addAIImproveLabelsButton(component: ComponentType<GenAIImproveLabelsButtonProps> | null) {\n InternalAIImproveLabelsButtonComponent = component;\n}\n","import { useFormContext } from 'react-hook-form';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { Button, Stack, Text } from '@grafana/ui';\n\nimport { AIImproveLabelsButtonComponent } from '../../../enterprise-components/AI/AIGenImproveLabelsButton/addAIImproveLabelsButton';\nimport { RuleFormValues } from '../../../types/rule-form';\nimport { isGrafanaManagedRuleByType, isRecordingRuleByType } from '../../../utils/rules';\nimport { NeedHelpInfo } from '../NeedHelpInfo';\n\nimport { LabelsInRule } from './LabelsField';\n\ninterface LabelsFieldInFormProps {\n onEditClick: () => void;\n}\nexport function LabelsFieldInForm({ onEditClick }: LabelsFieldInFormProps) {\n const { watch } = useFormContext<RuleFormValues>();\n\n const labels = watch('labels');\n const type = watch('type');\n\n const isRecordingRule = type ? isRecordingRuleByType(type) : false;\n const isGrafanaManaged = type ? isGrafanaManagedRuleByType(type) : false;\n\n const text = isRecordingRule\n ? t('alerting.alertform.labels.recording', 'Add labels to your rule.')\n : t(\n 'alerting.alertform.labels.alerting',\n 'Add labels to your rule for searching, silencing, or routing to a notification policy.'\n );\n\n const hasLabels = Object.keys(labels).length > 0 && labels.some((label) => label.key || label.value);\n\n return (\n <Stack direction=\"column\" gap={2}>\n <Stack direction=\"column\" gap={1}>\n <Text element=\"h5\">\n <Trans i18nKey=\"alerting.labels-field-in-form.labels\">Labels</Trans>\n </Text>\n <Stack direction={'column'} gap={1}>\n <Stack direction={'row'} gap={1}>\n <Text variant=\"bodySmall\" color=\"secondary\">\n {text}\n </Text>\n <NeedHelpInfo\n externalLink={\n 'https://grafana.com/docs/grafana/latest/alerting/fundamentals/alert-rules/annotation-label/'\n }\n linkText={`Read about labels`}\n contentText=\"The dropdown only displays labels that you have previously used for alerts.\n Select a label from the options below or type in a new one.\"\n title={t('alerting.labels-field-in-form.title-labels', 'Labels')}\n />\n </Stack>\n {isGrafanaManaged && <AIImproveLabelsButtonComponent />}\n </Stack>\n </Stack>\n <Stack direction=\"row\" gap={1} alignItems=\"center\">\n <LabelsInRule labels={labels} />\n {hasLabels ? (\n <Button variant=\"secondary\" type=\"button\" onClick={onEditClick} size=\"sm\">\n <Trans i18nKey=\"alerting.labels-field-in-form.edit-labels\">Edit labels</Trans>\n </Button>\n ) : (\n <Stack direction=\"row\" gap={2} alignItems=\"center\">\n <Text>\n <Trans i18nKey=\"alerting.labels-field-in-form.no-labels-selected\">No labels selected</Trans>\n </Text>\n <Button\n icon=\"plus\"\n type=\"button\"\n variant=\"secondary\"\n onClick={onEditClick}\n size=\"sm\"\n data-testid=\"add-labels-button\"\n >\n <Trans i18nKey=\"alerting.labels-field-in-form.add-labels\">Add labels</Trans>\n </Button>\n </Stack>\n )}\n </Stack>\n </Stack>\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 { Alert, LinkButton, useStyles2 } from '@grafana/ui';\n\ninterface AlertWarningProps {\n title: string;\n children: React.ReactNode;\n}\nexport function AlertWarning({ title, children }: AlertWarningProps) {\n return (\n <Alert className={useStyles2(warningStyles).warning} severity=\"warning\" title={title}>\n <p>{children}</p>\n <LinkButton href=\"alerting/list\">\n <Trans i18nKey=\"alerting.alert-warning.to-rule-list\">To rule list</Trans>\n </LinkButton>\n </Alert>\n );\n}\n\nconst warningStyles = (theme: GrafanaTheme2) => ({\n warning: css({\n margin: theme.spacing(4),\n }),\n});\n","export interface GrafanaGroupUpdatedResponse {\n message: string;\n /**\n * UIDs of rules created from this request\n */\n created?: string[];\n /**\n * UIDs of rules updated from this request\n */\n updated?: string[];\n}\n\nexport interface CloudGroupUpdatedResponse {\n error: string;\n errorType: string;\n status: 'error' | 'success';\n}\n\nexport type RulerGroupUpdatedResponse = GrafanaGroupUpdatedResponse | CloudGroupUpdatedResponse;\n\nexport function isGrafanaGroupUpdatedResponse(\n response: RulerGroupUpdatedResponse\n): response is GrafanaGroupUpdatedResponse {\n return 'message' in response;\n}\n\nexport function isCloudGroupUpdatedResponse(\n response: RulerGroupUpdatedResponse\n): response is CloudGroupUpdatedResponse {\n return 'status' in response;\n}\n","import { useState } from 'react';\n\nimport { t } from '@grafana/i18n';\nimport { LoadingPlaceholder } from '@grafana/ui';\n\nimport { alertRuleApi } from '../../api/alertRuleApi';\n\nimport { FileExportPreview } from './FileExportPreview';\nimport { GrafanaExportDrawer } from './GrafanaExportDrawer';\nimport { ExportFormats, allGrafanaExportProviders } from './providers';\n\ninterface GrafanaRuleExportPreviewProps {\n alertUid: string;\n exportFormat: ExportFormats;\n onClose: () => void;\n}\n\nconst GrafanaRuleExportPreview = ({ alertUid, exportFormat, onClose }: GrafanaRuleExportPreviewProps) => {\n const { currentData: ruleTextDefinition = '', isFetching } = alertRuleApi.endpoints.exportRules.useQuery({\n ruleUid: alertUid,\n format: exportFormat,\n });\n\n const downloadFileName = `${alertUid}-${new Date().getTime()}`;\n\n if (isFetching) {\n return <LoadingPlaceholder text={t('alerting.grafana-rule-export-preview.text-loading', 'Loading....')} />;\n }\n\n return (\n <FileExportPreview\n format={exportFormat}\n textDefinition={ruleTextDefinition}\n downloadFileName={downloadFileName}\n onClose={onClose}\n />\n );\n};\n\ninterface GrafanaRulerExporterProps {\n onClose: () => void;\n alertUid: string;\n}\n\nexport const GrafanaRuleExporter = ({ onClose, alertUid }: GrafanaRulerExporterProps) => {\n const [activeTab, setActiveTab] = useState<ExportFormats>('yaml');\n\n return (\n <GrafanaExportDrawer\n activeTab={activeTab}\n onTabChange={setActiveTab}\n onClose={onClose}\n formatProviders={Object.values(allGrafanaExportProviders)}\n >\n <GrafanaRuleExportPreview alertUid={alertUid} exportFormat={activeTab} onClose={onClose} />\n </GrafanaExportDrawer>\n );\n};\n","import { css } from '@emotion/css';\nimport { useMemo } from 'react';\nimport { Controller, useFormContext } from 'react-hook-form';\n\nimport { GrafanaTheme2, SelectableValue } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { Field, VirtualizedSelect, useStyles2 } from '@grafana/ui';\n\nimport { RuleFormValues } from '../../types/rule-form';\n\nimport { useGetNameSpacesByDatasourceName } from './useAlertRuleSuggestions';\n\ninterface Props {\n rulesSourceName: string;\n}\n\nexport const GroupAndNamespaceFields = ({ rulesSourceName }: Props) => {\n const {\n control,\n watch,\n formState: { errors },\n setValue,\n } = useFormContext<RuleFormValues>();\n\n const style = useStyles2(getStyle);\n const { namespaceGroups, isLoading } = useGetNameSpacesByDatasourceName(rulesSourceName);\n\n const namespace = watch('namespace');\n\n const namespaceOptions: Array<SelectableValue<string>> = useMemo(\n () =>\n Array.from(namespaceGroups.keys()).map((namespace) => ({\n label: namespace,\n value: namespace,\n })),\n [namespaceGroups]\n );\n\n const groupOptions: Array<SelectableValue<string>> = useMemo(\n () => (namespace && namespaceGroups.get(namespace)?.map((group) => ({ label: group, value: group }))) || [],\n [namespace, namespaceGroups]\n );\n\n return (\n <div className={style.flexRow}>\n <Field\n data-testid=\"namespace-picker\"\n label={t('alerting.group-and-namespace-fields.namespace-picker-label-namespace', 'Namespace')}\n // Disable translations as we don't intend to use this dropdown longterm,\n // so avoiding us adding translations for the sake of it\n // eslint-disable-next-line @grafana/i18n/no-untranslated-strings\n description=\"Type to search for an existing namespace or create a new one\"\n error={errors.namespace?.message}\n invalid={!!errors.namespace?.message}\n >\n <Controller\n render={({ field: { onChange, ref, ...field } }) => (\n <VirtualizedSelect\n {...field}\n allowCustomValue\n className={style.input}\n onChange={(value) => {\n setValue('group', ''); //reset if namespace changes\n onChange(value.value);\n }}\n options={namespaceOptions}\n width={42}\n isLoading={isLoading}\n disabled={isLoading}\n />\n )}\n name=\"namespace\"\n control={control}\n rules={{\n required: { value: true, message: t('alerting.group-and-namespace-fields.message.required', 'Required.') },\n }}\n />\n </Field>\n <Field\n data-testid=\"group-picker\"\n label={t('alerting.group-and-namespace-fields.group-picker-label-group', 'Group')}\n // Disable translations as we don't intend to use this dropdown longterm,\n // so avoiding us adding translations for the sake of it\n // eslint-disable-next-line @grafana/i18n/no-untranslated-strings\n description=\"Type to search for an existing group or create a new one\"\n error={errors.group?.message}\n invalid={!!errors.group?.message}\n >\n <Controller\n render={({ field: { ref, ...field } }) => (\n <VirtualizedSelect\n {...field}\n allowCustomValue\n options={groupOptions}\n width={42}\n onChange={(value) => {\n setValue('group', value.value ?? '');\n }}\n className={style.input}\n isLoading={isLoading}\n disabled={isLoading}\n />\n )}\n name=\"group\"\n control={control}\n rules={{\n required: { value: true, message: t('alerting.group-and-namespace-fields.message.required', 'Required.') },\n }}\n />\n </Field>\n </div>\n );\n};\n\nconst getStyle = (theme: GrafanaTheme2) => ({\n flexRow: css({\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'flex-start',\n\n '& > * + *': {\n marginLeft: theme.spacing(3),\n },\n }),\n input: css({\n width: '330px !important',\n }),\n});\n","import { css } from '@emotion/css';\nimport { Controller, useFormContext } from 'react-hook-form';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { Field, Input, Select, useStyles2 } from '@grafana/ui';\n\nimport { RuleFormType, RuleFormValues } from '../../types/rule-form';\nimport { timeOptions } from '../../utils/time';\n\nimport { GroupAndNamespaceFields } from './GroupAndNamespaceFields';\nimport { PreviewRule } from './PreviewRule';\nimport { RuleEditorSection } from './RuleEditorSection';\n\nexport const CloudEvaluationBehavior = () => {\n const styles = useStyles2(getStyles);\n const {\n register,\n control,\n watch,\n formState: { errors },\n } = useFormContext<RuleFormValues>();\n\n const type = watch('type');\n const dataSourceName = watch('dataSourceName');\n\n return (\n <RuleEditorSection\n stepNo={3}\n title={t('alerting.cloud-evaluation-behavior.title-set-evaluation-behavior', 'Set evaluation behavior')}\n >\n <Field\n label={t('alerting.cloud-evaluation-behavior.label-pending-period', 'Pending period')}\n description={t(\n 'alerting.cloud-evaluation-behavior.description-pending-period',\n 'Period during which the threshold condition must be met to trigger an alert. Selecting \"None\" triggers the alert immediately once the condition is met.'\n )}\n >\n <div className={styles.flexRow}>\n <Field invalid={!!errors.forTime?.message} error={errors.forTime?.message} className={styles.inlineField}>\n <Input\n {...register('forTime', {\n pattern: {\n value: /^\\d+$/,\n message: t(\n 'alerting.cloud-evaluation-behavior.message.must-be-a-positive-integer',\n 'Must be a positive integer.'\n ),\n },\n })}\n width={8}\n />\n </Field>\n <Controller\n name=\"forTimeUnit\"\n render={({ field: { onChange, ref, ...field } }) => (\n <Select\n {...field}\n options={timeOptions}\n onChange={(value) => onChange(value?.value)}\n width={15}\n className={styles.timeUnit}\n />\n )}\n control={control}\n />\n </div>\n </Field>\n {type === RuleFormType.cloudAlerting && dataSourceName && (\n <GroupAndNamespaceFields rulesSourceName={dataSourceName} />\n )}\n\n <PreviewRule />\n </RuleEditorSection>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n inlineField: css({\n marginBottom: 0,\n }),\n flexRow: css({\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'flex-start',\n alignItems: 'flex-start',\n }),\n timeUnit: css({\n marginLeft: theme.spacing(0.5),\n }),\n});\n","import { useFormContext } from 'react-hook-form';\n\nimport { t } from '@grafana/i18n';\n\nimport { RuleFormValues } from '../../types/rule-form';\n\nimport { GroupAndNamespaceFields } from './GroupAndNamespaceFields';\nimport { RuleEditorSection } from './RuleEditorSection';\n\nexport function RecordingRulesNameSpaceAndGroupStep() {\n const { watch } = useFormContext<RuleFormValues>();\n\n const dataSourceName = watch('dataSourceName');\n\n if (!dataSourceName) {\n return null;\n }\n\n return (\n <RuleEditorSection\n stepNo={3}\n title={t(\n 'alerting.recording-rules-name-space-and-group-step.title-add-namespace-and-group',\n 'Add namespace and group'\n )}\n description={t(\n 'alerting.recording-rules-name-space-and-group-step.description-select-namespace-group-recording',\n 'Select the Namespace and Group for your recording rule.'\n )}\n >\n <GroupAndNamespaceFields rulesSourceName={dataSourceName} />\n </RuleEditorSection>\n );\n}\n","import { css } from '@emotion/css';\nimport { useCallback, useEffect, useMemo, useState } from 'react';\nimport { FormProvider, SubmitErrorHandler, UseFormWatch, useForm } from 'react-hook-form';\nimport { useParams } from 'react-router-dom-v5-compat';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, locationService } from '@grafana/runtime';\nimport { Alert, Button, Stack, useStyles2 } from '@grafana/ui';\nimport { useAppNotification } from 'app/core/copy/appNotification';\nimport { contextSrv } from 'app/core/core';\nimport InfoPausedRule from 'app/features/alerting/unified/components/InfoPausedRule';\nimport {\n getRuleGroupLocationFromFormValues,\n getRuleGroupLocationFromRuleWithLocation,\n isCloudAlertingRuleByType,\n isCloudRecordingRuleByType,\n isGrafanaManagedRuleByType,\n isPausedRule,\n isRecordingRuleByType,\n rulerRuleType,\n} from 'app/features/alerting/unified/utils/rules';\nimport { isExpressionQuery } from 'app/features/expressions/guards';\nimport { RuleGroupIdentifier, RuleWithLocation } from 'app/types/unified-alerting';\nimport { PostableRuleGrafanaRuleDTO, RulerRuleDTO } from 'app/types/unified-alerting-dto';\n\nimport {\n LogMessages,\n logInfo,\n logWarning,\n trackAlertRuleFormCancelled,\n trackAlertRuleFormError,\n trackAlertRuleFormSaved,\n trackNewGrafanaAlertRuleFormCancelled,\n trackNewGrafanaAlertRuleFormError,\n trackNewGrafanaAlertRuleFormSavedSuccess,\n} from '../../../Analytics';\nimport {\n GrafanaGroupUpdatedResponse,\n RulerGroupUpdatedResponse,\n isGrafanaGroupUpdatedResponse,\n} from '../../../api/alertRuleModel';\nimport { useAddRuleToRuleGroup, useUpdateRuleInRuleGroup } from '../../../hooks/ruleGroup/useUpsertRuleFromRuleGroup';\nimport {\n defaultFormValuesForRuleType,\n formValuesFromExistingRule,\n formValuesFromPrefill,\n translateRouteParamToRuleType,\n} from '../../../rule-editor/formDefaults';\nimport {\n areQueriesTransformableToSimpleCondition,\n isExpressionQueryInAlert,\n} from '../../../rule-editor/formProcessing';\nimport { RuleFormType, RuleFormValues } from '../../../types/rule-form';\nimport { rulesNav } from '../../../utils/navigation';\nimport {\n MANUAL_ROUTING_KEY,\n SIMPLIFIED_QUERY_EDITOR_KEY,\n formValuesToRulerGrafanaRuleDTO,\n formValuesToRulerRuleDTO,\n} from '../../../utils/rule-form';\nimport { fromRulerRule, fromRulerRuleAndRuleGroupIdentifier } from '../../../utils/rule-id';\nimport { GrafanaRuleExporter } from '../../export/GrafanaRuleExporter';\nimport { AlertRuleNameAndMetric } from '../AlertRuleNameInput';\nimport AnnotationsStep from '../AnnotationsStep';\nimport { CloudEvaluationBehavior } from '../CloudEvaluationBehavior';\nimport { GrafanaEvaluationBehaviorStep } from '../GrafanaEvaluationBehavior';\nimport { GrafanaFolderAndLabelsStep } from '../GrafanaFolderAndLabelsStep';\nimport { NotificationsStep } from '../NotificationsStep';\nimport { RecordingRulesNameSpaceAndGroupStep } from '../RecordingRulesNameSpaceAndGroupStep';\nimport { RuleInspector } from '../RuleInspector';\nimport { QueryAndExpressionsStep } from '../query-and-alert-condition/QueryAndExpressionsStep';\n\ntype Props = {\n existing?: RuleWithLocation;\n prefill?: Partial<RuleFormValues>; // Existing implies we modify existing rule. Prefill only provides default form values\n isManualRestore?: boolean;\n};\n\nexport const AlertRuleForm = ({ existing, prefill, isManualRestore }: Props) => {\n const styles = useStyles2(getStyles);\n const notifyApp = useAppNotification();\n\n const routeParams = useParams<{ type: string; id: string }>();\n const uidFromParams = routeParams.id;\n\n const { redirectToDetailsPage } = useRedirectToDetailsPage(uidFromParams);\n const [showEditYaml, setShowEditYaml] = useState(false);\n\n const [addRuleToRuleGroup] = useAddRuleToRuleGroup();\n const [updateRuleInRuleGroup] = useUpdateRuleInRuleGroup();\n\n const ruleType = translateRouteParamToRuleType(routeParams.type);\n\n const defaultValues: RuleFormValues = useMemo(() => {\n // If we have an existing AND a prefill, then we're coming from the restore dialog\n // and we want to merge the two\n if (existing && prefill) {\n return { ...formValuesFromExistingRule(existing), ...formValuesFromPrefill(prefill) };\n }\n if (existing) {\n return formValuesFromExistingRule(existing);\n }\n\n if (prefill) {\n return formValuesFromPrefill(prefill);\n }\n\n return defaultFormValuesForRuleType(ruleType);\n }, [existing, prefill, ruleType]);\n\n const formAPI = useForm<RuleFormValues>({\n mode: 'onSubmit',\n defaultValues,\n shouldFocusError: true,\n });\n\n const {\n handleSubmit,\n watch,\n formState: { isSubmitting },\n trigger,\n } = formAPI;\n\n useEffect(() => {\n // If the user is manually restoring an old version of a rule,\n // we should trigger validation on the form so any problem areas are clearly highlighted for them to action\n if (isManualRestore) {\n trigger();\n }\n }, [isManualRestore, trigger]);\n const type = watch('type');\n const grafanaTypeRule = isGrafanaManagedRuleByType(type ?? RuleFormType.grafana);\n\n const dataSourceName = watch('dataSourceName');\n\n const showDataSourceDependantStep = Boolean(type && (isGrafanaManagedRuleByType(type) || !!dataSourceName));\n\n const [conditionErrorMsg, setConditionErrorMsg] = useState('');\n\n const checkAlertCondition = (msg = '') => {\n setConditionErrorMsg(msg);\n };\n\n // @todo why is error not propagated to form?\n const submit = async (values: RuleFormValues): Promise<void> => {\n const { type, evaluateEvery } = values;\n\n if (conditionErrorMsg !== '') {\n notifyApp.error(conditionErrorMsg);\n if (!existing && grafanaTypeRule) {\n // new Grafana-managed rule\n trackNewGrafanaAlertRuleFormError();\n }\n return;\n }\n\n trackAlertRuleFormSaved({ formAction: existing ? 'update' : 'create', ruleType: type });\n\n const ruleDefinition = grafanaTypeRule ? formValuesToRulerGrafanaRuleDTO(values) : formValuesToRulerRuleDTO(values);\n\n const ruleGroupIdentifier = existing\n ? getRuleGroupLocationFromRuleWithLocation(existing)\n : getRuleGroupLocationFromFormValues(values);\n\n const targetRuleGroupIdentifier = getRuleGroupLocationFromFormValues(values);\n\n let saveResult: RulerGroupUpdatedResponse;\n // @TODO move this to a hook too to make sure the logic here is tested for regressions?\n if (!existing) {\n // when creating a new rule, we save the manual routing setting , and editorSettings.simplifiedQueryEditor to the local storage\n storeInLocalStorageValues(values);\n // save the rule to the rule group\n saveResult = await addRuleToRuleGroup.execute(ruleGroupIdentifier, ruleDefinition, evaluateEvery);\n // track the new Grafana-managed rule creation in the analytics\n if (grafanaTypeRule) {\n const dataQueries = values.queries.filter((query) => !isExpressionQuery(query.model));\n const expressionQueries = values.queries.filter((query) => isExpressionQueryInAlert(query));\n trackNewGrafanaAlertRuleFormSavedSuccess({\n simplifiedQueryEditor: values.editorSettings?.simplifiedQueryEditor ?? false,\n simplifiedNotificationEditor: values.editorSettings?.simplifiedNotificationEditor ?? false,\n canBeTransformedToSimpleQuery: areQueriesTransformableToSimpleCondition(dataQueries, expressionQueries),\n });\n }\n } else {\n // when updating an existing rule\n const ruleIdentifier = fromRulerRuleAndRuleGroupIdentifier(ruleGroupIdentifier, existing.rule);\n saveResult = await updateRuleInRuleGroup.execute(\n ruleGroupIdentifier,\n ruleIdentifier,\n ruleDefinition,\n targetRuleGroupIdentifier,\n evaluateEvery\n );\n }\n\n redirectToDetailsPage(ruleDefinition, targetRuleGroupIdentifier, saveResult);\n return;\n };\n\n const onInvalid: SubmitErrorHandler<RuleFormValues> = (errors): void => {\n trackAlertRuleFormError({\n grafana_version: config.buildInfo.version,\n org_id: contextSrv.user.orgId,\n user_id: contextSrv.user.id,\n error: Object.keys(errors).toString(),\n formAction: existing ? 'update' : 'create',\n });\n notifyApp.error('There are errors in the form. Please correct them and try again!');\n };\n\n const cancelRuleCreation = () => {\n logInfo(LogMessages.cancelSavingAlertRule);\n trackAlertRuleFormCancelled({ formAction: existing ? 'update' : 'create' });\n if (!existing && grafanaTypeRule) {\n // new Grafana-managed rule\n trackNewGrafanaAlertRuleFormCancelled();\n }\n locationService.getHistory().goBack();\n };\n\n if (!type) {\n return null;\n }\n\n const isPaused = rulerRuleType.grafana.rule(existing?.rule) && isPausedRule(existing?.rule);\n\n return (\n <FormProvider {...formAPI}>\n <form onSubmit={(e) => e.preventDefault()} className={styles.form}>\n <div className={styles.contentOuter}>\n {isManualRestore && (\n <Alert\n severity=\"warning\"\n title={t('alerting.alertVersionHistory.warning-restore-manually-title', 'Restoring rule manually')}\n >\n <Trans i18nKey=\"alerting.alertVersionHistory.warning-restore-manually\">\n You are manually restoring an old version of this alert rule. Please review the changes carefully before\n saving the rule definition.\n </Trans>\n </Alert>\n )}\n {isPaused && <InfoPausedRule />}\n <Stack direction=\"column\" gap={3}>\n {/* Step 1 */}\n <AlertRuleNameAndMetric />\n\n {/* Step 2 */}\n <QueryAndExpressionsStep editingExistingRule={!!existing} onDataChange={checkAlertCondition} mode=\"edit\" />\n {/* Step 3-4-5 */}\n {showDataSourceDependantStep && (\n <>\n {/* Step 3 */}\n {isGrafanaManagedRuleByType(type) && <GrafanaFolderAndLabelsStep />}\n\n {isCloudAlertingRuleByType(type) && <CloudEvaluationBehavior />}\n\n {isCloudRecordingRuleByType(type) && <RecordingRulesNameSpaceAndGroupStep />}\n\n {/* Step 4 & 5 & 6*/}\n {isGrafanaManagedRuleByType(type) && (\n <GrafanaEvaluationBehaviorStep existing={Boolean(existing)} enableProvisionedGroups={false} />\n )}\n {/* Notifications step*/}\n <NotificationsStep alertUid={uidFromParams} />\n {/* Annotations only for alerting rules */}\n {!isRecordingRuleByType(type) && <AnnotationsStep />}\n </>\n )}\n\n {/* actions */}\n <Stack direction=\"row\" alignItems=\"center\">\n <Button\n data-testid=\"save-rule\"\n variant=\"primary\"\n type=\"button\"\n onClick={handleSubmit((values) => submit(values), onInvalid)}\n disabled={isSubmitting}\n icon={isSubmitting ? 'spinner' : undefined}\n >\n <Trans i18nKey=\"alerting.alert-rule-form.action-buttons.save\">Save</Trans>\n </Button>\n\n <Button variant=\"secondary\" disabled={isSubmitting} type=\"button\" onClick={cancelRuleCreation}>\n <Trans i18nKey=\"alerting.common.cancel\">Cancel</Trans>\n </Button>\n\n {existing && isCortexLokiOrRecordingRule(watch) && (\n <Button variant=\"secondary\" type=\"button\" onClick={() => setShowEditYaml(true)} disabled={isSubmitting}>\n <Trans i18nKey=\"alerting.alert-rule-form.action-buttons.edit-yaml\">Edit YAML</Trans>\n </Button>\n )}\n </Stack>\n </Stack>\n </div>\n </form>\n\n {showEditYaml && (\n <>\n {grafanaTypeRule && uidFromParams && (\n <GrafanaRuleExporter alertUid={uidFromParams} onClose={() => setShowEditYaml(false)} />\n )}\n\n {!grafanaTypeRule && <RuleInspector onClose={() => setShowEditYaml(false)} />}\n </>\n )}\n </FormProvider>\n );\n};\n\nfunction useRedirectToDetailsPage(existingUid?: string) {\n const notifyApp = useAppNotification();\n\n const redirectGrafanaRule = useCallback(\n (saveResult: GrafanaGroupUpdatedResponse) => {\n // if the response contains no created or updated rules, we'll use the existing UID.\n const newOrUpdatedRuleUid = (saveResult.created?.at(0) || saveResult.updated?.at(0)) ?? existingUid;\n if (newOrUpdatedRuleUid) {\n locationService.replace(\n rulesNav.detailsPageLink('grafana', { uid: newOrUpdatedRuleUid, ruleSourceName: 'grafana' }, undefined, {\n skipSubPath: true,\n })\n );\n } else {\n notifyApp.error(\n 'Cannot navigate to the new rule details page.',\n 'The rule was created but the UID is missing.'\n );\n logWarning('Cannot navigate to the new rule details page. The rule was created but the UID is missing.');\n }\n },\n [existingUid, notifyApp]\n );\n\n const redirectCloudRulerRule = useCallback((rule: RulerRuleDTO, groupId: RuleGroupIdentifier) => {\n const { dataSourceName, namespaceName, groupName } = groupId;\n const updatedRuleIdentifier = fromRulerRule(dataSourceName, namespaceName, groupName, rule);\n locationService.replace(\n rulesNav.detailsPageLink(updatedRuleIdentifier.ruleSourceName, updatedRuleIdentifier, undefined, {\n skipSubPath: true,\n })\n );\n }, []);\n\n const redirectToDetailsPage = useCallback(\n (\n rule: RulerRuleDTO | PostableRuleGrafanaRuleDTO,\n groupId: RuleGroupIdentifier,\n saveResult: RulerGroupUpdatedResponse\n ) => {\n if (isGrafanaGroupUpdatedResponse(saveResult)) {\n redirectGrafanaRule(saveResult);\n return;\n } else if (rulerRuleType.dataSource.rule(rule)) {\n redirectCloudRulerRule(rule, groupId);\n return;\n }\n\n logWarning(\n 'Cannot navigate to the new rule details page. The response is not a GrafanaGroupUpdatedResponse and ruleDefinition is not a Cloud Ruler rule.',\n { ruleFormType: rulerRuleType.dataSource.rule(rule) ? 'datasource' : 'grafana' }\n );\n },\n [redirectGrafanaRule, redirectCloudRulerRule]\n );\n\n return { redirectToDetailsPage };\n}\n\nconst isCortexLokiOrRecordingRule = (watch: UseFormWatch<RuleFormValues>) => {\n const [ruleType, dataSourceName] = watch(['type', 'dataSourceName']);\n\n return (ruleType === RuleFormType.cloudAlerting || ruleType === RuleFormType.cloudRecording) && dataSourceName !== '';\n};\n\nfunction storeInLocalStorageValues(values: RuleFormValues) {\n const { manualRouting, editorSettings } = values;\n\n if (manualRouting) {\n localStorage.setItem(MANUAL_ROUTING_KEY, 'true');\n } else {\n localStorage.setItem(MANUAL_ROUTING_KEY, 'false');\n }\n\n if (editorSettings) {\n if (editorSettings.simplifiedQueryEditor) {\n localStorage.setItem(SIMPLIFIED_QUERY_EDITOR_KEY, 'true');\n } else {\n localStorage.setItem(SIMPLIFIED_QUERY_EDITOR_KEY, 'false');\n }\n }\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n form: css({\n width: '100%',\n height: '100%',\n display: 'flex',\n flexDirection: 'column',\n }),\n contentOuter: css({\n background: theme.colors.background.primary,\n overflow: 'hidden',\n maxWidth: theme.breakpoints.values.xl,\n flex: 1,\n }),\n});\n","import { cloneDeep } from 'lodash';\n\nimport { RuleWithLocation } from 'app/types/unified-alerting';\nimport { RulerRuleDTO } from 'app/types/unified-alerting-dto';\n\nimport { generateCopiedName } from '../utils/duplicate';\nimport { GRAFANA_ORIGIN_LABEL } from '../utils/labels';\nimport { getRuleName, isPluginProvidedRule, rulerRuleType } from '../utils/rules';\n\nexport function changeRuleName(rule: RulerRuleDTO, newName: string) {\n if (rulerRuleType.grafana.rule(rule)) {\n rule.grafana_alert.title = newName;\n }\n if (rulerRuleType.dataSource.alertingRule(rule)) {\n rule.alert = newName;\n }\n\n if (rulerRuleType.dataSource.recordingRule(rule)) {\n rule.record = newName;\n }\n}\n\nexport function cloneRuleDefinition(rule: RuleWithLocation<RulerRuleDTO>) {\n const ruleClone = cloneDeep(rule);\n changeRuleName(\n ruleClone.rule,\n generateCopiedName(getRuleName(ruleClone.rule), ruleClone.group.rules.map(getRuleName))\n );\n\n if (rulerRuleType.grafana.rule(ruleClone.rule)) {\n ruleClone.rule.grafana_alert.uid = '';\n\n // Provisioned alert rules have provisioned alert group which cannot be used in UI\n if (Boolean(ruleClone.rule.grafana_alert.provenance)) {\n ruleClone.group = { name: '', rules: ruleClone.group.rules };\n }\n }\n\n if (rulerRuleType.any.rule(ruleClone.rule) && isPluginProvidedRule(ruleClone.rule)) {\n // Remove the origin label when cloning plugin-provided rules\n delete ruleClone.rule.labels?.[GRAFANA_ORIGIN_LABEL];\n }\n\n return ruleClone;\n}\n","import { NavModelItem } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Alert, Stack } from '@grafana/ui';\nimport { RuleIdentifier } from 'app/types/unified-alerting';\n\nimport { AlertWarning } from '../AlertWarning';\nimport { AlertingPageWrapper } from '../components/AlertingPageWrapper';\nimport { AlertRuleForm } from '../components/rule-editor/alert-rule-form/AlertRuleForm';\nimport { FederatedRuleWarning } from '../components/rule-viewer/FederatedRuleWarning';\nimport { useRuleWithLocation } from '../hooks/useCombinedRule';\nimport { useIsRuleEditable } from '../hooks/useIsRuleEditable';\nimport { RuleFormValues } from '../types/rule-form';\nimport { Annotation } from '../utils/constants';\nimport { stringifyErrorLike } from '../utils/misc';\nimport { rulerRuleToFormValues } from '../utils/rule-form';\nimport * as ruleId from '../utils/rule-id';\nimport { isFederatedRuleGroup, rulerRuleType } from '../utils/rules';\n\nimport { defaultPageNav } from './RuleEditor';\nimport { cloneRuleDefinition } from './clone.utils';\ninterface ExistingRuleEditorProps {\n identifier: RuleIdentifier;\n // Provide prefill if we are trying to restore an old version of an alert rule but we need the user to manually tweak the values\n prefill?: Partial<RuleFormValues>;\n // indicate if this is a manual restore\n isManualRestore?: boolean;\n // indicate if this is a cloning operation\n clone?: boolean;\n}\n\nexport function ExistingRuleEditor({\n identifier,\n prefill,\n isManualRestore = false,\n clone = false,\n}: ExistingRuleEditorProps) {\n const ruleSourceName = ruleId.ruleIdentifierToRuleSourceName(identifier);\n const {\n loading: loadingAlertRule,\n result: ruleWithLocation,\n error: fetchRuleError,\n } = useRuleWithLocation({ ruleIdentifier: identifier });\n const {\n isEditable,\n loading: loadingEditable,\n error: errorEditable,\n } = useIsRuleEditable(ruleSourceName, ruleWithLocation?.rule);\n\n if (fetchRuleError || errorEditable) {\n return (\n <AlertingPageWrapper navId=\"alert-list\" pageNav={getPageNav()}>\n <Alert\n severity=\"error\"\n title={t('alerting.existing-rule-editor.title-failed-to-load-rule', 'Failed to load rule')}\n >\n {stringifyErrorLike(errorEditable ?? fetchRuleError)}\n </Alert>\n </AlertingPageWrapper>\n );\n }\n\n const loading = loadingAlertRule || loadingEditable;\n if (loading) {\n return (\n <AlertingPageWrapper navId=\"alert-list\" pageNav={getPageNav()} isLoading={true}>\n {null}\n </AlertingPageWrapper>\n );\n }\n\n if (!ruleWithLocation && !loading) {\n return (\n <AlertingPageWrapper navId=\"alert-list\" pageNav={getPageNav()}>\n <AlertWarning title={t('alerting.existing-rule-editor.title-rule-not-found', 'Rule not found')}>\n <Trans i18nKey=\"alerting.existing-rule-editor.sorry-this-rule-does-not-exist\">\n Sorry! This rule does not exist.\n </Trans>\n </AlertWarning>\n </AlertingPageWrapper>\n );\n }\n\n if (isEditable === false) {\n return (\n <AlertingPageWrapper navId=\"alert-list\" pageNav={getPageNav()}>\n <AlertWarning title={t('alerting.existing-rule-editor.title-cannot-edit-rule', 'Cannot edit rule')}>\n <Trans i18nKey=\"alerting.existing-rule-editor.sorry-permission\">\n Sorry! You do not have permission to edit this rule.\n </Trans>\n </AlertWarning>\n </AlertingPageWrapper>\n );\n }\n\n // we shouldn't get here because loading / error handling happens before this\n if (!ruleWithLocation) {\n return null;\n }\n\n const rulerRule = ruleWithLocation.rule;\n const summary = rulerRuleType.any.alertingRule(rulerRule) ? rulerRule.annotations?.[Annotation.summary] : null;\n\n const isFederatedRule = isFederatedRuleGroup(ruleWithLocation.group);\n const isRecordingRule = rulerRuleType.any.recordingRule(rulerRule);\n\n const pageTitle = isRecordingRule\n ? t('alerting.editor.edit-recording-rule', 'Edit recording rule')\n : t('alerting.editor.edit-alert-rule', 'Edit alert rule');\n\n return (\n <AlertingPageWrapper\n navId=\"alert-list\"\n subTitle={\n <Stack direction=\"column\">\n {summary}\n {/* alerts and notifications and stuff */}\n {isFederatedRule && <FederatedRuleWarning />}\n </Stack>\n }\n pageNav={getPageNav({ text: pageTitle })}\n >\n {clone ? (\n <AlertRuleForm prefill={rulerRuleToFormValues(cloneRuleDefinition(ruleWithLocation))} />\n ) : (\n <AlertRuleForm existing={ruleWithLocation} prefill={prefill} isManualRestore={isManualRestore} />\n )}\n </AlertingPageWrapper>\n );\n}\n\nconst getPageNav = (pageNavOptions?: Partial<NavModelItem>): NavModelItem => {\n return { ...defaultPageNav, id: 'alert-rule-edit', text: '', ...pageNavOptions };\n};\n","import { useParams } from 'react-router-dom-v5-compat';\n\nimport { NavModelItem } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\n\nimport { AlertWarning } from '../AlertWarning';\nimport { AlertingPageWrapper } from '../components/AlertingPageWrapper';\nimport { AlertRuleForm } from '../components/rule-editor/alert-rule-form/AlertRuleForm';\nimport { useURLSearchParams } from '../hooks/useURLSearchParams';\nimport { useRulesAccess } from '../utils/accessControlHooks';\nimport * as ruleId from '../utils/rule-id';\nimport { withPageErrorBoundary } from '../withPageErrorBoundary';\n\nimport { ExistingRuleEditor } from './ExistingRuleEditor';\nimport { formValuesFromQueryParams, translateRouteParamToRuleType } from './formDefaults';\nexport type RuleEditorPathParams = {\n id?: string;\n type?: 'recording' | 'alerting' | 'grafana-recording';\n};\n\nexport const defaultPageNav: Partial<NavModelItem> = {\n id: 'alert-rule-view',\n};\n\nconst RuleEditor = () => {\n const { identifier } = useRuleEditorPathParams();\n const cloneIdentifier = useIdentifierFromCopy();\n const isManualRestore = useManualRestore();\n\n const { canCreateGrafanaRules, canCreateCloudRules, canEditRules } = useRulesAccess();\n\n if (!identifier && !canCreateGrafanaRules && !canCreateCloudRules) {\n return (\n <AlertWarning title={t('alerting.rule-editor.get-content.title-cannot-create-rules', 'Cannot create rules')}>\n <Trans i18nKey=\"alerting.rule-editor.get-content.sorry-allowed-create-rules\">\n Sorry! You are not allowed to create rules.\n </Trans>\n </AlertWarning>\n );\n }\n\n if (identifier && !canEditRules(identifier.ruleSourceName)) {\n return (\n <AlertWarning title={t('alerting.rule-editor.get-content.title-cannot-edit-rules', 'Cannot edit rules')}>\n <Trans i18nKey=\"alerting.rule-editor.get-content.sorry-allowed-rules\">\n Sorry! You are not allowed to edit rules.\n </Trans>\n </AlertWarning>\n );\n }\n\n if (identifier) {\n return (\n <ExistingRuleEditor key={JSON.stringify(identifier)} identifier={identifier} isManualRestore={isManualRestore} />\n );\n }\n\n if (cloneIdentifier) {\n return (\n <ExistingRuleEditor\n key={JSON.stringify(identifier)}\n identifier={cloneIdentifier}\n clone={true}\n isManualRestore={isManualRestore}\n />\n );\n }\n\n // for new alerting or recording rules\n return <NewRuleEditor />;\n};\n\nexport const RECORDING_TYPE = ['grafana-recording', 'recording'];\n\n/**\n * This one is used for creating new rules (both alerting and recording rules)\n */\nfunction NewRuleEditor() {\n const prefill = useDefaultsFromQuery();\n const isManualRestore = useManualRestore();\n const { type = '', identifier = '' } = useRuleEditorPathParams();\n\n const isExisting = Boolean(identifier);\n const isRecordingRule = RECORDING_TYPE.includes(type);\n\n const newText = isRecordingRule\n ? t('alerting.editor.new-recording-rule', 'New recording rule')\n : t('alerting.editor.new-alert-rule', 'New alert rule');\n\n const editText = isRecordingRule\n ? t('alerting.editor.edit-recording-rule', 'Edit recording rule')\n : t('alerting.editor.edit-alert-rule', 'Edit alert rule');\n\n return (\n <AlertingPageWrapper\n navId=\"alert-list\"\n pageNav={{\n id: 'alert-rule-add',\n text: isExisting ? editText : newText,\n }}\n >\n <AlertRuleForm prefill={prefill} isManualRestore={isManualRestore} />\n </AlertingPageWrapper>\n );\n}\n\n// The pageNav property makes it difficult to only rely on AlertingPageWrapper\n// to catch errors.\nexport default withPageErrorBoundary(RuleEditor);\n\nfunction useRuleEditorPathParams() {\n const params = useParams<RuleEditorPathParams>();\n const { type } = params;\n const id = ruleId.getRuleIdFromPathname(params);\n const identifier = ruleId.tryParse(id, true);\n\n return { identifier, type };\n}\n\nfunction useIdentifierFromCopy() {\n const [searchParams] = useURLSearchParams();\n const copyFromId = searchParams.get('copyFrom') ?? undefined;\n\n return ruleId.tryParse(copyFromId);\n}\n\nfunction useDefaultsFromQuery() {\n const { type } = useRuleEditorPathParams();\n const [searchParams] = useURLSearchParams();\n\n const ruleType = translateRouteParamToRuleType(type);\n\n const queryDefaults = searchParams.has('defaults')\n ? formValuesFromQueryParams(searchParams.get('defaults') ?? '', ruleType)\n : undefined;\n\n return queryDefaults;\n}\n\nfunction useManualRestore() {\n const [searchParams] = useURLSearchParams();\n const isManualRestore = searchParams.has('isManualRestore');\n\n return isManualRestore;\n}\n","import { t } from '@grafana/i18n';\nimport { Modal } from '@grafana/ui';\n\nimport { KBObjectArray } from '../../../types/rule-form';\n\nimport { LabelsSubForm } from './LabelsField';\n\nexport interface LabelsEditorModalProps {\n isOpen: boolean;\n initialLabels: Array<{\n key: string;\n value: string;\n }>;\n onClose: (labelsToUodate?: KBObjectArray) => void;\n dataSourceName: string;\n}\nexport function LabelsEditorModal({ isOpen, onClose, dataSourceName, initialLabels }: LabelsEditorModalProps) {\n return (\n <Modal\n title={t('alerting.labels-editor-modal.title-edit-labels', 'Edit labels')}\n closeOnEscape\n isOpen={isOpen}\n onDismiss={() => onClose()}\n >\n <LabelsSubForm dataSourceName={dataSourceName} onClose={onClose} initialLabels={initialLabels} />\n </Modal>\n );\n}\n","import { useMemo } from 'react';\nimport { useParams } from 'react-router-dom-v5-compat';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { locationService } from '@grafana/runtime';\nimport { Alert, LoadingPlaceholder } from '@grafana/ui';\n\nimport { RuleIdentifier } from '../../../../../types/unified-alerting';\nimport { useRuleWithLocation } from '../../hooks/useCombinedRule';\nimport { formValuesFromExistingRule } from '../../rule-editor/formDefaults';\nimport { stringifyErrorLike } from '../../utils/misc';\nimport * as ruleId from '../../utils/rule-id';\nimport { rulerRuleType } from '../../utils/rules';\nimport { createRelativeUrl } from '../../utils/url';\nimport { withPageErrorBoundary } from '../../withPageErrorBoundary';\nimport { AlertingPageWrapper } from '../AlertingPageWrapper';\nimport { ModifyExportRuleForm } from '../rule-editor/alert-rule-form/ModifyExportRuleForm';\n\nfunction GrafanaModifyExport() {\n const { id } = useParams();\n const ruleIdentifier = useMemo<RuleIdentifier | undefined>(() => {\n return ruleId.tryParse(id, true);\n }, [id]);\n\n if (!ruleIdentifier) {\n return (\n <Alert title={t('alerting.grafana-modify-export.title-invalid-rule-id', 'Invalid rule ID')} severity=\"error\">\n <Trans i18nKey=\"alerting.grafana-modify-export.body-invalid-rule-id\">\n The rule UID in the page URL is invalid. Please check the URL and try again.\n </Trans>\n </Alert>\n );\n }\n\n return <RuleModifyExport ruleIdentifier={ruleIdentifier} />;\n}\n\nfunction RuleModifyExport({ ruleIdentifier }: { ruleIdentifier: RuleIdentifier }) {\n const { loading, error, result: rulerRule } = useRuleWithLocation({ ruleIdentifier: ruleIdentifier });\n\n if (loading) {\n return <LoadingPlaceholder text={t('alerting.rule-modify-export.text-loading-the-rule', 'Loading the rule...')} />;\n }\n\n if (error) {\n return (\n <Alert\n title={t('alerting.rule-modify-export.title-cannot-load-modify-export', 'Cannot load modify export')}\n severity=\"error\"\n >\n {stringifyErrorLike(error)}\n </Alert>\n );\n }\n\n if (!rulerRule && !loading) {\n // alert rule does not exist\n return (\n <Alert\n title={t('alerting.rule-modify-export.title-cannot-exist', 'Cannot load the rule. The rule does not exist')}\n buttonContent=\"Go back to alert list\"\n onRemove={() => locationService.replace(createRelativeUrl('/alerting/list'))}\n />\n );\n }\n\n if (rulerRule && !rulerRuleType.grafana.rule(rulerRule.rule)) {\n // alert rule exists but is not a grafana-managed rule\n return (\n <Alert\n title={t(\n 'alerting.rule-modify-export.title-grafanamanaged-alert',\n 'This rule is not a Grafana-managed alert rule'\n )}\n buttonContent=\"Go back to alert list\"\n onRemove={() => locationService.replace(createRelativeUrl('/alerting/list'))}\n />\n );\n }\n\n if (rulerRule && rulerRuleType.grafana.rule(rulerRule.rule)) {\n return (\n <ModifyExportRuleForm\n ruleForm={formValuesFromExistingRule(rulerRule)}\n alertUid={rulerRule.rule.grafana_alert.uid}\n />\n );\n }\n\n return <Alert title={t('alerting.rule-modify-export.title-unknown-error', 'Unknown error')} />;\n}\n\nfunction GrafanaModifyExportPage() {\n return (\n <AlertingPageWrapper\n navId=\"alert-list\"\n pageNav={{\n text: t('alerting.grafana-modify-export-page.text.modify-export', 'Modify export'),\n subTitle:\n 'Modify the current alert rule and export the rule definition in the format of your choice. Any changes you make will not be saved.',\n }}\n >\n <GrafanaModifyExport />\n </AlertingPageWrapper>\n );\n}\n\nexport default withPageErrorBoundary(GrafanaModifyExportPage);\n","import { css } from '@emotion/css';\nimport { useState } from 'react';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { Trans, t } from '@grafana/i18n';\nimport { Button, Field, Input, Label, Modal, Stack, useStyles2 } from '@grafana/ui';\nimport { useCreateFolder } from 'app/api/clients/folder/v1beta1/hooks';\nimport { useAppNotification } from 'app/core/copy/appNotification';\nimport { contextSrv } from 'app/core/core';\nimport { AccessControlAction } from 'app/types/accessControl';\n\nimport { Folder } from '../../types/rule-form';\n\n/**\n * Provides a button and associated modal for creating a new folder\n */\nexport const CreateNewFolder = ({ onCreate }: { onCreate: (folder: Folder) => void }) => {\n const [isCreatingFolder, setIsCreatingFolder] = useState(false);\n const handleCreate = (folder: Folder) => {\n onCreate(folder);\n setIsCreatingFolder(false);\n };\n return (\n <>\n <Button\n onClick={() => setIsCreatingFolder(true)}\n type=\"button\"\n icon=\"plus\"\n fill=\"outline\"\n variant=\"secondary\"\n disabled={!contextSrv.hasPermission(AccessControlAction.FoldersCreate)}\n >\n <Trans i18nKey=\"alerting.create-new-folder.new-folder\">New folder</Trans>\n </Button>\n {isCreatingFolder && <FolderCreationModal onCreate={handleCreate} onClose={() => setIsCreatingFolder(false)} />}\n </>\n );\n};\n\nfunction FolderCreationModal({\n onClose,\n onCreate,\n}: {\n onClose: () => void;\n onCreate: (folder: Folder) => void;\n}): React.ReactElement {\n const styles = useStyles2(getStyles);\n const notifyApp = useAppNotification();\n const [title, setTitle] = useState('');\n const [isCreatingFolder, setIsCreatingFolder] = useState(false);\n const [createFolder] = useCreateFolder();\n\n const onSubmit = async () => {\n setIsCreatingFolder(true);\n const { data, error } = await createFolder({ title });\n\n if (error) {\n notifyApp.error('Failed to create folder');\n } else if (data) {\n onCreate({ title: data.title, uid: data.uid });\n notifyApp.success('Folder created');\n }\n setIsCreatingFolder(false);\n };\n\n return (\n <Modal\n className={styles.modal}\n isOpen\n title={t('alerting.create-new-folder.title-new-folder', 'New folder')}\n onDismiss={onClose}\n onClickBackdrop={onClose}\n >\n <Stack direction=\"column\" gap={2}>\n <Field\n label={\n <Label htmlFor=\"folder\">\n <Trans i18nKey=\"alerting.create-new-folder.folder.name\">Folder name</Trans>\n </Label>\n }\n >\n <Input\n data-testid={selectors.components.AlertRules.newFolderNameField}\n autoFocus={true}\n id=\"folderName\"\n placeholder={t('alerting.create-new-folder.placeholder-enter-a-name', 'Enter a name')}\n value={title}\n onChange={(e) => setTitle(e.currentTarget.value)}\n />\n </Field>\n\n <Modal.ButtonRow>\n <Button variant=\"secondary\" type=\"button\" onClick={onClose}>\n <Trans i18nKey=\"alerting.create-new-folder.folder.cancel\">Cancel</Trans>\n </Button>\n <Button\n onClick={onSubmit}\n disabled={!title || isCreatingFolder}\n data-testid={selectors.components.AlertRules.newFolderNameCreateButton}\n >\n <Trans i18nKey=\"alerting.create-new-folder.folder.create\">Create</Trans>\n </Button>\n </Modal.ButtonRow>\n </Stack>\n </Modal>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n modal: css({\n width: `${theme.breakpoints.values.sm}px`,\n }),\n});\n","import { PanelData } from '@grafana/data';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { RuleFormType } from './rule-form';\n\nexport type PreviewRuleRequest = GrafanaPreviewRuleRequest | CloudPreviewRuleRequest;\n\nexport type GrafanaPreviewRuleRequest = {\n grafana_condition: {\n condition: string;\n data: AlertQuery[];\n now: string;\n };\n};\n\nexport type CloudPreviewRuleRequest = {\n dataSourceUid: string;\n dataSourceName: string;\n expr: string;\n};\n\nexport type PreviewRuleResponse = {\n ruleType: RuleFormType;\n data: PanelData;\n};\n\nexport function isCloudPreviewRequest(request: PreviewRuleRequest): request is CloudPreviewRuleRequest {\n return 'expr' in request;\n}\n\nexport function isGrafanaPreviewRequest(request: PreviewRuleRequest): request is GrafanaPreviewRuleRequest {\n return 'grafana_condition' in request;\n}\n","import { Observable, of } from 'rxjs';\nimport { catchError, map, share } from 'rxjs/operators';\n\nimport {\n DataFrameJSON,\n LoadingState,\n PanelData,\n dataFrameFromJSON,\n getDefaultTimeRange,\n withLoadingIndicator,\n} from '@grafana/data';\nimport { getBackendSrv, toDataQueryError } from '@grafana/runtime';\n\nimport {\n PreviewRuleRequest,\n PreviewRuleResponse,\n isCloudPreviewRequest,\n isGrafanaPreviewRequest,\n} from '../types/preview';\nimport { RuleFormType } from '../types/rule-form';\nimport { GRAFANA_RULES_SOURCE_NAME } from '../utils/datasource';\n\nexport function previewAlertRule(request: PreviewRuleRequest): Observable<PreviewRuleResponse> {\n if (isCloudPreviewRequest(request)) {\n return fetchAlertRulePreview(request, request.dataSourceUid, RuleFormType.cloudAlerting);\n }\n\n if (isGrafanaPreviewRequest(request)) {\n return fetchAlertRulePreview(request, GRAFANA_RULES_SOURCE_NAME, RuleFormType.grafana);\n }\n\n throw new Error('unsupported preview rule request');\n}\n\ntype AlertRulePreviewResponse = {\n instances: DataFrameJSON[];\n};\n\nfunction fetchAlertRulePreview(\n request: PreviewRuleRequest,\n dataSourceUid: string,\n ruleType: RuleFormType\n): Observable<PreviewRuleResponse> {\n return withLoadingIndicator({\n whileLoading: createResponse(ruleType),\n source: getBackendSrv()\n .fetch<AlertRulePreviewResponse>({\n method: 'POST',\n url: `/api/v1/rule/test/${dataSourceUid}`,\n data: request,\n })\n .pipe(\n map(({ data }) => {\n return createResponse(ruleType, {\n state: LoadingState.Done,\n series: data.instances.map(dataFrameFromJSON),\n });\n }),\n catchError((error: Error) => {\n return of(\n createResponse(ruleType, {\n state: LoadingState.Error,\n error: toDataQueryError(error),\n })\n );\n }),\n share()\n ),\n });\n}\n\nfunction createResponse(ruleType: RuleFormType, data: Partial<PanelData> = {}): PreviewRuleResponse {\n return {\n ruleType,\n data: {\n state: LoadingState.Loading,\n series: [],\n timeRange: getDefaultTimeRange(),\n ...data,\n },\n };\n}\n","import { css } from '@emotion/css';\nimport * as React from 'react';\nimport AutoSizer from 'react-virtualized-auto-sizer';\n\nimport { FieldConfigSource, FieldMatcherID, GrafanaTheme2, LoadingState } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { PanelRenderer } from '@grafana/runtime';\nimport { TableCellDisplayMode, useStyles2 } from '@grafana/ui';\n\nimport { PreviewRuleResponse } from '../../types/preview';\nimport { RuleFormType } from '../../types/rule-form';\nimport { messageFromError } from '../../utils/redux';\n\ntype Props = {\n preview: PreviewRuleResponse | undefined;\n};\n\nexport function PreviewRuleResult(props: Props): React.ReactElement | null {\n const { preview } = props;\n const styles = useStyles2(getStyles);\n\n const fieldConfig: FieldConfigSource = {\n defaults: {},\n overrides: [\n {\n matcher: { id: FieldMatcherID.byName, options: 'Info' },\n properties: [{ id: 'custom.displayMode', value: TableCellDisplayMode.JSONView }],\n },\n ],\n };\n\n if (!preview) {\n return null;\n }\n\n const { data, ruleType } = preview;\n\n if (data.state === LoadingState.Loading) {\n return (\n <div className={styles.container}>\n <span>\n <Trans i18nKey=\"alerting.preview-rule-result.loading-preview\">Loading preview...</Trans>\n </span>\n </div>\n );\n }\n\n if (data.state === LoadingState.Error) {\n return (\n <div className={styles.container}>\n {data.error\n ? messageFromError(data.error)\n : t('alerting.preview-rule-result.preview-failed', 'Failed to preview alert rule')}\n </div>\n );\n }\n\n return (\n <div className={styles.container}>\n <Trans i18nKey=\"alerting.preview-rule-result.preview-based-on-query-result\">\n Preview based on the result of running the query, for this moment.\n </Trans>\n {ruleType === RuleFormType.grafana && (\n <Trans i18nKey=\"alerting.preview-rule-result.no-data-error-handling-not-applied\">\n Configuration for `no data` and `error handling` is not applied.\n </Trans>\n )}\n <div className={styles.table}>\n <AutoSizer>\n {({ width, height }) => (\n <div style={{ width: `${width}px`, height: `${height}px` }}>\n <PanelRenderer\n title=\"\"\n width={width}\n height={height}\n pluginId=\"table\"\n data={data}\n fieldConfig={fieldConfig}\n />\n </div>\n )}\n </AutoSizer>\n </div>\n </div>\n );\n}\n\nfunction getStyles(theme: GrafanaTheme2) {\n return {\n container: css({\n margin: `${theme.spacing(2)} 0`,\n }),\n table: css({\n flex: '1 1 auto',\n height: '135px',\n marginTop: theme.spacing(2),\n border: `1px solid ${theme.colors.border.medium}`,\n borderRadius: theme.shape.radius.default,\n }),\n };\n}\n","import { css } from '@emotion/css';\nimport * as React from 'react';\nimport { useCallback, useState } from 'react';\nimport { useFormContext } from 'react-hook-form';\nimport { useMountedState } from 'react-use';\nimport { takeWhile } from 'rxjs/operators';\n\nimport { GrafanaTheme2, LoadingState, dateTimeFormatISO } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { getDataSourceSrv } from '@grafana/runtime';\nimport { Alert, Button, Stack, useStyles2 } from '@grafana/ui';\n\nimport { previewAlertRule } from '../../api/preview';\nimport { useAlertQueriesStatus } from '../../hooks/useAlertQueriesStatus';\nimport { PreviewRuleRequest, PreviewRuleResponse } from '../../types/preview';\nimport { RuleFormType, RuleFormValues } from '../../types/rule-form';\nimport { isDataSourceManagedRuleByType } from '../../utils/rules';\n\nimport { PreviewRuleResult } from './PreviewRuleResult';\n\nconst fields: Array<keyof RuleFormValues> = ['type', 'dataSourceName', 'condition', 'queries', 'expression'];\n\nexport function PreviewRule(): React.ReactElement | null {\n const styles = useStyles2(getStyles);\n const [preview, onPreview] = usePreview();\n const { watch } = useFormContext<RuleFormValues>();\n const [type, condition, queries] = watch(['type', 'condition', 'queries']);\n const { allDataSourcesAvailable } = useAlertQueriesStatus(queries);\n\n if (!type || isDataSourceManagedRuleByType(type)) {\n return null;\n }\n\n const isPreviewAvailable = Boolean(condition) && allDataSourcesAvailable;\n\n return (\n <div className={styles.container}>\n <Stack>\n {allDataSourcesAvailable && (\n <Button disabled={!isPreviewAvailable} type=\"button\" variant=\"primary\" onClick={onPreview}>\n <Trans i18nKey=\"alerting.preview-rule.preview-alerts\">Preview alerts</Trans>\n </Button>\n )}\n {!allDataSourcesAvailable && (\n <Alert\n title={t('alerting.preview-rule.title-preview-is-not-available', 'Preview is not available')}\n severity=\"warning\"\n >\n <Trans i18nKey=\"alerting.preview-rule.body-preview-is-not-available\">\n Cannot display the query preview. Some of the data sources used in the queries are not available.\n </Trans>\n </Alert>\n )}\n </Stack>\n <PreviewRuleResult preview={preview} />\n </div>\n );\n}\n\nexport function usePreview(): [PreviewRuleResponse | undefined, () => void] {\n const [preview, setPreview] = useState<PreviewRuleResponse | undefined>();\n const { getValues } = useFormContext<RuleFormValues>();\n const isMounted = useMountedState();\n\n const onPreview = useCallback(() => {\n const values = getValues(fields);\n const request = createPreviewRequest(values);\n\n previewAlertRule(request)\n .pipe(takeWhile((response) => !isCompleted(response), true))\n .subscribe((response) => {\n if (!isMounted()) {\n return;\n }\n setPreview(response);\n });\n }, [getValues, isMounted]);\n\n return [preview, onPreview];\n}\n\nfunction createPreviewRequest(values: any[]): PreviewRuleRequest {\n const [type, dataSourceName, condition, queries, expression] = values;\n const dsSettings = getDataSourceSrv().getInstanceSettings(dataSourceName);\n if (!dsSettings) {\n throw new Error(`Cannot find data source settings for ${dataSourceName}`);\n }\n\n switch (type) {\n case RuleFormType.cloudAlerting:\n return {\n dataSourceUid: dsSettings.uid,\n dataSourceName,\n expr: expression,\n };\n\n case RuleFormType.grafana:\n return {\n grafana_condition: {\n condition,\n data: queries,\n now: dateTimeFormatISO(Date.now()),\n },\n };\n\n default:\n throw new Error(`Alert type ${type} not supported by preview.`);\n }\n}\n\nfunction isCompleted(response: PreviewRuleResponse): boolean {\n switch (response.data.state) {\n case LoadingState.Done:\n case LoadingState.Error:\n return true;\n default:\n return false;\n }\n}\n\nfunction getStyles(theme: GrafanaTheme2) {\n return {\n container: css({\n marginTop: theme.spacing(2),\n maxWidth: `${theme.breakpoints.values.xxl}px`,\n }),\n };\n}\n","import { DataFrame } from '@grafana/data';\n\nimport { GrafanaAlertState, Labels, isGrafanaAlertState } from '../../../../../types/unified-alerting-dto';\n\ninterface AlertPreviewInstance {\n state: GrafanaAlertState;\n info?: string;\n labels: Labels;\n}\n\ninterface AlertPreview {\n instances: AlertPreviewInstance[];\n}\n\n// Alerts previews come in a DataFrame format which is more suited for displaying time series data\n// In order to display a list of tags we need to transform DataFrame into set of labels\nexport function mapDataFrameToAlertPreview({ fields }: DataFrame): AlertPreview {\n const labelFields = fields.filter((field) => !['State', 'Info'].includes(field.name));\n const stateFieldIndex = fields.findIndex((field) => field.name === 'State');\n const infoFieldIndex = fields.findIndex((field) => field.name === 'Info');\n\n const labelIndexes = labelFields.map((labelField) => fields.indexOf(labelField));\n\n const instanceStatusCount = fields[stateFieldIndex]?.values.length ?? 0;\n\n const instances: AlertPreviewInstance[] = [];\n\n for (let index = 0; index < instanceStatusCount; index++) {\n const labelValues = labelIndexes.map((labelIndex) => [fields[labelIndex].name, fields[labelIndex].values[index]]);\n const state = fields[stateFieldIndex]?.values?.[index];\n const info = fields[infoFieldIndex]?.values?.[index];\n\n if (isGrafanaAlertState(state)) {\n instances.push({\n state: state,\n info: info,\n labels: Object.fromEntries(labelValues),\n });\n }\n }\n\n return { instances };\n}\n","import { css } from '@emotion/css';\n\nimport { DataFrame, GrafanaTheme2 } from '@grafana/data';\nimport { Trans } from '@grafana/i18n';\nimport { Icon, TagList, Tooltip, useStyles2 } from '@grafana/ui';\n\nimport { labelsToTags } from '../../utils/labels';\nimport { AlertStateTag } from '../rules/AlertStateTag';\n\nimport { mapDataFrameToAlertPreview } from './preview';\n\ninterface CloudAlertPreviewProps {\n preview: DataFrame;\n}\n\nexport function CloudAlertPreview({ preview }: CloudAlertPreviewProps) {\n const styles = useStyles2(getStyles);\n const alertPreview = mapDataFrameToAlertPreview(preview);\n\n return (\n <table className={styles.table}>\n <caption>\n <div>\n <Trans i18nKey=\"alerting.cloud-alert-preview.alerts-preview\">Alerts preview</Trans>\n </div>\n <span>\n <Trans i18nKey=\"alerting.cloud-alert-preview.running-query-preview\">\n Preview based on the result of running the query for this moment.\n </Trans>\n </span>\n </caption>\n <thead>\n <tr>\n <th>\n <Trans i18nKey=\"alerting.cloud-alert-preview.state\">State</Trans>\n </th>\n <th>\n <Trans i18nKey=\"alerting.cloud-alert-preview.labels\">Labels</Trans>\n </th>\n <th>\n <Trans i18nKey=\"alerting.cloud-alert-preview.info\">Info</Trans>\n </th>\n </tr>\n </thead>\n <tbody>\n {alertPreview.instances.map(({ state, info, labels }, index) => {\n const instanceTags = labelsToTags(labels);\n\n return (\n <tr key={index}>\n <td>{<AlertStateTag state={state} />}</td>\n <td>\n <TagList tags={instanceTags} className={styles.tagList} />\n </td>\n <td>\n {info && (\n <Tooltip content={info}>\n <Icon name=\"info-circle\" />\n </Tooltip>\n )}\n </td>\n </tr>\n );\n })}\n </tbody>\n </table>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n table: css({\n width: '100%',\n margin: theme.spacing(2, 0),\n\n caption: {\n captionSide: 'top',\n color: theme.colors.text.primary,\n\n '& > span': {\n fontSize: theme.typography.bodySmall.fontSize,\n color: theme.colors.text.secondary,\n },\n },\n\n 'td, th': {\n padding: theme.spacing(1, 1),\n },\n\n 'td + td, th + th': {\n paddingLeft: theme.spacing(3),\n },\n\n 'thead th': {\n '&:nth-child(1)': {\n width: '80px',\n },\n\n '&:nth-child(2)': {\n width: 'auto',\n },\n\n '&:nth-child(3)': {\n width: '40px',\n },\n },\n\n 'td:nth-child(3)': {\n textAlign: 'center',\n },\n\n 'tbody tr:nth-child(2n + 1)': {\n backgroundColor: theme.colors.background.secondary,\n },\n }),\n tagList: css({\n justifyContent: 'flex-start',\n }),\n});\n","import { css } from '@emotion/css';\nimport { noop } from 'lodash';\nimport { useCallback, useMemo } from 'react';\nimport { useAsync } from 'react-use';\n\nimport { CoreApp, DataSourcePluginContextProvider, GrafanaTheme2, LoadingState } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { PromQuery } from '@grafana/prometheus';\nimport { getDataSourceSrv } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport { Alert, Button, useStyles2 } from '@grafana/ui';\nimport { LokiQuery } from 'app/plugins/datasource/loki/types';\n\nimport { isSupportedExternalRulesSourceType } from '../../utils/datasource';\n\nimport { CloudAlertPreview } from './CloudAlertPreview';\nimport { usePreview } from './PreviewRule';\n\nexport interface ExpressionEditorProps {\n value?: string;\n onChange: (value: string) => void;\n dataSourceName: string; // will be a prometheus or loki datasource\n showPreviewAlertsButton: boolean;\n}\n\nexport const ExpressionEditor = ({\n value,\n onChange,\n dataSourceName,\n showPreviewAlertsButton = true,\n}: ExpressionEditorProps) => {\n const styles = useStyles2(getStyles);\n\n const { mapToValue, mapToQuery } = useQueryMappers(dataSourceName);\n\n const dataQuery = mapToQuery({ refId: 'A', hide: false }, value);\n\n const {\n error,\n loading,\n value: dataSource,\n } = useAsync(() => {\n return getDataSourceSrv().get(dataSourceName);\n }, [dataSourceName]);\n\n const onChangeQuery = useCallback(\n (query: DataQuery) => {\n onChange(mapToValue(query));\n },\n [onChange, mapToValue]\n );\n\n const [alertPreview, onPreview] = usePreview();\n\n const onRunQueriesClick = async () => {\n onPreview();\n };\n\n if (loading || dataSource?.name !== dataSourceName) {\n return null;\n }\n\n const dsi = getDataSourceSrv().getInstanceSettings(dataSourceName);\n\n if (error || !dataSource || !dataSource?.components?.QueryEditor || !dsi) {\n const errorMessage =\n error?.message ||\n t(\n 'alerting.expression-editor.error-no-component',\n 'Data source plugin does not export any Query Editor component'\n );\n return (\n <div>\n <Trans i18nKey=\"alerting.expression-editor.could-not-load-editor\">\n Could not load query editor due to: {{ errorMessage }}\n </Trans>\n </div>\n );\n }\n\n const previewLoaded = alertPreview?.data.state === LoadingState.Done;\n\n const QueryEditor = dataSource?.components?.QueryEditor;\n\n // The Preview endpoint returns the preview as a single-element array of data frames\n const previewDataFrame = alertPreview?.data?.series?.find((s) => s.name === 'evaluation results');\n // The preview API returns arrays with empty elements when there are no firing alerts\n const previewHasAlerts = previewDataFrame && previewDataFrame.fields.some((field) => field.values.length > 0);\n\n return (\n <>\n <DataSourcePluginContextProvider instanceSettings={dsi}>\n <QueryEditor\n query={dataQuery}\n queries={[dataQuery]}\n app={CoreApp.CloudAlerting}\n onChange={onChangeQuery}\n onRunQuery={noop}\n datasource={dataSource}\n />\n </DataSourcePluginContextProvider>\n {showPreviewAlertsButton && (\n <div className={styles.preview}>\n <Button\n type=\"button\"\n onClick={onRunQueriesClick}\n disabled={alertPreview?.data.state === LoadingState.Loading}\n >\n <Trans i18nKey=\"alerting.expression-editor.preview-alerts\">Preview alerts</Trans>\n </Button>\n {previewLoaded && !previewHasAlerts && (\n <Alert\n title={t('alerting.expression-editor.title-alerts-preview', 'Alerts preview')}\n severity=\"info\"\n className={styles.previewAlert}\n >\n <Trans i18nKey=\"alerting.expression-editor.there-firing-alerts-query\">\n There are no firing alerts for your query.\n </Trans>\n </Alert>\n )}\n {previewHasAlerts && <CloudAlertPreview preview={previewDataFrame} />}\n </div>\n )}\n </>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n preview: css({\n padding: theme.spacing(2, 0),\n maxWidth: `${theme.breakpoints.values.xl}px`,\n }),\n previewAlert: css({\n margin: theme.spacing(1, 0),\n }),\n});\n\ntype QueryMappers<T extends DataQuery = DataQuery> = {\n mapToValue: (query: T) => string;\n mapToQuery: (existing: T, value: string | undefined) => T;\n};\n\nexport function useQueryMappers(dataSourceName: string): QueryMappers {\n return useMemo(() => {\n const settings = getDataSourceSrv().getInstanceSettings(dataSourceName);\n if (!settings) {\n throw new Error(`Datasource ${dataSourceName} not found`);\n }\n\n if (!isSupportedExternalRulesSourceType(settings.type)) {\n throw new Error(`${settings.type} is not supported as an expression editor`);\n }\n\n return {\n mapToValue: (query: DataQuery) => (query as PromQuery | LokiQuery).expr,\n mapToQuery: (existing: DataQuery, value: string | undefined) => ({ ...existing, expr: value }),\n };\n }, [dataSourceName]);\n}\n","import { css } from '@emotion/css';\nimport { useMemo } from 'react';\n\nimport { GrafanaTheme2, PanelData } from '@grafana/data';\nimport { useStyles2 } from '@grafana/ui';\nimport { isExpressionQuery } from 'app/features/expressions/guards';\nimport { ExpressionQuery, ExpressionQueryType } from 'app/features/expressions/types';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { Expression } from '../expressions/Expression';\n\nimport { errorFromCurrentCondition, errorFromPreviewData, warningFromSeries } from './util';\n\ninterface Props {\n condition: string | null;\n onSetCondition: (refId: string) => void;\n panelData: Record<string, PanelData | undefined>;\n queries: AlertQuery[];\n onRemoveExpression: (refId: string) => void;\n onUpdateRefId: (oldRefId: string, newRefId: string) => void;\n onUpdateExpressionType: (refId: string, type: ExpressionQueryType) => void;\n onUpdateQueryExpression: (query: ExpressionQuery) => void;\n}\n\nexport const ExpressionsEditor = ({\n condition,\n onSetCondition,\n queries,\n panelData,\n onUpdateRefId,\n onRemoveExpression,\n onUpdateExpressionType,\n onUpdateQueryExpression,\n}: Props) => {\n const expressionQueries = useMemo(() => {\n return queries.reduce((acc: ExpressionQuery[], query) => {\n return isExpressionQuery(query.model) ? acc.concat(query.model) : acc;\n }, []);\n }, [queries]);\n const styles = useStyles2(getStyles);\n\n return (\n <div className={styles.wrapper}>\n {expressionQueries.map((query) => {\n const data = panelData[query.refId];\n\n const isAlertCondition = condition === query.refId;\n\n const errorFromCondition = data && isAlertCondition ? errorFromCurrentCondition(data) : undefined;\n const errorFromPreview = data ? errorFromPreviewData(data) : undefined;\n const error = errorFromPreview || errorFromCondition;\n\n const warning = data ? warningFromSeries(data.series) : undefined;\n\n return (\n <Expression\n key={query.refId}\n isAlertCondition={isAlertCondition}\n data={data}\n error={error}\n warning={warning}\n queries={queries}\n query={query}\n onSetCondition={onSetCondition}\n onRemoveExpression={onRemoveExpression}\n onUpdateRefId={onUpdateRefId}\n onUpdateExpressionType={onUpdateExpressionType}\n onChangeQuery={onUpdateQueryExpression}\n />\n );\n })}\n </div>\n );\n};\nconst getStyles = (theme: GrafanaTheme2) => ({\n wrapper: css({\n display: 'flex',\n gap: theme.spacing(2),\n alignContent: 'stretch',\n flexWrap: 'wrap',\n }),\n});\n","import { ReactElement } from 'react';\n\nimport { locationUtil } from '@grafana/data';\nimport { Trans } from '@grafana/i18n';\nimport { locationService } from '@grafana/runtime';\nimport { Button, Modal, Stack } from '@grafana/ui';\n\ntype Props = {\n onDismiss: () => void;\n path: string;\n title: string;\n};\n\nexport function ConfirmNavigationModal(props: Props): ReactElement {\n const { onDismiss, path, title } = props;\n const openInNewTab = () => {\n global.open(locationUtil.assureBaseUrl(path), '_blank');\n onDismiss();\n };\n const openInCurrentTab = () => locationService.push(path);\n\n return (\n <Modal title={title} isOpen onDismiss={onDismiss}>\n <Stack direction=\"column\" gap={1}>\n <p>\n <Trans i18nKey=\"explore.confirm-navigation-modal.new-tab\">\n Do you want to proceed in the current tab or open a new tab?\n </Trans>\n </p>\n </Stack>\n <Modal.ButtonRow>\n <Button onClick={onDismiss} fill=\"outline\" variant=\"secondary\">\n <Trans i18nKey=\"explore.confirm-navigation-modal.cancel\">Cancel</Trans>\n </Button>\n <Button type=\"submit\" variant=\"secondary\" onClick={openInNewTab} icon=\"external-link-alt\">\n <Trans i18nKey=\"explore.confirm-navigation-modal.open-in-new-tab\">Open in new tab</Trans>\n </Button>\n <Button type=\"submit\" variant=\"primary\" onClick={openInCurrentTab} icon=\"apps\">\n <Trans i18nKey=\"explore.confirm-navigation-modal.open\">Open</Trans>\n </Button>\n </Modal.ButtonRow>\n </Modal>\n );\n}\n","import { ReactElement, useMemo } from 'react';\n\nimport { PluginExtensionLink } from '@grafana/data';\nimport { Menu } from '@grafana/ui';\n\ntype Props = {\n extensions: PluginExtensionLink[];\n onSelect: (extension: PluginExtensionLink) => void;\n};\n\nexport function AlertingRuleExtensionPointMenu({ extensions, onSelect }: Props): ReactElement | null {\n const { categorised, uncategorised } = useExtensionLinksByCategory(extensions);\n const showDivider = uncategorised.length > 0 && Object.keys(categorised).length > 0;\n\n return (\n <Menu>\n <>\n {Object.keys(categorised).map((category) => (\n <Menu.Group key={category} label={category}>\n {renderItems(categorised[category], onSelect)}\n </Menu.Group>\n ))}\n {showDivider && <Menu.Divider key=\"divider\" />}\n {renderItems(uncategorised, onSelect)}\n </>\n </Menu>\n );\n}\n\nfunction renderItems(extensions: PluginExtensionLink[], onSelect: (link: PluginExtensionLink) => void): JSX.Element[] {\n return extensions.map((extension) => (\n <Menu.Item\n ariaLabel={extension.title}\n icon={extension?.icon || 'plug'}\n key={extension.id}\n label={extension.title}\n onClick={(event) => {\n if (extension.path) {\n return onSelect(extension);\n }\n extension.onClick?.(event);\n }}\n />\n ));\n}\n\ntype ExtensionLinksResult = {\n uncategorised: PluginExtensionLink[];\n categorised: Record<string, PluginExtensionLink[]>;\n};\n\nfunction useExtensionLinksByCategory(extensions: PluginExtensionLink[]): ExtensionLinksResult {\n return useMemo(() => {\n const uncategorised: PluginExtensionLink[] = [];\n const categorised: Record<string, PluginExtensionLink[]> = {};\n\n for (const link of extensions) {\n if (!link.category) {\n uncategorised.push(link);\n continue;\n }\n\n if (!Array.isArray(categorised[link.category])) {\n categorised[link.category] = [];\n }\n categorised[link.category].push(link);\n continue;\n }\n\n return {\n uncategorised,\n categorised,\n };\n }, [extensions]);\n}\n","import { first } from 'lodash';\n\nimport { PluginExtensionLink } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Dropdown, ToolbarButton } from '@grafana/ui';\n\nimport { AlertingRuleExtensionPointMenu } from './AlertingRuleExtensionPointMenu';\n\nexport type ExtensionDropdownProps = {\n links: PluginExtensionLink[];\n setSelectedExtension: (extension: PluginExtensionLink) => void;\n setIsModalOpen: (value: boolean) => void;\n isModalOpen: boolean;\n};\n\nexport function QuerylessAppsExtensions(props: ExtensionDropdownProps) {\n const { links, setSelectedExtension, setIsModalOpen, isModalOpen } = props;\n\n if (links.length === 0) {\n return undefined;\n }\n\n const menu = <AlertingRuleExtensionPointMenu extensions={links} onSelect={setSelectedExtension} />;\n\n if (links.length === 1) {\n const link = first(links)!;\n return (\n <ToolbarButton variant=\"canvas\" icon={link.icon} onClick={() => setSelectedExtension(link)}>\n <Trans i18nKey=\"explore.toolbar.add-to-queryless-extensions\">Go queryless</Trans>\n </ToolbarButton>\n );\n }\n\n return (\n <Dropdown onVisibleChange={setIsModalOpen} placement=\"bottom-start\" overlay={menu}>\n <ToolbarButton\n aria-label={t('explore.queryless-apps-extensions.aria-label-go-queryless', 'Go queryless')}\n variant=\"canvas\"\n isOpen={isModalOpen}\n >\n <Trans i18nKey=\"explore.toolbar.add-to-queryless-extensions\">Go queryless</Trans>\n </ToolbarButton>\n </Dropdown>\n );\n}\n","import { ReactElement, useState } from 'react';\n\nimport { PluginExtensionLink, PluginExtensionPoints } from '@grafana/data';\n// import { Trans, t } from '@grafana/i18n';\nimport { usePluginLinks } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\n// import { Button } from '@grafana/ui';\n\nimport { ConfirmNavigationModal } from './ConfirmationNavigationModal';\nimport { QuerylessAppsExtensions } from './QuerylessAppExtensions';\n\ntype Props = {\n extensionsToShow: 'queryless';\n query: DataQuery;\n};\n\nconst QUERYLESS_APPS = [\n 'grafana-pyroscope-app',\n 'grafana-lokiexplore-app',\n 'grafana-exploretraces-app',\n 'grafana-metricsdrilldown-app',\n];\n\n// Map data source types to compatible queryless apps\nconst DATASOURCE_TO_QUERYLESS_APP: Record<string, string[]> = {\n prometheus: ['grafana-metricsdrilldown-app'],\n // todo: add more data source types here\n // 'pyroscope': ['grafana-pyroscope-app'],\n // 'loki': ['grafana-lokiexplore-app'],\n // 'tempo': ['grafana-exploretraces-app'],\n};\n\nexport type PluginExtensionAlertingRuleContext = {\n targets: DataQuery[];\n // TODO: add rule form values for creating alerting rule from drilldown apps\n};\n\nexport function AlertingRuleQueryExtensionPoint({ extensionsToShow, query }: Props): ReactElement | null {\n const [selectedExtension, setSelectedExtension] = useState<PluginExtensionLink | undefined>();\n const [isModalOpen, setIsModalOpen] = useState<boolean>(false);\n\n const context: PluginExtensionAlertingRuleContext = {\n targets: [query],\n };\n\n const { links } = usePluginLinks({\n extensionPointId: PluginExtensionPoints.AlertingRuleQueryEditor,\n context: context,\n limitPerPlugin: 3,\n });\n\n // filter the link so that the query data source matches the queryless app data source\n // we only want one link per query row editor for now\n // but we can show an array of links for more flexibility in the future\n const querylessLinks = links.filter((link) => {\n if (!QUERYLESS_APPS.includes(link.pluginId)) {\n return false;\n }\n\n // Get the data source type from the query\n const datasourceType = query.datasource?.type;\n if (!datasourceType) {\n return false;\n }\n\n // Check if this queryless app is compatible with the data source type\n const compatibleApps = DATASOURCE_TO_QUERYLESS_APP[datasourceType.toLowerCase()] || [];\n return compatibleApps.includes(link.pluginId);\n });\n\n return (\n <>\n {extensionsToShow === 'queryless' && (\n <QuerylessAppsExtensions\n links={querylessLinks}\n setSelectedExtension={(extension) => {\n setSelectedExtension(extension);\n }}\n setIsModalOpen={setIsModalOpen}\n isModalOpen={isModalOpen}\n />\n )}\n {/* TODO: add basic extensions */}\n {!!selectedExtension && !!selectedExtension.path && (\n <ConfirmNavigationModal\n path={selectedExtension.path}\n title={selectedExtension.title}\n onDismiss={() => setSelectedExtension(undefined)}\n />\n )}\n </>\n );\n}\n","import { css } from '@emotion/css';\nimport { useState } from 'react';\n\nimport { GrafanaTheme2, RelativeTimeRange, getDefaultRelativeTimeRange } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Icon, InlineField, RelativeTimeRangePicker, Toggletip, clearButtonStyles, useStyles2 } from '@grafana/ui';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { TimeRangeLabel } from '../TimeRangeLabel';\n\nimport { AlertQueryOptions, MaxDataPointsOption, MinIntervalOption } from './QueryWrapper';\n\nexport interface QueryOptionsProps {\n query: AlertQuery;\n queryOptions: AlertQueryOptions;\n onChangeTimeRange?: (timeRange: RelativeTimeRange, index: number) => void;\n onChangeQueryOptions: (options: AlertQueryOptions, index: number) => void;\n index: number;\n}\n\nexport const QueryOptions = ({\n query,\n queryOptions,\n onChangeTimeRange,\n onChangeQueryOptions,\n index,\n}: QueryOptionsProps) => {\n const styles = useStyles2(getStyles);\n\n const [showOptions, setShowOptions] = useState(false);\n\n const separator = <span>, </span>;\n\n return (\n <>\n <Toggletip\n content={\n <div className={styles.queryOptions}>\n {onChangeTimeRange && (\n <InlineField label={t('alerting.query-options.label-time-range', 'Time Range')}>\n <RelativeTimeRangePicker\n timeRange={query.relativeTimeRange ?? getDefaultRelativeTimeRange()}\n onChange={(range) => onChangeTimeRange(range, index)}\n />\n </InlineField>\n )}\n <MaxDataPointsOption options={queryOptions} onChange={(options) => onChangeQueryOptions(options, index)} />\n <MinIntervalOption options={queryOptions} onChange={(options) => onChangeQueryOptions(options, index)} />\n </div>\n }\n closeButton={true}\n placement=\"bottom-start\"\n >\n <button type=\"button\" className={styles.actionLink} onClick={() => setShowOptions(!showOptions)}>\n <Trans i18nKey=\"alerting.query-options.button-options\">Options</Trans>{' '}\n {showOptions ? <Icon name=\"angle-right\" /> : <Icon name=\"angle-down\" />}\n </button>\n </Toggletip>\n\n <div className={styles.staticValues}>\n <span>\n <TimeRangeLabel relativeTimeRange={query.relativeTimeRange ?? getDefaultRelativeTimeRange()} />\n </span>\n\n {queryOptions.maxDataPoints && (\n <>\n {separator}\n <Trans\n i18nKey=\"alerting.query-options.max-data-points\"\n values={{ maxDataPoints: queryOptions.maxDataPoints }}\n >\n MD = {'{{maxDataPoints}}'}\n </Trans>\n </>\n )}\n {queryOptions.minInterval && (\n <>\n {separator}\n <Trans i18nKey=\"alerting.query-options.min-interval\" values={{ minInterval: queryOptions.minInterval }}>\n Min. Interval = {'{{minInterval}}'}\n </Trans>\n </>\n )}\n </div>\n </>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => {\n const clearButton = clearButtonStyles(theme);\n\n return {\n queryOptions: css({\n '> div': {\n justifyContent: 'space-between',\n },\n }),\n\n staticValues: css({\n color: theme.colors.text.secondary,\n marginRight: theme.spacing(1),\n }),\n\n actionLink: css(clearButton, {\n color: theme.colors.text.link,\n cursor: 'pointer',\n\n '&:hover': {\n textDecoration: 'underline',\n },\n }),\n };\n};\n","import { css } from '@emotion/css';\nimport { cloneDeep } from 'lodash';\nimport * as React from 'react';\nimport { ChangeEvent, useState } from 'react';\nimport { useFormContext } from 'react-hook-form';\n\nimport {\n CoreApp,\n DataSourceApi,\n DataSourceInstanceSettings,\n GrafanaTheme2,\n LoadingState,\n PanelData,\n RelativeTimeRange,\n ThresholdsConfig,\n getDefaultRelativeTimeRange,\n rangeUtil,\n} from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport { GraphThresholdsStyleMode, Icon, InlineField, Input, Stack, Tooltip, useStyles2 } from '@grafana/ui';\nimport { logInfo } from 'app/features/alerting/unified/Analytics';\nimport { QueryEditorRow } from 'app/features/query/components/QueryEditorRow';\nimport { AlertDataQuery, AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { RuleFormValues } from '../../types/rule-form';\nimport { msToSingleUnitDuration } from '../../utils/time';\nimport { ExpressionStatusIndicator } from '../expressions/ExpressionStatusIndicator';\nimport { AlertingRuleQueryExtensionPoint } from '../extensions/AlertingRuleQueryExtensionPoint';\n\nimport { QueryOptions } from './QueryOptions';\nimport { VizWrapper } from './VizWrapper';\n\nexport const DEFAULT_MAX_DATA_POINTS = 43200;\nexport const DEFAULT_MIN_INTERVAL = '1s';\n\nexport interface AlertQueryOptions {\n maxDataPoints?: number | undefined;\n minInterval?: string | undefined;\n}\n\ninterface Props {\n data: PanelData;\n error?: Error;\n query: AlertQuery;\n queries: AlertQuery[];\n dsSettings: DataSourceInstanceSettings;\n onChangeDataSource: (settings: DataSourceInstanceSettings, index: number) => void;\n onChangeQuery: (query: DataQuery, index: number) => void;\n onChangeTimeRange?: (timeRange: RelativeTimeRange, index: number) => void;\n onRemoveQuery: (query: DataQuery) => void;\n onDuplicateQuery: (query: AlertQuery) => void;\n onRunQueries: () => void;\n index: number;\n thresholds: ThresholdsConfig;\n thresholdsType?: GraphThresholdsStyleMode;\n onChangeThreshold?: (thresholds: ThresholdsConfig, index: number) => void;\n condition: string | null;\n onSetCondition: (refId: string) => void;\n onChangeQueryOptions: (options: AlertQueryOptions, index: number) => void;\n}\n\nexport const QueryWrapper = ({\n data,\n error,\n dsSettings,\n index,\n onChangeDataSource,\n onChangeQuery,\n onChangeTimeRange,\n onRunQueries,\n onRemoveQuery,\n onDuplicateQuery,\n query,\n queries,\n thresholds,\n thresholdsType,\n onChangeThreshold,\n condition,\n onSetCondition,\n onChangeQueryOptions,\n}: Props) => {\n const styles = useStyles2(getStyles);\n const [dsInstance, setDsInstance] = useState<DataSourceApi>();\n const defaults = dsInstance?.getDefaultQuery ? dsInstance.getDefaultQuery(CoreApp.UnifiedAlerting) : {};\n\n const { getValues } = useFormContext<RuleFormValues>();\n const isSwitchModeEnabled = config.featureToggles.alertingQueryAndExpressionsStepMode ?? false;\n const isAdvancedMode = isSwitchModeEnabled ? getValues('editorSettings.simplifiedQueryEditor') !== true : true;\n\n const queryWithDefaults = {\n ...defaults,\n ...cloneDeep(query.model),\n };\n\n if (queryWithDefaults.datasource && queryWithDefaults.datasource?.uid !== query.datasourceUid) {\n logInfo('rule query datasource and datasourceUid mismatch', {\n queryModelDatasourceUid: queryWithDefaults.datasource?.uid || '',\n queryDatasourceUid: query.datasourceUid,\n datasourceType: query.model.datasource?.type || 'unknown type',\n });\n // There are occasions when the rule query model datasource UID and the datasourceUid do not match\n // It's unclear as to why this happens, but we need better visibility on why this happens,\n // so we log when it does, and make the query model datasource UID match the datasource UID\n // We already elsewhere work under the assumption that the datasource settings are fetched from the datasourceUid property\n\n // This check is necessary for some few cases where the datasource might be an string instead of an object\n // see: https://github.com/grafana/grafana/issues/96040 for more context\n if (typeof queryWithDefaults.datasource === 'object' && Boolean(queryWithDefaults.datasource)) {\n queryWithDefaults.datasource.uid = query.datasourceUid;\n } else {\n // if the datasource is a string, we need to convert it to an object, and populate the fields from the query model\n queryWithDefaults.datasource = {};\n queryWithDefaults.datasource.uid = query.datasourceUid;\n queryWithDefaults.datasource.type = query.model.datasource?.type;\n queryWithDefaults.datasource.apiVersion = query.model.datasource?.apiVersion;\n }\n }\n\n function SelectingDataSourceTooltip() {\n const styles = useStyles2(getStyles);\n return (\n <div className={styles.dsTooltip}>\n <Tooltip\n content={\n <Trans i18nKey=\"alerting.selecting-data-source-tooltip.tooltip-content\">\n Not finding the data source you want? Some data sources are not supported for alerting. Click on the icon\n for more information.\n </Trans>\n }\n >\n <Icon\n name=\"info-circle\"\n onClick={() =>\n window.open(\n ' https://grafana.com/docs/grafana/latest/alerting/fundamentals/data-source-alerting/',\n '_blank'\n )\n }\n />\n </Tooltip>\n </div>\n );\n }\n\n // TODO add a warning label here too when the data looks like time series data and is used as an alert condition\n function HeaderExtras({\n query,\n error,\n index,\n isAdvancedMode = true,\n }: {\n query: AlertQuery<AlertDataQuery>;\n error?: Error;\n index: number;\n isAdvancedMode?: boolean;\n }) {\n const queryOptions: AlertQueryOptions = {\n maxDataPoints: query.model.maxDataPoints,\n minInterval: query.model.intervalMs ? msToSingleUnitDuration(query.model.intervalMs) : undefined,\n };\n const alertQueryOptions: AlertQueryOptions = {\n maxDataPoints: queryOptions.maxDataPoints,\n minInterval: queryOptions.minInterval,\n };\n\n const isAlertCondition = condition === query.refId;\n\n return (\n <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n <SelectingDataSourceTooltip />\n <AlertingRuleQueryExtensionPoint query={Object.assign({}, query.model)} extensionsToShow=\"queryless\" />\n <QueryOptions\n onChangeTimeRange={onChangeTimeRange}\n query={query}\n queryOptions={alertQueryOptions}\n onChangeQueryOptions={onChangeQueryOptions}\n index={index}\n />\n {isAdvancedMode && (\n <ExpressionStatusIndicator\n onSetCondition={() => onSetCondition(query.refId)}\n isCondition={isAlertCondition}\n />\n )}\n </Stack>\n );\n }\n\n const showVizualisation = data.state !== LoadingState.NotStarted;\n // ⚠️ the query editors want the entire array of queries passed as \"DataQuery\" NOT \"AlertQuery\"\n // TypeScript isn't complaining here because the interfaces just happen to be compatible\n const editorQueries = cloneDeep(queries.map((query) => query.model));\n const range = rangeUtil.relativeToTimeRange(query.relativeTimeRange ?? getDefaultRelativeTimeRange());\n\n return (\n <Stack direction=\"column\" gap={0.5}>\n <div className={styles.wrapper}>\n <QueryEditorRow<AlertDataQuery>\n hideRefId={!isAdvancedMode}\n hideActionButtons={!isAdvancedMode}\n collapsable={false}\n dataSource={dsSettings}\n onDataSourceLoaded={setDsInstance}\n onChangeDataSource={(settings) => onChangeDataSource(settings, index)}\n id={query.refId}\n index={index}\n key={query.refId}\n data={data}\n query={queryWithDefaults}\n onChange={(query) => onChangeQuery(query, index)}\n onRemoveQuery={onRemoveQuery}\n onAddQuery={() => onDuplicateQuery(cloneDeep(query))}\n onRunQuery={onRunQueries}\n queries={editorQueries}\n range={range}\n renderHeaderExtras={() => (\n <HeaderExtras query={query} index={index} error={error} isAdvancedMode={isAdvancedMode} />\n )}\n app={CoreApp.UnifiedAlerting}\n hideHideQueryButton={true}\n />\n </div>\n {showVizualisation && <VizWrapper data={data} thresholds={thresholds} thresholdsType={thresholdsType} />}\n </Stack>\n );\n};\n\nexport const EmptyQueryWrapper = ({ children }: React.PropsWithChildren<{}>) => {\n const styles = useStyles2(getStyles);\n return <div className={styles.wrapper}>{children}</div>;\n};\n\nexport function MaxDataPointsOption({\n options,\n onChange,\n}: {\n options: AlertQueryOptions;\n onChange: (options: AlertQueryOptions) => void;\n}) {\n const value = options.maxDataPoints ?? '';\n\n const onMaxDataPointsBlur = (event: ChangeEvent<HTMLInputElement>) => {\n const maxDataPointsNumber = parseInt(event.target.value, 10);\n\n const maxDataPoints = isNaN(maxDataPointsNumber) || maxDataPointsNumber === 0 ? undefined : maxDataPointsNumber;\n\n if (maxDataPoints !== options.maxDataPoints) {\n onChange({\n ...options,\n maxDataPoints,\n });\n }\n };\n\n return (\n <InlineField\n labelWidth={24}\n label={t('alerting.max-data-points-option.label-max-data-points', 'Max data points')}\n tooltip={t(\n 'alerting.max-data-points-option.tooltip-max-data-points',\n 'The maximum data points per series. Used directly by some data sources and used in calculation of auto interval. With streaming data this value is used for the rolling buffer.'\n )}\n >\n <Input\n type=\"number\"\n width={10}\n placeholder={DEFAULT_MAX_DATA_POINTS.toString()}\n spellCheck={false}\n onBlur={onMaxDataPointsBlur}\n defaultValue={value}\n />\n </InlineField>\n );\n}\n\nexport function MinIntervalOption({\n options,\n onChange,\n}: {\n options: AlertQueryOptions;\n onChange: (options: AlertQueryOptions) => void;\n}) {\n const value = options.minInterval ?? '';\n\n const onMinIntervalBlur = (event: ChangeEvent<HTMLInputElement>) => {\n const minInterval = event.target.value;\n if (minInterval !== value) {\n onChange({\n ...options,\n minInterval,\n });\n }\n };\n\n return (\n <InlineField\n label={t('alerting.min-interval-option.label-interval', 'Interval')}\n labelWidth={24}\n tooltip={\n <Trans i18nKey=\"alerting.min-interval-option.tooltip-interval\">\n Interval sent to the data source. Recommended to be set to write frequency, for example <code>1m</code> if\n your data is written every minute.\n </Trans>\n }\n >\n <Input\n type=\"text\"\n width={10}\n placeholder={DEFAULT_MIN_INTERVAL}\n spellCheck={false}\n onBlur={onMinIntervalBlur}\n defaultValue={value}\n />\n </InlineField>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n wrapper: css({\n label: 'AlertingQueryWrapper',\n marginBottom: theme.spacing(1),\n border: `1px solid ${theme.colors.border.weak}`,\n borderRadius: theme.shape.radius.default,\n\n button: {\n overflow: 'visible',\n },\n }),\n dsTooltip: css({\n display: 'flex',\n alignItems: 'center',\n '&:hover': {\n opacity: 0.85,\n cursor: 'pointer',\n },\n }),\n});\n","import { DragDropContext, DropResult, Droppable } from '@hello-pangea/dnd';\nimport { omit } from 'lodash';\nimport { PureComponent, useState } from 'react';\n\nimport {\n DataSourceInstanceSettings,\n LoadingState,\n PanelData,\n RelativeTimeRange,\n getDataSourceRef,\n rangeUtil,\n} from '@grafana/data';\nimport { Trans } from '@grafana/i18n';\nimport { getDataSourceSrv } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport { Button, Card, Icon, Stack } from '@grafana/ui';\nimport { QueryOperationRow } from 'app/core/components/QueryOperationRow/QueryOperationRow';\nimport { isExpressionQuery } from 'app/features/expressions/guards';\nimport { getDatasourceSrv } from 'app/features/plugins/datasource_srv';\nimport { AlertDataQuery, AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { getInstantFromDataQuery } from '../../utils/rule-form';\n\nimport { AlertQueryOptions, EmptyQueryWrapper, QueryWrapper } from './QueryWrapper';\nimport { errorFromCurrentCondition, errorFromPreviewData, getThresholdsForQueries } from './util';\n\ninterface Props {\n // The query configuration\n queries: AlertQuery[];\n expressions: AlertQuery[];\n data: Record<string, PanelData>;\n onRunQueries: () => void;\n\n // Query editing\n onQueriesChange: (queries: AlertQuery[]) => void;\n onDuplicateQuery: (query: AlertQuery) => void;\n condition: string | null;\n onSetCondition: (refId: string) => void;\n}\n\nexport class QueryRows extends PureComponent<Props> {\n constructor(props: Props) {\n super(props);\n }\n\n onRemoveQuery = (query: DataQuery) => {\n const { queries, onQueriesChange } = this.props;\n onQueriesChange(queries.filter((q) => q.refId !== query.refId));\n };\n\n onChangeTimeRange = (timeRange: RelativeTimeRange, index: number) => {\n const { queries, onQueriesChange } = this.props;\n onQueriesChange(\n queries.map((item, itemIndex) => {\n if (itemIndex !== index) {\n return item;\n }\n return {\n ...item,\n relativeTimeRange: timeRange,\n };\n })\n );\n };\n\n onChangeQueryOptions = (options: AlertQueryOptions, index: number) => {\n const { queries, onQueriesChange } = this.props;\n onQueriesChange(\n queries.map((item, itemIndex) => {\n if (itemIndex !== index) {\n return item;\n }\n return {\n ...item,\n model: {\n ...item.model,\n maxDataPoints: options.maxDataPoints,\n intervalMs: options.minInterval ? rangeUtil.intervalToMs(options.minInterval) : undefined,\n },\n };\n })\n );\n };\n\n onChangeDataSource = (settings: DataSourceInstanceSettings, index: number) => {\n const { queries, onQueriesChange } = this.props;\n\n const updatedQueries = queries.map((item, itemIndex) => {\n if (itemIndex !== index) {\n return item;\n }\n\n const previousSettings = this.getDataSourceSettings(item);\n\n // Copy model if changing to a datasource of same type.\n if (settings.type === previousSettings?.type) {\n return copyModel(item, settings);\n }\n return newModel(item, settings);\n });\n\n onQueriesChange(updatedQueries);\n };\n\n onChangeQuery = (query: DataQuery, index: number) => {\n const { queries, onQueriesChange } = this.props;\n\n onQueriesChange(\n queries.map((item, itemIndex) => {\n if (itemIndex !== index) {\n return item;\n }\n\n return {\n ...item,\n refId: query.refId,\n queryType: item.model.queryType ?? '',\n model: {\n ...item.model,\n ...query,\n datasource: query.datasource!,\n },\n };\n })\n );\n };\n\n onDragEnd = (result: DropResult) => {\n const { queries, onQueriesChange } = this.props;\n\n if (!result || !result.destination) {\n return;\n }\n\n const startIndex = result.source.index;\n const endIndex = result.destination.index;\n if (startIndex === endIndex) {\n return;\n }\n\n const update = Array.from(queries);\n const [removed] = update.splice(startIndex, 1);\n update.splice(endIndex, 0, removed);\n onQueriesChange(update);\n };\n\n getDataSourceSettings = (query: AlertQuery): DataSourceInstanceSettings | undefined => {\n return getDataSourceSrv().getInstanceSettings(query.datasourceUid);\n };\n\n render() {\n const { queries, expressions, condition } = this.props;\n const thresholdByRefId = getThresholdsForQueries([...queries, ...expressions], condition);\n\n return (\n <DragDropContext onDragEnd={this.onDragEnd}>\n <Droppable droppableId=\"alerting-queries\" direction=\"vertical\">\n {(provided) => {\n return (\n <div ref={provided.innerRef} {...provided.droppableProps}>\n <Stack direction=\"column\">\n {queries.map((query, index) => {\n const isCondition = this.props.condition === query.refId;\n const data: PanelData = this.props.data?.[query.refId] ?? {\n series: [],\n state: LoadingState.NotStarted,\n };\n const dsSettings = this.getDataSourceSettings(query);\n let error: Error | undefined = undefined;\n if (data && isCondition) {\n error = errorFromCurrentCondition(data);\n } else if (data) {\n error = errorFromPreviewData(data);\n }\n\n if (!dsSettings) {\n return (\n <DatasourceNotFound\n key={`${query.refId}-${index}`}\n index={index}\n model={query.model}\n onUpdateDatasource={() => {\n const defaultDataSource = getDatasourceSrv().getInstanceSettings(null);\n if (defaultDataSource) {\n this.onChangeDataSource(defaultDataSource, index);\n }\n }}\n onRemoveQuery={() => {\n this.onRemoveQuery(query);\n }}\n />\n );\n }\n\n return (\n <QueryWrapper\n index={index}\n key={query.refId}\n dsSettings={dsSettings}\n data={data}\n error={error}\n query={query}\n onChangeQuery={this.onChangeQuery}\n onRemoveQuery={this.onRemoveQuery}\n queries={[...queries, ...expressions]}\n onChangeDataSource={this.onChangeDataSource}\n onDuplicateQuery={this.props.onDuplicateQuery}\n onChangeTimeRange={this.onChangeTimeRange}\n onChangeQueryOptions={this.onChangeQueryOptions}\n thresholds={thresholdByRefId[query.refId]?.config}\n thresholdsType={thresholdByRefId[query.refId]?.mode}\n onRunQueries={this.props.onRunQueries}\n condition={this.props.condition}\n onSetCondition={this.props.onSetCondition}\n />\n );\n })}\n {provided.placeholder}\n </Stack>\n </div>\n );\n }}\n </Droppable>\n </DragDropContext>\n );\n }\n}\n\nfunction copyModel(item: AlertQuery, settings: DataSourceInstanceSettings): Omit<AlertQuery, 'datasource'> {\n return {\n ...item,\n model: {\n ...omit(item.model, 'datasource'),\n datasource: getDataSourceRef(settings),\n },\n datasourceUid: settings.uid,\n };\n}\n\nfunction newModel(item: AlertQuery, settings: DataSourceInstanceSettings): Omit<AlertQuery, 'datasource'> {\n const isExpression = isExpressionQuery(item);\n const isInstant = isExpression ? false : getInstantFromDataQuery(item);\n\n const newQuery: Omit<AlertQuery, 'datasource'> = {\n refId: item.refId,\n relativeTimeRange: item.relativeTimeRange,\n queryType: '',\n datasourceUid: settings.uid,\n model: {\n refId: item.refId,\n hide: false,\n datasource: getDataSourceRef(settings),\n },\n };\n\n if (isInstant && !isExpressionQuery(item)) {\n (newQuery as AlertQuery<AlertDataQuery>).model.instant = isInstant;\n }\n\n return newQuery;\n}\n\ninterface DatasourceNotFoundProps {\n index: number;\n model: AlertDataQuery;\n onUpdateDatasource: () => void;\n onRemoveQuery: () => void;\n}\n\nconst DatasourceNotFound = ({ index, onUpdateDatasource, onRemoveQuery, model }: DatasourceNotFoundProps) => {\n const refId = model.refId;\n\n const [showDetails, setShowDetails] = useState<boolean>(false);\n\n const toggleDetails = () => {\n setShowDetails((show) => !show);\n };\n\n const handleUpdateDatasource = () => {\n onUpdateDatasource();\n };\n\n return (\n <EmptyQueryWrapper>\n <QueryOperationRow title={refId} draggable index={index} id={refId} isOpen collapsable={false}>\n <Card noMargin>\n <Card.Heading>\n <Trans i18nKey=\"alerting.datasource-not-found.this-datasource-has-been-removed\">\n This datasource has been removed\n </Trans>\n </Card.Heading>\n <Card.Description>\n <Trans i18nKey=\"alerting.datasource-not-found.card-description\">\n The datasource for this query was not found, it was either removed or is not installed correctly.\n </Trans>\n </Card.Description>\n <Card.Figure>\n <Icon name=\"question-circle\" />\n </Card.Figure>\n <Card.Actions>\n <Button key=\"update\" variant=\"secondary\" onClick={handleUpdateDatasource}>\n <Trans i18nKey=\"alerting.datasource-not-found.update-datasource\">Update datasource</Trans>\n </Button>\n <Button key=\"remove\" variant=\"destructive\" onClick={onRemoveQuery}>\n <Trans i18nKey=\"alerting.datasource-not-found.remove-query\">Remove query</Trans>\n </Button>\n </Card.Actions>\n <Card.SecondaryActions>\n <Button\n key=\"details\"\n onClick={toggleDetails}\n icon={showDetails ? 'angle-up' : 'angle-down'}\n fill=\"text\"\n size=\"sm\"\n >\n <Trans i18nKey=\"alerting.datasource-not-found.show-details\">Show details</Trans>\n </Button>\n </Card.SecondaryActions>\n </Card>\n {showDetails && (\n <div>\n <pre>\n <code>{JSON.stringify(model, null, 2)}</code>\n </pre>\n </div>\n )}\n </QueryOperationRow>\n </EmptyQueryWrapper>\n );\n};\n","import { css } from '@emotion/css';\n\nimport { GrafanaTheme2, PanelData } from '@grafana/data';\nimport { useStyles2 } from '@grafana/ui';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { QueryRows } from './QueryRows';\n\ninterface Props {\n panelData: Record<string, PanelData>;\n queries: AlertQuery[];\n expressions: AlertQuery[];\n onRunQueries: () => void;\n onChangeQueries: (queries: AlertQuery[]) => void;\n onDuplicateQuery: (query: AlertQuery) => void;\n condition: string | null;\n onSetCondition: (refId: string) => void;\n}\n\nexport const QueryEditor = ({\n queries,\n expressions,\n panelData,\n onRunQueries,\n onChangeQueries,\n onDuplicateQuery,\n condition,\n onSetCondition,\n}: Props) => {\n const styles = useStyles2(getStyles);\n\n return (\n <div className={styles.container}>\n <QueryRows\n data={panelData}\n queries={queries}\n expressions={expressions}\n onRunQueries={onRunQueries}\n onQueriesChange={onChangeQueries}\n onDuplicateQuery={onDuplicateQuery}\n condition={condition}\n onSetCondition={onSetCondition}\n />\n </div>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n container: css({\n backgroundColor: theme.colors.background.primary,\n height: '100%',\n }),\n});\n","import { css } from '@emotion/css';\nimport { FC, useCallback, useEffect, useState } from 'react';\nimport { useAsync } from 'react-use';\n\nimport { CoreApp, GrafanaTheme2, LoadingState, PanelData } from '@grafana/data';\nimport { Trans } from '@grafana/i18n';\nimport { getDataSourceSrv } from '@grafana/runtime';\nimport { DataQuery } from '@grafana/schema';\nimport { useStyles2 } from '@grafana/ui';\nimport { DataSourceType } from 'app/features/alerting/unified/utils/datasource';\nimport { getTimeSrv } from 'app/features/dashboard/services/TimeSrv';\nimport { QueryErrorAlert } from 'app/features/query/components/QueryErrorAlert';\nimport { LokiQueryType } from 'app/plugins/datasource/loki/dataquery.gen';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { isPromOrLokiQuery } from '../../utils/rule-form';\n\nimport { VizWrapper } from './VizWrapper';\n\nexport interface RecordingRuleEditorProps {\n queries: AlertQuery[];\n onChangeQuery: (updatedQueries: AlertQuery[]) => void;\n runQueries: () => void;\n panelData: Record<string, PanelData>;\n dataSourceName: string;\n}\n\nexport const RecordingRuleEditor: FC<RecordingRuleEditorProps> = ({\n queries,\n onChangeQuery,\n runQueries,\n panelData,\n dataSourceName,\n}) => {\n const [data, setData] = useState<PanelData>({\n series: [],\n state: LoadingState.NotStarted,\n timeRange: getTimeSrv().timeRange(),\n });\n\n const styles = useStyles2(getStyles);\n\n useEffect(() => {\n setData(panelData?.[queries[0]?.refId]);\n }, [panelData, queries]);\n\n const {\n error,\n loading,\n value: dataSource,\n } = useAsync(() => {\n return getDataSourceSrv().get(dataSourceName);\n }, [dataSourceName]);\n\n const handleChangedQuery = useCallback(\n (changedQuery: DataQuery) => {\n if (!isPromOrLokiQuery(changedQuery) || !dataSource) {\n return;\n }\n\n const [query] = queries;\n const { uid: dataSourceId, type } = dataSource;\n const isLoki = type === DataSourceType.Loki;\n const expr = changedQuery.expr;\n\n const merged = {\n ...query,\n ...changedQuery,\n datasourceUid: dataSourceId,\n expr,\n model: {\n expr,\n datasource: changedQuery.datasource,\n refId: changedQuery.refId,\n editorMode: changedQuery.editorMode,\n // Instant and range are used by Prometheus queries\n instant: changedQuery.instant,\n range: changedQuery.range,\n // Query type is used by Loki queries\n // On first render/when creating a recording rule, the query type is not set\n // unless the user has changed it betwee range/instant. The cleanest way to handle this\n // is to default to instant, or whatever the changed type is\n queryType: isLoki ? changedQuery.queryType || LokiQueryType.Instant : changedQuery.queryType,\n legendFormat: changedQuery.legendFormat,\n },\n };\n onChangeQuery([merged]);\n },\n [dataSource, queries, onChangeQuery]\n );\n\n if (loading || dataSource?.name !== dataSourceName) {\n return null;\n }\n\n const dsi = getDataSourceSrv().getInstanceSettings(dataSourceName);\n\n if (error || !dataSource || !dataSource?.components?.QueryEditor || !dsi) {\n const errorMessage = error?.message || 'Data source plugin does not export any Query Editor component';\n return (\n <div>\n <Trans i18nKey=\"alerting.recording-rule-editor.error-no-query-editor\">\n Could not load query editor due to: {{ errorMessage }}\n </Trans>\n </div>\n );\n }\n\n const QueryEditor = dataSource.components.QueryEditor;\n\n return (\n <>\n {queries.length && (\n <>\n <QueryEditor\n query={queries[0]}\n queries={queries}\n app={CoreApp.UnifiedAlerting}\n onChange={handleChangedQuery}\n onRunQuery={runQueries}\n datasource={dataSource}\n />\n {(data?.errors || []).map((err) => {\n return <QueryErrorAlert key={err.message} error={err} />;\n })}\n </>\n )}\n\n {data && (\n <div className={styles.vizWrapper}>\n <VizWrapper data={data} />\n </div>\n )}\n </>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n vizWrapper: css({\n margin: theme.spacing(1, 0),\n }),\n});\n","import { css } from '@emotion/css';\nimport { Controller, useFormContext } from 'react-hook-form';\n\nimport { DataSourceInstanceSettings, GrafanaTheme2 } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { Field, useStyles2 } from '@grafana/ui';\n\nimport { RuleFormType, RuleFormValues } from '../../../types/rule-form';\nimport { CloudRulesSourcePicker } from '../CloudRulesSourcePicker';\n\nexport interface CloudDataSourceSelectorProps {\n disabled?: boolean;\n onChangeCloudDatasource: (datasourceUid: string) => void;\n}\nexport const CloudDataSourceSelector = ({ disabled, onChangeCloudDatasource }: CloudDataSourceSelectorProps) => {\n const {\n control,\n formState: { errors },\n setValue,\n watch,\n } = useFormContext<RuleFormValues>();\n\n const styles = useStyles2(getStyles);\n\n const ruleFormType = watch('type');\n\n return (\n <div className={styles.flexRow}>\n {(ruleFormType === RuleFormType.cloudAlerting || ruleFormType === RuleFormType.cloudRecording) && (\n <Field\n className={styles.formInput}\n label={\n disabled\n ? t('alerting.cloud-data-source-selector.label-disabled', 'Data source')\n : t('alerting.cloud-data-source-selector.label', 'Select data source')\n }\n error={errors.dataSourceName?.message}\n invalid={!!errors.dataSourceName?.message}\n >\n <Controller\n render={({ field: { onChange, ref, ...field } }) => (\n <CloudRulesSourcePicker\n {...field}\n disabled={disabled}\n onChange={(ds: DataSourceInstanceSettings) => {\n // reset expression as they don't need to persist after changing datasources\n setValue('expression', '');\n onChange(ds?.name ?? null);\n onChangeCloudDatasource(ds?.uid ?? null);\n }}\n />\n )}\n name=\"dataSourceName\"\n control={control}\n rules={{\n required: {\n value: true,\n message: t(\n 'alerting.cloud-data-source-selector.message.please-select-a-data-source',\n 'Please select a data source'\n ),\n },\n }}\n />\n </Field>\n )}\n </div>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n formInput: css({\n width: '330px',\n '& + &': {\n marginLeft: theme.spacing(3),\n },\n }),\n flexRow: css({\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'flex-start',\n alignItems: 'flex-end',\n }),\n});\n","import { createAction, createReducer, original } from '@reduxjs/toolkit';\n\nimport {\n ReducerID,\n RelativeTimeRange,\n getDataSourceRef,\n getDefaultRelativeTimeRange,\n getNextRefId,\n rangeUtil,\n} from '@grafana/data';\nimport { DataQuery } from '@grafana/schema';\nimport { dataSource as expressionDatasource } from 'app/features/expressions/ExpressionDatasource';\nimport { isExpressionQuery } from 'app/features/expressions/guards';\nimport { ExpressionDatasourceUID, ExpressionQuery, ExpressionQueryType } from 'app/features/expressions/types';\nimport {\n defaultCondition,\n isReducerExpression,\n isThresholdExpression,\n} from 'app/features/expressions/utils/expressionTypes';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { logError } from '../../../Analytics';\nimport { getDefaultOrFirstCompatibleDataSource } from '../../../utils/datasource';\nimport { getDefaultQueries, getInstantFromDataQuery } from '../../../utils/rule-form';\nimport { createDagFromQueries, getOriginOfRefId } from '../dag';\nimport { queriesWithUpdatedReferences, refIdExists } from '../util';\n\n// this one will be used as the refID when we create a new reducer for the threshold expression\nexport const NEW_REDUCER_REF = 'reducer';\n\nexport interface QueriesAndExpressionsState {\n queries: AlertQuery[];\n}\n\nconst findDataSourceFromExpression = (queries: AlertQuery[], refId: string): AlertQuery | undefined => {\n const dag = createDagFromQueries(queries);\n const dataSource = getOriginOfRefId(refId, dag)[0];\n if (!dataSource) {\n return;\n }\n\n const originQuery = queries.find((query) => query.refId === dataSource);\n if (originQuery && 'relativeTimeRange' in originQuery) {\n return originQuery;\n }\n\n return;\n};\n\nconst initialState: QueriesAndExpressionsState = {\n queries: [],\n};\n\nexport const duplicateQuery = createAction<AlertQuery>('duplicateQuery');\nexport const addNewDataQuery = createAction('addNewDataQuery');\nexport const setDataQueries = createAction<AlertQuery[]>('setDataQueries');\n\nexport const addNewExpression = createAction<ExpressionQueryType>('addNewExpression');\nexport const removeExpression = createAction<string>('removeExpression');\nexport const removeExpressions = createAction('removeExpressions');\nexport const addExpressions = createAction<AlertQuery[]>('addExpressions');\nexport const updateExpression = createAction<ExpressionQuery>('updateExpression');\nexport const updateExpressionRefId = createAction<{ oldRefId: string; newRefId: string }>('updateExpressionRefId');\nexport const rewireExpressions = createAction<{ oldRefId: string; newRefId: string }>('rewireExpressions');\nexport const updateExpressionType = createAction<{ refId: string; type: ExpressionQueryType }>('updateExpressionType');\nexport const updateExpressionTimeRange = createAction('updateExpressionTimeRange');\nexport const updateMaxDataPoints = createAction<{ refId: string; maxDataPoints: number }>('updateMaxDataPoints');\nexport const updateMinInterval = createAction<{ refId: string; minInterval: string }>('updateMinInterval');\n\nexport const resetToSimpleCondition = createAction('resetToSimpleCondition');\nexport const optimizeReduceExpression = createAction<{\n updatedQueries: AlertQuery[];\n expressionQueries: Array<AlertQuery<ExpressionQuery>>;\n}>('optimizeReduceExpression');\nexport const setRecordingRulesQueries = createAction<{ recordingRuleQueries: AlertQuery[]; expression: string }>(\n 'setRecordingRulesQueries'\n);\n\nexport const queriesAndExpressionsReducer = createReducer(initialState, (builder) => {\n // data queries actions\n builder\n // simple condition actions\n .addCase(resetToSimpleCondition, (state) => {\n state.queries = getDefaultQueries();\n })\n .addCase(duplicateQuery, (state, { payload }) => {\n state.queries = addQuery(state.queries, payload);\n })\n .addCase(addNewDataQuery, (state) => {\n const datasource = getDefaultOrFirstCompatibleDataSource();\n if (!datasource) {\n return;\n }\n\n state.queries = addQuery(state.queries, {\n datasourceUid: datasource.uid,\n model: {\n refId: '',\n datasource: getDataSourceRef(datasource),\n },\n });\n })\n .addCase(setDataQueries, (state, { payload }) => {\n const expressionQueries = state.queries.filter((query) => isExpressionQuery(query.model));\n state.queries = [...payload, ...expressionQueries];\n })\n .addCase(setRecordingRulesQueries, (state, { payload }) => {\n const query = payload.recordingRuleQueries[0];\n const recordingRuleQuery = {\n ...query,\n ...{ expr: payload.expression, model: query?.model },\n };\n\n state.queries = [recordingRuleQuery];\n })\n .addCase(updateMaxDataPoints, (state, action) => {\n state.queries = state.queries.map((query) => {\n return query.refId === action.payload.refId\n ? {\n ...query,\n model: {\n ...query.model,\n maxDataPoints: action.payload.maxDataPoints,\n },\n }\n : query;\n });\n })\n .addCase(updateMinInterval, (state, action) => {\n state.queries = state.queries.map((query) => {\n return query.refId === action.payload.refId\n ? {\n ...query,\n model: {\n ...query.model,\n intervalMs: action.payload.minInterval ? rangeUtil.intervalToMs(action.payload.minInterval) : undefined,\n },\n }\n : query;\n });\n });\n\n // expressions actions\n builder\n .addCase(addNewExpression, (state, { payload }) => {\n state.queries = addQuery(state.queries, {\n datasourceUid: ExpressionDatasourceUID,\n model: expressionDatasource.newQuery({\n type: payload,\n conditions: [{ ...defaultCondition, query: { params: [] } }],\n expression: '',\n }),\n });\n })\n .addCase(removeExpression, (state, { payload }) => {\n state.queries = state.queries.filter((query) => query.refId !== payload);\n })\n .addCase(removeExpressions, (state) => {\n state.queries = state.queries.filter((query) => !isExpressionQuery(query.model));\n })\n .addCase(addExpressions, (state, { payload }) => {\n state.queries = [...state.queries, ...payload];\n })\n .addCase(updateExpression, (state, { payload }) => {\n const queryToUpdate = state.queries.find((query) => query.refId === payload.refId);\n if (!queryToUpdate) {\n return;\n }\n\n queryToUpdate.model = payload;\n\n // the resample expression needs to also know what the relative time range is to work with, this means we have to copy it from the source node (data source query)\n if (payload.type === ExpressionQueryType.resample && payload.expression) {\n // findDataSourceFromExpression uses memoization and it doesn't always work with proxies when the proxy has been revoked\n const originalQueries = original(state)?.queries ?? [];\n\n let relativeTimeRange = getDefaultRelativeTimeRange();\n try {\n const dataSourceAlertQuery = findDataSourceFromExpression(originalQueries, payload.expression);\n if (dataSourceAlertQuery?.relativeTimeRange) {\n relativeTimeRange = dataSourceAlertQuery.relativeTimeRange;\n }\n } catch (error) {\n if (error instanceof Error) {\n logError(error);\n } else {\n logError(new Error('Error while trying to find data source from expression'));\n }\n }\n\n queryToUpdate.relativeTimeRange = relativeTimeRange;\n }\n })\n .addCase(updateExpressionTimeRange, (state) => {\n state.queries.forEach((query) => {\n // Resample expression needs to get the relativeTimeRange with its dataSource relativeTimeRange\n if (\n isExpressionQuery(query.model) &&\n query.model.type === ExpressionQueryType.resample &&\n query.model.expression\n ) {\n // findDataSourceFromExpression uses memoization and doesn't work with proxies\n const originalQueries = original(state)?.queries ?? [];\n\n const dataSource = findDataSourceFromExpression(originalQueries, query.model.expression);\n const relativeTimeRange = dataSource ? dataSource.relativeTimeRange : getDefaultRelativeTimeRange();\n query.relativeTimeRange = relativeTimeRange;\n }\n });\n })\n .addCase(updateExpressionRefId, (state, { payload }) => {\n const { newRefId, oldRefId } = payload;\n\n // if the new refId already exists we just refuse to update the state\n const newRefIdExists = refIdExists(state.queries, newRefId);\n if (newRefIdExists) {\n return;\n }\n\n const updatedQueries = queriesWithUpdatedReferences(state.queries, oldRefId, newRefId);\n state.queries = updatedQueries.map((query) => {\n if (query.refId === oldRefId) {\n return {\n ...query,\n refId: newRefId,\n model: {\n ...query.model,\n refId: newRefId,\n },\n };\n }\n\n return query;\n });\n })\n .addCase(rewireExpressions, (state, { payload }) => {\n state.queries = queriesWithUpdatedReferences(state.queries, payload.oldRefId, payload.newRefId);\n })\n // removes the reduce expression when we have a instant data query\n .addCase(optimizeReduceExpression, (state, { payload }) => {\n const { updatedQueries, expressionQueries } = payload;\n\n if (updatedQueries.length !== 1) {\n // we only optimize when we have one data query\n return;\n }\n\n const dataQuery = updatedQueries.at(0);\n const isInstantDataQuery = dataQuery ? getInstantFromDataQuery(dataQuery) : false;\n const hasReducer = expressionQueries.some((q) => isReducerExpression(q.model));\n const shouldRemoveReducer = isInstantDataQuery && expressionQueries.length === 2 && hasReducer;\n\n if (shouldRemoveReducer) {\n const reduceExpressionIndex = state.queries.findIndex(\n (query) =>\n isExpressionQuery(query.model) &&\n isReducerExpression(query.model) &&\n query.model.expression === dataQuery?.refId\n );\n\n state.queries.splice(reduceExpressionIndex, 1);\n state.queries[1].model.expression = dataQuery?.refId;\n }\n\n const shouldAddReduceExpression =\n !isInstantDataQuery && expressionQueries.length === 1 && isThresholdExpression(expressionQueries[0].model);\n if (shouldAddReduceExpression) {\n // add reducer to the second position\n // we only update the refid and the model to point to the reducer expression\n state.queries[1].model.expression = NEW_REDUCER_REF;\n\n // insert in second position the reducer expression\n state.queries.splice(1, 0, {\n datasourceUid: ExpressionDatasourceUID,\n model: expressionDatasource.newQuery({\n type: ExpressionQueryType.reduce,\n reducer: ReducerID.last,\n conditions: [{ ...defaultCondition, query: { params: [] } }],\n expression: dataQuery?.refId,\n refId: NEW_REDUCER_REF,\n }),\n refId: NEW_REDUCER_REF,\n queryType: 'expression',\n });\n }\n })\n .addCase(updateExpressionType, (state, action) => {\n state.queries = state.queries.map((query) => {\n return query.refId === action.payload.refId\n ? {\n ...query,\n model: {\n ...expressionDatasource.newQuery({\n type: action.payload.type,\n conditions: [{ ...defaultCondition, query: { params: [] } }],\n expression: '',\n }),\n refId: action.payload.refId,\n },\n }\n : query;\n });\n });\n});\n\nconst addQuery = (\n queries: AlertQuery[],\n queryToAdd: Pick<AlertQuery, 'model' | 'datasourceUid' | 'relativeTimeRange'>\n): AlertQuery[] => {\n const refId = getNextRefId(queries);\n const query: AlertQuery = {\n ...queryToAdd,\n refId,\n queryType: '',\n model: {\n ...queryToAdd.model,\n hide: false,\n refId,\n },\n relativeTimeRange: queryToAdd.relativeTimeRange ?? defaultTimeRange(queryToAdd.model),\n };\n\n return [...queries, query];\n};\n\nconst defaultTimeRange = (model: DataQuery): RelativeTimeRange | undefined => {\n if (isExpressionQuery(model)) {\n return;\n }\n\n return getDefaultRelativeTimeRange();\n};\n","import { css } from '@emotion/css';\nimport { produce } from 'immer';\nimport { Dispatch, FormEvent } from 'react';\nimport { UnknownAction } from 'redux';\n\nimport { GrafanaTheme2, PanelData, ReducerID, SelectableValue } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { InlineField, InlineFieldRow, Input, Select, Stack, Text, useStyles2 } from '@grafana/ui';\nimport { EvalFunction } from 'app/features/alerting/state/alertDef';\nimport { ThresholdSelect } from 'app/features/expressions/components/ThresholdSelect';\nimport { ExpressionQuery, ExpressionQueryType, reducerTypes, thresholdFunctions } from 'app/features/expressions/types';\nimport { getReducerType, isRangeEvaluator } from 'app/features/expressions/utils/expressionTypes';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { ToLabel } from '../../../../../expressions/components/ToLabel';\nimport { ExpressionResult } from '../../expressions/Expression';\n\nimport { updateExpression } from './reducer';\n\nexport interface SimpleCondition {\n whenField?: string;\n evaluator: {\n params: number[];\n type: EvalFunction;\n };\n}\n\n/**\n * This is the simple condition editor if the user is in the simple mode in the query section\n */\nexport interface SimpleConditionEditorProps {\n simpleCondition: SimpleCondition;\n onChange: (condition: SimpleCondition) => void;\n expressionQueriesList: Array<AlertQuery<ExpressionQuery>>;\n dispatch: Dispatch<UnknownAction>;\n previewData?: PanelData;\n}\n\n/**\n *\n * This represents the simple condition editor for the alerting query section\n * The state for this simple condition is kept in the parent component\n * But we have also to keep the reducer state in sync with this condition state (both kept in the parent)\n */\n\nexport const SimpleConditionEditor = ({\n simpleCondition,\n onChange,\n expressionQueriesList,\n dispatch,\n previewData,\n}: SimpleConditionEditorProps) => {\n const onReducerTypeChange = (value: SelectableValue<string>) => {\n onChange({ ...simpleCondition, whenField: value.value ?? ReducerID.last });\n updateReduceExpression(value.value ?? ReducerID.last, expressionQueriesList, dispatch);\n };\n\n const isRange = isRangeEvaluator(simpleCondition.evaluator.type);\n\n const thresholdFunction = thresholdFunctions.find((fn) => fn.value === simpleCondition.evaluator?.type);\n\n const onEvalFunctionChange = (value: SelectableValue<EvalFunction>) => {\n // change the condition kept in the parent\n onChange({\n ...simpleCondition,\n evaluator: { ...simpleCondition.evaluator, type: value.value ?? EvalFunction.IsAbove },\n });\n // update the reducer state where we store the queries\n updateThresholdFunction(value.value ?? EvalFunction.IsAbove, expressionQueriesList, dispatch);\n };\n\n const onEvaluateValueChange = (event: FormEvent<HTMLInputElement>, index = 0) => {\n const value = event.currentTarget.value;\n const numericValue = parseFloat(value) || 0; // try to convert input to a number that isn't NaN\n\n onChange(\n produce(simpleCondition, (draftCondition) => {\n draftCondition.evaluator.params[index] = numericValue;\n })\n );\n\n updateThresholdValue(numericValue, index, expressionQueriesList, dispatch);\n };\n\n const styles = useStyles2(getStyles);\n\n return (\n <div className={styles.condition.wrapper}>\n <Stack direction=\"column\" gap={0} width=\"100%\">\n <header className={styles.condition.header}>\n <Text variant=\"body\">\n <Trans i18nKey=\"alerting.simpleCondition.alertCondition\">Alert condition</Trans>\n </Text>\n </header>\n <InlineFieldRow className={styles.condition.container}>\n {simpleCondition.whenField && (\n <InlineField label={t('alerting.simple-condition-editor.label-when', 'WHEN')}>\n <Select\n options={reducerTypes}\n value={reducerTypes.find((o) => o.value === simpleCondition.whenField)}\n onChange={onReducerTypeChange}\n width={20}\n />\n </InlineField>\n )}\n <InlineField\n label={\n simpleCondition.whenField\n ? t('alerting.simple-condition-editor.label-of-query', 'OF QUERY')\n : t('alerting.simple-condition-editor.label-when-query', 'WHEN QUERY')\n }\n >\n <Stack direction=\"row\" gap={1} alignItems=\"center\">\n <ThresholdSelect onChange={onEvalFunctionChange} value={thresholdFunction} />\n {isRange ? (\n <>\n <Input\n type=\"number\"\n width={10}\n // by using the key prop we can force the input to re-render whenever the defaultValue updates\n // this is because we have a useEffect() that updates the data structure but \"defaultValue\" will memoize the\n // first value before the useEffect() runs\n key={simpleCondition.evaluator.params[0]}\n defaultValue={simpleCondition.evaluator.params[0] ?? ''}\n onBlur={(event) => {\n onEvaluateValueChange(event, 0);\n }}\n />\n <ToLabel />\n <Input\n type=\"number\"\n width={10}\n key={simpleCondition.evaluator.params[1]}\n defaultValue={simpleCondition.evaluator.params[1] ?? ''}\n onBlur={(event) => {\n onEvaluateValueChange(event, 1);\n }}\n />\n </>\n ) : (\n <Input\n type=\"number\"\n width={10}\n key={simpleCondition.evaluator.params[0]}\n defaultValue={simpleCondition.evaluator.params[0] ?? ''}\n onBlur={(event) => {\n onEvaluateValueChange(event, 0);\n }}\n />\n )}\n </Stack>\n </InlineField>\n </InlineFieldRow>\n {previewData?.series && <ExpressionResult series={previewData?.series} isAlertCondition={true} />}\n </Stack>\n </div>\n );\n};\n\nfunction updateReduceExpression(\n reducer: string,\n expressionQueriesList: Array<AlertQuery<ExpressionQuery>>,\n dispatch: Dispatch<UnknownAction>\n) {\n // 1. make sure have have a reduce expression and that it is pointing to the data query\n const reduceExpression = expressionQueriesList.find((query) => query.model.type === ExpressionQueryType.reduce);\n\n const newReduceExpression = reduceExpression\n ? produce(reduceExpression?.model, (draft) => {\n if (draft && draft.conditions) {\n draft.reducer = reducer;\n draft.conditions[0].reducer.type = getReducerType(reducer) ?? ReducerID.last;\n }\n })\n : undefined;\n newReduceExpression && dispatch(updateExpression(newReduceExpression));\n}\n\nfunction updateThresholdFunction(\n evaluator: EvalFunction,\n expressionQueriesList: Array<AlertQuery<ExpressionQuery>>,\n dispatch: Dispatch<UnknownAction>\n) {\n const thresholdExpression = expressionQueriesList.find((query) => query.model.type === ExpressionQueryType.threshold);\n\n const newThresholdExpression = produce(thresholdExpression, (draft) => {\n if (draft && draft.model.conditions) {\n draft.model.conditions[0].evaluator.type = evaluator;\n }\n });\n newThresholdExpression && dispatch(updateExpression(newThresholdExpression.model));\n}\n\nfunction updateThresholdValue(\n value: number,\n index: number,\n expressionQueriesList: Array<AlertQuery<ExpressionQuery>>,\n dispatch: Dispatch<UnknownAction>\n) {\n const thresholdExpression = expressionQueriesList.find((query) => query.model.type === ExpressionQueryType.threshold);\n\n const newThresholdExpression = produce(thresholdExpression, (draft) => {\n if (draft && draft.model.conditions) {\n draft.model.conditions[0].evaluator.params[index] = value;\n }\n });\n newThresholdExpression && dispatch(updateExpression(newThresholdExpression.model));\n}\n\nexport function getSimpleConditionFromExpressions(expressions: Array<AlertQuery<ExpressionQuery>>): SimpleCondition {\n const reduceExpression = expressions.find((query) => query.model.type === ExpressionQueryType.reduce);\n const thresholdExpression = expressions.find((query) => query.model.type === ExpressionQueryType.threshold);\n const conditionsFromThreshold = thresholdExpression?.model.conditions ?? [];\n const whenField = reduceExpression?.model.reducer;\n const params = conditionsFromThreshold[0]?.evaluator?.params\n ? [...conditionsFromThreshold[0]?.evaluator?.params]\n : [0];\n const type = conditionsFromThreshold[0]?.evaluator?.type ?? EvalFunction.IsAbove;\n\n return {\n whenField: whenField,\n evaluator: {\n params: params,\n type: type,\n },\n };\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n buttonSelectText: css({\n color: theme.colors.primary.text,\n fontSize: theme.typography.bodySmall.fontSize,\n textTransform: 'uppercase',\n padding: `0 ${theme.spacing(1)}`,\n }),\n condition: {\n wrapper: css({\n display: 'flex',\n border: `solid 1px ${theme.colors.border.medium}`,\n flex: 1,\n height: 'fit-content',\n borderRadius: theme.shape.radius.default,\n }),\n container: css({\n display: 'flex',\n flexDirection: 'row',\n padding: theme.spacing(1),\n flex: 1,\n width: '100%',\n }),\n header: css({\n background: theme.colors.background.secondary,\n padding: `${theme.spacing(0.5)} ${theme.spacing(1)}`,\n borderBottom: `solid 1px ${theme.colors.border.weak}`,\n flex: 1,\n }),\n },\n});\n","import { contextSrv } from 'app/core/core';\nimport { ExpressionDatasourceUID } from 'app/features/expressions/types';\nimport { AccessControlAction } from 'app/types/accessControl';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { useHasRulerV2 } from '../../../hooks/useHasRuler';\nimport { RuleFormType } from '../../../types/rule-form';\n\nexport const onlyOneDSInQueries = (queries: AlertQuery[]) => {\n return queries.filter((q) => q.datasourceUid !== ExpressionDatasourceUID).length === 1;\n};\n\nfunction getAvailableRuleTypes() {\n const canCreateGrafanaRules = contextSrv.hasPermission(AccessControlAction.AlertingRuleCreate);\n const canCreateCloudRules = contextSrv.hasPermission(AccessControlAction.AlertingRuleExternalWrite);\n const defaultRuleType = canCreateGrafanaRules ? RuleFormType.grafana : RuleFormType.cloudAlerting;\n\n const enabledRuleTypes: RuleFormType[] = [];\n if (canCreateGrafanaRules) {\n enabledRuleTypes.push(RuleFormType.grafana);\n }\n if (canCreateCloudRules) {\n enabledRuleTypes.push(RuleFormType.cloudAlerting, RuleFormType.cloudRecording);\n }\n\n return { enabledRuleTypes, defaultRuleType };\n}\n\nexport const useGetCanSwitch = ({\n queries,\n ruleFormType,\n}: {\n queries: AlertQuery[];\n ruleFormType: RuleFormType | undefined;\n}) => {\n // get available rule types\n const availableRuleTypes = getAvailableRuleTypes();\n\n // check if we have only one query in queries and if it's a cloud datasource\n const onlyOneDS = onlyOneDSInQueries(queries);\n const isRecordingRuleType = ruleFormType === RuleFormType.cloudRecording;\n const dataSourceIdFromQueries = queries[0]?.datasourceUid ?? '';\n const { hasRuler } = useHasRulerV2(dataSourceIdFromQueries);\n\n //let's check if we switch to cloud type\n const canSwitchToCloudRule = !isRecordingRuleType && onlyOneDS && hasRuler;\n\n const canSwitchToGrafanaRule = !isRecordingRuleType;\n // check for enabled types\n const grafanaTypeEnabled = availableRuleTypes.enabledRuleTypes.includes(RuleFormType.grafana);\n const cloudTypeEnabled = availableRuleTypes.enabledRuleTypes.includes(RuleFormType.cloudAlerting);\n\n // can we switch to the other type? (cloud or grafana)\n const canSwitchFromCloudToGrafana =\n ruleFormType === RuleFormType.cloudAlerting && grafanaTypeEnabled && canSwitchToGrafanaRule;\n const canSwitchFromGrafanaToCloud =\n ruleFormType === RuleFormType.grafana && canSwitchToCloudRule && cloudTypeEnabled && canSwitchToCloudRule;\n\n return canSwitchFromCloudToGrafana || canSwitchFromGrafanaToCloud;\n};\n","import { useFormContext } from 'react-hook-form';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { RadioButtonGroup, Stack, Text } from '@grafana/ui';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { RuleFormType, RuleFormValues } from '../../../types/rule-form';\nimport { NeedHelpInfo } from '../NeedHelpInfo';\n\nimport { useGetCanSwitch } from './utils';\n\ninterface SmartAlertTypeDetectorProps {\n editingExistingRule: boolean;\n queries: AlertQuery[];\n onClickSwitch: () => void;\n}\n\nexport function SmartAlertTypeDetector({ editingExistingRule, queries, onClickSwitch }: SmartAlertTypeDetectorProps) {\n const { getValues } = useFormContext<RuleFormValues>();\n\n const [ruleFormType] = getValues(['type']);\n const canSwitch = useGetCanSwitch({ queries, ruleFormType });\n\n const options = [\n { label: t('alerting.smart-alert-type-detector.grafana-managed', 'Grafana-managed'), value: RuleFormType.grafana },\n {\n label: t('alerting.smart-alert-type-detector.data-source-managed', 'Data source-managed'),\n value: RuleFormType.cloudAlerting,\n },\n ];\n\n // if we can't switch to data-source managed, disable it\n // TODO figure out how to show a popover to the user to indicate _why_ it's disabled\n const disabledOptions = canSwitch ? [] : [RuleFormType.cloudAlerting];\n\n return (\n <Stack direction=\"column\" gap={1} alignItems=\"flex-start\">\n <Stack direction=\"column\" gap={0}>\n <Text variant=\"h5\">\n <Trans i18nKey=\"alerting.smart-alert-type-detector.rule-type\">Rule type</Trans>\n </Text>\n <Stack direction=\"row\" gap={0.5} alignItems=\"center\">\n <Text variant=\"bodySmall\" color=\"secondary\">\n <Trans i18nKey=\"alerting.smart-alert-type-detector.select-where-alert-managed\">\n Select where the alert rule will be managed.\n </Trans>\n </Text>\n <NeedHelpInfo\n contentText={\n <>\n <Text color=\"primary\" variant=\"h6\">\n <Trans i18nKey=\"alerting.smart-alert-type-detector.grafanamanaged-alert-rules\">\n Grafana-managed alert rules\n </Trans>\n </Text>\n <p>\n <Trans i18nKey=\"alerting.smart-alert-type-detector.grafanamanaged-alert-rules-description\">\n Grafana-managed alert rules allow you to create alerts that can act on data from any of our\n supported data sources, including having multiple data sources in the same rule. You can also add\n expressions to transform your data and set alert conditions. Using images in alert notifications is\n also supported.\n </Trans>\n </p>\n <Text color=\"primary\" variant=\"h6\">\n <Trans i18nKey=\"alerting.smart-alert-type-detector.data-sourcemanaged-alert-rules\">\n Data source-managed alert rules\n </Trans>\n </Text>\n <p>\n <Trans i18nKey=\"alerting.smart-alert-type-detector.data-sourcemanaged-alert-rules-description\">\n Data source-managed alert rules can be used for Grafana Mimir or Grafana Loki data sources which\n have been configured to support rule creation. The use of expressions or multiple queries is not\n supported.\n </Trans>\n </p>\n </>\n }\n externalLink=\"https://grafana.com/docs/grafana/latest/alerting/fundamentals/alert-rules/alert-rule-types/\"\n linkText=\"Read about alert rule types\"\n title={t('alerting.smart-alert-type-detector.title-alert-rule-types', 'Alert rule types')}\n />\n </Stack>\n </Stack>\n <RadioButtonGroup\n options={options}\n disabled={editingExistingRule}\n disabledOptions={disabledOptions}\n value={ruleFormType}\n onChange={onClickSwitch}\n data-testid=\"rule-type-radio-group\"\n />\n {/* editing an existing rule, we just show \"cannot be changed\" */}\n {editingExistingRule && (\n <Text color=\"secondary\">\n <Trans i18nKey=\"alerting.smart-alert-type-detector.rule-type-cannot-be-changed\">\n The alert rule type cannot be changed for an existing rule.\n </Trans>\n </Text>\n )}\n {/* in regular alert creation we tell the user what options they have when using a cloud data source */}\n {!editingExistingRule && (\n <>\n {canSwitch ? (\n <Text color=\"secondary\">\n {ruleFormType === RuleFormType.grafana\n ? t(\n 'alerting.smart-alert-type-detector.switch-to-data-source-managed',\n 'The data source selected in your query supports alert rule management. Switch to data source-managed if you want the alert rule to be managed by the data source instead of Grafana.'\n )\n : t(\n 'alerting.smart-alert-type-detector.switch-to-grafana-managed',\n 'Switch to Grafana-managed to use expressions, multiple queries, images in notifications and various other features.'\n )}\n </Text>\n ) : (\n <Text color=\"secondary\">\n <Trans i18nKey=\"alerting.smart-alert-type-detector.rule-type-grafana-managed\">\n Based on the selected data sources this alert rule will be Grafana-managed.\n </Trans>\n </Text>\n )}\n </>\n )}\n </Stack>\n );\n}\n","import { RuleFormType } from '../../../types/rule-form';\n\ntype FormDescriptions = {\n sectionTitle: string;\n helpLabel: string;\n helpContent: string;\n helpLink: string;\n};\n\nexport const DESCRIPTIONS: Record<RuleFormType, FormDescriptions> = {\n [RuleFormType.cloudRecording]: {\n sectionTitle: 'Define recording rule',\n helpLabel: 'Define your recording rule',\n helpContent:\n 'Pre-compute frequently needed or computationally expensive expressions and save their result as a new set of time series.',\n helpLink: 'https://grafana.com/docs/grafana/latest/alerting/alerting-rules/create-recording-rules/',\n },\n [RuleFormType.grafanaRecording]: {\n sectionTitle: 'Define recording rule',\n helpLabel: 'Define your recording rule',\n helpContent:\n 'Pre-compute frequently needed or computationally expensive expressions and save their result as a new set of time series.',\n helpLink: 'https://grafana.com/docs/grafana/latest/alerting/alerting-rules/create-recording-rules/',\n },\n [RuleFormType.grafana]: {\n sectionTitle: 'Define query and alert condition',\n helpLabel: 'Define query and alert condition',\n helpContent:\n 'An alert rule consists of one or more queries and expressions that select the data you want to measure. Define queries and/or expressions and then choose one of them as the alert rule condition. This is the threshold that an alert rule must meet or exceed in order to fire. For more information on queries and expressions, see Query and transform data.',\n helpLink: 'https://grafana.com/docs/grafana/latest/panels-visualizations/query-transform-data/',\n },\n [RuleFormType.cloudAlerting]: {\n sectionTitle: 'Define query and alert condition',\n helpLabel: 'Define query and alert condition',\n helpContent:\n 'An alert rule consists of one or more queries and expressions that select the data you want to measure. Define queries and/or expressions and then choose one of them as the alert rule condition. This is the threshold that an alert rule must meet or exceed in order to fire. For more information on queries and expressions, see Query and transform data.',\n helpLink: 'https://grafana.com/docs/grafana/latest/panels-visualizations/query-transform-data/',\n },\n};\n","import { useEffect, useState } from 'react';\n\nimport { ReducerID } from '@grafana/data';\nimport { EvalFunction } from 'app/features/alerting/state/alertDef';\nimport { ExpressionQuery } from 'app/features/expressions/types';\nimport { AlertDataQuery, AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport { areQueriesTransformableToSimpleCondition } from '../../../rule-editor/formProcessing';\n\nimport { SimpleCondition, getSimpleConditionFromExpressions } from './SimpleCondition';\n\nfunction initializeSimpleCondition(\n isGrafanaAlertingType: boolean,\n dataQueries: Array<AlertQuery<AlertDataQuery>>,\n expressionQueries: Array<AlertQuery<ExpressionQuery>>\n) {\n if (isGrafanaAlertingType && areQueriesTransformableToSimpleCondition(dataQueries, expressionQueries)) {\n return getSimpleConditionFromExpressions(expressionQueries);\n } else {\n return {\n whenField: ReducerID.last,\n evaluator: {\n params: [0],\n type: EvalFunction.IsAbove,\n },\n };\n }\n}\nexport function determineAdvancedMode(simplifiedQueryEditor: boolean | undefined, isGrafanaAlertingType: boolean) {\n return simplifiedQueryEditor === false || !isGrafanaAlertingType;\n}\n\n/*\n This hook is used mantain the state of the advanced mode, and the simple condition,\n depending on the editor settings, the alert type, and the queries.\n */\nexport const useAdvancedMode = (\n simplifiedQueryEditor: boolean | undefined,\n isGrafanaAlertingType: boolean,\n dataQueries: Array<AlertQuery<ExpressionQuery | AlertDataQuery>>,\n expressionQueries: Array<AlertQuery<ExpressionQuery>>\n) => {\n const isAdvancedMode = determineAdvancedMode(simplifiedQueryEditor, isGrafanaAlertingType);\n\n const [simpleCondition, setSimpleCondition] = useState<SimpleCondition>(\n initializeSimpleCondition(isGrafanaAlertingType, dataQueries, expressionQueries)\n );\n\n useEffect(() => {\n if (isGrafanaAlertingType && !isAdvancedMode) {\n setSimpleCondition(getSimpleConditionFromExpressions(expressionQueries));\n }\n }, [isAdvancedMode, expressionQueries, isGrafanaAlertingType]);\n\n return { simpleCondition, setSimpleCondition };\n};\n","import { css } from '@emotion/css';\nimport { cloneDeep } from 'lodash';\nimport { useCallback, useEffect, useMemo, useReducer, useState } from 'react';\nimport { Controller, useFormContext } from 'react-hook-form';\nimport { useEffectOnce } from 'react-use';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { Trans, t } from '@grafana/i18n';\nimport { config, getDataSourceSrv } from '@grafana/runtime';\nimport {\n Alert,\n Button,\n ConfirmModal,\n Divider,\n Dropdown,\n Field,\n Menu,\n MenuItem,\n Stack,\n Text,\n Tooltip,\n useStyles2,\n} from '@grafana/ui';\nimport { isExpressionQuery } from 'app/features/expressions/guards';\nimport {\n ExpressionDatasourceUID,\n ExpressionQuery,\n ExpressionQueryType,\n expressionTypes,\n} from 'app/features/expressions/types';\nimport { AlertQuery } from 'app/types/unified-alerting-dto';\n\nimport {\n areQueriesTransformableToSimpleCondition,\n isExpressionQueryInAlert,\n} from '../../../rule-editor/formProcessing';\nimport { RuleFormType, RuleFormValues } from '../../../types/rule-form';\nimport { GRAFANA_RULES_SOURCE_NAME, getDefaultOrFirstCompatibleDataSource } from '../../../utils/datasource';\nimport { PromOrLokiQuery, isPromOrLokiQuery } from '../../../utils/rule-form';\nimport {\n isCloudAlertingRuleByType,\n isCloudRecordingRuleByType,\n isDataSourceManagedRuleByType,\n isGrafanaAlertingRuleByType,\n isGrafanaManagedRuleByType,\n} from '../../../utils/rules';\nimport { ExpressionEditor } from '../ExpressionEditor';\nimport { ExpressionsEditor } from '../ExpressionsEditor';\nimport { NeedHelpInfo } from '../NeedHelpInfo';\nimport { QueryEditor } from '../QueryEditor';\nimport { RecordingRuleEditor } from '../RecordingRuleEditor';\nimport { RuleEditorSection } from '../RuleEditorSection';\nimport { errorFromCurrentCondition, errorFromPreviewData, findRenamedDataQueryReferences, refIdExists } from '../util';\n\nimport { CloudDataSourceSelector } from './CloudDataSourceSelector';\nimport { SimpleConditionEditor, getSimpleConditionFromExpressions } from './SimpleCondition';\nimport { SmartAlertTypeDetector } from './SmartAlertTypeDetector';\nimport { DESCRIPTIONS } from './descriptions';\nimport {\n addExpressions,\n addNewDataQuery,\n addNewExpression,\n duplicateQuery,\n optimizeReduceExpression,\n queriesAndExpressionsReducer,\n removeExpression,\n removeExpressions,\n resetToSimpleCondition,\n rewireExpressions,\n setDataQueries,\n setRecordingRulesQueries,\n updateExpression,\n updateExpressionRefId,\n updateExpressionTimeRange,\n updateExpressionType,\n} from './reducer';\nimport { useAdvancedMode } from './useAdvancedMode';\nimport { useAlertQueryRunner } from './useAlertQueryRunner';\nimport { onlyOneDSInQueries } from './utils';\n\ninterface Props {\n editingExistingRule: boolean;\n onDataChange: (error: string) => void;\n /**\n * The mode of the rule editor.\n * - 'edit' standard rule editor mode\n * - 'draft' non-saveable form mode used for exporting to provisioning formats\n */\n mode: 'edit' | 'draft';\n}\n\nexport const QueryAndExpressionsStep = ({ editingExistingRule, onDataChange, mode }: Props) => {\n const {\n setValue,\n getValues,\n watch,\n formState: { errors },\n control,\n } = useFormContext<RuleFormValues>();\n\n const { queryPreviewData, runQueries, cancelQueries, isPreviewLoading } = useAlertQueryRunner();\n const isSwitchModeEnabled = config.featureToggles.alertingQueryAndExpressionsStepMode ?? false;\n\n const initialState = {\n queries: getValues('queries'),\n };\n\n const [{ queries }, dispatch] = useReducer(queriesAndExpressionsReducer, initialState);\n const isOptimizeReducerEnabled = config.featureToggles.alertingUIOptimizeReducer ?? false;\n\n // data queries only\n const dataQueries = useMemo(() => {\n return queries.filter((query) => !isExpressionQuery(query.model));\n }, [queries]);\n\n // expression queries only\n const expressionQueries = useMemo(() => {\n return queries.filter((query) => isExpressionQueryInAlert(query));\n }, [queries]);\n\n useEffectOnce(() => {\n // we only remove or add the reducer(optimize reducer) expression when creating a new alert.\n // When editing an alert, we assume the user wants to manually adjust expressions and queries for more control and customization.\n\n if (!editingExistingRule && isOptimizeReducerEnabled) {\n dispatch(optimizeReduceExpression({ updatedQueries: dataQueries, expressionQueries }));\n }\n });\n\n const [type, condition, dataSourceName, editorSettings] = watch([\n 'type',\n 'condition',\n 'dataSourceName',\n 'editorSettings',\n ]);\n //if its a new rule, look at the local storage\n\n const isGrafanaAlertingType = isGrafanaAlertingRuleByType(type);\n const isRecordingRuleType = isCloudRecordingRuleByType(type);\n const isCloudAlertRuleType = isCloudAlertingRuleByType(type);\n const [showResetModeModal, setShowResetModal] = useState(false);\n\n const simplifiedQueryInForm = editorSettings?.simplifiedQueryEditor;\n\n const { simpleCondition, setSimpleCondition } = useAdvancedMode(\n simplifiedQueryInForm,\n isGrafanaAlertingType,\n dataQueries,\n expressionQueries\n );\n\n const simplifiedQueryStep =\n isSwitchModeEnabled && isGrafanaAlertingType ? editorSettings?.simplifiedQueryEditor : false;\n\n // If we switch to simple mode we need to update the simple condition with the data in the queries reducer\n useEffect(() => {\n if (simplifiedQueryStep && isGrafanaAlertingType) {\n setSimpleCondition(getSimpleConditionFromExpressions(expressionQueries));\n }\n }, [simplifiedQueryStep, expressionQueries, isGrafanaAlertingType, setSimpleCondition]);\n\n const runQueriesPreview = useCallback(\n (condition?: string) => {\n if (isCloudAlertRuleType) {\n // we will skip preview for cloud rules, these do not have any time series preview\n // Grafana Managed rules and recording rules do\n return;\n }\n\n if (simplifiedQueryStep) {\n const lastExpression = expressionQueries.at(-1);\n if (!lastExpression) {\n return;\n }\n\n const condition = lastExpression.refId;\n // we need to be sure the condition is set once we switch to simple mode\n setValue('condition', condition);\n runQueries(getValues('queries'), condition);\n } else {\n runQueries(getValues('queries'), condition || (getValues('condition') ?? ''));\n }\n },\n [isCloudAlertRuleType, expressionQueries, simplifiedQueryStep, setValue, runQueries, getValues]\n );\n\n // whenever we update the queries we have to update the form too\n useEffect(() => {\n setValue('queries', queries, { shouldValidate: false });\n }, [queries, runQueries, setValue]);\n\n const noCompatibleDataSources = getDefaultOrFirstCompatibleDataSource() === undefined;\n\n const emptyQueries = queries.length === 0;\n\n // apply some validations and asserts to the results of the evaluation when creating or editing\n // Grafana-managed alert rules and Grafa-managed recording rules\n useEffect(() => {\n if (type && !isGrafanaManagedRuleByType(type)) {\n return;\n }\n\n const currentCondition = getValues('condition');\n if (!currentCondition) {\n return;\n }\n\n const previewData = queryPreviewData[currentCondition];\n if (!previewData) {\n return;\n }\n\n const error = errorFromPreviewData(previewData) ?? errorFromCurrentCondition(previewData);\n\n onDataChange(error?.message || '');\n }, [queryPreviewData, getValues, onDataChange, type]);\n\n const handleSetCondition = useCallback(\n (refId: string | null) => {\n if (!refId) {\n return;\n }\n\n runQueriesPreview(refId); //we need to run the queries to know if the condition is valid\n\n setValue('condition', refId);\n },\n [runQueriesPreview, setValue]\n );\n\n const onUpdateRefId = useCallback(\n (oldRefId: string, newRefId: string) => {\n const newRefIdExists = refIdExists(queries, newRefId);\n // TODO we should set an error and explain what went wrong instead of just refusing to update\n if (newRefIdExists) {\n return;\n }\n\n dispatch(updateExpressionRefId({ oldRefId, newRefId }));\n\n // update condition too if refId was updated\n if (condition === oldRefId) {\n setValue('condition', newRefId);\n }\n },\n [condition, queries, setValue]\n );\n\n const updateExpressionAndDatasource = useSetExpressionAndDataSource();\n\n const onChangeQueries = useCallback(\n (updatedQueries: AlertQuery[]) => {\n // Most data sources triggers onChange and onRunQueries consecutively\n // It means our reducer state is always one step behind when runQueries is invoked\n // Invocation cycle => onChange -> dispatch(setDataQueries) -> onRunQueries -> setDataQueries Reducer\n // As a workaround we update form values as soon as possible to avoid stale state\n // This way we can access up to date queries in runQueriesPreview without waiting for re-render\n const previousQueries = getValues('queries');\n\n const expressionQueries = previousQueries.filter<AlertQuery<ExpressionQuery>>(isExpressionQueryInAlert);\n\n setValue('queries', [...updatedQueries, ...expressionQueries], { shouldValidate: false });\n updateExpressionAndDatasource(updatedQueries);\n\n // we only remove or add the reducer(optimize reducer) expression when creating a new alert.\n // When editing an alert, we assume the user wants to manually adjust expressions and queries for more control and customization.\n if (!editingExistingRule && isOptimizeReducerEnabled) {\n dispatch(optimizeReduceExpression({ updatedQueries, expressionQueries }));\n }\n\n dispatch(setDataQueries(updatedQueries));\n dispatch(updateExpressionTimeRange());\n\n // check if we need to rewire expressions (and which ones)\n const [oldRefId, newRefId] = findRenamedDataQueryReferences(queries, updatedQueries);\n if (oldRefId && newRefId) {\n dispatch(rewireExpressions({ oldRefId, newRefId }));\n }\n },\n [queries, updateExpressionAndDatasource, getValues, setValue, editingExistingRule, isOptimizeReducerEnabled]\n );\n\n const onChangeRecordingRulesQueries = useCallback(\n (updatedQueries: AlertQuery[]) => {\n const query = updatedQueries[0];\n\n if (!isPromOrLokiQuery(query.model)) {\n return;\n }\n\n const expression = query.model.expr;\n\n setValue('queries', updatedQueries, { shouldValidate: false });\n updateExpressionAndDatasource(updatedQueries);\n\n dispatch(setRecordingRulesQueries({ recordingRuleQueries: updatedQueries, expression }));\n runQueriesPreview();\n },\n [runQueriesPreview, setValue, updateExpressionAndDatasource]\n );\n\n const onDuplicateQuery = useCallback((query: AlertQuery) => {\n dispatch(duplicateQuery(query));\n }, []);\n\n // update the condition if it's been removed\n useEffect(() => {\n if (!refIdExists(queries, condition)) {\n const lastRefId = queries.at(-1)?.refId ?? null;\n handleSetCondition(lastRefId);\n }\n }, [condition, queries, handleSetCondition]);\n\n const onClickType = useCallback(\n (type: ExpressionQueryType) => {\n dispatch(addNewExpression(type));\n },\n [dispatch]\n );\n\n const styles = useStyles2(getStyles);\n\n // Cloud alerts load data from form values\n // whereas Grafana managed alerts load data from reducer\n //when data source is changed in the cloud selector we need to update the queries in the reducer\n\n const onChangeCloudDatasource = useCallback(\n (datasourceUid: string) => {\n const newQueries = cloneDeep(queries);\n newQueries[0].datasourceUid = datasourceUid;\n setValue('queries', newQueries, { shouldValidate: false });\n\n updateExpressionAndDatasource(newQueries);\n\n dispatch(setDataQueries(newQueries));\n },\n [queries, setValue, updateExpressionAndDatasource, dispatch]\n );\n\n // ExpressionEditor for cloud query needs to update queries in the reducer and in the form\n // otherwise the value is not updated for Grafana managed alerts\n\n const onChangeExpression = (value: string) => {\n const newQueries = cloneDeep(queries);\n\n if (newQueries[0].model) {\n if (isPromOrLokiQuery(newQueries[0].model)) {\n newQueries[0].model.expr = value;\n } else {\n // first time we come from grafana-managed type\n // we need to convert the model to PromOrLokiQuery\n const promLoki: PromOrLokiQuery = {\n ...cloneDeep(newQueries[0].model),\n expr: value,\n };\n newQueries[0].model = promLoki;\n }\n }\n\n setValue('queries', newQueries, { shouldValidate: false });\n\n updateExpressionAndDatasource(newQueries);\n\n dispatch(setDataQueries(newQueries));\n runQueriesPreview();\n };\n\n const removeExpressionsInQueries = useCallback(() => dispatch(removeExpressions()), [dispatch]);\n\n const addExpressionsInQueries = useCallback(\n (expressions: AlertQuery[]) => dispatch(addExpressions(expressions)),\n [dispatch]\n );\n\n // we need to keep track of the previous expressions and condition reference to be able to restore them when switching back to grafana managed\n const [prevExpressions, setPrevExpressions] = useState<AlertQuery[]>([]);\n const [prevCondition, setPrevCondition] = useState<string | null>(null);\n\n const restoreExpressionsInQueries = useCallback(() => {\n addExpressionsInQueries(prevExpressions);\n }, [prevExpressions, addExpressionsInQueries]);\n\n const onClickSwitch = useCallback(() => {\n const typeInForm = getValues('type');\n if (typeInForm === RuleFormType.cloudAlerting) {\n setValue('type', RuleFormType.grafana);\n setValue('dataSourceName', GRAFANA_RULES_SOURCE_NAME);\n\n prevExpressions.length > 0 && restoreExpressionsInQueries();\n prevCondition && setValue('condition', prevCondition);\n } else {\n setValue('type', RuleFormType.cloudAlerting);\n // dataSourceName is used only by Mimir/Loki alerting and recording rules\n // It should be empty for Grafana managed alert rules\n const newDsName = getDataSourceSrv().getInstanceSettings(queries[0].datasourceUid)?.name;\n if (newDsName) {\n setValue('dataSourceName', newDsName);\n }\n\n updateExpressionAndDatasource(queries);\n\n const expressions = queries.filter((query) => query.datasourceUid === ExpressionDatasourceUID);\n setPrevExpressions(expressions);\n removeExpressionsInQueries();\n setPrevCondition(condition);\n }\n }, [\n getValues,\n setValue,\n prevExpressions.length,\n restoreExpressionsInQueries,\n prevCondition,\n updateExpressionAndDatasource,\n queries,\n removeExpressionsInQueries,\n condition,\n ]);\n\n const { sectionTitle, helpLabel, helpContent, helpLink } = DESCRIPTIONS[type ?? RuleFormType.grafana];\n\n if (!type) {\n return null;\n }\n const switchMode =\n isGrafanaAlertingType && isSwitchModeEnabled\n ? {\n isAdvancedMode: !simplifiedQueryStep,\n setAdvancedMode: (isAdvanced: boolean) => {\n if (!getValues('editorSettings.simplifiedQueryEditor')) {\n if (!areQueriesTransformableToSimpleCondition(dataQueries, expressionQueries)) {\n setShowResetModal(true);\n return;\n }\n }\n setValue('editorSettings.simplifiedQueryEditor', !isAdvanced);\n },\n }\n : undefined;\n\n const canSelectDataSourceManaged = onlyOneDSInQueries(queries);\n\n return (\n <>\n <RuleEditorSection\n stepNo={2}\n title={sectionTitle}\n fullWidth={true}\n description={\n <Stack direction=\"row\" gap={0.5} alignItems=\"center\">\n <Text variant=\"bodySmall\" color=\"secondary\">\n {helpLabel}\n </Text>\n <NeedHelpInfo\n contentText={helpContent}\n externalLink={helpLink}\n linkText={'Read more on our documentation website'}\n title={helpLabel}\n />\n </Stack>\n }\n switchMode={switchMode}\n >\n {/* This is the cloud data source selector */}\n {isDataSourceManagedRuleByType(type) && (\n <CloudDataSourceSelector onChangeCloudDatasource={onChangeCloudDatasource} disabled={editingExistingRule} />\n )}\n\n {/* This is the PromQL Editor for recording rules */}\n {isRecordingRuleType && dataSourceName && (\n <Field error={errors.expression?.message} invalid={!!errors.expression?.message} noMargin>\n <RecordingRuleEditor\n dataSourceName={dataSourceName}\n queries={queries}\n runQueries={() => runQueriesPreview()}\n onChangeQuery={onChangeRecordingRulesQueries}\n panelData={queryPreviewData}\n />\n </Field>\n )}\n\n {/* This is the PromQL Editor for Cloud rules */}\n {isCloudAlertRuleType && dataSourceName && (\n <Stack direction=\"column\">\n <Field error={errors.expression?.message} invalid={!!errors.expression?.message} noMargin>\n <Controller\n name=\"expression\"\n render={({ field: { ref, ...field } }) => {\n return (\n <ExpressionEditor\n {...field}\n dataSourceName={dataSourceName}\n showPreviewAlertsButton={!isRecordingRuleType}\n onChange={onChangeExpression}\n />\n );\n }}\n control={control}\n rules={{\n required: {\n value: true,\n message: t(\n 'alerting.query-and-expressions-step.message.a-valid-expression-is-required',\n 'A valid expression is required'\n ),\n },\n }}\n />\n </Field>\n {mode === 'edit' && (\n <>\n <Divider />\n <SmartAlertTypeDetector\n editingExistingRule={editingExistingRule}\n queries={queries}\n onClickSwitch={onClickSwitch}\n />\n </>\n )}\n </Stack>\n )}\n\n {/* This is the editor for Grafana managed rules and Grafana managed recording rules */}\n {isGrafanaManagedRuleByType(type) && (\n <Stack direction=\"column\">\n {/* Data Queries */}\n <QueryEditor\n queries={dataQueries}\n expressions={expressionQueries}\n onRunQueries={() => runQueriesPreview()}\n onChangeQueries={onChangeQueries}\n onDuplicateQuery={onDuplicateQuery}\n panelData={queryPreviewData}\n condition={condition}\n onSetCondition={handleSetCondition}\n />\n {!simplifiedQueryStep && (\n <Tooltip\n content={t(\n 'alerting.query-and-expressions-step.no-compatible-sources',\n 'You appear to have no compatible data sources'\n )}\n show={noCompatibleDataSources}\n >\n <Button\n type=\"button\"\n onClick={() => {\n dispatch(addNewDataQuery());\n }}\n variant=\"secondary\"\n data-testid={selectors.components.QueryTab.addQuery}\n disabled={noCompatibleDataSources}\n className={styles.addQueryButton}\n >\n <Trans i18nKey=\"alerting.query-and-expressions-step.add-query\">Add query</Trans>\n </Button>\n </Tooltip>\n )}\n {/* We only show Switch for Grafana managed alerts */}\n {canSelectDataSourceManaged && isGrafanaAlertingType && !simplifiedQueryStep && mode === 'edit' && (\n <>\n <Divider />\n <SmartAlertTypeDetector\n editingExistingRule={editingExistingRule}\n queries={queries}\n onClickSwitch={onClickSwitch}\n />\n </>\n )}\n {/* Expression Queries */}\n {!simplifiedQueryStep && (\n <>\n <Divider />\n <Stack direction=\"column\" gap={0}>\n <Text element=\"h5\">\n <Trans i18nKey=\"alerting.query-and-expressions-step.expressions\">Expressions</Trans>\n </Text>\n <Text variant=\"bodySmall\" color=\"secondary\">\n <Trans i18nKey=\"alerting.query-and-expressions-step.manipulate-returned-queries-other-operations\">\n Manipulate data returned from queries with math and other operations.\n </Trans>\n </Text>\n </Stack>\n\n <ExpressionsEditor\n queries={queries}\n panelData={queryPreviewData}\n condition={condition}\n onSetCondition={handleSetCondition}\n onRemoveExpression={(refId) => {\n dispatch(removeExpression(refId));\n }}\n onUpdateRefId={onUpdateRefId}\n onUpdateExpressionType={(refId, type) => {\n dispatch(updateExpressionType({ refId, type }));\n }}\n onUpdateQueryExpression={(model) => {\n dispatch(updateExpression(model));\n }}\n />\n </>\n )}\n {/* action buttons */}\n <Stack direction=\"column\">\n {simplifiedQueryStep && (\n <SimpleConditionEditor\n simpleCondition={simpleCondition}\n onChange={setSimpleCondition}\n expressionQueriesList={expressionQueries}\n dispatch={dispatch}\n previewData={queryPreviewData[condition ?? '']}\n />\n )}\n <Stack direction=\"row\">\n {!simplifiedQueryStep && config.expressionsEnabled && <TypeSelectorButton onClickType={onClickType} />}\n\n {isPreviewLoading && (\n <Button icon=\"spinner\" type=\"button\" variant=\"destructive\" onClick={cancelQueries}>\n <Trans i18nKey=\"alerting.common.cancel\">Cancel</Trans>\n </Button>\n )}\n {!isPreviewLoading && (\n <Button\n data-testid={selectors.components.AlertRules.previewButton}\n icon=\"sync\"\n type=\"button\"\n onClick={() => runQueriesPreview()}\n disabled={emptyQueries}\n >\n {!simplifiedQueryStep\n ? t('alerting.queryAndExpressionsStep.preview', 'Preview')\n : t('alerting.queryAndExpressionsStep.previewCondition', 'Preview alert rule condition')}\n </Button>\n )}\n </Stack>\n </Stack>\n\n {/* No Queries */}\n {emptyQueries && (\n <Alert\n title={t(\n 'alerting.query-and-expressions-step.title-queries-expressions-configured',\n 'No queries or expressions have been configured'\n )}\n severity=\"warning\"\n >\n <Trans i18nKey=\"alerting.query-and-expressions-step.body-queries-expressions-configured\">\n Create at least one query or expression to be alerted on\n </Trans>\n </Alert>\n )}\n </Stack>\n )}\n </RuleEditorSection>\n\n <ConfirmModal\n isOpen={showResetModeModal}\n title={t(\n 'alerting.query-and-expressions-step.title-deactivate-advanced-options',\n 'Deactivate advanced options'\n )}\n body={\n <div>\n <Text element=\"p\">\n <Trans i18nKey=\"alerting.queryAndExpressionsStep.disableAdvancedOptions.text\">\n The selected queries and expressions cannot be converted to default. If you deactivate advanced options,\n your query and condition will be reset to default settings.\n </Trans>\n </Text>\n <br />\n </div>\n }\n confirmText={t('alerting.query-and-expressions-step.confirmText-deactivate', 'Deactivate')}\n icon=\"exclamation-triangle\"\n onConfirm={() => {\n setValue('editorSettings.simplifiedQueryEditor', true);\n setShowResetModal(false);\n dispatch(resetToSimpleCondition());\n }}\n onDismiss={() => setShowResetModal(false)}\n />\n </>\n );\n};\n\nfunction TypeSelectorButton({ onClickType }: { onClickType: (type: ExpressionQueryType) => void }) {\n const newMenu = (\n <Menu>\n {expressionTypes.map((type) => (\n <Tooltip key={type.value} content={type.description ?? ''} placement=\"right\">\n <MenuItem\n key={type.value}\n onClick={() => onClickType(type.value ?? ExpressionQueryType.math)}\n label={type.label ?? ''}\n />\n </Tooltip>\n ))}\n </Menu>\n );\n\n return (\n <Dropdown overlay={newMenu}>\n <Button variant=\"secondary\" data-testid={'add-expression-button'} icon=\"angle-down\">\n <Trans i18nKey=\"alerting.type-selector-button.add-expression\">Add expression</Trans>\n </Button>\n </Dropdown>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n addQueryButton: css({\n width: 'fit-content',\n }),\n helpInfo: css({\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n width: 'fit-content',\n fontWeight: theme.typography.fontWeightMedium,\n marginLeft: theme.spacing(1),\n fontSize: theme.typography.size.sm,\n cursor: 'pointer',\n }),\n helpInfoText: css({\n marginLeft: theme.spacing(0.5),\n textDecoration: 'underline',\n }),\n infoLink: css({\n color: theme.colors.text.link,\n }),\n});\n\nconst useSetExpressionAndDataSource = () => {\n const { setValue } = useFormContext<RuleFormValues>();\n\n return (updatedQueries: AlertQuery[]) => {\n // update data source name and expression if it's been changed in the queries from the reducer when prom or loki query\n const query = updatedQueries[0];\n if (!query) {\n return;\n }\n\n const dataSourceSettings = getDataSourceSrv().getInstanceSettings(query.datasourceUid);\n if (!dataSourceSettings) {\n throw new Error('The Data source has not been defined.');\n }\n\n if (isPromOrLokiQuery(query.model)) {\n const expression = query.model.expr;\n setValue('expression', expression);\n }\n };\n};\n","import { memo, useCallback, useEffect, useMemo, useState } from 'react';\nimport { FormProvider, useForm } from 'react-hook-form';\nimport { useAsync } from 'react-use';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { Button, LinkButton, LoadingPlaceholder, Stack } from '@grafana/ui';\nimport { useAppNotification } from 'app/core/copy/appNotification';\n\nimport {\n PostableRulerRuleGroupDTO,\n RulerRuleDTO,\n RulerRuleGroupDTO,\n} from '../../../../../../types/unified-alerting-dto';\nimport { alertRuleApi } from '../../../api/alertRuleApi';\nimport { fetchRulerRulesGroup } from '../../../api/ruler';\nimport { useDataSourceFeatures } from '../../../hooks/useCombinedRule';\nimport { useReturnTo } from '../../../hooks/useReturnTo';\nimport { DEFAULT_GROUP_EVALUATION_INTERVAL, getDefaultFormValues } from '../../../rule-editor/formDefaults';\nimport { RuleFormType, RuleFormValues } from '../../../types/rule-form';\nimport { GRAFANA_RULES_SOURCE_NAME } from '../../../utils/datasource';\nimport { formValuesToRulerGrafanaRuleDTO, getDefaultQueries } from '../../../utils/rule-form';\nimport { rulerRuleType } from '../../../utils/rules';\nimport { FileExportPreview } from '../../export/FileExportPreview';\nimport { GrafanaExportDrawer } from '../../export/GrafanaExportDrawer';\nimport { ExportFormats, HclExportProvider, allGrafanaExportProviders } from '../../export/providers';\nimport { AlertRuleNameAndMetric } from '../AlertRuleNameInput';\nimport AnnotationsStep from '../AnnotationsStep';\nimport { GrafanaEvaluationBehaviorStep } from '../GrafanaEvaluationBehavior';\nimport { GrafanaFolderAndLabelsStep } from '../GrafanaFolderAndLabelsStep';\nimport { NotificationsStep } from '../NotificationsStep';\nimport { QueryAndExpressionsStep } from '../query-and-alert-condition/QueryAndExpressionsStep';\n\ninterface ModifyExportRuleFormProps {\n alertUid?: string;\n ruleForm?: RuleFormValues;\n}\n\nexport function ModifyExportRuleForm({ ruleForm, alertUid }: ModifyExportRuleFormProps) {\n const defaultValuesForNewRule: RuleFormValues = useMemo(() => {\n const defaultRuleType = RuleFormType.grafana;\n\n return {\n ...getDefaultFormValues(),\n condition: 'C',\n queries: getDefaultQueries(false),\n type: defaultRuleType,\n evaluateEvery: DEFAULT_GROUP_EVALUATION_INTERVAL,\n };\n }, []);\n\n const formAPI = useForm<RuleFormValues>({\n mode: 'onSubmit',\n defaultValues: ruleForm ?? defaultValuesForNewRule,\n shouldFocusError: true,\n });\n\n const existing = Boolean(ruleForm);\n const notifyApp = useAppNotification();\n const { returnTo } = useReturnTo('/alerting/list');\n\n const [exportData, setExportData] = useState<RuleFormValues | undefined>(undefined);\n const [conditionErrorMsg, setConditionErrorMsg] = useState('');\n\n const onInvalid = (): void => {\n notifyApp.error('There are errors in the form. Please correct them and try again!');\n };\n\n const checkAlertCondition = (msg = '') => {\n setConditionErrorMsg(msg);\n };\n\n const submit = (exportData: RuleFormValues | undefined) => {\n if (conditionErrorMsg !== '') {\n notifyApp.error(conditionErrorMsg);\n return;\n }\n setExportData(exportData);\n };\n\n const onClose = useCallback(() => {\n setExportData(undefined);\n }, [setExportData]);\n\n return (\n <FormProvider {...formAPI}>\n <Stack direction=\"column\">\n <form onSubmit={(e) => e.preventDefault()}>\n <div>\n <Stack direction=\"column\" gap={3}>\n {/* Step 1 */}\n <AlertRuleNameAndMetric />\n {/* Step 2 */}\n <QueryAndExpressionsStep editingExistingRule={existing} onDataChange={checkAlertCondition} mode=\"draft\" />\n {/* Step 3-4-5 */}\n <GrafanaFolderAndLabelsStep />\n\n {/* Step 4 & 5 */}\n <GrafanaEvaluationBehaviorStep existing={Boolean(existing)} enableProvisionedGroups={true} />\n {/* Notifications step*/}\n <NotificationsStep alertUid={alertUid} />\n {/* Annotations only for cloud and Grafana */}\n <AnnotationsStep />\n </Stack>\n </div>\n </form>\n {exportData && <GrafanaRuleDesignExporter exportValues={exportData} onClose={onClose} uid={alertUid} />}\n <Stack direction=\"row\">\n <Button key=\"export-rule\" onClick={formAPI.handleSubmit((formValues) => submit(formValues), onInvalid)}>\n <Trans i18nKey=\"alerting.modify-export-rule-form.action-buttons.export\">Export</Trans>\n </Button>\n <LinkButton href={returnTo} key=\"cancel\" variant=\"secondary\" onClick={() => submit(undefined)}>\n <Trans i18nKey=\"alerting.common.cancel\">Cancel</Trans>\n </LinkButton>\n </Stack>\n </Stack>\n </FormProvider>\n );\n}\n\nconst useGetGroup = (nameSpaceUID: string, group: string) => {\n const { dsFeatures } = useDataSourceFeatures(GRAFANA_RULES_SOURCE_NAME);\n\n const rulerConfig = dsFeatures?.rulerConfig;\n\n const targetGroup = useAsync(async () => {\n return rulerConfig ? await fetchRulerRulesGroup(rulerConfig, nameSpaceUID, group) : undefined;\n }, [rulerConfig, nameSpaceUID, group]);\n\n return targetGroup;\n};\n\ninterface GrafanaRuleDesignExportPreviewProps {\n exportFormat: ExportFormats;\n onClose: () => void;\n exportValues: RuleFormValues;\n uid?: string;\n}\nexport const getPayloadToExport = (\n formValues: RuleFormValues,\n existingGroup: RulerRuleGroupDTO<RulerRuleDTO> | null | undefined,\n ruleUid?: string\n): PostableRulerRuleGroupDTO => {\n const grafanaRuleDto = formValuesToRulerGrafanaRuleDTO(formValues);\n\n const updatedRule = { ...grafanaRuleDto, grafana_alert: { ...grafanaRuleDto.grafana_alert, uid: ruleUid } };\n if (existingGroup?.rules) {\n // we have to update the rule in the group in the same position if it exists, otherwise we have to add it at the end\n let alreadyExistsInGroup = false;\n const updatedRules = existingGroup.rules.map((rule: RulerRuleDTO) => {\n if (rulerRuleType.grafana.rule(rule) && rule.grafana_alert.uid === ruleUid) {\n alreadyExistsInGroup = true;\n return updatedRule;\n } else {\n return rule;\n }\n });\n if (!alreadyExistsInGroup) {\n // we have to add the updated rule at the end of the group\n updatedRules.push(updatedRule);\n }\n return {\n ...existingGroup,\n rules: updatedRules,\n };\n } else {\n // we have to create a new group with the updated rule\n return {\n name: existingGroup?.name ?? formValues.group,\n rules: [updatedRule],\n };\n }\n};\n\nconst useGetPayloadToExport = (values: RuleFormValues, ruleUid?: string) => {\n const rulerGroupDto = useGetGroup(values.folder?.uid ?? '', values.group);\n const payload: PostableRulerRuleGroupDTO = useMemo(() => {\n return getPayloadToExport(values, rulerGroupDto?.value, ruleUid);\n }, [ruleUid, rulerGroupDto, values]);\n return { payload, loadingGroup: rulerGroupDto.loading };\n};\n\nconst GrafanaRuleDesignExportPreview = ({\n exportFormat,\n exportValues,\n onClose,\n uid,\n}: GrafanaRuleDesignExportPreviewProps) => {\n const [getExport, exportData] = alertRuleApi.endpoints.exportModifiedRuleGroup.useMutation();\n const { loadingGroup, payload } = useGetPayloadToExport(exportValues, uid);\n\n const nameSpaceUID = exportValues.folder?.uid ?? '';\n\n useEffect(() => {\n !loadingGroup && payload.name && getExport({ payload, format: exportFormat, nameSpaceUID });\n }, [nameSpaceUID, exportFormat, payload, getExport, loadingGroup]);\n\n if (exportData.isLoading) {\n return <LoadingPlaceholder text={t('alerting.grafana-rule-design-export-preview.text-loading', 'Loading....')} />;\n }\n\n const downloadFileName = `modify-export-${payload.name}-${uid}-${new Date().getTime()}`;\n\n return (\n <FileExportPreview\n format={exportFormat}\n textDefinition={exportData.data ?? ''}\n downloadFileName={downloadFileName}\n onClose={onClose}\n />\n );\n};\n\ninterface GrafanaRuleDesignExporterProps {\n onClose: () => void;\n exportValues: RuleFormValues;\n uid?: string;\n}\n\nexport const GrafanaRuleDesignExporter = memo(({ onClose, exportValues, uid }: GrafanaRuleDesignExporterProps) => {\n const exportingNewRule = !uid;\n const initialTab = exportingNewRule ? 'hcl' : 'yaml';\n const [activeTab, setActiveTab] = useState<ExportFormats>(initialTab);\n\n const formatProviders = exportingNewRule ? [HclExportProvider] : Object.values(allGrafanaExportProviders);\n\n return (\n <GrafanaExportDrawer\n title={t('alerting.grafana-rule-design-exporter.title-export-group', 'Export Group')}\n activeTab={activeTab}\n onTabChange={setActiveTab}\n onClose={onClose}\n formatProviders={formatProviders}\n >\n <GrafanaRuleDesignExportPreview\n exportFormat={activeTab}\n onClose={onClose}\n exportValues={exportValues}\n uid={uid}\n />\n </GrafanaExportDrawer>\n );\n});\n\nGrafanaRuleDesignExporter.displayName = 'GrafanaRuleDesignExporter';\n","import { useCallback } from 'react';\nimport { Controller, useFormContext } from 'react-hook-form';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { Field, Label, Stack } from '@grafana/ui';\nimport { NestedFolderPicker } from 'app/core/components/NestedFolderPicker/NestedFolderPicker';\n\nimport { Folder, RuleFormValues } from '../../types/rule-form';\nimport { CreateNewFolder } from '../create-folder/CreateNewFolder';\n\nexport function FolderSelector() {\n const {\n formState: { errors },\n setValue,\n watch,\n } = useFormContext<RuleFormValues>();\n\n const resetGroup = useCallback(() => {\n setValue('group', '');\n }, [setValue]);\n\n const folder = watch('folder');\n\n const handleFolderCreation = (folder: Folder) => {\n resetGroup();\n setValue('folder', folder);\n };\n\n return (\n <Stack alignItems=\"center\">\n {\n <Field\n label={\n <Label\n htmlFor=\"folder\"\n description={t(\n 'alerting.folder-selector.description-select-folder',\n 'Select a folder to store your rule in.'\n )}\n >\n <Trans i18nKey=\"alerting.rule-form.folder.label\">Folder</Trans>\n </Label>\n }\n error={errors.folder?.message}\n data-testid=\"folder-picker\"\n >\n <Stack direction=\"row\" alignItems=\"center\">\n <Controller\n render={({ field: { ref, ...field } }) => (\n <div style={{ width: 420 }}>\n <NestedFolderPicker\n permission=\"view\"\n showRootFolder={false}\n invalid={!!errors.folder?.message}\n {...field}\n value={folder?.uid}\n onChange={(uid, title) => {\n if (uid && title) {\n setValue('folder', { title, uid });\n } else {\n setValue('folder', undefined);\n }\n\n resetGroup();\n }}\n />\n </div>\n )}\n name=\"folder\"\n rules={{\n required: {\n value: true,\n message: t('alerting.folder-selector.message.select-a-folder', 'Select a folder'),\n },\n }}\n />\n <CreateNewFolder onCreate={handleFolderCreation} />\n </Stack>\n </Field>\n }\n </Stack>\n );\n}\n","import { useEffect, useState } from 'react';\nimport { useFormContext } from 'react-hook-form';\n\nimport { Trans, t } from '@grafana/i18n';\nimport { Stack, Text } from '@grafana/ui';\n\nimport { alertRuleApi } from '../../api/alertRuleApi';\nimport { GRAFANA_RULER_CONFIG } from '../../api/featureDiscoveryApi';\nimport { KBObjectArray, RuleFormValues } from '../../types/rule-form';\nimport { GRAFANA_RULES_SOURCE_NAME } from '../../utils/datasource';\n\nimport { FolderSelector } from './FolderSelector';\nimport { NeedHelpInfo } from './NeedHelpInfo';\nimport { RuleEditorSection } from './RuleEditorSection';\nimport { LabelsEditorModal } from './labels/LabelsEditorModal';\nimport { LabelsFieldInForm } from './labels/LabelsFieldInForm';\n\nconst { usePrefetch } = alertRuleApi;\n\n/** Precondition: rule is Grafana managed.\n */\nexport function GrafanaFolderAndLabelsStep() {\n const { setValue, getValues } = useFormContext<RuleFormValues>();\n const [showLabelsEditor, setShowLabelsEditor] = useState(false);\n\n const prefechRulerRules = usePrefetch('rulerRules');\n\n useEffect(() => {\n prefechRulerRules({ rulerConfig: GRAFANA_RULER_CONFIG });\n }, [prefechRulerRules]);\n\n function onCloseLabelsEditor(labelsToUpdate?: KBObjectArray) {\n if (labelsToUpdate) {\n setValue('labels', labelsToUpdate);\n }\n setShowLabelsEditor(false);\n }\n\n function SectionDescription() {\n return (\n <Stack direction=\"row\" gap={0.5} alignItems=\"center\">\n <Text variant=\"bodySmall\" color=\"secondary\">\n <Trans i18nKey=\"alerting.rule-form.folder-and-labels\">\n Organize your alert rule with a folder and set of labels.\n </Trans>\n </Text>\n <NeedHelpInfo\n contentText={\n <>\n <p>\n {t(\n 'alerting.rule-form.folders.help-info',\n 'Folders are used for storing alert rules. You can extend the access provided by a role to alert rules and assign permissions to individual folders.'\n )}\n </p>\n <p>\n {t(\n 'alerting.rule-form.labels.help-info',\n 'Labels are used to differentiate an alert from all other alerts.You can use them for searching, silencing, and routing notifications.'\n )}\n </p>\n </>\n }\n />\n </Stack>\n );\n }\n\n return (\n <RuleEditorSection\n stepNo={3}\n title={t('alerting.grafana-folder-and-labels-step.title-add-folder-and-labels', 'Add folder and labels')}\n description={<SectionDescription />}\n >\n <Stack direction=\"column\" justify-content=\"flex-start\" align-items=\"flex-start\">\n <FolderSelector />\n <LabelsFieldInForm onEditClick={() => setShowLabelsEditor(true)} />\n <LabelsEditorModal\n isOpen={showLabelsEditor}\n onClose={onCloseLabelsEditor}\n dataSourceName={GRAFANA_RULES_SOURCE_NAME}\n initialLabels={getValues('labels')}\n />\n </Stack>\n </RuleEditorSection>\n );\n}\n","import { useEffect, useState } from 'react';\n\nimport { DataSourceInstanceSettings } from '@grafana/data';\n\nimport { featureDiscoveryApi } from '../api/featureDiscoveryApi';\nimport { getRulesDataSources } from '../utils/datasource';\n\nconst { useLazyDiscoverDsFeaturesQuery } = featureDiscoveryApi;\n\nexport function useRulesSourcesWithRuler(): {\n rulesSourcesWithRuler: DataSourceInstanceSettings[];\n isLoading: boolean;\n} {\n const [rulesSourcesWithRuler, setRulesSourcesWithRuler] = useState<DataSourceInstanceSettings[]>([]);\n const [discoverDsFeatures, { isLoading }] = useLazyDiscoverDsFeaturesQuery();\n\n useEffect(() => {\n const dataSources = getRulesDataSources();\n dataSources.forEach(async (ds) => {\n const { data: dsFeatures } = await discoverDsFeatures({ uid: ds.uid }, true);\n if (dsFeatures?.rulerConfig) {\n setRulesSourcesWithRuler((prev) => [...prev, ds]);\n }\n });\n }, [discoverDsFeatures]);\n\n return { rulesSourcesWithRuler, isLoading };\n}\n","import { useCallback } from 'react';\n\nimport { DataSourceInstanceSettings } from '@grafana/data';\nimport { DataSourcePicker, DataSourcePickerProps } from 'app/features/datasources/components/picker/DataSourcePicker';\n\nimport { useRulesSourcesWithRuler } from '../../hooks/useRuleSourcesWithRuler';\n\ninterface Props extends DataSourcePickerProps {\n disabled?: boolean;\n onChange: (ds: DataSourceInstanceSettings) => void;\n value: string | null;\n onBlur?: () => void;\n name?: string;\n}\n\nexport function CloudRulesSourcePicker({ value, disabled, ...props }: Props): JSX.Element {\n const { rulesSourcesWithRuler: dataSourcesWithRuler, isLoading } = useRulesSourcesWithRuler();\n\n const dataSourceFilter = useCallback(\n (ds: DataSourceInstanceSettings): boolean => {\n return dataSourcesWithRuler.some(({ uid }) => uid === ds.uid);\n },\n [dataSourcesWithRuler]\n );\n\n return (\n <DataSourcePicker\n disabled={isLoading || disabled}\n noDefault\n alerting\n filter={dataSourceFilter}\n current={value}\n {...props}\n />\n );\n}\n","import { t } from '@grafana/i18n';\n\nimport { withPageErrorBoundary } from '../../withPageErrorBoundary';\nimport { AlertingPageWrapper } from '../AlertingPageWrapper';\nimport { ModifyExportRuleForm } from '../rule-editor/alert-rule-form/ModifyExportRuleForm';\n\nfunction ExportNewGrafanaRulePage() {\n return (\n <AlertingPageWrapper\n navId=\"alert-list\"\n pageNav={{\n text: t('alerting.export-new-grafana-rule-page.text.export-new-grafana-rule', 'Export new Grafana rule'),\n subTitle: 'Export a new rule definition in Terraform(HCL) format. Any changes you make will not be saved.',\n }}\n >\n <ModifyExportRuleForm />\n </AlertingPageWrapper>\n );\n}\n\nexport default withPageErrorBoundary(ExportNewGrafanaRulePage);\n","import { useMemo } from 'react';\n\nimport { getRulesAccess } from './access-control';\n\nexport function useRulesAccess() {\n return useMemo(() => getRulesAccess(), []);\n}\n","import { QueryStatus } from '@reduxjs/toolkit/query';\nimport { isEmpty } from 'lodash';\nimport { useEffect } from 'react';\nimport { Controller, useFormContext } from 'react-hook-form';\n\nimport { base64UrlEncode } from '@grafana/alerting';\nimport {\n ContactPointSelector as GrafanaManagedContactPointSelector,\n notificationsAPIv0alpha1,\n} from '@grafana/alerting/unstable';\nimport { Trans, t } from '@grafana/i18n';\nimport { Field, FieldValidationMessage, Stack, TextLink } from '@grafana/ui';\nimport { RuleFormValues } from 'app/features/alerting/unified/types/rule-form';\nimport { stringifyFieldSelector } from 'app/features/alerting/unified/utils/k8s/utils';\nimport { createRelativeUrl } from 'app/features/alerting/unified/utils/url';\n\nexport interface ContactPointSelectorProps {\n alertManager: string;\n}\n\nexport function ContactPointSelector({ alertManager }: ContactPointSelectorProps) {\n const { control, watch, trigger } = useFormContext<RuleFormValues>();\n\n const selectedContactPointField = `contactPoints.${alertManager}.selectedContactPoint` as const;\n const contactPointInForm = watch(selectedContactPointField);\n\n // check if the contact point still exists, we'll use listReceiver to check if the contact point exists because getReceiver doesn't work with\n // contact point titles but with UUIDs (which is not what we store on the alert rule definition)\n const encodedContactPoint = contactPointInForm ? base64UrlEncode(contactPointInForm) : '';\n const { currentData, status } = notificationsAPIv0alpha1.endpoints.listReceiver.useQuery(\n {\n fieldSelector: stringifyFieldSelector([['metadata.name', encodedContactPoint]]),\n },\n { skip: !contactPointInForm }\n );\n\n const contactPointNotFound = contactPointInForm && status === QueryStatus.fulfilled && isEmpty(currentData?.items);\n\n // validate the contact point and check if it still exists when we've gotten a response from the API\n useEffect(() => {\n if (contactPointInForm && status === QueryStatus.fulfilled) {\n trigger(selectedContactPointField, { shouldFocus: true });\n }\n }, [contactPointInForm, selectedContactPointField, status, trigger]);\n\n return (\n <Stack direction=\"row\" alignItems=\"center\">\n <Field\n noMargin\n label={t('alerting.contact-point-selector.contact-point-picker-label-contact-point', 'Contact point')}\n data-testid=\"contact-point-picker\"\n >\n <Controller\n name={selectedContactPointField}\n render={({ field: { onChange }, fieldState: { error } }) => (\n <>\n <Stack>\n <GrafanaManagedContactPointSelector\n isClearable={false}\n onChange={(contactPoint) => onChange(contactPoint.spec.title)}\n width={50}\n value={contactPointInForm}\n />\n <LinkToContactPoints />\n </Stack>\n\n {/* Error can come from the required validation we have in here, or from the manual setError we do in the parent component.\n The only way I found to check the custom error is to check if the field has a value and if it's not in the options. */}\n\n {error && <FieldValidationMessage>{error?.message}</FieldValidationMessage>}\n </>\n )}\n rules={{\n validate: () => {\n if (contactPointNotFound) {\n return t(\n 'alerting.contactPoints.validation.notFound',\n `Contact point \"{{contactPoint}}\" could not be found`,\n {\n contactPoint: contactPointInForm,\n }\n );\n }\n return true;\n },\n required: {\n value: true,\n message: t(\n 'alerting.contact-point-selector.message.contact-point-is-required',\n 'Contact point is required.'\n ),\n },\n }}\n control={control}\n />\n </Field>\n </Stack>\n );\n}\nfunction LinkToContactPoints() {\n const hrefToContactPoints = '/alerting/notifications';\n return (\n <TextLink\n external\n href={createRelativeUrl(hrefToContactPoints)}\n aria-label={t(\n 'alerting.link-to-contact-points.aria-label-view-or-create-contact-points',\n 'View or create contact points'\n )}\n >\n <Trans i18nKey=\"alerting.link-to-contact-points.view-or-create-contact-points\">\n View or create contact points\n </Trans>\n </TextLink>\n );\n}\n","import { css } from '@emotion/css';\nimport { Controller, useFormContext } from 'react-hook-form';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { Field, useStyles2 } from '@grafana/ui';\nimport MuteTimingsSelector from 'app/features/alerting/unified/components/alertmanager-entities/MuteTimingsSelector';\nimport { BaseAlertmanagerArgs } from 'app/features/alerting/unified/types/hooks';\nimport { RuleFormValues } from 'app/features/alerting/unified/types/rule-form';\nimport { mapMultiSelectValueToStrings } from 'app/features/alerting/unified/utils/amroutes';\n\n/** Provides a form field for use in simplified routing, for selecting appropriate mute timings */\nexport function ActiveTimingFields({ alertmanager }: BaseAlertmanagerArgs) {\n const styles = useStyles2(getStyles);\n const {\n control,\n formState: { errors },\n } = useFormContext<RuleFormValues>();\n\n return (\n <Field\n label={t('alerting.active-timing-fields.am-active-timing-select-label-active-timings', 'Active timings')}\n data-testid=\"am-active-timing-select\"\n description={t(\n 'alerting.mute-timing-fields.am-active-timing-select-description-active-timings',\n 'Select a time interval to define when to only send notifications for this alert rule'\n )}\n className={styles.muteTimingField}\n invalid={!!errors.contactPoints?.[alertmanager]?.activeTimeIntervals}\n >\n <Controller\n render={({ field: { onChange, ref, ...field } }) => (\n <MuteTimingsSelector\n alertmanager={alertmanager}\n selectProps={{\n ...field,\n onChange: (value) => onChange(mapMultiSelectValueToStrings(value)),\n }}\n />\n )}\n control={control}\n name={`contactPoints.${alertmanager}.activeTimeIntervals`}\n />\n </Field>\n );\n}\nconst getStyles = (theme: GrafanaTheme2) => ({\n muteTimingField: css({\n marginTop: theme.spacing(1),\n }),\n});\n","import { css } from '@emotion/css';\nimport { Controller, useFormContext } from 'react-hook-form';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { Field, useStyles2 } from '@grafana/ui';\nimport MuteTimingsSelector from 'app/features/alerting/unified/components/alertmanager-entities/MuteTimingsSelector';\nimport { BaseAlertmanagerArgs } from 'app/features/alerting/unified/types/hooks';\nimport { RuleFormValues } from 'app/features/alerting/unified/types/rule-form';\nimport { mapMultiSelectValueToStrings } from 'app/features/alerting/unified/utils/amroutes';\n\n/** Provides a form field for use in simplified routing, for selecting appropriate mute timings */\nexport function MuteTimingFields({ alertmanager }: BaseAlertmanagerArgs) {\n const styles = useStyles2(getStyles);\n const {\n control,\n formState: { errors },\n } = useFormContext<RuleFormValues>();\n\n return (\n <Field\n label={t('alerting.mute-timing-fields.am-mute-timing-select-label-mute-timings', 'Mute timings')}\n data-testid=\"am-mute-timing-select\"\n description={t(\n 'alerting.mute-timing-fields.am-mute-timing-select-description-mute-timings',\n 'Select a mute timing to define when not to send notifications for this alert rule'\n )}\n className={styles.muteTimingField}\n invalid={!!errors.contactPoints?.[alertmanager]?.muteTimeIntervals}\n >\n <Controller\n render={({ field: { onChange, ref, ...field } }) => (\n <MuteTimingsSelector\n alertmanager={alertmanager}\n selectProps={{\n ...field,\n onChange: (value) => onChange(mapMultiSelectValueToStrings(value)),\n }}\n />\n )}\n control={control}\n name={`contactPoints.${alertmanager}.muteTimeIntervals`}\n />\n </Field>\n );\n}\nconst getStyles = (theme: GrafanaTheme2) => ({\n muteTimingField: css({\n marginTop: theme.spacing(1),\n }),\n});\n","import { useFormContext } from 'react-hook-form';\n\nimport { Field, useStyles2 } from '@grafana/ui';\nimport { RuleFormValues } from 'app/features/alerting/unified/types/rule-form';\nimport { promDurationValidator, repeatIntervalValidator } from 'app/features/alerting/unified/utils/amroutes';\n\nimport { PromDurationInput } from '../../../../notification-policies/PromDurationInput';\nimport { getFormStyles } from '../../../../notification-policies/formStyles';\nimport { routeTimingsFields } from '../../../../notification-policies/routeTimingsFields';\nimport { TIMING_OPTIONS_DEFAULTS } from '../../../../notification-policies/timingOptions';\n\ninterface RouteTimingsProps {\n alertManager: string;\n}\n\nexport function RouteTimings({ alertManager }: RouteTimingsProps) {\n const formStyles = useStyles2(getFormStyles);\n const {\n register,\n formState: { errors },\n getValues,\n } = useFormContext<RuleFormValues>();\n return (\n <>\n <Field\n label={routeTimingsFields.groupWait.label}\n description={routeTimingsFields.groupWait.description}\n invalid={!!errors.contactPoints?.[alertManager]?.groupWaitValue}\n error={errors.contactPoints?.[alertManager]?.groupWaitValue?.message}\n >\n <PromDurationInput\n {...register(`contactPoints.${alertManager}.groupWaitValue`, { validate: promDurationValidator })}\n aria-label={routeTimingsFields.groupWait.ariaLabel}\n className={formStyles.promDurationInput}\n placeholder={TIMING_OPTIONS_DEFAULTS.group_wait}\n />\n </Field>\n <Field\n label={routeTimingsFields.groupInterval.label}\n description={routeTimingsFields.groupInterval.description}\n invalid={!!errors.contactPoints?.[alertManager]?.groupIntervalValue}\n error={errors.contactPoints?.[alertManager]?.groupIntervalValue?.message}\n >\n <PromDurationInput\n {...register(`contactPoints.${alertManager}.groupIntervalValue`, {\n validate: promDurationValidator,\n })}\n aria-label={routeTimingsFields.groupInterval.ariaLabel}\n className={formStyles.promDurationInput}\n placeholder={TIMING_OPTIONS_DEFAULTS.group_interval}\n />\n </Field>\n <Field\n label={routeTimingsFields.repeatInterval.label}\n description={routeTimingsFields.repeatInterval.description}\n invalid={!!errors.contactPoints?.[alertManager]?.repeatIntervalValue}\n error={errors.contactPoints?.[alertManager]?.repeatIntervalValue?.message}\n >\n <PromDurationInput\n {...register(`contactPoints.${alertManager}.repeatIntervalValue`, {\n validate: (value: string) => {\n const groupInterval = getValues(`contactPoints.${alertManager}.repeatIntervalValue`);\n return repeatIntervalValidator(value, groupInterval);\n },\n })}\n aria-label={routeTimingsFields.repeatInterval.ariaLabel}\n className={formStyles.promDurationInput}\n placeholder={TIMING_OPTIONS_DEFAULTS.repeat_interval}\n />\n </Field>\n </>\n );\n}\n","import { css } from '@emotion/css';\nimport { useEffect, useState } from 'react';\nimport * as React from 'react';\nimport { Controller, useFormContext } from 'react-hook-form';\n\nimport { GrafanaTheme2, SelectableValue } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Field, FieldValidationMessage, InlineField, MultiSelect, Stack, Switch, Text, useStyles2 } from '@grafana/ui';\nimport { MultiValueRemove, MultiValueRemoveProps } from '@grafana/ui/internal';\nimport { RuleFormValues } from 'app/features/alerting/unified/types/rule-form';\nimport {\n commonGroupByOptions,\n mapMultiSelectValueToStrings,\n stringToSelectableValue,\n stringsToSelectableValues,\n} from 'app/features/alerting/unified/utils/amroutes';\n\nimport { getFormStyles } from '../../../../notification-policies/formStyles';\nimport { TIMING_OPTIONS_DEFAULTS } from '../../../../notification-policies/timingOptions';\n\nimport { RouteTimings } from './RouteTimings';\n\nconst REQUIRED_FIELDS_IN_GROUPBY = ['grafana_folder', 'alertname'];\n\nconst DEFAULTS_TIMINGS = {\n groupWaitValue: TIMING_OPTIONS_DEFAULTS.group_wait,\n groupIntervalValue: TIMING_OPTIONS_DEFAULTS.group_interval,\n repeatIntervalValue: TIMING_OPTIONS_DEFAULTS.repeat_interval,\n};\nconst DISABLE_GROUPING = '...';\n\nexport interface RoutingSettingsProps {\n alertManager: string;\n}\nexport const RoutingSettings = ({ alertManager }: RoutingSettingsProps) => {\n const formStyles = useStyles2(getFormStyles);\n const {\n control,\n watch,\n register,\n setValue,\n formState: { errors },\n } = useFormContext<RuleFormValues>();\n const [groupByOptions, setGroupByOptions] = useState(stringsToSelectableValues([]));\n const { groupIntervalValue, groupWaitValue, repeatIntervalValue } = DEFAULTS_TIMINGS;\n const overrideGrouping = watch(`contactPoints.${alertManager}.overrideGrouping`);\n const overrideTimings = watch(`contactPoints.${alertManager}.overrideTimings`);\n const groupByCount = watch(`contactPoints.${alertManager}.groupBy`)?.length ?? 0;\n\n const styles = useStyles2(getStyles);\n useEffect(() => {\n if (overrideGrouping && groupByCount === 0) {\n setValue(`contactPoints.${alertManager}.groupBy`, REQUIRED_FIELDS_IN_GROUPBY);\n }\n }, [overrideGrouping, setValue, alertManager, groupByCount]);\n\n const separator = <span>, </span>;\n\n return (\n <Stack direction=\"column\">\n <Stack direction=\"row\" gap={1} alignItems=\"center\" justifyContent=\"space-between\">\n <InlineField\n label={t('alerting.routing-settings.label-override-grouping', 'Override grouping')}\n transparent={true}\n className={styles.switchElement}\n >\n <Switch id=\"override-grouping-toggle\" {...register(`contactPoints.${alertManager}.overrideGrouping`)} />\n </InlineField>\n {!overrideGrouping && (\n <Text variant=\"body\" color=\"secondary\">\n <Trans\n i18nKey=\"alerting.routing-settings.grouping\"\n values={{ fields: REQUIRED_FIELDS_IN_GROUPBY.join(', ') }}\n >\n Grouping: <strong>{'{{fields}}'}</strong>\n </Trans>\n </Text>\n )}\n </Stack>\n {overrideGrouping && (\n <Field\n label={t('alerting.routing-settings.label-group-by', 'Group by')}\n description={t(\n 'alerting.routing-settings.description-group-by',\n 'Combine multiple alerts into a single notification by grouping them by the same label values. If empty, it is inherited from the default notification policy.'\n )}\n {...register(`contactPoints.${alertManager}.groupBy`)}\n invalid={!!errors.contactPoints?.[alertManager]?.groupBy}\n className={styles.optionalContent}\n >\n <Controller\n rules={{\n validate: (value: string[]) => {\n if (!value || value.length === 0) {\n return 'At least one group by option is required.';\n }\n if (value.length === 1 && value[0] === DISABLE_GROUPING) {\n return true;\n }\n // we need to make sure that the required fields are included\n const requiredFieldsIncluded = REQUIRED_FIELDS_IN_GROUPBY.every((field) => value.includes(field));\n if (!requiredFieldsIncluded) {\n return `Group by must include ${REQUIRED_FIELDS_IN_GROUPBY.join(', ')}`;\n }\n return true;\n },\n }}\n render={({ field: { onChange, ref, ...field }, fieldState: { error } }) => (\n <>\n <MultiSelect\n aria-label={t('alerting.routing-settings.aria-label-group-by', 'Group by')}\n {...field}\n allowCustomValue\n className={formStyles.input}\n onCreateOption={(opt: string) => {\n setGroupByOptions((opts) => [...opts, stringToSelectableValue(opt)]);\n\n // @ts-ignore-check: react-hook-form made me do this\n setValue(`contactPoints.${alertManager}.groupBy`, [...field.value, opt]);\n }}\n onChange={(value) => {\n return onChange(mapMultiSelectValueToStrings(value));\n }}\n options={[...commonGroupByOptions, ...groupByOptions]}\n components={{\n MultiValueRemove(\n props: React.PropsWithChildren<\n MultiValueRemoveProps &\n Array<SelectableValue<string>> & {\n data: {\n label: string;\n value: string;\n isFixed: boolean;\n };\n }\n >\n ) {\n const { data } = props;\n if (data.isFixed) {\n return null;\n }\n return MultiValueRemove(props);\n },\n }}\n />\n {error && <FieldValidationMessage>{error.message}</FieldValidationMessage>}\n </>\n )}\n name={`contactPoints.${alertManager}.groupBy`}\n control={control}\n />\n </Field>\n )}\n <Stack direction=\"row\" gap={1} alignItems=\"center\" justifyContent=\"space-between\">\n <InlineField\n label={t('alerting.routing-settings.label-override-timings', 'Override timings')}\n transparent={true}\n className={styles.switchElement}\n >\n <Switch id=\"override-timings-toggle\" {...register(`contactPoints.${alertManager}.overrideTimings`)} />\n </InlineField>\n {!overrideTimings && (\n <Text variant=\"body\" color=\"secondary\">\n <Trans i18nKey=\"alerting.routing-settings.group-wait\" values={{ groupWaitValue }}>\n Group wait: <strong>{'{{groupWaitValue}}'}</strong>\n </Trans>\n {separator}\n <Trans i18nKey=\"alerting.routing-settings.group-interval\" values={{ groupIntervalValue }}>\n Group interval: <strong>{'{{groupIntervalValue}}'}</strong>\n </Trans>\n {separator}\n <Trans i18nKey=\"alerting.routing-settings.repeat-interval\" values={{ repeatIntervalValue }}>\n Repeat interval: <strong>{'{{repeatIntervalValue}}'}</strong>\n </Trans>\n </Text>\n )}\n </Stack>\n {overrideTimings && (\n <div className={styles.optionalContent}>\n <RouteTimings alertManager={alertManager} />\n </div>\n )}\n </Stack>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n switchElement: css({\n flexFlow: 'row-reverse',\n gap: theme.spacing(1),\n alignItems: 'center',\n }),\n optionalContent: css({\n marginLeft: '49px',\n marginBottom: theme.spacing(1),\n }),\n});\n","import { css } from '@emotion/css';\nimport { useFormContext } from 'react-hook-form';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { CollapsableSection, Stack, Text, useStyles2 } from '@grafana/ui';\nimport { RuleFormValues } from 'app/features/alerting/unified/types/rule-form';\nimport { AlertManagerDataSource } from 'app/features/alerting/unified/utils/datasource';\n\nimport { NeedHelpInfo } from '../../NeedHelpInfo';\n\nimport { ContactPointSelector } from './contactPoint/ContactPointSelector';\nimport { ActiveTimingFields } from './route-settings/ActiveTimingFields';\nimport { MuteTimingFields } from './route-settings/MuteTimingFields';\nimport { RoutingSettings } from './route-settings/RouteSettings';\n\ninterface AlertManagerManualRoutingProps {\n alertManager: AlertManagerDataSource;\n}\n\nexport function AlertManagerManualRouting({ alertManager }: AlertManagerManualRoutingProps) {\n const styles = useStyles2(getStyles);\n\n const alertManagerName = alertManager.name;\n\n const { watch } = useFormContext<RuleFormValues>();\n\n const hasRouteSettings =\n watch(`contactPoints.${alertManagerName}.overrideGrouping`) ||\n watch(`contactPoints.${alertManagerName}.overrideTimings`) ||\n watch(`contactPoints.${alertManagerName}.muteTimeIntervals`)?.length > 0;\n\n return (\n <Stack direction=\"column\">\n <Stack direction=\"row\" alignItems=\"center\">\n <div className={styles.firstAlertManagerLine} />\n <div className={styles.alertManagerName}>\n <Trans i18nKey=\"alerting.rule-form.simple-routing.alertmanager-label\">Alertmanager:</Trans>\n <img src={alertManager.imgUrl} alt=\"Alert manager logo\" className={styles.img} />\n {alertManagerName}\n </div>\n <div className={styles.secondAlertManagerLine} />\n </Stack>\n <Stack direction=\"row\" gap={1} alignItems=\"center\">\n <ContactPointSelector alertManager={alertManagerName} />\n </Stack>\n {/* @TODO\n we can show the contact point details here when it's selected but we currently don't have a\n way to summarize the details from the ContactPoint type in @grafana/alerting\n */}\n <div className={styles.routingSection}>\n <CollapsableSection\n label={t(\n 'alerting.alert-manager-manual-routing.label-muting-grouping-and-timings-optional',\n 'Muting, grouping and timings (optional)'\n )}\n isOpen={hasRouteSettings}\n className={styles.collapsableSection}\n contentClassName={styles.collapsableSectionContent}\n >\n <Stack direction=\"column\" gap={1}>\n <Stack direction=\"row\" gap={0.5} alignItems=\"center\">\n <Text variant=\"bodySmall\" color=\"secondary\">\n <Trans i18nKey=\"alerting.rule-form.simple-routing.optional-settings.description\">\n Configure how notifications for this alert rule are sent.\n </Trans>\n </Text>\n <NeedHelpInfo\n title={t(\n 'alerting.alert-manager-manual-routing.title-muting-grouping-and-timings',\n 'Muting, grouping, and timings'\n )}\n linkText={'Read about notification grouping'}\n externalLink={\n 'https://grafana.com/docs/grafana/latest/alerting/fundamentals/notifications/group-alert-notifications/'\n }\n contentText={\n <>\n <p>\n {t(\n 'alerting.rule-form.simple-routing.optional-settings.help-info1',\n 'Mute timings allows you to temporarily pause notifications for a specific recurring period, such as a regular maintenance window or weekends.'\n )}\n </p>\n {t(\n 'alerting.rule-form.simple-routing.optional-settings.help-info2',\n 'Grouping and timing options combine multiple alerts within a specific period into a single notification, allowing you to customize default options.'\n )}\n </>\n }\n />\n </Stack>\n <MuteTimingFields alertmanager={alertManagerName} />\n <ActiveTimingFields alertmanager={alertManagerName} />\n <RoutingSettings alertManager={alertManagerName} />\n </Stack>\n </CollapsableSection>\n </div>\n </Stack>\n );\n}\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n firstAlertManagerLine: css({\n height: 1,\n width: theme.spacing(4),\n backgroundColor: theme.colors.secondary.main,\n }),\n alertManagerName: css({\n with: 'fit-content',\n }),\n secondAlertManagerLine: css({\n height: '1px',\n width: '100%',\n flex: 1,\n backgroundColor: theme.colors.secondary.main,\n }),\n img: css({\n marginLeft: theme.spacing(2),\n width: theme.spacing(3),\n height: theme.spacing(3),\n marginRight: theme.spacing(1),\n }),\n collapsableSection: css({\n width: 'fit-content',\n fontSize: theme.typography.body.fontSize,\n }),\n collapsableSectionContent: css({\n padding: '0',\n }),\n routingSection: css({\n display: 'flex',\n flexDirection: 'column',\n maxWidth: theme.breakpoints.values.xl,\n border: `solid 1px ${theme.colors.border.weak}`,\n borderRadius: theme.shape.radius.default,\n padding: `${theme.spacing(1)} ${theme.spacing(2)}`,\n marginTop: theme.spacing(2),\n }),\n});\n","import { useMemo } from 'react';\nimport { useFormContext } from 'react-hook-form';\n\nimport { AlertmanagerProvider } from 'app/features/alerting/unified/state/AlertmanagerContext';\nimport { RuleFormValues } from 'app/features/alerting/unified/types/rule-form';\nimport { getAlertManagerDataSourcesByPermission } from 'app/features/alerting/unified/utils/datasource';\n\nimport { AlertManagerManualRouting } from './AlertManagerRouting';\n\nexport function SimplifiedRouting() {\n const { getValues } = useFormContext<RuleFormValues>();\n const contactPointsInAlert = getValues('contactPoints');\n\n const allAlertManagersByPermission = getAlertManagerDataSourcesByPermission('notification');\n\n // We decided to only show internal alert manager for now. Once we want to show external alert managers we can use this code\n // const alertManagersDataSources = allAlertManagersByPermission.availableInternalDataSources.concat(\n // allAlertManagersByPermission.availableExternalDataSources\n // );\n\n const alertManagersDataSources = allAlertManagersByPermission.availableInternalDataSources;\n\n const alertManagersDataSourcesWithConfigAPI = alertManagersDataSources.filter((am) => am.hasConfigurationAPI);\n\n // we merge the selected contact points data for each alert manager, with the alert manager meta data\n const alertManagersWithSelectedContactPoints = useMemo(\n () =>\n alertManagersDataSourcesWithConfigAPI.map((am) => {\n const selectedContactPoint = contactPointsInAlert ? contactPointsInAlert[am.name] : undefined;\n return {\n alertManager: am,\n selectedContactPoint: selectedContactPoint?.selectedContactPoint ?? '',\n routeSettings: {\n muteTimeIntervals: selectedContactPoint?.muteTimeIntervals ?? [],\n activeTimeIntervals: selectedContactPoint?.activeTimeIntervals ?? [],\n overrideGrouping: selectedContactPoint?.overrideGrouping ?? false,\n groupBy: selectedContactPoint?.groupBy ?? [],\n overrideTimings: selectedContactPoint?.overrideTimings ?? false,\n groupWaitValue: selectedContactPoint?.groupWaitValue ?? '',\n groupIntervalValue: selectedContactPoint?.groupIntervalValue ?? '',\n repeatIntervalValue: selectedContactPoint?.repeatIntervalValue ?? '',\n },\n };\n }),\n [alertManagersDataSourcesWithConfigAPI, contactPointsInAlert]\n );\n\n return alertManagersWithSelectedContactPoints.map((alertManagerContactPoint, index) => {\n return (\n <AlertmanagerProvider\n accessType={'notification'}\n alertmanagerSourceName={alertManagerContactPoint.alertManager.name}\n key={alertManagerContactPoint.alertManager.name + index}\n >\n <AlertManagerManualRouting alertManager={alertManagerContactPoint.alertManager} />\n </AlertmanagerProvider>\n );\n });\n}\n","import { css } from '@emotion/css';\nimport { Fragment, Suspense, lazy } from 'react';\nimport { useEffectOnce } from 'react-use';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Button, LoadingPlaceholder, Stack, Text, useStyles2 } from '@grafana/ui';\nimport { alertRuleApi } from 'app/features/alerting/unified/api/alertRuleApi';\nimport { AlertQuery, Labels } from 'app/types/unified-alerting-dto';\n\nimport { Folder, KBObjectArray } from '../../../types/rule-form';\nimport { useGetAlertManagerDataSourcesByPermissionAndConfig } from '../../../utils/datasource';\n\nconst NotificationPreviewByAlertManager = lazy(() => import('./NotificationPreviewByAlertManager'));\nconst NotificationPreviewForGrafanaManaged = lazy(() => import('./NotificationPreviewGrafanaManaged'));\n\ninterface NotificationPreviewProps {\n customLabels: KBObjectArray;\n alertQueries: AlertQuery[];\n condition: string | null;\n folder?: Folder;\n alertName?: string;\n alertUid?: string;\n}\n\nconst { preview } = alertRuleApi.endpoints;\n\n// TODO the scroll position keeps resetting when we preview\n// this is to be expected because the list of routes dissapears as we start the request but is very annoying\nexport const NotificationPreview = ({\n alertQueries,\n customLabels,\n condition,\n folder,\n alertName,\n alertUid,\n}: NotificationPreviewProps) => {\n const styles = useStyles2(getStyles);\n const disabled = !condition || !folder;\n\n const [trigger, { data = [], isLoading, isUninitialized: previewUninitialized }] = preview.useMutation();\n\n // potential instances are the instances that are going to be routed to the notification policies\n // convert data to list of labels: are the representation of the potential instances\n const potentialInstances = data.reduce<Labels[]>((acc = [], instance) => {\n if (instance.labels) {\n acc.push(instance.labels);\n }\n\n return acc;\n }, []);\n\n const onPreview = () => {\n if (!folder || !condition) {\n return;\n }\n\n // Get the potential labels given the alert queries, the condition and the custom labels (autogenerated labels are calculated on the BE side)\n trigger({\n alertQueries: alertQueries,\n condition: condition,\n customLabels: customLabels,\n folder: folder,\n alertName: alertName,\n alertUid: alertUid,\n });\n };\n\n useEffectOnce(() => {\n onPreview();\n });\n\n // Get alert managers's data source information\n const alertManagerDataSources = useGetAlertManagerDataSourcesByPermissionAndConfig('notification');\n const singleAlertManagerConfigured = alertManagerDataSources.length === 1;\n\n return (\n <Stack direction=\"column\">\n <Stack direction=\"row\" alignItems=\"flex-start\" justifyContent=\"space-between\">\n <Stack direction=\"column\" gap={1}>\n <Text element=\"h5\">\n <Trans i18nKey=\"alerting.notification-preview.title\">Alert instance routing preview</Trans>\n </Text>\n {isLoading && previewUninitialized && (\n <Text color=\"secondary\" variant=\"bodySmall\">\n <Trans i18nKey=\"alerting.common.loading\">Loading...</Trans>\n </Text>\n )}\n {previewUninitialized ? (\n <Text color=\"secondary\" variant=\"bodySmall\">\n <Trans i18nKey=\"alerting.notification-preview.uninitialized\">\n When you have your folder selected and your query and labels are configured, click "Preview\n routing" to see the results here.\n </Trans>\n </Text>\n ) : (\n <Text color=\"secondary\" variant=\"bodySmall\">\n <Trans i18nKey=\"alerting.notification-preview.initialized\">\n Based on the labels added, alert instances are routed to the following notification policies. Expand\n each notification policy below to view more details.\n </Trans>\n </Text>\n )}\n </Stack>\n <Button icon=\"sync\" variant=\"secondary\" type=\"button\" onClick={onPreview} disabled={disabled}>\n <Trans i18nKey=\"alerting.notification-preview.preview-routing\">Preview routing</Trans>\n </Button>\n </Stack>\n {potentialInstances.length > 0 && (\n <Suspense\n fallback={\n <LoadingPlaceholder text={t('alerting.notification-preview.text-loading-preview', 'Loading preview...')} />\n }\n >\n {alertManagerDataSources.map((alertManagerSource) => (\n <Fragment key={alertManagerSource.name}>\n {!singleAlertManagerConfigured && (\n <Stack direction=\"row\" alignItems=\"center\">\n <div className={styles.firstAlertManagerLine} />\n <div className={styles.alertManagerName}>\n <Trans i18nKey=\"alerting.notification-preview.alertmanager\">Alertmanager:</Trans>\n <img src={alertManagerSource.imgUrl} alt=\"\" className={styles.img} />\n {alertManagerSource.name}\n </div>\n <div className={styles.secondAlertManagerLine} />\n </Stack>\n )}\n {alertManagerSource.name === 'grafana' ? (\n <NotificationPreviewForGrafanaManaged\n alertManagerSource={alertManagerSource}\n instances={potentialInstances}\n />\n ) : (\n <NotificationPreviewByAlertManager\n alertManagerSource={alertManagerSource}\n instances={potentialInstances}\n />\n )}\n </Fragment>\n ))}\n </Suspense>\n )}\n </Stack>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n firstAlertManagerLine: css({\n height: '1px',\n width: theme.spacing(4),\n backgroundColor: theme.colors.secondary.main,\n }),\n alertManagerName: css({\n width: 'fit-content',\n }),\n secondAlertManagerLine: css({\n height: '1px',\n width: '100%',\n flex: 1,\n backgroundColor: theme.colors.secondary.main,\n }),\n img: css({\n marginLeft: theme.spacing(2),\n width: theme.spacing(3),\n height: theme.spacing(3),\n marginRight: theme.spacing(1),\n }),\n});\n","import { css } from '@emotion/css';\nimport { useState } from 'react';\nimport { useFormContext } from 'react-hook-form';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { config } from '@grafana/runtime';\nimport { RadioButtonGroup, Stack, Text, TextLink, useStyles2 } from '@grafana/ui';\nimport { AlertmanagerChoice } from 'app/plugins/datasource/alertmanager/types';\n\nimport { alertmanagerApi } from '../../api/alertmanagerApi';\nimport { KBObjectArray, RuleFormType, RuleFormValues } from '../../types/rule-form';\nimport { GRAFANA_RULES_SOURCE_NAME } from '../../utils/datasource';\nimport { isGrafanaManagedRuleByType, isGrafanaRecordingRuleByType, isRecordingRuleByType } from '../../utils/rules';\n\nimport { NeedHelpInfo } from './NeedHelpInfo';\nimport { RuleEditorSection } from './RuleEditorSection';\nimport { SimplifiedRouting } from './alert-rule-form/simplifiedRouting/SimplifiedRouting';\nimport { LabelsEditorModal } from './labels/LabelsEditorModal';\nimport { LabelsFieldInForm } from './labels/LabelsFieldInForm';\nimport { NotificationPreview } from './notificaton-preview/NotificationPreview';\n\ntype NotificationsStepProps = {\n alertUid?: string;\n};\n\nenum RoutingOptions {\n NotificationPolicy = 'notification policy',\n ContactPoint = 'contact point',\n}\n\nfunction useHasInternalAlertmanagerEnabled() {\n const { useGetGrafanaAlertingConfigurationStatusQuery } = alertmanagerApi;\n const { currentData: amChoiceStatus } = useGetGrafanaAlertingConfigurationStatusQuery(undefined);\n return (\n amChoiceStatus?.alertmanagersChoice === AlertmanagerChoice.Internal ||\n amChoiceStatus?.alertmanagersChoice === AlertmanagerChoice.All\n );\n}\n\nexport const NotificationsStep = ({ alertUid }: NotificationsStepProps) => {\n const { watch, getValues, setValue } = useFormContext<RuleFormValues>();\n const styles = useStyles2(getStyles);\n\n const [type, manualRouting] = watch(['type', 'manualRouting']);\n const [showLabelsEditor, setShowLabelsEditor] = useState(false);\n\n const dataSourceName = watch('dataSourceName') ?? GRAFANA_RULES_SOURCE_NAME;\n const isGrafanaManaged = isGrafanaManagedRuleByType(type);\n const simplifiedModeInNotificationsStepEnabled = config.featureToggles.alertingNotificationsStepMode ?? false;\n const shouldRenderpreview = type === RuleFormType.grafana;\n const hasInternalAlertmanagerEnabled = useHasInternalAlertmanagerEnabled();\n\n const shouldAllowSimplifiedRouting = type === RuleFormType.grafana && hasInternalAlertmanagerEnabled;\n\n function onCloseLabelsEditor(labelsToUpdate?: KBObjectArray) {\n if (labelsToUpdate) {\n setValue('labels', labelsToUpdate);\n }\n setShowLabelsEditor(false);\n }\n\n if (isGrafanaRecordingRuleByType(type)) {\n return null;\n }\n\n const step = !isGrafanaManaged ? 4 : 5;\n\n const switchMode =\n isGrafanaManaged && simplifiedModeInNotificationsStepEnabled\n ? {\n isAdvancedMode: !manualRouting,\n setAdvancedMode: (isAdvanced: boolean) => {\n setValue('editorSettings.simplifiedNotificationEditor', !isAdvanced);\n setValue('manualRouting', !isAdvanced);\n },\n }\n : undefined;\n\n const title = (() => {\n if (isRecordingRuleByType(type)) {\n return 'Add labels';\n }\n if (isGrafanaManaged) {\n return 'Configure notifications';\n }\n return 'Configure labels and notifications';\n })();\n\n return (\n <RuleEditorSection\n stepNo={step}\n title={title}\n description={\n <Stack direction=\"row\" gap={0.5} alignItems=\"center\">\n {isRecordingRuleByType(type) ? (\n <Text variant=\"bodySmall\" color=\"secondary\">\n <Trans i18nKey=\"alerting.notifications-step.labels-better-manage-recording-rules\">\n Add labels to help you better manage your recording rules.\n </Trans>\n </Text>\n ) : (\n shouldAllowSimplifiedRouting && (\n <Text variant=\"bodySmall\" color=\"secondary\">\n <Trans i18nKey=\"alerting.notifications-step.recipient-notification-fires\">\n Select who should receive a notification when an alert rule fires.\n </Trans>\n </Text>\n )\n )}\n </Stack>\n }\n switchMode={switchMode}\n fullWidth\n >\n {!isGrafanaManaged && (\n <>\n <LabelsFieldInForm onEditClick={() => setShowLabelsEditor(true)} />\n <LabelsEditorModal\n isOpen={showLabelsEditor}\n onClose={onCloseLabelsEditor}\n dataSourceName={dataSourceName}\n initialLabels={getValues('labels')}\n />\n </>\n )}\n {shouldAllowSimplifiedRouting && (\n <div className={styles.configureNotifications}>\n <Text element=\"h5\">\n <Trans i18nKey=\"alerting.notifications-step.recipient\">Recipient</Trans>\n </Text>\n </div>\n )}\n {shouldAllowSimplifiedRouting && simplifiedModeInNotificationsStepEnabled && (\n <ManualAndAutomaticRoutingSimplified alertUid={alertUid} />\n )}\n {shouldAllowSimplifiedRouting && !simplifiedModeInNotificationsStepEnabled && (\n <ManualAndAutomaticRouting alertUid={alertUid} />\n )}\n {!shouldAllowSimplifiedRouting && shouldRenderpreview && <AutomaticRooting alertUid={alertUid} />}\n </RuleEditorSection>\n );\n};\n\n/**\n * Preconditions:\n * - the alert rule is a grafana rule\n *\n * This component will render the switch between the select contact point routing and the notification policy routing.\n * It also renders the section body of the NotificationsStep, depending on the routing option selected.\n * If select contact point routing is selected, it will render the SimplifiedRouting component.\n * If notification policy routing is selected, it will render the AutomaticRouting component.\n *\n */\nfunction ManualAndAutomaticRouting({ alertUid }: { alertUid?: string }) {\n const { watch, setValue } = useFormContext<RuleFormValues>();\n const styles = useStyles2(getStyles);\n\n const [manualRouting] = watch(['manualRouting']);\n\n const routingOptions = [\n {\n label: t(\n 'alerting.manual-and-automatic-routing.routing-options.label.select-contact-point',\n 'Select contact point'\n ),\n value: RoutingOptions.ContactPoint,\n },\n {\n label: t(\n 'alerting.manual-and-automatic-routing.routing-options.label.use-notification-policy',\n 'Use notification policy'\n ),\n value: RoutingOptions.NotificationPolicy,\n },\n ];\n\n const onRoutingOptionChange = (option: RoutingOptions) => {\n setValue('manualRouting', option === RoutingOptions.ContactPoint);\n };\n\n return (\n <Stack direction=\"column\" gap={2}>\n <Stack direction=\"column\">\n <RadioButtonGroup\n data-testid={manualRouting ? 'routing-options-contact-point' : 'routing-options-notification-policy'}\n options={routingOptions}\n value={manualRouting ? RoutingOptions.ContactPoint : RoutingOptions.NotificationPolicy}\n onChange={onRoutingOptionChange}\n className={styles.routingOptions}\n />\n </Stack>\n\n <RoutingOptionDescription manualRouting={manualRouting} />\n\n {manualRouting ? <SimplifiedRouting /> : <AutomaticRooting alertUid={alertUid} />}\n </Stack>\n );\n}\n\n/**\n * Preconditions:\n * - simple mode for notifications step is enabled\n * - the alert rule is a grafana rule\n *\n * This component will render the switch between the select contact point routing and the notification policy routing.\n * It also renders the section body of the NotificationsStep, depending on the routing option selected.\n * If select contact point routing is selected, it will render the SimplifiedRouting component.\n * If notification policy routing is selected, it will render the AutomaticRouting component.\n *\n */\nfunction ManualAndAutomaticRoutingSimplified({ alertUid }: { alertUid?: string }) {\n const { watch } = useFormContext<RuleFormValues>();\n\n const [manualRouting] = watch(['manualRouting']);\n\n return (\n <Stack direction=\"column\" gap={2}>\n <RoutingOptionDescription manualRouting={manualRouting} />\n\n {manualRouting ? <SimplifiedRouting /> : <AutomaticRooting alertUid={alertUid} />}\n </Stack>\n );\n}\n\ninterface AutomaticRootingProps {\n alertUid?: string;\n}\n\nfunction AutomaticRooting({ alertUid }: AutomaticRootingProps) {\n const { watch } = useFormContext<RuleFormValues>();\n const [labels, queries, condition, folder, alertName] = watch([\n 'labels',\n 'queries',\n 'condition',\n 'folder',\n 'name',\n 'manualRouting',\n ]);\n return (\n <NotificationPreview\n alertQueries={queries}\n customLabels={labels}\n condition={condition}\n folder={folder}\n alertName={alertName}\n alertUid={alertUid}\n />\n );\n}\n\n// Auxiliar components to build the texts and descriptions in the NotificationsStep\nfunction NeedHelpInfoForNotificationPolicy() {\n return (\n <NeedHelpInfo\n contentText={\n <Stack gap={1} direction=\"column\">\n <Stack direction=\"column\" gap={0}>\n <Trans i18nKey=\"alerting.need-help-info-for-notification-policy.notification-policies\">\n Firing alert instances are routed to notification policies based on matching labels. The default\n notification policy matches all alert instances.\n </Trans>\n </Stack>\n <Stack direction=\"column\" gap={0}>\n <Trans i18nKey=\"alerting.need-help-info-for-notification-policy.custom-labels\">\n Custom labels change the way your notifications are routed. First, add labels to your alert rule and then\n connect them to your notification policy by adding label matchers.\n </Trans>\n <TextLink\n href={`https://grafana.com/docs/grafana/latest/alerting/fundamentals/notifications/notification-policies/`}\n external\n >\n <Trans i18nKey=\"alerting.need-help-info-for-notification-policy.read-more\">\n Read about notification policies.\n </Trans>\n </TextLink>\n </Stack>\n </Stack>\n }\n title={t('alerting.need-help-info-for-notification-policy.title-notification-routing', 'Notification routing')}\n />\n );\n}\n\nfunction NeedHelpInfoForContactpoint() {\n return (\n <NeedHelpInfo\n contentText={\n <>\n <Trans i18nKey=\"alerting.need-help-info-for-contactpoint.select-contact-point\">\n Select a contact point to notify all recipients in it.\n </Trans>\n <br />\n <Trans i18nKey=\"alerting.need-help-info-for-contactpoint.customize-notifications\">\n Muting, grouping, and timings options allow you to customize how notifications are sent.\n </Trans>\n <br />\n <br />\n <Trans i18nKey=\"alerting.need-help-info-for-contactpoint.notification-policies\">\n Alternatively, toggle the <b>Advanced options</b> button to route notifications using notification policies\n for greater flexibility.\n </Trans>\n </>\n }\n externalLink=\"https://grafana.com/docs/grafana/latest/alerting/fundamentals/notifications/\"\n linkText=\"Read more about notifications\"\n title={t(\n 'alerting.need-help-info-for-contactpoint.title-notify-by-selecting-a-contact-point',\n 'Notify by selecting a contact point'\n )}\n />\n );\n}\ninterface NotificationsStepDescriptionProps {\n manualRouting: boolean;\n}\n\nexport const RoutingOptionDescription = ({ manualRouting }: NotificationsStepDescriptionProps) => {\n return (\n <Stack alignItems=\"center\">\n <Text variant=\"bodySmall\" color=\"secondary\">\n {manualRouting\n ? t(\n 'alerting.routing-option-description.manual',\n 'Notifications for firing alerts are routed to a selected contact point.'\n )\n : t(\n 'alerting.routing-option-description.matching-labels',\n 'Notifications for firing alerts are routed to contact points based on matching labels and the notification policy tree.'\n )}\n </Text>\n {manualRouting ? <NeedHelpInfoForContactpoint /> : <NeedHelpInfoForNotificationPolicy />}\n </Stack>\n );\n};\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n routingOptions: css({\n width: 'fit-content',\n }),\n configureNotifications: css({\n display: 'flex',\n flexDirection: 'column',\n marginTop: theme.spacing(2),\n }),\n});\n","import { Controller, useFormContext } from 'react-hook-form';\n\nimport { DataSourceInstanceSettings } from '@grafana/data';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { Trans, t } from '@grafana/i18n';\nimport { Field, Input, Stack, Text } from '@grafana/ui';\nimport { DataSourcePicker } from 'app/features/datasources/components/picker/DataSourcePicker';\n\nimport { RuleFormType, RuleFormValues } from '../../types/rule-form';\nimport { isValidRecordingRulesTarget } from '../../utils/datasource';\nimport { isCloudRecordingRuleByType, isGrafanaRecordingRuleByType, isRecordingRuleByType } from '../../utils/rules';\n\nimport { RuleEditorSection } from './RuleEditorSection';\n\nconst recordingRuleNameValidationPattern = (type: RuleFormType) => ({\n message: isGrafanaRecordingRuleByType(type)\n ? 'Recording rule metric must be valid metric name. It may only contain letters, numbers, and colons. It may not contain whitespace.'\n : 'Recording rule name must be valid metric name. It may only contain letters, numbers, and colons. It may not contain whitespace.',\n value: /^[a-zA-Z_:][a-zA-Z0-9_:]*$/,\n});\n\n/**\n * This component renders the input for the alert rule name.\n * In case of recording rule, it also renders the input for the recording rule metric, and it validates this value.\n */\nexport const AlertRuleNameAndMetric = () => {\n const {\n control,\n register,\n watch,\n formState: { errors },\n setValue,\n } = useFormContext<RuleFormValues>();\n\n const ruleFormType = watch('type');\n if (!ruleFormType) {\n return null;\n }\n const isRecording = isRecordingRuleByType(ruleFormType);\n const isGrafanaRecordingRule = isGrafanaRecordingRuleByType(ruleFormType);\n const isCloudRecordingRule = isCloudRecordingRuleByType(ruleFormType);\n const recordingLabel = isGrafanaRecordingRule ? 'recording rule and metric' : 'recording rule';\n const namePlaceholder = isRecording ? 'recording rule' : 'alert rule';\n const entityName = isRecording ? recordingLabel : 'alert rule';\n return (\n <RuleEditorSection\n stepNo={1}\n title={t('alerting.alert-rule-name-and-metric.title-section', 'Enter {{entityName}} name', { entityName })}\n description={\n <Text variant=\"bodySmall\" color=\"secondary\">\n <Trans i18nKey=\"alerting.alert-rule-name-and-metric.description-section\">\n Enter a name to identify your {{ entityName }}.\n </Trans>\n </Text>\n }\n >\n <Stack direction=\"column\">\n <Field\n label={t('alerting.alert-rule-name-and-metric.label-name', 'Name')}\n error={errors?.name?.message}\n invalid={!!errors.name?.message}\n >\n <Input\n data-testid={selectors.components.AlertRules.ruleNameField}\n id=\"name\"\n width={38}\n {...register('name', {\n required: {\n value: true,\n message: t('alerting.alert-rule-name-and-metric.message.must-enter-a-name', 'Must enter a name'),\n },\n pattern: isCloudRecordingRule\n ? recordingRuleNameValidationPattern(RuleFormType.cloudRecording)\n : undefined,\n })}\n aria-label={t('alerting.alert-rule-name-and-metric.aria-label-name', 'name')}\n placeholder={t(\n 'alerting.alert-rule-name-and-metric.placeholder-name',\n 'Give your {{namePlaceholder}} a name',\n { namePlaceholder }\n )}\n />\n </Field>\n {isGrafanaRecordingRule && (\n <Field\n label={t('alerting.alert-rule-name-and-metric.label-metric', 'Metric')}\n error={errors?.metric?.message}\n invalid={!!errors.metric?.message}\n >\n <Input\n id=\"metric\"\n width={38}\n {...register('metric', {\n required: {\n value: true,\n message: t(\n 'alerting.alert-rule-name-and-metric.message.must-enter-a-metric-name',\n 'Must enter a metric name'\n ),\n },\n pattern: recordingRuleNameValidationPattern(RuleFormType.grafanaRecording),\n })}\n aria-label={t('alerting.alert-rule-name-and-metric.metric-aria-label-metric', 'metric')}\n placeholder={t(\n 'alerting.alert-rule-name-and-metric.metric-placeholder-recorded-metric',\n 'Give the name of the new recorded metric'\n )}\n />\n </Field>\n )}\n\n {isGrafanaRecordingRule && (\n <Field\n id=\"target-data-source\"\n data-testid=\"target-data-source\"\n label={t('alerting.recording-rules.label-target-data-source', 'Target data source')}\n description={t(\n 'alerting.recording-rules.description-target-data-source',\n 'The Prometheus data source to store recording rules in'\n )}\n error={errors.targetDatasourceUid?.message}\n invalid={!!errors.targetDatasourceUid?.message}\n >\n <Controller\n render={({ field: { onChange, ref, ...field } }) => (\n <DataSourcePicker\n {...field}\n current={field.value}\n noDefault\n // Filter with `filter` prop instead of `type` prop to avoid showing the `-- Grafana --` data source\n filter={isValidRecordingRulesTarget}\n onChange={(ds: DataSourceInstanceSettings) => {\n setValue('targetDatasourceUid', ds.uid);\n }}\n />\n )}\n name=\"targetDatasourceUid\"\n control={control}\n rules={{\n required: {\n value: true,\n message: t(\n 'alerting.alert-rule-name-and-metric.message.please-select-a-data-source',\n 'Please select a data source'\n ),\n },\n }}\n />\n </Field>\n )}\n </Stack>\n </RuleEditorSection>\n );\n};\n"],"names":["generateCopiedName","originalName","exisitingNames","nonDuplicateName","newName","i","InternalAIImproveLabelsButtonComponent","AIImproveLabelsButtonComponent","props","WrappedComponent","addAIImproveLabelsButton","component","LabelsFieldInForm","onEditClick","watch","labels","type","isRecordingRule","isGrafanaManaged","text","hasLabels","label","Stack","Text","NeedHelpInfo","Button","AlertWarning","title","children","Alert","warningStyles","theme","isGrafanaGroupUpdatedResponse","response","isCloudGroupUpdatedResponse","GrafanaRuleExportPreview","alertUid","exportFormat","onClose","ruleTextDefinition","isFetching","alertRuleApi","downloadFileName","LoadingPlaceholder","FileExportPreview","GrafanaRuleExporter","activeTab","setActiveTab","GrafanaExportDrawer","GroupAndNamespaceFields","rulesSourceName","control","errors","setValue","style","getStyle","namespaceGroups","isLoading","namespace","namespaceOptions","groupOptions","group","Field","onChange","ref","field","value","CloudEvaluationBehavior","styles","getStyles","register","dataSourceName","RuleEditorSection","Input","Select","time","PreviewRule","RecordingRulesNameSpaceAndGroupStep","AlertRuleForm","existing","prefill","isManualRestore","notifyApp","routeParams","uidFromParams","redirectToDetailsPage","useRedirectToDetailsPage","showEditYaml","setShowEditYaml","addRuleToRuleGroup","updateRuleInRuleGroup","ruleType","defaultValues","formAPI","handleSubmit","isSubmitting","trigger","grafanaTypeRule","showDataSourceDependantStep","conditionErrorMsg","setConditionErrorMsg","checkAlertCondition","msg","submit","values","evaluateEvery","ruleDefinition","ruleGroupIdentifier","targetRuleGroupIdentifier","saveResult","ruleIdentifier","storeInLocalStorageValues","dataQueries","query","expressionQueries","onInvalid","config","cancelRuleCreation","isPaused","e","InfoPausedRule","QueryAndExpressionsStep","GrafanaFolderAndLabelsStep","GrafanaEvaluationBehavior","NotificationsStep","AnnotationsStep","isCortexLokiOrRecordingRule","RuleInspector","existingUid","redirectGrafanaRule","newOrUpdatedRuleUid","redirectCloudRulerRule","rule","groupId","namespaceName","groupName","updatedRuleIdentifier","manualRouting","editorSettings","changeRuleName","cloneRuleDefinition","ruleClone","ExistingRuleEditor","identifier","clone","ruleSourceName","loadingAlertRule","ruleWithLocation","fetchRuleError","isEditable","loadingEditable","errorEditable","useIsRuleEditable","AlertingPageWrapper","getPageNav","loading","rulerRule","summary","isFederatedRule","pageTitle","FederatedRuleWarning","pageNavOptions","defaultPageNav","RuleEditor","useRuleEditorPathParams","cloneIdentifier","useIdentifierFromCopy","useManualRestore","canCreateGrafanaRules","canCreateCloudRules","canEditRules","NewRuleEditor","RECORDING_TYPE","useDefaultsFromQuery","isExisting","newText","editText","withPageErrorBoundary","params","id","searchParams","useURLSearchParams","copyFromId","LabelsEditorModal","isOpen","initialLabels","GrafanaModifyExport","RuleModifyExport","error","GrafanaModifyExportPage","CreateNewFolder","onCreate","isCreatingFolder","setIsCreatingFolder","handleCreate","folder","FolderCreationModal","setTitle","createFolder","onSubmit","data","isCloudPreviewRequest","request","isGrafanaPreviewRequest","previewAlertRule","fetchAlertRulePreview","dataSourceUid","withLoadingIndicator","createResponse","map","catchError","of","toDataQueryError","share","PreviewRuleResult","preview","fieldConfig","width","height","PanelRenderer","fields","onPreview","usePreview","condition","queries","allDataSourcesAvailable","useAlertQueriesStatus","isPreviewAvailable","setPreview","getValues","isMounted","useMountedState","createPreviewRequest","takeWhile","isCompleted","expression","dsSettings","mapDataFrameToAlertPreview","labelFields","stateFieldIndex","infoFieldIndex","labelIndexes","labelField","instanceStatusCount","instances","index","labelValues","labelIndex","state","info","CloudAlertPreview","alertPreview","instanceTags","AlertStateTag","TagList","Tooltip","Icon","ExpressionEditor","showPreviewAlertsButton","mapToValue","mapToQuery","useQueryMappers","dataQuery","dataSource","useAsync","onChangeQuery","onRunQueriesClick","dsi","errorMessage","previewLoaded","QueryEditor","previewDataFrame","s","previewHasAlerts","DataSourcePluginContextProvider","settings","ExpressionsEditor","onSetCondition","panelData","onUpdateRefId","onRemoveExpression","onUpdateExpressionType","onUpdateQueryExpression","acc","isAlertCondition","errorFromCondition","warning","Expression","ConfirmNavigationModal","onDismiss","path","openInNewTab","openInCurrentTab","Modal","AlertingRuleExtensionPointMenu","extensions","onSelect","categorised","uncategorised","useExtensionLinksByCategory","showDivider","Menu","category","renderItems","extension","event","link","QuerylessAppsExtensions","links","setSelectedExtension","setIsModalOpen","isModalOpen","menu","ToolbarButton","Dropdown","QUERYLESS_APPS","DATASOURCE_TO_QUERYLESS_APP","AlertingRuleQueryExtensionPoint","extensionsToShow","selectedExtension","context","usePluginLinks","querylessLinks","datasourceType","QueryOptions","queryOptions","onChangeTimeRange","onChangeQueryOptions","showOptions","setShowOptions","separator","Toggletip","InlineField","RelativeTimeRangePicker","range","MaxDataPointsOption","options","MinIntervalOption","TimeRangeLabel","clearButton","DEFAULT_MAX_DATA_POINTS","DEFAULT_MIN_INTERVAL","QueryWrapper","onChangeDataSource","onRunQueries","onRemoveQuery","onDuplicateQuery","thresholds","thresholdsType","onChangeThreshold","dsInstance","setDsInstance","defaults","isAdvancedMode","queryWithDefaults","SelectingDataSourceTooltip","HeaderExtras","alertQueryOptions","ExpressionStatusIndicator","showVizualisation","editorQueries","QueryEditorRow","VizWrapper","EmptyQueryWrapper","onMaxDataPointsBlur","maxDataPointsNumber","maxDataPoints","onMinIntervalBlur","minInterval","QueryRows","onQueriesChange","q","timeRange","item","itemIndex","updatedQueries","previousSettings","copyModel","newModel","result","startIndex","endIndex","update","removed","expressions","thresholdByRefId","provided","isCondition","DatasourceNotFound","defaultDataSource","isInstant","newQuery","onUpdateDatasource","model","refId","showDetails","setShowDetails","toggleDetails","show","handleUpdateDatasource","QueryOperationRow","Card","onChangeQueries","RecordingRuleEditor","runQueries","setData","handleChangedQuery","changedQuery","dataSourceId","isLoki","expr","merged","err","QueryErrorAlert","CloudDataSourceSelector","disabled","onChangeCloudDatasource","ruleFormType","CloudRulesSourcePicker","ds","NEW_REDUCER_REF","findDataSourceFromExpression","dag","originQuery","initialState","duplicateQuery","addNewDataQuery","setDataQueries","addNewExpression","removeExpression","removeExpressions","addExpressions","updateExpression","updateExpressionRefId","rewireExpressions","updateExpressionType","updateExpressionTimeRange","updateMaxDataPoints","updateMinInterval","resetToSimpleCondition","optimizeReduceExpression","setRecordingRulesQueries","queriesAndExpressionsReducer","builder","payload","addQuery","datasource","recordingRuleQuery","action","queryToUpdate","originalQueries","relativeTimeRange","dataSourceAlertQuery","newRefId","oldRefId","isInstantDataQuery","hasReducer","reduceExpressionIndex","queryToAdd","defaultTimeRange","SimpleConditionEditor","simpleCondition","expressionQueriesList","dispatch","previewData","onReducerTypeChange","updateReduceExpression","isRange","thresholdFunction","fn","onEvalFunctionChange","updateThresholdFunction","onEvaluateValueChange","numericValue","draftCondition","updateThresholdValue","InlineFieldRow","o","ThresholdSelect","ToLabel","reducer","reduceExpression","newReduceExpression","draft","evaluator","thresholdExpression","newThresholdExpression","getSimpleConditionFromExpressions","conditionsFromThreshold","whenField","onlyOneDSInQueries","getAvailableRuleTypes","defaultRuleType","enabledRuleTypes","useGetCanSwitch","availableRuleTypes","onlyOneDS","isRecordingRuleType","dataSourceIdFromQueries","hasRuler","useHasRuler","canSwitchToCloudRule","canSwitchToGrafanaRule","grafanaTypeEnabled","cloudTypeEnabled","canSwitchFromCloudToGrafana","canSwitchFromGrafanaToCloud","SmartAlertTypeDetector","editingExistingRule","onClickSwitch","canSwitch","disabledOptions","RadioButtonGroup","DESCRIPTIONS","initializeSimpleCondition","isGrafanaAlertingType","determineAdvancedMode","simplifiedQueryEditor","useAdvancedMode","setSimpleCondition","onDataChange","mode","queryPreviewData","cancelQueries","isPreviewLoading","useAlertQueryRunner","isSwitchModeEnabled","isOptimizeReducerEnabled","useEffectOnce","isCloudAlertRuleType","showResetModeModal","setShowResetModal","simplifiedQueryInForm","simplifiedQueryStep","runQueriesPreview","lastExpression","noCompatibleDataSources","emptyQueries","currentCondition","handleSetCondition","updateExpressionAndDatasource","useSetExpressionAndDataSource","onChangeRecordingRulesQueries","lastRefId","onClickType","datasourceUid","newQueries","onChangeExpression","promLoki","removeExpressionsInQueries","addExpressionsInQueries","prevExpressions","setPrevExpressions","prevCondition","setPrevCondition","restoreExpressionsInQueries","newDsName","sectionTitle","helpLabel","helpContent","helpLink","switchMode","isAdvanced","canSelectDataSourceManaged","Divider","selectors","TypeSelectorButton","ConfirmModal","newMenu","MenuItem","ModifyExportRuleForm","ruleForm","defaultValuesForNewRule","returnTo","exportData","setExportData","GrafanaRuleDesignExporter","formValues","useGetGroup","nameSpaceUID","dsFeatures","rulerConfig","getPayloadToExport","existingGroup","ruleUid","grafanaRuleDto","updatedRule","alreadyExistsInGroup","updatedRules","useGetPayloadToExport","rulerGroupDto","GrafanaRuleDesignExportPreview","exportValues","uid","getExport","loadingGroup","exportingNewRule","initialTab","formatProviders","FolderSelector","resetGroup","handleFolderCreation","Label","NestedFolderPicker","usePrefetch","showLabelsEditor","setShowLabelsEditor","prefechRulerRules","onCloseLabelsEditor","labelsToUpdate","SectionDescription","useLazyDiscoverDsFeaturesQuery","featureDiscoveryApi","useRulesSourcesWithRuler","rulesSourcesWithRuler","setRulesSourcesWithRuler","discoverDsFeatures","prev","dataSourcesWithRuler","dataSourceFilter","DataSourcePicker","ExportNewGrafanaRulePage","useRulesAccess","alertManager","selectedContactPointField","contactPointInForm","encodedContactPoint","currentData","status","contactPointNotFound","contactPoint","LinkToContactPoints","FieldValidationMessage","TextLink","ActiveTimingFields","alertmanager","MuteTimingsSelector","MuteTimingFields","RouteTimings","formStyles","routeTimingsFields","PromDurationInput","groupInterval","REQUIRED_FIELDS_IN_GROUPBY","DEFAULTS_TIMINGS","DISABLE_GROUPING","RoutingSettings","groupByOptions","setGroupByOptions","groupIntervalValue","groupWaitValue","repeatIntervalValue","overrideGrouping","overrideTimings","groupByCount","Switch","opt","opts","MultiValue","AlertManagerManualRouting","alertManagerName","hasRouteSettings","CollapsableSection","SimplifiedRouting","contactPointsInAlert","alertManagersDataSourcesWithConfigAPI","am","selectedContactPoint","alertManagerContactPoint","NotificationPreviewByAlertManager","NotificationPreviewForGrafanaManaged","NotificationPreview","alertQueries","customLabels","alertName","previewUninitialized","potentialInstances","instance","alertManagerDataSources","singleAlertManagerConfigured","alertManagerSource","RoutingOptions","useHasInternalAlertmanagerEnabled","useGetGrafanaAlertingConfigurationStatusQuery","alertmanagerApi","amChoiceStatus","simplifiedModeInNotificationsStepEnabled","shouldRenderpreview","hasInternalAlertmanagerEnabled","shouldAllowSimplifiedRouting","step","ManualAndAutomaticRoutingSimplified","ManualAndAutomaticRouting","AutomaticRooting","routingOptions","onRoutingOptionChange","option","RoutingOptionDescription","NeedHelpInfoForNotificationPolicy","NeedHelpInfoForContactpoint","recordingRuleNameValidationPattern","AlertRuleNameAndMetric","isRecording","isGrafanaRecordingRule","isCloudRecordingRule","recordingLabel","namePlaceholder","entityName"],"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