mohamedsamara / mern-ecommerce

:balloon: Fullstack MERN Ecommerce Application
https://mern-store-gold.vercel.app
MIT License
1.63k stars 770 forks source link
express mern mern-ecommerce mern-stack mongoose node react redux redux-thunk

MERN Ecommerce

Description

An ecommerce store built with MERN stack, and utilizes third party API's. This ecommerce store enable three main different flows or implementations:

  1. Buyers browse the store categories, products and brands
  2. Sellers or Merchants manage their own brand component
  3. Admins manage and control the entire store components

Features:

Demo

This application is deployed on Vercel Please check it out :smile: here.

See admin dashboard demo

Docker Guide

To run this project locally you can use docker compose provided in the repository. Here is a guide on how to run this project locally using docker compose.

Clone the repository

git clone https://github.com/mohamedsamara/mern-ecommerce.git

Edit the dockercompose.yml file and update the the values for MONGO_URI and JWT_SECRET

Then simply start the docker compose:

docker-compose build
docker-compose up

Database Seed

npm run seed:db [email-***@****.com] [password-******] // This is just an example.

Install

npm install in the project root will install dependencies in both client and server. See package.json

Some basic Git commands are:

git clone https://github.com/mohamedsamara/mern-ecommerce.git
cd project
npm install

ENV

Create .env file for both client and server. See examples:

Frontend ENV

Backend ENV

Vercel Deployment

Both frontend and backend are deployed on Vercel from the same repository. When deploying on Vercel, make sure to specifiy the root directory as client and server when importing the repository. See client vercel.json and server vercel.json.

Start development

npm run dev

Languages & tools

Code Formatter


    {
      "editor.formatOnSave": true,
      "prettier.singleQuote": true,
      "prettier.arrowParens": "avoid",
      "prettier.jsxSingleQuote": true,
      "prettier.trailingComma": "none",
      "javascript.preferences.quoteStyle": "single",
    }