import {Fragment, useCallback, useContext, 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 {OnboardingContext} from 'sentry/components/onboarding/onboardingContext'; import {t, tct} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import {trackAnalytics} from 'sentry/utils/analytics'; import testableTransition from 'sentry/utils/testableTransition'; import useOrganization from 'sentry/utils/useOrganization'; import FallingError from 'sentry/views/onboarding/components/fallingError'; import WelcomeBackground from 'sentry/views/onboarding/components/welcomeBackground'; import {StepProps} from './types'; 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(props: StepProps) { const organization = useOrganization(); const onboardingContext = useContext(OnboardingContext); const source = 'targeted_onboarding'; useEffect(() => { trackAnalytics('growth.onboarding_start_onboarding', { organization, source, }); if (onboardingContext.data.selectedSDK) { // At this point the selectedSDK shall be undefined but just in case, cleaning this up here too onboardingContext.setData({...onboardingContext.data, selectedSDK: undefined}); } }, [organization, onboardingContext]); const handleComplete = useCallback(() => { trackAnalytics('growth.onboarding_clicked_instrument_app', { organization, source, }); props.onComplete(); }, [organization, source, props]); const handleSkipOnboarding = useCallback(() => { trackAnalytics('growth.onboarding_clicked_skip', { organization, source, }); }, [organization, source]); return ( {({fallingError, fallCount, isFalling}) => ( {t('Welcome to Sentry')} {t( 'Your code is probably broken. Maybe not. Find out for sure. Get started below.' )} {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.")}
{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; `;