https://github.com/hugo-fixit/hugo-json-feed
Hugo theme component for JSON feed custom Output Format.
https://github.com/hugo-fixit/hugo-json-feed
hugo json-feed theme-component
Last synced: about 1 year ago
JSON representation
Hugo theme component for JSON feed custom Output Format.
- Host: GitHub
- URL: https://github.com/hugo-fixit/hugo-json-feed
- Owner: hugo-fixit
- License: mit
- Created: 2024-08-22T03:28:23.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2025-04-11T03:30:14.000Z (about 1 year ago)
- Last Synced: 2025-04-11T18:07:37.287Z (about 1 year ago)
- Topics: hugo, json-feed, theme-component
- Language: HTML
- Homepage: https://lruihao.cn/feed.json
- Size: 14.6 KB
- Stars: 7
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.en.md
- License: LICENSE
Awesome Lists containing this project
README
# Hugo JSON Feed
English | [中文](/README.md)
> Hugo theme component for JSON feed custom Output Format.
This component enables JSON feeds for your site.
## Demo
- [Home Feed](https://lruihao.cn/feed.json)
- [Section Feed](https://lruihao.cn/posts/feed.json)
- [Term Feed](https://lruihao.cn/collections/project/feed.json)
## Install Component
The installation method is the same as [installing a theme](https://fixit.lruihao.cn/documentation/installation/). There are several ways to install, choose one, for example, install through Hugo Modules:
```diff
[module]
[[module.imports]]
path = "github.com/hugo-fixit/FixIt"
+ [[module.imports]]
+ path = "github.com/hugo-fixit/hugo-json-feed"
```
## Configuration
Add "jsonfeed" to all the Page Kinds for which you want to create JSON feeds:
```toml
[outputs]
# /feed.json
home = ["html", "rss", "jsonfeed"]
# /posts/feed.json etc.
section = ["html", "rss", "jsonfeed"]
# /tags/foo/feed.json etc.
term = ["html", "rss", "jsonfeed"]
```
If your site uses multiple theme components, you need to merge the `outputs` configuration of all theme components. For example, if your site uses both the `FixIt` and `hugo-json-feed` theme components, you need to merge the `outputs` configuration of the two theme components:
```toml
[outputs]
_merge = "shallow"
home = ["html", "rss", "jsonfeed", "archives", "offline", "readme", "baidu_urls", "search"]
page = ["html", "markdown"]
section = ["html", "rss", "jsonfeed"]
taxonomy = ["html"]
term = ["html", "rss", "jsonfeed"]
```
### Parameters
You can set the following parameters in your site configuration file:
```toml
[params]
# Global Feed config for JSON feed.
[params.feed]
# The number of posts to include in the feed. If set to -1, all posts.
limit = 10
# whether to show the full text content in feed.
fullText = true
# Section page config (all pages in section)
[params.section]
# Section feed config for JSON feed.
[params.section.feed]
# The number of posts to include in the feed. If set to -1, all posts.
limit = -1
# whether to show the full text content in feed.
fullText = false
# Term list (category or tag) page config
[params.list]
# Term list feed config for JSON feed.
[params.list.feed]
# The number of posts to include in the feed. If set to -1, all posts.
limit = -1
# whether to show the full text content in feed.
fullText = false
```
### Front Matter
You can set the following parameters in the front matter of the content file:
```yaml
---
title: "Hello World"
date: 2024-08-24T16:06:33+08:00
hiddenFromFeed: true
feed:
# feed.limit only valid in section or term page(_index.md).
limit: 10
fullText: true
---
```