import clsx from 'clsx'; import React from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { patchMe } from 'soapbox/actions/me'; import StillImage from 'soapbox/components/still-image'; import { Avatar, Button, Card, CardBody, Icon, Spinner, Stack, Text } from 'soapbox/components/ui'; import { useAppDispatch, useOwnAccount } from 'soapbox/hooks'; import toast from 'soapbox/toast'; import { isDefaultHeader } from 'soapbox/utils/accounts'; import resizeImage from 'soapbox/utils/resize-image'; import type { AxiosError } from 'axios'; const messages = defineMessages({ header: { id: 'account.header.alt', defaultMessage: 'Profile header' }, error: { id: 'onboarding.error', defaultMessage: 'An unexpected error occurred. Please try again or skip this step.' }, }); const CoverPhotoSelectionStep = ({ onNext }: { onNext: () => void }) => { const intl = useIntl(); const dispatch = useAppDispatch(); const { account } = useOwnAccount(); const fileInput = React.useRef(null); const [selectedFile, setSelectedFile] = React.useState(); const [isSubmitting, setSubmitting] = React.useState(false); const [isDisabled, setDisabled] = React.useState(true); const isDefault = account ? isDefaultHeader(account.header) : false; const openFilePicker = () => { fileInput.current?.click(); }; const handleFileChange = (event: React.ChangeEvent) => { const maxPixels = 1920 * 1080; const rawFile = event.target.files?.item(0); if (!rawFile) return; resizeImage(rawFile, maxPixels).then((file) => { const url = file ? URL.createObjectURL(file) : account?.header as string; setSelectedFile(url); setSubmitting(true); const formData = new FormData(); formData.append('header', file); const credentials = dispatch(patchMe(formData)); Promise.all([credentials]).then(() => { setDisabled(false); setSubmitting(false); onNext(); }).catch((error: AxiosError) => { setSubmitting(false); setDisabled(false); setSelectedFile(null); if (error.response?.status === 422) { toast.error((error.response.data as any).error.replace('Validation failed: ', '')); } else { toast.error(messages.error); } }); }).catch(console.error); }; return (
{selectedFile || account?.header && ( )} {isSubmitting && (
)}
{account && ( )} {account?.display_name} @{account?.username}
{isDisabled && ( )}
); }; export default CoverPhotoSelectionStep;