Загрузить индикатор прогресса для небольших файлов в метеоре CollectionFS
С meteor-cfs-ui
-пакет вы можете показать индикатор загрузки файлов. Но это хорошо работает только для файлов размером более 2 МБ. Если файлы меньше, полоса просто скачет с 0% до 100%.
Здесь я нашел решение для этого, который использует этот код:
if(fsFile.original.size < (2097152)*10) {
var chunkSize = fsFile.original.size / 10;
FS.config.uploadChunkSize = chunkSize;
}
uploadFile(fsFile, fullFileName, projectId);
Но где я должен поместить этот код?
Я объявляю свои магазины так:
Images = new FS.Collection("images", {
stores: [
new FS.Store.FileSystem("something", {
transformWrite: function (fileObj, readStream, writeStream) {
// do transformations
}
})]
});
Загрузка выполняется следующим образом:
FS.Utility.eachFile(event, function (file) {
var newFile = new FS.File(file);
newFile.uploadedFrom = Meteor.userId();
data = Images.insert(newFile, function (error, fileObject) {});
});
Так что я думаю, что это глупый вопрос, но я действительно не вижу, куда поместить этот код...
2 ответа
Загрузка происходит при вставке коллекции, поэтому вы должны иметь возможность установить chunkSize
прямо перед этим:
FS.Utility.eachFile(event, function (file) {
var newFile = new FS.File(file);
newFile.uploadedFrom = Meteor.userId();
var maxChunk = 2097152;
FS.config.uploadChunkSize =
( newFile.original.size < 10*maxChunk ) ? newFile.original.size/10 : maxChunk;
data = Images.insert(newFile, function (error, fileObject) {});
});
Кроме того, если вы используете FS.EventHandlers.insertFiles
и не видите полосу загрузки, создайте эту функцию в своем клиентском коде:
/**
* Replace for original FS.EventHandlers.insertFiles function.
*/
function cfsInsertFiles(collection, options) {
options = options || {};
var afterCallback = options.after;
var metadataCallback = options.metadata;
function insertFilesHandler(event) {
FS.Utility.eachFile(event, function (file) {
var f = new FS.File(file);
var maxChunk = 2097152;
FS.config.uploadChunkSize =
(f.original.size < 10 * maxChunk) ? f.original.size / 10 : maxChunk;
if (metadataCallback) {
FS.Utility.extend(f, metadataCallback(f));
}
collection.insert(f, afterCallback);
});
}
return insertFilesHandler;
}
И, наконец, используйте его вместо FS.EventHandlers.insertFiles
, Например:
Template.files.events({
'dropped .imageArea': cfsInsertFiles(Images, {
metadata: function (fileObj) {
return {
owner: Meteor.userId(),
foo: "bar"
};
},
after: function (error, fileObj) {
console.log("Inserted", fileObj.name);
}
})
});