import { Dispatch, SetStateAction, useEffect, useState } from "react"; import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; import { faClose } from "@fortawesome/free-solid-svg-icons"; import useAccountStore from "@/store/account"; import { AccountSettings } from "@/types/global"; import { signOut, useSession } from "next-auth/react"; import { resizeImage } from "@/lib/client/resizeImage"; import { faPenToSquare } from "@fortawesome/free-regular-svg-icons"; import SubmitButton from "../../SubmitButton"; import ProfilePhoto from "../../ProfilePhoto"; import { toast } from "react-hot-toast"; import TextInput from "@/components/TextInput"; type Props = { toggleSettingsModal: Function; setUser: Dispatch>; user: AccountSettings; }; const emailEnabled = process.env.NEXT_PUBLIC_EMAIL_PROVIDER; export default function ProfileSettings({ toggleSettingsModal, setUser, user, }: Props) { const { update, data } = useSession(); const { account, updateAccount } = useAccountStore(); const [profileStatus, setProfileStatus] = useState(true); const [submitLoader, setSubmitLoader] = useState(false); const handleProfileStatus = (e: boolean) => { setProfileStatus(!e); }; const handleImageUpload = async (e: any) => { const file: File = e.target.files[0]; const fileExtension = file.name.split(".").pop()?.toLowerCase(); const allowedExtensions = ["png", "jpeg", "jpg"]; if (allowedExtensions.includes(fileExtension as string)) { const resizedFile = await resizeImage(file); if ( resizedFile.size < 1048576 // 1048576 Bytes == 1MB ) { const reader = new FileReader(); reader.onload = () => { setUser({ ...user, profilePic: reader.result as string }); }; reader.readAsDataURL(resizedFile); } else { toast.error("Please select a PNG or JPEG file thats less than 1MB."); } } else { toast.error("Invalid file format."); } }; useEffect(() => { setUser({ ...user, newPassword: undefined }); }, []); const submit = async () => { setSubmitLoader(true); const load = toast.loading("Applying..."); const response = await updateAccount({ ...user, }); toast.dismiss(load); if (response.ok) { toast.success("Settings Applied!"); if (user.email !== account.email) { update({ id: data?.user.id, }); signOut(); } else if ( user.username !== account.username || user.name !== account.name ) update({ id: data?.user.id, }); setUser({ ...user, newPassword: undefined }); toggleSettingsModal(); } else toast.error(response.data as string); setSubmitLoader(false); }; return (

Profile Photo

{profileStatus && (
setUser({ ...user, profilePic: "", }) } className="absolute top-1 left-1 w-5 h-5 flex items-center justify-center border p-1 bg-white border-slate-200 rounded-full text-gray-500 hover:text-red-500 duration-100 cursor-pointer" >
)}

Display Name

setUser({ ...user, name: e.target.value })} />

Username

setUser({ ...user, username: e.target.value })} />
{emailEnabled ? (

Email

setUser({ ...user, email: e.target.value })} />
) : undefined} {user.email !== account.email ? (

You will need to log back in after you apply this Email.

) : undefined}
); }