Monorepo for Tangled
tangled.org
1{{ define "title" }}The Tangled Blog{{ end }}
2
3{{ define "extrameta" }}
4<meta name="description" content="The Tangled Blog" />
5<link rel="alternate" type="application/atom+xml" title="Atom" href="/feed.xml" />
6{{ end }}
7
8<!-- overrides the default slate bg -->
9{{ define "bodyClasses" }}!bg-white dark:!bg-gray-900{{ end }}
10
11{{ define "topbarLayout" }}
12 {{ template "blog/fragments/topbar" . }}
13{{ end }}
14
15{{ define "content" }}
16<div class="max-w-screen-lg mx-auto w-full px-4 py-10">
17
18 <header class="mb-10 text-center">
19 <h1 class="text-3xl font-bold dark:text-white mb-2">The Tangled Blog</h1>
20 <h2 class="text-lg text-gray-500 dark:text-gray-400">All the ropes and scaffolding.</h2>
21 </header>
22
23 {{ if .Featured }}
24 <div class="grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 gap-6 mb-14">
25 {{ range .Featured }}
26 <a href="/{{ .Meta.Slug }}" class="no-underline hover:no-underline group flex flex-col bg-white dark:bg-gray-800 rounded border border-gray-200 dark:border-gray-700 overflow-hidden hover:bg-gray-100/25 hover:dark:bg-gray-700/25 transition-colors">
27 <div class="overflow-hidden bg-gray-100 dark:bg-gray-700 md:h-48">
28 <img src="{{ .Meta.Image }}" alt="{{ .Meta.Title }}" class="w-full h-full object-cover group-hover:scale-[1.02] transition-transform duration-300" />
29 </div>
30 <div class="flex flex-col flex-1 px-5 py-4">
31 <div class="text-xs text-gray-400 dark:text-gray-500 mb-2">
32 {{ $date := .ParsedDate }}{{ $date | shortTimeFmt}}
33 {{ if .Meta.Draft }}<span class="text-red-500">[draft]</span>{{ end }}
34 </div>
35 <h2 class="font-bold text-gray-900 dark:text-white text-base leading-snug mb-1">{{ .Meta.Title }}</h2>
36 <p class="text-sm text-gray-500 dark:text-gray-400 line-clamp-2 flex-1">{{ .Meta.Subtitle }}</p>
37 <div class="flex items-center mt-4 gap-2">
38 {{ $hasAvatar := false }}{{ range .Meta.Authors }}{{ if tinyAvatar .Handle }}{{ $hasAvatar = true }}{{ end }}{{ end }}
39 {{ if $hasAvatar }}
40 <div class="inline-flex items-center -space-x-2">
41 {{ range .Meta.Authors }}
42 {{ $av := tinyAvatar .Handle }}{{ if $av }}<img src="{{ $av }}" class="size-6 rounded-full border border-gray-300 dark:border-gray-700" alt="{{ .Name }}" title="{{ .Name }}" />{{ end }}
43 {{ end }}
44 </div>
45 {{ end }}
46 <div class="text-xs">
47 {{ $last := sub (len .Meta.Authors) 1 }}
48 {{ range $i, $n := .Meta.Authors }}
49 {{ $n.Handle }}{{ if ne $i $last }}, {{ end }}
50 {{ end }}
51 </div>
52 </div>
53 </div>
54 </a>
55 {{ end }}
56 </div>
57 {{ end }}
58
59 <div class="grid grid-cols-1 rounded border border-gray-200 dark:border-gray-700 divide-y divide-gray-200 dark:divide-gray-700">
60 {{ range .Posts }}
61 <a href="/{{ .Meta.Slug }}" class="no-underline hover:no-underline group flex items-center justify-between gap-4 px-6 py-3 hover:bg-gray-100/25 hover:dark:bg-gray-700/25 transition-colors">
62 <div class="flex items-center gap-3 min-w-0">
63 <span class="font-medium text-gray-900 dark:text-white truncate">
64 {{ .Meta.Title }}
65 {{ if .Meta.Draft }}<span class="text-red-500 text-xs font-normal ml-1">[draft]</span>{{ end }}
66 </span>
67 </div>
68 <div class="flex items-center gap-2">
69 <div class="inline-flex items-center -space-x-2 shrink-0">
70 {{ range .Meta.Authors }}
71 <img src="{{ tinyAvatar .Handle }}" class="size-5 rounded-full border border-gray-300 dark:border-gray-700" alt="{{ .Name }}" title="{{ .Name }}" />
72 {{ end }}
73 </div>
74 <div class="text-sm text-gray-400 dark:text-gray-500 shrink-0">
75 {{ $date := .ParsedDate }}{{ $date | shortTimeFmt }}
76 </div>
77 </div>
78 </a>
79 {{ end }}
80 </div>
81
82</div>
83{{ end }}
84
85{{ define "footerLayout" }}{{ template "blog/fragments/footer" . }}{{ end }}