123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- 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 PageFilterBar from 'sentry/components/organizations/pageFilterBar';
- import {Panel, PanelHeader} from 'sentry/components/panels';
- import {t} from 'sentry/locale';
- import {space} from 'sentry/styles/space';
- import {Organization} from 'sentry/types';
- import withRouteAnalytics, {
- WithRouteAnalyticsProps,
- } from 'sentry/utils/routeAnalytics/withRouteAnalytics';
- import withOrganization from 'sentry/utils/withOrganization';
- import AsyncView from 'sentry/views/asyncView';
- import MonitorCheckIns from './monitorCheckIns';
- import MonitorHeader from './monitorHeader';
- import MonitorIssues from './monitorIssues';
- import MonitorStats from './monitorStats';
- import MonitorOnboarding from './onboarding';
- import {Monitor} from './types';
- type Props = AsyncView['props'] &
- WithRouteAnalyticsProps &
- RouteComponentProps<{monitorId: string}, {}> & {
- organization: Organization;
- };
- type State = AsyncView['state'] & {
- monitor: Monitor | null;
- };
- class MonitorDetails extends AsyncView<Props, State> {
- get orgSlug() {
- return this.props.organization.slug;
- }
- getEndpoints(): ReturnType<AsyncView['getEndpoints']> {
- const {params, location} = this.props;
- return [
- [
- 'monitor',
- `/organizations/${this.orgSlug}/monitors/${params.monitorId}/`,
- {query: location.query},
- ],
- ];
- }
- getTitle() {
- if (this.state.monitor) {
- return `${this.state.monitor.name} - Monitors - ${this.orgSlug}`;
- }
- return `Monitors - ${this.orgSlug}`;
- }
- onUpdate = (data: Monitor) =>
- this.setState(state => ({monitor: {...state.monitor, ...data}}));
- onRequestSuccess(response) {
- this.props.setEventNames(
- 'monitors.details_page_viewed',
- 'Monitors: Details Page Viewed'
- );
- this.props.setRouteAnalyticsParams({
- empty_state: !response.data?.lastCheckIn,
- });
- }
- renderBody() {
- const {monitor} = this.state;
- if (monitor === null) {
- return null;
- }
- return (
- <Layout.Page>
- <MonitorHeader monitor={monitor} orgId={this.orgSlug} onUpdate={this.onUpdate} />
- <Layout.Body>
- <Layout.Main fullWidth>
- {!monitor.lastCheckIn ? (
- <MonitorOnboarding />
- ) : (
- <Fragment>
- <StyledPageFilterBar condensed>
- <DatePageFilter alignDropdown="left" />
- </StyledPageFilterBar>
- <MonitorStats monitor={monitor} orgId={this.orgSlug} />
- <MonitorIssues monitor={monitor} orgId={this.orgSlug} />
- <Panel>
- <PanelHeader>{t('Recent Check-ins')}</PanelHeader>
- <MonitorCheckIns monitor={monitor} orgId={this.orgSlug} />
- </Panel>
- </Fragment>
- )}
- </Layout.Main>
- </Layout.Body>
- </Layout.Page>
- );
- }
- }
- const StyledPageFilterBar = styled(PageFilterBar)`
- margin-bottom: ${space(2)};
- `;
- export default withRouteAnalytics(withOrganization(MonitorDetails));
|