123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- import * as React from 'react';
- import Breadcrumbs from 'app/components/events/interfaces/breadcrumbs';
- import Csp from 'app/components/events/interfaces/csp';
- import DebugMeta from 'app/components/events/interfaces/debugMeta';
- import DebugMetaV2 from 'app/components/events/interfaces/debugMeta-v2';
- import Exception from 'app/components/events/interfaces/exception';
- import Generic from 'app/components/events/interfaces/generic';
- import Message from 'app/components/events/interfaces/message';
- import Request from 'app/components/events/interfaces/request';
- import Spans from 'app/components/events/interfaces/spans';
- import Stacktrace from 'app/components/events/interfaces/stacktrace';
- import Template from 'app/components/events/interfaces/template';
- import Threads from 'app/components/events/interfaces/threads';
- import {Group, Organization, Project, SharedViewOrganization} from 'app/types';
- import {Entry, EntryType, Event, EventTransaction} from 'app/types/event';
- type Props = {
- entry: Entry;
- projectSlug: Project['slug'];
- event: Event;
- organization: SharedViewOrganization | Organization;
- group?: Group;
- };
- function EventEntry({entry, projectSlug, event, organization, group}: Props) {
- const hasHierarchicalGrouping =
- !!organization.features?.includes('grouping-stacktrace-ui') &&
- !!(event.metadata.current_tree_label || event.metadata.finest_tree_label);
- const groupingCurrentLevel = group?.metadata?.current_level;
- switch (entry.type) {
- case EntryType.EXCEPTION: {
- const {data, type} = entry;
- return (
- <Exception
- type={type}
- event={event}
- data={data}
- projectId={projectSlug}
- groupingCurrentLevel={groupingCurrentLevel}
- hasHierarchicalGrouping={hasHierarchicalGrouping}
- />
- );
- }
- case EntryType.MESSAGE: {
- const {data} = entry;
- return <Message data={data} />;
- }
- case EntryType.REQUEST: {
- const {data, type} = entry;
- return <Request type={type} event={event} data={data} />;
- }
- case EntryType.STACKTRACE: {
- const {data, type} = entry;
- return (
- <Stacktrace
- type={type}
- event={event}
- data={data}
- projectId={projectSlug}
- groupingCurrentLevel={groupingCurrentLevel}
- hasHierarchicalGrouping={hasHierarchicalGrouping}
- />
- );
- }
- case EntryType.TEMPLATE: {
- const {data, type} = entry;
- return <Template type={type} event={event} data={data} />;
- }
- case EntryType.CSP: {
- const {data} = entry;
- return <Csp event={event} data={data} />;
- }
- case EntryType.EXPECTCT:
- case EntryType.EXPECTSTAPLE:
- case EntryType.HPKP: {
- const {data, type} = entry;
- return <Generic type={type} data={data} />;
- }
- case EntryType.BREADCRUMBS: {
- const {data, type} = entry;
- return (
- <Breadcrumbs
- type={type}
- data={data}
- organization={organization as Organization}
- event={event}
- />
- );
- }
- case EntryType.THREADS: {
- const {data, type} = entry;
- return (
- <Threads
- type={type}
- event={event}
- data={data}
- projectId={projectSlug}
- groupingCurrentLevel={groupingCurrentLevel}
- hasHierarchicalGrouping={hasHierarchicalGrouping}
- />
- );
- }
- case EntryType.DEBUGMETA:
- const {data} = entry;
- const hasImagesLoadedV2Feature =
- !!organization.features?.includes('images-loaded-v2');
- if (hasImagesLoadedV2Feature) {
- return (
- <DebugMetaV2
- event={event}
- projectId={projectSlug}
- groupId={group?.id}
- organization={organization as Organization}
- data={data as React.ComponentProps<typeof DebugMetaV2>['data']}
- />
- );
- }
- return (
- <DebugMeta
- event={event}
- projectId={projectSlug}
- organization={organization as Organization}
- data={data}
- />
- );
- case EntryType.SPANS:
- return (
- <Spans
- event={event as EventTransaction}
- organization={organization as Organization}
- />
- );
- default:
- // this should not happen
- /* eslint no-console:0 */
- window.console &&
- console.error &&
- console.error('Unregistered interface: ' + (entry as any).type);
- return null;
- }
- }
- export default EventEntry;
|