An SPA that displays fonts from Google Fonts API sorted by popularity. Users can define a custom text, font size, and filter fonts by search term.
- Responsive layout
- Instant search, ordered priority, match terms starting with query first, then terms with words that start with query, then terms that just contain query
- Varied default sample text
- Infinate scroll loading of fonts
- User collection
As a reimplementation of the wonderfully built Google Fonts website I wanted to expand on their minimalist feel of thin lines and simplicity, that lends itself so well to a fonts UI with a bit more playfulness.
I design the logo to feel like alternating typewriter keys and press printed letters and the thin lines decorating the font cards as wires to give a sense they're held in place. The tool bar compacts down well in being grouped by search, text control, display control, reset. The open collection button displays a list of the last three added font that tucks away so it's present by not distracting.
I choose to use an infinate scrolling method of loading more fonts over preallocating space and lazy loading. The search is currently very basic, it matches the query to the begining of font family names. So with time that's something I may improve.
cd dev/
- make new file named .env with REACT_APP_GOOGLE_FONT_API_KEY=[your-api-key-here]
- run
npm install
(in root folder/this location of your cloned/downloaded repo) npm start
- create-react-app
- react-router-dom
- aphrodite
- Google Fonts API
- axios
- react-query
- react-in-viewport
- react-lazyload
- react-springs
- header
- logo
- site menu/page links
- catalog
- toolbar
- search Google Fonts
- customise sample text
- alter font size
- toggle grid/bar view
- toggle light/dark theme
- reset all controls
- cards
- grid type
- bar type
- add to collection button
- remove from collection button
- toolbar
- featured
- articles
- about
cd dev/
npm run deploy