TechWorld, inspired by Amazon Website is a MERN Stack web application built to mimick the functionalities of an electronic store.
- Clear distinction between users and admin is established.
- Users can view, choose and order products to an address. Order history is stored and can be viewed in the profile page. All orders have unique order id.
- Home page has list of all products available and also contains a sidebar with product types including smartphones, laptops, watch and audio devices. Each product type when clicked opens a page with only that product type.
- Product page has 3 vertical fields including product image, product description and product stock with add to cart button.
- Cart page uses cookies and stores the chosen products with the quantity. Since it uses cookies, after the end of the browser session the cookies are destroyed and the cart data resets.
- Shipping page requires address input and payment method.
- Order page automatically creates a unique order id for every order.
- Users and admin have profile page to edit name, email and password.
- Every signin is verified using JSON Web Token (JWT).
- Admin has super user benefits to add new products, remove and edit existing products.
- React: Components, Props, Events, Hooks, Router, Axios
- Redux: Store, Reducers, Actions
- Node & Express: Web API, JWT
- MongoDB: Mongoose
- Development: ESLint, Babel, Git, GitHub
-
Clone repository
$ git clone git@github.com:vishaln15/techworld.git $ cd techworld/
-
Setup MongoDB Compass on respective Operating System
-
Run Backend
$ npm install $ npm start
-
Run frontend on a new terminal
$ cd frontend/ $ npm install $ npm start
-
Populate pre-existing admin and products
- Install JSON formatter extension on browser for better view of JSON objects.
- Run this on browser: http://localhost:5000/api/users/createAdmin
- This returns and renders an admin email and password object.
- Run this on browser: http://localhost:5000/api/products
- Creates a sample product in MongoDB database.
- Additionally, import the products.json file in MongoDB Compass to directly populate the products.
-
Admin Login
- Run http://localhost:3000/signin
- Enter admin email and password and click signin.
- Signout and View order pages update only after refreshing the page once.
- Add file uploader api to upload image of new product.
- Store data in S3 and deploy on Heroku.
- Add searchbar to search through products.
Adapted from https://github.com/basir/node-react-ecommerce . Huge thanks to Bassir Jafarzadeh whose YouTube video helped us understand and implement every step through the project.