/hexo-generator-anything

Hexo generator for custom Frontmatter variables

Primary LanguageJavaScriptMIT LicenseMIT

GitHub package.json version issues npm

Hexo Generator Anything

Hexo plugin to generate index pages from custom front matter variables.

ℹ️ This project is a fork from hexo-index-anything by Levi Wheatcroft, who is no longer maintaining the project. I have refactored the code and introduced some new features ... see below.

Introduction

Suppose you have an author variable in your front matter, this plugin will generate an overview page of all authors (called INDEX) and for each author, a listing page with all posts by that author (POSTS).

You can define multiple indexes to be created, by configuring several index-mappings out of your Frontmatter variables (see Configuration).

Example

The Frontmatter data of the following two posts...

../source/_posts/post-1.md

---
title: First Post
author: Maria
---

../source/_posts/post-2.md

---
title: Second Post
author: Jonas
---

../source/_posts/post-3.md

---
title: Third Post
author: Jonas
---

... will lead to:

  • ../output/author/index.html
    INDEX file with a link list of all authors

  • ../output/author/maria.html
    POSTS file with list of all posts from Maria, here 'First Post' only

  • ../output/author/jonas.html
    POSTS file with list of all posts from Jonas, here 'Second Post' and 'Third Post'

If you have activated the Hexo configuration attribute post_asset_folder, then the output will be:

  • ../output/author/index.html
  • ../output/author/maria/index.html
  • ../output/author/jonas/index.html

Installation

npm install hexo-generator-anything --save

Configuration

_config.yml

To configure the plugin, add following section to your Hexo's root _config.yml:

anything:
  layout_index: anything-index
  layout_posts: anything-posts
  index_mappings:
    - variable: author
      path: author
    - variable: my-other-variable
      path: others

The settings in depth:

Settings Description
layout_index EJS template for processing INDEX file
(if not set, Hexo's default index.ejs will be used)
layout_posts EJS template for processing POSTS file
(if not set, Hexo's default index.ejs will be used)
index_mappings List of Anything mappings
... variable Frontmatter variable in your posts to generate an index of
... path Part of the path of the output files, which represents the index

You can find examples for layout_index.ejs and layout_posts.ejs in the package samples folder under /node_modules/hexo-generator-anything/ after installation. Place the files in your Hexo's layout folder.

Additional Markdown Files

For generating the INDEX page, you can enrich the information about each author (variable value = key), by providing a Markdown file in in your sources folder: ../source/anything/{index}/{key}.

To stay with the example above, we have in index called authors and two keys: maria and jonas:

|- source
|  |- _anything
|  |  |- authors
|  |  |  |-> maria.md
|  |  |  |-> jonas.md 

Each of these files has to have at least one Frontmatter variable called title, where you can overwrite the default key string (value of the index variable in the posts). You can extend the Frontmatter with as many variables as you want and use it in your INDEX EJS template.

The content of the MD file will also be available in the data for generating the INDEX page.

Example:

---
title: Marias Posts
avatar: ./photos/maria.jpg
email: maria@my-domain.com
---

Maria is writer of the month. Don't miss her tweets on [https://twitter.com/maria](https://twitter.com/maria)

The INDEX page itself, may have a linked Markdown file too, to provide content or additional data:

|- source
|  |- _anything
|  |  |- authors
|  |  |  |-> index.md
|  |  |  |-> ...

Usage

Install, configure, then run hexo generate as usual.

Contributing

Yes, please ... fork the project, make your changes and submit pull requests against the main branch.

Demo

I have created this project for my blog and I use it to group some posts into series. You can see the result at: https://kiko.io/series

More Information

I have a section for this project on my blog with posts regarding this project (automatically generated by this plugin ;) at http://kiko.io/projects/hexo-generator-anything

History

1.0.5

  • Path fix (Lowercase)

1.0.4

  • Replaced vulnerable string.js library

1.0.3

  • Refactorings
  • Introducing Markdown file for INDEX page
  • titleSeparator setting removed
  • Updated samples

1.0.1/2

  • Markdown data fix

1.0.0

  • Initial version

License

MIT : http://opensource.org/licenses/MIT

Codebase Vizualization

For an inactive diagram, please visit Repo Visualization App... Visualization of the codebase