提交 | 用户 | age
|
f9ad6c
|
1 |
"use strict";
|
S |
2 |
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3 |
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4 |
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5 |
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6 |
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
|
7 |
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8 |
});
|
|
9 |
};
|
|
10 |
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
11 |
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
12 |
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
13 |
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
14 |
function step(op) {
|
|
15 |
if (f) throw new TypeError("Generator is already executing.");
|
|
16 |
while (_) try {
|
|
17 |
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;
|
|
18 |
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
19 |
switch (op[0]) {
|
|
20 |
case 0: case 1: t = op; break;
|
|
21 |
case 4: _.label++; return { value: op[1], done: false };
|
|
22 |
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
23 |
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
24 |
default:
|
|
25 |
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
26 |
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
27 |
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
28 |
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
29 |
if (t[2]) _.ops.pop();
|
|
30 |
_.trys.pop(); continue;
|
|
31 |
}
|
|
32 |
op = body.call(thisArg, _);
|
|
33 |
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
34 |
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
35 |
}
|
|
36 |
};
|
|
37 |
Component({
|
|
38 |
options: {
|
|
39 |
addGlobalClass: true,
|
|
40 |
multipleSlots: true
|
|
41 |
},
|
|
42 |
properties: {
|
8724a4
|
43 |
liveRoom: {
|
S |
44 |
type: Object,
|
|
45 |
value: {},
|
|
46 |
observer: function (newVal) {
|
|
47 |
console.log('监听liveRoom的newVal', newVal);
|
|
48 |
if (JSON.stringify(newVal) != '{}') {
|
|
49 |
this.setData({
|
|
50 |
isLive: true
|
|
51 |
});
|
|
52 |
}
|
|
53 |
}
|
|
54 |
},
|
f9ad6c
|
55 |
detail: {
|
S |
56 |
type: Object,
|
|
57 |
value: {},
|
|
58 |
observer: function (newVal) {
|
|
59 |
console.log('监听detail的newVal', newVal);
|
|
60 |
if (JSON.stringify(newVal) != '{}') {
|
|
61 |
this.getQrCode();
|
|
62 |
}
|
|
63 |
}
|
|
64 |
},
|
|
65 |
sellerList: {
|
|
66 |
type: Array,
|
|
67 |
value: []
|
|
68 |
},
|
|
69 |
},
|
|
70 |
data: {
|
|
71 |
imgDraw: {},
|
|
72 |
sharePath: '',
|
|
73 |
visible: false,
|
8724a4
|
74 |
qrCodeUrl: '',
|
S |
75 |
isLive: false
|
f9ad6c
|
76 |
},
|
S |
77 |
lifetimes: {
|
|
78 |
ready: function () {
|
|
79 |
return __awaiter(this, void 0, void 0, function () {
|
|
80 |
return __generator(this, function (_a) {
|
|
81 |
return [2];
|
|
82 |
});
|
|
83 |
});
|
|
84 |
}
|
|
85 |
},
|
|
86 |
pageLifetimes: {
|
|
87 |
show: function () {
|
|
88 |
},
|
|
89 |
hide: function () {
|
|
90 |
}
|
|
91 |
},
|
|
92 |
methods: {
|
8724a4
|
93 |
getLiveRoomQrCode: function () {
|
S |
94 |
return __awaiter(this, void 0, void 0, function () {
|
|
95 |
var roomid, _a, error, result;
|
|
96 |
return __generator(this, function (_b) {
|
|
97 |
switch (_b.label) {
|
|
98 |
case 0:
|
|
99 |
roomid = this.data.liveRoom.RoomId;
|
|
100 |
console.log(roomid);
|
|
101 |
return [4, wx.$utils.to(wx.$http.request({
|
|
102 |
url: "/shopping/live/getSharedCode.do",
|
|
103 |
data: {
|
|
104 |
roomid: roomid
|
|
105 |
}
|
|
106 |
}))];
|
|
107 |
case 1:
|
|
108 |
_a = _b.sent(), error = _a[0], result = _a[1];
|
|
109 |
if (error) {
|
|
110 |
console.log(error);
|
|
111 |
wx.showToast({
|
|
112 |
title: '获取二维码失败,请稍后再试',
|
|
113 |
icon: 'none',
|
|
114 |
});
|
|
115 |
return [2, false];
|
|
116 |
}
|
|
117 |
console.log(result);
|
|
118 |
this.setData({
|
|
119 |
qrCodeUrl: result.cdnUrl
|
|
120 |
});
|
|
121 |
return [2, true];
|
|
122 |
}
|
|
123 |
});
|
|
124 |
});
|
|
125 |
},
|
f9ad6c
|
126 |
getQrCode: function () {
|
S |
127 |
return __awaiter(this, void 0, void 0, function () {
|
|
128 |
var _a, error, result;
|
|
129 |
return __generator(this, function (_b) {
|
|
130 |
switch (_b.label) {
|
|
131 |
case 0: return [4, wx.$utils.to(wx.$http.request({
|
|
132 |
url: "/shopping/poster/getQrCodeForPoster.do",
|
|
133 |
data: {
|
|
134 |
QrCodeType: 80,
|
|
135 |
doccode: this.data.detail.doccode,
|
|
136 |
RefOpenId: wx.globalData.FromOpenId
|
|
137 |
}
|
|
138 |
}))];
|
|
139 |
case 1:
|
|
140 |
_a = _b.sent(), error = _a[0], result = _a[1];
|
|
141 |
if (error) {
|
|
142 |
console.log(error);
|
|
143 |
return [2];
|
|
144 |
}
|
|
145 |
console.log(result);
|
|
146 |
this.setData({
|
|
147 |
qrCodeUrl: result.QrCode
|
|
148 |
});
|
|
149 |
return [2];
|
|
150 |
}
|
|
151 |
});
|
|
152 |
});
|
|
153 |
},
|
|
154 |
handleClose: function () {
|
|
155 |
this.setData({
|
|
156 |
visible: false
|
|
157 |
});
|
|
158 |
this.triggerEvent('close');
|
|
159 |
},
|
8724a4
|
160 |
clearPoster: function () {
|
f9ad6c
|
161 |
this.setData({
|
8724a4
|
162 |
sharePath: ''
|
f9ad6c
|
163 |
});
|
8724a4
|
164 |
},
|
S |
165 |
drawPic: function () {
|
|
166 |
return __awaiter(this, void 0, void 0, function () {
|
|
167 |
return __generator(this, function (_a) {
|
|
168 |
switch (_a.label) {
|
|
169 |
case 0:
|
|
170 |
if (this.data.sharePath) {
|
|
171 |
this.setData({
|
|
172 |
visible: true
|
|
173 |
});
|
|
174 |
this.triggerEvent('initData');
|
|
175 |
return [2];
|
|
176 |
}
|
|
177 |
if (!this.data.isLive) return [3, 2];
|
|
178 |
return [4, this.getLiveRoomQrCode()];
|
|
179 |
case 1:
|
|
180 |
if (!(_a.sent()))
|
|
181 |
return [2];
|
|
182 |
_a.label = 2;
|
|
183 |
case 2:
|
|
184 |
if (!this.data.qrCodeUrl) {
|
|
185 |
wx.showToast({
|
|
186 |
title: '获取二维码失败,请稍后再试',
|
|
187 |
icon: 'none',
|
|
188 |
});
|
|
189 |
return [2];
|
|
190 |
}
|
|
191 |
wx.showLoading({
|
|
192 |
title: '生成中'
|
|
193 |
});
|
|
194 |
this.setData({
|
|
195 |
imgDraw: this.getImgDraw()
|
|
196 |
});
|
|
197 |
return [2];
|
|
198 |
}
|
|
199 |
});
|
|
200 |
});
|
|
201 |
},
|
|
202 |
getImgDraw: function () {
|
|
203 |
var _a = this.data, detail = _a.detail, liveRoom = _a.liveRoom, sellerList = _a.sellerList, qrCodeUrl = _a.qrCodeUrl;
|
|
204 |
var isLive = this.data.isLive;
|
|
205 |
console.log(detail, liveRoom, sellerList, qrCodeUrl, isLive);
|
|
206 |
var imgDraw = {
|
|
207 |
width: '750rpx',
|
|
208 |
height: '1334rpx',
|
|
209 |
background: '#f5f5f5',
|
|
210 |
views: [
|
|
211 |
{
|
|
212 |
"type": "image",
|
|
213 |
"url": "/assets/images/poster-bg.png",
|
|
214 |
"css": {
|
|
215 |
"width": "750rpx",
|
|
216 |
"height": "1334rpx",
|
|
217 |
"top": "0px",
|
|
218 |
"left": "0px",
|
|
219 |
"rotate": "0",
|
|
220 |
}
|
|
221 |
},
|
|
222 |
{
|
|
223 |
type: 'image',
|
|
224 |
url: isLive ? liveRoom.ShareImgUnidUrl : detail.coverImageUrl[0],
|
|
225 |
css: {
|
|
226 |
top: '10rpx',
|
|
227 |
left: '10rpx',
|
|
228 |
right: '10rpx',
|
|
229 |
width: '730rpx',
|
|
230 |
height: '480rpx',
|
|
231 |
borderRadius: '16rpx'
|
|
232 |
},
|
|
233 |
},
|
|
234 |
{
|
|
235 |
type: 'image',
|
|
236 |
url: (isLive ? liveRoom.AnchorImgUnidUrl : sellerList[0].sellerHeadimgurl) || '/assets/images/default-avatar.png',
|
|
237 |
css: {
|
|
238 |
top: '444rpx',
|
|
239 |
left: '328rpx',
|
|
240 |
width: '96rpx',
|
|
241 |
height: '96rpx',
|
|
242 |
borderWidth: '6rpx',
|
|
243 |
borderColor: '#FFF',
|
|
244 |
borderRadius: '96rpx'
|
|
245 |
}
|
|
246 |
},
|
|
247 |
{
|
|
248 |
type: 'text',
|
|
249 |
text: (isLive ? liveRoom.AnchorName : sellerList[0].sellerName) || '昵称',
|
|
250 |
css: {
|
|
251 |
top: '572rpx',
|
|
252 |
fontSize: '28rpx',
|
|
253 |
left: '375rpx',
|
|
254 |
align: 'center',
|
|
255 |
color: '#3c3c3c'
|
|
256 |
}
|
|
257 |
},
|
|
258 |
{
|
|
259 |
type: 'text',
|
|
260 |
text: "\u9080\u8BF7\u60A8\u53C2\u4E0E" + (isLive ? '直播' : '活动'),
|
|
261 |
css: {
|
|
262 |
top: '616rpx',
|
|
263 |
left: '375rpx',
|
|
264 |
align: 'center',
|
|
265 |
fontSize: '28rpx',
|
|
266 |
color: '#3c3c3c'
|
|
267 |
}
|
|
268 |
},
|
|
269 |
{
|
|
270 |
type: 'text',
|
|
271 |
text: ((isLive ? liveRoom.RoomName : detail.title) || '活动标题') + " ",
|
|
272 |
css: {
|
|
273 |
top: '684rpx',
|
|
274 |
left: '375rpx',
|
|
275 |
maxLines: 1,
|
|
276 |
align: 'center',
|
|
277 |
fontWeight: 'bold',
|
|
278 |
fontSize: '44rpx',
|
|
279 |
color: '#3c3c3c'
|
|
280 |
}
|
|
281 |
},
|
|
282 |
{
|
|
283 |
type: 'text',
|
|
284 |
text: "" + ((isLive ? '' : '¥' + detail.salesPrice) || ''),
|
|
285 |
css: {
|
|
286 |
top: '765rpx',
|
|
287 |
left: '375rpx',
|
|
288 |
maxLines: 1,
|
|
289 |
align: 'center',
|
|
290 |
fontWeight: 'bold',
|
|
291 |
fontSize: '44rpx',
|
|
292 |
color: '#f23232'
|
|
293 |
}
|
|
294 |
},
|
|
295 |
{
|
|
296 |
type: 'image',
|
|
297 |
url: qrCodeUrl,
|
|
298 |
css: {
|
|
299 |
top: '970rpx',
|
|
300 |
left: '390rpx',
|
|
301 |
width: '300rpx',
|
|
302 |
height: '300rpx'
|
|
303 |
}
|
|
304 |
},
|
|
305 |
{
|
|
306 |
type: 'text',
|
|
307 |
text: "\u957F\u6309\u4E8C\u7EF4\u7801\u8BC6\u522B\u53C2\u4E0E",
|
|
308 |
css: {
|
|
309 |
top: '1100rpx',
|
|
310 |
left: '55rpx',
|
|
311 |
fontSize: '32rpx',
|
|
312 |
color: '#3c3c3c'
|
|
313 |
}
|
|
314 |
},
|
|
315 |
]
|
|
316 |
};
|
|
317 |
return imgDraw;
|
f9ad6c
|
318 |
},
|
S |
319 |
onImgErr: function () {
|
|
320 |
wx.hideLoading();
|
|
321 |
wx.showToast({
|
|
322 |
title: '生成分享图失败,请刷新页面重试'
|
|
323 |
});
|
|
324 |
},
|
|
325 |
onImgOK: function (e) {
|
|
326 |
wx.hideLoading();
|
|
327 |
this.setData({
|
|
328 |
sharePath: e.detail.path,
|
|
329 |
visible: true,
|
|
330 |
});
|
|
331 |
this.triggerEvent('initData');
|
|
332 |
},
|
|
333 |
preventDefault: function () { },
|
|
334 |
handleSavePhoto: function () {
|
|
335 |
var _this = this;
|
|
336 |
wx.showLoading({
|
|
337 |
title: '正在保存...',
|
|
338 |
mask: true
|
|
339 |
});
|
|
340 |
wx.saveImageToPhotosAlbum({
|
|
341 |
filePath: this.data.sharePath,
|
|
342 |
success: function () {
|
|
343 |
wx.showToast({
|
|
344 |
title: '保存成功'
|
|
345 |
});
|
|
346 |
setTimeout(function () {
|
|
347 |
_this.setData({
|
|
348 |
visible: false
|
|
349 |
});
|
|
350 |
_this.triggerEvent('close');
|
|
351 |
}, 300);
|
|
352 |
},
|
|
353 |
fail: function () {
|
|
354 |
wx.getSetting({
|
|
355 |
success: function (res) {
|
|
356 |
var authSetting = res.authSetting;
|
|
357 |
if (!authSetting['scope.writePhotosAlbum']) {
|
|
358 |
wx.showModal({
|
|
359 |
title: '提示',
|
|
360 |
content: '您未开启保存图片到相册的权限,请点击确定去开启权限!',
|
|
361 |
success: function (res) {
|
|
362 |
if (res.confirm) {
|
|
363 |
wx.openSetting();
|
|
364 |
}
|
|
365 |
}
|
|
366 |
});
|
|
367 |
}
|
|
368 |
}
|
|
369 |
});
|
|
370 |
setTimeout(function () {
|
|
371 |
wx.hideLoading();
|
|
372 |
_this.setData({
|
|
373 |
visible: false
|
|
374 |
});
|
|
375 |
_this.triggerEvent('close');
|
|
376 |
}, 300);
|
|
377 |
}
|
|
378 |
});
|
|
379 |
}
|
|
380 |
}
|
|
381 |
});
|
8724a4
|
382 |
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["Component({\r\n  options: {\r\n    addGlobalClass:true,\r\n    multipleSlots: true // 在组件定义时的选项中启用多slot支持\r\n  },\r\n  properties: {\r\n    //属性值可以在组件使用时指定\r\n    liveRoom: {\r\n      type: Object,\r\n      value: {},\r\n      observer(newVal) {\r\n        console.log('监听liveRoom的newVal',newVal);\r\n        if (JSON.stringify(newVal) != '{}'){\r\n          this.setData({\r\n            isLive:true\r\n          })\r\n        }\r\n      }\r\n    },\r\n    detail:{\r\n      type: Object,\r\n      value: {},\r\n      observer(newVal) {\r\n        console.log('监听detail的newVal',newVal);\r\n        if (JSON.stringify(newVal) != '{}'){\r\n          this.getQrCode()\r\n        }\r\n      }\r\n    },\r\n    sellerList:{\r\n      type: Array,\r\n      value: []\r\n    },\r\n\r\n    // visible: {\r\n    //   type: Boolean,\r\n    //   value: false,\r\n    // }\r\n  },\r\n  data: {\r\n    imgDraw: {}, //绘制图片的大对象\r\n    sharePath: '', //生成的分享图\r\n    visible: false,\r\n    qrCodeUrl:'',\r\n    isLive:false //是否直播\r\n  },\r\n  lifetimes:{\r\n    async ready(){\r\n\r\n    }\r\n  },\r\n  pageLifetimes: {\r\n    show: function() {\r\n      // 页面被展示\r\n\r\n    },\r\n    hide() {\r\n\r\n    }\r\n  },\r\n  methods: {\r\n    async getLiveRoomQrCode(){\r\n      let roomid = this.data.liveRoom.RoomId;\r\n      console.log(roomid);\r\n      let [error, result] = await wx.$utils.to(\r\n        wx.$http.request({\r\n          url:`/shopping/live/getSharedCode.do`,\r\n          data:{\r\n            roomid\r\n          }\r\n        })\r\n      )\r\n      if (error){\r\n        console.log(error);\r\n        wx.showToast({\r\n          title: '获取二维码失败，请稍后再试',\r\n          icon:'none',\r\n        })\r\n        return false;\r\n      }\r\n      console.log(result);\r\n      this.setData({\r\n        qrCodeUrl:result.cdnUrl\r\n      })\r\n      return true;\r\n    },\r\n    async getQrCode(){\r\n      let [error, result] = await wx.$utils.to(\r\n        wx.$http.request({\r\n          url:`/shopping/poster/getQrCodeForPoster.do`,\r\n          data:{\r\n            QrCodeType:80,\r\n            doccode:this.data.detail.doccode,\r\n            RefOpenId:wx.globalData.FromOpenId\r\n          }\r\n        })\r\n      )\r\n      if (error){\r\n        console.log(error);\r\n        return;\r\n      }\r\n      console.log(result);\r\n      this.setData({\r\n        qrCodeUrl:result.QrCode\r\n      })\r\n    },\r\n    handleClose() {\r\n      this.setData({\r\n        visible: false\r\n      })\r\n      this.triggerEvent('close')\r\n    },\r\n    clearPoster() {\r\n      this.setData({\r\n        sharePath:''\r\n      })\r\n    },\r\n    async drawPic() {\r\n      if (this.data.sharePath) { //如果已经绘制过了本地保存有图片不需要重新绘制\r\n        this.setData({\r\n          visible: true\r\n        })\r\n        this.triggerEvent('initData')\r\n        return\r\n      }\r\n      if (this.data.isLive){\r\n        if (!await this.getLiveRoomQrCode()) return;\r\n      }\r\n      if (!this.data.qrCodeUrl) {\r\n        wx.showToast({\r\n          title: '获取二维码失败，请稍后再试',\r\n          icon:'none',\r\n        })\r\n        return;\r\n      }\r\n      wx.showLoading({\r\n        title: '生成中'\r\n      })\r\n\r\n      this.setData({\r\n        imgDraw: this.getImgDraw()\r\n      })\r\n    },\r\n     getImgDraw() {\r\n      let {detail,liveRoom,sellerList,qrCodeUrl} = this.data;\r\n      let isLive = this.data.isLive;\r\n      console.log(detail,liveRoom,sellerList,qrCodeUrl,isLive);\r\n      let imgDraw = {\r\n        width: '750rpx',\r\n        height: '1334rpx',\r\n        background: '#f5f5f5',\r\n        views: [\r\n          {\r\n            \"type\": \"image\",\r\n            \"url\": \"/assets/images/poster-bg.png\",\r\n            \"css\": {\r\n              \"width\": \"750rpx\",\r\n              \"height\": \"1334rpx\",\r\n              \"top\": \"0px\",\r\n              \"left\": \"0px\",\r\n              \"rotate\": \"0\",\r\n            }\r\n          },\r\n          {\r\n            type: 'image',\r\n            url: isLive?liveRoom.ShareImgUnidUrl:detail.coverImageUrl[0],\r\n            css: {\r\n              top: '10rpx',\r\n              left: '10rpx',\r\n              right: '10rpx',\r\n              width: '730rpx',\r\n              height: '480rpx',\r\n              borderRadius: '16rpx'\r\n            },\r\n          },\r\n          {\r\n            type: 'image',\r\n            url: (isLive?liveRoom.AnchorImgUnidUrl:sellerList[0].sellerHeadimgurl) || '/assets/images/default-avatar.png',\r\n            css: {\r\n              top: '444rpx',\r\n              left: '328rpx',\r\n              width: '96rpx',\r\n              height: '96rpx',\r\n              borderWidth: '6rpx',\r\n              borderColor: '#FFF',\r\n              borderRadius: '96rpx'\r\n            }\r\n          },\r\n          {\r\n            type: 'text',\r\n            text: (isLive?liveRoom.AnchorName: sellerList[0].sellerName) || '昵称',\r\n            css: {\r\n              top: '572rpx',\r\n              fontSize: '28rpx',\r\n              left: '375rpx',\r\n              align: 'center',\r\n              color: '#3c3c3c'\r\n            }\r\n          },\r\n          {\r\n            type: 'text',\r\n            text: `邀请您参与${(isLive?'直播':'活动')}`,\r\n            css: {\r\n              top: '616rpx',\r\n              left: '375rpx',\r\n              align: 'center',\r\n              fontSize: '28rpx',\r\n              color: '#3c3c3c'\r\n            }\r\n          },\r\n          {\r\n            type: 'text',\r\n            text: `${(isLive?liveRoom.RoomName:detail.title) || '活动标题'} `,\r\n            css: {\r\n              top: '684rpx',\r\n              left: '375rpx',\r\n              maxLines: 1,\r\n              align: 'center',\r\n              fontWeight: 'bold',\r\n              fontSize: '44rpx',\r\n              color: '#3c3c3c'\r\n            }\r\n          },\r\n          // {\r\n          //   type: 'text',\r\n          //   text: `活动价 ￥`,\r\n          //   css: {\r\n          //     top: '780rpx',\r\n          //     left: '250rpx',\r\n          //     maxLines: 1,\r\n          //     align: 'center',\r\n          //     fontWeight: 'bold',\r\n          //     fontSize: '28rpx',\r\n          //     color: '#f23232'\r\n          //   }\r\n          // },\r\n          {\r\n            type: 'text',\r\n            text: `${(isLive?'':'￥'+detail.salesPrice) || ''}`,\r\n            css: {\r\n              top: '765rpx',\r\n              left: '375rpx',\r\n              maxLines: 1,\r\n              align: 'center',\r\n              fontWeight: 'bold',\r\n              fontSize: '44rpx',\r\n              color: '#f23232'\r\n            }\r\n          },\r\n          {\r\n            type: 'image',\r\n            url: qrCodeUrl,\r\n            css: {\r\n              top: '970rpx',\r\n              left: '390rpx',\r\n              width: '300rpx',\r\n              height: '300rpx'\r\n            }\r\n          },\r\n          {\r\n            type: 'text',\r\n            text: `长按二维码识别参与`,\r\n            css: {\r\n              top: '1100rpx',\r\n              left: '55rpx',\r\n              fontSize: '32rpx',\r\n              color: '#3c3c3c'\r\n            }\r\n          },\r\n        ]\r\n      };\r\n      return imgDraw;\r\n    },\r\n    onImgErr() {\r\n      wx.hideLoading()\r\n      wx.showToast({\r\n        title: '生成分享图失败，请刷新页面重试'\r\n      })\r\n    },\r\n    onImgOK(e) {\r\n      wx.hideLoading()\r\n      this.setData({\r\n        sharePath: e.detail.path,\r\n        visible: true,\r\n      })\r\n      //通知外部绘制完成，重置isCanDraw为false\r\n      this.triggerEvent('initData')\r\n    },\r\n    preventDefault() { },\r\n    // 保存图片\r\n    handleSavePhoto() {\r\n      wx.showLoading({\r\n        title: '正在保存...',\r\n        mask: true\r\n      })\r\n      wx.saveImageToPhotosAlbum({\r\n        filePath: this.data.sharePath,\r\n        success: () => {\r\n          wx.showToast({\r\n            title: '保存成功'\r\n          })\r\n          setTimeout(() => {\r\n            this.setData({\r\n              visible: false\r\n            })\r\n            this.triggerEvent('close')\r\n          }, 300)\r\n        },\r\n        fail: () => {\r\n          wx.getSetting({\r\n            success: res => {\r\n              let authSetting = res.authSetting\r\n              if (!authSetting['scope.writePhotosAlbum']) {\r\n                wx.showModal({\r\n                  title: '提示',\r\n                  content: '您未开启保存图片到相册的权限，请点击确定去开启权限！',\r\n                  success(res) {\r\n                    if (res.confirm) {\r\n                      wx.openSetting()\r\n                    }\r\n                  }\r\n                })\r\n              }\r\n            }\r\n          })\r\n          setTimeout(() => {\r\n            wx.hideLoading()\r\n            this.setData({\r\n              visible: false\r\n            })\r\n            this.triggerEvent('close')\r\n          }, 300)\r\n        }\r\n      })\r\n    }\r\n  }\r\n})\r\n"]} |