2019-01-02 11:33:26 +00:00
|
|
|
// 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"
|
|
|
|
|
2023-07-28 08:53:47 +00:00
|
|
|
"github.com/gohugoio/hugo/resources/kinds"
|
2019-01-02 11:33:26 +00:00
|
|
|
"github.com/gohugoio/hugo/resources/page"
|
|
|
|
)
|
|
|
|
|
|
|
|
type pageData struct {
|
|
|
|
*pageState
|
|
|
|
|
|
|
|
dataInit sync.Once
|
|
|
|
data page.Data
|
|
|
|
}
|
|
|
|
|
2022-03-17 21:03:27 +00:00
|
|
|
func (p *pageData) Data() any {
|
2019-01-02 11:33:26 +00:00
|
|
|
p.dataInit.Do(func() {
|
|
|
|
p.data = make(page.Data)
|
|
|
|
|
2023-07-28 08:53:47 +00:00
|
|
|
if p.Kind() == kinds.KindPage {
|
2019-01-02 11:33:26 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
switch p.Kind() {
|
2023-07-28 08:53:47 +00:00
|
|
|
case kinds.KindTerm:
|
2019-09-10 09:26:34 +00:00
|
|
|
b := p.treeRef.n
|
|
|
|
name := b.viewInfo.name
|
|
|
|
termKey := b.viewInfo.termKey
|
2019-01-02 11:33:26 +00:00
|
|
|
|
2019-09-10 09:26:34 +00:00
|
|
|
taxonomy := p.s.Taxonomies()[name.plural].Get(termKey)
|
2019-01-02 11:33:26 +00:00
|
|
|
|
2019-09-10 09:26:34 +00:00
|
|
|
p.data[name.singular] = taxonomy
|
|
|
|
p.data["Singular"] = name.singular
|
|
|
|
p.data["Plural"] = name.plural
|
|
|
|
p.data["Term"] = b.viewInfo.term()
|
2023-07-28 08:53:47 +00:00
|
|
|
case kinds.KindTaxonomy:
|
2019-09-10 09:26:34 +00:00
|
|
|
b := p.treeRef.n
|
|
|
|
name := b.viewInfo.name
|
2019-01-02 11:33:26 +00:00
|
|
|
|
2019-09-10 09:26:34 +00:00
|
|
|
p.data["Singular"] = name.singular
|
|
|
|
p.data["Plural"] = name.plural
|
|
|
|
p.data["Terms"] = p.s.Taxonomies()[name.plural]
|
2019-01-02 11:33:26 +00:00
|
|
|
// 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
|
|
|
|
}
|