import {Fragment} from 'react'; import styled from '@emotion/styled'; import {Breadcrumbs} from 'sentry/components/breadcrumbs'; import ButtonBar from 'sentry/components/buttonBar'; import FeedbackWidgetButton from 'sentry/components/feedback/widget/feedbackWidgetButton'; 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 {PageHeadingQuestionTooltip} from 'sentry/components/pageHeadingQuestionTooltip'; import SearchBar from 'sentry/components/searchBar'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import {browserHistory} from 'sentry/utils/browserHistory'; import {decodeScalar, decodeSorts} from 'sentry/utils/queryString'; import {escapeFilterValue, MutableSearch} from 'sentry/utils/tokenizeSearch'; import useLocationQuery from 'sentry/utils/url/useLocationQuery'; import {useLocation} from 'sentry/utils/useLocation'; import * as ModuleLayout from 'sentry/views/performance/moduleLayout'; import {ModulePageProviders} from 'sentry/views/performance/modulePageProviders'; import {ModulesOnboarding} from 'sentry/views/performance/onboarding/modulesOnboarding'; import {OnboardingContent} from 'sentry/views/performance/onboarding/onboardingContent'; import {LatencyChart} from 'sentry/views/performance/queues/charts/latencyChart'; import {ThroughputChart} from 'sentry/views/performance/queues/charts/throughputChart'; import {isAValidSort, QueuesTable} from 'sentry/views/performance/queues/queuesTable'; import {Referrer} from 'sentry/views/performance/queues/referrers'; import { DEFAULT_QUERY_FILTER, MODULE_DESCRIPTION, MODULE_DOC_LINK, MODULE_TITLE, ONBOARDING_CONTENT, } from 'sentry/views/performance/queues/settings'; import {useModuleBreadcrumbs} from 'sentry/views/performance/utils/useModuleBreadcrumbs'; import {QueryParameterNames} from 'sentry/views/starfish/views/queryParameters'; const DEFAULT_SORT = { field: 'time_spent_percentage(app,span.duration)' as const, kind: 'desc' as const, }; function QueuesLandingPage() { const location = useLocation(); const query = useLocationQuery({ fields: { destination: decodeScalar, [QueryParameterNames.DESTINATIONS_SORT]: decodeScalar, }, }); const sort = decodeSorts(query[QueryParameterNames.DESTINATIONS_SORT]) .filter(isAValidSort) .at(0) ?? DEFAULT_SORT; const handleSearch = (newDestination: string) => { browserHistory.push({ ...location, query: { ...location.query, destination: newDestination === '' ? undefined : newDestination, [QueryParameterNames.DESTINATIONS_CURSOR]: undefined, }, }); }; // The QueuesTable component queries using the destination prop. // We wrap the user input in wildcards to allow for partial matches. const wildCardDestinationFilter = query.destination ? `*${escapeFilterValue(query.destination)}*` : undefined; const crumbs = useModuleBreadcrumbs('queue'); return ( {MODULE_TITLE} } referrer={'api.performance.queues.landing-onboarding'} > ); } function PageWithProviders() { return ( ); } export default PageWithProviders; const Flex = styled('div')` display: flex; flex-direction: column; gap: ${space(2)}; `;