refine imageCropper fetch

pull/52/head
Pan 2017-05-15 22:24:29 +08:00
parent 0476f25eba
commit 69fe4d1e91
1 changed files with 14 additions and 34 deletions

View File

@ -105,6 +105,7 @@
<script>
/* eslint-disable */
import {effectRipple, data2blob} from './utils';
import fetch from 'utils/fetch';
import langBag from './lang';
const mimes = {
'jpg': 'image/jpeg',
@ -659,7 +660,8 @@
})
}
//
const uploadProgress = function(event) {
function uploadProgress (event) {
console.log(event)
if (event.lengthComputable) {
that.progress = 100 * Math.round(event.loaded) / event.total;
}
@ -669,43 +671,21 @@
that.loading = 1;
that.setStep(3);
that.$emit('crop-success', createImgUrl, field, ki);
new Promise(function(resolve, reject) {
let client = new XMLHttpRequest();
client.open('POST', url, true);
client.onreadystatechange = function() {
if (this.readyState !== 4) {
return;
}
if (this.status === 200) {
resolve(JSON.parse(this.responseText));
} else {
reject(this.status);
}
};
client.upload.addEventListener("progress", uploadProgress, false); //
// header
if (typeof headers == 'object' && headers) {
Object.keys(headers).forEach((k) => {
client.setRequestHeader(k, headers[k]);
})
}
client.send(fmData);
}).then(
//
function(resData) {
that.loading = 2;
that.$emit('crop-upload-success', resData);
},
//
function(sts) {
if (that.value) {
fetch({
url,
method: 'post',
data: fmData
}).then(resData=>{
that.loading = 2;
that.$emit('crop-upload-success', resData.data);
}).catch(err=>{
if (that.value) {
that.loading = 3;
that.hasError = true;
that.errorMsg = lang.fail;
that.$emit('crop-upload-fail', sts, field, ki);
that.$emit('crop-upload-fail', err, field, ki);
}
}
);
});
}
}
}