import {Fragment} from 'react'; import type {Query} from 'history'; import EventsRequest from 'sentry/components/charts/eventsRequest'; import {HeaderTitleLegend} from 'sentry/components/charts/styles'; import {getInterval} from 'sentry/components/charts/utils'; import {normalizeDateTimeParams} from 'sentry/components/organizations/pageFilters/parse'; import QuestionTooltip from 'sentry/components/questionTooltip'; import {t} from 'sentry/locale'; import type {Organization, OrganizationSummary} from 'sentry/types'; import type {Series} from 'sentry/types/echarts'; import {getUtcToLocalDateObject} from 'sentry/utils/dates'; import {useMEPSettingContext} from 'sentry/utils/performance/contexts/metricsEnhancedSetting'; import useApi from 'sentry/utils/useApi'; import {useLocation} from 'sentry/utils/useLocation'; import DurationChart from 'sentry/views/performance/charts/chart'; import {getTermHelp, PerformanceTerm} from 'sentry/views/performance/data'; import {getMEPQueryParams} from 'sentry/views/performance/landing/widgets/utils'; import type {ViewProps} from 'sentry/views/performance/types'; type Props = ViewProps & { organization: OrganizationSummary; queryExtra: Query; withoutZerofill: boolean; }; /** * Fetch and render an area chart that shows user misery over a period */ function UserMiseryChart({ project, environment, organization, query, statsPeriod, withoutZerofill, start: propsStart, end: propsEnd, }: Props) { const location = useLocation(); const api = useApi(); const mepContext = useMEPSettingContext(); const start = propsStart ? getUtcToLocalDateObject(propsStart) : null; const end = propsEnd ? getUtcToLocalDateObject(propsEnd) : null; const utc = normalizeDateTimeParams(location.query).utc === 'true'; const period = statsPeriod; const datetimeSelection = {start, end, period}; const requestCommonProps = { api, start, end, project, environment, query, period, interval: getInterval(datetimeSelection, 'high'), }; const header = ( {t('User Misery')} ); const yAxis = 'user_misery()'; return ( {header} {({loading, reloading, timeseriesData}) => { const data: Series[] = timeseriesData?.[0] ? [{...timeseriesData[0], seriesName: yAxis}] : []; return ( ); }} ); } export default UserMiseryChart;