2022-11-09 23:11:36 -08:00
|
|
|
"use client"
|
|
|
|
|
2022-11-17 23:39:52 -08:00
|
|
|
import Button from "@components/button"
|
|
|
|
import Input from "@components/input"
|
|
|
|
import Note from "@components/note"
|
2022-11-28 18:36:11 -08:00
|
|
|
import { useToasts } from "@components/toasts"
|
2022-11-14 18:39:42 -08:00
|
|
|
import { User } from "next-auth"
|
2022-11-17 22:36:53 -08:00
|
|
|
import { useState } from "react"
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-11-11 19:17:44 -08:00
|
|
|
const Profile = ({ user }: { user: User }) => {
|
2022-11-14 17:26:37 -08:00
|
|
|
// TODO: make this displayName, requires fetching user from DB as session doesnt have it
|
2022-11-11 23:59:33 -08:00
|
|
|
const [name, setName] = useState<string>(user.name || "")
|
2022-04-21 22:01:59 -07:00
|
|
|
const [bio, setBio] = useState<string>()
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-04-21 22:01:59 -07:00
|
|
|
const { setToast } = useToasts()
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-04-21 22:01:59 -07:00
|
|
|
const handleNameChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
|
|
setName(e.target.value)
|
|
|
|
}
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-04-21 22:01:59 -07:00
|
|
|
const handleBioChange = (e: React.ChangeEvent<HTMLTextAreaElement>) => {
|
|
|
|
setBio(e.target.value)
|
|
|
|
}
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-04-21 22:01:59 -07:00
|
|
|
const onSubmit = async (e: React.FormEvent<HTMLFormElement>) => {
|
|
|
|
e.preventDefault()
|
2022-11-13 23:02:31 -08:00
|
|
|
if (!name && !bio) {
|
2022-04-21 22:01:59 -07:00
|
|
|
setToast({
|
2022-11-28 18:36:11 -08:00
|
|
|
message: "Please fill out at least one field",
|
2022-04-21 22:01:59 -07:00
|
|
|
type: "error"
|
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-04-21 22:01:59 -07:00
|
|
|
const data = {
|
|
|
|
displayName: name,
|
|
|
|
bio
|
|
|
|
}
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-11-14 01:28:40 -08:00
|
|
|
const res = await fetch(`/api/user/${user.id}`, {
|
2022-04-21 22:01:59 -07:00
|
|
|
method: "PUT",
|
|
|
|
headers: {
|
2022-11-17 22:36:53 -08:00
|
|
|
"Content-Type": "application/json"
|
2022-04-21 22:01:59 -07:00
|
|
|
},
|
|
|
|
body: JSON.stringify(data)
|
|
|
|
})
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-04-21 22:01:59 -07:00
|
|
|
if (res.status === 200) {
|
|
|
|
setToast({
|
2022-11-28 18:36:11 -08:00
|
|
|
message: "Profile updated",
|
2022-04-21 22:01:59 -07:00
|
|
|
type: "success"
|
|
|
|
})
|
|
|
|
} else {
|
|
|
|
setToast({
|
2022-11-28 18:36:11 -08:00
|
|
|
message: "Something went wrong updating your profile",
|
2022-04-21 22:01:59 -07:00
|
|
|
type: "error"
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2022-04-19 22:14:08 -07:00
|
|
|
|
2022-04-21 22:01:59 -07:00
|
|
|
return (
|
|
|
|
<>
|
2022-11-17 23:39:52 -08:00
|
|
|
<Note type="warning">
|
2022-04-21 22:01:59 -07:00
|
|
|
This information will be publicly available on your profile
|
|
|
|
</Note>
|
|
|
|
<form
|
|
|
|
style={{
|
|
|
|
display: "flex",
|
|
|
|
flexDirection: "column",
|
|
|
|
gap: "var(--gap)",
|
|
|
|
maxWidth: "300px"
|
|
|
|
}}
|
|
|
|
onSubmit={onSubmit}
|
|
|
|
>
|
|
|
|
<div>
|
|
|
|
<label htmlFor="displayName">Display name</label>
|
|
|
|
<Input
|
|
|
|
id="displayName"
|
|
|
|
width={"100%"}
|
|
|
|
placeholder="my name"
|
|
|
|
value={name || ""}
|
|
|
|
onChange={handleNameChange}
|
2022-11-28 18:36:11 -08:00
|
|
|
aria-label="Display name"
|
2022-04-21 22:01:59 -07:00
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<label htmlFor="email">Email</label>
|
|
|
|
<Input
|
|
|
|
id="email"
|
2022-11-17 23:39:52 -08:00
|
|
|
type="email"
|
2022-04-21 22:01:59 -07:00
|
|
|
width={"100%"}
|
|
|
|
placeholder="my@email.io"
|
2022-11-13 23:02:31 -08:00
|
|
|
value={user.email || undefined}
|
|
|
|
disabled
|
2022-11-28 18:36:11 -08:00
|
|
|
aria-label="Email"
|
2022-04-21 22:01:59 -07:00
|
|
|
/>
|
|
|
|
</div>
|
2022-11-28 18:33:06 -08:00
|
|
|
{/* <div>
|
2022-04-21 22:01:59 -07:00
|
|
|
<label htmlFor="bio">Biography (max 250 characters)</label>
|
2022-11-17 23:39:52 -08:00
|
|
|
<textarea
|
2022-04-21 22:01:59 -07:00
|
|
|
id="bio"
|
2022-11-17 23:39:52 -08:00
|
|
|
style={{ width: "100%" }}
|
2022-04-21 22:01:59 -07:00
|
|
|
maxLength={250}
|
|
|
|
placeholder="I enjoy..."
|
2022-11-17 23:39:52 -08:00
|
|
|
value={bio}
|
2022-04-21 22:01:59 -07:00
|
|
|
onChange={handleBioChange}
|
|
|
|
/>
|
2022-11-28 18:33:06 -08:00
|
|
|
</div> */}
|
|
|
|
<Button type="submit">
|
2022-04-21 22:01:59 -07:00
|
|
|
Submit
|
|
|
|
</Button>
|
|
|
|
</form>
|
|
|
|
</>
|
|
|
|
)
|
2022-04-19 22:14:08 -07:00
|
|
|
}
|
|
|
|
|
2022-04-21 22:01:59 -07:00
|
|
|
export default Profile
|