mirror of
https://github.com/overleaf/overleaf.git
synced 2024-10-31 21:21:03 -04:00
78 lines
2 KiB
TypeScript
78 lines
2 KiB
TypeScript
|
import { ReactNode } from 'react'
|
||
|
import { UserEmailData } from '../../../../../../types/user-email'
|
||
|
import { Row, Col } from 'react-bootstrap'
|
||
|
import classNames from 'classnames'
|
||
|
import getMeta from '../../../../utils/meta'
|
||
|
import ReconfirmationInfoSuccess from './reconfirmation-info/reconfirmation-info-success'
|
||
|
import ReconfirmationInfoPrompt from './reconfirmation-info/reconfirmation-info-prompt'
|
||
|
|
||
|
type ReconfirmationInfoProps = {
|
||
|
userEmailData: UserEmailData
|
||
|
}
|
||
|
|
||
|
function ReconfirmationInfo({ userEmailData }: ReconfirmationInfoProps) {
|
||
|
const reconfirmationRemoveEmail = getMeta(
|
||
|
'ol-reconfirmationRemoveEmail'
|
||
|
) as string
|
||
|
const reconfirmedViaSAML = getMeta('ol-reconfirmedViaSAML') as string
|
||
|
|
||
|
if (!userEmailData.affiliation) {
|
||
|
return null
|
||
|
}
|
||
|
|
||
|
if (
|
||
|
userEmailData.samlProviderId &&
|
||
|
userEmailData.samlProviderId === reconfirmedViaSAML
|
||
|
) {
|
||
|
return (
|
||
|
<ReconfirmationInfoContentWrapper asAlertInfo>
|
||
|
<ReconfirmationInfoSuccess
|
||
|
institution={userEmailData.affiliation.institution}
|
||
|
/>
|
||
|
</ReconfirmationInfoContentWrapper>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
if (userEmailData.affiliation.inReconfirmNotificationPeriod) {
|
||
|
return (
|
||
|
<ReconfirmationInfoContentWrapper
|
||
|
asAlertInfo={reconfirmationRemoveEmail === userEmailData.email}
|
||
|
>
|
||
|
<ReconfirmationInfoPrompt
|
||
|
institution={userEmailData.affiliation.institution}
|
||
|
primary={userEmailData.default}
|
||
|
email={userEmailData.email}
|
||
|
/>
|
||
|
</ReconfirmationInfoContentWrapper>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
return null
|
||
|
}
|
||
|
|
||
|
type ReconfirmationInfoContentWrapperProps = {
|
||
|
asAlertInfo: boolean
|
||
|
children: ReactNode
|
||
|
}
|
||
|
|
||
|
function ReconfirmationInfoContentWrapper({
|
||
|
asAlertInfo,
|
||
|
children,
|
||
|
}: ReconfirmationInfoContentWrapperProps) {
|
||
|
return (
|
||
|
<Row>
|
||
|
<Col md={12}>
|
||
|
<div
|
||
|
className={classNames('settings-reconfirm-info', 'small', {
|
||
|
'alert alert-info': asAlertInfo,
|
||
|
})}
|
||
|
>
|
||
|
{children}
|
||
|
</div>
|
||
|
</Col>
|
||
|
</Row>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
export default ReconfirmationInfo
|