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 {
AngleDown,
AngleLeft,
AngleRight,
AngleUp,
Bell,
CheckCircle,
Copy,
Cubes,
ExclamationCircle,
ExclamationTriangle,
ExternalLinkAltIcon,
InfoCircle,
PlusCircleIcon,
Times,
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()
}
}