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
use crate::util::*;
use yew::prelude::*;
pub struct Line {}
#[derive(Properties, Clone, PartialEq)]
pub struct LineProps {
#[prop_or_default]
pub class: String,
#[prop_or_default]
pub height: Option<Size>,
#[prop_or_default]
pub vertical: bool,
#[prop_or_default]
pub style: Option<Color>,
#[prop_or_default]
pub width: Option<Size>,
}
impl Component for Line {
type Message = ();
type Properties = LineProps;
fn create(_ctx: &Context<Self>) -> Self {
Self {}
}
fn view(&self, ctx: &Context<Self>) -> Html {
let props = ctx.props();
let mut classes = Classes::new();
if props.vertical {
classes.push("vr");
}
if let Some(style) = props.style.clone() {
classes.push(format!("bg-{}", style));
}
classes.push(props.class.clone());
let mut css = String::new();
if let Some(height) = props.height.clone() {
css = format!("height: {}", height);
}
if let Some(width) = props.width.clone() {
css = format!("{}; width: {}", css, width);
}
if props.vertical {
html! {
<div class={classes} style={css} />
}
} else {
html! {
<hr class={classes} style={css} />
}
}
}
}