Skip to main content

dioxus_bootstrap_css/
icon.rs

1use dioxus::prelude::*;
2
3/// Bootstrap Icon component.
4///
5/// Renders a Bootstrap Icon by name. See https://icons.getbootstrap.com/ for available icons.
6///
7/// ```rust
8/// rsx! {
9///     Icon { name: "search" }
10///     Icon { name: "shield-lock", class: "me-2 fs-4" }
11/// }
12/// ```
13#[derive(Clone, PartialEq, Props)]
14pub struct IconProps {
15    /// Icon name without the `bi-` prefix (e.g., "search", "shield-lock").
16    pub name: String,
17    /// Additional CSS classes.
18    #[props(default)]
19    pub class: String,
20}
21
22#[component]
23pub fn Icon(props: IconProps) -> Element {
24    let icon_class = if props.class.is_empty() {
25        format!("bi bi-{}", props.name)
26    } else {
27        format!("bi bi-{} {}", props.name, props.class)
28    };
29    rsx! {
30        i { class: "{icon_class}" }
31    }
32}