π A powerful, lightweight core library to transform CSS styles or style objects into Tailwind CSS utility classes. Perfect for migration projects and dynamic style generation.
- π Bidirectional Conversion: Transform CSS styles to Tailwind CSS classes
- π― Smart Parsing: Handles complex CSS properties and vendor prefixes
- π± Responsive Support: Converts responsive CSS to Tailwind breakpoints
- π§© TypeScript First: Full TypeScript support with type definitions
- πͺΆ Lightweight: Zero dependencies, optimized for performance
- π Browser Compatible: Works in both Node.js and browser environments
- π Debug Mode: Built-in debugging for troubleshooting conversions
# npm
npm install transform-to-tailwindcss-core
# yarn
yarn add transform-to-tailwindcss-core
# pnpm
pnpm add transform-to-tailwindcss-core
import { transformStyleToTailwindcss } from 'transform-to-tailwindcss-core'
// Basic usage
const [tailwindClasses, unconverted] = transformStyleToTailwindcss(
'color: red; font-size: 16px; margin: 10px'
)
console.log(tailwindClasses) // "text-red-500 text-base m-2.5"
console.log(unconverted) // [] (empty if all styles converted)
// With rem units
const [classes, unconverted] = transformStyleToTailwindcss(
'padding: 8px; background-color: #3b82f6',
true // enable rem conversion
)
// With debug mode
const [classes, unconverted] = transformStyleToTailwindcss(
'display: flex; justify-content: center',
false, // rem conversion
true // debug mode - shows conversion process
)
Converts CSS styles to Tailwind CSS utility classes.
styles
(string): CSS styles to convert (e.g., "color: red; font-size: 16px")isRem
(boolean, optional): Whether to convert pixel values to rem unitsdebug
(boolean, optional): Enable debug logging to see conversion process
Returns a tuple [string, string[]]
:
- First element: Converted Tailwind CSS classes as a string
- Second element: Array of unconverted CSS styles
This library supports a wide range of CSS properties including:
- Layout:
display
,position
,top
,right
,bottom
,left
- Flexbox:
flex
,flex-direction
,justify-content
,align-items
- Grid:
grid
,grid-template-columns
,grid-template-rows
- Spacing:
margin
,padding
,gap
- Sizing:
width
,height
,max-width
,min-height
- Typography:
font-size
,font-weight
,text-align
,line-height
- Colors:
color
,background-color
,border-color
- Borders:
border
,border-width
,border-radius
- Effects:
box-shadow
,opacity
,transform
- And many more...
Enable debug mode to see detailed conversion logs:
const [classes, unconverted] = transformStyleToTailwindcss(
'color: #ff0000; font-size: 18px; margin-top: 20px',
false,
true // debug mode
)
// Console output:
// π [DEBUG] Input styles: color: #ff0000; font-size: 18px; margin-top: 20px
// π [DEBUG] Processing style: color: #ff0000 -> key: color: #ff0000
// π [DEBUG] Converted to Tailwind: color: #ff0000 -> text-red-500
// π [DEBUG] Processing style: font-size: 18px -> key: font-size: 18px
// π [DEBUG] Converted to Tailwind: font-size: 18px -> text-lg
// ...
const [classes, unconverted] = transformStyleToTailwindcss(
'color: red; custom-property: value; font-size: 16px'
)
console.log(classes) // "text-red-500 text-base"
console.log(unconverted) // ["custom-property: value"]
// You can combine them for fallback
const finalStyles = unconverted.length > 0
? `${classes} [&]:${unconverted.join('; ')}`
: classes
- Legacy Code Migration: Convert existing CSS to Tailwind CSS
- Dynamic Styling: Generate Tailwind classes from user input
- Design Tools: Build CSS-to-Tailwind converters
- Component Libraries: Transform inline styles to utility classes
- Development Tools: Create IDE extensions or build plugins
We welcome contributions! Please see our Contributing Guide for details.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add some amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
If this project helped you, please consider: