123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- import {browserHistory} from 'react-router';
- import styled from '@emotion/styled';
- import {Breadcrumbs} from 'sentry/components/breadcrumbs';
- import IdBadge from 'sentry/components/idBadge';
- import * as Layout from 'sentry/components/layouts/thirds';
- import LoadingError from 'sentry/components/loadingError';
- import LoadingIndicator from 'sentry/components/loadingIndicator';
- import SentryDocumentTitle from 'sentry/components/sentryDocumentTitle';
- import {t} from 'sentry/locale';
- import {space} from 'sentry/styles/space';
- import {setApiQueryData, useApiQuery, useQueryClient} from 'sentry/utils/queryClient';
- import useOrganization from 'sentry/utils/useOrganization';
- import usePageFilters from 'sentry/utils/usePageFilters';
- import {useParams} from 'sentry/utils/useParams';
- import {normalizeUrl} from 'sentry/utils/withDomainRequired';
- import {makeMonitorDetailsQueryKey} from 'sentry/views/monitors/utils';
- import MonitorForm from './components/monitorForm';
- import type {Monitor} from './types';
- export default function EditMonitor() {
- const {monitorSlug} = useParams();
- const {selection} = usePageFilters();
- const organization = useOrganization();
- const queryClient = useQueryClient();
- const queryKey = makeMonitorDetailsQueryKey(organization, monitorSlug, {
- expand: ['alertRule'],
- });
- const {
- isLoading,
- isError,
- data: monitor,
- refetch,
- } = useApiQuery<Monitor>(queryKey, {
- cacheTime: 0,
- staleTime: 0,
- });
- function onSubmitSuccess(data: Monitor) {
- setApiQueryData(queryClient, queryKey, data);
- browserHistory.push(
- normalizeUrl({
- pathname: `/organizations/${organization.slug}/crons/${data.project.slug}/${data.slug}/`,
- query: {
- environment: selection.environments,
- project: selection.projects,
- },
- })
- );
- }
- function getTitle() {
- if (monitor) {
- return `${monitor.name} - Crons - ${organization.slug}`;
- }
- return `Crons - ${organization.slug}`;
- }
- if (isLoading) {
- return <LoadingIndicator />;
- }
- if (isError) {
- return <LoadingError onRetry={refetch} message="Failed to load monitor." />;
- }
- return (
- <SentryDocumentTitle title={getTitle()}>
- <Layout.Page>
- <Layout.Header>
- <Layout.HeaderContent>
- <Breadcrumbs
- crumbs={[
- {
- label: t('Crons'),
- to: normalizeUrl(`/organizations/${organization.slug}/crons/`),
- },
- {
- label: (
- <MonitorBreadcrumb>
- <IdBadge
- disableLink
- project={monitor.project}
- avatarSize={16}
- hideName
- avatarProps={{hasTooltip: true, tooltip: monitor.project.slug}}
- />
- {monitor.name}
- </MonitorBreadcrumb>
- ),
- to: normalizeUrl(
- `/organizations/${organization.slug}/crons/${monitor.project.slug}/${monitor.slug}/`
- ),
- },
- {
- label: t('Edit'),
- },
- ]}
- />
- <Layout.Title>{t('Edit Monitor')}</Layout.Title>
- </Layout.HeaderContent>
- </Layout.Header>
- <Layout.Body>
- <Layout.Main fullWidth>
- <MonitorForm
- monitor={monitor}
- apiMethod="PUT"
- apiEndpoint={`/organizations/${organization.slug}/monitors/${monitor.slug}/`}
- onSubmitSuccess={onSubmitSuccess}
- />
- </Layout.Main>
- </Layout.Body>
- </Layout.Page>
- </SentryDocumentTitle>
- );
- }
- const MonitorBreadcrumb = styled('div')`
- display: flex;
- gap: ${space(1)};
- align-items: center;
- `;
|