36 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import Clipboard from 'clipboard';
 | 
						|
export default (opts) => {
 | 
						|
    // default appendToBody true
 | 
						|
    const appendToBody = (opts === null || opts === void 0 ? void 0 : opts.appendToBody) === undefined ? true : opts.appendToBody;
 | 
						|
    return {
 | 
						|
        toClipboard(text, container) {
 | 
						|
            return new Promise((resolve, reject) => {
 | 
						|
                // make fake element
 | 
						|
                const fakeEl = document.createElement('button');
 | 
						|
                // setup a new Clipboard.js
 | 
						|
                const clipboard = new Clipboard(fakeEl, {
 | 
						|
                    text: () => text,
 | 
						|
                    action: () => 'copy',
 | 
						|
                    container: container !== undefined ? container : document.body
 | 
						|
                });
 | 
						|
                clipboard.on('success', (e) => {
 | 
						|
                    clipboard.destroy();
 | 
						|
                    resolve(e);
 | 
						|
                });
 | 
						|
                clipboard.on('error', (e) => {
 | 
						|
                    clipboard.destroy();
 | 
						|
                    reject(e);
 | 
						|
                });
 | 
						|
                // appendToBody fixes IE
 | 
						|
                if (appendToBody)
 | 
						|
                    document.body.appendChild(fakeEl);
 | 
						|
                // simulate click
 | 
						|
                fakeEl.click();
 | 
						|
                // remove from body if appended
 | 
						|
                if (appendToBody)
 | 
						|
                    document.body.removeChild(fakeEl);
 | 
						|
            });
 | 
						|
        }
 | 
						|
    };
 | 
						|
};
 | 
						|
//# sourceMappingURL=index.js.map
 |