About the Portfolio Project: E-Commerce Website II category

The E-Commerce Website II Project

Welcome to the subcategory for the E-Commerce Website II Project. This portfolio project can be found in the following courses or paths:

  • Full Stack Engineer Path

How to Get Feedback on your Project

Congratulations on finishing your portfolio project! Now you’ll want to follow these steps to get feedback on it.

  1. Post a link to your git repository :slight_smile:
  2. Give us a few sentences about your experience. Was this fun? Difficult? How long did it take?
  3. Check back in—if someone has replied to your post, come see what they have to say.

How to Give Feedback on Another Learner’s Project

Reviewing someone else’s code isn’t just a nice thing to do; it’s also a great opportunity to sharpen your skills by viewing a different perspective.

  1. Refer to the article in your Career Path on How to Review Someone Else’s Code
  2. Click through topics in this subcategory to view other submissions of this project.
  3. Reply to a thread with feedback, encouragement, or letting them know if they did something in a way you hadn’t thought of before!

No one has completed this project yet?

  1. Github link: https://github.com/dhatGuy/PERN-Store and Demo link: https://pern-store.netlify.app

  2. I spent so much time(about one week) on how to structure the database because I was confused about how to connect with the frontend. Also took a while to figure out how to implement the cart and order logic.
    Working on the frontend was easier for me compared to the backend.

Though I’m still working on it, I have implemented the most important features.
I added some features also which includes

  1. Reviews

  2. Signup email

Features to implement

  1. Sign in with Google

  2. Add seller role

  3. Integrate stripe payment

  4. Forgot password and reset the password (In progress)


Many people probably don’t go till this level . Sad :pensive:

Great work on being first to complete this! The task was not easy and it requires skills in many different areas. I have not started on it yet but it is great to be able to see some of the tools you choose. One small idea for improvement would be to make functionality so that items can be added to shopping cart before creating an account. But I realize that it would add some complexity to the cart logic…

Yes, I have thought of it before and I’m aware how complex it will be. I don’t really have an idea how to implement it yet. Maybe by creating a temporary table💭. I’ll make research how to.
If possible also, guests will be able to make purchase without creating an account.

I have seen some suggestions to use localStorage or cookie first for anonymous users and then sync this cart with database once users log in… For example here:

1 Like

Hi everyone!

I really enjoyed this challenge, and I think I learned a lot, I would like you to share your opinions with me if you want.

Please take a look at my e-commerce app in github: Postres de la abuela
Note: if you want to see the live version take a look at the readme.md file and click the link in the setup section

1 Like

Hi! I think it would be a good idea to add English language support. It would make it easier to navigate the app for many on here. Google translate does an ok job but not the same as native language support…

Its very important to know that Google translate its not working as well as expected with my app. Thank you very much!!

Hi! Your app looks really good, I like the shadow, the proportions and the font. I think the app would be easier to navigate if the logo was also a link to the home page. :ok_hand:

1 Like

This was a big challenge but finally got it deployed. Here is the link:

Github repo: https://github.com/mikejoh12/e-commerce
API Docs: https://e-market-api.herokuapp.com/api-docs/

It took 2 months (part-time) and some of the bigger challenges were: database-schema design, structuring the Express code into controller/service/db-layers, managing the JWT authentication, Google OAuth/Stripe-integrations, and handling the cart logic in different scenarios (logged out vs logged in). Think about which Express routes your front-end will need and consider only designing those. I created CRUD routes for pretty much all the tables which was a bit of unnecessary work unless also designing an admin-site. I debated going with AuthO for the authentication and it probably would have been a bit easier since the docs seem great. With passport it was a lot of looking around for info outside of the docs but it was a learning process. Ended up using Redux and it’s probably a good fit for the project. If using Redux, the redux-persist library was really helpful for storing the shopping-cart in localStorage before a user logs in and the database can be used.

Todo: Password reset, user-account-edit, e-mail notifications, tests, optimize images, create welcome/category-page.

Appreciate any feedback!