tw-lite
v1.0.0
Published
[data:image/s3,"s3://crabby-images/d4f14/d4f146872adac81153190e7169e4cb5c55cefdde" alt="npm registry"](https://www.npmjs.com/package/tw-lite) [data:image/s3,"s3://crabby-images/cfc35/cfc35c39e7e60d90867b7278f90ded83347cf852" alt="npm bundle size"](https://bundlephobia.com/package/[email protected]) [data:image/s3,"s3://crabby-images/b4e47/b4e47b9aeaf8e98ff0fee647a1ea013fc17b9397" alt="MIT License"`border hover:border-black`
And clone and style existing components:
const PurpleInput = tw(Input)`border-purple-500`
Transient props
You can define transient props that will be passed to the component, you can leverage these props to add dynamic styles:
type Props = {
$isEnabled: boolean;
$variant: "primary" | "secondary";
}
const Button = tw("button")<Props>`
${props => props.$variant === "primary" ? "bg-blue-500" : "bg-gray-500"}
${props => props.$isEnabled ? "cursor-pointer" : "cursor-not-allowed"}
`
<Button $isEnabled $variant="primary">Click me!</Button>
// this will render
<button class="bg-blue-500 cursor-pointer">Click me!</button>
Transient props should be prefixed with $
so they are not passed to HTML tags
to avoid polluting the DOM with extra attributes. However, they are always
forwarded to React components.
Good old CSS
Since tw-lite
doesn't parse the Tailwind classes, it can also be used with any
CSS class, for example regular CSS, CSS Modules or Sass classes.
// .btn and .btn-primary can be defined in a CSS or Sass stylesheet
const Button = tw("button")`btn btn-primary`
import styles from "./Button.module.css"
const Button = tw("button")`${styles.button} text-lg`
See the examples directory for more.
Compatibility with VSCode TailwindCSS extension
To get the best experience with the TailwindCSS Intellisense
extension for VSCode, you can add the following to your settings.json
:
{
"tailwindCSS.experimental.classRegex": [
"tw\\(.*?\\)`([^`]*)" // tw(Component)`...`
]
}
How it works
The tw
function is a tagged template literal that takes a string of Tailwind
classes and returns a component with those classes applied.
Unlike with twin.macro
, you must configure Tailwind as usual to generate the
final stylesheet. This utility will not parse your Tailwind config to generate
styles.
This however has a key benefit as your bundle size will be smaller.
Since tw-lite
doesn't depend on Babel macros, this means it can be used with
any bundler, including Bun, Vite, and esbuild without any additional setup.