mirror of
https://github.com/overleaf/overleaf.git
synced 2025-04-04 03:43:19 +00:00
Merge pull request #11158 from overleaf/em-recompile-pdf-split-test
Recompile PDF split test GitOrigin-RevId: b02b3fb5b7a979ac299358e276ed432d736c7a03
This commit is contained in:
parent
778aa45e96
commit
56726053e8
2 changed files with 52 additions and 3 deletions
|
@ -48,6 +48,10 @@ const ProjectListController = require('./ProjectListController')
|
|||
const ProjectAuditLogHandler = require('./ProjectAuditLogHandler')
|
||||
const PublicAccessLevels = require('../Authorization/PublicAccessLevels')
|
||||
|
||||
// We want the recompile-button-text split test to only target users who have
|
||||
// signed up recently.
|
||||
const RECOMPILE_BUTTON_SPLIT_TEST_MIN_SIGNUP_DATE = new Date('2023-01-16')
|
||||
|
||||
/**
|
||||
* @typedef {import("./types").GetProjectsRequest} GetProjectsRequest
|
||||
* @typedef {import("./types").GetProjectsResponse} GetProjectsResponse
|
||||
|
@ -1082,6 +1086,27 @@ const ProjectController = {
|
|||
}
|
||||
)
|
||||
},
|
||||
recompileButtonTextAssignment: [
|
||||
'user',
|
||||
(results, cb) => {
|
||||
if (
|
||||
results.user.signUpDate <
|
||||
RECOMPILE_BUTTON_SPLIT_TEST_MIN_SIGNUP_DATE
|
||||
) {
|
||||
return cb()
|
||||
}
|
||||
SplitTestHandler.getAssignment(
|
||||
req,
|
||||
res,
|
||||
'recompile-button-text',
|
||||
{},
|
||||
() => {
|
||||
// do not fail editor load if assignment fails
|
||||
cb()
|
||||
}
|
||||
)
|
||||
},
|
||||
],
|
||||
},
|
||||
(
|
||||
err,
|
||||
|
|
|
@ -1,8 +1,11 @@
|
|||
import { Button } from 'react-bootstrap'
|
||||
import PropTypes from 'prop-types'
|
||||
import Tooltip from '../../../shared/components/tooltip'
|
||||
import Icon from '../../../shared/components/icon'
|
||||
import { useTranslation } from 'react-i18next'
|
||||
import { memo } from 'react'
|
||||
import { memo, useCallback } from 'react'
|
||||
import { useSplitTestContext } from '../../../shared/context/split-test-context'
|
||||
import * as eventTracking from '../../../infrastructure/event-tracking'
|
||||
|
||||
const modifierKey = /Mac/i.test(navigator.platform) ? 'Cmd' : 'Ctrl'
|
||||
|
||||
|
@ -17,7 +20,28 @@ function PdfCompileButtonInner({
|
|||
}: PdfCompileButtonInnerProps) {
|
||||
const { t } = useTranslation()
|
||||
|
||||
const compileButtonLabel = compiling ? t('compiling') + '…' : t('recompile')
|
||||
const { splitTestVariants } = useSplitTestContext({
|
||||
splitTestVariants: PropTypes.object,
|
||||
})
|
||||
const recompileButtonTextVariant = splitTestVariants['recompile-button-text']
|
||||
|
||||
let compileButtonLabel
|
||||
if (compiling) {
|
||||
compileButtonLabel = t('compiling') + '…'
|
||||
} else if (splitTestVariants['recompile-button-text'] === 'recompile-pdf') {
|
||||
compileButtonLabel = t('recompile') + ' PDF'
|
||||
} else {
|
||||
compileButtonLabel = t('recompile')
|
||||
}
|
||||
|
||||
const handleRecompileButtonClick = useCallback(() => {
|
||||
if (recompileButtonTextVariant != null) {
|
||||
// Only send the event when the user is targeted by the
|
||||
// recompile-button-text split test
|
||||
eventTracking.sendMB('recompile-pdf-clicked')
|
||||
}
|
||||
startCompile()
|
||||
}, [recompileButtonTextVariant, startCompile])
|
||||
|
||||
return (
|
||||
<Tooltip
|
||||
|
@ -34,7 +58,7 @@ function PdfCompileButtonInner({
|
|||
<Button
|
||||
className="btn-recompile"
|
||||
bsStyle="primary"
|
||||
onClick={() => startCompile()}
|
||||
onClick={handleRecompileButtonClick}
|
||||
aria-label={compileButtonLabel}
|
||||
disabled={compiling}
|
||||
data-ol-loading={compiling}
|
||||
|
|
Loading…
Reference in a new issue