mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-21 09:38:01 +02:00
3d8577a689
- For now, supports Markdown-it plugins - Also fixed slow rendering of notes in some cases - Simplified how Markdown-It plugins are created and cleaned MdToHtml code commit89576de289
Merge:c75aa21f
5292fc14
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:23:00 2020 +0100 Merge branch 'release-1.3' into plugin_content_scripts commitc75aa21ffd
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:19:52 2020 +0100 Fixed tests commit075187729d
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:11:53 2020 +0100 Fixed tests commit14696b8c65
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 23:27:58 2020 +0100 Fixed slow rendering of note commit61c09f5bf8
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 22:35:21 2020 +0100 Clean up commit9f7ea7d865
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 20:05:31 2020 +0100 Updated doc commit98bf3bde8d
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 19:56:34 2020 +0100 Finished converting plugins commitfe90d92e01
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 17:52:02 2020 +0100 Simplified how Markdown-It plugins are created commit47c7b864cb
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 16:40:11 2020 +0100 Clean up rules commitd927a238bb
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 14:29:40 2020 +0100 Fixed tests commit388a56c5dd
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 14:00:47 2020 +0100 Add support for content scripts
51 lines
1.4 KiB
TypeScript
51 lines
1.4 KiB
TypeScript
import { RuleOptions } from 'lib/joplin-renderer/MdToHtml';
|
|
|
|
const md5 = require('md5');
|
|
const htmlUtils = require('../../htmlUtils');
|
|
|
|
export default {
|
|
plugin: function(markdownIt:any, ruleOptions:RuleOptions) {
|
|
markdownIt.core.ruler.push('sanitize_html', (state:any) => {
|
|
const tokens = state.tokens;
|
|
|
|
const walkHtmlTokens = (tokens:any[]) => {
|
|
if (!tokens || !tokens.length) return;
|
|
|
|
for (const token of tokens) {
|
|
if (!['html_block', 'html_inline'].includes(token.type)) {
|
|
walkHtmlTokens(token.children);
|
|
continue;
|
|
}
|
|
|
|
const cacheKey = md5(escape(token.content));
|
|
let sanitizedContent = ruleOptions.context.cache.value(cacheKey);
|
|
|
|
// For html_inline, the content is only a fragment of HTML, as it will be rendered, but
|
|
// it's not necessarily valid HTML. For example this HTML:
|
|
//
|
|
// <a href="#">Testing</a>
|
|
//
|
|
// will be rendered as three tokens:
|
|
//
|
|
// html_inline: <a href="#">
|
|
// text: Testing
|
|
// html_inline: </a>
|
|
//
|
|
// So the sanitizeHtml function must handle this kind of non-valid HTML.
|
|
|
|
if (!sanitizedContent) {
|
|
sanitizedContent = htmlUtils.sanitizeHtml(token.content, { addNoMdConvClass: true });
|
|
}
|
|
|
|
token.content = sanitizedContent;
|
|
|
|
ruleOptions.context.cache.setValue(cacheKey, sanitizedContent, 1000 * 60 * 60);
|
|
walkHtmlTokens(token.children);
|
|
}
|
|
};
|
|
|
|
walkHtmlTokens(tokens);
|
|
});
|
|
},
|
|
};
|