Compare commits
10 Commits
Author | SHA1 | Date | |
---|---|---|---|
8afb5423e3
|
|||
0f83a56299
|
|||
ae7b491107
|
|||
8599460702
|
|||
fb52d31090
|
|||
859064f00b
|
|||
7803b495c2
|
|||
f48c0c6b75
|
|||
34cacb48bb
|
|||
7d5d29dade
|
4
package-lock.json
generated
4
package-lock.json
generated
@@ -1,12 +1,12 @@
|
||||
{
|
||||
"name": "@doc-utils/markdown2html",
|
||||
"version": "0.1.13",
|
||||
"version": "0.1.18",
|
||||
"lockfileVersion": 2,
|
||||
"requires": true,
|
||||
"packages": {
|
||||
"": {
|
||||
"name": "@doc-utils/markdown2html",
|
||||
"version": "0.1.13",
|
||||
"version": "0.1.18",
|
||||
"dependencies": {
|
||||
"bytefield-svg": "^1.6.1",
|
||||
"dompurify": "^2.3.6",
|
||||
|
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@doc-utils/markdown2html",
|
||||
"version": "0.1.13",
|
||||
"version": "0.1.18",
|
||||
"publishConfig": {
|
||||
"registry": "https://gitea.home.jbrumond.me/api/packages/doc-utils/npm/"
|
||||
},
|
||||
|
62
src/breadcrumb-nav.ts
Normal file
62
src/breadcrumb-nav.ts
Normal file
@@ -0,0 +1,62 @@
|
||||
|
||||
import { marked } from 'marked';
|
||||
import { ParsedAttributes, parse_attributes } from './attrs';
|
||||
import { MarkdownOptions } from './render';
|
||||
|
||||
export interface BreadcrumbNavToken extends marked.Tokens.Generic {
|
||||
text: string;
|
||||
attrs: ParsedAttributes;
|
||||
items: marked.Token[][];
|
||||
}
|
||||
|
||||
export function breadcrumb_nav_ext(renderer: marked.Renderer, opts: MarkdownOptions) : marked.TokenizerExtension & marked.RendererExtension {
|
||||
return {
|
||||
name: 'breadcrumb_nav',
|
||||
level: 'block',
|
||||
start: (src) => src.match(/^\/\/\//)?.index,
|
||||
tokenizer(src, tokens) {
|
||||
const rule = /^\/\/\/(\/*)([^\n]+)?(?:\n)((?:[^\/]|\/\/?(?!\/\1))+)\/\/\/\1/;
|
||||
const match = rule.exec(src);
|
||||
|
||||
if (match) {
|
||||
const token: BreadcrumbNavToken = {
|
||||
type: 'breadcrumb_nav',
|
||||
raw: match[0],
|
||||
text: match[3],
|
||||
attrs: parse_attributes(match[2] || ''),
|
||||
tokens: [ ],
|
||||
items: [ ],
|
||||
};
|
||||
|
||||
const lines = match[3].trim().split('\n');
|
||||
|
||||
for (const line of lines) {
|
||||
const tokens = this.lexer.inlineTokens(line, [ ]);
|
||||
token.tokens.push(...tokens);
|
||||
token.items.push(tokens);
|
||||
}
|
||||
|
||||
return token;
|
||||
}
|
||||
},
|
||||
renderer(token: BreadcrumbNavToken) {
|
||||
return `<nav aria-label="breadcrumbs" ${token.attrs.html_attrs.join(' ')}>\n`
|
||||
+ `\t<ol>\n`
|
||||
+ '\t\t'
|
||||
+ token.items.map((tokens, index) =>{
|
||||
let item = '<li>\n';
|
||||
|
||||
if (index) {
|
||||
item += '\t\t\t<span class="separator" aria-hidden="true">/</span>\n';
|
||||
}
|
||||
|
||||
item += `\t\t\t${this.parser.parseInline(tokens, renderer)}\n`;
|
||||
|
||||
return item + '\t\t</li>';
|
||||
}).join('\n\t\t')
|
||||
+ '\n'
|
||||
+ `\t</ol>\n`
|
||||
+ `</nav>`;
|
||||
}
|
||||
};
|
||||
}
|
@@ -8,6 +8,6 @@ export function sanitize_html(html: string, custom_elements?: CustomElementHandl
|
||||
const { window } = new JSDOM('');
|
||||
const dom_purify = createDOMPurify(window as any as Window);
|
||||
return dom_purify.sanitize(html, {
|
||||
CUSTOM_ELEMENT_HANDLING: custom_elements
|
||||
CUSTOM_ELEMENT_HANDLING: custom_elements,
|
||||
});
|
||||
}
|
||||
|
@@ -9,6 +9,7 @@ import { katex_block_ext, katex_inline_ext } from './katex';
|
||||
import { footnote_list_ext, footnote_ref_ext } from './footnotes';
|
||||
import { description_list_ext } from './description-list';
|
||||
import { resolve_async_bindings } from './async-steps';
|
||||
import { breadcrumb_nav_ext } from './breadcrumb-nav';
|
||||
|
||||
export interface MarkdownOptions {
|
||||
base_url?: string;
|
||||
@@ -40,6 +41,7 @@ export async function render_markdown_to_html(markdown: string, options: Markdow
|
||||
description_list_ext(marked_options.renderer, options),
|
||||
section_ext(marked_options.renderer, options),
|
||||
icon_ext(marked_options.renderer, options),
|
||||
breadcrumb_nav_ext(marked_options.renderer, options),
|
||||
...(options.extensions || [ ]).map((ext) => {
|
||||
return ext(marked_options.renderer, options);
|
||||
}),
|
||||
|
@@ -197,7 +197,7 @@ function code(renderer: marked.Renderer, opts: MarkdownOptions) {
|
||||
|
||||
const arg_pattern = /^(?:[a-zA-Z0-9_:-]+|"(?:[^"\n]|(?<=\\)")*")/;
|
||||
|
||||
function parse_code_args(text: string) {
|
||||
function parse_code_args(text = '') {
|
||||
const args: string[] = [ ];
|
||||
|
||||
text = text.trim();
|
||||
|
Reference in New Issue
Block a user