Skip to content

e-commerce application having all core features of common e-commerce website like payements, back-office administration etc...

Notifications You must be signed in to change notification settings

calebrussel77/e-commerce-shop

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

E-Shop eCommerce Platform

eCommerce platform built with the React + Typescript & NodeJs + Typescript & Redux.

screenshot

Features

  • Full featured shopping cart
  • Responsive design
  • Product reviews and ratings
  • Multiple images uploads using cloudinary
  • Top products carousel
  • Product pagination
  • Product search feature
  • User profile with orders
  • Admin product management
  • Admin user management
  • Admin Order details page
  • Mark orders as delivered option
  • Checkout process (shipping, payment method, etc)
  • PayPal / credit card integration
  • Database seeder (products & users)

Usage

Typescript for the project

I have used typescript in the backend and the Frontend in this project. Be sure to have at least Node v14.6+ .

Env Variables

Create a .env file in the root of the project and add the following

NODE_ENV = development
PORT = 5000
DATABASE_URL = your mongodb uri
JWT_SECRET_KEY = 'abc123'
PAYPAL_CLIENT_ID = your paypal client id
CLOUDINARY_NAME=Your cloudnary name
CLOUDINARY_API_KEY=Your cloudainary api_key
CLOUDINARY_SECRET=Your cloudinary secret
REACT_APP_BASE_URL= it isn't required for the purpose because i already have a proxy on the frontend 

Install Dependencies (frontend & backend)

yarn install
cd frontend
yarn install

Run

# Run frontend (:3000) & backend (:4000)
yarn dev

# Run frontend only
yarn dev:client

# Run backend only
yarn dev:backend

Build & Deploy

# Create frontend prod build
cd frontend
yarn run build

There is a Heroku postbuild script, so if you push to Heroku, no need to build manually for deployment to Heroku

Seed Database

You can use the following commands to seed the database with some sample users and products as well as destroy all data

# Import data
yarn run data:import

# Destroy data
yarn run data:destroy
Sample User Logins

admin@test.fr (Admin)
123456

john@test.fr (Customer)
123456

jane@test.fr (Customer)
123456

License

The MIT License

About

e-commerce application having all core features of common e-commerce website like payements, back-office administration etc...

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages