Commit 2981c5e4 by 李嘉林

微信分享

parent b3200e6d
...@@ -28,6 +28,8 @@ ...@@ -28,6 +28,8 @@
v-if="list" v-if="list"
@changeStatus="changeStatus" @changeStatus="changeStatus"
></livedGoodsDia> ></livedGoodsDia>
<!-- 分享弹层 -->
<livedShareDia :showShareDia="showShareDia" @closeShareDia="closeShareDia" :info="info"></livedShareDia>
<!-- 底部控制层 --> <!-- 底部控制层 -->
<div class="control flex"> <div class="control flex">
<template v-if="!isSend"> <template v-if="!isSend">
...@@ -36,7 +38,7 @@ ...@@ -36,7 +38,7 @@
<p class="goodsNum" v-if="list.length>0">{{list.length}}</p> <p class="goodsNum" v-if="list.length>0">{{list.length}}</p>
</div> </div>
<div class="iptCopy" @click="isLogin">跟主播说点什么...</div> <div class="iptCopy" @click="isLogin">跟主播说点什么...</div>
<div class="shareIcon"> <div class="shareIcon" @click="showShare">
<img src="" alt=""> <img src="" alt="">
</div> </div>
<div class="heardIcon"> <div class="heardIcon">
...@@ -79,6 +81,7 @@ import livedAnnouncement from "@/components/livedModel/livedAnnouncement"; ...@@ -79,6 +81,7 @@ import livedAnnouncement from "@/components/livedModel/livedAnnouncement";
import livedIsMsg from "@/components/livedModel/livedIsMsg"; import livedIsMsg from "@/components/livedModel/livedIsMsg";
import livedExplainingCommodities from "@/components/livedModel/livedExplainingCommodities"; import livedExplainingCommodities from "@/components/livedModel/livedExplainingCommodities";
import livedGoodsDia from "@/components/livedModel/livedGoodsDia"; import livedGoodsDia from "@/components/livedModel/livedGoodsDia";
import livedShareDia from "@/components/livedModel/livedShareDia";
import live from "@/api/live"; import live from "@/api/live";
export default { export default {
props: [ props: [
...@@ -106,6 +109,7 @@ export default { ...@@ -106,6 +109,7 @@ export default {
num: 0, num: 0,
userComing: false, userComing: false,
showDia: false, //显示商品列表弹窗 showDia: false, //显示商品列表弹窗
showShareDia: false, //显示分享弹窗
isSend: false, //显示评论输入框 isSend: false, //显示评论输入框
sendVal: "", //输入内容 sendVal: "", //输入内容
getFocus: false, //获取焦点 getFocus: false, //获取焦点
...@@ -117,7 +121,8 @@ export default { ...@@ -117,7 +121,8 @@ export default {
livedAnnouncement, livedAnnouncement,
livedIsMsg, livedIsMsg,
livedExplainingCommodities, livedExplainingCommodities,
livedGoodsDia livedGoodsDia,
livedShareDia
}, },
computed: { computed: {
likeNumCopy() { likeNumCopy() {
...@@ -209,6 +214,12 @@ export default { ...@@ -209,6 +214,12 @@ export default {
changeStatus() { changeStatus() {
this.showDia = false; this.showDia = false;
}, },
showShare() {
this.showShareDia = true;
},
closeShareDia() {
this.showShareDia = false;
},
// 是否登录 // 是否登录
isLogin() { isLogin() {
let _this = this; let _this = this;
......
<template>
<div class="livedShareDia">
<van-popup
:show="showShareDia"
position="bottom"
:close-on-click-overlay="true"
@close="closeDia"
>
<div class="share flex">
<div class="wxShare">
<button data-name="shareBtn" open-type="share" plain="true">
<img
src=""
alt
/>
<p class="tit">微信分享</p>
</button>
</div>
<div class="createPoster">
<img
src=""
alt
/>
<p class="tit">生成海报</p>
</div>
</div>
<div class="cancel" @click="closeDia">取消</div>
</van-popup>
</div>
</template>
<script type="text/ecmascript-6">
import { DFSImg } from "@/utils/index";
export default {
props: ["showShareDia"],
name: "",
data() {
return {
liveId:"",
shopName: "",
shopLogo: "",
backPath: "",
};
},
components: {},
computed: {},
created() {},
onLoad(options) {
let params = JSON.parse(options.params);
this.liveId = params.liveId;
this.shopName = params.shopName;
this.backPath = params.fromPagePath || "/";
this.shopLogo = DFSImg(params.shopLogo, 40, 40);
this.init();
},
onUnload() {},
mounted() {},
methods: {
// 初始化信息
init() {},
initShare() {},
// 关闭
closeDia() {
this.$emit("closeShareDia");
}
}
};
</script>
<style lang="scss" scoped>
.flex {
display: flex;
}
img {
display: block;
}
.livedShareDia {
width: 100vw;
.share {
box-sizing: border-box;
width: 100%;
justify-content: space-around;
align-items: center;
padding: 20px;
& > div {
display: flex;
flex-direction: column;
align-items: center;
line-height: 30px;
img {
width: 60px;
height: 60px;
}
.tit {
font-size: 18px;
}
}
.wxShare {
button{
display: flex;
flex-direction: column;
align-items: center;
line-height: 30px;
}
button[plain] {
border: 0;
}
}
}
.cancel {
border-top: 10px solid #e5e4e9;
text-align: center;
height: 60px;
line-height: 60px;
font-size: 18px;
}
}
</style>
...@@ -73,11 +73,13 @@ ...@@ -73,11 +73,13 @@
</template> </template>
<script type="text/ecmascript-6"> <script type="text/ecmascript-6">
import { DFSImg } from "@/utils/index"; import { serialize, getQueryVariable, DFSImg } from "@/utils/index";
import live from "@/api/live"; import live from "@/api/live";
import notStarted from "@/components/livedModel/notStarted"; import notStarted from "@/components/livedModel/notStarted";
import livedControls from "@/components/livedModel/livedControls"; import livedControls from "@/components/livedModel/livedControls";
import livedIsEnded from "@/components/livedModel/livedIsEnded"; import livedIsEnded from "@/components/livedModel/livedIsEnded";
import spokesman from "@/api/spokesman";
import shop from "@/api/shop";
export default { export default {
name: "", name: "",
data() { data() {
...@@ -103,7 +105,11 @@ export default { ...@@ -103,7 +105,11 @@ export default {
infoTiming: null, //全局定时器 infoTiming: null, //全局定时器
goodTiming: null, //商品定时器 goodTiming: null, //商品定时器
endInfo: {}, //直播结束详情 endInfo: {}, //直播结束详情
firstComing: true // 首次进入 firstComing: true, // 首次进入
params: {},
userId: "",
hasInvitationStatus: 0, // 邀请资格:0-不能够邀请下级,1-能够邀请下级
spokesmanObj: {} //分销员信息
}; };
}, },
components: { components: {
...@@ -129,17 +135,61 @@ export default { ...@@ -129,17 +135,61 @@ export default {
} }
} }
}); });
let params = JSON.parse(options.params); this.params = JSON.parse(options.params);
this.$store.commit("setOfflineShopCode", params.offlineShopCode); console.log(this.params, "-----------------133");
this.liveId = params.liveId; this.$store.commit("setOfflineShopCode", this.params.offlineShopCode);
this.shopName = params.shopName; this.liveId = this.params.liveId;
this.backPath = params.fromPagePath || "/"; this.shopName = this.params.shopName;
this.shopLogo = DFSImg(params.shopLogo, 40, 40); this.backPath = this.params.fromPagePath || "/";
this.shopLogo = DFSImg(this.params.shopLogo, 40, 40);
// 是否有分销员信息
if(params.spokesmanGroupId){
this.$store.commit("setSpokesman", {
spokesmanGroupId: params.spokesmanGroupId,
spokesmanShopId: params.spokesmanShopId,
spokesmanRelId: params.spokesmanRelId
})
}
this.init(); this.init();
this.infoTiming = setInterval(() => { this.infoTiming = setInterval(() => {
this.timingGetInfo(); this.timingGetInfo();
}, 5000); }, 5000);
this.userEntry("IN"); this.userEntry("IN");
// 通过分享进入直播间重新查询订阅消息配置
this.getMsgConfig();
this.isLogin();
},
onShareAppMessage(options) {
let _this = this;
if(this.hasInvitationStatus==1){
Object.assign(this.params,this.params,this.spokesmanObj);
}
console.log(this.params,'--------------161')
let shareObj = {
title: this.liveNoticeInfo.title,
path: `/pages/lived/main?params=${JSON.stringify(this.params)}`,
imageUrl: this.liveNoticeInfo.coverUrl,
success: function(res) {
console.log("-----------success");
// 转发成功之后的回调
if (res.errMsg == "shareAppMessage:ok") {
console.log(res, "分享成功");
}
},
fail: function(res) {
console.log("-----------fail");
// 转发失败之后的回调
if (res.errMsg == "shareAppMessage:fail cancel") {
console.log(res, "取消转发");
} else if (res.errMsg == "shareAppMessage:fail") {
console.log(res, "转发失败");
}
}
};
console.log(shareObj, "----------------168");
return shareObj;
}, },
onUnload() { onUnload() {
this.liveNoticeInfo.liveBroadcastState = -1; this.liveNoticeInfo.liveBroadcastState = -1;
...@@ -194,6 +244,66 @@ export default { ...@@ -194,6 +244,66 @@ export default {
url: `../index/main?from=livedBackShop&backpath=${this.backPath}` url: `../index/main?from=livedBackShop&backpath=${this.backPath}`
}); });
}, },
// 是否登录
isLogin() {
let _this = this;
wx.getStorage({
key: "sessionid",
success(res) {
// 查询分销员信息
_this.getSpokesman();
},
fail(res) {
console.log("未登录------150");
// 跳转登录页
let backUrl = "/lived/main";
let query = {
liveId: _this.liveId,
fromType: "mini"
};
let url = `/pages/login/main?back=${backUrl}&params=${JSON.stringify(
query
)}`;
wx.navigateTo({
url: url
});
}
});
},
getMsgConfig() {
if (!this.$store.state.subscribeMessageObj) {
shop.getWxMiniSubscribeMessageConfig().then(res => {
if (res.data.code == 200) {
const data = res.data.data;
console.log("wx mini subscribe message data: ", data);
if (data != null) {
const subscribeMessageObj = {};
for (var key in data) {
if (data[key] && data[key].template_id) {
subscribeMessageObj[key] = data[key].template_id;
}
}
this.$store.commit("setSubscribeMessageObj", subscribeMessageObj);
}
}
});
}
},
getSpokesman() {
spokesman.getSpokesmanidByShare().then(res => {
if (res.data.code == 200) {
if (res.data.data.hasInvitationStatus == 1) {
this.hasInvitationStatus = 1;
this.spokesmanObj = {
spokesmanGroupId: res.data.data.groupId,
spokesmanShopId: res.data.data.shopId,
spokesmanRelId: res.data.data.spokesmanId
};
}
}
});
},
toShop() { toShop() {
// 到商城首页 // 到商城首页
this.backPath = "/"; this.backPath = "/";
......
{ {
"navigationStyle":"custom", "navigationStyle":"custom",
"navigationBarTextStyle": "white", "navigationBarTextStyle": "white",
"disableScroll": true,
"usingComponents": { "usingComponents": {
"van-button": "/static/vant/button/index", "van-button": "/static/vant/button/index",
"van-icon": "/static/vant/icon/index", "van-icon": "/static/vant/icon/index",
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment