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
use super::*;

/// Global footer option.
#[derive(Default, serde::Deserialize)]
#[serde(default)]
pub struct Footer {
    /// Footer text.
    pub label: String,
    /// Footer link, works on image and text.
    pub link: String,
    /// This item is sized. (*flatten*)
    #[serde(flatten)]
    pub size: Sized,
}

impl ToHtml for Footer {
    fn to_html(self, _ctx: &Ctx) -> String {
        let Self { label, link, size } = self;
        let (src, size) = size.size();
        if src.is_empty() && label.is_empty() {
            return String::new();
        }
        let link = link.wrap("<a href=\"", "\">\n");
        let link_end = if link.is_empty() { "" } else { "</a>\n" };
        let img = src.wrap("<img", &format!("{}/>", size));
        "<div class=\"footer\">\n".to_string()
            + &link
            + &img
            + &label.wrap("<span>&nbsp;", "</span>")
            + link_end
            + "</div>"
    }
}