"use strict";
|
var __assign = (this && this.__assign) || function () {
|
__assign = Object.assign || function(t) {
|
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
s = arguments[i];
|
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
t[p] = s[p];
|
}
|
return t;
|
};
|
return __assign.apply(this, arguments);
|
};
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
return new (P || (P = Promise))(function (resolve, reject) {
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
});
|
};
|
var __generator = (this && this.__generator) || function (thisArg, body) {
|
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
function verb(n) { return function (v) { return step([n, v]); }; }
|
function step(op) {
|
if (f) throw new TypeError("Generator is already executing.");
|
while (_) try {
|
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
if (y = 0, t) op = [op[0] & 2, t.value];
|
switch (op[0]) {
|
case 0: case 1: t = op; break;
|
case 4: _.label++; return { value: op[1], done: false };
|
case 5: _.label++; y = op[1]; op = [0]; continue;
|
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
default:
|
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
if (t[2]) _.ops.pop();
|
_.trys.pop(); continue;
|
}
|
op = body.call(thisArg, _);
|
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
}
|
};
|
Component({
|
options: {
|
styleIsolation: "shared",
|
addGlobalClass: true,
|
multipleSlots: true
|
},
|
properties: {
|
url: {
|
type: String,
|
value: ""
|
},
|
fileDeleteUrl: {
|
type: String,
|
value: ""
|
},
|
description: {
|
type: String,
|
value: "建议尺寸:500x500像素,72分辨率"
|
},
|
previewSize: {
|
type: String,
|
value: "500rpx"
|
},
|
imageFit: {
|
type: String,
|
value: "aspectFill"
|
},
|
hasSlot: {
|
type: Boolean,
|
value: false
|
},
|
multiple: {
|
type: Boolean,
|
value: false
|
},
|
imgList: {
|
type: Array,
|
value: []
|
},
|
isMustUpload: {
|
type: Boolean,
|
value: true
|
}
|
},
|
data: {
|
imgList: [],
|
coverImage: '',
|
images: ''
|
},
|
lifetimes: {
|
ready: function () {
|
console.log(this.data.imgList);
|
}
|
},
|
observers: {
|
'imgList': function (val) {
|
console.log('监听图片列表imgList', val, this.data.imgList);
|
if (val.length > 0) {
|
if (this.data.multiple) {
|
this.getImgUnid('images');
|
}
|
else {
|
this.getImgUnid('coverImage');
|
}
|
}
|
}
|
},
|
methods: {
|
uploadSingleFile: function (event) {
|
return __awaiter(this, void 0, void 0, function () {
|
var file, _a, err, result, imgList;
|
return __generator(this, function (_b) {
|
switch (_b.label) {
|
case 0:
|
file = event.detail.file;
|
console.log(event, file);
|
return [4, this.uploadFile({
|
file: file,
|
url: this.data.url,
|
formData: {}
|
})];
|
case 1:
|
_a = _b.sent(), err = _a[0], result = _a[1];
|
if (err) {
|
console.log(err);
|
return [2];
|
}
|
console.log(result);
|
imgList = this.data.imgList;
|
imgList.push(__assign({}, result));
|
this.setData({ imgList: imgList });
|
console.log('单张上传后imgList。。。', imgList);
|
this.getImgUnid('coverImage');
|
return [2];
|
}
|
});
|
});
|
},
|
uploadMultipleFile: function (event) {
|
return __awaiter(this, void 0, void 0, function () {
|
var file, imgList, unid, url, i, _a, err, result;
|
return __generator(this, function (_b) {
|
switch (_b.label) {
|
case 0:
|
file = event.detail.file;
|
console.log(event, file);
|
imgList = this.data.imgList;
|
unid = this.data.imgList[0] && this.data.imgList[0].unid || '';
|
url = this.data.url;
|
i = 0;
|
_b.label = 1;
|
case 1:
|
if (!(i < file.length)) return [3, 4];
|
if (unid) {
|
url += "&unid=" + unid;
|
}
|
console.log(url);
|
return [4, this.uploadFile({
|
file: file[i],
|
url: url,
|
formData: {}
|
})];
|
case 2:
|
_a = _b.sent(), err = _a[0], result = _a[1];
|
if (err) {
|
console.log(err);
|
return [2];
|
}
|
console.log(result);
|
imgList.push(__assign({}, result));
|
unid = result.unid;
|
_b.label = 3;
|
case 3:
|
i++;
|
return [3, 1];
|
case 4:
|
this.setData({ imgList: imgList });
|
console.log('多张上传后imgList。。。', imgList);
|
this.getImgUnid('images');
|
if (this.data.isMustUpload) {
|
this.checkImages("images", "请至少上传一张图片");
|
}
|
return [2];
|
}
|
});
|
});
|
},
|
deleteFile: function (event) {
|
return __awaiter(this, void 0, void 0, function () {
|
var _a, imgList, fileDeleteUrl, index, _b, err, result;
|
return __generator(this, function (_c) {
|
switch (_c.label) {
|
case 0:
|
_a = this.data, imgList = _a.imgList, fileDeleteUrl = _a.fileDeleteUrl;
|
index = event.detail.index;
|
console.log(index, 'dd');
|
return [4, wx.$utils.to(wx.$http.request({
|
url: fileDeleteUrl,
|
data: {
|
unid: imgList[index].unid,
|
seq: imgList[index].seq,
|
}
|
}))];
|
case 1:
|
_b = _c.sent(), err = _b[0], result = _b[1];
|
if (err) {
|
console.log(err);
|
return [2];
|
}
|
console.log(result);
|
if (result.state === "success") {
|
imgList.splice(index, 1);
|
this.setData({
|
imgList: imgList
|
});
|
}
|
console.log('删除后imgList。。。', imgList);
|
if (this.data.multiple) {
|
this.getImgUnid('images');
|
}
|
else {
|
this.getImgUnid('coverImage');
|
}
|
return [2];
|
}
|
});
|
});
|
},
|
uploadFile: function (param) {
|
return __awaiter(this, void 0, void 0, function () {
|
var _a, err, result;
|
return __generator(this, function (_b) {
|
switch (_b.label) {
|
case 0: return [4, wx.$utils.to(wx.$http.uploadFile({
|
url: param.url,
|
formData: param.formData,
|
filePath: param.file.url
|
}))];
|
case 1:
|
_a = _b.sent(), err = _a[0], result = _a[1];
|
return [2, [err, result]];
|
}
|
});
|
});
|
},
|
getImgList: function () {
|
return this.data.imgList;
|
},
|
getImgUnid: function (type) {
|
var _a, _b;
|
var unid;
|
if (!this.data.imgList[0]) {
|
unid = undefined;
|
this.setData((_a = {},
|
_a[type] = unid,
|
_a));
|
console.log(type, '图unid', unid);
|
return unid;
|
}
|
unid = this.data.imgList[0].unid + ';';
|
var seq = this.data.imgList.reduce(function (total, current) {
|
console.log('total:', total, 'current.seq:', current.seq);
|
return total + ';' + current.seq;
|
}, ' ');
|
var res = unid + seq.replace(' ;', '').replace(new RegExp(' ', 'gm'), '');
|
this.setData((_b = {},
|
_b[type] = res,
|
_b));
|
console.log(type, '图unid+seq', res);
|
return res;
|
},
|
checkImages: function (images, msg) {
|
var _a, _b;
|
if (!this.data[images]) {
|
this.setData((_a = {},
|
_a[images + "Error"] = msg,
|
_a));
|
return false;
|
}
|
this.setData((_b = {},
|
_b[images + "Error"] = "",
|
_b));
|
return true;
|
},
|
getCoverImageUnid: function () {
|
return this.data.coverImage;
|
},
|
getImagesUnid: function () {
|
return this.data.images;
|
},
|
clearImagesData: function () {
|
this.setData({
|
imgList: [],
|
images: '',
|
coverImage: ''
|
});
|
},
|
startUpload: function () {
|
var fileUpload = this.selectComponent('#my-file-uploader');
|
console.log('准备上传。。。');
|
fileUpload.startUpload();
|
}
|
}
|
});
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["type file = {\r\n  file: string,\r\n  url: string\r\n}\r\ntype Images = 'coverImage'|'images';\r\n// const app = getApp<IAppOption>();\r\nComponent({\r\n  /**\r\n   * 组件的属性列表\r\n   */\r\n  options: {\r\n    styleIsolation:\"shared\",\r\n    addGlobalClass:true,\r\n    multipleSlots: true // 在组件定义时的选项中启用多slot支持\r\n  },\r\n  properties: {\r\n    url:{\r\n      type: String,\r\n      value: \"\"\r\n    },\r\n    fileDeleteUrl:{\r\n      type: String,\r\n      value: \"\"\r\n    },\r\n    description:{\r\n      type: String,\r\n      value: \"建议尺寸:500x500像素，72分辨率\"\r\n    },\r\n    previewSize:{\r\n      type: String,\r\n      value: \"500rpx\"\r\n    },\r\n    imageFit:{\r\n      type: String,\r\n      value: \"aspectFill\"\r\n    },\r\n    hasSlot:{\r\n      type:Boolean,\r\n      value: false\r\n    },\r\n    multiple:{\r\n      type:Boolean,\r\n      value: false\r\n    },\r\n    imgList:{\r\n      type:Array,\r\n      value: []\r\n    },\r\n    isMustUpload:{\r\n      type:Boolean,\r\n      value: true\r\n    }\r\n  },\r\n\r\n  /**\r\n   * 组件的初始数据\r\n   */\r\n  data: {\r\n    imgList: <any>[],\r\n    coverImage:'',\r\n    images:''\r\n  },\r\n  lifetimes:{\r\n    ready(){\r\n      console.log(this.data.imgList);\r\n\r\n    }\r\n  },\r\n  observers: {\r\n    'imgList': function(val) {\r\n      console.log('监听图片列表imgList',val,this.data.imgList)\r\n      if (val.length>0) {\r\n        if (this.data.multiple){\r\n          this.getImgUnid('images');\r\n        } else {\r\n          this.getImgUnid('coverImage');\r\n        }\r\n      }\r\n\r\n    }\r\n  },\r\n  /**\r\n   * 组件的方法列表\r\n   */\r\n  methods: {\r\n    async uploadSingleFile(event:any) {\r\n      const { file } = event.detail;\r\n      console.log(event,file);\r\n      // 当设置 mutiple 为 true 时, file 为数组格式，否则为对象格式\r\n      let [err,result] = await this.uploadFile({\r\n        file,\r\n        url: this.data.url,\r\n        formData:{\r\n          // isCoverImage:true,\r\n          // formid:710802\r\n        }\r\n      });\r\n      if (err){\r\n        console.log(err);\r\n        return;\r\n      }\r\n      console.log(result);\r\n      let imgList = this.data.imgList;\r\n      imgList.push({ ...result });\r\n      this.setData({ imgList });\r\n      console.log('单张上传后imgList。。。',imgList);\r\n      this.getImgUnid('coverImage');\r\n      // this.triggerEvent('getCoverImage',{\r\n      //   imgList\r\n      // })\r\n\r\n    },\r\n    async uploadMultipleFile(event:any) {\r\n      const { file } = event.detail;\r\n      console.log(event,file);\r\n      let imgList = this.data.imgList;\r\n      let unid = this.data.imgList[0]&&this.data.imgList[0].unid||'';\r\n      let url = this.data.url;\r\n      for (let i = 0; i < file.length; i++) {\r\n        if (unid){\r\n          url+=`&unid=${unid}`;\r\n        }\r\n        console.log(url);\r\n        // 当设置 mutiple 为 true 时, file 为数组格式，否则为对象格式\r\n        let [err,result] = await this.uploadFile({\r\n          file:file[i],\r\n          url,\r\n          formData:{\r\n            // isCoverImage:true,\r\n            // formid:710802\r\n          }\r\n        });\r\n        if (err){\r\n          console.log(err);\r\n          return;\r\n        }\r\n        console.log(result);\r\n        imgList.push({ ...result });\r\n        unid = result.unid;\r\n      }\r\n\r\n      this.setData({ imgList });\r\n      console.log('多张上传后imgList。。。',imgList);\r\n      this.getImgUnid('images');\r\n      if (this.data.isMustUpload){\r\n        this.checkImages(\"images\", \"请至少上传一张图片\")\r\n      }\r\n\r\n      // this.triggerEvent('getCoverImage',{\r\n      //   imgList\r\n      // })\r\n\r\n    },\r\n    async deleteFile(event:any){\r\n      let {imgList,fileDeleteUrl} = this.data;\r\n      let {index} = event.detail;\r\n      console.log(index,'dd');\r\n      let [err,result] = await wx.$utils.to(\r\n        wx.$http.request({\r\n          url: fileDeleteUrl,\r\n          data:{\r\n            unid:imgList[index].unid,\r\n            seq:imgList[index].seq,\r\n          }\r\n        })\r\n      );\r\n      if (err){\r\n        console.log(err);\r\n        return;\r\n      }\r\n      console.log(result);\r\n      if (result.state === \"success\"){\r\n        imgList.splice(index, 1);\r\n        this.setData({\r\n          imgList\r\n        })\r\n      }\r\n      console.log('删除后imgList。。。',imgList);\r\n      if (this.data.multiple){\r\n        this.getImgUnid('images');\r\n      } else {\r\n        this.getImgUnid('coverImage');\r\n      }\r\n    },\r\n    async uploadFile(param:any){\r\n      let [err,result] = await wx.$utils.to(\r\n        wx.$http.uploadFile({\r\n          url:param.url,\r\n          formData:param.formData,\r\n          filePath:param.file.url\r\n        })\r\n      )\r\n        return [err,result];\r\n    },\r\n\r\n    getImgList(){\r\n      return this.data.imgList;\r\n    },\r\n    // getSingleImgUnid(){\r\n    //   let unid:string|boolean|undefined;\r\n    //   if (this.data.imgList[0]){\r\n    //     unid = this.data.imgList[0].unid+';'+this.data.imgList[0].seq;\r\n    //   } else {\r\n    //     unid = undefined;\r\n    //   }\r\n    //   this.setData({\r\n    //     coverImg:unid\r\n    //   });\r\n    //   console.log('封面图unid',unid);\r\n    //   return unid;\r\n    // },\r\n    getImgUnid(type:string){\r\n      let unid:string|boolean|undefined;\r\n      if (!this.data.imgList[0]){\r\n        unid = undefined;\r\n        this.setData({\r\n          [type]:unid\r\n        });\r\n        console.log(type,'图unid',unid);\r\n        return unid;\r\n      }\r\n      unid = this.data.imgList[0].unid+';';\r\n      let seq = this.data.imgList.reduce((total:string,current:any)=>{\r\n        console.log('total:',total,'current.seq:',current.seq);\r\n        return total+';'+current.seq\r\n      },' ')\r\n      let res = unid+seq.replace(' ;','').replace(new RegExp(' ', 'gm'), '')\r\n      this.setData({\r\n        [type]:res\r\n      });\r\n      console.log(type,'图unid+seq',res);\r\n      return res;\r\n    },\r\n    checkImages(images:Images, msg:string) {\r\n      if (!this.data[images]) {\r\n        this.setData({\r\n          [images + \"Error\"]: msg,\r\n        });\r\n        return false;\r\n      }\r\n      this.setData({\r\n        [images + \"Error\"]: \"\",\r\n      });\r\n      return true;\r\n      // this.handleLiveTime()\r\n    },\r\n    getCoverImageUnid(){\r\n      return this.data.coverImage;\r\n    },\r\n    getImagesUnid(){\r\n      return this.data.images;\r\n    },\r\n    clearImagesData(){\r\n      this.setData({\r\n        imgList:[],\r\n        images:'',\r\n        coverImage:''\r\n      })\r\n    },\r\n    startUpload(){\r\n      let fileUpload = this.selectComponent('#my-file-uploader');\r\n      console.log('准备上传。。。');\r\n      fileUpload.startUpload();\r\n    }\r\n      // async deleteFile(param:any){\r\n      //   let [err,result] = await wx.$utils.to(\r\n      //     wx.$http.uploadFile({\r\n      //       url:param.url,\r\n      //       formData:param.formData,\r\n      //       filePath:param.file.url\r\n      //     })\r\n      //   )\r\n      //   return [err,result];\r\n      // }\r\n  }\r\n})\r\n"]}
|