File: paste-image.html

package info (click to toggle)
webkit2gtk 2.46.1-2~bpo12%2B1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-backports
  • size: 420,212 kB
  • sloc: cpp: 3,538,579; javascript: 195,655; ansic: 170,215; python: 45,490; ruby: 18,411; asm: 18,016; perl: 16,533; xml: 4,605; yacc: 2,359; sh: 2,068; java: 1,711; lex: 1,327; pascal: 366; makefile: 316
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>