海报:完善拼团分享海报

pull/53/head
puhui999 2024-05-16 16:53:03 +08:00
parent 03512800b2
commit f46bfc6ee1
1 changed files with 100 additions and 91 deletions

View File

@ -1,114 +1,123 @@
import sheep from '@/sheep'; import sheep from '@/sheep';
import { formatImageUrlProtocol } from './index'; import { formatImageUrlProtocol } from './index';
import third from '@/sheep/api/migration/third';
const groupon = (poster) => { const groupon = async (poster) => {
const width = poster.width; const width = poster.width;
const userInfo = sheep.$store('user').userInfo; const userInfo = sheep.$store('user').userInfo;
const wxa_qrcode = (await third.wechat.getWxacode(poster.shareInfo.path, poster.shareInfo.query)).data;
return { return [
background: formatImageUrlProtocol(sheep.$url.cdn(sheep.$store('app').platform.share.posterInfo.groupon_bg)), {
list: [ type: 'image',
src: formatImageUrlProtocol(sheep.$url.cdn(sheep.$store('app').platform.share.posterInfo.groupon_bg)),
css: {
width,
position: 'fixed',
'object-fit': 'contain',
top: '0',
left: '0',
zIndex: -1,
},
},
{ {
name: 'nickname',
type: 'text', type: 'text',
val: userInfo.nickname, text: userInfo.nickname,
x: width * 0.22, css: {
y: width * 0.06, color: '#333',
paintbrushProps: {
fillStyle: '#333',
font: {
fontSize: 16, fontSize: 16,
fontFamily: 'sans-serif', fontFamily: 'sans-serif',
}, position: 'fixed',
top: width * 0.06,
left: width * 0.22,
}, },
}, },
{ {
name: 'avatar',
type: 'image', type: 'image',
val: formatImageUrlProtocol(sheep.$url.cdn(userInfo.avatar)), src: formatImageUrlProtocol(sheep.$url.cdn(userInfo.avatar)),
x: width * 0.04, css: {
y: width * 0.04, position: 'fixed',
left: width * 0.04,
top: width * 0.04,
width: width * 0.14, width: width * 0.14,
height: width * 0.14, height: width * 0.14,
d: width * 0.14, },
}, },
{ {
name: 'goodsImage',
type: 'image', type: 'image',
val: formatImageUrlProtocol(poster.shareInfo.poster.image), src: formatImageUrlProtocol(poster.shareInfo.poster.image),
x: width * 0.03, css: {
y: width * 0.21, position: 'fixed',
left: width * 0.03,
top: width * 0.21,
width: width * 0.94, width: width * 0.94,
height: width * 0.94, height: width * 0.94,
r: 10, borderRadius: 10,
},
}, },
{ {
name: 'goodsTitle',
type: 'text', type: 'text',
val: poster.shareInfo.poster.title, text: poster.shareInfo.poster.title,
x: width * 0.04, css: {
y: width * 1.18, color: '#333',
maxWidth: width * 0.91,
line: 2,
lineHeight: 5,
paintbrushProps: {
fillStyle: '#333',
font: {
fontSize: 14, fontSize: 14,
}, position: 'fixed',
top: width * 1.18,
left: width * 0.04,
maxWidth: width * 0.91,
lineHeight: 5,
}, },
}, },
{ {
name: 'goodsPrice',
type: 'text', type: 'text',
val: '¥' + poster.shareInfo.poster.price, text: '¥' + poster.shareInfo.poster.price,
x: width * 0.04, css: {
y: width * 1.3, color: '#ff0000',
paintbrushProps: {
fillStyle: '#ff0000',
font: {
fontSize: 20, fontSize: 20,
fontFamily: 'OPPOSANS', fontFamily: 'OPPOSANS',
}, position: 'fixed',
top: width * 1.3,
left: width * 0.04,
}, },
}, },
{ {
name: 'grouponNum',
type: 'text', type: 'text',
val: '2人团', text: '2人团',
x: width * 0.3, css: {
y: width * 1.32, color: '#ff0000',
paintbrushProps: { fontSize: 30,
fillStyle: '#ff0000',
font: {
fontSize: 10,
fontFamily: 'OPPOSANS', fontFamily: 'OPPOSANS',
}, position: 'fixed',
left: width * 0.3,
top: width * 1.32,
}, },
}, },
// #ifndef MP-WEIXIN // #ifndef MP-WEIXIN
{ {
name: 'qrcode',
type: 'qrcode', type: 'qrcode',
val: poster.shareInfo.link, text: poster.shareInfo.link,
x: width * 0.75, css: {
y: width * 1.3, position: 'fixed',
size: width * 0.2, left: width * 0.75,
top: width * 1.3,
width: width * 0.2,
height: width * 0.2,
},
}, },
// #endif // #endif
// #ifdef MP-WEIXIN // #ifdef MP-WEIXIN
{ {
name: 'wxacode',
type: 'image', type: 'image',
val: sheep.$api.third.wechat.getWxacode(poster.shareInfo.path), src: wxa_qrcode,
x: width * 0.75, css: {
y: width * 1.3, position: 'fixed',
left: width * 0.75,
top: width * 1.3,
width: width * 0.2, width: width * 0.2,
height: width * 0.2, height: width * 0.2,
}, },
},
// #endif // #endif
], ];
};
}; };
export default groupon; export default groupon;