Files
overleaf-cep/services/web/frontend/js/shared/components/start-free-trial-button.tsx
T
Mathias Jakobsen d8c7acfe62 Merge pull request #28438 from overleaf/dp-itm-content
Add itm-content param indicating split test variant to compile timeout paywalls

GitOrigin-RevId: 809e13f8e548498d890c055d20d7ce30fd6ead7f
2025-09-17 08:05:06 +00:00

60 lines
1.6 KiB
TypeScript

import { useCallback, useEffect } from 'react'
import { useTranslation } from 'react-i18next'
import { startFreeTrial } from '@/main/account-upgrade'
import * as eventTracking from '../../infrastructure/event-tracking'
import OLButton from '@/shared/components/ol/ol-button'
type StartFreeTrialButtonProps = {
source: string
variant?: string
buttonProps?: React.ComponentProps<typeof OLButton>
children?: React.ReactNode
handleClick?: React.ComponentProps<typeof OLButton>['onClick']
segmentation?: eventTracking.Segmentation
extraSearchParams?: Record<string, string>
}
export default function StartFreeTrialButton({
buttonProps = {
variant: 'secondary',
},
children,
handleClick,
source,
variant,
segmentation,
extraSearchParams,
}: StartFreeTrialButtonProps) {
const { t } = useTranslation()
useEffect(() => {
const eventSegmentation: { [key: string]: unknown } = {
'paywall-type': source,
...segmentation,
}
if (variant) {
eventSegmentation.variant = variant
}
eventTracking.sendMB('paywall-prompt', eventSegmentation)
}, [source, variant, segmentation])
const onClick = useCallback(
(event: React.MouseEvent<HTMLButtonElement, MouseEvent>) => {
event.preventDefault()
if (handleClick) {
handleClick(event)
}
startFreeTrial(source, variant, segmentation, extraSearchParams)
},
[handleClick, source, variant, segmentation, extraSearchParams]
)
return (
<OLButton {...buttonProps} onClick={onClick}>
{children || t('start_free_trial')}
</OLButton>
)
}