Recast Tailwind CSS Integration
Recast offers seamless integration with Tailwind CSS through our dedicated plugin, enhancing your development experience and unlocking powerful styling capabilities.
Installation
First, install the Recast Tailwind plugin:
npm install @rpxl/recast-tailwind-plugin
Setup
If you're using Tailwind CSS, add the Recast plugin to your
tailwind.config.js
:
module.exports = {
// ...other config
plugins: [require("@rpxl/recast-tailwind-plugin")],
};
This step is necessary if you're using Tailwind CSS and want to leverage the Recast Tailwind plugin's features.
What the Tailwind CSS Integration Provides:
-
Automatic Safelist Generation: The plugin automatically generates a safelist for your Recast components based on the breakpoints specified in your component definitions. This ensures that all Tailwind classes used in your Recast components are included in your production build, even if they aren't explicitly used in your templates.
-
Responsive Styling: The plugin enables responsive styling for Recast components using Tailwind's responsive syntax. Responsive component features are opt-in on a per-component basis. For example:
const Button = recast(ButtonPrimitive, {
variants: {
size: {
sm: "px-2 py-1 text-sm",
md: "px-4 py-2 text-base",
lg: "px-6 py-3 text-lg",
},
},
// Only allow these breakpoints to be
// used within the button component
breakpoints: ["sm", "md", "lg"],
});
<Button size={{ default: "sm", md: "md", lg: "lg" }}>Responsive Button</Button>;
Will generate the following classes:
<button
class="px-2 py-1 text-sm md:px-4 md:py-2 md:text-base lg:px-6 lg:py-3 lg:text-lg"
>
Responsive Button
</button>
Use responsive styles carefully. Specified breakpoints will automatically generate and add the corresponding classes to Tailwind, whether they're used or not. This is due to how Tailwind CSS statically analyzes classes during build time. For more details, see the Tailwind CSS documentation (opens in a new tab).
- Better Integration: The plugin ensures that Recast and Tailwind work together smoothly, allowing you to fully leverage both libraries' capabilities in your project.
This integration significantly enhances the developer experience when using Recast with Tailwind CSS, offering increased flexibility and efficiency in styling components.
VS Code Setup
To get Tailwind CSS IntelliSense working with Recast in VS Code:
-
Install the Tailwind CSS IntelliSense (opens in a new tab) VS Code extension.
-
Add the following to your
.vscode/settings.json
:
{
"tailwindCSS.experimental.classRegex": [
["recast\\(([^)]*)\\)", "[\"'`]([^\"'`]*).*?[\"'`]"]
]
}
Prettier Integration
Recast works seamlessly with the
prettier-plugin-tailwindcss (opens in a new tab).
Add the following to your .prettierrc
:
{ "tailwindFunctions": ["recast"] }
This ensures that your Tailwind classes within Recast components are properly sorted.
data:image/s3,"s3://crabby-images/c93df/c93df63b6f7c2492f981ef027d4cd803a5623719" alt="Tailwind CSS VS Code Intellisense"
Troubleshooting
If you encounter any issues with the Tailwind CSS integration:
- Ensure you've installed both
@rpxl/recast
and@rpxl/recast-tailwind-plugin
. - Verify that the Recast Tailwind plugin is correctly added to your
tailwind.config.js
. - Check that your VS Code settings are correctly configured for Tailwind CSS IntelliSense.
- Clear your build cache and restart your development server.