session-desktop/js/views/file_input_view.js
2015-01-11 01:27:22 -10:00

56 lines
1.7 KiB
JavaScript

var Whisper = Whisper || {};
(function () {
'use strict';
Whisper.FileInputView = Backbone.View.extend({
tagName: 'span',
className: 'file-input',
initialize: function() {
this.$input = this.$el.find('input[type=file]');
},
events: {
'change': 'previewImages'
},
addThumb: function(e) {
this.$el.append(
$('<img>').attr( "src", e.target.result ).addClass('preview')
);
},
previewImages: function() {
this.$el.find('img').remove();
var files = this.$input.prop('files');
for (var i = 0; i < files.length; i++) {
var FR = new FileReader();
FR.onload = this.addThumb.bind(this);
FR.readAsDataURL(files[i]);
}
},
hasFiles: function() {
var files = this.$input.prop('files');
return files && files.length && files.length > 0;
},
getFiles: function() {
var promises = [];
var files = this.$input.prop('files');
for (var i = 0; i < files.length; i++) {
var contentType = files[i].type;
var p = new Promise(function(resolve, reject) {
var FR = new FileReader();
FR.onload = function(e) {
resolve({data: e.target.result, contentType: contentType});
};
FR.readAsArrayBuffer(files[i]);
}.bind(this));
promises.push(p);
}
this.$el.find('img').remove();
return Promise.all(promises);
}
});
})();