forked from tangled.org/core
Monorepo for Tangled — https://tangled.org
at master 5.3 kB view raw
1{{ define "title" }}{{ .Path }} at {{ .Ref }} &middot; {{ .RepoInfo.FullName }}{{ end }} 2 3{{ define "extrameta" }} 4 {{ template "repo/fragments/meta" . }} 5 6 {{ $title := printf "%s at %s &middot; %s" .Path .Ref .RepoInfo.FullName }} 7 {{ $url := printf "https://tangled.org/%s/blob/%s/%s" .RepoInfo.FullName .Ref .Path }} 8 9 {{ template "repo/fragments/og" (dict "RepoInfo" .RepoInfo "Title" $title "Url" $url) }} 10 11{{ end }} 12 13{{ define "repoContent" }} 14 {{ $linkstyle := "no-underline hover:underline" }} 15 <div class="pb-2 mb-3 text-base border-b border-gray-200 dark:border-gray-700"> 16 <div class="flex flex-col md:flex-row md:justify-between gap-2"> 17 <div id="breadcrumbs" class="overflow-x-auto whitespace-nowrap text-gray-400 dark:text-gray-500"> 18 {{ range $idx, $value := .BreadCrumbs }} 19 {{ if ne $idx (sub (len $.BreadCrumbs) 1) }} 20 <a 21 href="{{ index . 1 }}" 22 class="text-bold text-gray-500 dark:text-gray-400 {{ $linkstyle }}" 23 >{{ pathUnescape (index . 0) }}</a 24 > 25 / 26 {{ else }} 27 <span class="text-bold text-black dark:text-white" 28 >{{ pathUnescape (index . 0) }}</span 29 > 30 {{ end }} 31 {{ end }} 32 </div> 33 <div id="file-info" class="text-gray-500 dark:text-gray-400 text-xs md:text-sm flex flex-wrap items-center gap-1 md:gap-0"> 34 <span>at <a href="/{{ .RepoInfo.FullName }}/tree/{{ .Ref }}">{{ .Ref }}</a></span> 35 36 {{ if .BlobView.ShowingText }} 37 <span class="select-none px-1 md:px-2 [&:before]:content-['·']"></span> 38 <span>{{ .Lines }} lines</span> 39 {{ end }} 40 41 {{ if .BlobView.SizeHint }} 42 <span class="select-none px-1 md:px-2 [&:before]:content-['·']"></span> 43 <span>{{ byteFmt .BlobView.SizeHint }}</span> 44 {{ end }} 45 46 {{ if .BlobView.HasRawView }} 47 <span class="select-none px-1 md:px-2 [&:before]:content-['·']"></span> 48 <a href="/{{ .RepoInfo.FullName }}/raw/{{ .Ref }}/{{ .Path }}">view raw</a> 49 {{ end }} 50 51 {{ if .BlobView.ShowToggle }} 52 <span class="select-none px-1 md:px-2 [&:before]:content-['·']"></span> 53 <a href="/{{ .RepoInfo.FullName }}/blob/{{ .Ref }}/{{ .Path }}?code={{ .BlobView.ShowingRendered }}" hx-boost="true"> 54 view {{ if .BlobView.ShowingRendered }}code{{ else }}rendered{{ end }} 55 </a> 56 {{ end }} 57 </div> 58 </div> 59 </div> 60 {{ if .BlobView.IsUnsupported }} 61 <p class="text-center text-gray-400 dark:text-gray-500"> 62 Previews are not supported for this file type. 63 </p> 64 {{ else if .BlobView.ContentType.IsSubmodule }} 65 <p class="text-center text-gray-400 dark:text-gray-500"> 66 This directory is a git submodule of <a href="{{ .BlobView.ContentSrc }}">{{ .BlobView.ContentSrc }}</a>. 67 </p> 68 {{ else if .BlobView.ContentType.IsImage }} 69 <div class="text-center"> 70 <img src="{{ .BlobView.ContentSrc }}" 71 alt="{{ .Path }}" 72 class="max-w-full h-auto mx-auto border border-gray-200 dark:border-gray-700 rounded" /> 73 </div> 74 {{ else if .BlobView.ContentType.IsVideo }} 75 <div class="text-center"> 76 <video controls class="max-w-full h-auto mx-auto border border-gray-200 dark:border-gray-700 rounded"> 77 <source src="{{ .BlobView.ContentSrc }}"> 78 Your browser does not support the video tag. 79 </video> 80 </div> 81 {{ else if .BlobView.ContentType.IsSvg }} 82 <div class="overflow-auto relative"> 83 {{ if .BlobView.ShowingRendered }} 84 <div class="text-center"> 85 <img src="{{ .BlobView.ContentSrc }}" 86 alt="{{ .Path }}" 87 class="max-w-full h-auto mx-auto border border-gray-200 dark:border-gray-700 rounded" /> 88 </div> 89 {{ else }} 90 <div id="blob-contents" class="whitespace-pre peer-target:bg-yellow-200 dark:peer-target:bg-yellow-900">{{ code .BlobView.Contents .Path | escapeHtml }}</div> 91 {{ end }} 92 </div> 93 {{ else if .BlobView.ContentType.IsMarkup }} 94 <div class="overflow-auto relative"> 95 {{ if .BlobView.ShowingRendered }} 96 <div id="blob-contents" class="prose dark:prose-invert">{{ .BlobView.Contents | readme }}</div> 97 {{ else }} 98 <div id="blob-contents" class="whitespace-pre peer-target:bg-yellow-200 dark:peer-target:bg-yellow-900">{{ code .BlobView.Contents .Path | escapeHtml }}</div> 99 {{ end }} 100 </div> 101 {{ else if .BlobView.ContentType.IsCode }} 102 <div class="overflow-auto relative"> 103 <div id="blob-contents" class="whitespace-pre peer-target:bg-yellow-200 dark:peer-target:bg-yellow-900">{{ code .BlobView.Contents .Path | escapeHtml }}</div> 104 </div> 105 {{ end }} 106 {{ template "fragments/multiline-select" }} 107{{ end }}