123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- import {Component, Fragment} from 'react';
- import Panel from 'sentry/components/panels/panel';
- import PanelBody from 'sentry/components/panels/panelBody';
- import type {Organization} from 'sentry/types/organization';
- import type {Project} from 'sentry/types/project';
- import removeAtArrayIndex from 'sentry/utils/array/removeAtArrayIndex';
- import replaceAtArrayIndex from 'sentry/utils/array/replaceAtArrayIndex';
- import ActionsPanel from 'sentry/views/alerts/rules/metric/triggers/actionsPanel';
- import AnomalyDetectionFormField from 'sentry/views/alerts/rules/metric/triggers/anomalyAlertsForm';
- import TriggerForm from 'sentry/views/alerts/rules/metric/triggers/form';
- import {
- type Action,
- AlertRuleComparisonType,
- type AlertRuleSensitivity,
- type AlertRuleThresholdType,
- type MetricActionTemplate,
- type Trigger,
- type UnsavedMetricRule,
- } from '../types';
- type Props = {
- aggregate: UnsavedMetricRule['aggregate'];
- availableActions: MetricActionTemplate[] | null;
- comparisonType: AlertRuleComparisonType;
- currentProject: string;
- disabled: boolean;
- errors: Map<number, {[fieldName: string]: string}>;
- onChange: (
- triggers: Trigger[],
- triggerIndex?: number,
- changeObj?: Partial<Trigger>
- ) => void;
- onResolveThresholdChange: (
- resolveThreshold: UnsavedMetricRule['resolveThreshold']
- ) => void;
- onSensitivityChange: (sensitivity: AlertRuleSensitivity) => void;
- onThresholdPeriodChange: (value: number) => void;
- onThresholdTypeChange: (thresholdType: AlertRuleThresholdType) => void;
- organization: Organization;
- projects: Project[];
- resolveThreshold: UnsavedMetricRule['resolveThreshold'];
- sensitivity: UnsavedMetricRule['sensitivity'];
- thresholdPeriod: UnsavedMetricRule['thresholdPeriod'];
- thresholdType: UnsavedMetricRule['thresholdType'];
- triggers: Trigger[];
- isMigration?: boolean;
- };
- /**
- * A list of forms to add, edit, and delete triggers.
- */
- class Triggers extends Component<Props> {
- handleDeleteTrigger = (index: number) => {
- const {triggers, onChange} = this.props;
- const updatedTriggers = removeAtArrayIndex(triggers, index);
- onChange(updatedTriggers);
- };
- handleChangeTrigger = (
- triggerIndex: number,
- trigger: Trigger,
- changeObj: Partial<Trigger>
- ) => {
- const {triggers, onChange} = this.props;
- const updatedTriggers = replaceAtArrayIndex(triggers, triggerIndex, trigger);
- onChange(updatedTriggers, triggerIndex, changeObj);
- };
- handleAddAction = (triggerIndex: number, action: Action) => {
- const {onChange, triggers} = this.props;
- const trigger = triggers[triggerIndex];
- const actions = [...trigger.actions, action];
- const updatedTriggers = replaceAtArrayIndex(triggers, triggerIndex, {
- ...trigger,
- actions,
- });
- onChange(updatedTriggers, triggerIndex, {actions});
- };
- handleChangeActions = (
- triggerIndex: number,
- triggers: Trigger[],
- actions: Action[]
- ): void => {
- const {onChange} = this.props;
- const trigger = triggers[triggerIndex];
- const updatedTriggers = replaceAtArrayIndex(triggers, triggerIndex, {
- ...trigger,
- actions,
- });
- onChange(updatedTriggers, triggerIndex, {actions});
- };
- render() {
- const {
- availableActions,
- currentProject,
- errors,
- organization,
- projects,
- triggers,
- disabled,
- aggregate,
- thresholdType,
- thresholdPeriod,
- comparisonType,
- resolveThreshold,
- isMigration,
- onSensitivityChange,
- onThresholdTypeChange,
- onResolveThresholdChange,
- onThresholdPeriodChange,
- sensitivity,
- } = this.props;
- // Note we only support 2 triggers max
- return (
- <Fragment>
- <Panel>
- <PanelBody>
- {comparisonType === AlertRuleComparisonType.DYNAMIC ? (
- <AnomalyDetectionFormField
- disabled={disabled}
- sensitivity={sensitivity}
- onSensitivityChange={onSensitivityChange}
- thresholdType={thresholdType}
- onThresholdTypeChange={onThresholdTypeChange}
- />
- ) : (
- <TriggerForm
- disabled={disabled}
- errors={errors}
- organization={organization}
- projects={projects}
- triggers={triggers}
- aggregate={aggregate}
- resolveThreshold={resolveThreshold}
- thresholdType={thresholdType}
- thresholdPeriod={thresholdPeriod}
- comparisonType={comparisonType}
- onChange={this.handleChangeTrigger}
- onThresholdTypeChange={onThresholdTypeChange}
- onResolveThresholdChange={onResolveThresholdChange}
- onThresholdPeriodChange={onThresholdPeriodChange}
- />
- )}
- </PanelBody>
- </Panel>
- {isMigration ? null : (
- <ActionsPanel
- disabled={disabled}
- loading={availableActions === null}
- error={false}
- availableActions={availableActions}
- currentProject={currentProject}
- organization={organization}
- projects={projects}
- triggers={triggers}
- onChange={this.handleChangeActions}
- onAdd={this.handleAddAction}
- comparisonType={comparisonType}
- />
- )}
- </Fragment>
- );
- }
- }
- export default Triggers;
|