Сохранение файлов в приложении Chrome

Резюме

Обычно я могу загрузить несколько файлов, но приложения Chrome не показывают полку загрузки, когда происходит загрузка. Как лучше всего обойти это ограничение приложений Chrome?

идеи

  • Я мог бы сделать это, создав zip-файл, но для этого потребовалось бы выполнить дополнительный шаг распаковки файла.
  • Я могу молча загружать файлы, и поэтому я могу отображать подсказку пользователю при загрузке файла, но для этого пользователю потребуется вручную искать файл в папке загрузок.

Чему я научился

  • Везде в Интернете мне говорят, что нужно использовать API загрузки Chrome, но это работает только для расширений Chrome, а не для приложений Chrome.
  • Я не могу вызвать сохранение как окно, потому что 50 сохранить как окна для 50 файлов недопустимо
  • Я могу, однако, вызвать приглашение с помощью chrome.fileSystem.chooseEntry({'type': "openDirectory"} попросить пользователя выбрать каталог, но я не могу найти способ сохранения в этом каталоге.
  • Мой вопрос в основном такой же, как Как расширение Chrome может сохранить много файлов в указанный пользователем каталог? но для приложения Chrome вместо расширения.

Код проекта и примера

Приложение, которое я создаю, будет таким же, как эта веб-страница, которую я создал, но с некоторыми изменениями, чтобы оно работало как веб-приложение.

Вот как мой сайт решает проблему

let example_pic = ""
let a = document.createElement("a");
a.href = example_pic;

document.body.appendChild(a)
a.click();

window.URL.revokeObjectURL(a.href);
a.remove()

1 ответ

Решение

Я могу, однако, вызвать приглашение с помощью chrome.fileSystem.chooseEntry({'type': "openDirectory"}) попросить пользователя выбрать каталог, но я не могу найти способ сохранения в этом каталоге.

Это то, что вам нужно работать.

Предположим, вы объявляете все суб-разрешения для fileSystem API:

"permissions": [
   {"fileSystem": ["write", "retainEntries", "directory"]}
]

Тогда ты можешь:

  1. Получить запись от пользователя:

    chrome.fileSystem.chooseEntry({'type': "openDirectory"}, function(dirEntry) {
      // Check for chrome.runtime.lastError, then use dirEntry
    });
    
  2. Сохраните его, чтобы вы могли использовать его позже, не спрашивая пользователя снова:

    dirEntryId = chrome.fileSystem.retainEntry(dirEntry);
    
    // Use chrome.storage to save/retrieve it
    
    chrome.fileSystem.restoreEntry(dirEntryId, function(entry) { /* ... */ });
    
  3. Используя HTML FileSystem API, создайте файлы в каталоге:

    dirEntry.getFile(
      "test.txt",
      {create: true}, // add "exclusive: true" to prevent overwrite
      function(fileEntry) { /* write here */ },
      function(e) { console.error(e) }
    );
    
Другие вопросы по тегам