mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 20:36:07 +01:00 
			
		
		
		
	Fixes: https://github.com/go-gitea/gitea/issues/31068 - Now it only does a single call to `GetExpandDirection` per line instead of multiples. - Exposed `data-expand-direction` to frontend so it can correctly size the buttons (it's a pain to do in tables). <img width="142" alt="Screenshot 2024-05-27 at 20 44 56" src="https://github.com/go-gitea/gitea/assets/115237/8b0b45a6-8e50-4081-8822-5e0775d8d941"> <img width="142" alt="Screenshot 2024-05-27 at 20 44 51" src="https://github.com/go-gitea/gitea/assets/115237/b7ba2c57-8f55-4e9f-9606-c96d16b77892"> <img width="132" alt="Screenshot 2024-05-27 at 20 44 46" src="https://github.com/go-gitea/gitea/assets/115237/0e838fb8-5e8c-4250-9843-a68b88d5418b"> <img width="80" alt="Screenshot 2024-05-27 at 20 44 33" src="https://github.com/go-gitea/gitea/assets/115237/da6c7f83-c160-4389-8ab2-889d0568cbe8"> <img width="80" alt="Screenshot 2024-05-27 at 20 44 26" src="https://github.com/go-gitea/gitea/assets/115237/cdb490b2-5040-484a-92e5-46fc5e37c199"> <img width="78" alt="Screenshot 2024-05-27 at 20 44 20" src="https://github.com/go-gitea/gitea/assets/115237/d2978ab0-764e-41ff-922c-25f8fe749f28"> Would backport as trivial enhancement.
		
			
				
	
	
		
			158 lines
		
	
	
		
			9.7 KiB
		
	
	
	
		
			Handlebars
		
	
	
	
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			9.7 KiB
		
	
	
	
		
			Handlebars
		
	
	
	
	
	
{{$file := .file}}
 | 
						|
{{$blobExcerptRepoLink := or ctx.RootData.CommitRepoLink ctx.RootData.RepoLink}}
 | 
						|
<colgroup>
 | 
						|
	<col width="50">
 | 
						|
	<col width="10">
 | 
						|
	<col width="10">
 | 
						|
	<col>
 | 
						|
	<col width="50">
 | 
						|
	<col width="10">
 | 
						|
	<col width="10">
 | 
						|
	<col>
 | 
						|
</colgroup>
 | 
						|
{{range $j, $section := $file.Sections}}
 | 
						|
	{{range $k, $line := $section.Lines}}
 | 
						|
		{{$hasmatch := ne $line.Match -1}}
 | 
						|
		{{if or (ne .GetType 2) (not $hasmatch)}}
 | 
						|
			<tr class="{{.GetHTMLDiffLineType}}-code nl-{{$k}} ol-{{$k}}" data-line-type="{{.GetHTMLDiffLineType}}">
 | 
						|
				{{if eq .GetType 4}}
 | 
						|
					{{$expandDirection := $line.GetExpandDirection}}
 | 
						|
					<td class="lines-num lines-num-old">
 | 
						|
						<div class="code-expander-buttons" data-expand-direction="{{$expandDirection}}">
 | 
						|
						{{if or (eq $expandDirection 3) (eq $expandDirection 5)}}
 | 
						|
							<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptRepoLink}}/blob_excerpt/{{PathEscape $.root.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=split&direction=down&wiki={{$.root.PageIsWiki}}&anchor=diff-{{$file.NameHash}}K{{$line.SectionInfo.RightIdx}}">
 | 
						|
								{{svg "octicon-fold-down"}}
 | 
						|
							</button>
 | 
						|
						{{end}}
 | 
						|
						{{if or (eq $expandDirection 3) (eq $expandDirection 4)}}
 | 
						|
							<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptRepoLink}}/blob_excerpt/{{PathEscape $.root.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=split&direction=up&wiki={{$.root.PageIsWiki}}&anchor=diff-{{$file.NameHash}}K{{$line.SectionInfo.RightIdx}}">
 | 
						|
								{{svg "octicon-fold-up"}}
 | 
						|
							</button>
 | 
						|
						{{end}}
 | 
						|
						{{if eq $expandDirection 2}}
 | 
						|
							<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptRepoLink}}/blob_excerpt/{{PathEscape $.root.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=split&direction=&wiki={{$.root.PageIsWiki}}&anchor=diff-{{$file.NameHash}}K{{$line.SectionInfo.RightIdx}}">
 | 
						|
								{{svg "octicon-fold"}}
 | 
						|
							</button>
 | 
						|
						{{end}}
 | 
						|
						</div>
 | 
						|
					</td>{{$inlineDiff := $section.GetComputedInlineDiffFor $line ctx.Locale}}
 | 
						|
					<td class="lines-escape lines-escape-old">{{if $inlineDiff.EscapeStatus.Escaped}}<button class="toggle-escape-button btn interact-bg" title="{{template "repo/diff/escape_title" dict "diff" $inlineDiff}}"></button>{{end}}</td>
 | 
						|
					<td colspan="6" class="lines-code lines-code-old ">{{/*
 | 
						|
						*/}}{{template "repo/diff/section_code" dict "diff" $inlineDiff}}{{/*
 | 
						|
					*/}}</td>
 | 
						|
				{{else if and (eq .GetType 3) $hasmatch}}{{/* DEL */}}
 | 
						|
					{{$match := index $section.Lines $line.Match}}
 | 
						|
					{{- $leftDiff := ""}}{{if $line.LeftIdx}}{{$leftDiff = $section.GetComputedInlineDiffFor $line ctx.Locale}}{{end}}
 | 
						|
					{{- $rightDiff := ""}}{{if $match.RightIdx}}{{$rightDiff = $section.GetComputedInlineDiffFor $match ctx.Locale}}{{end}}
 | 
						|
					<td class="lines-num lines-num-old del-code" data-line-num="{{$line.LeftIdx}}"><span rel="diff-{{$file.NameHash}}L{{$line.LeftIdx}}"></span></td>
 | 
						|
					<td class="lines-escape del-code lines-escape-old">{{if $line.LeftIdx}}{{if $leftDiff.EscapeStatus.Escaped}}<button class="toggle-escape-button btn interact-bg" title="{{template "repo/diff/escape_title" dict "diff" $leftDiff}}"></button>{{end}}{{end}}</td>
 | 
						|
					<td class="lines-type-marker lines-type-marker-old del-code"><span class="tw-font-mono" data-type-marker="{{$line.GetLineTypeMarker}}"></span></td>
 | 
						|
					<td class="lines-code lines-code-old del-code">{{/*
 | 
						|
						*/}}{{if and $.root.SignedUserID $.root.PageIsPullFiles}}{{/*
 | 
						|
							*/}}<button type="button" aria-label="{{ctx.Locale.Tr "repo.diff.comment.add_line_comment"}}" class="ui primary button add-code-comment add-code-comment-left{{if (not $line.CanComment)}} tw-invisible{{end}}" data-side="left" data-idx="{{$line.LeftIdx}}">{{/*
 | 
						|
								*/}}{{svg "octicon-plus"}}{{/*
 | 
						|
							*/}}</button>{{/*
 | 
						|
						*/}}{{end}}{{/*
 | 
						|
						*/}}{{if $line.LeftIdx}}{{/*
 | 
						|
							*/}}{{template "repo/diff/section_code" dict "diff" $leftDiff}}{{/*
 | 
						|
						*/}}{{else}}{{/*
 | 
						|
						*/}}<code class="code-inner"></code>{{/*
 | 
						|
						*/}}{{end}}{{/*
 | 
						|
					*/}}</td>
 | 
						|
					<td class="lines-num lines-num-new add-code" data-line-num="{{if $match.RightIdx}}{{$match.RightIdx}}{{end}}"><span rel="{{if $match.RightIdx}}diff-{{$file.NameHash}}R{{$match.RightIdx}}{{end}}"></span></td>
 | 
						|
					<td class="lines-escape add-code lines-escape-new">{{if $match.RightIdx}}{{if $rightDiff.EscapeStatus.Escaped}}<button class="toggle-escape-button btn interact-bg" title="{{template "repo/diff/escape_title" dict "diff" $rightDiff}}"></button>{{end}}{{end}}</td>
 | 
						|
					<td class="lines-type-marker lines-type-marker-new add-code">{{if $match.RightIdx}}<span class="tw-font-mono" data-type-marker="{{$match.GetLineTypeMarker}}"></span>{{end}}</td>
 | 
						|
					<td class="lines-code lines-code-new add-code">{{/*
 | 
						|
						*/}}{{if and $.root.SignedUserID $.root.PageIsPullFiles}}{{/*
 | 
						|
							*/}}<button type="button" aria-label="{{ctx.Locale.Tr "repo.diff.comment.add_line_comment"}}" class="ui primary button add-code-comment add-code-comment-right{{if (not $match.CanComment)}} tw-invisible{{end}}" data-side="right" data-idx="{{$match.RightIdx}}">{{/*
 | 
						|
								*/}}{{svg "octicon-plus"}}{{/*
 | 
						|
							*/}}</button>{{/*
 | 
						|
						*/}}{{end}}{{/*
 | 
						|
						*/}}{{if $match.RightIdx}}{{/*
 | 
						|
							*/}}{{template "repo/diff/section_code" dict "diff" $rightDiff}}{{/*
 | 
						|
						*/}}{{else}}{{/*
 | 
						|
							*/}}<code class="code-inner"></code>{{/*
 | 
						|
						*/}}{{end}}{{/*
 | 
						|
					*/}}</td>
 | 
						|
				{{else}}
 | 
						|
					{{$inlineDiff := $section.GetComputedInlineDiffFor $line ctx.Locale}}
 | 
						|
					<td class="lines-num lines-num-old" data-line-num="{{if $line.LeftIdx}}{{$line.LeftIdx}}{{end}}"><span rel="{{if $line.LeftIdx}}diff-{{$file.NameHash}}L{{$line.LeftIdx}}{{end}}"></span></td>
 | 
						|
					<td class="lines-escape lines-escape-old">{{if $line.LeftIdx}}{{if $inlineDiff.EscapeStatus.Escaped}}<button class="toggle-escape-button btn interact-bg" title="{{template "repo/diff/escape_title" dict "diff" $inlineDiff}}"></button>{{end}}{{end}}</td>
 | 
						|
					<td class="lines-type-marker lines-type-marker-old">{{if $line.LeftIdx}}<span class="tw-font-mono" data-type-marker="{{$line.GetLineTypeMarker}}"></span>{{end}}</td>
 | 
						|
					<td class="lines-code lines-code-old">{{/*
 | 
						|
						*/}}{{if and $.root.SignedUserID $.root.PageIsPullFiles (not (eq .GetType 2))}}{{/*
 | 
						|
							*/}}<button type="button" aria-label="{{ctx.Locale.Tr "repo.diff.comment.add_line_comment"}}" class="ui primary button add-code-comment add-code-comment-left{{if (not $line.CanComment)}} tw-invisible{{end}}" data-side="left" data-idx="{{$line.LeftIdx}}">{{/*
 | 
						|
								*/}}{{svg "octicon-plus"}}{{/*
 | 
						|
							*/}}</button>{{/*
 | 
						|
						*/}}{{end}}{{/*
 | 
						|
						*/}}{{if $line.LeftIdx}}{{/*
 | 
						|
							*/}}{{template "repo/diff/section_code" dict "diff" $inlineDiff}}{{/*
 | 
						|
						*/}}{{else}}{{/*
 | 
						|
						*/}}<code class="code-inner"></code>{{/*
 | 
						|
						*/}}{{end}}{{/*
 | 
						|
					*/}}</td>
 | 
						|
					<td class="lines-num lines-num-new" data-line-num="{{if $line.RightIdx}}{{$line.RightIdx}}{{end}}"><span rel="{{if $line.RightIdx}}diff-{{$file.NameHash}}R{{$line.RightIdx}}{{end}}"></span></td>
 | 
						|
					<td class="lines-escape lines-escape-new">{{if $line.RightIdx}}{{if $inlineDiff.EscapeStatus.Escaped}}<button class="toggle-escape-button btn interact-bg" title="{{template "repo/diff/escape_title" dict "diff" $inlineDiff}}"></button>{{end}}{{end}}</td>
 | 
						|
					<td class="lines-type-marker lines-type-marker-new">{{if $line.RightIdx}}<span class="tw-font-mono" data-type-marker="{{$line.GetLineTypeMarker}}"></span>{{end}}</td>
 | 
						|
					<td class="lines-code lines-code-new">{{/*
 | 
						|
						*/}}{{if and $.root.SignedUserID $.root.PageIsPullFiles (not (eq .GetType 3))}}{{/*
 | 
						|
							*/}}<button type="button" aria-label="{{ctx.Locale.Tr "repo.diff.comment.add_line_comment"}}" class="ui primary button add-code-comment add-code-comment-right{{if (not $line.CanComment)}} tw-invisible{{end}}" data-side="right" data-idx="{{$line.RightIdx}}">{{/*
 | 
						|
								*/}}{{svg "octicon-plus"}}{{/*
 | 
						|
							*/}}</button>{{/*
 | 
						|
						*/}}{{end}}{{/*
 | 
						|
						*/}}{{if $line.RightIdx}}{{/*
 | 
						|
							*/}}{{template "repo/diff/section_code" dict "diff" $inlineDiff}}{{/*
 | 
						|
						*/}}{{else}}{{/*
 | 
						|
						*/}}<code class="code-inner"></code>{{/*
 | 
						|
						*/}}{{end}}{{/*
 | 
						|
					*/}}</td>
 | 
						|
				{{end}}
 | 
						|
			</tr>
 | 
						|
			{{if and (eq .GetType 3) $hasmatch}}
 | 
						|
				{{$match := index $section.Lines $line.Match}}
 | 
						|
				{{if or $line.Comments $match.Comments}}
 | 
						|
					<tr class="add-comment" data-line-type="{{.GetHTMLDiffLineType}}">
 | 
						|
						<td class="add-comment-left" colspan="4">
 | 
						|
							{{if $line.Comments}}
 | 
						|
								{{if eq $line.GetCommentSide "previous"}}
 | 
						|
									{{template "repo/diff/conversation" dict "." $.root "comments" $line.Comments}}
 | 
						|
								{{end}}
 | 
						|
							{{end}}
 | 
						|
							{{if $match.Comments}}
 | 
						|
								{{if eq $match.GetCommentSide "previous"}}
 | 
						|
									{{template "repo/diff/conversation" dict "." $.root "comments" $match.Comments}}
 | 
						|
								{{end}}
 | 
						|
							{{end}}
 | 
						|
						</td>
 | 
						|
						<td class="add-comment-right" colspan="4">
 | 
						|
							{{if $line.Comments}}
 | 
						|
								{{if eq $line.GetCommentSide "proposed"}}
 | 
						|
									{{template "repo/diff/conversation" dict "." $.root "comments" $line.Comments}}
 | 
						|
								{{end}}
 | 
						|
							{{end}}
 | 
						|
							{{if $match.Comments}}
 | 
						|
								{{if eq $match.GetCommentSide "proposed"}}
 | 
						|
									{{template "repo/diff/conversation" dict "." $.root "comments" $match.Comments}}
 | 
						|
								{{end}}
 | 
						|
							{{end}}
 | 
						|
						</td>
 | 
						|
					</tr>
 | 
						|
				{{end}}
 | 
						|
			{{else if $line.Comments}}
 | 
						|
				<tr class="add-comment" data-line-type="{{.GetHTMLDiffLineType}}">
 | 
						|
					<td class="add-comment-left" colspan="4">
 | 
						|
						{{if eq $line.GetCommentSide "previous"}}
 | 
						|
							{{template "repo/diff/conversation" dict "." $.root "comments" $line.Comments}}
 | 
						|
						{{end}}
 | 
						|
					</td>
 | 
						|
					<td class="add-comment-right" colspan="4">
 | 
						|
						{{if eq $line.GetCommentSide "proposed"}}
 | 
						|
							{{template "repo/diff/conversation" dict "." $.root "comments" $line.Comments}}
 | 
						|
						{{end}}
 | 
						|
					</td>
 | 
						|
				</tr>
 | 
						|
			{{end}}
 | 
						|
		{{end}}
 | 
						|
	{{end}}
 | 
						|
{{end}}
 |