import styled from '@emotion/styled'; import ErrorPanel from 'sentry/components/charts/errorPanel'; import EventsRequest from 'sentry/components/charts/eventsRequest'; import {HeaderTitleLegend} from 'sentry/components/charts/styles'; import TransparentLoadingMask from 'sentry/components/charts/transparentLoadingMask'; import {getInterval} from 'sentry/components/charts/utils'; import {normalizeDateTimeParams} from 'sentry/components/organizations/pageFilters/parse'; import Placeholder from 'sentry/components/placeholder'; import QuestionTooltip from 'sentry/components/questionTooltip'; import {IconWarning} from 'sentry/icons'; import {space} from 'sentry/styles/space'; import {Organization} from 'sentry/types'; import {getUtcToLocalDateObject} from 'sentry/utils/dates'; import EventView from 'sentry/utils/discover/eventView'; import getDynamicText from 'sentry/utils/getDynamicText'; import useApi from 'sentry/utils/useApi'; import {useLocation} from 'sentry/utils/useLocation'; import Chart from '../../charts/chart'; import {DoubleHeaderContainer} from '../../styles'; import {getFieldOrBackup} from '../display/utils'; type Props = { eventView: EventView; field: string; organization: Organization; title: string; titleTooltip: string; usingBackupAxis: boolean; backupField?: string; }; function DurationChart({ organization, eventView, field, title, titleTooltip, backupField, usingBackupAxis, }: Props) { const location = useLocation(); const api = useApi(); // construct request parameters for fetching chart data const globalSelection = eventView.getPageFilters(); const start = globalSelection.datetime.start ? getUtcToLocalDateObject(globalSelection.datetime.start) : null; const end = globalSelection.datetime.end ? getUtcToLocalDateObject(globalSelection.datetime.end) : null; const {utc} = normalizeDateTimeParams(location.query); const _backupField = backupField ? [backupField] : []; const apiPayload = eventView.getEventsAPIPayload(location); return ( {({ loading, reloading, errored, timeseriesData: singleAxisResults, results: multiAxisResults, }) => { const _field = usingBackupAxis ? getFieldOrBackup(field, backupField) : field; const results = singleAxisResults ? singleAxisResults : [multiAxisResults?.find(r => r.seriesName === _field)].filter(Boolean); const series = results ? results.map(({...rest}) => { return { ...rest, seriesName: _field, }; }) : []; if (errored) { return ( ); } return (
{title} {results && ( {getDynamicText({ value: ( ), fixed: , })} )}
); }}
); } const ChartContainer = styled('div')` padding-top: ${space(1)}; `; const MaskContainer = styled('div')` position: relative; `; export default DurationChart;