summaryrefslogtreecommitdiff
path: root/src/index/templates.rs
blob: d56972c060cd3321f329b50a10de46fae16e22a6 (plain)
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
use maud::{html, Markup, DOCTYPE};

use crate::repo::{channel::Channel, login::Login};

pub fn authenticated<'c>(login: Login, channels: impl IntoIterator<Item = &'c Channel>) -> Markup {
    html! {
        (DOCTYPE)
        head {
            title { "hi" }
        }
        body {
            section {
                (channel_list(channels))
                (create_channel())
            }
            section {
                (logout_form(&login.name))
            }
        }
    }
}

fn channel_list<'c>(channels: impl IntoIterator<Item = &'c Channel>) -> Markup {
    html! {
        ul {
            @for channel in channels {
                (channel_list_entry(&channel))
            }
        }
    }
}

fn channel_list_entry(channel: &Channel) -> Markup {
    html! {
        li {
            a href=(format!("/{}", channel.id)) {
                (channel.name) " (" (channel.id) ")"
            }
        }
    }
}

fn create_channel() -> Markup {
    html! {
        form action="/create" method="post" {
            label {
                "name"
                input name="name" type="text" {}
            }
            button {
                "start channel"
            }
        }
    }
}

fn logout_form(name: &str) -> Markup {
    html! {
        form action="/logout" method="post" {
            button { "bye, " (name) }
        }
    }
}

pub fn unauthenticated() -> Markup {
    html! {
        (DOCTYPE)
        head {
            title { "hi" }
        }
        body {
            (login_form())
        }
    }
}

fn login_form() -> Markup {
    html! {
        form action="/login" method="post" {
            label {
                "login"
                input name="name" type="text" {}
            }
            label {
                "password"
                input name="password" type="password" {}
            }
            button { "hi" }
        }
    }
}

pub fn channel(channel: &Channel) -> Markup {
    html! {
        (DOCTYPE)
        head {
            title { "hi - " (channel.name) }
            script src="/js/channel.js" {}
            template id="message" {
                p {
                    span.sender { "(sender)" }
                    ": "
                    span.message { "(message)" }
                    " (at "
                    span.sent_at { "(sent_at)" }
                    ")" }
            }
            meta name="channel" content=(channel.id) {}
            link rel="events" href=(format!("/events?channel={}", channel.id)) {}
        }
        body {
            section class="messages" {}
            section {
                form action=(format!("/{}/send", channel.id)) method="post" {
                    label {
                        "message"
                        input name="message" type="text" autofocus {}
                    }
                    button { "send" }
                }
            }
            section {
                a href="/" { "back" }
            }
        }
    }
}