website/src/html/wiki.rs

105 lines
2.7 KiB
Rust
Raw Normal View History

2024-04-13 15:26:52 +02:00
use hypertext::{html_elements, maud_move, GlobalAttributes, Renderable};
2024-04-21 23:02:30 +02:00
2024-04-22 21:45:53 +02:00
use crate::{
gen::{Sack, TreePage},
html::page,
md::Wiki,
text::md::Outline
};
2024-04-21 23:02:30 +02:00
fn tree(sack: &Sack) -> impl Renderable {
2024-04-22 21:45:53 +02:00
let tree = sack.get_tree("wiki/**/*.html");
2024-04-13 15:26:52 +02:00
2024-04-21 23:02:30 +02:00
maud_move!(
h2 .link-tree__heading {
// {pages.chain(x => x.prefix)
// .map(pathify)
// .mapOrDefault(href =>
// <a class="link-tree__heading-text" href={href}>{heading}</a>,
// <span class="link-tree__heading-text">{heading}</span>
// )}
}
nav .link-tree__nav {
2024-04-21 23:47:36 +02:00
(list(&tree))
2024-04-21 23:02:30 +02:00
}
)
}
2024-04-22 21:45:53 +02:00
fn list(tree: &TreePage) -> impl Renderable + '_ {
2024-04-21 23:47:36 +02:00
let subs = {
let mut subs: Vec<_> = tree.subs.iter().collect();
subs.sort_by(|a, b| a.0.cmp(b.0));
subs
2024-04-21 23:02:30 +02:00
};
2024-04-21 23:47:36 +02:00
2024-04-21 23:02:30 +02:00
maud_move!(
ul .link-tree__nav-list {
2024-04-21 23:47:36 +02:00
@for (key, next) in subs {
2024-04-21 23:02:30 +02:00
li .link-tree__nav-list-item {
2024-04-21 23:47:36 +02:00
span .link-tree__nav-list-text {
@if let Some(ref link) = next.link {
2024-04-22 21:45:53 +02:00
a .link-tree__nav-list-text.link href=(link.path.as_str()) {
2024-04-21 23:47:36 +02:00
(&link.name)
}
} @else {
span .link-tree__nav-list-text {
(key)
}
}
}
2024-04-22 21:45:53 +02:00
@if !next.subs.is_empty() {
2024-04-21 23:47:36 +02:00
(list(next))
2024-04-21 23:02:30 +02:00
}
}
}
}
)
}
pub fn wiki<'data, 'html, 'sack, T>(
2024-04-21 11:45:19 +02:00
fm: &'data Wiki,
content: T,
2024-04-22 21:45:53 +02:00
_: Outline,
2024-04-21 23:02:30 +02:00
sack: &'sack Sack,
2024-04-21 11:45:19 +02:00
) -> impl Renderable + 'html
2024-04-13 15:26:52 +02:00
where
2024-04-21 23:02:30 +02:00
'sack: 'html,
2024-04-13 15:26:52 +02:00
'data: 'html,
T: Renderable + 'data
{
let main = maud_move!(
main .wiki-main {
// Slide in/out for mobile
input #wiki-aside-shown type="checkbox" hidden;
aside .wiki-aside {
// Slide button
label .wiki-aside__slider for="wiki-aside-shown" {
img .wiki-icon src="/static/svg/double-arrow.svg" width="24" height="24";
}
// Navigation tree
2024-04-21 23:02:30 +02:00
section .link-tree {
div {
(tree(sack))
}
}
2024-04-13 15:26:52 +02:00
}
article .wiki-article /*class:list={classlist)*/ {
header class="markdown" {
h1 #top { (fm.title.clone()) }
}
section .wiki-article__markdown.markdown {
(content)
}
}
}
);
page(&fm.title, main)
}