import {RouteComponentProps} from 'react-router';
import LoadingError from 'sentry/components/loadingError';
import LoadingIndicator from 'sentry/components/loadingIndicator';
import {t} from 'sentry/locale';
import OrganizationEnvironmentsStore from 'sentry/stores/organizationEnvironmentsStore';
import {useLegacyStore} from 'sentry/stores/useLegacyStore';
import {Environment, Group, Organization, Project} from 'sentry/types';
import {Event} from 'sentry/types/event';
import useApi from 'sentry/utils/useApi';
import usePageFilters from 'sentry/utils/usePageFilters';
import withOrganization from 'sentry/utils/withOrganization';
import {ReprocessingStatus} from '../utils';
import GroupEventDetails from './groupEventDetails';
export interface GroupEventDetailsProps
extends RouteComponentProps<{groupId: string; eventId?: string}, {}> {
event: Event;
eventError: boolean;
group: Group;
groupReprocessingStatus: ReprocessingStatus;
loadingEvent: boolean;
onRetry: () => void;
organization: Organization;
project: Project;
}
// Blocks rendering of the event until the environment is loaded
export function GroupEventDetailsContainer(props: GroupEventDetailsProps) {
const {selection} = usePageFilters();
const api = useApi();
// fetchOrganizationEnvironments is called in groupDetails.tsx
const state = useLegacyStore(OrganizationEnvironmentsStore);
if (state.error) {
return (
);
}
// null implies loading state
if (!state.environments) {
return ;
}
const environments: Environment[] = state.environments.filter(env =>
selection.environments.includes(env.name)
);
return ;
}
export default withOrganization(GroupEventDetailsContainer);