import {useCallback, useMemo} from 'react';
import styled from '@emotion/styled';
import type {Location} from 'history';
import {Button} from 'sentry/components/button';
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 PageFiltersContainer from 'sentry/components/organizations/pageFilters/container';
import {ProjectPageFilter} from 'sentry/components/organizations/projectPageFilter';
import {
EAPSpanSearchQueryBuilder,
SpanSearchQueryBuilder,
} from 'sentry/components/performance/spanSearchQueryBuilder';
import SentryDocumentTitle from 'sentry/components/sentryDocumentTitle';
import {t} from 'sentry/locale';
import {space} from 'sentry/styles/space';
import {DiscoverDatasets} from 'sentry/utils/discover/types';
import {ALLOWED_EXPLORE_VISUALIZE_AGGREGATES} from 'sentry/utils/fields';
import {useLocation} from 'sentry/utils/useLocation';
import {useNavigate} from 'sentry/utils/useNavigate';
import useOrganization from 'sentry/utils/useOrganization';
import usePageFilters from 'sentry/utils/usePageFilters';
import {ExploreCharts} from 'sentry/views/explore/charts';
import {
SpanTagsProvider,
useSpanTags,
} from 'sentry/views/explore/contexts/spanTagsContext';
import {useDataset} from 'sentry/views/explore/hooks/useDataset';
import {useResultMode} from 'sentry/views/explore/hooks/useResultsMode';
import {useUserQuery} from 'sentry/views/explore/hooks/useUserQuery';
import {ExploreTables} from 'sentry/views/explore/tables';
import {ExploreToolbar} from 'sentry/views/explore/toolbar';
interface ExploreContentProps {
location: Location;
}
function ExploreContentImpl({}: ExploreContentProps) {
const location = useLocation();
const navigate = useNavigate();
const organization = useOrganization();
const {selection} = usePageFilters();
const [dataset] = useDataset();
const [resultsMode] = useResultMode();
const numberTags = useSpanTags('number');
const stringTags = useSpanTags('string');
const supportedAggregates = useMemo(() => {
return resultsMode === 'aggregate' ? ALLOWED_EXPLORE_VISUALIZE_AGGREGATES : [];
}, [resultsMode]);
const [userQuery, setUserQuery] = useUserQuery();
const toolbarExtras = organization.features.includes('visibility-explore-dataset')
? ['dataset toggle' as const]
: [];
const switchToOldTraceExplorer = useCallback(() => {
navigate({
...location,
query: {
...location.query,
view: 'trace',
},
});
}, [location, navigate]);
return (
{t('Explore')}
{dataset === DiscoverDatasets.SPANS_INDEXED ? (
) : (
)}
);
}
export function ExploreContent(props: ExploreContentProps) {
const [dataset] = useDataset();
return (
);
}
const Body = styled(Layout.Body)`
gap: ${space(2)};
@media (min-width: ${p => p.theme.breakpoints.medium}) {
grid-template-columns: 300px minmax(100px, auto);
}
@media (min-width: ${p => p.theme.breakpoints.xlarge}) {
grid-template-columns: 350px minmax(100px, auto);
}
`;
const TopSection = styled('div')`
display: grid;
gap: ${space(2)};
grid-column: 1/3;
margin-bottom: ${space(2)};
@media (min-width: ${p => p.theme.breakpoints.large}) {
grid-template-columns: minmax(300px, auto) 1fr;
margin-bottom: 0;
}
@media (min-width: ${p => p.theme.breakpoints.xlarge}) {
grid-template-columns: minmax(350px, auto) 1fr;
}
`;
const MainSection = styled(Layout.Main)`
grid-column: 2/3;
`;
const StyledPageFilterBar = styled(PageFilterBar)`
width: auto;
`;