File: paste-image.html

package info (click to toggle)
webkit2gtk 2.34.6-1~deb10u1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 262,936 kB
  • sloc: cpp: 2,410,633; javascript: 191,866; ansic: 97,227; xml: 65,800; python: 30,274; ruby: 17,137; perl: 15,396; asm: 9,345; yacc: 2,309; sh: 1,660; lex: 1,293; java: 726; makefile: 106; pascal: 60
file content (34 lines) | stat: -rw-r--r-- 882 bytes parent folder | download | duplicates (14)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<!DOCTYPE html>
<html>
<body>
<div id="editor" contenteditable></div>
<script>
const editor = document.getElementById('editor');
editor.focus();

var dataTransfer = {};
editor.addEventListener('paste', (event) => {
    dataTransfer.types = Array.from(event.clipboardData.types);
    dataTransfer.files = Array.from(event.clipboardData.files);
    dataTransfer.items = Array.from(event.clipboardData.items).map(cloneItem);
});

function cloneItem(item) {
    return {
        kind: item.kind,
        type: item.type,
        file: item.getAsFile(),
    }
}

var imageElement;
function insertFileAsImage(file) {
    imageElement = document.createElement('img');
    imageElement.onload = () => window.webkit.messageHandlers.testHandler.postMessage('loaded');
    imageElement.src = URL.createObjectURL(file);
    document.body.appendChild(imageElement);
}

</script>
</body>
</html>