Skip to content

Commit

Permalink
fix: #380 修复粘贴时转义&的问题,同时修复粘贴table时出现过多换行的问题\n feat: 当表格thead为空的时候,不再渲…
Browse files Browse the repository at this point in the history
…染<thead>
  • Loading branch information
sunsonliu committed Jan 12, 2023
1 parent cfdfd0d commit 266a5f1
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 49 deletions.
17 changes: 16 additions & 1 deletion src/core/hooks/Table.js
Original file line number Diff line number Diff line change
Expand Up @@ -174,8 +174,23 @@ export default class Table extends ParagraphBase {
};
}

/**
* 如果table.head是空的,就不渲染<thead>了
* @param {String} str
* @returns {Boolean}
*/
$testHeadEmpty(str) {
const test = str
.replace(/&nbsp;/g, '')
.replace(/\s/g, '')
.replace(/(~CTH\$|~CTHU|~CTHL|~CTHR|~CTHC)/g, '');
return test?.length > 0;
}

$renderTable(COLUMN_ALIGN_MAP, tableHeader, tableRows, dataLines) {
const cacheSrc = `~CTHD${tableHeader}~CTHD$~CTBD${tableRows}~CTBD$`;
const cacheSrc = this.$testHeadEmpty(tableHeader)
? `~CTHD${tableHeader}~CTHD$~CTBD${tableRows}~CTBD$`
: `~CTBD${tableRows}~CTBD$`;
const html = cacheSrc;
const sign = this.$engine.md5(html);
const renderHtml = html
Expand Down
60 changes: 12 additions & 48 deletions src/utils/htmlparser.js
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ const htmlParser = {
.replace(/\n{3,}/g, '\n\n\n')
.replace(/&gt;/g, '>')
.replace(/&lt;/g, '<')
.replace(/&amp;/g, '&')
.trim('\n');
},
/**
Expand All @@ -68,43 +69,7 @@ const htmlParser = {
*/
$handleTagObject(temObj, returnString) {
let ret = returnString;
if (temObj.attrs.class && temObj.attrs.class.indexOf('mermaid') >= 0) {
// 针对 mermaid 图
try {
ret += [
'\n```',
temObj.attrs['data-type'],
'\n',
decodeURIComponent(atob(temObj.attrs['data-code'])),
'\n```\n',
].join('');
} catch (e) {
ret += [
'\n```',
temObj.attrs['data-type'],
'\n',
decodeURIComponent(temObj.attrs['data-code']),
'\n```\n',
].join('');
}
} else if (temObj.attrs.class && temObj.attrs.class.indexOf('mathjax-wrapper') >= 0) {
// 针对公式,首尾加空格是为了适应新语法
try {
ret += ` ${decodeURIComponent(atob(temObj.attrs['data-source']))} `;
} catch (e) {
ret += ` ${decodeURIComponent(temObj.attrs['data-source'])} `;
}
} else if (temObj.attrs['data-control'] && temObj.attrs['data-control'] === 'tapd-table') {
// 处理高阶表格 cherryMarkdown里不需要这段逻辑
ret += ['\n```', ' tapd-table ', temObj.attrs['data-size'], '\n'].join('');

if (temObj.children[1] && temObj.children[1].children[0].content) {
const data = temObj.children[1].children[0].content.replace(/\s+/g, '');
ret += ['\n', data, '\n```\n'].join('');
} else {
ret += ['\n', '"工作表":{"数据":{"19::25":" "}} ', '\n```\n'].join(''); // 高阶数据存在问题,转换为默认
}
} else if (temObj.attrs.class && temObj.attrs.class.indexOf('ch-icon') >= 0) {
if (temObj.attrs.class && temObj.attrs.class.indexOf('ch-icon') >= 0) {
// 针对checklist
if (temObj.attrs.class.indexOf('ch-icon-check') >= 0) {
ret += '[x]';
Expand Down Expand Up @@ -168,8 +133,7 @@ const htmlParser = {
// 递归找到对应的代码文本
ret += self.$dealCodeTag(temObj);
} else {
// 代码块会对<、>做转义,转成markdown时就不需要转义了
ret += temObj.content.replace(/&lt;/g, '<').replace(/&gt;/g, '>');
ret += temObj.content;
}
}
return ret;
Expand Down Expand Up @@ -761,7 +725,7 @@ const htmlParser = {
},
convertCode(str) {
if (/\n/.test(str)) {
return `\n\`\`\`\n${str.replace(/\n+$/, '')}\n\`\`\`\n`;
return `\`\`\`\n${str.replace(/\n+$/, '')}\n\`\`\``;
}
return ` \`${str.replace(/`/g, '\\`')}\` `;
},
Expand Down Expand Up @@ -818,19 +782,19 @@ const htmlParser = {
return `^^${str.trim().replace(/\^\^/g, '\\^\\^')}^^`;
},
convertTd(str) {
return `~|${str.trim().replace(/\n/g, '<br>')} ~|`;
return `~|${str.trim().replace(/\n{1,}/g, '<br>')} ~|`;
},
convertTh(str) {
return `~|${str.trim().replace(/\n/g, '<br>')} ~|`;
return `~|${str.trim().replace(/\n{1,}/g, '<br>')} ~|`;
},
convertTr(str) {
return `${str}\n`;
return `${str.replace(/\n/g, '')}\n`;
},
convertThead(str) {
return `${str.replace(/~\|~\|/g, '~|').replace(/~\|/g, '|')}|:--|\n`;
},
convertTable(str) {
const ret = `\n${str.replace(/~\|~\|/g, '~|').replace(/~\|/g, '|')}\n`;
const ret = `\n${str.replace(/~\|~\|/g, '~|').replace(/~\|/g, '|')}\n`.replace(/\n{2,}/g, '\n');
if (/\|:--\|/.test(ret)) {
return ret;
}
Expand All @@ -840,7 +804,7 @@ const htmlParser = {
return `- ${str.replace(/^\n/, '').replace(/\n+$/, '').replace(/\n+/g, '\n\t')}\n`;
},
convertUl(str) {
return `\n\n${str}\n\n`;
return `${str}\n`;
},
convertOl(str) {
const arr = str.split('\n');
Expand All @@ -852,7 +816,7 @@ const htmlParser = {
}
}
const $str = arr.join('\n');
return `\n\n${$str}\n\n`;
return `${$str}\n`;
},
convertStrong(str) {
return /^\s*$/.test(str) ? '' : `**${str}**`;
Expand Down Expand Up @@ -885,10 +849,10 @@ const htmlParser = {
return `###### ${str.trim().replace(/\n+$/, '')}\n\n`;
},
convertBlockquote(str) {
return `\n>${str.trim()}\n\n`;
return `>${str.trim()}\n\n`;
},
convertAddress(str) {
return `\n>${str.trim()}\n\n`;
return `>${str.trim()}\n\n`;
},
},
/**
Expand Down

0 comments on commit 266a5f1

Please sign in to comment.