import React, { useRef, useEffect } from 'react'; import {useFormik} from 'formik'; import * as Yup from 'yup'; import Modal from 'components/Modal'; import actions from 'providers/Store/actions' import { useStore } from 'providers/Store'; const NewFolder = ({collectionUid, handleCancel, handleClose}) => { const [store, storeDispatch] = useStore(); const inputRef = useRef(); const formik = useFormik({ enableReinitialize: true, initialValues: { folderName: '' }, validationSchema: Yup.object({ folderName: Yup.string() .min(1, 'must be atleast 1 characters') .max(50, 'must be 50 characters or less') .required('name is required') }), onSubmit: (values) => { storeDispatch({ type: actions.SIDEBAR_COLLECTION_NEW_FOLDER, collectionUid: collectionUid, folderName: values.folderName }); handleClose(); } }); useEffect(() => { if(inputRef && inputRef.current) { inputRef.current.focus(); } }, [inputRef]); const onSubmit = () => formik.handleSubmit(); return (
{formik.touched.folderName && formik.errors.folderName ? (
{formik.errors.folderName}
) : null}
); }; export default NewFolder;