+
SUCCESS!
Everything went ok!, enjoy your product
diff --git a/src/components/Products/Product.jsx b/src/components/Products/Product.jsx
index 52ac3ed..5bacd40 100644
--- a/src/components/Products/Product.jsx
+++ b/src/components/Products/Product.jsx
@@ -1,4 +1,4 @@
-import React, { useContext, useEffect } from "react";
+import React, { useContext, useEffect, useState } from "react";
import { UserContext } from "../../providers/index";
import { coin, buy } from "../../assets/index";
import { SuccessModal, FailureModal } from "../Modals/index";
@@ -17,27 +17,36 @@ const Product = ({
}) => {
const user = useContext(UserContext);
- const { isShowing, toggle } = useModal();
-
useEffect(() => {
if (!user) return;
}, [user]);
+ const [error, setError] = useState(false);
+
+ const { isShowing, toggle } = useModal();
+
const { points } = user;
const canBuy = cost <= points;
- const openBuyModal = () => {
- redeemProduct(_id).then((res) => {
- // toggle();
- console.log(res);
- });
+ const showModal = () => {
+ redeemProduct(_id)
+ .then((res) => {
+ toggle();
+ })
+ .catch((err) => {
+ setError(true);
+ toggle();
+ });
};
return (
-
- {/*
*/}
+ {error ? (
+
+ ) : (
+
+ )}
@@ -53,7 +62,7 @@ const Product = ({
{cost}
data:image/s3,"s3://crabby-images/19139/1913961123cd457424253053168d8e58acd0739a" alt="coin"
-
+
>
diff --git a/src/services/productsService.jsx b/src/services/productsService.jsx
index 454f4ce..3ab7050 100644
--- a/src/services/productsService.jsx
+++ b/src/services/productsService.jsx
@@ -5,29 +5,28 @@ const headers = {
Authorization: `Bearer ${API.AUTH_TOKEN}`,
};
-export const getProducts = async () => {
- try {
- const response = await fetch(API.PRODUCTS, { headers });
- const json = await response.json();
- return json;
- } catch (error) {
- return alert(JSON.stringify(error));
- }
+export const getProducts = () => {
+ return fetch(API.PRODUCTS, { headers })
+ .then((response) => {
+ if (!response.ok) {
+ throw Error(response.statusText);
+ }
+ return response;
+ })
+ .then((response) => response.json());
};
-export const redeemProduct = async (id) => {
- try {
- console.log(id);
- const response = await fetch(API.REDEEEM, {
- headers,
- method: "POST",
- body: JSON.stringify({ productId: id }),
- });
- console.log("request", response);
- const json = await response.json();
- return json;
- } catch (error) {
- console.log("Error", error);
- return alert(JSON.stringify(error));
- }
+export const redeemProduct = (id) => {
+ return fetch(API.REDEEEM, {
+ headers,
+ method: "POST",
+ body: JSON.stringify({ productId: id }),
+ })
+ .then((response) => {
+ if (!response.ok) {
+ throw Error(response.statusText);
+ }
+ return response;
+ })
+ .then((response) => response.json());
};
diff --git a/src/services/userService.jsx b/src/services/userService.jsx
index 697a55a..6fb352d 100644
--- a/src/services/userService.jsx
+++ b/src/services/userService.jsx
@@ -6,25 +6,27 @@ const headers = {
};
export const getUser = async () => {
- try {
- const response = await fetch(API.USER, { headers });
- const json = await response.json();
- return json;
- } catch (error) {
- return alert(JSON.stringify(error));
- }
+ return fetch(API.USER, { headers })
+ .then((response) => {
+ if (!response.ok) {
+ throw Error(response.statusText);
+ }
+ return response;
+ })
+ .then((response) => response.json());
};
export const addPoints = async (coins) => {
- try {
- const response = await fetch(API.ADD_POINTS, {
- method: "POST",
- body: JSON.stringify({ amount: coins }),
- headers,
- });
- const json = await response.json();
- return json;
- } catch (error) {
- return alert(JSON.stringify(error));
- }
+ return fetch(API.ADD_POINTS, {
+ headers,
+ method: "POST",
+ body: JSON.stringify({ amount: coins }),
+ })
+ .then((response) => {
+ if (!response.ok) {
+ throw Error(response.statusText);
+ }
+ return response;
+ })
+ .then((response) => response.json());
};