File size: 3,121 Bytes
583c1c7
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import { app } from "../../scripts/app.js";
const clipboardSupportedPromise = new Promise(async (resolve) => {
    try {
        const result = await navigator.permissions.query({ name: "clipboard-write" });
        resolve(result.state === "granted");
        return;
    }
    catch (e) {
        try {
            if (!navigator.clipboard.write) {
                throw new Error();
            }
            new ClipboardItem({ "image/png": new Blob([], { type: "image/png" }) });
            resolve(true);
            return;
        }
        catch (e) {
            resolve(false);
        }
    }
});
app.registerExtension({
    name: "rgthree.CopyImageToClipboard",
    async beforeRegisterNodeDef(nodeType, nodeData) {
        if (nodeData.name.toLowerCase().includes("image")) {
            if (await clipboardSupportedPromise) {
                const getExtraMenuOptions = nodeType.prototype.getExtraMenuOptions;
                nodeType.prototype.getExtraMenuOptions = function (canvas, options) {
                    var _a;
                    getExtraMenuOptions ? getExtraMenuOptions.apply(this, arguments) : undefined;
                    if ((_a = this.imgs) === null || _a === void 0 ? void 0 : _a.length) {
                        let img = this.imgs[this.imageIndex || 0] || this.imgs[this.overIndex || 0] || this.imgs[0];
                        const foundIdx = options.findIndex((option) => { var _a; return (_a = option === null || option === void 0 ? void 0 : option.content) === null || _a === void 0 ? void 0 : _a.includes("Copy Image"); });
                        if (img && foundIdx === -1) {
                            const menuItem = {
                                content: "Copy Image (rgthree)",
                                callback: () => {
                                    const canvas = document.createElement("canvas");
                                    const ctx = canvas.getContext("2d");
                                    canvas.width = img.naturalWidth;
                                    canvas.height = img.naturalHeight;
                                    ctx.drawImage(img, 0, 0, img.naturalWidth, img.naturalHeight);
                                    canvas.toBlob((blob) => {
                                        navigator.clipboard.write([new ClipboardItem({ "image/png": blob })]);
                                    });
                                },
                            };
                            let idx = options.findIndex((option) => { var _a; return (_a = option === null || option === void 0 ? void 0 : option.content) === null || _a === void 0 ? void 0 : _a.includes("Open Image"); }) + 1;
                            if (idx != null) {
                                options.splice(idx, 0, menuItem);
                            }
                            else {
                                options.unshift(menuItem);
                            }
                        }
                    }
                };
            }
        }
    },
});