mirror of
https://github.com/laurent22/joplin.git
synced 2025-05-31 22:29:43 +02:00
- 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 commit 89576de2896c99134f25f2a2db25008514cb1315 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 commit c75aa21ffdc42764d71dc9deadba7a7ef4233995 Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:19:52 2020 +0100 Fixed tests commit 075187729d11a16d385b651cbf1ebb89f14935e0 Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:11:53 2020 +0100 Fixed tests commit 14696b8c651e7afdaf71269bcdbadf0d58d3ef8a Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 23:27:58 2020 +0100 Fixed slow rendering of note commit 61c09f5bf856481f91b00cfe87ff05596c63d4bc Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 22:35:21 2020 +0100 Clean up commit 9f7ea7d865a990b3a21cc8c59093390d9db61653 Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 20:05:31 2020 +0100 Updated doc commit 98bf3bde8d6663f2f91ff965304b4aac00bdd98b Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 19:56:34 2020 +0100 Finished converting plugins commit fe90d92e01427bd2b38200393713ea28763507a9 Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 17:52:02 2020 +0100 Simplified how Markdown-It plugins are created commit 47c7b864cbb864d5df79849f27625aecf312df4b Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 16:40:11 2020 +0100 Clean up rules commit d927a238bb635a4be45f9216d776f7d07cb0a584 Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 14:29:40 2020 +0100 Fixed tests commit 388a56c5dde4c382e3ee0035791137150adaba1b Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 14:00:47 2020 +0100 Add support for content scripts
43 lines
1.3 KiB
TypeScript
43 lines
1.3 KiB
TypeScript
import markdownUtils from 'lib/markdownUtils';
|
|
import Setting from 'lib/models/Setting';
|
|
import shim from 'lib/shim';
|
|
import MarkupToHtml, { MarkupLanguage } from 'lib/joplin-renderer/MarkupToHtml';
|
|
|
|
const htmlUtils = require('lib/htmlUtils');
|
|
const Resource = require('lib/models/Resource');
|
|
|
|
class MarkupLanguageUtils {
|
|
lib_(language:MarkupLanguage) {
|
|
if (language === MarkupLanguage.Html) return htmlUtils;
|
|
if (language === MarkupLanguage.Markdown) return markdownUtils;
|
|
throw new Error(`Unsupported markup language: ${language}`);
|
|
}
|
|
|
|
extractImageUrls(language:MarkupLanguage, text:string) {
|
|
return this.lib_(language).extractImageUrls(text);
|
|
}
|
|
|
|
// Create a new MarkupToHtml instance while injecting options specific to Joplin
|
|
// desktop and mobile applications.
|
|
newMarkupToHtml(options:any = null) {
|
|
const subValues = Setting.subValues('markdown.plugin', Setting.toPlainObject());
|
|
const pluginOptions:any = {};
|
|
for (const n in subValues) {
|
|
pluginOptions[n] = { enabled: subValues[n] };
|
|
}
|
|
|
|
options = Object.assign({
|
|
ResourceModel: Resource,
|
|
pluginOptions: pluginOptions,
|
|
tempDir: Setting.value('tempDir'),
|
|
fsDriver: shim.fsDriver(),
|
|
}, options);
|
|
|
|
return new MarkupToHtml(options);
|
|
}
|
|
}
|
|
|
|
const markupLanguageUtils = new MarkupLanguageUtils();
|
|
|
|
export default markupLanguageUtils;
|