-
-
Notifications
You must be signed in to change notification settings - Fork 2.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
22 changed files
with
914 additions
and
91 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,105 @@ | ||
import MarkdownIt from 'markdown-it' | ||
import { RuleBlock } from 'markdown-it/lib/parser_block' | ||
|
||
// Replacing the default htmlBlock rule to allow using custom components at | ||
// root level | ||
|
||
const blockNames: string[] = require('markdown-it/lib/common/html_blocks') | ||
const HTML_OPEN_CLOSE_TAG_RE: RegExp = require('markdown-it/lib/common/html_re') | ||
.HTML_OPEN_CLOSE_TAG_RE | ||
|
||
// An array of opening and corresponding closing sequences for html tags, | ||
// last argument defines whether it can terminate a paragraph or not | ||
const HTML_SEQUENCES: [RegExp, RegExp, boolean][] = [ | ||
[/^<(script|pre|style)(?=(\s|>|$))/i, /<\/(script|pre|style)>/i, true], | ||
[/^<!--/, /-->/, true], | ||
[/^<\?/, /\?>/, true], | ||
[/^<![A-Z]/, />/, true], | ||
[/^<!\[CDATA\[/, /\]\]>/, true], | ||
// PascalCase Components | ||
[/^<[A-Z]/, />/, true], | ||
// custom elements with hyphens | ||
[/^<\w+\-/, />/, true], | ||
[ | ||
new RegExp('^</?(' + blockNames.join('|') + ')(?=(\\s|/?>|$))', 'i'), | ||
/^$/, | ||
true | ||
], | ||
[new RegExp(HTML_OPEN_CLOSE_TAG_RE.source + '\\s*$'), /^$/, false] | ||
] | ||
|
||
export const componentPlugin = (md: MarkdownIt) => { | ||
md.block.ruler.at('html_block', htmlBlock) | ||
} | ||
|
||
const htmlBlock: RuleBlock = ( | ||
state, | ||
startLine, | ||
endLine, | ||
silent | ||
): boolean => { | ||
let i, nextLine, lineText | ||
let pos = state.bMarks[startLine] + state.tShift[startLine] | ||
let max = state.eMarks[startLine] | ||
|
||
// if it's indented more than 3 spaces, it should be a code block | ||
if (state.sCount[startLine] - state.blkIndent >= 4) { | ||
return false | ||
} | ||
|
||
if (!state.md.options.html) { | ||
return false | ||
} | ||
|
||
if (state.src.charCodeAt(pos) !== 0x3c /* < */) { | ||
return false | ||
} | ||
|
||
lineText = state.src.slice(pos, max) | ||
|
||
for (i = 0; i < HTML_SEQUENCES.length; i++) { | ||
if (HTML_SEQUENCES[i][0].test(lineText)) { | ||
break | ||
} | ||
} | ||
|
||
if (i === HTML_SEQUENCES.length) { | ||
return false | ||
} | ||
|
||
if (silent) { | ||
// true if this sequence can be a terminator, false otherwise | ||
return HTML_SEQUENCES[i][2] | ||
} | ||
|
||
nextLine = startLine + 1 | ||
|
||
// If we are here - we detected HTML block. | ||
// Let's roll down till block end. | ||
if (!HTML_SEQUENCES[i][1].test(lineText)) { | ||
for (; nextLine < endLine; nextLine++) { | ||
if (state.sCount[nextLine] < state.blkIndent) { | ||
break | ||
} | ||
|
||
pos = state.bMarks[nextLine] + state.tShift[nextLine] | ||
max = state.eMarks[nextLine] | ||
lineText = state.src.slice(pos, max) | ||
|
||
if (HTML_SEQUENCES[i][1].test(lineText)) { | ||
if (lineText.length !== 0) { | ||
nextLine++ | ||
} | ||
break | ||
} | ||
} | ||
} | ||
|
||
state.line = nextLine | ||
|
||
const token = state.push('html_block', '', 0) | ||
token.map = [startLine, nextLine] | ||
token.content = state.getLines(startLine, nextLine, state.blkIndent, true) | ||
|
||
return true | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
import MarkdownIt from 'markdown-it' | ||
import Token from 'markdown-it/lib/token' | ||
|
||
const container = require('markdown-it-container') | ||
|
||
export const containerPlugin = (md: MarkdownIt) => { | ||
md.use(...createContainer('tip', 'TIP')) | ||
.use(...createContainer('warning', 'WARNING')) | ||
.use(...createContainer('danger', 'WARNING')) | ||
// explicitly escape Vue syntax | ||
.use(container, 'v-pre', { | ||
render: (tokens: Token[], idx: number) => | ||
tokens[idx].nesting === 1 ? `<div v-pre>\n` : `</div>\n` | ||
}) | ||
} | ||
|
||
type ContainerArgs = [ | ||
typeof container, | ||
string, | ||
{ | ||
render(tokens: Token[], idx: number): string | ||
} | ||
] | ||
|
||
function createContainer(klass: string, defaultTitle: string): ContainerArgs { | ||
return [ | ||
container, | ||
klass, | ||
{ | ||
render(tokens, idx) { | ||
const token = tokens[idx] | ||
const info = token.info.trim().slice(klass.length).trim() | ||
if (token.nesting === 1) { | ||
return `<div class="${klass} custom-block"><p class="custom-block-title">${ | ||
info || defaultTitle | ||
}</p>\n` | ||
} else { | ||
return `</div>\n` | ||
} | ||
} | ||
} | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
const chalk = require('chalk') | ||
const prism = require('prismjs') | ||
const loadLanguages = require('prismjs/components/index') | ||
const escapeHtml = require('escape-html') | ||
|
||
// required to make embedded highlighting work... | ||
loadLanguages(['markup', 'css', 'javascript']) | ||
|
||
function wrap(code: string, lang: string): string { | ||
if (lang === 'text') { | ||
code = escapeHtml(code) | ||
} | ||
return `<pre v-pre class="language-${lang}"><code>${code}</code></pre>` | ||
} | ||
|
||
export const highlight = (str: string, lang: string) => { | ||
if (!lang) { | ||
return wrap(str, 'text') | ||
} | ||
lang = lang.toLowerCase() | ||
const rawLang = lang | ||
if (lang === 'vue' || lang === 'html') { | ||
lang = 'markup' | ||
} | ||
if (lang === 'md') { | ||
lang = 'markdown' | ||
} | ||
if (lang === 'ts') { | ||
lang = 'typescript' | ||
} | ||
if (lang === 'py') { | ||
lang = 'python' | ||
} | ||
if (!prism.languages[lang]) { | ||
try { | ||
loadLanguages([lang]) | ||
} catch (e) { | ||
console.warn( | ||
chalk.yellow( | ||
`[vuepress] Syntax highlight for language "${lang}" is not supported.` | ||
) | ||
) | ||
} | ||
} | ||
if (prism.languages[lang]) { | ||
const code = prism.highlight(str, prism.languages[lang], lang) | ||
return wrap(code, rawLang) | ||
} | ||
return wrap(str, 'text') | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
// Modified from https://github.com/egoist/markdown-it-highlight-lines | ||
import MarkdownIt from 'markdown-it' | ||
|
||
const RE = /{([\d,-]+)}/ | ||
const wrapperRE = /^<pre .*?><code>/ | ||
|
||
export const highlightLinePlugin = (md: MarkdownIt) => { | ||
const fence = md.renderer.rules.fence! | ||
md.renderer.rules.fence = (...args) => { | ||
const [tokens, idx, options] = args | ||
const token = tokens[idx] | ||
|
||
const rawInfo = token.info | ||
if (!rawInfo || !RE.test(rawInfo)) { | ||
return fence(...args) | ||
} | ||
|
||
const langName = rawInfo.replace(RE, '').trim() | ||
// ensure the next plugin get the correct lang. | ||
token.info = langName | ||
|
||
const lineNumbers = RE.exec(rawInfo)![1] | ||
.split(',') | ||
.map(v => v.split('-').map(v => parseInt(v, 10))) | ||
|
||
const code = options.highlight | ||
? options.highlight(token.content, langName) | ||
: token.content | ||
|
||
const rawCode = code.replace(wrapperRE, '') | ||
const highlightLinesCode = rawCode.split('\n').map((split, index) => { | ||
const lineNumber = index + 1 | ||
const inRange = lineNumbers.some(([start, end]) => { | ||
if (start && end) { | ||
return lineNumber >= start && lineNumber <= end | ||
} | ||
return lineNumber === start | ||
}) | ||
if (inRange) { | ||
return `<div class="highlighted"> </div>` | ||
} | ||
return '<br>' | ||
}).join('') | ||
|
||
const highlightLinesWrapperCode = | ||
`<div class="highlight-lines">${highlightLinesCode}</div>` | ||
|
||
return highlightLinesWrapperCode + code | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
import MarkdownIt from 'markdown-it' | ||
|
||
export const hoistPlugin = (md: MarkdownIt & { __data: any }) => { | ||
const RE = /^<(script|style)(?=(\s|>|$))/i | ||
|
||
md.renderer.rules.html_block = (tokens, idx) => { | ||
const content = tokens[idx].content | ||
const hoistedTags = md.__data.hoistedTags || (md.__data.hoistedTags = []) | ||
if (RE.test(content.trim())) { | ||
hoistedTags.push(content) | ||
return '' | ||
} else { | ||
return content | ||
} | ||
} | ||
} |
Oops, something went wrong.