Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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.

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.x

Type 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!