Composer: Fix pasting media from clipboard on iOS (#1698)
This commit is contained in:
parent
6b8ba8c2ce
commit
c2fcd83567
@ -1,22 +1,30 @@
|
||||
export default async function getFilesFromDataTransferItems(dataTransferItems: DataTransferItemList) {
|
||||
const files: File[] = [];
|
||||
|
||||
function traverseFileTreePromise(entry: FileSystemEntry | File) {
|
||||
function traverseFileTreePromise(entry: FileSystemEntry | File, item: DataTransferItem) {
|
||||
return new Promise(resolve => {
|
||||
if (entry instanceof File) {
|
||||
files.push(entry);
|
||||
resolve(entry);
|
||||
} else if (entry.isFile) {
|
||||
const itemFile = item.getAsFile();
|
||||
(entry as FileSystemFileEntry).file((file) => {
|
||||
files.push(file);
|
||||
resolve(file);
|
||||
}, () => {
|
||||
// iOS Safari throws an error "NotFoundError: Path does not exist" for files from the clipboard
|
||||
// https://stackoverflow.com/a/50059309
|
||||
if (itemFile) {
|
||||
files.push(itemFile);
|
||||
}
|
||||
resolve(itemFile);
|
||||
});
|
||||
} else if (entry.isDirectory) {
|
||||
let dirReader = (entry as FileSystemDirectoryEntry).createReader();
|
||||
dirReader.readEntries((entries) => {
|
||||
let entriesPromises = [];
|
||||
for (let entr of entries) {
|
||||
entriesPromises.push(traverseFileTreePromise(entr));
|
||||
entriesPromises.push(traverseFileTreePromise(entr, item));
|
||||
}
|
||||
resolve(Promise.all(entriesPromises));
|
||||
});
|
||||
@ -29,7 +37,7 @@ export default async function getFilesFromDataTransferItems(dataTransferItems: D
|
||||
if (item.kind === 'file') {
|
||||
const entry = item.webkitGetAsEntry() || item.getAsFile();
|
||||
if (entry) {
|
||||
entriesPromises.push(traverseFileTreePromise(entry));
|
||||
entriesPromises.push(traverseFileTreePromise(entry, item));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -24,12 +24,12 @@ const useClipboardPaste = (
|
||||
return;
|
||||
}
|
||||
|
||||
e.preventDefault();
|
||||
|
||||
const pastedText = e.clipboardData.getData('text').substring(0, MAX_MESSAGE_LENGTH);
|
||||
const { items } = e.clipboardData;
|
||||
let files: File[] = [];
|
||||
|
||||
e.preventDefault();
|
||||
if (items.length > 0) {
|
||||
files = await getFilesFromDataTransferItems(items);
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user