|
|
@ -1,15 +1,46 @@ |
|
|
|
import { useClipboard } from '#imports' |
|
|
|
import { Modal } from 'ant-design-vue' |
|
|
|
|
|
|
|
import { useClipboard, useI18n } from '#imports' |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
export const useCopy = (showDialogIfFailed = false) => { |
|
|
|
|
|
|
|
const { t } = useI18n() |
|
|
|
|
|
|
|
|
|
|
|
export const useCopy = () => { |
|
|
|
|
|
|
|
/** fallback for copy if clipboard api is not supported */ |
|
|
|
/** fallback for copy if clipboard api is not supported */ |
|
|
|
const copyFallback = (text: string) => { |
|
|
|
const copyFallback = async (text: string, retryCount = 0): Promise<boolean> => { |
|
|
|
const textAreaEl = document.createElement('textarea') |
|
|
|
try { |
|
|
|
textAreaEl.innerHTML = text |
|
|
|
const textAreaEl = document.createElement('textarea') |
|
|
|
document.body.appendChild(textAreaEl) |
|
|
|
textAreaEl.innerHTML = text |
|
|
|
textAreaEl.select() |
|
|
|
document.body.appendChild(textAreaEl) |
|
|
|
const result = document.execCommand('copy') |
|
|
|
textAreaEl.select() |
|
|
|
document.body.removeChild(textAreaEl) |
|
|
|
const result = document.execCommand('copy') |
|
|
|
return result |
|
|
|
document.body.removeChild(textAreaEl) |
|
|
|
|
|
|
|
if (!result && retryCount < 3) { |
|
|
|
|
|
|
|
// retry if copy failed
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => |
|
|
|
|
|
|
|
setTimeout( |
|
|
|
|
|
|
|
() => |
|
|
|
|
|
|
|
copyFallback(text, retryCount + 1) |
|
|
|
|
|
|
|
.then(resolve) |
|
|
|
|
|
|
|
.catch(reject), |
|
|
|
|
|
|
|
100, |
|
|
|
|
|
|
|
), |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!result) { |
|
|
|
|
|
|
|
throw new Error('failed') |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return result |
|
|
|
|
|
|
|
} catch (e) { |
|
|
|
|
|
|
|
if (!showDialogIfFailed) throw new Error(t('msg.error.copyToClipboardError')) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Modal.info({ |
|
|
|
|
|
|
|
title: 'Copy failed, please manually copy it from here', |
|
|
|
|
|
|
|
content: text, |
|
|
|
|
|
|
|
class: 'nc-copy-failed-modal', |
|
|
|
|
|
|
|
width: '550px', |
|
|
|
|
|
|
|
}) |
|
|
|
|
|
|
|
return false |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const { copy: _copy, isSupported } = useClipboard() |
|
|
|
const { copy: _copy, isSupported } = useClipboard() |
|
|
@ -18,12 +49,11 @@ export const useCopy = () => { |
|
|
|
try { |
|
|
|
try { |
|
|
|
if (isSupported.value) { |
|
|
|
if (isSupported.value) { |
|
|
|
await _copy(text) |
|
|
|
await _copy(text) |
|
|
|
} else { |
|
|
|
return true |
|
|
|
copyFallback(text) |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} catch (e) { |
|
|
|
} catch {} |
|
|
|
copyFallback(text) |
|
|
|
|
|
|
|
} |
|
|
|
return copyFallback(text) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return { copy } |
|
|
|
return { copy } |
|
|
|