diff --git a/packages/app-cli/tests/html_to_md/image_utf8_data_url.html b/packages/app-cli/tests/html_to_md/image_utf8_data_url.html new file mode 100644 index 00000000000..d15198eb0a0 --- /dev/null +++ b/packages/app-cli/tests/html_to_md/image_utf8_data_url.html @@ -0,0 +1,9 @@ +
+ SVG image: + + +
+PNG image:
\ No newline at end of file diff --git a/packages/app-cli/tests/html_to_md/image_utf8_data_url.md b/packages/app-cli/tests/html_to_md/image_utf8_data_url.md new file mode 100644 index 00000000000..c7a7280ae76 --- /dev/null +++ b/packages/app-cli/tests/html_to_md/image_utf8_data_url.md @@ -0,0 +1,3 @@ +SVG image: ![](data:image/svg+xml;utf8,%0A%09%09) + +PNG image: ![]() \ No newline at end of file diff --git a/packages/app-cli/tests/md_to_html/image_with_data_url.html b/packages/app-cli/tests/md_to_html/image_with_data_url.html new file mode 100644 index 00000000000..e91a0e3f82a --- /dev/null +++ b/packages/app-cli/tests/md_to_html/image_with_data_url.html @@ -0,0 +1,2 @@ +SVG image:
+PNG image:
diff --git a/packages/app-cli/tests/md_to_html/image_with_data_url.md b/packages/app-cli/tests/md_to_html/image_with_data_url.md new file mode 100644 index 00000000000..1bbcb9020c5 --- /dev/null +++ b/packages/app-cli/tests/md_to_html/image_with_data_url.md @@ -0,0 +1,3 @@ +SVG image: ![](data:image/svg+xml;utf8,) + +PNG image: ![]() \ No newline at end of file diff --git a/packages/app-desktop/gui/NoteEditor/NoteBody/TinyMCE/TinyMCE.tsx b/packages/app-desktop/gui/NoteEditor/NoteBody/TinyMCE/TinyMCE.tsx index 61b900bd70a..0aa272e5086 100644 --- a/packages/app-desktop/gui/NoteEditor/NoteBody/TinyMCE/TinyMCE.tsx +++ b/packages/app-desktop/gui/NoteEditor/NoteBody/TinyMCE/TinyMCE.tsx @@ -608,6 +608,14 @@ const TinyMCE = (props: NoteBodyEditorProps, ref: any) => { localization_function: _, contextmenu: false, browser_spellcheck: true, + + // Work around an issue where images with a base64 SVG data URL would be broken. + // + // See https://github.com/tinymce/tinymce/issues/3864 + // + // This was fixed in TinyMCE 6.1, so remove it when we upgrade. + images_dataimg_filter: (img: HTMLImageElement) => !img.src.startsWith('data:'), + formats: { joplinHighlight: { inline: 'mark', remove: 'all' }, joplinStrikethrough: { inline: 's', remove: 'all' }, diff --git a/packages/renderer/MdToHtml/validateLinks.ts b/packages/renderer/MdToHtml/validateLinks.ts index 6b9e92559fc..d35adcaa714 100644 --- a/packages/renderer/MdToHtml/validateLinks.ts +++ b/packages/renderer/MdToHtml/validateLinks.ts @@ -7,7 +7,7 @@ export default function(url: string) { // url should be normalized at this point, and existing entities are decoded const str = url.trim().toLowerCase(); - if (str.indexOf('data:image/svg+xml,') === 0) { + if (str.startsWith('data:image/svg+xml,') || str.startsWith('data:image/svg+xml;utf8,')) { return true; } diff --git a/packages/turndown/src/commonmark-rules.js b/packages/turndown/src/commonmark-rules.js index a33170540a2..6d00ce146dd 100644 --- a/packages/turndown/src/commonmark-rules.js +++ b/packages/turndown/src/commonmark-rules.js @@ -293,6 +293,9 @@ function filterLinkHref (href) { // Replace the spaces with %20 because otherwise they can cause problems for some // renderer and space is not a valid URL character anyway. href = href.replace(/ /g, '%20'); + // Newlines and tabs also break renderers + href = href.replace(/\n/g, '%0A'); + href = href.replace(/\t/g, '%09'); // Brackets also should be escaped href = href.replace(/\(/g, '%28'); href = href.replace(/\)/g, '%29');