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
86
87
88
use std::borrow::BorrowMut;
use html_escape::encode_text;
use crate::{DefaultModifiers, Renderable};
use crate::node::{Node, NodeContainer};
#[derive(Debug, Clone)]
pub enum TextStyle {
LargeTitle,
H1,
H2,
H3,
Headline,
Subtitle1,
Subtitle2,
Subtitle3,
Body,
Article,
Button,
Label,
Overline,
Caption,
}
#[derive(Debug, Clone)]
pub struct Text {
node: Node,
pub content: String,
pub style: TextStyle,
pub no_wrap: bool,
pub encode_text: bool,
}
impl Text {
pub fn new(content: &str, style: TextStyle) -> Self {
Text {
node: Node::default(),
content: content.to_string(),
style,
no_wrap: false,
encode_text: true,
}
}
pub fn bold(&mut self, is_bold: bool) -> Self {
if is_bold {
self.get_node().node_style.push(("font-weight".to_string(), "bold".to_string()));
} else {
self.get_node().node_style.push(("font-weight".to_string(), "normal".to_string()));
}
self.clone()
}
pub fn no_wrap(&mut self, is_no_wrap: bool) -> Self {
self.no_wrap = is_no_wrap;
self.clone()
}
pub fn disable_purification(&mut self) -> Self {
self.encode_text = false;
self.clone()
}
}
impl NodeContainer for Text {
fn get_node(&mut self) -> &mut Node {
self.node.borrow_mut()
}
}
impl DefaultModifiers<Text> for Text {}
impl Renderable for Text {
fn render(&self) -> Node {
let mut text = self.clone()
.add_class("text")
.add_class(format!("text--{:?}", self.style).to_lowercase().as_str());
if self.encode_text {
text.node.text = Some(encode_text(&self.content).to_string());
} else {
text.node.text = Some(self.content.to_string());
}
if self.no_wrap {
text.add_class("text--nowrap");
}
text.node
}
}