Classic
A comprehensive utility library designed to standardize and simplify the management of styles across web application and cache styles. This library facilitates consistent styling, theme management and dynamically combine components styles i.e varient,size.
What's in it?
Picture this: You're a web developer tired of juggling stylesheets like a circus performer with too many flaming torches. Well, grab your virtual wand because we're about to turn that CSS circus into a well-choreographed dance party!
-
Manages all your component or html elements styles in single place.
-
One change of text and POOF! Your entire app's theme changes faster than you can say "abracadabra"
-
No more playing "Find and Replace" across 100 files when your client decides hot pink isn't their brand color anymore.
-
Mix and match variants like you're playing dress-up with your code.
-
"Small", "Large", "Primary", "Secondary" - it's like a fashion show where every component/html elements gets its moment to shine!
-
Toss in a base style, add a pinch of variant magic, sprinkle some size adjustments and Your components/html elements are dressed to impress.
Installation
Install the gem and add to the application's Gemfile by executing:
bundle add classic
If bundler is not being used to manage dependencies, install the gem by executing:
gem install classic
Usage
- Configuration.
-
files
is location of your styles yml. -
raise_error_on_not_found
. Default value isfalse
. If style not found then raise an error. Disable on production environment. i.econfig.raise_error_on_not_found = Rails.env.development?
-
auto_reload_on_change
Rails only flag will reload styles on yaml files changes. Default value isfalse
. Enable in rails development env. i.econfig.auto_reload_on_change = !Rails.env.development?
-
classes_merge_handler
handle custom merging of classes. Default isproc { |classes| classes.join(" ") }
i.etw_class_merge = TailwindMerge::Merger.new proc { |classes| class_merge.merge(classes) }
tw_class_merge = TailwindMerge::Merger.new
Classic.configure do |config|
config.files = Dir["style/**/*.yaml"]
config.raise_error_on_not_found = true
config.auto_reload_on_change = true # For rails only.
config.classes_merge_handler = proc { |classes| tw_class_merge.merge(classes) }
end
-
Rails: Generate config. Default style directory is "style"
./bin/rails g classic:install
Specify style directory
./bin/rails g classic:install app_style
- How to define style using yml.
btn:
base: inline-flex items-center justify-center rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-5
varient:
default: bg-primary text-primary-foreground shadow hover:bg-primary/90
destructive: bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90
outline: border border-input bg-transparent shadow-sm hover:bg-accent hover:text-accent-foreground
secondary: bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80
ghost: hover:bg-accent hover:text-accent-foreground
link: text-primary underline-offset-4 hover:underline
size:
default: h-9 px-4 py-2
sm: h-8 rounded-md px-3 text-xs
lg: h-10 rounded-md px-8
icon: h-9 w-9
default: "(varient.default,size.default)"
card:
<self: rounded-xl border bg-card text-card-foreground shadow
header: flex flex-col space-y-1.5 p-6
title: font-semibold leading-none tracking-tight
description: text-sm text-muted-foreground
content: p-6 pt-0
footer: flex items-center p-6 pt-0
"@aliases":
btn-primary: "btn(varient.outline,size.default)"
- How to use in erb, haml templates or any other templates by calling "to_cls" method on string.
-
Combine options.
btn(varient.outline,size.lg).to_cls
btn(varient.link,size.default).to_cls
-
Default style define in
default
key.btn.to_cls
-
How to use alias?
btn-primary.to_cls
-
<self
- Element has multiple sub component/element style key and want to use parent key as a container.-
card.to_cls
This will use<self
key of card.
-
-
Add custom classes.
btn(varient.outline,size.lg).to_cls("mt-2 px-2")
-
btn.to_cls("mt-2 px-2")
# it will merge classes to btn default syle
-
If you are using Tailwind css then add yaml files to your tailwind config content section. i.e
content: [ "./styles/*.yaml" ],
Development
After checking out the repo, run bin/setup
to install dependencies. Then, run rake test
to run the tests. You can also run bin/console
for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install
. To release a new version, update the version number in version.rb
, and then run bundle exec rake release
, which will create a git tag for the version, push git commits and the created tag, and push the .gem
file to rubygems.org.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/EloquentStudio/classic. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.
License
The gem is available as open source under the terms of the MIT License.
Code of Conduct
Everyone interacting in the Classic project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.