mirror of
https://github.com/overleaf/overleaf.git
synced 2024-10-24 21:12:38 -04:00
[web] Set Subscription pages to have layout-react
(#20969)
* [web] Set Subscription pages to have `layout-react`
* [web] import `header-footer-react` in Subscription pages (!!)
* [web] Add `ol-user` meta tag to the subscription pages (!!)
⚠️ invite_logged_out.pug should be updated instead of setting the user as `{}`
* [web] Fix unit test
* [web] Update User types to handle a logged out user, add `LOGGED_OUT_USER` const
* [web] Add type `User` to `getSessionUser`
* [web] Remove `LOGGED_OUT_USER` const
* [web] Just pass `{ id: null }` as the user
* [web] Remove comment in pugs, it breaks things
* [web] Don't pass the full user to the frontend!!!
Co-authored-by: Jakob Ackermann <jakob.ackermann@overleaf.com>
---------
Co-authored-by: Jakob Ackermann <jakob.ackermann@overleaf.com>
GitOrigin-RevId: 1768f1f13de924a18be43c1a08614000500dcbec
This commit is contained in:
parent
1b2f5af1c0
commit
2c7530a6cf
14 changed files with 41 additions and 11 deletions
|
@ -1,6 +1,12 @@
|
||||||
const _ = require('lodash')
|
const _ = require('lodash')
|
||||||
|
|
||||||
|
/** @typedef {import('../../../../types/user').User} User */
|
||||||
|
|
||||||
const SessionManager = {
|
const SessionManager = {
|
||||||
|
/**
|
||||||
|
* @param session
|
||||||
|
* @returns {User | null}
|
||||||
|
*/
|
||||||
getSessionUser(session) {
|
getSessionUser(session) {
|
||||||
const sessionUser = _.get(session, ['user'])
|
const sessionUser = _.get(session, ['user'])
|
||||||
const sessionPassportUser = _.get(session, ['passport', 'user'])
|
const sessionPassportUser = _.get(session, ['passport', 'user'])
|
||||||
|
|
|
@ -169,12 +169,16 @@ async function viewInvite(req, res, next) {
|
||||||
invite.email
|
invite.email
|
||||||
)
|
)
|
||||||
|
|
||||||
|
/** @type {import('../../../../types/user').LoggedOutUser} */
|
||||||
|
const userWithoutSensitiveFields = { id: null }
|
||||||
|
|
||||||
return res.render('subscriptions/team/invite_logged_out', {
|
return res.render('subscriptions/team/invite_logged_out', {
|
||||||
inviterName: invite.inviterName,
|
inviterName: invite.inviterName,
|
||||||
inviteToken: invite.token,
|
inviteToken: invite.token,
|
||||||
appName: settings.appName,
|
appName: settings.appName,
|
||||||
accountExists: userByEmail != null,
|
accountExists: userByEmail != null,
|
||||||
emailAddress: invite.email,
|
emailAddress: invite.email,
|
||||||
|
userWithoutSensitiveFields,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,6 +37,7 @@ block append meta
|
||||||
subdomainLang: settings.i18n.subdomainLang,
|
subdomainLang: settings.i18n.subdomainLang,
|
||||||
translatedLanguages: settings.translatedLanguages
|
translatedLanguages: settings.translatedLanguages
|
||||||
})
|
})
|
||||||
|
meta(name="ol-user" data-type="json" content=(userWithoutSensitiveFields || getSessionUser()))
|
||||||
|
|
||||||
block body
|
block body
|
||||||
if (typeof suppressNavbar === "undefined")
|
if (typeof suppressNavbar === "undefined")
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
extends ../layout-marketing
|
extends ../layout-react
|
||||||
|
|
||||||
block vars
|
block vars
|
||||||
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
extends ../layout-marketing
|
extends ../layout-react
|
||||||
|
|
||||||
block vars
|
block vars
|
||||||
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
extends ../layout-marketing
|
extends ../layout-react
|
||||||
|
|
||||||
block vars
|
block vars
|
||||||
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
extends ../../layout-marketing
|
extends ../../layout-react
|
||||||
|
|
||||||
block vars
|
block vars
|
||||||
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
extends ../../layout-marketing
|
extends ../../layout-react
|
||||||
|
|
||||||
block vars
|
block vars
|
||||||
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
extends ../../layout-marketing
|
extends ../../layout-react
|
||||||
|
|
||||||
block vars
|
block vars
|
||||||
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
extends ../../layout-marketing
|
extends ../../layout-react
|
||||||
|
|
||||||
block vars
|
block vars
|
||||||
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
- bootstrap5PageStatus = 'enabled' // One of 'disabled', 'enabled', and 'queryStringOnly'
|
||||||
|
|
|
@ -6,3 +6,4 @@ import '../../../features/contact-form'
|
||||||
import '../../../features/event-tracking'
|
import '../../../features/event-tracking'
|
||||||
import '../../../features/cookie-banner'
|
import '../../../features/cookie-banner'
|
||||||
import '../../../features/link-helpers/slow-link'
|
import '../../../features/link-helpers/slow-link'
|
||||||
|
import '../../../features/header-footer-react'
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
import { createContext, FC, useContext, useMemo } from 'react'
|
import { createContext, FC, useContext, useMemo } from 'react'
|
||||||
import getMeta from '../../utils/meta'
|
import getMeta from '../../utils/meta'
|
||||||
import { User } from '../../../../types/user'
|
import { LoggedOutUser, User } from '../../../../types/user'
|
||||||
|
|
||||||
export const UserContext = createContext<User | undefined>(undefined)
|
export const UserContext = createContext<User | LoggedOutUser | undefined>(
|
||||||
|
undefined
|
||||||
|
)
|
||||||
|
|
||||||
export const UserProvider: FC = ({ children }) => {
|
export const UserProvider: FC = ({ children }) => {
|
||||||
const user = useMemo(() => getMeta('ol-user'), [])
|
const user = useMemo(() => getMeta('ol-user'), [])
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { User, Features } from '../../../types/user'
|
import { User, Features, LoggedOutUser } from '../../../types/user'
|
||||||
import { User as MinimalUser } from '../../../types/admin/user'
|
import { User as MinimalUser } from '../../../types/admin/user'
|
||||||
import { User as ManagedUser } from '../../../types/group-management/user'
|
import { User as ManagedUser } from '../../../types/group-management/user'
|
||||||
import { UserSettings } from '../../../types/user-settings'
|
import { UserSettings } from '../../../types/user-settings'
|
||||||
|
@ -204,7 +204,7 @@ export interface Meta {
|
||||||
'ol-usGovBannerVariant': USGovBannerVariant
|
'ol-usGovBannerVariant': USGovBannerVariant
|
||||||
'ol-useShareJsHash': boolean
|
'ol-useShareJsHash': boolean
|
||||||
'ol-usedLatex': 'never' | 'occasionally' | 'often' | undefined
|
'ol-usedLatex': 'never' | 'occasionally' | 'often' | undefined
|
||||||
'ol-user': User
|
'ol-user': User | LoggedOutUser
|
||||||
'ol-userAffiliations': Affiliation[]
|
'ol-userAffiliations': Affiliation[]
|
||||||
'ol-userCanExtendTrial': boolean
|
'ol-userCanExtendTrial': boolean
|
||||||
'ol-userCanNotStartRequestedTrial': boolean
|
'ol-userCanNotStartRequestedTrial': boolean
|
||||||
|
|
|
@ -46,4 +46,20 @@ export type User = {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export type LoggedOutUser = {
|
||||||
|
id: null
|
||||||
|
email?: undefined
|
||||||
|
first_name?: undefined
|
||||||
|
last_name?: undefined
|
||||||
|
signUpDate?: undefined
|
||||||
|
labsProgram?: boolean
|
||||||
|
alphaProgram?: boolean
|
||||||
|
betaProgram?: boolean
|
||||||
|
allowedFreeTrial?: boolean
|
||||||
|
features?: Features
|
||||||
|
refProviders?: RefProviders
|
||||||
|
writefull?: undefined
|
||||||
|
isAdmin?: boolean
|
||||||
|
}
|
||||||
|
|
||||||
export type MongoUser = Pick<User, Exclude<keyof User, 'id'>> & { _id: string }
|
export type MongoUser = Pick<User, Exclude<keyof User, 'id'>> & { _id: string }
|
||||||
|
|
Loading…
Reference in a new issue