mirror of
				https://github.com/xtekky/gpt4free.git
				synced 2025-10-26 17:50:22 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			55 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| class CopyButtonPlugin {
 | |
|     constructor(options = {}) {
 | |
|         self.hook = options.hook;
 | |
|         self.callback = options.callback
 | |
|     }
 | |
|     "after:highlightElement"({
 | |
|         el,
 | |
|         text
 | |
|     }) {
 | |
|         let button = Object.assign(document.createElement("button"), {
 | |
|             innerHTML: "Copy",
 | |
|             className: "hljs-copy-button"
 | |
|         });
 | |
|         button.dataset.copied = false;
 | |
|         el.parentElement.classList.add("hljs-copy-wrapper");
 | |
|         el.parentElement.appendChild(button);
 | |
|         el.parentElement.style.setProperty("--hljs-theme-background", window.getComputedStyle(el).backgroundColor);
 | |
|         button.onclick = async () => {
 | |
|             let newText = text;
 | |
|             if (hook && typeof hook === "function") {
 | |
|                 newText = hook(text, el) || text
 | |
|             }
 | |
|             try {            
 | |
|                 if (!navigator.clipboard) {
 | |
|                     throw new Error("navigator.clipboard: Clipboard API unavailable.");
 | |
|                 }
 | |
|                 await navigator.clipboard.writeText(newText);
 | |
|             } catch (e) {
 | |
|                 console.error(e);
 | |
|                 console.error("Clipboard API writeText() failed! Fallback to document.exec(\"copy\")...");
 | |
|                 fallback_clipboard(newText);
 | |
|             }
 | |
|                 button.innerHTML = "Copied!";
 | |
|                 button.dataset.copied = true;
 | |
|                 let alert = Object.assign(document.createElement("div"), {
 | |
|                     role: "status",
 | |
|                     className: "hljs-copy-alert",
 | |
|                     innerHTML: "Copied to clipboard"
 | |
|                 });
 | |
|                 el.parentElement.appendChild(alert);
 | |
|                 setTimeout(() => {
 | |
|                     button.innerHTML = "Copy";
 | |
|                     button.dataset.copied = false;
 | |
|                     el.parentElement.removeChild(alert);
 | |
|                     alert = null
 | |
|                 }, 2e3)
 | |
|             }
 | |
| 
 | |
|             
 | |
|             if (typeof callback === "function") return callback(newText, el);
 | |
|             
 | |
|         }
 | |
|     
 | |
| }
 | 
