import {Fragment, useState} from 'react'; import styled from '@emotion/styled'; import {addErrorMessage} from 'sentry/actionCreators/indicator'; import type {RequestOptions} from 'sentry/api'; import AlertLink from 'sentry/components/alertLink'; import Tag from 'sentry/components/badge/tag'; import {Button} from 'sentry/components/button'; import ButtonBar from 'sentry/components/buttonBar'; import type {FormProps} from 'sentry/components/forms/form'; import Form from 'sentry/components/forms/form'; import JsonForm from 'sentry/components/forms/jsonForm'; import LoadingError from 'sentry/components/loadingError'; import LoadingIndicator from 'sentry/components/loadingIndicator'; import Panel from 'sentry/components/panels/panel'; import PanelBody from 'sentry/components/panels/panelBody'; import PanelHeader from 'sentry/components/panels/panelHeader'; import PanelItem from 'sentry/components/panels/panelItem'; import SentryDocumentTitle from 'sentry/components/sentryDocumentTitle'; import accountEmailsFields from 'sentry/data/forms/accountEmails'; import {IconDelete, IconStack} from 'sentry/icons'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import type {UserEmail} from 'sentry/types/user'; import type {ApiQueryKey} from 'sentry/utils/queryClient'; import {useApiQuery, useQueryClient} from 'sentry/utils/queryClient'; import useApi from 'sentry/utils/useApi'; import SettingsPageHeader from 'sentry/views/settings/components/settingsPageHeader'; const ENDPOINT = '/users/me/emails/'; function AccountEmails() { const queryClient = useQueryClient(); const handleSubmitSuccess: FormProps['onSubmitSuccess'] = (_change, model, id) => { queryClient.invalidateQueries({queryKey: makeEmailsEndpointKey()}); if (id === undefined) { return; } model.setValue(id, ''); }; return (
}> {t('Want to change how many emails you get? Use the notifications panel.')}
); } export default AccountEmails; function makeEmailsEndpointKey(): ApiQueryKey { return [ENDPOINT]; } export function EmailAddresses() { const api = useApi(); const [isUpdating, setIsUpdating] = useState(false); const { data: emails = [], isPending, isError, refetch, } = useApiQuery(makeEmailsEndpointKey(), {staleTime: 0, gcTime: 0}); if (isPending || isUpdating) { return ( {t('Email Addresses')} ); } if (isError) { return ; } function doApiCall(endpoint: string, requestParams: RequestOptions) { setIsUpdating(true); api .requestPromise(endpoint, requestParams) .catch(err => { if (err?.responseJSON?.email) { addErrorMessage(err.responseJSON.email); } }) .finally(() => { refetch(); setIsUpdating(false); }); } const handleSetPrimary = (email: string) => { doApiCall(ENDPOINT, { method: 'PUT', data: {email}, }); }; const handleRemove = (email: string) => { doApiCall(ENDPOINT, { method: 'DELETE', data: {email}, }); }; const handleVerify = (email: string) => { doApiCall(`${ENDPOINT}confirm/`, { method: 'POST', data: {email}, }); }; const primary = emails.find(({isPrimary}) => isPrimary); const secondary = emails.filter(({isPrimary}) => !isPrimary); return ( {t('Email Addresses')} {primary && ( )} {secondary.map(emailObj => ( ))} ); } type EmailRowProps = { email: string; onRemove: (email: string) => void; onVerify: (email: string) => void; hideRemove?: boolean; isPrimary?: boolean; isVerified?: boolean; onSetPrimary?: (email: string) => void; }; function EmailRow({ email, onRemove, onVerify, onSetPrimary, isVerified, isPrimary, hideRemove, }: EmailRowProps) { return ( {email} {!isVerified && {t('Unverified')}} {isPrimary && {t('Primary')}} {!isPrimary && isVerified && ( )} {!isVerified && ( )} {!hideRemove && !isPrimary && (