import {useCallback} from 'react'; import styled from '@emotion/styled'; import {removeProject} from 'sentry/actionCreators/projects'; import {Button} from 'sentry/components/button'; import ButtonBar from 'sentry/components/buttonBar'; import Confirm from 'sentry/components/confirm'; import {useRecentCreatedProject} from 'sentry/components/onboarding/useRecentCreatedProject'; import type {Platform} from 'sentry/data/platformPickerCategories'; import {IconChevron} from 'sentry/icons/iconChevron'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import type {Project} from 'sentry/types/project'; import {trackAnalytics} from 'sentry/utils/analytics'; import {handleXhrErrorResponse} from 'sentry/utils/handleXhrErrorResponse'; import useApi from 'sentry/utils/useApi'; import useOrganization from 'sentry/utils/useOrganization'; import useRouter from 'sentry/utils/useRouter'; import {normalizeUrl} from 'sentry/utils/withDomainRequired'; type Props = { platform: Platform; projectSlug: Project['slug']; }; export function PlatformDocHeader({platform, projectSlug}: Props) { const organization = useOrganization(); const api = useApi(); const router = useRouter(); const recentCreatedProject = useRecentCreatedProject({ orgSlug: organization.slug, projectSlug, }); const shallProjectBeDeleted = recentCreatedProject && // if the project has received a first error, we don't delete it recentCreatedProject.firstError === false && // if the project has received a first transaction, we don't delete it recentCreatedProject.firstTransaction === false && // if the project has replays, we don't delete it recentCreatedProject.hasReplays === false && // if the project has sessions, we don't delete it recentCreatedProject.hasSessions === false && // if the project is older than one hour, we don't delete it recentCreatedProject.olderThanOneHour === false; const handleGoBack = useCallback(async () => { if (!recentCreatedProject) { return; } trackAnalytics('project_creation.back_button_clicked', { organization, }); if (shallProjectBeDeleted) { trackAnalytics('project_creation.data_removal_modal_confirm_button_clicked', { organization, platform: recentCreatedProject.slug, project_id: recentCreatedProject.id, }); try { await removeProject({ api, orgSlug: organization.slug, projectSlug: recentCreatedProject.slug, origin: 'getting_started', }); trackAnalytics('project_creation.data_removed', { organization, date_created: recentCreatedProject.dateCreated, platform: recentCreatedProject.slug, project_id: recentCreatedProject.id, }); } catch (error) { handleXhrErrorResponse('Unable to delete project in project creation', error); // we don't give the user any feedback regarding this error as this shall be silent } } router.replace( normalizeUrl( `/organizations/${organization.slug}/projects/new/?referrer=getting-started&project=${recentCreatedProject.id}` ) ); }, [api, recentCreatedProject, organization, shallProjectBeDeleted, router]); return (

{t('Configure %(platform)s SDK', {platform: platform.name ?? 'other'})}

{ if (!recentCreatedProject) { return; } trackAnalytics('project_creation.data_removal_modal_dismissed', { organization, platform: recentCreatedProject.slug, project_id: recentCreatedProject.id, }); }} onRender={() => { if (!recentCreatedProject) { return; } trackAnalytics('project_creation.data_removal_modal_rendered', { organization, platform: recentCreatedProject.slug, project_id: recentCreatedProject.id, }); }} > {platform.key !== 'other' && ( )}
); } const StyledPageHeader = styled('div')` display: flex; justify-content: space-between; margin-bottom: ${space(3)}; h2 { margin: 0; } @media (max-width: ${p => p.theme.breakpoints.small}) { flex-direction: column; align-items: flex-start; h2 { margin-bottom: ${space(2)}; } } `;