Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

docmatter

bevry467Artistic-2.04.7.0

Battle tested SSG front matter parser. Extracted from DocPad. Delimiter lines have 3+ of the same character (such as /*** and ***/) allowing front matters to work with the syntax highlighting of your code editor. Supports custom parsers, e.g. `--- cso

coffeescript, data, esnext, extract, extracting, front, front-matter, frontmatter, generator, matter, meta, meta-data, metadata, node, ssg, static-site-generator, template

readme

docmatter

Status of the GitHub Workflow: bevry NPM version NPM downloads
GitHub Sponsors donate button ThanksDev donate button Patreon donate button Liberapay donate button Buy Me A Coffee donate button Open Collective donate button crypto donate button PayPal donate button
Discord server badge Twitch community badge

Battle tested SSG front matter parser. Extracted from DocPad. Delimiter lines have 3+ of the same character (such as /*** and ***/) allowing front matters to work with the syntax highlighting of your code editor. Supports custom parsers, e.g. --- cson. Parsers are handled externally.

Usage

docmatter is designed to be functional yet minimal, default parser as well as parsing of the headers are handled by you

const docmatter = require('docmatter')
const yamljs = require('yamljs')

function parse (input) {
    const matter = docmatter(input)

    // if no front matter: {content}
    if (!matter.header) return { content: matter.content.trim() }

    // if front matter: {delimiter, parser, header, body, content}
    let data = null
    switch (matter.parser) {
        case 'json':
            if (matter.header[0] === '{' && matter.header[matter.header.length - 1] === '}') {
                data = JSON.parse(matter.header)
            }
            else {
                data = JSON.parse(`{${matter.header}}`)
            }
            break;


        case 'yaml':
        default:
            data = yamljs.parse(
                matter.header.replace(/\t/g, '    ')  // YAML doesn't support tabs that well
            )
            break;
    }
    return { data, content: matter.body.trim() }
}


// no content and only front matter
console.log(parse(`
---
title: Hello World
---
`))
// => { data: { title: 'Hello World' }, content: '' }


// markdown content with default front matter
console.log(parse(`
---
title: Hello World
---

**hello world**
`))
// => { data: { title: 'Hello World' }, content: '**hello world**' }


// markdown content with json front matter
console.log(parse(`
--- json
"title": "Hello World"
---

**hello world**
`))
// => { data: { title: 'Hello World' }, content: '**hello world**' }


// markdown content with no front matter
console.log(parse(`
**hello world**
`))
// => { content: '**hello world**' }


// javascript content with default front matter
console.log(parse(`
/***
minify: true
***/

alert('Hello World')
`))
// => { data: { minify: true }, content: 'alert(\'Hello World\')' }

Install

npm

  • Install: npm install --save docmatter
  • Import: import * as pkg from ('docmatter')
  • Require: const pkg = require('docmatter')

Editions

This package is published with the following editions:

  • docmatter/source/index.coffee is CoffeeScript source code with Require for modules
  • docmatter aliases docmatter/edition-esnext/index.js
  • docmatter/edition-esnext/index.js is CoffeeScript compiled for Node.js 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modules

History

Discover the release history by heading on over to the HISTORY.md file.

Backers

Code

Discover how to contribute via the CONTRIBUTING.md file.

Authors

Maintainers

Contributors

Finances

GitHub Sponsors donate button ThanksDev donate button Patreon donate button Liberapay donate button Buy Me A Coffee donate button Open Collective donate button crypto donate button PayPal donate button

Sponsors

  • Andrew Nesbitt — Software engineer and researcher
  • Balsa — We're Balsa, and we're building tools for builders.
  • Codecov — Empower developers with tools to improve code quality and testing.
  • Poonacha Medappa
  • Rob Morris
  • Sentry — Real-time crash reporting for your web apps, mobile apps, and games.
  • Syntax — Syntax Podcast

Donors

License

Unless stated otherwise all works are:

and licensed under:

changelog

History

v4.7.0 2023 December 29

v4.6.0 2023 December 27

v4.5.0 2023 December 6

v4.4.0 2023 November 24

v4.3.0 2023 November 21

v4.2.0 2023 November 15

v4.1.0 2023 November 14

v4.0.0 2023 November 13

  • Updated dependencies, base files, and editions using boundation
  • Minimum required Node.js version changed from node: >=10 to node: >=6 adapting to ecosystem changes

v3.23.0 2023 November 1

v3.22.0 2021 July 30

v3.21.0 2021 July 29

v3.20.0 2021 July 28

v3.19.0 2020 October 29

v3.18.0 2020 September 4

v3.17.0 2020 August 18

v3.16.0 2020 August 4

v3.15.0 2020 July 22

v3.14.0 2020 July 22

v3.13.0 2020 July 3

v3.12.0 2020 July 3

v3.11.0 2020 June 25

v3.10.0 2020 June 21

v3.9.0 2020 June 21

v3.8.0 2020 June 20

v3.7.0 2020 June 20

v3.6.0 2020 June 10

v3.5.0 2020 June 10

v3.4.0 2020 May 22

v3.3.0 2020 May 21

v3.2.0 2020 May 12

v3.1.0 2020 May 4

v3.0.0 2020 March 26

  • Updated dependencies, base files, and editions using boundation
  • Minimum required node version changed from node: >=8 to node: >=10 to keep up with mandatory ecosystem changes

v2.5.0 2019 December 9

v2.4.0 2019 December 1

v2.3.0 2019 December 1

v2.2.0 2019 December 1

v2.1.0 2019 November 18

v2.0.0 2019 November 18

  • Updated dependencies, base files, and editions using boundation
  • Minimum required node version changed from node: >=4 to node: >=8 to keep up with mandatory ecosystem changes

v1.2.0 2019 November 13

v1.1.0 2019 January 1

v1.0.0 2018 June 10