mirror of
https://github.com/gohugoio/hugo.git
synced 2025-01-12 14:43:05 +00:00
Misc paginator adjustments
* Rewind paginator for server mode * Add some more related tests. * Replace the clumsy scratch constructs in internal paginator template with variables See #5825
This commit is contained in:
parent
3db4a1cf7a
commit
612a06f067
5 changed files with 121 additions and 13 deletions
|
@ -81,3 +81,7 @@ func (p *pagePaginator) Paginator(options ...interface{}) (*page.Pager, error) {
|
|||
|
||||
return p.current, nil
|
||||
}
|
||||
|
||||
func (p *pagePaginator) rewind() {
|
||||
p.current = p.current.First()
|
||||
}
|
||||
|
|
98
hugolib/paginator_test.go
Normal file
98
hugolib/paginator_test.go
Normal file
|
@ -0,0 +1,98 @@
|
|||
// Copyright 2019 The Hugo Authors. All rights reserved.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package hugolib
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestPaginator(t *testing.T) {
|
||||
configFile := `
|
||||
baseURL = "https://example.com/foo/"
|
||||
paginate = 3
|
||||
paginatepath = "thepage"
|
||||
|
||||
[languages.en]
|
||||
weight = 1
|
||||
contentDir = "content/en"
|
||||
|
||||
[languages.nn]
|
||||
weight = 2
|
||||
contentDir = "content/nn"
|
||||
|
||||
`
|
||||
b := newTestSitesBuilder(t).WithConfigFile("toml", configFile)
|
||||
var content []string
|
||||
for i := 0; i < 9; i++ {
|
||||
for _, contentDir := range []string{"content/en", "content/nn"} {
|
||||
content = append(content, fmt.Sprintf(contentDir+"/blog/page%d.md", i), fmt.Sprintf(`---
|
||||
title: Page %d
|
||||
---
|
||||
|
||||
Content.
|
||||
`, i))
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
b.WithContent(content...)
|
||||
|
||||
pagTemplate := `
|
||||
{{ $pag := $.Paginator }}
|
||||
Total: {{ $pag.TotalPages }}
|
||||
First: {{ $pag.First.URL }}
|
||||
Page Number: {{ $pag.PageNumber }}
|
||||
URL: {{ $pag.URL }}
|
||||
{{ with $pag.Next }}Next: {{ .URL }}{{ end }}
|
||||
{{ with $pag.Prev }}Prev: {{ .URL }}{{ end }}
|
||||
{{ range $i, $e := $pag.Pagers }}
|
||||
{{ printf "%d: %d/%d %t" $i $pag.PageNumber .PageNumber (eq . $pag) -}}
|
||||
{{ end }}
|
||||
`
|
||||
|
||||
b.WithTemplatesAdded("index.html", pagTemplate)
|
||||
b.WithTemplatesAdded("index.xml", pagTemplate)
|
||||
|
||||
b.Build(BuildCfg{})
|
||||
|
||||
b.AssertFileContent("public/index.html",
|
||||
"Page Number: 1",
|
||||
"0: 1/1 true")
|
||||
|
||||
b.AssertFileContent("public/thepage/2/index.html",
|
||||
"Total: 3",
|
||||
"Page Number: 2",
|
||||
"URL: /foo/thepage/2/",
|
||||
"Next: /foo/thepage/3/",
|
||||
"Prev: /foo/",
|
||||
"1: 2/2 true",
|
||||
)
|
||||
|
||||
b.AssertFileContent("public/index.xml",
|
||||
"Page Number: 1",
|
||||
"0: 1/1 true")
|
||||
b.AssertFileContent("public/thepage/2/index.xml",
|
||||
"Page Number: 2",
|
||||
"1: 2/2 true")
|
||||
|
||||
b.AssertFileContent("public/nn/index.html",
|
||||
"Page Number: 1",
|
||||
"0: 1/1 true")
|
||||
|
||||
b.AssertFileContent("public/nn/index.xml",
|
||||
"Page Number: 1",
|
||||
"0: 1/1 true")
|
||||
|
||||
}
|
|
@ -172,7 +172,11 @@ func (s *Site) renderPaginator(p *pageState, layouts []string) error {
|
|||
d.Type = f
|
||||
|
||||
// Rewind
|
||||
p.paginator.current = p.paginator.current.First()
|
||||
p.paginator.rewind()
|
||||
defer func() {
|
||||
// Prepare for any re-rendering in server mode.
|
||||
p.paginator.rewind()
|
||||
}()
|
||||
|
||||
// Write alias for page 1
|
||||
d.Addends = fmt.Sprintf("/%s/%d", paginatePath, 1)
|
||||
|
|
13
tpl/tplimpl/embedded/templates.autogen.go
generated
13
tpl/tplimpl/embedded/templates.autogen.go
generated
|
@ -239,21 +239,22 @@ if (!doNotTrack) {
|
|||
<li class="page-item{{ if not $pag.HasPrev }} disabled{{ end }}">
|
||||
<a href="{{ if $pag.HasPrev }}{{ $pag.Prev.URL }}{{ end }}" class="page-link" aria-label="Previous"><span aria-hidden="true">«</span></a>
|
||||
</li>
|
||||
{{ $.Scratch.Set "__paginator.ellipsed" false }}
|
||||
{{ $ellipsed := false }}
|
||||
{{ $shouldEllipse := false }}
|
||||
{{ range $pag.Pagers }}
|
||||
{{ $right := sub .TotalPages .PageNumber }}
|
||||
{{ $showNumber := or (le .PageNumber 3) (eq $right 0) }}
|
||||
{{ $showNumber := or $showNumber (and (gt .PageNumber (sub $pag.PageNumber 2)) (lt .PageNumber (add $pag.PageNumber 2))) }}
|
||||
{{ if $showNumber }}
|
||||
{{ $.Scratch.Set "__paginator.ellipsed" false }}
|
||||
{{ $.Scratch.Set "__paginator.shouldEllipse" false }}
|
||||
{{ $ellipsed = false }}
|
||||
{{ $shouldEllipse = false }}
|
||||
{{ else }}
|
||||
{{ $.Scratch.Set "__paginator.shouldEllipse" (not ($.Scratch.Get "__paginator.ellipsed") ) }}
|
||||
{{ $.Scratch.Set "__paginator.ellipsed" true }}
|
||||
{{ $shouldEllipse = not $ellipsed }}
|
||||
{{ $ellipsed = true }}
|
||||
{{ end }}
|
||||
{{ if $showNumber }}
|
||||
<li class="page-item{{ if eq . $pag }} active{{ end }}"><a class="page-link" href="{{ .URL }}">{{ .PageNumber }}</a></li>
|
||||
{{ else if ($.Scratch.Get "__paginator.shouldEllipse") }}
|
||||
{{ else if $shouldEllipse }}
|
||||
<li class="page-item disabled"><span aria-hidden="true"> … </span></li>
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
|
|
|
@ -9,21 +9,22 @@
|
|||
<li class="page-item{{ if not $pag.HasPrev }} disabled{{ end }}">
|
||||
<a href="{{ if $pag.HasPrev }}{{ $pag.Prev.URL }}{{ end }}" class="page-link" aria-label="Previous"><span aria-hidden="true">«</span></a>
|
||||
</li>
|
||||
{{ $.Scratch.Set "__paginator.ellipsed" false }}
|
||||
{{ $ellipsed := false }}
|
||||
{{ $shouldEllipse := false }}
|
||||
{{ range $pag.Pagers }}
|
||||
{{ $right := sub .TotalPages .PageNumber }}
|
||||
{{ $showNumber := or (le .PageNumber 3) (eq $right 0) }}
|
||||
{{ $showNumber := or $showNumber (and (gt .PageNumber (sub $pag.PageNumber 2)) (lt .PageNumber (add $pag.PageNumber 2))) }}
|
||||
{{ if $showNumber }}
|
||||
{{ $.Scratch.Set "__paginator.ellipsed" false }}
|
||||
{{ $.Scratch.Set "__paginator.shouldEllipse" false }}
|
||||
{{ $ellipsed = false }}
|
||||
{{ $shouldEllipse = false }}
|
||||
{{ else }}
|
||||
{{ $.Scratch.Set "__paginator.shouldEllipse" (not ($.Scratch.Get "__paginator.ellipsed") ) }}
|
||||
{{ $.Scratch.Set "__paginator.ellipsed" true }}
|
||||
{{ $shouldEllipse = not $ellipsed }}
|
||||
{{ $ellipsed = true }}
|
||||
{{ end }}
|
||||
{{ if $showNumber }}
|
||||
<li class="page-item{{ if eq . $pag }} active{{ end }}"><a class="page-link" href="{{ .URL }}">{{ .PageNumber }}</a></li>
|
||||
{{ else if ($.Scratch.Get "__paginator.shouldEllipse") }}
|
||||
{{ else if $shouldEllipse }}
|
||||
<li class="page-item disabled"><span aria-hidden="true"> … </span></li>
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
|
|
Loading…
Reference in a new issue