From 58927ece306fc42cad0d4779a102a6f9b6e62d41 Mon Sep 17 00:00:00 2001 From: Odafe Aror Date: Sat, 18 Nov 2023 18:53:05 +0000 Subject: [PATCH] add edit-profile --- .../edit/_components/edit-profile-form.tsx | 195 ++++++++++++++++++ .../app/dapp/profile/[username]/edit/page.tsx | 6 +- frontend/nextjs/src/components/ui/button.tsx | 2 +- 3 files changed, 201 insertions(+), 2 deletions(-) create mode 100644 frontend/nextjs/src/app/dapp/profile/[username]/edit/_components/edit-profile-form.tsx diff --git a/frontend/nextjs/src/app/dapp/profile/[username]/edit/_components/edit-profile-form.tsx b/frontend/nextjs/src/app/dapp/profile/[username]/edit/_components/edit-profile-form.tsx new file mode 100644 index 0000000..a980e2f --- /dev/null +++ b/frontend/nextjs/src/app/dapp/profile/[username]/edit/_components/edit-profile-form.tsx @@ -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>({ + resolver: zodResolver(formSchema), + defaultValues: { + displayName: "Naval Ravikant", + username: "naval", + email: "naval@ravikant.io", + 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) { + console.log(values) + toast({ + title: "Profile updated!", + variant: "success", + }) + } + + const profilePlaceholderImage = ""; + + return ( +
+
+ + + ( + + + <> +
+ {`Preview +
+ + +
+ +
+ Profile Picture + +
+ )} + /> + + ( + + Email + + + + + + )} + /> + + ( + + Display Name + + + + + + )} + /> + + ( + + Username + + + + + + )} + /> + + ( + + About + +