mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-25 03:19:50 +02:00 
			
		
		
		
	Refactor tmpl and blob_excerpt (#32967)
1. do not use `{{/* */}}` to remove spaces, use `{{- -}}`
2. fix "blob_excerpt" endpoint, remove the legacy fragile code: have
tested commit diff and wiki diff
			
			
This commit is contained in:
		
							parent
							
								
									2a828e2798
								
							
						
					
					
						commit
						b7260400f8
					
				| @ -24,7 +24,7 @@ import ( | ||||
| func ProtocolMiddlewares() (handlers []any) { | ||||
| 	// the order is important | ||||
| 	handlers = append(handlers, ChiRoutePathHandler())   // make sure chi has correct paths | ||||
| 	handlers = append(handlers, RequestContextHandler()) //	// prepare the context and panic recovery | ||||
| 	handlers = append(handlers, RequestContextHandler()) //	prepare the context and panic recovery | ||||
| 
 | ||||
| 	if setting.ReverseProxyLimit > 0 && len(setting.ReverseProxyTrustedProxies) > 0 { | ||||
| 		handlers = append(handlers, ForwardedHeadersHandler(setting.ReverseProxyLimit, setting.ReverseProxyTrustedProxies)) | ||||
|  | ||||
| @ -864,7 +864,7 @@ func ExcerptBlob(ctx *context.Context) { | ||||
| 	direction := ctx.FormString("direction") | ||||
| 	filePath := ctx.FormString("path") | ||||
| 	gitRepo := ctx.Repo.GitRepo | ||||
| 	if ctx.FormBool("wiki") { | ||||
| 	if ctx.Data["PageIsWiki"] == true { | ||||
| 		var err error | ||||
| 		gitRepo, err = gitrepo.OpenWikiRepository(ctx, ctx.Repo.Repository) | ||||
| 		if err != nil { | ||||
|  | ||||
| @ -1166,7 +1166,7 @@ func registerRoutes(m *web.Router) { | ||||
| 			Get(repo.SetDiffViewStyle, repo.SetWhitespaceBehavior, repo.CompareDiff). | ||||
| 			Post(reqSignIn, context.RepoMustNotBeArchived(), reqRepoPullsReader, repo.MustAllowPulls, web.Bind(forms.CreateIssueForm{}), repo.SetWhitespaceBehavior, repo.CompareAndPullRequestPost) | ||||
| 	}, optSignIn, context.RepoAssignment, reqRepoCodeReader) | ||||
| 	// end "/{username}/{reponame}": find, compare, list (code related) | ||||
| 	// end "/{username}/{reponame}": repo code: find, compare, list | ||||
| 
 | ||||
| 	m.Group("/{username}/{reponame}", func() { | ||||
| 		m.Get("/issues/posters", repo.IssuePosters) // it can't use {type:issues|pulls} because it would conflict with other routes like "/pulls/{index}" | ||||
| @ -1443,6 +1443,7 @@ func registerRoutes(m *web.Router) { | ||||
| 		m.Combo("/*"). | ||||
| 			Get(repo.Wiki). | ||||
| 			Post(context.RepoMustNotBeArchived(), reqSignIn, reqRepoWikiWriter, web.Bind(forms.NewWikiForm{}), repo.WikiPost) | ||||
| 		m.Get("/blob_excerpt/{sha}", repo.SetEditorconfigIfExists, repo.SetDiffViewStyle, repo.ExcerptBlob) | ||||
| 		m.Get("/commit/{sha:[a-f0-9]{7,64}}", repo.SetEditorconfigIfExists, repo.SetDiffViewStyle, repo.SetWhitespaceBehavior, repo.Diff) | ||||
| 		m.Get("/commit/{sha:[a-f0-9]{7,64}}.{ext:patch|diff}", repo.RawDiff) | ||||
| 		m.Get("/raw/*", repo.WikiRaw) | ||||
| @ -1518,27 +1519,6 @@ func registerRoutes(m *web.Router) { | ||||
| 			m.Get("", repo.Branches) | ||||
| 		}, repo.MustBeNotEmpty, context.RepoRef()) | ||||
| 
 | ||||
| 		m.Group("/blob_excerpt", func() { | ||||
| 			m.Get("/{sha}", repo.SetEditorconfigIfExists, repo.SetDiffViewStyle, repo.ExcerptBlob) | ||||
| 		}, func(ctx *context.Context) { | ||||
| 			// FIXME: refactor this function, use separate routes for wiki/code | ||||
| 			if ctx.FormBool("wiki") { | ||||
| 				ctx.Data["PageIsWiki"] = true | ||||
| 				repo.MustEnableWiki(ctx) | ||||
| 				return | ||||
| 			} | ||||
| 
 | ||||
| 			if ctx.Written() { | ||||
| 				return | ||||
| 			} | ||||
| 			context.RepoRef()(ctx) | ||||
| 			if ctx.Written() { | ||||
| 				return | ||||
| 			} | ||||
| 
 | ||||
| 			repo.MustBeNotEmpty(ctx) | ||||
| 		}) | ||||
| 
 | ||||
| 		m.Group("/media", func() { | ||||
| 			m.Get("/branch/*", context.RepoRefByType(context.RepoRefBranch), repo.SingleDownloadOrLFS) | ||||
| 			m.Get("/tag/*", context.RepoRefByType(context.RepoRefTag), repo.SingleDownloadOrLFS) | ||||
| @ -1578,6 +1558,8 @@ func registerRoutes(m *web.Router) { | ||||
| 			m.Get("/commit/*", context.RepoRefByType(context.RepoRefCommit), repo.RefBlame) | ||||
| 		}, repo.MustBeNotEmpty) | ||||
| 
 | ||||
| 		m.Get("/blob_excerpt/{sha}", repo.SetEditorconfigIfExists, repo.SetDiffViewStyle, repo.ExcerptBlob) | ||||
| 
 | ||||
| 		m.Group("", func() { | ||||
| 			m.Get("/graph", repo.Graph) | ||||
| 			m.Get("/commit/{sha:([a-f0-9]{7,64})$}", repo.SetEditorconfigIfExists, repo.SetDiffViewStyle, repo.SetWhitespaceBehavior, repo.Diff) | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| {{/* | ||||
| ==== DO NOT EDIT ==== | ||||
| {{/* ==== DO NOT EDIT ==== | ||||
| If you are customizing Gitea, please do not change this file. | ||||
| If you introduce mistakes in it, Gitea JavaScript code wouldn't run correctly. | ||||
| */}} | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| {{/* | ||||
| Two buttons (negative, positive): | ||||
| {{/* Two buttons (negative, positive): | ||||
| * ModalButtonTypes: "yes" (default) or "confirm" | ||||
| * ModalButtonCancelText | ||||
| * ModalButtonOkText | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| {{$blobExcerptLink := print $.RepoLink (Iif $.PageIsWiki "/wiki" "") "/blob_excerpt/" (PathEscape $.AfterCommitID) (QueryBuild "?" "anchor" $.Anchor)}} | ||||
| {{if $.IsSplitStyle}} | ||||
| 	{{range $k, $line := $.section.Lines}} | ||||
| 	<tr class="{{.GetHTMLDiffLineType}}-code nl-{{$k}} ol-{{$k}} line-expanded"> | ||||
| @ -6,42 +7,48 @@ | ||||
| 			<td class="lines-num lines-num-old" data-line-num="{{if $line.LeftIdx}}{{$line.LeftIdx}}{{end}}"> | ||||
| 				<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="{{$.RepoLink}}/blob_excerpt/{{PathEscape $.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=split&direction=down&wiki={{$.PageIsWiki}}&anchor={{$.Anchor}}"> | ||||
| 					<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=split&direction=down"> | ||||
| 						{{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="{{$.RepoLink}}/blob_excerpt/{{PathEscape $.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=split&direction=up&wiki={{$.PageIsWiki}}&anchor={{$.Anchor}}"> | ||||
| 					<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=split&direction=up"> | ||||
| 						{{svg "octicon-fold-up"}} | ||||
| 					</button> | ||||
| 				{{end}} | ||||
| 				{{if eq $expandDirection 2}} | ||||
| 					<button class="code-expander-button" hx-target="closest tr" hx-get="{{$.RepoLink}}/blob_excerpt/{{PathEscape $.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=split&direction=&wiki={{$.PageIsWiki}}&anchor={{$.Anchor}}"> | ||||
| 					<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=split"> | ||||
| 						{{svg "octicon-fold"}} | ||||
| 					</button> | ||||
| 				{{end}} | ||||
| 				</div> | ||||
| 			</td> | ||||
| 			<td colspan="7" class="lines-code lines-code-old ">{{$inlineDiff := $.section.GetComputedInlineDiffFor $line ctx.Locale}}{{/* | ||||
| 				*/}}{{template "repo/diff/section_code" dict "diff" $inlineDiff}}</td> | ||||
| 			<td colspan="7" class="lines-code lines-code-old"> | ||||
| 				{{- $inlineDiff := $.section.GetComputedInlineDiffFor $line ctx.Locale -}} | ||||
| 				{{- template "repo/diff/section_code" dict "diff" $inlineDiff -}} | ||||
| 			</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-{{$.FileNameHash}}L{{$line.LeftIdx}}{{end}}"></span></td> | ||||
| 			<td class="lines-escape lines-escape-old">{{if and $line.LeftIdx $inlineDiff.EscapeStatus.Escaped}}<button class="toggle-escape-button btn interact-bg" title="{{template "repo/diff/escape_title" dict "diff" $inlineDiff}}"></button>{{end}}</td> | ||||
| 			<td class="lines-type-marker lines-type-marker-old">{{if $line.LeftIdx}}<span class="tw-font-mono" data-type-marker=""></span>{{end}}</td> | ||||
| 			<td class="lines-code lines-code-old">{{/* | ||||
| 				*/}}{{if $line.LeftIdx}}{{template "repo/diff/section_code" dict "diff" $inlineDiff}}{{else}}{{/* | ||||
| 					*/}}<code class="code-inner"></code>{{/* | ||||
| 				*/}}{{end}}{{/* | ||||
| 			*/}}</td> | ||||
| 			<td class="lines-code lines-code-old"> | ||||
| 				{{- 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-{{$.FileNameHash}}R{{$line.RightIdx}}{{end}}"></span></td> | ||||
| 			<td class="lines-escape lines-escape-new">{{if and $line.RightIdx $inlineDiff.EscapeStatus.Escaped}}<button class="toggle-escape-button btn interact-bg" title="{{template "repo/diff/escape_title" dict "diff" $inlineDiff}}"></button>{{end}}</td> | ||||
| 			<td class="lines-type-marker lines-type-marker-new">{{if $line.RightIdx}}<span class="tw-font-mono" data-type-marker=""></span>{{end}}</td> | ||||
| 			<td class="lines-code lines-code-new">{{/* | ||||
| 				*/}}{{if $line.RightIdx}}{{template "repo/diff/section_code" dict "diff" $inlineDiff}}{{else}}{{/* | ||||
| 					*/}}<code class="code-inner"></code>{{/* | ||||
| 				*/}}{{end}}{{/* | ||||
| 			*/}}</td> | ||||
| 			<td class="lines-code lines-code-new"> | ||||
| 				{{- if $line.RightIdx -}} | ||||
| 					{{- template "repo/diff/section_code" dict "diff" $inlineDiff -}} | ||||
| 				{{- else -}} | ||||
| 					<code class="code-inner"></code> | ||||
| 				{{- end -}} | ||||
| 			</td> | ||||
| 		{{end}} | ||||
| 	</tr> | ||||
| 	{{end}} | ||||
| @ -53,17 +60,17 @@ | ||||
| 			<td colspan="2" class="lines-num"> | ||||
| 				<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="{{$.RepoLink}}/blob_excerpt/{{PathEscape $.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=unified&direction=down&wiki={{$.PageIsWiki}}&anchor={{$.Anchor}}"> | ||||
| 						<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=unified&direction=down"> | ||||
| 							{{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="{{$.RepoLink}}/blob_excerpt/{{PathEscape $.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=unified&direction=up&wiki={{$.PageIsWiki}}&anchor={{$.Anchor}}"> | ||||
| 						<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=unified&direction=up"> | ||||
| 							{{svg "octicon-fold-up"}} | ||||
| 						</button> | ||||
| 					{{end}} | ||||
| 					{{if eq $expandDirection 2}} | ||||
| 						<button class="code-expander-button" hx-target="closest tr" hx-get="{{$.RepoLink}}/blob_excerpt/{{PathEscape $.AfterCommitID}}?{{$line.GetBlobExcerptQuery}}&style=unified&direction=&wiki={{$.PageIsWiki}}&anchor={{$.Anchor}}"> | ||||
| 						<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=unified"> | ||||
| 							{{svg "octicon-fold"}} | ||||
| 						</button> | ||||
| 					{{end}} | ||||
|  | ||||
| @ -36,10 +36,7 @@ | ||||
| 			{{template "repo/diff/options_dropdown" .}} | ||||
| 			{{if .PageIsPullFiles}} | ||||
| 				<div id="diff-commit-select" data-issuelink="{{$.Issue.Link}}" data-queryparams="?style={{if $.IsSplitStyle}}split{{else}}unified{{end}}&whitespace={{$.WhitespaceBehavior}}&show-outdated={{$.ShowOutdatedComments}}" data-filter_changes_by_commit="{{ctx.Locale.Tr "repo.pulls.filter_changes_by_commit"}}"> | ||||
| 					{{/* | ||||
| 						the following will be replaced by vue component | ||||
| 						but this avoids any loading artifacts till the vue component is initialized | ||||
| 					*/}} | ||||
| 					{{/* the following will be replaced by vue component, but this avoids any loading artifacts till the vue component is initialized */}} | ||||
| 					<div class="ui jump dropdown basic button custom"> | ||||
| 						{{svg "octicon-git-commit"}} | ||||
| 					</div> | ||||
|  | ||||
| @ -1,2 +1,2 @@ | ||||
| {{if .diff.EscapeStatus.HasInvisible}}{{ctx.Locale.Tr "repo.invisible_runes_line"}} {{end}}{{/* | ||||
| */}}{{if .diff.EscapeStatus.HasAmbiguous}}{{ctx.Locale.Tr "repo.ambiguous_runes_line"}}{{end}} | ||||
| {{if .diff.EscapeStatus.HasInvisible}}{{ctx.Locale.Tr "repo.invisible_runes_line"}} {{end -}} | ||||
| {{- if .diff.EscapeStatus.HasAmbiguous}}{{ctx.Locale.Tr "repo.ambiguous_runes_line"}}{{end}} | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| {{$file := .file}} | ||||
| {{$blobExcerptRepoLink := or ctx.RootData.CommitRepoLink ctx.RootData.RepoLink}} | ||||
| {{$blobExcerptLink := print (or ctx.RootData.CommitRepoLink ctx.RootData.RepoLink) (Iif $.root.PageIsWiki "/wiki" "") "/blob_excerpt/" (PathEscape $.root.AfterCommitID) "?"}} | ||||
| <colgroup> | ||||
| 	<col width="50"> | ||||
| 	<col width="10"> | ||||
| @ -20,26 +20,24 @@ | ||||
| 					<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}}"> | ||||
| 							<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=split&direction=down&&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}}"> | ||||
| 							<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=split&direction=up&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}}"> | ||||
| 							<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=split&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> | ||||
| 					<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}} | ||||
| @ -47,65 +45,65 @@ | ||||
| 					<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-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> | ||||
| 					<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-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> | ||||
| 					<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}} | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| {{$file := .file}} | ||||
| {{$blobExcerptRepoLink := or ctx.RootData.CommitRepoLink ctx.RootData.RepoLink}} | ||||
| {{$blobExcerptLink := print (or ctx.RootData.CommitRepoLink ctx.RootData.RepoLink) (Iif $.root.PageIsWiki "/wiki" "") "/blob_excerpt/" (PathEscape $.root.AfterCommitID) "?"}} | ||||
| <colgroup> | ||||
| 	<col width="50"> | ||||
| 	<col width="50"> | ||||
| @ -16,17 +16,17 @@ | ||||
| 					<td colspan="2" class="lines-num"> | ||||
| 						<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=unified&direction=down&wiki={{$.root.PageIsWiki}}&anchor=diff-{{$file.NameHash}}K{{$line.SectionInfo.RightIdx}}"> | ||||
| 								<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=unified&direction=down&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=unified&direction=up&wiki={{$.root.PageIsWiki}}&anchor=diff-{{$file.NameHash}}K{{$line.SectionInfo.RightIdx}}"> | ||||
| 								<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=unified&direction=up&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=unified&direction=&wiki={{$.root.PageIsWiki}}&anchor=diff-{{$file.NameHash}}K{{$line.SectionInfo.RightIdx}}"> | ||||
| 								<button class="code-expander-button" hx-target="closest tr" hx-get="{{$blobExcerptLink}}&{{$line.GetBlobExcerptQuery}}&style=unified&anchor=diff-{{$file.NameHash}}K{{$line.SectionInfo.RightIdx}}"> | ||||
| 									{{svg "octicon-fold"}} | ||||
| 								</button> | ||||
| 							{{end}} | ||||
| @ -48,18 +48,16 @@ | ||||
| 			</td> | ||||
| 			<td class="lines-type-marker"><span class="tw-font-mono" data-type-marker="{{$line.GetLineTypeMarker}}"></span></td> | ||||
| 			{{if eq .GetType 4}} | ||||
| 				<td class="chroma lines-code blob-hunk">{{/* | ||||
| 					*/}}{{template "repo/diff/section_code" dict "diff" $inlineDiff}}{{/* | ||||
| 				*/}}</td> | ||||
| 				<td class="chroma lines-code blob-hunk">{{template "repo/diff/section_code" dict "diff" $inlineDiff}}</td> | ||||
| 			{{else}} | ||||
| 				<td class="chroma lines-code{{if (not $line.RightIdx)}} lines-code-old{{end}}">{{/* | ||||
| 					*/}}{{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-{{if $line.RightIdx}}right{{else}}left{{end}}{{if (not $line.CanComment)}} tw-invisible{{end}}" data-side="{{if $line.RightIdx}}right{{else}}left{{end}}" data-idx="{{if $line.RightIdx}}{{$line.RightIdx}}{{else}}{{$line.LeftIdx}}{{end}}">{{/* | ||||
| 							*/}}{{svg "octicon-plus"}}{{/* | ||||
| 						*/}}</button>{{/* | ||||
| 					*/}}{{end}}{{/* | ||||
| 					*/}}{{template "repo/diff/section_code" dict "diff" $inlineDiff}}{{/* | ||||
| 				*/}}</td> | ||||
| 				<td class="chroma lines-code{{if (not $line.RightIdx)}} lines-code-old{{end}}"> | ||||
| 					{{- 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-{{if $line.RightIdx}}right{{else}}left{{end}}{{if (not $line.CanComment)}} tw-invisible{{end}}" data-side="{{if $line.RightIdx}}right{{else}}left{{end}}" data-idx="{{if $line.RightIdx}}{{$line.RightIdx}}{{else}}{{$line.LeftIdx}}{{end}}"> | ||||
| 							{{- svg "octicon-plus" -}} | ||||
| 						</button> | ||||
| 					{{- end -}} | ||||
| 					{{- template "repo/diff/section_code" dict "diff" $inlineDiff -}} | ||||
| 				</td> | ||||
| 			{{end}} | ||||
| 		</tr> | ||||
| 		{{if $line.Comments}} | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| {{/* | ||||
| {{/* Template Attributes: | ||||
| * "labels" from query string (needed by JS) | ||||
| * QueryLink | ||||
| * Labels | ||||
|  | ||||
| @ -6,7 +6,7 @@ | ||||
| 		{{if $pageMeta.Issue}}data-update-url="{{$pageMeta.RepoLink}}/issues/milestone?issue_ids={{$pageMeta.Issue.ID}}"{{end}} | ||||
| > | ||||
| 	<input class="combo-value" name="milestone_id" type="hidden" value="{{$data.SelectedMilestoneID}}"> | ||||
| 	<div class="ui dropdown {{if not $pageMeta.CanModifyIssueOrPull}}disabled{{end}} "> | ||||
| 	<div class="ui dropdown {{if not $pageMeta.CanModifyIssueOrPull}}disabled{{end}}"> | ||||
| 		<a class="text muted"> | ||||
| 			<strong>{{ctx.Locale.Tr "repo.issues.new.milestone"}}</strong> {{if $pageMeta.CanModifyIssueOrPull}}{{svg "octicon-gear"}}{{end}} | ||||
| 		</a> | ||||
|  | ||||
| @ -367,8 +367,7 @@ | ||||
| 				{{end}} | ||||
| 			{{end}}{{/* end if: pull request status */}} | ||||
| 
 | ||||
| 			{{/* | ||||
| 			Manually Merged is not a well-known feature, it is used to mark a non-mergeable PR (already merged, conflicted) as merged | ||||
| 			{{/* Manually Merged is not a well-known feature, it is used to mark a non-mergeable PR (already merged, conflicted) as merged | ||||
| 			To test it: | ||||
| 			* Enable "Manually Merged" feature in the Repository Settings | ||||
| 			* Create a pull request, either: | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| {{/* | ||||
| Template Attributes: | ||||
| {{/* Template Attributes: | ||||
| * CommitStatus: summary of all commit status state | ||||
| * CommitStatuses: all commit status elements | ||||
| * MissingRequiredChecks: commit check contexts that are required by branch protection but not present | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| {{/* | ||||
| Template Attributes: | ||||
| {{/* Template Attributes: | ||||
| * Release: the release | ||||
| * IsLatest: boolean indicating whether this is the latest release, optional | ||||
| */}} | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| {{/* | ||||
| Template Attributes: | ||||
| {{/* Template Attributes: | ||||
| * CustomInit: do not initialize the editor automatically | ||||
| * ContainerId: id attribute for the container element | ||||
| * ContainerClasses: additional classes for the container element | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user