css-loader-macros

Crates.iocss-loader-macros
lib.rscss-loader-macros
version0.0.1
sourcesrc
created_at2022-08-18 10:15:26.67842
updated_at2022-08-18 10:15:26.67842
descriptionA simple macro to include style files in Rust using CSS Modules-like scoping
homepage
repository
max_upload_size
id648077
size8,526
Martin E. Zulliger (thepeak99)

documentation

README

rust-css-loader

A simple macro to include style files in Rust using CSS Modules-like scoping.

Example

main.rs:

use yew::prelude::*;

import_style!("src/styles.scss");

#[function_component(App)]
fn app() -> Html {
    html! {
        <h1 class={styles.header}>{ "Hello World" }</h1>
    }
}

fn main() {
    println!("Hello, world!");
    yew::start_app::<App>();
}

styles.scss

$textcolor: yellow;
$fontsize: 18px;

.header {
  color: $textcolor;
  font-size: $fontsize;
}

Notes

Styles are imported relative to CARGO_MANIFEST_DIR, basically the directory that contains the Cargo.toml file. It would be nice to do relative path imports like in Javascript, however, due to a little limitation in the Rust compiler, this can't be done right now.

Secondly, the same limitation prevents us from having a way to "link" the style file to the Rust source file, hence modifying the style files won't trigger a rebuild/reload.

These both issues be addressed after this API is stabilized in the Rust compiler.

.css files are imported directly and .scss are compiled with rsass and loaded automatically.

Commit count: 0

cargo fmt