import React, { useEffect, useRef } from 'react'; import Portal from "components/Portal/index"; import Modal from "components/Modal/index"; import { useFormik } from 'formik'; import { renameWorkspace } from 'providers/ReduxStore/slices/workspaces'; import * as Yup from 'yup'; import { useDispatch } from 'react-redux'; const EditWorkspace = ({onClose, workspace}) => { const dispatch = useDispatch(); const inputRef = useRef(); const formik = useFormik({ enableReinitialize: true, initialValues: { name: workspace.name }, validationSchema: Yup.object({ name: Yup.string() .min(1, 'must be atleast 1 characters') .max(30, 'must be 30 characters or less') .required('name is required') }), onSubmit: (values) => { dispatch(renameWorkspace({name: values.name, uid: workspace.uid})); onClose(); } }); useEffect(() => { if(inputRef && inputRef.current) { inputRef.current.focus(); } }, [inputRef]); const onSubmit = () => { formik.handleSubmit(); } return (
{formik.touched.name && formik.errors.name ? (
{formik.errors.name}
) : null}
); } export default EditWorkspace;