diff --git a/README.md b/README.md
index 4588cfd..c917848 100644
--- a/README.md
+++ b/README.md
@@ -148,6 +148,7 @@ The context menu offers additional options for nodes, groups, colors, and the ca
- Custom color option (only available in "default" Color Mode).
- Show title on Reroute node
- Render Reroute as dot
+- Copy Images
@@ -165,6 +166,11 @@ The context menu offers additional options for nodes, groups, colors, and the ca
Reroute as dot
+
+
data:image/s3,"s3://crabby-images/a7fa9/a7fa923af2e5444ae1802c44cfb9ed2a5b372b03" alt="Copy images"
+
Copy Image
+
+
**Groups**
diff --git a/extensions/images.js b/extensions/images.js
new file mode 100644
index 0000000..ad1807a
--- /dev/null
+++ b/extensions/images.js
@@ -0,0 +1,51 @@
+/**
+ * Coded with love by Failfa.st
+ * LICENSE: AGPL 3.0
+ * https://github.com/failfa-st/failfast-comfyui-extensions/blob/main/LICENSE
+ *
+ * Visit https://github.com/failfa-st/failfast-comfyui-extensions for more info
+ *
+ * Homepage: https://failfa.st
+ * GitHub: https://github.com/failfa-st
+ * Discord: https://discord.com/invite/m3TBB9XEkb
+ */
+import { app } from "/scripts/app.js";
+
+const imagesName = "Failfast.images";
+
+function copyImageToClipboard(img) {
+ const canvas = document.createElement("canvas");
+ canvas.width = img.naturalWidth;
+ canvas.height = img.naturalHeight;
+ const context = canvas.getContext("2d");
+ context.drawImage(img, 0, 0);
+ canvas.toBlob(function (blob) {
+ const items = [new ClipboardItem({ "image/png": blob })];
+ navigator.clipboard.write(items);
+ });
+ canvas.remove();
+}
+app.registerExtension({
+ name: imagesName,
+ async init(app) {
+ const getNodeMenuOptions = LGraphCanvas.prototype.getNodeMenuOptions;
+ LGraphCanvas.prototype.getNodeMenuOptions = function (node) {
+ const options = getNodeMenuOptions.apply(this, arguments);
+ const isImageMenu = options.some(
+ (option) => option?.content === "Save Image",
+ );
+ if (isImageMenu) {
+ options.splice(2, 0, {
+ content: "Copy Image",
+ callback() {
+ const [img] = node.imgs;
+ if (img) {
+ copyImageToClipboard(img);
+ }
+ },
+ });
+ }
+ return options;
+ };
+ },
+});