css-style

master docs · crate info · pipeline · rustc version · unsafe forbidden

This crate provides you a typed CSS style with builder-style methods. See API Docs

NOTE: css-style is not (yet) production ready but is good for use in side projects and internal tools.

Features

Goal

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).

Non-Goal

The Style object is not intended for parsing or retrieving typed values out of it. Conisder using other crate for parsing purpose.

Qucik Example

```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::named::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);