Skip to content

Latest commit

 

History

History
79 lines (61 loc) · 5.18 KB

README.md

File metadata and controls

79 lines (61 loc) · 5.18 KB

Clothing Store v1 | A React E-commerce custom project

React basic e-commerce store, build as part of the course "Complete React Developer" from "Zero To Master". (PS: read the About the Course section down below)

My React experience has been on and off as my career led to be a Senior Frontend Developer on other platforms (Salesforce SFCC) that don't use React, so I decided to get an extensive course to challenge improve and expand my experience with it.

» Open the *current version here: https://fleps.github.io/clothing-store/

*Published version is always based on the code from the release branch.

1. Project Technical Details

  • Node v18.16
  • Project Boilerplate created using @vitejs/plugin-react v4.2 (Vite 5.1) (the course uses CRA)
  • React + react-dom v18.2
  • React-router v6.22
  • Sass v1.72
  • Firebase v10.9

2. Features (as part of the course)

  • Login / Registration using Firebase auth with Google and Email/Password options
  • Initially using useContext for Authentication, Products list and Minicart show/hide/render.
    • Refactor #1: Context changes, converting useStates inside the Context to useReducer
    • Refactor #2: Contexts gets replaced by using Redux. reselect added to the project to memoize the category array and avoid recreating it without need and unnecessary re-renders. Redux-thunk and Redux-Saga examples.
    • Refactor #3: Manual Redux reworked to use Redux-Toolkit
  • Shop / Category pages with functional Add To Cart button + Minicart + Bag icon counter
  • Cart/Minicart quantity changes + product removal + counter update
  • Categories data comes from Firebase.
  • Code performance improvements:
    • added useCallback to avoid redefining functions;
    • added memo to some components to avoid unnecessary re-renders;
    • added react lazy and Suspense to App for better bundle/code splitting;
  • Added Unit Test for basic testing + Redux Reducer and Selectors.

3. Extra features and customizations added by me (not part of the course)

  • Products have currency and proper price format.

  • Minicart open / close improvements:

    • Minicart auto opens when adding a product to the bag (if the user is not on Cart page). Very basic for e-commerce.
    • Minicart closes when changing "pages".
    • Minicart has CSS animation to open/close, doesn't just appear/disappear.
    • Logic improved: reworked calls to avoid unnecessary re-renders when opening / closing.
  • Unnecessary useState + useEffects removed following React docs.

  • Added cleanup function on useEffect that fetches the category data from Firebase (course never mentions this)

  • Semantic / accessible HTML (course code has divs nested into spans, divs/spans having click events...)

  • Optimized arrays methods, course teaches bad practices doing 2 (or even more) transverse on the same arrays for no reason.

  • Github Actions Workflow implemented to auto-publish when a new version gets pushed to /releases branch

  • Added Redux-Persist for minicart with Redux-Toolkit.

  • Added Loading element on categories async fetch using Redux-Toolkit createAsyncThunk approach.

  • Added scroll position reset when navigating to checkout

  • Unit Test added with Vitest + Testing-Library + as I built the project using Vite and not CRA.

  • Site UI / CSS / Styles customized

    • Navigation fixed position
    • Minicart shadow, fixed position
    • Round corners and shadows added on many elements
    • Implemented proper mobile/responsive behavior/styles
    • Checkout total element has fixed positions for better UX if having scroll (different between mobile/desktop)
    • Product card image effect, shadows, corners and button appearing css animation added
    • Added site footer with bottom position.
    • Image lazy loading
    • Loading properly added on category pages
    • Scroll position reset to top on "page" change
    • Smooth CSS animation on "page" change

About the Course

Now that I finished the course, I'm not sure I recommend it. I can't judge the React part itself too much, and the course still has its values to introduce many different topics needed for someone wanting to learn React, but I expected way more from it.

On the pure Front-End side of things (proper UX for e-commerce sites, good practices for HTML/JS/CSS, responsive layout) the course lacks tremendously and actually teaches bad practices (double array transverse, nesting divs inside spans, attaching onClick events do spans/divs...).

Also, the teaching method can be frustrating as it's based on refactoring over and over the same features (without explaining that this was going to happen). This resulted in features being developed with incomplete solutions on a specific approach, and then in a few lessons it was completely refactored to show another way, but always with some flaw. At the end, it becomes overwhelming and it's not clear what is the best way to do XYZ feature.

v1 Completed

The project is now completed, I've added quite a few customizations (read section 3), specially on the UI side, which I'm satisfied with.

Maybe in I'll add more functionalities on a new version in the future, who knows.