import {useCallback, useState} from 'react'; import styled from '@emotion/styled'; import {Button} from 'sentry/components/button'; import {Flex} from 'sentry/components/container/flex'; import {useReplayContext} from 'sentry/components/replays/replayContext'; import Well from 'sentry/components/well'; import {t, tct} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import formatReplayDuration from 'sentry/utils/duration/formatReplayDuration'; import TimestampButton from 'sentry/views/replays/detail/timestampButton'; interface Props { initialOffsetMs: number; refetch: () => void; } export default function AccessibilityRefetchBanner({initialOffsetMs, refetch}: Props) { const {currentTime, replay, setCurrentTime, isPlaying, togglePlayPause} = useReplayContext(); const startTimestampMs = replay?.getReplay()?.started_at?.getTime() ?? 0; const [lastOffsetMs, setLastOffsetMs] = useState(initialOffsetMs); const handleClickRefetch = useCallback(() => { togglePlayPause(false); setLastOffsetMs(currentTime); refetch(); }, [currentTime, refetch, togglePlayPause]); const handleClickTimestamp = useCallback(() => { setCurrentTime(lastOffsetMs); }, [setCurrentTime, lastOffsetMs]); const now = formatReplayDuration(currentTime, false); return ( {tct('Results as of [lastRuntime]', { lastRuntime: ( ), })} ); } const StyledWell = styled(Well)` margin-bottom: 0; border-radius: ${p => p.theme.borderRadiusTop}; `; const StyledTimestampButton = styled(TimestampButton)` align-self: center; align-items: center; `;