Monorepo for Tangled
tangled.org
1{{ define "title" }}Pulls · {{ .RepoInfo.FullName }} · Tangled{{ end }}
2
3{{ define "extrameta" }}
4 {{ $title := "Pulls"}}
5 {{ $url := printf "https://tangled.org/%s/pulls" .RepoInfo.FullName }}
6
7 {{ template "repo/fragments/og" (dict "RepoInfo" .RepoInfo "Title" $title "Url" $url) }}
8{{ end }}
9
10{{ define "repoContent" }}
11 {{ $active := .FilterState }}
12 {{ $open :=
13 (dict
14 "Key" "open"
15 "Value" "Open"
16 "Icon" "git-pull-request"
17 "Meta" (scaleFmt .RepoInfo.Stats.PullCount.Open)) }}
18 {{ $merged :=
19 (dict
20 "Key" "merged"
21 "Value" "Merged"
22 "Icon" "git-merge"
23 "Meta" (scaleFmt .RepoInfo.Stats.PullCount.Merged)) }}
24 {{ $closed :=
25 (dict
26 "Key" "closed"
27 "Value" "Closed"
28 "Icon" "ban"
29 "Meta" (scaleFmt .RepoInfo.Stats.PullCount.Closed)) }}
30 {{ $values := list $open $merged $closed }}
31 <div class="grid gap-2 grid-cols-[auto_1fr_auto] grid-row-2">
32 <form id="search-form" class="flex relative col-span-3 sm:col-span-1 sm:col-start-2" method="GET">
33 <div class="flex-1 flex relative">
34 <input
35 id="search-q"
36 class="flex-1 py-1 pl-2 pr-10 mr-[-1px] rounded-r-none peer"
37 type="text"
38 name="q"
39 value="{{ .FilterQuery }}"
40 placeholder="Search pulls..."
41 >
42 <a
43 {{ if $active }}href="?q=state:{{ $active }}"{{ else }}href="?"{{ end }}
44 class="absolute right-3 top-1/2 -translate-y-1/2 text-gray-400 hover:text-gray-600 dark:hover:text-gray-300 hidden peer-[:not(:placeholder-shown)]:block"
45 >
46 {{ i "x" "w-4 h-4" }}
47 </a>
48 </div>
49 <button
50 type="submit"
51 class="p-2 text-gray-400 border rounded-r border-gray-300 dark:border-gray-600"
52 >
53 {{ i "search" "w-4 h-4" }}
54 </button>
55 </form>
56 <div class="sm:row-start-1">
57 {{ template "fragments/tabSelector" (dict "Name" "state" "Values" $values "Active" $active "Include" "#search-q" "Form" "search-form") }}
58 </div>
59 <a
60 href="/{{ .RepoInfo.FullName }}/pulls/new"
61 class="col-start-3 btn-create text-sm flex items-center gap-2 no-underline hover:no-underline hover:text-white"
62 >
63 {{ i "git-pull-request-create" "w-4 h-4" }}
64 <span>New</span>
65 </a>
66 </div>
67 <div class="error" id="pulls"></div>
68{{ end }}
69
70{{ define "repoAfter" }}
71 <div class="flex flex-col gap-2 mt-2">
72 {{ range $stack := .Stacks }}
73 {{ $topPR := index $stack 0 }}
74 <div class="rounded bg-white dark:bg-gray-800">
75 <div class="px-6 py-4 z-5">
76 <div class="pb-2">
77 <a href="/{{ $.RepoInfo.FullName }}/pulls/{{ $topPR.PullId }}" class="dark:text-white">
78 {{ $topPR.Title | description }}
79 <span class="text-gray-500 dark:text-gray-400">#{{ $topPR.PullId }}</span>
80 </a>
81 </div>
82 <div class="text-sm text-gray-500 dark:text-gray-400 flex flex-wrap items-center gap-1">
83 {{ template "repo/pulls/fragments/pullState" $topPR.State }}
84 <span class="ml-1 flex items-center gap-1">
85 {{ template "user/fragments/picLink" (list $topPR.OwnerDid "size-6" (index $.VouchRelationships (did $topPR.OwnerDid))) }}
86 <a href="/{{ resolve $topPR.OwnerDid }}">{{ resolve $topPR.OwnerDid }}</a>
87 </span>
88
89 <span class="before:content-['·']">
90 {{ template "repo/fragments/time" $topPR.Created }}
91 </span>
92
93 <span class="before:content-['·']">
94 {{ $commentCount := $topPR.TotalComments }}
95 {{ $commentCount }} comment{{ if ne $commentCount 1 }}s{{ end }}
96 </span>
97
98 <span class="before:content-['·']">
99 Round
100 <span class="font-mono">
101 #{{ $topPR.LastRoundNumber }}
102 </span>
103 </span>
104
105 {{ $pipeline := index $.Pipelines $topPR.LatestSha }}
106 {{ if and $pipeline $pipeline.Id }}
107 <span class="before:content-['·']"></span>
108 {{ template "repo/pipelines/fragments/pipelineSymbol" (dict "Pipeline" $pipeline "ShortSummary" true) }}
109 {{ end }}
110
111 {{ $state := $topPR.Labels }}
112 {{ range $k, $d := $.LabelDefs }}
113 {{ range $v, $s := $state.GetValSet $d.AtUri.String }}
114 {{ template "labels/fragments/label" (dict "def" $d "val" $v "withPrefix" true "baseFilterQuery" $.BaseFilterQuery "basePath" (printf "/%s/pulls" $.RepoInfo.FullName)) }}
115 {{ end }}
116 {{ end }}
117 </div>
118 </div>
119 {{ if gt (len $stack) 1 }}
120 <details class="group">
121 <summary class="px-6 pb-4 text-xs list-none cursor-pointer hover:text-gray-500 hover:dark:text-gray-400">
122 <span class="flex items-center gap-2">
123 <span class="group-open:hidden">
124 {{ i "chevrons-up-down" "size-3" }}
125 </span>
126 <span class="hidden group-open:flex">
127 {{ i "chevrons-down-up" "size-3" }}
128 </span>
129 {{ $rest := sub (len $stack) 1 }}
130 Expand {{ $rest }} pull{{if ne $rest 1 }}s{{end}} in this stack
131 </span>
132 </summary>
133 {{ template "stackedPullList" (list (slice $stack 1) $) }}
134 </details>
135 {{ end }}
136 </div>
137 {{ end }}
138 </div>
139 {{if gt .PullCount .Page.Limit }}
140 {{ template "fragments/pagination" (dict
141 "Page" .Page
142 "TotalCount" .PullCount
143 "BasePath" (printf "/%s/pulls" .RepoInfo.FullName)
144 "QueryParams" (queryParams "q" .FilterQuery)
145 ) }}
146 {{ end }}
147{{ end }}
148
149{{ define "stackedPullList" }}
150 {{ $list := index . 0 }}
151 {{ $root := index . 1 }}
152 <div class="grid grid-cols-1 rounded-b border-b border-t border-gray-200 dark:border-gray-900 divide-y divide-gray-200 dark:divide-gray-900">
153 {{ range $pull := $list }}
154 {{ $pipeline := index $root.Pipelines $pull.LatestSha }}
155 <a href="/{{ $root.RepoInfo.FullName }}/pulls/{{ $pull.PullId }}" class="no-underline hover:no-underline hover:bg-gray-100/25 hover:dark:bg-gray-700/25">
156 <div class="flex gap-2 items-center px-6">
157 <div class="flex-grow min-w-0 w-full py-2">
158 {{ template "repo/pulls/fragments/summarizedPullHeader" (list $pull $pipeline) }}
159 </div>
160 </div>
161 </a>
162 {{ end }}
163 </div>
164{{ end }}