Use the tree for taxonomy.Pages()
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 18 Feb 2020 17:49:11 +0000 (18:49 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 18 Feb 2020 18:47:45 +0000 (19:47 +0100)
hugolib/content_map_page.go
hugolib/page.go
hugolib/taxonomy_test.go

index 3269abe12a1884d10b0485c9199ee7fbcbcb20da..06d1310ec81f88698a9282065fbeaecd4608505a 100644 (file)
@@ -827,6 +827,20 @@ func (b *pagesMapBucket) getTaxonomies() page.Pages {
        return b.sections
 }
 
+func (b *pagesMapBucket) getTaxonomyEntries() page.Pages {
+       var pas page.Pages
+       ref := b.owner.treeRef
+       viewInfo := ref.n.viewInfo
+       prefix := strings.ToLower("/" + viewInfo.name.plural + "/" + viewInfo.termKey + "/")
+       ref.m.taxonomyEntries.WalkPrefix(prefix, func(s string, v interface{}) bool {
+               n := v.(*contentNode)
+               pas = append(pas, n.viewInfo.ref.p)
+               return false
+       })
+       page.SortByDefault(pas)
+       return pas
+}
+
 type sectionAggregate struct {
        datesAll             resource.Dates
        datesSection         resource.Dates
index fa6c84d87ddf4975a9c4ec2caaf97d7c9197a0aa..1384d7293c7f387430d3ee43ee52dd1c6bc39493 100644 (file)
@@ -186,10 +186,7 @@ func (p *pageState) Pages() page.Pages {
                case page.KindSection, page.KindHome:
                        pages = p.getPagesAndSections()
                case page.KindTaxonomy:
-                       b := p.treeRef.n
-                       viewInfo := b.viewInfo
-                       taxonomy := p.s.Taxonomies()[viewInfo.name.plural].Get(viewInfo.termKey)
-                       pages = taxonomy.Pages()
+                       pages = p.bucket.getTaxonomyEntries()
                case page.KindTaxonomyTerm:
                        pages = p.bucket.getTaxonomies()
                default:
index 6d049a0c3167e5e4fe55e211f2780449a4d74ede..d91e7699f3808f875815c8cd46954132d4fe1132 100644 (file)
@@ -538,14 +538,28 @@ categories.funny:|/blog/p1/|
 
 }
 
-func TestTaxonomiesParent(t *testing.T) {
+func TestTaxonomiesPageCollections(t *testing.T) {
        t.Parallel()
 
        b := newTestSitesBuilder(t)
-       b.WithContent("p.md", `---
-title: "Page"
+       b.WithContent("p1.md", `---
+title: "Page1"
+categories: ["funny", "cats"]
+---
+`, "p2.md", `---
+title: "Page2"
 categories: ["funny"]
 ---
+`)
+
+       b.WithTemplatesAdded("index.html", `
+{{ $categories := site.GetPage "categories" }}
+{{ $funny := site.GetPage "categories/funny" }}
+{{ $cats := site.GetPage "categories/cats" }}
+
+Categories Pages: {{ range $categories.Pages}}{{.RelPermalink }}|{{ end }}:END
+Funny Pages: {{ range $funny.Pages}}{{.RelPermalink }}|{{ end }}:END
+Cats Pages: {{ range $cats.Pages}}{{.RelPermalink }}|{{ end }}:END
 
 `)
 
@@ -560,7 +574,13 @@ categories: ["funny"]
        b.Assert(cat.Parent().IsHome(), qt.Equals, true)
        b.Assert(funny.Parent(), qt.Equals, cat)
 
-       b.AssertFileContent("public/categories/funny/index.xml", `<link>http://example.com/p/</link>`)
+       b.AssertFileContent("public/index.html", `
+Categories Pages: /categories/cats/|/categories/funny/|:END
+Funny Pages: /p1/|/p2/|:END
+Cats Pages: /p1/|:END
+`)
+
+       b.AssertFileContent("public/categories/funny/index.xml", `<link>http://example.com/p1/</link>`)
        b.AssertFileContent("public/categories/index.xml", `<link>http://example.com/categories/funny/</link>`)
 
 }