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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
use yew::prelude::*;
use yew::virtual_dom::VNode;

#[derive(Copy, Clone, Debug, PartialEq, Eq)]
pub enum Icon {
    // Font Awesome
    AngleDown,
    AngleLeft,
    AngleRight,
    AngleUp,

    Bell,

    CheckCircle,
    Copy,
    Cubes,

    ExclamationCircle,
    ExclamationTriangle,
    ExternalLinkAltIcon,

    InfoCircle,

    PlusCircleIcon,

    Times,

    // Patternfly
    Help,
    Pending,
}

impl Icon {
    pub fn as_html(&self) -> Html {
        self.with_classes(Classes::new())
    }

    pub fn with_classes(&self, classes: Classes) -> Html {
        let icon_classes = match self {
            Icon::AngleDown => fa("fa-angle-down"),
            Icon::AngleLeft => fa("fa-angle-left"),
            Icon::AngleRight => fa("fa-angle-right"),
            Icon::AngleUp => fa("fa-angle-up"),

            Icon::Bell => fa("fa-bell"),

            Icon::CheckCircle => fa("fa-check-circle"),
            Icon::Copy => fa("fa-copy"),
            Icon::Cubes => fa("fa-cubes"),

            Icon::ExclamationCircle => fa("fa-exclamation-circle"),
            Icon::ExclamationTriangle => fa("fa-exclamation-triangle"),
            Icon::ExternalLinkAltIcon => fa("fa-external-link-alt"),

            Icon::InfoCircle => fa("fa-info-circle"),

            Icon::PlusCircleIcon => fa("fa-plus-circle"),
            Icon::Times => fa("fa-times"),

            Icon::Help => pf("pf-icon-help"),
            Icon::Pending => pf("pf-icon-pending"),
        };

        html! {
            <i class=(icon_classes, classes) aria-hidden="true"></i>
        }
    }
}
fn fa(name: &str) -> Classes {
    let mut classes = Classes::from("fas");
    classes.push(name);
    classes
}

fn pf(name: &str) -> Classes {
    let mut classes = Classes::from("pficon");
    classes.push(name);
    classes
}

impl From<Icon> for VNode {
    fn from(icon: Icon) -> Self {
        icon.as_html()
    }
}