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}
-
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
new file mode 100644
index 00000000..81664f64
--- /dev/null
+++ b/client/src/Pages/ProductItem.jsx
@@ -0,0 +1,324 @@
+// 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}
+//
+//
+// 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:
+ "",
+ },
+ {
+ 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
+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.description}
+
₹{product.price}
+
+ ))}
+
+
+
+
+
CHILDREN'S BOOK
+
+ {filteredProducts.map((product) => (
+
+
+
{product.name}
+
{product.description}
+
₹{product.price}
+
+ ))}
+
+
+
+
+
NON-FICTION
+
+ {filteredProducts.map((product) => (
+
+
+
{product.name}
+
{product.description}
+
₹{product.price}
+
+ ))}
+
+
+
+ >
+ );
+};
+export default ProductItem;
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;