If you've been around for long enough, you've probably seen every other way to organize CSS: from writing it on the go to the emergence of frameworks

Component variants with the "class_variants" gem

submited by
Style Pass
2025-01-21 10:30:02

If you've been around for long enough, you've probably seen every other way to organize CSS: from writing it on the go to the emergence of frameworks like Bootstrap or the use of organizational methodologies to improve maintainability.

Every one of them had their pros and cons, but the advent and rise to popularity of Tailwind proved that utility-first CSS is generally more convenient for the average developer.

But, the number of classes needed to style a component is generally large, so rendering them conditionally makes reading and understanding what's happening a bit difficult.

Utility-first frameworks like Tailwind are remarkable, but they require us to define numerous classes to achieve our styling goals.

That's even more problematic if we want to introduce versatility into our components: now we have to introduce helpers, decorators or pollute our views with conditionals.

This is a valid way of achieving the feature, but as soon as we start adding more options, like size or roundness, things can get out of control pretty quickly.

Leave a Comment