This crate provides you a typed CSS style with builder-style methods. See API Docs
NOTE: css-style is not (yet) prodction ready but is good for use in side projects and internal tools.
Length
,
Px
, BorderStyle::None
..etc)The goal for this crate is to provide a Style
object with builder-pattern
methods to build up a CSS inline-style value, thus can be used with/by other
crates that works with styling HTML tags (such as yew
, seed
,
tinytemplate
..etc).
The Style
object is not intended for parsing or retrieving typed values out of
it. Conisder using other crate for parsing purpose.
```rust use css_style::{Style, Color, unit::{ms, px}};
let style = Style::default() .andtransition(|conf| { conf .insert("opacity", |conf| conf.duration(ms(150.)).ease()) .insert("transform", |conf| conf.duration(ms(150.)).ease()) .insert("visibility", |conf| conf.duration(ms(150.)).ease()) }) .andposition(|conf| conf.absolute()) .andbackground(|conf| conf.color(Color::White)) .andborder(|conf| { conf.none() .width(px(0)) .radius(px(4)) }) .andpadding(|conf| conf.x(px(4)).y(px(2))) .andmargin(|conf| conf.top(px(2))) .insert("box-shadow", "0 2px 8px rgba(0, 35, 11, 0.15)");
println!("{}", style); ```
this would print:
css
transition: opacity 150ms ease, transform 150ms ease, visibility 150ms ease;
position: absolute;
background-color: white;
border-left-width: 0px;
border-left-style: none;
border-top-width: 0px;
border-top-style: none;
border-right-width: 0px;
border-right-style: none;
border-bottom-width: 0px;
border-bottom-style: none;
border-top-left-radius: 4px;
border-top-right-radius: 4px;
border-bottom-left-radius: 4px;
border-bottom-right-radius: 4px;
padding-top: 2px;
padding-right: 4px;
padding-bottom: 2px;
padding-left: 4px;
margin-top: 2px;
box-shadow: 0 2px 8px rgba(0, 35, 11, 0.15);