// ==UserScript== // @name Dall-e-2 Copy Button Userscript // @namespace http://tampermonkey.net/ // @version 0.1 // @description Copy 6 mini images to clipboard // @author Jonathan // @match https://labs.openai.com/e/* // @icon  // @grant none // @license CC // @downloadURL none // ==/UserScript== function waitForElm(selector) { return new Promise(resolve => { if (document.querySelector(selector)) { return resolve(document.querySelector(selector)); } const observer = new MutationObserver(mutations => { if (document.querySelector(selector)) { resolve(document.querySelector(selector)); observer.disconnect(); } }); observer.observe(document.body, { childList: true, subtree: true }); }); } (function() { 'use strict'; const addBtn = function() { const node = document.getElementsByClassName('task-page-generations')[0]; const btn = document.createElement('div'); btn.style['align-self'] = 'center'; btn.style['padding-bottom'] = '10px'; btn.innerHTML = ''; btn.addEventListener('click', function() { console.log('copy button clicked'); const canvas = document.createElement('canvas'); canvas.id = "copy-canvas"; const imSize = 400; const margin = 8 canvas.width = 3*imSize + (4*margin); canvas.height =2*imSize + (2*margin) + 50; const body = document.getElementsByTagName("body")[0]; body.appendChild(canvas); const ctx = canvas.getContext('2d'); ctx.fillStyle = "white"; ctx.fillRect(0, 0, canvas.width, canvas.height); const images = document.getElementsByClassName('generated-image'); const sig = document.getElementsByClassName('image-signature')[0]; for(var i = 0; i < 6; i++) { const img = images.item(i).firstChild; const x = (imSize * i + (i%3*margin)) % 1200 + margin; const y = margin+ (i<3?0:imSize + margin); ctx.drawImage(img, x, y, imSize, imSize); ctx.translate(x+imSize-80, y+imSize-16); for(var p=0;p { addBtn(); }); })();