Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wtchnm/vitamin
Opinionated Vite starter template.
https://github.com/wtchnm/vitamin
cypress e2e eslint jest prettier react tailwindcss typescript vite vitest
Last synced: 5 days ago
JSON representation
Opinionated Vite starter template.
- Host: GitHub
- URL: https://github.com/wtchnm/vitamin
- Owner: wtchnm
- License: mit
- Created: 2021-02-08T19:18:44.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-08-25T02:28:39.000Z (6 months ago)
- Last Synced: 2025-02-07T12:09:06.117Z (13 days ago)
- Topics: cypress, e2e, eslint, jest, prettier, react, tailwindcss, typescript, vite, vitest
- Language: TypeScript
- Homepage: https://vitamin-wtchnm.vercel.app/
- Size: 5.7 MB
- Stars: 568
- Watchers: 5
- Forks: 50
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# Vitamin
[data:image/s3,"s3://crabby-images/306b3/306b3dc26ba89f095c75f730072dc4ed27238187" alt="codecov"](https://codecov.io/gh/wtchnm/Vitamin) data:image/s3,"s3://crabby-images/b7a79/b7a7999ad960b22b1668da07d8308c90cf73e27a" alt="Test workflow" data:image/s3,"s3://crabby-images/6a9b9/6a9b910ac1b659e8f9e125a2a2f8b47ff2eecfcf" alt="CodeQL workflow" [data:image/s3,"s3://crabby-images/7baa6/7baa6da055b5d7f6c3e59eb05406419f73d1b703" alt="Vitamin"](https://dashboard.cypress.io/projects/etow1b/runs) [data:image/s3,"s3://crabby-images/66d2a/66d2aa6f1e0afe66f640aa4ac2de0141d66555dc" alt="code style: prettier"](https://github.com/prettier/prettier) [data:image/s3,"s3://crabby-images/a3a68/a3a68cf6effdd60271bb53de8385538cd7ea17c9" alt="Commitizen friendly"](http://commitizen.github.io/cz-cli/) [data:image/s3,"s3://crabby-images/a6d36/a6d36c750f205f1b0294ad766af3fb3737f99c6f" alt="license"](https://github.com/wtchnm/Vitamin/blob/main/LICENSE)
> [!WARNING]
> Project in maintenance mode.Opinionated Vite starter template.
## Features
- [Vite](https://vitejs.dev) with [React](https://reactjs.org), [TypeScript](https://www.typescriptlang.org) and [absolute imports](https://github.com/aleclarson/vite-tsconfig-paths).
- [Tailwind CSS v3](https://tailwindcss.com) with a [basic reset for form styles](https://github.com/tailwindlabs/tailwindcss-forms) and a [Prettier plugin](https://github.com/tailwindlabs/prettier-plugin-tailwindcss) that automatically sorts classes.
- Use [ESLint](https://eslint.org), [stylelint](https://stylelint.io) and [Prettier](https://prettier.io) on VSCode and before you commit with [Husky](https://github.com/typicode/husky) and [lint-staged](https://github.com/okonet/lint-staged).
- [PWA](https://github.com/antfu/vite-plugin-pwa) with [17/17 Lighthouse score](https://web.dev/pwa-checklist/).
- Write unit and integration tests with [Vitest](https://vitest.dev/) and [Testing Library](https://testing-library.com/).
- Write e2e tests with [Cypress](https://www.cypress.io).
- GitHub Actions for automatic [dependency updates](https://renovatebot.com/), [CodeQL Analysis](https://securitylab.github.com/tools/codeql), running tests and code coverage with [Codecov](https://about.codecov.io/).
- Deploy to [vercel.com](https://vercel.com/) with pre-configured [SPA fallback](https://vercel.com/docs/configuration#routes/advanced/spa-fallback).## Getting started
Use this repository as a [GitHub template](https://github.com/wtchnm/Vitamin/generate) or use [degit](https://github.com/Rich-Harris/degit) to clone to your machine with an empty git history:
```
npx degit wtchnm/Vitamin#main my-app
```Then, install the dependencies:
```
pnpm install
```### Before you start coding
- [ ] If you don't plan to use GitHub Actions, delete the `.github` directory.
- [ ] Clean up the `cypress/e2e/index.spec.ts` file.
- [ ] Change the `favicon.png`, `apple-touch-icon.png`, `android-chrome-192x192.png` and `android-chrome-512x512.png`. [favicon.io](https://favicon.io) is a cool tool for generating these assets.
- [ ] In the `src` folder, remove the `__tests__`, `api` and `components` folder and the `types.ts` file.
- [ ] If you don't plan to use `react-query`, remove the query client logic in the `main.tsx` file.
- [ ] Change the title, description and theme color in the `index.html` and `vite.config.ts`. The [Inter](https://rsms.me/inter/) font is included, so remove it if you want.
- [ ] Modify or delete the `LICENSE` file.
- [ ] Change the `name` field in package.json.## Scripts
- `pnpm dev` - start a development server with hot reload.
- `pnpm build` - build for production. The generated files will be on the `dist` folder.
- `pnpm preview` - locally preview the production build.
- `pnpm test` - run unit and integration tests related to changed files based on git.
- `pnpm test:ci` - run all unit and integration tests in CI mode.
- `pnpm test:e2e` - run all e2e tests with the Cypress Test Runner.
- `pnpm test:e2e:headless` - run all e2e tests headlessly.
- `pnpm format` - format all files with Prettier.
- `pnpm lint` - runs TypeScript, ESLint and Stylelint.
- `pnpm validate` - runs `lint`, `test:ci` and `test:e2e:ci`.