import {Fragment, useCallback, useState} from 'react';
import styled from '@emotion/styled';
import {openModal} from 'sentry/actionCreators/modal';
import {Button} from 'sentry/components/button';
import {TabList, Tabs} from 'sentry/components/tabs';
import {IconTable} from 'sentry/icons/iconTable';
import {t} from 'sentry/locale';
import {space} from 'sentry/styles/space';
import {useResultMode} from 'sentry/views/explore/hooks/useResultsMode';
import {useSampleFields} from 'sentry/views/explore/hooks/useSampleFields';
import {useSpanTags} from '../contexts/spanTagsContext';
import {TracesTable} from './tracesTable/index';
import {AggregatesTable} from './aggregatesTable';
import {ColumnEditorModal} from './columnEditorModal';
import {SpansTable} from './spansTable';
enum Tab {
SPAN = 'span',
TRACE = 'trace',
}
interface ExploreTablesProps {}
export function ExploreTables({}: ExploreTablesProps) {
const [resultMode] = useResultMode();
return (
{resultMode === 'aggregate' && }
{resultMode === 'samples' && }
);
}
function ExploreAggregatesTable() {
return ;
}
function ExploreSamplesTable() {
const [tab, setTab] = useState(Tab.SPAN);
const [fields, setFields] = useSampleFields();
const numberTags = useSpanTags('number');
const stringTags = useSpanTags('string');
const openColumnEditor = useCallback(() => {
openModal(
modalProps => (
),
{closeEvents: 'escape-key'}
);
}, [fields, setFields, stringTags, numberTags]);
return (
{t('Span Samples')}
{t('Trace Samples')}
}
>
{t('Edit Table')}
{tab === Tab.SPAN && }
{tab === Tab.TRACE && }
);
}
const SamplesTableHeader = styled('div')`
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: ${space(2)};
`;