import React, { useContext } from 'react'; import { useParams, useHistory } from 'react-router-dom'; import { Formik } from 'formik'; import _ from 'lodash'; import Page, { Action } from '../Page'; import hooks from '../../hooks/useAPIClient'; import { post, patch, del } from '../../requests'; import ServiceContext from './ServiceContext'; interface Params { id: string; } const ServiceForm: React.FC = () => { const service = useContext(ServiceContext); const history = useHistory(); const { id } = useParams(); const { data: item, mutate } = hooks[service.route].useItem(id); const handleDelete = () => del(`/${service.route}/${id}`) .then(() => history.push(`/${service.route}`)); const onSubmit = (values: any) => { const promise = id ? patch(`/${service.route}/${id}`, values) : post(`/${service.route}`, values); return promise.then(response => { mutate(response.data); history.push(`/${service.route}`); }); }; const actions: Action[] = [ { name: 'Назад', variant: 'outlined', route: '..' }, { name: 'Удалить', variant: 'outlined', onClick: handleDelete }, { name: 'Сохранить', type: 'submit', form: 'form' }, ]; return ( {(!id || item) && ( )} ); }; export default ServiceForm;