This is still a work in progress. It IS live and good enough for me to use, but I'm still tuning it, adding features, and managing technical debt.
- React - Used because of its popularity within the community and my familiarity.
- Typescript - Used for static typing and code completion/documentation.
- NextJS 13+ - Used because I wanted to build something with the new app directory.
- Tailwind - Used because of its developer experience, flexibility, and the fact that it's zero runtime.
- DatoCMS - I love the UI for DatoCMS and feel like they have a generous free tier.
- Apollo - Used because of its popularity within the community and my familiarity.
- Jest - A great testing framework that I have used in the past. It has great support and documentation.
- Light/dark toggle
- Statically generated
- Semantic release (automatic versioning and changelog generation)
- CI/CD (Github Actions)
- Linting (eslint, commit linting, prettier)
- Husky (pre-commit & pre-push hooks)
- Testing (unit and e2e)
- Accessibility (axe)
- Typescript Codegen (graphql-codegen)
- Headless content, components, and pages
- Turbo for caching and template generation
An icon sprite is currently generated from the src/assets/icons
directory. This reduces the load time for SVG's.
To add to the icon sprite you add an SVG to the src/assets/icons
directory and run yarn gen:icons
to create a new sprite. This will:
- strip out extra attributes and optimize the SVG
- create a new sprite in
public
- create a new types file at
src/molecules/icon/iconIds.ts
with the new icon names
To improve the developer experience and speed up build/testing times I'm using turbo. Turbo is a caching and template generation tool that is built on top of Bazel. It's a quick setup (especially when not using a monorepo), and it works well.
When building, testing, or linting the project, turbo
will cache the results. This means that if you run the same command again, it will use the cached results instead of running the command again.
In order to take advantage of this, you need to run the commands through turbo
. For example, instead of running yarn test
you would run turbo test
.
Turbo should be used for the following commands:
build
test
lint
format
Turbo can also be used to generate components. This is done by running
turbo gen newUI
This will prompt a series of questions to ensure the component gets generated into the correct location as well as with the correct name, file structure, and supporting files.
As of now, there is only support for generating components
and molecules