From 0ab836db760dd77a494a9a94da876c9931fc0458 Mon Sep 17 00:00:00 2001 From: akkshara Date: Sun, 6 Oct 2024 18:04:34 +0530 Subject: [PATCH 1/3] Products showcased --- client/src/Pages/ProductItem.jsx | 315 +++++++++++++++++++++++++++++++ 1 file changed, 315 insertions(+) create mode 100644 client/src/Pages/ProductItem.jsx diff --git a/client/src/Pages/ProductItem.jsx b/client/src/Pages/ProductItem.jsx new file mode 100644 index 00000000..6ac626fd --- /dev/null +++ b/client/src/Pages/ProductItem.jsx @@ -0,0 +1,315 @@ +// import React, { useState, useEffect } from "react"; +// import axios from "axios"; +// import Spinner from "./Spinner"; +// import { FaHeart, FaRegHeart } from "react-icons/fa"; +// import { Link } from "react-router-dom"; + +// const ProductItem = () => { +// const [products, setProducts] = useState([]); +// const [isLoading, setIsLoading] = useState(true); +// const [wishlist, setWishlist] = useState([]); + +// useEffect(() => { +// const fetchProducts = async () => { +// try { +// const response = await axios.get( +// "http://localhost:8080/api/product/admin/products" +// ); +// setProducts(response.data.products); +// setIsLoading(false); +// } catch (error) { +// console.error("Error fetching products", error); +// } +// }; + +// const fetchWishlist = async () => { +// try { +// const authToken = localStorage.getItem("token"); +// const response = await axios.get( +// "http://localhost:8080/api/wishlist/getwishlistdata", +// { +// headers: { +// "Content-Type": "application/json", +// "auth-token": authToken, +// }, +// withCredentials: true, +// } +// ); + +// // Extract product IDs from wishlist items +// const wishlistItems = response.data.wishlistItems; +// const wishlistProductIds = wishlistItems.map( +// (item) => item.product._id +// ); +// setWishlist(wishlistProductIds); +// } catch (error) { +// console.error("Error fetching wishlist", error); +// } +// }; + +// fetchProducts(); +// fetchWishlist(); +// }, []); + +// const toggleWishlist = async (product) => { +// try { +// const authToken = localStorage.getItem("token"); +// const productId = product._id; + +// if (wishlist.includes(productId)) { +// await axios.delete( +// `http://localhost:8080/api/wishlist/removefromwishlist/${productId}`, +// { +// headers: { +// "Content-Type": "application/json", +// "auth-token": authToken, +// }, +// withCredentials: true, +// } +// ); + +// setWishlist(wishlist.filter((id) => id !== productId)); +// } else { +// await axios.post( +// `http://localhost:8080/api/wishlist/addtowishlist/${productId}`, +// {}, +// { +// headers: { +// "Content-Type": "application/json", +// "auth-token": authToken, +// }, +// withCredentials: true, +// } +// ); + +// setWishlist([...wishlist, productId]); +// } +// } catch (error) { +// console.error("Error toggling wishlist", error); +// } +// }; + +// const renderBooks = (books) => { +// return books.map((book) => ( +//
+// +// {book.name} +//

+// {book.name} +//

+//

+// Author: {book.author} +//

+//

{book.description}

+//
+//

+// ₹{book.price} +//

+// +//
+//
+// )); +// }; + +// const categories = [...new Set(products.map((book) => book.category))]; + +// return ( +//
+// {isLoading ? ( +// // Display spinner while data is not loaded +// ) : ( +// categories.map((category) => ( +//
+//

+// {category} +//

+//
+// {renderBooks( +// products.filter((book) => book.category === category) +// )} +//
+//
+// )) +// )} +//
+// ); +// }; + +// export default ProductItem; + +import React, { useState } from "react"; + +const productData = [ + { + id: 1, + name: "The Enchanted Forest", + author: "Lila Woods", + description: + "A thrilling adventure through magical forests and forgotten kingdoms.", + price: 350, + image: + "https://images.unsplash.com/photo-1512820790803-83ca734da794?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&ixid=MnwzNjUyOXwwfDF8c2VhcmNofDJ8fGZhc2NpbmF0ZXxlbnwwfHx8fDE2NDE0ODQyMjA&ixlib=rb-1.2.1&q=80&w=400", + }, + { + id: 2, + name: "Journey to the Stars", + author: "Marcus Orion", + description: + "A space exploration tale that challenges the limits of human imagination.", + price: 450, + image: + "https://images.unsplash.com/photo-1534081333815-ae5019106622?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&ixid=MnwzNjUyOXwwfDF8c2VhcmNofDV8fGZ1dHVyaXN0aWMlMjBzcGFjZXxlbnwwfHx8fDE2NDE0ODQzNzQ&ixlib=rb-1.2.1&q=80&w=400", + }, + { + id: 3, + name: "Whispers of the Sea", + author: "Eva Maris", + description: + "An inspiring story about love, loss, and the mysteries of the ocean.", + price: 300, + image: + "https://images.unsplash.com/photo-1500674425229-f692875b0ab7?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&ixid=MnwzNjUyOXwwfDF8c2VhcmNofDN8fG9jZWFufGVufDB8fHx8MTY0MTQ4NDI4Nw&ixlib=rb-1.2.1&q=80&w=400", + }, + { + id: 4, + name: "The Last Kingdom", + author: "Henry Blackwell", + description: + "An epic tale of the rise and fall of a mighty kingdom in ancient times.", + price: 400, + image: + "", + }, + { + id: 5, + name: "A Tale of Two Worlds", + author: "Sophie Lennon", + description: + "A gripping story that bridges the gap between two parallel worlds.", + price: 380, + image: + "", + }, +]; + +// ProductShowcase component +const ProductItem = () => { + const [searchTerm, setSearchTerm] = useState(""); + + // Filter products based on the search term + const filteredProducts = productData.filter((product) => + product.name.toLowerCase().includes(searchTerm.toLowerCase()) + ); + + return ( + <> +
+ {/* Title */} +

+ CHECK OUT NEW COLLECTIONS +

+ + {/* Search Bar */} +
+ setSearchTerm(e.target.value)} + /> +
+ + {/* Product Grid */} +
+

FICTIONALS

+
+ {filteredProducts.map((product) => ( +
+ {product.name} +

{product.name}

+

{product.description}

+

₹{product.price}

+
+ ))} +
+
+
+ +
+

CHILDREN'S BOOK

+
+ {filteredProducts.map((product) => ( +
+ {product.name} +

{product.name}

+

{product.description}

+

₹{product.price}

+
+ ))} +
+
+ +
+

NON-FICTION

+
+ {filteredProducts.map((product) => ( +
+ {product.name} +

{product.name}

+

{product.description}

+

₹{product.price}

+
+ ))} +
+
+ + ); +}; + +export default ProductItem; From 19932ee8ac094f7641eadc2be4ae5b5feead23f6 Mon Sep 17 00:00:00 2001 From: akkshara Date: Sun, 6 Oct 2024 18:07:26 +0530 Subject: [PATCH 2/3] Products showcased --- client/src/Pages/Cart.jsx | 428 +++++++++++++++---------------- client/src/Pages/ProductItem.js | 121 --------- client/src/Pages/ProductItem.jsx | 10 + client/src/Pages/Shop.jsx | 16 +- 4 files changed, 231 insertions(+), 344 deletions(-) delete mode 100644 client/src/Pages/ProductItem.js diff --git a/client/src/Pages/Cart.jsx b/client/src/Pages/Cart.jsx index 565f3449..fa214712 100644 --- a/client/src/Pages/Cart.jsx +++ b/client/src/Pages/Cart.jsx @@ -1,215 +1,213 @@ -import React, { useState, useEffect } from "react"; -import Spinner from "./Spinner"; -import { fetchCartData, addItemToCart, removeItemFromCart } from "../api/api.js"; -import "./Cart.css"; -import Preloader from '../Components/Preloader'; - -import { useAuth } from "../Context/AuthContext"; -import { useToast } from "../Context/ToastContext"; - -import { useNavigate } from "react-router-dom"; - - -function Cart() { - const [isLoading, setIsLoading] = useState(true); - const [data, setData] = useState(null); - const [error, setError] = useState(null); - const [retryCount, setRetryCount] = useState(0); - const navigate = useNavigate(); - const isAuthenticated =!! localStorage.getItem('token'); - if(!isAuthenticated){ - navigate('/login') - - } - - const { userLoggedIn } = useAuth(); - const { showToast } = useToast(); - const navigate = useNavigate(); - - - useEffect(() => { - fetchCartData() - .then((cartData) => { - setData(cartData); - setIsLoading(false); - setError(null); // Reset error state on successful data fetch - }) - .catch((err) => { - setError("Failed to load cart data. Please try again later."); - setIsLoading(false); - console.error("Error fetching cart data:", err); - }); - }, [retryCount]); // Retry whenever retryCount changes - - useEffect(() => { - if (!userLoggedIn) { - showToast("error", "Please login to view your cart.", undefined, 7000); - setTimeout(() => { - navigate("/login"); - }, 3000); // 3000 milliseconds = 3 seconds - } - }, [userLoggedIn]); - - const handleAddItem = (item) => { - setIsLoading(true); - addItemToCart(item) - .then((updatedCart) => { - setData(updatedCart); - setIsLoading(false); - }) - .catch((err) => { - setError("Failed to add item to cart. Please try again later."); - setIsLoading(false); - console.error("Error adding item to cart:", err); - }); - }; - - const handleRemoveItem = (itemId) => { - setIsLoading(true); - removeItemFromCart(itemId) - .then((updatedCart) => { - setData(updatedCart); - setIsLoading(false); - }) - .catch((err) => { - setError("Failed to remove item from cart. Please try again later."); - setIsLoading(false); - console.error("Error removing item from cart:", err); - }); - }; - - const handleRetry = () => { - setRetryCount(retryCount + 1); // Trigger useEffect to retry fetching data - }; - - const renderCartItems = () => { - if (!data || !data.items || data.items.length === 0) { - return ( - - Your cart is empty. - - ); - } - - return data.items.map((item) => ( - - - {item.name} - - {item.name} - ${item.price.toFixed(2)} - - - {item.quantity} - - - - - - - )); - }; - - const renderSuggestedProducts = () => { - // Replace with actual suggested products logic - return ( -
-

Suggested Products

-
    -
  • Suggested Product 1
  • -
  • Suggested Product 2
  • -
  • Suggested Product 3
  • -
-
- ); - }; - - if (isLoading) { - return ; - } - - if (error) { - return ( - <> - -
-

Shopping Cart

-

{error}

- - {/*
*/} - - - - - - - - - - - - {renderCartItems()} - -
ImageNamePriceQuantityAction
-
-
Total: ${data ? data.total.toFixed(2) : "0.00"}
- -
-
- {renderSuggestedProducts()} -
- - ); - } - - return ( - <> -
-

Shopping Cart

- - - - - - - - - - - - {renderCartItems()} - -
ImageNamePriceQuantityAction
-
-
Total: ${data ? data.total.toFixed(2) : "0.00"}
- -
- {/*
*/} - {renderSuggestedProducts()} -
- - ); -} - -export default Cart; +// import React, { useState, useEffect } from "react"; +// import Spinner from "./Spinner"; +// import { fetchCartData, addItemToCart, removeItemFromCart } from "../api/api.js"; +// import "./Cart.css"; +// import Preloader from '../Components/Preloader'; + +// import { useAuth } from "../Context/AuthContext"; +// import { useToast } from "../Context/ToastContext"; + +// import { useNavigate } from "react-router-dom"; + +// function Cart() { +// const [isLoading, setIsLoading] = useState(true); +// const [data, setData] = useState(null); +// const [error, setError] = useState(null); +// const [retryCount, setRetryCount] = useState(0); +// const navigate = useNavigate(); +// const isAuthenticated =!! localStorage.getItem('token'); +// if(!isAuthenticated){ +// navigate('/login') + +// } + +// const { userLoggedIn } = useAuth(); +// const { showToast } = useToast(); +// const navigate = useNavigate(); + +// useEffect(() => { +// fetchCartData() +// .then((cartData) => { +// setData(cartData); +// setIsLoading(false); +// setError(null); // Reset error state on successful data fetch +// }) +// .catch((err) => { +// setError("Failed to load cart data. Please try again later."); +// setIsLoading(false); +// console.error("Error fetching cart data:", err); +// }); +// }, [retryCount]); // Retry whenever retryCount changes + +// useEffect(() => { +// if (!userLoggedIn) { +// showToast("error", "Please login to view your cart.", undefined, 7000); +// setTimeout(() => { +// navigate("/login"); +// }, 3000); // 3000 milliseconds = 3 seconds +// } +// }, [userLoggedIn]); + +// const handleAddItem = (item) => { +// setIsLoading(true); +// addItemToCart(item) +// .then((updatedCart) => { +// setData(updatedCart); +// setIsLoading(false); +// }) +// .catch((err) => { +// setError("Failed to add item to cart. Please try again later."); +// setIsLoading(false); +// console.error("Error adding item to cart:", err); +// }); +// }; + +// const handleRemoveItem = (itemId) => { +// setIsLoading(true); +// removeItemFromCart(itemId) +// .then((updatedCart) => { +// setData(updatedCart); +// setIsLoading(false); +// }) +// .catch((err) => { +// setError("Failed to remove item from cart. Please try again later."); +// setIsLoading(false); +// console.error("Error removing item from cart:", err); +// }); +// }; + +// const handleRetry = () => { +// setRetryCount(retryCount + 1); // Trigger useEffect to retry fetching data +// }; + +// const renderCartItems = () => { +// if (!data || !data.items || data.items.length === 0) { +// return ( +// +// Your cart is empty. +// +// ); +// } + +// return data.items.map((item) => ( +// +// +// {item.name} +// +// {item.name} +// ${item.price.toFixed(2)} +// +// +// {item.quantity} +// +// +// +// +// +// +// )); +// }; + +// const renderSuggestedProducts = () => { +// // Replace with actual suggested products logic +// return ( +//
+//

Suggested Products

+//
    +//
  • Suggested Product 1
  • +//
  • Suggested Product 2
  • +//
  • Suggested Product 3
  • +//
+//
+// ); +// }; + +// if (isLoading) { +// return ; +// } + +// if (error) { +// return ( +// <> +// +//
+//

Shopping Cart

+//

{error}

+// +// {/*
*/} +// +// +// +// +// +// +// +// +// +// +// +// {renderCartItems()} +// +//
ImageNamePriceQuantityAction
+//
+//
Total: ${data ? data.total.toFixed(2) : "0.00"}
+// +//
+//
+// {renderSuggestedProducts()} +//
+// +// ); +// } + +// return ( +// <> +//
+//

Shopping Cart

+// +// +// +// +// +// +// +// +// +// +// +// {renderCartItems()} +// +//
ImageNamePriceQuantityAction
+//
+//
Total: ${data ? data.total.toFixed(2) : "0.00"}
+// +//
+// {/*
*/} +// {renderSuggestedProducts()} +//
+// +// ); +// } + +// export default Cart; diff --git a/client/src/Pages/ProductItem.js b/client/src/Pages/ProductItem.js deleted file mode 100644 index 9310dd9f..00000000 --- a/client/src/Pages/ProductItem.js +++ /dev/null @@ -1,121 +0,0 @@ -import React, { useState, useEffect } from 'react'; -import axios from 'axios'; -import Spinner from './Spinner'; -import { FaHeart, FaRegHeart } from 'react-icons/fa'; -import { Link } from 'react-router-dom'; - -const ProductItem = () => { - const [products, setProducts] = useState([]); - const [isLoading, setIsLoading] = useState(true); - const [wishlist, setWishlist] = useState([]); - - useEffect(() => { - const fetchProducts = async () => { - try { - const response = await axios.get('http://localhost:8080/api/product/admin/products'); - setProducts(response.data.products); - setIsLoading(false); - } catch (error) { - console.error('Error fetching products', error); - } - }; - - const fetchWishlist = async () => { - try { - const authToken = localStorage.getItem('token'); - const response = await axios.get('http://localhost:8080/api/wishlist/getwishlistdata', { - headers: { - "Content-Type": "application/json", - "auth-token": authToken - }, - withCredentials: true - }); - - // Extract product IDs from wishlist items - const wishlistItems = response.data.wishlistItems; - const wishlistProductIds = wishlistItems.map(item => item.product._id); - setWishlist(wishlistProductIds); - } catch (error) { - console.error('Error fetching wishlist', error); - } - }; - - fetchProducts(); - fetchWishlist(); - }, []); - - const toggleWishlist = async (product) => { - try { - const authToken = localStorage.getItem('token'); - const productId = product._id; - - if (wishlist.includes(productId)) { - await axios.delete(`http://localhost:8080/api/wishlist/removefromwishlist/${productId}`, { - headers: { - "Content-Type": "application/json", - "auth-token": authToken - }, - withCredentials: true - }); - - setWishlist(wishlist.filter((id) => id !== productId)); - } else { - await axios.post(`http://localhost:8080/api/wishlist/addtowishlist/${productId}`, {}, { - headers: { - "Content-Type": "application/json", - "auth-token": authToken - }, - withCredentials: true - }); - - setWishlist([...wishlist, productId]); - } - } catch (error) { - console.error('Error toggling wishlist', error); - } - }; - - const renderBooks = (books) => { - return books.map((book) => ( -
- - {book.name} -

{book.name}

-

Author: {book.author}

-

{book.description}

-
-

₹{book.price}

- -
-
- )); - }; - - const categories = [...new Set(products.map((book) => book.category))]; - - return ( -
- {isLoading ? ( - // Display spinner while data is not loaded - ) : ( - categories.map((category) => ( -
-

{category}

-
- {renderBooks(products.filter((book) => book.category === category))} -
-
- )) - )} -
- ); -}; - -export default ProductItem; diff --git a/client/src/Pages/ProductItem.jsx b/client/src/Pages/ProductItem.jsx index 6ac626fd..17552a0f 100644 --- a/client/src/Pages/ProductItem.jsx +++ b/client/src/Pages/ProductItem.jsx @@ -214,6 +214,16 @@ const productData = [ image: "", }, + { + id: 6, + name: "Whispers of the Sea", + author: "Eva Maris", + description: + "An inspiring story about love, loss, and the mysteries of the ocean.", + price: 300, + image: + "https://images.unsplash.com/photo-1500674425229-f692875b0ab7?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&ixid=MnwzNjUyOXwwfDF8c2VhcmNofDN8fG9jZWFufGVufDB8fHx8MTY0MTQ4NDI4Nw&ixlib=rb-1.2.1&q=80&w=400", + }, ]; // ProductShowcase component diff --git a/client/src/Pages/Shop.jsx b/client/src/Pages/Shop.jsx index 1c6a7bf6..6d28e120 100644 --- a/client/src/Pages/Shop.jsx +++ b/client/src/Pages/Shop.jsx @@ -1,14 +1,14 @@ -import React from 'react' -import Productitem from './ProductItem' -import Preloader from '../Components/Preloader' +import React from "react"; +import Productitem from "./ProductItem"; +import Preloader from "../Components/Preloader"; const Shop = () => { return (
- - + {/* */} +
- ) -} + ); +}; -export default Shop +export default Shop; From fa3a7e6e5af0ec41dcc1cef74ffaa451745b4574 Mon Sep 17 00:00:00 2001 From: akkshara Date: Mon, 7 Oct 2024 22:15:52 +0530 Subject: [PATCH 3/3] reduced size --- client/src/Pages/ProductItem.jsx | 79 ++++++++++++++++---------------- 1 file changed, 39 insertions(+), 40 deletions(-) diff --git a/client/src/Pages/ProductItem.jsx b/client/src/Pages/ProductItem.jsx index 17552a0f..81664f64 100644 --- a/client/src/Pages/ProductItem.jsx +++ b/client/src/Pages/ProductItem.jsx @@ -266,7 +266,7 @@ const ProductItem = () => { {product.name}

{product.name}

{product.description}

@@ -275,51 +275,50 @@ const ProductItem = () => { ))} - -
-

CHILDREN'S BOOK

-
- {filteredProducts.map((product) => ( -
- {product.name} -

{product.name}

-

{product.description}

-

₹{product.price}

-
- ))} +
+

CHILDREN'S BOOK

+
+ {filteredProducts.map((product) => ( +
+ {product.name} +

{product.name}

+

{product.description}

+

₹{product.price}

+
+ ))} +
-
-
-

NON-FICTION

-
- {filteredProducts.map((product) => ( -
- {product.name} -

{product.name}

-

{product.description}

-

₹{product.price}

-
- ))} +
+

NON-FICTION

+
+ {filteredProducts.map((product) => ( +
+ {product.name} +

{product.name}

+

{product.description}

+

₹{product.price}

+
+ ))} +
); }; - export default ProductItem;