import { useState } from 'react'; import { Button, FormControl, FormErrorMessage, FormLabel, Modal, ModalBody, ModalCloseButton, ModalContent, ModalFooter, ModalHeader, ModalOverlay, NumberInput, NumberInputField, NumberInputStepper, NumberIncrementStepper, NumberDecrementStepper, } from "@chakra-ui/react" import { useMutation, useQueryClient } from "@tanstack/react-query" import { type SubmitHandler, useForm } from "react-hook-form" import { type ApiError, type AboutUsCreate, AboutUsService } from "../../client" import useCustomToast from "../../hooks/useCustomToast" import { handleError } from "../../utils" import { EditorState, convertToRaw } from 'draft-js'; import { Editor } from "react-draft-wysiwyg"; import draftToHtml from 'draftjs-to-html'; import "react-draft-wysiwyg/dist/react-draft-wysiwyg.css"; interface AddAboutUsProps { isOpen: boolean onClose: () => void } // type FileUploadProps = { // register: UseFormRegisterReturn // accept?: string // multiple?: boolean // children?: ReactNode // } // const FileUpload = (props: FileUploadProps) => { // const { register, accept, multiple, children } = props // const inputRef = useRef(null) // const { ref, ...rest } = register as { ref: (instance: HTMLInputElement | null) => void } // const handleClick = () => inputRef.current?.click() // return ( // // { // ref(e) // inputRef.current = e // }} // /> // <> // {children} // // // ) // } const AddAboutUs = ({ isOpen, onClose }: AddAboutUsProps) => { const queryClient = useQueryClient() const showToast = useCustomToast() const { register, handleSubmit, reset, formState: { errors, isSubmitting }, } = useForm({ mode: "onBlur", criteriaMode: "all", defaultValues: { index: 0, description: "", image: undefined, }, }) const [editorState, setEditorState] = useState(EditorState.createEmpty()); const [content, setContent] = useState(''); // const validateFiles = (value: File) => { // if (typeof value === 'string') return true; // const fsMb = value.size / (1024 * 1024) // const MAX_FILE_SIZE = 10 // if (fsMb > MAX_FILE_SIZE) { // return 'Max file size 10mb' // } // return true // } // type FormValues = { // file_: FileList // } const mutation = useMutation({ mutationFn: (data: AboutUsCreate) => AboutUsService.createAboutUs({ formData: data }), onSuccess: () => { showToast("Success!", "About Us created successfully.", "success") reset() setEditorState(EditorState.createEmpty()); onClose() }, onError: (err: ApiError) => { handleError(err, showToast) }, onSettled: () => { queryClient.invalidateQueries({ queryKey: ["aboutUs"] }) }, }) const onSubmit: SubmitHandler = (data) => { if (data.image instanceof FileList && data.image.length > 0) { data.image = data.image[0] } mutation.mutate(data) console.log(data) } return ( <> Add About Us { setEditorState(newState); setContent(draftToHtml(convertToRaw(newState.getCurrentContent()))); reset({ description: content, }); }} toolbar={{ options: ['inline', 'blockType', 'fontSize', 'list', 'textAlign', 'history', 'embedded', 'emoji', 'image'], inline: { inDropdown: true }, list: { inDropdown: true }, textAlign: { inDropdown: true }, link: { inDropdown: true }, history: { inDropdown: true }, }} /> Index {errors.index && ( {errors.index.message} )} {'Image Upload'} {errors.image && errors?.image.message} ) } export default AddAboutUs