Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/luminarakash/e-commerce
A Seamless Shopping Experience Powered by the MERN Stack, Redux Toolkit, and Material UI
https://github.com/luminarakash/e-commerce
cloudinary css3 expressjs html5 javascript jwt-authentication mongodb mongoose nodejs reactjs redux restful-api tailwind-css
Last synced: 28 days ago
JSON representation
A Seamless Shopping Experience Powered by the MERN Stack, Redux Toolkit, and Material UI
- Host: GitHub
- URL: https://github.com/luminarakash/e-commerce
- Owner: luminarakash
- Created: 2024-10-16T14:20:50.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2024-12-11T05:13:33.000Z (about 1 month ago)
- Last Synced: 2024-12-11T05:19:05.007Z (about 1 month ago)
- Topics: cloudinary, css3, expressjs, html5, javascript, jwt-authentication, mongodb, mongoose, nodejs, reactjs, redux, restful-api, tailwind-css
- Language: JavaScript
- Homepage:
- Size: 39.4 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# E-Commerce
## A Seamless Shopping Experience Powered by the MERN Stack, Redux Toolkit, and Material UI**MERN E-commerce:** is a full-stack application designed to transform your online shopping experience. Built with the MERN stack (MongoDB, Express.js, React, Node.js), it leverages Redux Toolkit for efficient state management and Material UI for a sleek, user-friendly interface. This project offers a robust platform for both users and admins, packed with essential features for a seamless experience.
![ecommerce-homepage](https://github.com/luminarakash/E-Commerce/blob/main/frontend/src/assest/ss1.png)
![ecommerce](https://github.com/luminarakash/E-Commerce/blob/main/frontend/src/assest/ss2.png)
# **Features**
### **User:**
- **Product Reviews:**
- Write, edit, and delete reviews.
- Instant updates on ratings and star percentages.
- **Wishlist:**
- Add, remove, and annotate products with personalized notes.
- **Order Management:**
- Create new orders and view order history.
- **Profile Management:**
- Manage email, username, and multiple addresses.
- **Shopping Cart:**
- Add products, adjust quantities, and view subtotals.### **Admin:**
- **Product Management:**
- Add, edit, delete, and soft-delete products.
- Manage product attributes like name and stock.
- **Order Management:**
- View and update order details and status.### **Security & User Experience:**
- **Secure Authentication:**
- Login, signup, OTP verification, password reset, and logout.- **Intuitive Interface:**
- Powered by Material UI for a visually appealing and user-friendly experience.### **Scalability:**
- **Built for Growth:**
- Scalable architecture to handle increasing user demands.# **Project Setup**
### Install dependencies for frontend and backend separately
**Tip:** To efficiently install dependencies for both frontend and backend simultaneously, use split terminals.Install frontend dependencies
```bash
cd frontend
npm install
npm start
```Install backend dependencies
```bash
cd backend
npm install
npm run dev
```### Environment Variables
**Backend**
- Create a `.env` file in the `backend` directory.
- Add the following variables with appropriate values
```bash
# Database connection string
MONGO_URI="mongodb://....................../your-database-name"# Frontend URL (adjust if needed)
ORIGIN="http://localhost:3000"# Token and cookie expiration settings
LOGIN_TOKEN_EXPIRATION="8h"# Secret key for jwt security
SECRET_KEY="your-secret-key"**Frontend**
- Create a `.env` file in the `frontend` directory
- Add the following variable:
```bash
# Backend URL (adjust if needed)
REACT_APP_BASE_URL="http://localhost:8080"
```**Important**
- Replace all placeholders (e.g., your_database_name) with your actual values.
- Exclude the `.env` file from version control to protect sensitive information.### Login with demo account (Optional)
- After successfully seeding the database, you can now explore the application's functionalities using pre-populated sample data.
- here are the `login credentials`
```bash
email: [email protected]
pass: helloWorld@123
```
### Accessing the Application
Once both servers are running, you can access them at the following URL's:
- Backend: http://localhost:8080
- Frontend: http://localhost:3000## **Bonus**
Don't forget to star the repository and share your feedback!✨## Authors
- [@luminarakash](https://github.com/luminarakash) ♥ : Akash Patel