Opinionated Vite starter template.
- Vite with React, TypeScript and absolute imports.
- Tailwind CSS v2 with the JIT engine enabled, a basic reset for form styles and dark mode.
- Use ESLint, stylelint and Prettier on VSCode and before you commit with Husky and lint-staged.
- PWA with 17/17 Lighthouse score.
- Write unit and integration tests with Jest and Testing Library.
- Write e2e tests with Cypress.
- GitHub Actions for automatic dependency updates, CodeQL Analysis, running tests and code coverage with Codecov.
- Deploy to Vercel with pre-configured SPA fallback.
Use this repository as a GitHub template or use degit to clone to your machine with an empty git history:
npx degit wtchnm/Vitamin#main my-app
Then, install the dependencies:
yarn install
- If you don't plan to use GitHub Actions, delete the
.github
directory. - Clean up the
cypress/integration/index.spec.ts
file. - Change the
favicon.png
,apple-touch-icon.png
,android-chrome-192x192.png
andandroid-chrome-512x512.png
. favicon.io is a cool tool for generating these assets. - In the
src
folder, remove the__tests__
,api
andcomponents
folder and thetypes.ts
file. - If you don't plan to use
react-query
, remove the query client logic in themain.tsx
file. - Change the title, description and theme color in the
index.html
andvite.config.ts
. The Inter font is included, so remove it if you want. - Modify or delete the
LICENSE
file. - Change the
name
field in package.json.
yarn dev
- start a development server with hot reload.yarn build
- build for production. The generated files will be on thedist
folder.yarn serve
- locally preview the production build.yarn test
- run unit and integration tests related to changed files based on git.yarn test:ci
- run all unit and integration tests in CI mode.yarn test:e2e
- run all e2e tests with the Cypress Test Runner.yarn test:e2e:headless
- run all e2e tests headlessly.yarn format
- format all files with Prettier.yarn lint
- runs TypeScript, ESLint and Stylelint.yarn validate
- runslint
,test:ci
andtest:e2e:ci
.