metalsmith-reading-time
TypeScript icon, indicating that this package has built-in type declarations

2.0.1 • Public • Published

metalsmith-reading-time

npm: version npm: downloads

Snyk: vulnerabilities codecov: coverage license

A Metalsmith plugin to estimate pages' reading times.

Installation

npm install --save metalsmith-reading-time

JavaScript Usage

const Metalsmith  = require('metalsmith');
const readingTime = require('metalsmith-reading-time');

Metalsmith(__dirname)
    .use(readingTime({
        // options here
    }))
    .build((err) => {
        if (err) {
            throw err;
        }
    });

File metadata

This plugin adds a metadata field named readingTime to each file which can be used with templating engines, such as with handlebars:

Reading time: {{ readingTime }}

The rest of the page content.

Reading time will be reported in minutes in the form "# min read" per reading-time.

Options

pattern (optional)

Type: string Default: "**/*"

A micromatch glob pattern to find input files.

stripHtml (optional)

Type: boolean Default: true

Whether to strip HTML tags from content before evaluating the reading time or not.

replacements (optional)

type: [string | RegExp, string][] Default: []

A list of tuples fed to String.replace() to get rid of meaningless content before evaluating the reading time.

readingTime (optional)

Type: object Default: {}

An object of reading-time options, example:

{
  "readingTime": {
    "wordsPerMinute": 200
  }
}

Changelog

Changelog

Package Sidebar

Install

npm i metalsmith-reading-time

Weekly Downloads

6

Version

2.0.1

License

GPL-3.0-or-later

Unpacked Size

44.1 kB

Total Files

6

Last publish

Collaborators

  • emmercm