1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- import {useState} from 'react';
- import {Location} from 'history';
- import LoadingError from 'sentry/components/loadingError';
- import {t} from 'sentry/locale';
- import {Organization} from 'sentry/types';
- import EventView, {decodeSorts} from 'sentry/utils/discover/eventView';
- import EventsTable from 'sentry/views/performance/transactionSummary/transactionEvents/eventsTable';
- export interface Props {
- isPerfIssue: boolean;
- issueId: string;
- location: Location;
- organization: Organization;
- excludedTags?: string[];
- }
- const AllEventsTable = (props: Props) => {
- const {location, organization, issueId, isPerfIssue, excludedTags} = props;
- const [error, setError] = useState<string>('');
- const eventView: EventView = EventView.fromLocation(props.location);
- eventView.sorts = decodeSorts(location);
- eventView.fields = [
- {field: 'id'},
- {field: 'transaction'},
- {field: 'trace'},
- {field: 'release'},
- {field: 'environment'},
- {field: 'user.display'},
- ...(isPerfIssue ? [{field: 'transaction.duration'}] : []),
- {field: 'timestamp'},
- ];
- const idQuery = isPerfIssue
- ? `performance.issue_ids:${issueId}`
- : `issue.id:${issueId}`;
- eventView.query = `${idQuery} ${props.location.query.query || ''}`;
- const columnTitles: Readonly<string[]> = [
- t('event id'),
- t('transaction'),
- t('trace id'),
- t('release'),
- t('environment'),
- t('user'),
- ...(isPerfIssue ? [t('total duration')] : []),
- t('timestamp'),
- ];
- if (error) {
- return <LoadingError message={error} />;
- }
- return (
- <EventsTable
- eventView={eventView}
- location={location}
- issueId={issueId}
- organization={organization}
- excludedTags={excludedTags}
- setError={() => {
- (msg: string) => setError(msg);
- }}
- transactionName=""
- disablePagination
- columnTitles={columnTitles.slice()}
- />
- );
- };
- export default AllEventsTable;
|