Skip to content
This repository has been archived by the owner on Oct 6, 2023. It is now read-only.

A custom Pug filter to render Markdown (with options)

License

Notifications You must be signed in to change notification settings

metamodern-design/pug-filter-markdown

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

@metamodern/pug-filter-markdown

A custom Pug filter to render Markdown (with options)

Install

npm i @metamodern/pug-filter-markdown

Usage

This package is released as an ES module only. Minimum Node.js version is 12 (latest LTS as of release date). CommonJS require() is not supported.

// render.js

import pug from 'pug';
import pugFilterMarkdown from '@metamodern/pug-filter-markdown';

const html = pug.renderFile('path/to/file.pug', {
  filters: {
    md: pugFilterMarkdown,
  },
});


// file.pug

div.text-center
  :md(inline tag='h1' class='text-lg text-red')
    This is *Markdown*
  

API

The module's default export is a function with the following parameters:

function(content: string, {
  linkify = true,
  typographer = true,
  inline = false,
  ...options
} = {}): string

Required

  • content: the Markdown string to be rendered to HTML

Rendering Options

For details, see the markdown-it docs and live demo.

  • linkify: autoconvert URL-like text to links
  • typographer: enable some language-neutral replacement and quotes beautification
  • inline: render a single line without paragraph wrap

Wrapping Options

When one or more of the following options is passed, rendered paragraphs or inline text will be wrapped in an enclosing element. The tag defaults to div when only class or attrs is defined.

  • tag: sets the HTML tag of the enclosing element (e.g., 'article')
  • class: set the class attribute on the enclosing element (using space-separated class names)
  • attrs: set additional attributes on the enclosing element (using space-separated key="value" assignments)

Further Customization

See the markdown-it docs for additional options that may be passed to the rendering function.

About

A custom Pug filter to render Markdown (with options)

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published