// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React, { useState } from 'react'; import { Modal } from './Modal'; import { ConfirmationDialog } from './ConfirmationDialog'; import type { PropsType as ProfileEditorPropsType } from './ProfileEditor'; import { ProfileEditor, EditState } from './ProfileEditor'; import type { ProfileDataType } from '../state/ducks/conversations'; import type { AvatarUpdateType } from '../types/Avatar'; export type PropsDataType = { hasError: boolean; } & Pick; type PropsType = { myProfileChanged: ( profileData: ProfileDataType, avatar: AvatarUpdateType ) => unknown; toggleProfileEditor: () => unknown; toggleProfileEditorHasError: () => unknown; } & PropsDataType & Omit; export function ProfileEditorModal({ hasError, i18n, myProfileChanged, onSetSkinTone, toggleProfileEditor, toggleProfileEditorHasError, ...restProps }: PropsType): JSX.Element { const MODAL_TITLES_BY_EDIT_STATE: Record = { [EditState.BetterAvatar]: i18n('icu:ProfileEditorModal--avatar'), [EditState.Bio]: i18n('icu:ProfileEditorModal--about'), [EditState.None]: i18n('icu:ProfileEditorModal--profile'), [EditState.ProfileName]: i18n('icu:ProfileEditorModal--name'), [EditState.UsernameOnboarding]: undefined, [EditState.Username]: i18n('icu:ProfileEditorModal--username'), [EditState.UsernameLink]: undefined, }; const [modalTitle, setModalTitle] = useState( MODAL_TITLES_BY_EDIT_STATE[EditState.None] ); if (hasError) { return ( {i18n('icu:ProfileEditorModal--error')} ); } return ( { setModalTitle(MODAL_TITLES_BY_EDIT_STATE[editState]); }} onProfileChanged={myProfileChanged} onSetSkinTone={onSetSkinTone} /> ); }