chore: profile setting improvement (#3306)

This commit is contained in:
Anmol Singh Bhatia 2024-01-03 18:25:41 +05:30 committed by GitHub
parent b58d7a715a
commit b522de99ba
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -62,16 +62,6 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
}, [myProfile, reset]); }, [myProfile, reset]);
const onSubmit = async (formData: IUser) => { const onSubmit = async (formData: IUser) => {
if (formData.first_name === "" || formData.last_name === "") {
setToastAlert({
type: "error",
title: "Error!",
message: "First and last names are required.",
});
return;
}
const payload: Partial<IUser> = { const payload: Partial<IUser> = {
first_name: formData.first_name, first_name: formData.first_name,
last_name: formData.last_name, last_name: formData.last_name,
@ -160,7 +150,7 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
)} )}
/> />
<DeactivateAccountModal isOpen={deactivateAccountModal} onClose={() => setDeactivateAccountModal(false)} /> <DeactivateAccountModal isOpen={deactivateAccountModal} onClose={() => setDeactivateAccountModal(false)} />
<div className="mx-auto mt-16 flex h-full w-full flex-col space-y-10 overflow-y-auto px-8 pb-8 lg:w-3/5"> <div className="mx-auto flex h-full w-full flex-col space-y-10 overflow-y-auto pt-16 px-8 pb-8 lg:w-3/5">
<form onSubmit={handleSubmit(onSubmit)}> <form onSubmit={handleSubmit(onSubmit)}>
<div className="flex w-full flex-col gap-8"> <div className="flex w-full flex-col gap-8">
<div className="relative h-44 w-full"> <div className="relative h-44 w-full">
@ -218,19 +208,24 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
</div> </div>
{/* <Link href={`/profile/${myProfile.id}`}> {/* <Link href={`/profile/${myProfile.id}`}>
<span className="flex item-center gap-1 text-sm text-custom-primary-100 underline font-medium"> <span className="flex item-center gap-1 text-sm text-custom-primary-100 underline font-medium">
<ExternalLink className="h-4 w-4" /> <ExternalLink className="h-4 w-4" />
Activity Overview Activity Overview
</span> </span>
</Link> */} </Link> */}
</div> </div>
<div className="grid grid-cols-1 gap-6 px-8 lg:grid-cols-2 2xl:grid-cols-3"> <div className="grid grid-cols-1 gap-6 px-8 lg:grid-cols-2 2xl:grid-cols-3">
<div className="flex flex-col gap-1"> <div className="flex flex-col gap-1">
<h4 className="text-sm">First name</h4> <h4 className="text-sm">
First name <span className="text-red-500">*</span>
</h4>
<Controller <Controller
control={control} control={control}
name="first_name" name="first_name"
rules={{
required: "First name is required.",
}}
render={({ field: { value, onChange, ref } }) => ( render={({ field: { value, onChange, ref } }) => (
<Input <Input
id="first_name" id="first_name"
@ -241,10 +236,11 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
ref={ref} ref={ref}
hasError={Boolean(errors.first_name)} hasError={Boolean(errors.first_name)}
placeholder="Enter your first name" placeholder="Enter your first name"
className="w-full rounded-md" className={`w-full rounded-md ${errors.first_name ? "border-red-500" : ""}`}
/> />
)} )}
/> />
{errors.first_name && <span className="text-xs text-red-500">Please enter first name</span>}
</div> </div>
<div className="flex flex-col gap-1"> <div className="flex flex-col gap-1">
@ -270,10 +266,15 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
</div> </div>
<div className="flex flex-col gap-1"> <div className="flex flex-col gap-1">
<h4 className="text-sm">Email</h4> <h4 className="text-sm">
Email<span className="text-red-500">*</span>
</h4>
<Controller <Controller
control={control} control={control}
name="email" name="email"
rules={{
required: "Email is required.",
}}
render={({ field: { value, onChange, ref } }) => ( render={({ field: { value, onChange, ref } }) => (
<Input <Input
id="email" id="email"
@ -284,7 +285,7 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
ref={ref} ref={ref}
hasError={Boolean(errors.email)} hasError={Boolean(errors.email)}
placeholder="Enter your email" placeholder="Enter your email"
className="w-full rounded-md" className={`w-full rounded-md ${errors.email ? "border-red-500" : ""}`}
disabled disabled
/> />
)} )}
@ -292,17 +293,19 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
</div> </div>
<div className="flex flex-col gap-1"> <div className="flex flex-col gap-1">
<h4 className="text-sm">Role</h4> <h4 className="text-sm">
Role<span className="text-red-500">*</span>
</h4>
<Controller <Controller
name="role" name="role"
control={control} control={control}
rules={{ required: "This field is required" }} rules={{ required: "Role is required." }}
render={({ field: { value, onChange } }) => ( render={({ field: { value, onChange } }) => (
<CustomSelect <CustomSelect
value={value} value={value}
onChange={onChange} onChange={onChange}
label={value ? value.toString() : "Select your role"} label={value ? value.toString() : "Select your role"}
buttonClassName={errors.role ? "border-red-500 bg-red-500/10" : "border-none"} buttonClassName={errors.role ? "border-red-500" : "border-none"}
className="rounded-md border-[0.5px] !border-custom-border-200" className="rounded-md border-[0.5px] !border-custom-border-200"
width="w-full" width="w-full"
input input
@ -319,7 +322,9 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
</div> </div>
<div className="flex flex-col gap-1"> <div className="flex flex-col gap-1">
<h4 className="text-sm">Display name</h4> <h4 className="text-sm">
Display name<span className="text-red-500">*</span>
</h4>
<Controller <Controller
control={control} control={control}
name="display_name" name="display_name"
@ -349,19 +354,22 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
ref={ref} ref={ref}
hasError={Boolean(errors.display_name)} hasError={Boolean(errors.display_name)}
placeholder="Enter your display name" placeholder="Enter your display name"
className="w-full" className={`w-full ${errors.display_name ? "border-red-500" : ""}`}
/> />
)} )}
/> />
{errors.display_name && <span className="text-xs text-red-500">Please enter display name</span>}
</div> </div>
<div className="flex flex-col gap-1"> <div className="flex flex-col gap-1">
<h4 className="text-sm">Timezone</h4> <h4 className="text-sm">
Timezone<span className="text-red-500">*</span>
</h4>
<Controller <Controller
name="user_timezone" name="user_timezone"
control={control} control={control}
rules={{ required: "This field is required" }} rules={{ required: "Time zone is required" }}
render={({ field: { value, onChange } }) => ( render={({ field: { value, onChange } }) => (
<CustomSearchSelect <CustomSearchSelect
value={value} value={value}
@ -369,13 +377,13 @@ const ProfileSettingsPage: NextPageWithLayout = observer(() => {
options={timeZoneOptions} options={timeZoneOptions}
onChange={onChange} onChange={onChange}
optionsClassName="w-full" optionsClassName="w-full"
buttonClassName="border-none" buttonClassName={errors.user_timezone ? "border-red-500" : "border-none"}
className="rounded-md border-[0.5px] !border-custom-border-200" className="rounded-md border-[0.5px] !border-custom-border-200"
input input
/> />
)} )}
/> />
{errors.role && <span className="text-xs text-red-500">Please select a role</span>} {errors.role && <span className="text-xs text-red-500">Please select a time zone</span>}
</div> </div>
<div className="flex items-center justify-between py-2"> <div className="flex items-center justify-between py-2">