Monorepo for Tangled tangled.org
5

Configure Feed

Select the types of activity you want to include in your feed.

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 }}