django-vue3-admin-web/node_modules/vue-clipboard3/dist/esm/index.js
2025-10-20 21:21:14 +08:00

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