Monorepo for Tangled
at 74318eac9fdd72cf69e916276814351931ed0dcb 363 lines 15 kB view raw
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 items-center gap-3"> 18 <a href="/{{ .RepoInfo.FullName }}/commits/{{ .Ref | urlquery }}" class="inline-flex md:hidden 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 md:hidden 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 md:hidden 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 -my-4 -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 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-stretch"> 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 </div> 114{{ end }} 115 116{{ define "fileTree" }} 117 <div id="file-tree" class="col-span-1 pr-2 md:border-r md:border-gray-200 dark:md:border-gray-700" > 118 {{ $linkstyle := "no-underline hover:underline dark:text-white" }} 119 120 {{ range .Files }} 121 <div class="grid grid-cols-3 gap-4 items-center py-1"> 122 <div class="col-span-2"> 123 {{ $link := printf "/%s/%s/%s/%s" $.RepoInfo.FullName "tree" (urlquery $.Ref) .Name }} 124 {{ $icon := "folder" }} 125 {{ $iconStyle := "size-4 fill-current" }} 126 127 {{ if .IsSubmodule }} 128 {{ $link = printf "/%s/%s/%s/%s" $.RepoInfo.FullName "blob" (urlquery $.Ref) .Name }} 129 {{ $icon = "folder-input" }} 130 {{ $iconStyle = "size-4" }} 131 {{ end }} 132 133 {{ if .IsFile }} 134 {{ $link = printf "/%s/%s/%s/%s" $.RepoInfo.FullName "blob" (urlquery $.Ref) .Name }} 135 {{ $icon = "file" }} 136 {{ $iconStyle = "size-4" }} 137 {{ end }} 138 139 <a href="{{ $link }}" class="{{ $linkstyle }}"> 140 <div class="flex items-center gap-2"> 141 {{ i $icon $iconStyle "flex-shrink-0" }} 142 <span class="truncate">{{ .Name }}</span> 143 </div> 144 </a> 145 </div> 146 147 <div class="text-sm col-span-1 text-right"> 148 {{ with .LastCommit }} 149 <a href="/{{ $.RepoInfo.FullName }}/commit/{{ .Hash }}" class="text-gray-500 dark:text-gray-400">{{ template "repo/fragments/time" .When }}</a> 150 {{ end }} 151 </div> 152 </div> 153 {{ end }} 154 </div> 155{{ end }} 156 157{{ define "rightInfo" }} 158 <div id="right-info" class="hidden md:block col-span-1"> 159 {{ block "commitLog" . }} {{ end }} 160 {{ block "branchList" . }} {{ end }} 161 {{ block "tagList" . }} {{ end }} 162 </div> 163{{ end }} 164 165{{ define "commitLog" }} 166<div id="commit-log" class="md:col-span-1 px-2 pb-4"> 167 <div class="flex justify-between items-center"> 168 <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"> 169 {{ i "logs" "w-4 h-4" }} commits 170 <span class="bg-gray-100 dark:bg-gray-700 font-normal rounded py-1/2 px-1 text-sm">{{ .TotalCommits }}</span> 171 </a> 172 </div> 173 <div class="flex flex-col gap-6"> 174 {{ range .CommitsTrunc }} 175 <div> 176 <div id="commit-message"> 177 {{ $messageParts := splitN .Message "\n\n" 2 }} 178 <div class="text-base cursor-pointer"> 179 <div> 180 <div> 181 <a 182 href="/{{ $.RepoInfo.FullName }}/commit/{{ .Hash.String }}" 183 class="inline no-underline hover:underline dark:text-white" 184 >{{ index $messageParts 0 }}</a 185 > 186 {{ if gt (len $messageParts) 1 }} 187 188 <button 189 class="py-1/2 px-1 bg-gray-200 hover:bg-gray-400 rounded dark:bg-gray-700 dark:hover:bg-gray-600" 190 hx-on:click="this.parentElement.nextElementSibling.classList.toggle('hidden')" 191 > 192 {{ i "ellipsis" "w-3 h-3" }} 193 </button> 194 {{ end }} 195 </div> 196 {{ if gt (len $messageParts) 1 }} 197 <p 198 class="hidden mt-1 text-sm cursor-text pb-2 dark:text-gray-300" 199 > 200 {{ nl2br (index $messageParts 1) }} 201 </p> 202 {{ end }} 203 </div> 204 </div> 205 </div> 206 207 <!-- commit info bar --> 208 <div class="text-xs mt-2 text-gray-500 dark:text-gray-400 flex items-center flex-wrap"> 209 {{ $verified := $.VerifiedCommits.IsVerified .Hash.String }} 210 {{ $hashStyle := "text-gray-700 dark:text-gray-300 bg-gray-100 dark:bg-gray-900" }} 211 {{ if $verified }} 212 {{ $hashStyle = "bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200 px-2 rounded" }} 213 {{ end }} 214 <span class="font-mono"> 215 <a href="/{{ $.RepoInfo.FullName }}/commit/{{ .Hash.String }}" 216 class="no-underline hover:underline {{ $hashStyle }} px-2 py-1 rounded flex items-center gap-2"> 217 {{ slice .Hash.String 0 8 }} 218 {{ if $verified }} 219 {{ i "shield-check" "w-3 h-3" }} 220 {{ end }} 221 </a> 222 </span> 223 <span 224 class="mx-1 before:content-['·'] before:select-none" 225 ></span> 226 {{ template "attribution" (list . $.EmailToDid) }} 227 <div class="inline-block px-1 select-none after:content-['·']"></div> 228 {{ template "repo/fragments/time" .Committer.When }} 229 230 <!-- tags/branches --> 231 {{ $tagsForCommit := index $.TagMap .Hash.String }} 232 {{ if gt (len $tagsForCommit) 0 }} 233 <div class="inline-block px-1 select-none after:content-['·']"></div> 234 {{ end }} 235 {{ range $tagsForCommit }} 236 <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"> 237 {{ . }} 238 </span> 239 {{ end }} 240 241 <!-- ci status --> 242 {{ $pipeline := index $.Pipelines .Hash.String }} 243 {{ if and $pipeline (gt (len $pipeline.Statuses) 0) }} 244 <div class="inline-block px-1 select-none after:content-['·']"></div> 245 {{ template "repo/pipelines/fragments/pipelineSymbolLong" (dict "RepoInfo" $.RepoInfo "Pipeline" $pipeline) }} 246 {{ end }} 247 </div> 248 </div> 249 {{ end }} 250 </div> 251</div> 252{{ end }} 253 254{{ define "attribution" }} 255 {{ $commit := index . 0 }} 256 {{ $map := index . 1 }} 257 <span class="flex items-center gap-1"> 258 {{ $author := index $map $commit.Author.Email }} 259 {{ $coauthors := $commit.CoAuthors }} 260 {{ $all := list }} 261 262 {{ if $author }} 263 {{ $all = append $all $author }} 264 {{ end }} 265 {{ range $coauthors }} 266 {{ $co := index $map .Email }} 267 {{ if $co }} 268 {{ $all = append $all $co }} 269 {{ end }} 270 {{ end }} 271 272 {{ if $author }} 273 {{ template "fragments/tinyAvatarList" (dict "all" $all "classes" "size-6") }} 274 {{ else }} 275 {{ placeholderAvatar "tiny" }} 276 {{ end }} 277 <a href="{{ if $author }}/{{ $author }}{{ else }}mailto:{{ $commit.Author.Email }}{{ end }}" 278 class="no-underline hover:underline"> 279 {{ if $author }}{{ resolve $author }}{{ else }}{{ $commit.Author.Name }}{{ end }} 280 {{ if $coauthors }} +{{ length $coauthors }}{{ end }} 281 </a> 282 </span> 283{{ end }} 284 285{{ define "branchList" }} 286 {{ if gt (len .BranchesTrunc) 0 }} 287 <div id="branches" class="md:col-span-1 px-2 py-4 border-t border-gray-200 dark:border-gray-700"> 288 <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"> 289 {{ i "git-branch" "w-4 h-4" }} branches 290 <span class="bg-gray-100 dark:bg-gray-700 font-normal rounded py-1/2 px-1 text-sm">{{ len .Branches }}</span> 291 </a> 292 <div class="flex flex-col gap-1"> 293 {{ range .BranchesTrunc }} 294 <div class="text-base flex items-center justify-between overflow-hidden"> 295 <div class="flex items-center gap-2 min-w-0 flex-1"> 296 <a href="/{{ $.RepoInfo.FullName }}/tree/{{ .Reference.Name | urlquery }}" 297 class="inline-block truncate no-underline hover:underline dark:text-white"> 298 {{ .Reference.Name }} 299 </a> 300 {{ if .Commit }} 301 <span class="px-1 text-gray-500 dark:text-gray-400 select-none after:content-['·'] shrink-0"></span> 302 <span class="whitespace-nowrap text-xs text-gray-500 dark:text-gray-400 shrink-0">{{ template "repo/fragments/time" .Commit.Committer.When }}</span> 303 {{ end }} 304 {{ if .IsDefault }} 305 <span class="px-1 text-gray-500 dark:text-gray-400 select-none after:content-['·'] shrink-0"></span> 306 <span class="bg-gray-200 dark:bg-gray-700 rounded py-1/2 px-1 text-xs font-mono shrink-0">default</span> 307 {{ end }} 308 </div> 309 {{ if ne $.Ref .Reference.Name }} 310 <a href="/{{ $.RepoInfo.FullName }}/compare/{{ $.Ref | urlquery }}...{{ .Reference.Name | urlquery }}" 311 class="text-xs flex gap-2 items-center shrink-0 ml-2" 312 title="Compare branches or tags"> 313 {{ i "git-compare" "w-3 h-3" }} compare 314 </a> 315 {{ end }} 316 </div> 317 {{ end }} 318 </div> 319 </div> 320 {{ end }} 321{{ end }} 322 323{{ define "tagList" }} 324 {{ if gt (len .TagsTrunc) 0 }} 325 <div id="tags" class="md:col-span-1 px-2 py-4 border-t border-gray-200 dark:border-gray-700"> 326 <div class="flex justify-between items-center"> 327 <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"> 328 {{ i "tags" "w-4 h-4" }} tags 329 <span class="bg-gray-100 dark:bg-gray-700 font-normal rounded py-1/2 px-1 text-sm">{{ len .Tags }}</span> 330 </a> 331 </div> 332 <div class="flex flex-col gap-1"> 333 {{ range $idx, $tag := .TagsTrunc }} 334 {{ with $tag }} 335 <div> 336 <div class="text-base flex items-center gap-2"> 337 <a href="/{{ $.RepoInfo.FullName }}/tags/{{ .Reference.Name | urlquery }}" 338 class="inline no-underline hover:underline dark:text-white"> 339 {{ .Reference.Name }} 340 </a> 341 </div> 342 <div> 343 {{ with .Tag }} 344 <span class="text-xs text-gray-500 dark:text-gray-400">{{ template "repo/fragments/time" .Tagger.When }}</span> 345 {{ end }} 346 {{ if eq $idx 0 }} 347 {{ with .Tag }}<span class="px-1 text-gray-500 dark:text-gray-400 select-none after:content-['·']"></span>{{ end }} 348 <span class="bg-gray-200 dark:bg-gray-700 rounded py-1/2 px-1 text-xs font-mono">latest</span> 349 {{ end }} 350 </div> 351 </div> 352 {{ end }} 353 {{ end }} 354 </div> 355 </div> 356 {{ end }} 357{{ end }} 358 359{{ define "repoAfter" }} 360 {{- if or .HTMLReadme .Readme -}} 361 {{ template "repo/fragments/readme" . }} 362 {{- end -}} 363{{ end }}