I'm working on a solution that allows to paste screenshots directly into a textarea in Rails, which will be parsed as Markdown lateron.
I found the neat Paste.js library which captures the clipboard, detects whether a string or an image is pasted, and then reacts upon images by converting them into a Base64 string which then can be used as an image.
Being as it is, Paste.js offers everything needed to simply paste a simple image tag into the textarea like this:

But this will clutter up the whole textarea, Base64 strings can become very, very long. So I'd like only to be inserted a placeholder like so:

And then, in a hidden input field, I'd like to send the Base64 data:
<input type="hidden" name="post[content][screenshots][3857c1cf-1a68-4549-bc0d-aa18af25bb82]" value="...SUVORK5CYII=" />
My question is now: how would you implement this on the server side in Rails? I simply want to save them as regular files under uploads
, where I also store uploads from Carrierwave.
I don't want them to be uploaded automatically when pasted, as users can cancel when creating or editing a post, and I don't want the upload space to be cluttered up with images that are not in use.
Also, I don't want the images (once saved) to be removed from the server again, e.g. when removing the reference from the blog post, as the blog posts are versioned (using PaperTrail) and references will always exist in the old versions, so I think it's sensible to also keep the old images.
Do you think this makes sense? Or do I miss something? Are there limitations I don't see (e.g. upload limit of long Base64 strings)?
Maybe are there other libraries doing the same? I know GitHub Issues support this feature, but I couldn't find out how they did it, and they don't allow pasting screenshots in Firefox, either (which is supported by Paste.js).
I had this exact requirement for my blog. Thank for the tip for paste.js; I implemented it and wrote a write up.
I used the following approach to implement it.
I want to change that last point so it can remember the location of the user's cursor and insert it there, as opposed to appending it to the end.