@cw-dbhingradiya/component-library
v3.2.8
Published
React component library (Sidebar, etc.) built with TypeScript and Vite.
Readme
Component Library
React component library (Sidebar, etc.) built with TypeScript and Vite.
Using this library in another repo
Install
npm install @cw-dbhingradiya/component-libraryImport components and types
import { Sidebar, type SidebarTab, type TabId, } from "@cw-dbhingradiya/component-library";Import styles (required for Tailwind styles)
import "@cw-dbhingradiya/component-library/style.css"; // or import "@cw-dbhingradiya/component-library/dist/style.css";Example usage
const tabs: SidebarTab[] = [ { id: "home", label: "Home" }, { id: "settings", label: "Settings" }, ]; <Sidebar tabs={tabs} activeTabId="home" onTabClick={(id) => setActiveTabId(id)} />;
The consuming app must have react and react-dom installed (peer dependencies).
Publishing to npm
- Build: Run
npm run build:lib(also runs automatically onnpm publishviaprepublishOnly). - Login:
npm login(one-time). - Publish:
npm publish
After publishing, consumers can install with:
npm install @cw-dbhingradiya/component-library
Development (this repo)
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 (or oxc when used in rolldown-vite) for Fast Refresh
- @vitejs/plugin-react-swc uses SWC for Fast Refresh
React Compiler
The React Compiler is not enabled on this template because of its impact on dev & build performances. To add it, see this documentation.
Expanding the ESLint configuration
If you are developing a production application, we recommend updating the configuration to enable type-aware lint rules:
export default defineConfig([
globalIgnores(["dist"]),
{
files: ["**/*.{ts,tsx}"],
extends: [
// Other configs...
// Remove tseslint.configs.recommended and replace with this
tseslint.configs.recommendedTypeChecked,
// Alternatively, use this for stricter rules
tseslint.configs.strictTypeChecked,
// Optionally, add this for stylistic rules
tseslint.configs.stylisticTypeChecked,
// Other configs...
],
languageOptions: {
parserOptions: {
project: ["./tsconfig.node.json", "./tsconfig.app.json"],
tsconfigRootDir: import.meta.dirname,
},
// other options...
},
},
]);You can also install eslint-plugin-react-x and eslint-plugin-react-dom for React-specific lint rules:
// eslint.config.js
import reactX from "eslint-plugin-react-x";
import reactDom from "eslint-plugin-react-dom";
export default defineConfig([
globalIgnores(["dist"]),
{
files: ["**/*.{ts,tsx}"],
extends: [
// Other configs...
// Enable lint rules for React
reactX.configs["recommended-typescript"],
// Enable lint rules for React DOM
reactDom.configs.recommended,
],
languageOptions: {
parserOptions: {
project: ["./tsconfig.node.json", "./tsconfig.app.json"],
tsconfigRootDir: import.meta.dirname,
},
// other options...
},
},
]);