Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/parin-prog/ecommerce_mern_app
A eCommerce project is a web application for online shopping built using the MERN stack, which includes MongoDB, Express, React, and Node.js. The MERN stack is a popular open-source technology stack for building modern web applications that can handle a large amount of data and user traffic.
https://github.com/parin-prog/ecommerce_mern_app
chartjs css3 express expressjs firebase javascript material-ui mern-stack mongodb mui-icons nodejs reactjs stripe styled-components
Last synced: 23 days ago
JSON representation
A eCommerce project is a web application for online shopping built using the MERN stack, which includes MongoDB, Express, React, and Node.js. The MERN stack is a popular open-source technology stack for building modern web applications that can handle a large amount of data and user traffic.
- Host: GitHub
- URL: https://github.com/parin-prog/ecommerce_mern_app
- Owner: parin-prog
- License: apache-2.0
- Created: 2023-05-07T15:15:10.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-24T07:33:09.000Z (about 1 year ago)
- Last Synced: 2024-11-07T23:40:11.562Z (3 months ago)
- Topics: chartjs, css3, express, expressjs, firebase, javascript, material-ui, mern-stack, mongodb, mui-icons, nodejs, reactjs, stripe, styled-components
- Language: JavaScript
- Homepage: https://ecommerce-mern-app-henna.vercel.app/
- Size: 10 MB
- Stars: 3
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# eCommerce_MERN_app :shopping_cart:
![Logo](/client/src/Logo.png)### Version 1 :
* The data is stored using MongoDB
* Stripe integration for payment.
* For payment and order information used firestore.
* Yet, Features and improvements required in admin panel.
version 1 is hosted [HERE!](https://ecommerce-mern-app-henna.vercel.app/)An E commerce platform made using React JS, Redux, MaterialUI, Router, ExpressJS, MongoDB, Firestore, Stripe API (temporarily creating dummy payment gateway).
### The application is composed of the following Features:
## Front-End
* A landing page with animated minimalistic design, with the major categories of items.
* A quick peek page where 5 products of each categories are on display.
* A page with Sign-in and Sign-out components.
* All form related fields are made using reusable components.
* Has a cart feature which opens up and displays the items selected in a summary, also has a checkout button.
* The cart component also allows to edit the contents of the items selected.
* Checkout features are integrated with the appplication.## Backend
* API Endpoints: Various API endpoints manage CRUD operations for products, categories, users, and more.* Authentication: Secure Sign-in and Sign-out components ensure user access control through authentication tokens.
* Reusable Components: Form-related fields are designed as reusable components for maintainability and extensibility.
* Cart Management: Users can add and remove items, and update quantities in their shopping cart.
## Payment
* Secure Payments: Stripe API integration enhances the application's payment processing capabilities, providing a secure and reliable payment gateway for online transactions.
* Order Storage: Completed orders are meticulously stored in Firestore, guaranteeing the preservation of order details for future reference and fulfillment.
* Seamless Payment Flow: The Stripe integration ensures a seamless payment flow within the application, allowing users to complete transactions swiftly and securely, enhancing the overall shopping experience.
---
---
### Admin panel [Here](/admin/README.md)
---
---
**SCREENSHOTS:**
---Landing Page:
![](/client/src/assets/home.png)
---
Product Preview:![](/client/src/assets/product.png)
![](/client/src/assets/explore.png)
![](/client/src/assets/products.png)
![](/client/src/assets/footer.png)
---
Sign-in && Sign-Up Page:![](/client/src/assets/login.png)
![](/client/src/assets/register.png)Cart Section:
![](/client/src/assets/cart.png)
Payment:
![](/client/src/assets/stripe.png)
---
## Developed With
* [Visual Studio Code](https://code.visualstudio.com/) - A source code editor developed by Microsoft for Windows, Linux and macOS. It includes support for debugging, embedded Git control, syntax highlighting, intelligent code completion, snippets, and code refactoring
* [React](https://reactjs.org/) - A javascript library for building user interfaces
* [Create react app](https://create-react-app.dev/) - A quick method to start developing a react application.
* [Babel](https://babeljs.io/) - A transpiler for javascript
* [Webpack](https://webpack.js.org/) - A module bundler
* [MaterialUI](https://mui.com/material-ui/) - A prebuilt comp. provider
* [ExpressJS](https://expressjs.com/) - A web application framework for Node.js.
* [NodeJS](https://nodejs.org/en) - A JavaScript runtime for server-side applications.
* [MongoDB](https://www.mongodb.com/atlas/database) - A NoSQL database system.
* [Firestore](https://firebase.google.com/) - A cloud-based NoSQL database service from Firebase.
* [Stripe](https://stripe.com/) - A payment processing platform for online businesses.---
## Getting Started
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
### Prerequisites
The following software is required to be installed on your system:
* Node 16.x
* Npm 8.xType the following commands in the terminal to verify your node and npm versions
```bash
node -v
npm -v
```## How to Run
1. **Clone the Repository**: Start by cloning this repository to your local machine.
2. **Backend Setup**:
- Navigate to the backend directory and run `npm install` to install the required backend dependencies.
- Configure the database and environment variables as specified in the backend documentation.
- Run `npm start` to start the server.3. **Frontend Setup**:
- Navigate to the frontend directory and run `npm install` to install the required frontend dependencies.
- Configure the frontend environment variables as necessary.
- Run `npm start` to launch the frontend.4. **Access the Application**:
- Visit the application in your web browser at `http://localhost:3000` (by default for the frontend).
- Ensure the backend is running on a different port as specified in your configuration.Feel free to explore and build upon this project to create a fully functional e-commerce application. For any questions or assistance, please don't hesitate to reach out to us. Happy coding and happy shopping!