|
@@ -2,15 +2,16 @@ const Plugin = require('./Plugin')
|
|
|
const UppySocket = require('../core/UppySocket')
|
|
|
const Utils = require('../core/Utils')
|
|
|
|
|
|
-module.exports = class Multipart extends Plugin {
|
|
|
+module.exports = class XHRUpload extends Plugin {
|
|
|
constructor (core, opts) {
|
|
|
super(core, opts)
|
|
|
this.type = 'uploader'
|
|
|
- this.id = 'Multipart'
|
|
|
- this.title = 'Multipart'
|
|
|
+ this.id = 'XHRUpload'
|
|
|
+ this.title = 'XHRUpload'
|
|
|
|
|
|
// Default options
|
|
|
const defaultOptions = {
|
|
|
+ formData: true,
|
|
|
fieldName: 'files[]',
|
|
|
metaFields: null,
|
|
|
responseUrlFieldName: 'url',
|
|
@@ -28,31 +29,34 @@ module.exports = class Multipart extends Plugin {
|
|
|
this.handleUpload = this.handleUpload.bind(this)
|
|
|
}
|
|
|
|
|
|
+ createFormDataUpload (file, opts) {
|
|
|
+ const formPost = new FormData()
|
|
|
+
|
|
|
+ const metaFields = Array.isArray(opts.metaFields)
|
|
|
+ ? opts.metaFields
|
|
|
+ // Send along all fields by default.
|
|
|
+ : Object.keys(file.meta)
|
|
|
+ metaFields.forEach((item) => {
|
|
|
+ formPost.append(item, file.meta[item])
|
|
|
+ })
|
|
|
+
|
|
|
+ formPost.append(opts.fieldName, file.data)
|
|
|
+
|
|
|
+ return formPost
|
|
|
+ }
|
|
|
+
|
|
|
+ createBareUpload (file, opts) {
|
|
|
+ return file.data
|
|
|
+ }
|
|
|
+
|
|
|
upload (file, current, total) {
|
|
|
- const opts = Object.assign({}, this.opts, file.multipart || {})
|
|
|
+ const opts = Object.assign({}, this.opts, file.xhrUpload || {})
|
|
|
|
|
|
this.core.log(`uploading ${current} of ${total}`)
|
|
|
return new Promise((resolve, reject) => {
|
|
|
- // turn file into an array so we can use bundle
|
|
|
- // if (!opts.bundle) {
|
|
|
- // files = [files[current]]
|
|
|
- // }
|
|
|
-
|
|
|
- // for (let i in files) {
|
|
|
- // formPost.append(opts.fieldName, files[i])
|
|
|
- // }
|
|
|
-
|
|
|
- const formPost = new FormData()
|
|
|
-
|
|
|
- const metaFields = Array.isArray(opts.metaFields)
|
|
|
- ? opts.metaFields
|
|
|
- // Send along all fields by default.
|
|
|
- : Object.keys(file.meta)
|
|
|
- metaFields.forEach((item) => {
|
|
|
- formPost.append(item, file.meta[item])
|
|
|
- })
|
|
|
-
|
|
|
- formPost.append(opts.fieldName, file.data)
|
|
|
+ const data = opts.formData
|
|
|
+ ? this.createFormDataUpload(file, opts)
|
|
|
+ : this.createBareUpload(file, opts)
|
|
|
|
|
|
const xhr = new XMLHttpRequest()
|
|
|
|
|
@@ -97,13 +101,13 @@ module.exports = class Multipart extends Plugin {
|
|
|
return reject('Upload error')
|
|
|
})
|
|
|
|
|
|
- xhr.open('POST', opts.endpoint, true)
|
|
|
+ xhr.open(opts.method.toUpperCase(), opts.endpoint, true)
|
|
|
|
|
|
Object.keys(opts.headers).forEach((header) => {
|
|
|
xhr.setRequestHeader(header, opts.headers[header])
|
|
|
})
|
|
|
|
|
|
- xhr.send(formPost)
|
|
|
+ xhr.send(data)
|
|
|
|
|
|
this.core.emitter.on('core:upload-cancel', (fileID) => {
|
|
|
if (fileID === file.id) {
|
|
@@ -122,7 +126,7 @@ module.exports = class Multipart extends Plugin {
|
|
|
}
|
|
|
|
|
|
uploadRemote (file, current, total) {
|
|
|
- const opts = Object.assign({}, this.opts, file.multipart || {})
|
|
|
+ const opts = Object.assign({}, this.opts, file.xhrUpload || {})
|
|
|
return new Promise((resolve, reject) => {
|
|
|
this.core.emitter.emit('core:upload-started', file.id)
|
|
|
|
|
@@ -184,11 +188,11 @@ module.exports = class Multipart extends Plugin {
|
|
|
|
|
|
handleUpload (fileIDs) {
|
|
|
if (fileIDs.length === 0) {
|
|
|
- this.core.log('Multipart: no files to upload!')
|
|
|
+ this.core.log('XHRUpload: no files to upload!')
|
|
|
return Promise.resolve()
|
|
|
}
|
|
|
|
|
|
- this.core.log('Multipart is uploading...')
|
|
|
+ this.core.log('XHRUpload is uploading...')
|
|
|
const files = fileIDs.map(getFile, this)
|
|
|
function getFile (fileID) {
|
|
|
return this.core.state.files[fileID]
|