import {useMemo} from 'react'; import styled from '@emotion/styled'; import {Breadcrumbs} from 'sentry/components/breadcrumbs'; import ErrorBoundary from 'sentry/components/errorBoundary'; 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 PageFiltersContainer from 'sentry/components/organizations/pageFilters/container'; import {ProjectPageFilter} from 'sentry/components/organizations/projectPageFilter'; import SentryDocumentTitle from 'sentry/components/sentryDocumentTitle'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import {PageAlert, PageAlertProvider} from 'sentry/utils/performance/contexts/pageAlert'; import useOrganization from 'sentry/utils/useOrganization'; import usePageFilters from 'sentry/utils/usePageFilters'; import useProjects from 'sentry/utils/useProjects'; import {normalizeUrl} from 'sentry/utils/withDomainRequired'; import {useOnboardingProject} from 'sentry/views/performance/browser/webVitals/utils/useOnboardingProject'; import Onboarding from 'sentry/views/performance/onboarding'; import {ReleaseComparisonSelector} from 'sentry/views/starfish/components/releaseSelector'; import {ROUTE_NAMES} from 'sentry/views/starfish/utils/routeNames'; import {ScreensView, YAxis} from 'sentry/views/starfish/views/screens'; import {PlatformSelector} from 'sentry/views/starfish/views/screens/platformSelector'; import {isCrossPlatform} from 'sentry/views/starfish/views/screens/utils'; export default function PageloadModule() { const organization = useOrganization(); const onboardingProject = useOnboardingProject(); const {selection} = usePageFilters(); const {projects} = useProjects(); const project = useMemo(() => { if (selection.projects.length !== 1) { return null; } return projects.find(p => p.id === String(selection.projects)); }, [projects, selection.projects]); return ( {t('Screen Loads')} {organization.features.includes( 'performance-screens-platform-selector' ) && project && isCrossPlatform(project) && } {onboardingProject && ( )} {!onboardingProject && ( )} ); } const Container = styled('div')` display: grid; grid-template-rows: auto auto auto; gap: ${space(2)}; margin-bottom: ${space(2)}; @media (min-width: ${p => p.theme.breakpoints.large}) { grid-template-rows: auto; grid-template-columns: auto 1fr auto; } `; const OnboardingContainer = styled('div')` margin-top: ${space(2)}; `; const HeaderWrapper = styled('div')` display: flex; `;