Building a state management tool like redux from scratch
In order to get a better understanding of state management tools, especially redux, I decided to build my own simpler version of the library, both in vanilla javascript to support any kind of project and also a react-typescript one.
You can see how in these code sanboxes dependencies, we only have bundler and in the case of the react one, react (and other stuff) but never redux. The whole point of these exercises was to re-create redux and react-redux myself, from scratch.
JS Redux Todo - CodeSandbox
Typical todo app made using a custom-simpler-version of redux built from scratch. All in vanilla javascript.
data:image/s3,"s3://crabby-images/585a4/585a48004ec0804f441549c4cfa9e85a8252b1d4" alt="JS Redux Todo - CodeSandbox"
React Redux Todo - CodeSandbox
Typical todo app made using a simpler version of react-redux built from scratch. All in typescript.
data:image/s3,"s3://crabby-images/78b97/78b977cb37c14be83bcb34fc594d8c249fe1df3e" alt="React Redux Todo - CodeSandbox"
Also made this for a better understanding on middlewares and particularly what thunks are and how they work.
Redux Thunk React - CodeSandbox
Basic implementation of redux thunk, used on a style-less todo react app.
data:image/s3,"s3://crabby-images/76459/764597d0876cada1f019757e2074929b1de661fe" alt="Redux Thunk React - CodeSandbox"
Finally, having recreated react-redux as it is today, with hooks and all the latest paterns, I wanted to go on a trip down memory lane and do a similar thing but looking back at how we used to do things in react before hooks. This version uses class components and in order to re-create react-redux, we create our very own connect
higher order component.
React Redux (class) - CodeSandbox
Basic implementation of react-redux (with its old "connect" higher order component) on a style-less react todo app.
data:image/s3,"s3://crabby-images/83265/83265f5bcc2dcd182e5ca905a8ef2d91b028ed5f" alt="React Redux (class) - CodeSandbox"