diff options
author | silverwind <me@silverwind.io> | 2020-11-02 18:08:30 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-02 12:08:30 -0500 |
commit | 842a75776a1a6c4bbe54e1fdd830fdc18f7b7153 (patch) | |
tree | cfa2ba06b354cc1db95757ba4ae6c7624cf593a4 | |
parent | fc40cdfa892b232c3447bbde69cba0214d72821b (diff) | |
download | gitea-842a75776a1a6c4bbe54e1fdd830fdc18f7b7153.tar.gz gitea-842a75776a1a6c4bbe54e1fdd830fdc18f7b7153.zip |
Refactor image paste code (#13354)
Some minor refactors I did while investigating another issue.
Functionalily should be pretty much the same as before.
Co-authored-by: techknowlogick <techknowlogick@gitea.io>
Co-authored-by: Lauris BH <lauris@nix.lv>
-rw-r--r-- | web_src/js/index.js | 80 |
1 files changed, 33 insertions, 47 deletions
diff --git a/web_src/js/index.js b/web_src/js/index.js index fa80b5fb65..ef6d72a4f7 100644 --- a/web_src/js/index.js +++ b/web_src/js/index.js @@ -305,42 +305,32 @@ function replaceAndKeepCursor(field, oldval, newval) { } } -function retrieveImageFromClipboardAsBlob(pasteEvent, callback) { - if (!pasteEvent.clipboardData) { - return; - } +function getPastedImages(e) { + if (!e.clipboardData) return []; - const {items} = pasteEvent.clipboardData; - if (typeof items === 'undefined') { - return; + const files = []; + for (const item of e.clipboardData.items || []) { + if (!item.type || !item.type.startsWith('image/')) continue; + files.push(item.getAsFile()); } - for (let i = 0; i < items.length; i++) { - if (!items[i].type.includes('image')) continue; - const blob = items[i].getAsFile(); - - if (typeof (callback) === 'function') { - pasteEvent.preventDefault(); - pasteEvent.stopPropagation(); - callback(blob); - } + if (files.length) { + e.preventDefault(); + e.stopPropagation(); } + return files; } -function uploadFile(file, callback) { - const xhr = new XMLHttpRequest(); - - xhr.addEventListener('load', () => { - if (xhr.status === 200) { - callback(xhr.responseText); - } - }); - - xhr.open('post', $('#dropzone').data('upload-url'), true); - xhr.setRequestHeader('X-Csrf-Token', csrf); +async function uploadFile(file) { const formData = new FormData(); formData.append('file', file, file.name); - xhr.send(formData); + + const res = await fetch($('#dropzone').data('upload-url'), { + method: 'POST', + headers: {'X-Csrf-Token': csrf}, + body: formData, + }); + return await res.json(); } function reload() { @@ -350,33 +340,29 @@ function reload() { function initImagePaste(target) { target.each(function () { const field = this; - field.addEventListener('paste', (event) => { - retrieveImageFromClipboardAsBlob(event, (img) => { + field.addEventListener('paste', async (e) => { + for (const img of getPastedImages(e)) { const name = img.name.substr(0, img.name.lastIndexOf('.')); insertAtCursor(field, `![${name}]()`); - uploadFile(img, (res) => { - const data = JSON.parse(res); - replaceAndKeepCursor(field, `![${name}]()`, `![${name}](${AppSubUrl}/attachments/${data.uuid})`); - const input = $(`<input id="${data.uuid}" name="files" type="hidden">`).val(data.uuid); - $('.files').append(input); - }); - }); + const data = await uploadFile(img); + replaceAndKeepCursor(field, `![${name}]()`, `![${name}](${AppSubUrl}/attachments/${data.uuid})`); + const input = $(`<input id="${data.uuid}" name="files" type="hidden">`).val(data.uuid); + $('.files').append(input); + } }, false); }); } function initSimpleMDEImagePaste(simplemde, files) { - simplemde.codemirror.on('paste', (_, event) => { - retrieveImageFromClipboardAsBlob(event, (img) => { + simplemde.codemirror.on('paste', async (_, e) => { + for (const img of getPastedImages(e)) { const name = img.name.substr(0, img.name.lastIndexOf('.')); - uploadFile(img, (res) => { - const data = JSON.parse(res); - const pos = simplemde.codemirror.getCursor(); - simplemde.codemirror.replaceRange(`![${name}](${AppSubUrl}/attachments/${data.uuid})`, pos); - const input = $(`<input id="${data.uuid}" name="files" type="hidden">`).val(data.uuid); - files.append(input); - }); - }); + const data = await uploadFile(img); + const pos = simplemde.codemirror.getCursor(); + simplemde.codemirror.replaceRange(`![${name}](${AppSubUrl}/attachments/${data.uuid})`, pos); + const input = $(`<input id="${data.uuid}" name="files" type="hidden">`).val(data.uuid); + files.append(input); + } }); } |