cloud-ui.vusion
Version:
Vusion Cloud UI
85 lines (68 loc) • 2.04 kB
JavaScript
function getError(url, options, xhr) {
let msg;
if (xhr.response) {
msg = `${xhr.response.error || xhr.response}`;
} else if (xhr.responseText) {
msg = `${xhr.responseText}`;
} else {
msg = `Fail to post ${url} ${xhr.status}`;
}
const err = new Error(msg);
err.status = xhr.status;
err.method = 'post';
err.url = url;
return err;
}
function getBody(xhr) {
const text = xhr.responseText || xhr.response;
if (!text)
return text;
try {
return JSON.parse(text);
} catch (e) {
return text;
}
}
export default function upload(options) {
if (typeof XMLHttpRequest === 'undefined')
return;
const xhr = new XMLHttpRequest();
const url = options.url;
if (xhr.upload) {
xhr.upload.onprogress = function onprogress(e) {
if (e.total > 0) {
e.percent = e.loaded / e.total * 100;
}
options.onProgress(e);
};
}
const formData = new FormData();
if (options.data) {
Object.keys(options.data).forEach((key) => {
formData.append(key, options.data[key]);
});
}
const files = options.file.length ? Array.from(options.file) : [options.file];
files.forEach((file) => formData.append(options.name, file, file.name));
xhr.onerror = function onerror(e) {
options.onError(e);
};
xhr.onload = function onload() {
if (xhr.status < 200 || xhr.status >= 300) {
return options.onError(getError(url, options, xhr));
}
options.onSuccess(getBody(xhr));
};
xhr.open('post', url, true);
if (options.withCredentials && 'withCredentials' in xhr) {
xhr.withCredentials = true;
}
const headers = options.headers || {};
for (const key in headers) {
if (headers.hasOwnProperty(key) && headers[key] !== null) {
xhr.setRequestHeader(key, headers[key]);
}
}
xhr.send(formData);
return xhr;
}