123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- import type {CSSProperties, MouseEvent} from 'react';
- import {useCallback} from 'react';
- import styled from '@emotion/styled';
- import classNames from 'classnames';
- import BreadcrumbItem from 'sentry/components/replays/breadcrumbs/breadcrumbItem';
- import {useReplayContext} from 'sentry/components/replays/replayContext';
- import type {Extraction} from 'sentry/utils/replays/extractDomNodes';
- import useCrumbHandlers from 'sentry/utils/replays/hooks/useCrumbHandlers';
- import type {ReplayFrame} from 'sentry/utils/replays/types';
- import type {ReplayTraceRow} from 'sentry/views/replays/detail/perfTable/useReplayPerfData';
- interface Props {
- extraction: Extraction | undefined;
- frame: ReplayFrame;
- index: number;
- onClick: ReturnType<typeof useCrumbHandlers>['onClickTimestamp'];
- onDimensionChange: (index: number) => void;
- onInspectorExpanded: (
- index: number,
- path: string,
- expandedState: Record<string, boolean>,
- event: MouseEvent<HTMLDivElement>
- ) => void;
- startTimestampMs: number;
- style: CSSProperties;
- traces: ReplayTraceRow | undefined;
- breadcrumbIndex?: number[][];
- expandPaths?: string[];
- }
- export default function BreadcrumbRow({
- expandPaths,
- extraction,
- frame,
- index,
- onClick,
- onDimensionChange,
- onInspectorExpanded,
- startTimestampMs,
- style,
- traces,
- }: Props) {
- const {currentTime, currentHoverTime} = useReplayContext();
- const {onMouseEnter, onMouseLeave} = useCrumbHandlers();
- const handleDimensionChange = useCallback(
- () => onDimensionChange(index),
- [onDimensionChange, index]
- );
- const handleObjectInspectorExpanded = useCallback(
- (path, expandedState, e) => onInspectorExpanded?.(index, path, expandedState, e),
- [index, onInspectorExpanded]
- );
- const hasOccurred = currentTime >= frame.offsetMs;
- const isBeforeHover =
- currentHoverTime === undefined || currentHoverTime >= frame.offsetMs;
- return (
- <StyledTimeBorder
- className={classNames({
- beforeCurrentTime: hasOccurred,
- afterCurrentTime: !hasOccurred,
- beforeHoverTime: currentHoverTime !== undefined ? isBeforeHover : undefined,
- afterHoverTime: currentHoverTime !== undefined ? !isBeforeHover : undefined,
- })}
- style={style}
- >
- <BreadcrumbItem
- frame={frame}
- traces={traces}
- extraction={extraction}
- onClick={onClick}
- onMouseEnter={onMouseEnter}
- onMouseLeave={onMouseLeave}
- startTimestampMs={startTimestampMs}
- expandPaths={expandPaths}
- onDimensionChange={handleDimensionChange}
- onInspectorExpanded={handleObjectInspectorExpanded}
- />
- </StyledTimeBorder>
- );
- }
- const StyledTimeBorder = styled('div')`
- /* Overridden in TabItemContainer, depending on *CurrentTime and *HoverTime classes */
- border-top: 1px solid transparent;
- border-bottom: 1px solid transparent;
- `;
|