mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-28 22:03:16 -05:00
Merge pull request #15887 from overleaf/msm-new-notification-inr-latam
[web] New notification style: inr/latam/writefull/groups GitOrigin-RevId: 85ffa6d5c7ee775bf16fbb6e1fb7ce1860077b93
This commit is contained in:
parent
583074ab5c
commit
b61f34c740
6 changed files with 105 additions and 45 deletions
|
@ -96,14 +96,16 @@ export default function INRBanner({ variant, splitTestName }: INRBannerProps) {
|
|||
|
||||
if (variant === 'default') {
|
||||
return (
|
||||
<Notification bsStyle="info" onDismiss={bannerDismissed}>
|
||||
<Notification.Body>
|
||||
<Notification
|
||||
bsStyle="info"
|
||||
onDismiss={bannerDismissed}
|
||||
body={
|
||||
<Trans
|
||||
i18nKey="inr_discount_offer"
|
||||
components={[<b />]} // eslint-disable-line react/jsx-key
|
||||
/>
|
||||
</Notification.Body>
|
||||
<Notification.Action>
|
||||
}
|
||||
action={
|
||||
<Button
|
||||
bsStyle="info"
|
||||
bsSize="sm"
|
||||
|
@ -112,13 +114,15 @@ export default function INRBanner({ variant, splitTestName }: INRBannerProps) {
|
|||
>
|
||||
{t('get_discounted_plan')}
|
||||
</Button>
|
||||
</Notification.Action>
|
||||
</Notification>
|
||||
}
|
||||
/>
|
||||
)
|
||||
} else if (variant === 'green-banner') {
|
||||
return (
|
||||
<Notification bsStyle="success" onDismiss={bannerDismissed}>
|
||||
<Notification.Body>
|
||||
<Notification
|
||||
bsStyle="success"
|
||||
onDismiss={bannerDismissed}
|
||||
body={
|
||||
<Trans
|
||||
i18nKey="inr_discount_offer_green_banner"
|
||||
components={[<b />, <br />]} // eslint-disable-line react/jsx-key
|
||||
|
@ -126,17 +130,18 @@ export default function INRBanner({ variant, splitTestName }: INRBannerProps) {
|
|||
shouldUnescape
|
||||
tOptions={{ interpolation: { escapeValue: true } }}
|
||||
/>
|
||||
</Notification.Body>
|
||||
<Notification.Action>
|
||||
}
|
||||
action={
|
||||
<Button
|
||||
bsStyle="success"
|
||||
bsSize="sm"
|
||||
className="pull-right"
|
||||
onClick={handleClick}
|
||||
>
|
||||
{t('get_discounted_plan')} ₹
|
||||
</Button>
|
||||
</Notification.Action>
|
||||
</Notification>
|
||||
}
|
||||
/>
|
||||
)
|
||||
} else if (variant === 'modal') {
|
||||
return (
|
||||
|
|
|
@ -83,8 +83,10 @@ export default function LATAMBanner() {
|
|||
} = LATAM_CURRENCIES[currency as keyof typeof LATAM_CURRENCIES]
|
||||
|
||||
return (
|
||||
<Notification bsStyle="info" onDismiss={() => handleDismiss()}>
|
||||
<Notification.Body>
|
||||
<Notification
|
||||
bsStyle="info"
|
||||
onDismiss={() => handleDismiss()}
|
||||
body={
|
||||
<Trans
|
||||
i18nKey="latam_discount_offer"
|
||||
components={[<b />]} // eslint-disable-line react/jsx-key
|
||||
|
@ -92,8 +94,8 @@ export default function LATAMBanner() {
|
|||
shouldUnescape
|
||||
tOptions={{ interpolation: { escapeValue: true } }}
|
||||
/>
|
||||
</Notification.Body>
|
||||
<Notification.Action>
|
||||
}
|
||||
action={
|
||||
<Button
|
||||
bsStyle="info"
|
||||
bsSize="sm"
|
||||
|
@ -102,7 +104,7 @@ export default function LATAMBanner() {
|
|||
>
|
||||
{t('get_discounted_plan')}
|
||||
</Button>
|
||||
</Notification.Action>
|
||||
</Notification>
|
||||
}
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
|
|
@ -62,11 +62,11 @@ export default function GroupsAndEnterpriseBanner() {
|
|||
}
|
||||
|
||||
return (
|
||||
<Notification bsStyle="info" onDismiss={handleClose}>
|
||||
<Notification.Body>
|
||||
<BannerContent variant={groupsAndEnterpriseBannerVariant} />
|
||||
</Notification.Body>
|
||||
<Notification.Action>
|
||||
<Notification
|
||||
bsStyle="info"
|
||||
onDismiss={handleClose}
|
||||
body={<BannerContent variant={groupsAndEnterpriseBannerVariant} />}
|
||||
action={
|
||||
<a
|
||||
className="pull-right btn btn-info btn-sm"
|
||||
href={contactSalesUrl}
|
||||
|
@ -76,8 +76,8 @@ export default function GroupsAndEnterpriseBanner() {
|
|||
>
|
||||
{t('contact_sales')}
|
||||
</a>
|
||||
</Notification.Action>
|
||||
</Notification>
|
||||
}
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
||||
|
|
|
@ -4,21 +4,44 @@ import Body from './body'
|
|||
import Action from './action'
|
||||
import Close from '../../../../shared/components/close'
|
||||
import classnames from 'classnames'
|
||||
import NewNotification, {
|
||||
NotificationType,
|
||||
} from '@/shared/components/notification'
|
||||
import getMeta from '@/utils/meta'
|
||||
|
||||
type NotificationProps = {
|
||||
bsStyle: AlertProps['bsStyle']
|
||||
children: React.ReactNode
|
||||
children?: React.ReactNode
|
||||
body?: React.ReactNode
|
||||
action?: React.ReactElement
|
||||
onDismiss?: AlertProps['onDismiss']
|
||||
className?: string
|
||||
}
|
||||
|
||||
/**
|
||||
* Renders either a legacy-styled notification using Boostrap `Alert`, or a new-styled notification using
|
||||
* the shared `Notification` component.
|
||||
*
|
||||
* The content of the notification is provided either with `children` (keeping backwards compatibility),
|
||||
* or a `body` prop (along with an optional `action`).
|
||||
*
|
||||
* When the content is provided via `body` prop the notification is rendered with the new Notification component
|
||||
* if `ol-newNotificationStyle` meta is set to true.
|
||||
*/
|
||||
function Notification({
|
||||
bsStyle,
|
||||
children,
|
||||
onDismiss,
|
||||
className,
|
||||
body,
|
||||
action,
|
||||
...props
|
||||
}: NotificationProps) {
|
||||
const newNotificationStyle = getMeta(
|
||||
'ol-newNotificationStyle',
|
||||
false
|
||||
) as boolean
|
||||
|
||||
const [show, setShow] = useState(true)
|
||||
|
||||
const handleDismiss = () => {
|
||||
|
@ -33,18 +56,49 @@ function Notification({
|
|||
return null
|
||||
}
|
||||
|
||||
return (
|
||||
<li className={classnames('notification-entry', className)} {...props}>
|
||||
<Alert bsStyle={bsStyle}>
|
||||
{children}
|
||||
{onDismiss ? (
|
||||
<div className="notification-close">
|
||||
<Close onDismiss={handleDismiss} />
|
||||
</div>
|
||||
) : null}
|
||||
</Alert>
|
||||
</li>
|
||||
)
|
||||
if (newNotificationStyle && body) {
|
||||
const newNotificationType = (
|
||||
bsStyle === 'danger' ? 'error' : bsStyle
|
||||
) as NotificationType
|
||||
return (
|
||||
<NewNotification
|
||||
type={newNotificationType}
|
||||
isDismissible={onDismiss != null}
|
||||
onDismiss={handleDismiss}
|
||||
content={body as React.ReactElement}
|
||||
action={action}
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
||||
if (body) {
|
||||
return (
|
||||
<li className={classnames('notification-entry', className)} {...props}>
|
||||
<Alert bsStyle={bsStyle}>
|
||||
<Body>{body}</Body>
|
||||
{action && <Action>{action}</Action>}
|
||||
{onDismiss ? (
|
||||
<div className="notification-close">
|
||||
<Close onDismiss={handleDismiss} />
|
||||
</div>
|
||||
) : null}
|
||||
</Alert>
|
||||
</li>
|
||||
)
|
||||
} else {
|
||||
return (
|
||||
<li className={classnames('notification-entry', className)} {...props}>
|
||||
<Alert bsStyle={bsStyle}>
|
||||
{children}
|
||||
{onDismiss ? (
|
||||
<div className="notification-close">
|
||||
<Close onDismiss={handleDismiss} />
|
||||
</div>
|
||||
) : null}
|
||||
</Alert>
|
||||
</li>
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
Notification.Body = Body
|
||||
|
|
|
@ -41,15 +41,14 @@ function WritefullPromoBanner({
|
|||
bsStyle="info"
|
||||
onDismiss={handleClose}
|
||||
className="centered-alert"
|
||||
>
|
||||
<Notification.Body>
|
||||
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>
|
||||
</Notification.Body>
|
||||
<Notification.Action>
|
||||
}
|
||||
action={
|
||||
<a
|
||||
className="pull-right btn btn-info btn-sm"
|
||||
href="https://my.writefull.com/overleaf-invite?code=OVERLEAF10"
|
||||
|
@ -66,8 +65,8 @@ function WritefullPromoBanner({
|
|||
/>
|
||||
<span>Get Writefull for Overleaf</span>
|
||||
</a>
|
||||
</Notification.Action>
|
||||
</Notification>
|
||||
}
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
||||
|
|
|
@ -3,7 +3,7 @@ import React, { ReactElement, useState } from 'react'
|
|||
import { useTranslation } from 'react-i18next'
|
||||
import MaterialIcon from './material-icon'
|
||||
|
||||
type NotificationType = 'info' | 'success' | 'warning' | 'error'
|
||||
export type NotificationType = 'info' | 'success' | 'warning' | 'error'
|
||||
|
||||
type NotificationProps = {
|
||||
action?: React.ReactElement
|
||||
|
|
Loading…
Reference in a new issue