123456789101112131415161718192021222324252627282930313233343536373839404142 |
- import {RefObject, useEffect, useMemo} from 'react';
- import type {List as ReactVirtualizedList} from 'react-virtualized';
- import {useReplayContext} from 'sentry/components/replays/replayContext';
- import type {Crumb} from 'sentry/types/breadcrumbs';
- import {getPrevReplayEvent} from 'sentry/utils/replays/getReplayEvent';
- type Opts = {
- breadcrumbs: undefined | Crumb[];
- ref: RefObject<ReactVirtualizedList>;
- startTimestampMs: number;
- };
- function useScrollToCurrentItem({breadcrumbs, ref, startTimestampMs}: Opts) {
- const {currentTime} = useReplayContext();
- const itemLookup = useMemo(
- () =>
- breadcrumbs &&
- breadcrumbs
- .map(({timestamp}, i) => [+new Date(timestamp || ''), i])
- .sort(([a], [b]) => a - b),
- [breadcrumbs]
- );
- const current = useMemo(
- () =>
- getPrevReplayEvent({
- itemLookup,
- items: breadcrumbs || [],
- targetTimestampMs: startTimestampMs + currentTime,
- }),
- [itemLookup, breadcrumbs, currentTime, startTimestampMs]
- );
- useEffect(() => {
- if (ref.current && current) {
- const index = breadcrumbs?.findIndex(crumb => crumb.id === current.id);
- ref.current?.scrollToRow(index ? index + 1 : undefined);
- }
- }, [breadcrumbs, current, ref]);
- }
- export default useScrollToCurrentItem;
|