import * as qs from 'query-string'; import Link from 'sentry/components/links/link'; import {useLocation} from 'sentry/utils/useLocation'; import {useModuleURL} from 'sentry/views/performance/utils/useModuleURL'; import {OverflowEllipsisTextContainer} from 'sentry/views/starfish/components/textAlign'; interface Props { domain?: string; project?: string; transaction?: string; transactionMethod?: string; } export function TransactionCell({ domain, project, transaction, transactionMethod, }: Props) { const moduleURL = useModuleURL('http'); const location = useLocation(); if (!transaction) { return NULL_DESCRIPTION; } // TODO: This checks if the transaction name starts with the request method so we don't end up with labels like `GET GET /users` but any transaction name with an HTTP method prefix is incorrect, so it's not clear that we should cater to this const label = transactionMethod && !transaction.startsWith(transactionMethod) ? `${transactionMethod} ${transaction}` : transaction; const pathname = `${moduleURL}/domains/`; const query = { ...location.query, domain, project, transaction, transactionMethod, }; return ( {label} ); } const NULL_DESCRIPTION = <null>;