mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 06:24:11 +01:00 
			
		
		
		
	When view _Siderbar or _Footer, just display once (#19501)
Co-authored-by: zeripath <art27@cantab.net>
This commit is contained in:
		
							parent
							
								
									2728f0c213
								
							
						
					
					
						commit
						5651c650c0
					
				@ -191,6 +191,9 @@ func renderViewPage(ctx *context.Context) (*git.Repository, *git.TreeEntry) {
 | 
			
		||||
	ctx.Data["title"] = pageName
 | 
			
		||||
	ctx.Data["RequireHighlightJS"] = true
 | 
			
		||||
 | 
			
		||||
	isSideBar := pageName == "_Sidebar"
 | 
			
		||||
	isFooter := pageName == "_Footer"
 | 
			
		||||
 | 
			
		||||
	// lookup filename in wiki - get filecontent, gitTree entry , real filename
 | 
			
		||||
	data, entry, pageFilename, noEntry := wikiContentsByName(ctx, commit, pageName)
 | 
			
		||||
	if noEntry {
 | 
			
		||||
@ -203,20 +206,30 @@ func renderViewPage(ctx *context.Context) (*git.Repository, *git.TreeEntry) {
 | 
			
		||||
		return nil, nil
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	sidebarContent, _, _, _ := wikiContentsByName(ctx, commit, "_Sidebar")
 | 
			
		||||
	if ctx.Written() {
 | 
			
		||||
		if wikiRepo != nil {
 | 
			
		||||
			wikiRepo.Close()
 | 
			
		||||
	var sidebarContent []byte
 | 
			
		||||
	if !isSideBar {
 | 
			
		||||
		sidebarContent, _, _, _ = wikiContentsByName(ctx, commit, "_Sidebar")
 | 
			
		||||
		if ctx.Written() {
 | 
			
		||||
			if wikiRepo != nil {
 | 
			
		||||
				wikiRepo.Close()
 | 
			
		||||
			}
 | 
			
		||||
			return nil, nil
 | 
			
		||||
		}
 | 
			
		||||
		return nil, nil
 | 
			
		||||
	} else {
 | 
			
		||||
		sidebarContent = data
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	footerContent, _, _, _ := wikiContentsByName(ctx, commit, "_Footer")
 | 
			
		||||
	if ctx.Written() {
 | 
			
		||||
		if wikiRepo != nil {
 | 
			
		||||
			wikiRepo.Close()
 | 
			
		||||
	var footerContent []byte
 | 
			
		||||
	if !isFooter {
 | 
			
		||||
		footerContent, _, _, _ = wikiContentsByName(ctx, commit, "_Footer")
 | 
			
		||||
		if ctx.Written() {
 | 
			
		||||
			if wikiRepo != nil {
 | 
			
		||||
				wikiRepo.Close()
 | 
			
		||||
			}
 | 
			
		||||
			return nil, nil
 | 
			
		||||
		}
 | 
			
		||||
		return nil, nil
 | 
			
		||||
	} else {
 | 
			
		||||
		footerContent = data
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	rctx := &markup.RenderContext{
 | 
			
		||||
@ -237,27 +250,35 @@ func renderViewPage(ctx *context.Context) (*git.Repository, *git.TreeEntry) {
 | 
			
		||||
 | 
			
		||||
	ctx.Data["EscapeStatus"], ctx.Data["content"] = charset.EscapeControlString(buf.String())
 | 
			
		||||
 | 
			
		||||
	buf.Reset()
 | 
			
		||||
	if err := markdown.Render(rctx, bytes.NewReader(sidebarContent), &buf); err != nil {
 | 
			
		||||
		if wikiRepo != nil {
 | 
			
		||||
			wikiRepo.Close()
 | 
			
		||||
	if !isSideBar {
 | 
			
		||||
		buf.Reset()
 | 
			
		||||
		if err := markdown.Render(rctx, bytes.NewReader(sidebarContent), &buf); err != nil {
 | 
			
		||||
			if wikiRepo != nil {
 | 
			
		||||
				wikiRepo.Close()
 | 
			
		||||
			}
 | 
			
		||||
			ctx.ServerError("Render", err)
 | 
			
		||||
			return nil, nil
 | 
			
		||||
		}
 | 
			
		||||
		ctx.ServerError("Render", err)
 | 
			
		||||
		return nil, nil
 | 
			
		||||
		ctx.Data["sidebarPresent"] = sidebarContent != nil
 | 
			
		||||
		ctx.Data["sidebarEscapeStatus"], ctx.Data["sidebarContent"] = charset.EscapeControlString(buf.String())
 | 
			
		||||
	} else {
 | 
			
		||||
		ctx.Data["sidebarPresent"] = false
 | 
			
		||||
	}
 | 
			
		||||
	ctx.Data["sidebarPresent"] = sidebarContent != nil
 | 
			
		||||
	ctx.Data["sidebarEscapeStatus"], ctx.Data["sidebarContent"] = charset.EscapeControlString(buf.String())
 | 
			
		||||
 | 
			
		||||
	buf.Reset()
 | 
			
		||||
	if err := markdown.Render(rctx, bytes.NewReader(footerContent), &buf); err != nil {
 | 
			
		||||
		if wikiRepo != nil {
 | 
			
		||||
			wikiRepo.Close()
 | 
			
		||||
	if !isFooter {
 | 
			
		||||
		buf.Reset()
 | 
			
		||||
		if err := markdown.Render(rctx, bytes.NewReader(footerContent), &buf); err != nil {
 | 
			
		||||
			if wikiRepo != nil {
 | 
			
		||||
				wikiRepo.Close()
 | 
			
		||||
			}
 | 
			
		||||
			ctx.ServerError("Render", err)
 | 
			
		||||
			return nil, nil
 | 
			
		||||
		}
 | 
			
		||||
		ctx.ServerError("Render", err)
 | 
			
		||||
		return nil, nil
 | 
			
		||||
		ctx.Data["footerPresent"] = footerContent != nil
 | 
			
		||||
		ctx.Data["footerEscapeStatus"], ctx.Data["footerContent"] = charset.EscapeControlString(buf.String())
 | 
			
		||||
	} else {
 | 
			
		||||
		ctx.Data["footerPresent"] = false
 | 
			
		||||
	}
 | 
			
		||||
	ctx.Data["footerPresent"] = footerContent != nil
 | 
			
		||||
	ctx.Data["footerEscapeStatus"], ctx.Data["footerContent"] = charset.EscapeControlString(buf.String())
 | 
			
		||||
 | 
			
		||||
	// get commit count - wiki revisions
 | 
			
		||||
	commitsCount, _ := wikiRepo.FileCommitsCount("master", pageFilename)
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user