This is a heavy modification of a base project started by Adrian Hajdin. I really enjoyed the figma design but the "finished" project really just lacked a number of core things I would expect from a modern experience.
A truly modern web application spans multiple pages and will be pulling data, images and more across the wire to deliver a smooth and performant experience to the end user. On top of that missing type safety for compilation and a lack of better folder structure for preprocessors or other platform tooling in the future.
That being said Adrian finally got me off my butt to just sit down and actually commit something using the tools I love to the open web. While this still needs more work Im just going to expand upon it for a bit in my free time.
Next gen image formatting, PRPL pattern and the works can turn that static page into something quite performant. My new application is on the right and the old base repo on the left.
Before and after resource load where I took some liberties and moved most of it off the initial page and onto subsequent pages but could have achieved a similar result leaving it all on one page and using the intersection observer api again. That being said we are down from 3.9MB of JS resources to just 279kb on initial page load and above the fold in almost the same amount of requests, just imagine throwing all this over http 2!
I would love to add several more things to this application before calling it "done". In order of importance:
- Auto Scripts for linting and testing to be run automatically with Husky
- Some simple filters/loops inside the code could and should be unit tested with Jest
- Deploy it with Vercel automatically
- Add back older image formats and use the size attribute better with built in next optimizations. (Ie is dead but safari still finds ways ...)
- Add Sign Up/Sign in Functionality
- Add an "Explore Library" feature as there is one missing link on the site and I did not know what to do with it feature wise
- Answer some of the sample todo's I have left around the code around some dynamic content loading
First, make sure to get all those great packages you will need
npm install
Then, run the development server using the tool of choice:
npm run dev
# or
yarn dev
# or
pnpm dev
Open http://localhost:3000 with your browser to see the result.
Make sure the development server is running and then feel free to open up cypress for a spin.
npm run cypress
# or
npm run cypress:test