Classnames

Current Crates.io Version

A lLibrary for generating BEM style classnames, in Rust.

If you don't know BEM, BEM it is a set of naming conventions for CSS names. Please read the DEM guide linked for an explination of the naming conventions.

Using Classnames

With Classnames you import ::classnames::Class, and that is used as the root for creating new classnames.

The crux of using Classnames ...

Calling each of these creates Class types (or similar). These can then be printed, or turned into a string, to retrieve the full class name as a string.

Basic usage example ...

``` use ::classnames::Class;

fn example() { // ".my-component" let base_class = Class::new("my-component");

// ".my-component .my-component--large" let baseclasslarge = base_class.attr("large");

// ".my-component_child-name" let childclass = base_class.el("child-name");

// ".my-componentchild-name .my-componentchild-name--red" let childclassred = child_class.attr("red"); } ```

Example with RSX

Classnames is intended to be used with something else for rendering HTML. For example with the render crate, which is used here.

This is an example for the HTML to a hypothetical TextInput component, which can be optionally disabled.

``` use ::classnames::Class; use ::render::{rsx, Render, component};

#[component] pub fn TextInput( isdisabled: bool, error: &'static str, ) -> impl Render { let baseclass = Class::new("text-input");

rsx! {
  <div
    class={base_class}
  >
    <input class={base_class.el("input").maybe_attr("disabled", is_disabled)} type={"text"} />

    <div class={base_class.el("error")}>
      {error}
    </div>

    <img src={"/input-icon.svg"} class={base_class.el("icon").attr("large")} />
  </div>
}

} ```

Running render( true, &"Some error has occured" ) will produce HTML like ...

```

<div class="text-input__error">
  {"Some error has occured"}
</div>

<img src={"/input-icon.svg"} class="text-input__icon text-input__icon--large" />

```