Skip to content

Latest commit

 

History

History
299 lines (201 loc) · 7.13 KB

README.md

File metadata and controls

299 lines (201 loc) · 7.13 KB

E-Commerce Application

Project Overview

The E-Commerce Application is a scalable, high-performance platform for online shopping. It supports users, vendors, and administrators with distinct functionalities and a seamless shopping experience.

Repository Links:

Live Links:


Technology Stack & Packages

Dependencies

Below are the key dependencies used in this project:

Core Libraries:

  • react: ^18.3.1
  • react-dom: ^18.3.1
  • react-router-dom: ^6.26.1

State Management:

  • @reduxjs/toolkit: ^2.2.7
  • react-redux: ^9.1.2
  • redux-persist: ^6.0.0

Form Handling and Validation:

  • react-hook-form: ^7.53.2
  • @hookform/resolvers: ^3.9.1
  • zod: ^3.23.8

UI Libraries:

  • @mui/material: ^5.16.7
  • @mui/icons-material: ^5.16.7
  • react-icons: ^5.3.0
  • react-image-gallery: ^1.3.0
  • swiper: ^11.1.15

Styling:

  • tailwindcss: ^3.4.10
  • @emotion/react: ^11.13.3
  • @emotion/styled: ^11.13.0

Utilities:

  • lodash: ^4.17.21
  • lodash.debounce: ^4.0.8
  • jwt-decode: ^4.0.0
  • recharts: ^2.14.1
  • react-scroll: ^1.9.0
  • sonner: ^1.7.0

Dev Dependencies:

  • vite: ^5.4.1
  • typescript: ^5.5.3
  • eslint: ^9.9.0
  • tailwindcss: ^3.4.10
  • autoprefixer: ^10.4.20
  • @vitejs/plugin-react: ^4.3.1
  • typescript-eslint: ^8.0.1

Features & Functionalities

Admin Role:

  • Manage users (suspend/delete accounts)
  • Blacklist vendor shops
  • Dynamically manage product categories
  • Monitor transactions and platform activities

Vendor Role:

  • Create and manage their shop
  • Add/edit/delete products with attributes like name, price, category, inventory count, images, and discounts
  • View and respond to customer reviews
  • Manage order history

Customer Role:

  • Browse and filter products (e.g., by price, category)
  • Add products to the cart and apply coupon codes
  • Compare up to three products
  • View purchase history
  • Leave reviews and ratings for purchased products

Home Page

  • Display all available products from various vendors.
  • Prioritize products from followed shops for logged-in users.
  • Infinite scrolling for product listing.
  • Filtering and searching functionalities (price range, category, keyword, etc.).
  • Scroll-to-top button for better navigation.
  • Display a list of categories. When a category is clicked, redirect the user to the "All Products" page and automatically filter the products to show only those belonging to the selected category.
  • Show flash sale products and add a button at the bottom. After clicking the button, redirect to the flash sale page and display all flash sale products.

Product Details Page

  • Product name, price, category, images, and detailed descriptions.
  • Display the shop name with a clickable link redirecting to the shop page.
  • Related products section showing products in the same category.
  • Customer reviews and ratings for the product.

Shop Page

  • Vendor’s shop name and details.
  • List of products belonging to the vendor only.
  • Option for customers to add products directly to the cart from the shop page.
  • Option for users to follow or unfollow the shop.
  • Follower count.

Cart Functionality

  • Products can only be added from one vendor at a time.
  • If attempting to add products from another vendor, show a warning with options:
    • Replace the cart with the new product(s).
    • Retain the current cart and cancel the addition.
  • Display product details, pricing, and total cost in the cart.

Checkout

  • Apply coupon codes for discounts during checkout.
  • Integrate Aamarpay or Stripe for payment processing.

Order History

  • For Vendors: View a detailed list of all orders placed for their shop.
  • For Customers: View their purchase history with product and order details.

Authentication

  • Signup Page: Option to register as a user or vendor.
    • If a vendor is selected, redirect them to the dashboard to add their shop name and some initial products.
  • Login Page: Secure login using JWT.
  • Password Management:
    • Change password after logging in.
    • Reset password functionality via email.

Recent Products Page

  • Display the last 10 products viewed by the user.
  • Include product details, prices, and direct links to the product page.

Comparison Feature

  • Allow users to compare up to three products, but only if the products are from the same category.
  • Comparison will be based on attributes such as price, category, ratings, and other relevant details.
  • If a user attempts to add a product from a different category for comparison, display a warning message indicating that only products from the same category can be compared.

Responsive Design

  • Mobile and desktop-friendly interface for all users.

Frontend Setup Instructions

Prerequisites:

  • Node.js installed
  • Backend server running
  • Environment variables configured (e.g., .env file)

Installation:

  1. Clone the repository:

    git clone <repository-url>
  2. Navigate to the frontend directory:

    cd frontend
  3. Install dependencies:

    npm install
  4. Start the development server:

    npm run dev

Project Scripts

Development:

npm run dev

Starts the development server on http://localhost:5173.

Build:

npm run build

Creates a production-ready build of the application.

Lint:

npm run lint

Runs ESLint to analyze and fix code quality issues.


Additional Notes

  • Ensure that the backend API is running and accessible before starting the frontend server.
  • Refer to the backend README for more details on API setup and endpoints.

Known Issues/Bugs

  • User cannot see overall product details throw modal by click view icon.
  • Admin or vendor cannot reply user review.
  • In dashboard have some static data.
  • Admin or Vendor cannot edit or update overall order details, They can just order status change and payment status change.

Key Highlights

  • JWT-based authentication for secure access.
  • Paginated APIs for scalability.
  • Responsive design for seamless mobile and desktop experiences.
  • Advanced filtering and search functionalities.
  • Integrated third-party services for payments and image uploads.

Authentication and Authorization

Admin Or Super Admin:

Vendor:

User(Customer):

Contribution

Contributions are welcome. Feel free to open issues or submit pull requests for any improvements or bug fixes.


License

This project is licensed under the MIT License.