import React, {Fragment} from 'react'; import {Breadcrumbs} from 'sentry/components/breadcrumbs'; import FloatingFeedbackWidget from 'sentry/components/feedback/widget/floatingFeedbackWidget'; import * as Layout from 'sentry/components/layouts/thirds'; import {DatePageFilter} from 'sentry/components/organizations/datePageFilter'; import {EnvironmentPageFilter} from 'sentry/components/organizations/environmentPageFilter'; import PageFilterBar from 'sentry/components/organizations/pageFilterBar'; import {ProjectPageFilter} from 'sentry/components/organizations/projectPageFilter'; import {t} from 'sentry/locale'; import {fromSorts} from 'sentry/utils/discover/eventView'; import {decodeScalar} from 'sentry/utils/queryString'; import {MutableSearch} from 'sentry/utils/tokenizeSearch'; import {useLocation} from 'sentry/utils/useLocation'; import useOrganization from 'sentry/utils/useOrganization'; import {normalizeUrl} from 'sentry/utils/withDomainRequired'; import {useOnboardingProject} from 'sentry/views/performance/browser/webVitals/utils/useOnboardingProject'; import {DomainsTable, isAValidSort} from 'sentry/views/performance/http/domainsTable'; import {DurationChart} from 'sentry/views/performance/http/durationChart'; import {ResponseRateChart} from 'sentry/views/performance/http/responseRateChart'; import {ThroughputChart} from 'sentry/views/performance/http/throughputChart'; import * as ModuleLayout from 'sentry/views/performance/moduleLayout'; import {ModulePageProviders} from 'sentry/views/performance/modulePageProviders'; import Onboarding from 'sentry/views/performance/onboarding'; import {useSynchronizeCharts} from 'sentry/views/starfish/components/chart'; import {useSpanMetrics} from 'sentry/views/starfish/queries/useSpanMetrics'; import {useSpanMetricsSeries} from 'sentry/views/starfish/queries/useSpanMetricsSeries'; import {ModuleName} from 'sentry/views/starfish/types'; import {QueryParameterNames} from 'sentry/views/starfish/views/queryParameters'; export function HTTPLandingPage() { const organization = useOrganization(); const location = useLocation(); const onboardingProject = useOnboardingProject(); const sortField = decodeScalar(location.query?.[QueryParameterNames.DOMAINS_SORT]); const sort = fromSorts(sortField).filter(isAValidSort).at(0) ?? DEFAULT_SORT; const chartFilters = { 'span.module': ModuleName.HTTP, has: 'span.domain', }; const tableFilters = { 'span.module': ModuleName.HTTP, has: 'span.domain', }; const cursor = decodeScalar(location.query?.[QueryParameterNames.DOMAINS_CURSOR]); const { isLoading: isThroughputDataLoading, data: throughputData, error: throughputError, } = useSpanMetricsSeries({ search: MutableSearch.fromQueryObject(chartFilters), yAxis: ['spm()'], referrer: 'api.starfish.http-module-landing-throughput-chart', }); const { isLoading: isDurationDataLoading, data: durationData, error: durationError, } = useSpanMetricsSeries({ search: MutableSearch.fromQueryObject(chartFilters), yAxis: [`avg(span.self_time)`], referrer: 'api.starfish.http-module-landing-duration-chart', }); const { isLoading: isResponseCodeDataLoading, data: responseCodeData, error: responseCodeError, } = useSpanMetricsSeries({ search: MutableSearch.fromQueryObject(chartFilters), yAxis: ['http_response_rate(3)', 'http_response_rate(4)', 'http_response_rate(5)'], referrer: 'api.starfish.http-module-landing-response-code-chart', }); const domainsListResponse = useSpanMetrics({ search: MutableSearch.fromQueryObject(tableFilters), fields: [ 'project.id', 'span.domain', 'spm()', 'http_response_rate(2)', 'http_response_rate(4)', 'http_response_rate(5)', 'avg(span.self_time)', 'sum(span.self_time)', 'time_spent_percentage()', ], sorts: [sort], limit: DOMAIN_TABLE_ROW_COUNT, cursor, referrer: 'api.starfish.http-module-landing-domains-list', }); useSynchronizeCharts([!isThroughputDataLoading && !isDurationDataLoading]); return ( {t('HTTP')} {onboardingProject && ( )} {!onboardingProject && ( )} ); } const DEFAULT_SORT = { field: 'time_spent_percentage()' as const, kind: 'desc' as const, }; const DOMAIN_TABLE_ROW_COUNT = 10; function LandingPageWithProviders() { return ( ); } export default LandingPageWithProviders;