123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- import {Fragment} from 'react';
- import {RouteComponentProps} from 'react-router';
- import styled from '@emotion/styled';
- import DatePageFilter from 'sentry/components/datePageFilter';
- import * as Layout from 'sentry/components/layouts/thirds';
- import LoadingIndicator from 'sentry/components/loadingIndicator';
- import PageFilterBar from 'sentry/components/organizations/pageFilterBar';
- import SentryDocumentTitle from 'sentry/components/sentryDocumentTitle';
- 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 DetailsSidebar from 'sentry/views/monitors/components/detailsSidebar';
- import MonitorCheckIns from './components/monitorCheckIns';
- import MonitorHeader from './components/monitorHeader';
- import MonitorIssues from './components/monitorIssues';
- import MonitorStats from './components/monitorStats';
- import MonitorOnboarding from './components/onboarding';
- import {Monitor} from './types';
- type Props = RouteComponentProps<{monitorSlug: string}, {}>;
- function MonitorDetails({params, location}: Props) {
- const {selection} = usePageFilters();
- const organization = useOrganization();
- const queryClient = useQueryClient();
- // TODO(epurkhiser): For now we just use the fist environment OR production
- // if we have all environments selected
- const environment = selection.environments[0];
- const queryKey = [
- `/organizations/${organization.slug}/monitors/${params.monitorSlug}/`,
- {query: {...location.query, environment}},
- ] as const;
- const {data: monitor} = useApiQuery<Monitor>(queryKey, {staleTime: 0});
- function onUpdate(data: Monitor) {
- const updatedMonitor = {
- ...data,
- // TODO(davidenwang): This is a bit of a hack, due to the PUT request
- // which pauses/unpauses a monitor not returning monitor environments
- // we should reuse the environments retrieved from the initial request
- environments: monitor?.environments,
- };
- setApiQueryData(queryClient, queryKey, updatedMonitor);
- }
- if (!monitor) {
- return (
- <Layout.Page>
- <LoadingIndicator />
- </Layout.Page>
- );
- }
- const monitorEnv = monitor.environments.find(env => env.name === environment);
- return (
- <SentryDocumentTitle title={`Crons - ${monitor.name}`}>
- <Layout.Page>
- <MonitorHeader monitor={monitor} orgId={organization.slug} onUpdate={onUpdate} />
- <Layout.Body>
- <Layout.Main>
- {!monitorEnv?.lastCheckIn ? (
- <MonitorOnboarding orgId={organization.slug} monitor={monitor} />
- ) : (
- <Fragment>
- <StyledPageFilterBar condensed>
- <DatePageFilter alignDropdown="left" />
- </StyledPageFilterBar>
- <MonitorStats
- orgId={organization.slug}
- monitor={monitor}
- monitorEnv={monitorEnv}
- />
- <MonitorIssues
- orgId={organization.slug}
- monitor={monitor}
- monitorEnv={monitorEnv}
- />
- <MonitorCheckIns
- orgId={organization.slug}
- monitor={monitor}
- monitorEnv={monitorEnv}
- />
- </Fragment>
- )}
- </Layout.Main>
- <Layout.Side>
- <DetailsSidebar monitorEnv={monitorEnv} monitor={monitor} />
- </Layout.Side>
- </Layout.Body>
- </Layout.Page>
- </SentryDocumentTitle>
- );
- }
- const StyledPageFilterBar = styled(PageFilterBar)`
- margin-bottom: ${space(2)};
- `;
- export default MonitorDetails;
|