This repository was published together with an article on how to create a react component library using Vite's library mode.
Here is another repo that consumes this libarary: https://github.com/receter/my-component-library-consumer
The demo library on npm: https://www.npmjs.com/package/@receter/my-component-library
You can install it with npm (don't expect much fanciness):
npm i @receter/my-component-library
import { Button, Label, Input } from '@receter/my-component-library';
See this file for an example on using this library: https://github.com/receter/my-component-library-consumer/blob/main/src/App.tsx
This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.
Currently, two official plugins are available:
- @vitejs/plugin-react uses Babel for Fast Refresh
- @vitejs/plugin-react-swc uses SWC for Fast Refresh
If you are developing a production application, we recommend updating the configuration to enable type aware lint rules:
- Configure the top-level
parserOptions
property like this:
parserOptions: {
ecmaVersion: 'latest',
sourceType: 'module',
project: ['./tsconfig.json', './tsconfig.node.json'],
tsconfigRootDir: __dirname,
},
- Replace
plugin:@typescript-eslint/recommended
toplugin:@typescript-eslint/recommended-type-checked
orplugin:@typescript-eslint/strict-type-checked
- Optionally add
plugin:@typescript-eslint/stylistic-type-checked
- Install eslint-plugin-react and add
plugin:react/recommended
&plugin:react/jsx-runtime
to theextends
list