import {Fragment} from 'react'; import {openHelpSearchModal} from 'sentry/actionCreators/modal'; import {Button} from 'sentry/components/button'; import ExternalLink from 'sentry/components/links/externalLink'; import {t, tct} from 'sentry/locale'; import type {Project} from 'sentry/types/project'; import normalizeUrl from 'sentry/utils/url/normalizeUrl'; import useOrganization from 'sentry/utils/useOrganization'; import usePageFilters from 'sentry/utils/usePageFilters'; import {useDenylistedProjects} from 'sentry/views/insights/database/queries/useDenylistedProjects'; import {useOutdatedSDKProjects} from 'sentry/views/insights/database/queries/useOutdatedSDKProjects'; import {MODULE_DOC_LINK} from 'sentry/views/insights/database/settings'; interface Props { Wrapper?: React.ComponentType; isDataAvailable?: boolean; } function DivWrapper(props) { return
; } export function NoDataMessage({Wrapper = DivWrapper, isDataAvailable}: Props) { const organization = useOrganization(); const {selection, isReady: pageFilterIsReady} = usePageFilters(); const selectedProjectIds = selection.projects.map(projectId => projectId.toString()); const {projects: outdatedProjects, isFetching: areOutdatedProjectsFetching} = useOutdatedSDKProjects({ projectId: selectedProjectIds, enabled: pageFilterIsReady && !isDataAvailable, }); const {projects: denylistedProjects, isFetching: areDenylistProjectsFetching} = useDenylistedProjects({ projectId: selectedProjectIds, }); const isDataFetching = areOutdatedProjectsFetching || areDenylistProjectsFetching; if (isDataFetching) { return null; } const hasAnyProblematicProjects = (!areOutdatedProjectsFetching && outdatedProjects.length > 0) || (!areDenylistProjectsFetching && denylistedProjects.length > 0); if (isDataAvailable && !hasAnyProblematicProjects) { return null; } return ( {!isDataAvailable && tct( 'No queries found. Try updating your filters, or learn more about performance monitoring for queries in our [documentation:documentation].', { documentation: , } )}{' '} {outdatedProjects.length > 0 && tct('You may be missing data due to outdated SDKs: [projectList].', { projectList: , })}{' '} {denylistedProjects.length > 0 && tct( 'Some of your projects have been omitted from query performance analysis. Please [supportLink]. Omitted projects: [projectList].', { supportLink: ( ), projectList: , } )} ); } interface ProjectListProps { projects: Project[]; limit?: number; } function ProjectList({projects, limit = MAX_LISTED_PROJECTS}: ProjectListProps) { const organization = useOrganization(); const visibleProjects = projects.slice(0, limit + 1); const hasMoreProjectsThanVisible = projects.length > MAX_LISTED_PROJECTS; return ( {visibleProjects.slice(0, limit).map((project, projectIndex) => { return ( {project.name} {projectIndex < visibleProjects.length - 1 && ', '} ); })} {hasMoreProjectsThanVisible && tct(' and [count] more.', { count: projects.length - limit, })}{' '} ); } const MAX_LISTED_PROJECTS = 3;