1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- import clamp from 'lodash/clamp';
- import ExternalLink from 'sentry/components/links/externalLink';
- import {Tooltip} from 'sentry/components/tooltip';
- import {tct} from 'sentry/locale';
- import {defined} from 'sentry/utils';
- import {NumberContainer} from 'sentry/utils/discover/styles';
- import getDuration from 'sentry/utils/duration/getDuration';
- import {formatPercentage, formatSpanOperation} from 'sentry/utils/formatters';
- interface Props {
- containerProps?: React.DetailedHTMLProps<
- React.HTMLAttributes<HTMLDivElement>,
- HTMLDivElement
- >;
- op?: string;
- percentage?: number;
- total?: number;
- }
- export function TimeSpentCell({percentage, total, op, containerProps}: Props) {
- const formattedTotal = getDuration((total ?? 0) / 1000, 2, true);
- const tooltip = percentage ? getTimeSpentExplanation(percentage, op) : undefined;
- return (
- <NumberContainer {...containerProps}>
- <Tooltip isHoverable title={tooltip} showUnderline>
- {defined(total) ? formattedTotal : '--'}
- </Tooltip>
- </NumberContainer>
- );
- }
- export function getTimeSpentExplanation(percentage: number, op?: string) {
- const formattedPercentage = formatPercentage(clamp(percentage ?? 0, 0, 1));
- return tct(
- 'The application spent [percentage] of its total time on this [span]. Read more about Time Spent in our [documentation:documentation].',
- {
- percentage: formattedPercentage,
- span: formatSpanOperation(op, 'short'),
- documentation: (
- <ExternalLink href="https://docs.sentry.io/product/performance/queries/#what-is-time-spent" />
- ),
- }
- );
- }
|