remark-gfm-custom
v1.0.5
Published
A configurable remark-gfm that allows you to toggle the GitHub Flavored Markdown (GFM) features.
Downloads
588
Maintainers
Readme
remark-gfm-custom
A configurable remark-gfm that allows you to toggle the GitHub Flavored Markdown (GFM) features.
This package has the same functionality as remark-gfm, with the additional ability to enable or disable specific GFM features like autolinks, footnotes, tables, and more.
Installation
# Deno
deno add npm:remark-gfm-custom
# Bun
bun add remark-gfm-custom
# pnpm
pnpm add remark-gfm-custom
# npm
npm install remark-gfm-customUsage
import assert from "node:assert";
import remarkParse from "remark-parse";
import remarkRehype from "remark-rehype";
import rehypeStringify from "rehype-stringify";
import { unified } from "unified";
import { remarkGfmCustom } from "remark-gfm-custom";
const file = await unified()
.use(remarkParse)
// This disables the GFM autolink feature.
.use(remarkGfmCustom, { plugins: { autolinkLiteral: false } })
.use(remarkRehype)
.use(rehypeStringify)
.process("https://example.com");
assert.equal(file.toString(), "<p>https://example.com</p>");API
This package exports the following:
remarkGfmCustom
function remarkGfmCustom(options?: Options): void;The main plugin. It receives one optional parameter to configure behavior. See
the Options section below for configuration details.
Options
type Options = {
remarkGfm?: FootnoteOptions | TableOptions | StrikethroughOptions;
plugins?: {
autolinkLiteral?: boolean;
footnote?: boolean;
strikethrough?: boolean;
table?: boolean;
taskListItem?: boolean;
};
};Configuration for remarkGfmCustom. This consists of two
main categories: remarkGfm and plugins.
remarkGfm
type remarkGfm = FootnoteOptions | TableOptions | StrikethroughOptions;Options passed directly to the remark-gfm plugins. The available fields are:
firstLineBlank
type firstLineBlank = boolean;Serialize with a blank line for the first line of footnote definitions.
- Default:
false. - Reference: https://github.com/remarkjs/remark-gfm#options
stringLength
type stringLength = (value: string) => number;Detect the size of table cells, used when aligning cells.
- Default:
d => d.length. - Reference: https://github.com/remarkjs/remark-gfm#options
singleTilde
type singleTilde = boolean;Whether to support strikethrough with a single tilde. Single tildes work on GitHub but are technically prohibited by GFM.
- Default:
true. - Reference: https://github.com/remarkjs/remark-gfm#options
tablePipeAlign
type tablePipeAlign = boolean;Whether to align table pipes.
- Default:
true. - Reference: https://github.com/remarkjs/remark-gfm#options
tableCellPadding
type tableCellPadding = boolean;Whether to add a space of padding between table pipes and cells.
- Default:
true. - Reference: https://github.com/remarkjs/remark-gfm#options
plugins
Options to enable or disable specific remark-gfm bundled plugins.
All fields below are boolean and default to true. Set a field to false to
disable that specific GFM feature.
autolinkLiteral
Toggle GFM literal autolinks.
footnote
Toggle the GFM footnotes.
strikethrough
Toggle the GFM strikethrough.
table
Toggle the GFM tables.
taskListItem
Toggle the GFM task list items.
Contributing
Please see CONTRIBUTING.md for contribution guidelines.
