123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- import {RouteComponentProps} from 'react-router';
- import pick from 'lodash/pick';
- import * as Layout from 'sentry/components/layouts/thirds';
- import {Organization, Project} from 'sentry/types';
- import EventView from 'sentry/utils/discover/eventView';
- import {uniqueId} from 'sentry/utils/guid';
- import {normalizeUrl} from 'sentry/utils/withDomainRequired';
- import {
- DuplicateActionFields,
- DuplicateMetricFields,
- DuplicateTriggerFields,
- } from 'sentry/views/alerts/rules/metric/constants';
- import {MetricRule} from 'sentry/views/alerts/rules/metric/types';
- import {WizardRuleTemplate} from 'sentry/views/alerts/wizard/options';
- import DeprecatedAsyncView from 'sentry/views/deprecatedAsyncView';
- import RuleForm from './ruleForm';
- type Props = {
- organization: Organization;
- project: Project;
- userTeamIds: string[];
- eventView?: EventView;
- sessionId?: string;
- wizardTemplate?: WizardRuleTemplate;
- } & RouteComponentProps<{}, {}>;
- type State = {
- duplicateTargetRule?: MetricRule;
- } & DeprecatedAsyncView['state'];
- /**
- * Show metric rules form with values from an existing rule. Redirects to alerts list after creation.
- */
- class MetricRulesDuplicate extends DeprecatedAsyncView<Props, State> {
- getEndpoints(): ReturnType<DeprecatedAsyncView['getEndpoints']> {
- const {
- organization,
- location: {query},
- } = this.props;
- return [
- [
- 'duplicateTargetRule',
- `/organizations/${organization.slug}/alert-rules/${query.duplicateRuleId}/`,
- ],
- ];
- }
- handleSubmitSuccess = (data: any) => {
- const {router, organization, project} = this.props;
- const alertRuleId: string | undefined = data
- ? (data.id as string | undefined)
- : undefined;
- const target = alertRuleId
- ? {
- pathname: `/organizations/${organization.slug}/alerts/rules/details/${alertRuleId}/`,
- }
- : {
- pathname: `/organizations/${organization.slug}/alerts/rules/`,
- query: {project: project.id},
- };
- router.push(normalizeUrl(target));
- };
- renderBody() {
- const {project, sessionId, userTeamIds, ...otherProps} = this.props;
- const {duplicateTargetRule} = this.state;
- if (!duplicateTargetRule) {
- return this.renderLoading();
- }
- return (
- <Layout.Main>
- <RuleForm
- onSubmitSuccess={this.handleSubmitSuccess}
- rule={
- {
- ...pick(duplicateTargetRule, DuplicateMetricFields),
- triggers: duplicateTargetRule.triggers.map(trigger => ({
- ...pick(trigger, DuplicateTriggerFields),
- actions: trigger.actions.map(action => ({
- inputChannelId: null,
- integrationId: action.integrationId ?? undefined,
- options: null,
- sentryAppId: undefined,
- unsavedId: uniqueId(),
- unsavedDateCreated: new Date().toISOString(),
- ...pick(action, DuplicateActionFields),
- })),
- })),
- name: duplicateTargetRule.name + ' copy',
- } as MetricRule
- }
- sessionId={sessionId}
- project={project}
- userTeamIds={userTeamIds}
- isDuplicateRule
- {...otherProps}
- />
- </Layout.Main>
- );
- }
- }
- export default MetricRulesDuplicate;
|