mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-21 20:47:08 -05:00
Merge pull request #17369 from overleaf/jdt-rm-old-wf-prj-list-ad
removing old writefull ad from project list and removing uneeded spli… GitOrigin-RevId: 84722949c4972ba0b7c8e0bf6d2884608e26a613
This commit is contained in:
parent
ce19b5f568
commit
5701a1cccd
4 changed files with 23 additions and 191 deletions
|
@ -357,12 +357,6 @@ async function projectListPage(req, res, next) {
|
|||
}
|
||||
}
|
||||
|
||||
await SplitTestHandler.promises.getAssignment(
|
||||
req,
|
||||
res,
|
||||
'writefull-oauth-promotion'
|
||||
)
|
||||
|
||||
let showInrGeoBanner = false
|
||||
let showBrlGeoBanner = false
|
||||
let recommendedCurrency
|
||||
|
|
|
@ -4,7 +4,6 @@ import Institution from './groups/institution'
|
|||
import ConfirmEmail from './groups/confirm-email'
|
||||
import ReconfirmationInfo from './groups/affiliation/reconfirmation-info'
|
||||
import GroupsAndEnterpriseBanner from './groups-and-enterprise-banner'
|
||||
import WritefullPromoBanner from './writefull-promo-banner'
|
||||
import WritefullPremiumPromoBanner from './writefull-premium-promo-banner'
|
||||
import GroupSsoSetupSuccess from './groups/group-sso-setup-success'
|
||||
import INRBanner from './ads/inr-banner'
|
||||
|
@ -13,14 +12,8 @@ import importOverleafModules from '../../../../../macros/import-overleaf-module.
|
|||
import customLocalStorage from '../../../../infrastructure/local-storage'
|
||||
import { sendMB } from '../../../../infrastructure/event-tracking'
|
||||
import classNames from 'classnames'
|
||||
import { isSplitTestEnabled } from '@/utils/splitTestUtils'
|
||||
import BRLBanner from './ads/brl-banner'
|
||||
|
||||
const isChromium = () =>
|
||||
(window.navigator as any).userAgentData?.brands?.some(
|
||||
(item: { brand: string }) => item.brand === 'Chromium'
|
||||
)
|
||||
|
||||
type Subscription = {
|
||||
groupId: string
|
||||
groupName: string
|
||||
|
@ -45,9 +38,6 @@ function UserNotifications() {
|
|||
)
|
||||
const showInrGeoBanner = getMeta('ol-showInrGeoBanner', false)
|
||||
const showBrlGeoBanner = getMeta('ol-showBrlGeoBanner', false)
|
||||
const writefullOauthPromotionSplitTestEnabled = isSplitTestEnabled(
|
||||
'writefull-oauth-promotion'
|
||||
)
|
||||
const user = getMeta('ol-user')
|
||||
|
||||
// Temporary workaround to prevent also showing groups/enterprise banner
|
||||
|
@ -60,20 +50,14 @@ function UserNotifications() {
|
|||
}
|
||||
|
||||
const show =
|
||||
user?.writefull?.enabled === true || // show to any users who have writefull enabled regardless of split test
|
||||
(!writefullOauthPromotionSplitTestEnabled && // show old banner to users who are not in the split test, who are on chrome and havent dismissed
|
||||
isChromium() &&
|
||||
getMeta('ol-showWritefullPromoBanner'))
|
||||
user?.writefull?.enabled === true ||
|
||||
window.writefull?.type === 'extension'
|
||||
|
||||
if (show) {
|
||||
sendMB('promo-prompt', {
|
||||
location: 'dashboard-banner',
|
||||
page: '/project',
|
||||
name:
|
||||
user?.writefull?.enabled === true ||
|
||||
writefullOauthPromotionSplitTestEnabled
|
||||
? 'writefull-premium'
|
||||
: 'writefull',
|
||||
name: 'writefull-premium',
|
||||
})
|
||||
}
|
||||
|
||||
|
@ -81,15 +65,6 @@ function UserNotifications() {
|
|||
})
|
||||
const [dismissedWritefull, setDismissedWritefull] = useState(false)
|
||||
|
||||
const hasWritefullExtensionAlreadyInstalled =
|
||||
window.writefull?.type === 'extension'
|
||||
const usesWritefullIntegration =
|
||||
writefullOauthPromotionSplitTestEnabled || user?.writefull?.enabled
|
||||
const writefullBannerVariant =
|
||||
hasWritefullExtensionAlreadyInstalled || usesWritefullIntegration
|
||||
? 'plans-page'
|
||||
: 'chrome-store'
|
||||
|
||||
return (
|
||||
<div
|
||||
className={classNames('user-notifications', {
|
||||
|
@ -112,24 +87,15 @@ function UserNotifications() {
|
|||
<ReconfirmationInfo />
|
||||
{!showWritefull && !dismissedWritefull && <GroupsAndEnterpriseBanner />}
|
||||
{showInrGeoBanner && <INRBanner />}
|
||||
|
||||
<WritefullPremiumPromoBanner
|
||||
show={showWritefull}
|
||||
setShow={setShowWritefull}
|
||||
onDismiss={() => {
|
||||
setDismissedWritefull(true)
|
||||
}}
|
||||
/>
|
||||
{showBrlGeoBanner && <BRLBanner />}
|
||||
{writefullBannerVariant === 'plans-page' ? (
|
||||
<WritefullPremiumPromoBanner
|
||||
show={showWritefull}
|
||||
setShow={setShowWritefull}
|
||||
onDismiss={() => {
|
||||
setDismissedWritefull(true)
|
||||
}}
|
||||
/>
|
||||
) : (
|
||||
<WritefullPromoBanner
|
||||
show={showWritefull}
|
||||
setShow={setShowWritefull}
|
||||
onDismiss={() => {
|
||||
setDismissedWritefull(true)
|
||||
}}
|
||||
/>
|
||||
)}
|
||||
</ul>
|
||||
</div>
|
||||
)
|
||||
|
|
|
@ -1,80 +0,0 @@
|
|||
import { memo, useCallback } from 'react'
|
||||
import Notification from './notification'
|
||||
import { sendMB } from '../../../../infrastructure/event-tracking'
|
||||
import customLocalStorage from '../../../../infrastructure/local-storage'
|
||||
import getMeta from '@/utils/meta'
|
||||
|
||||
const eventSegmentation = {
|
||||
location: 'dashboard-banner',
|
||||
page: '/project',
|
||||
name: 'writefull',
|
||||
}
|
||||
|
||||
function WritefullPromoBanner({
|
||||
show,
|
||||
setShow,
|
||||
onDismiss,
|
||||
}: {
|
||||
show: boolean
|
||||
setShow: (value: boolean) => void
|
||||
onDismiss: () => void
|
||||
}) {
|
||||
const newNotificationStyle = getMeta(
|
||||
'ol-newNotificationStyle',
|
||||
false
|
||||
) as boolean
|
||||
const handleOpenLink = useCallback(() => {
|
||||
sendMB('promo-click', eventSegmentation)
|
||||
}, [])
|
||||
|
||||
const handleClose = useCallback(() => {
|
||||
customLocalStorage.setItem('has_dismissed_writefull_promo_banner', true)
|
||||
setShow(false)
|
||||
sendMB('promo-dismiss', eventSegmentation)
|
||||
onDismiss()
|
||||
}, [setShow, onDismiss])
|
||||
|
||||
if (!show) {
|
||||
return null
|
||||
}
|
||||
|
||||
return (
|
||||
<Notification
|
||||
bsStyle="info"
|
||||
onDismiss={handleClose}
|
||||
className="centered-alert"
|
||||
body={
|
||||
<span>
|
||||
Get <b>10% off</b> Writefull premium—AI-based language feedback and
|
||||
TeXGPT to help you write great papers faster. Use code:{' '}
|
||||
<b>OVERLEAF10</b>
|
||||
</span>
|
||||
}
|
||||
action={
|
||||
<a
|
||||
className={
|
||||
newNotificationStyle
|
||||
? 'btn btn-secondary btn-sm'
|
||||
: 'pull-right btn btn-info btn-sm'
|
||||
}
|
||||
href="https://my.writefull.com/overleaf-invite?code=OVERLEAF10"
|
||||
target="_blank"
|
||||
rel="noreferrer"
|
||||
onClick={handleOpenLink}
|
||||
>
|
||||
<img
|
||||
alt="Writefull Logo"
|
||||
src=""
|
||||
height={16}
|
||||
width={16}
|
||||
style={{ marginRight: 4 }}
|
||||
aria-hidden="true"
|
||||
/>
|
||||
<span>Get Writefull for Overleaf</span>
|
||||
</a>
|
||||
}
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
||||
export default memo(WritefullPromoBanner)
|
|
@ -977,23 +977,19 @@ describe('<UserNotifications />', function () {
|
|||
window.metaAttributesCache = window.metaAttributesCache || new Map()
|
||||
})
|
||||
|
||||
describe('when writefull-oauth-promotion split test is not enabled', function () {
|
||||
describe('when the writefull integration is enabled', function () {
|
||||
beforeEach(function () {
|
||||
window.metaAttributesCache.set('ol-splitTestVariants', {
|
||||
'writefull-oauth-promotion': 'default',
|
||||
})
|
||||
window.metaAttributesCache.set('ol-user', {
|
||||
writefull: { enabled: false },
|
||||
writefull: { enabled: true },
|
||||
})
|
||||
})
|
||||
|
||||
it('shows the older banner', function () {
|
||||
it('shows the banner', function () {
|
||||
renderWithinProjectListProvider(UserNotifications)
|
||||
const ctaLink = screen.getByRole('link', {
|
||||
name: 'Get Writefull for Overleaf',
|
||||
name: 'Get Writefull Premium',
|
||||
})
|
||||
expect(ctaLink.getAttribute('href')).to.equal(
|
||||
'https://my.writefull.com/overleaf-invite?code=OVERLEAF10'
|
||||
'https://my.writefull.com/overleaf-invite?code=OVERLEAF10&redirect=plans'
|
||||
)
|
||||
})
|
||||
|
||||
|
@ -1010,67 +1006,23 @@ describe('<UserNotifications />', function () {
|
|||
it("doesn't show the banner if it has been dismissed", function () {
|
||||
localStorage.setItem(
|
||||
'has_dismissed_writefull_promo_banner',
|
||||
new Date(Date.now() - 1000)
|
||||
new Date(Date.now() - 500)
|
||||
)
|
||||
renderWithinProjectListProvider(UserNotifications)
|
||||
expect(screen.queryByRole('link', { name: /Writefull/ })).to.be.null
|
||||
})
|
||||
})
|
||||
|
||||
describe('when writefull-oauth-promotion split test is enabled', function () {
|
||||
describe('when the writefull integration is not enabled', function () {
|
||||
beforeEach(function () {
|
||||
window.metaAttributesCache.set('ol-splitTestVariants', {
|
||||
'writefull-oauth-promotion': 'enabled',
|
||||
window.metaAttributesCache.set('ol-user', {
|
||||
writefull: { enabled: false },
|
||||
})
|
||||
})
|
||||
|
||||
describe('when the writefull integration is enabled', function () {
|
||||
beforeEach(function () {
|
||||
window.metaAttributesCache.set('ol-user', {
|
||||
writefull: { enabled: true },
|
||||
})
|
||||
})
|
||||
it('shows the banner', function () {
|
||||
renderWithinProjectListProvider(UserNotifications)
|
||||
const ctaLink = screen.getByRole('link', {
|
||||
name: 'Get Writefull Premium',
|
||||
})
|
||||
expect(ctaLink.getAttribute('href')).to.equal(
|
||||
'https://my.writefull.com/overleaf-invite?code=OVERLEAF10&redirect=plans'
|
||||
)
|
||||
})
|
||||
|
||||
it('dismisses the banner when the close button is clicked', function () {
|
||||
renderWithinProjectListProvider(UserNotifications)
|
||||
screen.getByRole('link', { name: /Writefull/ })
|
||||
const closeButton = screen.getByRole('button', { name: 'Close' })
|
||||
fireEvent.click(closeButton)
|
||||
expect(screen.queryByRole('link', { name: /Writefull/ })).to.be.null
|
||||
expect(localStorage.getItem('has_dismissed_writefull_promo_banner'))
|
||||
.to.exist
|
||||
})
|
||||
|
||||
it("doesn't show the banner if it has been dismissed", function () {
|
||||
localStorage.setItem(
|
||||
'has_dismissed_writefull_promo_banner',
|
||||
new Date(Date.now() - 500)
|
||||
)
|
||||
renderWithinProjectListProvider(UserNotifications)
|
||||
expect(screen.queryByRole('link', { name: /Writefull/ })).to.be.null
|
||||
})
|
||||
})
|
||||
|
||||
describe('when the writefull integration is not enabled', function () {
|
||||
beforeEach(function () {
|
||||
window.metaAttributesCache.set('ol-user', {
|
||||
writefull: { enabled: false },
|
||||
})
|
||||
})
|
||||
|
||||
it("doesn't show the banner", function () {
|
||||
renderWithinProjectListProvider(UserNotifications)
|
||||
expect(screen.queryByRole('link', { name: /Writefull/ })).to.be.null
|
||||
})
|
||||
it("doesn't show the banner", function () {
|
||||
renderWithinProjectListProvider(UserNotifications)
|
||||
expect(screen.queryByRole('link', { name: /Writefull/ })).to.be.null
|
||||
})
|
||||
})
|
||||
})
|
||||
|
|
Loading…
Reference in a new issue