overleaf/services/web/frontend/js/features/settings/components/emails-section.tsx
Timothée Alby d3dc83b776 Merge pull request #7722 from overleaf/ii-add-email-ui-without-affiliations
Add emails without affiliations

GitOrigin-RevId: 13d53b604f8d7cf0f36b2c5caea85ecc15cfc6d5
2022-04-26 08:04:12 +00:00

81 lines
2.2 KiB
TypeScript

import { Fragment } from 'react'
import { useTranslation, Trans } from 'react-i18next'
import getMeta from '../../../utils/meta'
import {
UserEmailsProvider,
useUserEmailsContext,
} from '../context/user-email-context'
import EmailsHeader from './emails/header'
import EmailsRow from './emails/row'
import AddEmail from './emails/add-email'
import Icon from '../../../shared/components/icon'
import { Alert } from 'react-bootstrap'
import { ExposedSettings } from '../../../../../types/exposed-settings'
function EmailsSectionContent() {
const { t } = useTranslation()
const {
state: { data: userEmailsData },
isInitializing,
isInitializingError,
} = useUserEmailsContext()
const userEmails = Object.values(userEmailsData.byId)
return (
<>
<h3>{t('emails_and_affiliations_title')}</h3>
<p className="small">{t('emails_and_affiliations_explanation')}</p>
<p className="small">
<Trans i18nKey="change_primary_email_address_instructions">
<strong />
{/* eslint-disable-next-line jsx-a11y/anchor-has-content */}
<a href="/learn/how-to/Keeping_your_account_secure" />
</Trans>
</p>
<div className="table">
<EmailsHeader />
{isInitializing ? (
<div className="text-center">
<Icon type="refresh" fw spin /> {t('loading')}...
</div>
) : (
<>
{userEmails?.map(userEmail => (
<Fragment key={userEmail.email}>
<EmailsRow userEmailData={userEmail} />
<div className="horizontal-divider" />
</Fragment>
))}
</>
)}
<AddEmail />
{isInitializingError && (
<Alert bsStyle="danger" className="text-center">
<Icon type="exclamation-triangle" fw />{' '}
{t('error_performing_request')}
</Alert>
)}
</div>
</>
)
}
function EmailsSection() {
const { hasAffiliationsFeature } = getMeta(
'ol-ExposedSettings'
) as ExposedSettings
if (!hasAffiliationsFeature) {
return null
}
return (
<>
<UserEmailsProvider>
<EmailsSectionContent />
</UserEmailsProvider>
<hr />
</>
)
}
export default EmailsSection