From 5e014457bfdb9e004a13300723f7a09c1139a1c0 Mon Sep 17 00:00:00 2001 From: Param Harrison Date: Tue, 21 Apr 2020 09:52:28 +0300 Subject: [PATCH] feat: error handling in API --- src/api.js | 20 ++++++++++++++------ src/components/edit-contact.js | 22 ++++++++++++++++------ 2 files changed, 30 insertions(+), 12 deletions(-) diff --git a/src/api.js b/src/api.js index ff850f5..5a89829 100644 --- a/src/api.js +++ b/src/api.js @@ -25,12 +25,20 @@ export const postContacts = async (payload) => { }; export const putContacts = async ({ id, ...payload }) => { - const response = await fetch(`${BASE_URL}/contacts/${id}`, { - method: "PUT", - ...requestPayload(payload), - }); - const data = await response.json(); - return data; + try { + const response = await fetch(`${BASE_URL}/contacts/${id}`, { + method: "PUT", + ...requestPayload(payload), + }); + if (response.ok) { + const data = await response.json(); + return { data }; + } else { + throw Error(response.statusText); + } + } catch (error) { + return { error }; + } }; export const deleteContacts = async (id) => { diff --git a/src/components/edit-contact.js b/src/components/edit-contact.js index bcc2236..82ef6ca 100644 --- a/src/components/edit-contact.js +++ b/src/components/edit-contact.js @@ -1,4 +1,4 @@ -import React from "react"; +import React, { useState } from "react"; import { useHistory } from "react-router-dom"; import ContactForm from "./contact-form"; import { useGlobalStore } from "./global-state"; @@ -8,17 +8,27 @@ const EditContact = (props) => { const id = props.match.params.id; const history = useHistory(); const { editContact } = useGlobalStore(); + const [error, setError] = useState(""); const onSubmit = (submitData) => { - const payload = { id, ...submitData }; + const payload = { ...submitData }; (async () => { - const data = await putContacts(payload); - editContact(data); - history.push("/"); + const { data, error } = await putContacts(payload); + if (error) { + setError(error.message); + } else { + editContact(data); + history.push("/"); + } })(); }; - return ; + return ( + <> + {error ?
{error}
: null} + + + ); }; export default EditContact;