1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
//! Badge
use yew::prelude::*;

/// Properties for [`Badge`]
#[derive(Clone, PartialEq, Properties)]
pub struct BadgeProperties {
    /// Optional Attributes
    #[prop_or_default]
    pub children: Html,
    #[prop_or_default]
    pub class: Classes,
    #[prop_or_default]
    pub read: bool,
    #[prop_or_default]
    pub screen_reader_text: AttrValue,
}

/// Badge component
///
/// > A **badge** is used to annotate other information like a label or an object name.
///
/// See: <https://www.patternfly.org/components/badge>
///
/// ## Properties
///
/// Defined by [`BadgeProperties`].
#[function_component(Badge)]
pub fn badge(props: &BadgeProperties) -> Html {
    let mut class = classes!("pf-v5-c-badge");
    if props.read {
        class.push("pf-m-read");
    } else {
        class.push("pf-m-unread");
    }
    class.extend(props.class.clone());
    html! {
        <span {class}>
            { props.children.clone() }
            if !props.screen_reader_text.is_empty() {
                <span class="pf-v5-u-screen-reader">{ props.screen_reader_text.clone() }</span>
            }
        </span>
    }
}