123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- import type {ComponentProps} from 'react';
- import styled from '@emotion/styled';
- import type {Location} from 'history';
- import GridEditable, {
- COL_WIDTH_UNDEFINED,
- type GridColumnHeader,
- } from 'sentry/components/gridEditable';
- import {t} from 'sentry/locale';
- import type {Organization} from 'sentry/types/organization';
- import type {EventsMetaType} from 'sentry/utils/discover/eventView';
- import {getFieldRenderer} from 'sentry/utils/discover/fieldRenderers';
- import {useLocation} from 'sentry/utils/useLocation';
- import useOrganization from 'sentry/utils/useOrganization';
- import {renderHeadCell} from 'sentry/views/insights/common/components/tableCells/renderHeadCell';
- import {SpanIdCell} from 'sentry/views/insights/common/components/tableCells/spanIdCell';
- import {MessageActorType} from 'sentry/views/insights/queues/settings';
- import type {SpanIndexedResponse} from 'sentry/views/insights/types';
- import {ModuleName, SpanIndexedField} from 'sentry/views/insights/types';
- import {TraceViewSources} from 'sentry/views/performance/newTraceDetails/traceHeader/breadcrumbs';
- type DataRowKeys =
- | SpanIndexedField.PROJECT
- | SpanIndexedField.TRANSACTION_ID
- | SpanIndexedField.TRACE
- | SpanIndexedField.TIMESTAMP
- | SpanIndexedField.ID
- | SpanIndexedField.SPAN_DESCRIPTION
- | SpanIndexedField.MESSAGING_MESSAGE_BODY_SIZE
- | SpanIndexedField.MESSAGING_MESSAGE_RECEIVE_LATENCY
- | SpanIndexedField.MESSAGING_MESSAGE_ID
- | SpanIndexedField.MESSAGING_MESSAGE_RETRY_COUNT
- | SpanIndexedField.TRACE_STATUS
- | SpanIndexedField.SPAN_DURATION;
- type ColumnKeys =
- | SpanIndexedField.ID
- | SpanIndexedField.MESSAGING_MESSAGE_ID
- | SpanIndexedField.MESSAGING_MESSAGE_BODY_SIZE
- | SpanIndexedField.MESSAGING_MESSAGE_RETRY_COUNT
- | SpanIndexedField.TRACE_STATUS
- | SpanIndexedField.SPAN_DURATION;
- type DataRow = Pick<SpanIndexedResponse, DataRowKeys>;
- type Column = GridColumnHeader<ColumnKeys>;
- const CONSUMER_COLUMN_ORDER: Column[] = [
- {
- key: SpanIndexedField.ID,
- name: t('Span ID'),
- width: 150,
- },
- {
- key: SpanIndexedField.MESSAGING_MESSAGE_ID,
- name: t('Message ID'),
- width: COL_WIDTH_UNDEFINED,
- },
- {
- key: SpanIndexedField.SPAN_DURATION,
- name: t('Span Duration'),
- width: COL_WIDTH_UNDEFINED,
- },
- {
- key: SpanIndexedField.MESSAGING_MESSAGE_RETRY_COUNT,
- name: t('Retries'),
- width: COL_WIDTH_UNDEFINED,
- },
- {
- key: SpanIndexedField.TRACE_STATUS,
- name: t('Status'),
- width: COL_WIDTH_UNDEFINED,
- },
- ];
- const PRODUCER_COLUMN_ORDER: Column[] = [
- {
- key: SpanIndexedField.ID,
- name: t('Span ID'),
- width: 150,
- },
- {
- key: SpanIndexedField.MESSAGING_MESSAGE_ID,
- name: t('Message ID'),
- width: COL_WIDTH_UNDEFINED,
- },
- {
- key: SpanIndexedField.MESSAGING_MESSAGE_BODY_SIZE,
- name: t('Message Size'),
- width: COL_WIDTH_UNDEFINED,
- },
- {
- key: SpanIndexedField.TRACE_STATUS,
- name: t('Status'),
- width: COL_WIDTH_UNDEFINED,
- },
- ];
- interface Props {
- data: DataRow[];
- isLoading: boolean;
- type: MessageActorType;
- error?: Error | null;
- highlightedSpanId?: string;
- meta?: EventsMetaType;
- onSampleMouseOut?: ComponentProps<typeof GridEditable>['onRowMouseOut'];
- onSampleMouseOver?: ComponentProps<typeof GridEditable>['onRowMouseOver'];
- }
- export function MessageSpanSamplesTable({
- data,
- isLoading,
- error,
- meta,
- onSampleMouseOver,
- onSampleMouseOut,
- highlightedSpanId,
- type,
- }: Props) {
- const location = useLocation();
- const organization = useOrganization();
- return (
- <GridEditable
- aria-label={t('Span Samples')}
- isLoading={isLoading}
- error={error}
- data={data}
- columnOrder={
- type === MessageActorType.PRODUCER ? PRODUCER_COLUMN_ORDER : CONSUMER_COLUMN_ORDER
- }
- columnSortBy={[]}
- grid={{
- renderHeadCell: col =>
- renderHeadCell({
- column: col,
- location,
- }),
- renderBodyCell: (column, row) =>
- renderBodyCell(column, row, meta, location, organization),
- }}
- highlightedRowKey={data.findIndex(row => row.span_id === highlightedSpanId)}
- onRowMouseOver={onSampleMouseOver}
- onRowMouseOut={onSampleMouseOut}
- />
- );
- }
- function renderBodyCell(
- column: Column,
- row: DataRow,
- meta: EventsMetaType | undefined,
- location: Location,
- organization: Organization
- ) {
- const key = column.key;
- if (row[key] === undefined) {
- return (
- <AlignRight>
- <NoValue>{' \u2014 '}</NoValue>
- </AlignRight>
- );
- }
- if (key === SpanIndexedField.ID) {
- return (
- <SpanIdCell
- moduleName={ModuleName.QUEUE}
- projectSlug={row.project}
- traceId={row.trace}
- timestamp={row.timestamp}
- transactionId={row[SpanIndexedField.TRANSACTION_ID]}
- spanId={row[SpanIndexedField.ID]}
- source={TraceViewSources.QUEUES_MODULE}
- location={location}
- />
- );
- }
- if (!meta?.fields) {
- return row[column.key];
- }
- const renderer = getFieldRenderer(column.key, meta.fields, false);
- return renderer(row, {
- location,
- organization,
- unit: meta.units?.[column.key],
- });
- }
- const AlignRight = styled('span')`
- text-align: right;
- `;
- const NoValue = styled('span')`
- color: ${p => p.theme.gray300};
- `;
|