Skip to content

Commit

Permalink
add edit-profile
Browse files Browse the repository at this point in the history
  • Loading branch information
od41 committed Nov 18, 2023
1 parent d02425d commit 58927ec
Show file tree
Hide file tree
Showing 3 changed files with 201 additions and 2 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,195 @@
"use client"
import React from 'react'
import * as z from "zod"
import { zodResolver } from "@hookform/resolvers/zod"
import { useForm } from "react-hook-form"

import { Button } from "@/components/ui/button"
import {
Form,
FormControl,
FormField,
FormItem,
FormLabel,
FormMessage,
} from "@/components/ui/form"
import { Input } from "@/components/ui/input"
import { useToast } from "@/components/ui/use-toast"
import RichTextEditor from '@/components/ui/rich-text-editor'
import Image from 'next/image'
import { Textarea } from '@/components/ui/textarea'
import { Plus } from 'lucide-react'

const formSchema = z.object({
displayName: z.string().min(1, {
message: "Title can't be empty",
}),
username: z.string().min(4, {
message: "That username is too short. Use atleast 4 characters"
}),
email: z.string().email({
message: "Please enter a valid email address"
}),
about: z.string(),
profilePicture: z.string().refine((value) => isValidFileType(value), {
message: 'Invalid file type. Only images e.g JPG, JPEG or PNG are allowed.',
}),

})

// Define a function to check if the file type is valid
const isValidFileType = (fileName: string): boolean => {
const validExtensions = ['.jpg', '.png']; // Add more valid extensions as needed
const fileExtension = fileName.substring(fileName.lastIndexOf('.')).toLowerCase();
return validExtensions.includes(fileExtension);
};

const EditProfileForm = () => {
const form = useForm<z.infer<typeof formSchema>>({
resolver: zodResolver(formSchema),
defaultValues: {
displayName: "Naval Ravikant",
username: "naval",
email: "[email protected]",
about: "Congue id arcu pellentesque mauris ac sed. Integer enim ac in porta sit.",
},
})
const { toast } = useToast()

const handleFileUpload = (file: File) => {
// Handle the uploaded file here
// You can perform validation, processing, etc.
console.log('Uploaded file:', file);
};

function onSubmit(values: z.infer<typeof formSchema>) {
console.log(values)
toast({
title: "Profile updated!",
variant: "success",
})
}

const profilePlaceholderImage = "";

return (
<div>
<Form {...form}>
<form onSubmit={form.handleSubmit(onSubmit)} className="space-y-8">

<FormField
control={form.control}
name="profilePicture"
render={({ field }) => (
<FormItem>
<FormControl className='mb-3'>
<>
<div className="w-20 h-20 rounded-full relative">
<Image
src="https://images.unsplash.com/photo-1639149888905-fb39731f2e6c?q=80&w=1528&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D"
fill
placeholder={profilePlaceholderImage}
className='object-cover rounded-full'
alt={`Preview your profile picture`}
/>
</div>

<Input placeholder="Your email" className='mb-4' type='file' {...field} />
<div className='mb-4'></div>
</>
</FormControl>
<FormLabel >Profile Picture</FormLabel>
<FormMessage />
</FormItem>
)}
/>

<FormField
control={form.control}
name="email"
render={({ field }) => (
<FormItem>
<FormLabel>Email</FormLabel>
<FormControl>
<Input placeholder="Your email" {...field} />
</FormControl>
<FormMessage />
</FormItem>
)}
/>

<FormField
control={form.control}
name="displayName"
render={({ field }) => (
<FormItem>
<FormLabel>Display Name</FormLabel>
<FormControl>
<Input placeholder="Your name" {...field} />
</FormControl>
<FormMessage className='text-xs text-muted font-normal' />
</FormItem>
)}
/>

<FormField
control={form.control}
name="username"
render={({ field }) => (
<FormItem>
<FormLabel>Username</FormLabel>
<FormControl>
<Input placeholder="Your username" {...field} />
</FormControl>
<FormMessage />
</FormItem>
)}
/>

<FormField
control={form.control}
name="about"
render={({ field }) => (
<FormItem>
<FormLabel>About</FormLabel>
<FormControl>
<Textarea placeholder="Say what you're about" {...field} />
</FormControl>
<FormMessage />
</FormItem>
)}
/>

<FormField
control={form.control}
name="about"
render={({ field }) => (
<FormItem>
<FormLabel>Tags</FormLabel>
<FormControl>
<div className='flex gap-3 flex-wrap w-full'>
{['blockchain', 'UX design','blockchain', 'UX design','blockchain', 'UX design'].map((tag, key) => (
<Button className='rounded-full text-sm ' size="sm" variant="outline">
{tag}
<Plus className='w-4 h-4 text-muted ml-2' />
</Button>)
)}
</div>

</FormControl>
<FormMessage />
</FormItem>
)}
/>

<div className="flex justify-end w-full">
<Button variant='outline' className='w-[160px] mr-3'>Cancel</Button>
<Button type="submit" variant='default' className='w-[160px] '>Update Profile</Button>
</div>
</form>
</Form>
</div>
)
}

export default EditProfileForm
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
import React from 'react'
import EditProfileForm from './_components/edit-profile-form'

const EditProfile = () => {
return (
<div>EditProfile</div>
<div>
<h4 className='text-xl text-foreground font-bold mb-5'>Edit Profile</h4>
<EditProfileForm />
</div>
)
}

Expand Down
2 changes: 1 addition & 1 deletion frontend/nextjs/src/components/ui/button.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ const buttonVariants = cva(
variants: {
variant: {
gradient: "bg-pink-gradient hover:bg-reverse-pink-gradient hover:text-white/80",
default: "bg-primary text-primary-foreground hover:bg-primary/90",
default: "bg-accent-2 text-primary-foreground hover:bg-accent-shade",
destructive:
"bg-destructive text-destructive-foreground hover:bg-destructive/90",
outline:
Expand Down

0 comments on commit 58927ec

Please sign in to comment.