26 lines
871 B
TypeScript
26 lines
871 B
TypeScript
|
// markdown-it plugin for generating line numbers.
|
||
|
// It depends on preWrapper plugin.
|
||
|
|
||
|
import type MarkdownIt from 'markdown-it';
|
||
|
|
||
|
export const lineNumberPlugin = (md: MarkdownIt) => {
|
||
|
const fence = md.renderer.rules.fence!;
|
||
|
md.renderer.rules.fence = (...args) => {
|
||
|
const rawCode = fence(...args);
|
||
|
const code = rawCode.slice(rawCode.indexOf('<code>'), rawCode.indexOf('</code>'));
|
||
|
|
||
|
const lines = code.split('\n');
|
||
|
const lineNumbersCode = [...Array(lines.length - 1)]
|
||
|
.map((_line, index) => `<span class="line-number">${index + 1}</span><br>`)
|
||
|
.join('');
|
||
|
|
||
|
const lineNumbersWrapperCode = `<div class="line-numbers-wrapper">${lineNumbersCode}</div>`;
|
||
|
|
||
|
const finalCode = rawCode
|
||
|
.replace(/<\/div>$/, `${lineNumbersWrapperCode}</div>`)
|
||
|
.replace(/"(language-\w+)"/, '"$1 line-numbers-mode"');
|
||
|
|
||
|
return finalCode;
|
||
|
};
|
||
|
};
|