summaryrefslogtreecommitdiff
path: root/view/timer.templ
blob: 76bd7ba0263753de885249705cbc715d5df29d0c (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
package view

import (
	"fmt"
	"stevenlr.com/timer/model"
)

templ TimerTokenForm(timer model.Timer) {
	<p class="token-form">
		<button
			type="button"
			hx-post={ fmt.Sprint("/timer/", timer.Id, "/resetToken") }
			hx-target="closest .token-form"
			hx-confirm="Are you sure you want to reset the token for this timer?"
		>Reset token</button>
		<button
			type="button"
			hx-get={ fmt.Sprint("/timer/", timer.Id, "/token") }
			hx-swap="outerHTML"
		>Show token</button>
	</p>
}

templ TimerView(timer model.Timer) {
	<div class="timer">
		<h1>Timer "{ timer.Name }"</h1>
		<p><a href="/">Back to list</a></p>
		<p>Start time: <local-date>{ timer.StartTime.AsUTCString() }</local-date></p>
		<p>End time: <local-date>{ timer.EndTime.AsUTCString() }</local-date></p>
		<p>
			Total time:
			<timer-countdown
				start={ timer.StartTime.AsUTCString() }
				end={ timer.EndTime.AsUTCString() }
			></timer-countdown>
		</p>
		<p>
			Remaining time:
			<timer-countdown
				end={ timer.EndTime.AsUTCString() }
			></timer-countdown>
		</p>
		if !timer.IsFinished() {
			<h3>Add time</h3>
			<p>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/15m") }>15 minutes</button>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/30m") }>30 minutes</button>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/1h") }>1 hour</button>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/2h") }>2 hours</button>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/6h") }>6 hours</button>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/12h") }>12 hours</button>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/1d") }>1 day</button>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/1w") }>1 week</button>
				<button hx-target="closest .timer" hx-post={ fmt.Sprint("/timer/", timer.Id, "/addTime/4w") }>4 weeks</button>
			</p>
		}
		<h3>API token</h3>
		@TimerTokenForm(timer)
	</div>
}