This full-stack e-commerce application is built using cutting-edge technologies to provide users with a seamless shopping experience. Below are some key features and technologies used in the development:
-
Browse and Shop:
- Buyers can explore store categories, products, and brands.
- Intuitive filtering options for price, rating, and categories to enhance the search experience.
-
Admin Dashboard:
- Comprehensive admin dashboard to manage and control various components of the store.
-
User Engagement:
- Enabled user reviews, ratings, and Wishlist features to enhance user interaction.
-
Payment Integration:
- Integrated Stripe for secure and convenient payment processing.
-
Additional Functionality:
- Implemented advanced product searching and filtering functionalities.
- Integrated coupon code functionality for discounts.
- Seamless return and refund features for a smooth user experience.
- Increased Performing performance by 85% using caching.
-
Upcoming Features:
- Adding more filtering functionalities for the products.
- Adding Google OAuth, OTP Based Login to the users.
- Adding subscription functionality using Stripe membership for users.
- Adding Multilingual Support for the users of different languages.
- Adding Recommendation System for the users to help them shop better with suggesstions.
-
Backend:
- Node.js provides the backend environment.
- Express middleware handles requests, routes, and user authentication.
- MongoDB with Mongoose schemas models the application data.
-
Frontend:
- React.js for building dynamic and responsive UI components.
- Redux for managing the application's state.
- Redux Thunk middleware for handling asynchronous redux actions.
-
Testing:
- Unit tests performed using Mocha and Chai in the backend to ensure robust code quality.
-
Storage:
- AWS-S3 utilized for efficient storage of user avatars and product images, ensuring scalability and performance.
Some basic git commands are:
$ git clone https://github.com/AnantDuhan/MERN-Ecommerce.git
$ cd MERN-Ecommerce
$ npm install
For Backend - npm install
For Frontend - cd frontend
npm install
Make Sure to Create a config.env file in backend/config directory that include:
- DB_URI & JWT_SECRET_KEY & JWT_EXPIRES_IN
- PORT, FRONTEND_URL & RESULT_PER_PAGE
- STRIPE_PUBLISHABLE_KEY & STRIPE_SECRET_KEY
- COOKIE_EXPIRES
- SMTP_HOST, SMTP_PORT & SMTP_SERVICE
- SMTP_MAIL & SMTP_PASSWORD
- AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY, AWS_BUCKET_NAME & AWS_BUCKET_REGION
> Create a Procfile in the root directory of your application with the following command **web: npm run start:production**
$ npm run production
for frontend
$ npm start
for backend
$ npm run dev
$ npm run start:production
- Add a
.vscode
directory - Create a file
settings.json
inside.vscode
- Install Prettier - Code formatter in VSCode
- Add the following snippet:
{
"editor.formatOnSave": true,
"prettier.singleQuote": true,
"prettier.arrowParens": "avoid",
"prettier.jsxSingleQuote": true,
"prettier.trailingComma": "none",
"javascript.preferences.quoteStyle": "single"
}