Automatically convert base64 images on paste

Follows from discussion here: Discord

Related:

Use case or problem

Some ‘copy sources’ of image data don’t use the proper DataObject format (see: c# - Adding Image with url to clipboard - Stack Overflow), but instead an HTML fragment. Examples of this appear to include OneNote, Clipt, and EverNote.

In these cases images are embedded using ![](BASE64 IMAGE DATA) which badly pollutes the markdown file and is not desired in most cases.

Ideally these cases would be handled similarly to good image pastes, which put the image into the configured attachment folder and reference it with an embed like ![[image...]].

Using clipboard inspector:

Bad image:

<html>
<body>
<!--StartFragment--><img src="" style="color: rgb(0, 0, 0); font-family: &quot;Segoe UI&quot;, Tahoma, sans-serif; font-size: 12px; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; orphans: 2; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial;"><!--EndFragment-->
</body>
</html>

Good image:

Use case or problem

I am annotating YouTube videos and trying to import my notes. These sometimes include embedded images - screen grabs. These display in the markdown as something like…

![Zozc!3.x_ZS of(...

These display properly BUT they make editing the markdown IMPOSSIBLE because the markdown is completely overwhelmed by thousands of bytes of this stuff. The entire visible page is a continuous stream of bytes. This is what it looks like to me…

https://1drv.ms/u/s!AjaZ-t3uLVN_0N1316E8WdE--pdEXQ?e=i3Trng

Proposed solution

Few ideas:

  • Plug-in to export these embedded images into an “images” folder and replace embedded data with local link.
  • Format the markdown of these images (or any really long link) so they are collapsed by default. Don’t like the markdown files being huge though.
  • Preferred option is a built-in converter, not a plug-in, that notices these situations upon paste and offers to move the embedded images into another folder. Also when an image is embedded and you are previewing it, show a menu button near the image for “export this image” and “export all images in file”.

Current workaround (optional)

Delete the images

Related feature requests (optional)

5 Likes

+1 for this.

It would be awesome if links were shown as the title only, but when the cursor is inside the link, expand to show the full URL. Bear does this in a similar way and it keeps the markup looking very clean.

How do you even capture and embed them as base64? I mean not how to use the data object instead of a link, but what is your workflow to easily capture screengrabs from a video as a base64-encoded string?

This happens to me when pasting from OneNote.

I am bumping into this issue as well. My usecase is when working with charts in Google Sheets, downloading the chart as a PNG results in a horrible resolution. Clicking ‘copy chart’ and pasting the image gives a much better resolution but in Obsidian it results in a base-64 encoded link which totally kills the editing experience.

Copied files into vault from previous note systems (possibly TwiddlyWiki or Joplin).

:index_pointing_up: A good workaround is to use pandoc to extract the images to files and replace the link with a ref to the created file.

You can try it following this example (from a vault directory):

pandoc --extract-media ./media/ -s ds3231_pinout.md -o ds3231_pinout-pandoc.md
  • the destination directory for image files (./media) is created if absent
  • the -s option ensures that enventual front matter is preserved

To run this command on my vault folders, I used ripgrep to select all md files and pipe the list to xargs(1) which handles the loop:

rg -l 'data:image' | xargs -i pandoc --extract-media ./media/ -s {} -o {}

If you don’t want to install ripgrep you should get the same output with GNU grep:

grep -l -e 'data:image' *md

Use case or problem

I tend to dump a lot of my Jupyter notebook figures to notes at obsidian to store partial results and explore possible interpretations of results. If one copies and pastes a figure from Jupyter into a note, typically it pastes something like:
![](......(verylongstring)==)
A (verylongstring) can be hundreds or thousands of lines that completely disrupt the performance and manageability of the note editing.

Proposed solution

Collapsing the information inside data:image/png;base64 would be brilliant, it would allow users to embed figures while preserving the not layout and not having to attach figures. I propose something like:

Current workaround (optional)

Save the figure locally and attaching to the note

3 Likes

This topic was automatically closed 90 days after the last reply. New replies are no longer allowed.