forked from tangled.org/core
Monorepo for Tangled — https://tangled.org
1{{ define "title" }}{{ .RepoInfo.FullName }} at {{ .Ref }}{{ end }} 2 3 4{{ define "extrameta" }} 5 {{ template "repo/fragments/meta" . }} 6 7 {{ template "repo/fragments/og" (dict "RepoInfo" .RepoInfo) }} 8{{ end }} 9 10{{ define "repoContent" }} 11 <main> 12 {{ if .Languages }} 13 {{ block "repoLanguages" . }}{{ end }} 14 {{ end }} 15 <div class="flex items-center justify-between pb-5"> 16 {{ block "branchSelector" . }}{{ end }} 17 <div class="flex md:hidden items-center gap-2"> 18 <a href="/{{ .RepoInfo.FullName }}/commits/{{ .Ref | urlquery }}" class="inline-flex items-center text-sm gap-1 font-bold"> 19 {{ i "git-commit-horizontal" "w-4" "h-4" }} {{ .TotalCommits }} 20 </a> 21 <a href="/{{ .RepoInfo.FullName }}/branches" class="inline-flex items-center text-sm gap-1 font-bold"> 22 {{ i "git-branch" "w-4" "h-4" }} {{ len .Branches }} 23 </a> 24 <a href="/{{ .RepoInfo.FullName }}/tags" class="inline-flex items-center text-sm gap-1 font-bold"> 25 {{ i "tags" "w-4" "h-4" }} {{ len .Tags }} 26 </a> 27 {{ template "repo/fragments/cloneDropdown" . }} 28 </div> 29 </div> 30 <div class="grid grid-cols-1 md:grid-cols-2 gap-2"> 31 {{ block "fileTree" . }}{{ end }} 32 {{ block "rightInfo" . }}{{ end }} 33 </div> 34 </main> 35{{ end }} 36 37{{ define "repoLanguages" }} 38 <details class="group -m-6 mb-4"> 39 <summary class="flex gap-[1px] h-4 scale-y-50 hover:scale-y-100 origin-top group-open:scale-y-100 transition-all hover:cursor-pointer overflow-hidden rounded-t"> 40 {{ range $value := .Languages }} 41 <div 42 title='{{ or $value.Name "Other" }} {{ printf "%.1f" $value.Percentage }}%' 43 style="background-color: {{ $value.Color }}; width: {{ $value.Percentage }}%" 44 ></div> 45 {{ end }} 46 </summary> 47 <div class="px-4 py-2 border-b border-gray-200 dark:border-gray-600 flex items-center gap-4 flex-wrap"> 48 {{ range $value := .Languages }} 49 <div 50 class="flex flex-grow items-center gap-2 text-xs align-items-center justify-center" 51 > 52 {{ template "repo/fragments/colorBall" (dict "color" (langColor $value.Name)) }} 53 <div>{{ or $value.Name "Other" }} 54 <span class="text-gray-500 dark:text-gray-400"> 55 {{ if lt $value.Percentage 0.05 }} 56 0.1% 57 {{ else }} 58 {{ printf "%.1f" $value.Percentage }}% 59 {{ end }} 60 </span></div> 61 </div> 62 {{ end }} 63 </div> 64 </details> 65{{ end }} 66 67{{ define "branchSelector" }} 68 <div class="flex gap-2 items-center justify-between w-full"> 69 <div class="flex gap-2 items-center"> 70 <select 71 onchange="window.location.href = '/{{ .RepoInfo.FullName }}/tree/' + encodeURIComponent(this.value)" 72 class="p-1 border max-w-32 border-gray-200 bg-white dark:bg-gray-800 dark:text-white dark:border-gray-700" 73 > 74 <optgroup label="branches ({{len .Branches}})" class="bold text-sm"> 75 {{ range .Branches }} 76 <option 77 value="{{ .Reference.Name }}" 78 class="py-1" 79 {{ if eq .Reference.Name $.Ref }} 80 selected 81 {{ end }} 82 > 83 {{ .Reference.Name }} 84 </option> 85 {{ end }} 86 </optgroup> 87 <optgroup label="tags ({{len .Tags}})" class="bold text-sm"> 88 {{ range .Tags }} 89 <option 90 value="{{ .Reference.Name }}" 91 class="py-1" 92 {{ if eq .Reference.Name $.Ref }} 93 selected 94 {{ end }} 95 > 96 {{ .Reference.Name }} 97 </option> 98 {{ else }} 99 <option class="py-1" disabled>no tags found</option> 100 {{ end }} 101 </optgroup> 102 </select> 103 <div class="flex items-center gap-2"> 104 <a 105 href="/{{ .RepoInfo.FullName }}/compare?base={{ $.Ref | urlquery }}" 106 class="btn flex items-center gap-2 no-underline hover:no-underline" 107 title="Compare branches or tags" 108 > 109 {{ i "git-compare" "w-4 h-4" }} 110 </a> 111 </div> 112 </div> 113 114 <!-- Clone dropdown in top right --> 115 <div class="hidden md:flex items-center "> 116 {{ template "repo/fragments/cloneDropdown" . }} 117 </div> 118 </div> 119{{ end }} 120 121{{ define "fileTree" }} 122 <div id="file-tree" class="col-span-1 pr-2 md:border-r md:border-gray-200 dark:md:border-gray-700" > 123 {{ $linkstyle := "no-underline hover:underline dark:text-white" }} 124 125 {{ range .Files }} 126 <div class="grid grid-cols-3 gap-4 items-center py-1"> 127 <div class="col-span-2"> 128 {{ $link := printf "/%s/%s/%s/%s" $.RepoInfo.FullName "tree" (urlquery $.Ref) .Name }} 129 {{ $icon := "folder" }} 130 {{ $iconStyle := "size-4 fill-current" }} 131 132 {{ if .IsFile }} 133 {{ $link = printf "/%s/%s/%s/%s" $.RepoInfo.FullName "blob" (urlquery $.Ref) .Name }} 134 {{ $icon = "file" }} 135 {{ $iconStyle = "size-4" }} 136 {{ end }} 137 <a href="{{ $link }}" class="{{ $linkstyle }}"> 138 <div class="flex items-center gap-2"> 139 {{ i $icon $iconStyle "flex-shrink-0" }} 140 <span class="truncate">{{ .Name }}</span> 141 </div> 142 </a> 143 </div> 144 145 <div class="text-sm col-span-1 text-right"> 146 {{ with .LastCommit }} 147 <a href="/{{ $.RepoInfo.FullName }}/commit/{{ .Hash }}" class="text-gray-500 dark:text-gray-400">{{ template "repo/fragments/time" .When }}</a> 148 {{ end }} 149 </div> 150 </div> 151 {{ end }} 152 </div> 153{{ end }} 154 155{{ define "rightInfo" }} 156 <div id="right-info" class="hidden md:block col-span-1"> 157 {{ block "commitLog" . }} {{ end }} 158 {{ block "branchList" . }} {{ end }} 159 {{ block "tagList" . }} {{ end }} 160 </div> 161{{ end }} 162 163{{ define "commitLog" }} 164<div id="commit-log" class="md:col-span-1 px-2 pb-4"> 165 <div class="flex justify-between items-center"> 166 <a href="/{{ .RepoInfo.FullName }}/commits/{{ .Ref | urlquery }}" class="flex items-center gap-2 pb-2 cursor-pointer font-bold hover:text-gray-600 dark:hover:text-gray-300 hover:no-underline"> 167 {{ i "logs" "w-4 h-4" }} commits 168 <span class="bg-gray-100 dark:bg-gray-700 font-normal rounded py-1/2 px-1 text-sm">{{ .TotalCommits }}</span> 169 </a> 170 </div> 171 <div class="flex flex-col gap-6"> 172 {{ range .CommitsTrunc }} 173 <div> 174 <div id="commit-message"> 175 {{ $messageParts := splitN .Message "\n\n" 2 }} 176 <div class="text-base cursor-pointer"> 177 <div> 178 <div> 179 <a 180 href="/{{ $.RepoInfo.FullName }}/commit/{{ .Hash.String }}" 181 class="inline no-underline hover:underline dark:text-white" 182 >{{ index $messageParts 0 }}</a 183 > 184 {{ if gt (len $messageParts) 1 }} 185 186 <button 187 class="py-1/2 px-1 bg-gray-200 hover:bg-gray-400 rounded dark:bg-gray-700 dark:hover:bg-gray-600" 188 hx-on:click="this.parentElement.nextElementSibling.classList.toggle('hidden')" 189 > 190 {{ i "ellipsis" "w-3 h-3" }} 191 </button> 192 {{ end }} 193 </div> 194 {{ if gt (len $messageParts) 1 }} 195 <p 196 class="hidden mt-1 text-sm cursor-text pb-2 dark:text-gray-300" 197 > 198 {{ nl2br (index $messageParts 1) }} 199 </p> 200 {{ end }} 201 </div> 202 </div> 203 </div> 204 205 <!-- commit info bar --> 206 <div class="text-xs mt-2 text-gray-500 dark:text-gray-400 flex items-center flex-wrap"> 207 {{ $verified := $.VerifiedCommits.IsVerified .Hash.String }} 208 {{ $hashStyle := "text-gray-700 dark:text-gray-300 bg-gray-100 dark:bg-gray-900" }} 209 {{ if $verified }} 210 {{ $hashStyle = "bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200 px-2 rounded" }} 211 {{ end }} 212 <span class="font-mono"> 213 <a href="/{{ $.RepoInfo.FullName }}/commit/{{ .Hash.String }}" 214 class="no-underline hover:underline {{ $hashStyle }} px-2 py-1 rounded flex items-center gap-2"> 215 {{ slice .Hash.String 0 8 }} 216 {{ if $verified }} 217 {{ i "shield-check" "w-3 h-3" }} 218 {{ end }} 219 </a> 220 </span> 221 <span 222 class="mx-1 before:content-['·'] before:select-none" 223 ></span> 224 <span> 225 {{ $did := index $.EmailToDid .Author.Email }} 226 <a href="{{ if $did }}/{{ resolve $did }}{{ else }}mailto:{{ .Author.Email }}{{ end }}" 227 class="text-gray-500 dark:text-gray-400 no-underline hover:underline" 228 >{{ if $did }}{{ template "user/fragments/picHandleLink" $did }}{{ else }}{{ .Author.Name }}{{ end }}</a> 229 </span> 230 <div class="inline-block px-1 select-none after:content-['·']"></div> 231 {{ template "repo/fragments/time" .Committer.When }} 232 233 <!-- tags/branches --> 234 {{ $tagsForCommit := index $.TagMap .Hash.String }} 235 {{ if gt (len $tagsForCommit) 0 }} 236 <div class="inline-block px-1 select-none after:content-['·']"></div> 237 {{ end }} 238 {{ range $tagsForCommit }} 239 <span class="text-xs rounded bg-gray-100 dark:bg-gray-700 text-black dark:text-white font-mono px-2 mx-[2px] inline-flex items-center"> 240 {{ . }} 241 </span> 242 {{ end }} 243 244 <!-- ci status --> 245 {{ $pipeline := index $.Pipelines .Hash.String }} 246 {{ if and $pipeline (gt (len $pipeline.Statuses) 0) }} 247 <div class="inline-block px-1 select-none after:content-['·']"></div> 248 {{ template "repo/pipelines/fragments/pipelineSymbolLong" (dict "RepoInfo" $.RepoInfo "Pipeline" $pipeline) }} 249 {{ end }} 250 </div> 251 </div> 252 {{ end }} 253 </div> 254</div> 255{{ end }} 256 257{{ define "branchList" }} 258 {{ if gt (len .BranchesTrunc) 0 }} 259 <div id="branches" class="md:col-span-1 px-2 py-4 border-t border-gray-200 dark:border-gray-700"> 260 <a href="/{{ .RepoInfo.FullName }}/branches" class="flex items-center gap-2 pb-2 cursor-pointer font-bold hover:text-gray-600 dark:hover:text-gray-300 hover:no-underline"> 261 {{ i "git-branch" "w-4 h-4" }} branches 262 <span class="bg-gray-100 dark:bg-gray-700 font-normal rounded py-1/2 px-1 text-sm">{{ len .Branches }}</span> 263 </a> 264 <div class="flex flex-col gap-1"> 265 {{ range .BranchesTrunc }} 266 <div class="text-base flex items-center justify-between overflow-hidden"> 267 <div class="flex items-center gap-2 min-w-0 flex-1"> 268 <a href="/{{ $.RepoInfo.FullName }}/tree/{{ .Reference.Name | urlquery }}" 269 class="inline-block truncate no-underline hover:underline dark:text-white"> 270 {{ .Reference.Name }} 271 </a> 272 {{ if .Commit }} 273 <span class="px-1 text-gray-500 dark:text-gray-400 select-none after:content-['·'] shrink-0"></span> 274 <span class="whitespace-nowrap text-xs text-gray-500 dark:text-gray-400 shrink-0">{{ template "repo/fragments/time" .Commit.Committer.When }}</span> 275 {{ end }} 276 {{ if .IsDefault }} 277 <span class="px-1 text-gray-500 dark:text-gray-400 select-none after:content-['·'] shrink-0"></span> 278 <span class="bg-gray-200 dark:bg-gray-700 rounded py-1/2 px-1 text-xs font-mono shrink-0">default</span> 279 {{ end }} 280 </div> 281 {{ if ne $.Ref .Reference.Name }} 282 <a href="/{{ $.RepoInfo.FullName }}/compare/{{ $.Ref | urlquery }}...{{ .Reference.Name | urlquery }}" 283 class="text-xs flex gap-2 items-center shrink-0 ml-2" 284 title="Compare branches or tags"> 285 {{ i "git-compare" "w-3 h-3" }} compare 286 </a> 287 {{ end }} 288 </div> 289 {{ end }} 290 </div> 291 </div> 292 {{ end }} 293{{ end }} 294 295{{ define "tagList" }} 296 {{ if gt (len .TagsTrunc) 0 }} 297 <div id="tags" class="md:col-span-1 px-2 py-4 border-t border-gray-200 dark:border-gray-700"> 298 <div class="flex justify-between items-center"> 299 <a href="/{{ .RepoInfo.FullName }}/tags" class="flex items-center gap-2 pb-2 cursor-pointer font-bold hover:text-gray-600 dark:hover:text-gray-300 hover:no-underline"> 300 {{ i "tags" "w-4 h-4" }} tags 301 <span class="bg-gray-100 dark:bg-gray-700 font-normal rounded py-1/2 px-1 text-sm">{{ len .Tags }}</span> 302 </a> 303 </div> 304 <div class="flex flex-col gap-1"> 305 {{ range $idx, $tag := .TagsTrunc }} 306 {{ with $tag }} 307 <div> 308 <div class="text-base flex items-center gap-2"> 309 <a href="/{{ $.RepoInfo.FullName }}/tree/{{ .Reference.Name | urlquery }}" 310 class="inline no-underline hover:underline dark:text-white"> 311 {{ .Reference.Name }} 312 </a> 313 </div> 314 <div> 315 {{ with .Tag }} 316 <span class="text-xs text-gray-500 dark:text-gray-400">{{ template "repo/fragments/time" .Tagger.When }}</span> 317 {{ end }} 318 {{ if eq $idx 0 }} 319 {{ with .Tag }}<span class="px-1 text-gray-500 dark:text-gray-400 select-none after:content-['·']"></span>{{ end }} 320 <span class="bg-gray-200 dark:bg-gray-700 rounded py-1/2 px-1 text-xs font-mono">latest</span> 321 {{ end }} 322 </div> 323 </div> 324 {{ end }} 325 {{ end }} 326 </div> 327 </div> 328 {{ end }} 329{{ end }} 330 331{{ define "repoAfter" }} 332 {{- if or .HTMLReadme .Readme -}} 333 {{ template "repo/fragments/readme" . }} 334 {{- end -}} 335{{ end }}