Install TailwindBox via npm or yarn:
npm install tailwindbox
# or
yarn add tailwindbox
Here's a quick example of how to use TailwindBox:
import { tw } from "tailwindbox";
function App() {
const isDarkMode = true;
const styles = tw({
base: "p-4 rounded-lg shadow-md",
dark: { if: isDarkMode, classes: "bg-gray-800 text-white" },
light: { if: !isDarkMode, classes: "bg-white text-black" },
});
return <div className={styles}>Hello, TailwindBox!</div>;
}
export default App;
base
: Always applies the base styles (p-4 rounded-lg shadow-md
).dark
: Appliesbg-gray-800 text-white
only ifisDarkMode
is true.light
: Appliesbg-white text-black
only ifisDarkMode
is false.
- Object-Like Structure: Define TailwindCSS styles in an object-based format.
- Conditional Classes: Apply classes dynamically based on your application's state.
- Improved Readability: Simplify long and complex class strings.
- Lightweight: A minimal library designed for TailwindCSS users.
tw(config: StyleConfig): string
Parameters:
config
: An object where keys define style groups, and values are either:- A string of TailwindCSS classes (always applied).
- An object with
if
andclasses
for conditional application.
Returns:
- A single string with the resulting TailwindCSS classes.
Example
const styles = tw({
base: "p-4 rounded-lg shadow-md",
dark: { if: isDarkMode, classes: "bg-gray-800 text-white" },
light: { if: !isDarkMode, classes: "bg-white text-black" },
});
- Readable: No more unreadable, long
className
strings. - Reusable: Encapsulate style logic in objects for easier maintenance.
- Dynamic: Apply styles conditionally without cluttering your JSX.
Contributions are welcome! If you have ideas, bug fixes, or feature requests, feel free to open an issue or submit a pull request.
This project is licensed under the MIT License.