2023-04-14 21:08:40 +08:00
|
|
|
export class Clipboard {
|
2019-12-21 23:48:03 +08:00
|
|
|
|
2024-10-04 21:36:20 +08:00
|
|
|
protected data: DataTransfer;
|
|
|
|
|
|
|
|
constructor(clipboardData: DataTransfer) {
|
2019-12-21 23:48:03 +08:00
|
|
|
this.data = clipboardData;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the clipboard has any items.
|
|
|
|
*/
|
2024-10-04 21:36:20 +08:00
|
|
|
hasItems(): boolean {
|
2019-12-21 23:48:03 +08:00
|
|
|
return Boolean(this.data) && Boolean(this.data.types) && this.data.types.length > 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the given event has tabular-looking data in the clipboard.
|
|
|
|
*/
|
2024-10-04 21:36:20 +08:00
|
|
|
containsTabularData(): boolean {
|
2023-04-19 05:20:02 +08:00
|
|
|
const rtfData = this.data.getData('text/rtf');
|
2024-10-04 21:36:20 +08:00
|
|
|
return !!rtfData && rtfData.includes('\\trowd');
|
2019-12-21 23:48:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the images that are in the clipboard data.
|
|
|
|
*/
|
2024-10-04 21:36:20 +08:00
|
|
|
getImages(): File[] {
|
|
|
|
return this.getFiles().filter(f => f.type.includes('image'));
|
2019-12-21 23:48:03 +08:00
|
|
|
}
|
2023-04-19 05:20:02 +08:00
|
|
|
|
2023-04-24 23:19:20 +08:00
|
|
|
/**
|
|
|
|
* Get the files included in the clipboard data.
|
|
|
|
*/
|
2024-10-04 21:36:20 +08:00
|
|
|
getFiles(): File[] {
|
2023-04-24 23:19:20 +08:00
|
|
|
const {files} = this.data;
|
|
|
|
return [...files];
|
|
|
|
}
|
2019-12-21 23:48:03 +08:00
|
|
|
}
|
|
|
|
|
2024-10-04 21:36:20 +08:00
|
|
|
export async function copyTextToClipboard(text: string) {
|
2023-04-18 22:08:17 +08:00
|
|
|
if (window.isSecureContext && navigator.clipboard) {
|
|
|
|
await navigator.clipboard.writeText(text);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Backup option where we can't use the navigator.clipboard API
|
2023-04-19 05:20:02 +08:00
|
|
|
const tempInput = document.createElement('textarea');
|
2024-10-04 21:36:20 +08:00
|
|
|
tempInput.setAttribute('style', 'position: absolute; left: -1000px; top: -1000px;');
|
2023-04-18 22:08:17 +08:00
|
|
|
tempInput.value = text;
|
|
|
|
document.body.appendChild(tempInput);
|
|
|
|
tempInput.select();
|
2023-04-19 05:20:02 +08:00
|
|
|
document.execCommand('copy');
|
2023-04-18 22:08:17 +08:00
|
|
|
document.body.removeChild(tempInput);
|
2023-04-14 21:08:40 +08:00
|
|
|
}
|