Support Tailwindcss V4
This is an npm package that exports all shadcn/ui components without the need for a CLI, designed for ease of use.
It simply provides all useful files along with type declarations.
Weekly publish latest version components to npm.
- Create a new react project.
- Get started with Tailwind CSS.
npm i class-variance-authority clsx tailwind-merge lucide-react tw-animate-css
npm i shadcn-packagedFor nextjs user, next.config.js
const nextConfig = {
// ...
transpilePackages: ["shadcn-packaged"],
};
export default nextConfig;For vite user, vite.config.js
export default defineConfig({
optimizeDeps: {
include: ['shadcn-packaged/**/*.{js,jsx,ts,tsx}'],
},
})Import default style
If you have a fully customized style in global entry css file, see Custom Theme.
The global entry css file, index.css | global.css
/* "shadcn-packaged/index.css" includes `@import "tailwindcss"` */
@import "shadcn-packaged/index.css";
/* source detection, according to the actual path specified */
@source "../node_modules/shadcn-packaged";Import code
import { Button } from 'shadcn-packaged/ui/button';
import { cn } from 'shadcn-packaged/lib/utils';
import { useToast } from 'shadcn/hooks/use-toast';Package Struct
- shadcn-packaged/ui/*: components
- shadcn-packaged/hooks/*: hooks
- shadcn-packaged/lib/utils: utils
This package support vscode auto import.
If the automatic code import does not take effect, please try the following methods.
- add below code to project main.tsx or root layout.tsx in NextJS.
/// <reference types="shadcn-packaged" />- change tsconig.json
{
"compilerOptions": {
// append to exist types
"types": ["...", "./node_modules/shadcn-packaged/**/*.ts"]
}
}The global entry css file, index.css | global.css, more detail see shadcn theme
/* "shadcn-packaged/index.css" includes `@import "tailwindcss"` */
@import "shadcn-packaged/index.css";
/* source detection, according to the actual path specified */
@source "../node_modules/shadcn-packaged";
@custom-variant dark (&:is(.dark *));
:root {
...
}
.dark {
...
}
@theme inline {
...
}
@layer base {
...
}MIT anuoua