123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- import {cloneElement, Fragment, isValidElement, useEffect} from 'react';
- import {RouteComponentProps} from 'react-router';
- import {fetchOrgMembers} from 'sentry/actionCreators/members';
- import {navigateTo} from 'sentry/actionCreators/navigation';
- import Alert from 'sentry/components/alert';
- import LoadingIndicator from 'sentry/components/loadingIndicator';
- import {t} from 'sentry/locale';
- import {Organization} from 'sentry/types';
- import useApi from 'sentry/utils/useApi';
- import useProjects from 'sentry/utils/useProjects';
- import useScrollToTop from 'sentry/utils/useScrollToTop';
- type Props = RouteComponentProps<RouteParams, {}> & {
- hasMetricAlerts: boolean;
- organization: Organization;
- children?: React.ReactNode;
- };
- type RouteParams = {
- projectId?: string;
- };
- function AlertBuilderProjectProvider(props: Props) {
- const api = useApi();
- useScrollToTop({location: props.location});
- const {children, params, organization, ...other} = props;
- const projectId = params.projectId || props.location.query.project;
- const hasAlertWizardV3 = organization.features.includes('alert-wizard-v3');
- const useFirstProject = hasAlertWizardV3 && projectId === undefined;
- // calling useProjects() without args fetches all projects
- const {projects, initiallyLoaded, fetching, fetchError} = useProjects(
- useFirstProject
- ? undefined
- : {
- slugs: [projectId],
- }
- );
- const project = useFirstProject
- ? projects.find(p => p.isMember) ?? (projects.length && projects[0])
- : projects.find(({slug}) => slug === projectId);
- useEffect(() => {
- if (!project) {
- return;
- }
- // fetch members list for mail action fields
- fetchOrgMembers(api, organization.slug, [project.id]);
- }, [api, organization, project]);
- if (!initiallyLoaded || fetching) {
- return <LoadingIndicator />;
- }
- // If there's no project show the project selector modal
- if (!project && !fetchError) {
- navigateTo(
- hasAlertWizardV3
- ? `/organizations/${organization.slug}/alerts/wizard/?referrer=${props.location.query.referrer}&project=:projectId`
- : `/organizations/${organization.slug}/alerts/:projectId/wizard/?referrer=${props.location.query.referrer}`,
- props.router
- );
- }
- // if loaded, but project fetching states incomplete or project can't be found, project doesn't exist
- if (!project || fetchError) {
- return (
- <Alert type="warning">{t('The project you were looking for was not found.')}</Alert>
- );
- }
- return (
- <Fragment>
- {children && isValidElement(children)
- ? cloneElement(children, {
- ...other,
- ...children.props,
- project,
- projectId: useFirstProject ? project.slug : projectId,
- organization,
- })
- : children}
- </Fragment>
- );
- }
- export default AlertBuilderProjectProvider;
|