util.markup
Tools for manipulating markup documents (markdown, restructuredtext, asciidoc, etc).
This module is a wrapper to handle the parsing of multiple types of markup documents and outputting the results to HTML. It uses a static factory method to retrieve a parser instance. This parser instance contains a promise based method named parse
. Parameters are passed to this method using a MarkupToolOptions
object. The resolution of the promise is an object with HTMLResults
as the structure. This factory handles the following markup types:
Installation
This module uses yarn to manage dependencies and run scripts for development.
To install as an application dependency:
$ yarn add util.markup
To build the production version of the app and run all tests:
$ yarn run all
Usage
To retrieve the MarkupFactory
parser instance use the .instance()
factory method:
; const content: string = '# Header 1 Some text with *bold* # Header 2 Some more text'; const parser: MarkupTool = MarkupFactory;const options: MarkupToolOptions = markup: content filename: "test.html" parser ;
API
functions
.parse(options: MarkupToolOptions)
- the only method available from the factory object. This will parse the given input markup file. It is Promise based, so the reslution of the promise returnHTMLResults
.
properties
-
HTMLResults
- the results of theparse
method.err {string}
- error message if the parsing of the document failsfilename {string}
- file where the HTML output was stored (in a Node/electron environment only)html {string}
- the HTML output result from parsing the markdown type
-
MarkupToolOptions
- options passed to theparse
method:markup {string}
- the markup document contents that will be parsed into HTMLfilename {string}
- the output file name where the HTML content will be savedcss: {string}
- custom, inline CSS that will be applied to the output HTML document
CLI
The tool installs a command line version of this library to a program named markup
. It uses the following options:
markup -t {asciidoc|md|rst} -i {input file} -o {output file}
-t
- the type of file to process (markdown, asciidoc, or restructuredtext)-i
- the input file to parse-o
- the output HTML file created