Welcome to Fusion Electronics, a MERN-Stack E-commerce Application! This project is a working demo of a full-stack web application that was built using the MERN stack (MongoDB, Express.js, React.js, Node.js). It aims to provide a comprehensive example of building a modern e-commerce platform, covering frontend user interface, backend server logic, database management, and integration with third-party libraries.
- Introduction
- Live Deployment
- User Interface
- Features
- Technologies Used
- Getting Started
- Project Structure
- Running the Application
- Testing the APIs
- Swagger API Documentation
- OpenAPI Specification
- Deployment
- Containerization
- Contributing
- License
- Creator
This project is a demonstration of building an e-commerce application using the MERN stack, which consists of MongoDB (database), Express.js (server), React.js (frontend), and Node.js (runtime environment). The application allows users to browse products, add them to a shopping cart, proceed to checkout, and simulate the order processing. It includes basic validations for user inputs and simulates the checkout process on the backend.
The application is deployed live on Vercel. You can access it at the following URL: Fusion Electronics.
The backend server is deployed on Render and can be accessed at the following URL: Fusion Electronics API.
Note: The backend server may take a few seconds to wake up if it has been inactive for a while. For your information, it is hosted on the free tier of Render, with 0.1 CPU and 512 MB of memory only, so it may take a bit longer to respond to requests, especially after periods of inactivity.
-
Product Management:
- View a list of products.
- View detailed product information.
- Add products to the shopping cart.
-
Shopping Cart:
- View items in the shopping cart.
- Remove items from the cart.
- Calculate total amount of items in the cart.
-
Checkout Process:
- Enter billing, shipping, and payment information.
- Simulate the order creation process on the backend.
- Receive confirmation of order success.
-
Frontend:
- React.js
- Material-UI for styling
- Axios for API requests
react-credit-cards-2
for credit card visualizationreact-router-dom
for routingreact-hook-form
for form validationreact-toastify
for toast notifications- Jest and React Testing Library for testing
-
Backend:
- Node.js
- Express.js
- MongoDB (with Mongoose ODM)
- Axios for external API requests
- JsonWebToken for user authentication
- Bcrypt for password hashing
- Dotenv for environment variables
- Cors for cross-origin resource sharing
- Swagger for API documentation
- Nodemon for server hot-reloading
- Middleware: JWT for securing API endpoints
-
Development Tools:
- Jetbrains WebStorm (IDE)
- Postman (for API testing)
- Git (version control)
- npm (package manager)
The project is organized into two main "stacks": The backend is in the backend
directory that hosts all product & order data and the frontend is in the root
directory. Here is an overview of the project structure:
fullstack-ecommerce/
├── backend/ # Node.js server files
│ ├── config/ # Configuration files
│ │ └── db.js # Database connection
│ ├── models/ # Mongoose models
│ │ └── product.js # Product schema
│ ├── routes/ # Route handlers
│ │ ├── products.js # Product routes
│ │ ├── search.js # Search routes
│ │ └── checkout.js # Checkout routes
│ ├── seed/ # Database seed data
│ │ └── products.js # Product seed data
│ ├── .env # Environment variables
│ └── index.js # Server entry point
├── public/ # Frontend public assets
│ ├── index.html # HTML template
│ ├── manifest.json # Web app manifest
│ └── favicon.ico # Favicon
├── src/ # React.js frontend files
│ ├── components/ # Reusable components
│ │ ├── CheckoutForm.jsx # Checkout form component
│ │ ├── ProductCard.jsx # Product card component
│ │ ├── NavigationBar.jsx # Navigation bar component
│ │ ├── OrderConfirmation.jsx # Order confirmation component
│ │ ├── ProductListing.jsx # Product listing component
│ │ ├── SearchResults.jsx # Search results component
│ │ └── ShoppingCart.jsx # Shopping cart component
│ ├── dev/ # Development utilities
│ │ ├── index.js # Development entry point
│ │ ├── palette.jsx # Color palette
│ │ ├── preview.jsx # Component preview
│ │ └── useInitials.js # Initials hook
│ ├── pages/ # Page components
│ │ ├── Cart.jsx # Cart page component
│ │ ├── Checkout.jsx # Checkout page component
│ │ ├── Home.jsx # Home page component
│ │ ├── ProductDetails.jsx # Product details page component
│ │ ├── OrderSuccess.jsx # Order success page component
│ │ ├── ProductDetails.jsx # Product details page component
│ │ └── Shop.jsx # Shop page component
│ ├── App.jsx # Main application component
│ ├── App.css # Main application styles
│ └── index.js # React entry point
├── build/ # Frontend production build files
├── tests/ # Test files
├── .gitignore # Git ignore file
├── package.json # NPM package file
├── jsconfig.json # JS config file
└── setupProxy.js # Proxy configuration
Before running this project, ensure you have the following installed:
- Node.js (with npm)
- MongoDB (with either local or remote instance)
- Git
-
Clone the repository:
git clone https://github.com/hoangsonww/MERN-Stack-Ecommerce-App.git cd MERN-Stack-Ecommerce-App # Fix the path if necessary
-
Install project dependencies:
# Install server (backend) dependencies cd backend npm install # Install client (frontend) dependencies cd .. npm install
-
Set up the backend:
-
Create a
.env
file in thebackend/
directory and add the following environment variable (replace the URI with your MongoDB connection string):MONGO_URI=mongodb://localhost:27017/Ecommerce-Products JWT_SECRET=your_secret_key
For your information, I am using MongoDB Atlas for this project. You can create a free account and get your connection string from there if you want to deploy the application to the cloud.
-
Ensure that your MongoDB server is running. If you're using Mac, you can start the MongoDB server with the following command:
brew services start mongodb-community
-
Seed the database with sample data:
cd backend/seed node productSeeds.js dev
-
Run the backend server: (first
cd
into the backend directory)cd .. npm start
-
-
Set up the frontend:
- First,
cd
into theroot
directory if you are not already there:Orcd ..
cd fullstack-ecommerce
- Start the frontend development server:
npm start
- Note: The frontend server will run on
http://localhost:3000
by default. If you encounter any errors when starting related to thereact-credit-cards-2
package, it is OK to just ignore them as the application will still run correctly.
- First,
- Open your browser and navigate to
http://localhost:3000
to view the application.
- Simply open your browser and navigate to
http://localhost:5000/api/products
to view the list of products. - You can also change the sample data by navigating to
backend/seed/productSeeds.js
and modifying the data there.
- The backend server includes Swagger API documentation that can be accessed at
http://localhost:5000/api-docs
. - Before accessing the above URL, ensure that the backend server is running.
- The Swagger UI provides a detailed overview of the API endpoints, request/response schemas, and example requests.
- If you have everything set up correctly, you should see the Swagger UI documentation page:
- View the API Documentation
- Open Swagger Editor.
- Upload the
openapi.yaml
file or paste its content. - Visualize and interact with the API documentation.
- Test the API
- Import
openapi.yaml
into Postman:- Open Postman → Import → Select
openapi.yaml
. - Test the API endpoints directly from Postman.
- Open Postman → Import → Select
- Or use Swagger UI:
- Provide the file URL or upload it to view and test endpoints.
- Generate Client Libraries
- Install OpenAPI Generator:
npm install @openapitools/openapi-generator-cli -g
- Generate a client library:
openapi-generator-cli generate -i openapi.yaml -g <language> -o ./client
- Replace
<language>
with the desired programming language.
- Generate Server Stubs
- Generate a server stub:
openapi-generator-cli generate -i openapi.yaml -g <framework> -o ./server
- Replace
<framework>
with the desired framework.
- Run a Mock Server
- Install Prism:
npm install -g @stoplight/prism-cli
- Start the mock server:
prism mock openapi.yaml
- Validate the OpenAPI File
- Use Swagger Validator:
- Upload
openapi.yaml
or paste its content to check for errors.
- Upload
This guide enables you to view, test, and utilize the API. You can generate client libraries, server stubs, and run a mock server using the OpenAPI Specification.
To deploy the application:
- Configure deployment settings for both frontend (React) and backend (Node.js) according to your chosen hosting provider (e.g., AWS, Heroku, Netlify).
This project can be containerized using Docker. First, ensure that Docker Desktop is running on your system. Then, to create a Docker image, run the following command:
docker compose up --build
This command will create a Docker image for the frontend and backend, and run the application in a containerized environment.
Contributions to this project are welcome! Here are some ways you can contribute:
- Report bugs and request features by opening issues.
- Implement new features or enhancements and submit pull requests.
- Improve documentation and README files.
This project is licensed under the MIT License - see the LICENSE file for details.
- Son Nguyen - hoangsonww
- Email: [email protected].
Thank you for exploring Fusion Electronics - a MERN Stack E-commerce Application! If you have any questions or feedback, feel free to reach out or open an issue.
Happy coding! 🚀