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.
With Classnames you import ::classnames::Class
, and that is used as the root for creating new 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.
Class::new
for creating a base class..el
on it to generate a child class..attr
to generate the class for that component, and the componnt with an attribute.``` 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"); } ```
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" />
```