106 lines
2.3 KiB
JavaScript
106 lines
2.3 KiB
JavaScript
![]() |
"use strict";
|
||
|
|
||
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
||
|
|
||
|
exports.__esModule = true;
|
||
|
exports.default = void 0;
|
||
|
|
||
|
var _utils = require("../../utils");
|
||
|
|
||
|
var _uploader = _interopRequireDefault(require("../../uploader"));
|
||
|
|
||
|
// Utils
|
||
|
// Components
|
||
|
var namespace = (0, _utils.createNamespace)('sku-img-uploader');
|
||
|
var createComponent = namespace[0];
|
||
|
var t = namespace[2];
|
||
|
|
||
|
var _default = createComponent({
|
||
|
props: {
|
||
|
value: String,
|
||
|
uploadImg: Function,
|
||
|
customUpload: Function,
|
||
|
maxSize: {
|
||
|
type: Number,
|
||
|
default: 6
|
||
|
}
|
||
|
},
|
||
|
data: function data() {
|
||
|
return {
|
||
|
fileList: []
|
||
|
};
|
||
|
},
|
||
|
watch: {
|
||
|
value: function value(val) {
|
||
|
if (val) {
|
||
|
this.fileList = [{
|
||
|
url: val,
|
||
|
isImage: true
|
||
|
}];
|
||
|
} else {
|
||
|
this.fileList = [];
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
methods: {
|
||
|
afterReadFile: function afterReadFile(file) {
|
||
|
var _this = this;
|
||
|
|
||
|
file.status = 'uploading';
|
||
|
file.message = t('uploading');
|
||
|
this.uploadImg(file.file, file.content).then(function (img) {
|
||
|
file.status = 'done';
|
||
|
|
||
|
_this.$emit('input', img);
|
||
|
}).catch(function () {
|
||
|
file.status = 'failed';
|
||
|
file.message = t('fail');
|
||
|
});
|
||
|
},
|
||
|
onOversize: function onOversize() {
|
||
|
this.$toast(t('oversize', this.maxSize));
|
||
|
},
|
||
|
onDelete: function onDelete() {
|
||
|
this.$emit('input', '');
|
||
|
},
|
||
|
onClickUpload: function onClickUpload() {
|
||
|
var _this2 = this;
|
||
|
|
||
|
if (this.customUpload) {
|
||
|
this.customUpload().then(function (url) {
|
||
|
_this2.fileList.push({
|
||
|
url: url
|
||
|
});
|
||
|
|
||
|
_this2.$emit('input', url);
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
render: function render() {
|
||
|
var _this3 = this;
|
||
|
|
||
|
var h = arguments[0];
|
||
|
return h(_uploader.default, {
|
||
|
"attrs": {
|
||
|
"maxCount": 1,
|
||
|
"readonly": !!this.customUpload,
|
||
|
"maxSize": this.maxSize * 1024 * 1024,
|
||
|
"afterRead": this.afterReadFile
|
||
|
},
|
||
|
"on": {
|
||
|
"oversize": this.onOversize,
|
||
|
"delete": this.onDelete,
|
||
|
"click-upload": this.onClickUpload
|
||
|
},
|
||
|
"model": {
|
||
|
value: _this3.fileList,
|
||
|
callback: function callback($$v) {
|
||
|
_this3.fileList = $$v;
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
|
||
|
exports.default = _default;
|