FFF

Converts the data structure to FFF

Options

extensions string[]

The list extensions this plugin applies to

Default:
[ ".html" ]
presets object[]

The list of presets to apply

See https://fff.js.org/concepts/flavor-transform.html#fff-transform-preset

strict boolean object
Default:
false
date created updated published

To convert the generic date field to one of these values

getGitDate boolean

Get the date from the git history

postTypeDiscovery boolean

Description

FFF is a front matter specification designed to be framework-agnostic, so you can reuse your data with different static site generators, like Hexo, Hugo or Lume.

This plugin converts the page data to follow the FFF standard, so if you use this standard with any other SSG and want to migrate to Lume (or vice versa), this plugin should ease the migration.

Installation

Import this plugin in your _config.ts file to use it:

import lume from "lume/mod.ts";
import fff from "lume/plugins/fff.ts";

const site = lume();

site.use(fff(/* Options */));

export default site;

Usage

The plugin can modify the page data using the Flavor Transform feature.

As an example, Lume's Data model uses the variable date to save the page date. But date can have many meanings (creation date, last updated date, published date, etc). The FFF standard defines three date variables: created, updated and published and it will create one of these variables from the date variable:

site.use(fff({
  date: "published", // Create the variable 'published' from the variable 'date'
}));

See the FFF documentation for more info.