import Input from '@components/forms/Input' import Label from '@components/forms/Label' import Button, { IconButton } from '@components/shared/Button' import InlineNotification from '@components/shared/InlineNotification' import Loading from '@components/shared/Loading' import { ExclamationCircleIcon, PencilIcon, PlusIcon, } from '@heroicons/react/20/solid' import { bs58 } from '@project-serum/anchor/dist/cjs/utils/bytes' import { useWallet } from '@solana/wallet-adapter-react' import startCase from 'lodash/startCase' import { useTranslation } from 'next-i18next' import { ChangeEvent, useState } from 'react' import { MANGO_DATA_API_URL } from 'utils/constants' import { notify } from 'utils/notifications' import ProfileImage from './ProfileImage' import useProfileDetails from 'hooks/useProfileDetails' const EditProfileForm = ({ onFinish, onEditProfileImage, onboarding = false, }: { onFinish: () => void onEditProfileImage: () => void onboarding?: boolean }) => { const { t } = useTranslation(['profile', 'onboarding']) const { data: profile, refetch: refetchProfileDetails } = useProfileDetails() const { publicKey, signMessage } = useWallet() const [profileName, setProfileName] = useState( startCase(profile?.profile_name) || '', ) const [inputError, setInputError] = useState('') const [loadUniquenessCheck, setLoadUniquenessCheck] = useState(false) const [loadUpdateProfile, setLoadUpdateProfile] = useState(false) const [updateError, setUpdateError] = useState('') const validateProfileNameUniqueness = async (name: string) => { try { setLoadUniquenessCheck(true) const response = await fetch( `${MANGO_DATA_API_URL}/user-data/check-profile-name-unique?profile-name=${name}`, ) const uniquenessCheck = await response.json() if (uniquenessCheck) { return true } else { setInputError(t('profile:uniqueness-fail')) return false } } catch { setInputError(t('profile:uniqueness-api-fail')) return false } finally { setLoadUniquenessCheck(false) } } const onChangeNameInput = (name: string) => { setProfileName(name) const re = /^[a-zA-Z0-9 ]*$/gm if (!re.test(name)) { setInputError(t('profile:invalid-characters')) } else { setInputError('') } } const saveProfile = async () => { setUpdateError('') const name = profileName.trim().toLowerCase() if (profile?.profile_name === name) { onFinish() return } const isUnique = await validateProfileNameUniqueness(name) if (!inputError && isUnique) { setLoadUpdateProfile(true) try { if (!publicKey) throw new Error('Wallet not connected!') if (!signMessage) throw new Error('Wallet does not support message signing!') const messageString = JSON.stringify({ profile_name: name, trader_category: profile?.trader_category, profile_image_url: profile?.profile_image_url || '', }) const message = new TextEncoder().encode(messageString) const signature = await signMessage(message) const requestOptions = { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ wallet_pk: publicKey.toString(), message: messageString, signature: bs58.encode(signature), }), } const response = await fetch( `${MANGO_DATA_API_URL}/user-data/profile-details`, requestOptions, ) if (response.status === 200) { setLoadUpdateProfile(false) await refetchProfileDetails() onFinish() notify({ type: 'success', title: t('profile:profile-update-success'), }) } } catch { setLoadUpdateProfile(false) setUpdateError(t('profile:profile-update-fail')) } } } return ( <> {updateError ? (
{inputError}