1{{ define "title" }}{{ .Path }} at {{ .Ref }} · {{ .RepoInfo.FullName }}{{ end }}
2
3{{ define "extrameta" }}
4 {{ template "repo/fragments/meta" . }}
5
6 {{ $title := printf "%s at %s · %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 id="blob-contents" class="whitespace-pre peer-target:bg-yellow-200 dark:peer-target:bg-yellow-900">{{ code .BlobView.Contents .Path | escapeHtml }}</div>
103 {{ end }}
104 {{ template "fragments/multiline-select" }}
105{{ end }}