import {useEffect, useMemo} from 'react'; import styled from '@emotion/styled'; import {Location} from 'history'; import * as Layout from 'sentry/components/layouts/thirds'; import type {Group, Organization} from 'sentry/types'; import {trackAnalytics} from 'sentry/utils/analytics'; import EventView from 'sentry/utils/discover/eventView'; import useReplayList from 'sentry/utils/replays/hooks/useReplayList'; import {useLocation} from 'sentry/utils/useLocation'; import useOrganization from 'sentry/utils/useOrganization'; import useReplaysFromIssue from 'sentry/views/issueDetails/groupReplays/useReplaysFromIssue'; import ReplayTable from 'sentry/views/replays/replayTable'; import {ReplayColumns} from 'sentry/views/replays/replayTable/types'; import type {ReplayListLocationQuery} from 'sentry/views/replays/types'; type Props = { group: Group; }; const VISIBLE_COLUMNS = [ ReplayColumns.replay, ReplayColumns.os, ReplayColumns.browser, ReplayColumns.duration, ReplayColumns.countErrors, ReplayColumns.activity, ]; function GroupReplays({group}: Props) { const organization = useOrganization(); const location = useLocation(); const {eventView, fetchError, pageLinks} = useReplaysFromIssue({ group, location, organization, }); useEffect(() => { trackAnalytics('replay.render-issues-group-list', { project_id: group.project.id, platform: group.project.platform, organization, }); // we only want to fire this event once // eslint-disable-next-line react-hooks/exhaustive-deps }, []); if (!eventView) { return ( ); } return ( ); } function GroupReplaysTable({ eventView, organization, visibleColumns, }: { eventView: EventView; organization: Organization; pageLinks: string | null; visibleColumns: ReplayColumns[]; }) { const location = useMemo(() => ({query: {}} as Location), []); const {replays, isFetching, fetchError} = useReplayList({ eventView, location, organization, queryReferrer: 'issueReplays', }); return ( ); } const StyledLayoutPage = styled(Layout.Page)` box-shadow: 0px 0px 1px ${p => p.theme.gray200}; background-color: ${p => p.theme.background}; `; export default GroupReplays;