JSPM

rehype-line-numbers

0.1.1
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 12
  • Score
    100M100P100Q57506F
  • License MIT

Rehype plugin that adds data-line attribute to elements.

Package Exports

  • rehype-line-numbers

Readme

rehype-line-numbers

npm version

A rehype plugin to add data-line attributes to HTML elements, indicating their starting line number in the source.

What this is

This plugin inspects the HAST (HTML Abstract Syntax Tree) and, for elements with positional information, adds a data-line attribute.

Installation

pnpm install rehype-line-numbers

Use

See examples/ for a working example.

Say we have the following file example.html:

<h1>Example</h1>
<p>This is a <strong>paragraph!</strong></p>

<p>Lorem ipsum</p>

<div>
    <p>A thing</p>
    <p>Another thing</p>
</div>

<em>the end.</em>

…and our module example.js looks as follows:

const file = await read('example.html');

await unified()
    .use(rehypeParse, {fragment: true})
    .use(rehypeLineNumbers)
    .use(rehypeStringify)
    .process(file)

console.log('--- Top Level Only ---');
console.log(String(file))

const file2 = await read('example.html');

await unified()
    .use(rehypeParse, {fragment: true})
    .use(rehypeLineNumbers, {scope: 'all'})
    .use(rehypeStringify)
    .process(file2)

console.log('\n--- All Elements ---');
console.log(String(file2))

Now running node example.js yields:

--- Top Level Only ---
<h1 data-line="1">Example</h1>
<p data-line="2">This is a <strong>paragraph!</strong></p>

<p data-line="4">Lorem ipsum</p>

<div data-line="6">
    <p>A thing</p>
    <p>Another thing</p>
</div>

<em data-line="11">the end.</em>

--- All Elements ---
<h1 data-line="1">Example</h1>
<p data-line="2">This is a <strong data-line="2">paragraph!</strong></p>

<p data-line="4">Lorem ipsum</p>

<div data-line="6">
    <p data-line="7">A thing</p>
    <p data-line="8">Another thing</p>
</div>

<em data-line="11">the end.</em>

API

rehypeDataLine(options?)

options: RehypeLineNumbersOptions

interface RehypeLineNumbersOptions { scope?: 'all' | 'topLevel'; }

Determines which elements receive the data-line attribute.

  • 'topLevel': (default) Only elements that are direct children of the root of the document tree.
  • 'all': All elements in the document tree that have line information.

Compatibility

This plugin is ESM-only.

Contributing

Contributions are welcome! Please open an issue or submit a pull request.

License

MIT