Sanakey
2021-06-04 355a84d740a2a9dfa1d67cb2d2e11843d42809ac
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
"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"]}