import type {CSSProperties} from 'react'; import {useCallback} from 'react'; 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 useCurrentHoverTime from 'sentry/utils/replays/playback/providers/useCurrentHoverTime'; import type {ReplayFrame} from 'sentry/utils/replays/types'; interface Props { extraction: Extraction | undefined; frame: ReplayFrame; index: number; onClick: ReturnType['onClickTimestamp']; onInspectorExpanded: ( index: number, path: string, expandedState: Record ) => void; startTimestampMs: number; style: CSSProperties; breadcrumbIndex?: number[][]; expandPaths?: string[]; } export default function BreadcrumbRow({ expandPaths, extraction, frame, index, onClick, onInspectorExpanded, startTimestampMs, style, }: Props) { const {currentTime} = useReplayContext(); const [currentHoverTime] = useCurrentHoverTime(); const {onMouseEnter, onMouseLeave} = useCrumbHandlers(); const handleObjectInspectorExpanded = useCallback( (path, expandedState) => onInspectorExpanded?.(index, path, expandedState), [index, onInspectorExpanded] ); const hasOccurred = currentTime >= frame.offsetMs; const isBeforeHover = currentHoverTime === undefined || currentHoverTime >= frame.offsetMs; return ( ); }