import omit from 'lodash/omit'; import {defined} from 'sentry/utils'; import GenericDiscoverQuery, { DiscoverQueryProps, GenericChildrenProps, } from 'sentry/utils/discover/genericDiscoverQuery'; import withApi from 'sentry/utils/withApi'; import {SpanExample} from './types'; type SpanExamplesProps = { spanGroup: string; spanOp: string; maxExclusiveTime?: string; minExclusiveTime?: string; }; type RequestProps = DiscoverQueryProps & SpanExamplesProps; export type ChildrenProps = Omit, 'tableData'> & { examples: SpanExample[] | null; }; type Props = RequestProps & { children: (props: ChildrenProps) => React.ReactNode; }; function getSuspectSpanPayload(props: RequestProps) { const {spanOp, spanGroup, minExclusiveTime, maxExclusiveTime} = props; const span = defined(spanOp) && defined(spanGroup) ? `${spanOp}:${spanGroup}` : undefined; const payload = defined(span) ? {span, min_exclusive_time: minExclusiveTime, max_exclusive_time: maxExclusiveTime} : {}; const additionalPayload = omit(props.eventView.getEventsAPIPayload(props.location), [ 'field', ]); return {...payload, ...additionalPayload}; } function SuspectSpansQuery(props: Props) { return ( route="events-spans" getRequestPayload={getSuspectSpanPayload} {...omit(props, 'children')} > {({tableData, ...rest}) => { return props.children({ examples: tableData ?? null, ...rest, }); }} ); } export default withApi(SuspectSpansQuery);