diff --git a/.travis.yml b/.travis.yml index 27e5419..92c763c 100644 --- a/.travis.yml +++ b/.travis.yml @@ -6,11 +6,19 @@ cache: node_js: - "10" +before_script: + - rm -rf node_modules + - rm -rf .git + - git clone https://github.com/hexojs/hexo-theme-unit-test temp + - mkdir temp/themes + - mkdir temp/themes/landscape + - rsync -av ./ ./temp/themes/landscape --exclude ./temp/ + - cd temp + - npm install + - cd themes/landscape + - npm install + script: - - git clone https://github.com/hexojs/hexo-theme-unit-test generate_test - - git clone https://github.com/ikeq/hexo-theme-inside.git generate_test/themes/landscape - - cd generate_test - - npm install - - hexo g & hexo g - - cd .. - npm test + - cd ../.. + - hexo g && hexo g diff --git a/lib/renderer/md.js b/lib/renderer/md.js index 44b9728..747e755 100644 --- a/lib/renderer/md.js +++ b/lib/renderer/md.js @@ -1,13 +1,6 @@ const marked = require('marked'); const { stripHTML } = require('hexo-util'); const { isExternal, htmlTag } = require('../utils'); -const { DomHandler, DomUtils, Parser } = require('htmlparser2'); - -const parseHtml = html => { - const handler = new DomHandler(); - new Parser(handler).end(html); - return handler.dom; -}; class Renderer extends marked.Renderer { constructor(ctx) { @@ -28,18 +21,25 @@ class Renderer extends marked.Renderer { } table(header, body) { const { styles } = this - const hasHeader = DomUtils.getText(parseHtml(header)) - .replace(/ /g, '').trim() - return [ `
`, '', - hasHeader ? `${header}` : '', + `${header}`, `${body}`, '
', '
' ].join('') } + tablecell(content, flags) { + if (flags.header) { + if (content === ' ') content = ''; + const attrs = !content // is empty + ? { style: 'padding:0' } + : { align: flags.align }; + return htmlTag('th', attrs, content); + } + return htmlTag('td', { align: flags.align }, content); + } link(href, title, text) { return htmlTag('a', { href, title, target: isExternal(href) ? '_blank' : '' }, text); } diff --git a/lib/utils.js b/lib/utils.js index 6442872..b7f8147 100644 --- a/lib/utils.js +++ b/lib/utils.js @@ -184,8 +184,10 @@ exports.parseToc = function (html, depth) { current.push({ id: item.id, title: item.text, - index: [parents[parents.length - 1].index, current.length + 1] - .filter(i => i).join('.') + index: [ + parents.length ? parents[parents.length - 1].index : '', + current.length + 1 + ].filter(i => i).join('.') }) }, open() { @@ -195,7 +197,9 @@ exports.parseToc = function (html, depth) { }, close() { parents.pop() - current = parents[parents.length - 1].children + current = parents.length + ? parents[parents.length - 1].children + : parents; } } } diff --git a/test/scripts/renderers/md.js b/test/scripts/renderers/md.js index b512d34..6c49401 100644 --- a/test/scripts/renderers/md.js +++ b/test/scripts/renderers/md.js @@ -62,6 +62,6 @@ describe('md', function () { text: ` | |  -|-|- a|b|c` })) - .toBe('
abc
'); + .toBe('
abc
'); }); });