<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title>Paste to base64</title> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/foundation/6.5.3/css/foundation.min.css" /> <style> .container { margin: 0 auto; width: 960px; } textarea { display: block; width: 100%; height: 618px; } </style> </head> <body> <div class="grid-container"> <h1>Paste to base64</h1> <div class="grid-x grid-margin-x"> <div class="cell small-6"> <h3>Raw Base64</h3> <label> <b>base64</b> <textarea name="base64TextArea"></textarea> </label> </div> <div class="cell small-6"> <h3>Base64 for Markdown</h3> <label> <b>Example in Markdown</b> <div class="callout"> <ol> <li> Embed the base64 image to the document (ideally, at the end of the document) <div class="callout"> <code>[abc]:...</code> </div> </li> <li> Refer to embedded base64's named reference of <code>abc</code> <div class="callout"> <code>![abc] lorem ipsum dolor</code> </div> </li> </ol> </div> </label> <label> <b>Markdown Reference Name</b> <input type="text" name="markdownReferenceName" /> </label> <label> <b>Embedded Markdown Base64 Reference</b> <button type="button" class="button" name="copyButton" onclick="handleCopyButton()" > Copy </button> <textarea name="base64TextAreaForMarkdown"></textarea> </label> </div> </div> </div> </body> <script type="text/javascript"> function handleCopyButton(event) { const base64TextArea = document.getElementsByName( "base64TextAreaForMarkdown" )[0]; base64TextArea.select(); document.execCommand("copy"); } function onPasteHandler({ clipboardData, originalEvent }) { const base64TextArea = document.getElementsByName("base64TextArea")[0]; const base64TextAreaForMarkdown = document.getElementsByName( "base64TextAreaForMarkdown" )[0]; const markdownReferenceName = document.getElementsByName( "markdownReferenceName" )[0]; if (!markdownReferenceName.value) { alert("Must provide a reference name first"); markdownReferenceName.focus(); return; } const clipboard = clipboardData || originalEvent.clipboardData; const items = clipboard.items; // update the base64 embedded markdown reference with new markdown reference name markdownReferenceName.onchange = function(event) { const { value } = event.currentTarget; const currentBase64 = base64TextArea.value; base64TextAreaForMarkdown.innerText = `[${value}]:${currentBase64}`; }; const item = items[0]; if (item.kind === "file") { const blob = item.getAsFile(); const reader = new FileReader(); reader.onload = ({ target }) => { base64TextArea.innerText = target.result; const markdownReferenceNameValue = markdownReferenceName.value; base64TextAreaForMarkdown.innerText = `[${markdownReferenceNameValue}]:${ target.result }`; }; reader.readAsDataURL(blob); } } document.onpaste = onPasteHandler; </script> </html>
评论已关闭!