mirror of
https://github.com/gohugoio/hugo.git
synced 2025-01-02 19:51:35 +00:00
fc045e12a9
And we have taken great measures to limit potential site breakage: * For `disableKinds` and `outputs` we try to map from old to new values if possible, if not we print an ERROR that can be toggled off if not relevant. * The layout lookup is mostly compatible with more options for the new `term` kind. That leaves: * Where queries in site.Pages using taxonomy/taxonomyTerm Kind values as filter. * Other places where these kind value are used in the templates (classes etc.) Fixes #6911 Fixes #7395
67 lines
1.7 KiB
Go
67 lines
1.7 KiB
Go
// 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 (
|
|
"sync"
|
|
|
|
"github.com/gohugoio/hugo/resources/page"
|
|
)
|
|
|
|
type pageData struct {
|
|
*pageState
|
|
|
|
dataInit sync.Once
|
|
data page.Data
|
|
}
|
|
|
|
func (p *pageData) Data() interface{} {
|
|
p.dataInit.Do(func() {
|
|
p.data = make(page.Data)
|
|
|
|
if p.Kind() == page.KindPage {
|
|
return
|
|
}
|
|
|
|
switch p.Kind() {
|
|
case page.KindTerm:
|
|
b := p.treeRef.n
|
|
name := b.viewInfo.name
|
|
termKey := b.viewInfo.termKey
|
|
|
|
taxonomy := p.s.Taxonomies()[name.plural].Get(termKey)
|
|
|
|
p.data[name.singular] = taxonomy
|
|
p.data["Singular"] = name.singular
|
|
p.data["Plural"] = name.plural
|
|
p.data["Term"] = b.viewInfo.term()
|
|
case page.KindTaxonomy:
|
|
b := p.treeRef.n
|
|
name := b.viewInfo.name
|
|
|
|
p.data["Singular"] = name.singular
|
|
p.data["Plural"] = name.plural
|
|
p.data["Terms"] = p.s.Taxonomies()[name.plural]
|
|
// keep the following just for legacy reasons
|
|
p.data["OrderedIndex"] = p.data["Terms"]
|
|
p.data["Index"] = p.data["Terms"]
|
|
}
|
|
|
|
// Assign the function to the map to make sure it is lazily initialized
|
|
p.data["pages"] = p.Pages
|
|
|
|
})
|
|
|
|
return p.data
|
|
}
|