import {Fragment, useEffect} from 'react'; import styled from '@emotion/styled'; import {motion, MotionProps} from 'framer-motion'; import OnboardingInstall from 'sentry-images/spot/onboarding-install.svg'; import OnboardingSetup from 'sentry-images/spot/onboarding-setup.svg'; import {openInviteMembersModal} from 'sentry/actionCreators/modal'; import {Button} from 'sentry/components/button'; import Link from 'sentry/components/links/link'; import {t, tct} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import trackAdvancedAnalyticsEvent from 'sentry/utils/analytics/trackAdvancedAnalyticsEvent'; import testableTransition from 'sentry/utils/testableTransition'; import FallingError from 'sentry/views/onboarding/components/fallingError'; import WelcomeBackground from 'sentry/views/onboarding/components/welcomeBackground'; import {StepProps} from './types'; import {usePersistedOnboardingState} from './utils'; const fadeAway: MotionProps = { variants: { initial: {opacity: 0}, animate: {opacity: 1, filter: 'blur(0px)'}, exit: {opacity: 0, filter: 'blur(1px)'}, }, transition: testableTransition({duration: 0.8}), }; type TextWrapperProps = { cta: React.ReactNode; src: string; subText: React.ReactNode; title: React.ReactNode; }; function InnerAction({title, subText, cta, src}: TextWrapperProps) { return ( {title} {subText} {cta} ); } function TargetedOnboardingWelcome({ organization, jumpToSetupProject, ...props }: StepProps) { const source = 'targeted_onboarding'; const [clientState, setClientState] = usePersistedOnboardingState(); useEffect(() => { trackAdvancedAnalyticsEvent('growth.onboarding_start_onboarding', { organization, source, }); }); const onComplete = () => { trackAdvancedAnalyticsEvent('growth.onboarding_clicked_instrument_app', { organization, source, }); if (clientState) { setClientState({ ...clientState, url: 'select-platform/', state: 'started', }); } props.onComplete(); }; // jump to setup project if the backend set this state for us useEffect(() => { if (clientState?.state === 'projects_selected') { jumpToSetupProject(); } }, [clientState, jumpToSetupProject]); return ( {({fallingError, fallCount, isFalling}) => ( {t('Welcome to Sentry')} {t( 'Your code is probably broken. Maybe not. Find out for sure. Get started below.' )} { // triggerFall(); onComplete(); }} priority="primary" > {t('Start')} {(fallCount === 0 || isFalling) && ( {fallingError} )} } /> {t('friends')}} )} src={OnboardingSetup} cta={ { openInviteMembersModal({source}); }} priority="primary" > {t('Invite Team')} } /> {t("Gee, I've used Sentry before.")}
{ trackAdvancedAnalyticsEvent('growth.onboarding_clicked_skip', { organization, source, }); if (clientState) { setClientState({ ...clientState, state: 'skipped', }); } }} to={`/organizations/${organization.slug}/issues/?referrer=onboarding-welcome-skip`} > {t('Skip onboarding.')}
)}
); } export default TargetedOnboardingWelcome; const PositionedFallingError = styled('span')` display: block; position: absolute; right: 0px; top: 30px; `; const Wrapper = styled(motion.div)` position: relative; margin-top: auto; margin-bottom: auto; max-width: 400px; display: flex; flex-direction: column; align-items: center; text-align: center; margin-left: auto; margin-right: auto; h1 { font-size: 42px; } `; const ActionItem = styled(motion.div)` min-height: 120px; border-radius: ${space(0.5)}; padding: ${space(2)}; margin-bottom: ${space(2)}; justify-content: space-around; border: 1px solid ${p => p.theme.gray200}; @media (min-width: ${p => p.theme.breakpoints.small}) { display: grid; grid-template-columns: 125px auto 125px; width: 680px; align-items: center; } @media (max-width: ${p => p.theme.breakpoints.small}) { display: flex; flex-direction: column; } `; const TextWrapper = styled('div')` text-align: left; margin: auto ${space(3)}; min-height: 70px; @media (max-width: ${p => p.theme.breakpoints.small}) { text-align: center; margin: ${space(1)} ${space(1)}; margin-top: ${space(3)}; } `; const Strike = styled('span')` text-decoration: line-through; `; const ActionTitle = styled('h5')` font-weight: 900; margin: 0 0 ${space(0.5)}; color: ${p => p.theme.gray400}; `; const SubText = styled('span')` font-weight: 400; color: ${p => p.theme.gray400}; `; const SubHeaderText = styled(motion.h6)` color: ${p => p.theme.gray300}; `; const ButtonWrapper = styled('div')` margin: ${space(1)}; position: relative; `; const ActionImage = styled('img')` height: 100px; `; const ButtonWithFill = styled(Button)` width: 100%; position: relative; z-index: 1; `;